Blame 0011-ArmVirtPkg-take-PcdResizeXterm-from-the-QEMU-command.patch

0a0d662
From 6c5f6dfcbac8a9eb6db10352d4d2f20166bab27c Mon Sep 17 00:00:00 2001
3485002
From: Laszlo Ersek <lersek@redhat.com>
3485002
Date: Sun, 26 Jul 2015 08:02:50 +0000
2941706
Subject: [PATCH] ArmVirtPkg: take PcdResizeXterm from the QEMU command line
2941706
 (RH only)
3485002
3485002
Notes about the 20160608b-988715a -> 20170228-c325e41585e3 rebase:
3485002
3485002
- Adapt commit 6b97969096a3 to the fact that upstream has deprecated such
3485002
  setter functions for dynamic PCDs that don't return a status code (such
3485002
  as PcdSetBool()). Employ PcdSetBoolS(), and assert that it succeeds --
3485002
  there's really no circumstance in this case when it could fail.
3485002
3485002
Notes about the 20170228-c325e41585e3 -> 20171011-92d07e48907f rebase:
3485002
3485002
- Refresh downstream-only commit d4564d39dfdb against context changes in
3485002
  "ArmVirtPkg/ArmVirtQemu.dsc" from upstream commit 7e5f1b673870
3485002
  ("ArmVirtPkg/PlatformHasAcpiDtDxe: allow guest level ACPI disable
3485002
  override", 2017-03-29).
3485002
3485002
Contributed-under: TianoCore Contribution Agreement 1.0
3485002
Signed-off-by: Laszlo Ersek <lersek@redhat.com>
3485002
(cherry picked from commit d4564d39dfdbf74e762af43314005a2c026cb262)
7ae6f15
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
3485002
---
7ae6f15
 ArmVirtPkg/ArmVirtQemu.dsc                    |  7 +-
7ae6f15
 .../TerminalPcdProducerLib.c                  | 87 +++++++++++++++++++
7ae6f15
 .../TerminalPcdProducerLib.inf                | 41 +++++++++
3485002
 3 files changed, 134 insertions(+), 1 deletion(-)
3485002
 create mode 100644 ArmVirtPkg/Library/TerminalPcdProducerLib/TerminalPcdProducerLib.c
3485002
 create mode 100644 ArmVirtPkg/Library/TerminalPcdProducerLib/TerminalPcdProducerLib.inf
3485002
3485002
diff --git a/ArmVirtPkg/ArmVirtQemu.dsc b/ArmVirtPkg/ArmVirtQemu.dsc
0a0d662
index 00412a3afb..311ceb865a 100644
3485002
--- a/ArmVirtPkg/ArmVirtQemu.dsc
3485002
+++ b/ArmVirtPkg/ArmVirtQemu.dsc
0a0d662
@@ -237,6 +237,8 @@
3485002
   gEfiMdeModulePkgTokenSpaceGuid.PcdSmbiosDocRev|0x0
3485002
   gUefiOvmfPkgTokenSpaceGuid.PcdQemuSmbiosValidated|FALSE
3485002
 
3485002
+  gEfiMdeModulePkgTokenSpaceGuid.PcdResizeXterm|FALSE
3485002
+
3485002
 [PcdsDynamicHii]
3485002
   gArmVirtTokenSpaceGuid.PcdForceNoAcpi|L"ForceNoAcpi"|gArmVirtVariableGuid|0x0|FALSE|NV,BS
3485002
 
0a0d662
@@ -314,7 +316,10 @@
3485002
   MdeModulePkg/Universal/Console/ConPlatformDxe/ConPlatformDxe.inf
3485002
   MdeModulePkg/Universal/Console/ConSplitterDxe/ConSplitterDxe.inf
3485002
   MdeModulePkg/Universal/Console/GraphicsConsoleDxe/GraphicsConsoleDxe.inf
3485002
-  MdeModulePkg/Universal/Console/TerminalDxe/TerminalDxe.inf
3485002
+  MdeModulePkg/Universal/Console/TerminalDxe/TerminalDxe.inf {
3485002
+    <LibraryClasses>
3485002
+      NULL|ArmVirtPkg/Library/TerminalPcdProducerLib/TerminalPcdProducerLib.inf
3485002
+  }
3485002
   MdeModulePkg/Universal/SerialDxe/SerialDxe.inf
3485002
 
3485002
   MdeModulePkg/Universal/HiiDatabaseDxe/HiiDatabaseDxe.inf
3485002
diff --git a/ArmVirtPkg/Library/TerminalPcdProducerLib/TerminalPcdProducerLib.c b/ArmVirtPkg/Library/TerminalPcdProducerLib/TerminalPcdProducerLib.c
3485002
new file mode 100644
9fc821a
index 0000000000..814ad48199
3485002
--- /dev/null
3485002
+++ b/ArmVirtPkg/Library/TerminalPcdProducerLib/TerminalPcdProducerLib.c
3485002
@@ -0,0 +1,87 @@
3485002
+/** @file
3485002
+*  Plugin library for setting up dynamic PCDs for TerminalDxe, from fw_cfg
3485002
+*
3485002
+*  Copyright (C) 2015-2016, Red Hat, Inc.
3485002
+*  Copyright (c) 2014, Linaro Ltd. All rights reserved.
3485002
+*
3485002
+*  This program and the accompanying materials are licensed and made available
3485002
+*  under the terms and conditions of the BSD License which accompanies this
3485002
+*  distribution.  The full text of the license may be found at
3485002
+*  http://opensource.org/licenses/bsd-license.php
3485002
+*
3485002
+*  THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
3485002
+*  WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR
3485002
+*  IMPLIED.
3485002
+*
3485002
+**/
3485002
+
3485002
+#include <Library/DebugLib.h>
3485002
+#include <Library/PcdLib.h>
3485002
+#include <Library/QemuFwCfgLib.h>
3485002
+
3485002
+STATIC
3485002
+RETURN_STATUS
3485002
+GetNamedFwCfgBoolean (
3485002
+  IN  CONST CHAR8 *FwCfgFileName,
3485002
+  OUT BOOLEAN     *Setting
3485002
+  )
3485002
+{
3485002
+  RETURN_STATUS        Status;
3485002
+  FIRMWARE_CONFIG_ITEM FwCfgItem;
3485002
+  UINTN                FwCfgSize;
3485002
+  UINT8                Value[3];
3485002
+
3485002
+  Status = QemuFwCfgFindFile (FwCfgFileName, &FwCfgItem, &FwCfgSize);
3485002
+  if (RETURN_ERROR (Status)) {
3485002
+    return Status;
3485002
+  }
3485002
+  if (FwCfgSize > sizeof Value) {
3485002
+    return RETURN_BAD_BUFFER_SIZE;
3485002
+  }
3485002
+  QemuFwCfgSelectItem (FwCfgItem);
3485002
+  QemuFwCfgReadBytes (FwCfgSize, Value);
3485002
+
3485002
+  if ((FwCfgSize == 1) ||
3485002
+      (FwCfgSize == 2 && Value[1] == '\n') ||
3485002
+      (FwCfgSize == 3 && Value[1] == '\r' && Value[2] == '\n')) {
3485002
+    switch (Value[0]) {
3485002
+      case '0':
3485002
+      case 'n':
3485002
+      case 'N':
3485002
+        *Setting = FALSE;
3485002
+        return RETURN_SUCCESS;
3485002
+
3485002
+      case '1':
3485002
+      case 'y':
3485002
+      case 'Y':
3485002
+        *Setting = TRUE;
3485002
+        return RETURN_SUCCESS;
3485002
+
3485002
+      default:
3485002
+        break;
3485002
+    }
3485002
+  }
3485002
+  return RETURN_PROTOCOL_ERROR;
3485002
+}
3485002
+
3485002
+#define UPDATE_BOOLEAN_PCD_FROM_FW_CFG(TokenName)                             \
3485002
+          do {                                                                \
3485002
+            BOOLEAN       Setting;                                            \
3485002
+            RETURN_STATUS PcdStatus;                                          \
3485002
+                                                                              \
3485002
+            if (!RETURN_ERROR (GetNamedFwCfgBoolean (                         \
3485002
+                    "opt/org.tianocore.edk2.aavmf/" #TokenName, &Setting))) { \
3485002
+              PcdStatus = PcdSetBoolS (TokenName, Setting);                   \
3485002
+              ASSERT_RETURN_ERROR (PcdStatus);                                \
3485002
+            }                                                                 \
3485002
+          } while (0)
3485002
+
3485002
+RETURN_STATUS
3485002
+EFIAPI
3485002
+TerminalPcdProducerLibConstructor (
3485002
+  VOID
3485002
+  )
3485002
+{
3485002
+  UPDATE_BOOLEAN_PCD_FROM_FW_CFG (PcdResizeXterm);
3485002
+  return RETURN_SUCCESS;
3485002
+}
3485002
diff --git a/ArmVirtPkg/Library/TerminalPcdProducerLib/TerminalPcdProducerLib.inf b/ArmVirtPkg/Library/TerminalPcdProducerLib/TerminalPcdProducerLib.inf
3485002
new file mode 100644
9fc821a
index 0000000000..fecb37bcdf
3485002
--- /dev/null
3485002
+++ b/ArmVirtPkg/Library/TerminalPcdProducerLib/TerminalPcdProducerLib.inf
3485002
@@ -0,0 +1,41 @@
3485002
+## @file
3485002
+#  Plugin library for setting up dynamic PCDs for TerminalDxe, from fw_cfg
3485002
+#
3485002
+#  Copyright (C) 2015-2016, Red Hat, Inc.
3485002
+#  Copyright (c) 2014, Linaro Ltd. All rights reserved.
3485002
+#
3485002
+#  This program and the accompanying materials are licensed and made available
3485002
+#  under the terms and conditions of the BSD License which accompanies this
3485002
+#  distribution.  The full text of the license may be found at
3485002
+#  http://opensource.org/licenses/bsd-license.php
3485002
+#
3485002
+#  THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
3485002
+#  WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR
3485002
+#  IMPLIED.
3485002
+#
3485002
+##
3485002
+
3485002
+[Defines]
3485002
+  INF_VERSION                    = 0x00010005
3485002
+  BASE_NAME                      = TerminalPcdProducerLib
3485002
+  FILE_GUID                      = 4a0c5ed7-8c42-4c01-8f4c-7bf258316a96
3485002
+  MODULE_TYPE                    = BASE
3485002
+  VERSION_STRING                 = 1.0
3485002
+  LIBRARY_CLASS                  = TerminalPcdProducerLib|DXE_DRIVER
3485002
+  CONSTRUCTOR                    = TerminalPcdProducerLibConstructor
3485002
+
3485002
+[Sources]
3485002
+  TerminalPcdProducerLib.c
3485002
+
3485002
+[Packages]
3485002
+  MdePkg/MdePkg.dec
3485002
+  OvmfPkg/OvmfPkg.dec
3485002
+  MdeModulePkg/MdeModulePkg.dec
3485002
+
3485002
+[LibraryClasses]
3485002
+  DebugLib
3485002
+  PcdLib
3485002
+  QemuFwCfgLib
3485002
+
3485002
+[Pcd]
3485002
+  gEfiMdeModulePkgTokenSpaceGuid.PcdResizeXterm