mirror of
https://github.com/speed47/spectre-meltdown-checker.git
synced 2026-06-04 13:43:05 +02:00
26cf31b282
* chore: add stalebot in dryrun built from commitafadf53f7fdated 2026-04-02 13:13:19 +0200 by Stéphane Lesimple (speed47_github@speed47.net) * Merge branch 'test' into source built from commit952fe6a87fdated 2026-04-02 18:40:05 +0200 by Stéphane Lesimple (speed47_github@speed47.net) * Merge pull request #530 from speed47/test built from commitd3c0f1a24ddated 2026-04-02 16:49:41 +0000 by Stéphane Lesimple (speed47_github@speed47.net) chore: workflows revamp * Merge pull request #532 from speed47/test built from commit6fac2d8ff1dated 2026-04-02 21:32:39 +0000 by Stéphane Lesimple (speed47_github@speed47.net) Retbleed / Downfall overhald / doc updates * enh: add known fixed ucode versions for CVE-2023-23583 (Reptar) and CVE-2024-45332 (BPI) built from commitcccb3c0081dated 2026-04-04 17:50:04 +0200 by Stéphane Lesimple (speed47_github@speed47.net) * fix: add rebleet to --variant built from commit7a7408d124dated 2026-04-04 18:17:35 +0200 by Stéphane Lesimple (speed47_github@speed47.net) * Merge pull request #566 from speed47/test built from commit3e2b6cc734dated 2026-04-20 11:02:38 +0000 by Stéphane Lesimple (speed47_github@speed47.net) Prepare release v26.33.0420xxx * Merge pull request #571 from speed47/test built from commit0045d237fadated 2026-06-01 20:44:44 +0000 by Stéphane Lesimple (speed47_github@speed47.net) Prepare next release * update: fwdb from v349+i20260227+615b to v349+i20260512+1cce, 19 microcode changes built from commit645a79846bdated 2026-06-01 20:56:45 +0000 by github-actions[bot] (41898282+github-actions[bot]@users.noreply.github.com) --------- Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
186 lines
6.3 KiB
YAML
186 lines
6.3 KiB
YAML
name: build
|
|
|
|
on:
|
|
push:
|
|
branches:
|
|
- test
|
|
- source
|
|
|
|
jobs:
|
|
build:
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
steps:
|
|
- uses: actions/checkout@v6
|
|
with:
|
|
persist-credentials: true
|
|
- name: install prerequisites
|
|
run: sudo apt-get update && sudo apt-get install -y shellcheck shfmt jq sqlite3 iucode-tool make
|
|
- name: update Intel model list
|
|
run: ./scripts/update_intel_models.sh
|
|
- name: build and check
|
|
run: |
|
|
make build fmt-check shellcheck
|
|
mv spectre-meltdown-checker.sh dist/
|
|
- name: check direct execution
|
|
run: |
|
|
set -x
|
|
expected=$(cat .github/workflows/expected_cve_count)
|
|
cd dist
|
|
|
|
json=$(sudo ./spectre-meltdown-checker.sh --batch json || true)
|
|
|
|
# Validate JSON is well-formed (and show it if not)
|
|
echo "$json" | jq . >/dev/null || {
|
|
echo "Invalid JSON produced by spectre-meltdown-checker.sh"
|
|
echo "$json"
|
|
exit 1
|
|
}
|
|
|
|
# Validate required keys exist
|
|
for key in meta system cpu cpu_microcode vulnerabilities; do
|
|
echo "$json" | jq -e ".$key" >/dev/null || {
|
|
echo "Missing top-level key: $key"
|
|
echo "$json" | jq .
|
|
exit 1
|
|
}
|
|
done
|
|
|
|
# Use -r to get raw scalars (no quotes)
|
|
fmtver=$(echo "$json" | jq -r '.meta.format_version // empty')
|
|
if [ "$fmtver" != "1" ]; then
|
|
echo "Unexpected format_version: $fmtver"
|
|
echo "$json" | jq .
|
|
exit 1
|
|
fi
|
|
|
|
run_as_root=$(echo "$json" | jq -r '.meta.run_as_root // empty')
|
|
if [ "$run_as_root" != "true" ]; then
|
|
echo "Expected run_as_root=true, got: $run_as_root"
|
|
echo "$json" | jq .
|
|
exit 1
|
|
fi
|
|
|
|
mocked=$(echo "$json" | jq -r '.meta.mocked // "false"')
|
|
if [ "$mocked" = "true" ]; then
|
|
echo "mocked=true must never appear in production"
|
|
echo "$json" | jq .
|
|
exit 1
|
|
fi
|
|
|
|
# Count CVEs robustly (as a number)
|
|
nb=$(echo "$json" | jq -r '[.vulnerabilities[].cve] | length')
|
|
if [ "$nb" -ne "$expected" ]; then
|
|
echo "Invalid number of CVEs reported: $nb instead of $expected"
|
|
echo "$json" | jq '.vulnerabilities[].cve'
|
|
exit 1
|
|
else
|
|
echo "OK $nb CVEs reported"
|
|
fi
|
|
|
|
# Validate json-terse backward compatibility
|
|
nb_terse=$(sudo ./spectre-meltdown-checker.sh --batch json-terse | jq -r 'map(.CVE) | length')
|
|
if [ "$nb_terse" -ne "$expected" ]; then
|
|
echo "json-terse backward compat broken: $nb_terse CVEs instead of $expected"
|
|
exit 1
|
|
else
|
|
echo "OK json-terse backward compat: $nb_terse CVEs"
|
|
fi
|
|
- name: check docker compose run execution
|
|
run: |
|
|
expected=$(cat .github/workflows/expected_cve_count)
|
|
cd dist
|
|
docker compose build
|
|
json=$(docker compose run --rm spectre-meltdown-checker --batch json || true)
|
|
echo "$json" | jq . > /dev/null
|
|
fmtver=$(echo "$json" | jq '.meta.format_version')
|
|
if [ "$fmtver" != "1" ]; then
|
|
echo "Unexpected format_version: $fmtver"
|
|
exit 1
|
|
fi
|
|
nb=$(echo "$json" | jq '.vulnerabilities[].cve' | wc -l)
|
|
if [ "$nb" -ne "$expected" ]; then
|
|
echo "Invalid number of CVEs reported: $nb instead of $expected"
|
|
exit 1
|
|
else
|
|
echo "OK $nb CVEs reported"
|
|
fi
|
|
- name: check docker run execution
|
|
run: |
|
|
expected=$(cat .github/workflows/expected_cve_count)
|
|
cd dist
|
|
docker build -t spectre-meltdown-checker .
|
|
json=$(docker run --rm --privileged -v /boot:/boot:ro -v /dev/cpu:/dev/cpu:ro -v /lib/modules:/lib/modules:ro spectre-meltdown-checker --batch json || true)
|
|
echo "$json" | jq . > /dev/null
|
|
fmtver=$(echo "$json" | jq '.meta.format_version')
|
|
if [ "$fmtver" != "1" ]; then
|
|
echo "Unexpected format_version: $fmtver"
|
|
exit 1
|
|
fi
|
|
nb=$(echo "$json" | jq '.vulnerabilities[].cve' | wc -l)
|
|
if [ "$nb" -ne "$expected" ]; then
|
|
echo "Invalid number of CVEs reported: $nb instead of $expected"
|
|
exit 1
|
|
else
|
|
echo "OK $nb CVEs reported"
|
|
fi
|
|
- name: check fwdb update (separated)
|
|
run: |
|
|
cd dist
|
|
nbtmp1=$(find /tmp 2>/dev/null | wc -l)
|
|
./spectre-meltdown-checker.sh --update-fwdb; ret=$?
|
|
if [ "$ret" != 0 ]; then
|
|
echo "Non-zero return value: $ret"
|
|
exit 1
|
|
fi
|
|
nbtmp2=$(find /tmp 2>/dev/null | wc -l)
|
|
if [ "$nbtmp1" != "$nbtmp2" ]; then
|
|
echo "Left temporary files!"
|
|
exit 1
|
|
fi
|
|
if ! [ -e ~/.mcedb ]; then
|
|
echo "No .mcedb file found after updating fwdb"
|
|
exit 1
|
|
fi
|
|
- name: check fwdb update (builtin)
|
|
run: |
|
|
cd dist
|
|
nbtmp1=$(find /tmp 2>/dev/null | wc -l)
|
|
./spectre-meltdown-checker.sh --update-builtin-fwdb; ret=$?
|
|
if [ "$ret" != 0 ]; then
|
|
echo "Non-zero return value: $ret"
|
|
exit 1
|
|
fi
|
|
nbtmp2=$(find /tmp 2>/dev/null | wc -l)
|
|
if [ "$nbtmp1" != "$nbtmp2" ]; then
|
|
echo "Left temporary files!"
|
|
exit 1
|
|
fi
|
|
- name: create a pull request to ${{ github.ref_name }}-build
|
|
run: |
|
|
# all the files in dist/* and .github/* must be moved as is to the -build branch root, move them out for now:
|
|
tmpdir=$(mktemp -d)
|
|
mv ./dist/* .github $tmpdir/
|
|
rm -rf ./dist
|
|
|
|
git fetch origin ${{ github.ref_name }}-build
|
|
git checkout -f ${{ github.ref_name }}-build
|
|
rm -rf doc/
|
|
mv $tmpdir/* .
|
|
rm -rf src/ scripts/ img/
|
|
mkdir -p .github
|
|
rsync -vaP --delete $tmpdir/.github/ .github/
|
|
|
|
git add --all
|
|
echo =#=#= DIFF CACHED
|
|
git diff --cached
|
|
echo =#=#= STATUS
|
|
git status
|
|
echo =#=#= COMMIT
|
|
git config --global user.name "github-actions[bot]"
|
|
git config --global user.email "41898282+github-actions[bot]@users.noreply.github.com"
|
|
git log ${{ github.ref }} -1 --format=format:'%s%n%n built from commit %H%n dated %ai%n by %an (%ae)%n%n %b'
|
|
git log ${{ github.ref }} -1 --format=format:'%s%n%n built from commit %H%n dated %ai%n by %an (%ae)%n%n %b' | git commit -F -
|
|
git push
|