diff --git a/.github/workflows/bincheck.yml b/.github/workflows/bincheck.yml
index 45f85c07b2c5..4a503e7a10ca 100644
--- a/.github/workflows/bincheck.yml
+++ b/.github/workflows/bincheck.yml
@@ -9,18 +9,17 @@ jobs:
linux:
runs-on: ubuntu-latest
steps:
- - uses: actions/checkout@v2
- - run: sudo apt-get update && sudo apt-get install -y qemu-system-x86
+ - uses: actions/checkout@v3
- run: cd build/release/bincheck && ./test-linux ${{ github.ref_name }} ${{ github.sha }}
darwin:
runs-on: macos-latest
steps:
- - uses: actions/checkout@v2
+ - uses: actions/checkout@v3
- run: cd build/release/bincheck && ./test-macos ${{ github.ref_name }} ${{ github.sha }}
windows:
runs-on: windows-latest
steps:
- - uses: actions/checkout@v2
+ - uses: actions/checkout@v3
- run: cd build/release/bincheck && bash test-windows ${{ github.ref_name }} ${{ github.sha }}
diff --git a/build/release/bincheck/README.md b/build/release/bincheck/README.md
index 775ca7a3bb23..84a6391b0726 100644
--- a/build/release/bincheck/README.md
+++ b/build/release/bincheck/README.md
@@ -10,58 +10,3 @@ sanity checks are:
bincheck action is triggered when a new tag with `v` prefix is created. Check
https://github.com/cockroachdb/cockroach/actions after a release is published.
-
-
-## The nitty-gritty
-
-### Overview
-
-For the MacOS and Windows binaries, the mechanics involved are simple. We ask
-GitHub Actions to spin us up a MacOS or Windows runner, download the
-appropriate pre-built `cockroach` binary, and run our sanity checks.
-
-Linux is more complicated, not out of necessity, but out of ambition. We co-opt
-the Linux verification step to additionally test support for pre-SSE4.2
-CPUs†. This requires emulating such a CPU, and Linux is the only
-operating system that is feasible to run under emulation. Windows and MacOS have
-prohibitively slow boot times, and, perhaps more importantly, Windows and MacOS
-install media are not freely available.
-
-So, with the help of [Buildroot], an embedded Linux build manager, this
-repository ships an [8.7MB Linux distribution][linux-image] that's capable of
-running under [QEMU] and launching our pre-built CockroachDB binaries. To verify
-the Linux binaries, we first boot this Linux distribution on an emulated
-pre-SSE4.2 CPU (`qemu-system-x86_64 -cpu qemu64,-sse4.2`), then run our sanity
-checks from inside this VM.
-
-†SSE4.2 support is particularly important in CockroachDB,
-since RocksDB internally uses a [CRC32C checksum][crc32c] to protect against
-data corruption. SSE4.2 includes hardware support for computing CRC32C
-checksums, but is only available on CPUs released after November 2008. Producing
-a binary that can dynamically switch between the SSE4.2 and non-SSE4.2
-implementations at runtime [has proven difficult][issue-15589].
-
-
-### Updating the Linux image
-
-After [installing Buildroot][buildroot-install]:
-
-```shell
-$ make qemu_x86_64_glibc_defconfig BR2_EXTERNAL=buildroot
-$ make menuconfig # Only if configuration changes are necessary.
-$ make
-$ cp output/images/bzImage images/qemu_x86_64_glibc_bzImage
-```
-
-At the time of writing, `qemu_x86_64_glibc_defconfig` instructed Buildroot to
-build a Linux 4.9 kernel, install Bash and OpenSSH into userland, and configure
-sshd to boot at startup and allow passwordless `root` authentication.
-`/etc/fstab` is modified to mount the first hard drive at `/bincheck`, assuming
-it's a FAT volume.
-
-[buildroot-install]: https://buildroot.org/download.html
-[issue-15589]: https://github.com/cockroachdb/cockroach/issues/15589
-[linux-image]: ./images/qemu_x86_64_glibc_bzImage
-[Buildroot]: https://buildroot.org
-[CRC32C]: http://www.evanjones.ca/crc32c.html
-[QEMU]: http://qemu.org
diff --git a/build/release/bincheck/bincheck b/build/release/bincheck/bincheck
index d3e267daf3c8..24c9f8e96af2 100755
--- a/build/release/bincheck/bincheck
+++ b/build/release/bincheck/bincheck
@@ -34,7 +34,7 @@ echo ""
# Start node with encryption enabled.
"$cockroach" start-single-node --insecure --listening-url-file="$urlfile" --enterprise-encryption=path=cockroach-data,key=aes-128.key,old-key=plain --pid-file="$pidfile" &
-trap "kill -9 $! &> /dev/null" EXIT
+trap "kill -9 $! || true" EXIT
for i in {0..3}
do
[[ -f "$urlfile" ]] && break
@@ -58,7 +58,7 @@ diff -u expected actual
# Attempt a clean shutdown for good measure. We'll force-kill in the atexit
# handler if this fails.
-cat "$pidfile" | xargs kill -TERM
+kill -TERM $(cat "$pidfile") || true
trap - EXIT
# Verify reported version matches expected version.
diff --git a/build/release/bincheck/buildroot.patch b/build/release/bincheck/buildroot.patch
deleted file mode 100644
index abaa744445ba..000000000000
--- a/build/release/bincheck/buildroot.patch
+++ /dev/null
@@ -1,35 +0,0 @@
-diff --git a/package/ncurses/Config.in b/package/ncurses/Config.in
-index 92be164..b3333f1 100644
---- a/package/ncurses/Config.in
-+++ b/package/ncurses/Config.in
-@@ -23,4 +23,9 @@ config BR2_PACKAGE_NCURSES_TARGET_PROGS
- help
- Include ncurses programs in target (clear, reset, tput, ...)
-
-+config BR2_PACKAGE_NCURSES_TERMLIB
-+ bool "separate terminfo library"
-+ help
-+ Build a separate terminfo library (libtinfo)
-+
- endif
-diff --git a/package/ncurses/ncurses.mk b/package/ncurses/ncurses.mk
-index 94c8c9a..c1b61aa 100644
---- a/package/ncurses/ncurses.mk
-+++ b/package/ncurses/ncurses.mk
-@@ -27,6 +27,7 @@ NCURSES_CONF_OPTS = \
- --enable-pc-files \
- --with-pkg-config-libdir="/usr/lib/pkgconfig" \
- $(if $(BR2_PACKAGE_NCURSES_TARGET_PROGS),,--without-progs) \
-+ $(if $(BR2_PACKAGE_NCURSES_TERMLIB),--with-termlib) \
- --without-manpages
-
- ifeq ($(BR2_STATIC_LIBS),y)
-@@ -65,7 +66,7 @@ NCURSES_TERMINFO_FILES = \
- ifeq ($(BR2_PACKAGE_NCURSES_WCHAR),y)
- NCURSES_CONF_OPTS += --enable-widec
- NCURSES_LIB_SUFFIX = w
--NCURSES_LIBS = ncurses menu panel form
-+NCURSES_LIBS = ncurses menu panel form $(if $(BR2_PACKAGE_NCURSES_TERMLIB),tinfo)
-
- define NCURSES_LINK_LIBS_STATIC
- $(foreach lib,$(NCURSES_LIBS:%=lib%), \
diff --git a/build/release/bincheck/buildroot/Config.in b/build/release/bincheck/buildroot/Config.in
deleted file mode 100644
index e69de29bb2d1..000000000000
diff --git a/build/release/bincheck/buildroot/board/qemu/common/fs-overlay/bincheck/.keep b/build/release/bincheck/buildroot/board/qemu/common/fs-overlay/bincheck/.keep
deleted file mode 100644
index e69de29bb2d1..000000000000
diff --git a/build/release/bincheck/buildroot/board/qemu/common/fs-overlay/etc/ssh/sshd_config b/build/release/bincheck/buildroot/board/qemu/common/fs-overlay/etc/ssh/sshd_config
deleted file mode 100644
index 5ae17a5a4d05..000000000000
--- a/build/release/bincheck/buildroot/board/qemu/common/fs-overlay/etc/ssh/sshd_config
+++ /dev/null
@@ -1,3 +0,0 @@
-PasswordAuthentication yes
-PermitEmptyPasswords yes
-PermitRootLogin yes
diff --git a/build/release/bincheck/buildroot/board/qemu/common/post-build.sh b/build/release/bincheck/buildroot/board/qemu/common/post-build.sh
deleted file mode 100755
index 6a4758d7d3ea..000000000000
--- a/build/release/bincheck/buildroot/board/qemu/common/post-build.sh
+++ /dev/null
@@ -1,6 +0,0 @@
-#!/bin/sh
-
-fstab=$TARGET_DIR/etc/fstab
-grep -q /bincheck "$fstab" || cat >> "$fstab" < /dev/null" EXIT
-
-for i in {0..4}
-do
- ssh true && break
- backoff=$((2 ** i))
- echo "VM not yet available; sleeping for $backoff seconds"
- sleep $backoff
-done
-
-ssh /bin/bash -s /bincheck/cockroach "$COCKROACH_VERSION" "$COCKROACH_SHA" < bincheck
+./bincheck ./mnt/cockroach "$COCKROACH_VERSION" "$COCKROACH_SHA"