Skip to content

Commit 37df6f9

Browse files
Merge branch 'main' into isel-fpclass
2 parents 6f68650 + 47e2de0 commit 37df6f9

File tree

14,005 files changed

+860389
-429738
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

14,005 files changed

+860389
-429738
lines changed

.ci/compute_projects.py

Lines changed: 54 additions & 12 deletions
Original file line numberDiff line numberDiff line change
@@ -19,6 +19,7 @@
1919
PROJECT_DEPENDENCIES = {
2020
"llvm": set(),
2121
"clang": {"llvm"},
22+
"CIR": {"clang", "mlir"},
2223
"bolt": {"clang", "lld", "llvm"},
2324
"clang-tools-extra": {"clang", "llvm"},
2425
"compiler-rt": {"clang", "lld"},
@@ -55,6 +56,7 @@
5556
".ci": {
5657
"llvm",
5758
"clang",
59+
"CIR",
5860
"lld",
5961
"lldb",
6062
"bolt",
@@ -77,6 +79,7 @@
7779
DEPENDENT_RUNTIMES_TO_TEST = {
7880
"clang": {"compiler-rt"},
7981
"clang-tools-extra": {"libc"},
82+
"libc": {"libc"},
8083
".ci": {"compiler-rt", "libc"},
8184
}
8285
DEPENDENT_RUNTIMES_TO_TEST_NEEDS_RECONFIG = {
@@ -127,6 +130,7 @@
127130
"lldb": "check-lldb",
128131
"llvm": "check-llvm",
129132
"clang": "check-clang",
133+
"CIR": "check-clang-cir",
130134
"bolt": "check-bolt",
131135
"lld": "check-lld",
132136
"flang": "check-flang",
@@ -140,6 +144,23 @@
140144

141145
RUNTIMES = {"libcxx", "libcxxabi", "libunwind", "compiler-rt", "libc"}
142146

147+
# Meta projects are projects that need explicit handling but do not reside
148+
# in their own top level folder. To add a meta project, the start of the path
149+
# for the metaproject should be mapped to the name of the project below.
150+
# Multiple paths can map to the same metaproject.
151+
META_PROJECTS = {
152+
("clang", "lib", "CIR"): "CIR",
153+
("clang", "test", "CIR"): "CIR",
154+
("clang", "include", "clang", "CIR"): "CIR",
155+
("*", "docs"): "docs",
156+
("llvm", "utils", "gn"): "gn",
157+
(".github", "workflows", "premerge.yaml"): ".ci",
158+
("third-party",): ".ci",
159+
}
160+
161+
# Projects that should not run any tests. These need to be metaprojects.
162+
SKIP_PROJECTS = ["docs", "gn"]
163+
143164

144165
def _add_dependencies(projects: Set[str], runtimes: Set[str]) -> Set[str]:
145166
projects_with_dependents = set(projects)
@@ -232,21 +253,34 @@ def _compute_runtimes_to_build(
232253
return _exclude_projects(runtimes_to_build, platform)
233254

234255

256+
def _path_matches(matcher: tuple[str], file_path: tuple[str]) -> bool:
257+
if len(file_path) < len(matcher):
258+
return False
259+
for match_part, file_part in zip(matcher, file_path):
260+
if match_part == "*" or file_part == "*":
261+
continue
262+
if match_part != file_part:
263+
return False
264+
return True
265+
266+
267+
def _get_modified_projects_for_file(modified_file: str) -> Set[str]:
268+
modified_projects = set()
269+
path_parts = pathlib.Path(modified_file).parts
270+
for meta_project_files in META_PROJECTS.keys():
271+
if _path_matches(meta_project_files, path_parts):
272+
meta_project = META_PROJECTS[meta_project_files]
273+
if meta_project in SKIP_PROJECTS:
274+
return set()
275+
modified_projects.add(meta_project)
276+
modified_projects.add(pathlib.Path(modified_file).parts[0])
277+
return modified_projects
278+
279+
235280
def _get_modified_projects(modified_files: list[str]) -> Set[str]:
236281
modified_projects = set()
237282
for modified_file in modified_files:
238-
path_parts = pathlib.Path(modified_file).parts
239-
# Exclude files in the docs directory. They do not impact an test
240-
# targets and there is a separate workflow used for ensuring the
241-
# documentation builds.
242-
if len(path_parts) > 2 and path_parts[1] == "docs":
243-
continue
244-
# Exclude files for the gn build. We do not test it within premerge
245-
# and changes occur often enough that they otherwise take up
246-
# capacity.
247-
if len(path_parts) > 3 and path_parts[:3] == ("llvm", "utils", "gn"):
248-
continue
249-
modified_projects.add(pathlib.Path(modified_file).parts[0])
283+
modified_projects.update(_get_modified_projects_for_file(modified_file))
250284
return modified_projects
251285

252286

@@ -266,6 +300,13 @@ def get_env_variables(modified_files: list[str], platform: str) -> Set[str]:
266300
runtimes_check_targets_needs_reconfig = _compute_project_check_targets(
267301
runtimes_to_test_needs_reconfig
268302
)
303+
304+
# CIR is used as a pseudo-project in this script. It is built as part of the
305+
# clang build, but it requires an explicit option to enable. We set that
306+
# option here, and remove it from the projects_to_build list.
307+
enable_cir = "ON" if "CIR" in projects_to_build else "OFF"
308+
projects_to_build.discard("CIR")
309+
269310
# We use a semicolon to separate the projects/runtimes as they get passed
270311
# to the CMake invocation and thus we need to use the CMake list separator
271312
# (;). We use spaces to separate the check targets as they end up getting
@@ -278,6 +319,7 @@ def get_env_variables(modified_files: list[str], platform: str) -> Set[str]:
278319
"runtimes_check_targets_needs_reconfig": " ".join(
279320
sorted(runtimes_check_targets_needs_reconfig)
280321
),
322+
"enable_cir": enable_cir,
281323
}
282324

283325

.ci/compute_projects_test.py

Lines changed: 106 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -1,7 +1,7 @@
11
# Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
22
# See https://llvm.org/LICENSE.txt for license information.
33
# SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
4-
"""Does some stuff."""
4+
"""Tests for compute_projects.py"""
55

66
import unittest
77

@@ -104,6 +104,10 @@ def test_clang(self):
104104
env_variables["runtimes_check_targets_needs_reconfig"],
105105
"check-cxx check-cxxabi check-unwind",
106106
)
107+
self.assertEqual(
108+
env_variables["enable_cir"],
109+
"OFF",
110+
)
107111

108112
def test_clang_windows(self):
109113
env_variables = compute_projects.get_env_variables(
@@ -126,6 +130,32 @@ def test_clang_windows(self):
126130
env_variables["runtimes_check_targets_needs_reconfig"],
127131
"check-cxx check-cxxabi check-unwind",
128132
)
133+
self.assertEqual(env_variables["enable_cir"], "OFF")
134+
135+
def test_cir(self):
136+
env_variables = compute_projects.get_env_variables(
137+
["clang/lib/CIR/CMakeLists.txt"], "Linux"
138+
)
139+
self.assertEqual(
140+
env_variables["projects_to_build"],
141+
"clang;clang-tools-extra;lld;llvm;mlir",
142+
)
143+
self.assertEqual(
144+
env_variables["project_check_targets"],
145+
"check-clang check-clang-cir check-clang-tools",
146+
)
147+
self.assertEqual(
148+
env_variables["runtimes_to_build"], "compiler-rt;libcxx;libcxxabi;libunwind"
149+
)
150+
self.assertEqual(
151+
env_variables["runtimes_check_targets"],
152+
"check-compiler-rt",
153+
)
154+
self.assertEqual(
155+
env_variables["runtimes_check_targets_needs_reconfig"],
156+
"check-cxx check-cxxabi check-unwind",
157+
)
158+
self.assertEqual(env_variables["enable_cir"], "ON")
129159

130160
def test_bolt(self):
131161
env_variables = compute_projects.get_env_variables(
@@ -158,6 +188,7 @@ def test_mlir(self):
158188
self.assertEqual(env_variables["runtimes_to_build"], "")
159189
self.assertEqual(env_variables["runtimes_check_targets"], "")
160190
self.assertEqual(env_variables["runtimes_check_targets_needs_reconfig"], "")
191+
self.assertEqual(env_variables["enable_cir"], "OFF")
161192

162193
def test_flang(self):
163194
env_variables = compute_projects.get_env_variables(
@@ -168,10 +199,11 @@ def test_flang(self):
168199
self.assertEqual(env_variables["runtimes_to_build"], "")
169200
self.assertEqual(env_variables["runtimes_check_targets"], "")
170201
self.assertEqual(env_variables["runtimes_check_targets_needs_reconfig"], "")
202+
self.assertEqual(env_variables["enable_cir"], "OFF")
171203

172204
def test_invalid_subproject(self):
173205
env_variables = compute_projects.get_env_variables(
174-
["third-party/benchmark/CMakeLists.txt"], "Linux"
206+
["llvm-libgcc/CMakeLists.txt"], "Linux"
175207
)
176208
self.assertEqual(env_variables["projects_to_build"], "")
177209
self.assertEqual(env_variables["project_check_targets"], "")
@@ -187,7 +219,7 @@ def test_top_level_file(self):
187219
self.assertEqual(env_variables["runtimes_check_targets"], "")
188220
self.assertEqual(env_variables["runtimes_check_targets_needs_reconfig"], "")
189221

190-
def test_exclude_runtiems_in_projects(self):
222+
def test_exclude_libcxx_in_projects(self):
191223
env_variables = compute_projects.get_env_variables(
192224
["libcxx/CMakeLists.txt"], "Linux"
193225
)
@@ -197,6 +229,16 @@ def test_exclude_runtiems_in_projects(self):
197229
self.assertEqual(env_variables["runtimes_check_targets"], "")
198230
self.assertEqual(env_variables["runtimes_check_targets_needs_reconfig"], "")
199231

232+
def test_include_libc_in_runtimes(self):
233+
env_variables = compute_projects.get_env_variables(
234+
["libc/CMakeLists.txt"], "Linux"
235+
)
236+
self.assertEqual(env_variables["projects_to_build"], "clang;lld")
237+
self.assertEqual(env_variables["project_check_targets"], "")
238+
self.assertEqual(env_variables["runtimes_to_build"], "libc")
239+
self.assertEqual(env_variables["runtimes_check_targets"], "check-libc")
240+
self.assertEqual(env_variables["runtimes_check_targets_needs_reconfig"], "")
241+
200242
def test_exclude_docs(self):
201243
env_variables = compute_projects.get_env_variables(
202244
["llvm/docs/CIBestPractices.rst"], "Linux"
@@ -227,7 +269,7 @@ def test_ci(self):
227269
)
228270
self.assertEqual(
229271
env_variables["project_check_targets"],
230-
"check-bolt check-clang check-clang-tools check-flang check-lld check-lldb check-llvm check-mlir check-polly",
272+
"check-bolt check-clang check-clang-cir check-clang-tools check-flang check-lld check-lldb check-llvm check-mlir check-polly",
231273
)
232274
self.assertEqual(
233275
env_variables["runtimes_to_build"],
@@ -266,6 +308,66 @@ def test_clang_tools_extra(self):
266308
self.assertEqual(env_variables["runtimes_check_targets"], "check-libc")
267309
self.assertEqual(env_variables["runtimes_check_targets_needs_reconfig"], "")
268310

311+
def test_premerge_workflow(self):
312+
env_variables = compute_projects.get_env_variables(
313+
[".github/workflows/premerge.yaml"], "Linux"
314+
)
315+
self.assertEqual(
316+
env_variables["projects_to_build"],
317+
"bolt;clang;clang-tools-extra;flang;libclc;lld;lldb;llvm;mlir;polly",
318+
)
319+
self.assertEqual(
320+
env_variables["project_check_targets"],
321+
"check-bolt check-clang check-clang-cir check-clang-tools check-flang check-lld check-lldb check-llvm check-mlir check-polly",
322+
)
323+
self.assertEqual(
324+
env_variables["runtimes_to_build"],
325+
"compiler-rt;libc;libcxx;libcxxabi;libunwind",
326+
)
327+
self.assertEqual(
328+
env_variables["runtimes_check_targets"],
329+
"check-compiler-rt check-libc",
330+
)
331+
self.assertEqual(
332+
env_variables["runtimes_check_targets_needs_reconfig"],
333+
"check-cxx check-cxxabi check-unwind",
334+
)
335+
336+
def test_other_github_workflow(self):
337+
env_variables = compute_projects.get_env_variables(
338+
[".github/workflows/docs.yml"], "Linux"
339+
)
340+
self.assertEqual(env_variables["projects_to_build"], "")
341+
self.assertEqual(env_variables["project_check_targets"], "")
342+
self.assertEqual(env_variables["runtimes_to_build"], "")
343+
self.assertEqual(env_variables["runtimes_check_targets"], "")
344+
self.assertEqual(env_variables["runtimes_check_targets_needs_reconfig"], "")
345+
346+
def test_third_party_benchmark(self):
347+
env_variables = compute_projects.get_env_variables(
348+
["third-party/benchmark/CMakeLists.txt"], "Linux"
349+
)
350+
self.assertEqual(
351+
env_variables["projects_to_build"],
352+
"bolt;clang;clang-tools-extra;flang;libclc;lld;lldb;llvm;mlir;polly",
353+
)
354+
self.assertEqual(
355+
env_variables["project_check_targets"],
356+
"check-bolt check-clang check-clang-cir check-clang-tools check-flang check-lld check-lldb check-llvm check-mlir check-polly",
357+
)
358+
self.assertEqual(
359+
env_variables["runtimes_to_build"],
360+
"compiler-rt;libc;libcxx;libcxxabi;libunwind",
361+
)
362+
self.assertEqual(
363+
env_variables["runtimes_check_targets"],
364+
"check-compiler-rt check-libc",
365+
)
366+
self.assertEqual(
367+
env_variables["runtimes_check_targets_needs_reconfig"],
368+
"check-cxx check-cxxabi check-unwind",
369+
)
370+
269371

270372
if __name__ == "__main__":
271373
unittest.main()

.ci/generate_test_report_github.py

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -16,8 +16,8 @@
1616
parser.add_argument("junit_files", help="Paths to JUnit report files.", nargs="*")
1717
args = parser.parse_args()
1818

19-
report, _ = generate_test_report_lib.generate_report_from_files(
20-
args.title, args.return_code, args.junit_files, None
19+
report = generate_test_report_lib.generate_report_from_files(
20+
args.title, args.return_code, args.junit_files
2121
)
2222

2323
print(report)

0 commit comments

Comments
 (0)