Skip to content

Commit ae371e5

Browse files
committed
Merge branch 'main' into vp-arm-mve-transform
2 parents 21b33e6 + cd4c10a commit ae371e5

File tree

5,852 files changed

+339560
-106208
lines changed

Some content is hidden

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

5,852 files changed

+339560
-106208
lines changed

.ci/metrics/metrics.py

Lines changed: 62 additions & 39 deletions
Original file line numberDiff line numberDiff line change
@@ -3,6 +3,7 @@
33
import os
44
from dataclasses import dataclass
55
import sys
6+
import logging
67

78
import github
89
from github import Github
@@ -24,6 +25,7 @@ class JobMetrics:
2425
status: int
2526
created_at_ns: int
2627
workflow_id: int
28+
workflow_name: str
2729

2830

2931
@dataclass
@@ -43,40 +45,60 @@ def get_sampled_workflow_metrics(github_repo: github.Repository):
4345
Returns a list of GaugeMetric objects, containing the relevant metrics about
4446
the workflow
4547
"""
48+
queued_job_counts = {}
49+
running_job_counts = {}
4650

4751
# Other states are available (pending, waiting, etc), but the meaning
4852
# is not documented (See #70540).
4953
# "queued" seems to be the info we want.
50-
queued_workflow_count = len(
51-
[
52-
x
53-
for x in github_repo.get_workflow_runs(status="queued")
54-
if x.name in WORKFLOWS_TO_TRACK
55-
]
56-
)
57-
running_workflow_count = len(
58-
[
59-
x
60-
for x in github_repo.get_workflow_runs(status="in_progress")
61-
if x.name in WORKFLOWS_TO_TRACK
62-
]
63-
)
54+
for queued_workflow in github_repo.get_workflow_runs(status="queued"):
55+
if queued_workflow.name not in WORKFLOWS_TO_TRACK:
56+
continue
57+
for queued_workflow_job in queued_workflow.jobs():
58+
job_name = queued_workflow_job.name
59+
# Workflows marked as queued can potentially only have some jobs
60+
# queued, so make sure to also count jobs currently in progress.
61+
if queued_workflow_job.status == "queued":
62+
if job_name not in queued_job_counts:
63+
queued_job_counts[job_name] = 1
64+
else:
65+
queued_job_counts[job_name] += 1
66+
elif queued_workflow_job.status == "in_progress":
67+
if job_name not in running_job_counts:
68+
running_job_counts[job_name] = 1
69+
else:
70+
running_job_counts[job_name] += 1
71+
72+
for running_workflow in github_repo.get_workflow_runs(status="in_progress"):
73+
if running_workflow.name not in WORKFLOWS_TO_TRACK:
74+
continue
75+
for running_workflow_job in running_workflow.jobs():
76+
job_name = running_workflow_job.name
77+
if running_workflow_job.status != "in_progress":
78+
continue
79+
80+
if job_name not in running_job_counts:
81+
running_job_counts[job_name] = 1
82+
else:
83+
running_job_counts[job_name] += 1
6484

6585
workflow_metrics = []
66-
workflow_metrics.append(
67-
GaugeMetric(
68-
"workflow_queue_size",
69-
queued_workflow_count,
70-
time.time_ns(),
86+
for queued_job in queued_job_counts:
87+
workflow_metrics.append(
88+
GaugeMetric(
89+
f"workflow_queue_size_{queued_job}",
90+
queued_job_counts[queued_job],
91+
time.time_ns(),
92+
)
7193
)
72-
)
73-
workflow_metrics.append(
74-
GaugeMetric(
75-
"running_workflow_count",
76-
running_workflow_count,
77-
time.time_ns(),
94+
for running_job in running_job_counts:
95+
workflow_metrics.append(
96+
GaugeMetric(
97+
f"running_workflow_count_{running_job}",
98+
running_job_counts[running_job],
99+
time.time_ns(),
100+
)
78101
)
79-
)
80102
# Always send a hearbeat metric so we can monitor is this container is still able to log to Grafana.
81103
workflow_metrics.append(
82104
GaugeMetric("metrics_container_heartbeat", 1, time.time_ns())
@@ -157,7 +179,7 @@ def get_per_workflow_metrics(
157179
# longer in a testing state and we can directly assert the workflow
158180
# result.
159181
for step in workflow_job.steps:
160-
if step.conclusion != "success":
182+
if step.conclusion != "success" and step.conclusion != "skipped":
161183
job_result = 0
162184
break
163185

@@ -171,6 +193,10 @@ def get_per_workflow_metrics(
171193
# in nanoseconds.
172194
created_at_ns = int(created_at.timestamp()) * 10**9
173195

196+
logging.info(
197+
f"Adding a job metric for job {workflow_job.id} in workflow {workflow_run.id}"
198+
)
199+
174200
workflow_metrics.append(
175201
JobMetrics(
176202
workflow_run.name + "-" + workflow_job.name,
@@ -179,6 +205,7 @@ def get_per_workflow_metrics(
179205
job_result,
180206
created_at_ns,
181207
workflow_run.id,
208+
workflow_run.name,
182209
)
183210
)
184211

@@ -198,7 +225,7 @@ def upload_metrics(workflow_metrics, metrics_userid, api_key):
198225
"""
199226

