]> git.proxmox.com Git - mirror_edk2.git/blame - .pytool/CISettings.py
UefiCpuPkg: Move AsmRelocateApLoopStart from Mpfuncs.nasm to AmdSev.nasm
[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
43c11115 56 "EmbeddedPkg",\r
0358c0bf 57 "EmulatorPkg",\r
28b16c01 58 "IntelFsp2Pkg",\r
9ecab62d 59 "IntelFsp2WrapperPkg",\r
0358c0bf 60 "MdePkg",\r
4eb2baba
SB
61 "MdeModulePkg",\r
62 "NetworkPkg",\r
63 "PcAtChipsetPkg",\r
64 "SecurityPkg",\r
65 "UefiCpuPkg",\r
66 "FmpDevicePkg",\r
67 "ShellPkg",\r
b3d379d1 68 "SignedCapsulePkg",\r
d8d1f666 69 "StandaloneMmPkg",\r
4eb2baba 70 "FatPkg",\r
61364ab9 71 "CryptoPkg",\r
f3c11224 72 "PrmPkg",\r
0358c0bf 73 "UnitTestFrameworkPkg",\r
c4add64f 74 "OvmfPkg",\r
e3ee8c8d 75 "RedfishPkg",\r
cf01fdd5 76 "SourceLevelDebugPkg",\r
e3ee8c8d 77 "UefiPayloadPkg"\r
4eb2baba
SB
78 )\r
79\r
80 def GetArchitecturesSupported(self):\r
81 ''' return iterable of edk2 architectures supported by this build '''\r
e6956d00
AC
82 return (\r
83 "IA32",\r
4eb2baba
SB
84 "X64",\r
85 "ARM",\r
e6956d00 86 "AARCH64",\r
b1b5177a
CL
87 "RISCV64",\r
88 "LOONGARCH64")\r
4eb2baba
SB
89\r
90 def GetTargetsSupported(self):\r
91 ''' return iterable of edk2 target tags supported by this build '''\r
92 return ("DEBUG", "RELEASE", "NO-TARGET", "NOOPT")\r
93\r
94 # ####################################################################################### #\r
95 # Verify and Save requested Ci Build Config #\r
96 # ####################################################################################### #\r
97\r
98 def SetPackages(self, list_of_requested_packages):\r
99 ''' Confirm the requested package list is valid and configure SettingsManager\r
100 to build the requested packages.\r
101\r
102 Raise UnsupportedException if a requested_package is not supported\r
103 '''\r
104 unsupported = set(list_of_requested_packages) - \\r
105 set(self.GetPackagesSupported())\r
106 if(len(unsupported) > 0):\r
107 logging.critical(\r
108 "Unsupported Package Requested: " + " ".join(unsupported))\r
109 raise Exception("Unsupported Package Requested: " +\r
110 " ".join(unsupported))\r
111 self.ActualPackages = list_of_requested_packages\r
112\r
113 def SetArchitectures(self, list_of_requested_architectures):\r
114 ''' Confirm the requests architecture list is valid and configure SettingsManager\r
115 to run only the requested architectures.\r
116\r
117 Raise Exception if a list_of_requested_architectures is not supported\r
118 '''\r
119 unsupported = set(list_of_requested_architectures) - \\r
120 set(self.GetArchitecturesSupported())\r
121 if(len(unsupported) > 0):\r
122 logging.critical(\r
123 "Unsupported Architecture Requested: " + " ".join(unsupported))\r
124 raise Exception(\r
125 "Unsupported Architecture Requested: " + " ".join(unsupported))\r
126 self.ActualArchitectures = list_of_requested_architectures\r
127\r
128 def SetTargets(self, list_of_requested_target):\r
129 ''' Confirm the request target list is valid and configure SettingsManager\r
130 to run only the requested targets.\r
131\r
132 Raise UnsupportedException if a requested_target is not supported\r
133 '''\r
134 unsupported = set(list_of_requested_target) - \\r
135 set(self.GetTargetsSupported())\r
136 if(len(unsupported) > 0):\r
137 logging.critical(\r
138 "Unsupported Targets Requested: " + " ".join(unsupported))\r
139 raise Exception("Unsupported Targets Requested: " +\r
140 " ".join(unsupported))\r
141 self.ActualTargets = list_of_requested_target\r
142\r
143 # ####################################################################################### #\r
144 # Actual Configuration for Ci Build #\r
145 # ####################################################################################### #\r
146\r
147 def GetActiveScopes(self):\r
148 ''' return tuple containing scopes that should be active for this process '''\r
1534b622
MC
149 if self.ActualScopes is None:\r
150 scopes = ("cibuild", "edk2-build", "host-based-test")\r
151\r
152 self.ActualToolChainTag = shell_environment.GetBuildVars().GetValue("TOOL_CHAIN_TAG", "")\r
153\r
154 is_linux = GetHostInfo().os.upper() == "LINUX"\r
155\r
156 if self.UseBuiltInBaseTools is None:\r
157 is_linux = GetHostInfo().os.upper() == "LINUX"\r
158 # try and import the pip module for basetools\r
159 try:\r
160 import edk2basetools\r
161 self.UseBuiltInBaseTools = True\r
162 except ImportError:\r
163 self.UseBuiltInBaseTools = False\r
164 pass\r
165\r
166 if self.UseBuiltInBaseTools == True:\r
167 scopes += ('pipbuild-unix',) if is_linux else ('pipbuild-win',)\r
168 logging.warning("Using Pip Tools based BaseTools")\r
169 else:\r
170 logging.warning("Falling back to using in-tree BaseTools")\r
171\r
1534b622
MC
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
80f09771
MK
186 rs.append(RequiredSubmodule(\r
187 "UnitTestFrameworkPkg/Library/GoogleTestLib/googletest", False))\r
48b6c60c
SZ
188 rs.append(RequiredSubmodule(\r
189 "MdeModulePkg/Universal/RegularExpressionDxe/oniguruma", False))\r
58802e02
SZ
190 rs.append(RequiredSubmodule(\r
191 "MdeModulePkg/Library/BrotliCustomDecompressLib/brotli", False))\r
06033f5a
SZ
192 rs.append(RequiredSubmodule(\r
193 "BaseTools/Source/C/BrotliCompress/brotli", False))\r
acabf1b0
AC
194 rs.append(RequiredSubmodule(\r
195 "RedfishPkg/Library/JsonLib/jansson", False))\r
4eb2baba
SB
196 return rs\r
197\r
198 def GetName(self):\r
199 return "Edk2"\r
200\r
201 def GetDependencies(self):\r
61364ab9
MK
202 return [\r
203 ]\r
4eb2baba
SB
204\r
205 def GetPackagesPath(self):\r
206 return ()\r
207\r
208 def GetWorkspaceRoot(self):\r
209 ''' get WorkspacePath '''\r
210 return os.path.dirname(os.path.dirname(os.path.abspath(__file__)))\r
211\r
212 def FilterPackagesToTest(self, changedFilesList: list, potentialPackagesList: list) -> list:\r
213 ''' Filter potential packages to test based on changed files. '''\r
61364ab9
MK
214 build_these_packages = []\r
215 possible_packages = potentialPackagesList.copy()\r
4eb2baba 216 for f in changedFilesList:\r
61364ab9
MK
217 # split each part of path for comparison later\r
218 nodes = f.split("/")\r
4eb2baba
SB
219\r
220 # python file change in .pytool folder causes building all\r
221 if f.endswith(".py") and ".pytool" in nodes:\r
222 build_these_packages = possible_packages\r
223 break\r
224\r
225 # BaseTools files that might change the build\r
226 if "BaseTools" in nodes:\r
227 if os.path.splitext(f) not in [".txt", ".md"]:\r
228 build_these_packages = possible_packages\r
229 break\r
230 return build_these_packages\r