]> git.proxmox.com Git - mirror_edk2.git/blame - .pytool/CISettings.py
DynamicTablesPkg: AcpiSratLibArm fix ECC error
[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
82c65f14 5# Copyright (c) 2020, 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
25\r
26 # ####################################################################################### #\r
27 # Extra CmdLine configuration #\r
28 # ####################################################################################### #\r
29\r
30 def AddCommandLineOptions(self, parserObj):\r
31 pass\r
32\r
33 def RetrieveCommandLineOptions(self, args):\r
34 pass\r
35\r
36 # ####################################################################################### #\r
37 # Default Support for this Ci Build #\r
38 # ####################################################################################### #\r
39\r
40 def GetPackagesSupported(self):\r
41 ''' return iterable of edk2 packages supported by this build.\r
42 These should be edk2 workspace relative paths '''\r
43\r
0358c0bf 44 return ("ArmVirtPkg",\r
82c65f14 45 "DynamicTablesPkg",\r
0358c0bf
SB
46 "EmulatorPkg",\r
47 "MdePkg",\r
4eb2baba
SB
48 "MdeModulePkg",\r
49 "NetworkPkg",\r
50 "PcAtChipsetPkg",\r
51 "SecurityPkg",\r
52 "UefiCpuPkg",\r
53 "FmpDevicePkg",\r
54 "ShellPkg",\r
55 "FatPkg",\r
61364ab9 56 "CryptoPkg",\r
0358c0bf 57 "UnitTestFrameworkPkg",\r
c4add64f
AC
58 "OvmfPkg",\r
59 "RedfishPkg"\r
4eb2baba
SB
60 )\r
61\r
62 def GetArchitecturesSupported(self):\r
63 ''' return iterable of edk2 architectures supported by this build '''\r
e6956d00
AC
64 return (\r
65 "IA32",\r
4eb2baba
SB
66 "X64",\r
67 "ARM",\r
e6956d00
AC
68 "AARCH64",\r
69 "RISCV64")\r
4eb2baba
SB
70\r
71 def GetTargetsSupported(self):\r
72 ''' return iterable of edk2 target tags supported by this build '''\r
73 return ("DEBUG", "RELEASE", "NO-TARGET", "NOOPT")\r
74\r
75 # ####################################################################################### #\r
76 # Verify and Save requested Ci Build Config #\r
77 # ####################################################################################### #\r
78\r
79 def SetPackages(self, list_of_requested_packages):\r
80 ''' Confirm the requested package list is valid and configure SettingsManager\r
81 to build the requested packages.\r
82\r
83 Raise UnsupportedException if a requested_package is not supported\r
84 '''\r
85 unsupported = set(list_of_requested_packages) - \\r
86 set(self.GetPackagesSupported())\r
87 if(len(unsupported) > 0):\r
88 logging.critical(\r
89 "Unsupported Package Requested: " + " ".join(unsupported))\r
90 raise Exception("Unsupported Package Requested: " +\r
91 " ".join(unsupported))\r
92 self.ActualPackages = list_of_requested_packages\r
93\r
94 def SetArchitectures(self, list_of_requested_architectures):\r
95 ''' Confirm the requests architecture list is valid and configure SettingsManager\r
96 to run only the requested architectures.\r
97\r
98 Raise Exception if a list_of_requested_architectures is not supported\r
99 '''\r
100 unsupported = set(list_of_requested_architectures) - \\r
101 set(self.GetArchitecturesSupported())\r
102 if(len(unsupported) > 0):\r
103 logging.critical(\r
104 "Unsupported Architecture Requested: " + " ".join(unsupported))\r
105 raise Exception(\r
106 "Unsupported Architecture Requested: " + " ".join(unsupported))\r
107 self.ActualArchitectures = list_of_requested_architectures\r
108\r
109 def SetTargets(self, list_of_requested_target):\r
110 ''' Confirm the request target list is valid and configure SettingsManager\r
111 to run only the requested targets.\r
112\r
113 Raise UnsupportedException if a requested_target is not supported\r
114 '''\r
115 unsupported = set(list_of_requested_target) - \\r
116 set(self.GetTargetsSupported())\r
117 if(len(unsupported) > 0):\r
118 logging.critical(\r
119 "Unsupported Targets Requested: " + " ".join(unsupported))\r
120 raise Exception("Unsupported Targets Requested: " +\r
121 " ".join(unsupported))\r
122 self.ActualTargets = list_of_requested_target\r
123\r
124 # ####################################################################################### #\r
125 # Actual Configuration for Ci Build #\r
126 # ####################################################################################### #\r
127\r
128 def GetActiveScopes(self):\r
129 ''' return tuple containing scopes that should be active for this process '''\r
61364ab9 130 scopes = ("cibuild", "edk2-build", "host-based-test")\r
4eb2baba
SB
131\r
132 self.ActualToolChainTag = shell_environment.GetBuildVars().GetValue("TOOL_CHAIN_TAG", "")\r
133\r
134 if GetHostInfo().os.upper() == "LINUX" and self.ActualToolChainTag.upper().startswith("GCC"):\r
135 if "AARCH64" in self.ActualArchitectures:\r
136 scopes += ("gcc_aarch64_linux",)\r
137 if "ARM" in self.ActualArchitectures:\r
138 scopes += ("gcc_arm_linux",)\r
e6956d00
AC
139 if "RISCV64" in self.ActualArchitectures:\r
140 scopes += ("gcc_riscv64_unknown",)\r
4eb2baba
SB
141\r
142 return scopes\r
143\r
144 def GetRequiredSubmodules(self):\r
145 ''' return iterable containing RequiredSubmodule objects.\r
146 If no RequiredSubmodules return an empty iterable\r
147 '''\r
61364ab9 148 rs = []\r
4eb2baba
SB
149 rs.append(RequiredSubmodule(\r
150 "ArmPkg/Library/ArmSoftFloatLib/berkeley-softfloat-3", False))\r
151 rs.append(RequiredSubmodule(\r
152 "CryptoPkg/Library/OpensslLib/openssl", False))\r
61364ab9
MK
153 rs.append(RequiredSubmodule(\r
154 "UnitTestFrameworkPkg/Library/CmockaLib/cmocka", False))\r
48b6c60c
SZ
155 rs.append(RequiredSubmodule(\r
156 "MdeModulePkg/Universal/RegularExpressionDxe/oniguruma", False))\r
58802e02
SZ
157 rs.append(RequiredSubmodule(\r
158 "MdeModulePkg/Library/BrotliCustomDecompressLib/brotli", False))\r
06033f5a
SZ
159 rs.append(RequiredSubmodule(\r
160 "BaseTools/Source/C/BrotliCompress/brotli", False))\r
4eb2baba
SB
161 return rs\r
162\r
163 def GetName(self):\r
164 return "Edk2"\r
165\r
166 def GetDependencies(self):\r
61364ab9
MK
167 return [\r
168 ]\r
4eb2baba
SB
169\r
170 def GetPackagesPath(self):\r
171 return ()\r
172\r
173 def GetWorkspaceRoot(self):\r
174 ''' get WorkspacePath '''\r
175 return os.path.dirname(os.path.dirname(os.path.abspath(__file__)))\r
176\r
177 def FilterPackagesToTest(self, changedFilesList: list, potentialPackagesList: list) -> list:\r
178 ''' Filter potential packages to test based on changed files. '''\r
61364ab9
MK
179 build_these_packages = []\r
180 possible_packages = potentialPackagesList.copy()\r
4eb2baba 181 for f in changedFilesList:\r
61364ab9
MK
182 # split each part of path for comparison later\r
183 nodes = f.split("/")\r
4eb2baba
SB
184\r
185 # python file change in .pytool folder causes building all\r
186 if f.endswith(".py") and ".pytool" in nodes:\r
187 build_these_packages = possible_packages\r
188 break\r
189\r
190 # BaseTools files that might change the build\r
191 if "BaseTools" in nodes:\r
192 if os.path.splitext(f) not in [".txt", ".md"]:\r
193 build_these_packages = possible_packages\r
194 break\r
195 return build_these_packages\r