200227
if len(workflow_metrics) == 0:
201-
print("No metrics found to upload.", file=sys.stderr)
228+
logging.info("No metrics found to upload.")
202229
return
203230

204231
metrics_batch = []
@@ -227,16 +254,12 @@ def upload_metrics(workflow_metrics, metrics_userid, api_key):
227254
)
228255

229256
if response.status_code < 200 or response.status_code >= 300:
230-
print(
231-
f"Failed to submit data to Grafana: {response.status_code}", file=sys.stderr
232-
)
257+
logging.info(f"Failed to submit data to Grafana: {response.status_code}")
233258

234259

235260
def main():
236261
# Authenticate with Github
237262
auth = Auth.Token(os.environ["GITHUB_TOKEN"])
238-
github_object = Github(auth=auth)
239-
github_repo = github_object.get_repo("llvm/llvm-project")
240263

241264
grafana_api_key = os.environ["GRAFANA_API_KEY"]
242265
grafana_metrics_userid = os.environ["GRAFANA_METRICS_USERID"]
@@ -248,24 +271,24 @@ def main():
248271
# Enter the main loop. Every five minutes we wake up and dump metrics for
249272
# the relevant jobs.
250273
while True:
274+
github_object = Github(auth=auth)
275+
github_repo = github_object.get_repo("llvm/llvm-project")
276+
251277
current_metrics = get_per_workflow_metrics(github_repo, workflows_to_track)
252278
current_metrics += get_sampled_workflow_metrics(github_repo)
253-
# Always send a hearbeat metric so we can monitor is this container is still able to log to Grafana.
254-
current_metrics.append(
255-
GaugeMetric("metrics_container_heartbeat", 1, time.time_ns())
256-
)
257279

258280
upload_metrics(current_metrics, grafana_metrics_userid, grafana_api_key)
259-
print(f"Uploaded {len(current_metrics)} metrics", file=sys.stderr)
281+
logging.info(f"Uploaded {len(current_metrics)} metrics")
260282

261283
for workflow_metric in reversed(current_metrics):
262284
if isinstance(workflow_metric, JobMetrics):
263285
workflows_to_track[
264-
workflow_metric.job_name
286+
workflow_metric.workflow_name
265287
] = workflow_metric.workflow_id
266288

267289
time.sleep(SCRAPE_INTERVAL_SECONDS)
268290

269291

270292
if __name__ == "__main__":
293+
logging.basicConfig(level=logging.INFO)
271294
main()

