]> git.proxmox.com Git - mirror_edk2.git/blame - .pytool/CISettings.py
OvmfPkg/PlatformPei: set PcdConfidentialComputingAttr when SEV is active
[mirror_edk2.git] / .pytool / CISettings.py
CommitLineData
4eb2baba
SB
1# @file\r
2#\r
3# Copyright (c) Microsoft Corporation.\r
e6956d00 4# Copyright (c) 2020, Hewlett Packard Enterprise Development LP. All rights reserved.<BR>\r
d8d1f666 5# Copyright (c) 2020 - 2021, ARM Limited. All rights reserved.<BR>\r
4eb2baba
SB
6# SPDX-License-Identifier: BSD-2-Clause-Patent\r
7##\r
8import os\r
9import logging\r
10from edk2toolext.environment import shell_environment\r
11from edk2toolext.invocables.edk2_ci_build import CiBuildSettingsManager\r
12from edk2toolext.invocables.edk2_setup import SetupSettingsManager, RequiredSubmodule\r
13from edk2toolext.invocables.edk2_update import UpdateSettingsManager\r
14from edk2toolext.invocables.edk2_pr_eval import PrEvalSettingsManager\r
15from edk2toollib.utility_functions import GetHostInfo\r
16\r
17\r
18class Settings(CiBuildSettingsManager, UpdateSettingsManager, SetupSettingsManager, PrEvalSettingsManager):\r
19\r
20 def __init__(self):\r
21 self.ActualPackages = []\r
22 self.ActualTargets = []\r
23 self.ActualArchitectures = []\r
24 self.ActualToolChainTag = ""\r
1534b622
MC
25 self.UseBuiltInBaseTools = None\r
26 self.ActualScopes = None\r
4eb2baba
SB
27\r
28 # ####################################################################################### #\r
29 # Extra CmdLine configuration #\r
30 # ####################################################################################### #\r
31\r
32 def AddCommandLineOptions(self, parserObj):\r
1534b622
MC
33 group = parserObj.add_mutually_exclusive_group()\r
34 group.add_argument("-force_piptools", "--fpt", dest="force_piptools", action="store_true", default=False, help="Force the system to use pip tools")\r
35 group.add_argument("-no_piptools", "--npt", dest="no_piptools", action="store_true", default=False, help="Force the system to not use pip tools")\r
4eb2baba
SB
36\r
37 def RetrieveCommandLineOptions(self, args):\r
1534b622
MC
38 super().RetrieveCommandLineOptions(args)\r
39 if args.force_piptools:\r
40 self.UseBuiltInBaseTools = True\r
41 if args.no_piptools:\r
42 self.UseBuiltInBaseTools = False\r
4eb2baba
SB
43\r
44 # ####################################################################################### #\r
45 # Default Support for this Ci Build #\r
46 # ####################################################################################### #\r
47\r
48 def GetPackagesSupported(self):\r
49 ''' return iterable of edk2 packages supported by this build.\r
50 These should be edk2 workspace relative paths '''\r
51\r
2942cb58 52 return ("ArmPkg",\r
a4cf1959 53 "ArmPlatformPkg",\r
2942cb58 54 "ArmVirtPkg",\r
82c65f14 55 "DynamicTablesPkg",\r
0358c0bf
SB
56 "EmulatorPkg",\r
57 "MdePkg",\r
4eb2baba
SB
58 "MdeModulePkg",\r
59 "NetworkPkg",\r
60 "PcAtChipsetPkg",\r
61 "SecurityPkg",\r
62 "UefiCpuPkg",\r
63 "FmpDevicePkg",\r
64 "ShellPkg",\r
d8d1f666 65 "StandaloneMmPkg",\r
4eb2baba 66 "FatPkg",\r
61364ab9 67 "CryptoPkg",\r
0358c0bf 68 "UnitTestFrameworkPkg",\r
c4add64f 69 "OvmfPkg",\r
e3ee8c8d 70 "RedfishPkg",\r
71 "UefiPayloadPkg"\r
4eb2baba
SB
72 )\r
73\r
74 def GetArchitecturesSupported(self):\r
75 ''' return iterable of edk2 architectures supported by this build '''\r
e6956d00
AC
76 return (\r
77 "IA32",\r
4eb2baba
SB
78 "X64",\r
79 "ARM",\r
e6956d00
AC
80 "AARCH64",\r
81 "RISCV64")\r
4eb2baba
SB
82\r
83 def GetTargetsSupported(self):\r
84 ''' return iterable of edk2 target tags supported by this build '''\r
85 return ("DEBUG", "RELEASE", "NO-TARGET", "NOOPT")\r
86\r
87 # ####################################################################################### #\r
88 # Verify and Save requested Ci Build Config #\r
89 # ####################################################################################### #\r
90\r
91 def SetPackages(self, list_of_requested_packages):\r
92 ''' Confirm the requested package list is valid and configure SettingsManager\r
93 to build the requested packages.\r
94\r
95 Raise UnsupportedException if a requested_package is not supported\r
96 '''\r
97 unsupported = set(list_of_requested_packages) - \\r
98 set(self.GetPackagesSupported())\r
99 if(len(unsupported) > 0):\r
100 logging.critical(\r
101 "Unsupported Package Requested: " + " ".join(unsupported))\r
102 raise Exception("Unsupported Package Requested: " +\r
103 " ".join(unsupported))\r
104 self.ActualPackages = list_of_requested_packages\r
105\r
106 def SetArchitectures(self, list_of_requested_architectures):\r
107 ''' Confirm the requests architecture list is valid and configure SettingsManager\r
108 to run only the requested architectures.\r
109\r
110 Raise Exception if a list_of_requested_architectures is not supported\r
111 '''\r
112 unsupported = set(list_of_requested_architectures) - \\r
113 set(self.GetArchitecturesSupported())\r
114 if(len(unsupported) > 0):\r
115 logging.critical(\r
116 "Unsupported Architecture Requested: " + " ".join(unsupported))\r
117 raise Exception(\r
118 "Unsupported Architecture Requested: " + " ".join(unsupported))\r
119 self.ActualArchitectures = list_of_requested_architectures\r
120\r
121 def SetTargets(self, list_of_requested_target):\r
122 ''' Confirm the request target list is valid and configure SettingsManager\r
123 to run only the requested targets.\r
124\r
125 Raise UnsupportedException if a requested_target is not supported\r
126 '''\r
127 unsupported = set(list_of_requested_target) - \\r
128 set(self.GetTargetsSupported())\r
129 if(len(unsupported) > 0):\r
130 logging.critical(\r
131 "Unsupported Targets Requested: " + " ".join(unsupported))\r
132 raise Exception("Unsupported Targets Requested: " +\r
133 " ".join(unsupported))\r
134 self.ActualTargets = list_of_requested_target\r
135\r
136 # ####################################################################################### #\r
137 # Actual Configuration for Ci Build #\r
138 # ####################################################################################### #\r
139\r
140 def GetActiveScopes(self):\r
141 ''' return tuple containing scopes that should be active for this process '''\r
1534b622
MC
142 if self.ActualScopes is None:\r
143 scopes = ("cibuild", "edk2-build", "host-based-test")\r
144\r
145 self.ActualToolChainTag = shell_environment.GetBuildVars().GetValue("TOOL_CHAIN_TAG", "")\r
146\r
147 is_linux = GetHostInfo().os.upper() == "LINUX"\r
148\r
149 if self.UseBuiltInBaseTools is None:\r
150 is_linux = GetHostInfo().os.upper() == "LINUX"\r
151 # try and import the pip module for basetools\r
152 try:\r
153 import edk2basetools\r
154 self.UseBuiltInBaseTools = True\r
155 except ImportError:\r
156 self.UseBuiltInBaseTools = False\r
157 pass\r
158\r
159 if self.UseBuiltInBaseTools == True:\r
160 scopes += ('pipbuild-unix',) if is_linux else ('pipbuild-win',)\r
161 logging.warning("Using Pip Tools based BaseTools")\r
162 else:\r
163 logging.warning("Falling back to using in-tree BaseTools")\r
164\r
165 if is_linux and self.ActualToolChainTag.upper().startswith("GCC"):\r
166 if "AARCH64" in self.ActualArchitectures:\r
167 scopes += ("gcc_aarch64_linux",)\r
168 if "ARM" in self.ActualArchitectures:\r
169 scopes += ("gcc_arm_linux",)\r
170 if "RISCV64" in self.ActualArchitectures:\r
171 scopes += ("gcc_riscv64_unknown",)\r
172 self.ActualScopes = scopes\r
173 return self.ActualScopes\r
4eb2baba
SB
174\r
175 def GetRequiredSubmodules(self):\r
176 ''' return iterable containing RequiredSubmodule objects.\r
177 If no RequiredSubmodules return an empty iterable\r
178 '''\r
61364ab9 179 rs = []\r
4eb2baba
SB
180 rs.append(RequiredSubmodule(\r
181 "ArmPkg/Library/ArmSoftFloatLib/berkeley-softfloat-3", False))\r
182 rs.append(RequiredSubmodule(\r
183 "CryptoPkg/Library/OpensslLib/openssl", False))\r
61364ab9
MK
184 rs.append(RequiredSubmodule(\r
185 "UnitTestFrameworkPkg/Library/CmockaLib/cmocka", False))\r
48b6c60c
SZ
186 rs.append(RequiredSubmodule(\r
187 "MdeModulePkg/Universal/RegularExpressionDxe/oniguruma", False))\r
58802e02
SZ
188 rs.append(RequiredSubmodule(\r
189 "MdeModulePkg/Library/BrotliCustomDecompressLib/brotli", False))\r
06033f5a
SZ
190 rs.append(RequiredSubmodule(\r
191 "BaseTools/Source/C/BrotliCompress/brotli", False))\r
acabf1b0
AC
192 rs.append(RequiredSubmodule(\r
193 "RedfishPkg/Library/JsonLib/jansson", False))\r
4eb2baba
SB
194 return rs\r
195\r
196 def GetName(self):\r
197 return "Edk2"\r
198\r
199 def GetDependencies(self):\r
61364ab9
MK
200 return [\r
201 ]\r
4eb2baba
SB
202\r
203 def GetPackagesPath(self):\r
204 return ()\r
205\r
206 def GetWorkspaceRoot(self):\r
207 ''' get WorkspacePath '''\r
208 return os.path.dirname(os.path.dirname(os.path.abspath(__file__)))\r
209\r
210 def FilterPackagesToTest(self, changedFilesList: list, potentialPackagesList: list) -> list:\r
211 ''' Filter potential packages to test based on changed files. '''\r
61364ab9
MK
212 build_these_packages = []\r
213 possible_packages = potentialPackagesList.copy()\r
4eb2baba 214 for f in changedFilesList:\r
61364ab9
MK
215 # split each part of path for comparison later\r
216 nodes = f.split("/")\r
4eb2baba
SB
217\r
218 # python file change in .pytool folder causes building all\r
219 if f.endswith(".py") and ".pytool" in nodes:\r
220 build_these_packages = possible_packages\r
221 break\r
222\r
223 # BaseTools files that might change the build\r
224 if "BaseTools" in nodes:\r
225 if os.path.splitext(f) not in [".txt", ".md"]:\r
226 build_these_packages = possible_packages\r
227 break\r
228 return build_these_packages\r