.github/new-prs-labeler.yml

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -499,6 +499,7 @@ clang:static analyzer:
499499
- clang/tools/scan-build/**
500500
- clang/utils/analyzer/**
501501
- clang/docs/analyzer/**
502+
- clang/test/Analysis/**
502503

503504
pgo:
504505
- llvm/lib/Transforms/Instrumentation/CGProfile.cpp

.github/workflows/build-metrics-container.yml

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -27,7 +27,7 @@ jobs:
2727
container-filename: ${{ steps.vars.outputs.container-filename }}
2828
steps:
2929
- name: Checkout LLVM
30-
uses: actions/checkout@v4
30+
uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
3131
with:
3232
sparse-checkout: .ci/metrics/
3333
- name: Write Variables
@@ -49,7 +49,7 @@ jobs:
4949
run: |
5050
podman save ${{ steps.vars.outputs.container-name-tag }} > ${{ steps.vars.outputs.container-filename }}
5151
- name: Upload Container Image
52-
uses: actions/upload-artifact@v4
52+
uses: actions/upload-artifact@65c4c4a1ddee5b72f698fdd19549f0f0fb45cf08 # v4.6.0
5353
with:
5454
name: container
5555
path: ${{ steps.vars.outputs.container-filename }}
@@ -66,7 +66,7 @@ jobs:
6666
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
6767
steps:
6868
- name: Download Container
69-
uses: actions/download-artifact@v4
69+
uses: actions/download-artifact@fa0a91b85d4f404e444e00e005971372dc801d16 # v4.1.8
7070
with:
7171
name: container
7272
- name: Push Container

.github/workflows/ci-post-commit-analyzer.yml

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -44,7 +44,7 @@ jobs:
4444
uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1
4545

4646
- name: Setup ccache
47-
uses: hendrikmuhs/ccache-action@v1
47+
uses: hendrikmuhs/ccache-action@a1209f81afb8c005c13b4296c32e363431bffea5 # v1.2.17
4848
with:
4949
# A full build of llvm, clang, lld, and lldb takes about 250MB
5050
# of ccache space. There's not much reason to have more than this,

.github/workflows/commit-access-review.yml

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -15,7 +15,7 @@ jobs:
1515
runs-on: ubuntu-22.04
1616
steps:
1717
- name: Fetch LLVM sources
18-
uses: actions/checkout@v4
18+
uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
1919

2020
- name: Install dependencies
2121
run: |

.github/workflows/containers/github-action-ci/Dockerfile

Lines changed: 2 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -40,7 +40,7 @@ RUN cmake -B ./build -G Ninja ./llvm \
4040
RUN ninja -C ./build stage2-clang-bolt stage2-install-distribution && ninja -C ./build install-distribution
4141

4242
FROM base as ci-container
43-
43+
4444
COPY --from=stage1-toolchain $LLVM_SYSROOT $LLVM_SYSROOT
4545

4646
# Need to install curl for hendrikmuhs/ccache-action
@@ -49,7 +49,7 @@ COPY --from=stage1-toolchain $LLVM_SYSROOT $LLVM_SYSROOT
4949
# Need git for SPIRV-Tools tests.
5050
RUN apt-get update && \
5151
DEBIAN_FRONTEND=noninteractive apt-get install -y \
52-
binutils \
52+
binutils \
5353
cmake \
5454
curl \
5555
git \
@@ -59,7 +59,6 @@ RUN apt-get update && \
5959
perl-modules \
6060
python3-psutil \
6161
sudo \
62-
6362
# These are needed by the premerge pipeline. Pip is used to install
6463
# dependent python packages and ccache is used for build caching. File and
6564
# tzdata are used for tests.

.github/workflows/docs.yml

Lines changed: 5 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -60,12 +60,12 @@ jobs:
6060
# a local checkout beforehand.
6161
- name: Fetch LLVM sources (Push)
6262
if: ${{ github.event_name == 'push' }}
63-
uses: actions/checkout@v4
63+
uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
6464
with:
6565
fetch-depth: 1
6666
- name: Get subprojects that have doc changes
6767
id: docs-changed-subprojects
68-
uses: tj-actions/changed-files@v39
68+
uses: tj-actions/changed-files@fea790cb660e33aef4bdf07304e28fedd77dfa13 # v39.2.4
6969
with:
7070
files_yaml: |
7171
llvm:
@@ -98,11 +98,11 @@ jobs:
9898
- '.github/workflows/docs.yml'
9999
- name: Fetch LLVM sources (PR)
100100
if: ${{ github.event_name == 'pull_request' }}
101-
uses: actions/checkout@v4
101+
uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
102102
with:
103103
fetch-depth: 1
104104
- name: Setup Python env
105-
uses: actions/setup-python@v5
105+
uses: actions/setup-python@42375524e23c412d93fb67b49958b491fce71c38 # v5.4.0
106106
with:
107107
python-version: '3.11'
108108
cache: 'pip'
@@ -216,7 +216,7 @@ jobs:
216216
mkdir built-docs/flang
217217
cp -r flang-build/docs/* built-docs/flang/
218218
- name: Upload docs
219-
uses: actions/upload-artifact@v4
219+
uses: actions/upload-artifact@65c4c4a1ddee5b72f698fdd19549f0f0fb45cf08 # v4.6.0
220220
with:
221221
name: docs-output
222222
path: built-docs/

.github/workflows/email-check.yaml

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -14,7 +14,7 @@ jobs:
1414
if: github.repository == 'llvm/llvm-project'
1515
steps:
1616
- name: Fetch LLVM sources
17-
uses: actions/checkout@v4
17+
uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
1818
with:
1919
ref: ${{ github.event.pull_request.head.sha }}
2020

.github/workflows/issue-release-workflow.yml

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -42,7 +42,7 @@ jobs:
4242
contains(github.event.action == 'opened' && github.event.issue.body || github.event.comment.body, '/cherry-pick')
4343
steps:
4444
- name: Fetch LLVM sources
45-
uses: actions/checkout@v4
45+
uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
4646
with:
4747
repository: llvm/llvm-project
4848
# GitHub stores the token used for checkout and uses it for pushes

.github/workflows/issue-subscriber.yml

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -14,7 +14,7 @@ jobs:
1414
if: github.repository == 'llvm/llvm-project'
1515
steps:
1616
- name: Checkout Automation Script
17-
uses: actions/checkout@v4
17+
uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
1818
with:
1919
sparse-checkout: llvm/utils/git/
2020
ref: main

0 commit comments

Comments
 (0)