Running as unit: rb-build-arm64_11-85051.service ==================================================================================== Sat Feb 22 09:05:44 UTC 2025 - running /srv/jenkins/bin/reproducible_build.sh (for job reproducible_builder_arm64_11) on jenkins, called using "codethink04-arm64 codethink03-arm64" as arguments. Sat Feb 22 09:05:44 UTC 2025 - actually running "reproducible_build.sh" (md5sum 68e686e434c9ab7bc3ec047d8b309cbc) as "/tmp/jenkins-script-ZTsFaq1t" $ git clone https://salsa.debian.org/qa/jenkins.debian.net.git ; more CONTRIBUTING Sat Feb 22 09:05:44 UTC 2025 - checking /var/lib/jenkins/offline_nodes if codethink04-arm64.debian.net is marked as down. Sat Feb 22 09:05:44 UTC 2025 - checking via ssh if codethink04-arm64.debian.net is up. removed '/tmp/read-only-fs-test-IbolLU' Sat Feb 22 09:05:44 UTC 2025 - checking /var/lib/jenkins/offline_nodes if codethink03-arm64.debian.net is marked as down. Sat Feb 22 09:05:44 UTC 2025 - checking via ssh if codethink03-arm64.debian.net is up. removed '/tmp/read-only-fs-test-IYcWwi' ok, let's check if golang-github-cloudflare-cbpfc is building anywhere yet… ok, golang-github-cloudflare-cbpfc is not building anywhere… UPDATE 1 ============================================================================= Initialising reproducibly build of golang-github-cloudflare-cbpfc in trixie on arm64 on jenkins now. 1st build will be done on codethink04-arm64.debian.net. 2nd build will be done on codethink03-arm64.debian.net. ============================================================================= Sat Feb 22 09:06:02 UTC 2025 I: starting to build golang-github-cloudflare-cbpfc/trixie/arm64 on jenkins on '2025-02-22 09:05' Sat Feb 22 09:06:02 UTC 2025 I: The jenkins build log is/was available at https://jenkins.debian.net/userContent/reproducible/debian/build_service/arm64_11/85051/console.log 1740215162 arm64 trixie golang-github-cloudflare-cbpfc Sat Feb 22 09:06:02 UTC 2025 I: Downloading source for trixie/golang-github-cloudflare-cbpfc=0.0~git20231012.992ed75-2 --2025-02-22 09:06:02-- http://deb.debian.org/debian/pool/main/g/golang-github-cloudflare-cbpfc/golang-github-cloudflare-cbpfc_0.0%7egit20231012.992ed75-2.dsc Connecting to 46.16.76.132:3128... connected. Proxy request sent, awaiting response... 200 OK Length: 2689 (2.6K) [text/prs.lines.tag] Saving to: ‘golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.dsc’ 0K .. 100% 312M=0s 2025-02-22 09:06:02 (312 MB/s) - ‘golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.dsc’ saved [2689/2689] --2025-02-22 09:06:02-- http://deb.debian.org/debian/pool/main/g/golang-github-cloudflare-cbpfc/golang-github-cloudflare-cbpfc_0.0%7egit20231012.992ed75-2.dsc Connecting to 46.16.76.132:3128... connected. Proxy request sent, awaiting response... 200 OK Length: 2689 (2.6K) [text/prs.lines.tag] Saving to: ‘golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.dsc’ 0K .. 100% 312M=0s 2025-02-22 09:06:02 (312 MB/s) - ‘golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.dsc’ saved [2689/2689] Sat Feb 22 09:06:02 UTC 2025 I: golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.dsc -----BEGIN PGP SIGNED MESSAGE----- Hash: SHA512 Format: 3.0 (quilt) Source: golang-github-cloudflare-cbpfc Binary: golang-github-cloudflare-cbpfc-dev Architecture: all Version: 0.0~git20231012.992ed75-2 Maintainer: Debian Go Packaging Team Uploaders: Loren M. Lang Homepage: https://github.com/cloudflare/cbpfc Standards-Version: 4.6.0 Vcs-Browser: https://salsa.debian.org/go-team/packages/golang-github-cloudflare-cbpfc Vcs-Git: https://salsa.debian.org/go-team/packages/golang-github-cloudflare-cbpfc.git Testsuite: autopkgtest-pkg-go Build-Depends: debhelper-compat (= 13), clang, dh-golang, golang-any, golang-github-cilium-ebpf-dev, golang-github-pkg-errors-dev, golang-golang-x-net-dev, golang-golang-x-sys-dev Package-List: golang-github-cloudflare-cbpfc-dev deb golang optional arch=all Checksums-Sha1: c2f16a8167a678064827c9609fbc4d60ba22a4b2 28986 golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75.orig.tar.gz 297e474c7eb28383cd666a8ad481ae1122b9010d 3100 golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.debian.tar.xz Checksums-Sha256: 9d3a0a399816970fe0c288a323fe6c001ccde636770ac8aa636dbe69ed541c8f 28986 golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75.orig.tar.gz f4b5a128a8b084c30676ab5308fc5391b29f3c5f96af698ac8cf51eadb721a4b 3100 golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.debian.tar.xz Files: adcd99212645e3ede9daac2b3f1c52a8 28986 golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75.orig.tar.gz a7b90274ffda83b0c9449a5992c36511 3100 golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.debian.tar.xz Go-Import-Path: github.com/cloudflare/cbpfc Dgit: 5c10a663e750dd6a02e8eb018190cbdeeac868bb debian archive/debian/0.0_git20231012.992ed75-2 https://git.dgit.debian.org/golang-github-cloudflare-cbpfc -----BEGIN PGP SIGNATURE----- iQJIBAEBCgAyFiEEMN59F2OrlFLH4IJQSadpd5QoJssFAmZ9WukUHHNpcmV0YXJ0 QHRhdXdhcmUuZGUACgkQSadpd5QoJssM8w//eo/FIDGbFfQ3uMf5s1F0YAJuuyG4 VWmBjO4SN5g+qDXOMn9zuUnyuO97QZtNrw2Ja/+bO8CLtq5igLEonyD7CsEAInXC 3kWs3MnGBh7IY2MIdxDaxgiT4QddzMvj7FD9gOoPbcxfGg41rthOhZeBiLFUwp7K 3BvZUIp5S2Hu3BI0jP/R/XdwLjaamsVUO9M7/zhSK21Hw9Z7wHMe2nGChhpzUBtL ieVJIGcH1YhpRwCpOh9H4FweRHhOVCaqoDbC6WRLAUMrzSv3AIXYQGAXPT8389gJ YhTckwmzXfjjenJeudrpD3ccm3IIAho9w1vYzPZg8M70tmjEz1upeydYne8d1Dtm lo8PnUFsFu4SeQV4cAXm8JnolHUxQUqIhMVpgUnf1b31dHT62kIjy6b5n9qDvSOU 1jaIdVnMSVyIdlPfS6ijR+jveM6RClXGIZnWp8Wedfn6pcmQJGzy2hD4xz3tNpG4 s58PFMxFW5usbfSEZlCXSo+eREYkhVy0Ek59zRStsl/qjWt87mw7dckuzksgRS0D gzViRNkhFVptxFrTBD2+AdH4WPVdYky8Dg3sNB+5x+oQoF0mmG6aUucRDAxZwS9i yN/QDPeiOTrAoqs0A5jGA14ZowL072+NOEfcMM7IsxSLdzCNQoZ+y2NdNpKfOKX7 kHZwwElF2RZtlpI= =SGCp -----END PGP SIGNATURE----- Sat Feb 22 09:06:02 UTC 2025 I: Checking whether the package is not for us Sat Feb 22 09:06:02 UTC 2025 I: Starting 1st build on remote node codethink04-arm64.debian.net. Sat Feb 22 09:06:02 UTC 2025 I: Preparing to do remote build '1' on codethink04-arm64.debian.net. Sat Feb 22 09:06:02 UTC 2025 - checking /var/lib/jenkins/offline_nodes if codethink04-arm64.debian.net is marked as down. Sat Feb 22 09:06:02 UTC 2025 - checking via ssh if codethink04-arm64.debian.net is up. removed '/tmp/read-only-fs-test-GCxl15' ==================================================================================== Sat Feb 22 09:06:04 UTC 2025 - running /srv/jenkins/bin/reproducible_build.sh (for job /srv/jenkins/bin/reproducible_build.sh) on codethink04-arm64, called using "1 golang-github-cloudflare-cbpfc trixie /srv/reproducible-results/rbuild-debian/r-b-build.bvEh5Q9U 0.0~git20231012.992ed75-2" as arguments. Sat Feb 22 09:06:04 UTC 2025 - actually running "reproducible_build.sh" (md5sum 68e686e434c9ab7bc3ec047d8b309cbc) as "/tmp/jenkins-script-hyEKHSrk" $ git clone https://salsa.debian.org/qa/jenkins.debian.net.git ; more CONTRIBUTING Sat Feb 22 09:06:04 UTC 2025 I: Downloading source for trixie/golang-github-cloudflare-cbpfc=0.0~git20231012.992ed75-2 Reading package lists... NOTICE: 'golang-github-cloudflare-cbpfc' packaging is maintained in the 'Git' version control system at: https://salsa.debian.org/go-team/packages/golang-github-cloudflare-cbpfc.git Please use: git clone https://salsa.debian.org/go-team/packages/golang-github-cloudflare-cbpfc.git to retrieve the latest (possibly unreleased) updates to the package. Need to get 34.8 kB of source archives. Get:1 http://deb.debian.org/debian trixie/main golang-github-cloudflare-cbpfc 0.0~git20231012.992ed75-2 (dsc) [2689 B] Get:2 http://deb.debian.org/debian trixie/main golang-github-cloudflare-cbpfc 0.0~git20231012.992ed75-2 (tar) [29.0 kB] Get:3 http://deb.debian.org/debian trixie/main golang-github-cloudflare-cbpfc 0.0~git20231012.992ed75-2 (diff) [3100 B] Fetched 34.8 kB in 0s (381 kB/s) Download complete and in download only mode Reading package lists... NOTICE: 'golang-github-cloudflare-cbpfc' packaging is maintained in the 'Git' version control system at: https://salsa.debian.org/go-team/packages/golang-github-cloudflare-cbpfc.git Please use: git clone https://salsa.debian.org/go-team/packages/golang-github-cloudflare-cbpfc.git to retrieve the latest (possibly unreleased) updates to the package. Need to get 34.8 kB of source archives. Get:1 http://deb.debian.org/debian trixie/main golang-github-cloudflare-cbpfc 0.0~git20231012.992ed75-2 (dsc) [2689 B] Get:2 http://deb.debian.org/debian trixie/main golang-github-cloudflare-cbpfc 0.0~git20231012.992ed75-2 (tar) [29.0 kB] Get:3 http://deb.debian.org/debian trixie/main golang-github-cloudflare-cbpfc 0.0~git20231012.992ed75-2 (diff) [3100 B] Fetched 34.8 kB in 0s (381 kB/s) Download complete and in download only mode ============================================================================= Building golang-github-cloudflare-cbpfc in trixie on arm64 on codethink04-arm64 now. Date: Sat Feb 22 09:06:04 GMT 2025 Date UTC: Sat Feb 22 09:06:04 UTC 2025 ============================================================================= W: /root/.pbuilderrc does not exist I: Logging to b1/build.log I: pbuilder: network access will be disabled during build I: Current time: Fri Feb 21 21:06:04 -12 2025 I: pbuilder-time-stamp: 1740215164 I: Building the build Environment I: extracting base tarball [/var/cache/pbuilder/trixie-reproducible-base.tgz] I: copying local configuration W: --override-config is not set; not updating apt.conf Read the manpage for details. I: mounting /proc filesystem I: mounting /sys filesystem I: creating /{dev,run}/shm I: mounting /dev/pts filesystem I: redirecting /dev/ptmx to /dev/pts/ptmx I: policy-rc.d already exists I: Copying source file I: copying [golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.dsc] I: copying [./golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75.orig.tar.gz] I: copying [./golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.debian.tar.xz] I: Extracting source dpkg-source: warning: cannot verify inline signature for ./golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.dsc: unsupported subcommand dpkg-source: info: extracting golang-github-cloudflare-cbpfc in golang-github-cloudflare-cbpfc-0.0~git20231012.992ed75 dpkg-source: info: unpacking golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75.orig.tar.gz dpkg-source: info: unpacking golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.debian.tar.xz dpkg-source: info: using patch list from debian/patches/series dpkg-source: info: applying auto-gitignore I: Not using root during the build. I: Installing the build-deps I: user script /srv/workspace/pbuilder/2165263/tmp/hooks/D02_print_environment starting I: set BUILDDIR='/build/reproducible-path' BUILDUSERGECOS='first user,first room,first work-phone,first home-phone,first other' BUILDUSERNAME='pbuilder1' BUILD_ARCH='arm64' DEBIAN_FRONTEND='noninteractive' DEB_BUILD_OPTIONS='buildinfo=+all reproducible=+all parallel=12 ' DISTRIBUTION='trixie' HOME='/root' HOST_ARCH='arm64' IFS=' ' INVOCATION_ID='e5e12366e69441d9acc7a55619923dfc' LANG='C' LANGUAGE='en_US:en' LC_ALL='C' MAIL='/var/mail/root' OPTIND='1' PATH='/usr/sbin:/usr/bin:/sbin:/bin:/usr/games' PBCURRENTCOMMANDLINEOPERATION='build' PBUILDER_OPERATION='build' PBUILDER_PKGDATADIR='/usr/share/pbuilder' PBUILDER_PKGLIBDIR='/usr/lib/pbuilder' PBUILDER_SYSCONFDIR='/etc' PPID='2165263' PS1='# ' PS2='> ' PS4='+ ' PWD='/' SHELL='/bin/bash' SHLVL='2' SUDO_COMMAND='/usr/bin/timeout -k 18.1h 18h /usr/bin/ionice -c 3 /usr/bin/nice /usr/sbin/pbuilder --build --configfile /srv/reproducible-results/rbuild-debian/r-b-build.bvEh5Q9U/pbuilderrc_UIik --distribution trixie --hookdir /etc/pbuilder/first-build-hooks --debbuildopts -b --basetgz /var/cache/pbuilder/trixie-reproducible-base.tgz --buildresult /srv/reproducible-results/rbuild-debian/r-b-build.bvEh5Q9U/b1 --logfile b1/build.log golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.dsc' SUDO_GID='109' SUDO_UID='104' SUDO_USER='jenkins' TERM='unknown' TZ='/usr/share/zoneinfo/Etc/GMT+12' USER='root' _='/usr/bin/systemd-run' http_proxy='http://192.168.101.4:3128' I: uname -a Linux codethink04-arm64 6.1.0-31-cloud-arm64 #1 SMP Debian 6.1.128-1 (2025-02-07) aarch64 GNU/Linux I: ls -l /bin lrwxrwxrwx 1 root root 7 Nov 22 14:40 /bin -> usr/bin I: user script /srv/workspace/pbuilder/2165263/tmp/hooks/D02_print_environment finished -> Attempting to satisfy build-dependencies -> Creating pbuilder-satisfydepends-dummy package Package: pbuilder-satisfydepends-dummy Version: 0.invalid.0 Architecture: arm64 Maintainer: Debian Pbuilder Team Description: Dummy package to satisfy dependencies with aptitude - created by pbuilder This package was created automatically by pbuilder to satisfy the build-dependencies of the package being currently built. Depends: debhelper-compat (= 13), clang, dh-golang, golang-any, golang-github-cilium-ebpf-dev, golang-github-pkg-errors-dev, golang-golang-x-net-dev, golang-golang-x-sys-dev dpkg-deb: building package 'pbuilder-satisfydepends-dummy' in '/tmp/satisfydepends-aptitude/pbuilder-satisfydepends-dummy.deb'. Selecting previously unselected package pbuilder-satisfydepends-dummy. (Reading database ... 19972 files and directories currently installed.) Preparing to unpack .../pbuilder-satisfydepends-dummy.deb ... Unpacking pbuilder-satisfydepends-dummy (0.invalid.0) ... dpkg: pbuilder-satisfydepends-dummy: dependency problems, but configuring anyway as you requested: pbuilder-satisfydepends-dummy depends on debhelper-compat (= 13); however: Package debhelper-compat is not installed. pbuilder-satisfydepends-dummy depends on clang; however: Package clang is not installed. pbuilder-satisfydepends-dummy depends on dh-golang; however: Package dh-golang is not installed. pbuilder-satisfydepends-dummy depends on golang-any; however: Package golang-any is not installed. pbuilder-satisfydepends-dummy depends on golang-github-cilium-ebpf-dev; however: Package golang-github-cilium-ebpf-dev is not installed. pbuilder-satisfydepends-dummy depends on golang-github-pkg-errors-dev; however: Package golang-github-pkg-errors-dev is not installed. pbuilder-satisfydepends-dummy depends on golang-golang-x-net-dev; however: Package golang-golang-x-net-dev is not installed. pbuilder-satisfydepends-dummy depends on golang-golang-x-sys-dev; however: Package golang-golang-x-sys-dev is not installed. Setting up pbuilder-satisfydepends-dummy (0.invalid.0) ... Reading package lists... Building dependency tree... Reading state information... Initializing package states... Writing extended state information... Building tag database... pbuilder-satisfydepends-dummy is already installed at the requested version (0.invalid.0) pbuilder-satisfydepends-dummy is already installed at the requested version (0.invalid.0) The following NEW packages will be installed: autoconf{a} automake{a} autopoint{a} autotools-dev{a} binutils-gold{a} binutils-gold-aarch64-linux-gnu{a} bsdextrautils{a} clang{a} clang-19{a} debhelper{a} dh-autoreconf{a} dh-golang{a} dh-strip-nondeterminism{a} dwz{a} file{a} gettext{a} gettext-base{a} golang-1.24-go{a} golang-1.24-src{a} golang-any{a} golang-github-cilium-ebpf-dev{a} golang-github-pkg-errors-dev{a} golang-go{a} golang-golang-x-crypto-dev{a} golang-golang-x-exp-dev{a} golang-golang-x-net-dev{a} golang-golang-x-sys-dev{a} golang-golang-x-term-dev{a} golang-golang-x-text-dev{a} golang-src{a} groff-base{a} intltool-debian{a} libarchive-zip-perl{a} libclang-common-19-dev{a} libclang-cpp19{a} libclang1-19{a} libdebhelper-perl{a} libedit2{a} libelf1t64{a} libffi8{a} libfile-stripnondeterminism-perl{a} libgc1{a} libicu72{a} libllvm19{a} libmagic-mgc{a} libmagic1t64{a} libobjc-14-dev{a} libobjc4{a} libpipeline1{a} libtool{a} libuchardet0{a} libunistring5{a} libxml2{a} libz3-4{a} llvm-19-linker-tools{a} m4{a} man-db{a} po-debconf{a} sensible-utils{a} The following packages are RECOMMENDED but will NOT be installed: curl libarchive-cpio-perl libclang-rt-19-dev libltdl-dev libmail-sendmail-perl llvm-19-dev lynx pkgconf python3 wget 0 packages upgraded, 59 newly installed, 0 to remove and 0 not upgraded. Need to get 128 MB of archives. After unpacking 685 MB will be used. Writing extended state information... Get: 1 http://deb.debian.org/debian trixie/main arm64 sensible-utils all 0.0.24 [24.8 kB] Get: 2 http://deb.debian.org/debian trixie/main arm64 libmagic-mgc arm64 1:5.45-3+b1 [314 kB] Get: 3 http://deb.debian.org/debian trixie/main arm64 libmagic1t64 arm64 1:5.45-3+b1 [102 kB] Get: 4 http://deb.debian.org/debian trixie/main arm64 file arm64 1:5.45-3+b1 [43.4 kB] Get: 5 http://deb.debian.org/debian trixie/main arm64 gettext-base arm64 0.23.1-1 [241 kB] Get: 6 http://deb.debian.org/debian trixie/main arm64 libuchardet0 arm64 0.0.8-1+b2 [69.2 kB] Get: 7 http://deb.debian.org/debian trixie/main arm64 groff-base arm64 1.23.0-7 [1129 kB] Get: 8 http://deb.debian.org/debian trixie/main arm64 bsdextrautils arm64 2.40.4-3 [92.0 kB] Get: 9 http://deb.debian.org/debian trixie/main arm64 libpipeline1 arm64 1.5.8-1 [40.2 kB] Get: 10 http://deb.debian.org/debian trixie/main arm64 man-db arm64 2.13.0-1 [1404 kB] Get: 11 http://deb.debian.org/debian trixie/main arm64 m4 arm64 1.4.19-5 [284 kB] Get: 12 http://deb.debian.org/debian trixie/main arm64 autoconf all 2.72-3 [493 kB] Get: 13 http://deb.debian.org/debian trixie/main arm64 autotools-dev all 20220109.1 [51.6 kB] Get: 14 http://deb.debian.org/debian trixie/main arm64 automake all 1:1.17-3 [862 kB] Get: 15 http://deb.debian.org/debian trixie/main arm64 autopoint all 0.23.1-1 [770 kB] Get: 16 http://deb.debian.org/debian trixie/main arm64 binutils-gold-aarch64-linux-gnu arm64 2.44-1 [1704 kB] Get: 17 http://deb.debian.org/debian trixie/main arm64 binutils-gold arm64 2.44-1 [202 kB] Get: 18 http://deb.debian.org/debian trixie/main arm64 libedit2 arm64 3.1-20250104-1 [89.3 kB] Get: 19 http://deb.debian.org/debian trixie/main arm64 libffi8 arm64 3.4.7-1 [21.2 kB] Get: 20 http://deb.debian.org/debian trixie/main arm64 libicu72 arm64 72.1-6 [9239 kB] Get: 21 http://deb.debian.org/debian trixie/main arm64 libxml2 arm64 2.12.7+dfsg+really2.9.14-0.2+b1 [630 kB] Get: 22 http://deb.debian.org/debian trixie/main arm64 libz3-4 arm64 4.13.3-1 [7507 kB] Get: 23 http://deb.debian.org/debian trixie/main arm64 libllvm19 arm64 1:19.1.7-1+b1 [23.3 MB] Get: 24 http://deb.debian.org/debian trixie/main arm64 libclang-cpp19 arm64 1:19.1.7-1+b1 [12.0 MB] Get: 25 http://deb.debian.org/debian trixie/main arm64 libgc1 arm64 1:8.2.8-1 [241 kB] Get: 26 http://deb.debian.org/debian trixie/main arm64 libobjc4 arm64 14.2.0-16 [39.4 kB] Get: 27 http://deb.debian.org/debian trixie/main arm64 libobjc-14-dev arm64 14.2.0-16 [166 kB] Get: 28 http://deb.debian.org/debian trixie/main arm64 libclang-common-19-dev arm64 1:19.1.7-1+b1 [740 kB] Get: 29 http://deb.debian.org/debian trixie/main arm64 llvm-19-linker-tools arm64 1:19.1.7-1+b1 [1100 kB] Get: 30 http://deb.debian.org/debian trixie/main arm64 libclang1-19 arm64 1:19.1.7-1+b1 [6851 kB] Get: 31 http://deb.debian.org/debian trixie/main arm64 clang-19 arm64 1:19.1.7-1+b1 [112 kB] Get: 32 http://deb.debian.org/debian trixie/main arm64 clang arm64 1:19.0-63 [6244 B] Get: 33 http://deb.debian.org/debian trixie/main arm64 libdebhelper-perl all 13.24.1 [90.9 kB] Get: 34 http://deb.debian.org/debian trixie/main arm64 libtool all 2.5.4-3 [539 kB] Get: 35 http://deb.debian.org/debian trixie/main arm64 dh-autoreconf all 20 [17.1 kB] Get: 36 http://deb.debian.org/debian trixie/main arm64 libarchive-zip-perl all 1.68-1 [104 kB] Get: 37 http://deb.debian.org/debian trixie/main arm64 libfile-stripnondeterminism-perl all 1.14.1-2 [19.7 kB] Get: 38 http://deb.debian.org/debian trixie/main arm64 dh-strip-nondeterminism all 1.14.1-2 [8620 B] Get: 39 http://deb.debian.org/debian trixie/main arm64 libelf1t64 arm64 0.192-4 [189 kB] Get: 40 http://deb.debian.org/debian trixie/main arm64 dwz arm64 0.15-1+b1 [102 kB] Get: 41 http://deb.debian.org/debian trixie/main arm64 libunistring5 arm64 1.3-1 [449 kB] Get: 42 http://deb.debian.org/debian trixie/main arm64 gettext arm64 0.23.1-1 [1610 kB] Get: 43 http://deb.debian.org/debian trixie/main arm64 intltool-debian all 0.35.0+20060710.6 [22.9 kB] Get: 44 http://deb.debian.org/debian trixie/main arm64 po-debconf all 1.0.21+nmu1 [248 kB] Get: 45 http://deb.debian.org/debian trixie/main arm64 debhelper all 13.24.1 [920 kB] Get: 46 http://deb.debian.org/debian trixie/main arm64 dh-golang all 1.63 [24.4 kB] Get: 47 http://deb.debian.org/debian trixie/main arm64 golang-1.24-src all 1.24.0-1 [20.3 MB] Get: 48 http://deb.debian.org/debian trixie/main arm64 golang-1.24-go arm64 1.24.0-1 [24.6 MB] Get: 49 http://deb.debian.org/debian trixie/main arm64 golang-src all 2:1.24~2 [5136 B] Get: 50 http://deb.debian.org/debian trixie/main arm64 golang-go arm64 2:1.24~2 [44.3 kB] Get: 51 http://deb.debian.org/debian trixie/main arm64 golang-any arm64 2:1.24~2 [5216 B] Get: 52 http://deb.debian.org/debian trixie/main arm64 golang-golang-x-exp-dev all 0.0~git20231006.7918f67-1 [105 kB] Get: 53 http://deb.debian.org/debian trixie/main arm64 golang-golang-x-sys-dev all 0.22.0-1 [431 kB] Get: 54 http://deb.debian.org/debian trixie/main arm64 golang-github-cilium-ebpf-dev all 0.11.0-2 [1793 kB] Get: 55 http://deb.debian.org/debian trixie/main arm64 golang-github-pkg-errors-dev all 0.9.1-3 [12.9 kB] Get: 56 http://deb.debian.org/debian trixie/main arm64 golang-golang-x-term-dev all 0.22.0-1 [14.8 kB] Get: 57 http://deb.debian.org/debian trixie/main arm64 golang-golang-x-text-dev all 0.22.0-1 [3995 kB] Get: 58 http://deb.debian.org/debian trixie/main arm64 golang-golang-x-crypto-dev all 1:0.25.0-1 [1682 kB] Get: 59 http://deb.debian.org/debian trixie/main arm64 golang-golang-x-net-dev all 1:0.27.0-1 [898 kB] Fetched 128 MB in 1s (233 MB/s) Preconfiguring packages ... Selecting previously unselected package sensible-utils. (Reading database ... (Reading database ... 5% (Reading database ... 10% (Reading database ... 15% (Reading database ... 20% (Reading database ... 25% (Reading database ... 30% (Reading database ... 35% (Reading database ... 40% (Reading database ... 45% (Reading database ... 50% (Reading database ... 55% (Reading database ... 60% (Reading database ... 65% (Reading database ... 70% (Reading database ... 75% (Reading database ... 80% (Reading database ... 85% (Reading database ... 90% (Reading database ... 95% (Reading database ... 100% (Reading database ... 19972 files and directories currently installed.) Preparing to unpack .../00-sensible-utils_0.0.24_all.deb ... Unpacking sensible-utils (0.0.24) ... Selecting previously unselected package libmagic-mgc. Preparing to unpack .../01-libmagic-mgc_1%3a5.45-3+b1_arm64.deb ... Unpacking libmagic-mgc (1:5.45-3+b1) ... Selecting previously unselected package libmagic1t64:arm64. Preparing to unpack .../02-libmagic1t64_1%3a5.45-3+b1_arm64.deb ... Unpacking libmagic1t64:arm64 (1:5.45-3+b1) ... Selecting previously unselected package file. Preparing to unpack .../03-file_1%3a5.45-3+b1_arm64.deb ... Unpacking file (1:5.45-3+b1) ... Selecting previously unselected package gettext-base. Preparing to unpack .../04-gettext-base_0.23.1-1_arm64.deb ... Unpacking gettext-base (0.23.1-1) ... Selecting previously unselected package libuchardet0:arm64. Preparing to unpack .../05-libuchardet0_0.0.8-1+b2_arm64.deb ... Unpacking libuchardet0:arm64 (0.0.8-1+b2) ... Selecting previously unselected package groff-base. Preparing to unpack .../06-groff-base_1.23.0-7_arm64.deb ... Unpacking groff-base (1.23.0-7) ... Selecting previously unselected package bsdextrautils. Preparing to unpack .../07-bsdextrautils_2.40.4-3_arm64.deb ... Unpacking bsdextrautils (2.40.4-3) ... Selecting previously unselected package libpipeline1:arm64. Preparing to unpack .../08-libpipeline1_1.5.8-1_arm64.deb ... Unpacking libpipeline1:arm64 (1.5.8-1) ... Selecting previously unselected package man-db. Preparing to unpack .../09-man-db_2.13.0-1_arm64.deb ... Unpacking man-db (2.13.0-1) ... Selecting previously unselected package m4. Preparing to unpack .../10-m4_1.4.19-5_arm64.deb ... Unpacking m4 (1.4.19-5) ... Selecting previously unselected package autoconf. Preparing to unpack .../11-autoconf_2.72-3_all.deb ... Unpacking autoconf (2.72-3) ... Selecting previously unselected package autotools-dev. Preparing to unpack .../12-autotools-dev_20220109.1_all.deb ... Unpacking autotools-dev (20220109.1) ... Selecting previously unselected package automake. Preparing to unpack .../13-automake_1%3a1.17-3_all.deb ... Unpacking automake (1:1.17-3) ... Selecting previously unselected package autopoint. Preparing to unpack .../14-autopoint_0.23.1-1_all.deb ... Unpacking autopoint (0.23.1-1) ... Selecting previously unselected package binutils-gold-aarch64-linux-gnu. Preparing to unpack .../15-binutils-gold-aarch64-linux-gnu_2.44-1_arm64.deb ... Unpacking binutils-gold-aarch64-linux-gnu (2.44-1) ... Selecting previously unselected package binutils-gold. Preparing to unpack .../16-binutils-gold_2.44-1_arm64.deb ... Unpacking binutils-gold (2.44-1) ... Selecting previously unselected package libedit2:arm64. Preparing to unpack .../17-libedit2_3.1-20250104-1_arm64.deb ... Unpacking libedit2:arm64 (3.1-20250104-1) ... Selecting previously unselected package libffi8:arm64. Preparing to unpack .../18-libffi8_3.4.7-1_arm64.deb ... Unpacking libffi8:arm64 (3.4.7-1) ... Selecting previously unselected package libicu72:arm64. Preparing to unpack .../19-libicu72_72.1-6_arm64.deb ... Unpacking libicu72:arm64 (72.1-6) ... Selecting previously unselected package libxml2:arm64. Preparing to unpack .../20-libxml2_2.12.7+dfsg+really2.9.14-0.2+b1_arm64.deb ... Unpacking libxml2:arm64 (2.12.7+dfsg+really2.9.14-0.2+b1) ... Selecting previously unselected package libz3-4:arm64. Preparing to unpack .../21-libz3-4_4.13.3-1_arm64.deb ... Unpacking libz3-4:arm64 (4.13.3-1) ... Selecting previously unselected package libllvm19:arm64. Preparing to unpack .../22-libllvm19_1%3a19.1.7-1+b1_arm64.deb ... Unpacking libllvm19:arm64 (1:19.1.7-1+b1) ... Selecting previously unselected package libclang-cpp19. Preparing to unpack .../23-libclang-cpp19_1%3a19.1.7-1+b1_arm64.deb ... Unpacking libclang-cpp19 (1:19.1.7-1+b1) ... Selecting previously unselected package libgc1:arm64. Preparing to unpack .../24-libgc1_1%3a8.2.8-1_arm64.deb ... Unpacking libgc1:arm64 (1:8.2.8-1) ... Selecting previously unselected package libobjc4:arm64. Preparing to unpack .../25-libobjc4_14.2.0-16_arm64.deb ... Unpacking libobjc4:arm64 (14.2.0-16) ... Selecting previously unselected package libobjc-14-dev:arm64. Preparing to unpack .../26-libobjc-14-dev_14.2.0-16_arm64.deb ... Unpacking libobjc-14-dev:arm64 (14.2.0-16) ... Selecting previously unselected package libclang-common-19-dev:arm64. Preparing to unpack .../27-libclang-common-19-dev_1%3a19.1.7-1+b1_arm64.deb ... Unpacking libclang-common-19-dev:arm64 (1:19.1.7-1+b1) ... Selecting previously unselected package llvm-19-linker-tools. Preparing to unpack .../28-llvm-19-linker-tools_1%3a19.1.7-1+b1_arm64.deb ... Unpacking llvm-19-linker-tools (1:19.1.7-1+b1) ... Selecting previously unselected package libclang1-19. Preparing to unpack .../29-libclang1-19_1%3a19.1.7-1+b1_arm64.deb ... Unpacking libclang1-19 (1:19.1.7-1+b1) ... Selecting previously unselected package clang-19. Preparing to unpack .../30-clang-19_1%3a19.1.7-1+b1_arm64.deb ... Unpacking clang-19 (1:19.1.7-1+b1) ... Selecting previously unselected package clang. Preparing to unpack .../31-clang_1%3a19.0-63_arm64.deb ... Unpacking clang (1:19.0-63) ... Selecting previously unselected package libdebhelper-perl. Preparing to unpack .../32-libdebhelper-perl_13.24.1_all.deb ... Unpacking libdebhelper-perl (13.24.1) ... Selecting previously unselected package libtool. Preparing to unpack .../33-libtool_2.5.4-3_all.deb ... Unpacking libtool (2.5.4-3) ... Selecting previously unselected package dh-autoreconf. Preparing to unpack .../34-dh-autoreconf_20_all.deb ... Unpacking dh-autoreconf (20) ... Selecting previously unselected package libarchive-zip-perl. Preparing to unpack .../35-libarchive-zip-perl_1.68-1_all.deb ... Unpacking libarchive-zip-perl (1.68-1) ... Selecting previously unselected package libfile-stripnondeterminism-perl. Preparing to unpack .../36-libfile-stripnondeterminism-perl_1.14.1-2_all.deb ... Unpacking libfile-stripnondeterminism-perl (1.14.1-2) ... Selecting previously unselected package dh-strip-nondeterminism. Preparing to unpack .../37-dh-strip-nondeterminism_1.14.1-2_all.deb ... Unpacking dh-strip-nondeterminism (1.14.1-2) ... Selecting previously unselected package libelf1t64:arm64. Preparing to unpack .../38-libelf1t64_0.192-4_arm64.deb ... Unpacking libelf1t64:arm64 (0.192-4) ... Selecting previously unselected package dwz. Preparing to unpack .../39-dwz_0.15-1+b1_arm64.deb ... Unpacking dwz (0.15-1+b1) ... Selecting previously unselected package libunistring5:arm64. Preparing to unpack .../40-libunistring5_1.3-1_arm64.deb ... Unpacking libunistring5:arm64 (1.3-1) ... Selecting previously unselected package gettext. Preparing to unpack .../41-gettext_0.23.1-1_arm64.deb ... Unpacking gettext (0.23.1-1) ... Selecting previously unselected package intltool-debian. Preparing to unpack .../42-intltool-debian_0.35.0+20060710.6_all.deb ... Unpacking intltool-debian (0.35.0+20060710.6) ... Selecting previously unselected package po-debconf. Preparing to unpack .../43-po-debconf_1.0.21+nmu1_all.deb ... Unpacking po-debconf (1.0.21+nmu1) ... Selecting previously unselected package debhelper. Preparing to unpack .../44-debhelper_13.24.1_all.deb ... Unpacking debhelper (13.24.1) ... Selecting previously unselected package dh-golang. Preparing to unpack .../45-dh-golang_1.63_all.deb ... Unpacking dh-golang (1.63) ... Selecting previously unselected package golang-1.24-src. Preparing to unpack .../46-golang-1.24-src_1.24.0-1_all.deb ... Unpacking golang-1.24-src (1.24.0-1) ... Selecting previously unselected package golang-1.24-go. Preparing to unpack .../47-golang-1.24-go_1.24.0-1_arm64.deb ... Unpacking golang-1.24-go (1.24.0-1) ... Selecting previously unselected package golang-src. Preparing to unpack .../48-golang-src_2%3a1.24~2_all.deb ... Unpacking golang-src (2:1.24~2) ... Selecting previously unselected package golang-go:arm64. Preparing to unpack .../49-golang-go_2%3a1.24~2_arm64.deb ... Unpacking golang-go:arm64 (2:1.24~2) ... Selecting previously unselected package golang-any:arm64. Preparing to unpack .../50-golang-any_2%3a1.24~2_arm64.deb ... Unpacking golang-any:arm64 (2:1.24~2) ... Selecting previously unselected package golang-golang-x-exp-dev. Preparing to unpack .../51-golang-golang-x-exp-dev_0.0~git20231006.7918f67-1_all.deb ... Unpacking golang-golang-x-exp-dev (0.0~git20231006.7918f67-1) ... Selecting previously unselected package golang-golang-x-sys-dev. Preparing to unpack .../52-golang-golang-x-sys-dev_0.22.0-1_all.deb ... Unpacking golang-golang-x-sys-dev (0.22.0-1) ... Selecting previously unselected package golang-github-cilium-ebpf-dev. Preparing to unpack .../53-golang-github-cilium-ebpf-dev_0.11.0-2_all.deb ... Unpacking golang-github-cilium-ebpf-dev (0.11.0-2) ... Selecting previously unselected package golang-github-pkg-errors-dev. Preparing to unpack .../54-golang-github-pkg-errors-dev_0.9.1-3_all.deb ... Unpacking golang-github-pkg-errors-dev (0.9.1-3) ... Selecting previously unselected package golang-golang-x-term-dev. Preparing to unpack .../55-golang-golang-x-term-dev_0.22.0-1_all.deb ... Unpacking golang-golang-x-term-dev (0.22.0-1) ... Selecting previously unselected package golang-golang-x-text-dev. Preparing to unpack .../56-golang-golang-x-text-dev_0.22.0-1_all.deb ... Unpacking golang-golang-x-text-dev (0.22.0-1) ... Selecting previously unselected package golang-golang-x-crypto-dev. Preparing to unpack .../57-golang-golang-x-crypto-dev_1%3a0.25.0-1_all.deb ... Unpacking golang-golang-x-crypto-dev (1:0.25.0-1) ... Selecting previously unselected package golang-golang-x-net-dev. Preparing to unpack .../58-golang-golang-x-net-dev_1%3a0.27.0-1_all.deb ... Unpacking golang-golang-x-net-dev (1:0.27.0-1) ... Setting up golang-1.24-src (1.24.0-1) ... Setting up libpipeline1:arm64 (1.5.8-1) ... Setting up libicu72:arm64 (72.1-6) ... Setting up bsdextrautils (2.40.4-3) ... Setting up libmagic-mgc (1:5.45-3+b1) ... Setting up libclang-common-19-dev:arm64 (1:19.1.7-1+b1) ... Setting up golang-github-pkg-errors-dev (0.9.1-3) ... Setting up libarchive-zip-perl (1.68-1) ... Setting up libdebhelper-perl (13.24.1) ... Setting up libedit2:arm64 (3.1-20250104-1) ... Setting up golang-golang-x-sys-dev (0.22.0-1) ... Setting up libmagic1t64:arm64 (1:5.45-3+b1) ... Setting up gettext-base (0.23.1-1) ... Setting up m4 (1.4.19-5) ... Setting up binutils-gold-aarch64-linux-gnu (2.44-1) ... Setting up golang-golang-x-term-dev (0.22.0-1) ... Setting up file (1:5.45-3+b1) ... Setting up libelf1t64:arm64 (0.192-4) ... Setting up autotools-dev (20220109.1) ... Setting up libz3-4:arm64 (4.13.3-1) ... Setting up libunistring5:arm64 (1.3-1) ... Setting up autopoint (0.23.1-1) ... Setting up libgc1:arm64 (1:8.2.8-1) ... Setting up autoconf (2.72-3) ... Setting up libffi8:arm64 (3.4.7-1) ... Setting up dwz (0.15-1+b1) ... Setting up sensible-utils (0.0.24) ... Setting up golang-golang-x-text-dev (0.22.0-1) ... Setting up libuchardet0:arm64 (0.0.8-1+b2) ... Setting up golang-golang-x-crypto-dev (1:0.25.0-1) ... Setting up golang-golang-x-exp-dev (0.0~git20231006.7918f67-1) ... Setting up golang-src (2:1.24~2) ... Setting up libxml2:arm64 (2.12.7+dfsg+really2.9.14-0.2+b1) ... Setting up automake (1:1.17-3) ... update-alternatives: using /usr/bin/automake-1.17 to provide /usr/bin/automake (automake) in auto mode Setting up libfile-stripnondeterminism-perl (1.14.1-2) ... Setting up libllvm19:arm64 (1:19.1.7-1+b1) ... Setting up gettext (0.23.1-1) ... Setting up libclang1-19 (1:19.1.7-1+b1) ... Setting up libtool (2.5.4-3) ... Setting up binutils-gold (2.44-1) ... Setting up golang-github-cilium-ebpf-dev (0.11.0-2) ... Setting up libobjc4:arm64 (14.2.0-16) ... Setting up libobjc-14-dev:arm64 (14.2.0-16) ... Setting up intltool-debian (0.35.0+20060710.6) ... Setting up dh-autoreconf (20) ... Setting up golang-1.24-go (1.24.0-1) ... Setting up golang-golang-x-net-dev (1:0.27.0-1) ... Setting up dh-strip-nondeterminism (1.14.1-2) ... Setting up groff-base (1.23.0-7) ... Setting up llvm-19-linker-tools (1:19.1.7-1+b1) ... Setting up libclang-cpp19 (1:19.1.7-1+b1) ... Setting up golang-go:arm64 (2:1.24~2) ... Setting up po-debconf (1.0.21+nmu1) ... Setting up man-db (2.13.0-1) ... Not building database; man-db/auto-update is not 'true'. Setting up clang-19 (1:19.1.7-1+b1) ... Setting up golang-any:arm64 (2:1.24~2) ... Setting up clang (1:19.0-63) ... Setting up debhelper (13.24.1) ... Setting up dh-golang (1.63) ... Processing triggers for libc-bin (2.40-7) ... Reading package lists... Building dependency tree... Reading state information... Reading extended state information... Initializing package states... Writing extended state information... Building tag database... -> Finished parsing the build-deps I: Building the package I: Running cd /build/reproducible-path/golang-github-cloudflare-cbpfc-0.0~git20231012.992ed75/ && env PATH="/usr/sbin:/usr/bin:/sbin:/bin:/usr/games" HOME="/nonexistent/first-build" dpkg-buildpackage -us -uc -b && env PATH="/usr/sbin:/usr/bin:/sbin:/bin:/usr/games" HOME="/nonexistent/first-build" dpkg-genchanges -S > ../golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_source.changes dpkg-buildpackage: info: source package golang-github-cloudflare-cbpfc dpkg-buildpackage: info: source version 0.0~git20231012.992ed75-2 dpkg-buildpackage: info: source distribution unstable dpkg-buildpackage: info: source changed by Reinhard Tartler dpkg-source --before-build . dpkg-buildpackage: info: host architecture arm64 debian/rules clean dh clean --builddirectory=_build --buildsystem=golang --with=golang dh_auto_clean -O--builddirectory=_build -O--buildsystem=golang dh_autoreconf_clean -O--builddirectory=_build -O--buildsystem=golang dh_clean -O--builddirectory=_build -O--buildsystem=golang debian/rules binary dh binary --builddirectory=_build --buildsystem=golang --with=golang dh_update_autotools_config -O--builddirectory=_build -O--buildsystem=golang dh_autoreconf -O--builddirectory=_build -O--buildsystem=golang dh_auto_configure -O--builddirectory=_build -O--buildsystem=golang dh_auto_build -O--builddirectory=_build -O--buildsystem=golang cd _build && go install -trimpath -v -p 12 github.com/cloudflare/cbpfc github.com/cloudflare/cbpfc/clang internal/goarch internal/byteorder internal/goos internal/godebugs internal/asan internal/unsafeheader internal/msan internal/profilerecord internal/coverage/rtcov internal/runtime/syscall internal/abi internal/runtime/math internal/cpu cmp internal/itoa internal/goexperiment math/bits unicode/utf8 sync/atomic unicode crypto/internal/fips140/alias crypto/internal/boring/sig internal/chacha8rand crypto/internal/fips140deps/byteorder crypto/internal/fips140/subtle math internal/bytealg crypto/internal/fips140deps/cpu internal/runtime/atomic internal/runtime/sys internal/runtime/exithook internal/stringslite internal/race internal/sync internal/runtime/maps runtime internal/reflectlite iter crypto/subtle sync maps slices errors sort internal/bisect internal/testlog io internal/oserror path math/rand/v2 strconv syscall internal/godebug hash bytes strings crypto/internal/randutil reflect crypto crypto/internal/fips140deps/godebug crypto/internal/fips140 crypto/internal/impl regexp/syntax crypto/internal/fips140/sha256 crypto/internal/fips140/sha3 crypto/internal/fips140/sha512 crypto/internal/fips140/hmac crypto/internal/fips140/check crypto/internal/fips140/aes regexp internal/syscall/execenv time internal/syscall/unix io/fs context internal/poll internal/filepathlite internal/fmtsort encoding/binary os golang.org/x/sys/unix crypto/internal/sysrand fmt path/filepath io/ioutil crypto/internal/entropy crypto/internal/fips140/drbg os/exec crypto/internal/fips140only crypto/internal/fips140/aes/gcm crypto/cipher crypto/internal/boring encoding/hex golang.org/x/net/bpf net/url github.com/pkg/errors text/template/parse crypto/sha1 github.com/cloudflare/cbpfc/clang text/template github.com/cilium/ebpf/internal/unix github.com/cilium/ebpf/internal/sys github.com/cilium/ebpf/asm github.com/cloudflare/cbpfc debian/rules override_dh_auto_test make[1]: Entering directory '/build/reproducible-path/golang-github-cloudflare-cbpfc-0.0~git20231012.992ed75' dh_auto_test -- --short cd _build && go test -vet=off -v -p 12 --short github.com/cloudflare/cbpfc github.com/cloudflare/cbpfc/clang === RUN TestFunctionName --- PASS: TestFunctionName (0.00s) === RUN TestNoInline --- SKIP: TestNoInline (0.15s) === RUN TestZero --- PASS: TestZero (0.00s) === RUN TestRaw --- PASS: TestRaw (0.00s) === RUN TestLoadAbsoluteNegativeOffset --- PASS: TestLoadAbsoluteNegativeOffset (0.00s) === RUN TestExtension --- PASS: TestExtension (0.00s) === RUN TestJumpOut --- PASS: TestJumpOut (0.00s) === RUN TestJumpIfOut --- PASS: TestJumpIfOut (0.00s) === RUN TestJumpIfXOut --- PASS: TestJumpIfXOut (0.00s) === RUN TestFallthroughOut --- PASS: TestFallthroughOut (0.00s) === RUN TestNormalizeJumps --- PASS: TestNormalizeJumps (0.00s) === RUN TestInstructionReadsRegA --- PASS: TestInstructionReadsRegA (0.00s) === RUN TestInstructionWritesRegA --- PASS: TestInstructionWritesRegA (0.00s) === RUN TestInstructionReadsRegX --- PASS: TestInstructionReadsRegX (0.00s) === RUN TestInstructionWritesRegX --- PASS: TestInstructionWritesRegX (0.00s) === RUN TestInstructionReadsScratch --- PASS: TestInstructionReadsScratch (0.00s) === RUN TestInstructionWritesScratch --- PASS: TestInstructionWritesScratch (0.00s) === RUN TestUninitializedReg --- PASS: TestUninitializedReg (0.00s) === RUN TestPartiallyUninitializedReg --- PASS: TestPartiallyUninitializedReg (0.00s) === RUN TestUninitializedScratch --- PASS: TestUninitializedScratch (0.00s) === RUN TestPartiallyUninitializedScratch --- PASS: TestPartiallyUninitializedScratch (0.00s) === RUN TestBlocksJump --- PASS: TestBlocksJump (0.00s) === RUN TestBlocksJumpIf --- PASS: TestBlocksJumpIf (0.00s) === RUN TestBlocksJumpIfX --- PASS: TestBlocksJumpIfX (0.00s) === RUN TestDivisionByZeroImm --- PASS: TestDivisionByZeroImm (0.00s) === RUN TestDivisionByZeroX --- PASS: TestDivisionByZeroX (0.00s) === RUN TestDivisionByZeroXTwice --- PASS: TestDivisionByZeroXTwice (0.00s) === RUN TestDivisionByZeroXConstant --- PASS: TestDivisionByZeroXConstant (0.00s) === RUN TestDivisionByZeroXMemShift --- PASS: TestDivisionByZeroXMemShift (0.00s) === RUN TestDivisionByZeroXTXA --- PASS: TestDivisionByZeroXTXA (0.00s) === RUN TestDivisionByZeroParentsOK --- PASS: TestDivisionByZeroParentsOK (0.00s) === RUN TestDivisionByZeroParentsNOK --- PASS: TestDivisionByZeroParentsNOK (0.00s) === RUN TestRewriteLargePacketOffsets --- PASS: TestRewriteLargePacketOffsets (0.00s) === RUN TestRewriteLargePacketOffsetsDeadBlock === RUN TestRewriteLargePacketOffsetsDeadBlock/C === RUN TestRewriteLargePacketOffsetsDeadBlock/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 6 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemW dst: r4 src: r2 off: 2 imm: 0 6: SwapBE dst: r4 imm: 32 7: JGTImm dst: r4 off: -1 imm: 2 filter_block_2: 8: JLTImm dst: r4 off: -1 imm: 2 filter_block_3: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 0 12: JaImm dst: r0 off: -1 imm: 0 filter_block_8: 13: Mov32Reg dst: r4 src: r4 14: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 15: MovImm dst: r4 imm: 0 16: JaImm dst: r0 off: -1 imm: 0 result: 17: MovImm dst: r0 imm: 2 18: JEqImm dst: r4 off: -1 imm: 0 19: MovImm dst: r0 imm: 1 return: 20: Exit === RUN TestRewriteLargePacketOffsetsDeadBlock/kernel --- PASS: TestRewriteLargePacketOffsetsDeadBlock (0.09s) --- SKIP: TestRewriteLargePacketOffsetsDeadBlock/C (0.04s) --- SKIP: TestRewriteLargePacketOffsetsDeadBlock/eBPF (0.00s) --- PASS: TestRewriteLargePacketOffsetsDeadBlock/kernel (0.05s) === RUN TestAbsoluteGuardSize --- PASS: TestAbsoluteGuardSize (0.00s) === RUN TestNoAbsoluteGuard --- PASS: TestNoAbsoluteGuard (0.00s) === RUN TestAbsoluteGuardParentsOK --- PASS: TestAbsoluteGuardParentsOK (0.00s) === RUN TestAbsoluteGuardParentNoMatch --- PASS: TestAbsoluteGuardParentNoMatch (0.00s) === RUN TestAbsoluteGuardParentDeepNoMatch --- PASS: TestAbsoluteGuardParentDeepNoMatch (0.00s) === RUN TestAbsoluteGuardParentMatch --- PASS: TestAbsoluteGuardParentMatch (0.00s) === RUN TestIndirectGuardSize --- PASS: TestIndirectGuardSize (0.00s) === RUN TestNoIndirectGuard --- PASS: TestNoIndirectGuard (0.00s) === RUN TestIndirectGuardClobber === RUN TestIndirectGuardClobber/constant === RUN TestIndirectGuardClobber/scratch === RUN TestIndirectGuardClobber/memshift --- PASS: TestIndirectGuardClobber (0.00s) --- PASS: TestIndirectGuardClobber/constant (0.00s) --- PASS: TestIndirectGuardClobber/scratch (0.00s) --- PASS: TestIndirectGuardClobber/memshift (0.00s) === RUN TestIndirectGuardClobberLast --- PASS: TestIndirectGuardClobberLast (0.00s) === RUN TestIndirectGuardParentsOK --- PASS: TestIndirectGuardParentsOK (0.00s) === RUN TestIndirectGuardParentNoMatch --- PASS: TestIndirectGuardParentNoMatch (0.00s) === RUN TestIndirectGuardParentDeepNoMatch --- PASS: TestIndirectGuardParentDeepNoMatch (0.00s) === RUN TestIndirectGuardParentMatch --- PASS: TestIndirectGuardParentMatch (0.00s) === RUN TestIndirectGuardParentClobber === RUN TestIndirectGuardParentClobber/constant === RUN TestIndirectGuardParentClobber/scratch === RUN TestIndirectGuardParentClobber/memshift --- PASS: TestIndirectGuardParentClobber (0.00s) --- PASS: TestIndirectGuardParentClobber/constant (0.00s) --- PASS: TestIndirectGuardParentClobber/scratch (0.00s) --- PASS: TestIndirectGuardParentClobber/memshift (0.00s) === RUN TestIndirectGuardExtendClobber === RUN TestIndirectGuardExtendClobber/constant === RUN TestIndirectGuardExtendClobber/scratch === RUN TestIndirectGuardExtendClobber/memshift --- PASS: TestIndirectGuardExtendClobber (0.00s) --- PASS: TestIndirectGuardExtendClobber/constant (0.00s) --- PASS: TestIndirectGuardExtendClobber/scratch (0.00s) --- PASS: TestIndirectGuardExtendClobber/memshift (0.00s) === RUN TestIndirectGuardParentsNotOK --- PASS: TestIndirectGuardParentsNotOK (0.00s) === RUN TestZeroInitA === PAUSE TestZeroInitA === RUN TestZeroInitX === PAUSE TestZeroInitX === RUN TestPartialZeroInitX === PAUSE TestPartialZeroInitX === RUN TestLoadConstantA === PAUSE TestLoadConstantA === RUN TestLoadConstantX === PAUSE TestLoadConstantX === RUN TestLoadAbsolute === PAUSE TestLoadAbsolute === RUN TestLoadAbsoluteBigOffset === PAUSE TestLoadAbsoluteBigOffset === RUN TestLoadIndirect === PAUSE TestLoadIndirect === RUN TestLoadIndirectBigOffset === RUN TestLoadIndirectBigOffset/C === RUN TestLoadIndirectBigOffset/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 0 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: 0 7: JGEImm dst: r7 off: -1 imm: 65535 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 1 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemB dst: r4 src: r7 off: 0 imm: 0 13: Add32Imm dst: r4 imm: 2 14: Mov32Reg dst: r4 src: r4 15: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 16: MovImm dst: r4 imm: 0 17: JaImm dst: r0 off: -1 imm: 0 result: 18: MovImm dst: r0 imm: 2 19: JEqImm dst: r4 off: -1 imm: 0 20: MovImm dst: r0 imm: 1 return: 21: Exit === RUN TestLoadIndirectBigOffset/kernel === RUN TestLoadIndirectBigOffset/C#01 === RUN TestLoadIndirectBigOffset/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 0 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: 0 7: JGEImm dst: r7 off: -1 imm: 65532 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 4 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemW dst: r4 src: r7 off: 0 imm: 0 13: SwapBE dst: r4 imm: 32 14: Add32Imm dst: r4 imm: 2 15: Mov32Reg dst: r4 src: r4 16: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 17: MovImm dst: r4 imm: 0 18: JaImm dst: r0 off: -1 imm: 0 result: 19: MovImm dst: r0 imm: 2 20: JEqImm dst: r4 off: -1 imm: 0 21: MovImm dst: r0 imm: 1 return: 22: Exit === RUN TestLoadIndirectBigOffset/kernel#01 === RUN TestLoadIndirectBigOffset/C#02 === RUN TestLoadIndirectBigOffset/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 0 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: 65534 7: JGEImm dst: r7 off: -1 imm: 65535 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 1 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemB dst: r4 src: r7 off: 0 imm: 0 13: Add32Imm dst: r4 imm: 2 14: Mov32Reg dst: r4 src: r4 15: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 16: MovImm dst: r4 imm: 0 17: JaImm dst: r0 off: -1 imm: 0 result: 18: MovImm dst: r0 imm: 2 19: JEqImm dst: r4 off: -1 imm: 0 20: MovImm dst: r0 imm: 1 return: 21: Exit === RUN TestLoadIndirectBigOffset/kernel#02 === RUN TestLoadIndirectBigOffset/C#03 === RUN TestLoadIndirectBigOffset/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 0 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: 65535 7: JGEImm dst: r7 off: -1 imm: 65535 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 1 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemB dst: r4 src: r7 off: 0 imm: 0 13: Add32Imm dst: r4 imm: 2 14: Mov32Reg dst: r4 src: r4 15: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 16: MovImm dst: r4 imm: 0 17: JaImm dst: r0 off: -1 imm: 0 result: 18: MovImm dst: r0 imm: 2 19: JEqImm dst: r4 off: -1 imm: 0 20: MovImm dst: r0 imm: 1 return: 21: Exit === RUN TestLoadIndirectBigOffset/kernel#03 === RUN TestLoadIndirectBigOffset/C#04 === RUN TestLoadIndirectBigOffset/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 0 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: 65533 7: JGEImm dst: r7 off: -1 imm: 65534 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 2 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemH dst: r4 src: r7 off: 0 imm: 0 13: SwapBE dst: r4 imm: 16 14: Add32Imm dst: r4 imm: 2 15: Mov32Reg dst: r4 src: r4 16: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 17: MovImm dst: r4 imm: 0 18: JaImm dst: r0 off: -1 imm: 0 result: 19: MovImm dst: r0 imm: 2 20: JEqImm dst: r4 off: -1 imm: 0 21: MovImm dst: r0 imm: 1 return: 22: Exit === RUN TestLoadIndirectBigOffset/kernel#04 === RUN TestLoadIndirectBigOffset/C#05 === RUN TestLoadIndirectBigOffset/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 0 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: 65534 7: JGEImm dst: r7 off: -1 imm: 65534 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 2 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemH dst: r4 src: r7 off: 0 imm: 0 13: SwapBE dst: r4 imm: 16 14: Add32Imm dst: r4 imm: 2 15: Mov32Reg dst: r4 src: r4 16: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 17: MovImm dst: r4 imm: 0 18: JaImm dst: r0 off: -1 imm: 0 result: 19: MovImm dst: r0 imm: 2 20: JEqImm dst: r4 off: -1 imm: 0 21: MovImm dst: r0 imm: 1 return: 22: Exit === RUN TestLoadIndirectBigOffset/kernel#05 === RUN TestLoadIndirectBigOffset/C#06 === RUN TestLoadIndirectBigOffset/eBPF#06 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 0 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: 65531 7: JGEImm dst: r7 off: -1 imm: 65532 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 4 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemW dst: r4 src: r7 off: 0 imm: 0 13: SwapBE dst: r4 imm: 32 14: Add32Imm dst: r4 imm: 2 15: Mov32Reg dst: r4 src: r4 16: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 17: MovImm dst: r4 imm: 0 18: JaImm dst: r0 off: -1 imm: 0 result: 19: MovImm dst: r0 imm: 2 20: JEqImm dst: r4 off: -1 imm: 0 21: MovImm dst: r0 imm: 1 return: 22: Exit === RUN TestLoadIndirectBigOffset/kernel#06 === RUN TestLoadIndirectBigOffset/C#07 === RUN TestLoadIndirectBigOffset/eBPF#07 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 0 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: 65532 7: JGEImm dst: r7 off: -1 imm: 65532 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 4 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemW dst: r4 src: r7 off: 0 imm: 0 13: SwapBE dst: r4 imm: 32 14: Add32Imm dst: r4 imm: 2 15: Mov32Reg dst: r4 src: r4 16: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 17: MovImm dst: r4 imm: 0 18: JaImm dst: r0 off: -1 imm: 0 result: 19: MovImm dst: r0 imm: 2 20: JEqImm dst: r4 off: -1 imm: 0 21: MovImm dst: r0 imm: 1 return: 22: Exit === RUN TestLoadIndirectBigOffset/kernel#07 --- PASS: TestLoadIndirectBigOffset (0.61s) --- SKIP: TestLoadIndirectBigOffset/C (0.03s) --- SKIP: TestLoadIndirectBigOffset/eBPF (0.00s) --- PASS: TestLoadIndirectBigOffset/kernel (0.00s) --- SKIP: TestLoadIndirectBigOffset/C#01 (0.04s) --- SKIP: TestLoadIndirectBigOffset/eBPF#01 (0.00s) --- PASS: TestLoadIndirectBigOffset/kernel#01 (0.00s) --- SKIP: TestLoadIndirectBigOffset/C#02 (0.03s) --- SKIP: TestLoadIndirectBigOffset/eBPF#02 (0.00s) --- PASS: TestLoadIndirectBigOffset/kernel#02 (0.05s) --- SKIP: TestLoadIndirectBigOffset/C#03 (0.04s) --- SKIP: TestLoadIndirectBigOffset/eBPF#03 (0.00s) --- PASS: TestLoadIndirectBigOffset/kernel#03 (0.05s) --- SKIP: TestLoadIndirectBigOffset/C#04 (0.03s) --- SKIP: TestLoadIndirectBigOffset/eBPF#04 (0.00s) --- PASS: TestLoadIndirectBigOffset/kernel#04 (0.06s) --- SKIP: TestLoadIndirectBigOffset/C#05 (0.04s) --- SKIP: TestLoadIndirectBigOffset/eBPF#05 (0.00s) --- PASS: TestLoadIndirectBigOffset/kernel#05 (0.05s) --- SKIP: TestLoadIndirectBigOffset/C#06 (0.04s) --- SKIP: TestLoadIndirectBigOffset/eBPF#06 (0.00s) --- PASS: TestLoadIndirectBigOffset/kernel#06 (0.05s) --- SKIP: TestLoadIndirectBigOffset/C#07 (0.04s) --- SKIP: TestLoadIndirectBigOffset/eBPF#07 (0.00s) --- PASS: TestLoadIndirectBigOffset/kernel#07 (0.05s) === RUN TestLoadIndirectGuardOverflow === RUN TestLoadIndirectGuardOverflow/C === RUN TestLoadIndirectGuardOverflow/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 4 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemW dst: r4 src: r2 off: 0 imm: 0 6: SwapBE dst: r4 imm: 32 7: Mov32Reg dst: r5 src: r4 8: MovReg dst: r7 src: r5 9: LShImm dst: r7 imm: 32 10: ArShImm dst: r7 imm: 32 11: AddImm dst: r7 imm: -2147483648 12: JGEImm dst: r7 off: -1 imm: 0 13: AddReg dst: r7 src: r2 14: MovReg dst: r6 src: r7 15: AddImm dst: r6 imm: 3 16: JGTReg dst: r6 off: -1 src: r3 17: LdXMemB dst: r4 src: r7 off: 0 imm: 0 18: MovReg dst: r6 src: r7 19: AddImm dst: r6 imm: -2147483648 20: LdXMemH dst: r4 src: r6 off: 0 imm: 0 21: SwapBE dst: r4 imm: 16 22: LdXMemW dst: r4 src: r7 off: -1 imm: 0 23: SwapBE dst: r4 imm: 32 24: Mov32Reg dst: r4 src: r5 25: Mov32Reg dst: r4 src: r4 26: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 27: MovImm dst: r4 imm: 0 28: JaImm dst: r0 off: -1 imm: 0 result: 29: MovImm dst: r0 imm: 2 30: JEqImm dst: r4 off: -1 imm: 0 31: MovImm dst: r0 imm: 1 return: 32: Exit === RUN TestLoadIndirectGuardOverflow/kernel --- PASS: TestLoadIndirectGuardOverflow (0.09s) --- SKIP: TestLoadIndirectGuardOverflow/C (0.04s) --- SKIP: TestLoadIndirectGuardOverflow/eBPF (0.00s) --- PASS: TestLoadIndirectGuardOverflow/kernel (0.05s) === RUN TestScratchZero === PAUSE TestScratchZero === RUN TestScratchA === PAUSE TestScratchA === RUN TestScratchX === PAUSE TestScratchX === RUN TestMemShift === PAUSE TestMemShift === RUN TestLoadExtLen === PAUSE TestLoadExtLen === RUN TestALUAdd === PAUSE TestALUAdd === RUN TestALUSub === PAUSE TestALUSub === RUN TestALUMul === PAUSE TestALUMul === RUN TestALUDiv === PAUSE TestALUDiv === RUN TestALUDivZero === PAUSE TestALUDivZero === RUN TestALUDivNegative === RUN TestALUDivNegative/C === RUN TestALUDivNegative/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 4 3: Mov32Imm dst: r5 imm: -2 4: JEqImm dst: r5 off: -1 imm: 0 5: Div32Reg dst: r4 src: r5 6: JEqImm dst: r4 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 0 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 1 10: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 11: MovImm dst: r4 imm: 0 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestALUDivNegative/kernel --- PASS: TestALUDivNegative (0.06s) --- SKIP: TestALUDivNegative/C (0.06s) --- SKIP: TestALUDivNegative/eBPF (0.00s) --- PASS: TestALUDivNegative/kernel (0.00s) === RUN TestALUOr === PAUSE TestALUOr === RUN TestALUAnd === PAUSE TestALUAnd === RUN TestALUShiftLeft === PAUSE TestALUShiftLeft === RUN TestALUShiftRight === PAUSE TestALUShiftRight === RUN TestALUMod === PAUSE TestALUMod === RUN TestALUXor === PAUSE TestALUXor === RUN TestNegateA === PAUSE TestNegateA === RUN TestJump === PAUSE TestJump === RUN TestJump0 === PAUSE TestJump0 === RUN TestJumpIfEqual === PAUSE TestJumpIfEqual === RUN TestJumpIfNotEqual === PAUSE TestJumpIfNotEqual === RUN TestJumpIfGreaterThan === PAUSE TestJumpIfGreaterThan === RUN TestJumpIfLessThan === PAUSE TestJumpIfLessThan === RUN TestJumpIfGreaterOrEqual === PAUSE TestJumpIfGreaterOrEqual === RUN TestJumpIfLessOrEqual === PAUSE TestJumpIfLessOrEqual === RUN TestJumpIfBitsSet === PAUSE TestJumpIfBitsSet === RUN TestJumpIfBitsNotSet === PAUSE TestJumpIfBitsNotSet === RUN TestRetA === PAUSE TestRetA === RUN TestRetConstant === PAUSE TestRetConstant === RUN TestTXA === PAUSE TestTXA === RUN TestTAX === PAUSE TestTAX === CONT TestZeroInitA === RUN TestZeroInitA/C === CONT TestALUShiftLeft === RUN TestALUShiftLeft/C === CONT TestJumpIfLessThan === RUN TestJumpIfLessThan/C === CONT TestALUAnd === RUN TestALUAnd/C === CONT TestJumpIfGreaterThan === RUN TestJumpIfGreaterThan/C === CONT TestJumpIfNotEqual === CONT TestJumpIfEqual === CONT TestJump0 === CONT TestJump === CONT TestNegateA === CONT TestALUXor === CONT TestALUMod === RUN TestJumpIfNotEqual/C === RUN TestJumpIfEqual/C === RUN TestJump0/C === RUN TestJump/C === RUN TestNegateA/C === RUN TestALUXor/C === RUN TestALUMod/C === RUN TestZeroInitA/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 0 3: Mov32Reg dst: r4 src: r4 4: JaImm dst: r0 off: -1 imm: 0 result: 5: MovImm dst: r0 imm: 2 6: JEqImm dst: r4 off: -1 imm: 0 7: MovImm dst: r0 imm: 1 return: 8: Exit === RUN TestZeroInitA/kernel === RUN TestJumpIfGreaterThan/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: JGTImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfGreaterThan/kernel === RUN TestJumpIfGreaterThan/C#01 === RUN TestJumpIfLessThan/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: JLTImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfLessThan/kernel === RUN TestJumpIfNotEqual/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JNEImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfNotEqual/kernel === RUN TestALUShiftLeft/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: LSh32Imm dst: r4 imm: 0 4: JEqImm dst: r4 off: -1 imm: 1 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUShiftLeft/kernel === RUN TestALUShiftLeft/C#01 === RUN TestALUAnd/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: And32Imm dst: r4 imm: 0 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUAnd/kernel === RUN TestALUAnd/C#01 === RUN TestJump/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 1 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemB dst: r4 src: r2 off: 0 imm: 0 6: JEqImm dst: r4 off: -1 imm: 1 filter_block_2: 7: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 8: Mov32Imm dst: r4 imm: 1 filter_block_4: 9: Mov32Reg dst: r4 src: r4 10: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 11: MovImm dst: r4 imm: 0 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJump/kernel === RUN TestNegateA/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 26 3: Neg32Imm dst: r4 imm: 0 4: Mov32Imm dst: r6 imm: -2147483622 5: JEqReg dst: r4 off: -1 src: r6 filter_block_3: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestNegateA/kernel === RUN TestJumpIfEqual/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JEqImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfEqual/kernel === RUN TestJumpIfEqual/C#01 === RUN TestJump0/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 1 4: JGTReg dst: r6 off: -1 src: r3 5: Mov32Imm dst: r5 imm: 0 6: LdXMemB dst: r4 src: r2 off: 0 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 8: JEqReg dst: r4 off: -1 src: r5 filter_block_4: 9: Mov32Reg dst: r4 src: r4 10: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 11: MovImm dst: r4 imm: 0 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJump0/kernel === RUN TestALUMod/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 16 3: Mod32Imm dst: r4 imm: 4 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUMod/kernel === RUN TestALUMod/C#01 === RUN TestALUXor/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: Xor32Imm dst: r4 imm: 1 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUXor/kernel === RUN TestALUXor/C#01 --- PASS: TestZeroInitA (0.10s) --- SKIP: TestZeroInitA/C (0.05s) --- SKIP: TestZeroInitA/eBPF (0.00s) --- PASS: TestZeroInitA/kernel (0.05s) === CONT TestALUShiftRight === RUN TestALUShiftRight/C === RUN TestJumpIfNotEqual/C#01 === RUN TestJumpIfLessThan/C#01 === RUN TestJumpIfGreaterThan/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JGTImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfGreaterThan/kernel#01 === RUN TestJumpIfGreaterThan/C#02 === RUN TestALUShiftLeft/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: Mov32Imm dst: r5 imm: 0 4: LSh32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 1 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUShiftLeft/kernel#01 === RUN TestALUShiftLeft/C#02 --- PASS: TestJump (0.11s) --- SKIP: TestJump/C (0.06s) --- SKIP: TestJump/eBPF (0.00s) --- PASS: TestJump/kernel (0.05s) === CONT TestScratchA === RUN TestScratchA/C === RUN TestALUMod/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 16 3: Mov32Imm dst: r5 imm: 4 4: JEqImm dst: r5 off: -1 imm: 0 5: Mod32Reg dst: r4 src: r5 6: JEqImm dst: r4 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 0 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 1 10: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 11: MovImm dst: r4 imm: 0 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestALUMod/kernel#01 === RUN TestALUMod/C#02 --- PASS: TestNegateA (0.11s) --- SKIP: TestNegateA/C (0.06s) --- SKIP: TestNegateA/eBPF (0.00s) --- PASS: TestNegateA/kernel (0.05s) === CONT TestALUOr === RUN TestALUOr/C === RUN TestJump0/C#01 === RUN TestJumpIfEqual/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JEqImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfEqual/kernel#01 === RUN TestJumpIfEqual/C#02 === RUN TestALUXor/eBPF#01 === RUN TestALUShiftRight/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 240 3: RSh32Imm dst: r4 imm: 4 4: JEqImm dst: r4 off: -1 imm: 15 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUShiftRight/kernel === RUN TestALUShiftRight/C#01 === RUN TestALUAnd/eBPF#01 === NAME TestALUXor/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: Mov32Imm dst: r5 imm: 1 4: Xor32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 0 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUXor/kernel#01 === NAME TestALUAnd/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: Mov32Imm dst: r5 imm: 0 4: And32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 0 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUAnd/kernel#01 === RUN TestALUXor/C#02 === RUN TestALUAnd/C#02 === RUN TestScratchA/eBPF === RUN TestJumpIfNotEqual/eBPF#01 === NAME TestScratchA/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: -559038737 3: StXMemW dst: rfp src: r4 off: -32 imm: 0 4: Mov32Imm dst: r4 imm: 0 5: Mov32Imm dst: r4 imm: -1 6: StXMemW dst: rfp src: r4 off: -28 imm: 0 7: Mov32Imm dst: r4 imm: -1 8: StXMemW dst: rfp src: r4 off: -36 imm: 0 9: LdXMemW dst: r4 src: rfp off: -32 imm: 0 10: Mov32Imm dst: r6 imm: -559038737 11: JEqReg dst: r4 off: -1 src: r6 filter_block_9: 12: Mov32Imm dst: r4 imm: 0 13: JaImm dst: r0 off: -1 imm: 0 filter_block_10: 14: Mov32Imm dst: r4 imm: 1 15: JaImm dst: r0 off: -1 imm: 0 result: 16: MovImm dst: r0 imm: 2 17: JEqImm dst: r4 off: -1 imm: 0 18: MovImm dst: r0 imm: 1 return: 19: Exit === RUN TestScratchA/kernel === NAME TestJumpIfNotEqual/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JNEImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfNotEqual/kernel#01 === RUN TestScratchA/C#01 === RUN TestJumpIfGreaterThan/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: Mov32Imm dst: r5 imm: 23 4: JGTReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfGreaterThan/kernel#02 === RUN TestJumpIfGreaterThan/C#03 === RUN TestALUShiftLeft/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: LSh32Imm dst: r4 imm: 4 4: JEqImm dst: r4 off: -1 imm: 16 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUShiftLeft/kernel#02 === RUN TestALUShiftLeft/C#03 === RUN TestJumpIfLessThan/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JLTImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfLessThan/kernel#01 === RUN TestALUOr/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: Or32Imm dst: r4 imm: 0 4: JEqImm dst: r4 off: -1 imm: 1 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUOr/kernel === RUN TestALUOr/C#01 === RUN TestALUMod/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 17 3: Mod32Imm dst: r4 imm: 4 4: JEqImm dst: r4 off: -1 imm: 1 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUMod/kernel#02 === RUN TestALUMod/C#03 === RUN TestJumpIfEqual/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 23 4: JEqReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfEqual/kernel#02 === RUN TestJumpIfEqual/C#03 === RUN TestALUShiftRight/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 240 3: Mov32Imm dst: r5 imm: 4 4: RSh32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 15 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUShiftRight/kernel#01 === RUN TestALUShiftRight/C#02 === RUN TestALUAnd/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 240 3: And32Imm dst: r4 imm: 128 4: JEqImm dst: r4 off: -1 imm: 128 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUAnd/kernel#02 === RUN TestALUAnd/C#03 === RUN TestJump0/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 1 4: JGTReg dst: r6 off: -1 src: r3 5: Mov32Imm dst: r5 imm: 0 6: LdXMemB dst: r4 src: r2 off: 0 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 8: JEqReg dst: r4 off: -1 src: r5 filter_block_4: 9: Mov32Reg dst: r4 src: r4 10: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 11: MovImm dst: r4 imm: 0 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJump0/kernel#01 --- PASS: TestJump0 (0.25s) --- SKIP: TestJump0/C (0.08s) --- SKIP: TestJump0/eBPF (0.00s) --- PASS: TestJump0/kernel (0.10s) --- SKIP: TestJump0/C#01 (0.07s) --- SKIP: TestJump0/eBPF#01 (0.00s) --- PASS: TestJump0/kernel#01 (0.00s) === CONT TestALUDivZero === RUN TestALUDivZero/C === RUN TestJumpIfNotEqual/C#02 === RUN TestJumpIfGreaterThan/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JGTReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfGreaterThan/kernel#03 === RUN TestJumpIfGreaterThan/C#04 === RUN TestJumpIfEqual/eBPF#03 === RUN TestALUShiftRight/eBPF#02 === RUN TestJumpIfLessThan/C#02 === NAME TestALUShiftRight/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 240 3: RSh32Imm dst: r4 imm: 8 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUShiftRight/kernel#02 === RUN TestALUShiftRight/C#03 === RUN TestALUXor/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: Mod32Imm dst: r4 imm: 4 4: JEqImm dst: r4 off: -1 imm: 2 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUXor/kernel#02 === RUN TestALUXor/C#03 === RUN TestALUShiftLeft/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: Mov32Imm dst: r5 imm: 4 4: LSh32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 16 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUShiftLeft/kernel#03 --- PASS: TestALUShiftLeft (0.31s) --- SKIP: TestALUShiftLeft/C (0.06s) --- SKIP: TestALUShiftLeft/eBPF (0.01s) --- PASS: TestALUShiftLeft/kernel (0.00s) --- SKIP: TestALUShiftLeft/C#01 (0.06s) --- SKIP: TestALUShiftLeft/eBPF#01 (0.00s) --- PASS: TestALUShiftLeft/kernel#01 (0.00s) --- SKIP: TestALUShiftLeft/C#02 (0.09s) --- SKIP: TestALUShiftLeft/eBPF#02 (0.00s) --- PASS: TestALUShiftLeft/kernel#02 (0.00s) --- SKIP: TestALUShiftLeft/C#03 (0.09s) --- SKIP: TestALUShiftLeft/eBPF#03 (0.00s) --- PASS: TestALUShiftLeft/kernel#03 (0.00s) === CONT TestALUDiv === RUN TestALUDiv/C === RUN TestScratchA/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 0 3: StXMemW dst: rfp src: r4 off: -32 imm: 0 4: Mov32Imm dst: r4 imm: 0 5: Mov32Imm dst: r4 imm: -1 6: StXMemW dst: rfp src: r4 off: -28 imm: 0 7: Mov32Imm dst: r4 imm: -1 8: StXMemW dst: rfp src: r4 off: -36 imm: 0 9: LdXMemW dst: r4 src: rfp off: -32 imm: 0 10: JEqImm dst: r4 off: -1 imm: 0 filter_block_9: 11: Mov32Imm dst: r4 imm: 0 12: JaImm dst: r0 off: -1 imm: 0 filter_block_10: 13: Mov32Imm dst: r4 imm: 1 14: JaImm dst: r0 off: -1 imm: 0 result: 15: MovImm dst: r0 imm: 2 16: JEqImm dst: r4 off: -1 imm: 0 17: MovImm dst: r0 imm: 1 return: 18: Exit === RUN TestScratchA/kernel#01 --- PASS: TestScratchA (0.18s) --- SKIP: TestScratchA/C (0.08s) --- SKIP: TestScratchA/eBPF (0.00s) --- PASS: TestScratchA/kernel (0.00s) --- SKIP: TestScratchA/C#01 (0.10s) --- SKIP: TestScratchA/eBPF#01 (0.00s) --- PASS: TestScratchA/kernel#01 (0.00s) === CONT TestALUMul === RUN TestALUMul/C === NAME TestJumpIfEqual/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JEqReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestALUMod/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 17 3: Mov32Imm dst: r5 imm: 4 4: JEqImm dst: r5 off: -1 imm: 0 5: Mod32Reg dst: r4 src: r5 6: JEqImm dst: r4 off: -1 imm: 1 filter_block_4: 7: Mov32Imm dst: r4 imm: 0 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 1 10: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 11: MovImm dst: r4 imm: 0 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestALUMod/kernel#03 --- PASS: TestALUMod (0.30s) --- SKIP: TestALUMod/C (0.05s) --- SKIP: TestALUMod/eBPF (0.00s) --- PASS: TestALUMod/kernel (0.00s) --- SKIP: TestALUMod/C#01 (0.03s) --- SKIP: TestALUMod/eBPF#01 (0.00s) --- PASS: TestALUMod/kernel#01 (0.00s) --- SKIP: TestALUMod/C#02 (0.11s) --- SKIP: TestALUMod/eBPF#02 (0.00s) --- PASS: TestALUMod/kernel#02 (0.00s) --- SKIP: TestALUMod/C#03 (0.09s) --- SKIP: TestALUMod/eBPF#03 (0.00s) --- PASS: TestALUMod/kernel#03 (0.00s) === CONT TestALUSub === RUN TestALUSub/C === RUN TestALUAnd/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 240 3: Mov32Imm dst: r5 imm: 128 4: And32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 128 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUAnd/kernel#03 === RUN TestALUAnd/C#04 === RUN TestJumpIfNotEqual/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 23 4: JNEReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfNotEqual/kernel#02 === RUN TestALUOr/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: Mov32Imm dst: r5 imm: 0 4: Or32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 1 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUOr/kernel#01 === RUN TestALUOr/C#02 === RUN TestALUDivZero/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 1 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemB dst: r4 src: r2 off: 0 imm: 0 6: Mov32Reg dst: r5 src: r4 7: Mov32Imm dst: r4 imm: 10 8: JEqImm dst: r5 off: -1 imm: 0 9: Div32Reg dst: r4 src: r5 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 12: MovImm dst: r4 imm: 0 13: JaImm dst: r0 off: -1 imm: 0 result: 14: MovImm dst: r0 imm: 2 15: JEqImm dst: r4 off: -1 imm: 0 16: MovImm dst: r0 imm: 1 return: 17: Exit === RUN TestALUDivZero/kernel === RUN TestJumpIfEqual/kernel#03 === RUN TestJumpIfEqual/C#04 === RUN TestALUMul/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 0 3: Mul32Imm dst: r4 imm: 1 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUMul/kernel === RUN TestALUMul/C#01 === RUN TestJumpIfLessThan/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: Mov32Imm dst: r5 imm: 23 4: JLTReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfLessThan/kernel#02 === RUN TestJumpIfGreaterThan/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JGTImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfGreaterThan/kernel#04 === RUN TestALUXor/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: Mov32Imm dst: r5 imm: 4 4: JEqImm dst: r5 off: -1 imm: 0 5: Mod32Reg dst: r4 src: r5 6: JEqImm dst: r4 off: -1 imm: 2 filter_block_4: 7: Mov32Imm dst: r4 imm: 0 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 1 10: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 11: MovImm dst: r4 imm: 0 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestALUXor/kernel#03 --- PASS: TestALUXor (0.36s) --- SKIP: TestALUXor/C (0.06s) --- SKIP: TestALUXor/eBPF (0.00s) --- PASS: TestALUXor/kernel (0.00s) --- SKIP: TestALUXor/C#01 (0.10s) --- SKIP: TestALUXor/eBPF#01 (0.00s) --- PASS: TestALUXor/kernel#01 (0.00s) --- SKIP: TestALUXor/C#02 (0.08s) --- SKIP: TestALUXor/eBPF#02 (0.00s) --- PASS: TestALUXor/kernel#02 (0.00s) --- SKIP: TestALUXor/C#03 (0.08s) --- SKIP: TestALUXor/eBPF#03 (0.00s) --- PASS: TestALUXor/kernel#03 (0.00s) === CONT TestALUAdd === RUN TestALUAdd/C === RUN TestJumpIfEqual/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JEqImm dst: r4 off: -1 imm: 21 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfEqual/kernel#04 === RUN TestALUAnd/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 240 3: And32Imm dst: r4 imm: 15 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUAnd/kernel#04 === RUN TestALUAnd/C#05 === RUN TestJumpIfNotEqual/C#03 === RUN TestALUDivZero/C#01 === RUN TestALUShiftRight/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 240 3: Mov32Imm dst: r5 imm: 8 4: RSh32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 0 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUShiftRight/kernel#03 --- PASS: TestALUShiftRight (0.30s) --- SKIP: TestALUShiftRight/C (0.10s) --- SKIP: TestALUShiftRight/eBPF (0.00s) --- PASS: TestALUShiftRight/kernel (0.00s) --- SKIP: TestALUShiftRight/C#01 (0.06s) --- SKIP: TestALUShiftRight/eBPF#01 (0.00s) --- PASS: TestALUShiftRight/kernel#01 (0.00s) --- SKIP: TestALUShiftRight/C#02 (0.04s) --- SKIP: TestALUShiftRight/eBPF#02 (0.00s) --- PASS: TestALUShiftRight/kernel#02 (0.00s) --- SKIP: TestALUShiftRight/C#03 (0.10s) --- SKIP: TestALUShiftRight/eBPF#03 (0.00s) --- PASS: TestALUShiftRight/kernel#03 (0.00s) === CONT TestLoadExtLen === RUN TestLoadExtLen/C === RUN TestALUSub/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: Sub32Imm dst: r4 imm: 1 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUSub/kernel === RUN TestALUSub/C#01 === RUN TestALUMul/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 0 3: Mov32Imm dst: r5 imm: 1 4: Mul32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 0 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUMul/kernel#01 === RUN TestALUMul/C#02 === RUN TestJumpIfLessThan/C#03 === RUN TestALUDiv/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 2 3: Div32Imm dst: r4 imm: 2 4: JEqImm dst: r4 off: -1 imm: 1 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUDiv/kernel === RUN TestALUDiv/C#01 === RUN TestJumpIfGreaterThan/C#05 === RUN TestALUOr/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 240 3: Or32Imm dst: r4 imm: 15 4: JEqImm dst: r4 off: -1 imm: 255 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUOr/kernel#02 === RUN TestALUOr/C#03 === RUN TestJumpIfEqual/C#05 === RUN TestALUAnd/eBPF#05 === RUN TestJumpIfNotEqual/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JNEReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestALUAdd/eBPF === RUN TestJumpIfNotEqual/kernel#03 === RUN TestLoadExtLen/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r4 src: r3 3: Sub32Reg dst: r4 src: r2 4: JEqImm dst: r4 off: -1 imm: 16 filter_block_2: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestLoadExtLen/kernel --- PASS: TestLoadExtLen (0.10s) --- SKIP: TestLoadExtLen/C (0.10s) --- SKIP: TestLoadExtLen/eBPF (0.00s) --- PASS: TestLoadExtLen/kernel (0.00s) === CONT TestMemShift === RUN TestMemShift/C === NAME TestALUAnd/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 240 3: Mov32Imm dst: r5 imm: 15 4: And32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 0 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUAnd/kernel#05 --- PASS: TestALUAnd (0.50s) --- SKIP: TestALUAnd/C (0.07s) --- SKIP: TestALUAnd/eBPF (0.00s) --- PASS: TestALUAnd/kernel (0.00s) --- SKIP: TestALUAnd/C#01 (0.12s) --- SKIP: TestALUAnd/eBPF#01 (0.00s) --- PASS: TestALUAnd/kernel#01 (0.00s) --- SKIP: TestALUAnd/C#02 (0.04s) --- SKIP: TestALUAnd/eBPF#02 (0.00s) --- PASS: TestALUAnd/kernel#02 (0.00s) --- SKIP: TestALUAnd/C#03 (0.07s) --- SKIP: TestALUAnd/eBPF#03 (0.00s) --- PASS: TestALUAnd/kernel#03 (0.00s) --- SKIP: TestALUAnd/C#04 (0.05s) --- SKIP: TestALUAnd/eBPF#04 (0.00s) --- PASS: TestALUAnd/kernel#04 (0.00s) --- SKIP: TestALUAnd/C#05 (0.06s) --- SKIP: TestALUAnd/eBPF#05 (0.04s) --- PASS: TestALUAnd/kernel#05 (0.00s) === CONT TestScratchX === RUN TestScratchX/C === NAME TestALUAdd/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: Add32Imm dst: r4 imm: 0 4: JEqImm dst: r4 off: -1 imm: 1 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUAdd/kernel === RUN TestALUDiv/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 2 3: Mov32Imm dst: r5 imm: 2 4: JEqImm dst: r5 off: -1 imm: 0 5: Div32Reg dst: r4 src: r5 6: JEqImm dst: r4 off: -1 imm: 1 filter_block_4: 7: Mov32Imm dst: r4 imm: 0 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 1 10: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 11: MovImm dst: r4 imm: 0 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestALUDiv/kernel#01 === RUN TestALUSub/eBPF#01 === RUN TestALUAdd/C#01 === NAME TestALUSub/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: Mov32Imm dst: r5 imm: 1 4: Sub32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 0 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUDivZero/eBPF#01 === RUN TestALUSub/kernel#01 === NAME TestALUDivZero/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 1 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemB dst: r4 src: r2 off: 0 imm: 0 6: Mov32Reg dst: r5 src: r4 7: Mov32Imm dst: r4 imm: 10 8: JEqImm dst: r5 off: -1 imm: 0 9: Div32Reg dst: r4 src: r5 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 12: MovImm dst: r4 imm: 0 13: JaImm dst: r0 off: -1 imm: 0 result: 14: MovImm dst: r0 imm: 2 15: JEqImm dst: r4 off: -1 imm: 0 16: MovImm dst: r0 imm: 1 return: 17: Exit === RUN TestALUDivZero/kernel#01 === RUN TestALUSub/C#02 --- PASS: TestALUDivZero (0.24s) --- SKIP: TestALUDivZero/C (0.07s) --- SKIP: TestALUDivZero/eBPF (0.00s) --- PASS: TestALUDivZero/kernel (0.05s) --- SKIP: TestALUDivZero/C#01 (0.10s) --- SKIP: TestALUDivZero/eBPF#01 (0.00s) --- PASS: TestALUDivZero/kernel#01 (0.00s) === CONT TestLoadConstantX === RUN TestLoadConstantX/C === RUN TestALUDiv/C#02 === RUN TestALUMul/eBPF#02 === RUN TestJumpIfGreaterThan/eBPF#05 === RUN TestALUOr/eBPF#03 === NAME TestJumpIfGreaterThan/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JGTImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfGreaterThan/kernel#05 === NAME TestALUOr/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 240 3: Mov32Imm dst: r5 imm: 15 4: Or32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 255 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUOr/kernel#03 --- PASS: TestALUOr (0.40s) --- SKIP: TestALUOr/C (0.10s) --- SKIP: TestALUOr/eBPF (0.00s) --- PASS: TestALUOr/kernel (0.00s) --- SKIP: TestALUOr/C#01 (0.09s) --- SKIP: TestALUOr/eBPF#01 (0.00s) --- PASS: TestALUOr/kernel#01 (0.00s) --- SKIP: TestALUOr/C#02 (0.11s) --- SKIP: TestALUOr/eBPF#02 (0.00s) --- PASS: TestALUOr/kernel#02 (0.00s) --- SKIP: TestALUOr/C#03 (0.06s) --- SKIP: TestALUOr/eBPF#03 (0.02s) --- PASS: TestALUOr/kernel#03 (0.00s) === CONT TestScratchZero === RUN TestScratchZero/C === RUN TestJumpIfLessThan/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JLTReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfLessThan/kernel#03 === RUN TestMemShift/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 3 4: JGTReg dst: r6 off: -1 src: r3 5: Mov32Imm dst: r4 imm: 40 6: LdXMemB dst: r5 src: r2 off: 2 imm: 0 7: And32Imm dst: r5 imm: 15 8: LSh32Imm dst: r5 imm: 2 9: JEqReg dst: r4 off: -1 src: r5 filter_block_3: 10: Mov32Imm dst: r4 imm: 0 11: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 12: Mov32Imm dst: r4 imm: 1 13: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 14: MovImm dst: r4 imm: 0 15: JaImm dst: r0 off: -1 imm: 0 result: 16: MovImm dst: r0 imm: 2 17: JEqImm dst: r4 off: -1 imm: 0 18: MovImm dst: r0 imm: 1 return: 19: Exit === RUN TestMemShift/kernel === RUN TestMemShift/C#01 === RUN TestScratchX/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: -559038737 3: StXMemW dst: rfp src: r5 off: -32 imm: 0 4: Mov32Imm dst: r5 imm: 0 5: Mov32Imm dst: r5 imm: -1 6: StXMemW dst: rfp src: r5 off: -28 imm: 0 7: Mov32Imm dst: r5 imm: -1 8: StXMemW dst: rfp src: r5 off: -36 imm: 0 9: LdXMemW dst: r5 src: rfp off: -32 imm: 0 10: Mov32Reg dst: r4 src: r5 11: Mov32Imm dst: r6 imm: -559038737 12: JEqReg dst: r4 off: -1 src: r6 filter_block_10: 13: Mov32Imm dst: r4 imm: 0 14: JaImm dst: r0 off: -1 imm: 0 filter_block_11: 15: Mov32Imm dst: r4 imm: 1 16: JaImm dst: r0 off: -1 imm: 0 result: 17: MovImm dst: r0 imm: 2 18: JEqImm dst: r4 off: -1 imm: 0 19: MovImm dst: r0 imm: 1 return: 20: Exit === RUN TestScratchX/kernel === RUN TestScratchX/C#01 === NAME TestALUMul/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 4 3: Mul32Imm dst: r4 imm: 13 4: JEqImm dst: r4 off: -1 imm: 52 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUMul/kernel#02 === RUN TestALUMul/C#03 === RUN TestJumpIfEqual/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JEqImm dst: r4 off: -1 imm: 21 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfEqual/kernel#05 === RUN TestJumpIfNotEqual/C#04 === RUN TestALUSub/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 13 3: Sub32Imm dst: r4 imm: 9 4: JEqImm dst: r4 off: -1 imm: 4 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUSub/kernel#02 === RUN TestALUSub/C#03 === RUN TestLoadConstantX/eBPF === RUN TestALUAdd/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: Mov32Imm dst: r5 imm: 0 4: Add32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 1 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUAdd/kernel#01 === RUN TestALUAdd/C#02 === RUN TestJumpIfGreaterThan/C#06 === NAME TestLoadConstantX/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 1 3: Mov32Reg dst: r4 src: r5 4: JEqImm dst: r4 off: -1 imm: 1 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestLoadConstantX/kernel === RUN TestLoadConstantX/C#01 === RUN TestJumpIfLessThan/C#04 === RUN TestJumpIfEqual/C#06 === RUN TestALUDiv/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 19 3: Div32Imm dst: r4 imm: 3 4: JEqImm dst: r4 off: -1 imm: 6 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUDiv/kernel#02 === RUN TestALUDiv/C#03 === RUN TestScratchZero/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 4 3: StXMemW dst: rfp src: r4 off: -4 imm: 0 4: Mov32Imm dst: r4 imm: 0 5: LdXMemW dst: r4 src: rfp off: -4 imm: 0 6: JEqImm dst: r4 off: -1 imm: 4 filter_block_5: 7: Mov32Imm dst: r4 imm: 0 8: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 9: Mov32Imm dst: r4 imm: 1 10: JaImm dst: r0 off: -1 imm: 0 result: 11: MovImm dst: r0 imm: 2 12: JEqImm dst: r4 off: -1 imm: 0 13: MovImm dst: r0 imm: 1 return: 14: Exit === RUN TestScratchZero/kernel --- PASS: TestScratchZero (0.08s) --- SKIP: TestScratchZero/C (0.08s) --- SKIP: TestScratchZero/eBPF (0.00s) --- PASS: TestScratchZero/kernel (0.00s) === CONT TestLoadIndirect === RUN TestLoadIndirect/constant_valid === RUN TestLoadIndirect/constant_valid/C === RUN TestALUMul/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 4 3: Mov32Imm dst: r5 imm: 13 4: Mul32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 52 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUMul/kernel#03 === RUN TestALUMul/C#04 === RUN TestScratchX/eBPF#01 === RUN TestMemShift/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 3 4: JGTReg dst: r6 off: -1 src: r3 5: Mov32Imm dst: r4 imm: 0 6: LdXMemB dst: r5 src: r2 off: 2 imm: 0 7: And32Imm dst: r5 imm: 15 8: LSh32Imm dst: r5 imm: 2 9: JEqReg dst: r4 off: -1 src: r5 filter_block_3: 10: Mov32Imm dst: r4 imm: 0 11: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 12: Mov32Imm dst: r4 imm: 1 13: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 14: MovImm dst: r4 imm: 0 15: JaImm dst: r0 off: -1 imm: 0 result: 16: MovImm dst: r0 imm: 2 17: JEqImm dst: r4 off: -1 imm: 0 18: MovImm dst: r0 imm: 1 return: 19: Exit === RUN TestMemShift/kernel#01 --- PASS: TestMemShift (0.13s) --- SKIP: TestMemShift/C (0.04s) --- SKIP: TestMemShift/eBPF (0.00s) --- PASS: TestMemShift/kernel (0.00s) --- SKIP: TestMemShift/C#01 (0.09s) --- SKIP: TestMemShift/eBPF#01 (0.00s) --- PASS: TestMemShift/kernel#01 (0.00s) === CONT TestLoadAbsoluteBigOffset === RUN TestLoadAbsoluteBigOffset/C === NAME TestScratchX/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 0 3: StXMemW dst: rfp src: r5 off: -32 imm: 0 4: Mov32Imm dst: r5 imm: 0 5: Mov32Imm dst: r5 imm: -1 6: StXMemW dst: rfp src: r5 off: -28 imm: 0 7: Mov32Imm dst: r5 imm: -1 8: StXMemW dst: rfp src: r5 off: -36 imm: 0 9: LdXMemW dst: r5 src: rfp off: -32 imm: 0 10: Mov32Reg dst: r4 src: r5 11: JEqImm dst: r4 off: -1 imm: 0 filter_block_10: 12: Mov32Imm dst: r4 imm: 0 13: JaImm dst: r0 off: -1 imm: 0 filter_block_11: 14: Mov32Imm dst: r4 imm: 1 15: JaImm dst: r0 off: -1 imm: 0 result: 16: MovImm dst: r0 imm: 2 17: JEqImm dst: r4 off: -1 imm: 0 18: MovImm dst: r0 imm: 1 return: 19: Exit === RUN TestScratchX/kernel#01 --- PASS: TestScratchX (0.13s) --- SKIP: TestScratchX/C (0.04s) --- SKIP: TestScratchX/eBPF (0.00s) --- PASS: TestScratchX/kernel (0.00s) --- SKIP: TestScratchX/C#01 (0.08s) --- SKIP: TestScratchX/eBPF#01 (0.01s) --- PASS: TestScratchX/kernel#01 (0.00s) === CONT TestLoadAbsolute === RUN TestLoadAbsolute/C === RUN TestJumpIfGreaterThan/eBPF#06 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 23 4: JGTReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfGreaterThan/kernel#06 === RUN TestALUAdd/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 4 3: Add32Imm dst: r4 imm: 13 4: JEqImm dst: r4 off: -1 imm: 17 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUAdd/kernel#02 === RUN TestALUAdd/C#03 === RUN TestLoadConstantX/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 28 3: Mov32Reg dst: r4 src: r5 4: JEqImm dst: r4 off: -1 imm: 28 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestLoadConstantX/kernel#01 === RUN TestLoadConstantX/C#02 === RUN TestALUSub/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 13 3: Mov32Imm dst: r5 imm: 9 4: Sub32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 4 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUSub/kernel#03 --- PASS: TestALUSub (0.31s) --- SKIP: TestALUSub/C (0.06s) --- SKIP: TestALUSub/eBPF (0.00s) --- PASS: TestALUSub/kernel (0.00s) --- SKIP: TestALUSub/C#01 (0.08s) --- SKIP: TestALUSub/eBPF#01 (0.00s) --- PASS: TestALUSub/kernel#01 (0.00s) --- SKIP: TestALUSub/C#02 (0.08s) --- SKIP: TestALUSub/eBPF#02 (0.00s) --- PASS: TestALUSub/kernel#02 (0.00s) --- SKIP: TestALUSub/C#03 (0.08s) --- SKIP: TestALUSub/eBPF#03 (0.00s) --- PASS: TestALUSub/kernel#03 (0.00s) === CONT TestJumpIfBitsNotSet === RUN TestJumpIfBitsNotSet/C === RUN TestJumpIfNotEqual/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JNEImm dst: r4 off: -1 imm: 21 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfNotEqual/kernel#04 === RUN TestJumpIfNotEqual/C#05 === RUN TestLoadIndirect/constant_valid/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: -2147483644 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: 2147483647 7: JGEImm dst: r7 off: -1 imm: 65535 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 1 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemB dst: r4 src: r7 off: 0 imm: 0 13: JEqImm dst: r4 off: -1 imm: 5 filter_block_3: 14: Mov32Imm dst: r4 imm: 0 15: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 16: Mov32Imm dst: r4 imm: 1 17: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 18: MovImm dst: r4 imm: 0 19: JaImm dst: r0 off: -1 imm: 0 result: 20: MovImm dst: r0 imm: 2 21: JEqImm dst: r4 off: -1 imm: 0 22: MovImm dst: r0 imm: 1 return: 23: Exit === RUN TestLoadIndirect/constant_valid/kernel === RUN TestLoadIndirect/constant_valid/C#01 === RUN TestJumpIfGreaterThan/C#07 === RUN TestJumpIfBitsNotSet/eBPF === RUN TestALUDiv/eBPF#03 === NAME TestJumpIfBitsNotSet/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: JSetImm dst: r4 off: -1 imm: 4 4: JaImm dst: r0 off: -1 imm: 0 filter_block_2: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfBitsNotSet/kernel === NAME TestALUDiv/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 19 3: Mov32Imm dst: r5 imm: 3 4: JEqImm dst: r5 off: -1 imm: 0 5: Div32Reg dst: r4 src: r5 6: JEqImm dst: r4 off: -1 imm: 6 filter_block_4: 7: Mov32Imm dst: r4 imm: 0 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 1 10: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 11: MovImm dst: r4 imm: 0 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestALUDiv/kernel#03 --- PASS: TestALUDiv (0.39s) --- SKIP: TestALUDiv/C (0.09s) --- SKIP: TestALUDiv/eBPF (0.00s) --- PASS: TestALUDiv/kernel (0.00s) --- SKIP: TestALUDiv/C#01 (0.05s) --- SKIP: TestALUDiv/eBPF#01 (0.00s) --- PASS: TestALUDiv/kernel#01 (0.00s) --- SKIP: TestALUDiv/C#02 (0.08s) --- SKIP: TestALUDiv/eBPF#02 (0.00s) --- PASS: TestALUDiv/kernel#02 (0.00s) --- SKIP: TestALUDiv/C#03 (0.10s) --- SKIP: TestALUDiv/eBPF#03 (0.00s) --- PASS: TestALUDiv/kernel#03 (0.00s) === CONT TestTAX === RUN TestTAX/C === RUN TestJumpIfLessThan/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JLTImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfLessThan/kernel#04 === RUN TestJumpIfEqual/eBPF#06 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 21 4: JEqReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfEqual/kernel#06 === RUN TestLoadConstantX/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 0 3: Mov32Reg dst: r4 src: r5 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestLoadConstantX/kernel#02 --- PASS: TestLoadConstantX (0.20s) --- SKIP: TestLoadConstantX/C (0.08s) --- SKIP: TestLoadConstantX/eBPF (0.00s) --- PASS: TestLoadConstantX/kernel (0.00s) --- SKIP: TestLoadConstantX/C#01 (0.06s) --- SKIP: TestLoadConstantX/eBPF#01 (0.00s) --- PASS: TestLoadConstantX/kernel#01 (0.00s) --- SKIP: TestLoadConstantX/C#02 (0.05s) --- SKIP: TestLoadConstantX/eBPF#02 (0.00s) --- PASS: TestLoadConstantX/kernel#02 (0.00s) === CONT TestTXA === RUN TestTXA/C === RUN TestALUMul/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 2 3: Mul32Imm dst: r4 imm: -2147483648 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUAdd/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 4 3: Mov32Imm dst: r5 imm: 13 4: Add32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 17 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUAdd/kernel#03 === RUN TestLoadAbsoluteBigOffset/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 65535 4: JGTReg dst: r6 off: -1 src: r3 5: MovReg dst: r6 src: r2 6: AddImm dst: r6 imm: 65534 7: LdXMemB dst: r4 src: r6 off: 0 imm: 0 8: Add32Imm dst: r4 imm: 2 9: Mov32Reg dst: r4 src: r4 10: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 11: MovImm dst: r4 imm: 0 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestLoadAbsoluteBigOffset/kernel --- PASS: TestALUAdd (0.34s) --- SKIP: TestALUAdd/C (0.10s) --- SKIP: TestALUAdd/eBPF (0.00s) --- PASS: TestALUAdd/kernel (0.00s) --- SKIP: TestALUAdd/C#01 (0.09s) --- SKIP: TestALUAdd/eBPF#01 (0.00s) --- PASS: TestALUAdd/kernel#01 (0.00s) --- SKIP: TestALUAdd/C#02 (0.06s) --- SKIP: TestALUAdd/eBPF#02 (0.00s) --- PASS: TestALUAdd/kernel#02 (0.00s) --- SKIP: TestALUAdd/C#03 (0.08s) --- SKIP: TestALUAdd/eBPF#03 (0.00s) --- PASS: TestALUAdd/kernel#03 (0.00s) === CONT TestRetConstant === RUN TestRetConstant/C === RUN TestALUMul/kernel#04 === RUN TestALUMul/C#05 === RUN TestLoadAbsolute/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 3 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemB dst: r4 src: r2 off: 2 imm: 0 6: JEqImm dst: r4 off: -1 imm: 5 filter_block_2: 7: Mov32Imm dst: r4 imm: 0 8: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 9: Mov32Imm dst: r4 imm: 1 10: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 11: MovImm dst: r4 imm: 0 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestLoadAbsolute/kernel === RUN TestLoadAbsolute/C#01 === RUN TestJumpIfEqual/C#07 === RUN TestJumpIfLessThan/C#05 === RUN TestJumpIfBitsNotSet/C#01 === RUN TestTAX/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: Mov32Reg dst: r5 src: r4 4: Mov32Reg dst: r4 src: r5 5: Mov32Reg dst: r4 src: r4 6: JaImm dst: r0 off: -1 imm: 0 result: 7: MovImm dst: r0 imm: 2 8: JEqImm dst: r4 off: -1 imm: 0 9: MovImm dst: r0 imm: 1 return: 10: Exit === RUN TestTAX/kernel --- PASS: TestTAX (0.06s) --- SKIP: TestTAX/C (0.06s) --- SKIP: TestTAX/eBPF (0.00s) --- PASS: TestTAX/kernel (0.00s) === CONT TestRetA === RUN TestRetA/C === RUN TestLoadIndirect/constant_valid/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: -2147483644 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: 2147483647 7: JGEImm dst: r7 off: -1 imm: 65535 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 1 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemB dst: r4 src: r7 off: 0 imm: 0 13: JEqImm dst: r4 off: -1 imm: 6 filter_block_3: 14: Mov32Imm dst: r4 imm: 0 15: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 16: Mov32Imm dst: r4 imm: 1 17: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 18: MovImm dst: r4 imm: 0 19: JaImm dst: r0 off: -1 imm: 0 result: 20: MovImm dst: r0 imm: 2 21: JEqImm dst: r4 off: -1 imm: 0 22: MovImm dst: r0 imm: 1 return: 23: Exit === RUN TestLoadIndirect/constant_valid/kernel#01 === RUN TestTXA/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 1 3: Mov32Reg dst: r4 src: r5 4: Mov32Reg dst: r4 src: r4 5: JaImm dst: r0 off: -1 imm: 0 result: 6: MovImm dst: r0 imm: 2 7: JEqImm dst: r4 off: -1 imm: 0 8: MovImm dst: r0 imm: 1 return: 9: Exit === RUN TestTXA/kernel --- PASS: TestTXA (0.07s) --- SKIP: TestTXA/C (0.07s) --- SKIP: TestTXA/eBPF (0.00s) --- PASS: TestTXA/kernel (0.00s) === CONT TestJumpIfLessOrEqual === RUN TestJumpIfLessOrEqual/C === RUN TestLoadAbsoluteBigOffset/C#01 === RUN TestRetConstant/eBPF === RUN TestJumpIfGreaterThan/eBPF#07 === NAME TestRetConstant/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: JaImm dst: r0 off: -1 imm: 0 result: 4: MovImm dst: r0 imm: 2 5: JEqImm dst: r4 off: -1 imm: 0 6: MovImm dst: r0 imm: 1 return: 7: Exit === RUN TestRetConstant/kernel === NAME TestJumpIfGreaterThan/eBPF#07 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JGTReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestLoadAbsolute/eBPF#01 === RUN TestJumpIfGreaterThan/kernel#07 === NAME TestLoadAbsolute/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 3 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemB dst: r4 src: r2 off: 2 imm: 0 6: JEqImm dst: r4 off: -1 imm: 6 filter_block_2: 7: Mov32Imm dst: r4 imm: 0 8: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 9: Mov32Imm dst: r4 imm: 1 10: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 11: MovImm dst: r4 imm: 0 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestLoadAbsolute/kernel#01 === RUN TestRetConstant/C#01 === RUN TestRetA/eBPF === RUN TestALUMul/eBPF#05 === NAME TestRetA/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: Mov32Reg dst: r4 src: r4 4: JaImm dst: r0 off: -1 imm: 0 result: 5: MovImm dst: r0 imm: 2 6: JEqImm dst: r4 off: -1 imm: 0 7: MovImm dst: r0 imm: 1 return: 8: Exit === RUN TestJumpIfNotEqual/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JNEImm dst: r4 off: -1 imm: 21 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfNotEqual/kernel#05 === RUN TestJumpIfNotEqual/C#06 === NAME TestALUMul/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 2 3: Mov32Imm dst: r5 imm: -2147483648 4: Mul32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 0 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUMul/kernel#05 --- PASS: TestALUMul (0.50s) --- SKIP: TestALUMul/C (0.04s) --- SKIP: TestALUMul/eBPF (0.00s) --- PASS: TestALUMul/kernel (0.00s) --- SKIP: TestALUMul/C#01 (0.07s) --- SKIP: TestALUMul/eBPF#01 (0.00s) --- PASS: TestALUMul/kernel#01 (0.00s) --- SKIP: TestALUMul/C#02 (0.10s) --- SKIP: TestALUMul/eBPF#02 (0.02s) --- PASS: TestALUMul/kernel#02 (0.00s) --- SKIP: TestALUMul/C#03 (0.08s) --- SKIP: TestALUMul/eBPF#03 (0.00s) --- PASS: TestALUMul/kernel#03 (0.00s) --- SKIP: TestALUMul/C#04 (0.11s) --- SKIP: TestALUMul/eBPF#04 (0.00s) --- PASS: TestALUMul/kernel#04 (0.00s) --- SKIP: TestALUMul/C#05 (0.07s) --- SKIP: TestALUMul/eBPF#05 (0.01s) --- PASS: TestALUMul/kernel#05 (0.00s) === CONT TestJumpIfBitsSet === RUN TestJumpIfBitsSet/C === RUN TestLoadIndirect/constant_valid/C#02 === RUN TestRetA/kernel === RUN TestLoadAbsolute/C#02 --- PASS: TestRetA (0.09s) --- SKIP: TestRetA/C (0.05s) --- SKIP: TestRetA/eBPF (0.01s) --- PASS: TestRetA/kernel (0.00s) === CONT TestPartialZeroInitX === RUN TestPartialZeroInitX/C === RUN TestJumpIfGreaterThan/C#08 === RUN TestJumpIfBitsNotSet/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JSetImm dst: r4 off: -1 imm: 4 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfBitsNotSet/kernel#01 === RUN TestJumpIfLessThan/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JLTImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfLessThan/kernel#05 === RUN TestLoadAbsoluteBigOffset/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 0 3: JaImm dst: r0 off: -1 imm: 0 result: 4: MovImm dst: r0 imm: 2 5: JEqImm dst: r4 off: -1 imm: 0 6: MovImm dst: r0 imm: 1 return: 7: Exit === RUN TestLoadAbsoluteBigOffset/kernel#01 === RUN TestRetConstant/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 0 3: JaImm dst: r0 off: -1 imm: 0 result: 4: MovImm dst: r0 imm: 2 5: JEqImm dst: r4 off: -1 imm: 0 6: MovImm dst: r0 imm: 1 return: 7: Exit === RUN TestRetConstant/kernel#01 === RUN TestJumpIfBitsSet/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: JSetImm dst: r4 off: -1 imm: 4 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfBitsSet/kernel === RUN TestJumpIfBitsSet/C#01 === RUN TestJumpIfEqual/eBPF#07 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 21 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JEqReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfEqual/kernel#07 === RUN TestJumpIfNotEqual/eBPF#06 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 21 4: JNEReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfNotEqual/kernel#06 === RUN TestJumpIfNotEqual/C#07 === RUN TestJumpIfLessOrEqual/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: JLEImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfLessOrEqual/kernel === RUN TestJumpIfLessThan/C#06 === RUN TestJumpIfBitsNotSet/C#02 --- PASS: TestRetConstant (0.17s) --- SKIP: TestRetConstant/C (0.06s) --- SKIP: TestRetConstant/eBPF (0.00s) --- PASS: TestRetConstant/kernel (0.00s) --- SKIP: TestRetConstant/C#01 (0.06s) --- SKIP: TestRetConstant/eBPF#01 (0.00s) --- PASS: TestRetConstant/kernel#01 (0.05s) === CONT TestLoadConstantA === RUN TestLoadConstantA/C === RUN TestLoadAbsoluteBigOffset/C#02 === RUN TestLoadIndirect/constant_valid/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 3 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: -1 7: JGEImm dst: r7 off: -1 imm: 65534 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 2 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemH dst: r4 src: r7 off: 0 imm: 0 13: SwapBE dst: r4 imm: 16 14: JEqImm dst: r4 off: -1 imm: 57005 filter_block_3: 15: Mov32Imm dst: r4 imm: 0 16: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 17: Mov32Imm dst: r4 imm: 1 18: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 19: MovImm dst: r4 imm: 0 20: JaImm dst: r0 off: -1 imm: 0 result: 21: MovImm dst: r0 imm: 2 22: JEqImm dst: r4 off: -1 imm: 0 23: MovImm dst: r0 imm: 1 return: 24: Exit === RUN TestLoadIndirect/constant_valid/kernel#02 === RUN TestLoadIndirect/constant_valid/C#03 === RUN TestLoadAbsolute/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 4 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemH dst: r4 src: r2 off: 2 imm: 0 6: SwapBE dst: r4 imm: 16 7: JEqImm dst: r4 off: -1 imm: 57005 filter_block_2: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 12: MovImm dst: r4 imm: 0 13: JaImm dst: r0 off: -1 imm: 0 result: 14: MovImm dst: r0 imm: 2 15: JEqImm dst: r4 off: -1 imm: 0 16: MovImm dst: r0 imm: 1 return: 17: Exit === RUN TestLoadAbsolute/kernel#02 === RUN TestLoadAbsolute/C#03 === RUN TestJumpIfGreaterThan/eBPF#08 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: JGTImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfGreaterThan/kernel#08 === RUN TestJumpIfBitsSet/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JSetImm dst: r4 off: -1 imm: 4 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfBitsSet/kernel#01 === RUN TestJumpIfBitsSet/C#02 --- PASS: TestJumpIfEqual (0.93s) --- SKIP: TestJumpIfEqual/C (0.07s) --- SKIP: TestJumpIfEqual/eBPF (0.00s) --- PASS: TestJumpIfEqual/kernel (0.00s) --- SKIP: TestJumpIfEqual/C#01 (0.10s) --- SKIP: TestJumpIfEqual/eBPF#01 (0.00s) --- PASS: TestJumpIfEqual/kernel#01 (0.00s) --- SKIP: TestJumpIfEqual/C#02 (0.05s) --- SKIP: TestJumpIfEqual/eBPF#02 (0.00s) --- PASS: TestJumpIfEqual/kernel#02 (0.00s) --- SKIP: TestJumpIfEqual/C#03 (0.04s) --- SKIP: TestJumpIfEqual/eBPF#03 (0.01s) --- PASS: TestJumpIfEqual/kernel#03 (0.00s) --- SKIP: TestJumpIfEqual/C#04 (0.04s) --- SKIP: TestJumpIfEqual/eBPF#04 (0.00s) --- PASS: TestJumpIfEqual/kernel#04 (0.07s) --- SKIP: TestJumpIfEqual/C#05 (0.09s) --- SKIP: TestJumpIfEqual/eBPF#05 (0.00s) --- PASS: TestJumpIfEqual/kernel#05 (0.05s) --- SKIP: TestJumpIfEqual/C#06 (0.10s) --- SKIP: TestJumpIfEqual/eBPF#06 (0.00s) --- PASS: TestJumpIfEqual/kernel#06 (0.05s) --- SKIP: TestJumpIfEqual/C#07 (0.12s) --- SKIP: TestJumpIfEqual/eBPF#07 (0.00s) --- PASS: TestJumpIfEqual/kernel#07 (0.05s) === CONT TestJumpIfGreaterOrEqual === RUN TestJumpIfGreaterOrEqual/C === RUN TestJumpIfLessOrEqual/C#01 === RUN TestPartialZeroInitX/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 1 4: JGTReg dst: r6 off: -1 src: r3 5: Mov32Imm dst: r5 imm: 0 6: LdXMemB dst: r4 src: r2 off: 0 imm: 0 7: JNEImm dst: r4 off: -1 imm: 3 filter_block_2: 8: Mov32Reg dst: r5 src: r4 filter_block_3: 9: Mov32Reg dst: r4 src: r5 10: Mov32Reg dst: r4 src: r4 11: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 12: MovImm dst: r4 imm: 0 13: JaImm dst: r0 off: -1 imm: 0 result: 14: MovImm dst: r0 imm: 2 15: JEqImm dst: r4 off: -1 imm: 0 16: MovImm dst: r0 imm: 1 return: 17: Exit === RUN TestPartialZeroInitX/kernel === RUN TestJumpIfLessThan/eBPF#06 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 23 4: JLTReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfLessThan/kernel#06 === RUN TestLoadIndirect/constant_valid/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 3 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: -1 7: JGEImm dst: r7 off: -1 imm: 65534 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 2 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemH dst: r4 src: r7 off: 0 imm: 0 13: SwapBE dst: r4 imm: 16 14: JEqImm dst: r4 off: -1 imm: 57005 filter_block_3: 15: Mov32Imm dst: r4 imm: 0 16: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 17: Mov32Imm dst: r4 imm: 1 18: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 19: MovImm dst: r4 imm: 0 20: JaImm dst: r0 off: -1 imm: 0 result: 21: MovImm dst: r0 imm: 2 22: JEqImm dst: r4 off: -1 imm: 0 23: MovImm dst: r0 imm: 1 return: 24: Exit === RUN TestLoadIndirect/constant_valid/kernel#03 === RUN TestLoadAbsoluteBigOffset/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 65535 4: JGTReg dst: r6 off: -1 src: r3 5: MovReg dst: r6 src: r2 6: AddImm dst: r6 imm: 65533 7: LdXMemH dst: r4 src: r6 off: 0 imm: 0 8: SwapBE dst: r4 imm: 16 9: Add32Imm dst: r4 imm: 2 10: Mov32Reg dst: r4 src: r4 11: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 12: MovImm dst: r4 imm: 0 13: JaImm dst: r0 off: -1 imm: 0 result: 14: MovImm dst: r0 imm: 2 15: JEqImm dst: r4 off: -1 imm: 0 16: MovImm dst: r0 imm: 1 return: 17: Exit === RUN TestLoadAbsoluteBigOffset/kernel#02 === RUN TestJumpIfNotEqual/eBPF#07 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 21 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JNEReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfNotEqual/kernel#07 --- PASS: TestJumpIfNotEqual (0.99s) --- SKIP: TestJumpIfNotEqual/C (0.04s) --- SKIP: TestJumpIfNotEqual/eBPF (0.00s) --- PASS: TestJumpIfNotEqual/kernel (0.07s) --- SKIP: TestJumpIfNotEqual/C#01 (0.09s) --- SKIP: TestJumpIfNotEqual/eBPF#01 (0.00s) --- PASS: TestJumpIfNotEqual/kernel#01 (0.07s) --- SKIP: TestJumpIfNotEqual/C#02 (0.04s) --- SKIP: TestJumpIfNotEqual/eBPF#02 (0.00s) --- PASS: TestJumpIfNotEqual/kernel#02 (0.05s) --- SKIP: TestJumpIfNotEqual/C#03 (0.06s) --- SKIP: TestJumpIfNotEqual/eBPF#03 (0.02s) --- PASS: TestJumpIfNotEqual/kernel#03 (0.05s) --- SKIP: TestJumpIfNotEqual/C#04 (0.14s) --- SKIP: TestJumpIfNotEqual/eBPF#04 (0.00s) --- PASS: TestJumpIfNotEqual/kernel#04 (0.00s) --- SKIP: TestJumpIfNotEqual/C#05 (0.10s) --- SKIP: TestJumpIfNotEqual/eBPF#05 (0.00s) --- PASS: TestJumpIfNotEqual/kernel#05 (0.00s) --- SKIP: TestJumpIfNotEqual/C#06 (0.08s) --- SKIP: TestJumpIfNotEqual/eBPF#06 (0.00s) --- PASS: TestJumpIfNotEqual/kernel#06 (0.00s) --- SKIP: TestJumpIfNotEqual/C#07 (0.09s) --- SKIP: TestJumpIfNotEqual/eBPF#07 (0.00s) --- PASS: TestJumpIfNotEqual/kernel#07 (0.00s) === CONT TestZeroInitX === RUN TestZeroInitX/C === RUN TestJumpIfBitsNotSet/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: Mov32Imm dst: r5 imm: 4 4: JSetReg dst: r4 off: -1 src: r5 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestJumpIfBitsNotSet/kernel#02 === RUN TestLoadAbsolute/eBPF#03 === RUN TestJumpIfGreaterThan/C#09 === NAME TestLoadAbsolute/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 4 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemH dst: r4 src: r2 off: 2 imm: 0 6: SwapBE dst: r4 imm: 16 7: JEqImm dst: r4 off: -1 imm: 57007 filter_block_2: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 12: MovImm dst: r4 imm: 0 13: JaImm dst: r0 off: -1 imm: 0 result: 14: MovImm dst: r0 imm: 2 15: JEqImm dst: r4 off: -1 imm: 0 16: MovImm dst: r0 imm: 1 return: 17: Exit === RUN TestLoadAbsolute/kernel#03 === RUN TestLoadConstantA/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: JEqImm dst: r4 off: -1 imm: 1 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestLoadConstantA/kernel === RUN TestLoadConstantA/C#01 === RUN TestPartialZeroInitX/C#01 === RUN TestJumpIfGreaterOrEqual/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: JGEImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfGreaterOrEqual/kernel === RUN TestJumpIfGreaterOrEqual/C#01 === RUN TestLoadIndirect/constant_valid/C#04 === RUN TestJumpIfLessThan/C#07 === RUN TestJumpIfLessOrEqual/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JLEImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfLessOrEqual/kernel#01 === RUN TestZeroInitX/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 0 3: Mov32Reg dst: r4 src: r5 4: Mov32Reg dst: r4 src: r4 5: JaImm dst: r0 off: -1 imm: 0 result: 6: MovImm dst: r0 imm: 2 7: JEqImm dst: r4 off: -1 imm: 0 8: MovImm dst: r0 imm: 1 return: 9: Exit === RUN TestZeroInitX/kernel === RUN TestJumpIfBitsSet/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: Mov32Imm dst: r5 imm: 4 4: JSetReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfBitsSet/kernel#02 === RUN TestJumpIfBitsSet/C#03 === RUN TestLoadAbsolute/C#04 === RUN TestPartialZeroInitX/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 1 4: JGTReg dst: r6 off: -1 src: r3 5: Mov32Imm dst: r5 imm: 0 6: LdXMemB dst: r4 src: r2 off: 0 imm: 0 7: JNEImm dst: r4 off: -1 imm: 3 filter_block_2: 8: Mov32Reg dst: r5 src: r4 filter_block_3: 9: Mov32Reg dst: r4 src: r5 10: Mov32Reg dst: r4 src: r4 11: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 12: MovImm dst: r4 imm: 0 13: JaImm dst: r0 off: -1 imm: 0 result: 14: MovImm dst: r0 imm: 2 15: JEqImm dst: r4 off: -1 imm: 0 16: MovImm dst: r0 imm: 1 return: 17: Exit === RUN TestPartialZeroInitX/kernel#01 --- PASS: TestPartialZeroInitX (0.21s) --- SKIP: TestPartialZeroInitX/C (0.11s) --- SKIP: TestPartialZeroInitX/eBPF (0.00s) --- PASS: TestPartialZeroInitX/kernel (0.05s) --- SKIP: TestPartialZeroInitX/C#01 (0.05s) --- SKIP: TestPartialZeroInitX/eBPF#01 (0.00s) --- PASS: TestPartialZeroInitX/kernel#01 (0.00s) === RUN TestLoadAbsoluteBigOffset/C#03 === RUN TestJumpIfBitsNotSet/C#03 === RUN TestJumpIfGreaterThan/eBPF#09 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JGTImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfGreaterThan/kernel#09 === RUN TestJumpIfBitsSet/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: Mov32Imm dst: r5 imm: 4 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JSetReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfBitsSet/kernel#03 === RUN TestJumpIfBitsSet/C#04 === RUN TestJumpIfGreaterOrEqual/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JGEImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfGreaterOrEqual/kernel#01 === RUN TestJumpIfLessOrEqual/C#02 --- PASS: TestZeroInitX (0.11s) --- SKIP: TestZeroInitX/C (0.06s) --- SKIP: TestZeroInitX/eBPF (0.00s) --- PASS: TestZeroInitX/kernel (0.05s) === RUN TestJumpIfGreaterOrEqual/C#02 === RUN TestLoadConstantA/eBPF#01 === RUN TestJumpIfGreaterThan/C#10 === NAME TestLoadConstantA/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 28 3: JEqImm dst: r4 off: -1 imm: 28 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestLoadConstantA/kernel#01 === RUN TestLoadConstantA/C#02 === RUN TestJumpIfBitsNotSet/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: Mov32Imm dst: r5 imm: 4 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JSetReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfBitsNotSet/kernel#03 === RUN TestJumpIfLessThan/eBPF#07 === RUN TestLoadIndirect/constant_valid/eBPF#04 === NAME TestJumpIfLessThan/eBPF#07 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JLTReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfLessThan/kernel#07 === NAME TestLoadIndirect/constant_valid/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 1 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: 2 7: JGEImm dst: r7 off: -1 imm: 65532 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 4 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemW dst: r4 src: r7 off: 0 imm: 0 13: SwapBE dst: r4 imm: 32 14: Mov32Imm dst: r6 imm: -559038737 15: JEqReg dst: r4 off: -1 src: r6 filter_block_3: 16: Mov32Imm dst: r4 imm: 0 17: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 18: Mov32Imm dst: r4 imm: 1 19: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 20: MovImm dst: r4 imm: 0 21: JaImm dst: r0 off: -1 imm: 0 result: 22: MovImm dst: r0 imm: 2 23: JEqImm dst: r4 off: -1 imm: 0 24: MovImm dst: r0 imm: 1 return: 25: Exit === RUN TestLoadIndirect/constant_valid/kernel#04 === RUN TestLoadIndirect/constant_valid/C#05 === RUN TestLoadAbsoluteBigOffset/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 0 3: JaImm dst: r0 off: -1 imm: 0 result: 4: MovImm dst: r0 imm: 2 5: JEqImm dst: r4 off: -1 imm: 0 6: MovImm dst: r0 imm: 1 return: 7: Exit === RUN TestLoadAbsoluteBigOffset/kernel#03 === RUN TestJumpIfBitsSet/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: JSetImm dst: r4 off: -1 imm: 2 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfBitsSet/kernel#04 === RUN TestJumpIfLessOrEqual/eBPF#02 === RUN TestJumpIfBitsSet/C#05 === NAME TestJumpIfLessOrEqual/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: Mov32Imm dst: r5 imm: 23 4: JLEReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfLessOrEqual/kernel#02 === RUN TestLoadAbsolute/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 6 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemW dst: r4 src: r2 off: 2 imm: 0 6: SwapBE dst: r4 imm: 32 7: Mov32Imm dst: r6 imm: -559038737 8: JEqReg dst: r4 off: -1 src: r6 filter_block_2: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 13: MovImm dst: r4 imm: 0 14: JaImm dst: r0 off: -1 imm: 0 result: 15: MovImm dst: r0 imm: 2 16: JEqImm dst: r4 off: -1 imm: 0 17: MovImm dst: r0 imm: 1 return: 18: Exit === RUN TestLoadAbsolute/kernel#04 === RUN TestLoadAbsolute/C#05 === RUN TestJumpIfGreaterOrEqual/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: Mov32Imm dst: r5 imm: 23 4: JGEReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfGreaterOrEqual/kernel#02 === RUN TestJumpIfGreaterOrEqual/C#03 === RUN TestJumpIfBitsNotSet/C#04 === RUN TestLoadConstantA/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 0 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestLoadConstantA/kernel#02 --- PASS: TestLoadConstantA (0.28s) --- SKIP: TestLoadConstantA/C (0.10s) --- SKIP: TestLoadConstantA/eBPF (0.00s) --- PASS: TestLoadConstantA/kernel (0.00s) --- SKIP: TestLoadConstantA/C#01 (0.10s) --- SKIP: TestLoadConstantA/eBPF#01 (0.00s) --- PASS: TestLoadConstantA/kernel#01 (0.00s) --- SKIP: TestLoadConstantA/C#02 (0.06s) --- SKIP: TestLoadConstantA/eBPF#02 (0.00s) --- PASS: TestLoadConstantA/kernel#02 (0.00s) === RUN TestJumpIfLessThan/C#08 === RUN TestLoadIndirect/constant_valid/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 1 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: 2 7: JGEImm dst: r7 off: -1 imm: 65532 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 4 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemW dst: r4 src: r7 off: 0 imm: 0 13: SwapBE dst: r4 imm: 32 14: Mov32Imm dst: r6 imm: -559038737 15: JEqReg dst: r4 off: -1 src: r6 filter_block_3: 16: Mov32Imm dst: r4 imm: 0 17: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 18: Mov32Imm dst: r4 imm: 1 19: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 20: MovImm dst: r4 imm: 0 21: JaImm dst: r0 off: -1 imm: 0 result: 22: MovImm dst: r0 imm: 2 23: JEqImm dst: r4 off: -1 imm: 0 24: MovImm dst: r0 imm: 1 return: 25: Exit === RUN TestLoadIndirect/constant_valid/kernel#05 === RUN TestJumpIfGreaterThan/eBPF#10 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: Mov32Imm dst: r5 imm: 23 4: JGTReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfGreaterThan/kernel#10 === RUN TestJumpIfBitsSet/eBPF#05 === RUN TestLoadAbsoluteBigOffset/C#04 === RUN TestJumpIfLessOrEqual/C#03 === NAME TestJumpIfBitsSet/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JSetImm dst: r4 off: -1 imm: 2 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfBitsSet/kernel#05 === RUN TestJumpIfBitsSet/C#06 === RUN TestJumpIfGreaterOrEqual/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JGEReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfGreaterOrEqual/kernel#03 === RUN TestJumpIfGreaterOrEqual/C#04 === RUN TestLoadAbsolute/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 6 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemW dst: r4 src: r2 off: 2 imm: 0 6: SwapBE dst: r4 imm: 32 7: Mov32Imm dst: r6 imm: -558907665 8: JEqReg dst: r4 off: -1 src: r6 filter_block_2: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 13: MovImm dst: r4 imm: 0 14: JaImm dst: r0 off: -1 imm: 0 result: 15: MovImm dst: r0 imm: 2 16: JEqImm dst: r4 off: -1 imm: 0 17: MovImm dst: r0 imm: 1 return: 18: Exit === RUN TestLoadAbsolute/kernel#05 === RUN TestJumpIfBitsNotSet/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: JSetImm dst: r4 off: -1 imm: 2 4: JaImm dst: r0 off: -1 imm: 0 filter_block_2: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfBitsNotSet/kernel#04 === RUN TestJumpIfLessOrEqual/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JLEReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfLessOrEqual/kernel#03 === RUN TestJumpIfGreaterThan/C#11 === RUN TestJumpIfGreaterOrEqual/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JGEImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfGreaterOrEqual/kernel#04 === RUN TestJumpIfGreaterOrEqual/C#05 === RUN TestJumpIfLessThan/eBPF#08 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: JLTImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfLessThan/kernel#08 === RUN TestJumpIfLessThan/C#09 === RUN TestLoadIndirect/variable_valid === RUN TestLoadIndirect/variable_valid/C === RUN TestLoadAbsoluteBigOffset/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 65535 4: JGTReg dst: r6 off: -1 src: r3 5: MovReg dst: r6 src: r2 6: AddImm dst: r6 imm: 65531 7: LdXMemW dst: r4 src: r6 off: 0 imm: 0 8: SwapBE dst: r4 imm: 32 9: Add32Imm dst: r4 imm: 2 10: Mov32Reg dst: r4 src: r4 11: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 12: MovImm dst: r4 imm: 0 13: JaImm dst: r0 off: -1 imm: 0 result: 14: MovImm dst: r0 imm: 2 15: JEqImm dst: r4 off: -1 imm: 0 16: MovImm dst: r0 imm: 1 return: 17: Exit === RUN TestLoadAbsoluteBigOffset/kernel#04 === RUN TestJumpIfBitsSet/eBPF#06 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: Mov32Imm dst: r5 imm: 2 4: JSetReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfBitsSet/kernel#06 === RUN TestJumpIfBitsSet/C#07 --- PASS: TestLoadAbsolute (0.65s) --- SKIP: TestLoadAbsolute/C (0.10s) --- SKIP: TestLoadAbsolute/eBPF (0.00s) --- PASS: TestLoadAbsolute/kernel (0.00s) --- SKIP: TestLoadAbsolute/C#01 (0.05s) --- SKIP: TestLoadAbsolute/eBPF#01 (0.00s) --- PASS: TestLoadAbsolute/kernel#01 (0.05s) --- SKIP: TestLoadAbsolute/C#02 (0.09s) --- SKIP: TestLoadAbsolute/eBPF#02 (0.00s) --- PASS: TestLoadAbsolute/kernel#02 (0.00s) --- SKIP: TestLoadAbsolute/C#03 (0.06s) --- SKIP: TestLoadAbsolute/eBPF#03 (0.00s) --- PASS: TestLoadAbsolute/kernel#03 (0.06s) --- SKIP: TestLoadAbsolute/C#04 (0.10s) --- SKIP: TestLoadAbsolute/eBPF#04 (0.00s) --- PASS: TestLoadAbsolute/kernel#04 (0.00s) --- SKIP: TestLoadAbsolute/C#05 (0.08s) --- SKIP: TestLoadAbsolute/eBPF#05 (0.00s) --- PASS: TestLoadAbsolute/kernel#05 (0.05s) === RUN TestJumpIfBitsNotSet/C#05 === RUN TestJumpIfLessOrEqual/C#04 === RUN TestJumpIfGreaterThan/eBPF#11 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JGTReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfGreaterThan/kernel#11 === RUN TestJumpIfGreaterOrEqual/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JGEImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfGreaterOrEqual/kernel#05 === RUN TestJumpIfGreaterOrEqual/C#06 === RUN TestLoadAbsoluteBigOffset/C#05 === RUN TestJumpIfBitsNotSet/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JSetImm dst: r4 off: -1 imm: 2 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfBitsNotSet/kernel#05 === RUN TestJumpIfLessOrEqual/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JLEImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfLessOrEqual/kernel#04 === RUN TestJumpIfLessOrEqual/C#05 === RUN TestJumpIfLessThan/eBPF#09 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JLTImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfLessThan/kernel#09 === RUN TestJumpIfLessThan/C#10 === RUN TestLoadIndirect/variable_valid/eBPF === RUN TestJumpIfBitsSet/eBPF#07 === NAME TestLoadIndirect/variable_valid/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 4 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemW dst: r4 src: r2 off: 0 imm: 0 6: SwapBE dst: r4 imm: 32 7: Mov32Reg dst: r5 src: r4 8: MovReg dst: r7 src: r5 9: LShImm dst: r7 imm: 32 10: ArShImm dst: r7 imm: 32 11: AddImm dst: r7 imm: 13 12: JGEImm dst: r7 off: -1 imm: 65535 13: AddReg dst: r7 src: r2 14: MovReg dst: r6 src: r7 15: AddImm dst: r6 imm: 1 16: JGTReg dst: r6 off: -1 src: r3 17: LdXMemB dst: r4 src: r7 off: 0 imm: 0 18: JEqImm dst: r4 off: -1 imm: 5 filter_block_4: 19: Mov32Imm dst: r4 imm: 0 20: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 21: Mov32Imm dst: r4 imm: 1 22: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 23: MovImm dst: r4 imm: 0 24: JaImm dst: r0 off: -1 imm: 0 result: 25: MovImm dst: r0 imm: 2 26: JEqImm dst: r4 off: -1 imm: 0 27: MovImm dst: r0 imm: 1 return: 28: Exit === RUN TestLoadIndirect/variable_valid/kernel === RUN TestLoadIndirect/variable_valid/C#01 === NAME TestJumpIfBitsSet/eBPF#07 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: Mov32Imm dst: r5 imm: 2 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JSetReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfBitsSet/kernel#07 === RUN TestJumpIfBitsSet/C#08 === RUN TestJumpIfGreaterOrEqual/eBPF#06 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 23 4: JGEReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfGreaterOrEqual/kernel#06 === RUN TestJumpIfLessOrEqual/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JLEImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfLessOrEqual/kernel#05 === RUN TestJumpIfGreaterOrEqual/C#07 === RUN TestJumpIfLessOrEqual/C#06 --- PASS: TestJumpIfGreaterThan (1.38s) --- SKIP: TestJumpIfGreaterThan/C (0.05s) --- SKIP: TestJumpIfGreaterThan/eBPF (0.00s) --- PASS: TestJumpIfGreaterThan/kernel (0.00s) --- SKIP: TestJumpIfGreaterThan/C#01 (0.06s) --- SKIP: TestJumpIfGreaterThan/eBPF#01 (0.00s) --- PASS: TestJumpIfGreaterThan/kernel#01 (0.00s) --- SKIP: TestJumpIfGreaterThan/C#02 (0.09s) --- SKIP: TestJumpIfGreaterThan/eBPF#02 (0.00s) --- PASS: TestJumpIfGreaterThan/kernel#02 (0.00s) --- SKIP: TestJumpIfGreaterThan/C#03 (0.07s) --- SKIP: TestJumpIfGreaterThan/eBPF#03 (0.00s) --- PASS: TestJumpIfGreaterThan/kernel#03 (0.00s) --- SKIP: TestJumpIfGreaterThan/C#04 (0.09s) --- SKIP: TestJumpIfGreaterThan/eBPF#04 (0.00s) --- PASS: TestJumpIfGreaterThan/kernel#04 (0.06s) --- SKIP: TestJumpIfGreaterThan/C#05 (0.07s) --- SKIP: TestJumpIfGreaterThan/eBPF#05 (0.00s) --- PASS: TestJumpIfGreaterThan/kernel#05 (0.05s) --- SKIP: TestJumpIfGreaterThan/C#06 (0.04s) --- SKIP: TestJumpIfGreaterThan/eBPF#06 (0.00s) --- PASS: TestJumpIfGreaterThan/kernel#06 (0.07s) --- SKIP: TestJumpIfGreaterThan/C#07 (0.09s) --- SKIP: TestJumpIfGreaterThan/eBPF#07 (0.00s) --- PASS: TestJumpIfGreaterThan/kernel#07 (0.05s) --- SKIP: TestJumpIfGreaterThan/C#08 (0.09s) --- SKIP: TestJumpIfGreaterThan/eBPF#08 (0.00s) --- PASS: TestJumpIfGreaterThan/kernel#08 (0.06s) --- SKIP: TestJumpIfGreaterThan/C#09 (0.08s) --- SKIP: TestJumpIfGreaterThan/eBPF#09 (0.00s) --- PASS: TestJumpIfGreaterThan/kernel#09 (0.05s) --- SKIP: TestJumpIfGreaterThan/C#10 (0.08s) --- SKIP: TestJumpIfGreaterThan/eBPF#10 (0.00s) --- PASS: TestJumpIfGreaterThan/kernel#10 (0.05s) --- SKIP: TestJumpIfGreaterThan/C#11 (0.05s) --- SKIP: TestJumpIfGreaterThan/eBPF#11 (0.00s) --- PASS: TestJumpIfGreaterThan/kernel#11 (0.07s) === RUN TestLoadAbsoluteBigOffset/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 0 3: JaImm dst: r0 off: -1 imm: 0 result: 4: MovImm dst: r0 imm: 2 5: JEqImm dst: r4 off: -1 imm: 0 6: MovImm dst: r0 imm: 1 return: 7: Exit === RUN TestLoadAbsoluteBigOffset/kernel#05 === RUN TestJumpIfBitsNotSet/C#06 === RUN TestJumpIfLessThan/eBPF#10 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: Mov32Imm dst: r5 imm: 23 4: JLTReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfLessThan/kernel#10 === RUN TestJumpIfLessThan/C#11 === RUN TestJumpIfBitsSet/eBPF#08 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: JSetImm dst: r4 off: -1 imm: 8 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfBitsSet/kernel#08 === RUN TestJumpIfBitsNotSet/eBPF#06 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: Mov32Imm dst: r5 imm: 2 4: JSetReg dst: r4 off: -1 src: r5 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestJumpIfBitsNotSet/kernel#06 === RUN TestJumpIfGreaterOrEqual/eBPF#07 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JGEReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestLoadAbsoluteBigOffset/C#06 === RUN TestJumpIfGreaterOrEqual/kernel#07 === RUN TestJumpIfGreaterOrEqual/C#08 === RUN TestJumpIfLessOrEqual/eBPF#06 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 23 4: JLEReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfLessOrEqual/kernel#06 === RUN TestJumpIfLessOrEqual/C#07 === RUN TestLoadIndirect/variable_valid/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 4 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemW dst: r4 src: r2 off: 0 imm: 0 6: SwapBE dst: r4 imm: 32 7: Mov32Reg dst: r5 src: r4 8: MovReg dst: r7 src: r5 9: LShImm dst: r7 imm: 32 10: ArShImm dst: r7 imm: 32 11: AddImm dst: r7 imm: 13 12: JGEImm dst: r7 off: -1 imm: 65535 13: AddReg dst: r7 src: r2 14: MovReg dst: r6 src: r7 15: AddImm dst: r6 imm: 1 16: JGTReg dst: r6 off: -1 src: r3 17: LdXMemB dst: r4 src: r7 off: 0 imm: 0 18: JEqImm dst: r4 off: -1 imm: 6 filter_block_4: 19: Mov32Imm dst: r4 imm: 0 20: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 21: Mov32Imm dst: r4 imm: 1 22: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 23: MovImm dst: r4 imm: 0 24: JaImm dst: r0 off: -1 imm: 0 result: 25: MovImm dst: r0 imm: 2 26: JEqImm dst: r4 off: -1 imm: 0 27: MovImm dst: r0 imm: 1 return: 28: Exit === RUN TestLoadIndirect/variable_valid/kernel#01 === RUN TestJumpIfLessThan/eBPF#11 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JLTReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfLessThan/kernel#11 --- PASS: TestJumpIfLessThan (1.45s) --- SKIP: TestJumpIfLessThan/C (0.06s) --- SKIP: TestJumpIfLessThan/eBPF (0.00s) --- PASS: TestJumpIfLessThan/kernel (0.07s) --- SKIP: TestJumpIfLessThan/C#01 (0.11s) --- SKIP: TestJumpIfLessThan/eBPF#01 (0.00s) --- PASS: TestJumpIfLessThan/kernel#01 (0.05s) --- SKIP: TestJumpIfLessThan/C#02 (0.06s) --- SKIP: TestJumpIfLessThan/eBPF#02 (0.00s) --- PASS: TestJumpIfLessThan/kernel#02 (0.07s) --- SKIP: TestJumpIfLessThan/C#03 (0.08s) --- SKIP: TestJumpIfLessThan/eBPF#03 (0.00s) --- PASS: TestJumpIfLessThan/kernel#03 (0.05s) --- SKIP: TestJumpIfLessThan/C#04 (0.10s) --- SKIP: TestJumpIfLessThan/eBPF#04 (0.00s) --- PASS: TestJumpIfLessThan/kernel#04 (0.05s) --- SKIP: TestJumpIfLessThan/C#05 (0.09s) --- SKIP: TestJumpIfLessThan/eBPF#05 (0.00s) --- PASS: TestJumpIfLessThan/kernel#05 (0.05s) --- SKIP: TestJumpIfLessThan/C#06 (0.08s) --- SKIP: TestJumpIfLessThan/eBPF#06 (0.00s) --- PASS: TestJumpIfLessThan/kernel#06 (0.06s) --- SKIP: TestJumpIfLessThan/C#07 (0.09s) --- SKIP: TestJumpIfLessThan/eBPF#07 (0.00s) --- PASS: TestJumpIfLessThan/kernel#07 (0.05s) --- SKIP: TestJumpIfLessThan/C#08 (0.08s) --- SKIP: TestJumpIfLessThan/eBPF#08 (0.00s) --- PASS: TestJumpIfLessThan/kernel#08 (0.00s) --- SKIP: TestJumpIfLessThan/C#09 (0.07s) --- SKIP: TestJumpIfLessThan/eBPF#09 (0.00s) --- PASS: TestJumpIfLessThan/kernel#09 (0.00s) --- SKIP: TestJumpIfLessThan/C#10 (0.05s) --- SKIP: TestJumpIfLessThan/eBPF#10 (0.00s) --- PASS: TestJumpIfLessThan/kernel#10 (0.00s) --- SKIP: TestJumpIfLessThan/C#11 (0.05s) --- SKIP: TestJumpIfLessThan/eBPF#11 (0.00s) --- PASS: TestJumpIfLessThan/kernel#11 (0.00s) === RUN TestJumpIfBitsSet/C#09 === RUN TestJumpIfGreaterOrEqual/eBPF#08 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: JGEImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfGreaterOrEqual/kernel#08 === RUN TestLoadAbsoluteBigOffset/eBPF#06 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 65535 4: JGTReg dst: r6 off: -1 src: r3 5: Mov32Imm dst: r4 imm: 0 6: MovReg dst: r6 src: r2 7: AddImm dst: r6 imm: 65534 8: LdXMemB dst: r5 src: r6 off: 0 imm: 0 9: And32Imm dst: r5 imm: 15 10: LSh32Imm dst: r5 imm: 2 11: Add32Imm dst: r4 imm: 2 12: Mov32Reg dst: r4 src: r4 13: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 14: MovImm dst: r4 imm: 0 15: JaImm dst: r0 off: -1 imm: 0 result: 16: MovImm dst: r0 imm: 2 17: JEqImm dst: r4 off: -1 imm: 0 18: MovImm dst: r0 imm: 1 return: 19: Exit === RUN TestLoadAbsoluteBigOffset/kernel#06 === RUN TestJumpIfLessOrEqual/eBPF#07 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JLEReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfLessOrEqual/kernel#07 === RUN TestJumpIfLessOrEqual/C#08 === RUN TestJumpIfBitsNotSet/C#07 === RUN TestLoadIndirect/variable_valid/C#02 === RUN TestJumpIfLessOrEqual/eBPF#08 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: JLEImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfLessOrEqual/kernel#08 === RUN TestJumpIfLessOrEqual/C#09 === RUN TestJumpIfGreaterOrEqual/C#09 === RUN TestJumpIfBitsSet/eBPF#09 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JSetImm dst: r4 off: -1 imm: 8 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfBitsSet/kernel#09 === RUN TestLoadAbsoluteBigOffset/C#07 === RUN TestLoadIndirect/variable_valid/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 4 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemW dst: r4 src: r2 off: 0 imm: 0 6: SwapBE dst: r4 imm: 32 7: Mov32Reg dst: r5 src: r4 8: MovReg dst: r7 src: r5 9: LShImm dst: r7 imm: 32 10: ArShImm dst: r7 imm: 32 11: AddImm dst: r7 imm: -2147483641 12: JGEImm dst: r7 off: -1 imm: 65534 13: AddReg dst: r7 src: r2 14: MovReg dst: r6 src: r7 15: AddImm dst: r6 imm: 2 16: JGTReg dst: r6 off: -1 src: r3 17: LdXMemH dst: r4 src: r7 off: 0 imm: 0 18: SwapBE dst: r4 imm: 16 19: JEqImm dst: r4 off: -1 imm: 57005 filter_block_4: 20: Mov32Imm dst: r4 imm: 0 21: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 22: Mov32Imm dst: r4 imm: 1 23: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 24: MovImm dst: r4 imm: 0 25: JaImm dst: r0 off: -1 imm: 0 result: 26: MovImm dst: r0 imm: 2 27: JEqImm dst: r4 off: -1 imm: 0 28: MovImm dst: r0 imm: 1 return: 29: Exit === RUN TestLoadIndirect/variable_valid/kernel#02 === RUN TestLoadIndirect/variable_valid/C#03 === RUN TestJumpIfBitsNotSet/eBPF#07 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: Mov32Imm dst: r5 imm: 2 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JSetReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfBitsNotSet/kernel#07 === RUN TestJumpIfLessOrEqual/eBPF#09 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JLEImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfLessOrEqual/kernel#09 === RUN TestJumpIfLessOrEqual/C#10 === RUN TestJumpIfBitsSet/C#10 === RUN TestLoadAbsoluteBigOffset/eBPF#07 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 0 3: JaImm dst: r0 off: -1 imm: 0 result: 4: MovImm dst: r0 imm: 2 5: JEqImm dst: r4 off: -1 imm: 0 6: MovImm dst: r0 imm: 1 return: 7: Exit === RUN TestLoadAbsoluteBigOffset/kernel#07 === RUN TestLoadIndirect/variable_valid/eBPF#03 === RUN TestJumpIfGreaterOrEqual/eBPF#09 === NAME TestLoadIndirect/variable_valid/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 4 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemW dst: r4 src: r2 off: 0 imm: 0 6: SwapBE dst: r4 imm: 32 7: Mov32Reg dst: r5 src: r4 8: MovReg dst: r7 src: r5 9: LShImm dst: r7 imm: 32 10: ArShImm dst: r7 imm: 32 11: AddImm dst: r7 imm: -2147483641 12: JGEImm dst: r7 off: -1 imm: 65534 13: AddReg dst: r7 src: r2 14: MovReg dst: r6 src: r7 15: AddImm dst: r6 imm: 2 16: JGTReg dst: r6 off: -1 src: r3 17: LdXMemH dst: r4 src: r7 off: 0 imm: 0 18: SwapBE dst: r4 imm: 16 19: JEqImm dst: r4 off: -1 imm: 57005 filter_block_4: 20: Mov32Imm dst: r4 imm: 0 21: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 22: Mov32Imm dst: r4 imm: 1 23: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 24: MovImm dst: r4 imm: 0 25: JaImm dst: r0 off: -1 imm: 0 result: 26: MovImm dst: r0 imm: 2 27: JEqImm dst: r4 off: -1 imm: 0 28: MovImm dst: r0 imm: 1 return: 29: Exit === RUN TestLoadIndirect/variable_valid/kernel#03 === NAME TestJumpIfGreaterOrEqual/eBPF#09 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JGEImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfGreaterOrEqual/kernel#09 === RUN TestJumpIfBitsNotSet/C#08 === RUN TestJumpIfLessOrEqual/eBPF#10 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: Mov32Imm dst: r5 imm: 23 4: JLEReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfLessOrEqual/kernel#10 === RUN TestJumpIfLessOrEqual/C#11 === RUN TestJumpIfBitsSet/eBPF#10 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: Mov32Imm dst: r5 imm: 8 4: JSetReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfBitsSet/kernel#10 === RUN TestJumpIfBitsNotSet/eBPF#08 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: JSetImm dst: r4 off: -1 imm: 8 4: JaImm dst: r0 off: -1 imm: 0 filter_block_2: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfBitsNotSet/kernel#08 === RUN TestJumpIfBitsNotSet/C#09 === RUN TestJumpIfLessOrEqual/eBPF#11 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JLEReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit --- PASS: TestLoadAbsoluteBigOffset (1.00s) --- SKIP: TestLoadAbsoluteBigOffset/C (0.10s) --- SKIP: TestLoadAbsoluteBigOffset/eBPF (0.00s) --- PASS: TestLoadAbsoluteBigOffset/kernel (0.05s) --- SKIP: TestLoadAbsoluteBigOffset/C#01 (0.06s) --- SKIP: TestLoadAbsoluteBigOffset/eBPF#01 (0.00s) --- PASS: TestLoadAbsoluteBigOffset/kernel#01 (0.05s) --- SKIP: TestLoadAbsoluteBigOffset/C#02 (0.08s) --- SKIP: TestLoadAbsoluteBigOffset/eBPF#02 (0.00s) --- PASS: TestLoadAbsoluteBigOffset/kernel#02 (0.07s) --- SKIP: TestLoadAbsoluteBigOffset/C#03 (0.08s) --- SKIP: TestLoadAbsoluteBigOffset/eBPF#03 (0.00s) --- PASS: TestLoadAbsoluteBigOffset/kernel#03 (0.07s) --- SKIP: TestLoadAbsoluteBigOffset/C#04 (0.07s) --- SKIP: TestLoadAbsoluteBigOffset/eBPF#04 (0.00s) --- PASS: TestLoadAbsoluteBigOffset/kernel#04 (0.05s) --- SKIP: TestLoadAbsoluteBigOffset/C#05 (0.05s) --- SKIP: TestLoadAbsoluteBigOffset/eBPF#05 (0.00s) --- PASS: TestLoadAbsoluteBigOffset/kernel#05 (0.05s) --- SKIP: TestLoadAbsoluteBigOffset/C#06 (0.03s) --- SKIP: TestLoadAbsoluteBigOffset/eBPF#06 (0.00s) --- PASS: TestLoadAbsoluteBigOffset/kernel#06 (0.05s) --- SKIP: TestLoadAbsoluteBigOffset/C#07 (0.06s) --- SKIP: TestLoadAbsoluteBigOffset/eBPF#07 (0.00s) --- PASS: TestLoadAbsoluteBigOffset/kernel#07 (0.05s) === RUN TestJumpIfLessOrEqual/kernel#11 --- PASS: TestJumpIfLessOrEqual (0.85s) --- SKIP: TestJumpIfLessOrEqual/C (0.12s) --- SKIP: TestJumpIfLessOrEqual/eBPF (0.00s) --- PASS: TestJumpIfLessOrEqual/kernel (0.05s) --- SKIP: TestJumpIfLessOrEqual/C#01 (0.09s) --- SKIP: TestJumpIfLessOrEqual/eBPF#01 (0.00s) --- PASS: TestJumpIfLessOrEqual/kernel#01 (0.05s) --- SKIP: TestJumpIfLessOrEqual/C#02 (0.06s) --- SKIP: TestJumpIfLessOrEqual/eBPF#02 (0.00s) --- PASS: TestJumpIfLessOrEqual/kernel#02 (0.05s) --- SKIP: TestJumpIfLessOrEqual/C#03 (0.04s) --- SKIP: TestJumpIfLessOrEqual/eBPF#03 (0.00s) --- PASS: TestJumpIfLessOrEqual/kernel#03 (0.05s) --- SKIP: TestJumpIfLessOrEqual/C#04 (0.04s) --- SKIP: TestJumpIfLessOrEqual/eBPF#04 (0.00s) --- PASS: TestJumpIfLessOrEqual/kernel#04 (0.00s) --- SKIP: TestJumpIfLessOrEqual/C#05 (0.04s) --- SKIP: TestJumpIfLessOrEqual/eBPF#05 (0.00s) --- PASS: TestJumpIfLessOrEqual/kernel#05 (0.00s) --- SKIP: TestJumpIfLessOrEqual/C#06 (0.05s) --- SKIP: TestJumpIfLessOrEqual/eBPF#06 (0.00s) --- PASS: TestJumpIfLessOrEqual/kernel#06 (0.00s) --- SKIP: TestJumpIfLessOrEqual/C#07 (0.04s) --- SKIP: TestJumpIfLessOrEqual/eBPF#07 (0.00s) --- PASS: TestJumpIfLessOrEqual/kernel#07 (0.00s) --- SKIP: TestJumpIfLessOrEqual/C#08 (0.03s) --- SKIP: TestJumpIfLessOrEqual/eBPF#08 (0.00s) --- PASS: TestJumpIfLessOrEqual/kernel#08 (0.00s) --- SKIP: TestJumpIfLessOrEqual/C#09 (0.06s) --- SKIP: TestJumpIfLessOrEqual/eBPF#09 (0.00s) --- PASS: TestJumpIfLessOrEqual/kernel#09 (0.00s) --- SKIP: TestJumpIfLessOrEqual/C#10 (0.04s) --- SKIP: TestJumpIfLessOrEqual/eBPF#10 (0.00s) --- PASS: TestJumpIfLessOrEqual/kernel#10 (0.00s) --- SKIP: TestJumpIfLessOrEqual/C#11 (0.03s) --- SKIP: TestJumpIfLessOrEqual/eBPF#11 (0.00s) --- PASS: TestJumpIfLessOrEqual/kernel#11 (0.00s) === RUN TestJumpIfGreaterOrEqual/C#10 === RUN TestLoadIndirect/variable_valid/C#04 === RUN TestJumpIfBitsNotSet/eBPF#09 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JSetImm dst: r4 off: -1 imm: 8 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfBitsNotSet/kernel#09 === RUN TestJumpIfBitsNotSet/C#10 === RUN TestJumpIfBitsSet/C#11 === RUN TestLoadIndirect/variable_valid/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 4 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemW dst: r4 src: r2 off: 0 imm: 0 6: SwapBE dst: r4 imm: 32 7: Mov32Reg dst: r5 src: r4 8: MovReg dst: r7 src: r5 9: LShImm dst: r7 imm: 32 10: ArShImm dst: r7 imm: 32 11: AddImm dst: r7 imm: 4 12: JGEImm dst: r7 off: -1 imm: 65532 13: AddReg dst: r7 src: r2 14: MovReg dst: r6 src: r7 15: AddImm dst: r6 imm: 4 16: JGTReg dst: r6 off: -1 src: r3 17: LdXMemW dst: r4 src: r7 off: 0 imm: 0 18: SwapBE dst: r4 imm: 32 19: Mov32Imm dst: r6 imm: -559038737 20: JEqReg dst: r4 off: -1 src: r6 filter_block_4: 21: Mov32Imm dst: r4 imm: 0 22: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 23: Mov32Imm dst: r4 imm: 1 24: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 25: MovImm dst: r4 imm: 0 26: JaImm dst: r0 off: -1 imm: 0 result: 27: MovImm dst: r0 imm: 2 28: JEqImm dst: r4 off: -1 imm: 0 29: MovImm dst: r0 imm: 1 return: 30: Exit === RUN TestLoadIndirect/variable_valid/kernel#04 === RUN TestLoadIndirect/variable_valid/C#05 === RUN TestJumpIfGreaterOrEqual/eBPF#10 === RUN TestJumpIfBitsNotSet/eBPF#10 === NAME TestJumpIfGreaterOrEqual/eBPF#10 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: Mov32Imm dst: r5 imm: 23 4: JGEReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfGreaterOrEqual/kernel#10 === NAME TestJumpIfBitsNotSet/eBPF#10 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: Mov32Imm dst: r5 imm: 8 4: JSetReg dst: r4 off: -1 src: r5 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestJumpIfBitsNotSet/kernel#10 === RUN TestJumpIfBitsNotSet/C#11 === RUN TestJumpIfBitsSet/eBPF#11 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: Mov32Imm dst: r5 imm: 8 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JSetReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfBitsSet/kernel#11 === RUN TestLoadIndirect/variable_valid/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 4 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemW dst: r4 src: r2 off: 0 imm: 0 6: SwapBE dst: r4 imm: 32 7: Mov32Reg dst: r5 src: r4 8: MovReg dst: r7 src: r5 9: LShImm dst: r7 imm: 32 10: ArShImm dst: r7 imm: 32 11: AddImm dst: r7 imm: 4 12: JGEImm dst: r7 off: -1 imm: 65532 13: AddReg dst: r7 src: r2 14: MovReg dst: r6 src: r7 15: AddImm dst: r6 imm: 4 16: JGTReg dst: r6 off: -1 src: r3 17: LdXMemW dst: r4 src: r7 off: 0 imm: 0 18: SwapBE dst: r4 imm: 32 19: Mov32Imm dst: r6 imm: -559038737 20: JEqReg dst: r4 off: -1 src: r6 filter_block_4: 21: Mov32Imm dst: r4 imm: 0 22: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 23: Mov32Imm dst: r4 imm: 1 24: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 25: MovImm dst: r4 imm: 0 26: JaImm dst: r0 off: -1 imm: 0 result: 27: MovImm dst: r0 imm: 2 28: JEqImm dst: r4 off: -1 imm: 0 29: MovImm dst: r0 imm: 1 return: 30: Exit === RUN TestLoadIndirect/variable_valid/kernel#05 === RUN TestJumpIfBitsNotSet/eBPF#11 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: Mov32Imm dst: r5 imm: 8 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JSetReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfBitsNotSet/kernel#11 --- PASS: TestJumpIfBitsNotSet (1.07s) --- SKIP: TestJumpIfBitsNotSet/C (0.04s) --- SKIP: TestJumpIfBitsNotSet/eBPF (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel (0.05s) --- SKIP: TestJumpIfBitsNotSet/C#01 (0.09s) --- SKIP: TestJumpIfBitsNotSet/eBPF#01 (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel#01 (0.05s) --- SKIP: TestJumpIfBitsNotSet/C#02 (0.09s) --- SKIP: TestJumpIfBitsNotSet/eBPF#02 (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel#02 (0.07s) --- SKIP: TestJumpIfBitsNotSet/C#03 (0.07s) --- SKIP: TestJumpIfBitsNotSet/eBPF#03 (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel#03 (0.05s) --- SKIP: TestJumpIfBitsNotSet/C#04 (0.06s) --- SKIP: TestJumpIfBitsNotSet/eBPF#04 (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel#04 (0.05s) --- SKIP: TestJumpIfBitsNotSet/C#05 (0.05s) --- SKIP: TestJumpIfBitsNotSet/eBPF#05 (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel#05 (0.05s) --- SKIP: TestJumpIfBitsNotSet/C#06 (0.04s) --- SKIP: TestJumpIfBitsNotSet/eBPF#06 (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel#06 (0.05s) --- SKIP: TestJumpIfBitsNotSet/C#07 (0.06s) --- SKIP: TestJumpIfBitsNotSet/eBPF#07 (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel#07 (0.05s) --- SKIP: TestJumpIfBitsNotSet/C#08 (0.03s) --- SKIP: TestJumpIfBitsNotSet/eBPF#08 (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel#08 (0.00s) --- SKIP: TestJumpIfBitsNotSet/C#09 (0.04s) --- SKIP: TestJumpIfBitsNotSet/eBPF#09 (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel#09 (0.00s) --- SKIP: TestJumpIfBitsNotSet/C#10 (0.04s) --- SKIP: TestJumpIfBitsNotSet/eBPF#10 (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel#10 (0.00s) --- SKIP: TestJumpIfBitsNotSet/C#11 (0.03s) --- SKIP: TestJumpIfBitsNotSet/eBPF#11 (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel#11 (0.00s) === RUN TestJumpIfGreaterOrEqual/C#11 --- PASS: TestJumpIfBitsSet (0.93s) --- SKIP: TestJumpIfBitsSet/C (0.06s) --- SKIP: TestJumpIfBitsSet/eBPF (0.00s) --- PASS: TestJumpIfBitsSet/kernel (0.00s) --- SKIP: TestJumpIfBitsSet/C#01 (0.07s) --- SKIP: TestJumpIfBitsSet/eBPF#01 (0.00s) --- PASS: TestJumpIfBitsSet/kernel#01 (0.00s) --- SKIP: TestJumpIfBitsSet/C#02 (0.09s) --- SKIP: TestJumpIfBitsSet/eBPF#02 (0.00s) --- PASS: TestJumpIfBitsSet/kernel#02 (0.00s) --- SKIP: TestJumpIfBitsSet/C#03 (0.04s) --- SKIP: TestJumpIfBitsSet/eBPF#03 (0.00s) --- PASS: TestJumpIfBitsSet/kernel#03 (0.00s) --- SKIP: TestJumpIfBitsSet/C#04 (0.06s) --- SKIP: TestJumpIfBitsSet/eBPF#04 (0.00s) --- PASS: TestJumpIfBitsSet/kernel#04 (0.00s) --- SKIP: TestJumpIfBitsSet/C#05 (0.05s) --- SKIP: TestJumpIfBitsSet/eBPF#05 (0.00s) --- PASS: TestJumpIfBitsSet/kernel#05 (0.00s) --- SKIP: TestJumpIfBitsSet/C#06 (0.06s) --- SKIP: TestJumpIfBitsSet/eBPF#06 (0.00s) --- PASS: TestJumpIfBitsSet/kernel#06 (0.00s) --- SKIP: TestJumpIfBitsSet/C#07 (0.07s) --- SKIP: TestJumpIfBitsSet/eBPF#07 (0.00s) --- PASS: TestJumpIfBitsSet/kernel#07 (0.00s) --- SKIP: TestJumpIfBitsSet/C#08 (0.04s) --- SKIP: TestJumpIfBitsSet/eBPF#08 (0.00s) --- PASS: TestJumpIfBitsSet/kernel#08 (0.05s) --- SKIP: TestJumpIfBitsSet/C#09 (0.06s) --- SKIP: TestJumpIfBitsSet/eBPF#09 (0.00s) --- PASS: TestJumpIfBitsSet/kernel#09 (0.05s) --- SKIP: TestJumpIfBitsSet/C#10 (0.04s) --- SKIP: TestJumpIfBitsSet/eBPF#10 (0.00s) --- PASS: TestJumpIfBitsSet/kernel#10 (0.05s) --- SKIP: TestJumpIfBitsSet/C#11 (0.03s) --- SKIP: TestJumpIfBitsSet/eBPF#11 (0.00s) --- PASS: TestJumpIfBitsSet/kernel#11 (0.05s) === RUN TestLoadIndirect/constant_outofbounds === RUN TestLoadIndirect/constant_outofbounds/C === RUN TestJumpIfGreaterOrEqual/eBPF#11 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JGEReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfGreaterOrEqual/kernel#11 === RUN TestLoadIndirect/constant_outofbounds/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: -3 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: 3 7: JGEImm dst: r7 off: -1 imm: 65535 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 1 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemB dst: r4 src: r7 off: 0 imm: 0 13: Mov32Imm dst: r4 imm: 1 14: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 15: MovImm dst: r4 imm: 0 16: JaImm dst: r0 off: -1 imm: 0 result: 17: MovImm dst: r0 imm: 2 18: JEqImm dst: r4 off: -1 imm: 0 19: MovImm dst: r0 imm: 1 return: 20: Exit === RUN TestLoadIndirect/constant_outofbounds/kernel === RUN TestLoadIndirect/constant_outofbounds/C#01 --- PASS: TestJumpIfGreaterOrEqual (0.88s) --- SKIP: TestJumpIfGreaterOrEqual/C (0.06s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF (0.00s) --- PASS: TestJumpIfGreaterOrEqual/kernel (0.00s) --- SKIP: TestJumpIfGreaterOrEqual/C#01 (0.07s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF#01 (0.01s) --- PASS: TestJumpIfGreaterOrEqual/kernel#01 (0.00s) --- SKIP: TestJumpIfGreaterOrEqual/C#02 (0.07s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF#02 (0.00s) --- PASS: TestJumpIfGreaterOrEqual/kernel#02 (0.00s) --- SKIP: TestJumpIfGreaterOrEqual/C#03 (0.06s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF#03 (0.00s) --- PASS: TestJumpIfGreaterOrEqual/kernel#03 (0.00s) --- SKIP: TestJumpIfGreaterOrEqual/C#04 (0.04s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF#04 (0.00s) --- PASS: TestJumpIfGreaterOrEqual/kernel#04 (0.00s) --- SKIP: TestJumpIfGreaterOrEqual/C#05 (0.06s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF#05 (0.00s) --- PASS: TestJumpIfGreaterOrEqual/kernel#05 (0.00s) --- SKIP: TestJumpIfGreaterOrEqual/C#06 (0.03s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF#06 (0.00s) --- PASS: TestJumpIfGreaterOrEqual/kernel#06 (0.00s) --- SKIP: TestJumpIfGreaterOrEqual/C#07 (0.05s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF#07 (0.00s) --- PASS: TestJumpIfGreaterOrEqual/kernel#07 (0.00s) --- SKIP: TestJumpIfGreaterOrEqual/C#08 (0.03s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF#08 (0.00s) --- PASS: TestJumpIfGreaterOrEqual/kernel#08 (0.05s) --- SKIP: TestJumpIfGreaterOrEqual/C#09 (0.07s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF#09 (0.00s) --- PASS: TestJumpIfGreaterOrEqual/kernel#09 (0.05s) --- SKIP: TestJumpIfGreaterOrEqual/C#10 (0.06s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF#10 (0.00s) --- PASS: TestJumpIfGreaterOrEqual/kernel#10 (0.05s) --- SKIP: TestJumpIfGreaterOrEqual/C#11 (0.03s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF#11 (0.00s) --- PASS: TestJumpIfGreaterOrEqual/kernel#11 (0.05s) === RUN TestLoadIndirect/constant_outofbounds/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: -16 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: 15 7: JGEImm dst: r7 off: -1 imm: 65535 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 1 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemB dst: r4 src: r7 off: 0 imm: 0 13: Mov32Imm dst: r4 imm: 1 14: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 15: MovImm dst: r4 imm: 0 16: JaImm dst: r0 off: -1 imm: 0 result: 17: MovImm dst: r0 imm: 2 18: JEqImm dst: r4 off: -1 imm: 0 19: MovImm dst: r0 imm: 1 return: 20: Exit === RUN TestLoadIndirect/constant_outofbounds/kernel#01 === RUN TestLoadIndirect/constant_outofbounds/C#02 === RUN TestLoadIndirect/constant_outofbounds/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: -1 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: -2 7: JGEImm dst: r7 off: -1 imm: 65532 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 4 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemW dst: r4 src: r7 off: 0 imm: 0 13: SwapBE dst: r4 imm: 32 14: Mov32Imm dst: r4 imm: 1 15: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 16: MovImm dst: r4 imm: 0 17: JaImm dst: r0 off: -1 imm: 0 result: 18: MovImm dst: r0 imm: 2 19: JEqImm dst: r4 off: -1 imm: 0 20: MovImm dst: r0 imm: 1 return: 21: Exit === RUN TestLoadIndirect/constant_outofbounds/kernel#02 === RUN TestLoadIndirect/constant_outofbounds/C#03 === RUN TestLoadIndirect/constant_outofbounds/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 255 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: -300 7: JGEImm dst: r7 off: -1 imm: 65534 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 2 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemH dst: r4 src: r7 off: 0 imm: 0 13: SwapBE dst: r4 imm: 16 14: Mov32Imm dst: r4 imm: 1 15: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 16: MovImm dst: r4 imm: 0 17: JaImm dst: r0 off: -1 imm: 0 result: 18: MovImm dst: r0 imm: 2 19: JEqImm dst: r4 off: -1 imm: 0 20: MovImm dst: r0 imm: 1 return: 21: Exit === RUN TestLoadIndirect/constant_outofbounds/kernel#03 === RUN TestLoadIndirect/constant_outofbounds/C#04 === RUN TestLoadIndirect/constant_outofbounds/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: -16 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: 30 7: JGEImm dst: r7 off: -1 imm: 65535 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 1 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemB dst: r4 src: r7 off: 0 imm: 0 13: Mov32Imm dst: r4 imm: 1 14: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 15: MovImm dst: r4 imm: 0 16: JaImm dst: r0 off: -1 imm: 0 result: 17: MovImm dst: r0 imm: 2 18: JEqImm dst: r4 off: -1 imm: 0 19: MovImm dst: r0 imm: 1 return: 20: Exit === RUN TestLoadIndirect/constant_outofbounds/kernel#04 === RUN TestLoadIndirect/variable_outofbounds === RUN TestLoadIndirect/variable_outofbounds/C === RUN TestLoadIndirect/variable_outofbounds/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 4 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemW dst: r4 src: r2 off: 0 imm: 0 6: SwapBE dst: r4 imm: 32 7: Mov32Reg dst: r5 src: r4 8: MovReg dst: r7 src: r5 9: LShImm dst: r7 imm: 32 10: ArShImm dst: r7 imm: 32 11: AddImm dst: r7 imm: 3 12: JGEImm dst: r7 off: -1 imm: 65535 13: AddReg dst: r7 src: r2 14: MovReg dst: r6 src: r7 15: AddImm dst: r6 imm: 1 16: JGTReg dst: r6 off: -1 src: r3 17: LdXMemB dst: r4 src: r7 off: 0 imm: 0 18: Mov32Imm dst: r4 imm: 1 19: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 20: MovImm dst: r4 imm: 0 21: JaImm dst: r0 off: -1 imm: 0 result: 22: MovImm dst: r0 imm: 2 23: JEqImm dst: r4 off: -1 imm: 0 24: MovImm dst: r0 imm: 1 return: 25: Exit === RUN TestLoadIndirect/variable_outofbounds/kernel === RUN TestLoadIndirect/variable_outofbounds/C#01 === RUN TestLoadIndirect/variable_outofbounds/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 4 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemW dst: r4 src: r2 off: 0 imm: 0 6: SwapBE dst: r4 imm: 32 7: Mov32Reg dst: r5 src: r4 8: MovReg dst: r7 src: r5 9: LShImm dst: r7 imm: 32 10: ArShImm dst: r7 imm: 32 11: AddImm dst: r7 imm: 15 12: JGEImm dst: r7 off: -1 imm: 65535 13: AddReg dst: r7 src: r2 14: MovReg dst: r6 src: r7 15: AddImm dst: r6 imm: 1 16: JGTReg dst: r6 off: -1 src: r3 17: LdXMemB dst: r4 src: r7 off: 0 imm: 0 18: Mov32Imm dst: r4 imm: 1 19: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 20: MovImm dst: r4 imm: 0 21: JaImm dst: r0 off: -1 imm: 0 result: 22: MovImm dst: r0 imm: 2 23: JEqImm dst: r4 off: -1 imm: 0 24: MovImm dst: r0 imm: 1 return: 25: Exit === RUN TestLoadIndirect/variable_outofbounds/kernel#01 === RUN TestLoadIndirect/variable_outofbounds/C#02 === RUN TestLoadIndirect/variable_outofbounds/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 4 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemW dst: r4 src: r2 off: 0 imm: 0 6: SwapBE dst: r4 imm: 32 7: Mov32Reg dst: r5 src: r4 8: MovReg dst: r7 src: r5 9: LShImm dst: r7 imm: 32 10: ArShImm dst: r7 imm: 32 11: AddImm dst: r7 imm: -2 12: JGEImm dst: r7 off: -1 imm: 65532 13: AddReg dst: r7 src: r2 14: MovReg dst: r6 src: r7 15: AddImm dst: r6 imm: 4 16: JGTReg dst: r6 off: -1 src: r3 17: LdXMemW dst: r4 src: r7 off: 0 imm: 0 18: SwapBE dst: r4 imm: 32 19: Mov32Imm dst: r4 imm: 1 20: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 21: MovImm dst: r4 imm: 0 22: JaImm dst: r0 off: -1 imm: 0 result: 23: MovImm dst: r0 imm: 2 24: JEqImm dst: r4 off: -1 imm: 0 25: MovImm dst: r0 imm: 1 return: 26: Exit === RUN TestLoadIndirect/variable_outofbounds/kernel#02 === RUN TestLoadIndirect/variable_outofbounds/C#03 === RUN TestLoadIndirect/variable_outofbounds/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 4 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemW dst: r4 src: r2 off: 0 imm: 0 6: SwapBE dst: r4 imm: 32 7: Mov32Reg dst: r5 src: r4 8: MovReg dst: r7 src: r5 9: LShImm dst: r7 imm: 32 10: ArShImm dst: r7 imm: 32 11: AddImm dst: r7 imm: -300 12: JGEImm dst: r7 off: -1 imm: 65534 13: AddReg dst: r7 src: r2 14: MovReg dst: r6 src: r7 15: AddImm dst: r6 imm: 2 16: JGTReg dst: r6 off: -1 src: r3 17: LdXMemH dst: r4 src: r7 off: 0 imm: 0 18: SwapBE dst: r4 imm: 16 19: Mov32Imm dst: r4 imm: 1 20: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 21: MovImm dst: r4 imm: 0 22: JaImm dst: r0 off: -1 imm: 0 result: 23: MovImm dst: r0 imm: 2 24: JEqImm dst: r4 off: -1 imm: 0 25: MovImm dst: r0 imm: 1 return: 26: Exit === RUN TestLoadIndirect/variable_outofbounds/kernel#03 === RUN TestLoadIndirect/variable_outofbounds/C#04 === RUN TestLoadIndirect/variable_outofbounds/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 4 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemW dst: r4 src: r2 off: 0 imm: 0 6: SwapBE dst: r4 imm: 32 7: Mov32Reg dst: r5 src: r4 8: MovReg dst: r7 src: r5 9: LShImm dst: r7 imm: 32 10: ArShImm dst: r7 imm: 32 11: AddImm dst: r7 imm: 30 12: JGEImm dst: r7 off: -1 imm: 65535 13: AddReg dst: r7 src: r2 14: MovReg dst: r6 src: r7 15: AddImm dst: r6 imm: 1 16: JGTReg dst: r6 off: -1 src: r3 17: LdXMemB dst: r4 src: r7 off: 0 imm: 0 18: Mov32Imm dst: r4 imm: 1 19: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 20: MovImm dst: r4 imm: 0 21: JaImm dst: r0 off: -1 imm: 0 result: 22: MovImm dst: r0 imm: 2 23: JEqImm dst: r4 off: -1 imm: 0 24: MovImm dst: r0 imm: 1 return: 25: Exit === RUN TestLoadIndirect/variable_outofbounds/kernel#04 --- PASS: TestLoadIndirect (1.97s) --- PASS: TestLoadIndirect/constant_valid (0.63s) --- SKIP: TestLoadIndirect/constant_valid/C (0.05s) --- SKIP: TestLoadIndirect/constant_valid/eBPF (0.00s) --- PASS: TestLoadIndirect/constant_valid/kernel (0.00s) --- SKIP: TestLoadIndirect/constant_valid/C#01 (0.06s) --- SKIP: TestLoadIndirect/constant_valid/eBPF#01 (0.00s) --- PASS: TestLoadIndirect/constant_valid/kernel#01 (0.06s) --- SKIP: TestLoadIndirect/constant_valid/C#02 (0.07s) --- SKIP: TestLoadIndirect/constant_valid/eBPF#02 (0.00s) --- PASS: TestLoadIndirect/constant_valid/kernel#02 (0.00s) --- SKIP: TestLoadIndirect/constant_valid/C#03 (0.06s) --- SKIP: TestLoadIndirect/constant_valid/eBPF#03 (0.00s) --- PASS: TestLoadIndirect/constant_valid/kernel#03 (0.06s) --- SKIP: TestLoadIndirect/constant_valid/C#04 (0.10s) --- SKIP: TestLoadIndirect/constant_valid/eBPF#04 (0.00s) --- PASS: TestLoadIndirect/constant_valid/kernel#04 (0.00s) --- SKIP: TestLoadIndirect/constant_valid/C#05 (0.06s) --- SKIP: TestLoadIndirect/constant_valid/eBPF#05 (0.00s) --- PASS: TestLoadIndirect/constant_valid/kernel#05 (0.05s) --- PASS: TestLoadIndirect/variable_valid (0.49s) --- SKIP: TestLoadIndirect/variable_valid/C (0.07s) --- SKIP: TestLoadIndirect/variable_valid/eBPF (0.00s) --- PASS: TestLoadIndirect/variable_valid/kernel (0.00s) --- SKIP: TestLoadIndirect/variable_valid/C#01 (0.09s) --- SKIP: TestLoadIndirect/variable_valid/eBPF#01 (0.00s) --- PASS: TestLoadIndirect/variable_valid/kernel#01 (0.05s) --- SKIP: TestLoadIndirect/variable_valid/C#02 (0.04s) --- SKIP: TestLoadIndirect/variable_valid/eBPF#02 (0.00s) --- PASS: TestLoadIndirect/variable_valid/kernel#02 (0.00s) --- SKIP: TestLoadIndirect/variable_valid/C#03 (0.05s) --- SKIP: TestLoadIndirect/variable_valid/eBPF#03 (0.00s) --- PASS: TestLoadIndirect/variable_valid/kernel#03 (0.05s) --- SKIP: TestLoadIndirect/variable_valid/C#04 (0.05s) --- SKIP: TestLoadIndirect/variable_valid/eBPF#04 (0.00s) --- PASS: TestLoadIndirect/variable_valid/kernel#04 (0.00s) --- SKIP: TestLoadIndirect/variable_valid/C#05 (0.03s) --- SKIP: TestLoadIndirect/variable_valid/eBPF#05 (0.00s) --- PASS: TestLoadIndirect/variable_valid/kernel#05 (0.05s) --- PASS: TestLoadIndirect/constant_outofbounds (0.37s) --- SKIP: TestLoadIndirect/constant_outofbounds/C (0.03s) --- SKIP: TestLoadIndirect/constant_outofbounds/eBPF (0.00s) --- PASS: TestLoadIndirect/constant_outofbounds/kernel (0.00s) --- SKIP: TestLoadIndirect/constant_outofbounds/C#01 (0.03s) --- SKIP: TestLoadIndirect/constant_outofbounds/eBPF#01 (0.00s) --- PASS: TestLoadIndirect/constant_outofbounds/kernel#01 (0.05s) --- SKIP: TestLoadIndirect/constant_outofbounds/C#02 (0.03s) --- SKIP: TestLoadIndirect/constant_outofbounds/eBPF#02 (0.00s) --- PASS: TestLoadIndirect/constant_outofbounds/kernel#02 (0.05s) --- SKIP: TestLoadIndirect/constant_outofbounds/C#03 (0.03s) --- SKIP: TestLoadIndirect/constant_outofbounds/eBPF#03 (0.00s) --- PASS: TestLoadIndirect/constant_outofbounds/kernel#03 (0.05s) --- SKIP: TestLoadIndirect/constant_outofbounds/C#04 (0.03s) --- SKIP: TestLoadIndirect/constant_outofbounds/eBPF#04 (0.00s) --- PASS: TestLoadIndirect/constant_outofbounds/kernel#04 (0.05s) --- PASS: TestLoadIndirect/variable_outofbounds (0.45s) --- SKIP: TestLoadIndirect/variable_outofbounds/C (0.04s) --- SKIP: TestLoadIndirect/variable_outofbounds/eBPF (0.00s) --- PASS: TestLoadIndirect/variable_outofbounds/kernel (0.00s) --- SKIP: TestLoadIndirect/variable_outofbounds/C#01 (0.04s) --- SKIP: TestLoadIndirect/variable_outofbounds/eBPF#01 (0.00s) --- PASS: TestLoadIndirect/variable_outofbounds/kernel#01 (0.05s) --- SKIP: TestLoadIndirect/variable_outofbounds/C#02 (0.04s) --- SKIP: TestLoadIndirect/variable_outofbounds/eBPF#02 (0.00s) --- PASS: TestLoadIndirect/variable_outofbounds/kernel#02 (0.05s) --- SKIP: TestLoadIndirect/variable_outofbounds/C#03 (0.06s) --- SKIP: TestLoadIndirect/variable_outofbounds/eBPF#03 (0.00s) --- PASS: TestLoadIndirect/variable_outofbounds/kernel#03 (0.05s) --- SKIP: TestLoadIndirect/variable_outofbounds/C#04 (0.06s) --- SKIP: TestLoadIndirect/variable_outofbounds/eBPF#04 (0.00s) --- PASS: TestLoadIndirect/variable_outofbounds/kernel#04 (0.05s) PASS ok github.com/cloudflare/cbpfc 3.623s ? github.com/cloudflare/cbpfc/clang [no test files] make[1]: Leaving directory '/build/reproducible-path/golang-github-cloudflare-cbpfc-0.0~git20231012.992ed75' create-stamp debian/debhelper-build-stamp dh_testroot -O--builddirectory=_build -O--buildsystem=golang dh_prep -O--builddirectory=_build -O--buildsystem=golang dh_auto_install --destdir=debian/golang-github-cloudflare-cbpfc-dev/ -O--builddirectory=_build -O--buildsystem=golang dh_installdocs -O--builddirectory=_build -O--buildsystem=golang dh_installchangelogs -O--builddirectory=_build -O--buildsystem=golang dh_installsystemduser -O--builddirectory=_build -O--buildsystem=golang dh_perl -O--builddirectory=_build -O--buildsystem=golang dh_link -O--builddirectory=_build -O--buildsystem=golang dh_strip_nondeterminism -O--builddirectory=_build -O--buildsystem=golang dh_compress -O--builddirectory=_build -O--buildsystem=golang dh_fixperms -O--builddirectory=_build -O--buildsystem=golang dh_missing -O--builddirectory=_build -O--buildsystem=golang dh_installdeb -O--builddirectory=_build -O--buildsystem=golang dh_golang -O--builddirectory=_build -O--buildsystem=golang dh_gencontrol -O--builddirectory=_build -O--buildsystem=golang dh_md5sums -O--builddirectory=_build -O--buildsystem=golang dh_builddeb -O--builddirectory=_build -O--buildsystem=golang dpkg-deb: building package 'golang-github-cloudflare-cbpfc-dev' in '../golang-github-cloudflare-cbpfc-dev_0.0~git20231012.992ed75-2_all.deb'. dpkg-genbuildinfo --build=binary -O../golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_arm64.buildinfo dpkg-genchanges --build=binary -O../golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_arm64.changes dpkg-genchanges: info: binary-only upload (no source code included) dpkg-source --after-build . dpkg-buildpackage: info: binary-only upload (no source included) dpkg-genchanges: info: not including original source code in upload I: copying local configuration I: unmounting dev/ptmx filesystem I: unmounting dev/pts filesystem I: unmounting dev/shm filesystem I: unmounting proc filesystem I: unmounting sys filesystem I: cleaning the build env I: removing directory /srv/workspace/pbuilder/2165263 and its subdirectories I: Current time: Fri Feb 21 21:06:49 -12 2025 I: pbuilder-time-stamp: 1740215209 Sat Feb 22 09:06:49 UTC 2025 I: Signing ./b1/golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_arm64.buildinfo as golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_arm64.buildinfo.asc Sat Feb 22 09:06:49 UTC 2025 I: Signed ./b1/golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_arm64.buildinfo as ./b1/golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_arm64.buildinfo.asc Sat Feb 22 09:06:49 UTC 2025 - build #1 for golang-github-cloudflare-cbpfc/trixie/arm64 on codethink04-arm64 done. Starting cleanup. All cleanup done. Sat Feb 22 09:06:49 UTC 2025 - reproducible_build.sh stopped running as /tmp/jenkins-script-hyEKHSrk, removing. /srv/reproducible-results/rbuild-debian/r-b-build.bvEh5Q9U: total 16 drwxr-xr-x 2 jenkins jenkins 4096 Feb 22 09:06 b1 drwxr-xr-x 2 jenkins jenkins 4096 Feb 22 09:06 b2 -rw-r--r-- 1 jenkins jenkins 2689 Jun 27 2024 golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.dsc -rw------- 1 jenkins jenkins 4048 Feb 22 09:06 rbuildlog.HdrqVCF /srv/reproducible-results/rbuild-debian/r-b-build.bvEh5Q9U/b1: total 324 -rw-r--r-- 1 jenkins jenkins 270026 Feb 22 09:06 build.log -rw-r--r-- 1 jenkins jenkins 26656 Feb 22 09:06 golang-github-cloudflare-cbpfc-dev_0.0~git20231012.992ed75-2_all.deb -rw-r--r-- 1 jenkins jenkins 3100 Feb 22 09:06 golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.debian.tar.xz -rw-r--r-- 1 jenkins jenkins 2689 Feb 22 09:06 golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.dsc -rw-r--r-- 1 jenkins jenkins 5786 Feb 22 09:06 golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_arm64.buildinfo -rw-r--r-- 1 jenkins jenkins 6668 Feb 22 09:06 golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_arm64.buildinfo.asc -rw-r--r-- 1 jenkins jenkins 1414 Feb 22 09:06 golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_arm64.changes -rw-r--r-- 1 jenkins jenkins 1645 Feb 22 09:06 golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_source.changes /srv/reproducible-results/rbuild-debian/r-b-build.bvEh5Q9U/b2: total 0 Sat Feb 22 09:06:50 UTC 2025 I: Deleting $TMPDIR on codethink04-arm64.debian.net. I: pbuilder: network access will be disabled during build I: Current time: Fri Feb 21 21:06:04 -12 2025 I: pbuilder-time-stamp: 1740215164 I: Building the build Environment I: extracting base tarball [/var/cache/pbuilder/trixie-reproducible-base.tgz] I: copying local configuration W: --override-config is not set; not updating apt.conf Read the manpage for details. I: mounting /proc filesystem I: mounting /sys filesystem I: creating /{dev,run}/shm I: mounting /dev/pts filesystem I: redirecting /dev/ptmx to /dev/pts/ptmx I: policy-rc.d already exists I: Copying source file I: copying [golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.dsc] I: copying [./golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75.orig.tar.gz] I: copying [./golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.debian.tar.xz] I: Extracting source dpkg-source: warning: cannot verify inline signature for ./golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.dsc: unsupported subcommand dpkg-source: info: extracting golang-github-cloudflare-cbpfc in golang-github-cloudflare-cbpfc-0.0~git20231012.992ed75 dpkg-source: info: unpacking golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75.orig.tar.gz dpkg-source: info: unpacking golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.debian.tar.xz dpkg-source: info: using patch list from debian/patches/series dpkg-source: info: applying auto-gitignore I: Not using root during the build. I: Installing the build-deps I: user script /srv/workspace/pbuilder/2165263/tmp/hooks/D02_print_environment starting I: set BUILDDIR='/build/reproducible-path' BUILDUSERGECOS='first user,first room,first work-phone,first home-phone,first other' BUILDUSERNAME='pbuilder1' BUILD_ARCH='arm64' DEBIAN_FRONTEND='noninteractive' DEB_BUILD_OPTIONS='buildinfo=+all reproducible=+all parallel=12 ' DISTRIBUTION='trixie' HOME='/root' HOST_ARCH='arm64' IFS=' ' INVOCATION_ID='e5e12366e69441d9acc7a55619923dfc' LANG='C' LANGUAGE='en_US:en' LC_ALL='C' MAIL='/var/mail/root' OPTIND='1' PATH='/usr/sbin:/usr/bin:/sbin:/bin:/usr/games' PBCURRENTCOMMANDLINEOPERATION='build' PBUILDER_OPERATION='build' PBUILDER_PKGDATADIR='/usr/share/pbuilder' PBUILDER_PKGLIBDIR='/usr/lib/pbuilder' PBUILDER_SYSCONFDIR='/etc' PPID='2165263' PS1='# ' PS2='> ' PS4='+ ' PWD='/' SHELL='/bin/bash' SHLVL='2' SUDO_COMMAND='/usr/bin/timeout -k 18.1h 18h /usr/bin/ionice -c 3 /usr/bin/nice /usr/sbin/pbuilder --build --configfile /srv/reproducible-results/rbuild-debian/r-b-build.bvEh5Q9U/pbuilderrc_UIik --distribution trixie --hookdir /etc/pbuilder/first-build-hooks --debbuildopts -b --basetgz /var/cache/pbuilder/trixie-reproducible-base.tgz --buildresult /srv/reproducible-results/rbuild-debian/r-b-build.bvEh5Q9U/b1 --logfile b1/build.log golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.dsc' SUDO_GID='109' SUDO_UID='104' SUDO_USER='jenkins' TERM='unknown' TZ='/usr/share/zoneinfo/Etc/GMT+12' USER='root' _='/usr/bin/systemd-run' http_proxy='http://192.168.101.4:3128' I: uname -a Linux codethink04-arm64 6.1.0-31-cloud-arm64 #1 SMP Debian 6.1.128-1 (2025-02-07) aarch64 GNU/Linux I: ls -l /bin lrwxrwxrwx 1 root root 7 Nov 22 14:40 /bin -> usr/bin I: user script /srv/workspace/pbuilder/2165263/tmp/hooks/D02_print_environment finished -> Attempting to satisfy build-dependencies -> Creating pbuilder-satisfydepends-dummy package Package: pbuilder-satisfydepends-dummy Version: 0.invalid.0 Architecture: arm64 Maintainer: Debian Pbuilder Team Description: Dummy package to satisfy dependencies with aptitude - created by pbuilder This package was created automatically by pbuilder to satisfy the build-dependencies of the package being currently built. Depends: debhelper-compat (= 13), clang, dh-golang, golang-any, golang-github-cilium-ebpf-dev, golang-github-pkg-errors-dev, golang-golang-x-net-dev, golang-golang-x-sys-dev dpkg-deb: building package 'pbuilder-satisfydepends-dummy' in '/tmp/satisfydepends-aptitude/pbuilder-satisfydepends-dummy.deb'. Selecting previously unselected package pbuilder-satisfydepends-dummy. (Reading database ... 19972 files and directories currently installed.) Preparing to unpack .../pbuilder-satisfydepends-dummy.deb ... Unpacking pbuilder-satisfydepends-dummy (0.invalid.0) ... dpkg: pbuilder-satisfydepends-dummy: dependency problems, but configuring anyway as you requested: pbuilder-satisfydepends-dummy depends on debhelper-compat (= 13); however: Package debhelper-compat is not installed. pbuilder-satisfydepends-dummy depends on clang; however: Package clang is not installed. pbuilder-satisfydepends-dummy depends on dh-golang; however: Package dh-golang is not installed. pbuilder-satisfydepends-dummy depends on golang-any; however: Package golang-any is not installed. pbuilder-satisfydepends-dummy depends on golang-github-cilium-ebpf-dev; however: Package golang-github-cilium-ebpf-dev is not installed. pbuilder-satisfydepends-dummy depends on golang-github-pkg-errors-dev; however: Package golang-github-pkg-errors-dev is not installed. pbuilder-satisfydepends-dummy depends on golang-golang-x-net-dev; however: Package golang-golang-x-net-dev is not installed. pbuilder-satisfydepends-dummy depends on golang-golang-x-sys-dev; however: Package golang-golang-x-sys-dev is not installed. Setting up pbuilder-satisfydepends-dummy (0.invalid.0) ... Reading package lists... Building dependency tree... Reading state information... Initializing package states... Writing extended state information... Building tag database... pbuilder-satisfydepends-dummy is already installed at the requested version (0.invalid.0) pbuilder-satisfydepends-dummy is already installed at the requested version (0.invalid.0) The following NEW packages will be installed: autoconf{a} automake{a} autopoint{a} autotools-dev{a} binutils-gold{a} binutils-gold-aarch64-linux-gnu{a} bsdextrautils{a} clang{a} clang-19{a} debhelper{a} dh-autoreconf{a} dh-golang{a} dh-strip-nondeterminism{a} dwz{a} file{a} gettext{a} gettext-base{a} golang-1.24-go{a} golang-1.24-src{a} golang-any{a} golang-github-cilium-ebpf-dev{a} golang-github-pkg-errors-dev{a} golang-go{a} golang-golang-x-crypto-dev{a} golang-golang-x-exp-dev{a} golang-golang-x-net-dev{a} golang-golang-x-sys-dev{a} golang-golang-x-term-dev{a} golang-golang-x-text-dev{a} golang-src{a} groff-base{a} intltool-debian{a} libarchive-zip-perl{a} libclang-common-19-dev{a} libclang-cpp19{a} libclang1-19{a} libdebhelper-perl{a} libedit2{a} libelf1t64{a} libffi8{a} libfile-stripnondeterminism-perl{a} libgc1{a} libicu72{a} libllvm19{a} libmagic-mgc{a} libmagic1t64{a} libobjc-14-dev{a} libobjc4{a} libpipeline1{a} libtool{a} libuchardet0{a} libunistring5{a} libxml2{a} libz3-4{a} llvm-19-linker-tools{a} m4{a} man-db{a} po-debconf{a} sensible-utils{a} The following packages are RECOMMENDED but will NOT be installed: curl libarchive-cpio-perl libclang-rt-19-dev libltdl-dev libmail-sendmail-perl llvm-19-dev lynx pkgconf python3 wget 0 packages upgraded, 59 newly installed, 0 to remove and 0 not upgraded. Need to get 128 MB of archives. After unpacking 685 MB will be used. Writing extended state information... Get: 1 http://deb.debian.org/debian trixie/main arm64 sensible-utils all 0.0.24 [24.8 kB] Get: 2 http://deb.debian.org/debian trixie/main arm64 libmagic-mgc arm64 1:5.45-3+b1 [314 kB] Get: 3 http://deb.debian.org/debian trixie/main arm64 libmagic1t64 arm64 1:5.45-3+b1 [102 kB] Get: 4 http://deb.debian.org/debian trixie/main arm64 file arm64 1:5.45-3+b1 [43.4 kB] Get: 5 http://deb.debian.org/debian trixie/main arm64 gettext-base arm64 0.23.1-1 [241 kB] Get: 6 http://deb.debian.org/debian trixie/main arm64 libuchardet0 arm64 0.0.8-1+b2 [69.2 kB] Get: 7 http://deb.debian.org/debian trixie/main arm64 groff-base arm64 1.23.0-7 [1129 kB] Get: 8 http://deb.debian.org/debian trixie/main arm64 bsdextrautils arm64 2.40.4-3 [92.0 kB] Get: 9 http://deb.debian.org/debian trixie/main arm64 libpipeline1 arm64 1.5.8-1 [40.2 kB] Get: 10 http://deb.debian.org/debian trixie/main arm64 man-db arm64 2.13.0-1 [1404 kB] Get: 11 http://deb.debian.org/debian trixie/main arm64 m4 arm64 1.4.19-5 [284 kB] Get: 12 http://deb.debian.org/debian trixie/main arm64 autoconf all 2.72-3 [493 kB] Get: 13 http://deb.debian.org/debian trixie/main arm64 autotools-dev all 20220109.1 [51.6 kB] Get: 14 http://deb.debian.org/debian trixie/main arm64 automake all 1:1.17-3 [862 kB] Get: 15 http://deb.debian.org/debian trixie/main arm64 autopoint all 0.23.1-1 [770 kB] Get: 16 http://deb.debian.org/debian trixie/main arm64 binutils-gold-aarch64-linux-gnu arm64 2.44-1 [1704 kB] Get: 17 http://deb.debian.org/debian trixie/main arm64 binutils-gold arm64 2.44-1 [202 kB] Get: 18 http://deb.debian.org/debian trixie/main arm64 libedit2 arm64 3.1-20250104-1 [89.3 kB] Get: 19 http://deb.debian.org/debian trixie/main arm64 libffi8 arm64 3.4.7-1 [21.2 kB] Get: 20 http://deb.debian.org/debian trixie/main arm64 libicu72 arm64 72.1-6 [9239 kB] Get: 21 http://deb.debian.org/debian trixie/main arm64 libxml2 arm64 2.12.7+dfsg+really2.9.14-0.2+b1 [630 kB] Get: 22 http://deb.debian.org/debian trixie/main arm64 libz3-4 arm64 4.13.3-1 [7507 kB] Get: 23 http://deb.debian.org/debian trixie/main arm64 libllvm19 arm64 1:19.1.7-1+b1 [23.3 MB] Get: 24 http://deb.debian.org/debian trixie/main arm64 libclang-cpp19 arm64 1:19.1.7-1+b1 [12.0 MB] Get: 25 http://deb.debian.org/debian trixie/main arm64 libgc1 arm64 1:8.2.8-1 [241 kB] Get: 26 http://deb.debian.org/debian trixie/main arm64 libobjc4 arm64 14.2.0-16 [39.4 kB] Get: 27 http://deb.debian.org/debian trixie/main arm64 libobjc-14-dev arm64 14.2.0-16 [166 kB] Get: 28 http://deb.debian.org/debian trixie/main arm64 libclang-common-19-dev arm64 1:19.1.7-1+b1 [740 kB] Get: 29 http://deb.debian.org/debian trixie/main arm64 llvm-19-linker-tools arm64 1:19.1.7-1+b1 [1100 kB] Get: 30 http://deb.debian.org/debian trixie/main arm64 libclang1-19 arm64 1:19.1.7-1+b1 [6851 kB] Get: 31 http://deb.debian.org/debian trixie/main arm64 clang-19 arm64 1:19.1.7-1+b1 [112 kB] Get: 32 http://deb.debian.org/debian trixie/main arm64 clang arm64 1:19.0-63 [6244 B] Get: 33 http://deb.debian.org/debian trixie/main arm64 libdebhelper-perl all 13.24.1 [90.9 kB] Get: 34 http://deb.debian.org/debian trixie/main arm64 libtool all 2.5.4-3 [539 kB] Get: 35 http://deb.debian.org/debian trixie/main arm64 dh-autoreconf all 20 [17.1 kB] Get: 36 http://deb.debian.org/debian trixie/main arm64 libarchive-zip-perl all 1.68-1 [104 kB] Get: 37 http://deb.debian.org/debian trixie/main arm64 libfile-stripnondeterminism-perl all 1.14.1-2 [19.7 kB] Get: 38 http://deb.debian.org/debian trixie/main arm64 dh-strip-nondeterminism all 1.14.1-2 [8620 B] Get: 39 http://deb.debian.org/debian trixie/main arm64 libelf1t64 arm64 0.192-4 [189 kB] Get: 40 http://deb.debian.org/debian trixie/main arm64 dwz arm64 0.15-1+b1 [102 kB] Get: 41 http://deb.debian.org/debian trixie/main arm64 libunistring5 arm64 1.3-1 [449 kB] Get: 42 http://deb.debian.org/debian trixie/main arm64 gettext arm64 0.23.1-1 [1610 kB] Get: 43 http://deb.debian.org/debian trixie/main arm64 intltool-debian all 0.35.0+20060710.6 [22.9 kB] Get: 44 http://deb.debian.org/debian trixie/main arm64 po-debconf all 1.0.21+nmu1 [248 kB] Get: 45 http://deb.debian.org/debian trixie/main arm64 debhelper all 13.24.1 [920 kB] Get: 46 http://deb.debian.org/debian trixie/main arm64 dh-golang all 1.63 [24.4 kB] Get: 47 http://deb.debian.org/debian trixie/main arm64 golang-1.24-src all 1.24.0-1 [20.3 MB] Get: 48 http://deb.debian.org/debian trixie/main arm64 golang-1.24-go arm64 1.24.0-1 [24.6 MB] Get: 49 http://deb.debian.org/debian trixie/main arm64 golang-src all 2:1.24~2 [5136 B] Get: 50 http://deb.debian.org/debian trixie/main arm64 golang-go arm64 2:1.24~2 [44.3 kB] Get: 51 http://deb.debian.org/debian trixie/main arm64 golang-any arm64 2:1.24~2 [5216 B] Get: 52 http://deb.debian.org/debian trixie/main arm64 golang-golang-x-exp-dev all 0.0~git20231006.7918f67-1 [105 kB] Get: 53 http://deb.debian.org/debian trixie/main arm64 golang-golang-x-sys-dev all 0.22.0-1 [431 kB] Get: 54 http://deb.debian.org/debian trixie/main arm64 golang-github-cilium-ebpf-dev all 0.11.0-2 [1793 kB] Get: 55 http://deb.debian.org/debian trixie/main arm64 golang-github-pkg-errors-dev all 0.9.1-3 [12.9 kB] Get: 56 http://deb.debian.org/debian trixie/main arm64 golang-golang-x-term-dev all 0.22.0-1 [14.8 kB] Get: 57 http://deb.debian.org/debian trixie/main arm64 golang-golang-x-text-dev all 0.22.0-1 [3995 kB] Get: 58 http://deb.debian.org/debian trixie/main arm64 golang-golang-x-crypto-dev all 1:0.25.0-1 [1682 kB] Get: 59 http://deb.debian.org/debian trixie/main arm64 golang-golang-x-net-dev all 1:0.27.0-1 [898 kB] Fetched 128 MB in 1s (233 MB/s) Preconfiguring packages ... Selecting previously unselected package sensible-utils. (Reading database ... (Reading database ... 5% (Reading database ... 10% (Reading database ... 15% (Reading database ... 20% (Reading database ... 25% (Reading database ... 30% (Reading database ... 35% (Reading database ... 40% (Reading database ... 45% (Reading database ... 50% (Reading database ... 55% (Reading database ... 60% (Reading database ... 65% (Reading database ... 70% (Reading database ... 75% (Reading database ... 80% (Reading database ... 85% (Reading database ... 90% (Reading database ... 95% (Reading database ... 100% (Reading database ... 19972 files and directories currently installed.) Preparing to unpack .../00-sensible-utils_0.0.24_all.deb ... Unpacking sensible-utils (0.0.24) ... Selecting previously unselected package libmagic-mgc. Preparing to unpack .../01-libmagic-mgc_1%3a5.45-3+b1_arm64.deb ... Unpacking libmagic-mgc (1:5.45-3+b1) ... Selecting previously unselected package libmagic1t64:arm64. Preparing to unpack .../02-libmagic1t64_1%3a5.45-3+b1_arm64.deb ... Unpacking libmagic1t64:arm64 (1:5.45-3+b1) ... Selecting previously unselected package file. Preparing to unpack .../03-file_1%3a5.45-3+b1_arm64.deb ... Unpacking file (1:5.45-3+b1) ... Selecting previously unselected package gettext-base. Preparing to unpack .../04-gettext-base_0.23.1-1_arm64.deb ... Unpacking gettext-base (0.23.1-1) ... Selecting previously unselected package libuchardet0:arm64. Preparing to unpack .../05-libuchardet0_0.0.8-1+b2_arm64.deb ... Unpacking libuchardet0:arm64 (0.0.8-1+b2) ... Selecting previously unselected package groff-base. Preparing to unpack .../06-groff-base_1.23.0-7_arm64.deb ... Unpacking groff-base (1.23.0-7) ... Selecting previously unselected package bsdextrautils. Preparing to unpack .../07-bsdextrautils_2.40.4-3_arm64.deb ... Unpacking bsdextrautils (2.40.4-3) ... Selecting previously unselected package libpipeline1:arm64. Preparing to unpack .../08-libpipeline1_1.5.8-1_arm64.deb ... Unpacking libpipeline1:arm64 (1.5.8-1) ... Selecting previously unselected package man-db. Preparing to unpack .../09-man-db_2.13.0-1_arm64.deb ... Unpacking man-db (2.13.0-1) ... Selecting previously unselected package m4. Preparing to unpack .../10-m4_1.4.19-5_arm64.deb ... Unpacking m4 (1.4.19-5) ... Selecting previously unselected package autoconf. Preparing to unpack .../11-autoconf_2.72-3_all.deb ... Unpacking autoconf (2.72-3) ... Selecting previously unselected package autotools-dev. Preparing to unpack .../12-autotools-dev_20220109.1_all.deb ... Unpacking autotools-dev (20220109.1) ... Selecting previously unselected package automake. Preparing to unpack .../13-automake_1%3a1.17-3_all.deb ... Unpacking automake (1:1.17-3) ... Selecting previously unselected package autopoint. Preparing to unpack .../14-autopoint_0.23.1-1_all.deb ... Unpacking autopoint (0.23.1-1) ... Selecting previously unselected package binutils-gold-aarch64-linux-gnu. Preparing to unpack .../15-binutils-gold-aarch64-linux-gnu_2.44-1_arm64.deb ... Unpacking binutils-gold-aarch64-linux-gnu (2.44-1) ... Selecting previously unselected package binutils-gold. Preparing to unpack .../16-binutils-gold_2.44-1_arm64.deb ... Unpacking binutils-gold (2.44-1) ... Selecting previously unselected package libedit2:arm64. Preparing to unpack .../17-libedit2_3.1-20250104-1_arm64.deb ... Unpacking libedit2:arm64 (3.1-20250104-1) ... Selecting previously unselected package libffi8:arm64. Preparing to unpack .../18-libffi8_3.4.7-1_arm64.deb ... Unpacking libffi8:arm64 (3.4.7-1) ... Selecting previously unselected package libicu72:arm64. Preparing to unpack .../19-libicu72_72.1-6_arm64.deb ... Unpacking libicu72:arm64 (72.1-6) ... Selecting previously unselected package libxml2:arm64. Preparing to unpack .../20-libxml2_2.12.7+dfsg+really2.9.14-0.2+b1_arm64.deb ... Unpacking libxml2:arm64 (2.12.7+dfsg+really2.9.14-0.2+b1) ... Selecting previously unselected package libz3-4:arm64. Preparing to unpack .../21-libz3-4_4.13.3-1_arm64.deb ... Unpacking libz3-4:arm64 (4.13.3-1) ... Selecting previously unselected package libllvm19:arm64. Preparing to unpack .../22-libllvm19_1%3a19.1.7-1+b1_arm64.deb ... Unpacking libllvm19:arm64 (1:19.1.7-1+b1) ... Selecting previously unselected package libclang-cpp19. Preparing to unpack .../23-libclang-cpp19_1%3a19.1.7-1+b1_arm64.deb ... Unpacking libclang-cpp19 (1:19.1.7-1+b1) ... Selecting previously unselected package libgc1:arm64. Preparing to unpack .../24-libgc1_1%3a8.2.8-1_arm64.deb ... Unpacking libgc1:arm64 (1:8.2.8-1) ... Selecting previously unselected package libobjc4:arm64. Preparing to unpack .../25-libobjc4_14.2.0-16_arm64.deb ... Unpacking libobjc4:arm64 (14.2.0-16) ... Selecting previously unselected package libobjc-14-dev:arm64. Preparing to unpack .../26-libobjc-14-dev_14.2.0-16_arm64.deb ... Unpacking libobjc-14-dev:arm64 (14.2.0-16) ... Selecting previously unselected package libclang-common-19-dev:arm64. Preparing to unpack .../27-libclang-common-19-dev_1%3a19.1.7-1+b1_arm64.deb ... Unpacking libclang-common-19-dev:arm64 (1:19.1.7-1+b1) ... Selecting previously unselected package llvm-19-linker-tools. Preparing to unpack .../28-llvm-19-linker-tools_1%3a19.1.7-1+b1_arm64.deb ... Unpacking llvm-19-linker-tools (1:19.1.7-1+b1) ... Selecting previously unselected package libclang1-19. Preparing to unpack .../29-libclang1-19_1%3a19.1.7-1+b1_arm64.deb ... Unpacking libclang1-19 (1:19.1.7-1+b1) ... Selecting previously unselected package clang-19. Preparing to unpack .../30-clang-19_1%3a19.1.7-1+b1_arm64.deb ... Unpacking clang-19 (1:19.1.7-1+b1) ... Selecting previously unselected package clang. Preparing to unpack .../31-clang_1%3a19.0-63_arm64.deb ... Unpacking clang (1:19.0-63) ... Selecting previously unselected package libdebhelper-perl. Preparing to unpack .../32-libdebhelper-perl_13.24.1_all.deb ... Unpacking libdebhelper-perl (13.24.1) ... Selecting previously unselected package libtool. Preparing to unpack .../33-libtool_2.5.4-3_all.deb ... Unpacking libtool (2.5.4-3) ... Selecting previously unselected package dh-autoreconf. Preparing to unpack .../34-dh-autoreconf_20_all.deb ... Unpacking dh-autoreconf (20) ... Selecting previously unselected package libarchive-zip-perl. Preparing to unpack .../35-libarchive-zip-perl_1.68-1_all.deb ... Unpacking libarchive-zip-perl (1.68-1) ... Selecting previously unselected package libfile-stripnondeterminism-perl. Preparing to unpack .../36-libfile-stripnondeterminism-perl_1.14.1-2_all.deb ... Unpacking libfile-stripnondeterminism-perl (1.14.1-2) ... Selecting previously unselected package dh-strip-nondeterminism. Preparing to unpack .../37-dh-strip-nondeterminism_1.14.1-2_all.deb ... Unpacking dh-strip-nondeterminism (1.14.1-2) ... Selecting previously unselected package libelf1t64:arm64. Preparing to unpack .../38-libelf1t64_0.192-4_arm64.deb ... Unpacking libelf1t64:arm64 (0.192-4) ... Selecting previously unselected package dwz. Preparing to unpack .../39-dwz_0.15-1+b1_arm64.deb ... Unpacking dwz (0.15-1+b1) ... Selecting previously unselected package libunistring5:arm64. Preparing to unpack .../40-libunistring5_1.3-1_arm64.deb ... Unpacking libunistring5:arm64 (1.3-1) ... Selecting previously unselected package gettext. Preparing to unpack .../41-gettext_0.23.1-1_arm64.deb ... Unpacking gettext (0.23.1-1) ... Selecting previously unselected package intltool-debian. Preparing to unpack .../42-intltool-debian_0.35.0+20060710.6_all.deb ... Unpacking intltool-debian (0.35.0+20060710.6) ... Selecting previously unselected package po-debconf. Preparing to unpack .../43-po-debconf_1.0.21+nmu1_all.deb ... Unpacking po-debconf (1.0.21+nmu1) ... Selecting previously unselected package debhelper. Preparing to unpack .../44-debhelper_13.24.1_all.deb ... Unpacking debhelper (13.24.1) ... Selecting previously unselected package dh-golang. Preparing to unpack .../45-dh-golang_1.63_all.deb ... Unpacking dh-golang (1.63) ... Selecting previously unselected package golang-1.24-src. Preparing to unpack .../46-golang-1.24-src_1.24.0-1_all.deb ... Unpacking golang-1.24-src (1.24.0-1) ... Selecting previously unselected package golang-1.24-go. Preparing to unpack .../47-golang-1.24-go_1.24.0-1_arm64.deb ... Unpacking golang-1.24-go (1.24.0-1) ... Selecting previously unselected package golang-src. Preparing to unpack .../48-golang-src_2%3a1.24~2_all.deb ... Unpacking golang-src (2:1.24~2) ... Selecting previously unselected package golang-go:arm64. Preparing to unpack .../49-golang-go_2%3a1.24~2_arm64.deb ... Unpacking golang-go:arm64 (2:1.24~2) ... Selecting previously unselected package golang-any:arm64. Preparing to unpack .../50-golang-any_2%3a1.24~2_arm64.deb ... Unpacking golang-any:arm64 (2:1.24~2) ... Selecting previously unselected package golang-golang-x-exp-dev. Preparing to unpack .../51-golang-golang-x-exp-dev_0.0~git20231006.7918f67-1_all.deb ... Unpacking golang-golang-x-exp-dev (0.0~git20231006.7918f67-1) ... Selecting previously unselected package golang-golang-x-sys-dev. Preparing to unpack .../52-golang-golang-x-sys-dev_0.22.0-1_all.deb ... Unpacking golang-golang-x-sys-dev (0.22.0-1) ... Selecting previously unselected package golang-github-cilium-ebpf-dev. Preparing to unpack .../53-golang-github-cilium-ebpf-dev_0.11.0-2_all.deb ... Unpacking golang-github-cilium-ebpf-dev (0.11.0-2) ... Selecting previously unselected package golang-github-pkg-errors-dev. Preparing to unpack .../54-golang-github-pkg-errors-dev_0.9.1-3_all.deb ... Unpacking golang-github-pkg-errors-dev (0.9.1-3) ... Selecting previously unselected package golang-golang-x-term-dev. Preparing to unpack .../55-golang-golang-x-term-dev_0.22.0-1_all.deb ... Unpacking golang-golang-x-term-dev (0.22.0-1) ... Selecting previously unselected package golang-golang-x-text-dev. Preparing to unpack .../56-golang-golang-x-text-dev_0.22.0-1_all.deb ... Unpacking golang-golang-x-text-dev (0.22.0-1) ... Selecting previously unselected package golang-golang-x-crypto-dev. Preparing to unpack .../57-golang-golang-x-crypto-dev_1%3a0.25.0-1_all.deb ... Unpacking golang-golang-x-crypto-dev (1:0.25.0-1) ... Selecting previously unselected package golang-golang-x-net-dev. Preparing to unpack .../58-golang-golang-x-net-dev_1%3a0.27.0-1_all.deb ... Unpacking golang-golang-x-net-dev (1:0.27.0-1) ... Setting up golang-1.24-src (1.24.0-1) ... Setting up libpipeline1:arm64 (1.5.8-1) ... Setting up libicu72:arm64 (72.1-6) ... Setting up bsdextrautils (2.40.4-3) ... Setting up libmagic-mgc (1:5.45-3+b1) ... Setting up libclang-common-19-dev:arm64 (1:19.1.7-1+b1) ... Setting up golang-github-pkg-errors-dev (0.9.1-3) ... Setting up libarchive-zip-perl (1.68-1) ... Setting up libdebhelper-perl (13.24.1) ... Setting up libedit2:arm64 (3.1-20250104-1) ... Setting up golang-golang-x-sys-dev (0.22.0-1) ... Setting up libmagic1t64:arm64 (1:5.45-3+b1) ... Setting up gettext-base (0.23.1-1) ... Setting up m4 (1.4.19-5) ... Setting up binutils-gold-aarch64-linux-gnu (2.44-1) ... Setting up golang-golang-x-term-dev (0.22.0-1) ... Setting up file (1:5.45-3+b1) ... Setting up libelf1t64:arm64 (0.192-4) ... Setting up autotools-dev (20220109.1) ... Setting up libz3-4:arm64 (4.13.3-1) ... Setting up libunistring5:arm64 (1.3-1) ... Setting up autopoint (0.23.1-1) ... Setting up libgc1:arm64 (1:8.2.8-1) ... Setting up autoconf (2.72-3) ... Setting up libffi8:arm64 (3.4.7-1) ... Setting up dwz (0.15-1+b1) ... Setting up sensible-utils (0.0.24) ... Setting up golang-golang-x-text-dev (0.22.0-1) ... Setting up libuchardet0:arm64 (0.0.8-1+b2) ... Setting up golang-golang-x-crypto-dev (1:0.25.0-1) ... Setting up golang-golang-x-exp-dev (0.0~git20231006.7918f67-1) ... Setting up golang-src (2:1.24~2) ... Setting up libxml2:arm64 (2.12.7+dfsg+really2.9.14-0.2+b1) ... Setting up automake (1:1.17-3) ... update-alternatives: using /usr/bin/automake-1.17 to provide /usr/bin/automake (automake) in auto mode Setting up libfile-stripnondeterminism-perl (1.14.1-2) ... Setting up libllvm19:arm64 (1:19.1.7-1+b1) ... Setting up gettext (0.23.1-1) ... Setting up libclang1-19 (1:19.1.7-1+b1) ... Setting up libtool (2.5.4-3) ... Setting up binutils-gold (2.44-1) ... Setting up golang-github-cilium-ebpf-dev (0.11.0-2) ... Setting up libobjc4:arm64 (14.2.0-16) ... Setting up libobjc-14-dev:arm64 (14.2.0-16) ... Setting up intltool-debian (0.35.0+20060710.6) ... Setting up dh-autoreconf (20) ... Setting up golang-1.24-go (1.24.0-1) ... Setting up golang-golang-x-net-dev (1:0.27.0-1) ... Setting up dh-strip-nondeterminism (1.14.1-2) ... Setting up groff-base (1.23.0-7) ... Setting up llvm-19-linker-tools (1:19.1.7-1+b1) ... Setting up libclang-cpp19 (1:19.1.7-1+b1) ... Setting up golang-go:arm64 (2:1.24~2) ... Setting up po-debconf (1.0.21+nmu1) ... Setting up man-db (2.13.0-1) ... Not building database; man-db/auto-update is not 'true'. Setting up clang-19 (1:19.1.7-1+b1) ... Setting up golang-any:arm64 (2:1.24~2) ... Setting up clang (1:19.0-63) ... Setting up debhelper (13.24.1) ... Setting up dh-golang (1.63) ... Processing triggers for libc-bin (2.40-7) ... Reading package lists... Building dependency tree... Reading state information... Reading extended state information... Initializing package states... Writing extended state information... Building tag database... -> Finished parsing the build-deps I: Building the package I: Running cd /build/reproducible-path/golang-github-cloudflare-cbpfc-0.0~git20231012.992ed75/ && env PATH="/usr/sbin:/usr/bin:/sbin:/bin:/usr/games" HOME="/nonexistent/first-build" dpkg-buildpackage -us -uc -b && env PATH="/usr/sbin:/usr/bin:/sbin:/bin:/usr/games" HOME="/nonexistent/first-build" dpkg-genchanges -S > ../golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_source.changes dpkg-buildpackage: info: source package golang-github-cloudflare-cbpfc dpkg-buildpackage: info: source version 0.0~git20231012.992ed75-2 dpkg-buildpackage: info: source distribution unstable dpkg-buildpackage: info: source changed by Reinhard Tartler dpkg-source --before-build . dpkg-buildpackage: info: host architecture arm64 debian/rules clean dh clean --builddirectory=_build --buildsystem=golang --with=golang dh_auto_clean -O--builddirectory=_build -O--buildsystem=golang dh_autoreconf_clean -O--builddirectory=_build -O--buildsystem=golang dh_clean -O--builddirectory=_build -O--buildsystem=golang debian/rules binary dh binary --builddirectory=_build --buildsystem=golang --with=golang dh_update_autotools_config -O--builddirectory=_build -O--buildsystem=golang dh_autoreconf -O--builddirectory=_build -O--buildsystem=golang dh_auto_configure -O--builddirectory=_build -O--buildsystem=golang dh_auto_build -O--builddirectory=_build -O--buildsystem=golang cd _build && go install -trimpath -v -p 12 github.com/cloudflare/cbpfc github.com/cloudflare/cbpfc/clang internal/goarch internal/byteorder internal/goos internal/godebugs internal/asan internal/unsafeheader internal/msan internal/profilerecord internal/coverage/rtcov internal/runtime/syscall internal/abi internal/runtime/math internal/cpu cmp internal/itoa internal/goexperiment math/bits unicode/utf8 sync/atomic unicode crypto/internal/fips140/alias crypto/internal/boring/sig internal/chacha8rand crypto/internal/fips140deps/byteorder crypto/internal/fips140/subtle math internal/bytealg crypto/internal/fips140deps/cpu internal/runtime/atomic internal/runtime/sys internal/runtime/exithook internal/stringslite internal/race internal/sync internal/runtime/maps runtime internal/reflectlite iter crypto/subtle sync maps slices errors sort internal/bisect internal/testlog io internal/oserror path math/rand/v2 strconv syscall internal/godebug hash bytes strings crypto/internal/randutil reflect crypto crypto/internal/fips140deps/godebug crypto/internal/fips140 crypto/internal/impl regexp/syntax crypto/internal/fips140/sha256 crypto/internal/fips140/sha3 crypto/internal/fips140/sha512 crypto/internal/fips140/hmac crypto/internal/fips140/check crypto/internal/fips140/aes regexp internal/syscall/execenv time internal/syscall/unix io/fs context internal/poll internal/filepathlite internal/fmtsort encoding/binary os golang.org/x/sys/unix crypto/internal/sysrand fmt path/filepath io/ioutil crypto/internal/entropy crypto/internal/fips140/drbg os/exec crypto/internal/fips140only crypto/internal/fips140/aes/gcm crypto/cipher crypto/internal/boring encoding/hex golang.org/x/net/bpf net/url github.com/pkg/errors text/template/parse crypto/sha1 github.com/cloudflare/cbpfc/clang text/template github.com/cilium/ebpf/internal/unix github.com/cilium/ebpf/internal/sys github.com/cilium/ebpf/asm github.com/cloudflare/cbpfc debian/rules override_dh_auto_test make[1]: Entering directory '/build/reproducible-path/golang-github-cloudflare-cbpfc-0.0~git20231012.992ed75' dh_auto_test -- --short cd _build && go test -vet=off -v -p 12 --short github.com/cloudflare/cbpfc github.com/cloudflare/cbpfc/clang === RUN TestFunctionName --- PASS: TestFunctionName (0.00s) === RUN TestNoInline --- SKIP: TestNoInline (0.15s) === RUN TestZero --- PASS: TestZero (0.00s) === RUN TestRaw --- PASS: TestRaw (0.00s) === RUN TestLoadAbsoluteNegativeOffset --- PASS: TestLoadAbsoluteNegativeOffset (0.00s) === RUN TestExtension --- PASS: TestExtension (0.00s) === RUN TestJumpOut --- PASS: TestJumpOut (0.00s) === RUN TestJumpIfOut --- PASS: TestJumpIfOut (0.00s) === RUN TestJumpIfXOut --- PASS: TestJumpIfXOut (0.00s) === RUN TestFallthroughOut --- PASS: TestFallthroughOut (0.00s) === RUN TestNormalizeJumps --- PASS: TestNormalizeJumps (0.00s) === RUN TestInstructionReadsRegA --- PASS: TestInstructionReadsRegA (0.00s) === RUN TestInstructionWritesRegA --- PASS: TestInstructionWritesRegA (0.00s) === RUN TestInstructionReadsRegX --- PASS: TestInstructionReadsRegX (0.00s) === RUN TestInstructionWritesRegX --- PASS: TestInstructionWritesRegX (0.00s) === RUN TestInstructionReadsScratch --- PASS: TestInstructionReadsScratch (0.00s) === RUN TestInstructionWritesScratch --- PASS: TestInstructionWritesScratch (0.00s) === RUN TestUninitializedReg --- PASS: TestUninitializedReg (0.00s) === RUN TestPartiallyUninitializedReg --- PASS: TestPartiallyUninitializedReg (0.00s) === RUN TestUninitializedScratch --- PASS: TestUninitializedScratch (0.00s) === RUN TestPartiallyUninitializedScratch --- PASS: TestPartiallyUninitializedScratch (0.00s) === RUN TestBlocksJump --- PASS: TestBlocksJump (0.00s) === RUN TestBlocksJumpIf --- PASS: TestBlocksJumpIf (0.00s) === RUN TestBlocksJumpIfX --- PASS: TestBlocksJumpIfX (0.00s) === RUN TestDivisionByZeroImm --- PASS: TestDivisionByZeroImm (0.00s) === RUN TestDivisionByZeroX --- PASS: TestDivisionByZeroX (0.00s) === RUN TestDivisionByZeroXTwice --- PASS: TestDivisionByZeroXTwice (0.00s) === RUN TestDivisionByZeroXConstant --- PASS: TestDivisionByZeroXConstant (0.00s) === RUN TestDivisionByZeroXMemShift --- PASS: TestDivisionByZeroXMemShift (0.00s) === RUN TestDivisionByZeroXTXA --- PASS: TestDivisionByZeroXTXA (0.00s) === RUN TestDivisionByZeroParentsOK --- PASS: TestDivisionByZeroParentsOK (0.00s) === RUN TestDivisionByZeroParentsNOK --- PASS: TestDivisionByZeroParentsNOK (0.00s) === RUN TestRewriteLargePacketOffsets --- PASS: TestRewriteLargePacketOffsets (0.00s) === RUN TestRewriteLargePacketOffsetsDeadBlock === RUN TestRewriteLargePacketOffsetsDeadBlock/C === RUN TestRewriteLargePacketOffsetsDeadBlock/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 6 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemW dst: r4 src: r2 off: 2 imm: 0 6: SwapBE dst: r4 imm: 32 7: JGTImm dst: r4 off: -1 imm: 2 filter_block_2: 8: JLTImm dst: r4 off: -1 imm: 2 filter_block_3: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 0 12: JaImm dst: r0 off: -1 imm: 0 filter_block_8: 13: Mov32Reg dst: r4 src: r4 14: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 15: MovImm dst: r4 imm: 0 16: JaImm dst: r0 off: -1 imm: 0 result: 17: MovImm dst: r0 imm: 2 18: JEqImm dst: r4 off: -1 imm: 0 19: MovImm dst: r0 imm: 1 return: 20: Exit === RUN TestRewriteLargePacketOffsetsDeadBlock/kernel --- PASS: TestRewriteLargePacketOffsetsDeadBlock (0.09s) --- SKIP: TestRewriteLargePacketOffsetsDeadBlock/C (0.04s) --- SKIP: TestRewriteLargePacketOffsetsDeadBlock/eBPF (0.00s) --- PASS: TestRewriteLargePacketOffsetsDeadBlock/kernel (0.05s) === RUN TestAbsoluteGuardSize --- PASS: TestAbsoluteGuardSize (0.00s) === RUN TestNoAbsoluteGuard --- PASS: TestNoAbsoluteGuard (0.00s) === RUN TestAbsoluteGuardParentsOK --- PASS: TestAbsoluteGuardParentsOK (0.00s) === RUN TestAbsoluteGuardParentNoMatch --- PASS: TestAbsoluteGuardParentNoMatch (0.00s) === RUN TestAbsoluteGuardParentDeepNoMatch --- PASS: TestAbsoluteGuardParentDeepNoMatch (0.00s) === RUN TestAbsoluteGuardParentMatch --- PASS: TestAbsoluteGuardParentMatch (0.00s) === RUN TestIndirectGuardSize --- PASS: TestIndirectGuardSize (0.00s) === RUN TestNoIndirectGuard --- PASS: TestNoIndirectGuard (0.00s) === RUN TestIndirectGuardClobber === RUN TestIndirectGuardClobber/constant === RUN TestIndirectGuardClobber/scratch === RUN TestIndirectGuardClobber/memshift --- PASS: TestIndirectGuardClobber (0.00s) --- PASS: TestIndirectGuardClobber/constant (0.00s) --- PASS: TestIndirectGuardClobber/scratch (0.00s) --- PASS: TestIndirectGuardClobber/memshift (0.00s) === RUN TestIndirectGuardClobberLast --- PASS: TestIndirectGuardClobberLast (0.00s) === RUN TestIndirectGuardParentsOK --- PASS: TestIndirectGuardParentsOK (0.00s) === RUN TestIndirectGuardParentNoMatch --- PASS: TestIndirectGuardParentNoMatch (0.00s) === RUN TestIndirectGuardParentDeepNoMatch --- PASS: TestIndirectGuardParentDeepNoMatch (0.00s) === RUN TestIndirectGuardParentMatch --- PASS: TestIndirectGuardParentMatch (0.00s) === RUN TestIndirectGuardParentClobber === RUN TestIndirectGuardParentClobber/constant === RUN TestIndirectGuardParentClobber/scratch === RUN TestIndirectGuardParentClobber/memshift --- PASS: TestIndirectGuardParentClobber (0.00s) --- PASS: TestIndirectGuardParentClobber/constant (0.00s) --- PASS: TestIndirectGuardParentClobber/scratch (0.00s) --- PASS: TestIndirectGuardParentClobber/memshift (0.00s) === RUN TestIndirectGuardExtendClobber === RUN TestIndirectGuardExtendClobber/constant === RUN TestIndirectGuardExtendClobber/scratch === RUN TestIndirectGuardExtendClobber/memshift --- PASS: TestIndirectGuardExtendClobber (0.00s) --- PASS: TestIndirectGuardExtendClobber/constant (0.00s) --- PASS: TestIndirectGuardExtendClobber/scratch (0.00s) --- PASS: TestIndirectGuardExtendClobber/memshift (0.00s) === RUN TestIndirectGuardParentsNotOK --- PASS: TestIndirectGuardParentsNotOK (0.00s) === RUN TestZeroInitA === PAUSE TestZeroInitA === RUN TestZeroInitX === PAUSE TestZeroInitX === RUN TestPartialZeroInitX === PAUSE TestPartialZeroInitX === RUN TestLoadConstantA === PAUSE TestLoadConstantA === RUN TestLoadConstantX === PAUSE TestLoadConstantX === RUN TestLoadAbsolute === PAUSE TestLoadAbsolute === RUN TestLoadAbsoluteBigOffset === PAUSE TestLoadAbsoluteBigOffset === RUN TestLoadIndirect === PAUSE TestLoadIndirect === RUN TestLoadIndirectBigOffset === RUN TestLoadIndirectBigOffset/C === RUN TestLoadIndirectBigOffset/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 0 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: 0 7: JGEImm dst: r7 off: -1 imm: 65535 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 1 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemB dst: r4 src: r7 off: 0 imm: 0 13: Add32Imm dst: r4 imm: 2 14: Mov32Reg dst: r4 src: r4 15: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 16: MovImm dst: r4 imm: 0 17: JaImm dst: r0 off: -1 imm: 0 result: 18: MovImm dst: r0 imm: 2 19: JEqImm dst: r4 off: -1 imm: 0 20: MovImm dst: r0 imm: 1 return: 21: Exit === RUN TestLoadIndirectBigOffset/kernel === RUN TestLoadIndirectBigOffset/C#01 === RUN TestLoadIndirectBigOffset/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 0 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: 0 7: JGEImm dst: r7 off: -1 imm: 65532 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 4 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemW dst: r4 src: r7 off: 0 imm: 0 13: SwapBE dst: r4 imm: 32 14: Add32Imm dst: r4 imm: 2 15: Mov32Reg dst: r4 src: r4 16: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 17: MovImm dst: r4 imm: 0 18: JaImm dst: r0 off: -1 imm: 0 result: 19: MovImm dst: r0 imm: 2 20: JEqImm dst: r4 off: -1 imm: 0 21: MovImm dst: r0 imm: 1 return: 22: Exit === RUN TestLoadIndirectBigOffset/kernel#01 === RUN TestLoadIndirectBigOffset/C#02 === RUN TestLoadIndirectBigOffset/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 0 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: 65534 7: JGEImm dst: r7 off: -1 imm: 65535 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 1 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemB dst: r4 src: r7 off: 0 imm: 0 13: Add32Imm dst: r4 imm: 2 14: Mov32Reg dst: r4 src: r4 15: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 16: MovImm dst: r4 imm: 0 17: JaImm dst: r0 off: -1 imm: 0 result: 18: MovImm dst: r0 imm: 2 19: JEqImm dst: r4 off: -1 imm: 0 20: MovImm dst: r0 imm: 1 return: 21: Exit === RUN TestLoadIndirectBigOffset/kernel#02 === RUN TestLoadIndirectBigOffset/C#03 === RUN TestLoadIndirectBigOffset/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 0 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: 65535 7: JGEImm dst: r7 off: -1 imm: 65535 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 1 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemB dst: r4 src: r7 off: 0 imm: 0 13: Add32Imm dst: r4 imm: 2 14: Mov32Reg dst: r4 src: r4 15: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 16: MovImm dst: r4 imm: 0 17: JaImm dst: r0 off: -1 imm: 0 result: 18: MovImm dst: r0 imm: 2 19: JEqImm dst: r4 off: -1 imm: 0 20: MovImm dst: r0 imm: 1 return: 21: Exit === RUN TestLoadIndirectBigOffset/kernel#03 === RUN TestLoadIndirectBigOffset/C#04 === RUN TestLoadIndirectBigOffset/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 0 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: 65533 7: JGEImm dst: r7 off: -1 imm: 65534 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 2 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemH dst: r4 src: r7 off: 0 imm: 0 13: SwapBE dst: r4 imm: 16 14: Add32Imm dst: r4 imm: 2 15: Mov32Reg dst: r4 src: r4 16: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 17: MovImm dst: r4 imm: 0 18: JaImm dst: r0 off: -1 imm: 0 result: 19: MovImm dst: r0 imm: 2 20: JEqImm dst: r4 off: -1 imm: 0 21: MovImm dst: r0 imm: 1 return: 22: Exit === RUN TestLoadIndirectBigOffset/kernel#04 === RUN TestLoadIndirectBigOffset/C#05 === RUN TestLoadIndirectBigOffset/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 0 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: 65534 7: JGEImm dst: r7 off: -1 imm: 65534 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 2 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemH dst: r4 src: r7 off: 0 imm: 0 13: SwapBE dst: r4 imm: 16 14: Add32Imm dst: r4 imm: 2 15: Mov32Reg dst: r4 src: r4 16: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 17: MovImm dst: r4 imm: 0 18: JaImm dst: r0 off: -1 imm: 0 result: 19: MovImm dst: r0 imm: 2 20: JEqImm dst: r4 off: -1 imm: 0 21: MovImm dst: r0 imm: 1 return: 22: Exit === RUN TestLoadIndirectBigOffset/kernel#05 === RUN TestLoadIndirectBigOffset/C#06 === RUN TestLoadIndirectBigOffset/eBPF#06 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 0 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: 65531 7: JGEImm dst: r7 off: -1 imm: 65532 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 4 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemW dst: r4 src: r7 off: 0 imm: 0 13: SwapBE dst: r4 imm: 32 14: Add32Imm dst: r4 imm: 2 15: Mov32Reg dst: r4 src: r4 16: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 17: MovImm dst: r4 imm: 0 18: JaImm dst: r0 off: -1 imm: 0 result: 19: MovImm dst: r0 imm: 2 20: JEqImm dst: r4 off: -1 imm: 0 21: MovImm dst: r0 imm: 1 return: 22: Exit === RUN TestLoadIndirectBigOffset/kernel#06 === RUN TestLoadIndirectBigOffset/C#07 === RUN TestLoadIndirectBigOffset/eBPF#07 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 0 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: 65532 7: JGEImm dst: r7 off: -1 imm: 65532 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 4 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemW dst: r4 src: r7 off: 0 imm: 0 13: SwapBE dst: r4 imm: 32 14: Add32Imm dst: r4 imm: 2 15: Mov32Reg dst: r4 src: r4 16: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 17: MovImm dst: r4 imm: 0 18: JaImm dst: r0 off: -1 imm: 0 result: 19: MovImm dst: r0 imm: 2 20: JEqImm dst: r4 off: -1 imm: 0 21: MovImm dst: r0 imm: 1 return: 22: Exit === RUN TestLoadIndirectBigOffset/kernel#07 --- PASS: TestLoadIndirectBigOffset (0.61s) --- SKIP: TestLoadIndirectBigOffset/C (0.03s) --- SKIP: TestLoadIndirectBigOffset/eBPF (0.00s) --- PASS: TestLoadIndirectBigOffset/kernel (0.00s) --- SKIP: TestLoadIndirectBigOffset/C#01 (0.04s) --- SKIP: TestLoadIndirectBigOffset/eBPF#01 (0.00s) --- PASS: TestLoadIndirectBigOffset/kernel#01 (0.00s) --- SKIP: TestLoadIndirectBigOffset/C#02 (0.03s) --- SKIP: TestLoadIndirectBigOffset/eBPF#02 (0.00s) --- PASS: TestLoadIndirectBigOffset/kernel#02 (0.05s) --- SKIP: TestLoadIndirectBigOffset/C#03 (0.04s) --- SKIP: TestLoadIndirectBigOffset/eBPF#03 (0.00s) --- PASS: TestLoadIndirectBigOffset/kernel#03 (0.05s) --- SKIP: TestLoadIndirectBigOffset/C#04 (0.03s) --- SKIP: TestLoadIndirectBigOffset/eBPF#04 (0.00s) --- PASS: TestLoadIndirectBigOffset/kernel#04 (0.06s) --- SKIP: TestLoadIndirectBigOffset/C#05 (0.04s) --- SKIP: TestLoadIndirectBigOffset/eBPF#05 (0.00s) --- PASS: TestLoadIndirectBigOffset/kernel#05 (0.05s) --- SKIP: TestLoadIndirectBigOffset/C#06 (0.04s) --- SKIP: TestLoadIndirectBigOffset/eBPF#06 (0.00s) --- PASS: TestLoadIndirectBigOffset/kernel#06 (0.05s) --- SKIP: TestLoadIndirectBigOffset/C#07 (0.04s) --- SKIP: TestLoadIndirectBigOffset/eBPF#07 (0.00s) --- PASS: TestLoadIndirectBigOffset/kernel#07 (0.05s) === RUN TestLoadIndirectGuardOverflow === RUN TestLoadIndirectGuardOverflow/C === RUN TestLoadIndirectGuardOverflow/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 4 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemW dst: r4 src: r2 off: 0 imm: 0 6: SwapBE dst: r4 imm: 32 7: Mov32Reg dst: r5 src: r4 8: MovReg dst: r7 src: r5 9: LShImm dst: r7 imm: 32 10: ArShImm dst: r7 imm: 32 11: AddImm dst: r7 imm: -2147483648 12: JGEImm dst: r7 off: -1 imm: 0 13: AddReg dst: r7 src: r2 14: MovReg dst: r6 src: r7 15: AddImm dst: r6 imm: 3 16: JGTReg dst: r6 off: -1 src: r3 17: LdXMemB dst: r4 src: r7 off: 0 imm: 0 18: MovReg dst: r6 src: r7 19: AddImm dst: r6 imm: -2147483648 20: LdXMemH dst: r4 src: r6 off: 0 imm: 0 21: SwapBE dst: r4 imm: 16 22: LdXMemW dst: r4 src: r7 off: -1 imm: 0 23: SwapBE dst: r4 imm: 32 24: Mov32Reg dst: r4 src: r5 25: Mov32Reg dst: r4 src: r4 26: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 27: MovImm dst: r4 imm: 0 28: JaImm dst: r0 off: -1 imm: 0 result: 29: MovImm dst: r0 imm: 2 30: JEqImm dst: r4 off: -1 imm: 0 31: MovImm dst: r0 imm: 1 return: 32: Exit === RUN TestLoadIndirectGuardOverflow/kernel --- PASS: TestLoadIndirectGuardOverflow (0.09s) --- SKIP: TestLoadIndirectGuardOverflow/C (0.04s) --- SKIP: TestLoadIndirectGuardOverflow/eBPF (0.00s) --- PASS: TestLoadIndirectGuardOverflow/kernel (0.05s) === RUN TestScratchZero === PAUSE TestScratchZero === RUN TestScratchA === PAUSE TestScratchA === RUN TestScratchX === PAUSE TestScratchX === RUN TestMemShift === PAUSE TestMemShift === RUN TestLoadExtLen === PAUSE TestLoadExtLen === RUN TestALUAdd === PAUSE TestALUAdd === RUN TestALUSub === PAUSE TestALUSub === RUN TestALUMul === PAUSE TestALUMul === RUN TestALUDiv === PAUSE TestALUDiv === RUN TestALUDivZero === PAUSE TestALUDivZero === RUN TestALUDivNegative === RUN TestALUDivNegative/C === RUN TestALUDivNegative/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 4 3: Mov32Imm dst: r5 imm: -2 4: JEqImm dst: r5 off: -1 imm: 0 5: Div32Reg dst: r4 src: r5 6: JEqImm dst: r4 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 0 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 1 10: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 11: MovImm dst: r4 imm: 0 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestALUDivNegative/kernel --- PASS: TestALUDivNegative (0.06s) --- SKIP: TestALUDivNegative/C (0.06s) --- SKIP: TestALUDivNegative/eBPF (0.00s) --- PASS: TestALUDivNegative/kernel (0.00s) === RUN TestALUOr === PAUSE TestALUOr === RUN TestALUAnd === PAUSE TestALUAnd === RUN TestALUShiftLeft === PAUSE TestALUShiftLeft === RUN TestALUShiftRight === PAUSE TestALUShiftRight === RUN TestALUMod === PAUSE TestALUMod === RUN TestALUXor === PAUSE TestALUXor === RUN TestNegateA === PAUSE TestNegateA === RUN TestJump === PAUSE TestJump === RUN TestJump0 === PAUSE TestJump0 === RUN TestJumpIfEqual === PAUSE TestJumpIfEqual === RUN TestJumpIfNotEqual === PAUSE TestJumpIfNotEqual === RUN TestJumpIfGreaterThan === PAUSE TestJumpIfGreaterThan === RUN TestJumpIfLessThan === PAUSE TestJumpIfLessThan === RUN TestJumpIfGreaterOrEqual === PAUSE TestJumpIfGreaterOrEqual === RUN TestJumpIfLessOrEqual === PAUSE TestJumpIfLessOrEqual === RUN TestJumpIfBitsSet === PAUSE TestJumpIfBitsSet === RUN TestJumpIfBitsNotSet === PAUSE TestJumpIfBitsNotSet === RUN TestRetA === PAUSE TestRetA === RUN TestRetConstant === PAUSE TestRetConstant === RUN TestTXA === PAUSE TestTXA === RUN TestTAX === PAUSE TestTAX === CONT TestZeroInitA === RUN TestZeroInitA/C === CONT TestALUShiftLeft === RUN TestALUShiftLeft/C === CONT TestJumpIfLessThan === RUN TestJumpIfLessThan/C === CONT TestALUAnd === RUN TestALUAnd/C === CONT TestJumpIfGreaterThan === RUN TestJumpIfGreaterThan/C === CONT TestJumpIfNotEqual === CONT TestJumpIfEqual === CONT TestJump0 === CONT TestJump === CONT TestNegateA === CONT TestALUXor === CONT TestALUMod === RUN TestJumpIfNotEqual/C === RUN TestJumpIfEqual/C === RUN TestJump0/C === RUN TestJump/C === RUN TestNegateA/C === RUN TestALUXor/C === RUN TestALUMod/C === RUN TestZeroInitA/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 0 3: Mov32Reg dst: r4 src: r4 4: JaImm dst: r0 off: -1 imm: 0 result: 5: MovImm dst: r0 imm: 2 6: JEqImm dst: r4 off: -1 imm: 0 7: MovImm dst: r0 imm: 1 return: 8: Exit === RUN TestZeroInitA/kernel === RUN TestJumpIfGreaterThan/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: JGTImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfGreaterThan/kernel === RUN TestJumpIfGreaterThan/C#01 === RUN TestJumpIfLessThan/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: JLTImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfLessThan/kernel === RUN TestJumpIfNotEqual/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JNEImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfNotEqual/kernel === RUN TestALUShiftLeft/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: LSh32Imm dst: r4 imm: 0 4: JEqImm dst: r4 off: -1 imm: 1 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUShiftLeft/kernel === RUN TestALUShiftLeft/C#01 === RUN TestALUAnd/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: And32Imm dst: r4 imm: 0 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUAnd/kernel === RUN TestALUAnd/C#01 === RUN TestJump/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 1 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemB dst: r4 src: r2 off: 0 imm: 0 6: JEqImm dst: r4 off: -1 imm: 1 filter_block_2: 7: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 8: Mov32Imm dst: r4 imm: 1 filter_block_4: 9: Mov32Reg dst: r4 src: r4 10: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 11: MovImm dst: r4 imm: 0 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJump/kernel === RUN TestNegateA/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 26 3: Neg32Imm dst: r4 imm: 0 4: Mov32Imm dst: r6 imm: -2147483622 5: JEqReg dst: r4 off: -1 src: r6 filter_block_3: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestNegateA/kernel === RUN TestJumpIfEqual/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JEqImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfEqual/kernel === RUN TestJumpIfEqual/C#01 === RUN TestJump0/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 1 4: JGTReg dst: r6 off: -1 src: r3 5: Mov32Imm dst: r5 imm: 0 6: LdXMemB dst: r4 src: r2 off: 0 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 8: JEqReg dst: r4 off: -1 src: r5 filter_block_4: 9: Mov32Reg dst: r4 src: r4 10: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 11: MovImm dst: r4 imm: 0 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJump0/kernel === RUN TestALUMod/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 16 3: Mod32Imm dst: r4 imm: 4 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUMod/kernel === RUN TestALUMod/C#01 === RUN TestALUXor/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: Xor32Imm dst: r4 imm: 1 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUXor/kernel === RUN TestALUXor/C#01 --- PASS: TestZeroInitA (0.10s) --- SKIP: TestZeroInitA/C (0.05s) --- SKIP: TestZeroInitA/eBPF (0.00s) --- PASS: TestZeroInitA/kernel (0.05s) === CONT TestALUShiftRight === RUN TestALUShiftRight/C === RUN TestJumpIfNotEqual/C#01 === RUN TestJumpIfLessThan/C#01 === RUN TestJumpIfGreaterThan/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JGTImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfGreaterThan/kernel#01 === RUN TestJumpIfGreaterThan/C#02 === RUN TestALUShiftLeft/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: Mov32Imm dst: r5 imm: 0 4: LSh32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 1 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUShiftLeft/kernel#01 === RUN TestALUShiftLeft/C#02 --- PASS: TestJump (0.11s) --- SKIP: TestJump/C (0.06s) --- SKIP: TestJump/eBPF (0.00s) --- PASS: TestJump/kernel (0.05s) === CONT TestScratchA === RUN TestScratchA/C === RUN TestALUMod/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 16 3: Mov32Imm dst: r5 imm: 4 4: JEqImm dst: r5 off: -1 imm: 0 5: Mod32Reg dst: r4 src: r5 6: JEqImm dst: r4 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 0 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 1 10: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 11: MovImm dst: r4 imm: 0 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestALUMod/kernel#01 === RUN TestALUMod/C#02 --- PASS: TestNegateA (0.11s) --- SKIP: TestNegateA/C (0.06s) --- SKIP: TestNegateA/eBPF (0.00s) --- PASS: TestNegateA/kernel (0.05s) === CONT TestALUOr === RUN TestALUOr/C === RUN TestJump0/C#01 === RUN TestJumpIfEqual/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JEqImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfEqual/kernel#01 === RUN TestJumpIfEqual/C#02 === RUN TestALUXor/eBPF#01 === RUN TestALUShiftRight/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 240 3: RSh32Imm dst: r4 imm: 4 4: JEqImm dst: r4 off: -1 imm: 15 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUShiftRight/kernel === RUN TestALUShiftRight/C#01 === RUN TestALUAnd/eBPF#01 === NAME TestALUXor/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: Mov32Imm dst: r5 imm: 1 4: Xor32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 0 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUXor/kernel#01 === NAME TestALUAnd/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: Mov32Imm dst: r5 imm: 0 4: And32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 0 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUAnd/kernel#01 === RUN TestALUXor/C#02 === RUN TestALUAnd/C#02 === RUN TestScratchA/eBPF === RUN TestJumpIfNotEqual/eBPF#01 === NAME TestScratchA/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: -559038737 3: StXMemW dst: rfp src: r4 off: -32 imm: 0 4: Mov32Imm dst: r4 imm: 0 5: Mov32Imm dst: r4 imm: -1 6: StXMemW dst: rfp src: r4 off: -28 imm: 0 7: Mov32Imm dst: r4 imm: -1 8: StXMemW dst: rfp src: r4 off: -36 imm: 0 9: LdXMemW dst: r4 src: rfp off: -32 imm: 0 10: Mov32Imm dst: r6 imm: -559038737 11: JEqReg dst: r4 off: -1 src: r6 filter_block_9: 12: Mov32Imm dst: r4 imm: 0 13: JaImm dst: r0 off: -1 imm: 0 filter_block_10: 14: Mov32Imm dst: r4 imm: 1 15: JaImm dst: r0 off: -1 imm: 0 result: 16: MovImm dst: r0 imm: 2 17: JEqImm dst: r4 off: -1 imm: 0 18: MovImm dst: r0 imm: 1 return: 19: Exit === RUN TestScratchA/kernel === NAME TestJumpIfNotEqual/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JNEImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfNotEqual/kernel#01 === RUN TestScratchA/C#01 === RUN TestJumpIfGreaterThan/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: Mov32Imm dst: r5 imm: 23 4: JGTReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfGreaterThan/kernel#02 === RUN TestJumpIfGreaterThan/C#03 === RUN TestALUShiftLeft/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: LSh32Imm dst: r4 imm: 4 4: JEqImm dst: r4 off: -1 imm: 16 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUShiftLeft/kernel#02 === RUN TestALUShiftLeft/C#03 === RUN TestJumpIfLessThan/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JLTImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfLessThan/kernel#01 === RUN TestALUOr/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: Or32Imm dst: r4 imm: 0 4: JEqImm dst: r4 off: -1 imm: 1 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUOr/kernel === RUN TestALUOr/C#01 === RUN TestALUMod/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 17 3: Mod32Imm dst: r4 imm: 4 4: JEqImm dst: r4 off: -1 imm: 1 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUMod/kernel#02 === RUN TestALUMod/C#03 === RUN TestJumpIfEqual/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 23 4: JEqReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfEqual/kernel#02 === RUN TestJumpIfEqual/C#03 === RUN TestALUShiftRight/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 240 3: Mov32Imm dst: r5 imm: 4 4: RSh32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 15 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUShiftRight/kernel#01 === RUN TestALUShiftRight/C#02 === RUN TestALUAnd/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 240 3: And32Imm dst: r4 imm: 128 4: JEqImm dst: r4 off: -1 imm: 128 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUAnd/kernel#02 === RUN TestALUAnd/C#03 === RUN TestJump0/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 1 4: JGTReg dst: r6 off: -1 src: r3 5: Mov32Imm dst: r5 imm: 0 6: LdXMemB dst: r4 src: r2 off: 0 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 8: JEqReg dst: r4 off: -1 src: r5 filter_block_4: 9: Mov32Reg dst: r4 src: r4 10: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 11: MovImm dst: r4 imm: 0 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJump0/kernel#01 --- PASS: TestJump0 (0.25s) --- SKIP: TestJump0/C (0.08s) --- SKIP: TestJump0/eBPF (0.00s) --- PASS: TestJump0/kernel (0.10s) --- SKIP: TestJump0/C#01 (0.07s) --- SKIP: TestJump0/eBPF#01 (0.00s) --- PASS: TestJump0/kernel#01 (0.00s) === CONT TestALUDivZero === RUN TestALUDivZero/C === RUN TestJumpIfNotEqual/C#02 === RUN TestJumpIfGreaterThan/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JGTReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfGreaterThan/kernel#03 === RUN TestJumpIfGreaterThan/C#04 === RUN TestJumpIfEqual/eBPF#03 === RUN TestALUShiftRight/eBPF#02 === RUN TestJumpIfLessThan/C#02 === NAME TestALUShiftRight/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 240 3: RSh32Imm dst: r4 imm: 8 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUShiftRight/kernel#02 === RUN TestALUShiftRight/C#03 === RUN TestALUXor/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: Mod32Imm dst: r4 imm: 4 4: JEqImm dst: r4 off: -1 imm: 2 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUXor/kernel#02 === RUN TestALUXor/C#03 === RUN TestALUShiftLeft/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: Mov32Imm dst: r5 imm: 4 4: LSh32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 16 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUShiftLeft/kernel#03 --- PASS: TestALUShiftLeft (0.31s) --- SKIP: TestALUShiftLeft/C (0.06s) --- SKIP: TestALUShiftLeft/eBPF (0.01s) --- PASS: TestALUShiftLeft/kernel (0.00s) --- SKIP: TestALUShiftLeft/C#01 (0.06s) --- SKIP: TestALUShiftLeft/eBPF#01 (0.00s) --- PASS: TestALUShiftLeft/kernel#01 (0.00s) --- SKIP: TestALUShiftLeft/C#02 (0.09s) --- SKIP: TestALUShiftLeft/eBPF#02 (0.00s) --- PASS: TestALUShiftLeft/kernel#02 (0.00s) --- SKIP: TestALUShiftLeft/C#03 (0.09s) --- SKIP: TestALUShiftLeft/eBPF#03 (0.00s) --- PASS: TestALUShiftLeft/kernel#03 (0.00s) === CONT TestALUDiv === RUN TestALUDiv/C === RUN TestScratchA/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 0 3: StXMemW dst: rfp src: r4 off: -32 imm: 0 4: Mov32Imm dst: r4 imm: 0 5: Mov32Imm dst: r4 imm: -1 6: StXMemW dst: rfp src: r4 off: -28 imm: 0 7: Mov32Imm dst: r4 imm: -1 8: StXMemW dst: rfp src: r4 off: -36 imm: 0 9: LdXMemW dst: r4 src: rfp off: -32 imm: 0 10: JEqImm dst: r4 off: -1 imm: 0 filter_block_9: 11: Mov32Imm dst: r4 imm: 0 12: JaImm dst: r0 off: -1 imm: 0 filter_block_10: 13: Mov32Imm dst: r4 imm: 1 14: JaImm dst: r0 off: -1 imm: 0 result: 15: MovImm dst: r0 imm: 2 16: JEqImm dst: r4 off: -1 imm: 0 17: MovImm dst: r0 imm: 1 return: 18: Exit === RUN TestScratchA/kernel#01 --- PASS: TestScratchA (0.18s) --- SKIP: TestScratchA/C (0.08s) --- SKIP: TestScratchA/eBPF (0.00s) --- PASS: TestScratchA/kernel (0.00s) --- SKIP: TestScratchA/C#01 (0.10s) --- SKIP: TestScratchA/eBPF#01 (0.00s) --- PASS: TestScratchA/kernel#01 (0.00s) === CONT TestALUMul === RUN TestALUMul/C === NAME TestJumpIfEqual/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JEqReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestALUMod/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 17 3: Mov32Imm dst: r5 imm: 4 4: JEqImm dst: r5 off: -1 imm: 0 5: Mod32Reg dst: r4 src: r5 6: JEqImm dst: r4 off: -1 imm: 1 filter_block_4: 7: Mov32Imm dst: r4 imm: 0 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 1 10: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 11: MovImm dst: r4 imm: 0 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestALUMod/kernel#03 --- PASS: TestALUMod (0.30s) --- SKIP: TestALUMod/C (0.05s) --- SKIP: TestALUMod/eBPF (0.00s) --- PASS: TestALUMod/kernel (0.00s) --- SKIP: TestALUMod/C#01 (0.03s) --- SKIP: TestALUMod/eBPF#01 (0.00s) --- PASS: TestALUMod/kernel#01 (0.00s) --- SKIP: TestALUMod/C#02 (0.11s) --- SKIP: TestALUMod/eBPF#02 (0.00s) --- PASS: TestALUMod/kernel#02 (0.00s) --- SKIP: TestALUMod/C#03 (0.09s) --- SKIP: TestALUMod/eBPF#03 (0.00s) --- PASS: TestALUMod/kernel#03 (0.00s) === CONT TestALUSub === RUN TestALUSub/C === RUN TestALUAnd/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 240 3: Mov32Imm dst: r5 imm: 128 4: And32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 128 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUAnd/kernel#03 === RUN TestALUAnd/C#04 === RUN TestJumpIfNotEqual/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 23 4: JNEReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfNotEqual/kernel#02 === RUN TestALUOr/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: Mov32Imm dst: r5 imm: 0 4: Or32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 1 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUOr/kernel#01 === RUN TestALUOr/C#02 === RUN TestALUDivZero/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 1 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemB dst: r4 src: r2 off: 0 imm: 0 6: Mov32Reg dst: r5 src: r4 7: Mov32Imm dst: r4 imm: 10 8: JEqImm dst: r5 off: -1 imm: 0 9: Div32Reg dst: r4 src: r5 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 12: MovImm dst: r4 imm: 0 13: JaImm dst: r0 off: -1 imm: 0 result: 14: MovImm dst: r0 imm: 2 15: JEqImm dst: r4 off: -1 imm: 0 16: MovImm dst: r0 imm: 1 return: 17: Exit === RUN TestALUDivZero/kernel === RUN TestJumpIfEqual/kernel#03 === RUN TestJumpIfEqual/C#04 === RUN TestALUMul/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 0 3: Mul32Imm dst: r4 imm: 1 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUMul/kernel === RUN TestALUMul/C#01 === RUN TestJumpIfLessThan/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: Mov32Imm dst: r5 imm: 23 4: JLTReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfLessThan/kernel#02 === RUN TestJumpIfGreaterThan/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JGTImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfGreaterThan/kernel#04 === RUN TestALUXor/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: Mov32Imm dst: r5 imm: 4 4: JEqImm dst: r5 off: -1 imm: 0 5: Mod32Reg dst: r4 src: r5 6: JEqImm dst: r4 off: -1 imm: 2 filter_block_4: 7: Mov32Imm dst: r4 imm: 0 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 1 10: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 11: MovImm dst: r4 imm: 0 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestALUXor/kernel#03 --- PASS: TestALUXor (0.36s) --- SKIP: TestALUXor/C (0.06s) --- SKIP: TestALUXor/eBPF (0.00s) --- PASS: TestALUXor/kernel (0.00s) --- SKIP: TestALUXor/C#01 (0.10s) --- SKIP: TestALUXor/eBPF#01 (0.00s) --- PASS: TestALUXor/kernel#01 (0.00s) --- SKIP: TestALUXor/C#02 (0.08s) --- SKIP: TestALUXor/eBPF#02 (0.00s) --- PASS: TestALUXor/kernel#02 (0.00s) --- SKIP: TestALUXor/C#03 (0.08s) --- SKIP: TestALUXor/eBPF#03 (0.00s) --- PASS: TestALUXor/kernel#03 (0.00s) === CONT TestALUAdd === RUN TestALUAdd/C === RUN TestJumpIfEqual/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JEqImm dst: r4 off: -1 imm: 21 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfEqual/kernel#04 === RUN TestALUAnd/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 240 3: And32Imm dst: r4 imm: 15 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUAnd/kernel#04 === RUN TestALUAnd/C#05 === RUN TestJumpIfNotEqual/C#03 === RUN TestALUDivZero/C#01 === RUN TestALUShiftRight/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 240 3: Mov32Imm dst: r5 imm: 8 4: RSh32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 0 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUShiftRight/kernel#03 --- PASS: TestALUShiftRight (0.30s) --- SKIP: TestALUShiftRight/C (0.10s) --- SKIP: TestALUShiftRight/eBPF (0.00s) --- PASS: TestALUShiftRight/kernel (0.00s) --- SKIP: TestALUShiftRight/C#01 (0.06s) --- SKIP: TestALUShiftRight/eBPF#01 (0.00s) --- PASS: TestALUShiftRight/kernel#01 (0.00s) --- SKIP: TestALUShiftRight/C#02 (0.04s) --- SKIP: TestALUShiftRight/eBPF#02 (0.00s) --- PASS: TestALUShiftRight/kernel#02 (0.00s) --- SKIP: TestALUShiftRight/C#03 (0.10s) --- SKIP: TestALUShiftRight/eBPF#03 (0.00s) --- PASS: TestALUShiftRight/kernel#03 (0.00s) === CONT TestLoadExtLen === RUN TestLoadExtLen/C === RUN TestALUSub/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: Sub32Imm dst: r4 imm: 1 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUSub/kernel === RUN TestALUSub/C#01 === RUN TestALUMul/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 0 3: Mov32Imm dst: r5 imm: 1 4: Mul32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 0 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUMul/kernel#01 === RUN TestALUMul/C#02 === RUN TestJumpIfLessThan/C#03 === RUN TestALUDiv/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 2 3: Div32Imm dst: r4 imm: 2 4: JEqImm dst: r4 off: -1 imm: 1 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUDiv/kernel === RUN TestALUDiv/C#01 === RUN TestJumpIfGreaterThan/C#05 === RUN TestALUOr/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 240 3: Or32Imm dst: r4 imm: 15 4: JEqImm dst: r4 off: -1 imm: 255 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUOr/kernel#02 === RUN TestALUOr/C#03 === RUN TestJumpIfEqual/C#05 === RUN TestALUAnd/eBPF#05 === RUN TestJumpIfNotEqual/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JNEReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestALUAdd/eBPF === RUN TestJumpIfNotEqual/kernel#03 === RUN TestLoadExtLen/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r4 src: r3 3: Sub32Reg dst: r4 src: r2 4: JEqImm dst: r4 off: -1 imm: 16 filter_block_2: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestLoadExtLen/kernel --- PASS: TestLoadExtLen (0.10s) --- SKIP: TestLoadExtLen/C (0.10s) --- SKIP: TestLoadExtLen/eBPF (0.00s) --- PASS: TestLoadExtLen/kernel (0.00s) === CONT TestMemShift === RUN TestMemShift/C === NAME TestALUAnd/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 240 3: Mov32Imm dst: r5 imm: 15 4: And32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 0 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUAnd/kernel#05 --- PASS: TestALUAnd (0.50s) --- SKIP: TestALUAnd/C (0.07s) --- SKIP: TestALUAnd/eBPF (0.00s) --- PASS: TestALUAnd/kernel (0.00s) --- SKIP: TestALUAnd/C#01 (0.12s) --- SKIP: TestALUAnd/eBPF#01 (0.00s) --- PASS: TestALUAnd/kernel#01 (0.00s) --- SKIP: TestALUAnd/C#02 (0.04s) --- SKIP: TestALUAnd/eBPF#02 (0.00s) --- PASS: TestALUAnd/kernel#02 (0.00s) --- SKIP: TestALUAnd/C#03 (0.07s) --- SKIP: TestALUAnd/eBPF#03 (0.00s) --- PASS: TestALUAnd/kernel#03 (0.00s) --- SKIP: TestALUAnd/C#04 (0.05s) --- SKIP: TestALUAnd/eBPF#04 (0.00s) --- PASS: TestALUAnd/kernel#04 (0.00s) --- SKIP: TestALUAnd/C#05 (0.06s) --- SKIP: TestALUAnd/eBPF#05 (0.04s) --- PASS: TestALUAnd/kernel#05 (0.00s) === CONT TestScratchX === RUN TestScratchX/C === NAME TestALUAdd/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: Add32Imm dst: r4 imm: 0 4: JEqImm dst: r4 off: -1 imm: 1 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUAdd/kernel === RUN TestALUDiv/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 2 3: Mov32Imm dst: r5 imm: 2 4: JEqImm dst: r5 off: -1 imm: 0 5: Div32Reg dst: r4 src: r5 6: JEqImm dst: r4 off: -1 imm: 1 filter_block_4: 7: Mov32Imm dst: r4 imm: 0 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 1 10: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 11: MovImm dst: r4 imm: 0 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestALUDiv/kernel#01 === RUN TestALUSub/eBPF#01 === RUN TestALUAdd/C#01 === NAME TestALUSub/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: Mov32Imm dst: r5 imm: 1 4: Sub32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 0 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUDivZero/eBPF#01 === RUN TestALUSub/kernel#01 === NAME TestALUDivZero/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 1 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemB dst: r4 src: r2 off: 0 imm: 0 6: Mov32Reg dst: r5 src: r4 7: Mov32Imm dst: r4 imm: 10 8: JEqImm dst: r5 off: -1 imm: 0 9: Div32Reg dst: r4 src: r5 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 12: MovImm dst: r4 imm: 0 13: JaImm dst: r0 off: -1 imm: 0 result: 14: MovImm dst: r0 imm: 2 15: JEqImm dst: r4 off: -1 imm: 0 16: MovImm dst: r0 imm: 1 return: 17: Exit === RUN TestALUDivZero/kernel#01 === RUN TestALUSub/C#02 --- PASS: TestALUDivZero (0.24s) --- SKIP: TestALUDivZero/C (0.07s) --- SKIP: TestALUDivZero/eBPF (0.00s) --- PASS: TestALUDivZero/kernel (0.05s) --- SKIP: TestALUDivZero/C#01 (0.10s) --- SKIP: TestALUDivZero/eBPF#01 (0.00s) --- PASS: TestALUDivZero/kernel#01 (0.00s) === CONT TestLoadConstantX === RUN TestLoadConstantX/C === RUN TestALUDiv/C#02 === RUN TestALUMul/eBPF#02 === RUN TestJumpIfGreaterThan/eBPF#05 === RUN TestALUOr/eBPF#03 === NAME TestJumpIfGreaterThan/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JGTImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfGreaterThan/kernel#05 === NAME TestALUOr/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 240 3: Mov32Imm dst: r5 imm: 15 4: Or32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 255 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUOr/kernel#03 --- PASS: TestALUOr (0.40s) --- SKIP: TestALUOr/C (0.10s) --- SKIP: TestALUOr/eBPF (0.00s) --- PASS: TestALUOr/kernel (0.00s) --- SKIP: TestALUOr/C#01 (0.09s) --- SKIP: TestALUOr/eBPF#01 (0.00s) --- PASS: TestALUOr/kernel#01 (0.00s) --- SKIP: TestALUOr/C#02 (0.11s) --- SKIP: TestALUOr/eBPF#02 (0.00s) --- PASS: TestALUOr/kernel#02 (0.00s) --- SKIP: TestALUOr/C#03 (0.06s) --- SKIP: TestALUOr/eBPF#03 (0.02s) --- PASS: TestALUOr/kernel#03 (0.00s) === CONT TestScratchZero === RUN TestScratchZero/C === RUN TestJumpIfLessThan/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JLTReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfLessThan/kernel#03 === RUN TestMemShift/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 3 4: JGTReg dst: r6 off: -1 src: r3 5: Mov32Imm dst: r4 imm: 40 6: LdXMemB dst: r5 src: r2 off: 2 imm: 0 7: And32Imm dst: r5 imm: 15 8: LSh32Imm dst: r5 imm: 2 9: JEqReg dst: r4 off: -1 src: r5 filter_block_3: 10: Mov32Imm dst: r4 imm: 0 11: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 12: Mov32Imm dst: r4 imm: 1 13: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 14: MovImm dst: r4 imm: 0 15: JaImm dst: r0 off: -1 imm: 0 result: 16: MovImm dst: r0 imm: 2 17: JEqImm dst: r4 off: -1 imm: 0 18: MovImm dst: r0 imm: 1 return: 19: Exit === RUN TestMemShift/kernel === RUN TestMemShift/C#01 === RUN TestScratchX/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: -559038737 3: StXMemW dst: rfp src: r5 off: -32 imm: 0 4: Mov32Imm dst: r5 imm: 0 5: Mov32Imm dst: r5 imm: -1 6: StXMemW dst: rfp src: r5 off: -28 imm: 0 7: Mov32Imm dst: r5 imm: -1 8: StXMemW dst: rfp src: r5 off: -36 imm: 0 9: LdXMemW dst: r5 src: rfp off: -32 imm: 0 10: Mov32Reg dst: r4 src: r5 11: Mov32Imm dst: r6 imm: -559038737 12: JEqReg dst: r4 off: -1 src: r6 filter_block_10: 13: Mov32Imm dst: r4 imm: 0 14: JaImm dst: r0 off: -1 imm: 0 filter_block_11: 15: Mov32Imm dst: r4 imm: 1 16: JaImm dst: r0 off: -1 imm: 0 result: 17: MovImm dst: r0 imm: 2 18: JEqImm dst: r4 off: -1 imm: 0 19: MovImm dst: r0 imm: 1 return: 20: Exit === RUN TestScratchX/kernel === RUN TestScratchX/C#01 === NAME TestALUMul/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 4 3: Mul32Imm dst: r4 imm: 13 4: JEqImm dst: r4 off: -1 imm: 52 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUMul/kernel#02 === RUN TestALUMul/C#03 === RUN TestJumpIfEqual/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JEqImm dst: r4 off: -1 imm: 21 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfEqual/kernel#05 === RUN TestJumpIfNotEqual/C#04 === RUN TestALUSub/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 13 3: Sub32Imm dst: r4 imm: 9 4: JEqImm dst: r4 off: -1 imm: 4 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUSub/kernel#02 === RUN TestALUSub/C#03 === RUN TestLoadConstantX/eBPF === RUN TestALUAdd/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: Mov32Imm dst: r5 imm: 0 4: Add32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 1 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUAdd/kernel#01 === RUN TestALUAdd/C#02 === RUN TestJumpIfGreaterThan/C#06 === NAME TestLoadConstantX/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 1 3: Mov32Reg dst: r4 src: r5 4: JEqImm dst: r4 off: -1 imm: 1 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestLoadConstantX/kernel === RUN TestLoadConstantX/C#01 === RUN TestJumpIfLessThan/C#04 === RUN TestJumpIfEqual/C#06 === RUN TestALUDiv/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 19 3: Div32Imm dst: r4 imm: 3 4: JEqImm dst: r4 off: -1 imm: 6 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUDiv/kernel#02 === RUN TestALUDiv/C#03 === RUN TestScratchZero/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 4 3: StXMemW dst: rfp src: r4 off: -4 imm: 0 4: Mov32Imm dst: r4 imm: 0 5: LdXMemW dst: r4 src: rfp off: -4 imm: 0 6: JEqImm dst: r4 off: -1 imm: 4 filter_block_5: 7: Mov32Imm dst: r4 imm: 0 8: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 9: Mov32Imm dst: r4 imm: 1 10: JaImm dst: r0 off: -1 imm: 0 result: 11: MovImm dst: r0 imm: 2 12: JEqImm dst: r4 off: -1 imm: 0 13: MovImm dst: r0 imm: 1 return: 14: Exit === RUN TestScratchZero/kernel --- PASS: TestScratchZero (0.08s) --- SKIP: TestScratchZero/C (0.08s) --- SKIP: TestScratchZero/eBPF (0.00s) --- PASS: TestScratchZero/kernel (0.00s) === CONT TestLoadIndirect === RUN TestLoadIndirect/constant_valid === RUN TestLoadIndirect/constant_valid/C === RUN TestALUMul/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 4 3: Mov32Imm dst: r5 imm: 13 4: Mul32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 52 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUMul/kernel#03 === RUN TestALUMul/C#04 === RUN TestScratchX/eBPF#01 === RUN TestMemShift/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 3 4: JGTReg dst: r6 off: -1 src: r3 5: Mov32Imm dst: r4 imm: 0 6: LdXMemB dst: r5 src: r2 off: 2 imm: 0 7: And32Imm dst: r5 imm: 15 8: LSh32Imm dst: r5 imm: 2 9: JEqReg dst: r4 off: -1 src: r5 filter_block_3: 10: Mov32Imm dst: r4 imm: 0 11: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 12: Mov32Imm dst: r4 imm: 1 13: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 14: MovImm dst: r4 imm: 0 15: JaImm dst: r0 off: -1 imm: 0 result: 16: MovImm dst: r0 imm: 2 17: JEqImm dst: r4 off: -1 imm: 0 18: MovImm dst: r0 imm: 1 return: 19: Exit === RUN TestMemShift/kernel#01 --- PASS: TestMemShift (0.13s) --- SKIP: TestMemShift/C (0.04s) --- SKIP: TestMemShift/eBPF (0.00s) --- PASS: TestMemShift/kernel (0.00s) --- SKIP: TestMemShift/C#01 (0.09s) --- SKIP: TestMemShift/eBPF#01 (0.00s) --- PASS: TestMemShift/kernel#01 (0.00s) === CONT TestLoadAbsoluteBigOffset === RUN TestLoadAbsoluteBigOffset/C === NAME TestScratchX/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 0 3: StXMemW dst: rfp src: r5 off: -32 imm: 0 4: Mov32Imm dst: r5 imm: 0 5: Mov32Imm dst: r5 imm: -1 6: StXMemW dst: rfp src: r5 off: -28 imm: 0 7: Mov32Imm dst: r5 imm: -1 8: StXMemW dst: rfp src: r5 off: -36 imm: 0 9: LdXMemW dst: r5 src: rfp off: -32 imm: 0 10: Mov32Reg dst: r4 src: r5 11: JEqImm dst: r4 off: -1 imm: 0 filter_block_10: 12: Mov32Imm dst: r4 imm: 0 13: JaImm dst: r0 off: -1 imm: 0 filter_block_11: 14: Mov32Imm dst: r4 imm: 1 15: JaImm dst: r0 off: -1 imm: 0 result: 16: MovImm dst: r0 imm: 2 17: JEqImm dst: r4 off: -1 imm: 0 18: MovImm dst: r0 imm: 1 return: 19: Exit === RUN TestScratchX/kernel#01 --- PASS: TestScratchX (0.13s) --- SKIP: TestScratchX/C (0.04s) --- SKIP: TestScratchX/eBPF (0.00s) --- PASS: TestScratchX/kernel (0.00s) --- SKIP: TestScratchX/C#01 (0.08s) --- SKIP: TestScratchX/eBPF#01 (0.01s) --- PASS: TestScratchX/kernel#01 (0.00s) === CONT TestLoadAbsolute === RUN TestLoadAbsolute/C === RUN TestJumpIfGreaterThan/eBPF#06 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 23 4: JGTReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfGreaterThan/kernel#06 === RUN TestALUAdd/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 4 3: Add32Imm dst: r4 imm: 13 4: JEqImm dst: r4 off: -1 imm: 17 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUAdd/kernel#02 === RUN TestALUAdd/C#03 === RUN TestLoadConstantX/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 28 3: Mov32Reg dst: r4 src: r5 4: JEqImm dst: r4 off: -1 imm: 28 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestLoadConstantX/kernel#01 === RUN TestLoadConstantX/C#02 === RUN TestALUSub/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 13 3: Mov32Imm dst: r5 imm: 9 4: Sub32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 4 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUSub/kernel#03 --- PASS: TestALUSub (0.31s) --- SKIP: TestALUSub/C (0.06s) --- SKIP: TestALUSub/eBPF (0.00s) --- PASS: TestALUSub/kernel (0.00s) --- SKIP: TestALUSub/C#01 (0.08s) --- SKIP: TestALUSub/eBPF#01 (0.00s) --- PASS: TestALUSub/kernel#01 (0.00s) --- SKIP: TestALUSub/C#02 (0.08s) --- SKIP: TestALUSub/eBPF#02 (0.00s) --- PASS: TestALUSub/kernel#02 (0.00s) --- SKIP: TestALUSub/C#03 (0.08s) --- SKIP: TestALUSub/eBPF#03 (0.00s) --- PASS: TestALUSub/kernel#03 (0.00s) === CONT TestJumpIfBitsNotSet === RUN TestJumpIfBitsNotSet/C === RUN TestJumpIfNotEqual/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JNEImm dst: r4 off: -1 imm: 21 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfNotEqual/kernel#04 === RUN TestJumpIfNotEqual/C#05 === RUN TestLoadIndirect/constant_valid/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: -2147483644 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: 2147483647 7: JGEImm dst: r7 off: -1 imm: 65535 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 1 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemB dst: r4 src: r7 off: 0 imm: 0 13: JEqImm dst: r4 off: -1 imm: 5 filter_block_3: 14: Mov32Imm dst: r4 imm: 0 15: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 16: Mov32Imm dst: r4 imm: 1 17: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 18: MovImm dst: r4 imm: 0 19: JaImm dst: r0 off: -1 imm: 0 result: 20: MovImm dst: r0 imm: 2 21: JEqImm dst: r4 off: -1 imm: 0 22: MovImm dst: r0 imm: 1 return: 23: Exit === RUN TestLoadIndirect/constant_valid/kernel === RUN TestLoadIndirect/constant_valid/C#01 === RUN TestJumpIfGreaterThan/C#07 === RUN TestJumpIfBitsNotSet/eBPF === RUN TestALUDiv/eBPF#03 === NAME TestJumpIfBitsNotSet/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: JSetImm dst: r4 off: -1 imm: 4 4: JaImm dst: r0 off: -1 imm: 0 filter_block_2: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfBitsNotSet/kernel === NAME TestALUDiv/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 19 3: Mov32Imm dst: r5 imm: 3 4: JEqImm dst: r5 off: -1 imm: 0 5: Div32Reg dst: r4 src: r5 6: JEqImm dst: r4 off: -1 imm: 6 filter_block_4: 7: Mov32Imm dst: r4 imm: 0 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 1 10: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 11: MovImm dst: r4 imm: 0 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestALUDiv/kernel#03 --- PASS: TestALUDiv (0.39s) --- SKIP: TestALUDiv/C (0.09s) --- SKIP: TestALUDiv/eBPF (0.00s) --- PASS: TestALUDiv/kernel (0.00s) --- SKIP: TestALUDiv/C#01 (0.05s) --- SKIP: TestALUDiv/eBPF#01 (0.00s) --- PASS: TestALUDiv/kernel#01 (0.00s) --- SKIP: TestALUDiv/C#02 (0.08s) --- SKIP: TestALUDiv/eBPF#02 (0.00s) --- PASS: TestALUDiv/kernel#02 (0.00s) --- SKIP: TestALUDiv/C#03 (0.10s) --- SKIP: TestALUDiv/eBPF#03 (0.00s) --- PASS: TestALUDiv/kernel#03 (0.00s) === CONT TestTAX === RUN TestTAX/C === RUN TestJumpIfLessThan/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JLTImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfLessThan/kernel#04 === RUN TestJumpIfEqual/eBPF#06 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 21 4: JEqReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfEqual/kernel#06 === RUN TestLoadConstantX/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 0 3: Mov32Reg dst: r4 src: r5 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestLoadConstantX/kernel#02 --- PASS: TestLoadConstantX (0.20s) --- SKIP: TestLoadConstantX/C (0.08s) --- SKIP: TestLoadConstantX/eBPF (0.00s) --- PASS: TestLoadConstantX/kernel (0.00s) --- SKIP: TestLoadConstantX/C#01 (0.06s) --- SKIP: TestLoadConstantX/eBPF#01 (0.00s) --- PASS: TestLoadConstantX/kernel#01 (0.00s) --- SKIP: TestLoadConstantX/C#02 (0.05s) --- SKIP: TestLoadConstantX/eBPF#02 (0.00s) --- PASS: TestLoadConstantX/kernel#02 (0.00s) === CONT TestTXA === RUN TestTXA/C === RUN TestALUMul/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 2 3: Mul32Imm dst: r4 imm: -2147483648 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUAdd/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 4 3: Mov32Imm dst: r5 imm: 13 4: Add32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 17 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUAdd/kernel#03 === RUN TestLoadAbsoluteBigOffset/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 65535 4: JGTReg dst: r6 off: -1 src: r3 5: MovReg dst: r6 src: r2 6: AddImm dst: r6 imm: 65534 7: LdXMemB dst: r4 src: r6 off: 0 imm: 0 8: Add32Imm dst: r4 imm: 2 9: Mov32Reg dst: r4 src: r4 10: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 11: MovImm dst: r4 imm: 0 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestLoadAbsoluteBigOffset/kernel --- PASS: TestALUAdd (0.34s) --- SKIP: TestALUAdd/C (0.10s) --- SKIP: TestALUAdd/eBPF (0.00s) --- PASS: TestALUAdd/kernel (0.00s) --- SKIP: TestALUAdd/C#01 (0.09s) --- SKIP: TestALUAdd/eBPF#01 (0.00s) --- PASS: TestALUAdd/kernel#01 (0.00s) --- SKIP: TestALUAdd/C#02 (0.06s) --- SKIP: TestALUAdd/eBPF#02 (0.00s) --- PASS: TestALUAdd/kernel#02 (0.00s) --- SKIP: TestALUAdd/C#03 (0.08s) --- SKIP: TestALUAdd/eBPF#03 (0.00s) --- PASS: TestALUAdd/kernel#03 (0.00s) === CONT TestRetConstant === RUN TestRetConstant/C === RUN TestALUMul/kernel#04 === RUN TestALUMul/C#05 === RUN TestLoadAbsolute/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 3 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemB dst: r4 src: r2 off: 2 imm: 0 6: JEqImm dst: r4 off: -1 imm: 5 filter_block_2: 7: Mov32Imm dst: r4 imm: 0 8: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 9: Mov32Imm dst: r4 imm: 1 10: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 11: MovImm dst: r4 imm: 0 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestLoadAbsolute/kernel === RUN TestLoadAbsolute/C#01 === RUN TestJumpIfEqual/C#07 === RUN TestJumpIfLessThan/C#05 === RUN TestJumpIfBitsNotSet/C#01 === RUN TestTAX/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: Mov32Reg dst: r5 src: r4 4: Mov32Reg dst: r4 src: r5 5: Mov32Reg dst: r4 src: r4 6: JaImm dst: r0 off: -1 imm: 0 result: 7: MovImm dst: r0 imm: 2 8: JEqImm dst: r4 off: -1 imm: 0 9: MovImm dst: r0 imm: 1 return: 10: Exit === RUN TestTAX/kernel --- PASS: TestTAX (0.06s) --- SKIP: TestTAX/C (0.06s) --- SKIP: TestTAX/eBPF (0.00s) --- PASS: TestTAX/kernel (0.00s) === CONT TestRetA === RUN TestRetA/C === RUN TestLoadIndirect/constant_valid/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: -2147483644 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: 2147483647 7: JGEImm dst: r7 off: -1 imm: 65535 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 1 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemB dst: r4 src: r7 off: 0 imm: 0 13: JEqImm dst: r4 off: -1 imm: 6 filter_block_3: 14: Mov32Imm dst: r4 imm: 0 15: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 16: Mov32Imm dst: r4 imm: 1 17: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 18: MovImm dst: r4 imm: 0 19: JaImm dst: r0 off: -1 imm: 0 result: 20: MovImm dst: r0 imm: 2 21: JEqImm dst: r4 off: -1 imm: 0 22: MovImm dst: r0 imm: 1 return: 23: Exit === RUN TestLoadIndirect/constant_valid/kernel#01 === RUN TestTXA/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 1 3: Mov32Reg dst: r4 src: r5 4: Mov32Reg dst: r4 src: r4 5: JaImm dst: r0 off: -1 imm: 0 result: 6: MovImm dst: r0 imm: 2 7: JEqImm dst: r4 off: -1 imm: 0 8: MovImm dst: r0 imm: 1 return: 9: Exit === RUN TestTXA/kernel --- PASS: TestTXA (0.07s) --- SKIP: TestTXA/C (0.07s) --- SKIP: TestTXA/eBPF (0.00s) --- PASS: TestTXA/kernel (0.00s) === CONT TestJumpIfLessOrEqual === RUN TestJumpIfLessOrEqual/C === RUN TestLoadAbsoluteBigOffset/C#01 === RUN TestRetConstant/eBPF === RUN TestJumpIfGreaterThan/eBPF#07 === NAME TestRetConstant/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: JaImm dst: r0 off: -1 imm: 0 result: 4: MovImm dst: r0 imm: 2 5: JEqImm dst: r4 off: -1 imm: 0 6: MovImm dst: r0 imm: 1 return: 7: Exit === RUN TestRetConstant/kernel === NAME TestJumpIfGreaterThan/eBPF#07 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JGTReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestLoadAbsolute/eBPF#01 === RUN TestJumpIfGreaterThan/kernel#07 === NAME TestLoadAbsolute/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 3 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemB dst: r4 src: r2 off: 2 imm: 0 6: JEqImm dst: r4 off: -1 imm: 6 filter_block_2: 7: Mov32Imm dst: r4 imm: 0 8: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 9: Mov32Imm dst: r4 imm: 1 10: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 11: MovImm dst: r4 imm: 0 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestLoadAbsolute/kernel#01 === RUN TestRetConstant/C#01 === RUN TestRetA/eBPF === RUN TestALUMul/eBPF#05 === NAME TestRetA/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: Mov32Reg dst: r4 src: r4 4: JaImm dst: r0 off: -1 imm: 0 result: 5: MovImm dst: r0 imm: 2 6: JEqImm dst: r4 off: -1 imm: 0 7: MovImm dst: r0 imm: 1 return: 8: Exit === RUN TestJumpIfNotEqual/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JNEImm dst: r4 off: -1 imm: 21 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfNotEqual/kernel#05 === RUN TestJumpIfNotEqual/C#06 === NAME TestALUMul/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 2 3: Mov32Imm dst: r5 imm: -2147483648 4: Mul32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 0 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUMul/kernel#05 --- PASS: TestALUMul (0.50s) --- SKIP: TestALUMul/C (0.04s) --- SKIP: TestALUMul/eBPF (0.00s) --- PASS: TestALUMul/kernel (0.00s) --- SKIP: TestALUMul/C#01 (0.07s) --- SKIP: TestALUMul/eBPF#01 (0.00s) --- PASS: TestALUMul/kernel#01 (0.00s) --- SKIP: TestALUMul/C#02 (0.10s) --- SKIP: TestALUMul/eBPF#02 (0.02s) --- PASS: TestALUMul/kernel#02 (0.00s) --- SKIP: TestALUMul/C#03 (0.08s) --- SKIP: TestALUMul/eBPF#03 (0.00s) --- PASS: TestALUMul/kernel#03 (0.00s) --- SKIP: TestALUMul/C#04 (0.11s) --- SKIP: TestALUMul/eBPF#04 (0.00s) --- PASS: TestALUMul/kernel#04 (0.00s) --- SKIP: TestALUMul/C#05 (0.07s) --- SKIP: TestALUMul/eBPF#05 (0.01s) --- PASS: TestALUMul/kernel#05 (0.00s) === CONT TestJumpIfBitsSet === RUN TestJumpIfBitsSet/C === RUN TestLoadIndirect/constant_valid/C#02 === RUN TestRetA/kernel === RUN TestLoadAbsolute/C#02 --- PASS: TestRetA (0.09s) --- SKIP: TestRetA/C (0.05s) --- SKIP: TestRetA/eBPF (0.01s) --- PASS: TestRetA/kernel (0.00s) === CONT TestPartialZeroInitX === RUN TestPartialZeroInitX/C === RUN TestJumpIfGreaterThan/C#08 === RUN TestJumpIfBitsNotSet/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JSetImm dst: r4 off: -1 imm: 4 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfBitsNotSet/kernel#01 === RUN TestJumpIfLessThan/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JLTImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfLessThan/kernel#05 === RUN TestLoadAbsoluteBigOffset/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 0 3: JaImm dst: r0 off: -1 imm: 0 result: 4: MovImm dst: r0 imm: 2 5: JEqImm dst: r4 off: -1 imm: 0 6: MovImm dst: r0 imm: 1 return: 7: Exit === RUN TestLoadAbsoluteBigOffset/kernel#01 === RUN TestRetConstant/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 0 3: JaImm dst: r0 off: -1 imm: 0 result: 4: MovImm dst: r0 imm: 2 5: JEqImm dst: r4 off: -1 imm: 0 6: MovImm dst: r0 imm: 1 return: 7: Exit === RUN TestRetConstant/kernel#01 === RUN TestJumpIfBitsSet/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: JSetImm dst: r4 off: -1 imm: 4 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfBitsSet/kernel === RUN TestJumpIfBitsSet/C#01 === RUN TestJumpIfEqual/eBPF#07 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 21 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JEqReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfEqual/kernel#07 === RUN TestJumpIfNotEqual/eBPF#06 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 21 4: JNEReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfNotEqual/kernel#06 === RUN TestJumpIfNotEqual/C#07 === RUN TestJumpIfLessOrEqual/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: JLEImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfLessOrEqual/kernel === RUN TestJumpIfLessThan/C#06 === RUN TestJumpIfBitsNotSet/C#02 --- PASS: TestRetConstant (0.17s) --- SKIP: TestRetConstant/C (0.06s) --- SKIP: TestRetConstant/eBPF (0.00s) --- PASS: TestRetConstant/kernel (0.00s) --- SKIP: TestRetConstant/C#01 (0.06s) --- SKIP: TestRetConstant/eBPF#01 (0.00s) --- PASS: TestRetConstant/kernel#01 (0.05s) === CONT TestLoadConstantA === RUN TestLoadConstantA/C === RUN TestLoadAbsoluteBigOffset/C#02 === RUN TestLoadIndirect/constant_valid/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 3 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: -1 7: JGEImm dst: r7 off: -1 imm: 65534 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 2 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemH dst: r4 src: r7 off: 0 imm: 0 13: SwapBE dst: r4 imm: 16 14: JEqImm dst: r4 off: -1 imm: 57005 filter_block_3: 15: Mov32Imm dst: r4 imm: 0 16: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 17: Mov32Imm dst: r4 imm: 1 18: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 19: MovImm dst: r4 imm: 0 20: JaImm dst: r0 off: -1 imm: 0 result: 21: MovImm dst: r0 imm: 2 22: JEqImm dst: r4 off: -1 imm: 0 23: MovImm dst: r0 imm: 1 return: 24: Exit === RUN TestLoadIndirect/constant_valid/kernel#02 === RUN TestLoadIndirect/constant_valid/C#03 === RUN TestLoadAbsolute/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 4 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemH dst: r4 src: r2 off: 2 imm: 0 6: SwapBE dst: r4 imm: 16 7: JEqImm dst: r4 off: -1 imm: 57005 filter_block_2: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 12: MovImm dst: r4 imm: 0 13: JaImm dst: r0 off: -1 imm: 0 result: 14: MovImm dst: r0 imm: 2 15: JEqImm dst: r4 off: -1 imm: 0 16: MovImm dst: r0 imm: 1 return: 17: Exit === RUN TestLoadAbsolute/kernel#02 === RUN TestLoadAbsolute/C#03 === RUN TestJumpIfGreaterThan/eBPF#08 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: JGTImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfGreaterThan/kernel#08 === RUN TestJumpIfBitsSet/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JSetImm dst: r4 off: -1 imm: 4 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfBitsSet/kernel#01 === RUN TestJumpIfBitsSet/C#02 --- PASS: TestJumpIfEqual (0.93s) --- SKIP: TestJumpIfEqual/C (0.07s) --- SKIP: TestJumpIfEqual/eBPF (0.00s) --- PASS: TestJumpIfEqual/kernel (0.00s) --- SKIP: TestJumpIfEqual/C#01 (0.10s) --- SKIP: TestJumpIfEqual/eBPF#01 (0.00s) --- PASS: TestJumpIfEqual/kernel#01 (0.00s) --- SKIP: TestJumpIfEqual/C#02 (0.05s) --- SKIP: TestJumpIfEqual/eBPF#02 (0.00s) --- PASS: TestJumpIfEqual/kernel#02 (0.00s) --- SKIP: TestJumpIfEqual/C#03 (0.04s) --- SKIP: TestJumpIfEqual/eBPF#03 (0.01s) --- PASS: TestJumpIfEqual/kernel#03 (0.00s) --- SKIP: TestJumpIfEqual/C#04 (0.04s) --- SKIP: TestJumpIfEqual/eBPF#04 (0.00s) --- PASS: TestJumpIfEqual/kernel#04 (0.07s) --- SKIP: TestJumpIfEqual/C#05 (0.09s) --- SKIP: TestJumpIfEqual/eBPF#05 (0.00s) --- PASS: TestJumpIfEqual/kernel#05 (0.05s) --- SKIP: TestJumpIfEqual/C#06 (0.10s) --- SKIP: TestJumpIfEqual/eBPF#06 (0.00s) --- PASS: TestJumpIfEqual/kernel#06 (0.05s) --- SKIP: TestJumpIfEqual/C#07 (0.12s) --- SKIP: TestJumpIfEqual/eBPF#07 (0.00s) --- PASS: TestJumpIfEqual/kernel#07 (0.05s) === CONT TestJumpIfGreaterOrEqual === RUN TestJumpIfGreaterOrEqual/C === RUN TestJumpIfLessOrEqual/C#01 === RUN TestPartialZeroInitX/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 1 4: JGTReg dst: r6 off: -1 src: r3 5: Mov32Imm dst: r5 imm: 0 6: LdXMemB dst: r4 src: r2 off: 0 imm: 0 7: JNEImm dst: r4 off: -1 imm: 3 filter_block_2: 8: Mov32Reg dst: r5 src: r4 filter_block_3: 9: Mov32Reg dst: r4 src: r5 10: Mov32Reg dst: r4 src: r4 11: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 12: MovImm dst: r4 imm: 0 13: JaImm dst: r0 off: -1 imm: 0 result: 14: MovImm dst: r0 imm: 2 15: JEqImm dst: r4 off: -1 imm: 0 16: MovImm dst: r0 imm: 1 return: 17: Exit === RUN TestPartialZeroInitX/kernel === RUN TestJumpIfLessThan/eBPF#06 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 23 4: JLTReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfLessThan/kernel#06 === RUN TestLoadIndirect/constant_valid/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 3 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: -1 7: JGEImm dst: r7 off: -1 imm: 65534 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 2 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemH dst: r4 src: r7 off: 0 imm: 0 13: SwapBE dst: r4 imm: 16 14: JEqImm dst: r4 off: -1 imm: 57005 filter_block_3: 15: Mov32Imm dst: r4 imm: 0 16: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 17: Mov32Imm dst: r4 imm: 1 18: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 19: MovImm dst: r4 imm: 0 20: JaImm dst: r0 off: -1 imm: 0 result: 21: MovImm dst: r0 imm: 2 22: JEqImm dst: r4 off: -1 imm: 0 23: MovImm dst: r0 imm: 1 return: 24: Exit === RUN TestLoadIndirect/constant_valid/kernel#03 === RUN TestLoadAbsoluteBigOffset/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 65535 4: JGTReg dst: r6 off: -1 src: r3 5: MovReg dst: r6 src: r2 6: AddImm dst: r6 imm: 65533 7: LdXMemH dst: r4 src: r6 off: 0 imm: 0 8: SwapBE dst: r4 imm: 16 9: Add32Imm dst: r4 imm: 2 10: Mov32Reg dst: r4 src: r4 11: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 12: MovImm dst: r4 imm: 0 13: JaImm dst: r0 off: -1 imm: 0 result: 14: MovImm dst: r0 imm: 2 15: JEqImm dst: r4 off: -1 imm: 0 16: MovImm dst: r0 imm: 1 return: 17: Exit === RUN TestLoadAbsoluteBigOffset/kernel#02 === RUN TestJumpIfNotEqual/eBPF#07 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 21 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JNEReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfNotEqual/kernel#07 --- PASS: TestJumpIfNotEqual (0.99s) --- SKIP: TestJumpIfNotEqual/C (0.04s) --- SKIP: TestJumpIfNotEqual/eBPF (0.00s) --- PASS: TestJumpIfNotEqual/kernel (0.07s) --- SKIP: TestJumpIfNotEqual/C#01 (0.09s) --- SKIP: TestJumpIfNotEqual/eBPF#01 (0.00s) --- PASS: TestJumpIfNotEqual/kernel#01 (0.07s) --- SKIP: TestJumpIfNotEqual/C#02 (0.04s) --- SKIP: TestJumpIfNotEqual/eBPF#02 (0.00s) --- PASS: TestJumpIfNotEqual/kernel#02 (0.05s) --- SKIP: TestJumpIfNotEqual/C#03 (0.06s) --- SKIP: TestJumpIfNotEqual/eBPF#03 (0.02s) --- PASS: TestJumpIfNotEqual/kernel#03 (0.05s) --- SKIP: TestJumpIfNotEqual/C#04 (0.14s) --- SKIP: TestJumpIfNotEqual/eBPF#04 (0.00s) --- PASS: TestJumpIfNotEqual/kernel#04 (0.00s) --- SKIP: TestJumpIfNotEqual/C#05 (0.10s) --- SKIP: TestJumpIfNotEqual/eBPF#05 (0.00s) --- PASS: TestJumpIfNotEqual/kernel#05 (0.00s) --- SKIP: TestJumpIfNotEqual/C#06 (0.08s) --- SKIP: TestJumpIfNotEqual/eBPF#06 (0.00s) --- PASS: TestJumpIfNotEqual/kernel#06 (0.00s) --- SKIP: TestJumpIfNotEqual/C#07 (0.09s) --- SKIP: TestJumpIfNotEqual/eBPF#07 (0.00s) --- PASS: TestJumpIfNotEqual/kernel#07 (0.00s) === CONT TestZeroInitX === RUN TestZeroInitX/C === RUN TestJumpIfBitsNotSet/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: Mov32Imm dst: r5 imm: 4 4: JSetReg dst: r4 off: -1 src: r5 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestJumpIfBitsNotSet/kernel#02 === RUN TestLoadAbsolute/eBPF#03 === RUN TestJumpIfGreaterThan/C#09 === NAME TestLoadAbsolute/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 4 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemH dst: r4 src: r2 off: 2 imm: 0 6: SwapBE dst: r4 imm: 16 7: JEqImm dst: r4 off: -1 imm: 57007 filter_block_2: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 12: MovImm dst: r4 imm: 0 13: JaImm dst: r0 off: -1 imm: 0 result: 14: MovImm dst: r0 imm: 2 15: JEqImm dst: r4 off: -1 imm: 0 16: MovImm dst: r0 imm: 1 return: 17: Exit === RUN TestLoadAbsolute/kernel#03 === RUN TestLoadConstantA/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: JEqImm dst: r4 off: -1 imm: 1 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestLoadConstantA/kernel === RUN TestLoadConstantA/C#01 === RUN TestPartialZeroInitX/C#01 === RUN TestJumpIfGreaterOrEqual/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: JGEImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfGreaterOrEqual/kernel === RUN TestJumpIfGreaterOrEqual/C#01 === RUN TestLoadIndirect/constant_valid/C#04 === RUN TestJumpIfLessThan/C#07 === RUN TestJumpIfLessOrEqual/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JLEImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfLessOrEqual/kernel#01 === RUN TestZeroInitX/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 0 3: Mov32Reg dst: r4 src: r5 4: Mov32Reg dst: r4 src: r4 5: JaImm dst: r0 off: -1 imm: 0 result: 6: MovImm dst: r0 imm: 2 7: JEqImm dst: r4 off: -1 imm: 0 8: MovImm dst: r0 imm: 1 return: 9: Exit === RUN TestZeroInitX/kernel === RUN TestJumpIfBitsSet/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: Mov32Imm dst: r5 imm: 4 4: JSetReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfBitsSet/kernel#02 === RUN TestJumpIfBitsSet/C#03 === RUN TestLoadAbsolute/C#04 === RUN TestPartialZeroInitX/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 1 4: JGTReg dst: r6 off: -1 src: r3 5: Mov32Imm dst: r5 imm: 0 6: LdXMemB dst: r4 src: r2 off: 0 imm: 0 7: JNEImm dst: r4 off: -1 imm: 3 filter_block_2: 8: Mov32Reg dst: r5 src: r4 filter_block_3: 9: Mov32Reg dst: r4 src: r5 10: Mov32Reg dst: r4 src: r4 11: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 12: MovImm dst: r4 imm: 0 13: JaImm dst: r0 off: -1 imm: 0 result: 14: MovImm dst: r0 imm: 2 15: JEqImm dst: r4 off: -1 imm: 0 16: MovImm dst: r0 imm: 1 return: 17: Exit === RUN TestPartialZeroInitX/kernel#01 --- PASS: TestPartialZeroInitX (0.21s) --- SKIP: TestPartialZeroInitX/C (0.11s) --- SKIP: TestPartialZeroInitX/eBPF (0.00s) --- PASS: TestPartialZeroInitX/kernel (0.05s) --- SKIP: TestPartialZeroInitX/C#01 (0.05s) --- SKIP: TestPartialZeroInitX/eBPF#01 (0.00s) --- PASS: TestPartialZeroInitX/kernel#01 (0.00s) === RUN TestLoadAbsoluteBigOffset/C#03 === RUN TestJumpIfBitsNotSet/C#03 === RUN TestJumpIfGreaterThan/eBPF#09 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JGTImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfGreaterThan/kernel#09 === RUN TestJumpIfBitsSet/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: Mov32Imm dst: r5 imm: 4 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JSetReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfBitsSet/kernel#03 === RUN TestJumpIfBitsSet/C#04 === RUN TestJumpIfGreaterOrEqual/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JGEImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfGreaterOrEqual/kernel#01 === RUN TestJumpIfLessOrEqual/C#02 --- PASS: TestZeroInitX (0.11s) --- SKIP: TestZeroInitX/C (0.06s) --- SKIP: TestZeroInitX/eBPF (0.00s) --- PASS: TestZeroInitX/kernel (0.05s) === RUN TestJumpIfGreaterOrEqual/C#02 === RUN TestLoadConstantA/eBPF#01 === RUN TestJumpIfGreaterThan/C#10 === NAME TestLoadConstantA/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 28 3: JEqImm dst: r4 off: -1 imm: 28 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestLoadConstantA/kernel#01 === RUN TestLoadConstantA/C#02 === RUN TestJumpIfBitsNotSet/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: Mov32Imm dst: r5 imm: 4 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JSetReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfBitsNotSet/kernel#03 === RUN TestJumpIfLessThan/eBPF#07 === RUN TestLoadIndirect/constant_valid/eBPF#04 === NAME TestJumpIfLessThan/eBPF#07 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JLTReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfLessThan/kernel#07 === NAME TestLoadIndirect/constant_valid/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 1 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: 2 7: JGEImm dst: r7 off: -1 imm: 65532 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 4 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemW dst: r4 src: r7 off: 0 imm: 0 13: SwapBE dst: r4 imm: 32 14: Mov32Imm dst: r6 imm: -559038737 15: JEqReg dst: r4 off: -1 src: r6 filter_block_3: 16: Mov32Imm dst: r4 imm: 0 17: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 18: Mov32Imm dst: r4 imm: 1 19: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 20: MovImm dst: r4 imm: 0 21: JaImm dst: r0 off: -1 imm: 0 result: 22: MovImm dst: r0 imm: 2 23: JEqImm dst: r4 off: -1 imm: 0 24: MovImm dst: r0 imm: 1 return: 25: Exit === RUN TestLoadIndirect/constant_valid/kernel#04 === RUN TestLoadIndirect/constant_valid/C#05 === RUN TestLoadAbsoluteBigOffset/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 0 3: JaImm dst: r0 off: -1 imm: 0 result: 4: MovImm dst: r0 imm: 2 5: JEqImm dst: r4 off: -1 imm: 0 6: MovImm dst: r0 imm: 1 return: 7: Exit === RUN TestLoadAbsoluteBigOffset/kernel#03 === RUN TestJumpIfBitsSet/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: JSetImm dst: r4 off: -1 imm: 2 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfBitsSet/kernel#04 === RUN TestJumpIfLessOrEqual/eBPF#02 === RUN TestJumpIfBitsSet/C#05 === NAME TestJumpIfLessOrEqual/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: Mov32Imm dst: r5 imm: 23 4: JLEReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfLessOrEqual/kernel#02 === RUN TestLoadAbsolute/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 6 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemW dst: r4 src: r2 off: 2 imm: 0 6: SwapBE dst: r4 imm: 32 7: Mov32Imm dst: r6 imm: -559038737 8: JEqReg dst: r4 off: -1 src: r6 filter_block_2: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 13: MovImm dst: r4 imm: 0 14: JaImm dst: r0 off: -1 imm: 0 result: 15: MovImm dst: r0 imm: 2 16: JEqImm dst: r4 off: -1 imm: 0 17: MovImm dst: r0 imm: 1 return: 18: Exit === RUN TestLoadAbsolute/kernel#04 === RUN TestLoadAbsolute/C#05 === RUN TestJumpIfGreaterOrEqual/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: Mov32Imm dst: r5 imm: 23 4: JGEReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfGreaterOrEqual/kernel#02 === RUN TestJumpIfGreaterOrEqual/C#03 === RUN TestJumpIfBitsNotSet/C#04 === RUN TestLoadConstantA/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 0 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestLoadConstantA/kernel#02 --- PASS: TestLoadConstantA (0.28s) --- SKIP: TestLoadConstantA/C (0.10s) --- SKIP: TestLoadConstantA/eBPF (0.00s) --- PASS: TestLoadConstantA/kernel (0.00s) --- SKIP: TestLoadConstantA/C#01 (0.10s) --- SKIP: TestLoadConstantA/eBPF#01 (0.00s) --- PASS: TestLoadConstantA/kernel#01 (0.00s) --- SKIP: TestLoadConstantA/C#02 (0.06s) --- SKIP: TestLoadConstantA/eBPF#02 (0.00s) --- PASS: TestLoadConstantA/kernel#02 (0.00s) === RUN TestJumpIfLessThan/C#08 === RUN TestLoadIndirect/constant_valid/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 1 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: 2 7: JGEImm dst: r7 off: -1 imm: 65532 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 4 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemW dst: r4 src: r7 off: 0 imm: 0 13: SwapBE dst: r4 imm: 32 14: Mov32Imm dst: r6 imm: -559038737 15: JEqReg dst: r4 off: -1 src: r6 filter_block_3: 16: Mov32Imm dst: r4 imm: 0 17: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 18: Mov32Imm dst: r4 imm: 1 19: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 20: MovImm dst: r4 imm: 0 21: JaImm dst: r0 off: -1 imm: 0 result: 22: MovImm dst: r0 imm: 2 23: JEqImm dst: r4 off: -1 imm: 0 24: MovImm dst: r0 imm: 1 return: 25: Exit === RUN TestLoadIndirect/constant_valid/kernel#05 === RUN TestJumpIfGreaterThan/eBPF#10 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: Mov32Imm dst: r5 imm: 23 4: JGTReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfGreaterThan/kernel#10 === RUN TestJumpIfBitsSet/eBPF#05 === RUN TestLoadAbsoluteBigOffset/C#04 === RUN TestJumpIfLessOrEqual/C#03 === NAME TestJumpIfBitsSet/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JSetImm dst: r4 off: -1 imm: 2 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfBitsSet/kernel#05 === RUN TestJumpIfBitsSet/C#06 === RUN TestJumpIfGreaterOrEqual/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JGEReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfGreaterOrEqual/kernel#03 === RUN TestJumpIfGreaterOrEqual/C#04 === RUN TestLoadAbsolute/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 6 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemW dst: r4 src: r2 off: 2 imm: 0 6: SwapBE dst: r4 imm: 32 7: Mov32Imm dst: r6 imm: -558907665 8: JEqReg dst: r4 off: -1 src: r6 filter_block_2: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 13: MovImm dst: r4 imm: 0 14: JaImm dst: r0 off: -1 imm: 0 result: 15: MovImm dst: r0 imm: 2 16: JEqImm dst: r4 off: -1 imm: 0 17: MovImm dst: r0 imm: 1 return: 18: Exit === RUN TestLoadAbsolute/kernel#05 === RUN TestJumpIfBitsNotSet/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: JSetImm dst: r4 off: -1 imm: 2 4: JaImm dst: r0 off: -1 imm: 0 filter_block_2: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfBitsNotSet/kernel#04 === RUN TestJumpIfLessOrEqual/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JLEReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfLessOrEqual/kernel#03 === RUN TestJumpIfGreaterThan/C#11 === RUN TestJumpIfGreaterOrEqual/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JGEImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfGreaterOrEqual/kernel#04 === RUN TestJumpIfGreaterOrEqual/C#05 === RUN TestJumpIfLessThan/eBPF#08 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: JLTImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfLessThan/kernel#08 === RUN TestJumpIfLessThan/C#09 === RUN TestLoadIndirect/variable_valid === RUN TestLoadIndirect/variable_valid/C === RUN TestLoadAbsoluteBigOffset/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 65535 4: JGTReg dst: r6 off: -1 src: r3 5: MovReg dst: r6 src: r2 6: AddImm dst: r6 imm: 65531 7: LdXMemW dst: r4 src: r6 off: 0 imm: 0 8: SwapBE dst: r4 imm: 32 9: Add32Imm dst: r4 imm: 2 10: Mov32Reg dst: r4 src: r4 11: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 12: MovImm dst: r4 imm: 0 13: JaImm dst: r0 off: -1 imm: 0 result: 14: MovImm dst: r0 imm: 2 15: JEqImm dst: r4 off: -1 imm: 0 16: MovImm dst: r0 imm: 1 return: 17: Exit === RUN TestLoadAbsoluteBigOffset/kernel#04 === RUN TestJumpIfBitsSet/eBPF#06 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: Mov32Imm dst: r5 imm: 2 4: JSetReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfBitsSet/kernel#06 === RUN TestJumpIfBitsSet/C#07 --- PASS: TestLoadAbsolute (0.65s) --- SKIP: TestLoadAbsolute/C (0.10s) --- SKIP: TestLoadAbsolute/eBPF (0.00s) --- PASS: TestLoadAbsolute/kernel (0.00s) --- SKIP: TestLoadAbsolute/C#01 (0.05s) --- SKIP: TestLoadAbsolute/eBPF#01 (0.00s) --- PASS: TestLoadAbsolute/kernel#01 (0.05s) --- SKIP: TestLoadAbsolute/C#02 (0.09s) --- SKIP: TestLoadAbsolute/eBPF#02 (0.00s) --- PASS: TestLoadAbsolute/kernel#02 (0.00s) --- SKIP: TestLoadAbsolute/C#03 (0.06s) --- SKIP: TestLoadAbsolute/eBPF#03 (0.00s) --- PASS: TestLoadAbsolute/kernel#03 (0.06s) --- SKIP: TestLoadAbsolute/C#04 (0.10s) --- SKIP: TestLoadAbsolute/eBPF#04 (0.00s) --- PASS: TestLoadAbsolute/kernel#04 (0.00s) --- SKIP: TestLoadAbsolute/C#05 (0.08s) --- SKIP: TestLoadAbsolute/eBPF#05 (0.00s) --- PASS: TestLoadAbsolute/kernel#05 (0.05s) === RUN TestJumpIfBitsNotSet/C#05 === RUN TestJumpIfLessOrEqual/C#04 === RUN TestJumpIfGreaterThan/eBPF#11 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JGTReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfGreaterThan/kernel#11 === RUN TestJumpIfGreaterOrEqual/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JGEImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfGreaterOrEqual/kernel#05 === RUN TestJumpIfGreaterOrEqual/C#06 === RUN TestLoadAbsoluteBigOffset/C#05 === RUN TestJumpIfBitsNotSet/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JSetImm dst: r4 off: -1 imm: 2 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfBitsNotSet/kernel#05 === RUN TestJumpIfLessOrEqual/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JLEImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfLessOrEqual/kernel#04 === RUN TestJumpIfLessOrEqual/C#05 === RUN TestJumpIfLessThan/eBPF#09 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JLTImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfLessThan/kernel#09 === RUN TestJumpIfLessThan/C#10 === RUN TestLoadIndirect/variable_valid/eBPF === RUN TestJumpIfBitsSet/eBPF#07 === NAME TestLoadIndirect/variable_valid/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 4 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemW dst: r4 src: r2 off: 0 imm: 0 6: SwapBE dst: r4 imm: 32 7: Mov32Reg dst: r5 src: r4 8: MovReg dst: r7 src: r5 9: LShImm dst: r7 imm: 32 10: ArShImm dst: r7 imm: 32 11: AddImm dst: r7 imm: 13 12: JGEImm dst: r7 off: -1 imm: 65535 13: AddReg dst: r7 src: r2 14: MovReg dst: r6 src: r7 15: AddImm dst: r6 imm: 1 16: JGTReg dst: r6 off: -1 src: r3 17: LdXMemB dst: r4 src: r7 off: 0 imm: 0 18: JEqImm dst: r4 off: -1 imm: 5 filter_block_4: 19: Mov32Imm dst: r4 imm: 0 20: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 21: Mov32Imm dst: r4 imm: 1 22: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 23: MovImm dst: r4 imm: 0 24: JaImm dst: r0 off: -1 imm: 0 result: 25: MovImm dst: r0 imm: 2 26: JEqImm dst: r4 off: -1 imm: 0 27: MovImm dst: r0 imm: 1 return: 28: Exit === RUN TestLoadIndirect/variable_valid/kernel === RUN TestLoadIndirect/variable_valid/C#01 === NAME TestJumpIfBitsSet/eBPF#07 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: Mov32Imm dst: r5 imm: 2 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JSetReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfBitsSet/kernel#07 === RUN TestJumpIfBitsSet/C#08 === RUN TestJumpIfGreaterOrEqual/eBPF#06 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 23 4: JGEReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfGreaterOrEqual/kernel#06 === RUN TestJumpIfLessOrEqual/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JLEImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfLessOrEqual/kernel#05 === RUN TestJumpIfGreaterOrEqual/C#07 === RUN TestJumpIfLessOrEqual/C#06 --- PASS: TestJumpIfGreaterThan (1.38s) --- SKIP: TestJumpIfGreaterThan/C (0.05s) --- SKIP: TestJumpIfGreaterThan/eBPF (0.00s) --- PASS: TestJumpIfGreaterThan/kernel (0.00s) --- SKIP: TestJumpIfGreaterThan/C#01 (0.06s) --- SKIP: TestJumpIfGreaterThan/eBPF#01 (0.00s) --- PASS: TestJumpIfGreaterThan/kernel#01 (0.00s) --- SKIP: TestJumpIfGreaterThan/C#02 (0.09s) --- SKIP: TestJumpIfGreaterThan/eBPF#02 (0.00s) --- PASS: TestJumpIfGreaterThan/kernel#02 (0.00s) --- SKIP: TestJumpIfGreaterThan/C#03 (0.07s) --- SKIP: TestJumpIfGreaterThan/eBPF#03 (0.00s) --- PASS: TestJumpIfGreaterThan/kernel#03 (0.00s) --- SKIP: TestJumpIfGreaterThan/C#04 (0.09s) --- SKIP: TestJumpIfGreaterThan/eBPF#04 (0.00s) --- PASS: TestJumpIfGreaterThan/kernel#04 (0.06s) --- SKIP: TestJumpIfGreaterThan/C#05 (0.07s) --- SKIP: TestJumpIfGreaterThan/eBPF#05 (0.00s) --- PASS: TestJumpIfGreaterThan/kernel#05 (0.05s) --- SKIP: TestJumpIfGreaterThan/C#06 (0.04s) --- SKIP: TestJumpIfGreaterThan/eBPF#06 (0.00s) --- PASS: TestJumpIfGreaterThan/kernel#06 (0.07s) --- SKIP: TestJumpIfGreaterThan/C#07 (0.09s) --- SKIP: TestJumpIfGreaterThan/eBPF#07 (0.00s) --- PASS: TestJumpIfGreaterThan/kernel#07 (0.05s) --- SKIP: TestJumpIfGreaterThan/C#08 (0.09s) --- SKIP: TestJumpIfGreaterThan/eBPF#08 (0.00s) --- PASS: TestJumpIfGreaterThan/kernel#08 (0.06s) --- SKIP: TestJumpIfGreaterThan/C#09 (0.08s) --- SKIP: TestJumpIfGreaterThan/eBPF#09 (0.00s) --- PASS: TestJumpIfGreaterThan/kernel#09 (0.05s) --- SKIP: TestJumpIfGreaterThan/C#10 (0.08s) --- SKIP: TestJumpIfGreaterThan/eBPF#10 (0.00s) --- PASS: TestJumpIfGreaterThan/kernel#10 (0.05s) --- SKIP: TestJumpIfGreaterThan/C#11 (0.05s) --- SKIP: TestJumpIfGreaterThan/eBPF#11 (0.00s) --- PASS: TestJumpIfGreaterThan/kernel#11 (0.07s) === RUN TestLoadAbsoluteBigOffset/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 0 3: JaImm dst: r0 off: -1 imm: 0 result: 4: MovImm dst: r0 imm: 2 5: JEqImm dst: r4 off: -1 imm: 0 6: MovImm dst: r0 imm: 1 return: 7: Exit === RUN TestLoadAbsoluteBigOffset/kernel#05 === RUN TestJumpIfBitsNotSet/C#06 === RUN TestJumpIfLessThan/eBPF#10 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: Mov32Imm dst: r5 imm: 23 4: JLTReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfLessThan/kernel#10 === RUN TestJumpIfLessThan/C#11 === RUN TestJumpIfBitsSet/eBPF#08 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: JSetImm dst: r4 off: -1 imm: 8 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfBitsSet/kernel#08 === RUN TestJumpIfBitsNotSet/eBPF#06 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: Mov32Imm dst: r5 imm: 2 4: JSetReg dst: r4 off: -1 src: r5 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestJumpIfBitsNotSet/kernel#06 === RUN TestJumpIfGreaterOrEqual/eBPF#07 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JGEReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestLoadAbsoluteBigOffset/C#06 === RUN TestJumpIfGreaterOrEqual/kernel#07 === RUN TestJumpIfGreaterOrEqual/C#08 === RUN TestJumpIfLessOrEqual/eBPF#06 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 23 4: JLEReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfLessOrEqual/kernel#06 === RUN TestJumpIfLessOrEqual/C#07 === RUN TestLoadIndirect/variable_valid/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 4 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemW dst: r4 src: r2 off: 0 imm: 0 6: SwapBE dst: r4 imm: 32 7: Mov32Reg dst: r5 src: r4 8: MovReg dst: r7 src: r5 9: LShImm dst: r7 imm: 32 10: ArShImm dst: r7 imm: 32 11: AddImm dst: r7 imm: 13 12: JGEImm dst: r7 off: -1 imm: 65535 13: AddReg dst: r7 src: r2 14: MovReg dst: r6 src: r7 15: AddImm dst: r6 imm: 1 16: JGTReg dst: r6 off: -1 src: r3 17: LdXMemB dst: r4 src: r7 off: 0 imm: 0 18: JEqImm dst: r4 off: -1 imm: 6 filter_block_4: 19: Mov32Imm dst: r4 imm: 0 20: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 21: Mov32Imm dst: r4 imm: 1 22: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 23: MovImm dst: r4 imm: 0 24: JaImm dst: r0 off: -1 imm: 0 result: 25: MovImm dst: r0 imm: 2 26: JEqImm dst: r4 off: -1 imm: 0 27: MovImm dst: r0 imm: 1 return: 28: Exit === RUN TestLoadIndirect/variable_valid/kernel#01 === RUN TestJumpIfLessThan/eBPF#11 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JLTReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfLessThan/kernel#11 --- PASS: TestJumpIfLessThan (1.45s) --- SKIP: TestJumpIfLessThan/C (0.06s) --- SKIP: TestJumpIfLessThan/eBPF (0.00s) --- PASS: TestJumpIfLessThan/kernel (0.07s) --- SKIP: TestJumpIfLessThan/C#01 (0.11s) --- SKIP: TestJumpIfLessThan/eBPF#01 (0.00s) --- PASS: TestJumpIfLessThan/kernel#01 (0.05s) --- SKIP: TestJumpIfLessThan/C#02 (0.06s) --- SKIP: TestJumpIfLessThan/eBPF#02 (0.00s) --- PASS: TestJumpIfLessThan/kernel#02 (0.07s) --- SKIP: TestJumpIfLessThan/C#03 (0.08s) --- SKIP: TestJumpIfLessThan/eBPF#03 (0.00s) --- PASS: TestJumpIfLessThan/kernel#03 (0.05s) --- SKIP: TestJumpIfLessThan/C#04 (0.10s) --- SKIP: TestJumpIfLessThan/eBPF#04 (0.00s) --- PASS: TestJumpIfLessThan/kernel#04 (0.05s) --- SKIP: TestJumpIfLessThan/C#05 (0.09s) --- SKIP: TestJumpIfLessThan/eBPF#05 (0.00s) --- PASS: TestJumpIfLessThan/kernel#05 (0.05s) --- SKIP: TestJumpIfLessThan/C#06 (0.08s) --- SKIP: TestJumpIfLessThan/eBPF#06 (0.00s) --- PASS: TestJumpIfLessThan/kernel#06 (0.06s) --- SKIP: TestJumpIfLessThan/C#07 (0.09s) --- SKIP: TestJumpIfLessThan/eBPF#07 (0.00s) --- PASS: TestJumpIfLessThan/kernel#07 (0.05s) --- SKIP: TestJumpIfLessThan/C#08 (0.08s) --- SKIP: TestJumpIfLessThan/eBPF#08 (0.00s) --- PASS: TestJumpIfLessThan/kernel#08 (0.00s) --- SKIP: TestJumpIfLessThan/C#09 (0.07s) --- SKIP: TestJumpIfLessThan/eBPF#09 (0.00s) --- PASS: TestJumpIfLessThan/kernel#09 (0.00s) --- SKIP: TestJumpIfLessThan/C#10 (0.05s) --- SKIP: TestJumpIfLessThan/eBPF#10 (0.00s) --- PASS: TestJumpIfLessThan/kernel#10 (0.00s) --- SKIP: TestJumpIfLessThan/C#11 (0.05s) --- SKIP: TestJumpIfLessThan/eBPF#11 (0.00s) --- PASS: TestJumpIfLessThan/kernel#11 (0.00s) === RUN TestJumpIfBitsSet/C#09 === RUN TestJumpIfGreaterOrEqual/eBPF#08 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: JGEImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfGreaterOrEqual/kernel#08 === RUN TestLoadAbsoluteBigOffset/eBPF#06 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 65535 4: JGTReg dst: r6 off: -1 src: r3 5: Mov32Imm dst: r4 imm: 0 6: MovReg dst: r6 src: r2 7: AddImm dst: r6 imm: 65534 8: LdXMemB dst: r5 src: r6 off: 0 imm: 0 9: And32Imm dst: r5 imm: 15 10: LSh32Imm dst: r5 imm: 2 11: Add32Imm dst: r4 imm: 2 12: Mov32Reg dst: r4 src: r4 13: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 14: MovImm dst: r4 imm: 0 15: JaImm dst: r0 off: -1 imm: 0 result: 16: MovImm dst: r0 imm: 2 17: JEqImm dst: r4 off: -1 imm: 0 18: MovImm dst: r0 imm: 1 return: 19: Exit === RUN TestLoadAbsoluteBigOffset/kernel#06 === RUN TestJumpIfLessOrEqual/eBPF#07 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JLEReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfLessOrEqual/kernel#07 === RUN TestJumpIfLessOrEqual/C#08 === RUN TestJumpIfBitsNotSet/C#07 === RUN TestLoadIndirect/variable_valid/C#02 === RUN TestJumpIfLessOrEqual/eBPF#08 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: JLEImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfLessOrEqual/kernel#08 === RUN TestJumpIfLessOrEqual/C#09 === RUN TestJumpIfGreaterOrEqual/C#09 === RUN TestJumpIfBitsSet/eBPF#09 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JSetImm dst: r4 off: -1 imm: 8 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfBitsSet/kernel#09 === RUN TestLoadAbsoluteBigOffset/C#07 === RUN TestLoadIndirect/variable_valid/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 4 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemW dst: r4 src: r2 off: 0 imm: 0 6: SwapBE dst: r4 imm: 32 7: Mov32Reg dst: r5 src: r4 8: MovReg dst: r7 src: r5 9: LShImm dst: r7 imm: 32 10: ArShImm dst: r7 imm: 32 11: AddImm dst: r7 imm: -2147483641 12: JGEImm dst: r7 off: -1 imm: 65534 13: AddReg dst: r7 src: r2 14: MovReg dst: r6 src: r7 15: AddImm dst: r6 imm: 2 16: JGTReg dst: r6 off: -1 src: r3 17: LdXMemH dst: r4 src: r7 off: 0 imm: 0 18: SwapBE dst: r4 imm: 16 19: JEqImm dst: r4 off: -1 imm: 57005 filter_block_4: 20: Mov32Imm dst: r4 imm: 0 21: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 22: Mov32Imm dst: r4 imm: 1 23: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 24: MovImm dst: r4 imm: 0 25: JaImm dst: r0 off: -1 imm: 0 result: 26: MovImm dst: r0 imm: 2 27: JEqImm dst: r4 off: -1 imm: 0 28: MovImm dst: r0 imm: 1 return: 29: Exit === RUN TestLoadIndirect/variable_valid/kernel#02 === RUN TestLoadIndirect/variable_valid/C#03 === RUN TestJumpIfBitsNotSet/eBPF#07 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: Mov32Imm dst: r5 imm: 2 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JSetReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfBitsNotSet/kernel#07 === RUN TestJumpIfLessOrEqual/eBPF#09 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JLEImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfLessOrEqual/kernel#09 === RUN TestJumpIfLessOrEqual/C#10 === RUN TestJumpIfBitsSet/C#10 === RUN TestLoadAbsoluteBigOffset/eBPF#07 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 0 3: JaImm dst: r0 off: -1 imm: 0 result: 4: MovImm dst: r0 imm: 2 5: JEqImm dst: r4 off: -1 imm: 0 6: MovImm dst: r0 imm: 1 return: 7: Exit === RUN TestLoadAbsoluteBigOffset/kernel#07 === RUN TestLoadIndirect/variable_valid/eBPF#03 === RUN TestJumpIfGreaterOrEqual/eBPF#09 === NAME TestLoadIndirect/variable_valid/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 4 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemW dst: r4 src: r2 off: 0 imm: 0 6: SwapBE dst: r4 imm: 32 7: Mov32Reg dst: r5 src: r4 8: MovReg dst: r7 src: r5 9: LShImm dst: r7 imm: 32 10: ArShImm dst: r7 imm: 32 11: AddImm dst: r7 imm: -2147483641 12: JGEImm dst: r7 off: -1 imm: 65534 13: AddReg dst: r7 src: r2 14: MovReg dst: r6 src: r7 15: AddImm dst: r6 imm: 2 16: JGTReg dst: r6 off: -1 src: r3 17: LdXMemH dst: r4 src: r7 off: 0 imm: 0 18: SwapBE dst: r4 imm: 16 19: JEqImm dst: r4 off: -1 imm: 57005 filter_block_4: 20: Mov32Imm dst: r4 imm: 0 21: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 22: Mov32Imm dst: r4 imm: 1 23: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 24: MovImm dst: r4 imm: 0 25: JaImm dst: r0 off: -1 imm: 0 result: 26: MovImm dst: r0 imm: 2 27: JEqImm dst: r4 off: -1 imm: 0 28: MovImm dst: r0 imm: 1 return: 29: Exit === RUN TestLoadIndirect/variable_valid/kernel#03 === NAME TestJumpIfGreaterOrEqual/eBPF#09 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JGEImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfGreaterOrEqual/kernel#09 === RUN TestJumpIfBitsNotSet/C#08 === RUN TestJumpIfLessOrEqual/eBPF#10 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: Mov32Imm dst: r5 imm: 23 4: JLEReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfLessOrEqual/kernel#10 === RUN TestJumpIfLessOrEqual/C#11 === RUN TestJumpIfBitsSet/eBPF#10 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: Mov32Imm dst: r5 imm: 8 4: JSetReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfBitsSet/kernel#10 === RUN TestJumpIfBitsNotSet/eBPF#08 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: JSetImm dst: r4 off: -1 imm: 8 4: JaImm dst: r0 off: -1 imm: 0 filter_block_2: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfBitsNotSet/kernel#08 === RUN TestJumpIfBitsNotSet/C#09 === RUN TestJumpIfLessOrEqual/eBPF#11 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JLEReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit --- PASS: TestLoadAbsoluteBigOffset (1.00s) --- SKIP: TestLoadAbsoluteBigOffset/C (0.10s) --- SKIP: TestLoadAbsoluteBigOffset/eBPF (0.00s) --- PASS: TestLoadAbsoluteBigOffset/kernel (0.05s) --- SKIP: TestLoadAbsoluteBigOffset/C#01 (0.06s) --- SKIP: TestLoadAbsoluteBigOffset/eBPF#01 (0.00s) --- PASS: TestLoadAbsoluteBigOffset/kernel#01 (0.05s) --- SKIP: TestLoadAbsoluteBigOffset/C#02 (0.08s) --- SKIP: TestLoadAbsoluteBigOffset/eBPF#02 (0.00s) --- PASS: TestLoadAbsoluteBigOffset/kernel#02 (0.07s) --- SKIP: TestLoadAbsoluteBigOffset/C#03 (0.08s) --- SKIP: TestLoadAbsoluteBigOffset/eBPF#03 (0.00s) --- PASS: TestLoadAbsoluteBigOffset/kernel#03 (0.07s) --- SKIP: TestLoadAbsoluteBigOffset/C#04 (0.07s) --- SKIP: TestLoadAbsoluteBigOffset/eBPF#04 (0.00s) --- PASS: TestLoadAbsoluteBigOffset/kernel#04 (0.05s) --- SKIP: TestLoadAbsoluteBigOffset/C#05 (0.05s) --- SKIP: TestLoadAbsoluteBigOffset/eBPF#05 (0.00s) --- PASS: TestLoadAbsoluteBigOffset/kernel#05 (0.05s) --- SKIP: TestLoadAbsoluteBigOffset/C#06 (0.03s) --- SKIP: TestLoadAbsoluteBigOffset/eBPF#06 (0.00s) --- PASS: TestLoadAbsoluteBigOffset/kernel#06 (0.05s) --- SKIP: TestLoadAbsoluteBigOffset/C#07 (0.06s) --- SKIP: TestLoadAbsoluteBigOffset/eBPF#07 (0.00s) --- PASS: TestLoadAbsoluteBigOffset/kernel#07 (0.05s) === RUN TestJumpIfLessOrEqual/kernel#11 --- PASS: TestJumpIfLessOrEqual (0.85s) --- SKIP: TestJumpIfLessOrEqual/C (0.12s) --- SKIP: TestJumpIfLessOrEqual/eBPF (0.00s) --- PASS: TestJumpIfLessOrEqual/kernel (0.05s) --- SKIP: TestJumpIfLessOrEqual/C#01 (0.09s) --- SKIP: TestJumpIfLessOrEqual/eBPF#01 (0.00s) --- PASS: TestJumpIfLessOrEqual/kernel#01 (0.05s) --- SKIP: TestJumpIfLessOrEqual/C#02 (0.06s) --- SKIP: TestJumpIfLessOrEqual/eBPF#02 (0.00s) --- PASS: TestJumpIfLessOrEqual/kernel#02 (0.05s) --- SKIP: TestJumpIfLessOrEqual/C#03 (0.04s) --- SKIP: TestJumpIfLessOrEqual/eBPF#03 (0.00s) --- PASS: TestJumpIfLessOrEqual/kernel#03 (0.05s) --- SKIP: TestJumpIfLessOrEqual/C#04 (0.04s) --- SKIP: TestJumpIfLessOrEqual/eBPF#04 (0.00s) --- PASS: TestJumpIfLessOrEqual/kernel#04 (0.00s) --- SKIP: TestJumpIfLessOrEqual/C#05 (0.04s) --- SKIP: TestJumpIfLessOrEqual/eBPF#05 (0.00s) --- PASS: TestJumpIfLessOrEqual/kernel#05 (0.00s) --- SKIP: TestJumpIfLessOrEqual/C#06 (0.05s) --- SKIP: TestJumpIfLessOrEqual/eBPF#06 (0.00s) --- PASS: TestJumpIfLessOrEqual/kernel#06 (0.00s) --- SKIP: TestJumpIfLessOrEqual/C#07 (0.04s) --- SKIP: TestJumpIfLessOrEqual/eBPF#07 (0.00s) --- PASS: TestJumpIfLessOrEqual/kernel#07 (0.00s) --- SKIP: TestJumpIfLessOrEqual/C#08 (0.03s) --- SKIP: TestJumpIfLessOrEqual/eBPF#08 (0.00s) --- PASS: TestJumpIfLessOrEqual/kernel#08 (0.00s) --- SKIP: TestJumpIfLessOrEqual/C#09 (0.06s) --- SKIP: TestJumpIfLessOrEqual/eBPF#09 (0.00s) --- PASS: TestJumpIfLessOrEqual/kernel#09 (0.00s) --- SKIP: TestJumpIfLessOrEqual/C#10 (0.04s) --- SKIP: TestJumpIfLessOrEqual/eBPF#10 (0.00s) --- PASS: TestJumpIfLessOrEqual/kernel#10 (0.00s) --- SKIP: TestJumpIfLessOrEqual/C#11 (0.03s) --- SKIP: TestJumpIfLessOrEqual/eBPF#11 (0.00s) --- PASS: TestJumpIfLessOrEqual/kernel#11 (0.00s) === RUN TestJumpIfGreaterOrEqual/C#10 === RUN TestLoadIndirect/variable_valid/C#04 === RUN TestJumpIfBitsNotSet/eBPF#09 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JSetImm dst: r4 off: -1 imm: 8 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfBitsNotSet/kernel#09 === RUN TestJumpIfBitsNotSet/C#10 === RUN TestJumpIfBitsSet/C#11 === RUN TestLoadIndirect/variable_valid/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 4 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemW dst: r4 src: r2 off: 0 imm: 0 6: SwapBE dst: r4 imm: 32 7: Mov32Reg dst: r5 src: r4 8: MovReg dst: r7 src: r5 9: LShImm dst: r7 imm: 32 10: ArShImm dst: r7 imm: 32 11: AddImm dst: r7 imm: 4 12: JGEImm dst: r7 off: -1 imm: 65532 13: AddReg dst: r7 src: r2 14: MovReg dst: r6 src: r7 15: AddImm dst: r6 imm: 4 16: JGTReg dst: r6 off: -1 src: r3 17: LdXMemW dst: r4 src: r7 off: 0 imm: 0 18: SwapBE dst: r4 imm: 32 19: Mov32Imm dst: r6 imm: -559038737 20: JEqReg dst: r4 off: -1 src: r6 filter_block_4: 21: Mov32Imm dst: r4 imm: 0 22: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 23: Mov32Imm dst: r4 imm: 1 24: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 25: MovImm dst: r4 imm: 0 26: JaImm dst: r0 off: -1 imm: 0 result: 27: MovImm dst: r0 imm: 2 28: JEqImm dst: r4 off: -1 imm: 0 29: MovImm dst: r0 imm: 1 return: 30: Exit === RUN TestLoadIndirect/variable_valid/kernel#04 === RUN TestLoadIndirect/variable_valid/C#05 === RUN TestJumpIfGreaterOrEqual/eBPF#10 === RUN TestJumpIfBitsNotSet/eBPF#10 === NAME TestJumpIfGreaterOrEqual/eBPF#10 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: Mov32Imm dst: r5 imm: 23 4: JGEReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfGreaterOrEqual/kernel#10 === NAME TestJumpIfBitsNotSet/eBPF#10 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: Mov32Imm dst: r5 imm: 8 4: JSetReg dst: r4 off: -1 src: r5 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestJumpIfBitsNotSet/kernel#10 === RUN TestJumpIfBitsNotSet/C#11 === RUN TestJumpIfBitsSet/eBPF#11 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: Mov32Imm dst: r5 imm: 8 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JSetReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfBitsSet/kernel#11 === RUN TestLoadIndirect/variable_valid/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 4 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemW dst: r4 src: r2 off: 0 imm: 0 6: SwapBE dst: r4 imm: 32 7: Mov32Reg dst: r5 src: r4 8: MovReg dst: r7 src: r5 9: LShImm dst: r7 imm: 32 10: ArShImm dst: r7 imm: 32 11: AddImm dst: r7 imm: 4 12: JGEImm dst: r7 off: -1 imm: 65532 13: AddReg dst: r7 src: r2 14: MovReg dst: r6 src: r7 15: AddImm dst: r6 imm: 4 16: JGTReg dst: r6 off: -1 src: r3 17: LdXMemW dst: r4 src: r7 off: 0 imm: 0 18: SwapBE dst: r4 imm: 32 19: Mov32Imm dst: r6 imm: -559038737 20: JEqReg dst: r4 off: -1 src: r6 filter_block_4: 21: Mov32Imm dst: r4 imm: 0 22: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 23: Mov32Imm dst: r4 imm: 1 24: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 25: MovImm dst: r4 imm: 0 26: JaImm dst: r0 off: -1 imm: 0 result: 27: MovImm dst: r0 imm: 2 28: JEqImm dst: r4 off: -1 imm: 0 29: MovImm dst: r0 imm: 1 return: 30: Exit === RUN TestLoadIndirect/variable_valid/kernel#05 === RUN TestJumpIfBitsNotSet/eBPF#11 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: Mov32Imm dst: r5 imm: 8 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JSetReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfBitsNotSet/kernel#11 --- PASS: TestJumpIfBitsNotSet (1.07s) --- SKIP: TestJumpIfBitsNotSet/C (0.04s) --- SKIP: TestJumpIfBitsNotSet/eBPF (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel (0.05s) --- SKIP: TestJumpIfBitsNotSet/C#01 (0.09s) --- SKIP: TestJumpIfBitsNotSet/eBPF#01 (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel#01 (0.05s) --- SKIP: TestJumpIfBitsNotSet/C#02 (0.09s) --- SKIP: TestJumpIfBitsNotSet/eBPF#02 (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel#02 (0.07s) --- SKIP: TestJumpIfBitsNotSet/C#03 (0.07s) --- SKIP: TestJumpIfBitsNotSet/eBPF#03 (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel#03 (0.05s) --- SKIP: TestJumpIfBitsNotSet/C#04 (0.06s) --- SKIP: TestJumpIfBitsNotSet/eBPF#04 (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel#04 (0.05s) --- SKIP: TestJumpIfBitsNotSet/C#05 (0.05s) --- SKIP: TestJumpIfBitsNotSet/eBPF#05 (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel#05 (0.05s) --- SKIP: TestJumpIfBitsNotSet/C#06 (0.04s) --- SKIP: TestJumpIfBitsNotSet/eBPF#06 (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel#06 (0.05s) --- SKIP: TestJumpIfBitsNotSet/C#07 (0.06s) --- SKIP: TestJumpIfBitsNotSet/eBPF#07 (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel#07 (0.05s) --- SKIP: TestJumpIfBitsNotSet/C#08 (0.03s) --- SKIP: TestJumpIfBitsNotSet/eBPF#08 (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel#08 (0.00s) --- SKIP: TestJumpIfBitsNotSet/C#09 (0.04s) --- SKIP: TestJumpIfBitsNotSet/eBPF#09 (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel#09 (0.00s) --- SKIP: TestJumpIfBitsNotSet/C#10 (0.04s) --- SKIP: TestJumpIfBitsNotSet/eBPF#10 (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel#10 (0.00s) --- SKIP: TestJumpIfBitsNotSet/C#11 (0.03s) --- SKIP: TestJumpIfBitsNotSet/eBPF#11 (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel#11 (0.00s) === RUN TestJumpIfGreaterOrEqual/C#11 --- PASS: TestJumpIfBitsSet (0.93s) --- SKIP: TestJumpIfBitsSet/C (0.06s) --- SKIP: TestJumpIfBitsSet/eBPF (0.00s) --- PASS: TestJumpIfBitsSet/kernel (0.00s) --- SKIP: TestJumpIfBitsSet/C#01 (0.07s) --- SKIP: TestJumpIfBitsSet/eBPF#01 (0.00s) --- PASS: TestJumpIfBitsSet/kernel#01 (0.00s) --- SKIP: TestJumpIfBitsSet/C#02 (0.09s) --- SKIP: TestJumpIfBitsSet/eBPF#02 (0.00s) --- PASS: TestJumpIfBitsSet/kernel#02 (0.00s) --- SKIP: TestJumpIfBitsSet/C#03 (0.04s) --- SKIP: TestJumpIfBitsSet/eBPF#03 (0.00s) --- PASS: TestJumpIfBitsSet/kernel#03 (0.00s) --- SKIP: TestJumpIfBitsSet/C#04 (0.06s) --- SKIP: TestJumpIfBitsSet/eBPF#04 (0.00s) --- PASS: TestJumpIfBitsSet/kernel#04 (0.00s) --- SKIP: TestJumpIfBitsSet/C#05 (0.05s) --- SKIP: TestJumpIfBitsSet/eBPF#05 (0.00s) --- PASS: TestJumpIfBitsSet/kernel#05 (0.00s) --- SKIP: TestJumpIfBitsSet/C#06 (0.06s) --- SKIP: TestJumpIfBitsSet/eBPF#06 (0.00s) --- PASS: TestJumpIfBitsSet/kernel#06 (0.00s) --- SKIP: TestJumpIfBitsSet/C#07 (0.07s) --- SKIP: TestJumpIfBitsSet/eBPF#07 (0.00s) --- PASS: TestJumpIfBitsSet/kernel#07 (0.00s) --- SKIP: TestJumpIfBitsSet/C#08 (0.04s) --- SKIP: TestJumpIfBitsSet/eBPF#08 (0.00s) --- PASS: TestJumpIfBitsSet/kernel#08 (0.05s) --- SKIP: TestJumpIfBitsSet/C#09 (0.06s) --- SKIP: TestJumpIfBitsSet/eBPF#09 (0.00s) --- PASS: TestJumpIfBitsSet/kernel#09 (0.05s) --- SKIP: TestJumpIfBitsSet/C#10 (0.04s) --- SKIP: TestJumpIfBitsSet/eBPF#10 (0.00s) --- PASS: TestJumpIfBitsSet/kernel#10 (0.05s) --- SKIP: TestJumpIfBitsSet/C#11 (0.03s) --- SKIP: TestJumpIfBitsSet/eBPF#11 (0.00s) --- PASS: TestJumpIfBitsSet/kernel#11 (0.05s) === RUN TestLoadIndirect/constant_outofbounds === RUN TestLoadIndirect/constant_outofbounds/C === RUN TestJumpIfGreaterOrEqual/eBPF#11 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JGEReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfGreaterOrEqual/kernel#11 === RUN TestLoadIndirect/constant_outofbounds/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: -3 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: 3 7: JGEImm dst: r7 off: -1 imm: 65535 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 1 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemB dst: r4 src: r7 off: 0 imm: 0 13: Mov32Imm dst: r4 imm: 1 14: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 15: MovImm dst: r4 imm: 0 16: JaImm dst: r0 off: -1 imm: 0 result: 17: MovImm dst: r0 imm: 2 18: JEqImm dst: r4 off: -1 imm: 0 19: MovImm dst: r0 imm: 1 return: 20: Exit === RUN TestLoadIndirect/constant_outofbounds/kernel === RUN TestLoadIndirect/constant_outofbounds/C#01 --- PASS: TestJumpIfGreaterOrEqual (0.88s) --- SKIP: TestJumpIfGreaterOrEqual/C (0.06s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF (0.00s) --- PASS: TestJumpIfGreaterOrEqual/kernel (0.00s) --- SKIP: TestJumpIfGreaterOrEqual/C#01 (0.07s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF#01 (0.01s) --- PASS: TestJumpIfGreaterOrEqual/kernel#01 (0.00s) --- SKIP: TestJumpIfGreaterOrEqual/C#02 (0.07s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF#02 (0.00s) --- PASS: TestJumpIfGreaterOrEqual/kernel#02 (0.00s) --- SKIP: TestJumpIfGreaterOrEqual/C#03 (0.06s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF#03 (0.00s) --- PASS: TestJumpIfGreaterOrEqual/kernel#03 (0.00s) --- SKIP: TestJumpIfGreaterOrEqual/C#04 (0.04s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF#04 (0.00s) --- PASS: TestJumpIfGreaterOrEqual/kernel#04 (0.00s) --- SKIP: TestJumpIfGreaterOrEqual/C#05 (0.06s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF#05 (0.00s) --- PASS: TestJumpIfGreaterOrEqual/kernel#05 (0.00s) --- SKIP: TestJumpIfGreaterOrEqual/C#06 (0.03s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF#06 (0.00s) --- PASS: TestJumpIfGreaterOrEqual/kernel#06 (0.00s) --- SKIP: TestJumpIfGreaterOrEqual/C#07 (0.05s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF#07 (0.00s) --- PASS: TestJumpIfGreaterOrEqual/kernel#07 (0.00s) --- SKIP: TestJumpIfGreaterOrEqual/C#08 (0.03s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF#08 (0.00s) --- PASS: TestJumpIfGreaterOrEqual/kernel#08 (0.05s) --- SKIP: TestJumpIfGreaterOrEqual/C#09 (0.07s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF#09 (0.00s) --- PASS: TestJumpIfGreaterOrEqual/kernel#09 (0.05s) --- SKIP: TestJumpIfGreaterOrEqual/C#10 (0.06s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF#10 (0.00s) --- PASS: TestJumpIfGreaterOrEqual/kernel#10 (0.05s) --- SKIP: TestJumpIfGreaterOrEqual/C#11 (0.03s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF#11 (0.00s) --- PASS: TestJumpIfGreaterOrEqual/kernel#11 (0.05s) === RUN TestLoadIndirect/constant_outofbounds/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: -16 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: 15 7: JGEImm dst: r7 off: -1 imm: 65535 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 1 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemB dst: r4 src: r7 off: 0 imm: 0 13: Mov32Imm dst: r4 imm: 1 14: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 15: MovImm dst: r4 imm: 0 16: JaImm dst: r0 off: -1 imm: 0 result: 17: MovImm dst: r0 imm: 2 18: JEqImm dst: r4 off: -1 imm: 0 19: MovImm dst: r0 imm: 1 return: 20: Exit === RUN TestLoadIndirect/constant_outofbounds/kernel#01 === RUN TestLoadIndirect/constant_outofbounds/C#02 === RUN TestLoadIndirect/constant_outofbounds/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: -1 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: -2 7: JGEImm dst: r7 off: -1 imm: 65532 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 4 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemW dst: r4 src: r7 off: 0 imm: 0 13: SwapBE dst: r4 imm: 32 14: Mov32Imm dst: r4 imm: 1 15: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 16: MovImm dst: r4 imm: 0 17: JaImm dst: r0 off: -1 imm: 0 result: 18: MovImm dst: r0 imm: 2 19: JEqImm dst: r4 off: -1 imm: 0 20: MovImm dst: r0 imm: 1 return: 21: Exit === RUN TestLoadIndirect/constant_outofbounds/kernel#02 === RUN TestLoadIndirect/constant_outofbounds/C#03 === RUN TestLoadIndirect/constant_outofbounds/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 255 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: -300 7: JGEImm dst: r7 off: -1 imm: 65534 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 2 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemH dst: r4 src: r7 off: 0 imm: 0 13: SwapBE dst: r4 imm: 16 14: Mov32Imm dst: r4 imm: 1 15: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 16: MovImm dst: r4 imm: 0 17: JaImm dst: r0 off: -1 imm: 0 result: 18: MovImm dst: r0 imm: 2 19: JEqImm dst: r4 off: -1 imm: 0 20: MovImm dst: r0 imm: 1 return: 21: Exit === RUN TestLoadIndirect/constant_outofbounds/kernel#03 === RUN TestLoadIndirect/constant_outofbounds/C#04 === RUN TestLoadIndirect/constant_outofbounds/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: -16 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: 30 7: JGEImm dst: r7 off: -1 imm: 65535 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 1 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemB dst: r4 src: r7 off: 0 imm: 0 13: Mov32Imm dst: r4 imm: 1 14: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 15: MovImm dst: r4 imm: 0 16: JaImm dst: r0 off: -1 imm: 0 result: 17: MovImm dst: r0 imm: 2 18: JEqImm dst: r4 off: -1 imm: 0 19: MovImm dst: r0 imm: 1 return: 20: Exit === RUN TestLoadIndirect/constant_outofbounds/kernel#04 === RUN TestLoadIndirect/variable_outofbounds === RUN TestLoadIndirect/variable_outofbounds/C === RUN TestLoadIndirect/variable_outofbounds/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 4 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemW dst: r4 src: r2 off: 0 imm: 0 6: SwapBE dst: r4 imm: 32 7: Mov32Reg dst: r5 src: r4 8: MovReg dst: r7 src: r5 9: LShImm dst: r7 imm: 32 10: ArShImm dst: r7 imm: 32 11: AddImm dst: r7 imm: 3 12: JGEImm dst: r7 off: -1 imm: 65535 13: AddReg dst: r7 src: r2 14: MovReg dst: r6 src: r7 15: AddImm dst: r6 imm: 1 16: JGTReg dst: r6 off: -1 src: r3 17: LdXMemB dst: r4 src: r7 off: 0 imm: 0 18: Mov32Imm dst: r4 imm: 1 19: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 20: MovImm dst: r4 imm: 0 21: JaImm dst: r0 off: -1 imm: 0 result: 22: MovImm dst: r0 imm: 2 23: JEqImm dst: r4 off: -1 imm: 0 24: MovImm dst: r0 imm: 1 return: 25: Exit === RUN TestLoadIndirect/variable_outofbounds/kernel === RUN TestLoadIndirect/variable_outofbounds/C#01 === RUN TestLoadIndirect/variable_outofbounds/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 4 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemW dst: r4 src: r2 off: 0 imm: 0 6: SwapBE dst: r4 imm: 32 7: Mov32Reg dst: r5 src: r4 8: MovReg dst: r7 src: r5 9: LShImm dst: r7 imm: 32 10: ArShImm dst: r7 imm: 32 11: AddImm dst: r7 imm: 15 12: JGEImm dst: r7 off: -1 imm: 65535 13: AddReg dst: r7 src: r2 14: MovReg dst: r6 src: r7 15: AddImm dst: r6 imm: 1 16: JGTReg dst: r6 off: -1 src: r3 17: LdXMemB dst: r4 src: r7 off: 0 imm: 0 18: Mov32Imm dst: r4 imm: 1 19: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 20: MovImm dst: r4 imm: 0 21: JaImm dst: r0 off: -1 imm: 0 result: 22: MovImm dst: r0 imm: 2 23: JEqImm dst: r4 off: -1 imm: 0 24: MovImm dst: r0 imm: 1 return: 25: Exit === RUN TestLoadIndirect/variable_outofbounds/kernel#01 === RUN TestLoadIndirect/variable_outofbounds/C#02 === RUN TestLoadIndirect/variable_outofbounds/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 4 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemW dst: r4 src: r2 off: 0 imm: 0 6: SwapBE dst: r4 imm: 32 7: Mov32Reg dst: r5 src: r4 8: MovReg dst: r7 src: r5 9: LShImm dst: r7 imm: 32 10: ArShImm dst: r7 imm: 32 11: AddImm dst: r7 imm: -2 12: JGEImm dst: r7 off: -1 imm: 65532 13: AddReg dst: r7 src: r2 14: MovReg dst: r6 src: r7 15: AddImm dst: r6 imm: 4 16: JGTReg dst: r6 off: -1 src: r3 17: LdXMemW dst: r4 src: r7 off: 0 imm: 0 18: SwapBE dst: r4 imm: 32 19: Mov32Imm dst: r4 imm: 1 20: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 21: MovImm dst: r4 imm: 0 22: JaImm dst: r0 off: -1 imm: 0 result: 23: MovImm dst: r0 imm: 2 24: JEqImm dst: r4 off: -1 imm: 0 25: MovImm dst: r0 imm: 1 return: 26: Exit === RUN TestLoadIndirect/variable_outofbounds/kernel#02 === RUN TestLoadIndirect/variable_outofbounds/C#03 === RUN TestLoadIndirect/variable_outofbounds/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 4 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemW dst: r4 src: r2 off: 0 imm: 0 6: SwapBE dst: r4 imm: 32 7: Mov32Reg dst: r5 src: r4 8: MovReg dst: r7 src: r5 9: LShImm dst: r7 imm: 32 10: ArShImm dst: r7 imm: 32 11: AddImm dst: r7 imm: -300 12: JGEImm dst: r7 off: -1 imm: 65534 13: AddReg dst: r7 src: r2 14: MovReg dst: r6 src: r7 15: AddImm dst: r6 imm: 2 16: JGTReg dst: r6 off: -1 src: r3 17: LdXMemH dst: r4 src: r7 off: 0 imm: 0 18: SwapBE dst: r4 imm: 16 19: Mov32Imm dst: r4 imm: 1 20: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 21: MovImm dst: r4 imm: 0 22: JaImm dst: r0 off: -1 imm: 0 result: 23: MovImm dst: r0 imm: 2 24: JEqImm dst: r4 off: -1 imm: 0 25: MovImm dst: r0 imm: 1 return: 26: Exit === RUN TestLoadIndirect/variable_outofbounds/kernel#03 === RUN TestLoadIndirect/variable_outofbounds/C#04 === RUN TestLoadIndirect/variable_outofbounds/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 4 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemW dst: r4 src: r2 off: 0 imm: 0 6: SwapBE dst: r4 imm: 32 7: Mov32Reg dst: r5 src: r4 8: MovReg dst: r7 src: r5 9: LShImm dst: r7 imm: 32 10: ArShImm dst: r7 imm: 32 11: AddImm dst: r7 imm: 30 12: JGEImm dst: r7 off: -1 imm: 65535 13: AddReg dst: r7 src: r2 14: MovReg dst: r6 src: r7 15: AddImm dst: r6 imm: 1 16: JGTReg dst: r6 off: -1 src: r3 17: LdXMemB dst: r4 src: r7 off: 0 imm: 0 18: Mov32Imm dst: r4 imm: 1 19: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 20: MovImm dst: r4 imm: 0 21: JaImm dst: r0 off: -1 imm: 0 result: 22: MovImm dst: r0 imm: 2 23: JEqImm dst: r4 off: -1 imm: 0 24: MovImm dst: r0 imm: 1 return: 25: Exit === RUN TestLoadIndirect/variable_outofbounds/kernel#04 --- PASS: TestLoadIndirect (1.97s) --- PASS: TestLoadIndirect/constant_valid (0.63s) --- SKIP: TestLoadIndirect/constant_valid/C (0.05s) --- SKIP: TestLoadIndirect/constant_valid/eBPF (0.00s) --- PASS: TestLoadIndirect/constant_valid/kernel (0.00s) --- SKIP: TestLoadIndirect/constant_valid/C#01 (0.06s) --- SKIP: TestLoadIndirect/constant_valid/eBPF#01 (0.00s) --- PASS: TestLoadIndirect/constant_valid/kernel#01 (0.06s) --- SKIP: TestLoadIndirect/constant_valid/C#02 (0.07s) --- SKIP: TestLoadIndirect/constant_valid/eBPF#02 (0.00s) --- PASS: TestLoadIndirect/constant_valid/kernel#02 (0.00s) --- SKIP: TestLoadIndirect/constant_valid/C#03 (0.06s) --- SKIP: TestLoadIndirect/constant_valid/eBPF#03 (0.00s) --- PASS: TestLoadIndirect/constant_valid/kernel#03 (0.06s) --- SKIP: TestLoadIndirect/constant_valid/C#04 (0.10s) --- SKIP: TestLoadIndirect/constant_valid/eBPF#04 (0.00s) --- PASS: TestLoadIndirect/constant_valid/kernel#04 (0.00s) --- SKIP: TestLoadIndirect/constant_valid/C#05 (0.06s) --- SKIP: TestLoadIndirect/constant_valid/eBPF#05 (0.00s) --- PASS: TestLoadIndirect/constant_valid/kernel#05 (0.05s) --- PASS: TestLoadIndirect/variable_valid (0.49s) --- SKIP: TestLoadIndirect/variable_valid/C (0.07s) --- SKIP: TestLoadIndirect/variable_valid/eBPF (0.00s) --- PASS: TestLoadIndirect/variable_valid/kernel (0.00s) --- SKIP: TestLoadIndirect/variable_valid/C#01 (0.09s) --- SKIP: TestLoadIndirect/variable_valid/eBPF#01 (0.00s) --- PASS: TestLoadIndirect/variable_valid/kernel#01 (0.05s) --- SKIP: TestLoadIndirect/variable_valid/C#02 (0.04s) --- SKIP: TestLoadIndirect/variable_valid/eBPF#02 (0.00s) --- PASS: TestLoadIndirect/variable_valid/kernel#02 (0.00s) --- SKIP: TestLoadIndirect/variable_valid/C#03 (0.05s) --- SKIP: TestLoadIndirect/variable_valid/eBPF#03 (0.00s) --- PASS: TestLoadIndirect/variable_valid/kernel#03 (0.05s) --- SKIP: TestLoadIndirect/variable_valid/C#04 (0.05s) --- SKIP: TestLoadIndirect/variable_valid/eBPF#04 (0.00s) --- PASS: TestLoadIndirect/variable_valid/kernel#04 (0.00s) --- SKIP: TestLoadIndirect/variable_valid/C#05 (0.03s) --- SKIP: TestLoadIndirect/variable_valid/eBPF#05 (0.00s) --- PASS: TestLoadIndirect/variable_valid/kernel#05 (0.05s) --- PASS: TestLoadIndirect/constant_outofbounds (0.37s) --- SKIP: TestLoadIndirect/constant_outofbounds/C (0.03s) --- SKIP: TestLoadIndirect/constant_outofbounds/eBPF (0.00s) --- PASS: TestLoadIndirect/constant_outofbounds/kernel (0.00s) --- SKIP: TestLoadIndirect/constant_outofbounds/C#01 (0.03s) --- SKIP: TestLoadIndirect/constant_outofbounds/eBPF#01 (0.00s) --- PASS: TestLoadIndirect/constant_outofbounds/kernel#01 (0.05s) --- SKIP: TestLoadIndirect/constant_outofbounds/C#02 (0.03s) --- SKIP: TestLoadIndirect/constant_outofbounds/eBPF#02 (0.00s) --- PASS: TestLoadIndirect/constant_outofbounds/kernel#02 (0.05s) --- SKIP: TestLoadIndirect/constant_outofbounds/C#03 (0.03s) --- SKIP: TestLoadIndirect/constant_outofbounds/eBPF#03 (0.00s) --- PASS: TestLoadIndirect/constant_outofbounds/kernel#03 (0.05s) --- SKIP: TestLoadIndirect/constant_outofbounds/C#04 (0.03s) --- SKIP: TestLoadIndirect/constant_outofbounds/eBPF#04 (0.00s) --- PASS: TestLoadIndirect/constant_outofbounds/kernel#04 (0.05s) --- PASS: TestLoadIndirect/variable_outofbounds (0.45s) --- SKIP: TestLoadIndirect/variable_outofbounds/C (0.04s) --- SKIP: TestLoadIndirect/variable_outofbounds/eBPF (0.00s) --- PASS: TestLoadIndirect/variable_outofbounds/kernel (0.00s) --- SKIP: TestLoadIndirect/variable_outofbounds/C#01 (0.04s) --- SKIP: TestLoadIndirect/variable_outofbounds/eBPF#01 (0.00s) --- PASS: TestLoadIndirect/variable_outofbounds/kernel#01 (0.05s) --- SKIP: TestLoadIndirect/variable_outofbounds/C#02 (0.04s) --- SKIP: TestLoadIndirect/variable_outofbounds/eBPF#02 (0.00s) --- PASS: TestLoadIndirect/variable_outofbounds/kernel#02 (0.05s) --- SKIP: TestLoadIndirect/variable_outofbounds/C#03 (0.06s) --- SKIP: TestLoadIndirect/variable_outofbounds/eBPF#03 (0.00s) --- PASS: TestLoadIndirect/variable_outofbounds/kernel#03 (0.05s) --- SKIP: TestLoadIndirect/variable_outofbounds/C#04 (0.06s) --- SKIP: TestLoadIndirect/variable_outofbounds/eBPF#04 (0.00s) --- PASS: TestLoadIndirect/variable_outofbounds/kernel#04 (0.05s) PASS ok github.com/cloudflare/cbpfc 3.623s ? github.com/cloudflare/cbpfc/clang [no test files] make[1]: Leaving directory '/build/reproducible-path/golang-github-cloudflare-cbpfc-0.0~git20231012.992ed75' create-stamp debian/debhelper-build-stamp dh_testroot -O--builddirectory=_build -O--buildsystem=golang dh_prep -O--builddirectory=_build -O--buildsystem=golang dh_auto_install --destdir=debian/golang-github-cloudflare-cbpfc-dev/ -O--builddirectory=_build -O--buildsystem=golang dh_installdocs -O--builddirectory=_build -O--buildsystem=golang dh_installchangelogs -O--builddirectory=_build -O--buildsystem=golang dh_installsystemduser -O--builddirectory=_build -O--buildsystem=golang dh_perl -O--builddirectory=_build -O--buildsystem=golang dh_link -O--builddirectory=_build -O--buildsystem=golang dh_strip_nondeterminism -O--builddirectory=_build -O--buildsystem=golang dh_compress -O--builddirectory=_build -O--buildsystem=golang dh_fixperms -O--builddirectory=_build -O--buildsystem=golang dh_missing -O--builddirectory=_build -O--buildsystem=golang dh_installdeb -O--builddirectory=_build -O--buildsystem=golang dh_golang -O--builddirectory=_build -O--buildsystem=golang dh_gencontrol -O--builddirectory=_build -O--buildsystem=golang dh_md5sums -O--builddirectory=_build -O--buildsystem=golang dh_builddeb -O--builddirectory=_build -O--buildsystem=golang dpkg-deb: building package 'golang-github-cloudflare-cbpfc-dev' in '../golang-github-cloudflare-cbpfc-dev_0.0~git20231012.992ed75-2_all.deb'. dpkg-genbuildinfo --build=binary -O../golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_arm64.buildinfo dpkg-genchanges --build=binary -O../golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_arm64.changes dpkg-genchanges: info: binary-only upload (no source code included) dpkg-source --after-build . dpkg-buildpackage: info: binary-only upload (no source included) dpkg-genchanges: info: not including original source code in upload I: copying local configuration I: unmounting dev/ptmx filesystem I: unmounting dev/pts filesystem I: unmounting dev/shm filesystem I: unmounting proc filesystem I: unmounting sys filesystem I: cleaning the build env I: removing directory /srv/workspace/pbuilder/2165263 and its subdirectories I: Current time: Fri Feb 21 21:06:49 -12 2025 I: pbuilder-time-stamp: 1740215209 Sat Feb 22 09:06:51 UTC 2025 I: 1st build successful. Starting 2nd build on remote node codethink03-arm64.debian.net. Sat Feb 22 09:06:51 UTC 2025 I: Preparing to do remote build '2' on codethink03-arm64.debian.net. Sat Feb 22 09:06:51 UTC 2025 - checking /var/lib/jenkins/offline_nodes if codethink03-arm64.debian.net is marked as down. Sat Feb 22 09:06:51 UTC 2025 - checking via ssh if codethink03-arm64.debian.net is up. removed '/tmp/read-only-fs-test-lkks2T' ==================================================================================== Fri Mar 27 15:29:52 UTC 2026 - running /srv/jenkins/bin/reproducible_build.sh (for job /srv/jenkins/bin/reproducible_build.sh) on codethink03-arm64, called using "2 golang-github-cloudflare-cbpfc trixie /srv/reproducible-results/rbuild-debian/r-b-build.bvEh5Q9U 0.0~git20231012.992ed75-2" as arguments. Fri Mar 27 15:29:52 UTC 2026 - actually running "reproducible_build.sh" (md5sum 68e686e434c9ab7bc3ec047d8b309cbc) as "/tmp/jenkins-script-DzOLCG4y" $ git clone https://salsa.debian.org/qa/jenkins.debian.net.git ; more CONTRIBUTING Fri Mar 27 15:29:52 UTC 2026 I: Downloading source for trixie/golang-github-cloudflare-cbpfc=0.0~git20231012.992ed75-2 Reading package lists... NOTICE: 'golang-github-cloudflare-cbpfc' packaging is maintained in the 'Git' version control system at: https://salsa.debian.org/go-team/packages/golang-github-cloudflare-cbpfc.git Please use: git clone https://salsa.debian.org/go-team/packages/golang-github-cloudflare-cbpfc.git to retrieve the latest (possibly unreleased) updates to the package. Need to get 34.8 kB of source archives. Get:1 http://deb.debian.org/debian trixie/main golang-github-cloudflare-cbpfc 0.0~git20231012.992ed75-2 (dsc) [2689 B] Get:2 http://deb.debian.org/debian trixie/main golang-github-cloudflare-cbpfc 0.0~git20231012.992ed75-2 (tar) [29.0 kB] Get:3 http://deb.debian.org/debian trixie/main golang-github-cloudflare-cbpfc 0.0~git20231012.992ed75-2 (diff) [3100 B] Fetched 34.8 kB in 0s (1977 kB/s) Download complete and in download only mode Reading package lists... NOTICE: 'golang-github-cloudflare-cbpfc' packaging is maintained in the 'Git' version control system at: https://salsa.debian.org/go-team/packages/golang-github-cloudflare-cbpfc.git Please use: git clone https://salsa.debian.org/go-team/packages/golang-github-cloudflare-cbpfc.git to retrieve the latest (possibly unreleased) updates to the package. Need to get 34.8 kB of source archives. Get:1 http://deb.debian.org/debian trixie/main golang-github-cloudflare-cbpfc 0.0~git20231012.992ed75-2 (dsc) [2689 B] Get:2 http://deb.debian.org/debian trixie/main golang-github-cloudflare-cbpfc 0.0~git20231012.992ed75-2 (tar) [29.0 kB] Get:3 http://deb.debian.org/debian trixie/main golang-github-cloudflare-cbpfc 0.0~git20231012.992ed75-2 (diff) [3100 B] Fetched 34.8 kB in 0s (1977 kB/s) Download complete and in download only mode ============================================================================= Re-Building golang-github-cloudflare-cbpfc in trixie on arm64 on codethink03-arm64 now. Date: Fri Mar 27 15:29:53 GMT 2026 Date UTC: Fri Mar 27 15:29:53 UTC 2026 ============================================================================= ++ mktemp -t pbuilderrc_XXXX --tmpdir=/srv/reproducible-results/rbuild-debian/r-b-build.bvEh5Q9U + local TMPCFG=/srv/reproducible-results/rbuild-debian/r-b-build.bvEh5Q9U/pbuilderrc_5sMO + case ${ARCH} in + case $ARCH in + locale=nl_BE + language=nl + case "${SUITE}" in + reproducible_buildflags=+all + extra_deb_build_options= + case "${SRCPACKAGE}" in + cat + echo BUILDDIR=/build/reproducible-path + '[' golang-github-cloudflare-cbpfc = debian-installer -o golang-github-cloudflare-cbpfc = debian-installer-netboot-images ']' + pbuilder_options=() + local pbuilder_options + DEBBUILDOPTS=-b + BINARYTARGET= + '[' golang-github-cloudflare-cbpfc = u-boot ']' + case "${SRCPACKAGE}" in + PBUILDERTIMEOUT=24 + local PRESULT=0 + sudo timeout -k 24.1h 24h /usr/bin/ionice -c 3 /usr/bin/nice -n 11 /usr/bin/unshare --uts -- /usr/sbin/pbuilder --build --configfile /srv/reproducible-results/rbuild-debian/r-b-build.bvEh5Q9U/pbuilderrc_5sMO --distribution trixie --hookdir /etc/pbuilder/rebuild-hooks --debbuildopts -b --basetgz /var/cache/pbuilder/trixie-reproducible-base.tgz --buildresult /srv/reproducible-results/rbuild-debian/r-b-build.bvEh5Q9U/b2 --logfile b2/build.log golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.dsc W: /root/.pbuilderrc does not exist I: Logging to b2/build.log I: pbuilder: network access will be disabled during build I: Current time: Sat Mar 28 05:29:53 +14 2026 I: pbuilder-time-stamp: 1774625393 I: Building the build Environment I: extracting base tarball [/var/cache/pbuilder/trixie-reproducible-base.tgz] I: copying local configuration W: --override-config is not set; not updating apt.conf Read the manpage for details. I: mounting /proc filesystem I: mounting /sys filesystem I: creating /{dev,run}/shm I: mounting /dev/pts filesystem I: redirecting /dev/ptmx to /dev/pts/ptmx I: policy-rc.d already exists I: Copying source file I: copying [golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.dsc] I: copying [./golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75.orig.tar.gz] I: copying [./golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.debian.tar.xz] I: Extracting source dpkg-source: warning: cannot verify inline signature for ./golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.dsc: unsupported subcommand dpkg-source: info: extracting golang-github-cloudflare-cbpfc in golang-github-cloudflare-cbpfc-0.0~git20231012.992ed75 dpkg-source: info: unpacking golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75.orig.tar.gz dpkg-source: info: unpacking golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.debian.tar.xz dpkg-source: info: using patch list from debian/patches/series dpkg-source: info: applying auto-gitignore I: Not using root during the build. I: Installing the build-deps I: user script /srv/workspace/pbuilder/2844666/tmp/hooks/D01_modify_environment starting debug: Running on codethink03-arm64. I: Changing host+domainname to test build reproducibility I: Adding a custom variable just for the fun of it... I: Changing /bin/sh to bash '/bin/sh' -> '/bin/bash' lrwxrwxrwx 1 root root 9 Mar 27 15:30 /bin/sh -> /bin/bash I: Setting pbuilder2's login shell to /bin/bash I: Setting pbuilder2's GECOS to second user,second room,second work-phone,second home-phone,second other I: user script /srv/workspace/pbuilder/2844666/tmp/hooks/D01_modify_environment finished I: user script /srv/workspace/pbuilder/2844666/tmp/hooks/D02_print_environment starting I: set BASH=/bin/sh BASHOPTS=checkwinsize:cmdhist:complete_fullquote:extquote:force_fignore:globasciiranges:globskipdots:hostcomplete:interactive_comments:patsub_replacement:progcomp:promptvars:sourcepath BASH_ALIASES=() BASH_ARGC=() BASH_ARGV=() BASH_CMDS=() BASH_LINENO=([0]="12" [1]="0") BASH_LOADABLES_PATH=/usr/local/lib/bash:/usr/lib/bash:/opt/local/lib/bash:/usr/pkg/lib/bash:/opt/pkg/lib/bash:. BASH_SOURCE=([0]="/tmp/hooks/D02_print_environment" [1]="/tmp/hooks/D02_print_environment") BASH_VERSINFO=([0]="5" [1]="2" [2]="37" [3]="1" [4]="release" [5]="aarch64-unknown-linux-gnu") BASH_VERSION='5.2.37(1)-release' BUILDDIR=/build/reproducible-path BUILDUSERGECOS='second user,second room,second work-phone,second home-phone,second other' BUILDUSERNAME=pbuilder2 BUILD_ARCH=arm64 DEBIAN_FRONTEND=noninteractive DEB_BUILD_OPTIONS='buildinfo=+all reproducible=+all parallel=12 ' DIRSTACK=() DISTRIBUTION=trixie EUID=0 FUNCNAME=([0]="Echo" [1]="main") GROUPS=() HOME=/root HOSTNAME=i-capture-the-hostname HOSTTYPE=aarch64 HOST_ARCH=arm64 IFS=' ' INVOCATION_ID=a2d51ef857134714a1c60d52d7135770 LANG=C LANGUAGE=nl_BE:nl LC_ALL=C MACHTYPE=aarch64-unknown-linux-gnu MAIL=/var/mail/root OPTERR=1 OPTIND=1 OSTYPE=linux-gnu PATH=/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/i/capture/the/path PBCURRENTCOMMANDLINEOPERATION=build PBUILDER_OPERATION=build PBUILDER_PKGDATADIR=/usr/share/pbuilder PBUILDER_PKGLIBDIR=/usr/lib/pbuilder PBUILDER_SYSCONFDIR=/etc PIPESTATUS=([0]="0") POSIXLY_CORRECT=y PPID=2844666 PS4='+ ' PWD=/ SHELL=/bin/bash SHELLOPTS=braceexpand:errexit:hashall:interactive-comments:posix SHLVL=3 SUDO_COMMAND='/usr/bin/timeout -k 24.1h 24h /usr/bin/ionice -c 3 /usr/bin/nice -n 11 /usr/bin/unshare --uts -- /usr/sbin/pbuilder --build --configfile /srv/reproducible-results/rbuild-debian/r-b-build.bvEh5Q9U/pbuilderrc_5sMO --distribution trixie --hookdir /etc/pbuilder/rebuild-hooks --debbuildopts -b --basetgz /var/cache/pbuilder/trixie-reproducible-base.tgz --buildresult /srv/reproducible-results/rbuild-debian/r-b-build.bvEh5Q9U/b2 --logfile b2/build.log golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.dsc' SUDO_GID=109 SUDO_UID=104 SUDO_USER=jenkins TERM=unknown TZ=/usr/share/zoneinfo/Etc/GMT-14 UID=0 USER=root _='I: set' http_proxy=http://192.168.101.4:3128 I: uname -a Linux i-capture-the-hostname 6.1.0-31-cloud-arm64 #1 SMP Debian 6.1.128-1 (2025-02-07) aarch64 GNU/Linux I: ls -l /bin lrwxrwxrwx 1 root root 7 Nov 22 2024 /bin -> usr/bin I: user script /srv/workspace/pbuilder/2844666/tmp/hooks/D02_print_environment finished -> Attempting to satisfy build-dependencies -> Creating pbuilder-satisfydepends-dummy package Package: pbuilder-satisfydepends-dummy Version: 0.invalid.0 Architecture: arm64 Maintainer: Debian Pbuilder Team Description: Dummy package to satisfy dependencies with aptitude - created by pbuilder This package was created automatically by pbuilder to satisfy the build-dependencies of the package being currently built. Depends: debhelper-compat (= 13), clang, dh-golang, golang-any, golang-github-cilium-ebpf-dev, golang-github-pkg-errors-dev, golang-golang-x-net-dev, golang-golang-x-sys-dev dpkg-deb: building package 'pbuilder-satisfydepends-dummy' in '/tmp/satisfydepends-aptitude/pbuilder-satisfydepends-dummy.deb'. Selecting previously unselected package pbuilder-satisfydepends-dummy. (Reading database ... 19972 files and directories currently installed.) Preparing to unpack .../pbuilder-satisfydepends-dummy.deb ... Unpacking pbuilder-satisfydepends-dummy (0.invalid.0) ... dpkg: pbuilder-satisfydepends-dummy: dependency problems, but configuring anyway as you requested: pbuilder-satisfydepends-dummy depends on debhelper-compat (= 13); however: Package debhelper-compat is not installed. pbuilder-satisfydepends-dummy depends on clang; however: Package clang is not installed. pbuilder-satisfydepends-dummy depends on dh-golang; however: Package dh-golang is not installed. pbuilder-satisfydepends-dummy depends on golang-any; however: Package golang-any is not installed. pbuilder-satisfydepends-dummy depends on golang-github-cilium-ebpf-dev; however: Package golang-github-cilium-ebpf-dev is not installed. pbuilder-satisfydepends-dummy depends on golang-github-pkg-errors-dev; however: Package golang-github-pkg-errors-dev is not installed. pbuilder-satisfydepends-dummy depends on golang-golang-x-net-dev; however: Package golang-golang-x-net-dev is not installed. pbuilder-satisfydepends-dummy depends on golang-golang-x-sys-dev; however: Package golang-golang-x-sys-dev is not installed. Setting up pbuilder-satisfydepends-dummy (0.invalid.0) ... Reading package lists... Building dependency tree... Reading state information... Initializing package states... Writing extended state information... Building tag database... pbuilder-satisfydepends-dummy is already installed at the requested version (0.invalid.0) pbuilder-satisfydepends-dummy is already installed at the requested version (0.invalid.0) The following NEW packages will be installed: autoconf{a} automake{a} autopoint{a} autotools-dev{a} binutils-gold{a} binutils-gold-aarch64-linux-gnu{a} bsdextrautils{a} clang{a} clang-19{a} debhelper{a} dh-autoreconf{a} dh-golang{a} dh-strip-nondeterminism{a} dwz{a} file{a} gettext{a} gettext-base{a} golang-1.24-go{a} golang-1.24-src{a} golang-any{a} golang-github-cilium-ebpf-dev{a} golang-github-pkg-errors-dev{a} golang-go{a} golang-golang-x-crypto-dev{a} golang-golang-x-exp-dev{a} golang-golang-x-net-dev{a} golang-golang-x-sys-dev{a} golang-golang-x-term-dev{a} golang-golang-x-text-dev{a} golang-src{a} groff-base{a} intltool-debian{a} libarchive-zip-perl{a} libclang-common-19-dev{a} libclang-cpp19{a} libclang1-19{a} libdebhelper-perl{a} libedit2{a} libelf1t64{a} libffi8{a} libfile-stripnondeterminism-perl{a} libgc1{a} libicu72{a} libllvm19{a} libmagic-mgc{a} libmagic1t64{a} libobjc-14-dev{a} libobjc4{a} libpipeline1{a} libtool{a} libuchardet0{a} libunistring5{a} libxml2{a} libz3-4{a} llvm-19-linker-tools{a} m4{a} man-db{a} po-debconf{a} sensible-utils{a} The following packages are RECOMMENDED but will NOT be installed: curl libarchive-cpio-perl libclang-rt-19-dev libltdl-dev libmail-sendmail-perl llvm-19-dev lynx pkgconf python3 wget 0 packages upgraded, 59 newly installed, 0 to remove and 0 not upgraded. Need to get 128 MB of archives. After unpacking 685 MB will be used. Writing extended state information... Get: 1 http://deb.debian.org/debian trixie/main arm64 sensible-utils all 0.0.24 [24.8 kB] Get: 2 http://deb.debian.org/debian trixie/main arm64 libmagic-mgc arm64 1:5.45-3+b1 [314 kB] Get: 3 http://deb.debian.org/debian trixie/main arm64 libmagic1t64 arm64 1:5.45-3+b1 [102 kB] Get: 4 http://deb.debian.org/debian trixie/main arm64 file arm64 1:5.45-3+b1 [43.4 kB] Get: 5 http://deb.debian.org/debian trixie/main arm64 gettext-base arm64 0.23.1-1 [241 kB] Get: 6 http://deb.debian.org/debian trixie/main arm64 libuchardet0 arm64 0.0.8-1+b2 [69.2 kB] Get: 7 http://deb.debian.org/debian trixie/main arm64 groff-base arm64 1.23.0-7 [1129 kB] Get: 8 http://deb.debian.org/debian trixie/main arm64 bsdextrautils arm64 2.40.4-3 [92.0 kB] Get: 9 http://deb.debian.org/debian trixie/main arm64 libpipeline1 arm64 1.5.8-1 [40.2 kB] Get: 10 http://deb.debian.org/debian trixie/main arm64 man-db arm64 2.13.0-1 [1404 kB] Get: 11 http://deb.debian.org/debian trixie/main arm64 m4 arm64 1.4.19-5 [284 kB] Get: 12 http://deb.debian.org/debian trixie/main arm64 autoconf all 2.72-3 [493 kB] Get: 13 http://deb.debian.org/debian trixie/main arm64 autotools-dev all 20220109.1 [51.6 kB] Get: 14 http://deb.debian.org/debian trixie/main arm64 automake all 1:1.17-3 [862 kB] Get: 15 http://deb.debian.org/debian trixie/main arm64 autopoint all 0.23.1-1 [770 kB] Get: 16 http://deb.debian.org/debian trixie/main arm64 binutils-gold-aarch64-linux-gnu arm64 2.44-1 [1704 kB] Get: 17 http://deb.debian.org/debian trixie/main arm64 binutils-gold arm64 2.44-1 [202 kB] Get: 18 http://deb.debian.org/debian trixie/main arm64 libedit2 arm64 3.1-20250104-1 [89.3 kB] Get: 19 http://deb.debian.org/debian trixie/main arm64 libffi8 arm64 3.4.7-1 [21.2 kB] Get: 20 http://deb.debian.org/debian trixie/main arm64 libicu72 arm64 72.1-6 [9239 kB] Get: 21 http://deb.debian.org/debian trixie/main arm64 libxml2 arm64 2.12.7+dfsg+really2.9.14-0.2+b1 [630 kB] Get: 22 http://deb.debian.org/debian trixie/main arm64 libz3-4 arm64 4.13.3-1 [7507 kB] Get: 23 http://deb.debian.org/debian trixie/main arm64 libllvm19 arm64 1:19.1.7-1+b1 [23.3 MB] Get: 24 http://deb.debian.org/debian trixie/main arm64 libclang-cpp19 arm64 1:19.1.7-1+b1 [12.0 MB] Get: 25 http://deb.debian.org/debian trixie/main arm64 libgc1 arm64 1:8.2.8-1 [241 kB] Get: 26 http://deb.debian.org/debian trixie/main arm64 libobjc4 arm64 14.2.0-16 [39.4 kB] Get: 27 http://deb.debian.org/debian trixie/main arm64 libobjc-14-dev arm64 14.2.0-16 [166 kB] Get: 28 http://deb.debian.org/debian trixie/main arm64 libclang-common-19-dev arm64 1:19.1.7-1+b1 [740 kB] Get: 29 http://deb.debian.org/debian trixie/main arm64 llvm-19-linker-tools arm64 1:19.1.7-1+b1 [1100 kB] Get: 30 http://deb.debian.org/debian trixie/main arm64 libclang1-19 arm64 1:19.1.7-1+b1 [6851 kB] Get: 31 http://deb.debian.org/debian trixie/main arm64 clang-19 arm64 1:19.1.7-1+b1 [112 kB] Get: 32 http://deb.debian.org/debian trixie/main arm64 clang arm64 1:19.0-63 [6244 B] Get: 33 http://deb.debian.org/debian trixie/main arm64 libdebhelper-perl all 13.24.1 [90.9 kB] Get: 34 http://deb.debian.org/debian trixie/main arm64 libtool all 2.5.4-3 [539 kB] Get: 35 http://deb.debian.org/debian trixie/main arm64 dh-autoreconf all 20 [17.1 kB] Get: 36 http://deb.debian.org/debian trixie/main arm64 libarchive-zip-perl all 1.68-1 [104 kB] Get: 37 http://deb.debian.org/debian trixie/main arm64 libfile-stripnondeterminism-perl all 1.14.1-2 [19.7 kB] Get: 38 http://deb.debian.org/debian trixie/main arm64 dh-strip-nondeterminism all 1.14.1-2 [8620 B] Get: 39 http://deb.debian.org/debian trixie/main arm64 libelf1t64 arm64 0.192-4 [189 kB] Get: 40 http://deb.debian.org/debian trixie/main arm64 dwz arm64 0.15-1+b1 [102 kB] Get: 41 http://deb.debian.org/debian trixie/main arm64 libunistring5 arm64 1.3-1 [449 kB] Get: 42 http://deb.debian.org/debian trixie/main arm64 gettext arm64 0.23.1-1 [1610 kB] Get: 43 http://deb.debian.org/debian trixie/main arm64 intltool-debian all 0.35.0+20060710.6 [22.9 kB] Get: 44 http://deb.debian.org/debian trixie/main arm64 po-debconf all 1.0.21+nmu1 [248 kB] Get: 45 http://deb.debian.org/debian trixie/main arm64 debhelper all 13.24.1 [920 kB] Get: 46 http://deb.debian.org/debian trixie/main arm64 dh-golang all 1.63 [24.4 kB] Get: 47 http://deb.debian.org/debian trixie/main arm64 golang-1.24-src all 1.24.0-1 [20.3 MB] Get: 48 http://deb.debian.org/debian trixie/main arm64 golang-1.24-go arm64 1.24.0-1 [24.6 MB] Get: 49 http://deb.debian.org/debian trixie/main arm64 golang-src all 2:1.24~2 [5136 B] Get: 50 http://deb.debian.org/debian trixie/main arm64 golang-go arm64 2:1.24~2 [44.3 kB] Get: 51 http://deb.debian.org/debian trixie/main arm64 golang-any arm64 2:1.24~2 [5216 B] Get: 52 http://deb.debian.org/debian trixie/main arm64 golang-golang-x-exp-dev all 0.0~git20231006.7918f67-1 [105 kB] Get: 53 http://deb.debian.org/debian trixie/main arm64 golang-golang-x-sys-dev all 0.22.0-1 [431 kB] Get: 54 http://deb.debian.org/debian trixie/main arm64 golang-github-cilium-ebpf-dev all 0.11.0-2 [1793 kB] Get: 55 http://deb.debian.org/debian trixie/main arm64 golang-github-pkg-errors-dev all 0.9.1-3 [12.9 kB] Get: 56 http://deb.debian.org/debian trixie/main arm64 golang-golang-x-term-dev all 0.22.0-1 [14.8 kB] Get: 57 http://deb.debian.org/debian trixie/main arm64 golang-golang-x-text-dev all 0.22.0-1 [3995 kB] Get: 58 http://deb.debian.org/debian trixie/main arm64 golang-golang-x-crypto-dev all 1:0.25.0-1 [1682 kB] Get: 59 http://deb.debian.org/debian trixie/main arm64 golang-golang-x-net-dev all 1:0.27.0-1 [898 kB] Fetched 128 MB in 0s (277 MB/s) Preconfiguring packages ... Selecting previously unselected package sensible-utils. (Reading database ... (Reading database ... 5% (Reading database ... 10% (Reading database ... 15% (Reading database ... 20% (Reading database ... 25% (Reading database ... 30% (Reading database ... 35% (Reading database ... 40% (Reading database ... 45% (Reading database ... 50% (Reading database ... 55% (Reading database ... 60% (Reading database ... 65% (Reading database ... 70% (Reading database ... 75% (Reading database ... 80% (Reading database ... 85% (Reading database ... 90% (Reading database ... 95% (Reading database ... 100% (Reading database ... 19972 files and directories currently installed.) Preparing to unpack .../00-sensible-utils_0.0.24_all.deb ... Unpacking sensible-utils (0.0.24) ... Selecting previously unselected package libmagic-mgc. Preparing to unpack .../01-libmagic-mgc_1%3a5.45-3+b1_arm64.deb ... Unpacking libmagic-mgc (1:5.45-3+b1) ... Selecting previously unselected package libmagic1t64:arm64. Preparing to unpack .../02-libmagic1t64_1%3a5.45-3+b1_arm64.deb ... Unpacking libmagic1t64:arm64 (1:5.45-3+b1) ... Selecting previously unselected package file. Preparing to unpack .../03-file_1%3a5.45-3+b1_arm64.deb ... Unpacking file (1:5.45-3+b1) ... Selecting previously unselected package gettext-base. Preparing to unpack .../04-gettext-base_0.23.1-1_arm64.deb ... Unpacking gettext-base (0.23.1-1) ... Selecting previously unselected package libuchardet0:arm64. Preparing to unpack .../05-libuchardet0_0.0.8-1+b2_arm64.deb ... Unpacking libuchardet0:arm64 (0.0.8-1+b2) ... Selecting previously unselected package groff-base. Preparing to unpack .../06-groff-base_1.23.0-7_arm64.deb ... Unpacking groff-base (1.23.0-7) ... Selecting previously unselected package bsdextrautils. Preparing to unpack .../07-bsdextrautils_2.40.4-3_arm64.deb ... Unpacking bsdextrautils (2.40.4-3) ... Selecting previously unselected package libpipeline1:arm64. Preparing to unpack .../08-libpipeline1_1.5.8-1_arm64.deb ... Unpacking libpipeline1:arm64 (1.5.8-1) ... Selecting previously unselected package man-db. Preparing to unpack .../09-man-db_2.13.0-1_arm64.deb ... Unpacking man-db (2.13.0-1) ... Selecting previously unselected package m4. Preparing to unpack .../10-m4_1.4.19-5_arm64.deb ... Unpacking m4 (1.4.19-5) ... Selecting previously unselected package autoconf. Preparing to unpack .../11-autoconf_2.72-3_all.deb ... Unpacking autoconf (2.72-3) ... Selecting previously unselected package autotools-dev. Preparing to unpack .../12-autotools-dev_20220109.1_all.deb ... Unpacking autotools-dev (20220109.1) ... Selecting previously unselected package automake. Preparing to unpack .../13-automake_1%3a1.17-3_all.deb ... Unpacking automake (1:1.17-3) ... Selecting previously unselected package autopoint. Preparing to unpack .../14-autopoint_0.23.1-1_all.deb ... Unpacking autopoint (0.23.1-1) ... Selecting previously unselected package binutils-gold-aarch64-linux-gnu. Preparing to unpack .../15-binutils-gold-aarch64-linux-gnu_2.44-1_arm64.deb ... Unpacking binutils-gold-aarch64-linux-gnu (2.44-1) ... Selecting previously unselected package binutils-gold. Preparing to unpack .../16-binutils-gold_2.44-1_arm64.deb ... Unpacking binutils-gold (2.44-1) ... Selecting previously unselected package libedit2:arm64. Preparing to unpack .../17-libedit2_3.1-20250104-1_arm64.deb ... Unpacking libedit2:arm64 (3.1-20250104-1) ... Selecting previously unselected package libffi8:arm64. Preparing to unpack .../18-libffi8_3.4.7-1_arm64.deb ... Unpacking libffi8:arm64 (3.4.7-1) ... Selecting previously unselected package libicu72:arm64. Preparing to unpack .../19-libicu72_72.1-6_arm64.deb ... Unpacking libicu72:arm64 (72.1-6) ... Selecting previously unselected package libxml2:arm64. Preparing to unpack .../20-libxml2_2.12.7+dfsg+really2.9.14-0.2+b1_arm64.deb ... Unpacking libxml2:arm64 (2.12.7+dfsg+really2.9.14-0.2+b1) ... Selecting previously unselected package libz3-4:arm64. Preparing to unpack .../21-libz3-4_4.13.3-1_arm64.deb ... Unpacking libz3-4:arm64 (4.13.3-1) ... Selecting previously unselected package libllvm19:arm64. Preparing to unpack .../22-libllvm19_1%3a19.1.7-1+b1_arm64.deb ... Unpacking libllvm19:arm64 (1:19.1.7-1+b1) ... Selecting previously unselected package libclang-cpp19. Preparing to unpack .../23-libclang-cpp19_1%3a19.1.7-1+b1_arm64.deb ... Unpacking libclang-cpp19 (1:19.1.7-1+b1) ... Selecting previously unselected package libgc1:arm64. Preparing to unpack .../24-libgc1_1%3a8.2.8-1_arm64.deb ... Unpacking libgc1:arm64 (1:8.2.8-1) ... Selecting previously unselected package libobjc4:arm64. Preparing to unpack .../25-libobjc4_14.2.0-16_arm64.deb ... Unpacking libobjc4:arm64 (14.2.0-16) ... Selecting previously unselected package libobjc-14-dev:arm64. Preparing to unpack .../26-libobjc-14-dev_14.2.0-16_arm64.deb ... Unpacking libobjc-14-dev:arm64 (14.2.0-16) ... Selecting previously unselected package libclang-common-19-dev:arm64. Preparing to unpack .../27-libclang-common-19-dev_1%3a19.1.7-1+b1_arm64.deb ... Unpacking libclang-common-19-dev:arm64 (1:19.1.7-1+b1) ... Selecting previously unselected package llvm-19-linker-tools. Preparing to unpack .../28-llvm-19-linker-tools_1%3a19.1.7-1+b1_arm64.deb ... Unpacking llvm-19-linker-tools (1:19.1.7-1+b1) ... Selecting previously unselected package libclang1-19. Preparing to unpack .../29-libclang1-19_1%3a19.1.7-1+b1_arm64.deb ... Unpacking libclang1-19 (1:19.1.7-1+b1) ... Selecting previously unselected package clang-19. Preparing to unpack .../30-clang-19_1%3a19.1.7-1+b1_arm64.deb ... Unpacking clang-19 (1:19.1.7-1+b1) ... Selecting previously unselected package clang. Preparing to unpack .../31-clang_1%3a19.0-63_arm64.deb ... Unpacking clang (1:19.0-63) ... Selecting previously unselected package libdebhelper-perl. Preparing to unpack .../32-libdebhelper-perl_13.24.1_all.deb ... Unpacking libdebhelper-perl (13.24.1) ... Selecting previously unselected package libtool. Preparing to unpack .../33-libtool_2.5.4-3_all.deb ... Unpacking libtool (2.5.4-3) ... Selecting previously unselected package dh-autoreconf. Preparing to unpack .../34-dh-autoreconf_20_all.deb ... Unpacking dh-autoreconf (20) ... Selecting previously unselected package libarchive-zip-perl. Preparing to unpack .../35-libarchive-zip-perl_1.68-1_all.deb ... Unpacking libarchive-zip-perl (1.68-1) ... Selecting previously unselected package libfile-stripnondeterminism-perl. Preparing to unpack .../36-libfile-stripnondeterminism-perl_1.14.1-2_all.deb ... Unpacking libfile-stripnondeterminism-perl (1.14.1-2) ... Selecting previously unselected package dh-strip-nondeterminism. Preparing to unpack .../37-dh-strip-nondeterminism_1.14.1-2_all.deb ... Unpacking dh-strip-nondeterminism (1.14.1-2) ... Selecting previously unselected package libelf1t64:arm64. Preparing to unpack .../38-libelf1t64_0.192-4_arm64.deb ... Unpacking libelf1t64:arm64 (0.192-4) ... Selecting previously unselected package dwz. Preparing to unpack .../39-dwz_0.15-1+b1_arm64.deb ... Unpacking dwz (0.15-1+b1) ... Selecting previously unselected package libunistring5:arm64. Preparing to unpack .../40-libunistring5_1.3-1_arm64.deb ... Unpacking libunistring5:arm64 (1.3-1) ... Selecting previously unselected package gettext. Preparing to unpack .../41-gettext_0.23.1-1_arm64.deb ... Unpacking gettext (0.23.1-1) ... Selecting previously unselected package intltool-debian. Preparing to unpack .../42-intltool-debian_0.35.0+20060710.6_all.deb ... Unpacking intltool-debian (0.35.0+20060710.6) ... Selecting previously unselected package po-debconf. Preparing to unpack .../43-po-debconf_1.0.21+nmu1_all.deb ... Unpacking po-debconf (1.0.21+nmu1) ... Selecting previously unselected package debhelper. Preparing to unpack .../44-debhelper_13.24.1_all.deb ... Unpacking debhelper (13.24.1) ... Selecting previously unselected package dh-golang. Preparing to unpack .../45-dh-golang_1.63_all.deb ... Unpacking dh-golang (1.63) ... Selecting previously unselected package golang-1.24-src. Preparing to unpack .../46-golang-1.24-src_1.24.0-1_all.deb ... Unpacking golang-1.24-src (1.24.0-1) ... Selecting previously unselected package golang-1.24-go. Preparing to unpack .../47-golang-1.24-go_1.24.0-1_arm64.deb ... Unpacking golang-1.24-go (1.24.0-1) ... Selecting previously unselected package golang-src. Preparing to unpack .../48-golang-src_2%3a1.24~2_all.deb ... Unpacking golang-src (2:1.24~2) ... Selecting previously unselected package golang-go:arm64. Preparing to unpack .../49-golang-go_2%3a1.24~2_arm64.deb ... Unpacking golang-go:arm64 (2:1.24~2) ... Selecting previously unselected package golang-any:arm64. Preparing to unpack .../50-golang-any_2%3a1.24~2_arm64.deb ... Unpacking golang-any:arm64 (2:1.24~2) ... Selecting previously unselected package golang-golang-x-exp-dev. Preparing to unpack .../51-golang-golang-x-exp-dev_0.0~git20231006.7918f67-1_all.deb ... Unpacking golang-golang-x-exp-dev (0.0~git20231006.7918f67-1) ... Selecting previously unselected package golang-golang-x-sys-dev. Preparing to unpack .../52-golang-golang-x-sys-dev_0.22.0-1_all.deb ... Unpacking golang-golang-x-sys-dev (0.22.0-1) ... Selecting previously unselected package golang-github-cilium-ebpf-dev. Preparing to unpack .../53-golang-github-cilium-ebpf-dev_0.11.0-2_all.deb ... Unpacking golang-github-cilium-ebpf-dev (0.11.0-2) ... Selecting previously unselected package golang-github-pkg-errors-dev. Preparing to unpack .../54-golang-github-pkg-errors-dev_0.9.1-3_all.deb ... Unpacking golang-github-pkg-errors-dev (0.9.1-3) ... Selecting previously unselected package golang-golang-x-term-dev. Preparing to unpack .../55-golang-golang-x-term-dev_0.22.0-1_all.deb ... Unpacking golang-golang-x-term-dev (0.22.0-1) ... Selecting previously unselected package golang-golang-x-text-dev. Preparing to unpack .../56-golang-golang-x-text-dev_0.22.0-1_all.deb ... Unpacking golang-golang-x-text-dev (0.22.0-1) ... Selecting previously unselected package golang-golang-x-crypto-dev. Preparing to unpack .../57-golang-golang-x-crypto-dev_1%3a0.25.0-1_all.deb ... Unpacking golang-golang-x-crypto-dev (1:0.25.0-1) ... Selecting previously unselected package golang-golang-x-net-dev. Preparing to unpack .../58-golang-golang-x-net-dev_1%3a0.27.0-1_all.deb ... Unpacking golang-golang-x-net-dev (1:0.27.0-1) ... Setting up golang-1.24-src (1.24.0-1) ... Setting up libpipeline1:arm64 (1.5.8-1) ... Setting up libicu72:arm64 (72.1-6) ... Setting up bsdextrautils (2.40.4-3) ... Setting up libmagic-mgc (1:5.45-3+b1) ... Setting up libclang-common-19-dev:arm64 (1:19.1.7-1+b1) ... Setting up golang-github-pkg-errors-dev (0.9.1-3) ... Setting up libarchive-zip-perl (1.68-1) ... Setting up libdebhelper-perl (13.24.1) ... Setting up libedit2:arm64 (3.1-20250104-1) ... Setting up golang-golang-x-sys-dev (0.22.0-1) ... Setting up libmagic1t64:arm64 (1:5.45-3+b1) ... Setting up gettext-base (0.23.1-1) ... Setting up m4 (1.4.19-5) ... Setting up binutils-gold-aarch64-linux-gnu (2.44-1) ... Setting up golang-golang-x-term-dev (0.22.0-1) ... Setting up file (1:5.45-3+b1) ... Setting up libelf1t64:arm64 (0.192-4) ... Setting up autotools-dev (20220109.1) ... Setting up libz3-4:arm64 (4.13.3-1) ... Setting up libunistring5:arm64 (1.3-1) ... Setting up autopoint (0.23.1-1) ... Setting up libgc1:arm64 (1:8.2.8-1) ... Setting up autoconf (2.72-3) ... Setting up libffi8:arm64 (3.4.7-1) ... Setting up dwz (0.15-1+b1) ... Setting up sensible-utils (0.0.24) ... Setting up golang-golang-x-text-dev (0.22.0-1) ... Setting up libuchardet0:arm64 (0.0.8-1+b2) ... Setting up golang-golang-x-crypto-dev (1:0.25.0-1) ... Setting up golang-golang-x-exp-dev (0.0~git20231006.7918f67-1) ... Setting up golang-src (2:1.24~2) ... Setting up libxml2:arm64 (2.12.7+dfsg+really2.9.14-0.2+b1) ... Setting up automake (1:1.17-3) ... update-alternatives: using /usr/bin/automake-1.17 to provide /usr/bin/automake (automake) in auto mode Setting up libfile-stripnondeterminism-perl (1.14.1-2) ... Setting up libllvm19:arm64 (1:19.1.7-1+b1) ... Setting up gettext (0.23.1-1) ... Setting up libclang1-19 (1:19.1.7-1+b1) ... Setting up libtool (2.5.4-3) ... Setting up binutils-gold (2.44-1) ... Setting up golang-github-cilium-ebpf-dev (0.11.0-2) ... Setting up libobjc4:arm64 (14.2.0-16) ... Setting up libobjc-14-dev:arm64 (14.2.0-16) ... Setting up intltool-debian (0.35.0+20060710.6) ... Setting up dh-autoreconf (20) ... Setting up golang-1.24-go (1.24.0-1) ... Setting up golang-golang-x-net-dev (1:0.27.0-1) ... Setting up dh-strip-nondeterminism (1.14.1-2) ... Setting up groff-base (1.23.0-7) ... Setting up llvm-19-linker-tools (1:19.1.7-1+b1) ... Setting up libclang-cpp19 (1:19.1.7-1+b1) ... Setting up golang-go:arm64 (2:1.24~2) ... Setting up po-debconf (1.0.21+nmu1) ... Setting up man-db (2.13.0-1) ... Not building database; man-db/auto-update is not 'true'. Setting up clang-19 (1:19.1.7-1+b1) ... Setting up golang-any:arm64 (2:1.24~2) ... Setting up clang (1:19.0-63) ... Setting up debhelper (13.24.1) ... Setting up dh-golang (1.63) ... Processing triggers for libc-bin (2.40-7) ... Reading package lists... Building dependency tree... Reading state information... Reading extended state information... Initializing package states... Writing extended state information... Building tag database... -> Finished parsing the build-deps I: Building the package I: user script /srv/workspace/pbuilder/2844666/tmp/hooks/A99_set_merged_usr starting Not re-configuring usrmerge for trixie I: user script /srv/workspace/pbuilder/2844666/tmp/hooks/A99_set_merged_usr finished hostname: Name or service not known I: Running cd /build/reproducible-path/golang-github-cloudflare-cbpfc-0.0~git20231012.992ed75/ && env PATH="/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/i/capture/the/path" HOME="/nonexistent/second-build" dpkg-buildpackage -us -uc -b && env PATH="/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/i/capture/the/path" HOME="/nonexistent/second-build" dpkg-genchanges -S > ../golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_source.changes dpkg-buildpackage: info: source package golang-github-cloudflare-cbpfc dpkg-buildpackage: info: source version 0.0~git20231012.992ed75-2 dpkg-buildpackage: info: source distribution unstable dpkg-buildpackage: info: source changed by Reinhard Tartler dpkg-source --before-build . dpkg-buildpackage: info: host architecture arm64 debian/rules clean dh clean --builddirectory=_build --buildsystem=golang --with=golang dh_auto_clean -O--builddirectory=_build -O--buildsystem=golang dh_autoreconf_clean -O--builddirectory=_build -O--buildsystem=golang dh_clean -O--builddirectory=_build -O--buildsystem=golang debian/rules binary dh binary --builddirectory=_build --buildsystem=golang --with=golang dh_update_autotools_config -O--builddirectory=_build -O--buildsystem=golang dh_autoreconf -O--builddirectory=_build -O--buildsystem=golang dh_auto_configure -O--builddirectory=_build -O--buildsystem=golang dh_auto_build -O--builddirectory=_build -O--buildsystem=golang cd _build && go install -trimpath -v -p 12 github.com/cloudflare/cbpfc github.com/cloudflare/cbpfc/clang internal/coverage/rtcov internal/byteorder internal/unsafeheader internal/msan internal/goexperiment internal/asan internal/goos internal/cpu internal/profilerecord internal/godebugs internal/goarch cmp internal/itoa internal/runtime/syscall math/bits unicode/utf8 sync/atomic unicode crypto/internal/fips140/alias crypto/internal/boring/sig crypto/internal/fips140/subtle internal/abi internal/chacha8rand internal/runtime/math crypto/internal/fips140deps/byteorder math internal/bytealg crypto/internal/fips140deps/cpu internal/runtime/sys internal/runtime/atomic internal/stringslite internal/runtime/exithook internal/race internal/sync internal/runtime/maps runtime internal/reflectlite iter crypto/subtle sync maps slices errors sort internal/bisect internal/testlog internal/oserror math/rand/v2 io path strconv syscall hash internal/godebug bytes strings crypto/internal/randutil crypto reflect crypto/internal/fips140deps/godebug crypto/internal/impl regexp/syntax crypto/internal/fips140 crypto/internal/fips140/sha256 crypto/internal/fips140/sha3 crypto/internal/fips140/sha512 crypto/internal/fips140/hmac crypto/internal/fips140/check time internal/syscall/execenv internal/syscall/unix crypto/internal/fips140/aes regexp context io/fs internal/poll internal/filepathlite os internal/fmtsort encoding/binary golang.org/x/sys/unix crypto/internal/sysrand io/ioutil fmt path/filepath crypto/internal/entropy crypto/internal/fips140/drbg os/exec crypto/internal/fips140only crypto/internal/fips140/aes/gcm crypto/cipher encoding/hex github.com/pkg/errors golang.org/x/net/bpf net/url text/template/parse crypto/internal/boring github.com/cloudflare/cbpfc/clang crypto/sha1 text/template github.com/cilium/ebpf/internal/unix github.com/cilium/ebpf/internal/sys github.com/cilium/ebpf/asm github.com/cloudflare/cbpfc debian/rules override_dh_auto_test make[1]: Entering directory '/build/reproducible-path/golang-github-cloudflare-cbpfc-0.0~git20231012.992ed75' dh_auto_test -- --short cd _build && go test -vet=off -v -p 12 --short github.com/cloudflare/cbpfc github.com/cloudflare/cbpfc/clang === RUN TestFunctionName --- PASS: TestFunctionName (0.00s) === RUN TestNoInline --- SKIP: TestNoInline (0.16s) === RUN TestZero --- PASS: TestZero (0.00s) === RUN TestRaw --- PASS: TestRaw (0.00s) === RUN TestLoadAbsoluteNegativeOffset --- PASS: TestLoadAbsoluteNegativeOffset (0.00s) === RUN TestExtension --- PASS: TestExtension (0.00s) === RUN TestJumpOut --- PASS: TestJumpOut (0.00s) === RUN TestJumpIfOut --- PASS: TestJumpIfOut (0.00s) === RUN TestJumpIfXOut --- PASS: TestJumpIfXOut (0.00s) === RUN TestFallthroughOut --- PASS: TestFallthroughOut (0.00s) === RUN TestNormalizeJumps --- PASS: TestNormalizeJumps (0.00s) === RUN TestInstructionReadsRegA --- PASS: TestInstructionReadsRegA (0.00s) === RUN TestInstructionWritesRegA --- PASS: TestInstructionWritesRegA (0.00s) === RUN TestInstructionReadsRegX --- PASS: TestInstructionReadsRegX (0.00s) === RUN TestInstructionWritesRegX --- PASS: TestInstructionWritesRegX (0.00s) === RUN TestInstructionReadsScratch --- PASS: TestInstructionReadsScratch (0.00s) === RUN TestInstructionWritesScratch --- PASS: TestInstructionWritesScratch (0.00s) === RUN TestUninitializedReg --- PASS: TestUninitializedReg (0.00s) === RUN TestPartiallyUninitializedReg --- PASS: TestPartiallyUninitializedReg (0.00s) === RUN TestUninitializedScratch --- PASS: TestUninitializedScratch (0.00s) === RUN TestPartiallyUninitializedScratch --- PASS: TestPartiallyUninitializedScratch (0.00s) === RUN TestBlocksJump --- PASS: TestBlocksJump (0.00s) === RUN TestBlocksJumpIf --- PASS: TestBlocksJumpIf (0.00s) === RUN TestBlocksJumpIfX --- PASS: TestBlocksJumpIfX (0.00s) === RUN TestDivisionByZeroImm --- PASS: TestDivisionByZeroImm (0.00s) === RUN TestDivisionByZeroX --- PASS: TestDivisionByZeroX (0.00s) === RUN TestDivisionByZeroXTwice --- PASS: TestDivisionByZeroXTwice (0.00s) === RUN TestDivisionByZeroXConstant --- PASS: TestDivisionByZeroXConstant (0.00s) === RUN TestDivisionByZeroXMemShift --- PASS: TestDivisionByZeroXMemShift (0.00s) === RUN TestDivisionByZeroXTXA --- PASS: TestDivisionByZeroXTXA (0.00s) === RUN TestDivisionByZeroParentsOK --- PASS: TestDivisionByZeroParentsOK (0.00s) === RUN TestDivisionByZeroParentsNOK --- PASS: TestDivisionByZeroParentsNOK (0.00s) === RUN TestRewriteLargePacketOffsets --- PASS: TestRewriteLargePacketOffsets (0.00s) === RUN TestRewriteLargePacketOffsetsDeadBlock === RUN TestRewriteLargePacketOffsetsDeadBlock/C === RUN TestRewriteLargePacketOffsetsDeadBlock/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 6 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemW dst: r4 src: r2 off: 2 imm: 0 6: SwapBE dst: r4 imm: 32 7: JGTImm dst: r4 off: -1 imm: 2 filter_block_2: 8: JLTImm dst: r4 off: -1 imm: 2 filter_block_3: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 0 12: JaImm dst: r0 off: -1 imm: 0 filter_block_8: 13: Mov32Reg dst: r4 src: r4 14: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 15: MovImm dst: r4 imm: 0 16: JaImm dst: r0 off: -1 imm: 0 result: 17: MovImm dst: r0 imm: 2 18: JEqImm dst: r4 off: -1 imm: 0 19: MovImm dst: r0 imm: 1 return: 20: Exit === RUN TestRewriteLargePacketOffsetsDeadBlock/kernel --- PASS: TestRewriteLargePacketOffsetsDeadBlock (0.09s) --- SKIP: TestRewriteLargePacketOffsetsDeadBlock/C (0.04s) --- SKIP: TestRewriteLargePacketOffsetsDeadBlock/eBPF (0.00s) --- PASS: TestRewriteLargePacketOffsetsDeadBlock/kernel (0.05s) === RUN TestAbsoluteGuardSize --- PASS: TestAbsoluteGuardSize (0.00s) === RUN TestNoAbsoluteGuard --- PASS: TestNoAbsoluteGuard (0.00s) === RUN TestAbsoluteGuardParentsOK --- PASS: TestAbsoluteGuardParentsOK (0.00s) === RUN TestAbsoluteGuardParentNoMatch --- PASS: TestAbsoluteGuardParentNoMatch (0.00s) === RUN TestAbsoluteGuardParentDeepNoMatch --- PASS: TestAbsoluteGuardParentDeepNoMatch (0.00s) === RUN TestAbsoluteGuardParentMatch --- PASS: TestAbsoluteGuardParentMatch (0.00s) === RUN TestIndirectGuardSize --- PASS: TestIndirectGuardSize (0.00s) === RUN TestNoIndirectGuard --- PASS: TestNoIndirectGuard (0.00s) === RUN TestIndirectGuardClobber === RUN TestIndirectGuardClobber/constant === RUN TestIndirectGuardClobber/scratch === RUN TestIndirectGuardClobber/memshift --- PASS: TestIndirectGuardClobber (0.00s) --- PASS: TestIndirectGuardClobber/constant (0.00s) --- PASS: TestIndirectGuardClobber/scratch (0.00s) --- PASS: TestIndirectGuardClobber/memshift (0.00s) === RUN TestIndirectGuardClobberLast --- PASS: TestIndirectGuardClobberLast (0.00s) === RUN TestIndirectGuardParentsOK --- PASS: TestIndirectGuardParentsOK (0.00s) === RUN TestIndirectGuardParentNoMatch --- PASS: TestIndirectGuardParentNoMatch (0.00s) === RUN TestIndirectGuardParentDeepNoMatch --- PASS: TestIndirectGuardParentDeepNoMatch (0.00s) === RUN TestIndirectGuardParentMatch --- PASS: TestIndirectGuardParentMatch (0.00s) === RUN TestIndirectGuardParentClobber === RUN TestIndirectGuardParentClobber/constant === RUN TestIndirectGuardParentClobber/scratch === RUN TestIndirectGuardParentClobber/memshift --- PASS: TestIndirectGuardParentClobber (0.00s) --- PASS: TestIndirectGuardParentClobber/constant (0.00s) --- PASS: TestIndirectGuardParentClobber/scratch (0.00s) --- PASS: TestIndirectGuardParentClobber/memshift (0.00s) === RUN TestIndirectGuardExtendClobber === RUN TestIndirectGuardExtendClobber/constant === RUN TestIndirectGuardExtendClobber/scratch === RUN TestIndirectGuardExtendClobber/memshift --- PASS: TestIndirectGuardExtendClobber (0.00s) --- PASS: TestIndirectGuardExtendClobber/constant (0.00s) --- PASS: TestIndirectGuardExtendClobber/scratch (0.00s) --- PASS: TestIndirectGuardExtendClobber/memshift (0.00s) === RUN TestIndirectGuardParentsNotOK --- PASS: TestIndirectGuardParentsNotOK (0.00s) === RUN TestZeroInitA === PAUSE TestZeroInitA === RUN TestZeroInitX === PAUSE TestZeroInitX === RUN TestPartialZeroInitX === PAUSE TestPartialZeroInitX === RUN TestLoadConstantA === PAUSE TestLoadConstantA === RUN TestLoadConstantX === PAUSE TestLoadConstantX === RUN TestLoadAbsolute === PAUSE TestLoadAbsolute === RUN TestLoadAbsoluteBigOffset === PAUSE TestLoadAbsoluteBigOffset === RUN TestLoadIndirect === PAUSE TestLoadIndirect === RUN TestLoadIndirectBigOffset === RUN TestLoadIndirectBigOffset/C === RUN TestLoadIndirectBigOffset/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 0 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: 0 7: JGEImm dst: r7 off: -1 imm: 65535 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 1 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemB dst: r4 src: r7 off: 0 imm: 0 13: Add32Imm dst: r4 imm: 2 14: Mov32Reg dst: r4 src: r4 15: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 16: MovImm dst: r4 imm: 0 17: JaImm dst: r0 off: -1 imm: 0 result: 18: MovImm dst: r0 imm: 2 19: JEqImm dst: r4 off: -1 imm: 0 20: MovImm dst: r0 imm: 1 return: 21: Exit === RUN TestLoadIndirectBigOffset/kernel === RUN TestLoadIndirectBigOffset/C#01 === RUN TestLoadIndirectBigOffset/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 0 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: 0 7: JGEImm dst: r7 off: -1 imm: 65532 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 4 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemW dst: r4 src: r7 off: 0 imm: 0 13: SwapBE dst: r4 imm: 32 14: Add32Imm dst: r4 imm: 2 15: Mov32Reg dst: r4 src: r4 16: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 17: MovImm dst: r4 imm: 0 18: JaImm dst: r0 off: -1 imm: 0 result: 19: MovImm dst: r0 imm: 2 20: JEqImm dst: r4 off: -1 imm: 0 21: MovImm dst: r0 imm: 1 return: 22: Exit === RUN TestLoadIndirectBigOffset/kernel#01 === RUN TestLoadIndirectBigOffset/C#02 === RUN TestLoadIndirectBigOffset/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 0 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: 65534 7: JGEImm dst: r7 off: -1 imm: 65535 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 1 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemB dst: r4 src: r7 off: 0 imm: 0 13: Add32Imm dst: r4 imm: 2 14: Mov32Reg dst: r4 src: r4 15: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 16: MovImm dst: r4 imm: 0 17: JaImm dst: r0 off: -1 imm: 0 result: 18: MovImm dst: r0 imm: 2 19: JEqImm dst: r4 off: -1 imm: 0 20: MovImm dst: r0 imm: 1 return: 21: Exit === RUN TestLoadIndirectBigOffset/kernel#02 === RUN TestLoadIndirectBigOffset/C#03 === RUN TestLoadIndirectBigOffset/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 0 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: 65535 7: JGEImm dst: r7 off: -1 imm: 65535 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 1 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemB dst: r4 src: r7 off: 0 imm: 0 13: Add32Imm dst: r4 imm: 2 14: Mov32Reg dst: r4 src: r4 15: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 16: MovImm dst: r4 imm: 0 17: JaImm dst: r0 off: -1 imm: 0 result: 18: MovImm dst: r0 imm: 2 19: JEqImm dst: r4 off: -1 imm: 0 20: MovImm dst: r0 imm: 1 return: 21: Exit === RUN TestLoadIndirectBigOffset/kernel#03 === RUN TestLoadIndirectBigOffset/C#04 === RUN TestLoadIndirectBigOffset/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 0 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: 65533 7: JGEImm dst: r7 off: -1 imm: 65534 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 2 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemH dst: r4 src: r7 off: 0 imm: 0 13: SwapBE dst: r4 imm: 16 14: Add32Imm dst: r4 imm: 2 15: Mov32Reg dst: r4 src: r4 16: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 17: MovImm dst: r4 imm: 0 18: JaImm dst: r0 off: -1 imm: 0 result: 19: MovImm dst: r0 imm: 2 20: JEqImm dst: r4 off: -1 imm: 0 21: MovImm dst: r0 imm: 1 return: 22: Exit === RUN TestLoadIndirectBigOffset/kernel#04 === RUN TestLoadIndirectBigOffset/C#05 === RUN TestLoadIndirectBigOffset/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 0 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: 65534 7: JGEImm dst: r7 off: -1 imm: 65534 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 2 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemH dst: r4 src: r7 off: 0 imm: 0 13: SwapBE dst: r4 imm: 16 14: Add32Imm dst: r4 imm: 2 15: Mov32Reg dst: r4 src: r4 16: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 17: MovImm dst: r4 imm: 0 18: JaImm dst: r0 off: -1 imm: 0 result: 19: MovImm dst: r0 imm: 2 20: JEqImm dst: r4 off: -1 imm: 0 21: MovImm dst: r0 imm: 1 return: 22: Exit === RUN TestLoadIndirectBigOffset/kernel#05 === RUN TestLoadIndirectBigOffset/C#06 === RUN TestLoadIndirectBigOffset/eBPF#06 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 0 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: 65531 7: JGEImm dst: r7 off: -1 imm: 65532 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 4 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemW dst: r4 src: r7 off: 0 imm: 0 13: SwapBE dst: r4 imm: 32 14: Add32Imm dst: r4 imm: 2 15: Mov32Reg dst: r4 src: r4 16: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 17: MovImm dst: r4 imm: 0 18: JaImm dst: r0 off: -1 imm: 0 result: 19: MovImm dst: r0 imm: 2 20: JEqImm dst: r4 off: -1 imm: 0 21: MovImm dst: r0 imm: 1 return: 22: Exit === RUN TestLoadIndirectBigOffset/kernel#06 === RUN TestLoadIndirectBigOffset/C#07 === RUN TestLoadIndirectBigOffset/eBPF#07 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 0 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: 65532 7: JGEImm dst: r7 off: -1 imm: 65532 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 4 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemW dst: r4 src: r7 off: 0 imm: 0 13: SwapBE dst: r4 imm: 32 14: Add32Imm dst: r4 imm: 2 15: Mov32Reg dst: r4 src: r4 16: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 17: MovImm dst: r4 imm: 0 18: JaImm dst: r0 off: -1 imm: 0 result: 19: MovImm dst: r0 imm: 2 20: JEqImm dst: r4 off: -1 imm: 0 21: MovImm dst: r0 imm: 1 return: 22: Exit === RUN TestLoadIndirectBigOffset/kernel#07 --- PASS: TestLoadIndirectBigOffset (0.82s) --- SKIP: TestLoadIndirectBigOffset/C (0.07s) --- SKIP: TestLoadIndirectBigOffset/eBPF (0.00s) --- PASS: TestLoadIndirectBigOffset/kernel (0.00s) --- SKIP: TestLoadIndirectBigOffset/C#01 (0.07s) --- SKIP: TestLoadIndirectBigOffset/eBPF#01 (0.00s) --- PASS: TestLoadIndirectBigOffset/kernel#01 (0.00s) --- SKIP: TestLoadIndirectBigOffset/C#02 (0.07s) --- SKIP: TestLoadIndirectBigOffset/eBPF#02 (0.00s) --- PASS: TestLoadIndirectBigOffset/kernel#02 (0.05s) --- SKIP: TestLoadIndirectBigOffset/C#03 (0.06s) --- SKIP: TestLoadIndirectBigOffset/eBPF#03 (0.00s) --- PASS: TestLoadIndirectBigOffset/kernel#03 (0.05s) --- SKIP: TestLoadIndirectBigOffset/C#04 (0.06s) --- SKIP: TestLoadIndirectBigOffset/eBPF#04 (0.00s) --- PASS: TestLoadIndirectBigOffset/kernel#04 (0.05s) --- SKIP: TestLoadIndirectBigOffset/C#05 (0.06s) --- SKIP: TestLoadIndirectBigOffset/eBPF#05 (0.00s) --- PASS: TestLoadIndirectBigOffset/kernel#05 (0.05s) --- SKIP: TestLoadIndirectBigOffset/C#06 (0.07s) --- SKIP: TestLoadIndirectBigOffset/eBPF#06 (0.00s) --- PASS: TestLoadIndirectBigOffset/kernel#06 (0.05s) --- SKIP: TestLoadIndirectBigOffset/C#07 (0.06s) --- SKIP: TestLoadIndirectBigOffset/eBPF#07 (0.00s) --- PASS: TestLoadIndirectBigOffset/kernel#07 (0.05s) === RUN TestLoadIndirectGuardOverflow === RUN TestLoadIndirectGuardOverflow/C === RUN TestLoadIndirectGuardOverflow/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 4 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemW dst: r4 src: r2 off: 0 imm: 0 6: SwapBE dst: r4 imm: 32 7: Mov32Reg dst: r5 src: r4 8: MovReg dst: r7 src: r5 9: LShImm dst: r7 imm: 32 10: ArShImm dst: r7 imm: 32 11: AddImm dst: r7 imm: -2147483648 12: JGEImm dst: r7 off: -1 imm: 0 13: AddReg dst: r7 src: r2 14: MovReg dst: r6 src: r7 15: AddImm dst: r6 imm: 3 16: JGTReg dst: r6 off: -1 src: r3 17: LdXMemB dst: r4 src: r7 off: 0 imm: 0 18: MovReg dst: r6 src: r7 19: AddImm dst: r6 imm: -2147483648 20: LdXMemH dst: r4 src: r6 off: 0 imm: 0 21: SwapBE dst: r4 imm: 16 22: LdXMemW dst: r4 src: r7 off: -1 imm: 0 23: SwapBE dst: r4 imm: 32 24: Mov32Reg dst: r4 src: r5 25: Mov32Reg dst: r4 src: r4 26: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 27: MovImm dst: r4 imm: 0 28: JaImm dst: r0 off: -1 imm: 0 result: 29: MovImm dst: r0 imm: 2 30: JEqImm dst: r4 off: -1 imm: 0 31: MovImm dst: r0 imm: 1 return: 32: Exit === RUN TestLoadIndirectGuardOverflow/kernel --- PASS: TestLoadIndirectGuardOverflow (0.12s) --- SKIP: TestLoadIndirectGuardOverflow/C (0.07s) --- SKIP: TestLoadIndirectGuardOverflow/eBPF (0.00s) --- PASS: TestLoadIndirectGuardOverflow/kernel (0.05s) === RUN TestScratchZero === PAUSE TestScratchZero === RUN TestScratchA === PAUSE TestScratchA === RUN TestScratchX === PAUSE TestScratchX === RUN TestMemShift === PAUSE TestMemShift === RUN TestLoadExtLen === PAUSE TestLoadExtLen === RUN TestALUAdd === PAUSE TestALUAdd === RUN TestALUSub === PAUSE TestALUSub === RUN TestALUMul === PAUSE TestALUMul === RUN TestALUDiv === PAUSE TestALUDiv === RUN TestALUDivZero === PAUSE TestALUDivZero === RUN TestALUDivNegative === RUN TestALUDivNegative/C === RUN TestALUDivNegative/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 4 3: Mov32Imm dst: r5 imm: -2 4: JEqImm dst: r5 off: -1 imm: 0 5: Div32Reg dst: r4 src: r5 6: JEqImm dst: r4 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 0 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 1 10: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 11: MovImm dst: r4 imm: 0 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestALUDivNegative/kernel --- PASS: TestALUDivNegative (0.06s) --- SKIP: TestALUDivNegative/C (0.06s) --- SKIP: TestALUDivNegative/eBPF (0.00s) --- PASS: TestALUDivNegative/kernel (0.00s) === RUN TestALUOr === PAUSE TestALUOr === RUN TestALUAnd === PAUSE TestALUAnd === RUN TestALUShiftLeft === PAUSE TestALUShiftLeft === RUN TestALUShiftRight === PAUSE TestALUShiftRight === RUN TestALUMod === PAUSE TestALUMod === RUN TestALUXor === PAUSE TestALUXor === RUN TestNegateA === PAUSE TestNegateA === RUN TestJump === PAUSE TestJump === RUN TestJump0 === PAUSE TestJump0 === RUN TestJumpIfEqual === PAUSE TestJumpIfEqual === RUN TestJumpIfNotEqual === PAUSE TestJumpIfNotEqual === RUN TestJumpIfGreaterThan === PAUSE TestJumpIfGreaterThan === RUN TestJumpIfLessThan === PAUSE TestJumpIfLessThan === RUN TestJumpIfGreaterOrEqual === PAUSE TestJumpIfGreaterOrEqual === RUN TestJumpIfLessOrEqual === PAUSE TestJumpIfLessOrEqual === RUN TestJumpIfBitsSet === PAUSE TestJumpIfBitsSet === RUN TestJumpIfBitsNotSet === PAUSE TestJumpIfBitsNotSet === RUN TestRetA === PAUSE TestRetA === RUN TestRetConstant === PAUSE TestRetConstant === RUN TestTXA === PAUSE TestTXA === RUN TestTAX === PAUSE TestTAX === CONT TestZeroInitA === CONT TestTAX === RUN TestZeroInitA/C === CONT TestTXA === RUN TestTXA/C === RUN TestTAX/C === CONT TestJumpIfEqual === CONT TestJumpIfLessOrEqual === CONT TestJumpIfGreaterOrEqual === RUN TestJumpIfEqual/C === RUN TestJumpIfGreaterOrEqual/C === CONT TestALUAnd === RUN TestALUAnd/C === CONT TestJumpIfNotEqual === RUN TestJumpIfNotEqual/C === RUN TestJumpIfLessOrEqual/C === CONT TestRetConstant === RUN TestRetConstant/C === CONT TestJumpIfBitsNotSet === RUN TestJumpIfBitsNotSet/C === CONT TestJumpIfBitsSet === RUN TestJumpIfBitsSet/C === CONT TestRetA === RUN TestRetA/C === RUN TestJumpIfNotEqual/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JNEImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfNotEqual/kernel === RUN TestJumpIfLessOrEqual/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: JLEImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfLessOrEqual/kernel === RUN TestALUAnd/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: And32Imm dst: r4 imm: 0 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUAnd/kernel === RUN TestALUAnd/C#01 === RUN TestJumpIfEqual/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JEqImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfEqual/kernel === RUN TestJumpIfEqual/C#01 === RUN TestTAX/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: Mov32Reg dst: r5 src: r4 4: Mov32Reg dst: r4 src: r5 5: Mov32Reg dst: r4 src: r4 6: JaImm dst: r0 off: -1 imm: 0 result: 7: MovImm dst: r0 imm: 2 8: JEqImm dst: r4 off: -1 imm: 0 9: MovImm dst: r0 imm: 1 return: 10: Exit === RUN TestTAX/kernel --- PASS: TestTAX (0.06s) --- SKIP: TestTAX/C (0.06s) --- SKIP: TestTAX/eBPF (0.00s) --- PASS: TestTAX/kernel (0.00s) === CONT TestScratchX === RUN TestScratchX/C === RUN TestZeroInitA/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 0 3: Mov32Reg dst: r4 src: r4 4: JaImm dst: r0 off: -1 imm: 0 result: 5: MovImm dst: r0 imm: 2 6: JEqImm dst: r4 off: -1 imm: 0 7: MovImm dst: r0 imm: 1 return: 8: Exit === RUN TestZeroInitA/kernel === RUN TestJumpIfGreaterOrEqual/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: JGEImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfGreaterOrEqual/kernel === RUN TestJumpIfGreaterOrEqual/C#01 === RUN TestTXA/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 1 3: Mov32Reg dst: r4 src: r5 4: Mov32Reg dst: r4 src: r4 5: JaImm dst: r0 off: -1 imm: 0 result: 6: MovImm dst: r0 imm: 2 7: JEqImm dst: r4 off: -1 imm: 0 8: MovImm dst: r0 imm: 1 return: 9: Exit === RUN TestTXA/kernel --- PASS: TestTXA (0.07s) --- SKIP: TestTXA/C (0.07s) --- SKIP: TestTXA/eBPF (0.00s) --- PASS: TestTXA/kernel (0.00s) === CONT TestALUOr === RUN TestALUOr/C === RUN TestRetConstant/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: JaImm dst: r0 off: -1 imm: 0 result: 4: MovImm dst: r0 imm: 2 5: JEqImm dst: r4 off: -1 imm: 0 6: MovImm dst: r0 imm: 1 return: 7: Exit === RUN TestRetConstant/kernel === RUN TestRetConstant/C#01 === RUN TestJumpIfBitsSet/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: JSetImm dst: r4 off: -1 imm: 4 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfBitsSet/kernel === RUN TestJumpIfBitsSet/C#01 === RUN TestJumpIfBitsNotSet/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: JSetImm dst: r4 off: -1 imm: 4 4: JaImm dst: r0 off: -1 imm: 0 filter_block_2: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfBitsNotSet/kernel === RUN TestJumpIfLessOrEqual/C#01 === RUN TestJumpIfNotEqual/C#01 === RUN TestJumpIfEqual/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JEqImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfEqual/kernel#01 === RUN TestJumpIfEqual/C#02 --- PASS: TestZeroInitA (0.11s) --- SKIP: TestZeroInitA/C (0.06s) --- SKIP: TestZeroInitA/eBPF (0.00s) --- PASS: TestZeroInitA/kernel (0.05s) === CONT TestALUDivZero === RUN TestALUDivZero/C === RUN TestRetA/eBPF === RUN TestALUAnd/eBPF#01 === NAME TestRetA/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: Mov32Reg dst: r4 src: r4 4: JaImm dst: r0 off: -1 imm: 0 result: 5: MovImm dst: r0 imm: 2 6: JEqImm dst: r4 off: -1 imm: 0 7: MovImm dst: r0 imm: 1 return: 8: Exit === RUN TestRetA/kernel === NAME TestALUAnd/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: Mov32Imm dst: r5 imm: 0 4: And32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 0 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUAnd/kernel#01 --- PASS: TestRetA (0.07s) --- SKIP: TestRetA/C (0.06s) --- SKIP: TestRetA/eBPF (0.00s) --- PASS: TestRetA/kernel (0.00s) === CONT TestALUDiv === RUN TestALUDiv/C === RUN TestALUAnd/C#02 === RUN TestJumpIfGreaterOrEqual/eBPF#01 === RUN TestALUOr/eBPF === NAME TestJumpIfGreaterOrEqual/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JGEImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfGreaterOrEqual/kernel#01 === NAME TestALUOr/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: Or32Imm dst: r4 imm: 0 4: JEqImm dst: r4 off: -1 imm: 1 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUOr/kernel === RUN TestJumpIfGreaterOrEqual/C#02 === RUN TestALUOr/C#01 === RUN TestScratchX/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: -559038737 3: StXMemW dst: rfp src: r5 off: -32 imm: 0 4: Mov32Imm dst: r5 imm: 0 5: Mov32Imm dst: r5 imm: -1 6: StXMemW dst: rfp src: r5 off: -28 imm: 0 7: Mov32Imm dst: r5 imm: -1 8: StXMemW dst: rfp src: r5 off: -36 imm: 0 9: LdXMemW dst: r5 src: rfp off: -32 imm: 0 10: Mov32Reg dst: r4 src: r5 11: Mov32Imm dst: r6 imm: -559038737 12: JEqReg dst: r4 off: -1 src: r6 filter_block_10: 13: Mov32Imm dst: r4 imm: 0 14: JaImm dst: r0 off: -1 imm: 0 filter_block_11: 15: Mov32Imm dst: r4 imm: 1 16: JaImm dst: r0 off: -1 imm: 0 result: 17: MovImm dst: r0 imm: 2 18: JEqImm dst: r4 off: -1 imm: 0 19: MovImm dst: r0 imm: 1 return: 20: Exit === RUN TestScratchX/kernel === RUN TestScratchX/C#01 === RUN TestRetConstant/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 0 3: JaImm dst: r0 off: -1 imm: 0 result: 4: MovImm dst: r0 imm: 2 5: JEqImm dst: r4 off: -1 imm: 0 6: MovImm dst: r0 imm: 1 return: 7: Exit === RUN TestRetConstant/kernel#01 === RUN TestJumpIfBitsSet/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JSetImm dst: r4 off: -1 imm: 4 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfBitsSet/kernel#01 === RUN TestJumpIfBitsSet/C#02 === RUN TestJumpIfEqual/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 23 4: JEqReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfEqual/kernel#02 === RUN TestJumpIfEqual/C#03 === RUN TestJumpIfBitsNotSet/C#01 === RUN TestJumpIfNotEqual/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JNEImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfNotEqual/kernel#01 === RUN TestALUDivZero/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 1 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemB dst: r4 src: r2 off: 0 imm: 0 6: Mov32Reg dst: r5 src: r4 7: Mov32Imm dst: r4 imm: 10 8: JEqImm dst: r5 off: -1 imm: 0 9: Div32Reg dst: r4 src: r5 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 12: MovImm dst: r4 imm: 0 13: JaImm dst: r0 off: -1 imm: 0 result: 14: MovImm dst: r0 imm: 2 15: JEqImm dst: r4 off: -1 imm: 0 16: MovImm dst: r0 imm: 1 return: 17: Exit === RUN TestALUDivZero/kernel === RUN TestJumpIfLessOrEqual/eBPF#01 === RUN TestALUAnd/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 240 3: And32Imm dst: r4 imm: 128 4: JEqImm dst: r4 off: -1 imm: 128 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUAnd/kernel#02 === RUN TestALUAnd/C#03 === NAME TestJumpIfLessOrEqual/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JLEImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfLessOrEqual/kernel#01 === RUN TestALUDiv/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 2 3: Div32Imm dst: r4 imm: 2 4: JEqImm dst: r4 off: -1 imm: 1 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUDiv/kernel === RUN TestALUDiv/C#01 === RUN TestScratchX/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 0 3: StXMemW dst: rfp src: r5 off: -32 imm: 0 4: Mov32Imm dst: r5 imm: 0 5: Mov32Imm dst: r5 imm: -1 6: StXMemW dst: rfp src: r5 off: -28 imm: 0 7: Mov32Imm dst: r5 imm: -1 8: StXMemW dst: rfp src: r5 off: -36 imm: 0 9: LdXMemW dst: r5 src: rfp off: -32 imm: 0 10: Mov32Reg dst: r4 src: r5 11: JEqImm dst: r4 off: -1 imm: 0 filter_block_10: 12: Mov32Imm dst: r4 imm: 0 13: JaImm dst: r0 off: -1 imm: 0 filter_block_11: 14: Mov32Imm dst: r4 imm: 1 15: JaImm dst: r0 off: -1 imm: 0 result: 16: MovImm dst: r0 imm: 2 17: JEqImm dst: r4 off: -1 imm: 0 18: MovImm dst: r0 imm: 1 return: 19: Exit === RUN TestScratchX/kernel#01 --- PASS: TestScratchX (0.11s) --- SKIP: TestScratchX/C (0.07s) --- SKIP: TestScratchX/eBPF (0.00s) --- PASS: TestScratchX/kernel (0.00s) --- SKIP: TestScratchX/C#01 (0.04s) --- SKIP: TestScratchX/eBPF#01 (0.00s) --- PASS: TestScratchX/kernel#01 (0.00s) === CONT TestALUMul === RUN TestALUMul/C === RUN TestJumpIfGreaterOrEqual/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: Mov32Imm dst: r5 imm: 23 4: JGEReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfGreaterOrEqual/kernel#02 === RUN TestJumpIfGreaterOrEqual/C#03 === RUN TestALUOr/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: Mov32Imm dst: r5 imm: 0 4: Or32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 1 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUOr/kernel#01 === RUN TestALUOr/C#02 --- PASS: TestRetConstant (0.18s) --- SKIP: TestRetConstant/C (0.07s) --- SKIP: TestRetConstant/eBPF (0.00s) --- PASS: TestRetConstant/kernel (0.00s) --- SKIP: TestRetConstant/C#01 (0.06s) --- SKIP: TestRetConstant/eBPF#01 (0.00s) --- PASS: TestRetConstant/kernel#01 (0.05s) === CONT TestALUSub === RUN TestALUSub/C === RUN TestJumpIfEqual/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JEqReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfEqual/kernel#03 === RUN TestJumpIfEqual/C#04 === RUN TestJumpIfBitsSet/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: Mov32Imm dst: r5 imm: 4 4: JSetReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfBitsSet/kernel#02 === RUN TestJumpIfBitsSet/C#03 === RUN TestJumpIfBitsNotSet/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JSetImm dst: r4 off: -1 imm: 4 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfBitsNotSet/kernel#01 === RUN TestALUAnd/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 240 3: Mov32Imm dst: r5 imm: 128 4: And32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 128 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUAnd/kernel#03 === RUN TestALUAnd/C#04 === RUN TestJumpIfNotEqual/C#02 === RUN TestALUDiv/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 2 3: Mov32Imm dst: r5 imm: 2 4: JEqImm dst: r5 off: -1 imm: 0 5: Div32Reg dst: r4 src: r5 6: JEqImm dst: r4 off: -1 imm: 1 filter_block_4: 7: Mov32Imm dst: r4 imm: 0 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 1 10: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 11: MovImm dst: r4 imm: 0 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestALUDiv/kernel#01 === RUN TestALUDiv/C#02 === RUN TestALUDivZero/C#01 === RUN TestJumpIfLessOrEqual/C#02 === RUN TestALUSub/eBPF === RUN TestALUOr/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 240 3: Or32Imm dst: r4 imm: 15 4: JEqImm dst: r4 off: -1 imm: 255 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUOr/kernel#02 === RUN TestALUMul/eBPF === RUN TestALUOr/C#03 === NAME TestALUMul/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 0 3: Mul32Imm dst: r4 imm: 1 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUMul/kernel === RUN TestALUMul/C#01 === NAME TestALUSub/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: Sub32Imm dst: r4 imm: 1 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUSub/kernel === RUN TestALUSub/C#01 === RUN TestJumpIfEqual/eBPF#04 === RUN TestJumpIfGreaterOrEqual/eBPF#03 === NAME TestJumpIfEqual/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JEqImm dst: r4 off: -1 imm: 21 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfEqual/kernel#04 === NAME TestJumpIfGreaterOrEqual/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JGEReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfGreaterOrEqual/kernel#03 === RUN TestJumpIfGreaterOrEqual/C#04 === RUN TestALUAnd/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 240 3: And32Imm dst: r4 imm: 15 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUAnd/kernel#04 === RUN TestALUAnd/C#05 === RUN TestJumpIfBitsNotSet/C#02 === RUN TestJumpIfNotEqual/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 23 4: JNEReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfNotEqual/kernel#02 === RUN TestALUDiv/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 19 3: Div32Imm dst: r4 imm: 3 4: JEqImm dst: r4 off: -1 imm: 6 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUDiv/kernel#02 === RUN TestALUDiv/C#03 === RUN TestJumpIfBitsSet/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: Mov32Imm dst: r5 imm: 4 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JSetReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfBitsSet/kernel#03 === RUN TestALUMul/eBPF#01 === RUN TestALUOr/eBPF#03 === RUN TestALUDivZero/eBPF#01 === NAME TestALUMul/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 0 3: Mov32Imm dst: r5 imm: 1 4: Mul32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 0 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestJumpIfBitsSet/C#04 === NAME TestALUOr/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 240 3: Mov32Imm dst: r5 imm: 15 4: Or32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 255 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUMul/kernel#01 === RUN TestALUOr/kernel#03 === NAME TestALUDivZero/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 1 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemB dst: r4 src: r2 off: 0 imm: 0 6: Mov32Reg dst: r5 src: r4 7: Mov32Imm dst: r4 imm: 10 8: JEqImm dst: r5 off: -1 imm: 0 9: Div32Reg dst: r4 src: r5 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 12: MovImm dst: r4 imm: 0 13: JaImm dst: r0 off: -1 imm: 0 result: 14: MovImm dst: r0 imm: 2 15: JEqImm dst: r4 off: -1 imm: 0 16: MovImm dst: r0 imm: 1 return: 17: Exit === RUN TestALUDivZero/kernel#01 --- PASS: TestALUOr (0.19s) --- SKIP: TestALUOr/C (0.06s) --- SKIP: TestALUOr/eBPF (0.00s) --- PASS: TestALUOr/kernel (0.00s) --- SKIP: TestALUOr/C#01 (0.05s) --- SKIP: TestALUOr/eBPF#01 (0.00s) --- PASS: TestALUOr/kernel#01 (0.00s) --- SKIP: TestALUOr/C#02 (0.04s) --- SKIP: TestALUOr/eBPF#02 (0.00s) --- PASS: TestALUOr/kernel#02 (0.00s) --- SKIP: TestALUOr/C#03 (0.04s) --- SKIP: TestALUOr/eBPF#03 (0.00s) --- PASS: TestALUOr/kernel#03 (0.00s) === RUN TestALUMul/C#02 === CONT TestALUAdd === RUN TestALUAdd/C --- PASS: TestALUDivZero (0.15s) --- SKIP: TestALUDivZero/C (0.05s) --- SKIP: TestALUDivZero/eBPF (0.00s) --- PASS: TestALUDivZero/kernel (0.06s) --- SKIP: TestALUDivZero/C#01 (0.05s) --- SKIP: TestALUDivZero/eBPF#01 (0.00s) --- PASS: TestALUDivZero/kernel#01 (0.00s) === CONT TestLoadExtLen === RUN TestLoadExtLen/C === RUN TestJumpIfLessOrEqual/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: Mov32Imm dst: r5 imm: 23 4: JLEReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfLessOrEqual/kernel#02 === RUN TestJumpIfGreaterOrEqual/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JGEImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfGreaterOrEqual/kernel#04 === RUN TestJumpIfGreaterOrEqual/C#05 === RUN TestJumpIfBitsNotSet/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: Mov32Imm dst: r5 imm: 4 4: JSetReg dst: r4 off: -1 src: r5 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestJumpIfBitsNotSet/kernel#02 === RUN TestALUSub/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: Mov32Imm dst: r5 imm: 1 4: Sub32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 0 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUSub/kernel#01 === RUN TestALUSub/C#02 === RUN TestALUAnd/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 240 3: Mov32Imm dst: r5 imm: 15 4: And32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 0 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUAnd/kernel#05 --- PASS: TestALUAnd (0.29s) --- SKIP: TestALUAnd/C (0.06s) --- SKIP: TestALUAnd/eBPF (0.00s) --- PASS: TestALUAnd/kernel (0.00s) --- SKIP: TestALUAnd/C#01 (0.05s) --- SKIP: TestALUAnd/eBPF#01 (0.00s) --- PASS: TestALUAnd/kernel#01 (0.00s) --- SKIP: TestALUAnd/C#02 (0.05s) --- SKIP: TestALUAnd/eBPF#02 (0.00s) --- PASS: TestALUAnd/kernel#02 (0.00s) --- SKIP: TestALUAnd/C#03 (0.04s) --- SKIP: TestALUAnd/eBPF#03 (0.00s) --- PASS: TestALUAnd/kernel#03 (0.00s) --- SKIP: TestALUAnd/C#04 (0.04s) --- SKIP: TestALUAnd/eBPF#04 (0.00s) --- PASS: TestALUAnd/kernel#04 (0.00s) --- SKIP: TestALUAnd/C#05 (0.04s) --- SKIP: TestALUAnd/eBPF#05 (0.00s) --- PASS: TestALUAnd/kernel#05 (0.00s) === CONT TestMemShift === RUN TestMemShift/C === RUN TestJumpIfEqual/C#05 === RUN TestALUDiv/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 19 3: Mov32Imm dst: r5 imm: 3 4: JEqImm dst: r5 off: -1 imm: 0 5: Div32Reg dst: r4 src: r5 6: JEqImm dst: r4 off: -1 imm: 6 filter_block_4: 7: Mov32Imm dst: r4 imm: 0 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 1 10: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 11: MovImm dst: r4 imm: 0 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestALUDiv/kernel#03 === RUN TestALUAdd/eBPF --- PASS: TestALUDiv (0.19s) --- SKIP: TestALUDiv/C (0.05s) --- SKIP: TestALUDiv/eBPF (0.00s) --- PASS: TestALUDiv/kernel (0.00s) --- SKIP: TestALUDiv/C#01 (0.04s) --- SKIP: TestALUDiv/eBPF#01 (0.00s) --- PASS: TestALUDiv/kernel#01 (0.00s) --- SKIP: TestALUDiv/C#02 (0.05s) --- SKIP: TestALUDiv/eBPF#02 (0.00s) --- PASS: TestALUDiv/kernel#02 (0.00s) --- SKIP: TestALUDiv/C#03 (0.04s) --- SKIP: TestALUDiv/eBPF#03 (0.00s) --- PASS: TestALUDiv/kernel#03 (0.00s) === CONT TestJumpIfLessThan === RUN TestJumpIfLessThan/C === NAME TestALUAdd/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: Add32Imm dst: r4 imm: 0 4: JEqImm dst: r4 off: -1 imm: 1 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUAdd/kernel === RUN TestALUAdd/C#01 === RUN TestLoadExtLen/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r4 src: r3 3: Sub32Reg dst: r4 src: r2 4: JEqImm dst: r4 off: -1 imm: 16 filter_block_2: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestLoadExtLen/kernel === RUN TestJumpIfBitsSet/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: JSetImm dst: r4 off: -1 imm: 2 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfBitsSet/kernel#04 --- PASS: TestLoadExtLen (0.04s) --- SKIP: TestLoadExtLen/C (0.04s) --- SKIP: TestLoadExtLen/eBPF (0.00s) --- PASS: TestLoadExtLen/kernel (0.00s) === CONT TestLoadAbsolute === RUN TestLoadAbsolute/C === RUN TestJumpIfBitsSet/C#05 === RUN TestALUMul/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 4 3: Mul32Imm dst: r4 imm: 13 4: JEqImm dst: r4 off: -1 imm: 52 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUMul/kernel#02 === RUN TestALUMul/C#03 === RUN TestJumpIfNotEqual/C#03 === RUN TestJumpIfGreaterOrEqual/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JGEImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfGreaterOrEqual/kernel#05 === RUN TestJumpIfGreaterOrEqual/C#06 === RUN TestJumpIfLessOrEqual/C#03 === RUN TestALUSub/eBPF#02 === RUN TestMemShift/eBPF === NAME TestALUSub/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 13 3: Sub32Imm dst: r4 imm: 9 4: JEqImm dst: r4 off: -1 imm: 4 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUSub/kernel#02 === NAME TestMemShift/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 3 4: JGTReg dst: r6 off: -1 src: r3 5: Mov32Imm dst: r4 imm: 40 6: LdXMemB dst: r5 src: r2 off: 2 imm: 0 7: And32Imm dst: r5 imm: 15 8: LSh32Imm dst: r5 imm: 2 9: JEqReg dst: r4 off: -1 src: r5 filter_block_3: 10: Mov32Imm dst: r4 imm: 0 11: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 12: Mov32Imm dst: r4 imm: 1 13: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 14: MovImm dst: r4 imm: 0 15: JaImm dst: r0 off: -1 imm: 0 result: 16: MovImm dst: r0 imm: 2 17: JEqImm dst: r4 off: -1 imm: 0 18: MovImm dst: r0 imm: 1 return: 19: Exit === RUN TestMemShift/kernel === RUN TestALUSub/C#03 === RUN TestMemShift/C#01 === RUN TestJumpIfEqual/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JEqImm dst: r4 off: -1 imm: 21 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfEqual/kernel#05 === RUN TestJumpIfBitsNotSet/C#03 === RUN TestJumpIfLessThan/eBPF === RUN TestJumpIfBitsSet/eBPF#05 === NAME TestJumpIfLessThan/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: JLTImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfLessThan/kernel === RUN TestJumpIfNotEqual/eBPF#03 === RUN TestLoadAbsolute/eBPF === RUN TestALUAdd/eBPF#01 === NAME TestJumpIfBitsSet/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JSetImm dst: r4 off: -1 imm: 2 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfBitsSet/kernel#05 === RUN TestJumpIfBitsSet/C#06 === RUN TestALUMul/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 4 3: Mov32Imm dst: r5 imm: 13 4: Mul32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 52 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUMul/kernel#03 === RUN TestALUMul/C#04 === NAME TestJumpIfNotEqual/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JNEReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfNotEqual/kernel#03 === NAME TestLoadAbsolute/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 3 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemB dst: r4 src: r2 off: 2 imm: 0 6: JEqImm dst: r4 off: -1 imm: 5 filter_block_2: 7: Mov32Imm dst: r4 imm: 0 8: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 9: Mov32Imm dst: r4 imm: 1 10: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 11: MovImm dst: r4 imm: 0 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestLoadAbsolute/kernel === NAME TestALUAdd/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: Mov32Imm dst: r5 imm: 0 4: Add32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 1 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUAdd/kernel#01 === RUN TestLoadAbsolute/C#01 === RUN TestALUAdd/C#02 === RUN TestJumpIfGreaterOrEqual/eBPF#06 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 23 4: JGEReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfGreaterOrEqual/kernel#06 === RUN TestJumpIfGreaterOrEqual/C#07 === RUN TestALUSub/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 13 3: Mov32Imm dst: r5 imm: 9 4: Sub32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 4 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUSub/kernel#03 --- PASS: TestALUSub (0.18s) --- SKIP: TestALUSub/C (0.04s) --- SKIP: TestALUSub/eBPF (0.00s) --- PASS: TestALUSub/kernel (0.00s) --- SKIP: TestALUSub/C#01 (0.06s) --- SKIP: TestALUSub/eBPF#01 (0.00s) --- PASS: TestALUSub/kernel#01 (0.00s) --- SKIP: TestALUSub/C#02 (0.04s) --- SKIP: TestALUSub/eBPF#02 (0.00s) --- PASS: TestALUSub/kernel#02 (0.00s) --- SKIP: TestALUSub/C#03 (0.04s) --- SKIP: TestALUSub/eBPF#03 (0.00s) --- PASS: TestALUSub/kernel#03 (0.00s) === CONT TestScratchA === RUN TestScratchA/C === RUN TestJumpIfLessOrEqual/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JLEReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfLessOrEqual/kernel#03 === RUN TestMemShift/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 3 4: JGTReg dst: r6 off: -1 src: r3 5: Mov32Imm dst: r4 imm: 0 6: LdXMemB dst: r5 src: r2 off: 2 imm: 0 7: And32Imm dst: r5 imm: 15 8: LSh32Imm dst: r5 imm: 2 9: JEqReg dst: r4 off: -1 src: r5 filter_block_3: 10: Mov32Imm dst: r4 imm: 0 11: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 12: Mov32Imm dst: r4 imm: 1 13: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 14: MovImm dst: r4 imm: 0 15: JaImm dst: r0 off: -1 imm: 0 result: 16: MovImm dst: r0 imm: 2 17: JEqImm dst: r4 off: -1 imm: 0 18: MovImm dst: r0 imm: 1 return: 19: Exit === RUN TestMemShift/kernel#01 --- PASS: TestMemShift (0.08s) --- SKIP: TestMemShift/C (0.04s) --- SKIP: TestMemShift/eBPF (0.00s) --- PASS: TestMemShift/kernel (0.00s) --- SKIP: TestMemShift/C#01 (0.04s) --- SKIP: TestMemShift/eBPF#01 (0.00s) --- PASS: TestMemShift/kernel#01 (0.00s) === CONT TestScratchZero === RUN TestScratchZero/C === RUN TestJumpIfBitsSet/eBPF#06 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: Mov32Imm dst: r5 imm: 2 4: JSetReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfBitsSet/kernel#06 === RUN TestJumpIfBitsSet/C#07 === RUN TestJumpIfEqual/C#06 === RUN TestJumpIfBitsNotSet/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: Mov32Imm dst: r5 imm: 4 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JSetReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfBitsNotSet/kernel#03 === RUN TestALUMul/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 2 3: Mul32Imm dst: r4 imm: -2147483648 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUMul/kernel#04 === RUN TestALUMul/C#05 === RUN TestLoadAbsolute/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 3 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemB dst: r4 src: r2 off: 2 imm: 0 6: JEqImm dst: r4 off: -1 imm: 6 filter_block_2: 7: Mov32Imm dst: r4 imm: 0 8: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 9: Mov32Imm dst: r4 imm: 1 10: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 11: MovImm dst: r4 imm: 0 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestLoadAbsolute/kernel#01 === RUN TestJumpIfGreaterOrEqual/eBPF#07 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JGEReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfGreaterOrEqual/kernel#07 === RUN TestJumpIfGreaterOrEqual/C#08 === RUN TestALUAdd/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 4 3: Add32Imm dst: r4 imm: 13 4: JEqImm dst: r4 off: -1 imm: 17 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUAdd/kernel#02 === RUN TestALUAdd/C#03 === RUN TestScratchA/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: -559038737 3: StXMemW dst: rfp src: r4 off: -32 imm: 0 4: Mov32Imm dst: r4 imm: 0 5: Mov32Imm dst: r4 imm: -1 6: StXMemW dst: rfp src: r4 off: -28 imm: 0 7: Mov32Imm dst: r4 imm: -1 8: StXMemW dst: rfp src: r4 off: -36 imm: 0 9: LdXMemW dst: r4 src: rfp off: -32 imm: 0 10: Mov32Imm dst: r6 imm: -559038737 11: JEqReg dst: r4 off: -1 src: r6 filter_block_9: 12: Mov32Imm dst: r4 imm: 0 13: JaImm dst: r0 off: -1 imm: 0 filter_block_10: 14: Mov32Imm dst: r4 imm: 1 15: JaImm dst: r0 off: -1 imm: 0 result: 16: MovImm dst: r0 imm: 2 17: JEqImm dst: r4 off: -1 imm: 0 18: MovImm dst: r0 imm: 1 return: 19: Exit === RUN TestScratchA/kernel === RUN TestScratchA/C#01 === RUN TestJumpIfLessThan/C#01 === RUN TestJumpIfNotEqual/C#04 === RUN TestScratchZero/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 4 3: StXMemW dst: rfp src: r4 off: -4 imm: 0 4: Mov32Imm dst: r4 imm: 0 5: LdXMemW dst: r4 src: rfp off: -4 imm: 0 6: JEqImm dst: r4 off: -1 imm: 4 filter_block_5: 7: Mov32Imm dst: r4 imm: 0 8: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 9: Mov32Imm dst: r4 imm: 1 10: JaImm dst: r0 off: -1 imm: 0 result: 11: MovImm dst: r0 imm: 2 12: JEqImm dst: r4 off: -1 imm: 0 13: MovImm dst: r0 imm: 1 return: 14: Exit === RUN TestScratchZero/kernel --- PASS: TestScratchZero (0.04s) --- SKIP: TestScratchZero/C (0.04s) --- SKIP: TestScratchZero/eBPF (0.00s) --- PASS: TestScratchZero/kernel (0.00s) === CONT TestLoadIndirect === RUN TestLoadIndirect/constant_valid === RUN TestLoadIndirect/constant_valid/C === RUN TestJumpIfLessOrEqual/C#04 === RUN TestJumpIfBitsSet/eBPF#07 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: Mov32Imm dst: r5 imm: 2 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JSetReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfBitsSet/kernel#07 === RUN TestJumpIfBitsSet/C#08 === RUN TestJumpIfEqual/eBPF#06 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 21 4: JEqReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfEqual/kernel#06 === RUN TestALUMul/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 2 3: Mov32Imm dst: r5 imm: -2147483648 4: Mul32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 0 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUMul/kernel#05 --- PASS: TestALUMul (0.24s) --- SKIP: TestALUMul/C (0.05s) --- SKIP: TestALUMul/eBPF (0.00s) --- PASS: TestALUMul/kernel (0.00s) --- SKIP: TestALUMul/C#01 (0.04s) --- SKIP: TestALUMul/eBPF#01 (0.00s) --- PASS: TestALUMul/kernel#01 (0.00s) --- SKIP: TestALUMul/C#02 (0.04s) --- SKIP: TestALUMul/eBPF#02 (0.00s) --- PASS: TestALUMul/kernel#02 (0.00s) --- SKIP: TestALUMul/C#03 (0.04s) --- SKIP: TestALUMul/eBPF#03 (0.00s) --- PASS: TestALUMul/kernel#03 (0.00s) --- SKIP: TestALUMul/C#04 (0.03s) --- SKIP: TestALUMul/eBPF#04 (0.00s) --- PASS: TestALUMul/kernel#04 (0.00s) --- SKIP: TestALUMul/C#05 (0.04s) --- SKIP: TestALUMul/eBPF#05 (0.00s) --- PASS: TestALUMul/kernel#05 (0.00s) === CONT TestLoadAbsoluteBigOffset === RUN TestLoadAbsoluteBigOffset/C === RUN TestJumpIfGreaterOrEqual/eBPF#08 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: JGEImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfGreaterOrEqual/kernel#08 === RUN TestALUAdd/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 4 3: Mov32Imm dst: r5 imm: 13 4: Add32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 17 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUAdd/kernel#03 --- PASS: TestALUAdd (0.16s) --- SKIP: TestALUAdd/C (0.04s) --- SKIP: TestALUAdd/eBPF (0.00s) --- PASS: TestALUAdd/kernel (0.00s) --- SKIP: TestALUAdd/C#01 (0.04s) --- SKIP: TestALUAdd/eBPF#01 (0.00s) --- PASS: TestALUAdd/kernel#01 (0.00s) --- SKIP: TestALUAdd/C#02 (0.04s) --- SKIP: TestALUAdd/eBPF#02 (0.00s) --- PASS: TestALUAdd/kernel#02 (0.00s) --- SKIP: TestALUAdd/C#03 (0.04s) --- SKIP: TestALUAdd/eBPF#03 (0.00s) --- PASS: TestALUAdd/kernel#03 (0.00s) === CONT TestJumpIfGreaterThan === RUN TestJumpIfGreaterThan/C === RUN TestJumpIfLessThan/eBPF#01 === RUN TestScratchA/eBPF#01 === NAME TestJumpIfLessThan/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JLTImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfLessThan/kernel#01 === NAME TestScratchA/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 0 3: StXMemW dst: rfp src: r4 off: -32 imm: 0 4: Mov32Imm dst: r4 imm: 0 5: Mov32Imm dst: r4 imm: -1 6: StXMemW dst: rfp src: r4 off: -28 imm: 0 7: Mov32Imm dst: r4 imm: -1 8: StXMemW dst: rfp src: r4 off: -36 imm: 0 9: LdXMemW dst: r4 src: rfp off: -32 imm: 0 10: JEqImm dst: r4 off: -1 imm: 0 filter_block_9: 11: Mov32Imm dst: r4 imm: 0 12: JaImm dst: r0 off: -1 imm: 0 filter_block_10: 13: Mov32Imm dst: r4 imm: 1 14: JaImm dst: r0 off: -1 imm: 0 result: 15: MovImm dst: r0 imm: 2 16: JEqImm dst: r4 off: -1 imm: 0 17: MovImm dst: r0 imm: 1 return: 18: Exit === RUN TestScratchA/kernel#01 --- PASS: TestScratchA (0.07s) --- SKIP: TestScratchA/C (0.03s) --- SKIP: TestScratchA/eBPF (0.00s) --- PASS: TestScratchA/kernel (0.00s) --- SKIP: TestScratchA/C#01 (0.03s) --- SKIP: TestScratchA/eBPF#01 (0.00s) --- PASS: TestScratchA/kernel#01 (0.00s) === CONT TestLoadConstantA === RUN TestLoadConstantA/C === RUN TestJumpIfBitsNotSet/C#04 === RUN TestJumpIfNotEqual/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JNEImm dst: r4 off: -1 imm: 21 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfNotEqual/kernel#04 === RUN TestJumpIfNotEqual/C#05 === RUN TestLoadIndirect/constant_valid/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: -2147483644 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: 2147483647 7: JGEImm dst: r7 off: -1 imm: 65535 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 1 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemB dst: r4 src: r7 off: 0 imm: 0 13: JEqImm dst: r4 off: -1 imm: 5 filter_block_3: 14: Mov32Imm dst: r4 imm: 0 15: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 16: Mov32Imm dst: r4 imm: 1 17: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 18: MovImm dst: r4 imm: 0 19: JaImm dst: r0 off: -1 imm: 0 result: 20: MovImm dst: r0 imm: 2 21: JEqImm dst: r4 off: -1 imm: 0 22: MovImm dst: r0 imm: 1 return: 23: Exit === RUN TestLoadIndirect/constant_valid/kernel === RUN TestLoadIndirect/constant_valid/C#01 === RUN TestLoadAbsolute/C#02 === RUN TestJumpIfLessOrEqual/eBPF#04 === RUN TestJumpIfBitsSet/eBPF#08 === NAME TestJumpIfLessOrEqual/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JLEImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfLessOrEqual/kernel#04 === NAME TestJumpIfBitsSet/eBPF#08 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: JSetImm dst: r4 off: -1 imm: 8 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfBitsSet/kernel#08 === RUN TestJumpIfLessOrEqual/C#05 === RUN TestLoadAbsoluteBigOffset/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 65535 4: JGTReg dst: r6 off: -1 src: r3 5: MovReg dst: r6 src: r2 6: AddImm dst: r6 imm: 65534 7: LdXMemB dst: r4 src: r6 off: 0 imm: 0 8: Add32Imm dst: r4 imm: 2 9: Mov32Reg dst: r4 src: r4 10: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 11: MovImm dst: r4 imm: 0 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestLoadAbsoluteBigOffset/kernel === RUN TestJumpIfBitsNotSet/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: JSetImm dst: r4 off: -1 imm: 2 4: JaImm dst: r0 off: -1 imm: 0 filter_block_2: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfBitsNotSet/kernel#04 === RUN TestJumpIfGreaterThan/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: JGTImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfGreaterThan/kernel === RUN TestJumpIfGreaterThan/C#01 === RUN TestJumpIfEqual/C#07 === RUN TestLoadConstantA/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: JEqImm dst: r4 off: -1 imm: 1 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestLoadConstantA/kernel === RUN TestLoadConstantA/C#01 === RUN TestLoadAbsolute/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 4 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemH dst: r4 src: r2 off: 2 imm: 0 6: SwapBE dst: r4 imm: 16 7: JEqImm dst: r4 off: -1 imm: 57005 filter_block_2: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 12: MovImm dst: r4 imm: 0 13: JaImm dst: r0 off: -1 imm: 0 result: 14: MovImm dst: r0 imm: 2 15: JEqImm dst: r4 off: -1 imm: 0 16: MovImm dst: r0 imm: 1 return: 17: Exit === RUN TestLoadAbsolute/kernel#02 === RUN TestLoadAbsolute/C#03 === RUN TestLoadIndirect/constant_valid/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: -2147483644 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: 2147483647 7: JGEImm dst: r7 off: -1 imm: 65535 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 1 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemB dst: r4 src: r7 off: 0 imm: 0 13: JEqImm dst: r4 off: -1 imm: 6 filter_block_3: 14: Mov32Imm dst: r4 imm: 0 15: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 16: Mov32Imm dst: r4 imm: 1 17: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 18: MovImm dst: r4 imm: 0 19: JaImm dst: r0 off: -1 imm: 0 result: 20: MovImm dst: r0 imm: 2 21: JEqImm dst: r4 off: -1 imm: 0 22: MovImm dst: r0 imm: 1 return: 23: Exit === RUN TestLoadIndirect/constant_valid/kernel#01 === RUN TestJumpIfNotEqual/eBPF#05 === RUN TestJumpIfGreaterOrEqual/C#09 === NAME TestJumpIfNotEqual/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JNEImm dst: r4 off: -1 imm: 21 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfNotEqual/kernel#05 === RUN TestJumpIfNotEqual/C#06 === RUN TestJumpIfLessThan/C#02 === RUN TestJumpIfLessOrEqual/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JLEImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfLessOrEqual/kernel#05 === RUN TestJumpIfLessOrEqual/C#06 === RUN TestJumpIfBitsSet/C#09 === RUN TestJumpIfGreaterThan/eBPF#01 === RUN TestJumpIfEqual/eBPF#07 === NAME TestJumpIfGreaterThan/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JGTImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfGreaterThan/kernel#01 === NAME TestJumpIfEqual/eBPF#07 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 21 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JEqReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfEqual/kernel#07 === RUN TestJumpIfGreaterThan/C#02 === RUN TestLoadConstantA/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 28 3: JEqImm dst: r4 off: -1 imm: 28 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestLoadConstantA/kernel#01 === RUN TestLoadConstantA/C#02 === RUN TestLoadAbsoluteBigOffset/C#01 === RUN TestLoadAbsolute/eBPF#03 === RUN TestJumpIfGreaterOrEqual/eBPF#09 === RUN TestJumpIfNotEqual/eBPF#06 === NAME TestJumpIfGreaterOrEqual/eBPF#09 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JGEImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === NAME TestLoadAbsolute/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 4 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemH dst: r4 src: r2 off: 2 imm: 0 6: SwapBE dst: r4 imm: 16 7: JEqImm dst: r4 off: -1 imm: 57007 filter_block_2: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 12: MovImm dst: r4 imm: 0 13: JaImm dst: r0 off: -1 imm: 0 result: 14: MovImm dst: r0 imm: 2 15: JEqImm dst: r4 off: -1 imm: 0 16: MovImm dst: r0 imm: 1 return: 17: Exit === RUN TestLoadAbsolute/kernel#03 === NAME TestJumpIfNotEqual/eBPF#06 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 21 4: JNEReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfNotEqual/kernel#06 === RUN TestJumpIfGreaterOrEqual/kernel#09 === RUN TestJumpIfNotEqual/C#07 === RUN TestJumpIfLessThan/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: Mov32Imm dst: r5 imm: 23 4: JLTReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfLessThan/kernel#02 === RUN TestJumpIfBitsNotSet/C#05 === RUN TestJumpIfLessOrEqual/eBPF#06 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 23 4: JLEReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfLessOrEqual/kernel#06 === RUN TestJumpIfLessOrEqual/C#07 === RUN TestLoadIndirect/constant_valid/C#02 === RUN TestJumpIfGreaterThan/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: Mov32Imm dst: r5 imm: 23 4: JGTReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfGreaterThan/kernel#02 === RUN TestJumpIfGreaterThan/C#03 === RUN TestLoadAbsoluteBigOffset/eBPF#01 === RUN TestJumpIfBitsSet/eBPF#09 === NAME TestLoadAbsoluteBigOffset/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 0 3: JaImm dst: r0 off: -1 imm: 0 result: 4: MovImm dst: r0 imm: 2 5: JEqImm dst: r4 off: -1 imm: 0 6: MovImm dst: r0 imm: 1 return: 7: Exit === RUN TestLoadAbsoluteBigOffset/kernel#01 === NAME TestJumpIfBitsSet/eBPF#09 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JSetImm dst: r4 off: -1 imm: 8 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfBitsSet/kernel#09 === RUN TestLoadConstantA/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 0 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestLoadConstantA/kernel#02 --- PASS: TestLoadConstantA (0.11s) --- SKIP: TestLoadConstantA/C (0.04s) --- SKIP: TestLoadConstantA/eBPF (0.00s) --- PASS: TestLoadConstantA/kernel (0.00s) --- SKIP: TestLoadConstantA/C#01 (0.03s) --- SKIP: TestLoadConstantA/eBPF#01 (0.00s) --- PASS: TestLoadConstantA/kernel#01 (0.00s) --- SKIP: TestLoadConstantA/C#02 (0.03s) --- SKIP: TestLoadConstantA/eBPF#02 (0.00s) --- PASS: TestLoadConstantA/kernel#02 (0.00s) === CONT TestLoadConstantX === RUN TestLoadConstantX/C === RUN TestJumpIfNotEqual/eBPF#07 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 21 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JNEReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfNotEqual/kernel#07 --- PASS: TestJumpIfNotEqual (0.55s) --- SKIP: TestJumpIfNotEqual/C (0.06s) --- SKIP: TestJumpIfNotEqual/eBPF (0.00s) --- PASS: TestJumpIfNotEqual/kernel (0.05s) --- SKIP: TestJumpIfNotEqual/C#01 (0.05s) --- SKIP: TestJumpIfNotEqual/eBPF#01 (0.00s) --- PASS: TestJumpIfNotEqual/kernel#01 (0.05s) --- SKIP: TestJumpIfNotEqual/C#02 (0.05s) --- SKIP: TestJumpIfNotEqual/eBPF#02 (0.00s) --- PASS: TestJumpIfNotEqual/kernel#02 (0.05s) --- SKIP: TestJumpIfNotEqual/C#03 (0.04s) --- SKIP: TestJumpIfNotEqual/eBPF#03 (0.00s) --- PASS: TestJumpIfNotEqual/kernel#03 (0.05s) --- SKIP: TestJumpIfNotEqual/C#04 (0.04s) --- SKIP: TestJumpIfNotEqual/eBPF#04 (0.00s) --- PASS: TestJumpIfNotEqual/kernel#04 (0.00s) --- SKIP: TestJumpIfNotEqual/C#05 (0.04s) --- SKIP: TestJumpIfNotEqual/eBPF#05 (0.00s) --- PASS: TestJumpIfNotEqual/kernel#05 (0.00s) --- SKIP: TestJumpIfNotEqual/C#06 (0.04s) --- SKIP: TestJumpIfNotEqual/eBPF#06 (0.00s) --- PASS: TestJumpIfNotEqual/kernel#06 (0.00s) --- SKIP: TestJumpIfNotEqual/C#07 (0.04s) --- SKIP: TestJumpIfNotEqual/eBPF#07 (0.00s) --- PASS: TestJumpIfNotEqual/kernel#07 (0.00s) === CONT TestPartialZeroInitX === RUN TestPartialZeroInitX/C === RUN TestJumpIfBitsNotSet/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JSetImm dst: r4 off: -1 imm: 2 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfBitsNotSet/kernel#05 --- PASS: TestJumpIfEqual (0.55s) --- SKIP: TestJumpIfEqual/C (0.06s) --- SKIP: TestJumpIfEqual/eBPF (0.00s) --- PASS: TestJumpIfEqual/kernel (0.00s) --- SKIP: TestJumpIfEqual/C#01 (0.05s) --- SKIP: TestJumpIfEqual/eBPF#01 (0.00s) --- PASS: TestJumpIfEqual/kernel#01 (0.00s) --- SKIP: TestJumpIfEqual/C#02 (0.04s) --- SKIP: TestJumpIfEqual/eBPF#02 (0.00s) --- PASS: TestJumpIfEqual/kernel#02 (0.00s) --- SKIP: TestJumpIfEqual/C#03 (0.04s) --- SKIP: TestJumpIfEqual/eBPF#03 (0.00s) --- PASS: TestJumpIfEqual/kernel#03 (0.00s) --- SKIP: TestJumpIfEqual/C#04 (0.05s) --- SKIP: TestJumpIfEqual/eBPF#04 (0.00s) --- PASS: TestJumpIfEqual/kernel#04 (0.05s) --- SKIP: TestJumpIfEqual/C#05 (0.04s) --- SKIP: TestJumpIfEqual/eBPF#05 (0.00s) --- PASS: TestJumpIfEqual/kernel#05 (0.05s) --- SKIP: TestJumpIfEqual/C#06 (0.04s) --- SKIP: TestJumpIfEqual/eBPF#06 (0.00s) --- PASS: TestJumpIfEqual/kernel#06 (0.05s) --- SKIP: TestJumpIfEqual/C#07 (0.03s) --- SKIP: TestJumpIfEqual/eBPF#07 (0.00s) --- PASS: TestJumpIfEqual/kernel#07 (0.05s) === RUN TestJumpIfLessOrEqual/eBPF#07 === CONT TestALUMod === RUN TestALUMod/C === NAME TestJumpIfLessOrEqual/eBPF#07 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JLEReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfLessOrEqual/kernel#07 === RUN TestJumpIfLessOrEqual/C#08 === RUN TestJumpIfGreaterOrEqual/C#10 === RUN TestLoadAbsolute/C#04 === RUN TestLoadIndirect/constant_valid/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 3 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: -1 7: JGEImm dst: r7 off: -1 imm: 65534 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 2 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemH dst: r4 src: r7 off: 0 imm: 0 13: SwapBE dst: r4 imm: 16 14: JEqImm dst: r4 off: -1 imm: 57005 filter_block_3: 15: Mov32Imm dst: r4 imm: 0 16: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 17: Mov32Imm dst: r4 imm: 1 18: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 19: MovImm dst: r4 imm: 0 20: JaImm dst: r0 off: -1 imm: 0 result: 21: MovImm dst: r0 imm: 2 22: JEqImm dst: r4 off: -1 imm: 0 23: MovImm dst: r0 imm: 1 return: 24: Exit === RUN TestLoadIndirect/constant_valid/kernel#02 === RUN TestJumpIfLessThan/C#03 === RUN TestLoadIndirect/constant_valid/C#03 === RUN TestJumpIfGreaterThan/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JGTReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfGreaterThan/kernel#03 === RUN TestJumpIfGreaterThan/C#04 === RUN TestLoadConstantX/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 1 3: Mov32Reg dst: r4 src: r5 4: JEqImm dst: r4 off: -1 imm: 1 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestLoadConstantX/kernel === RUN TestLoadConstantX/C#01 === RUN TestALUMod/eBPF === RUN TestLoadAbsoluteBigOffset/C#02 === RUN TestJumpIfBitsSet/C#10 === NAME TestALUMod/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 16 3: Mod32Imm dst: r4 imm: 4 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUMod/kernel === RUN TestPartialZeroInitX/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 1 4: JGTReg dst: r6 off: -1 src: r3 5: Mov32Imm dst: r5 imm: 0 6: LdXMemB dst: r4 src: r2 off: 0 imm: 0 7: JNEImm dst: r4 off: -1 imm: 3 filter_block_2: 8: Mov32Reg dst: r5 src: r4 filter_block_3: 9: Mov32Reg dst: r4 src: r5 10: Mov32Reg dst: r4 src: r4 11: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 12: MovImm dst: r4 imm: 0 13: JaImm dst: r0 off: -1 imm: 0 result: 14: MovImm dst: r0 imm: 2 15: JEqImm dst: r4 off: -1 imm: 0 16: MovImm dst: r0 imm: 1 return: 17: Exit === RUN TestPartialZeroInitX/kernel === RUN TestALUMod/C#01 === RUN TestJumpIfLessOrEqual/eBPF#08 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: JLEImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfLessOrEqual/kernel#08 === RUN TestJumpIfGreaterThan/eBPF#04 === RUN TestJumpIfBitsNotSet/C#06 === RUN TestJumpIfLessThan/eBPF#03 === RUN TestLoadIndirect/constant_valid/eBPF#03 === RUN TestJumpIfGreaterOrEqual/eBPF#10 === NAME TestJumpIfLessThan/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JLTReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfLessOrEqual/C#09 === RUN TestJumpIfLessThan/kernel#03 === RUN TestLoadAbsolute/eBPF#04 === NAME TestJumpIfGreaterOrEqual/eBPF#10 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: Mov32Imm dst: r5 imm: 23 4: JGEReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfGreaterOrEqual/kernel#10 === NAME TestLoadIndirect/constant_valid/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 3 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: -1 7: JGEImm dst: r7 off: -1 imm: 65534 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 2 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemH dst: r4 src: r7 off: 0 imm: 0 13: SwapBE dst: r4 imm: 16 14: JEqImm dst: r4 off: -1 imm: 57005 filter_block_3: 15: Mov32Imm dst: r4 imm: 0 16: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 17: Mov32Imm dst: r4 imm: 1 18: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 19: MovImm dst: r4 imm: 0 20: JaImm dst: r0 off: -1 imm: 0 result: 21: MovImm dst: r0 imm: 2 22: JEqImm dst: r4 off: -1 imm: 0 23: MovImm dst: r0 imm: 1 return: 24: Exit === RUN TestLoadIndirect/constant_valid/kernel#03 === NAME TestLoadAbsolute/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 6 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemW dst: r4 src: r2 off: 2 imm: 0 6: SwapBE dst: r4 imm: 32 7: Mov32Imm dst: r6 imm: -559038737 8: JEqReg dst: r4 off: -1 src: r6 filter_block_2: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 13: MovImm dst: r4 imm: 0 14: JaImm dst: r0 off: -1 imm: 0 result: 15: MovImm dst: r0 imm: 2 16: JEqImm dst: r4 off: -1 imm: 0 17: MovImm dst: r0 imm: 1 return: 18: Exit === RUN TestLoadAbsolute/kernel#04 === NAME TestJumpIfGreaterThan/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JGTImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfGreaterThan/kernel#04 === RUN TestLoadAbsolute/C#05 === RUN TestLoadConstantX/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 28 3: Mov32Reg dst: r4 src: r5 4: JEqImm dst: r4 off: -1 imm: 28 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestLoadConstantX/kernel#01 === RUN TestLoadConstantX/C#02 === RUN TestALUMod/eBPF#01 === RUN TestJumpIfBitsSet/eBPF#10 === RUN TestLoadAbsoluteBigOffset/eBPF#02 === NAME TestALUMod/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 16 3: Mov32Imm dst: r5 imm: 4 4: JEqImm dst: r5 off: -1 imm: 0 5: Mod32Reg dst: r4 src: r5 6: JEqImm dst: r4 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 0 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 1 10: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 11: MovImm dst: r4 imm: 0 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === NAME TestJumpIfBitsSet/eBPF#10 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: Mov32Imm dst: r5 imm: 8 4: JSetReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUMod/kernel#01 === RUN TestJumpIfBitsSet/kernel#10 === RUN TestALUMod/C#02 === NAME TestLoadAbsoluteBigOffset/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 65535 4: JGTReg dst: r6 off: -1 src: r3 5: MovReg dst: r6 src: r2 6: AddImm dst: r6 imm: 65533 7: LdXMemH dst: r4 src: r6 off: 0 imm: 0 8: SwapBE dst: r4 imm: 16 9: Add32Imm dst: r4 imm: 2 10: Mov32Reg dst: r4 src: r4 11: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 12: MovImm dst: r4 imm: 0 13: JaImm dst: r0 off: -1 imm: 0 result: 14: MovImm dst: r0 imm: 2 15: JEqImm dst: r4 off: -1 imm: 0 16: MovImm dst: r0 imm: 1 return: 17: Exit === RUN TestLoadAbsoluteBigOffset/kernel#02 === RUN TestPartialZeroInitX/C#01 === RUN TestJumpIfBitsNotSet/eBPF#06 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: Mov32Imm dst: r5 imm: 2 4: JSetReg dst: r4 off: -1 src: r5 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestJumpIfBitsNotSet/kernel#06 === RUN TestLoadConstantX/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 0 3: Mov32Reg dst: r4 src: r5 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestLoadConstantX/kernel#02 --- PASS: TestLoadConstantX (0.10s) --- SKIP: TestLoadConstantX/C (0.03s) --- SKIP: TestLoadConstantX/eBPF (0.00s) --- PASS: TestLoadConstantX/kernel (0.00s) --- SKIP: TestLoadConstantX/C#01 (0.03s) --- SKIP: TestLoadConstantX/eBPF#01 (0.00s) --- PASS: TestLoadConstantX/kernel#01 (0.00s) --- SKIP: TestLoadConstantX/C#02 (0.03s) --- SKIP: TestLoadConstantX/eBPF#02 (0.00s) --- PASS: TestLoadConstantX/kernel#02 (0.00s) === CONT TestJump0 === RUN TestJump0/C === RUN TestJumpIfLessOrEqual/eBPF#09 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JLEImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfLessOrEqual/kernel#09 === RUN TestJumpIfLessOrEqual/C#10 === RUN TestLoadAbsolute/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 6 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemW dst: r4 src: r2 off: 2 imm: 0 6: SwapBE dst: r4 imm: 32 7: Mov32Imm dst: r6 imm: -558907665 8: JEqReg dst: r4 off: -1 src: r6 filter_block_2: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 13: MovImm dst: r4 imm: 0 14: JaImm dst: r0 off: -1 imm: 0 result: 15: MovImm dst: r0 imm: 2 16: JEqImm dst: r4 off: -1 imm: 0 17: MovImm dst: r0 imm: 1 return: 18: Exit === RUN TestLoadAbsolute/kernel#05 === RUN TestLoadIndirect/constant_valid/C#04 === RUN TestJumpIfGreaterOrEqual/C#11 === RUN TestJumpIfGreaterThan/C#05 === RUN TestJumpIfLessThan/C#04 === RUN TestALUMod/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 17 3: Mod32Imm dst: r4 imm: 4 4: JEqImm dst: r4 off: -1 imm: 1 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUMod/kernel#02 === RUN TestALUMod/C#03 === RUN TestJumpIfLessOrEqual/eBPF#10 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: Mov32Imm dst: r5 imm: 23 4: JLEReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfLessOrEqual/kernel#10 === RUN TestJumpIfBitsSet/C#11 === RUN TestJumpIfLessOrEqual/C#11 === RUN TestJump0/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 1 4: JGTReg dst: r6 off: -1 src: r3 5: Mov32Imm dst: r5 imm: 0 6: LdXMemB dst: r4 src: r2 off: 0 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 8: JEqReg dst: r4 off: -1 src: r5 filter_block_4: 9: Mov32Reg dst: r4 src: r4 10: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 11: MovImm dst: r4 imm: 0 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJump0/kernel === RUN TestLoadAbsoluteBigOffset/C#03 === RUN TestPartialZeroInitX/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 1 4: JGTReg dst: r6 off: -1 src: r3 5: Mov32Imm dst: r5 imm: 0 6: LdXMemB dst: r4 src: r2 off: 0 imm: 0 7: JNEImm dst: r4 off: -1 imm: 3 filter_block_2: 8: Mov32Reg dst: r5 src: r4 filter_block_3: 9: Mov32Reg dst: r4 src: r5 10: Mov32Reg dst: r4 src: r4 11: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 12: MovImm dst: r4 imm: 0 13: JaImm dst: r0 off: -1 imm: 0 result: 14: MovImm dst: r0 imm: 2 15: JEqImm dst: r4 off: -1 imm: 0 16: MovImm dst: r0 imm: 1 return: 17: Exit === RUN TestPartialZeroInitX/kernel#01 --- PASS: TestPartialZeroInitX (0.13s) --- SKIP: TestPartialZeroInitX/C (0.04s) --- SKIP: TestPartialZeroInitX/eBPF (0.00s) --- PASS: TestPartialZeroInitX/kernel (0.05s) --- SKIP: TestPartialZeroInitX/C#01 (0.04s) --- SKIP: TestPartialZeroInitX/eBPF#01 (0.00s) --- PASS: TestPartialZeroInitX/kernel#01 (0.00s) === CONT TestJump === RUN TestJump/C === RUN TestJumpIfBitsNotSet/C#07 === RUN TestJumpIfGreaterThan/eBPF#05 --- PASS: TestLoadAbsolute (0.39s) --- SKIP: TestLoadAbsolute/C (0.04s) --- SKIP: TestLoadAbsolute/eBPF (0.00s) --- PASS: TestLoadAbsolute/kernel (0.00s) --- SKIP: TestLoadAbsolute/C#01 (0.04s) --- SKIP: TestLoadAbsolute/eBPF#01 (0.00s) --- PASS: TestLoadAbsolute/kernel#01 (0.05s) --- SKIP: TestLoadAbsolute/C#02 (0.04s) --- SKIP: TestLoadAbsolute/eBPF#02 (0.00s) --- PASS: TestLoadAbsolute/kernel#02 (0.00s) --- SKIP: TestLoadAbsolute/C#03 (0.04s) --- SKIP: TestLoadAbsolute/eBPF#03 (0.00s) --- PASS: TestLoadAbsolute/kernel#03 (0.05s) --- SKIP: TestLoadAbsolute/C#04 (0.04s) --- SKIP: TestLoadAbsolute/eBPF#04 (0.00s) --- PASS: TestLoadAbsolute/kernel#04 (0.00s) --- SKIP: TestLoadAbsolute/C#05 (0.04s) --- SKIP: TestLoadAbsolute/eBPF#05 (0.00s) --- PASS: TestLoadAbsolute/kernel#05 (0.05s) === NAME TestJumpIfGreaterThan/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JGTImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfGreaterThan/kernel#05 === CONT TestNegateA === RUN TestNegateA/C === RUN TestJumpIfLessThan/eBPF#04 === RUN TestJumpIfGreaterOrEqual/eBPF#11 === NAME TestJumpIfLessThan/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JLTImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfLessThan/kernel#04 === NAME TestJumpIfGreaterOrEqual/eBPF#11 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JGEReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfGreaterOrEqual/kernel#11 === RUN TestLoadIndirect/constant_valid/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 1 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: 2 7: JGEImm dst: r7 off: -1 imm: 65532 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 4 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemW dst: r4 src: r7 off: 0 imm: 0 13: SwapBE dst: r4 imm: 32 14: Mov32Imm dst: r6 imm: -559038737 15: JEqReg dst: r4 off: -1 src: r6 filter_block_3: 16: Mov32Imm dst: r4 imm: 0 17: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 18: Mov32Imm dst: r4 imm: 1 19: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 20: MovImm dst: r4 imm: 0 21: JaImm dst: r0 off: -1 imm: 0 result: 22: MovImm dst: r0 imm: 2 23: JEqImm dst: r4 off: -1 imm: 0 24: MovImm dst: r0 imm: 1 return: 25: Exit === RUN TestLoadIndirect/constant_valid/kernel#04 === RUN TestLoadIndirect/constant_valid/C#05 === RUN TestALUMod/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 17 3: Mov32Imm dst: r5 imm: 4 4: JEqImm dst: r5 off: -1 imm: 0 5: Mod32Reg dst: r4 src: r5 6: JEqImm dst: r4 off: -1 imm: 1 filter_block_4: 7: Mov32Imm dst: r4 imm: 0 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 1 10: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 11: MovImm dst: r4 imm: 0 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestALUMod/kernel#03 --- PASS: TestALUMod (0.14s) --- SKIP: TestALUMod/C (0.03s) --- SKIP: TestALUMod/eBPF (0.00s) --- PASS: TestALUMod/kernel (0.00s) --- SKIP: TestALUMod/C#01 (0.04s) --- SKIP: TestALUMod/eBPF#01 (0.00s) --- PASS: TestALUMod/kernel#01 (0.00s) --- SKIP: TestALUMod/C#02 (0.04s) --- SKIP: TestALUMod/eBPF#02 (0.00s) --- PASS: TestALUMod/kernel#02 (0.00s) --- SKIP: TestALUMod/C#03 (0.03s) --- SKIP: TestALUMod/eBPF#03 (0.00s) --- PASS: TestALUMod/kernel#03 (0.00s) === CONT TestALUXor === RUN TestALUXor/C === RUN TestJumpIfBitsSet/eBPF#11 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: Mov32Imm dst: r5 imm: 8 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JSetReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfBitsSet/kernel#11 === RUN TestLoadAbsoluteBigOffset/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 0 3: JaImm dst: r0 off: -1 imm: 0 result: 4: MovImm dst: r0 imm: 2 5: JEqImm dst: r4 off: -1 imm: 0 6: MovImm dst: r0 imm: 1 return: 7: Exit === RUN TestLoadAbsoluteBigOffset/kernel#03 === RUN TestJumpIfLessOrEqual/eBPF#11 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JLEReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfLessOrEqual/kernel#11 === RUN TestJump/eBPF --- PASS: TestJumpIfLessOrEqual (0.72s) --- SKIP: TestJumpIfLessOrEqual/C (0.06s) --- SKIP: TestJumpIfLessOrEqual/eBPF (0.00s) --- PASS: TestJumpIfLessOrEqual/kernel (0.05s) --- SKIP: TestJumpIfLessOrEqual/C#01 (0.05s) --- SKIP: TestJumpIfLessOrEqual/eBPF#01 (0.00s) --- PASS: TestJumpIfLessOrEqual/kernel#01 (0.06s) --- SKIP: TestJumpIfLessOrEqual/C#02 (0.05s) --- SKIP: TestJumpIfLessOrEqual/eBPF#02 (0.00s) --- PASS: TestJumpIfLessOrEqual/kernel#02 (0.05s) --- SKIP: TestJumpIfLessOrEqual/C#03 (0.04s) --- SKIP: TestJumpIfLessOrEqual/eBPF#03 (0.00s) --- PASS: TestJumpIfLessOrEqual/kernel#03 (0.05s) --- SKIP: TestJumpIfLessOrEqual/C#04 (0.04s) --- SKIP: TestJumpIfLessOrEqual/eBPF#04 (0.00s) --- PASS: TestJumpIfLessOrEqual/kernel#04 (0.00s) --- SKIP: TestJumpIfLessOrEqual/C#05 (0.03s) --- SKIP: TestJumpIfLessOrEqual/eBPF#05 (0.00s) --- PASS: TestJumpIfLessOrEqual/kernel#05 (0.00s) --- SKIP: TestJumpIfLessOrEqual/C#06 (0.03s) --- SKIP: TestJumpIfLessOrEqual/eBPF#06 (0.00s) --- PASS: TestJumpIfLessOrEqual/kernel#06 (0.00s) --- SKIP: TestJumpIfLessOrEqual/C#07 (0.03s) --- SKIP: TestJumpIfLessOrEqual/eBPF#07 (0.00s) --- PASS: TestJumpIfLessOrEqual/kernel#07 (0.00s) --- SKIP: TestJumpIfLessOrEqual/C#08 (0.04s) --- SKIP: TestJumpIfLessOrEqual/eBPF#08 (0.00s) --- PASS: TestJumpIfLessOrEqual/kernel#08 (0.00s) --- SKIP: TestJumpIfLessOrEqual/C#09 (0.04s) --- SKIP: TestJumpIfLessOrEqual/eBPF#09 (0.00s) --- PASS: TestJumpIfLessOrEqual/kernel#09 (0.00s) --- SKIP: TestJumpIfLessOrEqual/C#10 (0.03s) --- SKIP: TestJumpIfLessOrEqual/eBPF#10 (0.00s) --- PASS: TestJumpIfLessOrEqual/kernel#10 (0.00s) --- SKIP: TestJumpIfLessOrEqual/C#11 (0.05s) --- SKIP: TestJumpIfLessOrEqual/eBPF#11 (0.00s) --- PASS: TestJumpIfLessOrEqual/kernel#11 (0.00s) === CONT TestALUShiftLeft === RUN TestALUShiftLeft/C === NAME TestJump/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 1 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemB dst: r4 src: r2 off: 0 imm: 0 6: JEqImm dst: r4 off: -1 imm: 1 filter_block_2: 7: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 8: Mov32Imm dst: r4 imm: 1 filter_block_4: 9: Mov32Reg dst: r4 src: r4 10: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 11: MovImm dst: r4 imm: 0 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJump/kernel === RUN TestNegateA/eBPF === RUN TestJump0/C#01 === NAME TestNegateA/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 26 3: Neg32Imm dst: r4 imm: 0 4: Mov32Imm dst: r6 imm: -2147483622 5: JEqReg dst: r4 off: -1 src: r6 filter_block_3: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestNegateA/kernel === RUN TestJumpIfBitsNotSet/eBPF#07 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: Mov32Imm dst: r5 imm: 2 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JSetReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfBitsNotSet/kernel#07 === RUN TestLoadIndirect/constant_valid/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 1 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: 2 7: JGEImm dst: r7 off: -1 imm: 65532 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 4 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemW dst: r4 src: r7 off: 0 imm: 0 13: SwapBE dst: r4 imm: 32 14: Mov32Imm dst: r6 imm: -559038737 15: JEqReg dst: r4 off: -1 src: r6 filter_block_3: 16: Mov32Imm dst: r4 imm: 0 17: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 18: Mov32Imm dst: r4 imm: 1 19: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 20: MovImm dst: r4 imm: 0 21: JaImm dst: r0 off: -1 imm: 0 result: 22: MovImm dst: r0 imm: 2 23: JEqImm dst: r4 off: -1 imm: 0 24: MovImm dst: r0 imm: 1 return: 25: Exit === RUN TestLoadIndirect/constant_valid/kernel#05 === RUN TestALUXor/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: Xor32Imm dst: r4 imm: 1 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUXor/kernel === RUN TestALUXor/C#01 === RUN TestJumpIfGreaterThan/C#06 --- PASS: TestJumpIfGreaterOrEqual (0.74s) --- SKIP: TestJumpIfGreaterOrEqual/C (0.06s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF (0.00s) --- PASS: TestJumpIfGreaterOrEqual/kernel (0.00s) --- SKIP: TestJumpIfGreaterOrEqual/C#01 (0.07s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF#01 (0.00s) --- PASS: TestJumpIfGreaterOrEqual/kernel#01 (0.00s) --- SKIP: TestJumpIfGreaterOrEqual/C#02 (0.05s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF#02 (0.00s) --- PASS: TestJumpIfGreaterOrEqual/kernel#02 (0.00s) --- SKIP: TestJumpIfGreaterOrEqual/C#03 (0.06s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF#03 (0.00s) --- PASS: TestJumpIfGreaterOrEqual/kernel#03 (0.00s) --- SKIP: TestJumpIfGreaterOrEqual/C#04 (0.04s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF#04 (0.00s) --- PASS: TestJumpIfGreaterOrEqual/kernel#04 (0.00s) --- SKIP: TestJumpIfGreaterOrEqual/C#05 (0.04s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF#05 (0.00s) --- PASS: TestJumpIfGreaterOrEqual/kernel#05 (0.00s) --- SKIP: TestJumpIfGreaterOrEqual/C#06 (0.04s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF#06 (0.00s) --- PASS: TestJumpIfGreaterOrEqual/kernel#06 (0.00s) --- SKIP: TestJumpIfGreaterOrEqual/C#07 (0.04s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF#07 (0.00s) --- PASS: TestJumpIfGreaterOrEqual/kernel#07 (0.00s) --- SKIP: TestJumpIfGreaterOrEqual/C#08 (0.04s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF#08 (0.00s) --- PASS: TestJumpIfGreaterOrEqual/kernel#08 (0.05s) --- SKIP: TestJumpIfGreaterOrEqual/C#09 (0.04s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF#09 (0.00s) --- PASS: TestJumpIfGreaterOrEqual/kernel#09 (0.05s) --- SKIP: TestJumpIfGreaterOrEqual/C#10 (0.04s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF#10 (0.00s) --- PASS: TestJumpIfGreaterOrEqual/kernel#10 (0.05s) --- SKIP: TestJumpIfGreaterOrEqual/C#11 (0.04s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF#11 (0.00s) --- PASS: TestJumpIfGreaterOrEqual/kernel#11 (0.05s) === RUN TestJumpIfLessThan/C#05 === CONT TestALUShiftRight === RUN TestALUShiftRight/C === RUN TestALUShiftLeft/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: LSh32Imm dst: r4 imm: 0 4: JEqImm dst: r4 off: -1 imm: 1 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUShiftLeft/kernel === RUN TestALUShiftLeft/C#01 === RUN TestJump0/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 1 4: JGTReg dst: r6 off: -1 src: r3 5: Mov32Imm dst: r5 imm: 0 6: LdXMemB dst: r4 src: r2 off: 0 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 8: JEqReg dst: r4 off: -1 src: r5 filter_block_4: 9: Mov32Reg dst: r4 src: r4 10: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 11: MovImm dst: r4 imm: 0 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJump0/kernel#01 --- PASS: TestJump0 (0.12s) --- SKIP: TestJump0/C (0.04s) --- SKIP: TestJump0/eBPF (0.00s) --- PASS: TestJump0/kernel (0.05s) --- SKIP: TestJump0/C#01 (0.03s) --- SKIP: TestJump0/eBPF#01 (0.00s) --- PASS: TestJump0/kernel#01 (0.00s) === CONT TestZeroInitX === RUN TestZeroInitX/C --- PASS: TestJumpIfBitsSet (0.76s) --- SKIP: TestJumpIfBitsSet/C (0.05s) --- SKIP: TestJumpIfBitsSet/eBPF (0.00s) --- PASS: TestJumpIfBitsSet/kernel (0.00s) --- SKIP: TestJumpIfBitsSet/C#01 (0.05s) --- SKIP: TestJumpIfBitsSet/eBPF#01 (0.00s) --- PASS: TestJumpIfBitsSet/kernel#01 (0.00s) --- SKIP: TestJumpIfBitsSet/C#02 (0.04s) --- SKIP: TestJumpIfBitsSet/eBPF#02 (0.00s) --- PASS: TestJumpIfBitsSet/kernel#02 (0.00s) --- SKIP: TestJumpIfBitsSet/C#03 (0.06s) --- SKIP: TestJumpIfBitsSet/eBPF#03 (0.00s) --- PASS: TestJumpIfBitsSet/kernel#03 (0.00s) --- SKIP: TestJumpIfBitsSet/C#04 (0.04s) --- SKIP: TestJumpIfBitsSet/eBPF#04 (0.00s) --- PASS: TestJumpIfBitsSet/kernel#04 (0.00s) --- SKIP: TestJumpIfBitsSet/C#05 (0.04s) --- SKIP: TestJumpIfBitsSet/eBPF#05 (0.00s) --- PASS: TestJumpIfBitsSet/kernel#05 (0.00s) --- SKIP: TestJumpIfBitsSet/C#06 (0.03s) --- SKIP: TestJumpIfBitsSet/eBPF#06 (0.00s) --- PASS: TestJumpIfBitsSet/kernel#06 (0.00s) --- SKIP: TestJumpIfBitsSet/C#07 (0.04s) --- SKIP: TestJumpIfBitsSet/eBPF#07 (0.00s) --- PASS: TestJumpIfBitsSet/kernel#07 (0.00s) --- SKIP: TestJumpIfBitsSet/C#08 (0.03s) --- SKIP: TestJumpIfBitsSet/eBPF#08 (0.00s) --- PASS: TestJumpIfBitsSet/kernel#08 (0.05s) --- SKIP: TestJumpIfBitsSet/C#09 (0.04s) --- SKIP: TestJumpIfBitsSet/eBPF#09 (0.00s) --- PASS: TestJumpIfBitsSet/kernel#09 (0.05s) --- SKIP: TestJumpIfBitsSet/C#10 (0.04s) --- SKIP: TestJumpIfBitsSet/eBPF#10 (0.00s) --- PASS: TestJumpIfBitsSet/kernel#10 (0.05s) --- SKIP: TestJumpIfBitsSet/C#11 (0.04s) --- SKIP: TestJumpIfBitsSet/eBPF#11 (0.00s) --- PASS: TestJumpIfBitsSet/kernel#11 (0.05s) === RUN TestALUXor/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: Mov32Imm dst: r5 imm: 1 4: Xor32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 0 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUXor/kernel#01 === RUN TestALUXor/C#02 === RUN TestLoadAbsoluteBigOffset/C#04 --- PASS: TestJump (0.09s) --- SKIP: TestJump/C (0.04s) --- SKIP: TestJump/eBPF (0.00s) --- PASS: TestJump/kernel (0.05s) --- PASS: TestNegateA (0.09s) --- SKIP: TestNegateA/C (0.03s) --- SKIP: TestNegateA/eBPF (0.00s) --- PASS: TestNegateA/kernel (0.05s) === RUN TestJumpIfLessThan/eBPF#05 === RUN TestJumpIfBitsNotSet/C#08 === NAME TestJumpIfLessThan/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JLTImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfLessThan/kernel#05 === RUN TestALUShiftRight/eBPF === RUN TestLoadIndirect/variable_valid === RUN TestLoadIndirect/variable_valid/C === NAME TestALUShiftRight/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 240 3: RSh32Imm dst: r4 imm: 4 4: JEqImm dst: r4 off: -1 imm: 15 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUShiftRight/kernel === RUN TestALUShiftRight/C#01 === RUN TestJumpIfGreaterThan/eBPF#06 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 23 4: JGTReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfGreaterThan/kernel#06 === RUN TestALUShiftLeft/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: Mov32Imm dst: r5 imm: 0 4: LSh32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 1 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUShiftLeft/kernel#01 === RUN TestALUShiftLeft/C#02 === RUN TestZeroInitX/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 0 3: Mov32Reg dst: r4 src: r5 4: Mov32Reg dst: r4 src: r4 5: JaImm dst: r0 off: -1 imm: 0 result: 6: MovImm dst: r0 imm: 2 7: JEqImm dst: r4 off: -1 imm: 0 8: MovImm dst: r0 imm: 1 return: 9: Exit === RUN TestZeroInitX/kernel === RUN TestALUXor/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: Mod32Imm dst: r4 imm: 4 4: JEqImm dst: r4 off: -1 imm: 2 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUXor/kernel#02 === RUN TestALUXor/C#03 === RUN TestLoadAbsoluteBigOffset/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 65535 4: JGTReg dst: r6 off: -1 src: r3 5: MovReg dst: r6 src: r2 6: AddImm dst: r6 imm: 65531 7: LdXMemW dst: r4 src: r6 off: 0 imm: 0 8: SwapBE dst: r4 imm: 32 9: Add32Imm dst: r4 imm: 2 10: Mov32Reg dst: r4 src: r4 11: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 12: MovImm dst: r4 imm: 0 13: JaImm dst: r0 off: -1 imm: 0 result: 14: MovImm dst: r0 imm: 2 15: JEqImm dst: r4 off: -1 imm: 0 16: MovImm dst: r0 imm: 1 return: 17: Exit === RUN TestLoadAbsoluteBigOffset/kernel#04 === RUN TestJumpIfBitsNotSet/eBPF#08 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: JSetImm dst: r4 off: -1 imm: 8 4: JaImm dst: r0 off: -1 imm: 0 filter_block_2: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfBitsNotSet/kernel#08 === RUN TestJumpIfBitsNotSet/C#09 === RUN TestALUShiftRight/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 240 3: Mov32Imm dst: r5 imm: 4 4: RSh32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 15 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUShiftRight/kernel#01 === RUN TestLoadIndirect/variable_valid/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 4 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemW dst: r4 src: r2 off: 0 imm: 0 6: SwapBE dst: r4 imm: 32 7: Mov32Reg dst: r5 src: r4 8: MovReg dst: r7 src: r5 9: LShImm dst: r7 imm: 32 10: ArShImm dst: r7 imm: 32 11: AddImm dst: r7 imm: 13 12: JGEImm dst: r7 off: -1 imm: 65535 13: AddReg dst: r7 src: r2 14: MovReg dst: r6 src: r7 15: AddImm dst: r6 imm: 1 16: JGTReg dst: r6 off: -1 src: r3 17: LdXMemB dst: r4 src: r7 off: 0 imm: 0 18: JEqImm dst: r4 off: -1 imm: 5 filter_block_4: 19: Mov32Imm dst: r4 imm: 0 20: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 21: Mov32Imm dst: r4 imm: 1 22: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 23: MovImm dst: r4 imm: 0 24: JaImm dst: r0 off: -1 imm: 0 result: 25: MovImm dst: r0 imm: 2 26: JEqImm dst: r4 off: -1 imm: 0 27: MovImm dst: r0 imm: 1 return: 28: Exit === RUN TestLoadIndirect/variable_valid/kernel === RUN TestALUShiftRight/C#02 === RUN TestLoadIndirect/variable_valid/C#01 === RUN TestJumpIfLessThan/C#06 === RUN TestALUXor/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: Mov32Imm dst: r5 imm: 4 4: JEqImm dst: r5 off: -1 imm: 0 5: Mod32Reg dst: r4 src: r5 6: JEqImm dst: r4 off: -1 imm: 2 filter_block_4: 7: Mov32Imm dst: r4 imm: 0 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 1 10: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 11: MovImm dst: r4 imm: 0 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestALUXor/kernel#03 --- PASS: TestALUXor (0.14s) --- SKIP: TestALUXor/C (0.04s) --- SKIP: TestALUXor/eBPF (0.00s) --- PASS: TestALUXor/kernel (0.00s) --- SKIP: TestALUXor/C#01 (0.03s) --- SKIP: TestALUXor/eBPF#01 (0.00s) --- PASS: TestALUXor/kernel#01 (0.00s) --- SKIP: TestALUXor/C#02 (0.03s) --- SKIP: TestALUXor/eBPF#02 (0.00s) --- PASS: TestALUXor/kernel#02 (0.00s) --- SKIP: TestALUXor/C#03 (0.03s) --- SKIP: TestALUXor/eBPF#03 (0.00s) --- PASS: TestALUXor/kernel#03 (0.00s) === RUN TestALUShiftLeft/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: LSh32Imm dst: r4 imm: 4 4: JEqImm dst: r4 off: -1 imm: 16 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUShiftLeft/kernel#02 === RUN TestALUShiftLeft/C#03 === RUN TestJumpIfGreaterThan/C#07 --- PASS: TestZeroInitX (0.08s) --- SKIP: TestZeroInitX/C (0.03s) --- SKIP: TestZeroInitX/eBPF (0.00s) --- PASS: TestZeroInitX/kernel (0.05s) === RUN TestJumpIfBitsNotSet/eBPF#09 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JSetImm dst: r4 off: -1 imm: 8 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfBitsNotSet/kernel#09 === RUN TestJumpIfBitsNotSet/C#10 === RUN TestALUShiftRight/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 240 3: RSh32Imm dst: r4 imm: 8 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestALUShiftRight/kernel#02 === RUN TestALUShiftRight/C#03 === RUN TestLoadIndirect/variable_valid/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 4 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemW dst: r4 src: r2 off: 0 imm: 0 6: SwapBE dst: r4 imm: 32 7: Mov32Reg dst: r5 src: r4 8: MovReg dst: r7 src: r5 9: LShImm dst: r7 imm: 32 10: ArShImm dst: r7 imm: 32 11: AddImm dst: r7 imm: 13 12: JGEImm dst: r7 off: -1 imm: 65535 13: AddReg dst: r7 src: r2 14: MovReg dst: r6 src: r7 15: AddImm dst: r6 imm: 1 16: JGTReg dst: r6 off: -1 src: r3 17: LdXMemB dst: r4 src: r7 off: 0 imm: 0 18: JEqImm dst: r4 off: -1 imm: 6 filter_block_4: 19: Mov32Imm dst: r4 imm: 0 20: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 21: Mov32Imm dst: r4 imm: 1 22: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 23: MovImm dst: r4 imm: 0 24: JaImm dst: r0 off: -1 imm: 0 result: 25: MovImm dst: r0 imm: 2 26: JEqImm dst: r4 off: -1 imm: 0 27: MovImm dst: r0 imm: 1 return: 28: Exit === RUN TestLoadIndirect/variable_valid/kernel#01 === RUN TestLoadAbsoluteBigOffset/C#05 === RUN TestJumpIfLessThan/eBPF#06 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 23 4: JLTReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfLessThan/kernel#06 === RUN TestALUShiftLeft/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: Mov32Imm dst: r5 imm: 4 4: LSh32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 16 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUShiftLeft/kernel#03 --- PASS: TestALUShiftLeft (0.16s) --- SKIP: TestALUShiftLeft/C (0.04s) --- SKIP: TestALUShiftLeft/eBPF (0.00s) --- PASS: TestALUShiftLeft/kernel (0.00s) --- SKIP: TestALUShiftLeft/C#01 (0.03s) --- SKIP: TestALUShiftLeft/eBPF#01 (0.00s) --- PASS: TestALUShiftLeft/kernel#01 (0.00s) --- SKIP: TestALUShiftLeft/C#02 (0.05s) --- SKIP: TestALUShiftLeft/eBPF#02 (0.00s) --- PASS: TestALUShiftLeft/kernel#02 (0.00s) --- SKIP: TestALUShiftLeft/C#03 (0.04s) --- SKIP: TestALUShiftLeft/eBPF#03 (0.00s) --- PASS: TestALUShiftLeft/kernel#03 (0.00s) === RUN TestJumpIfBitsNotSet/eBPF#10 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: Mov32Imm dst: r5 imm: 8 4: JSetReg dst: r4 off: -1 src: r5 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestJumpIfBitsNotSet/kernel#10 === RUN TestJumpIfBitsNotSet/C#11 === RUN TestJumpIfGreaterThan/eBPF#07 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JGTReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfGreaterThan/kernel#07 === RUN TestLoadAbsoluteBigOffset/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 0 3: JaImm dst: r0 off: -1 imm: 0 result: 4: MovImm dst: r0 imm: 2 5: JEqImm dst: r4 off: -1 imm: 0 6: MovImm dst: r0 imm: 1 return: 7: Exit === RUN TestLoadAbsoluteBigOffset/kernel#05 === RUN TestALUShiftRight/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 240 3: Mov32Imm dst: r5 imm: 8 4: RSh32Reg dst: r4 src: r5 5: JEqImm dst: r4 off: -1 imm: 0 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: 10: MovImm dst: r0 imm: 2 11: JEqImm dst: r4 off: -1 imm: 0 12: MovImm dst: r0 imm: 1 return: 13: Exit === RUN TestALUShiftRight/kernel#03 --- PASS: TestALUShiftRight (0.16s) --- SKIP: TestALUShiftRight/C (0.04s) --- SKIP: TestALUShiftRight/eBPF (0.00s) --- PASS: TestALUShiftRight/kernel (0.00s) --- SKIP: TestALUShiftRight/C#01 (0.04s) --- SKIP: TestALUShiftRight/eBPF#01 (0.00s) --- PASS: TestALUShiftRight/kernel#01 (0.00s) --- SKIP: TestALUShiftRight/C#02 (0.04s) --- SKIP: TestALUShiftRight/eBPF#02 (0.00s) --- PASS: TestALUShiftRight/kernel#02 (0.00s) --- SKIP: TestALUShiftRight/C#03 (0.04s) --- SKIP: TestALUShiftRight/eBPF#03 (0.00s) --- PASS: TestALUShiftRight/kernel#03 (0.00s) === RUN TestLoadIndirect/variable_valid/C#02 === RUN TestJumpIfLessThan/C#07 === RUN TestJumpIfBitsNotSet/eBPF#11 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: Mov32Imm dst: r5 imm: 8 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JSetReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfBitsNotSet/kernel#11 --- PASS: TestJumpIfBitsNotSet (0.93s) --- SKIP: TestJumpIfBitsNotSet/C (0.11s) --- SKIP: TestJumpIfBitsNotSet/eBPF (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel (0.05s) --- SKIP: TestJumpIfBitsNotSet/C#01 (0.04s) --- SKIP: TestJumpIfBitsNotSet/eBPF#01 (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel#01 (0.05s) --- SKIP: TestJumpIfBitsNotSet/C#02 (0.03s) --- SKIP: TestJumpIfBitsNotSet/eBPF#02 (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel#02 (0.05s) --- SKIP: TestJumpIfBitsNotSet/C#03 (0.04s) --- SKIP: TestJumpIfBitsNotSet/eBPF#03 (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel#03 (0.05s) --- SKIP: TestJumpIfBitsNotSet/C#04 (0.03s) --- SKIP: TestJumpIfBitsNotSet/eBPF#04 (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel#04 (0.05s) --- SKIP: TestJumpIfBitsNotSet/C#05 (0.04s) --- SKIP: TestJumpIfBitsNotSet/eBPF#05 (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel#05 (0.05s) --- SKIP: TestJumpIfBitsNotSet/C#06 (0.03s) --- SKIP: TestJumpIfBitsNotSet/eBPF#06 (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel#06 (0.05s) --- SKIP: TestJumpIfBitsNotSet/C#07 (0.04s) --- SKIP: TestJumpIfBitsNotSet/eBPF#07 (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel#07 (0.05s) --- SKIP: TestJumpIfBitsNotSet/C#08 (0.04s) --- SKIP: TestJumpIfBitsNotSet/eBPF#08 (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel#08 (0.00s) --- SKIP: TestJumpIfBitsNotSet/C#09 (0.03s) --- SKIP: TestJumpIfBitsNotSet/eBPF#09 (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel#09 (0.00s) --- SKIP: TestJumpIfBitsNotSet/C#10 (0.03s) --- SKIP: TestJumpIfBitsNotSet/eBPF#10 (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel#10 (0.00s) --- SKIP: TestJumpIfBitsNotSet/C#11 (0.04s) --- SKIP: TestJumpIfBitsNotSet/eBPF#11 (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel#11 (0.00s) === RUN TestJumpIfGreaterThan/C#08 === RUN TestLoadAbsoluteBigOffset/C#06 === RUN TestLoadIndirect/variable_valid/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 4 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemW dst: r4 src: r2 off: 0 imm: 0 6: SwapBE dst: r4 imm: 32 7: Mov32Reg dst: r5 src: r4 8: MovReg dst: r7 src: r5 9: LShImm dst: r7 imm: 32 10: ArShImm dst: r7 imm: 32 11: AddImm dst: r7 imm: -2147483641 12: JGEImm dst: r7 off: -1 imm: 65534 13: AddReg dst: r7 src: r2 14: MovReg dst: r6 src: r7 15: AddImm dst: r6 imm: 2 16: JGTReg dst: r6 off: -1 src: r3 17: LdXMemH dst: r4 src: r7 off: 0 imm: 0 18: SwapBE dst: r4 imm: 16 19: JEqImm dst: r4 off: -1 imm: 57005 filter_block_4: 20: Mov32Imm dst: r4 imm: 0 21: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 22: Mov32Imm dst: r4 imm: 1 23: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 24: MovImm dst: r4 imm: 0 25: JaImm dst: r0 off: -1 imm: 0 result: 26: MovImm dst: r0 imm: 2 27: JEqImm dst: r4 off: -1 imm: 0 28: MovImm dst: r0 imm: 1 return: 29: Exit === RUN TestLoadIndirect/variable_valid/kernel#02 === RUN TestLoadIndirect/variable_valid/C#03 === RUN TestJumpIfLessThan/eBPF#07 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JLTReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfLessThan/kernel#07 === RUN TestJumpIfGreaterThan/eBPF#08 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: JGTImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfGreaterThan/kernel#08 === RUN TestLoadAbsoluteBigOffset/eBPF#06 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 65535 4: JGTReg dst: r6 off: -1 src: r3 5: Mov32Imm dst: r4 imm: 0 6: MovReg dst: r6 src: r2 7: AddImm dst: r6 imm: 65534 8: LdXMemB dst: r5 src: r6 off: 0 imm: 0 9: And32Imm dst: r5 imm: 15 10: LSh32Imm dst: r5 imm: 2 11: Add32Imm dst: r4 imm: 2 12: Mov32Reg dst: r4 src: r4 13: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 14: MovImm dst: r4 imm: 0 15: JaImm dst: r0 off: -1 imm: 0 result: 16: MovImm dst: r0 imm: 2 17: JEqImm dst: r4 off: -1 imm: 0 18: MovImm dst: r0 imm: 1 return: 19: Exit === RUN TestLoadAbsoluteBigOffset/kernel#06 === RUN TestLoadIndirect/variable_valid/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 4 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemW dst: r4 src: r2 off: 0 imm: 0 6: SwapBE dst: r4 imm: 32 7: Mov32Reg dst: r5 src: r4 8: MovReg dst: r7 src: r5 9: LShImm dst: r7 imm: 32 10: ArShImm dst: r7 imm: 32 11: AddImm dst: r7 imm: -2147483641 12: JGEImm dst: r7 off: -1 imm: 65534 13: AddReg dst: r7 src: r2 14: MovReg dst: r6 src: r7 15: AddImm dst: r6 imm: 2 16: JGTReg dst: r6 off: -1 src: r3 17: LdXMemH dst: r4 src: r7 off: 0 imm: 0 18: SwapBE dst: r4 imm: 16 19: JEqImm dst: r4 off: -1 imm: 57005 filter_block_4: 20: Mov32Imm dst: r4 imm: 0 21: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 22: Mov32Imm dst: r4 imm: 1 23: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 24: MovImm dst: r4 imm: 0 25: JaImm dst: r0 off: -1 imm: 0 result: 26: MovImm dst: r0 imm: 2 27: JEqImm dst: r4 off: -1 imm: 0 28: MovImm dst: r0 imm: 1 return: 29: Exit === RUN TestLoadIndirect/variable_valid/kernel#03 === RUN TestJumpIfLessThan/C#08 === RUN TestJumpIfGreaterThan/C#09 === RUN TestLoadAbsoluteBigOffset/C#07 === RUN TestLoadIndirect/variable_valid/C#04 === RUN TestJumpIfLessThan/eBPF#08 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: JLTImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 result: 8: MovImm dst: r0 imm: 2 9: JEqImm dst: r4 off: -1 imm: 0 10: MovImm dst: r0 imm: 1 return: 11: Exit === RUN TestJumpIfLessThan/kernel#08 === RUN TestJumpIfLessThan/C#09 === RUN TestJumpIfGreaterThan/eBPF#09 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JGTImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfGreaterThan/kernel#09 === RUN TestLoadAbsoluteBigOffset/eBPF#07 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 0 3: JaImm dst: r0 off: -1 imm: 0 result: 4: MovImm dst: r0 imm: 2 5: JEqImm dst: r4 off: -1 imm: 0 6: MovImm dst: r0 imm: 1 return: 7: Exit === RUN TestLoadAbsoluteBigOffset/kernel#07 === RUN TestLoadIndirect/variable_valid/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 4 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemW dst: r4 src: r2 off: 0 imm: 0 6: SwapBE dst: r4 imm: 32 7: Mov32Reg dst: r5 src: r4 8: MovReg dst: r7 src: r5 9: LShImm dst: r7 imm: 32 10: ArShImm dst: r7 imm: 32 11: AddImm dst: r7 imm: 4 12: JGEImm dst: r7 off: -1 imm: 65532 13: AddReg dst: r7 src: r2 14: MovReg dst: r6 src: r7 15: AddImm dst: r6 imm: 4 16: JGTReg dst: r6 off: -1 src: r3 17: LdXMemW dst: r4 src: r7 off: 0 imm: 0 18: SwapBE dst: r4 imm: 32 19: Mov32Imm dst: r6 imm: -559038737 20: JEqReg dst: r4 off: -1 src: r6 filter_block_4: 21: Mov32Imm dst: r4 imm: 0 22: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 23: Mov32Imm dst: r4 imm: 1 24: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 25: MovImm dst: r4 imm: 0 26: JaImm dst: r0 off: -1 imm: 0 result: 27: MovImm dst: r0 imm: 2 28: JEqImm dst: r4 off: -1 imm: 0 29: MovImm dst: r0 imm: 1 return: 30: Exit === RUN TestLoadIndirect/variable_valid/kernel#04 === RUN TestLoadIndirect/variable_valid/C#05 === RUN TestJumpIfLessThan/eBPF#09 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JLTImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 10: Mov32Imm dst: r4 imm: 1 11: JaImm dst: r0 off: -1 imm: 0 result: 12: MovImm dst: r0 imm: 2 13: JEqImm dst: r4 off: -1 imm: 0 14: MovImm dst: r0 imm: 1 return: 15: Exit === RUN TestJumpIfLessThan/kernel#09 === RUN TestJumpIfLessThan/C#10 === RUN TestJumpIfGreaterThan/C#10 --- PASS: TestLoadAbsoluteBigOffset (0.75s) --- SKIP: TestLoadAbsoluteBigOffset/C (0.03s) --- SKIP: TestLoadAbsoluteBigOffset/eBPF (0.00s) --- PASS: TestLoadAbsoluteBigOffset/kernel (0.05s) --- SKIP: TestLoadAbsoluteBigOffset/C#01 (0.03s) --- SKIP: TestLoadAbsoluteBigOffset/eBPF#01 (0.00s) --- PASS: TestLoadAbsoluteBigOffset/kernel#01 (0.05s) --- SKIP: TestLoadAbsoluteBigOffset/C#02 (0.04s) --- SKIP: TestLoadAbsoluteBigOffset/eBPF#02 (0.00s) --- PASS: TestLoadAbsoluteBigOffset/kernel#02 (0.05s) --- SKIP: TestLoadAbsoluteBigOffset/C#03 (0.04s) --- SKIP: TestLoadAbsoluteBigOffset/eBPF#03 (0.00s) --- PASS: TestLoadAbsoluteBigOffset/kernel#03 (0.05s) --- SKIP: TestLoadAbsoluteBigOffset/C#04 (0.04s) --- SKIP: TestLoadAbsoluteBigOffset/eBPF#04 (0.00s) --- PASS: TestLoadAbsoluteBigOffset/kernel#04 (0.05s) --- SKIP: TestLoadAbsoluteBigOffset/C#05 (0.03s) --- SKIP: TestLoadAbsoluteBigOffset/eBPF#05 (0.00s) --- PASS: TestLoadAbsoluteBigOffset/kernel#05 (0.05s) --- SKIP: TestLoadAbsoluteBigOffset/C#06 (0.06s) --- SKIP: TestLoadAbsoluteBigOffset/eBPF#06 (0.00s) --- PASS: TestLoadAbsoluteBigOffset/kernel#06 (0.05s) --- SKIP: TestLoadAbsoluteBigOffset/C#07 (0.06s) --- SKIP: TestLoadAbsoluteBigOffset/eBPF#07 (0.00s) --- PASS: TestLoadAbsoluteBigOffset/kernel#07 (0.05s) === RUN TestJumpIfLessThan/eBPF#10 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: Mov32Imm dst: r5 imm: 23 4: JLTReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfLessThan/kernel#10 === RUN TestJumpIfLessThan/C#11 === RUN TestLoadIndirect/variable_valid/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 4 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemW dst: r4 src: r2 off: 0 imm: 0 6: SwapBE dst: r4 imm: 32 7: Mov32Reg dst: r5 src: r4 8: MovReg dst: r7 src: r5 9: LShImm dst: r7 imm: 32 10: ArShImm dst: r7 imm: 32 11: AddImm dst: r7 imm: 4 12: JGEImm dst: r7 off: -1 imm: 65532 13: AddReg dst: r7 src: r2 14: MovReg dst: r6 src: r7 15: AddImm dst: r6 imm: 4 16: JGTReg dst: r6 off: -1 src: r3 17: LdXMemW dst: r4 src: r7 off: 0 imm: 0 18: SwapBE dst: r4 imm: 32 19: Mov32Imm dst: r6 imm: -559038737 20: JEqReg dst: r4 off: -1 src: r6 filter_block_4: 21: Mov32Imm dst: r4 imm: 0 22: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 23: Mov32Imm dst: r4 imm: 1 24: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 25: MovImm dst: r4 imm: 0 26: JaImm dst: r0 off: -1 imm: 0 result: 27: MovImm dst: r0 imm: 2 28: JEqImm dst: r4 off: -1 imm: 0 29: MovImm dst: r0 imm: 1 return: 30: Exit === RUN TestLoadIndirect/variable_valid/kernel#05 === RUN TestJumpIfGreaterThan/eBPF#10 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: Mov32Imm dst: r5 imm: 23 4: JGTReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: 9: MovImm dst: r0 imm: 2 10: JEqImm dst: r4 off: -1 imm: 0 11: MovImm dst: r0 imm: 1 return: 12: Exit === RUN TestJumpIfGreaterThan/kernel#10 === RUN TestJumpIfLessThan/eBPF#11 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JLTReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfLessThan/kernel#11 --- PASS: TestJumpIfLessThan (0.92s) --- SKIP: TestJumpIfLessThan/C (0.04s) --- SKIP: TestJumpIfLessThan/eBPF (0.00s) --- PASS: TestJumpIfLessThan/kernel (0.05s) --- SKIP: TestJumpIfLessThan/C#01 (0.03s) --- SKIP: TestJumpIfLessThan/eBPF#01 (0.00s) --- PASS: TestJumpIfLessThan/kernel#01 (0.05s) --- SKIP: TestJumpIfLessThan/C#02 (0.03s) --- SKIP: TestJumpIfLessThan/eBPF#02 (0.00s) --- PASS: TestJumpIfLessThan/kernel#02 (0.05s) --- SKIP: TestJumpIfLessThan/C#03 (0.04s) --- SKIP: TestJumpIfLessThan/eBPF#03 (0.00s) --- PASS: TestJumpIfLessThan/kernel#03 (0.05s) --- SKIP: TestJumpIfLessThan/C#04 (0.04s) --- SKIP: TestJumpIfLessThan/eBPF#04 (0.00s) --- PASS: TestJumpIfLessThan/kernel#04 (0.05s) --- SKIP: TestJumpIfLessThan/C#05 (0.03s) --- SKIP: TestJumpIfLessThan/eBPF#05 (0.00s) --- PASS: TestJumpIfLessThan/kernel#05 (0.05s) --- SKIP: TestJumpIfLessThan/C#06 (0.04s) --- SKIP: TestJumpIfLessThan/eBPF#06 (0.00s) --- PASS: TestJumpIfLessThan/kernel#06 (0.05s) --- SKIP: TestJumpIfLessThan/C#07 (0.06s) --- SKIP: TestJumpIfLessThan/eBPF#07 (0.00s) --- PASS: TestJumpIfLessThan/kernel#07 (0.05s) --- SKIP: TestJumpIfLessThan/C#08 (0.06s) --- SKIP: TestJumpIfLessThan/eBPF#08 (0.00s) --- PASS: TestJumpIfLessThan/kernel#08 (0.00s) --- SKIP: TestJumpIfLessThan/C#09 (0.05s) --- SKIP: TestJumpIfLessThan/eBPF#09 (0.00s) --- PASS: TestJumpIfLessThan/kernel#09 (0.00s) --- SKIP: TestJumpIfLessThan/C#10 (0.04s) --- SKIP: TestJumpIfLessThan/eBPF#10 (0.00s) --- PASS: TestJumpIfLessThan/kernel#10 (0.00s) --- SKIP: TestJumpIfLessThan/C#11 (0.04s) --- SKIP: TestJumpIfLessThan/eBPF#11 (0.00s) --- PASS: TestJumpIfLessThan/kernel#11 (0.00s) === RUN TestLoadIndirect/constant_outofbounds === RUN TestLoadIndirect/constant_outofbounds/C === RUN TestJumpIfGreaterThan/C#11 === RUN TestLoadIndirect/constant_outofbounds/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: -3 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: 3 7: JGEImm dst: r7 off: -1 imm: 65535 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 1 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemB dst: r4 src: r7 off: 0 imm: 0 13: Mov32Imm dst: r4 imm: 1 14: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 15: MovImm dst: r4 imm: 0 16: JaImm dst: r0 off: -1 imm: 0 result: 17: MovImm dst: r0 imm: 2 18: JEqImm dst: r4 off: -1 imm: 0 19: MovImm dst: r0 imm: 1 return: 20: Exit === RUN TestLoadIndirect/constant_outofbounds/kernel === RUN TestLoadIndirect/constant_outofbounds/C#01 === RUN TestJumpIfGreaterThan/eBPF#11 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: JGTReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 filter_block_6: 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 14: JEqImm dst: r4 off: -1 imm: 0 15: MovImm dst: r0 imm: 1 return: 16: Exit === RUN TestJumpIfGreaterThan/kernel#11 === RUN TestLoadIndirect/constant_outofbounds/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: -16 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: 15 7: JGEImm dst: r7 off: -1 imm: 65535 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 1 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemB dst: r4 src: r7 off: 0 imm: 0 13: Mov32Imm dst: r4 imm: 1 14: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 15: MovImm dst: r4 imm: 0 16: JaImm dst: r0 off: -1 imm: 0 result: 17: MovImm dst: r0 imm: 2 18: JEqImm dst: r4 off: -1 imm: 0 19: MovImm dst: r0 imm: 1 return: 20: Exit === RUN TestLoadIndirect/constant_outofbounds/kernel#01 --- PASS: TestJumpIfGreaterThan (0.94s) --- SKIP: TestJumpIfGreaterThan/C (0.04s) --- SKIP: TestJumpIfGreaterThan/eBPF (0.00s) --- PASS: TestJumpIfGreaterThan/kernel (0.00s) --- SKIP: TestJumpIfGreaterThan/C#01 (0.04s) --- SKIP: TestJumpIfGreaterThan/eBPF#01 (0.00s) --- PASS: TestJumpIfGreaterThan/kernel#01 (0.00s) --- SKIP: TestJumpIfGreaterThan/C#02 (0.03s) --- SKIP: TestJumpIfGreaterThan/eBPF#02 (0.00s) --- PASS: TestJumpIfGreaterThan/kernel#02 (0.00s) --- SKIP: TestJumpIfGreaterThan/C#03 (0.03s) --- SKIP: TestJumpIfGreaterThan/eBPF#03 (0.00s) --- PASS: TestJumpIfGreaterThan/kernel#03 (0.00s) --- SKIP: TestJumpIfGreaterThan/C#04 (0.03s) --- SKIP: TestJumpIfGreaterThan/eBPF#04 (0.00s) --- PASS: TestJumpIfGreaterThan/kernel#04 (0.05s) --- SKIP: TestJumpIfGreaterThan/C#05 (0.04s) --- SKIP: TestJumpIfGreaterThan/eBPF#05 (0.00s) --- PASS: TestJumpIfGreaterThan/kernel#05 (0.05s) --- SKIP: TestJumpIfGreaterThan/C#06 (0.05s) --- SKIP: TestJumpIfGreaterThan/eBPF#06 (0.00s) --- PASS: TestJumpIfGreaterThan/kernel#06 (0.05s) --- SKIP: TestJumpIfGreaterThan/C#07 (0.05s) --- SKIP: TestJumpIfGreaterThan/eBPF#07 (0.00s) --- PASS: TestJumpIfGreaterThan/kernel#07 (0.05s) --- SKIP: TestJumpIfGreaterThan/C#08 (0.04s) --- SKIP: TestJumpIfGreaterThan/eBPF#08 (0.00s) --- PASS: TestJumpIfGreaterThan/kernel#08 (0.05s) --- SKIP: TestJumpIfGreaterThan/C#09 (0.06s) --- SKIP: TestJumpIfGreaterThan/eBPF#09 (0.00s) --- PASS: TestJumpIfGreaterThan/kernel#09 (0.05s) --- SKIP: TestJumpIfGreaterThan/C#10 (0.06s) --- SKIP: TestJumpIfGreaterThan/eBPF#10 (0.00s) --- PASS: TestJumpIfGreaterThan/kernel#10 (0.05s) --- SKIP: TestJumpIfGreaterThan/C#11 (0.06s) --- SKIP: TestJumpIfGreaterThan/eBPF#11 (0.00s) --- PASS: TestJumpIfGreaterThan/kernel#11 (0.05s) === RUN TestLoadIndirect/constant_outofbounds/C#02 === RUN TestLoadIndirect/constant_outofbounds/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: -1 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: -2 7: JGEImm dst: r7 off: -1 imm: 65532 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 4 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemW dst: r4 src: r7 off: 0 imm: 0 13: SwapBE dst: r4 imm: 32 14: Mov32Imm dst: r4 imm: 1 15: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 16: MovImm dst: r4 imm: 0 17: JaImm dst: r0 off: -1 imm: 0 result: 18: MovImm dst: r0 imm: 2 19: JEqImm dst: r4 off: -1 imm: 0 20: MovImm dst: r0 imm: 1 return: 21: Exit === RUN TestLoadIndirect/constant_outofbounds/kernel#02 === RUN TestLoadIndirect/constant_outofbounds/C#03 === RUN TestLoadIndirect/constant_outofbounds/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: 255 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: -300 7: JGEImm dst: r7 off: -1 imm: 65534 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 2 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemH dst: r4 src: r7 off: 0 imm: 0 13: SwapBE dst: r4 imm: 16 14: Mov32Imm dst: r4 imm: 1 15: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 16: MovImm dst: r4 imm: 0 17: JaImm dst: r0 off: -1 imm: 0 result: 18: MovImm dst: r0 imm: 2 19: JEqImm dst: r4 off: -1 imm: 0 20: MovImm dst: r0 imm: 1 return: 21: Exit === RUN TestLoadIndirect/constant_outofbounds/kernel#03 === RUN TestLoadIndirect/constant_outofbounds/C#04 === RUN TestLoadIndirect/constant_outofbounds/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r5 imm: -16 3: MovReg dst: r7 src: r5 4: LShImm dst: r7 imm: 32 5: ArShImm dst: r7 imm: 32 6: AddImm dst: r7 imm: 30 7: JGEImm dst: r7 off: -1 imm: 65535 8: AddReg dst: r7 src: r2 9: MovReg dst: r6 src: r7 10: AddImm dst: r6 imm: 1 11: JGTReg dst: r6 off: -1 src: r3 12: LdXMemB dst: r4 src: r7 off: 0 imm: 0 13: Mov32Imm dst: r4 imm: 1 14: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 15: MovImm dst: r4 imm: 0 16: JaImm dst: r0 off: -1 imm: 0 result: 17: MovImm dst: r0 imm: 2 18: JEqImm dst: r4 off: -1 imm: 0 19: MovImm dst: r0 imm: 1 return: 20: Exit === RUN TestLoadIndirect/constant_outofbounds/kernel#04 === RUN TestLoadIndirect/variable_outofbounds === RUN TestLoadIndirect/variable_outofbounds/C === RUN TestLoadIndirect/variable_outofbounds/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 4 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemW dst: r4 src: r2 off: 0 imm: 0 6: SwapBE dst: r4 imm: 32 7: Mov32Reg dst: r5 src: r4 8: MovReg dst: r7 src: r5 9: LShImm dst: r7 imm: 32 10: ArShImm dst: r7 imm: 32 11: AddImm dst: r7 imm: 3 12: JGEImm dst: r7 off: -1 imm: 65535 13: AddReg dst: r7 src: r2 14: MovReg dst: r6 src: r7 15: AddImm dst: r6 imm: 1 16: JGTReg dst: r6 off: -1 src: r3 17: LdXMemB dst: r4 src: r7 off: 0 imm: 0 18: Mov32Imm dst: r4 imm: 1 19: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 20: MovImm dst: r4 imm: 0 21: JaImm dst: r0 off: -1 imm: 0 result: 22: MovImm dst: r0 imm: 2 23: JEqImm dst: r4 off: -1 imm: 0 24: MovImm dst: r0 imm: 1 return: 25: Exit === RUN TestLoadIndirect/variable_outofbounds/kernel === RUN TestLoadIndirect/variable_outofbounds/C#01 === RUN TestLoadIndirect/variable_outofbounds/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 4 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemW dst: r4 src: r2 off: 0 imm: 0 6: SwapBE dst: r4 imm: 32 7: Mov32Reg dst: r5 src: r4 8: MovReg dst: r7 src: r5 9: LShImm dst: r7 imm: 32 10: ArShImm dst: r7 imm: 32 11: AddImm dst: r7 imm: 15 12: JGEImm dst: r7 off: -1 imm: 65535 13: AddReg dst: r7 src: r2 14: MovReg dst: r6 src: r7 15: AddImm dst: r6 imm: 1 16: JGTReg dst: r6 off: -1 src: r3 17: LdXMemB dst: r4 src: r7 off: 0 imm: 0 18: Mov32Imm dst: r4 imm: 1 19: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 20: MovImm dst: r4 imm: 0 21: JaImm dst: r0 off: -1 imm: 0 result: 22: MovImm dst: r0 imm: 2 23: JEqImm dst: r4 off: -1 imm: 0 24: MovImm dst: r0 imm: 1 return: 25: Exit === RUN TestLoadIndirect/variable_outofbounds/kernel#01 === RUN TestLoadIndirect/variable_outofbounds/C#02 === RUN TestLoadIndirect/variable_outofbounds/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 4 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemW dst: r4 src: r2 off: 0 imm: 0 6: SwapBE dst: r4 imm: 32 7: Mov32Reg dst: r5 src: r4 8: MovReg dst: r7 src: r5 9: LShImm dst: r7 imm: 32 10: ArShImm dst: r7 imm: 32 11: AddImm dst: r7 imm: -2 12: JGEImm dst: r7 off: -1 imm: 65532 13: AddReg dst: r7 src: r2 14: MovReg dst: r6 src: r7 15: AddImm dst: r6 imm: 4 16: JGTReg dst: r6 off: -1 src: r3 17: LdXMemW dst: r4 src: r7 off: 0 imm: 0 18: SwapBE dst: r4 imm: 32 19: Mov32Imm dst: r4 imm: 1 20: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 21: MovImm dst: r4 imm: 0 22: JaImm dst: r0 off: -1 imm: 0 result: 23: MovImm dst: r0 imm: 2 24: JEqImm dst: r4 off: -1 imm: 0 25: MovImm dst: r0 imm: 1 return: 26: Exit === RUN TestLoadIndirect/variable_outofbounds/kernel#02 === RUN TestLoadIndirect/variable_outofbounds/C#03 === RUN TestLoadIndirect/variable_outofbounds/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 4 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemW dst: r4 src: r2 off: 0 imm: 0 6: SwapBE dst: r4 imm: 32 7: Mov32Reg dst: r5 src: r4 8: MovReg dst: r7 src: r5 9: LShImm dst: r7 imm: 32 10: ArShImm dst: r7 imm: 32 11: AddImm dst: r7 imm: -300 12: JGEImm dst: r7 off: -1 imm: 65534 13: AddReg dst: r7 src: r2 14: MovReg dst: r6 src: r7 15: AddImm dst: r6 imm: 2 16: JGTReg dst: r6 off: -1 src: r3 17: LdXMemH dst: r4 src: r7 off: 0 imm: 0 18: SwapBE dst: r4 imm: 16 19: Mov32Imm dst: r4 imm: 1 20: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 21: MovImm dst: r4 imm: 0 22: JaImm dst: r0 off: -1 imm: 0 result: 23: MovImm dst: r0 imm: 2 24: JEqImm dst: r4 off: -1 imm: 0 25: MovImm dst: r0 imm: 1 return: 26: Exit === RUN TestLoadIndirect/variable_outofbounds/kernel#03 === RUN TestLoadIndirect/variable_outofbounds/C#04 === RUN TestLoadIndirect/variable_outofbounds/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 4 4: JGTReg dst: r6 off: -1 src: r3 5: LdXMemW dst: r4 src: r2 off: 0 imm: 0 6: SwapBE dst: r4 imm: 32 7: Mov32Reg dst: r5 src: r4 8: MovReg dst: r7 src: r5 9: LShImm dst: r7 imm: 32 10: ArShImm dst: r7 imm: 32 11: AddImm dst: r7 imm: 30 12: JGEImm dst: r7 off: -1 imm: 65535 13: AddReg dst: r7 src: r2 14: MovReg dst: r6 src: r7 15: AddImm dst: r6 imm: 1 16: JGTReg dst: r6 off: -1 src: r3 17: LdXMemB dst: r4 src: r7 off: 0 imm: 0 18: Mov32Imm dst: r4 imm: 1 19: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 20: MovImm dst: r4 imm: 0 21: JaImm dst: r0 off: -1 imm: 0 result: 22: MovImm dst: r0 imm: 2 23: JEqImm dst: r4 off: -1 imm: 0 24: MovImm dst: r0 imm: 1 return: 25: Exit === RUN TestLoadIndirect/variable_outofbounds/kernel#04 --- PASS: TestLoadIndirect (1.88s) --- PASS: TestLoadIndirect/constant_valid (0.38s) --- SKIP: TestLoadIndirect/constant_valid/C (0.04s) --- SKIP: TestLoadIndirect/constant_valid/eBPF (0.00s) --- PASS: TestLoadIndirect/constant_valid/kernel (0.00s) --- SKIP: TestLoadIndirect/constant_valid/C#01 (0.04s) --- SKIP: TestLoadIndirect/constant_valid/eBPF#01 (0.00s) --- PASS: TestLoadIndirect/constant_valid/kernel#01 (0.05s) --- SKIP: TestLoadIndirect/constant_valid/C#02 (0.04s) --- SKIP: TestLoadIndirect/constant_valid/eBPF#02 (0.00s) --- PASS: TestLoadIndirect/constant_valid/kernel#02 (0.00s) --- SKIP: TestLoadIndirect/constant_valid/C#03 (0.04s) --- SKIP: TestLoadIndirect/constant_valid/eBPF#03 (0.00s) --- PASS: TestLoadIndirect/constant_valid/kernel#03 (0.05s) --- SKIP: TestLoadIndirect/constant_valid/C#04 (0.04s) --- SKIP: TestLoadIndirect/constant_valid/eBPF#04 (0.00s) --- PASS: TestLoadIndirect/constant_valid/kernel#04 (0.00s) --- SKIP: TestLoadIndirect/constant_valid/C#05 (0.04s) --- SKIP: TestLoadIndirect/constant_valid/eBPF#05 (0.00s) --- PASS: TestLoadIndirect/constant_valid/kernel#05 (0.05s) --- PASS: TestLoadIndirect/variable_valid (0.47s) --- SKIP: TestLoadIndirect/variable_valid/C (0.04s) --- SKIP: TestLoadIndirect/variable_valid/eBPF (0.00s) --- PASS: TestLoadIndirect/variable_valid/kernel (0.00s) --- SKIP: TestLoadIndirect/variable_valid/C#01 (0.04s) --- SKIP: TestLoadIndirect/variable_valid/eBPF#01 (0.00s) --- PASS: TestLoadIndirect/variable_valid/kernel#01 (0.05s) --- SKIP: TestLoadIndirect/variable_valid/C#02 (0.04s) --- SKIP: TestLoadIndirect/variable_valid/eBPF#02 (0.00s) --- PASS: TestLoadIndirect/variable_valid/kernel#02 (0.00s) --- SKIP: TestLoadIndirect/variable_valid/C#03 (0.06s) --- SKIP: TestLoadIndirect/variable_valid/eBPF#03 (0.00s) --- PASS: TestLoadIndirect/variable_valid/kernel#03 (0.05s) --- SKIP: TestLoadIndirect/variable_valid/C#04 (0.06s) --- SKIP: TestLoadIndirect/variable_valid/eBPF#04 (0.00s) --- PASS: TestLoadIndirect/variable_valid/kernel#04 (0.00s) --- SKIP: TestLoadIndirect/variable_valid/C#05 (0.06s) --- SKIP: TestLoadIndirect/variable_valid/eBPF#05 (0.00s) --- PASS: TestLoadIndirect/variable_valid/kernel#05 (0.05s) --- PASS: TestLoadIndirect/constant_outofbounds (0.48s) --- SKIP: TestLoadIndirect/constant_outofbounds/C (0.05s) --- SKIP: TestLoadIndirect/constant_outofbounds/eBPF (0.00s) --- PASS: TestLoadIndirect/constant_outofbounds/kernel (0.00s) --- SKIP: TestLoadIndirect/constant_outofbounds/C#01 (0.04s) --- SKIP: TestLoadIndirect/constant_outofbounds/eBPF#01 (0.00s) --- PASS: TestLoadIndirect/constant_outofbounds/kernel#01 (0.05s) --- SKIP: TestLoadIndirect/constant_outofbounds/C#02 (0.06s) --- SKIP: TestLoadIndirect/constant_outofbounds/eBPF#02 (0.00s) --- PASS: TestLoadIndirect/constant_outofbounds/kernel#02 (0.05s) --- SKIP: TestLoadIndirect/constant_outofbounds/C#03 (0.06s) --- SKIP: TestLoadIndirect/constant_outofbounds/eBPF#03 (0.00s) --- PASS: TestLoadIndirect/constant_outofbounds/kernel#03 (0.05s) --- SKIP: TestLoadIndirect/constant_outofbounds/C#04 (0.07s) --- SKIP: TestLoadIndirect/constant_outofbounds/eBPF#04 (0.00s) --- PASS: TestLoadIndirect/constant_outofbounds/kernel#04 (0.05s) --- PASS: TestLoadIndirect/variable_outofbounds (0.55s) --- SKIP: TestLoadIndirect/variable_outofbounds/C (0.07s) --- SKIP: TestLoadIndirect/variable_outofbounds/eBPF (0.00s) --- PASS: TestLoadIndirect/variable_outofbounds/kernel (0.00s) --- SKIP: TestLoadIndirect/variable_outofbounds/C#01 (0.07s) --- SKIP: TestLoadIndirect/variable_outofbounds/eBPF#01 (0.00s) --- PASS: TestLoadIndirect/variable_outofbounds/kernel#01 (0.05s) --- SKIP: TestLoadIndirect/variable_outofbounds/C#02 (0.07s) --- SKIP: TestLoadIndirect/variable_outofbounds/eBPF#02 (0.00s) --- PASS: TestLoadIndirect/variable_outofbounds/kernel#02 (0.05s) --- SKIP: TestLoadIndirect/variable_outofbounds/C#03 (0.07s) --- SKIP: TestLoadIndirect/variable_outofbounds/eBPF#03 (0.00s) --- PASS: TestLoadIndirect/variable_outofbounds/kernel#03 (0.05s) --- SKIP: TestLoadIndirect/variable_outofbounds/C#04 (0.07s) --- SKIP: TestLoadIndirect/variable_outofbounds/eBPF#04 (0.00s) --- PASS: TestLoadIndirect/variable_outofbounds/kernel#04 (0.05s) PASS ok github.com/cloudflare/cbpfc 3.566s ? github.com/cloudflare/cbpfc/clang [no test files] make[1]: Leaving directory '/build/reproducible-path/golang-github-cloudflare-cbpfc-0.0~git20231012.992ed75' create-stamp debian/debhelper-build-stamp dh_testroot -O--builddirectory=_build -O--buildsystem=golang dh_prep -O--builddirectory=_build -O--buildsystem=golang dh_auto_install --destdir=debian/golang-github-cloudflare-cbpfc-dev/ -O--builddirectory=_build -O--buildsystem=golang dh_installdocs -O--builddirectory=_build -O--buildsystem=golang dh_installchangelogs -O--builddirectory=_build -O--buildsystem=golang dh_installsystemduser -O--builddirectory=_build -O--buildsystem=golang dh_perl -O--builddirectory=_build -O--buildsystem=golang dh_link -O--builddirectory=_build -O--buildsystem=golang dh_strip_nondeterminism -O--builddirectory=_build -O--buildsystem=golang dh_compress -O--builddirectory=_build -O--buildsystem=golang dh_fixperms -O--builddirectory=_build -O--buildsystem=golang dh_missing -O--builddirectory=_build -O--buildsystem=golang dh_installdeb -O--builddirectory=_build -O--buildsystem=golang dh_golang -O--builddirectory=_build -O--buildsystem=golang dh_gencontrol -O--builddirectory=_build -O--buildsystem=golang dh_md5sums -O--builddirectory=_build -O--buildsystem=golang dh_builddeb -O--builddirectory=_build -O--buildsystem=golang dpkg-deb: building package 'golang-github-cloudflare-cbpfc-dev' in '../golang-github-cloudflare-cbpfc-dev_0.0~git20231012.992ed75-2_all.deb'. dpkg-genbuildinfo --build=binary -O../golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_arm64.buildinfo dpkg-genchanges --build=binary -O../golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_arm64.changes dpkg-genchanges: info: binary-only upload (no source code included) dpkg-source --after-build . dpkg-buildpackage: info: binary-only upload (no source included) dpkg-genchanges: info: not including original source code in upload I: copying local configuration I: user script /srv/workspace/pbuilder/2844666/tmp/hooks/B01_cleanup starting I: user script /srv/workspace/pbuilder/2844666/tmp/hooks/B01_cleanup finished I: unmounting dev/ptmx filesystem I: unmounting dev/pts filesystem I: unmounting dev/shm filesystem I: unmounting proc filesystem I: unmounting sys filesystem I: cleaning the build env I: removing directory /srv/workspace/pbuilder/2844666 and its subdirectories I: Current time: Sat Mar 28 05:30:45 +14 2026 I: pbuilder-time-stamp: 1774625445 + false + set +x Fri Mar 27 15:30:45 UTC 2026 I: Signing ./b2/golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_arm64.buildinfo as golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_arm64.buildinfo.asc Fri Mar 27 15:30:45 UTC 2026 I: Signed ./b2/golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_arm64.buildinfo as ./b2/golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_arm64.buildinfo.asc Fri Mar 27 15:30:45 UTC 2026 - build #2 for golang-github-cloudflare-cbpfc/trixie/arm64 on codethink03-arm64 done. Starting cleanup. All cleanup done. Fri Mar 27 15:30:45 UTC 2026 - reproducible_build.sh stopped running as /tmp/jenkins-script-DzOLCG4y, removing. /srv/reproducible-results/rbuild-debian/r-b-build.bvEh5Q9U: total 284 drwxr-xr-x 2 jenkins jenkins 4096 Feb 22 09:06 b1 drwxr-xr-x 2 jenkins jenkins 4096 Feb 22 09:07 b2 -rw-r--r-- 1 jenkins jenkins 2689 Jun 27 2024 golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.dsc -rw------- 1 jenkins jenkins 274375 Feb 22 09:06 rbuildlog.HdrqVCF /srv/reproducible-results/rbuild-debian/r-b-build.bvEh5Q9U/b1: total 328 -rw-r--r-- 1 jenkins jenkins 270026 Feb 22 09:06 build.log -rw-r--r-- 1 jenkins jenkins 26656 Feb 22 09:06 golang-github-cloudflare-cbpfc-dev_0.0~git20231012.992ed75-2_all.deb -rw-r--r-- 1 jenkins jenkins 3100 Feb 22 09:06 golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.debian.tar.xz -rw-r--r-- 1 jenkins jenkins 2689 Feb 22 09:06 golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.dsc -rw-r--r-- 1 jenkins jenkins 5786 Feb 22 09:06 golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_arm64.buildinfo -rw-r--r-- 1 jenkins jenkins 6668 Feb 22 09:06 golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_arm64.buildinfo.asc -rw-r--r-- 1 jenkins jenkins 1414 Feb 22 09:06 golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_arm64.changes -rw-r--r-- 1 jenkins jenkins 1645 Feb 22 09:06 golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_source.changes /srv/reproducible-results/rbuild-debian/r-b-build.bvEh5Q9U/b2: total 328 -rw-r--r-- 1 jenkins jenkins 272484 Feb 22 09:07 build.log -rw-r--r-- 1 jenkins jenkins 26656 Feb 22 09:07 golang-github-cloudflare-cbpfc-dev_0.0~git20231012.992ed75-2_all.deb -rw-r--r-- 1 jenkins jenkins 3100 Feb 22 09:07 golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.debian.tar.xz -rw-r--r-- 1 jenkins jenkins 2689 Feb 22 09:07 golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.dsc -rw-r--r-- 1 jenkins jenkins 5786 Feb 22 09:07 golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_arm64.buildinfo -rw-r--r-- 1 jenkins jenkins 6668 Feb 22 09:07 golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_arm64.buildinfo.asc -rw-r--r-- 1 jenkins jenkins 1414 Feb 22 09:07 golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_arm64.changes -rw-r--r-- 1 jenkins jenkins 1645 Feb 22 09:07 golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_source.changes Sat Feb 22 09:07:46 UTC 2025 I: Deleting $TMPDIR on codethink03-arm64.debian.net. Sat Feb 22 09:07:47 UTC 2025 I: golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_arm64.changes: Format: 1.8 Date: Thu, 27 Jun 2024 08:26:19 -0400 Source: golang-github-cloudflare-cbpfc Binary: golang-github-cloudflare-cbpfc-dev Architecture: all Version: 0.0~git20231012.992ed75-2 Distribution: unstable Urgency: medium Maintainer: Debian Go Packaging Team Changed-By: Reinhard Tartler Description: golang-github-cloudflare-cbpfc-dev - cBPF to C or eBPF compiler (library) Changes: golang-github-cloudflare-cbpfc (0.0~git20231012.992ed75-2) unstable; urgency=medium . * Team upload. * No-change re-upload to aid testing migration Checksums-Sha1: b028795efd3c40a7907fba2a0e182f58a3a77469 26656 golang-github-cloudflare-cbpfc-dev_0.0~git20231012.992ed75-2_all.deb 8c508c2b3171e5724769b1dec2ab66912b41ac57 5786 golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_arm64.buildinfo Checksums-Sha256: 3a7cecf18331c1a3cbf930c97973370ddc3e960b2f518589444a26d68b21056d 26656 golang-github-cloudflare-cbpfc-dev_0.0~git20231012.992ed75-2_all.deb 12188b24aa08ddc347019b9c76277bab53e113dc3949ac01ecfd613a51152dae 5786 golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_arm64.buildinfo Files: 951e8a68ad660d4eb10d0937f623c556 26656 golang optional golang-github-cloudflare-cbpfc-dev_0.0~git20231012.992ed75-2_all.deb abd68fc1b8a63eadc4783fbfd2f630fe 5786 golang optional golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_arm64.buildinfo removed '/var/lib/jenkins/userContent/reproducible/debian/rbuild/trixie/arm64/golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.rbuild.log' removed '/var/lib/jenkins/userContent/reproducible/debian/rbuild/trixie/arm64/golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.rbuild.log.gz' removed '/var/lib/jenkins/userContent/reproducible/debian/logs/trixie/arm64/golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.build1.log.gz' removed '/var/lib/jenkins/userContent/reproducible/debian/logs/trixie/arm64/golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.build2.log.gz' removed '/var/lib/jenkins/userContent/reproducible/debian/buildinfo/trixie/arm64/golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_arm64.buildinfo' removed '/var/lib/jenkins/userContent/reproducible/debian/logdiffs/trixie/arm64/golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.diff.gz' Diff of the two buildlogs: -- --- b1/build.log 2025-02-22 09:06:50.818293409 +0000 +++ b2/build.log 2025-02-22 09:07:46.523786388 +0000 @@ -1,6 +1,6 @@ I: pbuilder: network access will be disabled during build -I: Current time: Fri Feb 21 21:06:04 -12 2025 -I: pbuilder-time-stamp: 1740215164 +I: Current time: Sat Mar 28 05:29:53 +14 2026 +I: pbuilder-time-stamp: 1774625393 I: Building the build Environment I: extracting base tarball [/var/cache/pbuilder/trixie-reproducible-base.tgz] I: copying local configuration @@ -24,52 +24,84 @@ dpkg-source: info: applying auto-gitignore I: Not using root during the build. I: Installing the build-deps -I: user script /srv/workspace/pbuilder/2165263/tmp/hooks/D02_print_environment starting +I: user script /srv/workspace/pbuilder/2844666/tmp/hooks/D01_modify_environment starting +debug: Running on codethink03-arm64. +I: Changing host+domainname to test build reproducibility +I: Adding a custom variable just for the fun of it... +I: Changing /bin/sh to bash +'/bin/sh' -> '/bin/bash' +lrwxrwxrwx 1 root root 9 Mar 27 15:30 /bin/sh -> /bin/bash +I: Setting pbuilder2's login shell to /bin/bash +I: Setting pbuilder2's GECOS to second user,second room,second work-phone,second home-phone,second other +I: user script /srv/workspace/pbuilder/2844666/tmp/hooks/D01_modify_environment finished +I: user script /srv/workspace/pbuilder/2844666/tmp/hooks/D02_print_environment starting I: set - BUILDDIR='/build/reproducible-path' - BUILDUSERGECOS='first user,first room,first work-phone,first home-phone,first other' - BUILDUSERNAME='pbuilder1' - BUILD_ARCH='arm64' - DEBIAN_FRONTEND='noninteractive' + BASH=/bin/sh + BASHOPTS=checkwinsize:cmdhist:complete_fullquote:extquote:force_fignore:globasciiranges:globskipdots:hostcomplete:interactive_comments:patsub_replacement:progcomp:promptvars:sourcepath + BASH_ALIASES=() + BASH_ARGC=() + BASH_ARGV=() + BASH_CMDS=() + BASH_LINENO=([0]="12" [1]="0") + BASH_LOADABLES_PATH=/usr/local/lib/bash:/usr/lib/bash:/opt/local/lib/bash:/usr/pkg/lib/bash:/opt/pkg/lib/bash:. + BASH_SOURCE=([0]="/tmp/hooks/D02_print_environment" [1]="/tmp/hooks/D02_print_environment") + BASH_VERSINFO=([0]="5" [1]="2" [2]="37" [3]="1" [4]="release" [5]="aarch64-unknown-linux-gnu") + BASH_VERSION='5.2.37(1)-release' + BUILDDIR=/build/reproducible-path + BUILDUSERGECOS='second user,second room,second work-phone,second home-phone,second other' + BUILDUSERNAME=pbuilder2 + BUILD_ARCH=arm64 + DEBIAN_FRONTEND=noninteractive DEB_BUILD_OPTIONS='buildinfo=+all reproducible=+all parallel=12 ' - DISTRIBUTION='trixie' - HOME='/root' - HOST_ARCH='arm64' + DIRSTACK=() + DISTRIBUTION=trixie + EUID=0 + FUNCNAME=([0]="Echo" [1]="main") + GROUPS=() + HOME=/root + HOSTNAME=i-capture-the-hostname + HOSTTYPE=aarch64 + HOST_ARCH=arm64 IFS=' ' - INVOCATION_ID='e5e12366e69441d9acc7a55619923dfc' - LANG='C' - LANGUAGE='en_US:en' - LC_ALL='C' - MAIL='/var/mail/root' - OPTIND='1' - PATH='/usr/sbin:/usr/bin:/sbin:/bin:/usr/games' - PBCURRENTCOMMANDLINEOPERATION='build' - PBUILDER_OPERATION='build' - PBUILDER_PKGDATADIR='/usr/share/pbuilder' - PBUILDER_PKGLIBDIR='/usr/lib/pbuilder' - PBUILDER_SYSCONFDIR='/etc' - PPID='2165263' - PS1='# ' - PS2='> ' + INVOCATION_ID=a2d51ef857134714a1c60d52d7135770 + LANG=C + LANGUAGE=nl_BE:nl + LC_ALL=C + MACHTYPE=aarch64-unknown-linux-gnu + MAIL=/var/mail/root + OPTERR=1 + OPTIND=1 + OSTYPE=linux-gnu + PATH=/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/i/capture/the/path + PBCURRENTCOMMANDLINEOPERATION=build + PBUILDER_OPERATION=build + PBUILDER_PKGDATADIR=/usr/share/pbuilder + PBUILDER_PKGLIBDIR=/usr/lib/pbuilder + PBUILDER_SYSCONFDIR=/etc + PIPESTATUS=([0]="0") + POSIXLY_CORRECT=y + PPID=2844666 PS4='+ ' - PWD='/' - SHELL='/bin/bash' - SHLVL='2' - SUDO_COMMAND='/usr/bin/timeout -k 18.1h 18h /usr/bin/ionice -c 3 /usr/bin/nice /usr/sbin/pbuilder --build --configfile /srv/reproducible-results/rbuild-debian/r-b-build.bvEh5Q9U/pbuilderrc_UIik --distribution trixie --hookdir /etc/pbuilder/first-build-hooks --debbuildopts -b --basetgz /var/cache/pbuilder/trixie-reproducible-base.tgz --buildresult /srv/reproducible-results/rbuild-debian/r-b-build.bvEh5Q9U/b1 --logfile b1/build.log golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.dsc' - SUDO_GID='109' - SUDO_UID='104' - SUDO_USER='jenkins' - TERM='unknown' - TZ='/usr/share/zoneinfo/Etc/GMT+12' - USER='root' - _='/usr/bin/systemd-run' - http_proxy='http://192.168.101.4:3128' + PWD=/ + SHELL=/bin/bash + SHELLOPTS=braceexpand:errexit:hashall:interactive-comments:posix + SHLVL=3 + SUDO_COMMAND='/usr/bin/timeout -k 24.1h 24h /usr/bin/ionice -c 3 /usr/bin/nice -n 11 /usr/bin/unshare --uts -- /usr/sbin/pbuilder --build --configfile /srv/reproducible-results/rbuild-debian/r-b-build.bvEh5Q9U/pbuilderrc_5sMO --distribution trixie --hookdir /etc/pbuilder/rebuild-hooks --debbuildopts -b --basetgz /var/cache/pbuilder/trixie-reproducible-base.tgz --buildresult /srv/reproducible-results/rbuild-debian/r-b-build.bvEh5Q9U/b2 --logfile b2/build.log golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.dsc' + SUDO_GID=109 + SUDO_UID=104 + SUDO_USER=jenkins + TERM=unknown + TZ=/usr/share/zoneinfo/Etc/GMT-14 + UID=0 + USER=root + _='I: set' + http_proxy=http://192.168.101.4:3128 I: uname -a - Linux codethink04-arm64 6.1.0-31-cloud-arm64 #1 SMP Debian 6.1.128-1 (2025-02-07) aarch64 GNU/Linux + Linux i-capture-the-hostname 6.1.0-31-cloud-arm64 #1 SMP Debian 6.1.128-1 (2025-02-07) aarch64 GNU/Linux I: ls -l /bin - lrwxrwxrwx 1 root root 7 Nov 22 14:40 /bin -> usr/bin -I: user script /srv/workspace/pbuilder/2165263/tmp/hooks/D02_print_environment finished + lrwxrwxrwx 1 root root 7 Nov 22 2024 /bin -> usr/bin +I: user script /srv/workspace/pbuilder/2844666/tmp/hooks/D02_print_environment finished -> Attempting to satisfy build-dependencies -> Creating pbuilder-satisfydepends-dummy package Package: pbuilder-satisfydepends-dummy @@ -178,7 +210,7 @@ Get: 57 http://deb.debian.org/debian trixie/main arm64 golang-golang-x-text-dev all 0.22.0-1 [3995 kB] Get: 58 http://deb.debian.org/debian trixie/main arm64 golang-golang-x-crypto-dev all 1:0.25.0-1 [1682 kB] Get: 59 http://deb.debian.org/debian trixie/main arm64 golang-golang-x-net-dev all 1:0.27.0-1 [898 kB] -Fetched 128 MB in 1s (233 MB/s) +Fetched 128 MB in 0s (277 MB/s) Preconfiguring packages ... Selecting previously unselected package sensible-utils. (Reading database ... (Reading database ... 5% (Reading database ... 10% (Reading database ... 15% (Reading database ... 20% (Reading database ... 25% (Reading database ... 30% (Reading database ... 35% (Reading database ... 40% (Reading database ... 45% (Reading database ... 50% (Reading database ... 55% (Reading database ... 60% (Reading database ... 65% (Reading database ... 70% (Reading database ... 75% (Reading database ... 80% (Reading database ... 85% (Reading database ... 90% (Reading database ... 95% (Reading database ... 100% (Reading database ... 19972 files and directories currently installed.) @@ -429,7 +461,11 @@ Building tag database... -> Finished parsing the build-deps I: Building the package -I: Running cd /build/reproducible-path/golang-github-cloudflare-cbpfc-0.0~git20231012.992ed75/ && env PATH="/usr/sbin:/usr/bin:/sbin:/bin:/usr/games" HOME="/nonexistent/first-build" dpkg-buildpackage -us -uc -b && env PATH="/usr/sbin:/usr/bin:/sbin:/bin:/usr/games" HOME="/nonexistent/first-build" dpkg-genchanges -S > ../golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_source.changes +I: user script /srv/workspace/pbuilder/2844666/tmp/hooks/A99_set_merged_usr starting +Not re-configuring usrmerge for trixie +I: user script /srv/workspace/pbuilder/2844666/tmp/hooks/A99_set_merged_usr finished +hostname: Name or service not known +I: Running cd /build/reproducible-path/golang-github-cloudflare-cbpfc-0.0~git20231012.992ed75/ && env PATH="/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/i/capture/the/path" HOME="/nonexistent/second-build" dpkg-buildpackage -us -uc -b && env PATH="/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/i/capture/the/path" HOME="/nonexistent/second-build" dpkg-genchanges -S > ../golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_source.changes dpkg-buildpackage: info: source package golang-github-cloudflare-cbpfc dpkg-buildpackage: info: source version 0.0~git20231012.992ed75-2 dpkg-buildpackage: info: source distribution unstable @@ -448,38 +484,38 @@ dh_auto_configure -O--builddirectory=_build -O--buildsystem=golang dh_auto_build -O--builddirectory=_build -O--buildsystem=golang cd _build && go install -trimpath -v -p 12 github.com/cloudflare/cbpfc github.com/cloudflare/cbpfc/clang -internal/goarch +internal/coverage/rtcov internal/byteorder -internal/goos -internal/godebugs -internal/asan internal/unsafeheader internal/msan -internal/profilerecord -internal/coverage/rtcov -internal/runtime/syscall -internal/abi -internal/runtime/math +internal/goexperiment +internal/asan +internal/goos internal/cpu +internal/profilerecord +internal/godebugs +internal/goarch cmp internal/itoa -internal/goexperiment +internal/runtime/syscall math/bits unicode/utf8 sync/atomic unicode crypto/internal/fips140/alias crypto/internal/boring/sig +crypto/internal/fips140/subtle +internal/abi internal/chacha8rand +internal/runtime/math crypto/internal/fips140deps/byteorder -crypto/internal/fips140/subtle math internal/bytealg crypto/internal/fips140deps/cpu -internal/runtime/atomic internal/runtime/sys -internal/runtime/exithook +internal/runtime/atomic internal/stringslite +internal/runtime/exithook internal/race internal/sync internal/runtime/maps @@ -494,59 +530,59 @@ sort internal/bisect internal/testlog -io internal/oserror -path math/rand/v2 +io +path strconv syscall -internal/godebug hash +internal/godebug bytes strings crypto/internal/randutil -reflect crypto +reflect crypto/internal/fips140deps/godebug -crypto/internal/fips140 crypto/internal/impl regexp/syntax +crypto/internal/fips140 crypto/internal/fips140/sha256 crypto/internal/fips140/sha3 crypto/internal/fips140/sha512 crypto/internal/fips140/hmac crypto/internal/fips140/check -crypto/internal/fips140/aes -regexp -internal/syscall/execenv time +internal/syscall/execenv internal/syscall/unix -io/fs +crypto/internal/fips140/aes +regexp context +io/fs internal/poll internal/filepathlite +os internal/fmtsort encoding/binary -os golang.org/x/sys/unix crypto/internal/sysrand +io/ioutil fmt path/filepath -io/ioutil crypto/internal/entropy crypto/internal/fips140/drbg os/exec crypto/internal/fips140only crypto/internal/fips140/aes/gcm crypto/cipher -crypto/internal/boring encoding/hex +github.com/pkg/errors golang.org/x/net/bpf net/url -github.com/pkg/errors text/template/parse -crypto/sha1 +crypto/internal/boring github.com/cloudflare/cbpfc/clang +crypto/sha1 text/template github.com/cilium/ebpf/internal/unix github.com/cilium/ebpf/internal/sys @@ -559,7 +595,7 @@ === RUN TestFunctionName --- PASS: TestFunctionName (0.00s) === RUN TestNoInline ---- SKIP: TestNoInline (0.15s) +--- SKIP: TestNoInline (0.16s) === RUN TestZero --- PASS: TestZero (0.00s) === RUN TestRaw @@ -974,29 +1010,29 @@ return: 22: Exit === RUN TestLoadIndirectBigOffset/kernel#07 ---- PASS: TestLoadIndirectBigOffset (0.61s) - --- SKIP: TestLoadIndirectBigOffset/C (0.03s) +--- PASS: TestLoadIndirectBigOffset (0.82s) + --- SKIP: TestLoadIndirectBigOffset/C (0.07s) --- SKIP: TestLoadIndirectBigOffset/eBPF (0.00s) --- PASS: TestLoadIndirectBigOffset/kernel (0.00s) - --- SKIP: TestLoadIndirectBigOffset/C#01 (0.04s) + --- SKIP: TestLoadIndirectBigOffset/C#01 (0.07s) --- SKIP: TestLoadIndirectBigOffset/eBPF#01 (0.00s) --- PASS: TestLoadIndirectBigOffset/kernel#01 (0.00s) - --- SKIP: TestLoadIndirectBigOffset/C#02 (0.03s) + --- SKIP: TestLoadIndirectBigOffset/C#02 (0.07s) --- SKIP: TestLoadIndirectBigOffset/eBPF#02 (0.00s) --- PASS: TestLoadIndirectBigOffset/kernel#02 (0.05s) - --- SKIP: TestLoadIndirectBigOffset/C#03 (0.04s) + --- SKIP: TestLoadIndirectBigOffset/C#03 (0.06s) --- SKIP: TestLoadIndirectBigOffset/eBPF#03 (0.00s) --- PASS: TestLoadIndirectBigOffset/kernel#03 (0.05s) - --- SKIP: TestLoadIndirectBigOffset/C#04 (0.03s) + --- SKIP: TestLoadIndirectBigOffset/C#04 (0.06s) --- SKIP: TestLoadIndirectBigOffset/eBPF#04 (0.00s) - --- PASS: TestLoadIndirectBigOffset/kernel#04 (0.06s) - --- SKIP: TestLoadIndirectBigOffset/C#05 (0.04s) + --- PASS: TestLoadIndirectBigOffset/kernel#04 (0.05s) + --- SKIP: TestLoadIndirectBigOffset/C#05 (0.06s) --- SKIP: TestLoadIndirectBigOffset/eBPF#05 (0.00s) --- PASS: TestLoadIndirectBigOffset/kernel#05 (0.05s) - --- SKIP: TestLoadIndirectBigOffset/C#06 (0.04s) + --- SKIP: TestLoadIndirectBigOffset/C#06 (0.07s) --- SKIP: TestLoadIndirectBigOffset/eBPF#06 (0.00s) --- PASS: TestLoadIndirectBigOffset/kernel#06 (0.05s) - --- SKIP: TestLoadIndirectBigOffset/C#07 (0.04s) + --- SKIP: TestLoadIndirectBigOffset/C#07 (0.06s) --- SKIP: TestLoadIndirectBigOffset/eBPF#07 (0.00s) --- PASS: TestLoadIndirectBigOffset/kernel#07 (0.05s) === RUN TestLoadIndirectGuardOverflow @@ -1041,8 +1077,8 @@ return: 32: Exit === RUN TestLoadIndirectGuardOverflow/kernel ---- PASS: TestLoadIndirectGuardOverflow (0.09s) - --- SKIP: TestLoadIndirectGuardOverflow/C (0.04s) +--- PASS: TestLoadIndirectGuardOverflow (0.12s) + --- SKIP: TestLoadIndirectGuardOverflow/C (0.07s) --- SKIP: TestLoadIndirectGuardOverflow/eBPF (0.00s) --- PASS: TestLoadIndirectGuardOverflow/kernel (0.05s) === RUN TestScratchZero @@ -1140,51 +1176,36 @@ === RUN TestTAX === PAUSE TestTAX === CONT TestZeroInitA +=== CONT TestTAX === RUN TestZeroInitA/C -=== CONT TestALUShiftLeft -=== RUN TestALUShiftLeft/C -=== CONT TestJumpIfLessThan -=== RUN TestJumpIfLessThan/C +=== CONT TestTXA +=== RUN TestTXA/C +=== RUN TestTAX/C +=== CONT TestJumpIfEqual +=== CONT TestJumpIfLessOrEqual +=== CONT TestJumpIfGreaterOrEqual +=== RUN TestJumpIfEqual/C +=== RUN TestJumpIfGreaterOrEqual/C === CONT TestALUAnd === RUN TestALUAnd/C -=== CONT TestJumpIfGreaterThan -=== RUN TestJumpIfGreaterThan/C === CONT TestJumpIfNotEqual -=== CONT TestJumpIfEqual -=== CONT TestJump0 -=== CONT TestJump -=== CONT TestNegateA -=== CONT TestALUXor -=== CONT TestALUMod === RUN TestJumpIfNotEqual/C -=== RUN TestJumpIfEqual/C -=== RUN TestJump0/C -=== RUN TestJump/C -=== RUN TestNegateA/C -=== RUN TestALUXor/C -=== RUN TestALUMod/C -=== RUN TestZeroInitA/eBPF - ebpf_test.go:17: - 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 - 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 - filter_block_0: - 2: Mov32Imm dst: r4 imm: 0 - 3: Mov32Reg dst: r4 src: r4 - 4: JaImm dst: r0 off: -1 imm: 0 - result: - 5: MovImm dst: r0 imm: 2 - 6: JEqImm dst: r4 off: -1 imm: 0 - 7: MovImm dst: r0 imm: 1 - return: - 8: Exit -=== RUN TestZeroInitA/kernel -=== RUN TestJumpIfGreaterThan/eBPF +=== RUN TestJumpIfLessOrEqual/C +=== CONT TestRetConstant +=== RUN TestRetConstant/C +=== CONT TestJumpIfBitsNotSet +=== RUN TestJumpIfBitsNotSet/C +=== CONT TestJumpIfBitsSet +=== RUN TestJumpIfBitsSet/C +=== CONT TestRetA +=== RUN TestRetA/C +=== RUN TestJumpIfNotEqual/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 24 - 3: JGTImm dst: r4 off: -1 imm: 23 + 2: Mov32Imm dst: r4 imm: 23 + 3: JNEImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 @@ -1197,35 +1218,14 @@ 10: MovImm dst: r0 imm: 1 return: 11: Exit -=== RUN TestJumpIfGreaterThan/kernel -=== RUN TestJumpIfGreaterThan/C#01 -=== RUN TestJumpIfLessThan/eBPF +=== RUN TestJumpIfNotEqual/kernel +=== RUN TestJumpIfLessOrEqual/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 - 3: JLTImm dst: r4 off: -1 imm: 23 - filter_block_2: - 4: Mov32Imm dst: r4 imm: 0 - 5: JaImm dst: r0 off: -1 imm: 0 - filter_block_3: - 6: Mov32Imm dst: r4 imm: 1 - 7: JaImm dst: r0 off: -1 imm: 0 - result: - 8: MovImm dst: r0 imm: 2 - 9: JEqImm dst: r4 off: -1 imm: 0 - 10: MovImm dst: r0 imm: 1 - return: - 11: Exit -=== RUN TestJumpIfLessThan/kernel -=== RUN TestJumpIfNotEqual/eBPF - ebpf_test.go:17: - 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 - 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 - filter_block_0: - 2: Mov32Imm dst: r4 imm: 23 - 3: JNEImm dst: r4 off: -1 imm: 23 + 3: JLEImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 @@ -1238,29 +1238,7 @@ 10: MovImm dst: r0 imm: 1 return: 11: Exit -=== RUN TestJumpIfNotEqual/kernel -=== RUN TestALUShiftLeft/eBPF - ebpf_test.go:17: - 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 - 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 - filter_block_0: - 2: Mov32Imm dst: r4 imm: 1 - 3: LSh32Imm dst: r4 imm: 0 - 4: JEqImm dst: r4 off: -1 imm: 1 - filter_block_3: - 5: Mov32Imm dst: r4 imm: 0 - 6: JaImm dst: r0 off: -1 imm: 0 - filter_block_4: - 7: Mov32Imm dst: r4 imm: 1 - 8: JaImm dst: r0 off: -1 imm: 0 - result: - 9: MovImm dst: r0 imm: 2 - 10: JEqImm dst: r4 off: -1 imm: 0 - 11: MovImm dst: r0 imm: 1 - return: - 12: Exit -=== RUN TestALUShiftLeft/kernel -=== RUN TestALUShiftLeft/C#01 +=== RUN TestJumpIfLessOrEqual/kernel === RUN TestALUAnd/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 @@ -1283,62 +1261,72 @@ 12: Exit === RUN TestALUAnd/kernel === RUN TestALUAnd/C#01 -=== RUN TestJump/eBPF +=== RUN TestJumpIfEqual/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: MovReg dst: r6 src: r2 - 3: AddImm dst: r6 imm: 1 - 4: JGTReg dst: r6 off: -1 src: r3 - 5: LdXMemB dst: r4 src: r2 off: 0 imm: 0 - 6: JEqImm dst: r4 off: -1 imm: 1 + 2: Mov32Imm dst: r4 imm: 23 + 3: JEqImm dst: r4 off: -1 imm: 23 filter_block_2: - 7: JaImm dst: r0 off: -1 imm: 0 + 4: Mov32Imm dst: r4 imm: 0 + 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: - 8: Mov32Imm dst: r4 imm: 1 - filter_block_4: - 9: Mov32Reg dst: r4 src: r4 - 10: JaImm dst: r0 off: -1 imm: 0 - filter_nomatch: - 11: MovImm dst: r4 imm: 0 - 12: JaImm dst: r0 off: -1 imm: 0 + 6: Mov32Imm dst: r4 imm: 1 + 7: JaImm dst: r0 off: -1 imm: 0 result: - 13: MovImm dst: r0 imm: 2 - 14: JEqImm dst: r4 off: -1 imm: 0 - 15: MovImm dst: r0 imm: 1 + 8: MovImm dst: r0 imm: 2 + 9: JEqImm dst: r4 off: -1 imm: 0 + 10: MovImm dst: r0 imm: 1 return: - 16: Exit -=== RUN TestJump/kernel -=== RUN TestNegateA/eBPF + 11: Exit +=== RUN TestJumpIfEqual/kernel +=== RUN TestJumpIfEqual/C#01 +=== RUN TestTAX/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 26 - 3: Neg32Imm dst: r4 imm: 0 - 4: Mov32Imm dst: r6 imm: -2147483622 - 5: JEqReg dst: r4 off: -1 src: r6 - filter_block_3: - 6: Mov32Imm dst: r4 imm: 0 - 7: JaImm dst: r0 off: -1 imm: 0 - filter_block_4: - 8: Mov32Imm dst: r4 imm: 1 - 9: JaImm dst: r0 off: -1 imm: 0 + 2: Mov32Imm dst: r4 imm: 1 + 3: Mov32Reg dst: r5 src: r4 + 4: Mov32Reg dst: r4 src: r5 + 5: Mov32Reg dst: r4 src: r4 + 6: JaImm dst: r0 off: -1 imm: 0 result: - 10: MovImm dst: r0 imm: 2 - 11: JEqImm dst: r4 off: -1 imm: 0 - 12: MovImm dst: r0 imm: 1 + 7: MovImm dst: r0 imm: 2 + 8: JEqImm dst: r4 off: -1 imm: 0 + 9: MovImm dst: r0 imm: 1 return: - 13: Exit -=== RUN TestNegateA/kernel -=== RUN TestJumpIfEqual/eBPF + 10: Exit +=== RUN TestTAX/kernel +--- PASS: TestTAX (0.06s) + --- SKIP: TestTAX/C (0.06s) + --- SKIP: TestTAX/eBPF (0.00s) + --- PASS: TestTAX/kernel (0.00s) +=== CONT TestScratchX +=== RUN TestScratchX/C +=== RUN TestZeroInitA/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 23 - 3: JEqImm dst: r4 off: -1 imm: 23 + 2: Mov32Imm dst: r4 imm: 0 + 3: Mov32Reg dst: r4 src: r4 + 4: JaImm dst: r0 off: -1 imm: 0 + result: + 5: MovImm dst: r0 imm: 2 + 6: JEqImm dst: r4 off: -1 imm: 0 + 7: MovImm dst: r0 imm: 1 + return: + 8: Exit +=== RUN TestZeroInitA/kernel +=== RUN TestJumpIfGreaterOrEqual/eBPF + ebpf_test.go:17: + 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 + 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 + filter_block_0: + 2: Mov32Imm dst: r4 imm: 24 + 3: JGEImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 @@ -1351,68 +1339,78 @@ 10: MovImm dst: r0 imm: 1 return: 11: Exit -=== RUN TestJumpIfEqual/kernel -=== RUN TestJumpIfEqual/C#01 -=== RUN TestJump0/eBPF +=== RUN TestJumpIfGreaterOrEqual/kernel +=== RUN TestJumpIfGreaterOrEqual/C#01 +=== RUN TestTXA/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: MovReg dst: r6 src: r2 - 3: AddImm dst: r6 imm: 1 - 4: JGTReg dst: r6 off: -1 src: r3 - 5: Mov32Imm dst: r5 imm: 0 - 6: LdXMemB dst: r4 src: r2 off: 0 imm: 0 - 7: JaImm dst: r0 off: -1 imm: 0 - filter_block_3: - 8: JEqReg dst: r4 off: -1 src: r5 - filter_block_4: - 9: Mov32Reg dst: r4 src: r4 - 10: JaImm dst: r0 off: -1 imm: 0 - filter_nomatch: - 11: MovImm dst: r4 imm: 0 - 12: JaImm dst: r0 off: -1 imm: 0 + 2: Mov32Imm dst: r5 imm: 1 + 3: Mov32Reg dst: r4 src: r5 + 4: Mov32Reg dst: r4 src: r4 + 5: JaImm dst: r0 off: -1 imm: 0 result: - 13: MovImm dst: r0 imm: 2 - 14: JEqImm dst: r4 off: -1 imm: 0 - 15: MovImm dst: r0 imm: 1 + 6: MovImm dst: r0 imm: 2 + 7: JEqImm dst: r4 off: -1 imm: 0 + 8: MovImm dst: r0 imm: 1 return: - 16: Exit -=== RUN TestJump0/kernel -=== RUN TestALUMod/eBPF + 9: Exit +=== RUN TestTXA/kernel +--- PASS: TestTXA (0.07s) + --- SKIP: TestTXA/C (0.07s) + --- SKIP: TestTXA/eBPF (0.00s) + --- PASS: TestTXA/kernel (0.00s) +=== CONT TestALUOr +=== RUN TestALUOr/C +=== RUN TestRetConstant/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 16 - 3: Mod32Imm dst: r4 imm: 4 - 4: JEqImm dst: r4 off: -1 imm: 0 - filter_block_3: - 5: Mov32Imm dst: r4 imm: 0 - 6: JaImm dst: r0 off: -1 imm: 0 - filter_block_4: - 7: Mov32Imm dst: r4 imm: 1 - 8: JaImm dst: r0 off: -1 imm: 0 + 2: Mov32Imm dst: r4 imm: 1 + 3: JaImm dst: r0 off: -1 imm: 0 result: - 9: MovImm dst: r0 imm: 2 - 10: JEqImm dst: r4 off: -1 imm: 0 - 11: MovImm dst: r0 imm: 1 + 4: MovImm dst: r0 imm: 2 + 5: JEqImm dst: r4 off: -1 imm: 0 + 6: MovImm dst: r0 imm: 1 return: - 12: Exit -=== RUN TestALUMod/kernel -=== RUN TestALUMod/C#01 -=== RUN TestALUXor/eBPF + 7: Exit +=== RUN TestRetConstant/kernel +=== RUN TestRetConstant/C#01 +=== RUN TestJumpIfBitsSet/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 1 - 3: Xor32Imm dst: r4 imm: 1 - 4: JEqImm dst: r4 off: -1 imm: 0 + 2: Mov32Imm dst: r4 imm: 6 + 3: JSetImm dst: r4 off: -1 imm: 4 + filter_block_2: + 4: Mov32Imm dst: r4 imm: 0 + 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: + 6: Mov32Imm dst: r4 imm: 1 + 7: JaImm dst: r0 off: -1 imm: 0 + result: + 8: MovImm dst: r0 imm: 2 + 9: JEqImm dst: r4 off: -1 imm: 0 + 10: MovImm dst: r0 imm: 1 + return: + 11: Exit +=== RUN TestJumpIfBitsSet/kernel +=== RUN TestJumpIfBitsSet/C#01 +=== RUN TestJumpIfBitsNotSet/eBPF + ebpf_test.go:17: + 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 + 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 + filter_block_0: + 2: Mov32Imm dst: r4 imm: 6 + 3: JSetImm dst: r4 off: -1 imm: 4 + 4: JaImm dst: r0 off: -1 imm: 0 + filter_block_2: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 - filter_block_4: + filter_block_3: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: @@ -1421,25 +1419,18 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestALUXor/kernel -=== RUN TestALUXor/C#01 ---- PASS: TestZeroInitA (0.10s) - --- SKIP: TestZeroInitA/C (0.05s) - --- SKIP: TestZeroInitA/eBPF (0.00s) - --- PASS: TestZeroInitA/kernel (0.05s) -=== CONT TestALUShiftRight -=== RUN TestALUShiftRight/C +=== RUN TestJumpIfBitsNotSet/kernel +=== RUN TestJumpIfLessOrEqual/C#01 === RUN TestJumpIfNotEqual/C#01 -=== RUN TestJumpIfLessThan/C#01 -=== RUN TestJumpIfGreaterThan/eBPF#01 +=== RUN TestJumpIfEqual/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 24 + 2: Mov32Imm dst: r4 imm: 23 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: - 4: JGTImm dst: r4 off: -1 imm: 23 + 4: JEqImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 @@ -1456,17 +1447,40 @@ 14: MovImm dst: r0 imm: 1 return: 15: Exit -=== RUN TestJumpIfGreaterThan/kernel#01 -=== RUN TestJumpIfGreaterThan/C#02 -=== RUN TestALUShiftLeft/eBPF#01 +=== RUN TestJumpIfEqual/kernel#01 +=== RUN TestJumpIfEqual/C#02 +--- PASS: TestZeroInitA (0.11s) + --- SKIP: TestZeroInitA/C (0.06s) + --- SKIP: TestZeroInitA/eBPF (0.00s) + --- PASS: TestZeroInitA/kernel (0.05s) +=== CONT TestALUDivZero +=== RUN TestALUDivZero/C +=== RUN TestRetA/eBPF +=== RUN TestALUAnd/eBPF#01 +=== NAME TestRetA/eBPF + ebpf_test.go:17: + 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 + 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 + filter_block_0: + 2: Mov32Imm dst: r4 imm: 1 + 3: Mov32Reg dst: r4 src: r4 + 4: JaImm dst: r0 off: -1 imm: 0 + result: + 5: MovImm dst: r0 imm: 2 + 6: JEqImm dst: r4 off: -1 imm: 0 + 7: MovImm dst: r0 imm: 1 + return: + 8: Exit +=== RUN TestRetA/kernel +=== NAME TestALUAnd/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 3: Mov32Imm dst: r5 imm: 0 - 4: LSh32Reg dst: r4 src: r5 - 5: JEqImm dst: r4 off: -1 imm: 1 + 4: And32Reg dst: r4 src: r5 + 5: JEqImm dst: r4 off: -1 imm: 0 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 @@ -1479,57 +1493,25 @@ 12: MovImm dst: r0 imm: 1 return: 13: Exit -=== RUN TestALUShiftLeft/kernel#01 -=== RUN TestALUShiftLeft/C#02 ---- PASS: TestJump (0.11s) - --- SKIP: TestJump/C (0.06s) - --- SKIP: TestJump/eBPF (0.00s) - --- PASS: TestJump/kernel (0.05s) -=== CONT TestScratchA -=== RUN TestScratchA/C -=== RUN TestALUMod/eBPF#01 - ebpf_test.go:17: - 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 - 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 - filter_block_0: - 2: Mov32Imm dst: r4 imm: 16 - 3: Mov32Imm dst: r5 imm: 4 - 4: JEqImm dst: r5 off: -1 imm: 0 - 5: Mod32Reg dst: r4 src: r5 - 6: JEqImm dst: r4 off: -1 imm: 0 - filter_block_4: - 7: Mov32Imm dst: r4 imm: 0 - 8: JaImm dst: r0 off: -1 imm: 0 - filter_block_5: - 9: Mov32Imm dst: r4 imm: 1 - 10: JaImm dst: r0 off: -1 imm: 0 - filter_nomatch: - 11: MovImm dst: r4 imm: 0 - 12: JaImm dst: r0 off: -1 imm: 0 - result: - 13: MovImm dst: r0 imm: 2 - 14: JEqImm dst: r4 off: -1 imm: 0 - 15: MovImm dst: r0 imm: 1 - return: - 16: Exit -=== RUN TestALUMod/kernel#01 -=== RUN TestALUMod/C#02 ---- PASS: TestNegateA (0.11s) - --- SKIP: TestNegateA/C (0.06s) - --- SKIP: TestNegateA/eBPF (0.00s) - --- PASS: TestNegateA/kernel (0.05s) -=== CONT TestALUOr -=== RUN TestALUOr/C -=== RUN TestJump0/C#01 -=== RUN TestJumpIfEqual/eBPF#01 +=== RUN TestALUAnd/kernel#01 +--- PASS: TestRetA (0.07s) + --- SKIP: TestRetA/C (0.06s) + --- SKIP: TestRetA/eBPF (0.00s) + --- PASS: TestRetA/kernel (0.00s) +=== CONT TestALUDiv +=== RUN TestALUDiv/C +=== RUN TestALUAnd/C#02 +=== RUN TestJumpIfGreaterOrEqual/eBPF#01 +=== RUN TestALUOr/eBPF +=== NAME TestJumpIfGreaterOrEqual/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 23 + 2: Mov32Imm dst: r4 imm: 24 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: - 4: JEqImm dst: r4 off: -1 imm: 23 + 4: JGEImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 @@ -1546,17 +1528,15 @@ 14: MovImm dst: r0 imm: 1 return: 15: Exit -=== RUN TestJumpIfEqual/kernel#01 -=== RUN TestJumpIfEqual/C#02 -=== RUN TestALUXor/eBPF#01 -=== RUN TestALUShiftRight/eBPF +=== RUN TestJumpIfGreaterOrEqual/kernel#01 +=== NAME TestALUOr/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 240 - 3: RSh32Imm dst: r4 imm: 4 - 4: JEqImm dst: r4 off: -1 imm: 15 + 2: Mov32Imm dst: r4 imm: 1 + 3: Or32Imm dst: r4 imm: 0 + 4: JEqImm dst: r4 off: -1 imm: 1 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 @@ -1569,94 +1549,62 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestALUShiftRight/kernel -=== RUN TestALUShiftRight/C#01 -=== RUN TestALUAnd/eBPF#01 -=== NAME TestALUXor/eBPF#01 - ebpf_test.go:17: - 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 - 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 - filter_block_0: - 2: Mov32Imm dst: r4 imm: 1 - 3: Mov32Imm dst: r5 imm: 1 - 4: Xor32Reg dst: r4 src: r5 - 5: JEqImm dst: r4 off: -1 imm: 0 - filter_block_4: - 6: Mov32Imm dst: r4 imm: 0 - 7: JaImm dst: r0 off: -1 imm: 0 - filter_block_5: - 8: Mov32Imm dst: r4 imm: 1 - 9: JaImm dst: r0 off: -1 imm: 0 - result: - 10: MovImm dst: r0 imm: 2 - 11: JEqImm dst: r4 off: -1 imm: 0 - 12: MovImm dst: r0 imm: 1 - return: - 13: Exit -=== RUN TestALUXor/kernel#01 -=== NAME TestALUAnd/eBPF#01 +=== RUN TestALUOr/kernel +=== RUN TestJumpIfGreaterOrEqual/C#02 +=== RUN TestALUOr/C#01 +=== RUN TestScratchX/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 1 - 3: Mov32Imm dst: r5 imm: 0 - 4: And32Reg dst: r4 src: r5 - 5: JEqImm dst: r4 off: -1 imm: 0 - filter_block_4: - 6: Mov32Imm dst: r4 imm: 0 - 7: JaImm dst: r0 off: -1 imm: 0 - filter_block_5: - 8: Mov32Imm dst: r4 imm: 1 - 9: JaImm dst: r0 off: -1 imm: 0 + 2: Mov32Imm dst: r5 imm: -559038737 + 3: StXMemW dst: rfp src: r5 off: -32 imm: 0 + 4: Mov32Imm dst: r5 imm: 0 + 5: Mov32Imm dst: r5 imm: -1 + 6: StXMemW dst: rfp src: r5 off: -28 imm: 0 + 7: Mov32Imm dst: r5 imm: -1 + 8: StXMemW dst: rfp src: r5 off: -36 imm: 0 + 9: LdXMemW dst: r5 src: rfp off: -32 imm: 0 + 10: Mov32Reg dst: r4 src: r5 + 11: Mov32Imm dst: r6 imm: -559038737 + 12: JEqReg dst: r4 off: -1 src: r6 + filter_block_10: + 13: Mov32Imm dst: r4 imm: 0 + 14: JaImm dst: r0 off: -1 imm: 0 + filter_block_11: + 15: Mov32Imm dst: r4 imm: 1 + 16: JaImm dst: r0 off: -1 imm: 0 result: - 10: MovImm dst: r0 imm: 2 - 11: JEqImm dst: r4 off: -1 imm: 0 - 12: MovImm dst: r0 imm: 1 + 17: MovImm dst: r0 imm: 2 + 18: JEqImm dst: r4 off: -1 imm: 0 + 19: MovImm dst: r0 imm: 1 return: - 13: Exit -=== RUN TestALUAnd/kernel#01 -=== RUN TestALUXor/C#02 -=== RUN TestALUAnd/C#02 -=== RUN TestScratchA/eBPF -=== RUN TestJumpIfNotEqual/eBPF#01 -=== NAME TestScratchA/eBPF + 20: Exit +=== RUN TestScratchX/kernel +=== RUN TestScratchX/C#01 +=== RUN TestRetConstant/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: -559038737 - 3: StXMemW dst: rfp src: r4 off: -32 imm: 0 - 4: Mov32Imm dst: r4 imm: 0 - 5: Mov32Imm dst: r4 imm: -1 - 6: StXMemW dst: rfp src: r4 off: -28 imm: 0 - 7: Mov32Imm dst: r4 imm: -1 - 8: StXMemW dst: rfp src: r4 off: -36 imm: 0 - 9: LdXMemW dst: r4 src: rfp off: -32 imm: 0 - 10: Mov32Imm dst: r6 imm: -559038737 - 11: JEqReg dst: r4 off: -1 src: r6 - filter_block_9: - 12: Mov32Imm dst: r4 imm: 0 - 13: JaImm dst: r0 off: -1 imm: 0 - filter_block_10: - 14: Mov32Imm dst: r4 imm: 1 - 15: JaImm dst: r0 off: -1 imm: 0 + 2: Mov32Imm dst: r4 imm: 0 + 3: JaImm dst: r0 off: -1 imm: 0 result: - 16: MovImm dst: r0 imm: 2 - 17: JEqImm dst: r4 off: -1 imm: 0 - 18: MovImm dst: r0 imm: 1 + 4: MovImm dst: r0 imm: 2 + 5: JEqImm dst: r4 off: -1 imm: 0 + 6: MovImm dst: r0 imm: 1 return: - 19: Exit -=== RUN TestScratchA/kernel -=== NAME TestJumpIfNotEqual/eBPF#01 + 7: Exit +=== RUN TestRetConstant/kernel#01 +=== RUN TestJumpIfBitsSet/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 23 + 2: Mov32Imm dst: r4 imm: 6 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: - 4: JNEImm dst: r4 off: -1 imm: 23 + 4: JSetImm dst: r4 off: -1 imm: 4 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 @@ -1673,16 +1621,16 @@ 14: MovImm dst: r0 imm: 1 return: 15: Exit -=== RUN TestJumpIfNotEqual/kernel#01 -=== RUN TestScratchA/C#01 -=== RUN TestJumpIfGreaterThan/eBPF#02 +=== RUN TestJumpIfBitsSet/kernel#01 +=== RUN TestJumpIfBitsSet/C#02 +=== RUN TestJumpIfEqual/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 24 + 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 23 - 4: JGTReg dst: r4 off: -1 src: r5 + 4: JEqReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 @@ -1695,16 +1643,69 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestJumpIfGreaterThan/kernel#02 -=== RUN TestJumpIfGreaterThan/C#03 -=== RUN TestALUShiftLeft/eBPF#02 +=== RUN TestJumpIfEqual/kernel#02 +=== RUN TestJumpIfEqual/C#03 +=== RUN TestJumpIfBitsNotSet/C#01 +=== RUN TestJumpIfNotEqual/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 1 - 3: LSh32Imm dst: r4 imm: 4 - 4: JEqImm dst: r4 off: -1 imm: 16 + 2: Mov32Imm dst: r4 imm: 23 + 3: JEqImm dst: r4 off: -1 imm: 0 + filter_block_2: + 4: JNEImm dst: r4 off: -1 imm: 23 + 5: JaImm dst: r0 off: -1 imm: 0 + filter_block_3: + 6: Mov32Imm dst: r4 imm: 1 + 7: JaImm dst: r0 off: -1 imm: 0 + filter_block_4: + 8: Mov32Imm dst: r4 imm: 0 + 9: JaImm dst: r0 off: -1 imm: 0 + filter_block_5: + 10: Mov32Imm dst: r4 imm: 1 + 11: JaImm dst: r0 off: -1 imm: 0 + result: + 12: MovImm dst: r0 imm: 2 + 13: JEqImm dst: r4 off: -1 imm: 0 + 14: MovImm dst: r0 imm: 1 + return: + 15: Exit +=== RUN TestJumpIfNotEqual/kernel#01 +=== RUN TestALUDivZero/eBPF + ebpf_test.go:17: + 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 + 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 + filter_block_0: + 2: MovReg dst: r6 src: r2 + 3: AddImm dst: r6 imm: 1 + 4: JGTReg dst: r6 off: -1 src: r3 + 5: LdXMemB dst: r4 src: r2 off: 0 imm: 0 + 6: Mov32Reg dst: r5 src: r4 + 7: Mov32Imm dst: r4 imm: 10 + 8: JEqImm dst: r5 off: -1 imm: 0 + 9: Div32Reg dst: r4 src: r5 + 10: Mov32Imm dst: r4 imm: 1 + 11: JaImm dst: r0 off: -1 imm: 0 + filter_nomatch: + 12: MovImm dst: r4 imm: 0 + 13: JaImm dst: r0 off: -1 imm: 0 + result: + 14: MovImm dst: r0 imm: 2 + 15: JEqImm dst: r4 off: -1 imm: 0 + 16: MovImm dst: r0 imm: 1 + return: + 17: Exit +=== RUN TestALUDivZero/kernel +=== RUN TestJumpIfLessOrEqual/eBPF#01 +=== RUN TestALUAnd/eBPF#02 + ebpf_test.go:17: + 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 + 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 + filter_block_0: + 2: Mov32Imm dst: r4 imm: 240 + 3: And32Imm dst: r4 imm: 128 + 4: JEqImm dst: r4 off: -1 imm: 128 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 @@ -1717,9 +1718,9 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestALUShiftLeft/kernel#02 -=== RUN TestALUShiftLeft/C#03 -=== RUN TestJumpIfLessThan/eBPF#01 +=== RUN TestALUAnd/kernel#02 +=== RUN TestALUAnd/C#03 +=== NAME TestJumpIfLessOrEqual/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 @@ -1727,7 +1728,7 @@ 2: Mov32Imm dst: r4 imm: 24 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: - 4: JLTImm dst: r4 off: -1 imm: 23 + 4: JLEImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 @@ -1744,14 +1745,14 @@ 14: MovImm dst: r0 imm: 1 return: 15: Exit -=== RUN TestJumpIfLessThan/kernel#01 -=== RUN TestALUOr/eBPF +=== RUN TestJumpIfLessOrEqual/kernel#01 +=== RUN TestALUDiv/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 1 - 3: Or32Imm dst: r4 imm: 0 + 2: Mov32Imm dst: r4 imm: 2 + 3: Div32Imm dst: r4 imm: 2 4: JEqImm dst: r4 off: -1 imm: 1 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 @@ -1765,38 +1766,53 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestALUOr/kernel -=== RUN TestALUOr/C#01 -=== RUN TestALUMod/eBPF#02 +=== RUN TestALUDiv/kernel +=== RUN TestALUDiv/C#01 +=== RUN TestScratchX/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 17 - 3: Mod32Imm dst: r4 imm: 4 - 4: JEqImm dst: r4 off: -1 imm: 1 - filter_block_3: - 5: Mov32Imm dst: r4 imm: 0 - 6: JaImm dst: r0 off: -1 imm: 0 - filter_block_4: - 7: Mov32Imm dst: r4 imm: 1 - 8: JaImm dst: r0 off: -1 imm: 0 + 2: Mov32Imm dst: r5 imm: 0 + 3: StXMemW dst: rfp src: r5 off: -32 imm: 0 + 4: Mov32Imm dst: r5 imm: 0 + 5: Mov32Imm dst: r5 imm: -1 + 6: StXMemW dst: rfp src: r5 off: -28 imm: 0 + 7: Mov32Imm dst: r5 imm: -1 + 8: StXMemW dst: rfp src: r5 off: -36 imm: 0 + 9: LdXMemW dst: r5 src: rfp off: -32 imm: 0 + 10: Mov32Reg dst: r4 src: r5 + 11: JEqImm dst: r4 off: -1 imm: 0 + filter_block_10: + 12: Mov32Imm dst: r4 imm: 0 + 13: JaImm dst: r0 off: -1 imm: 0 + filter_block_11: + 14: Mov32Imm dst: r4 imm: 1 + 15: JaImm dst: r0 off: -1 imm: 0 result: - 9: MovImm dst: r0 imm: 2 - 10: JEqImm dst: r4 off: -1 imm: 0 - 11: MovImm dst: r0 imm: 1 + 16: MovImm dst: r0 imm: 2 + 17: JEqImm dst: r4 off: -1 imm: 0 + 18: MovImm dst: r0 imm: 1 return: - 12: Exit -=== RUN TestALUMod/kernel#02 -=== RUN TestALUMod/C#03 -=== RUN TestJumpIfEqual/eBPF#02 + 19: Exit +=== RUN TestScratchX/kernel#01 +--- PASS: TestScratchX (0.11s) + --- SKIP: TestScratchX/C (0.07s) + --- SKIP: TestScratchX/eBPF (0.00s) + --- PASS: TestScratchX/kernel (0.00s) + --- SKIP: TestScratchX/C#01 (0.04s) + --- SKIP: TestScratchX/eBPF#01 (0.00s) + --- PASS: TestScratchX/kernel#01 (0.00s) +=== CONT TestALUMul +=== RUN TestALUMul/C +=== RUN TestJumpIfGreaterOrEqual/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 23 + 2: Mov32Imm dst: r4 imm: 24 3: Mov32Imm dst: r5 imm: 23 - 4: JEqReg dst: r4 off: -1 src: r5 + 4: JGEReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 @@ -1809,17 +1825,17 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestJumpIfEqual/kernel#02 -=== RUN TestJumpIfEqual/C#03 -=== RUN TestALUShiftRight/eBPF#01 +=== RUN TestJumpIfGreaterOrEqual/kernel#02 +=== RUN TestJumpIfGreaterOrEqual/C#03 +=== RUN TestALUOr/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 240 - 3: Mov32Imm dst: r5 imm: 4 - 4: RSh32Reg dst: r4 src: r5 - 5: JEqImm dst: r4 off: -1 imm: 15 + 2: Mov32Imm dst: r4 imm: 1 + 3: Mov32Imm dst: r5 imm: 0 + 4: Or32Reg dst: r4 src: r5 + 5: JEqImm dst: r4 off: -1 imm: 1 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 @@ -1832,16 +1848,53 @@ 12: MovImm dst: r0 imm: 1 return: 13: Exit -=== RUN TestALUShiftRight/kernel#01 -=== RUN TestALUShiftRight/C#02 -=== RUN TestALUAnd/eBPF#02 +=== RUN TestALUOr/kernel#01 +=== RUN TestALUOr/C#02 +--- PASS: TestRetConstant (0.18s) + --- SKIP: TestRetConstant/C (0.07s) + --- SKIP: TestRetConstant/eBPF (0.00s) + --- PASS: TestRetConstant/kernel (0.00s) + --- SKIP: TestRetConstant/C#01 (0.06s) + --- SKIP: TestRetConstant/eBPF#01 (0.00s) + --- PASS: TestRetConstant/kernel#01 (0.05s) +=== CONT TestALUSub +=== RUN TestALUSub/C +=== RUN TestJumpIfEqual/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 240 - 3: And32Imm dst: r4 imm: 128 - 4: JEqImm dst: r4 off: -1 imm: 128 + 2: Mov32Imm dst: r4 imm: 23 + 3: Mov32Imm dst: r5 imm: 23 + 4: JEqImm dst: r4 off: -1 imm: 0 + filter_block_3: + 5: JEqReg dst: r4 off: -1 src: r5 + 6: JaImm dst: r0 off: -1 imm: 0 + filter_block_4: + 7: Mov32Imm dst: r4 imm: 1 + 8: JaImm dst: r0 off: -1 imm: 0 + filter_block_5: + 9: Mov32Imm dst: r4 imm: 0 + 10: JaImm dst: r0 off: -1 imm: 0 + filter_block_6: + 11: Mov32Imm dst: r4 imm: 1 + 12: JaImm dst: r0 off: -1 imm: 0 + result: + 13: MovImm dst: r0 imm: 2 + 14: JEqImm dst: r4 off: -1 imm: 0 + 15: MovImm dst: r0 imm: 1 + return: + 16: Exit +=== RUN TestJumpIfEqual/kernel#03 +=== RUN TestJumpIfEqual/C#04 +=== RUN TestJumpIfBitsSet/eBPF#02 + ebpf_test.go:17: + 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 + 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 + filter_block_0: + 2: Mov32Imm dst: r4 imm: 6 + 3: Mov32Imm dst: r5 imm: 4 + 4: JSetReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 @@ -1854,63 +1907,76 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestALUAnd/kernel#02 -=== RUN TestALUAnd/C#03 -=== RUN TestJump0/eBPF#01 +=== RUN TestJumpIfBitsSet/kernel#02 +=== RUN TestJumpIfBitsSet/C#03 +=== RUN TestJumpIfBitsNotSet/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: MovReg dst: r6 src: r2 - 3: AddImm dst: r6 imm: 1 - 4: JGTReg dst: r6 off: -1 src: r3 - 5: Mov32Imm dst: r5 imm: 0 - 6: LdXMemB dst: r4 src: r2 off: 0 imm: 0 - 7: JaImm dst: r0 off: -1 imm: 0 + 2: Mov32Imm dst: r4 imm: 6 + 3: JEqImm dst: r4 off: -1 imm: 0 + filter_block_2: + 4: JSetImm dst: r4 off: -1 imm: 4 + 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: - 8: JEqReg dst: r4 off: -1 src: r5 + 6: Mov32Imm dst: r4 imm: 1 + 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: - 9: Mov32Reg dst: r4 src: r4 - 10: JaImm dst: r0 off: -1 imm: 0 - filter_nomatch: - 11: MovImm dst: r4 imm: 0 - 12: JaImm dst: r0 off: -1 imm: 0 + 8: Mov32Imm dst: r4 imm: 0 + 9: JaImm dst: r0 off: -1 imm: 0 + filter_block_5: + 10: Mov32Imm dst: r4 imm: 1 + 11: JaImm dst: r0 off: -1 imm: 0 result: - 13: MovImm dst: r0 imm: 2 - 14: JEqImm dst: r4 off: -1 imm: 0 - 15: MovImm dst: r0 imm: 1 + 12: MovImm dst: r0 imm: 2 + 13: JEqImm dst: r4 off: -1 imm: 0 + 14: MovImm dst: r0 imm: 1 return: - 16: Exit -=== RUN TestJump0/kernel#01 ---- PASS: TestJump0 (0.25s) - --- SKIP: TestJump0/C (0.08s) - --- SKIP: TestJump0/eBPF (0.00s) - --- PASS: TestJump0/kernel (0.10s) - --- SKIP: TestJump0/C#01 (0.07s) - --- SKIP: TestJump0/eBPF#01 (0.00s) - --- PASS: TestJump0/kernel#01 (0.00s) -=== CONT TestALUDivZero -=== RUN TestALUDivZero/C + 15: Exit +=== RUN TestJumpIfBitsNotSet/kernel#01 +=== RUN TestALUAnd/eBPF#03 + ebpf_test.go:17: + 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 + 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 + filter_block_0: + 2: Mov32Imm dst: r4 imm: 240 + 3: Mov32Imm dst: r5 imm: 128 + 4: And32Reg dst: r4 src: r5 + 5: JEqImm dst: r4 off: -1 imm: 128 + filter_block_4: + 6: Mov32Imm dst: r4 imm: 0 + 7: JaImm dst: r0 off: -1 imm: 0 + filter_block_5: + 8: Mov32Imm dst: r4 imm: 1 + 9: JaImm dst: r0 off: -1 imm: 0 + result: + 10: MovImm dst: r0 imm: 2 + 11: JEqImm dst: r4 off: -1 imm: 0 + 12: MovImm dst: r0 imm: 1 + return: + 13: Exit +=== RUN TestALUAnd/kernel#03 +=== RUN TestALUAnd/C#04 === RUN TestJumpIfNotEqual/C#02 -=== RUN TestJumpIfGreaterThan/eBPF#03 +=== RUN TestALUDiv/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 24 - 3: Mov32Imm dst: r5 imm: 23 - 4: JEqImm dst: r4 off: -1 imm: 0 - filter_block_3: - 5: JGTReg dst: r4 off: -1 src: r5 - 6: JaImm dst: r0 off: -1 imm: 0 + 2: Mov32Imm dst: r4 imm: 2 + 3: Mov32Imm dst: r5 imm: 2 + 4: JEqImm dst: r5 off: -1 imm: 0 + 5: Div32Reg dst: r4 src: r5 + 6: JEqImm dst: r4 off: -1 imm: 1 filter_block_4: - 7: Mov32Imm dst: r4 imm: 1 + 7: Mov32Imm dst: r4 imm: 0 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: - 9: Mov32Imm dst: r4 imm: 0 + 9: Mov32Imm dst: r4 imm: 1 10: JaImm dst: r0 off: -1 imm: 0 - filter_block_6: - 11: Mov32Imm dst: r4 imm: 1 + filter_nomatch: + 11: MovImm dst: r4 imm: 0 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 @@ -1918,19 +1984,19 @@ 15: MovImm dst: r0 imm: 1 return: 16: Exit -=== RUN TestJumpIfGreaterThan/kernel#03 -=== RUN TestJumpIfGreaterThan/C#04 -=== RUN TestJumpIfEqual/eBPF#03 -=== RUN TestALUShiftRight/eBPF#02 -=== RUN TestJumpIfLessThan/C#02 -=== NAME TestALUShiftRight/eBPF#02 +=== RUN TestALUDiv/kernel#01 +=== RUN TestALUDiv/C#02 +=== RUN TestALUDivZero/C#01 +=== RUN TestJumpIfLessOrEqual/C#02 +=== RUN TestALUSub/eBPF +=== RUN TestALUOr/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 240 - 3: RSh32Imm dst: r4 imm: 8 - 4: JEqImm dst: r4 off: -1 imm: 0 + 3: Or32Imm dst: r4 imm: 15 + 4: JEqImm dst: r4 off: -1 imm: 255 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 @@ -1943,16 +2009,17 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestALUShiftRight/kernel#02 -=== RUN TestALUShiftRight/C#03 -=== RUN TestALUXor/eBPF#02 +=== RUN TestALUOr/kernel#02 +=== RUN TestALUMul/eBPF +=== RUN TestALUOr/C#03 +=== NAME TestALUMul/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 6 - 3: Mod32Imm dst: r4 imm: 4 - 4: JEqImm dst: r4 off: -1 imm: 2 + 2: Mov32Imm dst: r4 imm: 0 + 3: Mul32Imm dst: r4 imm: 1 + 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 @@ -1965,91 +2032,62 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestALUXor/kernel#02 -=== RUN TestALUXor/C#03 -=== RUN TestALUShiftLeft/eBPF#03 +=== RUN TestALUMul/kernel +=== RUN TestALUMul/C#01 +=== NAME TestALUSub/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 - 3: Mov32Imm dst: r5 imm: 4 - 4: LSh32Reg dst: r4 src: r5 - 5: JEqImm dst: r4 off: -1 imm: 16 + 3: Sub32Imm dst: r4 imm: 1 + 4: JEqImm dst: r4 off: -1 imm: 0 + filter_block_3: + 5: Mov32Imm dst: r4 imm: 0 + 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: - 6: Mov32Imm dst: r4 imm: 0 - 7: JaImm dst: r0 off: -1 imm: 0 - filter_block_5: - 8: Mov32Imm dst: r4 imm: 1 - 9: JaImm dst: r0 off: -1 imm: 0 + 7: Mov32Imm dst: r4 imm: 1 + 8: JaImm dst: r0 off: -1 imm: 0 result: - 10: MovImm dst: r0 imm: 2 - 11: JEqImm dst: r4 off: -1 imm: 0 - 12: MovImm dst: r0 imm: 1 + 9: MovImm dst: r0 imm: 2 + 10: JEqImm dst: r4 off: -1 imm: 0 + 11: MovImm dst: r0 imm: 1 return: - 13: Exit -=== RUN TestALUShiftLeft/kernel#03 ---- PASS: TestALUShiftLeft (0.31s) - --- SKIP: TestALUShiftLeft/C (0.06s) - --- SKIP: TestALUShiftLeft/eBPF (0.01s) - --- PASS: TestALUShiftLeft/kernel (0.00s) - --- SKIP: TestALUShiftLeft/C#01 (0.06s) - --- SKIP: TestALUShiftLeft/eBPF#01 (0.00s) - --- PASS: TestALUShiftLeft/kernel#01 (0.00s) - --- SKIP: TestALUShiftLeft/C#02 (0.09s) - --- SKIP: TestALUShiftLeft/eBPF#02 (0.00s) - --- PASS: TestALUShiftLeft/kernel#02 (0.00s) - --- SKIP: TestALUShiftLeft/C#03 (0.09s) - --- SKIP: TestALUShiftLeft/eBPF#03 (0.00s) - --- PASS: TestALUShiftLeft/kernel#03 (0.00s) -=== CONT TestALUDiv -=== RUN TestALUDiv/C -=== RUN TestScratchA/eBPF#01 + 12: Exit +=== RUN TestALUSub/kernel +=== RUN TestALUSub/C#01 +=== RUN TestJumpIfEqual/eBPF#04 +=== RUN TestJumpIfGreaterOrEqual/eBPF#03 +=== NAME TestJumpIfEqual/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 0 - 3: StXMemW dst: rfp src: r4 off: -32 imm: 0 + 2: Mov32Imm dst: r4 imm: 23 + 3: JEqImm dst: r4 off: -1 imm: 21 + filter_block_2: 4: Mov32Imm dst: r4 imm: 0 - 5: Mov32Imm dst: r4 imm: -1 - 6: StXMemW dst: rfp src: r4 off: -28 imm: 0 - 7: Mov32Imm dst: r4 imm: -1 - 8: StXMemW dst: rfp src: r4 off: -36 imm: 0 - 9: LdXMemW dst: r4 src: rfp off: -32 imm: 0 - 10: JEqImm dst: r4 off: -1 imm: 0 - filter_block_9: - 11: Mov32Imm dst: r4 imm: 0 - 12: JaImm dst: r0 off: -1 imm: 0 - filter_block_10: - 13: Mov32Imm dst: r4 imm: 1 - 14: JaImm dst: r0 off: -1 imm: 0 + 5: JaImm dst: r0 off: -1 imm: 0 + filter_block_3: + 6: Mov32Imm dst: r4 imm: 1 + 7: JaImm dst: r0 off: -1 imm: 0 result: - 15: MovImm dst: r0 imm: 2 - 16: JEqImm dst: r4 off: -1 imm: 0 - 17: MovImm dst: r0 imm: 1 + 8: MovImm dst: r0 imm: 2 + 9: JEqImm dst: r4 off: -1 imm: 0 + 10: MovImm dst: r0 imm: 1 return: - 18: Exit -=== RUN TestScratchA/kernel#01 ---- PASS: TestScratchA (0.18s) - --- SKIP: TestScratchA/C (0.08s) - --- SKIP: TestScratchA/eBPF (0.00s) - --- PASS: TestScratchA/kernel (0.00s) - --- SKIP: TestScratchA/C#01 (0.10s) - --- SKIP: TestScratchA/eBPF#01 (0.00s) - --- PASS: TestScratchA/kernel#01 (0.00s) -=== CONT TestALUMul -=== RUN TestALUMul/C -=== NAME TestJumpIfEqual/eBPF#03 + 11: Exit +=== RUN TestJumpIfEqual/kernel#04 +=== NAME TestJumpIfGreaterOrEqual/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 23 + 2: Mov32Imm dst: r4 imm: 24 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: - 5: JEqReg dst: r4 off: -1 src: r5 + 5: JGEReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 @@ -2066,24 +2104,93 @@ 15: MovImm dst: r0 imm: 1 return: 16: Exit -=== RUN TestALUMod/eBPF#03 +=== RUN TestJumpIfGreaterOrEqual/kernel#03 +=== RUN TestJumpIfGreaterOrEqual/C#04 +=== RUN TestALUAnd/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 17 + 2: Mov32Imm dst: r4 imm: 240 + 3: And32Imm dst: r4 imm: 15 + 4: JEqImm dst: r4 off: -1 imm: 0 + filter_block_3: + 5: Mov32Imm dst: r4 imm: 0 + 6: JaImm dst: r0 off: -1 imm: 0 + filter_block_4: + 7: Mov32Imm dst: r4 imm: 1 + 8: JaImm dst: r0 off: -1 imm: 0 + result: + 9: MovImm dst: r0 imm: 2 + 10: JEqImm dst: r4 off: -1 imm: 0 + 11: MovImm dst: r0 imm: 1 + return: + 12: Exit +=== RUN TestALUAnd/kernel#04 +=== RUN TestALUAnd/C#05 +=== RUN TestJumpIfBitsNotSet/C#02 +=== RUN TestJumpIfNotEqual/eBPF#02 + ebpf_test.go:17: + 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 + 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 + filter_block_0: + 2: Mov32Imm dst: r4 imm: 23 + 3: Mov32Imm dst: r5 imm: 23 + 4: JNEReg dst: r4 off: -1 src: r5 + filter_block_3: + 5: Mov32Imm dst: r4 imm: 0 + 6: JaImm dst: r0 off: -1 imm: 0 + filter_block_4: + 7: Mov32Imm dst: r4 imm: 1 + 8: JaImm dst: r0 off: -1 imm: 0 + result: + 9: MovImm dst: r0 imm: 2 + 10: JEqImm dst: r4 off: -1 imm: 0 + 11: MovImm dst: r0 imm: 1 + return: + 12: Exit +=== RUN TestJumpIfNotEqual/kernel#02 +=== RUN TestALUDiv/eBPF#02 + ebpf_test.go:17: + 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 + 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 + filter_block_0: + 2: Mov32Imm dst: r4 imm: 19 + 3: Div32Imm dst: r4 imm: 3 + 4: JEqImm dst: r4 off: -1 imm: 6 + filter_block_3: + 5: Mov32Imm dst: r4 imm: 0 + 6: JaImm dst: r0 off: -1 imm: 0 + filter_block_4: + 7: Mov32Imm dst: r4 imm: 1 + 8: JaImm dst: r0 off: -1 imm: 0 + result: + 9: MovImm dst: r0 imm: 2 + 10: JEqImm dst: r4 off: -1 imm: 0 + 11: MovImm dst: r0 imm: 1 + return: + 12: Exit +=== RUN TestALUDiv/kernel#02 +=== RUN TestALUDiv/C#03 +=== RUN TestJumpIfBitsSet/eBPF#03 + ebpf_test.go:17: + 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 + 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 + filter_block_0: + 2: Mov32Imm dst: r4 imm: 6 3: Mov32Imm dst: r5 imm: 4 - 4: JEqImm dst: r5 off: -1 imm: 0 - 5: Mod32Reg dst: r4 src: r5 - 6: JEqImm dst: r4 off: -1 imm: 1 + 4: JEqImm dst: r4 off: -1 imm: 0 + filter_block_3: + 5: JSetReg dst: r4 off: -1 src: r5 + 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: - 7: Mov32Imm dst: r4 imm: 0 + 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: - 9: Mov32Imm dst: r4 imm: 1 + 9: Mov32Imm dst: r4 imm: 0 10: JaImm dst: r0 off: -1 imm: 0 - filter_nomatch: - 11: MovImm dst: r4 imm: 0 + filter_block_6: + 11: Mov32Imm dst: r4 imm: 1 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 @@ -2091,31 +2198,19 @@ 15: MovImm dst: r0 imm: 1 return: 16: Exit -=== RUN TestALUMod/kernel#03 ---- PASS: TestALUMod (0.30s) - --- SKIP: TestALUMod/C (0.05s) - --- SKIP: TestALUMod/eBPF (0.00s) - --- PASS: TestALUMod/kernel (0.00s) - --- SKIP: TestALUMod/C#01 (0.03s) - --- SKIP: TestALUMod/eBPF#01 (0.00s) - --- PASS: TestALUMod/kernel#01 (0.00s) - --- SKIP: TestALUMod/C#02 (0.11s) - --- SKIP: TestALUMod/eBPF#02 (0.00s) - --- PASS: TestALUMod/kernel#02 (0.00s) - --- SKIP: TestALUMod/C#03 (0.09s) - --- SKIP: TestALUMod/eBPF#03 (0.00s) - --- PASS: TestALUMod/kernel#03 (0.00s) -=== CONT TestALUSub -=== RUN TestALUSub/C -=== RUN TestALUAnd/eBPF#03 +=== RUN TestJumpIfBitsSet/kernel#03 +=== RUN TestALUMul/eBPF#01 +=== RUN TestALUOr/eBPF#03 +=== RUN TestALUDivZero/eBPF#01 +=== NAME TestALUMul/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 240 - 3: Mov32Imm dst: r5 imm: 128 - 4: And32Reg dst: r4 src: r5 - 5: JEqImm dst: r4 off: -1 imm: 128 + 2: Mov32Imm dst: r4 imm: 0 + 3: Mov32Imm dst: r5 imm: 1 + 4: Mul32Reg dst: r4 src: r5 + 5: JEqImm dst: r4 off: -1 imm: 0 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 @@ -2128,38 +2223,16 @@ 12: MovImm dst: r0 imm: 1 return: 13: Exit -=== RUN TestALUAnd/kernel#03 -=== RUN TestALUAnd/C#04 -=== RUN TestJumpIfNotEqual/eBPF#02 - ebpf_test.go:17: - 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 - 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 - filter_block_0: - 2: Mov32Imm dst: r4 imm: 23 - 3: Mov32Imm dst: r5 imm: 23 - 4: JNEReg dst: r4 off: -1 src: r5 - filter_block_3: - 5: Mov32Imm dst: r4 imm: 0 - 6: JaImm dst: r0 off: -1 imm: 0 - filter_block_4: - 7: Mov32Imm dst: r4 imm: 1 - 8: JaImm dst: r0 off: -1 imm: 0 - result: - 9: MovImm dst: r0 imm: 2 - 10: JEqImm dst: r4 off: -1 imm: 0 - 11: MovImm dst: r0 imm: 1 - return: - 12: Exit -=== RUN TestJumpIfNotEqual/kernel#02 -=== RUN TestALUOr/eBPF#01 +=== RUN TestJumpIfBitsSet/C#04 +=== NAME TestALUOr/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 1 - 3: Mov32Imm dst: r5 imm: 0 + 2: Mov32Imm dst: r4 imm: 240 + 3: Mov32Imm dst: r5 imm: 15 4: Or32Reg dst: r4 src: r5 - 5: JEqImm dst: r4 off: -1 imm: 1 + 5: JEqImm dst: r4 off: -1 imm: 255 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 @@ -2172,9 +2245,9 @@ 12: MovImm dst: r0 imm: 1 return: 13: Exit -=== RUN TestALUOr/kernel#01 -=== RUN TestALUOr/C#02 -=== RUN TestALUDivZero/eBPF +=== RUN TestALUMul/kernel#01 +=== RUN TestALUOr/kernel#03 +=== NAME TestALUDivZero/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 @@ -2198,39 +2271,40 @@ 16: MovImm dst: r0 imm: 1 return: 17: Exit -=== RUN TestALUDivZero/kernel -=== RUN TestJumpIfEqual/kernel#03 -=== RUN TestJumpIfEqual/C#04 -=== RUN TestALUMul/eBPF - ebpf_test.go:17: - 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 - 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 - filter_block_0: - 2: Mov32Imm dst: r4 imm: 0 - 3: Mul32Imm dst: r4 imm: 1 - 4: JEqImm dst: r4 off: -1 imm: 0 - filter_block_3: - 5: Mov32Imm dst: r4 imm: 0 - 6: JaImm dst: r0 off: -1 imm: 0 - filter_block_4: - 7: Mov32Imm dst: r4 imm: 1 - 8: JaImm dst: r0 off: -1 imm: 0 - result: - 9: MovImm dst: r0 imm: 2 - 10: JEqImm dst: r4 off: -1 imm: 0 - 11: MovImm dst: r0 imm: 1 - return: - 12: Exit -=== RUN TestALUMul/kernel -=== RUN TestALUMul/C#01 -=== RUN TestJumpIfLessThan/eBPF#02 +=== RUN TestALUDivZero/kernel#01 +--- PASS: TestALUOr (0.19s) + --- SKIP: TestALUOr/C (0.06s) + --- SKIP: TestALUOr/eBPF (0.00s) + --- PASS: TestALUOr/kernel (0.00s) + --- SKIP: TestALUOr/C#01 (0.05s) + --- SKIP: TestALUOr/eBPF#01 (0.00s) + --- PASS: TestALUOr/kernel#01 (0.00s) + --- SKIP: TestALUOr/C#02 (0.04s) + --- SKIP: TestALUOr/eBPF#02 (0.00s) + --- PASS: TestALUOr/kernel#02 (0.00s) + --- SKIP: TestALUOr/C#03 (0.04s) + --- SKIP: TestALUOr/eBPF#03 (0.00s) + --- PASS: TestALUOr/kernel#03 (0.00s) +=== RUN TestALUMul/C#02 +=== CONT TestALUAdd +=== RUN TestALUAdd/C +--- PASS: TestALUDivZero (0.15s) + --- SKIP: TestALUDivZero/C (0.05s) + --- SKIP: TestALUDivZero/eBPF (0.00s) + --- PASS: TestALUDivZero/kernel (0.06s) + --- SKIP: TestALUDivZero/C#01 (0.05s) + --- SKIP: TestALUDivZero/eBPF#01 (0.00s) + --- PASS: TestALUDivZero/kernel#01 (0.00s) +=== CONT TestLoadExtLen +=== RUN TestLoadExtLen/C +=== RUN TestJumpIfLessOrEqual/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 24 3: Mov32Imm dst: r5 imm: 23 - 4: JLTReg dst: r4 off: -1 src: r5 + 4: JLEReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 @@ -2243,14 +2317,14 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestJumpIfLessThan/kernel#02 -=== RUN TestJumpIfGreaterThan/eBPF#04 +=== RUN TestJumpIfLessOrEqual/kernel#02 +=== RUN TestJumpIfGreaterOrEqual/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 - 3: JGTImm dst: r4 off: -1 imm: 23 + 3: JGEImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 @@ -2263,17 +2337,107 @@ 10: MovImm dst: r0 imm: 1 return: 11: Exit -=== RUN TestJumpIfGreaterThan/kernel#04 -=== RUN TestALUXor/eBPF#03 +=== RUN TestJumpIfGreaterOrEqual/kernel#04 +=== RUN TestJumpIfGreaterOrEqual/C#05 +=== RUN TestJumpIfBitsNotSet/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 3: Mov32Imm dst: r5 imm: 4 + 4: JSetReg dst: r4 off: -1 src: r5 + 5: JaImm dst: r0 off: -1 imm: 0 + filter_block_3: + 6: Mov32Imm dst: r4 imm: 0 + 7: JaImm dst: r0 off: -1 imm: 0 + filter_block_4: + 8: Mov32Imm dst: r4 imm: 1 + 9: JaImm dst: r0 off: -1 imm: 0 + result: + 10: MovImm dst: r0 imm: 2 + 11: JEqImm dst: r4 off: -1 imm: 0 + 12: MovImm dst: r0 imm: 1 + return: + 13: Exit +=== RUN TestJumpIfBitsNotSet/kernel#02 +=== RUN TestALUSub/eBPF#01 + ebpf_test.go:17: + 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 + 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 + filter_block_0: + 2: Mov32Imm dst: r4 imm: 1 + 3: Mov32Imm dst: r5 imm: 1 + 4: Sub32Reg dst: r4 src: r5 + 5: JEqImm dst: r4 off: -1 imm: 0 + filter_block_4: + 6: Mov32Imm dst: r4 imm: 0 + 7: JaImm dst: r0 off: -1 imm: 0 + filter_block_5: + 8: Mov32Imm dst: r4 imm: 1 + 9: JaImm dst: r0 off: -1 imm: 0 + result: + 10: MovImm dst: r0 imm: 2 + 11: JEqImm dst: r4 off: -1 imm: 0 + 12: MovImm dst: r0 imm: 1 + return: + 13: Exit +=== RUN TestALUSub/kernel#01 +=== RUN TestALUSub/C#02 +=== RUN TestALUAnd/eBPF#05 + ebpf_test.go:17: + 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 + 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 + filter_block_0: + 2: Mov32Imm dst: r4 imm: 240 + 3: Mov32Imm dst: r5 imm: 15 + 4: And32Reg dst: r4 src: r5 + 5: JEqImm dst: r4 off: -1 imm: 0 + filter_block_4: + 6: Mov32Imm dst: r4 imm: 0 + 7: JaImm dst: r0 off: -1 imm: 0 + filter_block_5: + 8: Mov32Imm dst: r4 imm: 1 + 9: JaImm dst: r0 off: -1 imm: 0 + result: + 10: MovImm dst: r0 imm: 2 + 11: JEqImm dst: r4 off: -1 imm: 0 + 12: MovImm dst: r0 imm: 1 + return: + 13: Exit +=== RUN TestALUAnd/kernel#05 +--- PASS: TestALUAnd (0.29s) + --- SKIP: TestALUAnd/C (0.06s) + --- SKIP: TestALUAnd/eBPF (0.00s) + --- PASS: TestALUAnd/kernel (0.00s) + --- SKIP: TestALUAnd/C#01 (0.05s) + --- SKIP: TestALUAnd/eBPF#01 (0.00s) + --- PASS: TestALUAnd/kernel#01 (0.00s) + --- SKIP: TestALUAnd/C#02 (0.05s) + --- SKIP: TestALUAnd/eBPF#02 (0.00s) + --- PASS: TestALUAnd/kernel#02 (0.00s) + --- SKIP: TestALUAnd/C#03 (0.04s) + --- SKIP: TestALUAnd/eBPF#03 (0.00s) + --- PASS: TestALUAnd/kernel#03 (0.00s) + --- SKIP: TestALUAnd/C#04 (0.04s) + --- SKIP: TestALUAnd/eBPF#04 (0.00s) + --- PASS: TestALUAnd/kernel#04 (0.00s) + --- SKIP: TestALUAnd/C#05 (0.04s) + --- SKIP: TestALUAnd/eBPF#05 (0.00s) + --- PASS: TestALUAnd/kernel#05 (0.00s) +=== CONT TestMemShift +=== RUN TestMemShift/C +=== RUN TestJumpIfEqual/C#05 +=== RUN TestALUDiv/eBPF#03 + ebpf_test.go:17: + 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 + 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 + filter_block_0: + 2: Mov32Imm dst: r4 imm: 19 + 3: Mov32Imm dst: r5 imm: 3 4: JEqImm dst: r5 off: -1 imm: 0 - 5: Mod32Reg dst: r4 src: r5 - 6: JEqImm dst: r4 off: -1 imm: 2 + 5: Div32Reg dst: r4 src: r5 + 6: JEqImm dst: r4 off: -1 imm: 6 filter_block_4: 7: Mov32Imm dst: r4 imm: 0 8: JaImm dst: r0 off: -1 imm: 0 @@ -2289,54 +2453,57 @@ 15: MovImm dst: r0 imm: 1 return: 16: Exit -=== RUN TestALUXor/kernel#03 ---- PASS: TestALUXor (0.36s) - --- SKIP: TestALUXor/C (0.06s) - --- SKIP: TestALUXor/eBPF (0.00s) - --- PASS: TestALUXor/kernel (0.00s) - --- SKIP: TestALUXor/C#01 (0.10s) - --- SKIP: TestALUXor/eBPF#01 (0.00s) - --- PASS: TestALUXor/kernel#01 (0.00s) - --- SKIP: TestALUXor/C#02 (0.08s) - --- SKIP: TestALUXor/eBPF#02 (0.00s) - --- PASS: TestALUXor/kernel#02 (0.00s) - --- SKIP: TestALUXor/C#03 (0.08s) - --- SKIP: TestALUXor/eBPF#03 (0.00s) - --- PASS: TestALUXor/kernel#03 (0.00s) -=== CONT TestALUAdd -=== RUN TestALUAdd/C -=== RUN TestJumpIfEqual/eBPF#04 +=== RUN TestALUDiv/kernel#03 +=== RUN TestALUAdd/eBPF +--- PASS: TestALUDiv (0.19s) + --- SKIP: TestALUDiv/C (0.05s) + --- SKIP: TestALUDiv/eBPF (0.00s) + --- PASS: TestALUDiv/kernel (0.00s) + --- SKIP: TestALUDiv/C#01 (0.04s) + --- SKIP: TestALUDiv/eBPF#01 (0.00s) + --- PASS: TestALUDiv/kernel#01 (0.00s) + --- SKIP: TestALUDiv/C#02 (0.05s) + --- SKIP: TestALUDiv/eBPF#02 (0.00s) + --- PASS: TestALUDiv/kernel#02 (0.00s) + --- SKIP: TestALUDiv/C#03 (0.04s) + --- SKIP: TestALUDiv/eBPF#03 (0.00s) + --- PASS: TestALUDiv/kernel#03 (0.00s) +=== CONT TestJumpIfLessThan +=== RUN TestJumpIfLessThan/C +=== NAME TestALUAdd/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 23 - 3: JEqImm dst: r4 off: -1 imm: 21 - filter_block_2: - 4: Mov32Imm dst: r4 imm: 0 - 5: JaImm dst: r0 off: -1 imm: 0 + 2: Mov32Imm dst: r4 imm: 1 + 3: Add32Imm dst: r4 imm: 0 + 4: JEqImm dst: r4 off: -1 imm: 1 filter_block_3: - 6: Mov32Imm dst: r4 imm: 1 - 7: JaImm dst: r0 off: -1 imm: 0 + 5: Mov32Imm dst: r4 imm: 0 + 6: JaImm dst: r0 off: -1 imm: 0 + filter_block_4: + 7: Mov32Imm dst: r4 imm: 1 + 8: JaImm dst: r0 off: -1 imm: 0 result: - 8: MovImm dst: r0 imm: 2 - 9: JEqImm dst: r4 off: -1 imm: 0 - 10: MovImm dst: r0 imm: 1 + 9: MovImm dst: r0 imm: 2 + 10: JEqImm dst: r4 off: -1 imm: 0 + 11: MovImm dst: r0 imm: 1 return: - 11: Exit -=== RUN TestJumpIfEqual/kernel#04 -=== RUN TestALUAnd/eBPF#04 + 12: Exit +=== RUN TestALUAdd/kernel +=== RUN TestALUAdd/C#01 +=== RUN TestLoadExtLen/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 240 - 3: And32Imm dst: r4 imm: 15 - 4: JEqImm dst: r4 off: -1 imm: 0 - filter_block_3: + 2: MovReg dst: r4 src: r3 + 3: Sub32Reg dst: r4 src: r2 + 4: JEqImm dst: r4 off: -1 imm: 16 + filter_block_2: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 - filter_block_4: + filter_block_3: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: @@ -2345,55 +2512,42 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestALUAnd/kernel#04 -=== RUN TestALUAnd/C#05 -=== RUN TestJumpIfNotEqual/C#03 -=== RUN TestALUDivZero/C#01 -=== RUN TestALUShiftRight/eBPF#03 +=== RUN TestLoadExtLen/kernel +=== RUN TestJumpIfBitsSet/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 240 - 3: Mov32Imm dst: r5 imm: 8 - 4: RSh32Reg dst: r4 src: r5 - 5: JEqImm dst: r4 off: -1 imm: 0 - filter_block_4: - 6: Mov32Imm dst: r4 imm: 0 + 2: Mov32Imm dst: r4 imm: 6 + 3: JSetImm dst: r4 off: -1 imm: 2 + filter_block_2: + 4: Mov32Imm dst: r4 imm: 0 + 5: JaImm dst: r0 off: -1 imm: 0 + filter_block_3: + 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 - filter_block_5: - 8: Mov32Imm dst: r4 imm: 1 - 9: JaImm dst: r0 off: -1 imm: 0 result: - 10: MovImm dst: r0 imm: 2 - 11: JEqImm dst: r4 off: -1 imm: 0 - 12: MovImm dst: r0 imm: 1 + 8: MovImm dst: r0 imm: 2 + 9: JEqImm dst: r4 off: -1 imm: 0 + 10: MovImm dst: r0 imm: 1 return: - 13: Exit -=== RUN TestALUShiftRight/kernel#03 ---- PASS: TestALUShiftRight (0.30s) - --- SKIP: TestALUShiftRight/C (0.10s) - --- SKIP: TestALUShiftRight/eBPF (0.00s) - --- PASS: TestALUShiftRight/kernel (0.00s) - --- SKIP: TestALUShiftRight/C#01 (0.06s) - --- SKIP: TestALUShiftRight/eBPF#01 (0.00s) - --- PASS: TestALUShiftRight/kernel#01 (0.00s) - --- SKIP: TestALUShiftRight/C#02 (0.04s) - --- SKIP: TestALUShiftRight/eBPF#02 (0.00s) - --- PASS: TestALUShiftRight/kernel#02 (0.00s) - --- SKIP: TestALUShiftRight/C#03 (0.10s) - --- SKIP: TestALUShiftRight/eBPF#03 (0.00s) - --- PASS: TestALUShiftRight/kernel#03 (0.00s) -=== CONT TestLoadExtLen -=== RUN TestLoadExtLen/C -=== RUN TestALUSub/eBPF + 11: Exit +=== RUN TestJumpIfBitsSet/kernel#04 +--- PASS: TestLoadExtLen (0.04s) + --- SKIP: TestLoadExtLen/C (0.04s) + --- SKIP: TestLoadExtLen/eBPF (0.00s) + --- PASS: TestLoadExtLen/kernel (0.00s) +=== CONT TestLoadAbsolute +=== RUN TestLoadAbsolute/C +=== RUN TestJumpIfBitsSet/C#05 +=== RUN TestALUMul/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 1 - 3: Sub32Imm dst: r4 imm: 1 - 4: JEqImm dst: r4 off: -1 imm: 0 + 2: Mov32Imm dst: r4 imm: 4 + 3: Mul32Imm dst: r4 imm: 13 + 4: JEqImm dst: r4 off: -1 imm: 52 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 @@ -2406,40 +2560,47 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestALUSub/kernel -=== RUN TestALUSub/C#01 -=== RUN TestALUMul/eBPF#01 +=== RUN TestALUMul/kernel#02 +=== RUN TestALUMul/C#03 +=== RUN TestJumpIfNotEqual/C#03 +=== RUN TestJumpIfGreaterOrEqual/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 0 - 3: Mov32Imm dst: r5 imm: 1 - 4: Mul32Reg dst: r4 src: r5 - 5: JEqImm dst: r4 off: -1 imm: 0 - filter_block_4: - 6: Mov32Imm dst: r4 imm: 0 + 2: Mov32Imm dst: r4 imm: 23 + 3: JEqImm dst: r4 off: -1 imm: 0 + filter_block_2: + 4: JGEImm dst: r4 off: -1 imm: 23 + 5: JaImm dst: r0 off: -1 imm: 0 + filter_block_3: + 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 - filter_block_5: - 8: Mov32Imm dst: r4 imm: 1 + filter_block_4: + 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 + filter_block_5: + 10: Mov32Imm dst: r4 imm: 1 + 11: JaImm dst: r0 off: -1 imm: 0 result: - 10: MovImm dst: r0 imm: 2 - 11: JEqImm dst: r4 off: -1 imm: 0 - 12: MovImm dst: r0 imm: 1 + 12: MovImm dst: r0 imm: 2 + 13: JEqImm dst: r4 off: -1 imm: 0 + 14: MovImm dst: r0 imm: 1 return: - 13: Exit -=== RUN TestALUMul/kernel#01 -=== RUN TestALUMul/C#02 -=== RUN TestJumpIfLessThan/C#03 -=== RUN TestALUDiv/eBPF + 15: Exit +=== RUN TestJumpIfGreaterOrEqual/kernel#05 +=== RUN TestJumpIfGreaterOrEqual/C#06 +=== RUN TestJumpIfLessOrEqual/C#03 +=== RUN TestALUSub/eBPF#02 +=== RUN TestMemShift/eBPF +=== NAME TestALUSub/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 2 - 3: Div32Imm dst: r4 imm: 2 - 4: JEqImm dst: r4 off: -1 imm: 1 + 2: Mov32Imm dst: r4 imm: 13 + 3: Sub32Imm dst: r4 imm: 9 + 4: JEqImm dst: r4 off: -1 imm: 4 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 @@ -2452,97 +2613,126 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestALUDiv/kernel -=== RUN TestALUDiv/C#01 -=== RUN TestJumpIfGreaterThan/C#05 -=== RUN TestALUOr/eBPF#02 +=== RUN TestALUSub/kernel#02 +=== NAME TestMemShift/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 240 - 3: Or32Imm dst: r4 imm: 15 - 4: JEqImm dst: r4 off: -1 imm: 255 + 2: MovReg dst: r6 src: r2 + 3: AddImm dst: r6 imm: 3 + 4: JGTReg dst: r6 off: -1 src: r3 + 5: Mov32Imm dst: r4 imm: 40 + 6: LdXMemB dst: r5 src: r2 off: 2 imm: 0 + 7: And32Imm dst: r5 imm: 15 + 8: LSh32Imm dst: r5 imm: 2 + 9: JEqReg dst: r4 off: -1 src: r5 filter_block_3: - 5: Mov32Imm dst: r4 imm: 0 - 6: JaImm dst: r0 off: -1 imm: 0 + 10: Mov32Imm dst: r4 imm: 0 + 11: JaImm dst: r0 off: -1 imm: 0 filter_block_4: - 7: Mov32Imm dst: r4 imm: 1 - 8: JaImm dst: r0 off: -1 imm: 0 + 12: Mov32Imm dst: r4 imm: 1 + 13: JaImm dst: r0 off: -1 imm: 0 + filter_nomatch: + 14: MovImm dst: r4 imm: 0 + 15: JaImm dst: r0 off: -1 imm: 0 result: - 9: MovImm dst: r0 imm: 2 - 10: JEqImm dst: r4 off: -1 imm: 0 - 11: MovImm dst: r0 imm: 1 + 16: MovImm dst: r0 imm: 2 + 17: JEqImm dst: r4 off: -1 imm: 0 + 18: MovImm dst: r0 imm: 1 return: - 12: Exit -=== RUN TestALUOr/kernel#02 -=== RUN TestALUOr/C#03 -=== RUN TestJumpIfEqual/C#05 -=== RUN TestALUAnd/eBPF#05 -=== RUN TestJumpIfNotEqual/eBPF#03 + 19: Exit +=== RUN TestMemShift/kernel +=== RUN TestALUSub/C#03 +=== RUN TestMemShift/C#01 +=== RUN TestJumpIfEqual/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 - 3: Mov32Imm dst: r5 imm: 23 - 4: JEqImm dst: r4 off: -1 imm: 0 + 3: JEqImm dst: r4 off: -1 imm: 0 + filter_block_2: + 4: JEqImm dst: r4 off: -1 imm: 21 + 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: - 5: JNEReg dst: r4 off: -1 src: r5 - 6: JaImm dst: r0 off: -1 imm: 0 + 6: Mov32Imm dst: r4 imm: 1 + 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: - 7: Mov32Imm dst: r4 imm: 1 - 8: JaImm dst: r0 off: -1 imm: 0 + 8: Mov32Imm dst: r4 imm: 0 + 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: - 9: Mov32Imm dst: r4 imm: 0 - 10: JaImm dst: r0 off: -1 imm: 0 - filter_block_6: - 11: Mov32Imm dst: r4 imm: 1 - 12: JaImm dst: r0 off: -1 imm: 0 + 10: Mov32Imm dst: r4 imm: 1 + 11: JaImm dst: r0 off: -1 imm: 0 result: - 13: MovImm dst: r0 imm: 2 - 14: JEqImm dst: r4 off: -1 imm: 0 - 15: MovImm dst: r0 imm: 1 + 12: MovImm dst: r0 imm: 2 + 13: JEqImm dst: r4 off: -1 imm: 0 + 14: MovImm dst: r0 imm: 1 return: - 16: Exit -=== RUN TestALUAdd/eBPF -=== RUN TestJumpIfNotEqual/kernel#03 -=== RUN TestLoadExtLen/eBPF + 15: Exit +=== RUN TestJumpIfEqual/kernel#05 +=== RUN TestJumpIfBitsNotSet/C#03 +=== RUN TestJumpIfLessThan/eBPF +=== RUN TestJumpIfBitsSet/eBPF#05 +=== NAME TestJumpIfLessThan/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: MovReg dst: r4 src: r3 - 3: Sub32Reg dst: r4 src: r2 - 4: JEqImm dst: r4 off: -1 imm: 16 + 2: Mov32Imm dst: r4 imm: 24 + 3: JLTImm dst: r4 off: -1 imm: 23 filter_block_2: - 5: Mov32Imm dst: r4 imm: 0 - 6: JaImm dst: r0 off: -1 imm: 0 + 4: Mov32Imm dst: r4 imm: 0 + 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: - 7: Mov32Imm dst: r4 imm: 1 - 8: JaImm dst: r0 off: -1 imm: 0 + 6: Mov32Imm dst: r4 imm: 1 + 7: JaImm dst: r0 off: -1 imm: 0 result: - 9: MovImm dst: r0 imm: 2 - 10: JEqImm dst: r4 off: -1 imm: 0 - 11: MovImm dst: r0 imm: 1 + 8: MovImm dst: r0 imm: 2 + 9: JEqImm dst: r4 off: -1 imm: 0 + 10: MovImm dst: r0 imm: 1 return: - 12: Exit -=== RUN TestLoadExtLen/kernel ---- PASS: TestLoadExtLen (0.10s) - --- SKIP: TestLoadExtLen/C (0.10s) - --- SKIP: TestLoadExtLen/eBPF (0.00s) - --- PASS: TestLoadExtLen/kernel (0.00s) -=== CONT TestMemShift -=== RUN TestMemShift/C -=== NAME TestALUAnd/eBPF#05 + 11: Exit +=== RUN TestJumpIfLessThan/kernel +=== RUN TestJumpIfNotEqual/eBPF#03 +=== RUN TestLoadAbsolute/eBPF +=== RUN TestALUAdd/eBPF#01 +=== NAME TestJumpIfBitsSet/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 240 - 3: Mov32Imm dst: r5 imm: 15 - 4: And32Reg dst: r4 src: r5 - 5: JEqImm dst: r4 off: -1 imm: 0 + 2: Mov32Imm dst: r4 imm: 6 + 3: JEqImm dst: r4 off: -1 imm: 0 + filter_block_2: + 4: JSetImm dst: r4 off: -1 imm: 2 + 5: JaImm dst: r0 off: -1 imm: 0 + filter_block_3: + 6: Mov32Imm dst: r4 imm: 1 + 7: JaImm dst: r0 off: -1 imm: 0 + filter_block_4: + 8: Mov32Imm dst: r4 imm: 0 + 9: JaImm dst: r0 off: -1 imm: 0 + filter_block_5: + 10: Mov32Imm dst: r4 imm: 1 + 11: JaImm dst: r0 off: -1 imm: 0 + result: + 12: MovImm dst: r0 imm: 2 + 13: JEqImm dst: r4 off: -1 imm: 0 + 14: MovImm dst: r0 imm: 1 + return: + 15: Exit +=== RUN TestJumpIfBitsSet/kernel#05 +=== RUN TestJumpIfBitsSet/C#06 +=== RUN TestALUMul/eBPF#03 + ebpf_test.go:17: + 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 + 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 + filter_block_0: + 2: Mov32Imm dst: r4 imm: 4 + 3: Mov32Imm dst: r5 imm: 13 + 4: Mul32Reg dst: r4 src: r5 + 5: JEqImm dst: r4 off: -1 imm: 52 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 @@ -2555,63 +2745,49 @@ 12: MovImm dst: r0 imm: 1 return: 13: Exit -=== RUN TestALUAnd/kernel#05 ---- PASS: TestALUAnd (0.50s) - --- SKIP: TestALUAnd/C (0.07s) - --- SKIP: TestALUAnd/eBPF (0.00s) - --- PASS: TestALUAnd/kernel (0.00s) - --- SKIP: TestALUAnd/C#01 (0.12s) - --- SKIP: TestALUAnd/eBPF#01 (0.00s) - --- PASS: TestALUAnd/kernel#01 (0.00s) - --- SKIP: TestALUAnd/C#02 (0.04s) - --- SKIP: TestALUAnd/eBPF#02 (0.00s) - --- PASS: TestALUAnd/kernel#02 (0.00s) - --- SKIP: TestALUAnd/C#03 (0.07s) - --- SKIP: TestALUAnd/eBPF#03 (0.00s) - --- PASS: TestALUAnd/kernel#03 (0.00s) - --- SKIP: TestALUAnd/C#04 (0.05s) - --- SKIP: TestALUAnd/eBPF#04 (0.00s) - --- PASS: TestALUAnd/kernel#04 (0.00s) - --- SKIP: TestALUAnd/C#05 (0.06s) - --- SKIP: TestALUAnd/eBPF#05 (0.04s) - --- PASS: TestALUAnd/kernel#05 (0.00s) -=== CONT TestScratchX -=== RUN TestScratchX/C -=== NAME TestALUAdd/eBPF +=== RUN TestALUMul/kernel#03 +=== RUN TestALUMul/C#04 +=== NAME TestJumpIfNotEqual/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 1 - 3: Add32Imm dst: r4 imm: 0 - 4: JEqImm dst: r4 off: -1 imm: 1 + 2: Mov32Imm dst: r4 imm: 23 + 3: Mov32Imm dst: r5 imm: 23 + 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: - 5: Mov32Imm dst: r4 imm: 0 - 6: JaImm dst: r0 off: -1 imm: 0 + 5: JNEReg dst: r4 off: -1 src: r5 + 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 + filter_block_5: + 9: Mov32Imm dst: r4 imm: 0 + 10: JaImm dst: r0 off: -1 imm: 0 + filter_block_6: + 11: Mov32Imm dst: r4 imm: 1 + 12: JaImm dst: r0 off: -1 imm: 0 result: - 9: MovImm dst: r0 imm: 2 - 10: JEqImm dst: r4 off: -1 imm: 0 - 11: MovImm dst: r0 imm: 1 + 13: MovImm dst: r0 imm: 2 + 14: JEqImm dst: r4 off: -1 imm: 0 + 15: MovImm dst: r0 imm: 1 return: - 12: Exit -=== RUN TestALUAdd/kernel -=== RUN TestALUDiv/eBPF#01 + 16: Exit +=== RUN TestJumpIfNotEqual/kernel#03 +=== NAME TestLoadAbsolute/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 2 - 3: Mov32Imm dst: r5 imm: 2 - 4: JEqImm dst: r5 off: -1 imm: 0 - 5: Div32Reg dst: r4 src: r5 - 6: JEqImm dst: r4 off: -1 imm: 1 - filter_block_4: + 2: MovReg dst: r6 src: r2 + 3: AddImm dst: r6 imm: 3 + 4: JGTReg dst: r6 off: -1 src: r3 + 5: LdXMemB dst: r4 src: r2 off: 2 imm: 0 + 6: JEqImm dst: r4 off: -1 imm: 5 + filter_block_2: 7: Mov32Imm dst: r4 imm: 0 8: JaImm dst: r0 off: -1 imm: 0 - filter_block_5: + filter_block_3: 9: Mov32Imm dst: r4 imm: 1 10: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: @@ -2623,18 +2799,16 @@ 15: MovImm dst: r0 imm: 1 return: 16: Exit -=== RUN TestALUDiv/kernel#01 -=== RUN TestALUSub/eBPF#01 -=== RUN TestALUAdd/C#01 -=== NAME TestALUSub/eBPF#01 +=== RUN TestLoadAbsolute/kernel +=== NAME TestALUAdd/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 1 - 3: Mov32Imm dst: r5 imm: 1 - 4: Sub32Reg dst: r4 src: r5 - 5: JEqImm dst: r4 off: -1 imm: 0 + 3: Mov32Imm dst: r5 imm: 0 + 4: Add32Reg dst: r4 src: r5 + 5: JEqImm dst: r4 off: -1 imm: 1 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 @@ -2647,82 +2821,40 @@ 12: MovImm dst: r0 imm: 1 return: 13: Exit -=== RUN TestALUDivZero/eBPF#01 -=== RUN TestALUSub/kernel#01 -=== NAME TestALUDivZero/eBPF#01 - ebpf_test.go:17: - 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 - 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 - filter_block_0: - 2: MovReg dst: r6 src: r2 - 3: AddImm dst: r6 imm: 1 - 4: JGTReg dst: r6 off: -1 src: r3 - 5: LdXMemB dst: r4 src: r2 off: 0 imm: 0 - 6: Mov32Reg dst: r5 src: r4 - 7: Mov32Imm dst: r4 imm: 10 - 8: JEqImm dst: r5 off: -1 imm: 0 - 9: Div32Reg dst: r4 src: r5 - 10: Mov32Imm dst: r4 imm: 1 - 11: JaImm dst: r0 off: -1 imm: 0 - filter_nomatch: - 12: MovImm dst: r4 imm: 0 - 13: JaImm dst: r0 off: -1 imm: 0 - result: - 14: MovImm dst: r0 imm: 2 - 15: JEqImm dst: r4 off: -1 imm: 0 - 16: MovImm dst: r0 imm: 1 - return: - 17: Exit -=== RUN TestALUDivZero/kernel#01 -=== RUN TestALUSub/C#02 ---- PASS: TestALUDivZero (0.24s) - --- SKIP: TestALUDivZero/C (0.07s) - --- SKIP: TestALUDivZero/eBPF (0.00s) - --- PASS: TestALUDivZero/kernel (0.05s) - --- SKIP: TestALUDivZero/C#01 (0.10s) - --- SKIP: TestALUDivZero/eBPF#01 (0.00s) - --- PASS: TestALUDivZero/kernel#01 (0.00s) -=== CONT TestLoadConstantX -=== RUN TestLoadConstantX/C -=== RUN TestALUDiv/C#02 -=== RUN TestALUMul/eBPF#02 -=== RUN TestJumpIfGreaterThan/eBPF#05 -=== RUN TestALUOr/eBPF#03 -=== NAME TestJumpIfGreaterThan/eBPF#05 +=== RUN TestALUAdd/kernel#01 +=== RUN TestLoadAbsolute/C#01 +=== RUN TestALUAdd/C#02 +=== RUN TestJumpIfGreaterOrEqual/eBPF#06 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 - 3: JEqImm dst: r4 off: -1 imm: 0 - filter_block_2: - 4: JGTImm dst: r4 off: -1 imm: 23 - 5: JaImm dst: r0 off: -1 imm: 0 + 3: Mov32Imm dst: r5 imm: 23 + 4: JGEReg dst: r4 off: -1 src: r5 filter_block_3: - 6: Mov32Imm dst: r4 imm: 1 - 7: JaImm dst: r0 off: -1 imm: 0 + 5: Mov32Imm dst: r4 imm: 0 + 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: - 8: Mov32Imm dst: r4 imm: 0 - 9: JaImm dst: r0 off: -1 imm: 0 - filter_block_5: - 10: Mov32Imm dst: r4 imm: 1 - 11: JaImm dst: r0 off: -1 imm: 0 + 7: Mov32Imm dst: r4 imm: 1 + 8: JaImm dst: r0 off: -1 imm: 0 result: - 12: MovImm dst: r0 imm: 2 - 13: JEqImm dst: r4 off: -1 imm: 0 - 14: MovImm dst: r0 imm: 1 + 9: MovImm dst: r0 imm: 2 + 10: JEqImm dst: r4 off: -1 imm: 0 + 11: MovImm dst: r0 imm: 1 return: - 15: Exit -=== RUN TestJumpIfGreaterThan/kernel#05 -=== NAME TestALUOr/eBPF#03 + 12: Exit +=== RUN TestJumpIfGreaterOrEqual/kernel#06 +=== RUN TestJumpIfGreaterOrEqual/C#07 +=== RUN TestALUSub/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 240 - 3: Mov32Imm dst: r5 imm: 15 - 4: Or32Reg dst: r4 src: r5 - 5: JEqImm dst: r4 off: -1 imm: 255 + 2: Mov32Imm dst: r4 imm: 13 + 3: Mov32Imm dst: r5 imm: 9 + 4: Sub32Reg dst: r4 src: r5 + 5: JEqImm dst: r4 off: -1 imm: 4 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 @@ -2735,23 +2867,23 @@ 12: MovImm dst: r0 imm: 1 return: 13: Exit -=== RUN TestALUOr/kernel#03 ---- PASS: TestALUOr (0.40s) - --- SKIP: TestALUOr/C (0.10s) - --- SKIP: TestALUOr/eBPF (0.00s) - --- PASS: TestALUOr/kernel (0.00s) - --- SKIP: TestALUOr/C#01 (0.09s) - --- SKIP: TestALUOr/eBPF#01 (0.00s) - --- PASS: TestALUOr/kernel#01 (0.00s) - --- SKIP: TestALUOr/C#02 (0.11s) - --- SKIP: TestALUOr/eBPF#02 (0.00s) - --- PASS: TestALUOr/kernel#02 (0.00s) - --- SKIP: TestALUOr/C#03 (0.06s) - --- SKIP: TestALUOr/eBPF#03 (0.02s) - --- PASS: TestALUOr/kernel#03 (0.00s) -=== CONT TestScratchZero -=== RUN TestScratchZero/C -=== RUN TestJumpIfLessThan/eBPF#03 +=== RUN TestALUSub/kernel#03 +--- PASS: TestALUSub (0.18s) + --- SKIP: TestALUSub/C (0.04s) + --- SKIP: TestALUSub/eBPF (0.00s) + --- PASS: TestALUSub/kernel (0.00s) + --- SKIP: TestALUSub/C#01 (0.06s) + --- SKIP: TestALUSub/eBPF#01 (0.00s) + --- PASS: TestALUSub/kernel#01 (0.00s) + --- SKIP: TestALUSub/C#02 (0.04s) + --- SKIP: TestALUSub/eBPF#02 (0.00s) + --- PASS: TestALUSub/kernel#02 (0.00s) + --- SKIP: TestALUSub/C#03 (0.04s) + --- SKIP: TestALUSub/eBPF#03 (0.00s) + --- PASS: TestALUSub/kernel#03 (0.00s) +=== CONT TestScratchA +=== RUN TestScratchA/C +=== RUN TestJumpIfLessOrEqual/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 @@ -2760,7 +2892,7 @@ 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: - 5: JLTReg dst: r4 off: -1 src: r5 + 5: JLEReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 @@ -2777,8 +2909,8 @@ 15: MovImm dst: r0 imm: 1 return: 16: Exit -=== RUN TestJumpIfLessThan/kernel#03 -=== RUN TestMemShift/eBPF +=== RUN TestJumpIfLessOrEqual/kernel#03 +=== RUN TestMemShift/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 @@ -2786,7 +2918,7 @@ 2: MovReg dst: r6 src: r2 3: AddImm dst: r6 imm: 3 4: JGTReg dst: r6 off: -1 src: r3 - 5: Mov32Imm dst: r4 imm: 40 + 5: Mov32Imm dst: r4 imm: 0 6: LdXMemB dst: r5 src: r2 off: 2 imm: 0 7: And32Imm dst: r5 imm: 15 8: LSh32Imm dst: r5 imm: 2 @@ -2806,46 +2938,24 @@ 18: MovImm dst: r0 imm: 1 return: 19: Exit -=== RUN TestMemShift/kernel -=== RUN TestMemShift/C#01 -=== RUN TestScratchX/eBPF - ebpf_test.go:17: - 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 - 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 - filter_block_0: - 2: Mov32Imm dst: r5 imm: -559038737 - 3: StXMemW dst: rfp src: r5 off: -32 imm: 0 - 4: Mov32Imm dst: r5 imm: 0 - 5: Mov32Imm dst: r5 imm: -1 - 6: StXMemW dst: rfp src: r5 off: -28 imm: 0 - 7: Mov32Imm dst: r5 imm: -1 - 8: StXMemW dst: rfp src: r5 off: -36 imm: 0 - 9: LdXMemW dst: r5 src: rfp off: -32 imm: 0 - 10: Mov32Reg dst: r4 src: r5 - 11: Mov32Imm dst: r6 imm: -559038737 - 12: JEqReg dst: r4 off: -1 src: r6 - filter_block_10: - 13: Mov32Imm dst: r4 imm: 0 - 14: JaImm dst: r0 off: -1 imm: 0 - filter_block_11: - 15: Mov32Imm dst: r4 imm: 1 - 16: JaImm dst: r0 off: -1 imm: 0 - result: - 17: MovImm dst: r0 imm: 2 - 18: JEqImm dst: r4 off: -1 imm: 0 - 19: MovImm dst: r0 imm: 1 - return: - 20: Exit -=== RUN TestScratchX/kernel -=== RUN TestScratchX/C#01 -=== NAME TestALUMul/eBPF#02 +=== RUN TestMemShift/kernel#01 +--- PASS: TestMemShift (0.08s) + --- SKIP: TestMemShift/C (0.04s) + --- SKIP: TestMemShift/eBPF (0.00s) + --- PASS: TestMemShift/kernel (0.00s) + --- SKIP: TestMemShift/C#01 (0.04s) + --- SKIP: TestMemShift/eBPF#01 (0.00s) + --- PASS: TestMemShift/kernel#01 (0.00s) +=== CONT TestScratchZero +=== RUN TestScratchZero/C +=== RUN TestJumpIfBitsSet/eBPF#06 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 4 - 3: Mul32Imm dst: r4 imm: 13 - 4: JEqImm dst: r4 off: -1 imm: 52 + 2: Mov32Imm dst: r4 imm: 6 + 3: Mov32Imm dst: r5 imm: 2 + 4: JSetReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 @@ -2858,43 +2968,44 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestALUMul/kernel#02 -=== RUN TestALUMul/C#03 -=== RUN TestJumpIfEqual/eBPF#05 +=== RUN TestJumpIfBitsSet/kernel#06 +=== RUN TestJumpIfBitsSet/C#07 +=== RUN TestJumpIfEqual/C#06 +=== RUN TestJumpIfBitsNotSet/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 23 - 3: JEqImm dst: r4 off: -1 imm: 0 - filter_block_2: - 4: JEqImm dst: r4 off: -1 imm: 21 - 5: JaImm dst: r0 off: -1 imm: 0 + 2: Mov32Imm dst: r4 imm: 6 + 3: Mov32Imm dst: r5 imm: 4 + 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: - 6: Mov32Imm dst: r4 imm: 1 - 7: JaImm dst: r0 off: -1 imm: 0 + 5: JSetReg dst: r4 off: -1 src: r5 + 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: - 8: Mov32Imm dst: r4 imm: 0 - 9: JaImm dst: r0 off: -1 imm: 0 + 7: Mov32Imm dst: r4 imm: 1 + 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: - 10: Mov32Imm dst: r4 imm: 1 - 11: JaImm dst: r0 off: -1 imm: 0 + 9: Mov32Imm dst: r4 imm: 0 + 10: JaImm dst: r0 off: -1 imm: 0 + filter_block_6: + 11: Mov32Imm dst: r4 imm: 1 + 12: JaImm dst: r0 off: -1 imm: 0 result: - 12: MovImm dst: r0 imm: 2 - 13: JEqImm dst: r4 off: -1 imm: 0 - 14: MovImm dst: r0 imm: 1 + 13: MovImm dst: r0 imm: 2 + 14: JEqImm dst: r4 off: -1 imm: 0 + 15: MovImm dst: r0 imm: 1 return: - 15: Exit -=== RUN TestJumpIfEqual/kernel#05 -=== RUN TestJumpIfNotEqual/C#04 -=== RUN TestALUSub/eBPF#02 + 16: Exit +=== RUN TestJumpIfBitsNotSet/kernel#03 +=== RUN TestALUMul/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 13 - 3: Sub32Imm dst: r4 imm: 9 - 4: JEqImm dst: r4 off: -1 imm: 4 + 2: Mov32Imm dst: r4 imm: 2 + 3: Mul32Imm dst: r4 imm: -2147483648 + 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 @@ -2907,65 +3018,70 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestALUSub/kernel#02 -=== RUN TestALUSub/C#03 -=== RUN TestLoadConstantX/eBPF -=== RUN TestALUAdd/eBPF#01 +=== RUN TestALUMul/kernel#04 +=== RUN TestALUMul/C#05 +=== RUN TestLoadAbsolute/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 1 - 3: Mov32Imm dst: r5 imm: 0 - 4: Add32Reg dst: r4 src: r5 - 5: JEqImm dst: r4 off: -1 imm: 1 - filter_block_4: - 6: Mov32Imm dst: r4 imm: 0 - 7: JaImm dst: r0 off: -1 imm: 0 - filter_block_5: - 8: Mov32Imm dst: r4 imm: 1 - 9: JaImm dst: r0 off: -1 imm: 0 + 2: MovReg dst: r6 src: r2 + 3: AddImm dst: r6 imm: 3 + 4: JGTReg dst: r6 off: -1 src: r3 + 5: LdXMemB dst: r4 src: r2 off: 2 imm: 0 + 6: JEqImm dst: r4 off: -1 imm: 6 + filter_block_2: + 7: Mov32Imm dst: r4 imm: 0 + 8: JaImm dst: r0 off: -1 imm: 0 + filter_block_3: + 9: Mov32Imm dst: r4 imm: 1 + 10: JaImm dst: r0 off: -1 imm: 0 + filter_nomatch: + 11: MovImm dst: r4 imm: 0 + 12: JaImm dst: r0 off: -1 imm: 0 result: - 10: MovImm dst: r0 imm: 2 - 11: JEqImm dst: r4 off: -1 imm: 0 - 12: MovImm dst: r0 imm: 1 + 13: MovImm dst: r0 imm: 2 + 14: JEqImm dst: r4 off: -1 imm: 0 + 15: MovImm dst: r0 imm: 1 return: - 13: Exit -=== RUN TestALUAdd/kernel#01 -=== RUN TestALUAdd/C#02 -=== RUN TestJumpIfGreaterThan/C#06 -=== NAME TestLoadConstantX/eBPF + 16: Exit +=== RUN TestLoadAbsolute/kernel#01 +=== RUN TestJumpIfGreaterOrEqual/eBPF#07 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r5 imm: 1 - 3: Mov32Reg dst: r4 src: r5 - 4: JEqImm dst: r4 off: -1 imm: 1 + 2: Mov32Imm dst: r4 imm: 23 + 3: Mov32Imm dst: r5 imm: 23 + 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: - 5: Mov32Imm dst: r4 imm: 0 - 6: JaImm dst: r0 off: -1 imm: 0 + 5: JGEReg dst: r4 off: -1 src: r5 + 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 + filter_block_5: + 9: Mov32Imm dst: r4 imm: 0 + 10: JaImm dst: r0 off: -1 imm: 0 + filter_block_6: + 11: Mov32Imm dst: r4 imm: 1 + 12: JaImm dst: r0 off: -1 imm: 0 result: - 9: MovImm dst: r0 imm: 2 - 10: JEqImm dst: r4 off: -1 imm: 0 - 11: MovImm dst: r0 imm: 1 + 13: MovImm dst: r0 imm: 2 + 14: JEqImm dst: r4 off: -1 imm: 0 + 15: MovImm dst: r0 imm: 1 return: - 12: Exit -=== RUN TestLoadConstantX/kernel -=== RUN TestLoadConstantX/C#01 -=== RUN TestJumpIfLessThan/C#04 -=== RUN TestJumpIfEqual/C#06 -=== RUN TestALUDiv/eBPF#02 + 16: Exit +=== RUN TestJumpIfGreaterOrEqual/kernel#07 +=== RUN TestJumpIfGreaterOrEqual/C#08 +=== RUN TestALUAdd/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 19 - 3: Div32Imm dst: r4 imm: 3 - 4: JEqImm dst: r4 off: -1 imm: 6 + 2: Mov32Imm dst: r4 imm: 4 + 3: Add32Imm dst: r4 imm: 13 + 4: JEqImm dst: r4 off: -1 imm: 17 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 @@ -2978,8 +3094,39 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestALUDiv/kernel#02 -=== RUN TestALUDiv/C#03 +=== RUN TestALUAdd/kernel#02 +=== RUN TestALUAdd/C#03 +=== RUN TestScratchA/eBPF + ebpf_test.go:17: + 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 + 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 + filter_block_0: + 2: Mov32Imm dst: r4 imm: -559038737 + 3: StXMemW dst: rfp src: r4 off: -32 imm: 0 + 4: Mov32Imm dst: r4 imm: 0 + 5: Mov32Imm dst: r4 imm: -1 + 6: StXMemW dst: rfp src: r4 off: -28 imm: 0 + 7: Mov32Imm dst: r4 imm: -1 + 8: StXMemW dst: rfp src: r4 off: -36 imm: 0 + 9: LdXMemW dst: r4 src: rfp off: -32 imm: 0 + 10: Mov32Imm dst: r6 imm: -559038737 + 11: JEqReg dst: r4 off: -1 src: r6 + filter_block_9: + 12: Mov32Imm dst: r4 imm: 0 + 13: JaImm dst: r0 off: -1 imm: 0 + filter_block_10: + 14: Mov32Imm dst: r4 imm: 1 + 15: JaImm dst: r0 off: -1 imm: 0 + result: + 16: MovImm dst: r0 imm: 2 + 17: JEqImm dst: r4 off: -1 imm: 0 + 18: MovImm dst: r0 imm: 1 + return: + 19: Exit +=== RUN TestScratchA/kernel +=== RUN TestScratchA/C#01 +=== RUN TestJumpIfLessThan/C#01 +=== RUN TestJumpIfNotEqual/C#04 === RUN TestScratchZero/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 @@ -3003,120 +3150,50 @@ return: 14: Exit === RUN TestScratchZero/kernel ---- PASS: TestScratchZero (0.08s) - --- SKIP: TestScratchZero/C (0.08s) +--- PASS: TestScratchZero (0.04s) + --- SKIP: TestScratchZero/C (0.04s) --- SKIP: TestScratchZero/eBPF (0.00s) --- PASS: TestScratchZero/kernel (0.00s) === CONT TestLoadIndirect === RUN TestLoadIndirect/constant_valid === RUN TestLoadIndirect/constant_valid/C -=== RUN TestALUMul/eBPF#03 - ebpf_test.go:17: - 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 - 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 - filter_block_0: - 2: Mov32Imm dst: r4 imm: 4 - 3: Mov32Imm dst: r5 imm: 13 - 4: Mul32Reg dst: r4 src: r5 - 5: JEqImm dst: r4 off: -1 imm: 52 - filter_block_4: - 6: Mov32Imm dst: r4 imm: 0 - 7: JaImm dst: r0 off: -1 imm: 0 - filter_block_5: - 8: Mov32Imm dst: r4 imm: 1 - 9: JaImm dst: r0 off: -1 imm: 0 - result: - 10: MovImm dst: r0 imm: 2 - 11: JEqImm dst: r4 off: -1 imm: 0 - 12: MovImm dst: r0 imm: 1 - return: - 13: Exit -=== RUN TestALUMul/kernel#03 -=== RUN TestALUMul/C#04 -=== RUN TestScratchX/eBPF#01 -=== RUN TestMemShift/eBPF#01 +=== RUN TestJumpIfLessOrEqual/C#04 +=== RUN TestJumpIfBitsSet/eBPF#07 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: MovReg dst: r6 src: r2 - 3: AddImm dst: r6 imm: 3 - 4: JGTReg dst: r6 off: -1 src: r3 - 5: Mov32Imm dst: r4 imm: 0 - 6: LdXMemB dst: r5 src: r2 off: 2 imm: 0 - 7: And32Imm dst: r5 imm: 15 - 8: LSh32Imm dst: r5 imm: 2 - 9: JEqReg dst: r4 off: -1 src: r5 + 2: Mov32Imm dst: r4 imm: 6 + 3: Mov32Imm dst: r5 imm: 2 + 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: - 10: Mov32Imm dst: r4 imm: 0 - 11: JaImm dst: r0 off: -1 imm: 0 + 5: JSetReg dst: r4 off: -1 src: r5 + 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: - 12: Mov32Imm dst: r4 imm: 1 - 13: JaImm dst: r0 off: -1 imm: 0 - filter_nomatch: - 14: MovImm dst: r4 imm: 0 - 15: JaImm dst: r0 off: -1 imm: 0 - result: - 16: MovImm dst: r0 imm: 2 - 17: JEqImm dst: r4 off: -1 imm: 0 - 18: MovImm dst: r0 imm: 1 - return: - 19: Exit -=== RUN TestMemShift/kernel#01 ---- PASS: TestMemShift (0.13s) - --- SKIP: TestMemShift/C (0.04s) - --- SKIP: TestMemShift/eBPF (0.00s) - --- PASS: TestMemShift/kernel (0.00s) - --- SKIP: TestMemShift/C#01 (0.09s) - --- SKIP: TestMemShift/eBPF#01 (0.00s) - --- PASS: TestMemShift/kernel#01 (0.00s) -=== CONT TestLoadAbsoluteBigOffset -=== RUN TestLoadAbsoluteBigOffset/C -=== NAME TestScratchX/eBPF#01 - ebpf_test.go:17: - 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 - 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 - filter_block_0: - 2: Mov32Imm dst: r5 imm: 0 - 3: StXMemW dst: rfp src: r5 off: -32 imm: 0 - 4: Mov32Imm dst: r5 imm: 0 - 5: Mov32Imm dst: r5 imm: -1 - 6: StXMemW dst: rfp src: r5 off: -28 imm: 0 - 7: Mov32Imm dst: r5 imm: -1 - 8: StXMemW dst: rfp src: r5 off: -36 imm: 0 - 9: LdXMemW dst: r5 src: rfp off: -32 imm: 0 - 10: Mov32Reg dst: r4 src: r5 - 11: JEqImm dst: r4 off: -1 imm: 0 - filter_block_10: - 12: Mov32Imm dst: r4 imm: 0 - 13: JaImm dst: r0 off: -1 imm: 0 - filter_block_11: - 14: Mov32Imm dst: r4 imm: 1 - 15: JaImm dst: r0 off: -1 imm: 0 + 7: Mov32Imm dst: r4 imm: 1 + 8: JaImm dst: r0 off: -1 imm: 0 + filter_block_5: + 9: Mov32Imm dst: r4 imm: 0 + 10: JaImm dst: r0 off: -1 imm: 0 + filter_block_6: + 11: Mov32Imm dst: r4 imm: 1 + 12: JaImm dst: r0 off: -1 imm: 0 result: - 16: MovImm dst: r0 imm: 2 - 17: JEqImm dst: r4 off: -1 imm: 0 - 18: MovImm dst: r0 imm: 1 + 13: MovImm dst: r0 imm: 2 + 14: JEqImm dst: r4 off: -1 imm: 0 + 15: MovImm dst: r0 imm: 1 return: - 19: Exit -=== RUN TestScratchX/kernel#01 ---- PASS: TestScratchX (0.13s) - --- SKIP: TestScratchX/C (0.04s) - --- SKIP: TestScratchX/eBPF (0.00s) - --- PASS: TestScratchX/kernel (0.00s) - --- SKIP: TestScratchX/C#01 (0.08s) - --- SKIP: TestScratchX/eBPF#01 (0.01s) - --- PASS: TestScratchX/kernel#01 (0.00s) -=== CONT TestLoadAbsolute -=== RUN TestLoadAbsolute/C -=== RUN TestJumpIfGreaterThan/eBPF#06 + 16: Exit +=== RUN TestJumpIfBitsSet/kernel#07 +=== RUN TestJumpIfBitsSet/C#08 +=== RUN TestJumpIfEqual/eBPF#06 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 - 3: Mov32Imm dst: r5 imm: 23 - 4: JGTReg dst: r4 off: -1 src: r5 + 3: Mov32Imm dst: r5 imm: 21 + 4: JEqReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 @@ -3129,60 +3206,79 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestJumpIfGreaterThan/kernel#06 -=== RUN TestALUAdd/eBPF#02 +=== RUN TestJumpIfEqual/kernel#06 +=== RUN TestALUMul/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 4 - 3: Add32Imm dst: r4 imm: 13 - 4: JEqImm dst: r4 off: -1 imm: 17 - filter_block_3: - 5: Mov32Imm dst: r4 imm: 0 - 6: JaImm dst: r0 off: -1 imm: 0 + 2: Mov32Imm dst: r4 imm: 2 + 3: Mov32Imm dst: r5 imm: -2147483648 + 4: Mul32Reg dst: r4 src: r5 + 5: JEqImm dst: r4 off: -1 imm: 0 filter_block_4: - 7: Mov32Imm dst: r4 imm: 1 - 8: JaImm dst: r0 off: -1 imm: 0 + 6: Mov32Imm dst: r4 imm: 0 + 7: JaImm dst: r0 off: -1 imm: 0 + filter_block_5: + 8: Mov32Imm dst: r4 imm: 1 + 9: JaImm dst: r0 off: -1 imm: 0 result: - 9: MovImm dst: r0 imm: 2 - 10: JEqImm dst: r4 off: -1 imm: 0 - 11: MovImm dst: r0 imm: 1 + 10: MovImm dst: r0 imm: 2 + 11: JEqImm dst: r4 off: -1 imm: 0 + 12: MovImm dst: r0 imm: 1 return: - 12: Exit -=== RUN TestALUAdd/kernel#02 -=== RUN TestALUAdd/C#03 -=== RUN TestLoadConstantX/eBPF#01 + 13: Exit +=== RUN TestALUMul/kernel#05 +--- PASS: TestALUMul (0.24s) + --- SKIP: TestALUMul/C (0.05s) + --- SKIP: TestALUMul/eBPF (0.00s) + --- PASS: TestALUMul/kernel (0.00s) + --- SKIP: TestALUMul/C#01 (0.04s) + --- SKIP: TestALUMul/eBPF#01 (0.00s) + --- PASS: TestALUMul/kernel#01 (0.00s) + --- SKIP: TestALUMul/C#02 (0.04s) + --- SKIP: TestALUMul/eBPF#02 (0.00s) + --- PASS: TestALUMul/kernel#02 (0.00s) + --- SKIP: TestALUMul/C#03 (0.04s) + --- SKIP: TestALUMul/eBPF#03 (0.00s) + --- PASS: TestALUMul/kernel#03 (0.00s) + --- SKIP: TestALUMul/C#04 (0.03s) + --- SKIP: TestALUMul/eBPF#04 (0.00s) + --- PASS: TestALUMul/kernel#04 (0.00s) + --- SKIP: TestALUMul/C#05 (0.04s) + --- SKIP: TestALUMul/eBPF#05 (0.00s) + --- PASS: TestALUMul/kernel#05 (0.00s) +=== CONT TestLoadAbsoluteBigOffset +=== RUN TestLoadAbsoluteBigOffset/C +=== RUN TestJumpIfGreaterOrEqual/eBPF#08 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r5 imm: 28 - 3: Mov32Reg dst: r4 src: r5 - 4: JEqImm dst: r4 off: -1 imm: 28 + 2: Mov32Imm dst: r4 imm: 22 + 3: JGEImm dst: r4 off: -1 imm: 23 + filter_block_2: + 4: Mov32Imm dst: r4 imm: 0 + 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: - 5: Mov32Imm dst: r4 imm: 0 - 6: JaImm dst: r0 off: -1 imm: 0 - filter_block_4: - 7: Mov32Imm dst: r4 imm: 1 - 8: JaImm dst: r0 off: -1 imm: 0 + 6: Mov32Imm dst: r4 imm: 1 + 7: JaImm dst: r0 off: -1 imm: 0 result: - 9: MovImm dst: r0 imm: 2 - 10: JEqImm dst: r4 off: -1 imm: 0 - 11: MovImm dst: r0 imm: 1 + 8: MovImm dst: r0 imm: 2 + 9: JEqImm dst: r4 off: -1 imm: 0 + 10: MovImm dst: r0 imm: 1 return: - 12: Exit -=== RUN TestLoadConstantX/kernel#01 -=== RUN TestLoadConstantX/C#02 -=== RUN TestALUSub/eBPF#03 + 11: Exit +=== RUN TestJumpIfGreaterOrEqual/kernel#08 +=== RUN TestALUAdd/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 13 - 3: Mov32Imm dst: r5 imm: 9 - 4: Sub32Reg dst: r4 src: r5 - 5: JEqImm dst: r4 off: -1 imm: 4 + 2: Mov32Imm dst: r4 imm: 4 + 3: Mov32Imm dst: r5 imm: 13 + 4: Add32Reg dst: r4 src: r5 + 5: JEqImm dst: r4 off: -1 imm: 17 filter_block_4: 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 @@ -3195,22 +3291,87 @@ 12: MovImm dst: r0 imm: 1 return: 13: Exit -=== RUN TestALUSub/kernel#03 ---- PASS: TestALUSub (0.31s) - --- SKIP: TestALUSub/C (0.06s) - --- SKIP: TestALUSub/eBPF (0.00s) - --- PASS: TestALUSub/kernel (0.00s) - --- SKIP: TestALUSub/C#01 (0.08s) - --- SKIP: TestALUSub/eBPF#01 (0.00s) - --- PASS: TestALUSub/kernel#01 (0.00s) - --- SKIP: TestALUSub/C#02 (0.08s) - --- SKIP: TestALUSub/eBPF#02 (0.00s) - --- PASS: TestALUSub/kernel#02 (0.00s) - --- SKIP: TestALUSub/C#03 (0.08s) - --- SKIP: TestALUSub/eBPF#03 (0.00s) - --- PASS: TestALUSub/kernel#03 (0.00s) -=== CONT TestJumpIfBitsNotSet -=== RUN TestJumpIfBitsNotSet/C +=== RUN TestALUAdd/kernel#03 +--- PASS: TestALUAdd (0.16s) + --- SKIP: TestALUAdd/C (0.04s) + --- SKIP: TestALUAdd/eBPF (0.00s) + --- PASS: TestALUAdd/kernel (0.00s) + --- SKIP: TestALUAdd/C#01 (0.04s) + --- SKIP: TestALUAdd/eBPF#01 (0.00s) + --- PASS: TestALUAdd/kernel#01 (0.00s) + --- SKIP: TestALUAdd/C#02 (0.04s) + --- SKIP: TestALUAdd/eBPF#02 (0.00s) + --- PASS: TestALUAdd/kernel#02 (0.00s) + --- SKIP: TestALUAdd/C#03 (0.04s) + --- SKIP: TestALUAdd/eBPF#03 (0.00s) + --- PASS: TestALUAdd/kernel#03 (0.00s) +=== CONT TestJumpIfGreaterThan +=== RUN TestJumpIfGreaterThan/C +=== RUN TestJumpIfLessThan/eBPF#01 +=== RUN TestScratchA/eBPF#01 +=== NAME TestJumpIfLessThan/eBPF#01 + ebpf_test.go:17: + 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 + 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 + filter_block_0: + 2: Mov32Imm dst: r4 imm: 24 + 3: JEqImm dst: r4 off: -1 imm: 0 + filter_block_2: + 4: JLTImm dst: r4 off: -1 imm: 23 + 5: JaImm dst: r0 off: -1 imm: 0 + filter_block_3: + 6: Mov32Imm dst: r4 imm: 1 + 7: JaImm dst: r0 off: -1 imm: 0 + filter_block_4: + 8: Mov32Imm dst: r4 imm: 0 + 9: JaImm dst: r0 off: -1 imm: 0 + filter_block_5: + 10: Mov32Imm dst: r4 imm: 1 + 11: JaImm dst: r0 off: -1 imm: 0 + result: + 12: MovImm dst: r0 imm: 2 + 13: JEqImm dst: r4 off: -1 imm: 0 + 14: MovImm dst: r0 imm: 1 + return: + 15: Exit +=== RUN TestJumpIfLessThan/kernel#01 +=== NAME TestScratchA/eBPF#01 + ebpf_test.go:17: + 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 + 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 + filter_block_0: + 2: Mov32Imm dst: r4 imm: 0 + 3: StXMemW dst: rfp src: r4 off: -32 imm: 0 + 4: Mov32Imm dst: r4 imm: 0 + 5: Mov32Imm dst: r4 imm: -1 + 6: StXMemW dst: rfp src: r4 off: -28 imm: 0 + 7: Mov32Imm dst: r4 imm: -1 + 8: StXMemW dst: rfp src: r4 off: -36 imm: 0 + 9: LdXMemW dst: r4 src: rfp off: -32 imm: 0 + 10: JEqImm dst: r4 off: -1 imm: 0 + filter_block_9: + 11: Mov32Imm dst: r4 imm: 0 + 12: JaImm dst: r0 off: -1 imm: 0 + filter_block_10: + 13: Mov32Imm dst: r4 imm: 1 + 14: JaImm dst: r0 off: -1 imm: 0 + result: + 15: MovImm dst: r0 imm: 2 + 16: JEqImm dst: r4 off: -1 imm: 0 + 17: MovImm dst: r0 imm: 1 + return: + 18: Exit +=== RUN TestScratchA/kernel#01 +--- PASS: TestScratchA (0.07s) + --- SKIP: TestScratchA/C (0.03s) + --- SKIP: TestScratchA/eBPF (0.00s) + --- PASS: TestScratchA/kernel (0.00s) + --- SKIP: TestScratchA/C#01 (0.03s) + --- SKIP: TestScratchA/eBPF#01 (0.00s) + --- PASS: TestScratchA/kernel#01 (0.00s) +=== CONT TestLoadConstantA +=== RUN TestLoadConstantA/C +=== RUN TestJumpIfBitsNotSet/C#04 === RUN TestJumpIfNotEqual/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 @@ -3266,78 +3427,36 @@ 23: Exit === RUN TestLoadIndirect/constant_valid/kernel === RUN TestLoadIndirect/constant_valid/C#01 -=== RUN TestJumpIfGreaterThan/C#07 -=== RUN TestJumpIfBitsNotSet/eBPF -=== RUN TestALUDiv/eBPF#03 -=== NAME TestJumpIfBitsNotSet/eBPF +=== RUN TestLoadAbsolute/C#02 +=== RUN TestJumpIfLessOrEqual/eBPF#04 +=== RUN TestJumpIfBitsSet/eBPF#08 +=== NAME TestJumpIfLessOrEqual/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 6 - 3: JSetImm dst: r4 off: -1 imm: 4 - 4: JaImm dst: r0 off: -1 imm: 0 + 2: Mov32Imm dst: r4 imm: 23 + 3: JLEImm dst: r4 off: -1 imm: 23 filter_block_2: - 5: Mov32Imm dst: r4 imm: 0 - 6: JaImm dst: r0 off: -1 imm: 0 + 4: Mov32Imm dst: r4 imm: 0 + 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: - 7: Mov32Imm dst: r4 imm: 1 - 8: JaImm dst: r0 off: -1 imm: 0 - result: - 9: MovImm dst: r0 imm: 2 - 10: JEqImm dst: r4 off: -1 imm: 0 - 11: MovImm dst: r0 imm: 1 - return: - 12: Exit -=== RUN TestJumpIfBitsNotSet/kernel -=== NAME TestALUDiv/eBPF#03 - ebpf_test.go:17: - 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 - 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 - filter_block_0: - 2: Mov32Imm dst: r4 imm: 19 - 3: Mov32Imm dst: r5 imm: 3 - 4: JEqImm dst: r5 off: -1 imm: 0 - 5: Div32Reg dst: r4 src: r5 - 6: JEqImm dst: r4 off: -1 imm: 6 - filter_block_4: - 7: Mov32Imm dst: r4 imm: 0 - 8: JaImm dst: r0 off: -1 imm: 0 - filter_block_5: - 9: Mov32Imm dst: r4 imm: 1 - 10: JaImm dst: r0 off: -1 imm: 0 - filter_nomatch: - 11: MovImm dst: r4 imm: 0 - 12: JaImm dst: r0 off: -1 imm: 0 + 6: Mov32Imm dst: r4 imm: 1 + 7: JaImm dst: r0 off: -1 imm: 0 result: - 13: MovImm dst: r0 imm: 2 - 14: JEqImm dst: r4 off: -1 imm: 0 - 15: MovImm dst: r0 imm: 1 + 8: MovImm dst: r0 imm: 2 + 9: JEqImm dst: r4 off: -1 imm: 0 + 10: MovImm dst: r0 imm: 1 return: - 16: Exit -=== RUN TestALUDiv/kernel#03 ---- PASS: TestALUDiv (0.39s) - --- SKIP: TestALUDiv/C (0.09s) - --- SKIP: TestALUDiv/eBPF (0.00s) - --- PASS: TestALUDiv/kernel (0.00s) - --- SKIP: TestALUDiv/C#01 (0.05s) - --- SKIP: TestALUDiv/eBPF#01 (0.00s) - --- PASS: TestALUDiv/kernel#01 (0.00s) - --- SKIP: TestALUDiv/C#02 (0.08s) - --- SKIP: TestALUDiv/eBPF#02 (0.00s) - --- PASS: TestALUDiv/kernel#02 (0.00s) - --- SKIP: TestALUDiv/C#03 (0.10s) - --- SKIP: TestALUDiv/eBPF#03 (0.00s) - --- PASS: TestALUDiv/kernel#03 (0.00s) -=== CONT TestTAX -=== RUN TestTAX/C -=== RUN TestJumpIfLessThan/eBPF#04 + 11: Exit +=== RUN TestJumpIfLessOrEqual/kernel#04 +=== NAME TestJumpIfBitsSet/eBPF#08 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 23 - 3: JLTImm dst: r4 off: -1 imm: 23 + 2: Mov32Imm dst: r4 imm: 6 + 3: JSetImm dst: r4 off: -1 imm: 8 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 @@ -3350,73 +3469,44 @@ 10: MovImm dst: r0 imm: 1 return: 11: Exit -=== RUN TestJumpIfLessThan/kernel#04 -=== RUN TestJumpIfEqual/eBPF#06 +=== RUN TestJumpIfBitsSet/kernel#08 +=== RUN TestJumpIfLessOrEqual/C#05 +=== RUN TestLoadAbsoluteBigOffset/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 23 - 3: Mov32Imm dst: r5 imm: 21 - 4: JEqReg dst: r4 off: -1 src: r5 - filter_block_3: - 5: Mov32Imm dst: r4 imm: 0 - 6: JaImm dst: r0 off: -1 imm: 0 - filter_block_4: - 7: Mov32Imm dst: r4 imm: 1 - 8: JaImm dst: r0 off: -1 imm: 0 + 2: MovReg dst: r6 src: r2 + 3: AddImm dst: r6 imm: 65535 + 4: JGTReg dst: r6 off: -1 src: r3 + 5: MovReg dst: r6 src: r2 + 6: AddImm dst: r6 imm: 65534 + 7: LdXMemB dst: r4 src: r6 off: 0 imm: 0 + 8: Add32Imm dst: r4 imm: 2 + 9: Mov32Reg dst: r4 src: r4 + 10: JaImm dst: r0 off: -1 imm: 0 + filter_nomatch: + 11: MovImm dst: r4 imm: 0 + 12: JaImm dst: r0 off: -1 imm: 0 result: - 9: MovImm dst: r0 imm: 2 - 10: JEqImm dst: r4 off: -1 imm: 0 - 11: MovImm dst: r0 imm: 1 + 13: MovImm dst: r0 imm: 2 + 14: JEqImm dst: r4 off: -1 imm: 0 + 15: MovImm dst: r0 imm: 1 return: - 12: Exit -=== RUN TestJumpIfEqual/kernel#06 -=== RUN TestLoadConstantX/eBPF#02 + 16: Exit +=== RUN TestLoadAbsoluteBigOffset/kernel +=== RUN TestJumpIfBitsNotSet/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r5 imm: 0 - 3: Mov32Reg dst: r4 src: r5 - 4: JEqImm dst: r4 off: -1 imm: 0 - filter_block_3: + 2: Mov32Imm dst: r4 imm: 6 + 3: JSetImm dst: r4 off: -1 imm: 2 + 4: JaImm dst: r0 off: -1 imm: 0 + filter_block_2: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 - filter_block_4: - 7: Mov32Imm dst: r4 imm: 1 - 8: JaImm dst: r0 off: -1 imm: 0 - result: - 9: MovImm dst: r0 imm: 2 - 10: JEqImm dst: r4 off: -1 imm: 0 - 11: MovImm dst: r0 imm: 1 - return: - 12: Exit -=== RUN TestLoadConstantX/kernel#02 ---- PASS: TestLoadConstantX (0.20s) - --- SKIP: TestLoadConstantX/C (0.08s) - --- SKIP: TestLoadConstantX/eBPF (0.00s) - --- PASS: TestLoadConstantX/kernel (0.00s) - --- SKIP: TestLoadConstantX/C#01 (0.06s) - --- SKIP: TestLoadConstantX/eBPF#01 (0.00s) - --- PASS: TestLoadConstantX/kernel#01 (0.00s) - --- SKIP: TestLoadConstantX/C#02 (0.05s) - --- SKIP: TestLoadConstantX/eBPF#02 (0.00s) - --- PASS: TestLoadConstantX/kernel#02 (0.00s) -=== CONT TestTXA -=== RUN TestTXA/C -=== RUN TestALUMul/eBPF#04 - ebpf_test.go:17: - 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 - 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 - filter_block_0: - 2: Mov32Imm dst: r4 imm: 2 - 3: Mul32Imm dst: r4 imm: -2147483648 - 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: - 5: Mov32Imm dst: r4 imm: 0 - 6: JaImm dst: r0 off: -1 imm: 0 - filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: @@ -3425,122 +3515,78 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestALUAdd/eBPF#03 +=== RUN TestJumpIfBitsNotSet/kernel#04 +=== RUN TestJumpIfGreaterThan/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 4 - 3: Mov32Imm dst: r5 imm: 13 - 4: Add32Reg dst: r4 src: r5 - 5: JEqImm dst: r4 off: -1 imm: 17 - filter_block_4: - 6: Mov32Imm dst: r4 imm: 0 + 2: Mov32Imm dst: r4 imm: 24 + 3: JGTImm dst: r4 off: -1 imm: 23 + filter_block_2: + 4: Mov32Imm dst: r4 imm: 0 + 5: JaImm dst: r0 off: -1 imm: 0 + filter_block_3: + 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 - filter_block_5: - 8: Mov32Imm dst: r4 imm: 1 - 9: JaImm dst: r0 off: -1 imm: 0 result: - 10: MovImm dst: r0 imm: 2 - 11: JEqImm dst: r4 off: -1 imm: 0 - 12: MovImm dst: r0 imm: 1 + 8: MovImm dst: r0 imm: 2 + 9: JEqImm dst: r4 off: -1 imm: 0 + 10: MovImm dst: r0 imm: 1 return: - 13: Exit -=== RUN TestALUAdd/kernel#03 -=== RUN TestLoadAbsoluteBigOffset/eBPF + 11: Exit +=== RUN TestJumpIfGreaterThan/kernel +=== RUN TestJumpIfGreaterThan/C#01 +=== RUN TestJumpIfEqual/C#07 +=== RUN TestLoadConstantA/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: MovReg dst: r6 src: r2 - 3: AddImm dst: r6 imm: 65535 - 4: JGTReg dst: r6 off: -1 src: r3 - 5: MovReg dst: r6 src: r2 - 6: AddImm dst: r6 imm: 65534 - 7: LdXMemB dst: r4 src: r6 off: 0 imm: 0 - 8: Add32Imm dst: r4 imm: 2 - 9: Mov32Reg dst: r4 src: r4 - 10: JaImm dst: r0 off: -1 imm: 0 - filter_nomatch: - 11: MovImm dst: r4 imm: 0 - 12: JaImm dst: r0 off: -1 imm: 0 + 2: Mov32Imm dst: r4 imm: 1 + 3: JEqImm dst: r4 off: -1 imm: 1 + filter_block_2: + 4: Mov32Imm dst: r4 imm: 0 + 5: JaImm dst: r0 off: -1 imm: 0 + filter_block_3: + 6: Mov32Imm dst: r4 imm: 1 + 7: JaImm dst: r0 off: -1 imm: 0 result: - 13: MovImm dst: r0 imm: 2 - 14: JEqImm dst: r4 off: -1 imm: 0 - 15: MovImm dst: r0 imm: 1 + 8: MovImm dst: r0 imm: 2 + 9: JEqImm dst: r4 off: -1 imm: 0 + 10: MovImm dst: r0 imm: 1 return: - 16: Exit -=== RUN TestLoadAbsoluteBigOffset/kernel ---- PASS: TestALUAdd (0.34s) - --- SKIP: TestALUAdd/C (0.10s) - --- SKIP: TestALUAdd/eBPF (0.00s) - --- PASS: TestALUAdd/kernel (0.00s) - --- SKIP: TestALUAdd/C#01 (0.09s) - --- SKIP: TestALUAdd/eBPF#01 (0.00s) - --- PASS: TestALUAdd/kernel#01 (0.00s) - --- SKIP: TestALUAdd/C#02 (0.06s) - --- SKIP: TestALUAdd/eBPF#02 (0.00s) - --- PASS: TestALUAdd/kernel#02 (0.00s) - --- SKIP: TestALUAdd/C#03 (0.08s) - --- SKIP: TestALUAdd/eBPF#03 (0.00s) - --- PASS: TestALUAdd/kernel#03 (0.00s) -=== CONT TestRetConstant -=== RUN TestRetConstant/C -=== RUN TestALUMul/kernel#04 -=== RUN TestALUMul/C#05 -=== RUN TestLoadAbsolute/eBPF + 11: Exit +=== RUN TestLoadConstantA/kernel +=== RUN TestLoadConstantA/C#01 +=== RUN TestLoadAbsolute/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 - 3: AddImm dst: r6 imm: 3 + 3: AddImm dst: r6 imm: 4 4: JGTReg dst: r6 off: -1 src: r3 - 5: LdXMemB dst: r4 src: r2 off: 2 imm: 0 - 6: JEqImm dst: r4 off: -1 imm: 5 + 5: LdXMemH dst: r4 src: r2 off: 2 imm: 0 + 6: SwapBE dst: r4 imm: 16 + 7: JEqImm dst: r4 off: -1 imm: 57005 filter_block_2: - 7: Mov32Imm dst: r4 imm: 0 - 8: JaImm dst: r0 off: -1 imm: 0 + 8: Mov32Imm dst: r4 imm: 0 + 9: JaImm dst: r0 off: -1 imm: 0 filter_block_3: - 9: Mov32Imm dst: r4 imm: 1 - 10: JaImm dst: r0 off: -1 imm: 0 + 10: Mov32Imm dst: r4 imm: 1 + 11: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: - 11: MovImm dst: r4 imm: 0 - 12: JaImm dst: r0 off: -1 imm: 0 - result: - 13: MovImm dst: r0 imm: 2 - 14: JEqImm dst: r4 off: -1 imm: 0 - 15: MovImm dst: r0 imm: 1 - return: - 16: Exit -=== RUN TestLoadAbsolute/kernel -=== RUN TestLoadAbsolute/C#01 -=== RUN TestJumpIfEqual/C#07 -=== RUN TestJumpIfLessThan/C#05 -=== RUN TestJumpIfBitsNotSet/C#01 -=== RUN TestTAX/eBPF - ebpf_test.go:17: - 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 - 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 - filter_block_0: - 2: Mov32Imm dst: r4 imm: 1 - 3: Mov32Reg dst: r5 src: r4 - 4: Mov32Reg dst: r4 src: r5 - 5: Mov32Reg dst: r4 src: r4 - 6: JaImm dst: r0 off: -1 imm: 0 + 12: MovImm dst: r4 imm: 0 + 13: JaImm dst: r0 off: -1 imm: 0 result: - 7: MovImm dst: r0 imm: 2 - 8: JEqImm dst: r4 off: -1 imm: 0 - 9: MovImm dst: r0 imm: 1 + 14: MovImm dst: r0 imm: 2 + 15: JEqImm dst: r4 off: -1 imm: 0 + 16: MovImm dst: r0 imm: 1 return: - 10: Exit -=== RUN TestTAX/kernel ---- PASS: TestTAX (0.06s) - --- SKIP: TestTAX/C (0.06s) - --- SKIP: TestTAX/eBPF (0.00s) - --- PASS: TestTAX/kernel (0.00s) -=== CONT TestRetA -=== RUN TestRetA/C + 17: Exit +=== RUN TestLoadAbsolute/kernel#02 +=== RUN TestLoadAbsolute/C#03 === RUN TestLoadIndirect/constant_valid/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 @@ -3574,55 +3620,102 @@ return: 23: Exit === RUN TestLoadIndirect/constant_valid/kernel#01 -=== RUN TestTXA/eBPF +=== RUN TestJumpIfNotEqual/eBPF#05 +=== RUN TestJumpIfGreaterOrEqual/C#09 +=== NAME TestJumpIfNotEqual/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r5 imm: 1 - 3: Mov32Reg dst: r4 src: r5 - 4: Mov32Reg dst: r4 src: r4 - 5: JaImm dst: r0 off: -1 imm: 0 + 2: Mov32Imm dst: r4 imm: 23 + 3: JEqImm dst: r4 off: -1 imm: 0 + filter_block_2: + 4: JNEImm dst: r4 off: -1 imm: 21 + 5: JaImm dst: r0 off: -1 imm: 0 + filter_block_3: + 6: Mov32Imm dst: r4 imm: 1 + 7: JaImm dst: r0 off: -1 imm: 0 + filter_block_4: + 8: Mov32Imm dst: r4 imm: 0 + 9: JaImm dst: r0 off: -1 imm: 0 + filter_block_5: + 10: Mov32Imm dst: r4 imm: 1 + 11: JaImm dst: r0 off: -1 imm: 0 result: - 6: MovImm dst: r0 imm: 2 - 7: JEqImm dst: r4 off: -1 imm: 0 - 8: MovImm dst: r0 imm: 1 + 12: MovImm dst: r0 imm: 2 + 13: JEqImm dst: r4 off: -1 imm: 0 + 14: MovImm dst: r0 imm: 1 return: - 9: Exit -=== RUN TestTXA/kernel ---- PASS: TestTXA (0.07s) - --- SKIP: TestTXA/C (0.07s) - --- SKIP: TestTXA/eBPF (0.00s) - --- PASS: TestTXA/kernel (0.00s) -=== CONT TestJumpIfLessOrEqual -=== RUN TestJumpIfLessOrEqual/C -=== RUN TestLoadAbsoluteBigOffset/C#01 -=== RUN TestRetConstant/eBPF -=== RUN TestJumpIfGreaterThan/eBPF#07 -=== NAME TestRetConstant/eBPF + 15: Exit +=== RUN TestJumpIfNotEqual/kernel#05 +=== RUN TestJumpIfNotEqual/C#06 +=== RUN TestJumpIfLessThan/C#02 +=== RUN TestJumpIfLessOrEqual/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 1 - 3: JaImm dst: r0 off: -1 imm: 0 + 2: Mov32Imm dst: r4 imm: 23 + 3: JEqImm dst: r4 off: -1 imm: 0 + filter_block_2: + 4: JLEImm dst: r4 off: -1 imm: 23 + 5: JaImm dst: r0 off: -1 imm: 0 + filter_block_3: + 6: Mov32Imm dst: r4 imm: 1 + 7: JaImm dst: r0 off: -1 imm: 0 + filter_block_4: + 8: Mov32Imm dst: r4 imm: 0 + 9: JaImm dst: r0 off: -1 imm: 0 + filter_block_5: + 10: Mov32Imm dst: r4 imm: 1 + 11: JaImm dst: r0 off: -1 imm: 0 result: - 4: MovImm dst: r0 imm: 2 - 5: JEqImm dst: r4 off: -1 imm: 0 - 6: MovImm dst: r0 imm: 1 + 12: MovImm dst: r0 imm: 2 + 13: JEqImm dst: r4 off: -1 imm: 0 + 14: MovImm dst: r0 imm: 1 return: - 7: Exit -=== RUN TestRetConstant/kernel -=== NAME TestJumpIfGreaterThan/eBPF#07 + 15: Exit +=== RUN TestJumpIfLessOrEqual/kernel#05 +=== RUN TestJumpIfLessOrEqual/C#06 +=== RUN TestJumpIfBitsSet/C#09 +=== RUN TestJumpIfGreaterThan/eBPF#01 +=== RUN TestJumpIfEqual/eBPF#07 +=== NAME TestJumpIfGreaterThan/eBPF#01 + ebpf_test.go:17: + 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 + 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 + filter_block_0: + 2: Mov32Imm dst: r4 imm: 24 + 3: JEqImm dst: r4 off: -1 imm: 0 + filter_block_2: + 4: JGTImm dst: r4 off: -1 imm: 23 + 5: JaImm dst: r0 off: -1 imm: 0 + filter_block_3: + 6: Mov32Imm dst: r4 imm: 1 + 7: JaImm dst: r0 off: -1 imm: 0 + filter_block_4: + 8: Mov32Imm dst: r4 imm: 0 + 9: JaImm dst: r0 off: -1 imm: 0 + filter_block_5: + 10: Mov32Imm dst: r4 imm: 1 + 11: JaImm dst: r0 off: -1 imm: 0 + result: + 12: MovImm dst: r0 imm: 2 + 13: JEqImm dst: r4 off: -1 imm: 0 + 14: MovImm dst: r0 imm: 1 + return: + 15: Exit +=== RUN TestJumpIfGreaterThan/kernel#01 +=== NAME TestJumpIfEqual/eBPF#07 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 - 3: Mov32Imm dst: r5 imm: 23 + 3: Mov32Imm dst: r5 imm: 21 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: - 5: JGTReg dst: r4 off: -1 src: r5 + 5: JEqReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 @@ -3639,60 +3732,42 @@ 15: MovImm dst: r0 imm: 1 return: 16: Exit -=== RUN TestLoadAbsolute/eBPF#01 -=== RUN TestJumpIfGreaterThan/kernel#07 -=== NAME TestLoadAbsolute/eBPF#01 +=== RUN TestJumpIfEqual/kernel#07 +=== RUN TestJumpIfGreaterThan/C#02 +=== RUN TestLoadConstantA/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: MovReg dst: r6 src: r2 - 3: AddImm dst: r6 imm: 3 - 4: JGTReg dst: r6 off: -1 src: r3 - 5: LdXMemB dst: r4 src: r2 off: 2 imm: 0 - 6: JEqImm dst: r4 off: -1 imm: 6 + 2: Mov32Imm dst: r4 imm: 28 + 3: JEqImm dst: r4 off: -1 imm: 28 filter_block_2: - 7: Mov32Imm dst: r4 imm: 0 - 8: JaImm dst: r0 off: -1 imm: 0 + 4: Mov32Imm dst: r4 imm: 0 + 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: - 9: Mov32Imm dst: r4 imm: 1 - 10: JaImm dst: r0 off: -1 imm: 0 - filter_nomatch: - 11: MovImm dst: r4 imm: 0 - 12: JaImm dst: r0 off: -1 imm: 0 - result: - 13: MovImm dst: r0 imm: 2 - 14: JEqImm dst: r4 off: -1 imm: 0 - 15: MovImm dst: r0 imm: 1 - return: - 16: Exit -=== RUN TestLoadAbsolute/kernel#01 -=== RUN TestRetConstant/C#01 -=== RUN TestRetA/eBPF -=== RUN TestALUMul/eBPF#05 -=== NAME TestRetA/eBPF - ebpf_test.go:17: - 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 - 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 - filter_block_0: - 2: Mov32Imm dst: r4 imm: 1 - 3: Mov32Reg dst: r4 src: r4 - 4: JaImm dst: r0 off: -1 imm: 0 + 6: Mov32Imm dst: r4 imm: 1 + 7: JaImm dst: r0 off: -1 imm: 0 result: - 5: MovImm dst: r0 imm: 2 - 6: JEqImm dst: r4 off: -1 imm: 0 - 7: MovImm dst: r0 imm: 1 + 8: MovImm dst: r0 imm: 2 + 9: JEqImm dst: r4 off: -1 imm: 0 + 10: MovImm dst: r0 imm: 1 return: - 8: Exit -=== RUN TestJumpIfNotEqual/eBPF#05 + 11: Exit +=== RUN TestLoadConstantA/kernel#01 +=== RUN TestLoadConstantA/C#02 +=== RUN TestLoadAbsoluteBigOffset/C#01 +=== RUN TestLoadAbsolute/eBPF#03 +=== RUN TestJumpIfGreaterOrEqual/eBPF#09 +=== RUN TestJumpIfNotEqual/eBPF#06 +=== NAME TestJumpIfGreaterOrEqual/eBPF#09 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 23 + 2: Mov32Imm dst: r4 imm: 22 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: - 4: JNEImm dst: r4 off: -1 imm: 21 + 4: JGEImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 @@ -3709,114 +3784,126 @@ 14: MovImm dst: r0 imm: 1 return: 15: Exit -=== RUN TestJumpIfNotEqual/kernel#05 -=== RUN TestJumpIfNotEqual/C#06 -=== NAME TestALUMul/eBPF#05 +=== NAME TestLoadAbsolute/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 2 - 3: Mov32Imm dst: r5 imm: -2147483648 - 4: Mul32Reg dst: r4 src: r5 - 5: JEqImm dst: r4 off: -1 imm: 0 - filter_block_4: - 6: Mov32Imm dst: r4 imm: 0 - 7: JaImm dst: r0 off: -1 imm: 0 - filter_block_5: - 8: Mov32Imm dst: r4 imm: 1 + 2: MovReg dst: r6 src: r2 + 3: AddImm dst: r6 imm: 4 + 4: JGTReg dst: r6 off: -1 src: r3 + 5: LdXMemH dst: r4 src: r2 off: 2 imm: 0 + 6: SwapBE dst: r4 imm: 16 + 7: JEqImm dst: r4 off: -1 imm: 57007 + filter_block_2: + 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 + filter_block_3: + 10: Mov32Imm dst: r4 imm: 1 + 11: JaImm dst: r0 off: -1 imm: 0 + filter_nomatch: + 12: MovImm dst: r4 imm: 0 + 13: JaImm dst: r0 off: -1 imm: 0 result: - 10: MovImm dst: r0 imm: 2 - 11: JEqImm dst: r4 off: -1 imm: 0 - 12: MovImm dst: r0 imm: 1 + 14: MovImm dst: r0 imm: 2 + 15: JEqImm dst: r4 off: -1 imm: 0 + 16: MovImm dst: r0 imm: 1 return: - 13: Exit -=== RUN TestALUMul/kernel#05 ---- PASS: TestALUMul (0.50s) - --- SKIP: TestALUMul/C (0.04s) - --- SKIP: TestALUMul/eBPF (0.00s) - --- PASS: TestALUMul/kernel (0.00s) - --- SKIP: TestALUMul/C#01 (0.07s) - --- SKIP: TestALUMul/eBPF#01 (0.00s) - --- PASS: TestALUMul/kernel#01 (0.00s) - --- SKIP: TestALUMul/C#02 (0.10s) - --- SKIP: TestALUMul/eBPF#02 (0.02s) - --- PASS: TestALUMul/kernel#02 (0.00s) - --- SKIP: TestALUMul/C#03 (0.08s) - --- SKIP: TestALUMul/eBPF#03 (0.00s) - --- PASS: TestALUMul/kernel#03 (0.00s) - --- SKIP: TestALUMul/C#04 (0.11s) - --- SKIP: TestALUMul/eBPF#04 (0.00s) - --- PASS: TestALUMul/kernel#04 (0.00s) - --- SKIP: TestALUMul/C#05 (0.07s) - --- SKIP: TestALUMul/eBPF#05 (0.01s) - --- PASS: TestALUMul/kernel#05 (0.00s) -=== CONT TestJumpIfBitsSet -=== RUN TestJumpIfBitsSet/C -=== RUN TestLoadIndirect/constant_valid/C#02 -=== RUN TestRetA/kernel -=== RUN TestLoadAbsolute/C#02 ---- PASS: TestRetA (0.09s) - --- SKIP: TestRetA/C (0.05s) - --- SKIP: TestRetA/eBPF (0.01s) - --- PASS: TestRetA/kernel (0.00s) -=== CONT TestPartialZeroInitX -=== RUN TestPartialZeroInitX/C -=== RUN TestJumpIfGreaterThan/C#08 -=== RUN TestJumpIfBitsNotSet/eBPF#01 + 17: Exit +=== RUN TestLoadAbsolute/kernel#03 +=== NAME TestJumpIfNotEqual/eBPF#06 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 6 - 3: JEqImm dst: r4 off: -1 imm: 0 - filter_block_2: - 4: JSetImm dst: r4 off: -1 imm: 4 - 5: JaImm dst: r0 off: -1 imm: 0 + 2: Mov32Imm dst: r4 imm: 23 + 3: Mov32Imm dst: r5 imm: 21 + 4: JNEReg dst: r4 off: -1 src: r5 filter_block_3: - 6: Mov32Imm dst: r4 imm: 1 - 7: JaImm dst: r0 off: -1 imm: 0 + 5: Mov32Imm dst: r4 imm: 0 + 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: - 8: Mov32Imm dst: r4 imm: 0 - 9: JaImm dst: r0 off: -1 imm: 0 - filter_block_5: - 10: Mov32Imm dst: r4 imm: 1 - 11: JaImm dst: r0 off: -1 imm: 0 + 7: Mov32Imm dst: r4 imm: 1 + 8: JaImm dst: r0 off: -1 imm: 0 result: - 12: MovImm dst: r0 imm: 2 - 13: JEqImm dst: r4 off: -1 imm: 0 - 14: MovImm dst: r0 imm: 1 + 9: MovImm dst: r0 imm: 2 + 10: JEqImm dst: r4 off: -1 imm: 0 + 11: MovImm dst: r0 imm: 1 return: - 15: Exit -=== RUN TestJumpIfBitsNotSet/kernel#01 -=== RUN TestJumpIfLessThan/eBPF#05 + 12: Exit +=== RUN TestJumpIfNotEqual/kernel#06 +=== RUN TestJumpIfGreaterOrEqual/kernel#09 +=== RUN TestJumpIfNotEqual/C#07 +=== RUN TestJumpIfLessThan/eBPF#02 + ebpf_test.go:17: + 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 + 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 + filter_block_0: + 2: Mov32Imm dst: r4 imm: 24 + 3: Mov32Imm dst: r5 imm: 23 + 4: JLTReg dst: r4 off: -1 src: r5 + filter_block_3: + 5: Mov32Imm dst: r4 imm: 0 + 6: JaImm dst: r0 off: -1 imm: 0 + filter_block_4: + 7: Mov32Imm dst: r4 imm: 1 + 8: JaImm dst: r0 off: -1 imm: 0 + result: + 9: MovImm dst: r0 imm: 2 + 10: JEqImm dst: r4 off: -1 imm: 0 + 11: MovImm dst: r0 imm: 1 + return: + 12: Exit +=== RUN TestJumpIfLessThan/kernel#02 +=== RUN TestJumpIfBitsNotSet/C#05 +=== RUN TestJumpIfLessOrEqual/eBPF#06 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 - 3: JEqImm dst: r4 off: -1 imm: 0 - filter_block_2: - 4: JLTImm dst: r4 off: -1 imm: 23 - 5: JaImm dst: r0 off: -1 imm: 0 + 3: Mov32Imm dst: r5 imm: 23 + 4: JLEReg dst: r4 off: -1 src: r5 filter_block_3: - 6: Mov32Imm dst: r4 imm: 1 - 7: JaImm dst: r0 off: -1 imm: 0 + 5: Mov32Imm dst: r4 imm: 0 + 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: - 8: Mov32Imm dst: r4 imm: 0 - 9: JaImm dst: r0 off: -1 imm: 0 - filter_block_5: - 10: Mov32Imm dst: r4 imm: 1 - 11: JaImm dst: r0 off: -1 imm: 0 + 7: Mov32Imm dst: r4 imm: 1 + 8: JaImm dst: r0 off: -1 imm: 0 result: - 12: MovImm dst: r0 imm: 2 - 13: JEqImm dst: r4 off: -1 imm: 0 - 14: MovImm dst: r0 imm: 1 + 9: MovImm dst: r0 imm: 2 + 10: JEqImm dst: r4 off: -1 imm: 0 + 11: MovImm dst: r0 imm: 1 return: - 15: Exit -=== RUN TestJumpIfLessThan/kernel#05 + 12: Exit +=== RUN TestJumpIfLessOrEqual/kernel#06 +=== RUN TestJumpIfLessOrEqual/C#07 +=== RUN TestLoadIndirect/constant_valid/C#02 +=== RUN TestJumpIfGreaterThan/eBPF#02 + ebpf_test.go:17: + 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 + 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 + filter_block_0: + 2: Mov32Imm dst: r4 imm: 24 + 3: Mov32Imm dst: r5 imm: 23 + 4: JGTReg dst: r4 off: -1 src: r5 + filter_block_3: + 5: Mov32Imm dst: r4 imm: 0 + 6: JaImm dst: r0 off: -1 imm: 0 + filter_block_4: + 7: Mov32Imm dst: r4 imm: 1 + 8: JaImm dst: r0 off: -1 imm: 0 + result: + 9: MovImm dst: r0 imm: 2 + 10: JEqImm dst: r4 off: -1 imm: 0 + 11: MovImm dst: r0 imm: 1 + return: + 12: Exit +=== RUN TestJumpIfGreaterThan/kernel#02 +=== RUN TestJumpIfGreaterThan/C#03 === RUN TestLoadAbsoluteBigOffset/eBPF#01 +=== RUN TestJumpIfBitsSet/eBPF#09 +=== NAME TestLoadAbsoluteBigOffset/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 @@ -3830,27 +3917,39 @@ return: 7: Exit === RUN TestLoadAbsoluteBigOffset/kernel#01 -=== RUN TestRetConstant/eBPF#01 +=== NAME TestJumpIfBitsSet/eBPF#09 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 0 - 3: JaImm dst: r0 off: -1 imm: 0 + 2: Mov32Imm dst: r4 imm: 6 + 3: JEqImm dst: r4 off: -1 imm: 0 + filter_block_2: + 4: JSetImm dst: r4 off: -1 imm: 8 + 5: JaImm dst: r0 off: -1 imm: 0 + filter_block_3: + 6: Mov32Imm dst: r4 imm: 1 + 7: JaImm dst: r0 off: -1 imm: 0 + filter_block_4: + 8: Mov32Imm dst: r4 imm: 0 + 9: JaImm dst: r0 off: -1 imm: 0 + filter_block_5: + 10: Mov32Imm dst: r4 imm: 1 + 11: JaImm dst: r0 off: -1 imm: 0 result: - 4: MovImm dst: r0 imm: 2 - 5: JEqImm dst: r4 off: -1 imm: 0 - 6: MovImm dst: r0 imm: 1 + 12: MovImm dst: r0 imm: 2 + 13: JEqImm dst: r4 off: -1 imm: 0 + 14: MovImm dst: r0 imm: 1 return: - 7: Exit -=== RUN TestRetConstant/kernel#01 -=== RUN TestJumpIfBitsSet/eBPF + 15: Exit +=== RUN TestJumpIfBitsSet/kernel#09 +=== RUN TestLoadConstantA/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 6 - 3: JSetImm dst: r4 off: -1 imm: 4 + 2: Mov32Imm dst: r4 imm: 0 + 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 @@ -3863,9 +3962,20 @@ 10: MovImm dst: r0 imm: 1 return: 11: Exit -=== RUN TestJumpIfBitsSet/kernel -=== RUN TestJumpIfBitsSet/C#01 -=== RUN TestJumpIfEqual/eBPF#07 +=== RUN TestLoadConstantA/kernel#02 +--- PASS: TestLoadConstantA (0.11s) + --- SKIP: TestLoadConstantA/C (0.04s) + --- SKIP: TestLoadConstantA/eBPF (0.00s) + --- PASS: TestLoadConstantA/kernel (0.00s) + --- SKIP: TestLoadConstantA/C#01 (0.03s) + --- SKIP: TestLoadConstantA/eBPF#01 (0.00s) + --- PASS: TestLoadConstantA/kernel#01 (0.00s) + --- SKIP: TestLoadConstantA/C#02 (0.03s) + --- SKIP: TestLoadConstantA/eBPF#02 (0.00s) + --- PASS: TestLoadConstantA/kernel#02 (0.00s) +=== CONT TestLoadConstantX +=== RUN TestLoadConstantX/C +=== RUN TestJumpIfNotEqual/eBPF#07 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 @@ -3874,7 +3984,7 @@ 3: Mov32Imm dst: r5 imm: 21 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: - 5: JEqReg dst: r4 off: -1 src: r5 + 5: JNEReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 @@ -3891,61 +4001,118 @@ 15: MovImm dst: r0 imm: 1 return: 16: Exit -=== RUN TestJumpIfEqual/kernel#07 -=== RUN TestJumpIfNotEqual/eBPF#06 +=== RUN TestJumpIfNotEqual/kernel#07 +--- PASS: TestJumpIfNotEqual (0.55s) + --- SKIP: TestJumpIfNotEqual/C (0.06s) + --- SKIP: TestJumpIfNotEqual/eBPF (0.00s) + --- PASS: TestJumpIfNotEqual/kernel (0.05s) + --- SKIP: TestJumpIfNotEqual/C#01 (0.05s) + --- SKIP: TestJumpIfNotEqual/eBPF#01 (0.00s) + --- PASS: TestJumpIfNotEqual/kernel#01 (0.05s) + --- SKIP: TestJumpIfNotEqual/C#02 (0.05s) + --- SKIP: TestJumpIfNotEqual/eBPF#02 (0.00s) + --- PASS: TestJumpIfNotEqual/kernel#02 (0.05s) + --- SKIP: TestJumpIfNotEqual/C#03 (0.04s) + --- SKIP: TestJumpIfNotEqual/eBPF#03 (0.00s) + --- PASS: TestJumpIfNotEqual/kernel#03 (0.05s) + --- SKIP: TestJumpIfNotEqual/C#04 (0.04s) + --- SKIP: TestJumpIfNotEqual/eBPF#04 (0.00s) + --- PASS: TestJumpIfNotEqual/kernel#04 (0.00s) + --- SKIP: TestJumpIfNotEqual/C#05 (0.04s) + --- SKIP: TestJumpIfNotEqual/eBPF#05 (0.00s) + --- PASS: TestJumpIfNotEqual/kernel#05 (0.00s) + --- SKIP: TestJumpIfNotEqual/C#06 (0.04s) + --- SKIP: TestJumpIfNotEqual/eBPF#06 (0.00s) + --- PASS: TestJumpIfNotEqual/kernel#06 (0.00s) + --- SKIP: TestJumpIfNotEqual/C#07 (0.04s) + --- SKIP: TestJumpIfNotEqual/eBPF#07 (0.00s) + --- PASS: TestJumpIfNotEqual/kernel#07 (0.00s) +=== CONT TestPartialZeroInitX +=== RUN TestPartialZeroInitX/C +=== RUN TestJumpIfBitsNotSet/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 23 - 3: Mov32Imm dst: r5 imm: 21 - 4: JNEReg dst: r4 off: -1 src: r5 + 2: Mov32Imm dst: r4 imm: 6 + 3: JEqImm dst: r4 off: -1 imm: 0 + filter_block_2: + 4: JSetImm dst: r4 off: -1 imm: 2 + 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: - 5: Mov32Imm dst: r4 imm: 0 - 6: JaImm dst: r0 off: -1 imm: 0 + 6: Mov32Imm dst: r4 imm: 1 + 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: - 7: Mov32Imm dst: r4 imm: 1 - 8: JaImm dst: r0 off: -1 imm: 0 + 8: Mov32Imm dst: r4 imm: 0 + 9: JaImm dst: r0 off: -1 imm: 0 + filter_block_5: + 10: Mov32Imm dst: r4 imm: 1 + 11: JaImm dst: r0 off: -1 imm: 0 result: - 9: MovImm dst: r0 imm: 2 - 10: JEqImm dst: r4 off: -1 imm: 0 - 11: MovImm dst: r0 imm: 1 + 12: MovImm dst: r0 imm: 2 + 13: JEqImm dst: r4 off: -1 imm: 0 + 14: MovImm dst: r0 imm: 1 return: - 12: Exit -=== RUN TestJumpIfNotEqual/kernel#06 -=== RUN TestJumpIfNotEqual/C#07 -=== RUN TestJumpIfLessOrEqual/eBPF + 15: Exit +=== RUN TestJumpIfBitsNotSet/kernel#05 +--- PASS: TestJumpIfEqual (0.55s) + --- SKIP: TestJumpIfEqual/C (0.06s) + --- SKIP: TestJumpIfEqual/eBPF (0.00s) + --- PASS: TestJumpIfEqual/kernel (0.00s) + --- SKIP: TestJumpIfEqual/C#01 (0.05s) + --- SKIP: TestJumpIfEqual/eBPF#01 (0.00s) + --- PASS: TestJumpIfEqual/kernel#01 (0.00s) + --- SKIP: TestJumpIfEqual/C#02 (0.04s) + --- SKIP: TestJumpIfEqual/eBPF#02 (0.00s) + --- PASS: TestJumpIfEqual/kernel#02 (0.00s) + --- SKIP: TestJumpIfEqual/C#03 (0.04s) + --- SKIP: TestJumpIfEqual/eBPF#03 (0.00s) + --- PASS: TestJumpIfEqual/kernel#03 (0.00s) + --- SKIP: TestJumpIfEqual/C#04 (0.05s) + --- SKIP: TestJumpIfEqual/eBPF#04 (0.00s) + --- PASS: TestJumpIfEqual/kernel#04 (0.05s) + --- SKIP: TestJumpIfEqual/C#05 (0.04s) + --- SKIP: TestJumpIfEqual/eBPF#05 (0.00s) + --- PASS: TestJumpIfEqual/kernel#05 (0.05s) + --- SKIP: TestJumpIfEqual/C#06 (0.04s) + --- SKIP: TestJumpIfEqual/eBPF#06 (0.00s) + --- PASS: TestJumpIfEqual/kernel#06 (0.05s) + --- SKIP: TestJumpIfEqual/C#07 (0.03s) + --- SKIP: TestJumpIfEqual/eBPF#07 (0.00s) + --- PASS: TestJumpIfEqual/kernel#07 (0.05s) +=== RUN TestJumpIfLessOrEqual/eBPF#07 +=== CONT TestALUMod +=== RUN TestALUMod/C +=== NAME TestJumpIfLessOrEqual/eBPF#07 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 24 - 3: JLEImm dst: r4 off: -1 imm: 23 - filter_block_2: - 4: Mov32Imm dst: r4 imm: 0 - 5: JaImm dst: r0 off: -1 imm: 0 + 2: Mov32Imm dst: r4 imm: 23 + 3: Mov32Imm dst: r5 imm: 23 + 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: - 6: Mov32Imm dst: r4 imm: 1 - 7: JaImm dst: r0 off: -1 imm: 0 + 5: JLEReg dst: r4 off: -1 src: r5 + 6: JaImm dst: r0 off: -1 imm: 0 + filter_block_4: + 7: Mov32Imm dst: r4 imm: 1 + 8: JaImm dst: r0 off: -1 imm: 0 + filter_block_5: + 9: Mov32Imm dst: r4 imm: 0 + 10: JaImm dst: r0 off: -1 imm: 0 + filter_block_6: + 11: Mov32Imm dst: r4 imm: 1 + 12: JaImm dst: r0 off: -1 imm: 0 result: - 8: MovImm dst: r0 imm: 2 - 9: JEqImm dst: r4 off: -1 imm: 0 - 10: MovImm dst: r0 imm: 1 + 13: MovImm dst: r0 imm: 2 + 14: JEqImm dst: r4 off: -1 imm: 0 + 15: MovImm dst: r0 imm: 1 return: - 11: Exit -=== RUN TestJumpIfLessOrEqual/kernel -=== RUN TestJumpIfLessThan/C#06 -=== RUN TestJumpIfBitsNotSet/C#02 ---- PASS: TestRetConstant (0.17s) - --- SKIP: TestRetConstant/C (0.06s) - --- SKIP: TestRetConstant/eBPF (0.00s) - --- PASS: TestRetConstant/kernel (0.00s) - --- SKIP: TestRetConstant/C#01 (0.06s) - --- SKIP: TestRetConstant/eBPF#01 (0.00s) - --- PASS: TestRetConstant/kernel#01 (0.05s) -=== CONT TestLoadConstantA -=== RUN TestLoadConstantA/C -=== RUN TestLoadAbsoluteBigOffset/C#02 + 16: Exit +=== RUN TestJumpIfLessOrEqual/kernel#07 +=== RUN TestJumpIfLessOrEqual/C#08 +=== RUN TestJumpIfGreaterOrEqual/C#10 +=== RUN TestLoadAbsolute/C#04 === RUN TestLoadIndirect/constant_valid/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 @@ -3980,110 +4147,82 @@ return: 24: Exit === RUN TestLoadIndirect/constant_valid/kernel#02 +=== RUN TestJumpIfLessThan/C#03 === RUN TestLoadIndirect/constant_valid/C#03 -=== RUN TestLoadAbsolute/eBPF#02 +=== RUN TestJumpIfGreaterThan/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: MovReg dst: r6 src: r2 - 3: AddImm dst: r6 imm: 4 - 4: JGTReg dst: r6 off: -1 src: r3 - 5: LdXMemH dst: r4 src: r2 off: 2 imm: 0 - 6: SwapBE dst: r4 imm: 16 - 7: JEqImm dst: r4 off: -1 imm: 57005 - filter_block_2: - 8: Mov32Imm dst: r4 imm: 0 - 9: JaImm dst: r0 off: -1 imm: 0 + 2: Mov32Imm dst: r4 imm: 24 + 3: Mov32Imm dst: r5 imm: 23 + 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: - 10: Mov32Imm dst: r4 imm: 1 - 11: JaImm dst: r0 off: -1 imm: 0 - filter_nomatch: - 12: MovImm dst: r4 imm: 0 - 13: JaImm dst: r0 off: -1 imm: 0 + 5: JGTReg dst: r4 off: -1 src: r5 + 6: JaImm dst: r0 off: -1 imm: 0 + filter_block_4: + 7: Mov32Imm dst: r4 imm: 1 + 8: JaImm dst: r0 off: -1 imm: 0 + filter_block_5: + 9: Mov32Imm dst: r4 imm: 0 + 10: JaImm dst: r0 off: -1 imm: 0 + filter_block_6: + 11: Mov32Imm dst: r4 imm: 1 + 12: JaImm dst: r0 off: -1 imm: 0 result: - 14: MovImm dst: r0 imm: 2 - 15: JEqImm dst: r4 off: -1 imm: 0 - 16: MovImm dst: r0 imm: 1 + 13: MovImm dst: r0 imm: 2 + 14: JEqImm dst: r4 off: -1 imm: 0 + 15: MovImm dst: r0 imm: 1 return: - 17: Exit -=== RUN TestLoadAbsolute/kernel#02 -=== RUN TestLoadAbsolute/C#03 -=== RUN TestJumpIfGreaterThan/eBPF#08 + 16: Exit +=== RUN TestJumpIfGreaterThan/kernel#03 +=== RUN TestJumpIfGreaterThan/C#04 +=== RUN TestLoadConstantX/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 22 - 3: JGTImm dst: r4 off: -1 imm: 23 - filter_block_2: - 4: Mov32Imm dst: r4 imm: 0 - 5: JaImm dst: r0 off: -1 imm: 0 + 2: Mov32Imm dst: r5 imm: 1 + 3: Mov32Reg dst: r4 src: r5 + 4: JEqImm dst: r4 off: -1 imm: 1 filter_block_3: - 6: Mov32Imm dst: r4 imm: 1 - 7: JaImm dst: r0 off: -1 imm: 0 + 5: Mov32Imm dst: r4 imm: 0 + 6: JaImm dst: r0 off: -1 imm: 0 + filter_block_4: + 7: Mov32Imm dst: r4 imm: 1 + 8: JaImm dst: r0 off: -1 imm: 0 result: - 8: MovImm dst: r0 imm: 2 - 9: JEqImm dst: r4 off: -1 imm: 0 - 10: MovImm dst: r0 imm: 1 + 9: MovImm dst: r0 imm: 2 + 10: JEqImm dst: r4 off: -1 imm: 0 + 11: MovImm dst: r0 imm: 1 return: - 11: Exit -=== RUN TestJumpIfGreaterThan/kernel#08 -=== RUN TestJumpIfBitsSet/eBPF#01 + 12: Exit +=== RUN TestLoadConstantX/kernel +=== RUN TestLoadConstantX/C#01 +=== RUN TestALUMod/eBPF +=== RUN TestLoadAbsoluteBigOffset/C#02 +=== RUN TestJumpIfBitsSet/C#10 +=== NAME TestALUMod/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 6 - 3: JEqImm dst: r4 off: -1 imm: 0 - filter_block_2: - 4: JSetImm dst: r4 off: -1 imm: 4 - 5: JaImm dst: r0 off: -1 imm: 0 + 2: Mov32Imm dst: r4 imm: 16 + 3: Mod32Imm dst: r4 imm: 4 + 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: - 6: Mov32Imm dst: r4 imm: 1 - 7: JaImm dst: r0 off: -1 imm: 0 + 5: Mov32Imm dst: r4 imm: 0 + 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: - 8: Mov32Imm dst: r4 imm: 0 - 9: JaImm dst: r0 off: -1 imm: 0 - filter_block_5: - 10: Mov32Imm dst: r4 imm: 1 - 11: JaImm dst: r0 off: -1 imm: 0 + 7: Mov32Imm dst: r4 imm: 1 + 8: JaImm dst: r0 off: -1 imm: 0 result: - 12: MovImm dst: r0 imm: 2 - 13: JEqImm dst: r4 off: -1 imm: 0 - 14: MovImm dst: r0 imm: 1 + 9: MovImm dst: r0 imm: 2 + 10: JEqImm dst: r4 off: -1 imm: 0 + 11: MovImm dst: r0 imm: 1 return: - 15: Exit -=== RUN TestJumpIfBitsSet/kernel#01 -=== RUN TestJumpIfBitsSet/C#02 ---- PASS: TestJumpIfEqual (0.93s) - --- SKIP: TestJumpIfEqual/C (0.07s) - --- SKIP: TestJumpIfEqual/eBPF (0.00s) - --- PASS: TestJumpIfEqual/kernel (0.00s) - --- SKIP: TestJumpIfEqual/C#01 (0.10s) - --- SKIP: TestJumpIfEqual/eBPF#01 (0.00s) - --- PASS: TestJumpIfEqual/kernel#01 (0.00s) - --- SKIP: TestJumpIfEqual/C#02 (0.05s) - --- SKIP: TestJumpIfEqual/eBPF#02 (0.00s) - --- PASS: TestJumpIfEqual/kernel#02 (0.00s) - --- SKIP: TestJumpIfEqual/C#03 (0.04s) - --- SKIP: TestJumpIfEqual/eBPF#03 (0.01s) - --- PASS: TestJumpIfEqual/kernel#03 (0.00s) - --- SKIP: TestJumpIfEqual/C#04 (0.04s) - --- SKIP: TestJumpIfEqual/eBPF#04 (0.00s) - --- PASS: TestJumpIfEqual/kernel#04 (0.07s) - --- SKIP: TestJumpIfEqual/C#05 (0.09s) - --- SKIP: TestJumpIfEqual/eBPF#05 (0.00s) - --- PASS: TestJumpIfEqual/kernel#05 (0.05s) - --- SKIP: TestJumpIfEqual/C#06 (0.10s) - --- SKIP: TestJumpIfEqual/eBPF#06 (0.00s) - --- PASS: TestJumpIfEqual/kernel#06 (0.05s) - --- SKIP: TestJumpIfEqual/C#07 (0.12s) - --- SKIP: TestJumpIfEqual/eBPF#07 (0.00s) - --- PASS: TestJumpIfEqual/kernel#07 (0.05s) -=== CONT TestJumpIfGreaterOrEqual -=== RUN TestJumpIfGreaterOrEqual/C -=== RUN TestJumpIfLessOrEqual/C#01 + 12: Exit +=== RUN TestALUMod/kernel === RUN TestPartialZeroInitX/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 @@ -4111,14 +4250,69 @@ return: 17: Exit === RUN TestPartialZeroInitX/kernel -=== RUN TestJumpIfLessThan/eBPF#06 +=== RUN TestALUMod/C#01 +=== RUN TestJumpIfLessOrEqual/eBPF#08 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 23 + 2: Mov32Imm dst: r4 imm: 22 + 3: JLEImm dst: r4 off: -1 imm: 23 + filter_block_2: + 4: Mov32Imm dst: r4 imm: 0 + 5: JaImm dst: r0 off: -1 imm: 0 + filter_block_3: + 6: Mov32Imm dst: r4 imm: 1 + 7: JaImm dst: r0 off: -1 imm: 0 + result: + 8: MovImm dst: r0 imm: 2 + 9: JEqImm dst: r4 off: -1 imm: 0 + 10: MovImm dst: r0 imm: 1 + return: + 11: Exit +=== RUN TestJumpIfLessOrEqual/kernel#08 +=== RUN TestJumpIfGreaterThan/eBPF#04 +=== RUN TestJumpIfBitsNotSet/C#06 +=== RUN TestJumpIfLessThan/eBPF#03 +=== RUN TestLoadIndirect/constant_valid/eBPF#03 +=== RUN TestJumpIfGreaterOrEqual/eBPF#10 +=== NAME TestJumpIfLessThan/eBPF#03 + ebpf_test.go:17: + 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 + 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 + filter_block_0: + 2: Mov32Imm dst: r4 imm: 24 3: Mov32Imm dst: r5 imm: 23 - 4: JLTReg dst: r4 off: -1 src: r5 + 4: JEqImm dst: r4 off: -1 imm: 0 + filter_block_3: + 5: JLTReg dst: r4 off: -1 src: r5 + 6: JaImm dst: r0 off: -1 imm: 0 + filter_block_4: + 7: Mov32Imm dst: r4 imm: 1 + 8: JaImm dst: r0 off: -1 imm: 0 + filter_block_5: + 9: Mov32Imm dst: r4 imm: 0 + 10: JaImm dst: r0 off: -1 imm: 0 + filter_block_6: + 11: Mov32Imm dst: r4 imm: 1 + 12: JaImm dst: r0 off: -1 imm: 0 + result: + 13: MovImm dst: r0 imm: 2 + 14: JEqImm dst: r4 off: -1 imm: 0 + 15: MovImm dst: r0 imm: 1 + return: + 16: Exit +=== RUN TestJumpIfLessOrEqual/C#09 +=== RUN TestJumpIfLessThan/kernel#03 +=== RUN TestLoadAbsolute/eBPF#04 +=== NAME TestJumpIfGreaterOrEqual/eBPF#10 + ebpf_test.go:17: + 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 + 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 + filter_block_0: + 2: Mov32Imm dst: r4 imm: 22 + 3: Mov32Imm dst: r5 imm: 23 + 4: JGEReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 @@ -4131,8 +4325,8 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestJumpIfLessThan/kernel#06 -=== RUN TestLoadIndirect/constant_valid/eBPF#03 +=== RUN TestJumpIfGreaterOrEqual/kernel#10 +=== NAME TestLoadIndirect/constant_valid/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 @@ -4166,50 +4360,98 @@ return: 24: Exit === RUN TestLoadIndirect/constant_valid/kernel#03 -=== RUN TestLoadAbsoluteBigOffset/eBPF#02 +=== NAME TestLoadAbsolute/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 - 3: AddImm dst: r6 imm: 65535 + 3: AddImm dst: r6 imm: 6 4: JGTReg dst: r6 off: -1 src: r3 - 5: MovReg dst: r6 src: r2 - 6: AddImm dst: r6 imm: 65533 - 7: LdXMemH dst: r4 src: r6 off: 0 imm: 0 - 8: SwapBE dst: r4 imm: 16 - 9: Add32Imm dst: r4 imm: 2 - 10: Mov32Reg dst: r4 src: r4 - 11: JaImm dst: r0 off: -1 imm: 0 + 5: LdXMemW dst: r4 src: r2 off: 2 imm: 0 + 6: SwapBE dst: r4 imm: 32 + 7: Mov32Imm dst: r6 imm: -559038737 + 8: JEqReg dst: r4 off: -1 src: r6 + filter_block_2: + 9: Mov32Imm dst: r4 imm: 0 + 10: JaImm dst: r0 off: -1 imm: 0 + filter_block_3: + 11: Mov32Imm dst: r4 imm: 1 + 12: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: - 12: MovImm dst: r4 imm: 0 - 13: JaImm dst: r0 off: -1 imm: 0 + 13: MovImm dst: r4 imm: 0 + 14: JaImm dst: r0 off: -1 imm: 0 result: - 14: MovImm dst: r0 imm: 2 - 15: JEqImm dst: r4 off: -1 imm: 0 - 16: MovImm dst: r0 imm: 1 + 15: MovImm dst: r0 imm: 2 + 16: JEqImm dst: r4 off: -1 imm: 0 + 17: MovImm dst: r0 imm: 1 return: - 17: Exit -=== RUN TestLoadAbsoluteBigOffset/kernel#02 -=== RUN TestJumpIfNotEqual/eBPF#07 + 18: Exit +=== RUN TestLoadAbsolute/kernel#04 +=== NAME TestJumpIfGreaterThan/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 23 - 3: Mov32Imm dst: r5 imm: 21 - 4: JEqImm dst: r4 off: -1 imm: 0 + 3: JGTImm dst: r4 off: -1 imm: 23 + filter_block_2: + 4: Mov32Imm dst: r4 imm: 0 + 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: - 5: JNEReg dst: r4 off: -1 src: r5 - 6: JaImm dst: r0 off: -1 imm: 0 + 6: Mov32Imm dst: r4 imm: 1 + 7: JaImm dst: r0 off: -1 imm: 0 + result: + 8: MovImm dst: r0 imm: 2 + 9: JEqImm dst: r4 off: -1 imm: 0 + 10: MovImm dst: r0 imm: 1 + return: + 11: Exit +=== RUN TestJumpIfGreaterThan/kernel#04 +=== RUN TestLoadAbsolute/C#05 +=== RUN TestLoadConstantX/eBPF#01 + ebpf_test.go:17: + 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 + 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 + filter_block_0: + 2: Mov32Imm dst: r5 imm: 28 + 3: Mov32Reg dst: r4 src: r5 + 4: JEqImm dst: r4 off: -1 imm: 28 + filter_block_3: + 5: Mov32Imm dst: r4 imm: 0 + 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 + result: + 9: MovImm dst: r0 imm: 2 + 10: JEqImm dst: r4 off: -1 imm: 0 + 11: MovImm dst: r0 imm: 1 + return: + 12: Exit +=== RUN TestLoadConstantX/kernel#01 +=== RUN TestLoadConstantX/C#02 +=== RUN TestALUMod/eBPF#01 +=== RUN TestJumpIfBitsSet/eBPF#10 +=== RUN TestLoadAbsoluteBigOffset/eBPF#02 +=== NAME TestALUMod/eBPF#01 + ebpf_test.go:17: + 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 + 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 + filter_block_0: + 2: Mov32Imm dst: r4 imm: 16 + 3: Mov32Imm dst: r5 imm: 4 + 4: JEqImm dst: r5 off: -1 imm: 0 + 5: Mod32Reg dst: r4 src: r5 + 6: JEqImm dst: r4 off: -1 imm: 0 + filter_block_4: + 7: Mov32Imm dst: r4 imm: 0 + 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: - 9: Mov32Imm dst: r4 imm: 0 + 9: Mov32Imm dst: r4 imm: 1 10: JaImm dst: r0 off: -1 imm: 0 - filter_block_6: - 11: Mov32Imm dst: r4 imm: 1 + filter_nomatch: + 11: MovImm dst: r4 imm: 0 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 @@ -4217,74 +4459,43 @@ 15: MovImm dst: r0 imm: 1 return: 16: Exit -=== RUN TestJumpIfNotEqual/kernel#07 ---- PASS: TestJumpIfNotEqual (0.99s) - --- SKIP: TestJumpIfNotEqual/C (0.04s) - --- SKIP: TestJumpIfNotEqual/eBPF (0.00s) - --- PASS: TestJumpIfNotEqual/kernel (0.07s) - --- SKIP: TestJumpIfNotEqual/C#01 (0.09s) - --- SKIP: TestJumpIfNotEqual/eBPF#01 (0.00s) - --- PASS: TestJumpIfNotEqual/kernel#01 (0.07s) - --- SKIP: TestJumpIfNotEqual/C#02 (0.04s) - --- SKIP: TestJumpIfNotEqual/eBPF#02 (0.00s) - --- PASS: TestJumpIfNotEqual/kernel#02 (0.05s) - --- SKIP: TestJumpIfNotEqual/C#03 (0.06s) - --- SKIP: TestJumpIfNotEqual/eBPF#03 (0.02s) - --- PASS: TestJumpIfNotEqual/kernel#03 (0.05s) - --- SKIP: TestJumpIfNotEqual/C#04 (0.14s) - --- SKIP: TestJumpIfNotEqual/eBPF#04 (0.00s) - --- PASS: TestJumpIfNotEqual/kernel#04 (0.00s) - --- SKIP: TestJumpIfNotEqual/C#05 (0.10s) - --- SKIP: TestJumpIfNotEqual/eBPF#05 (0.00s) - --- PASS: TestJumpIfNotEqual/kernel#05 (0.00s) - --- SKIP: TestJumpIfNotEqual/C#06 (0.08s) - --- SKIP: TestJumpIfNotEqual/eBPF#06 (0.00s) - --- PASS: TestJumpIfNotEqual/kernel#06 (0.00s) - --- SKIP: TestJumpIfNotEqual/C#07 (0.09s) - --- SKIP: TestJumpIfNotEqual/eBPF#07 (0.00s) - --- PASS: TestJumpIfNotEqual/kernel#07 (0.00s) -=== CONT TestZeroInitX -=== RUN TestZeroInitX/C -=== RUN TestJumpIfBitsNotSet/eBPF#02 +=== NAME TestJumpIfBitsSet/eBPF#10 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 - 3: Mov32Imm dst: r5 imm: 4 - 4: JSetReg dst: r4 off: -1 src: r5 - 5: JaImm dst: r0 off: -1 imm: 0 + 3: Mov32Imm dst: r5 imm: 8 + 4: JSetReg dst: r4 off: -1 src: r5 filter_block_3: - 6: Mov32Imm dst: r4 imm: 0 - 7: JaImm dst: r0 off: -1 imm: 0 + 5: Mov32Imm dst: r4 imm: 0 + 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: - 8: Mov32Imm dst: r4 imm: 1 - 9: JaImm dst: r0 off: -1 imm: 0 + 7: Mov32Imm dst: r4 imm: 1 + 8: JaImm dst: r0 off: -1 imm: 0 result: - 10: MovImm dst: r0 imm: 2 - 11: JEqImm dst: r4 off: -1 imm: 0 - 12: MovImm dst: r0 imm: 1 + 9: MovImm dst: r0 imm: 2 + 10: JEqImm dst: r4 off: -1 imm: 0 + 11: MovImm dst: r0 imm: 1 return: - 13: Exit -=== RUN TestJumpIfBitsNotSet/kernel#02 -=== RUN TestLoadAbsolute/eBPF#03 -=== RUN TestJumpIfGreaterThan/C#09 -=== NAME TestLoadAbsolute/eBPF#03 + 12: Exit +=== RUN TestALUMod/kernel#01 +=== RUN TestJumpIfBitsSet/kernel#10 +=== RUN TestALUMod/C#02 +=== NAME TestLoadAbsoluteBigOffset/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 - 3: AddImm dst: r6 imm: 4 + 3: AddImm dst: r6 imm: 65535 4: JGTReg dst: r6 off: -1 src: r3 - 5: LdXMemH dst: r4 src: r2 off: 2 imm: 0 - 6: SwapBE dst: r4 imm: 16 - 7: JEqImm dst: r4 off: -1 imm: 57007 - filter_block_2: - 8: Mov32Imm dst: r4 imm: 0 - 9: JaImm dst: r0 off: -1 imm: 0 - filter_block_3: - 10: Mov32Imm dst: r4 imm: 1 + 5: MovReg dst: r6 src: r2 + 6: AddImm dst: r6 imm: 65533 + 7: LdXMemH dst: r4 src: r6 off: 0 imm: 0 + 8: SwapBE dst: r4 imm: 16 + 9: Add32Imm dst: r4 imm: 2 + 10: Mov32Reg dst: r4 src: r4 11: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: 12: MovImm dst: r4 imm: 0 @@ -4295,58 +4506,69 @@ 16: MovImm dst: r0 imm: 1 return: 17: Exit -=== RUN TestLoadAbsolute/kernel#03 -=== RUN TestLoadConstantA/eBPF +=== RUN TestLoadAbsoluteBigOffset/kernel#02 +=== RUN TestPartialZeroInitX/C#01 +=== RUN TestJumpIfBitsNotSet/eBPF#06 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 1 - 3: JEqImm dst: r4 off: -1 imm: 1 - filter_block_2: - 4: Mov32Imm dst: r4 imm: 0 - 5: JaImm dst: r0 off: -1 imm: 0 + 2: Mov32Imm dst: r4 imm: 6 + 3: Mov32Imm dst: r5 imm: 2 + 4: JSetReg dst: r4 off: -1 src: r5 + 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: - 6: Mov32Imm dst: r4 imm: 1 + 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 + filter_block_4: + 8: Mov32Imm dst: r4 imm: 1 + 9: JaImm dst: r0 off: -1 imm: 0 result: - 8: MovImm dst: r0 imm: 2 - 9: JEqImm dst: r4 off: -1 imm: 0 - 10: MovImm dst: r0 imm: 1 + 10: MovImm dst: r0 imm: 2 + 11: JEqImm dst: r4 off: -1 imm: 0 + 12: MovImm dst: r0 imm: 1 return: - 11: Exit -=== RUN TestLoadConstantA/kernel -=== RUN TestLoadConstantA/C#01 -=== RUN TestPartialZeroInitX/C#01 -=== RUN TestJumpIfGreaterOrEqual/eBPF + 13: Exit +=== RUN TestJumpIfBitsNotSet/kernel#06 +=== RUN TestLoadConstantX/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 24 - 3: JGEImm dst: r4 off: -1 imm: 23 - filter_block_2: - 4: Mov32Imm dst: r4 imm: 0 - 5: JaImm dst: r0 off: -1 imm: 0 + 2: Mov32Imm dst: r5 imm: 0 + 3: Mov32Reg dst: r4 src: r5 + 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: - 6: Mov32Imm dst: r4 imm: 1 - 7: JaImm dst: r0 off: -1 imm: 0 + 5: Mov32Imm dst: r4 imm: 0 + 6: JaImm dst: r0 off: -1 imm: 0 + filter_block_4: + 7: Mov32Imm dst: r4 imm: 1 + 8: JaImm dst: r0 off: -1 imm: 0 result: - 8: MovImm dst: r0 imm: 2 - 9: JEqImm dst: r4 off: -1 imm: 0 - 10: MovImm dst: r0 imm: 1 + 9: MovImm dst: r0 imm: 2 + 10: JEqImm dst: r4 off: -1 imm: 0 + 11: MovImm dst: r0 imm: 1 return: - 11: Exit -=== RUN TestJumpIfGreaterOrEqual/kernel -=== RUN TestJumpIfGreaterOrEqual/C#01 -=== RUN TestLoadIndirect/constant_valid/C#04 -=== RUN TestJumpIfLessThan/C#07 -=== RUN TestJumpIfLessOrEqual/eBPF#01 + 12: Exit +=== RUN TestLoadConstantX/kernel#02 +--- PASS: TestLoadConstantX (0.10s) + --- SKIP: TestLoadConstantX/C (0.03s) + --- SKIP: TestLoadConstantX/eBPF (0.00s) + --- PASS: TestLoadConstantX/kernel (0.00s) + --- SKIP: TestLoadConstantX/C#01 (0.03s) + --- SKIP: TestLoadConstantX/eBPF#01 (0.00s) + --- PASS: TestLoadConstantX/kernel#01 (0.00s) + --- SKIP: TestLoadConstantX/C#02 (0.03s) + --- SKIP: TestLoadConstantX/eBPF#02 (0.00s) + --- PASS: TestLoadConstantX/kernel#02 (0.00s) +=== CONT TestJump0 +=== RUN TestJump0/C +=== RUN TestJumpIfLessOrEqual/eBPF#09 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 24 + 2: Mov32Imm dst: r4 imm: 22 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JLEImm dst: r4 off: -1 imm: 23 @@ -4366,31 +4588,48 @@ 14: MovImm dst: r0 imm: 1 return: 15: Exit -=== RUN TestJumpIfLessOrEqual/kernel#01 -=== RUN TestZeroInitX/eBPF +=== RUN TestJumpIfLessOrEqual/kernel#09 +=== RUN TestJumpIfLessOrEqual/C#10 +=== RUN TestLoadAbsolute/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r5 imm: 0 - 3: Mov32Reg dst: r4 src: r5 - 4: Mov32Reg dst: r4 src: r4 - 5: JaImm dst: r0 off: -1 imm: 0 + 2: MovReg dst: r6 src: r2 + 3: AddImm dst: r6 imm: 6 + 4: JGTReg dst: r6 off: -1 src: r3 + 5: LdXMemW dst: r4 src: r2 off: 2 imm: 0 + 6: SwapBE dst: r4 imm: 32 + 7: Mov32Imm dst: r6 imm: -558907665 + 8: JEqReg dst: r4 off: -1 src: r6 + filter_block_2: + 9: Mov32Imm dst: r4 imm: 0 + 10: JaImm dst: r0 off: -1 imm: 0 + filter_block_3: + 11: Mov32Imm dst: r4 imm: 1 + 12: JaImm dst: r0 off: -1 imm: 0 + filter_nomatch: + 13: MovImm dst: r4 imm: 0 + 14: JaImm dst: r0 off: -1 imm: 0 result: - 6: MovImm dst: r0 imm: 2 - 7: JEqImm dst: r4 off: -1 imm: 0 - 8: MovImm dst: r0 imm: 1 + 15: MovImm dst: r0 imm: 2 + 16: JEqImm dst: r4 off: -1 imm: 0 + 17: MovImm dst: r0 imm: 1 return: - 9: Exit -=== RUN TestZeroInitX/kernel -=== RUN TestJumpIfBitsSet/eBPF#02 + 18: Exit +=== RUN TestLoadAbsolute/kernel#05 +=== RUN TestLoadIndirect/constant_valid/C#04 +=== RUN TestJumpIfGreaterOrEqual/C#11 +=== RUN TestJumpIfGreaterThan/C#05 +=== RUN TestJumpIfLessThan/C#04 +=== RUN TestALUMod/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 6 - 3: Mov32Imm dst: r5 imm: 4 - 4: JSetReg dst: r4 off: -1 src: r5 + 2: Mov32Imm dst: r4 imm: 17 + 3: Mod32Imm dst: r4 imm: 4 + 4: JEqImm dst: r4 off: -1 imm: 1 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 @@ -4403,9 +4642,58 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestJumpIfBitsSet/kernel#02 -=== RUN TestJumpIfBitsSet/C#03 -=== RUN TestLoadAbsolute/C#04 +=== RUN TestALUMod/kernel#02 +=== RUN TestALUMod/C#03 +=== RUN TestJumpIfLessOrEqual/eBPF#10 + ebpf_test.go:17: + 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 + 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 + filter_block_0: + 2: Mov32Imm dst: r4 imm: 22 + 3: Mov32Imm dst: r5 imm: 23 + 4: JLEReg dst: r4 off: -1 src: r5 + filter_block_3: + 5: Mov32Imm dst: r4 imm: 0 + 6: JaImm dst: r0 off: -1 imm: 0 + filter_block_4: + 7: Mov32Imm dst: r4 imm: 1 + 8: JaImm dst: r0 off: -1 imm: 0 + result: + 9: MovImm dst: r0 imm: 2 + 10: JEqImm dst: r4 off: -1 imm: 0 + 11: MovImm dst: r0 imm: 1 + return: + 12: Exit +=== RUN TestJumpIfLessOrEqual/kernel#10 +=== RUN TestJumpIfBitsSet/C#11 +=== RUN TestJumpIfLessOrEqual/C#11 +=== RUN TestJump0/eBPF + ebpf_test.go:17: + 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 + 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 + filter_block_0: + 2: MovReg dst: r6 src: r2 + 3: AddImm dst: r6 imm: 1 + 4: JGTReg dst: r6 off: -1 src: r3 + 5: Mov32Imm dst: r5 imm: 0 + 6: LdXMemB dst: r4 src: r2 off: 0 imm: 0 + 7: JaImm dst: r0 off: -1 imm: 0 + filter_block_3: + 8: JEqReg dst: r4 off: -1 src: r5 + filter_block_4: + 9: Mov32Reg dst: r4 src: r4 + 10: JaImm dst: r0 off: -1 imm: 0 + filter_nomatch: + 11: MovImm dst: r4 imm: 0 + 12: JaImm dst: r0 off: -1 imm: 0 + result: + 13: MovImm dst: r0 imm: 2 + 14: JEqImm dst: r4 off: -1 imm: 0 + 15: MovImm dst: r0 imm: 1 + return: + 16: Exit +=== RUN TestJump0/kernel +=== RUN TestLoadAbsoluteBigOffset/C#03 === RUN TestPartialZeroInitX/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 @@ -4433,21 +4721,42 @@ return: 17: Exit === RUN TestPartialZeroInitX/kernel#01 ---- PASS: TestPartialZeroInitX (0.21s) - --- SKIP: TestPartialZeroInitX/C (0.11s) +--- PASS: TestPartialZeroInitX (0.13s) + --- SKIP: TestPartialZeroInitX/C (0.04s) --- SKIP: TestPartialZeroInitX/eBPF (0.00s) --- PASS: TestPartialZeroInitX/kernel (0.05s) - --- SKIP: TestPartialZeroInitX/C#01 (0.05s) + --- SKIP: TestPartialZeroInitX/C#01 (0.04s) --- SKIP: TestPartialZeroInitX/eBPF#01 (0.00s) --- PASS: TestPartialZeroInitX/kernel#01 (0.00s) -=== RUN TestLoadAbsoluteBigOffset/C#03 -=== RUN TestJumpIfBitsNotSet/C#03 -=== RUN TestJumpIfGreaterThan/eBPF#09 +=== CONT TestJump +=== RUN TestJump/C +=== RUN TestJumpIfBitsNotSet/C#07 +=== RUN TestJumpIfGreaterThan/eBPF#05 +--- PASS: TestLoadAbsolute (0.39s) + --- SKIP: TestLoadAbsolute/C (0.04s) + --- SKIP: TestLoadAbsolute/eBPF (0.00s) + --- PASS: TestLoadAbsolute/kernel (0.00s) + --- SKIP: TestLoadAbsolute/C#01 (0.04s) + --- SKIP: TestLoadAbsolute/eBPF#01 (0.00s) + --- PASS: TestLoadAbsolute/kernel#01 (0.05s) + --- SKIP: TestLoadAbsolute/C#02 (0.04s) + --- SKIP: TestLoadAbsolute/eBPF#02 (0.00s) + --- PASS: TestLoadAbsolute/kernel#02 (0.00s) + --- SKIP: TestLoadAbsolute/C#03 (0.04s) + --- SKIP: TestLoadAbsolute/eBPF#03 (0.00s) + --- PASS: TestLoadAbsolute/kernel#03 (0.05s) + --- SKIP: TestLoadAbsolute/C#04 (0.04s) + --- SKIP: TestLoadAbsolute/eBPF#04 (0.00s) + --- PASS: TestLoadAbsolute/kernel#04 (0.00s) + --- SKIP: TestLoadAbsolute/C#05 (0.04s) + --- SKIP: TestLoadAbsolute/eBPF#05 (0.00s) + --- PASS: TestLoadAbsolute/kernel#05 (0.05s) +=== NAME TestJumpIfGreaterThan/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 22 + 2: Mov32Imm dst: r4 imm: 23 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: 4: JGTImm dst: r4 off: -1 imm: 23 @@ -4467,76 +4776,18 @@ 14: MovImm dst: r0 imm: 1 return: 15: Exit -=== RUN TestJumpIfGreaterThan/kernel#09 -=== RUN TestJumpIfBitsSet/eBPF#03 - ebpf_test.go:17: - 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 - 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 - filter_block_0: - 2: Mov32Imm dst: r4 imm: 6 - 3: Mov32Imm dst: r5 imm: 4 - 4: JEqImm dst: r4 off: -1 imm: 0 - filter_block_3: - 5: JSetReg dst: r4 off: -1 src: r5 - 6: JaImm dst: r0 off: -1 imm: 0 - filter_block_4: - 7: Mov32Imm dst: r4 imm: 1 - 8: JaImm dst: r0 off: -1 imm: 0 - filter_block_5: - 9: Mov32Imm dst: r4 imm: 0 - 10: JaImm dst: r0 off: -1 imm: 0 - filter_block_6: - 11: Mov32Imm dst: r4 imm: 1 - 12: JaImm dst: r0 off: -1 imm: 0 - result: - 13: MovImm dst: r0 imm: 2 - 14: JEqImm dst: r4 off: -1 imm: 0 - 15: MovImm dst: r0 imm: 1 - return: - 16: Exit -=== RUN TestJumpIfBitsSet/kernel#03 -=== RUN TestJumpIfBitsSet/C#04 -=== RUN TestJumpIfGreaterOrEqual/eBPF#01 - ebpf_test.go:17: - 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 - 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 - filter_block_0: - 2: Mov32Imm dst: r4 imm: 24 - 3: JEqImm dst: r4 off: -1 imm: 0 - filter_block_2: - 4: JGEImm dst: r4 off: -1 imm: 23 - 5: JaImm dst: r0 off: -1 imm: 0 - filter_block_3: - 6: Mov32Imm dst: r4 imm: 1 - 7: JaImm dst: r0 off: -1 imm: 0 - filter_block_4: - 8: Mov32Imm dst: r4 imm: 0 - 9: JaImm dst: r0 off: -1 imm: 0 - filter_block_5: - 10: Mov32Imm dst: r4 imm: 1 - 11: JaImm dst: r0 off: -1 imm: 0 - result: - 12: MovImm dst: r0 imm: 2 - 13: JEqImm dst: r4 off: -1 imm: 0 - 14: MovImm dst: r0 imm: 1 - return: - 15: Exit -=== RUN TestJumpIfGreaterOrEqual/kernel#01 -=== RUN TestJumpIfLessOrEqual/C#02 ---- PASS: TestZeroInitX (0.11s) - --- SKIP: TestZeroInitX/C (0.06s) - --- SKIP: TestZeroInitX/eBPF (0.00s) - --- PASS: TestZeroInitX/kernel (0.05s) -=== RUN TestJumpIfGreaterOrEqual/C#02 -=== RUN TestLoadConstantA/eBPF#01 -=== RUN TestJumpIfGreaterThan/C#10 -=== NAME TestLoadConstantA/eBPF#01 +=== RUN TestJumpIfGreaterThan/kernel#05 +=== CONT TestNegateA +=== RUN TestNegateA/C +=== RUN TestJumpIfLessThan/eBPF#04 +=== RUN TestJumpIfGreaterOrEqual/eBPF#11 +=== NAME TestJumpIfLessThan/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 28 - 3: JEqImm dst: r4 off: -1 imm: 28 + 2: Mov32Imm dst: r4 imm: 23 + 3: JLTImm dst: r4 off: -1 imm: 23 filter_block_2: 4: Mov32Imm dst: r4 imm: 0 5: JaImm dst: r0 off: -1 imm: 0 @@ -4549,47 +4800,17 @@ 10: MovImm dst: r0 imm: 1 return: 11: Exit -=== RUN TestLoadConstantA/kernel#01 -=== RUN TestLoadConstantA/C#02 -=== RUN TestJumpIfBitsNotSet/eBPF#03 - ebpf_test.go:17: - 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 - 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 - filter_block_0: - 2: Mov32Imm dst: r4 imm: 6 - 3: Mov32Imm dst: r5 imm: 4 - 4: JEqImm dst: r4 off: -1 imm: 0 - filter_block_3: - 5: JSetReg dst: r4 off: -1 src: r5 - 6: JaImm dst: r0 off: -1 imm: 0 - filter_block_4: - 7: Mov32Imm dst: r4 imm: 1 - 8: JaImm dst: r0 off: -1 imm: 0 - filter_block_5: - 9: Mov32Imm dst: r4 imm: 0 - 10: JaImm dst: r0 off: -1 imm: 0 - filter_block_6: - 11: Mov32Imm dst: r4 imm: 1 - 12: JaImm dst: r0 off: -1 imm: 0 - result: - 13: MovImm dst: r0 imm: 2 - 14: JEqImm dst: r4 off: -1 imm: 0 - 15: MovImm dst: r0 imm: 1 - return: - 16: Exit -=== RUN TestJumpIfBitsNotSet/kernel#03 -=== RUN TestJumpIfLessThan/eBPF#07 -=== RUN TestLoadIndirect/constant_valid/eBPF#04 -=== NAME TestJumpIfLessThan/eBPF#07 +=== RUN TestJumpIfLessThan/kernel#04 +=== NAME TestJumpIfGreaterOrEqual/eBPF#11 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 23 + 2: Mov32Imm dst: r4 imm: 22 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: - 5: JLTReg dst: r4 off: -1 src: r5 + 5: JGEReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 @@ -4606,8 +4827,8 @@ 15: MovImm dst: r0 imm: 1 return: 16: Exit -=== RUN TestJumpIfLessThan/kernel#07 -=== NAME TestLoadIndirect/constant_valid/eBPF#04 +=== RUN TestJumpIfGreaterOrEqual/kernel#11 +=== RUN TestLoadIndirect/constant_valid/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 @@ -4643,146 +4864,233 @@ 25: Exit === RUN TestLoadIndirect/constant_valid/kernel#04 === RUN TestLoadIndirect/constant_valid/C#05 -=== RUN TestLoadAbsoluteBigOffset/eBPF#03 +=== RUN TestALUMod/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 0 - 3: JaImm dst: r0 off: -1 imm: 0 + 2: Mov32Imm dst: r4 imm: 17 + 3: Mov32Imm dst: r5 imm: 4 + 4: JEqImm dst: r5 off: -1 imm: 0 + 5: Mod32Reg dst: r4 src: r5 + 6: JEqImm dst: r4 off: -1 imm: 1 + filter_block_4: + 7: Mov32Imm dst: r4 imm: 0 + 8: JaImm dst: r0 off: -1 imm: 0 + filter_block_5: + 9: Mov32Imm dst: r4 imm: 1 + 10: JaImm dst: r0 off: -1 imm: 0 + filter_nomatch: + 11: MovImm dst: r4 imm: 0 + 12: JaImm dst: r0 off: -1 imm: 0 result: - 4: MovImm dst: r0 imm: 2 - 5: JEqImm dst: r4 off: -1 imm: 0 - 6: MovImm dst: r0 imm: 1 + 13: MovImm dst: r0 imm: 2 + 14: JEqImm dst: r4 off: -1 imm: 0 + 15: MovImm dst: r0 imm: 1 return: - 7: Exit -=== RUN TestLoadAbsoluteBigOffset/kernel#03 -=== RUN TestJumpIfBitsSet/eBPF#04 + 16: Exit +=== RUN TestALUMod/kernel#03 +--- PASS: TestALUMod (0.14s) + --- SKIP: TestALUMod/C (0.03s) + --- SKIP: TestALUMod/eBPF (0.00s) + --- PASS: TestALUMod/kernel (0.00s) + --- SKIP: TestALUMod/C#01 (0.04s) + --- SKIP: TestALUMod/eBPF#01 (0.00s) + --- PASS: TestALUMod/kernel#01 (0.00s) + --- SKIP: TestALUMod/C#02 (0.04s) + --- SKIP: TestALUMod/eBPF#02 (0.00s) + --- PASS: TestALUMod/kernel#02 (0.00s) + --- SKIP: TestALUMod/C#03 (0.03s) + --- SKIP: TestALUMod/eBPF#03 (0.00s) + --- PASS: TestALUMod/kernel#03 (0.00s) +=== CONT TestALUXor +=== RUN TestALUXor/C +=== RUN TestJumpIfBitsSet/eBPF#11 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 - 3: JSetImm dst: r4 off: -1 imm: 2 - filter_block_2: - 4: Mov32Imm dst: r4 imm: 0 - 5: JaImm dst: r0 off: -1 imm: 0 + 3: Mov32Imm dst: r5 imm: 8 + 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: - 6: Mov32Imm dst: r4 imm: 1 - 7: JaImm dst: r0 off: -1 imm: 0 + 5: JSetReg dst: r4 off: -1 src: r5 + 6: JaImm dst: r0 off: -1 imm: 0 + filter_block_4: + 7: Mov32Imm dst: r4 imm: 1 + 8: JaImm dst: r0 off: -1 imm: 0 + filter_block_5: + 9: Mov32Imm dst: r4 imm: 0 + 10: JaImm dst: r0 off: -1 imm: 0 + filter_block_6: + 11: Mov32Imm dst: r4 imm: 1 + 12: JaImm dst: r0 off: -1 imm: 0 result: - 8: MovImm dst: r0 imm: 2 - 9: JEqImm dst: r4 off: -1 imm: 0 - 10: MovImm dst: r0 imm: 1 + 13: MovImm dst: r0 imm: 2 + 14: JEqImm dst: r4 off: -1 imm: 0 + 15: MovImm dst: r0 imm: 1 return: - 11: Exit -=== RUN TestJumpIfBitsSet/kernel#04 -=== RUN TestJumpIfLessOrEqual/eBPF#02 -=== RUN TestJumpIfBitsSet/C#05 -=== NAME TestJumpIfLessOrEqual/eBPF#02 + 16: Exit +=== RUN TestJumpIfBitsSet/kernel#11 +=== RUN TestLoadAbsoluteBigOffset/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 24 + 2: Mov32Imm dst: r4 imm: 0 + 3: JaImm dst: r0 off: -1 imm: 0 + result: + 4: MovImm dst: r0 imm: 2 + 5: JEqImm dst: r4 off: -1 imm: 0 + 6: MovImm dst: r0 imm: 1 + return: + 7: Exit +=== RUN TestLoadAbsoluteBigOffset/kernel#03 +=== RUN TestJumpIfLessOrEqual/eBPF#11 + ebpf_test.go:17: + 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 + 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 + filter_block_0: + 2: Mov32Imm dst: r4 imm: 22 3: Mov32Imm dst: r5 imm: 23 - 4: JLEReg dst: r4 off: -1 src: r5 + 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: - 5: Mov32Imm dst: r4 imm: 0 - 6: JaImm dst: r0 off: -1 imm: 0 + 5: JLEReg dst: r4 off: -1 src: r5 + 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 + filter_block_5: + 9: Mov32Imm dst: r4 imm: 0 + 10: JaImm dst: r0 off: -1 imm: 0 + filter_block_6: + 11: Mov32Imm dst: r4 imm: 1 + 12: JaImm dst: r0 off: -1 imm: 0 result: - 9: MovImm dst: r0 imm: 2 - 10: JEqImm dst: r4 off: -1 imm: 0 - 11: MovImm dst: r0 imm: 1 + 13: MovImm dst: r0 imm: 2 + 14: JEqImm dst: r4 off: -1 imm: 0 + 15: MovImm dst: r0 imm: 1 return: - 12: Exit -=== RUN TestJumpIfLessOrEqual/kernel#02 -=== RUN TestLoadAbsolute/eBPF#04 + 16: Exit +=== RUN TestJumpIfLessOrEqual/kernel#11 +=== RUN TestJump/eBPF +--- PASS: TestJumpIfLessOrEqual (0.72s) + --- SKIP: TestJumpIfLessOrEqual/C (0.06s) + --- SKIP: TestJumpIfLessOrEqual/eBPF (0.00s) + --- PASS: TestJumpIfLessOrEqual/kernel (0.05s) + --- SKIP: TestJumpIfLessOrEqual/C#01 (0.05s) + --- SKIP: TestJumpIfLessOrEqual/eBPF#01 (0.00s) + --- PASS: TestJumpIfLessOrEqual/kernel#01 (0.06s) + --- SKIP: TestJumpIfLessOrEqual/C#02 (0.05s) + --- SKIP: TestJumpIfLessOrEqual/eBPF#02 (0.00s) + --- PASS: TestJumpIfLessOrEqual/kernel#02 (0.05s) + --- SKIP: TestJumpIfLessOrEqual/C#03 (0.04s) + --- SKIP: TestJumpIfLessOrEqual/eBPF#03 (0.00s) + --- PASS: TestJumpIfLessOrEqual/kernel#03 (0.05s) + --- SKIP: TestJumpIfLessOrEqual/C#04 (0.04s) + --- SKIP: TestJumpIfLessOrEqual/eBPF#04 (0.00s) + --- PASS: TestJumpIfLessOrEqual/kernel#04 (0.00s) + --- SKIP: TestJumpIfLessOrEqual/C#05 (0.03s) + --- SKIP: TestJumpIfLessOrEqual/eBPF#05 (0.00s) + --- PASS: TestJumpIfLessOrEqual/kernel#05 (0.00s) + --- SKIP: TestJumpIfLessOrEqual/C#06 (0.03s) + --- SKIP: TestJumpIfLessOrEqual/eBPF#06 (0.00s) + --- PASS: TestJumpIfLessOrEqual/kernel#06 (0.00s) + --- SKIP: TestJumpIfLessOrEqual/C#07 (0.03s) + --- SKIP: TestJumpIfLessOrEqual/eBPF#07 (0.00s) + --- PASS: TestJumpIfLessOrEqual/kernel#07 (0.00s) + --- SKIP: TestJumpIfLessOrEqual/C#08 (0.04s) + --- SKIP: TestJumpIfLessOrEqual/eBPF#08 (0.00s) + --- PASS: TestJumpIfLessOrEqual/kernel#08 (0.00s) + --- SKIP: TestJumpIfLessOrEqual/C#09 (0.04s) + --- SKIP: TestJumpIfLessOrEqual/eBPF#09 (0.00s) + --- PASS: TestJumpIfLessOrEqual/kernel#09 (0.00s) + --- SKIP: TestJumpIfLessOrEqual/C#10 (0.03s) + --- SKIP: TestJumpIfLessOrEqual/eBPF#10 (0.00s) + --- PASS: TestJumpIfLessOrEqual/kernel#10 (0.00s) + --- SKIP: TestJumpIfLessOrEqual/C#11 (0.05s) + --- SKIP: TestJumpIfLessOrEqual/eBPF#11 (0.00s) + --- PASS: TestJumpIfLessOrEqual/kernel#11 (0.00s) +=== CONT TestALUShiftLeft +=== RUN TestALUShiftLeft/C +=== NAME TestJump/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: MovReg dst: r6 src: r2 - 3: AddImm dst: r6 imm: 6 + 3: AddImm dst: r6 imm: 1 4: JGTReg dst: r6 off: -1 src: r3 - 5: LdXMemW dst: r4 src: r2 off: 2 imm: 0 - 6: SwapBE dst: r4 imm: 32 - 7: Mov32Imm dst: r6 imm: -559038737 - 8: JEqReg dst: r4 off: -1 src: r6 + 5: LdXMemB dst: r4 src: r2 off: 0 imm: 0 + 6: JEqImm dst: r4 off: -1 imm: 1 filter_block_2: - 9: Mov32Imm dst: r4 imm: 0 - 10: JaImm dst: r0 off: -1 imm: 0 + 7: JaImm dst: r0 off: -1 imm: 0 filter_block_3: - 11: Mov32Imm dst: r4 imm: 1 - 12: JaImm dst: r0 off: -1 imm: 0 + 8: Mov32Imm dst: r4 imm: 1 + filter_block_4: + 9: Mov32Reg dst: r4 src: r4 + 10: JaImm dst: r0 off: -1 imm: 0 filter_nomatch: - 13: MovImm dst: r4 imm: 0 - 14: JaImm dst: r0 off: -1 imm: 0 + 11: MovImm dst: r4 imm: 0 + 12: JaImm dst: r0 off: -1 imm: 0 result: - 15: MovImm dst: r0 imm: 2 - 16: JEqImm dst: r4 off: -1 imm: 0 - 17: MovImm dst: r0 imm: 1 + 13: MovImm dst: r0 imm: 2 + 14: JEqImm dst: r4 off: -1 imm: 0 + 15: MovImm dst: r0 imm: 1 return: - 18: Exit -=== RUN TestLoadAbsolute/kernel#04 -=== RUN TestLoadAbsolute/C#05 -=== RUN TestJumpIfGreaterOrEqual/eBPF#02 + 16: Exit +=== RUN TestJump/kernel +=== RUN TestNegateA/eBPF +=== RUN TestJump0/C#01 +=== NAME TestNegateA/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 24 - 3: Mov32Imm dst: r5 imm: 23 - 4: JGEReg dst: r4 off: -1 src: r5 + 2: Mov32Imm dst: r4 imm: 26 + 3: Neg32Imm dst: r4 imm: 0 + 4: Mov32Imm dst: r6 imm: -2147483622 + 5: JEqReg dst: r4 off: -1 src: r6 filter_block_3: - 5: Mov32Imm dst: r4 imm: 0 - 6: JaImm dst: r0 off: -1 imm: 0 + 6: Mov32Imm dst: r4 imm: 0 + 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: - 7: Mov32Imm dst: r4 imm: 1 - 8: JaImm dst: r0 off: -1 imm: 0 + 8: Mov32Imm dst: r4 imm: 1 + 9: JaImm dst: r0 off: -1 imm: 0 result: - 9: MovImm dst: r0 imm: 2 - 10: JEqImm dst: r4 off: -1 imm: 0 - 11: MovImm dst: r0 imm: 1 + 10: MovImm dst: r0 imm: 2 + 11: JEqImm dst: r4 off: -1 imm: 0 + 12: MovImm dst: r0 imm: 1 return: - 12: Exit -=== RUN TestJumpIfGreaterOrEqual/kernel#02 -=== RUN TestJumpIfGreaterOrEqual/C#03 -=== RUN TestJumpIfBitsNotSet/C#04 -=== RUN TestLoadConstantA/eBPF#02 + 13: Exit +=== RUN TestNegateA/kernel +=== RUN TestJumpIfBitsNotSet/eBPF#07 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 0 - 3: JEqImm dst: r4 off: -1 imm: 0 - filter_block_2: - 4: Mov32Imm dst: r4 imm: 0 - 5: JaImm dst: r0 off: -1 imm: 0 + 2: Mov32Imm dst: r4 imm: 6 + 3: Mov32Imm dst: r5 imm: 2 + 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: - 6: Mov32Imm dst: r4 imm: 1 - 7: JaImm dst: r0 off: -1 imm: 0 + 5: JSetReg dst: r4 off: -1 src: r5 + 6: JaImm dst: r0 off: -1 imm: 0 + filter_block_4: + 7: Mov32Imm dst: r4 imm: 1 + 8: JaImm dst: r0 off: -1 imm: 0 + filter_block_5: + 9: Mov32Imm dst: r4 imm: 0 + 10: JaImm dst: r0 off: -1 imm: 0 + filter_block_6: + 11: Mov32Imm dst: r4 imm: 1 + 12: JaImm dst: r0 off: -1 imm: 0 result: - 8: MovImm dst: r0 imm: 2 - 9: JEqImm dst: r4 off: -1 imm: 0 - 10: MovImm dst: r0 imm: 1 + 13: MovImm dst: r0 imm: 2 + 14: JEqImm dst: r4 off: -1 imm: 0 + 15: MovImm dst: r0 imm: 1 return: - 11: Exit -=== RUN TestLoadConstantA/kernel#02 ---- PASS: TestLoadConstantA (0.28s) - --- SKIP: TestLoadConstantA/C (0.10s) - --- SKIP: TestLoadConstantA/eBPF (0.00s) - --- PASS: TestLoadConstantA/kernel (0.00s) - --- SKIP: TestLoadConstantA/C#01 (0.10s) - --- SKIP: TestLoadConstantA/eBPF#01 (0.00s) - --- PASS: TestLoadConstantA/kernel#01 (0.00s) - --- SKIP: TestLoadConstantA/C#02 (0.06s) - --- SKIP: TestLoadConstantA/eBPF#02 (0.00s) - --- PASS: TestLoadConstantA/kernel#02 (0.00s) -=== RUN TestJumpIfLessThan/C#08 + 16: Exit +=== RUN TestJumpIfBitsNotSet/kernel#07 === RUN TestLoadIndirect/constant_valid/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 @@ -4818,14 +5126,14 @@ return: 25: Exit === RUN TestLoadIndirect/constant_valid/kernel#05 -=== RUN TestJumpIfGreaterThan/eBPF#10 +=== RUN TestALUXor/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 22 - 3: Mov32Imm dst: r5 imm: 23 - 4: JGTReg dst: r4 off: -1 src: r5 + 2: Mov32Imm dst: r4 imm: 1 + 3: Xor32Imm dst: r4 imm: 1 + 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 @@ -4838,56 +5146,89 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestJumpIfGreaterThan/kernel#10 -=== RUN TestJumpIfBitsSet/eBPF#05 -=== RUN TestLoadAbsoluteBigOffset/C#04 -=== RUN TestJumpIfLessOrEqual/C#03 -=== NAME TestJumpIfBitsSet/eBPF#05 +=== RUN TestALUXor/kernel +=== RUN TestALUXor/C#01 +=== RUN TestJumpIfGreaterThan/C#06 +--- PASS: TestJumpIfGreaterOrEqual (0.74s) + --- SKIP: TestJumpIfGreaterOrEqual/C (0.06s) + --- SKIP: TestJumpIfGreaterOrEqual/eBPF (0.00s) + --- PASS: TestJumpIfGreaterOrEqual/kernel (0.00s) + --- SKIP: TestJumpIfGreaterOrEqual/C#01 (0.07s) + --- SKIP: TestJumpIfGreaterOrEqual/eBPF#01 (0.00s) + --- PASS: TestJumpIfGreaterOrEqual/kernel#01 (0.00s) + --- SKIP: TestJumpIfGreaterOrEqual/C#02 (0.05s) + --- SKIP: TestJumpIfGreaterOrEqual/eBPF#02 (0.00s) + --- PASS: TestJumpIfGreaterOrEqual/kernel#02 (0.00s) + --- SKIP: TestJumpIfGreaterOrEqual/C#03 (0.06s) + --- SKIP: TestJumpIfGreaterOrEqual/eBPF#03 (0.00s) + --- PASS: TestJumpIfGreaterOrEqual/kernel#03 (0.00s) + --- SKIP: TestJumpIfGreaterOrEqual/C#04 (0.04s) + --- SKIP: TestJumpIfGreaterOrEqual/eBPF#04 (0.00s) + --- PASS: TestJumpIfGreaterOrEqual/kernel#04 (0.00s) + --- SKIP: TestJumpIfGreaterOrEqual/C#05 (0.04s) + --- SKIP: TestJumpIfGreaterOrEqual/eBPF#05 (0.00s) + --- PASS: TestJumpIfGreaterOrEqual/kernel#05 (0.00s) + --- SKIP: TestJumpIfGreaterOrEqual/C#06 (0.04s) + --- SKIP: TestJumpIfGreaterOrEqual/eBPF#06 (0.00s) + --- PASS: TestJumpIfGreaterOrEqual/kernel#06 (0.00s) + --- SKIP: TestJumpIfGreaterOrEqual/C#07 (0.04s) + --- SKIP: TestJumpIfGreaterOrEqual/eBPF#07 (0.00s) + --- PASS: TestJumpIfGreaterOrEqual/kernel#07 (0.00s) + --- SKIP: TestJumpIfGreaterOrEqual/C#08 (0.04s) + --- SKIP: TestJumpIfGreaterOrEqual/eBPF#08 (0.00s) + --- PASS: TestJumpIfGreaterOrEqual/kernel#08 (0.05s) + --- SKIP: TestJumpIfGreaterOrEqual/C#09 (0.04s) + --- SKIP: TestJumpIfGreaterOrEqual/eBPF#09 (0.00s) + --- PASS: TestJumpIfGreaterOrEqual/kernel#09 (0.05s) + --- SKIP: TestJumpIfGreaterOrEqual/C#10 (0.04s) + --- SKIP: TestJumpIfGreaterOrEqual/eBPF#10 (0.00s) + --- PASS: TestJumpIfGreaterOrEqual/kernel#10 (0.05s) + --- SKIP: TestJumpIfGreaterOrEqual/C#11 (0.04s) + --- SKIP: TestJumpIfGreaterOrEqual/eBPF#11 (0.00s) + --- PASS: TestJumpIfGreaterOrEqual/kernel#11 (0.05s) +=== RUN TestJumpIfLessThan/C#05 +=== CONT TestALUShiftRight +=== RUN TestALUShiftRight/C +=== RUN TestALUShiftLeft/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 6 - 3: JEqImm dst: r4 off: -1 imm: 0 - filter_block_2: - 4: JSetImm dst: r4 off: -1 imm: 2 - 5: JaImm dst: r0 off: -1 imm: 0 + 2: Mov32Imm dst: r4 imm: 1 + 3: LSh32Imm dst: r4 imm: 0 + 4: JEqImm dst: r4 off: -1 imm: 1 filter_block_3: - 6: Mov32Imm dst: r4 imm: 1 - 7: JaImm dst: r0 off: -1 imm: 0 + 5: Mov32Imm dst: r4 imm: 0 + 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: - 8: Mov32Imm dst: r4 imm: 0 - 9: JaImm dst: r0 off: -1 imm: 0 - filter_block_5: - 10: Mov32Imm dst: r4 imm: 1 - 11: JaImm dst: r0 off: -1 imm: 0 + 7: Mov32Imm dst: r4 imm: 1 + 8: JaImm dst: r0 off: -1 imm: 0 result: - 12: MovImm dst: r0 imm: 2 - 13: JEqImm dst: r4 off: -1 imm: 0 - 14: MovImm dst: r0 imm: 1 + 9: MovImm dst: r0 imm: 2 + 10: JEqImm dst: r4 off: -1 imm: 0 + 11: MovImm dst: r0 imm: 1 return: - 15: Exit -=== RUN TestJumpIfBitsSet/kernel#05 -=== RUN TestJumpIfBitsSet/C#06 -=== RUN TestJumpIfGreaterOrEqual/eBPF#03 + 12: Exit +=== RUN TestALUShiftLeft/kernel +=== RUN TestALUShiftLeft/C#01 +=== RUN TestJump0/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 24 - 3: Mov32Imm dst: r5 imm: 23 - 4: JEqImm dst: r4 off: -1 imm: 0 + 2: MovReg dst: r6 src: r2 + 3: AddImm dst: r6 imm: 1 + 4: JGTReg dst: r6 off: -1 src: r3 + 5: Mov32Imm dst: r5 imm: 0 + 6: LdXMemB dst: r4 src: r2 off: 0 imm: 0 + 7: JaImm dst: r0 off: -1 imm: 0 filter_block_3: - 5: JGEReg dst: r4 off: -1 src: r5 - 6: JaImm dst: r0 off: -1 imm: 0 + 8: JEqReg dst: r4 off: -1 src: r5 filter_block_4: - 7: Mov32Imm dst: r4 imm: 1 - 8: JaImm dst: r0 off: -1 imm: 0 - filter_block_5: - 9: Mov32Imm dst: r4 imm: 0 + 9: Mov32Reg dst: r4 src: r4 10: JaImm dst: r0 off: -1 imm: 0 - filter_block_6: - 11: Mov32Imm dst: r4 imm: 1 + filter_nomatch: + 11: MovImm dst: r4 imm: 0 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 @@ -4895,48 +5236,128 @@ 15: MovImm dst: r0 imm: 1 return: 16: Exit -=== RUN TestJumpIfGreaterOrEqual/kernel#03 -=== RUN TestJumpIfGreaterOrEqual/C#04 -=== RUN TestLoadAbsolute/eBPF#05 +=== RUN TestJump0/kernel#01 +--- PASS: TestJump0 (0.12s) + --- SKIP: TestJump0/C (0.04s) + --- SKIP: TestJump0/eBPF (0.00s) + --- PASS: TestJump0/kernel (0.05s) + --- SKIP: TestJump0/C#01 (0.03s) + --- SKIP: TestJump0/eBPF#01 (0.00s) + --- PASS: TestJump0/kernel#01 (0.00s) +=== CONT TestZeroInitX +=== RUN TestZeroInitX/C +--- PASS: TestJumpIfBitsSet (0.76s) + --- SKIP: TestJumpIfBitsSet/C (0.05s) + --- SKIP: TestJumpIfBitsSet/eBPF (0.00s) + --- PASS: TestJumpIfBitsSet/kernel (0.00s) + --- SKIP: TestJumpIfBitsSet/C#01 (0.05s) + --- SKIP: TestJumpIfBitsSet/eBPF#01 (0.00s) + --- PASS: TestJumpIfBitsSet/kernel#01 (0.00s) + --- SKIP: TestJumpIfBitsSet/C#02 (0.04s) + --- SKIP: TestJumpIfBitsSet/eBPF#02 (0.00s) + --- PASS: TestJumpIfBitsSet/kernel#02 (0.00s) + --- SKIP: TestJumpIfBitsSet/C#03 (0.06s) + --- SKIP: TestJumpIfBitsSet/eBPF#03 (0.00s) + --- PASS: TestJumpIfBitsSet/kernel#03 (0.00s) + --- SKIP: TestJumpIfBitsSet/C#04 (0.04s) + --- SKIP: TestJumpIfBitsSet/eBPF#04 (0.00s) + --- PASS: TestJumpIfBitsSet/kernel#04 (0.00s) + --- SKIP: TestJumpIfBitsSet/C#05 (0.04s) + --- SKIP: TestJumpIfBitsSet/eBPF#05 (0.00s) + --- PASS: TestJumpIfBitsSet/kernel#05 (0.00s) + --- SKIP: TestJumpIfBitsSet/C#06 (0.03s) + --- SKIP: TestJumpIfBitsSet/eBPF#06 (0.00s) + --- PASS: TestJumpIfBitsSet/kernel#06 (0.00s) + --- SKIP: TestJumpIfBitsSet/C#07 (0.04s) + --- SKIP: TestJumpIfBitsSet/eBPF#07 (0.00s) + --- PASS: TestJumpIfBitsSet/kernel#07 (0.00s) + --- SKIP: TestJumpIfBitsSet/C#08 (0.03s) + --- SKIP: TestJumpIfBitsSet/eBPF#08 (0.00s) + --- PASS: TestJumpIfBitsSet/kernel#08 (0.05s) + --- SKIP: TestJumpIfBitsSet/C#09 (0.04s) + --- SKIP: TestJumpIfBitsSet/eBPF#09 (0.00s) + --- PASS: TestJumpIfBitsSet/kernel#09 (0.05s) + --- SKIP: TestJumpIfBitsSet/C#10 (0.04s) + --- SKIP: TestJumpIfBitsSet/eBPF#10 (0.00s) + --- PASS: TestJumpIfBitsSet/kernel#10 (0.05s) + --- SKIP: TestJumpIfBitsSet/C#11 (0.04s) + --- SKIP: TestJumpIfBitsSet/eBPF#11 (0.00s) + --- PASS: TestJumpIfBitsSet/kernel#11 (0.05s) +=== RUN TestALUXor/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: MovReg dst: r6 src: r2 - 3: AddImm dst: r6 imm: 6 - 4: JGTReg dst: r6 off: -1 src: r3 - 5: LdXMemW dst: r4 src: r2 off: 2 imm: 0 - 6: SwapBE dst: r4 imm: 32 - 7: Mov32Imm dst: r6 imm: -558907665 - 8: JEqReg dst: r4 off: -1 src: r6 + 2: Mov32Imm dst: r4 imm: 1 + 3: Mov32Imm dst: r5 imm: 1 + 4: Xor32Reg dst: r4 src: r5 + 5: JEqImm dst: r4 off: -1 imm: 0 + filter_block_4: + 6: Mov32Imm dst: r4 imm: 0 + 7: JaImm dst: r0 off: -1 imm: 0 + filter_block_5: + 8: Mov32Imm dst: r4 imm: 1 + 9: JaImm dst: r0 off: -1 imm: 0 + result: + 10: MovImm dst: r0 imm: 2 + 11: JEqImm dst: r4 off: -1 imm: 0 + 12: MovImm dst: r0 imm: 1 + return: + 13: Exit +=== RUN TestALUXor/kernel#01 +=== RUN TestALUXor/C#02 +=== RUN TestLoadAbsoluteBigOffset/C#04 +--- PASS: TestJump (0.09s) + --- SKIP: TestJump/C (0.04s) + --- SKIP: TestJump/eBPF (0.00s) + --- PASS: TestJump/kernel (0.05s) +--- PASS: TestNegateA (0.09s) + --- SKIP: TestNegateA/C (0.03s) + --- SKIP: TestNegateA/eBPF (0.00s) + --- PASS: TestNegateA/kernel (0.05s) +=== RUN TestJumpIfLessThan/eBPF#05 +=== RUN TestJumpIfBitsNotSet/C#08 +=== NAME TestJumpIfLessThan/eBPF#05 + ebpf_test.go:17: + 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 + 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 + filter_block_0: + 2: Mov32Imm dst: r4 imm: 23 + 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: - 9: Mov32Imm dst: r4 imm: 0 - 10: JaImm dst: r0 off: -1 imm: 0 + 4: JLTImm dst: r4 off: -1 imm: 23 + 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: - 11: Mov32Imm dst: r4 imm: 1 - 12: JaImm dst: r0 off: -1 imm: 0 - filter_nomatch: - 13: MovImm dst: r4 imm: 0 - 14: JaImm dst: r0 off: -1 imm: 0 + 6: Mov32Imm dst: r4 imm: 1 + 7: JaImm dst: r0 off: -1 imm: 0 + filter_block_4: + 8: Mov32Imm dst: r4 imm: 0 + 9: JaImm dst: r0 off: -1 imm: 0 + filter_block_5: + 10: Mov32Imm dst: r4 imm: 1 + 11: JaImm dst: r0 off: -1 imm: 0 result: - 15: MovImm dst: r0 imm: 2 - 16: JEqImm dst: r4 off: -1 imm: 0 - 17: MovImm dst: r0 imm: 1 + 12: MovImm dst: r0 imm: 2 + 13: JEqImm dst: r4 off: -1 imm: 0 + 14: MovImm dst: r0 imm: 1 return: - 18: Exit -=== RUN TestLoadAbsolute/kernel#05 -=== RUN TestJumpIfBitsNotSet/eBPF#04 + 15: Exit +=== RUN TestJumpIfLessThan/kernel#05 +=== RUN TestALUShiftRight/eBPF +=== RUN TestLoadIndirect/variable_valid +=== RUN TestLoadIndirect/variable_valid/C +=== NAME TestALUShiftRight/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 6 - 3: JSetImm dst: r4 off: -1 imm: 2 - 4: JaImm dst: r0 off: -1 imm: 0 - filter_block_2: + 2: Mov32Imm dst: r4 imm: 240 + 3: RSh32Imm dst: r4 imm: 4 + 4: JEqImm dst: r4 off: -1 imm: 15 + filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 - filter_block_3: + filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: @@ -4945,79 +5366,90 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestJumpIfBitsNotSet/kernel#04 -=== RUN TestJumpIfLessOrEqual/eBPF#03 +=== RUN TestALUShiftRight/kernel +=== RUN TestALUShiftRight/C#01 +=== RUN TestJumpIfGreaterThan/eBPF#06 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 24 + 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 23 - 4: JEqImm dst: r4 off: -1 imm: 0 + 4: JGTReg dst: r4 off: -1 src: r5 filter_block_3: - 5: JLEReg dst: r4 off: -1 src: r5 - 6: JaImm dst: r0 off: -1 imm: 0 + 5: Mov32Imm dst: r4 imm: 0 + 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 - filter_block_5: - 9: Mov32Imm dst: r4 imm: 0 - 10: JaImm dst: r0 off: -1 imm: 0 - filter_block_6: - 11: Mov32Imm dst: r4 imm: 1 - 12: JaImm dst: r0 off: -1 imm: 0 result: - 13: MovImm dst: r0 imm: 2 - 14: JEqImm dst: r4 off: -1 imm: 0 - 15: MovImm dst: r0 imm: 1 + 9: MovImm dst: r0 imm: 2 + 10: JEqImm dst: r4 off: -1 imm: 0 + 11: MovImm dst: r0 imm: 1 return: - 16: Exit -=== RUN TestJumpIfLessOrEqual/kernel#03 -=== RUN TestJumpIfGreaterThan/C#11 -=== RUN TestJumpIfGreaterOrEqual/eBPF#04 + 12: Exit +=== RUN TestJumpIfGreaterThan/kernel#06 +=== RUN TestALUShiftLeft/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 23 - 3: JGEImm dst: r4 off: -1 imm: 23 - filter_block_2: - 4: Mov32Imm dst: r4 imm: 0 - 5: JaImm dst: r0 off: -1 imm: 0 - filter_block_3: - 6: Mov32Imm dst: r4 imm: 1 + 2: Mov32Imm dst: r4 imm: 1 + 3: Mov32Imm dst: r5 imm: 0 + 4: LSh32Reg dst: r4 src: r5 + 5: JEqImm dst: r4 off: -1 imm: 1 + filter_block_4: + 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 + filter_block_5: + 8: Mov32Imm dst: r4 imm: 1 + 9: JaImm dst: r0 off: -1 imm: 0 result: - 8: MovImm dst: r0 imm: 2 - 9: JEqImm dst: r4 off: -1 imm: 0 - 10: MovImm dst: r0 imm: 1 + 10: MovImm dst: r0 imm: 2 + 11: JEqImm dst: r4 off: -1 imm: 0 + 12: MovImm dst: r0 imm: 1 return: - 11: Exit -=== RUN TestJumpIfGreaterOrEqual/kernel#04 -=== RUN TestJumpIfGreaterOrEqual/C#05 -=== RUN TestJumpIfLessThan/eBPF#08 + 13: Exit +=== RUN TestALUShiftLeft/kernel#01 +=== RUN TestALUShiftLeft/C#02 +=== RUN TestZeroInitX/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 22 - 3: JLTImm dst: r4 off: -1 imm: 23 - filter_block_2: - 4: Mov32Imm dst: r4 imm: 0 + 2: Mov32Imm dst: r5 imm: 0 + 3: Mov32Reg dst: r4 src: r5 + 4: Mov32Reg dst: r4 src: r4 5: JaImm dst: r0 off: -1 imm: 0 + result: + 6: MovImm dst: r0 imm: 2 + 7: JEqImm dst: r4 off: -1 imm: 0 + 8: MovImm dst: r0 imm: 1 + return: + 9: Exit +=== RUN TestZeroInitX/kernel +=== RUN TestALUXor/eBPF#02 + ebpf_test.go:17: + 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 + 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 + filter_block_0: + 2: Mov32Imm dst: r4 imm: 6 + 3: Mod32Imm dst: r4 imm: 4 + 4: JEqImm dst: r4 off: -1 imm: 2 filter_block_3: - 6: Mov32Imm dst: r4 imm: 1 - 7: JaImm dst: r0 off: -1 imm: 0 + 5: Mov32Imm dst: r4 imm: 0 + 6: JaImm dst: r0 off: -1 imm: 0 + filter_block_4: + 7: Mov32Imm dst: r4 imm: 1 + 8: JaImm dst: r0 off: -1 imm: 0 result: - 8: MovImm dst: r0 imm: 2 - 9: JEqImm dst: r4 off: -1 imm: 0 - 10: MovImm dst: r0 imm: 1 + 9: MovImm dst: r0 imm: 2 + 10: JEqImm dst: r4 off: -1 imm: 0 + 11: MovImm dst: r0 imm: 1 return: - 11: Exit -=== RUN TestJumpIfLessThan/kernel#08 -=== RUN TestJumpIfLessThan/C#09 -=== RUN TestLoadIndirect/variable_valid -=== RUN TestLoadIndirect/variable_valid/C + 12: Exit +=== RUN TestALUXor/kernel#02 +=== RUN TestALUXor/C#03 === RUN TestLoadAbsoluteBigOffset/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 @@ -5043,18 +5475,18 @@ return: 17: Exit === RUN TestLoadAbsoluteBigOffset/kernel#04 -=== RUN TestJumpIfBitsSet/eBPF#06 +=== RUN TestJumpIfBitsNotSet/eBPF#08 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 - 3: Mov32Imm dst: r5 imm: 2 - 4: JSetReg dst: r4 off: -1 src: r5 - filter_block_3: + 3: JSetImm dst: r4 off: -1 imm: 8 + 4: JaImm dst: r0 off: -1 imm: 0 + filter_block_2: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 - filter_block_4: + filter_block_3: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: @@ -5063,161 +5495,31 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestJumpIfBitsSet/kernel#06 -=== RUN TestJumpIfBitsSet/C#07 ---- PASS: TestLoadAbsolute (0.65s) - --- SKIP: TestLoadAbsolute/C (0.10s) - --- SKIP: TestLoadAbsolute/eBPF (0.00s) - --- PASS: TestLoadAbsolute/kernel (0.00s) - --- SKIP: TestLoadAbsolute/C#01 (0.05s) - --- SKIP: TestLoadAbsolute/eBPF#01 (0.00s) - --- PASS: TestLoadAbsolute/kernel#01 (0.05s) - --- SKIP: TestLoadAbsolute/C#02 (0.09s) - --- SKIP: TestLoadAbsolute/eBPF#02 (0.00s) - --- PASS: TestLoadAbsolute/kernel#02 (0.00s) - --- SKIP: TestLoadAbsolute/C#03 (0.06s) - --- SKIP: TestLoadAbsolute/eBPF#03 (0.00s) - --- PASS: TestLoadAbsolute/kernel#03 (0.06s) - --- SKIP: TestLoadAbsolute/C#04 (0.10s) - --- SKIP: TestLoadAbsolute/eBPF#04 (0.00s) - --- PASS: TestLoadAbsolute/kernel#04 (0.00s) - --- SKIP: TestLoadAbsolute/C#05 (0.08s) - --- SKIP: TestLoadAbsolute/eBPF#05 (0.00s) - --- PASS: TestLoadAbsolute/kernel#05 (0.05s) -=== RUN TestJumpIfBitsNotSet/C#05 -=== RUN TestJumpIfLessOrEqual/C#04 -=== RUN TestJumpIfGreaterThan/eBPF#11 - ebpf_test.go:17: - 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 - 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 - filter_block_0: - 2: Mov32Imm dst: r4 imm: 22 - 3: Mov32Imm dst: r5 imm: 23 - 4: JEqImm dst: r4 off: -1 imm: 0 - filter_block_3: - 5: JGTReg dst: r4 off: -1 src: r5 - 6: JaImm dst: r0 off: -1 imm: 0 - filter_block_4: - 7: Mov32Imm dst: r4 imm: 1 - 8: JaImm dst: r0 off: -1 imm: 0 - filter_block_5: - 9: Mov32Imm dst: r4 imm: 0 - 10: JaImm dst: r0 off: -1 imm: 0 - filter_block_6: - 11: Mov32Imm dst: r4 imm: 1 - 12: JaImm dst: r0 off: -1 imm: 0 - result: - 13: MovImm dst: r0 imm: 2 - 14: JEqImm dst: r4 off: -1 imm: 0 - 15: MovImm dst: r0 imm: 1 - return: - 16: Exit -=== RUN TestJumpIfGreaterThan/kernel#11 -=== RUN TestJumpIfGreaterOrEqual/eBPF#05 +=== RUN TestJumpIfBitsNotSet/kernel#08 +=== RUN TestJumpIfBitsNotSet/C#09 +=== RUN TestALUShiftRight/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 23 - 3: JEqImm dst: r4 off: -1 imm: 0 - filter_block_2: - 4: JGEImm dst: r4 off: -1 imm: 23 - 5: JaImm dst: r0 off: -1 imm: 0 - filter_block_3: - 6: Mov32Imm dst: r4 imm: 1 - 7: JaImm dst: r0 off: -1 imm: 0 + 2: Mov32Imm dst: r4 imm: 240 + 3: Mov32Imm dst: r5 imm: 4 + 4: RSh32Reg dst: r4 src: r5 + 5: JEqImm dst: r4 off: -1 imm: 15 filter_block_4: - 8: Mov32Imm dst: r4 imm: 0 - 9: JaImm dst: r0 off: -1 imm: 0 - filter_block_5: - 10: Mov32Imm dst: r4 imm: 1 - 11: JaImm dst: r0 off: -1 imm: 0 - result: - 12: MovImm dst: r0 imm: 2 - 13: JEqImm dst: r4 off: -1 imm: 0 - 14: MovImm dst: r0 imm: 1 - return: - 15: Exit -=== RUN TestJumpIfGreaterOrEqual/kernel#05 -=== RUN TestJumpIfGreaterOrEqual/C#06 -=== RUN TestLoadAbsoluteBigOffset/C#05 -=== RUN TestJumpIfBitsNotSet/eBPF#05 - ebpf_test.go:17: - 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 - 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 - filter_block_0: - 2: Mov32Imm dst: r4 imm: 6 - 3: JEqImm dst: r4 off: -1 imm: 0 - filter_block_2: - 4: JSetImm dst: r4 off: -1 imm: 2 - 5: JaImm dst: r0 off: -1 imm: 0 - filter_block_3: - 6: Mov32Imm dst: r4 imm: 1 + 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 - filter_block_4: - 8: Mov32Imm dst: r4 imm: 0 - 9: JaImm dst: r0 off: -1 imm: 0 filter_block_5: - 10: Mov32Imm dst: r4 imm: 1 - 11: JaImm dst: r0 off: -1 imm: 0 - result: - 12: MovImm dst: r0 imm: 2 - 13: JEqImm dst: r4 off: -1 imm: 0 - 14: MovImm dst: r0 imm: 1 - return: - 15: Exit -=== RUN TestJumpIfBitsNotSet/kernel#05 -=== RUN TestJumpIfLessOrEqual/eBPF#04 - ebpf_test.go:17: - 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 - 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 - filter_block_0: - 2: Mov32Imm dst: r4 imm: 23 - 3: JLEImm dst: r4 off: -1 imm: 23 - filter_block_2: - 4: Mov32Imm dst: r4 imm: 0 - 5: JaImm dst: r0 off: -1 imm: 0 - filter_block_3: - 6: Mov32Imm dst: r4 imm: 1 - 7: JaImm dst: r0 off: -1 imm: 0 - result: - 8: MovImm dst: r0 imm: 2 - 9: JEqImm dst: r4 off: -1 imm: 0 - 10: MovImm dst: r0 imm: 1 - return: - 11: Exit -=== RUN TestJumpIfLessOrEqual/kernel#04 -=== RUN TestJumpIfLessOrEqual/C#05 -=== RUN TestJumpIfLessThan/eBPF#09 - ebpf_test.go:17: - 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 - 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 - filter_block_0: - 2: Mov32Imm dst: r4 imm: 22 - 3: JEqImm dst: r4 off: -1 imm: 0 - filter_block_2: - 4: JLTImm dst: r4 off: -1 imm: 23 - 5: JaImm dst: r0 off: -1 imm: 0 - filter_block_3: - 6: Mov32Imm dst: r4 imm: 1 - 7: JaImm dst: r0 off: -1 imm: 0 - filter_block_4: - 8: Mov32Imm dst: r4 imm: 0 + 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 - filter_block_5: - 10: Mov32Imm dst: r4 imm: 1 - 11: JaImm dst: r0 off: -1 imm: 0 result: - 12: MovImm dst: r0 imm: 2 - 13: JEqImm dst: r4 off: -1 imm: 0 - 14: MovImm dst: r0 imm: 1 + 10: MovImm dst: r0 imm: 2 + 11: JEqImm dst: r4 off: -1 imm: 0 + 12: MovImm dst: r0 imm: 1 return: - 15: Exit -=== RUN TestJumpIfLessThan/kernel#09 -=== RUN TestJumpIfLessThan/C#10 + 13: Exit +=== RUN TestALUShiftRight/kernel#01 === RUN TestLoadIndirect/variable_valid/eBPF -=== RUN TestJumpIfBitsSet/eBPF#07 -=== NAME TestLoadIndirect/variable_valid/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 @@ -5255,26 +5557,27 @@ return: 28: Exit === RUN TestLoadIndirect/variable_valid/kernel +=== RUN TestALUShiftRight/C#02 === RUN TestLoadIndirect/variable_valid/C#01 -=== NAME TestJumpIfBitsSet/eBPF#07 +=== RUN TestJumpIfLessThan/C#06 +=== RUN TestALUXor/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 - 3: Mov32Imm dst: r5 imm: 2 - 4: JEqImm dst: r4 off: -1 imm: 0 - filter_block_3: - 5: JSetReg dst: r4 off: -1 src: r5 - 6: JaImm dst: r0 off: -1 imm: 0 + 3: Mov32Imm dst: r5 imm: 4 + 4: JEqImm dst: r5 off: -1 imm: 0 + 5: Mod32Reg dst: r4 src: r5 + 6: JEqImm dst: r4 off: -1 imm: 2 filter_block_4: - 7: Mov32Imm dst: r4 imm: 1 + 7: Mov32Imm dst: r4 imm: 0 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: - 9: Mov32Imm dst: r4 imm: 0 + 9: Mov32Imm dst: r4 imm: 1 10: JaImm dst: r0 off: -1 imm: 0 - filter_block_6: - 11: Mov32Imm dst: r4 imm: 1 + filter_nomatch: + 11: MovImm dst: r4 imm: 0 12: JaImm dst: r0 off: -1 imm: 0 result: 13: MovImm dst: r0 imm: 2 @@ -5282,16 +5585,28 @@ 15: MovImm dst: r0 imm: 1 return: 16: Exit -=== RUN TestJumpIfBitsSet/kernel#07 -=== RUN TestJumpIfBitsSet/C#08 -=== RUN TestJumpIfGreaterOrEqual/eBPF#06 +=== RUN TestALUXor/kernel#03 +--- PASS: TestALUXor (0.14s) + --- SKIP: TestALUXor/C (0.04s) + --- SKIP: TestALUXor/eBPF (0.00s) + --- PASS: TestALUXor/kernel (0.00s) + --- SKIP: TestALUXor/C#01 (0.03s) + --- SKIP: TestALUXor/eBPF#01 (0.00s) + --- PASS: TestALUXor/kernel#01 (0.00s) + --- SKIP: TestALUXor/C#02 (0.03s) + --- SKIP: TestALUXor/eBPF#02 (0.00s) + --- PASS: TestALUXor/kernel#02 (0.00s) + --- SKIP: TestALUXor/C#03 (0.03s) + --- SKIP: TestALUXor/eBPF#03 (0.00s) + --- PASS: TestALUXor/kernel#03 (0.00s) +=== RUN TestALUShiftLeft/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 23 - 3: Mov32Imm dst: r5 imm: 23 - 4: JGEReg dst: r4 off: -1 src: r5 + 2: Mov32Imm dst: r4 imm: 1 + 3: LSh32Imm dst: r4 imm: 4 + 4: JEqImm dst: r4 off: -1 imm: 16 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 @@ -5304,17 +5619,23 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestJumpIfGreaterOrEqual/kernel#06 -=== RUN TestJumpIfLessOrEqual/eBPF#05 +=== RUN TestALUShiftLeft/kernel#02 +=== RUN TestALUShiftLeft/C#03 +=== RUN TestJumpIfGreaterThan/C#07 +--- PASS: TestZeroInitX (0.08s) + --- SKIP: TestZeroInitX/C (0.03s) + --- SKIP: TestZeroInitX/eBPF (0.00s) + --- PASS: TestZeroInitX/kernel (0.05s) +=== RUN TestJumpIfBitsNotSet/eBPF#09 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 23 + 2: Mov32Imm dst: r4 imm: 6 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: - 4: JLEImm dst: r4 off: -1 imm: 23 - 5: JaImm dst: r0 off: -1 imm: 0 + 4: JSetImm dst: r4 off: -1 imm: 8 + 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 @@ -5330,163 +5651,17 @@ 14: MovImm dst: r0 imm: 1 return: 15: Exit -=== RUN TestJumpIfLessOrEqual/kernel#05 -=== RUN TestJumpIfGreaterOrEqual/C#07 -=== RUN TestJumpIfLessOrEqual/C#06 ---- PASS: TestJumpIfGreaterThan (1.38s) - --- SKIP: TestJumpIfGreaterThan/C (0.05s) - --- SKIP: TestJumpIfGreaterThan/eBPF (0.00s) - --- PASS: TestJumpIfGreaterThan/kernel (0.00s) - --- SKIP: TestJumpIfGreaterThan/C#01 (0.06s) - --- SKIP: TestJumpIfGreaterThan/eBPF#01 (0.00s) - --- PASS: TestJumpIfGreaterThan/kernel#01 (0.00s) - --- SKIP: TestJumpIfGreaterThan/C#02 (0.09s) - --- SKIP: TestJumpIfGreaterThan/eBPF#02 (0.00s) - --- PASS: TestJumpIfGreaterThan/kernel#02 (0.00s) - --- SKIP: TestJumpIfGreaterThan/C#03 (0.07s) - --- SKIP: TestJumpIfGreaterThan/eBPF#03 (0.00s) - --- PASS: TestJumpIfGreaterThan/kernel#03 (0.00s) - --- SKIP: TestJumpIfGreaterThan/C#04 (0.09s) - --- SKIP: TestJumpIfGreaterThan/eBPF#04 (0.00s) - --- PASS: TestJumpIfGreaterThan/kernel#04 (0.06s) - --- SKIP: TestJumpIfGreaterThan/C#05 (0.07s) - --- SKIP: TestJumpIfGreaterThan/eBPF#05 (0.00s) - --- PASS: TestJumpIfGreaterThan/kernel#05 (0.05s) - --- SKIP: TestJumpIfGreaterThan/C#06 (0.04s) - --- SKIP: TestJumpIfGreaterThan/eBPF#06 (0.00s) - --- PASS: TestJumpIfGreaterThan/kernel#06 (0.07s) - --- SKIP: TestJumpIfGreaterThan/C#07 (0.09s) - --- SKIP: TestJumpIfGreaterThan/eBPF#07 (0.00s) - --- PASS: TestJumpIfGreaterThan/kernel#07 (0.05s) - --- SKIP: TestJumpIfGreaterThan/C#08 (0.09s) - --- SKIP: TestJumpIfGreaterThan/eBPF#08 (0.00s) - --- PASS: TestJumpIfGreaterThan/kernel#08 (0.06s) - --- SKIP: TestJumpIfGreaterThan/C#09 (0.08s) - --- SKIP: TestJumpIfGreaterThan/eBPF#09 (0.00s) - --- PASS: TestJumpIfGreaterThan/kernel#09 (0.05s) - --- SKIP: TestJumpIfGreaterThan/C#10 (0.08s) - --- SKIP: TestJumpIfGreaterThan/eBPF#10 (0.00s) - --- PASS: TestJumpIfGreaterThan/kernel#10 (0.05s) - --- SKIP: TestJumpIfGreaterThan/C#11 (0.05s) - --- SKIP: TestJumpIfGreaterThan/eBPF#11 (0.00s) - --- PASS: TestJumpIfGreaterThan/kernel#11 (0.07s) -=== RUN TestLoadAbsoluteBigOffset/eBPF#05 - ebpf_test.go:17: - 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 - 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 - filter_block_0: - 2: Mov32Imm dst: r4 imm: 0 - 3: JaImm dst: r0 off: -1 imm: 0 - result: - 4: MovImm dst: r0 imm: 2 - 5: JEqImm dst: r4 off: -1 imm: 0 - 6: MovImm dst: r0 imm: 1 - return: - 7: Exit -=== RUN TestLoadAbsoluteBigOffset/kernel#05 -=== RUN TestJumpIfBitsNotSet/C#06 -=== RUN TestJumpIfLessThan/eBPF#10 - ebpf_test.go:17: - 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 - 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 - filter_block_0: - 2: Mov32Imm dst: r4 imm: 22 - 3: Mov32Imm dst: r5 imm: 23 - 4: JLTReg dst: r4 off: -1 src: r5 - filter_block_3: - 5: Mov32Imm dst: r4 imm: 0 - 6: JaImm dst: r0 off: -1 imm: 0 - filter_block_4: - 7: Mov32Imm dst: r4 imm: 1 - 8: JaImm dst: r0 off: -1 imm: 0 - result: - 9: MovImm dst: r0 imm: 2 - 10: JEqImm dst: r4 off: -1 imm: 0 - 11: MovImm dst: r0 imm: 1 - return: - 12: Exit -=== RUN TestJumpIfLessThan/kernel#10 -=== RUN TestJumpIfLessThan/C#11 -=== RUN TestJumpIfBitsSet/eBPF#08 - ebpf_test.go:17: - 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 - 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 - filter_block_0: - 2: Mov32Imm dst: r4 imm: 6 - 3: JSetImm dst: r4 off: -1 imm: 8 - filter_block_2: - 4: Mov32Imm dst: r4 imm: 0 - 5: JaImm dst: r0 off: -1 imm: 0 - filter_block_3: - 6: Mov32Imm dst: r4 imm: 1 - 7: JaImm dst: r0 off: -1 imm: 0 - result: - 8: MovImm dst: r0 imm: 2 - 9: JEqImm dst: r4 off: -1 imm: 0 - 10: MovImm dst: r0 imm: 1 - return: - 11: Exit -=== RUN TestJumpIfBitsSet/kernel#08 -=== RUN TestJumpIfBitsNotSet/eBPF#06 - ebpf_test.go:17: - 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 - 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 - filter_block_0: - 2: Mov32Imm dst: r4 imm: 6 - 3: Mov32Imm dst: r5 imm: 2 - 4: JSetReg dst: r4 off: -1 src: r5 - 5: JaImm dst: r0 off: -1 imm: 0 - filter_block_3: - 6: Mov32Imm dst: r4 imm: 0 - 7: JaImm dst: r0 off: -1 imm: 0 - filter_block_4: - 8: Mov32Imm dst: r4 imm: 1 - 9: JaImm dst: r0 off: -1 imm: 0 - result: - 10: MovImm dst: r0 imm: 2 - 11: JEqImm dst: r4 off: -1 imm: 0 - 12: MovImm dst: r0 imm: 1 - return: - 13: Exit -=== RUN TestJumpIfBitsNotSet/kernel#06 -=== RUN TestJumpIfGreaterOrEqual/eBPF#07 +=== RUN TestJumpIfBitsNotSet/kernel#09 +=== RUN TestJumpIfBitsNotSet/C#10 +=== RUN TestALUShiftRight/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 23 - 3: Mov32Imm dst: r5 imm: 23 + 2: Mov32Imm dst: r4 imm: 240 + 3: RSh32Imm dst: r4 imm: 8 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: - 5: JGEReg dst: r4 off: -1 src: r5 - 6: JaImm dst: r0 off: -1 imm: 0 - filter_block_4: - 7: Mov32Imm dst: r4 imm: 1 - 8: JaImm dst: r0 off: -1 imm: 0 - filter_block_5: - 9: Mov32Imm dst: r4 imm: 0 - 10: JaImm dst: r0 off: -1 imm: 0 - filter_block_6: - 11: Mov32Imm dst: r4 imm: 1 - 12: JaImm dst: r0 off: -1 imm: 0 - result: - 13: MovImm dst: r0 imm: 2 - 14: JEqImm dst: r4 off: -1 imm: 0 - 15: MovImm dst: r0 imm: 1 - return: - 16: Exit -=== RUN TestLoadAbsoluteBigOffset/C#06 -=== RUN TestJumpIfGreaterOrEqual/kernel#07 -=== RUN TestJumpIfGreaterOrEqual/C#08 -=== RUN TestJumpIfLessOrEqual/eBPF#06 - ebpf_test.go:17: - 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 - 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 - filter_block_0: - 2: Mov32Imm dst: r4 imm: 23 - 3: Mov32Imm dst: r5 imm: 23 - 4: JLEReg dst: r4 off: -1 src: r5 - filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: @@ -5498,8 +5673,8 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestJumpIfLessOrEqual/kernel#06 -=== RUN TestJumpIfLessOrEqual/C#07 +=== RUN TestALUShiftRight/kernel#02 +=== RUN TestALUShiftRight/C#03 === RUN TestLoadIndirect/variable_valid/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 @@ -5538,119 +5713,87 @@ return: 28: Exit === RUN TestLoadIndirect/variable_valid/kernel#01 -=== RUN TestJumpIfLessThan/eBPF#11 +=== RUN TestLoadAbsoluteBigOffset/C#05 +=== RUN TestJumpIfLessThan/eBPF#06 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 22 + 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 23 - 4: JEqImm dst: r4 off: -1 imm: 0 + 4: JLTReg dst: r4 off: -1 src: r5 filter_block_3: - 5: JLTReg dst: r4 off: -1 src: r5 - 6: JaImm dst: r0 off: -1 imm: 0 + 5: Mov32Imm dst: r4 imm: 0 + 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 - filter_block_5: - 9: Mov32Imm dst: r4 imm: 0 - 10: JaImm dst: r0 off: -1 imm: 0 - filter_block_6: - 11: Mov32Imm dst: r4 imm: 1 - 12: JaImm dst: r0 off: -1 imm: 0 result: - 13: MovImm dst: r0 imm: 2 - 14: JEqImm dst: r4 off: -1 imm: 0 - 15: MovImm dst: r0 imm: 1 + 9: MovImm dst: r0 imm: 2 + 10: JEqImm dst: r4 off: -1 imm: 0 + 11: MovImm dst: r0 imm: 1 return: - 16: Exit -=== RUN TestJumpIfLessThan/kernel#11 ---- PASS: TestJumpIfLessThan (1.45s) - --- SKIP: TestJumpIfLessThan/C (0.06s) - --- SKIP: TestJumpIfLessThan/eBPF (0.00s) - --- PASS: TestJumpIfLessThan/kernel (0.07s) - --- SKIP: TestJumpIfLessThan/C#01 (0.11s) - --- SKIP: TestJumpIfLessThan/eBPF#01 (0.00s) - --- PASS: TestJumpIfLessThan/kernel#01 (0.05s) - --- SKIP: TestJumpIfLessThan/C#02 (0.06s) - --- SKIP: TestJumpIfLessThan/eBPF#02 (0.00s) - --- PASS: TestJumpIfLessThan/kernel#02 (0.07s) - --- SKIP: TestJumpIfLessThan/C#03 (0.08s) - --- SKIP: TestJumpIfLessThan/eBPF#03 (0.00s) - --- PASS: TestJumpIfLessThan/kernel#03 (0.05s) - --- SKIP: TestJumpIfLessThan/C#04 (0.10s) - --- SKIP: TestJumpIfLessThan/eBPF#04 (0.00s) - --- PASS: TestJumpIfLessThan/kernel#04 (0.05s) - --- SKIP: TestJumpIfLessThan/C#05 (0.09s) - --- SKIP: TestJumpIfLessThan/eBPF#05 (0.00s) - --- PASS: TestJumpIfLessThan/kernel#05 (0.05s) - --- SKIP: TestJumpIfLessThan/C#06 (0.08s) - --- SKIP: TestJumpIfLessThan/eBPF#06 (0.00s) - --- PASS: TestJumpIfLessThan/kernel#06 (0.06s) - --- SKIP: TestJumpIfLessThan/C#07 (0.09s) - --- SKIP: TestJumpIfLessThan/eBPF#07 (0.00s) - --- PASS: TestJumpIfLessThan/kernel#07 (0.05s) - --- SKIP: TestJumpIfLessThan/C#08 (0.08s) - --- SKIP: TestJumpIfLessThan/eBPF#08 (0.00s) - --- PASS: TestJumpIfLessThan/kernel#08 (0.00s) - --- SKIP: TestJumpIfLessThan/C#09 (0.07s) - --- SKIP: TestJumpIfLessThan/eBPF#09 (0.00s) - --- PASS: TestJumpIfLessThan/kernel#09 (0.00s) - --- SKIP: TestJumpIfLessThan/C#10 (0.05s) - --- SKIP: TestJumpIfLessThan/eBPF#10 (0.00s) - --- PASS: TestJumpIfLessThan/kernel#10 (0.00s) - --- SKIP: TestJumpIfLessThan/C#11 (0.05s) - --- SKIP: TestJumpIfLessThan/eBPF#11 (0.00s) - --- PASS: TestJumpIfLessThan/kernel#11 (0.00s) -=== RUN TestJumpIfBitsSet/C#09 -=== RUN TestJumpIfGreaterOrEqual/eBPF#08 + 12: Exit +=== RUN TestJumpIfLessThan/kernel#06 +=== RUN TestALUShiftLeft/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 22 - 3: JGEImm dst: r4 off: -1 imm: 23 - filter_block_2: - 4: Mov32Imm dst: r4 imm: 0 - 5: JaImm dst: r0 off: -1 imm: 0 - filter_block_3: - 6: Mov32Imm dst: r4 imm: 1 + 2: Mov32Imm dst: r4 imm: 1 + 3: Mov32Imm dst: r5 imm: 4 + 4: LSh32Reg dst: r4 src: r5 + 5: JEqImm dst: r4 off: -1 imm: 16 + filter_block_4: + 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 + filter_block_5: + 8: Mov32Imm dst: r4 imm: 1 + 9: JaImm dst: r0 off: -1 imm: 0 result: - 8: MovImm dst: r0 imm: 2 - 9: JEqImm dst: r4 off: -1 imm: 0 - 10: MovImm dst: r0 imm: 1 + 10: MovImm dst: r0 imm: 2 + 11: JEqImm dst: r4 off: -1 imm: 0 + 12: MovImm dst: r0 imm: 1 return: - 11: Exit -=== RUN TestJumpIfGreaterOrEqual/kernel#08 -=== RUN TestLoadAbsoluteBigOffset/eBPF#06 + 13: Exit +=== RUN TestALUShiftLeft/kernel#03 +--- PASS: TestALUShiftLeft (0.16s) + --- SKIP: TestALUShiftLeft/C (0.04s) + --- SKIP: TestALUShiftLeft/eBPF (0.00s) + --- PASS: TestALUShiftLeft/kernel (0.00s) + --- SKIP: TestALUShiftLeft/C#01 (0.03s) + --- SKIP: TestALUShiftLeft/eBPF#01 (0.00s) + --- PASS: TestALUShiftLeft/kernel#01 (0.00s) + --- SKIP: TestALUShiftLeft/C#02 (0.05s) + --- SKIP: TestALUShiftLeft/eBPF#02 (0.00s) + --- PASS: TestALUShiftLeft/kernel#02 (0.00s) + --- SKIP: TestALUShiftLeft/C#03 (0.04s) + --- SKIP: TestALUShiftLeft/eBPF#03 (0.00s) + --- PASS: TestALUShiftLeft/kernel#03 (0.00s) +=== RUN TestJumpIfBitsNotSet/eBPF#10 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: MovReg dst: r6 src: r2 - 3: AddImm dst: r6 imm: 65535 - 4: JGTReg dst: r6 off: -1 src: r3 - 5: Mov32Imm dst: r4 imm: 0 - 6: MovReg dst: r6 src: r2 - 7: AddImm dst: r6 imm: 65534 - 8: LdXMemB dst: r5 src: r6 off: 0 imm: 0 - 9: And32Imm dst: r5 imm: 15 - 10: LSh32Imm dst: r5 imm: 2 - 11: Add32Imm dst: r4 imm: 2 - 12: Mov32Reg dst: r4 src: r4 - 13: JaImm dst: r0 off: -1 imm: 0 - filter_nomatch: - 14: MovImm dst: r4 imm: 0 - 15: JaImm dst: r0 off: -1 imm: 0 + 2: Mov32Imm dst: r4 imm: 6 + 3: Mov32Imm dst: r5 imm: 8 + 4: JSetReg dst: r4 off: -1 src: r5 + 5: JaImm dst: r0 off: -1 imm: 0 + filter_block_3: + 6: Mov32Imm dst: r4 imm: 0 + 7: JaImm dst: r0 off: -1 imm: 0 + filter_block_4: + 8: Mov32Imm dst: r4 imm: 1 + 9: JaImm dst: r0 off: -1 imm: 0 result: - 16: MovImm dst: r0 imm: 2 - 17: JEqImm dst: r4 off: -1 imm: 0 - 18: MovImm dst: r0 imm: 1 + 10: MovImm dst: r0 imm: 2 + 11: JEqImm dst: r4 off: -1 imm: 0 + 12: MovImm dst: r0 imm: 1 return: - 19: Exit -=== RUN TestLoadAbsoluteBigOffset/kernel#06 -=== RUN TestJumpIfLessOrEqual/eBPF#07 + 13: Exit +=== RUN TestJumpIfBitsNotSet/kernel#10 +=== RUN TestJumpIfBitsNotSet/C#11 +=== RUN TestJumpIfGreaterThan/eBPF#07 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 @@ -5659,7 +5802,7 @@ 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: - 5: JLEReg dst: r4 off: -1 src: r5 + 5: JGTReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 @@ -5676,59 +5819,124 @@ 15: MovImm dst: r0 imm: 1 return: 16: Exit -=== RUN TestJumpIfLessOrEqual/kernel#07 -=== RUN TestJumpIfLessOrEqual/C#08 -=== RUN TestJumpIfBitsNotSet/C#07 -=== RUN TestLoadIndirect/variable_valid/C#02 -=== RUN TestJumpIfLessOrEqual/eBPF#08 +=== RUN TestJumpIfGreaterThan/kernel#07 +=== RUN TestLoadAbsoluteBigOffset/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 22 - 3: JLEImm dst: r4 off: -1 imm: 23 - filter_block_2: - 4: Mov32Imm dst: r4 imm: 0 - 5: JaImm dst: r0 off: -1 imm: 0 - filter_block_3: - 6: Mov32Imm dst: r4 imm: 1 + 2: Mov32Imm dst: r4 imm: 0 + 3: JaImm dst: r0 off: -1 imm: 0 + result: + 4: MovImm dst: r0 imm: 2 + 5: JEqImm dst: r4 off: -1 imm: 0 + 6: MovImm dst: r0 imm: 1 + return: + 7: Exit +=== RUN TestLoadAbsoluteBigOffset/kernel#05 +=== RUN TestALUShiftRight/eBPF#03 + ebpf_test.go:17: + 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 + 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 + filter_block_0: + 2: Mov32Imm dst: r4 imm: 240 + 3: Mov32Imm dst: r5 imm: 8 + 4: RSh32Reg dst: r4 src: r5 + 5: JEqImm dst: r4 off: -1 imm: 0 + filter_block_4: + 6: Mov32Imm dst: r4 imm: 0 7: JaImm dst: r0 off: -1 imm: 0 + filter_block_5: + 8: Mov32Imm dst: r4 imm: 1 + 9: JaImm dst: r0 off: -1 imm: 0 result: - 8: MovImm dst: r0 imm: 2 - 9: JEqImm dst: r4 off: -1 imm: 0 - 10: MovImm dst: r0 imm: 1 + 10: MovImm dst: r0 imm: 2 + 11: JEqImm dst: r4 off: -1 imm: 0 + 12: MovImm dst: r0 imm: 1 return: - 11: Exit -=== RUN TestJumpIfLessOrEqual/kernel#08 -=== RUN TestJumpIfLessOrEqual/C#09 -=== RUN TestJumpIfGreaterOrEqual/C#09 -=== RUN TestJumpIfBitsSet/eBPF#09 + 13: Exit +=== RUN TestALUShiftRight/kernel#03 +--- PASS: TestALUShiftRight (0.16s) + --- SKIP: TestALUShiftRight/C (0.04s) + --- SKIP: TestALUShiftRight/eBPF (0.00s) + --- PASS: TestALUShiftRight/kernel (0.00s) + --- SKIP: TestALUShiftRight/C#01 (0.04s) + --- SKIP: TestALUShiftRight/eBPF#01 (0.00s) + --- PASS: TestALUShiftRight/kernel#01 (0.00s) + --- SKIP: TestALUShiftRight/C#02 (0.04s) + --- SKIP: TestALUShiftRight/eBPF#02 (0.00s) + --- PASS: TestALUShiftRight/kernel#02 (0.00s) + --- SKIP: TestALUShiftRight/C#03 (0.04s) + --- SKIP: TestALUShiftRight/eBPF#03 (0.00s) + --- PASS: TestALUShiftRight/kernel#03 (0.00s) +=== RUN TestLoadIndirect/variable_valid/C#02 +=== RUN TestJumpIfLessThan/C#07 +=== RUN TestJumpIfBitsNotSet/eBPF#11 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 6 - 3: JEqImm dst: r4 off: -1 imm: 0 - filter_block_2: - 4: JSetImm dst: r4 off: -1 imm: 8 - 5: JaImm dst: r0 off: -1 imm: 0 + 3: Mov32Imm dst: r5 imm: 8 + 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: - 6: Mov32Imm dst: r4 imm: 1 - 7: JaImm dst: r0 off: -1 imm: 0 + 5: JSetReg dst: r4 off: -1 src: r5 + 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: - 8: Mov32Imm dst: r4 imm: 0 - 9: JaImm dst: r0 off: -1 imm: 0 + 7: Mov32Imm dst: r4 imm: 1 + 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: - 10: Mov32Imm dst: r4 imm: 1 - 11: JaImm dst: r0 off: -1 imm: 0 + 9: Mov32Imm dst: r4 imm: 0 + 10: JaImm dst: r0 off: -1 imm: 0 + filter_block_6: + 11: Mov32Imm dst: r4 imm: 1 + 12: JaImm dst: r0 off: -1 imm: 0 result: - 12: MovImm dst: r0 imm: 2 - 13: JEqImm dst: r4 off: -1 imm: 0 - 14: MovImm dst: r0 imm: 1 + 13: MovImm dst: r0 imm: 2 + 14: JEqImm dst: r4 off: -1 imm: 0 + 15: MovImm dst: r0 imm: 1 return: - 15: Exit -=== RUN TestJumpIfBitsSet/kernel#09 -=== RUN TestLoadAbsoluteBigOffset/C#07 + 16: Exit +=== RUN TestJumpIfBitsNotSet/kernel#11 +--- PASS: TestJumpIfBitsNotSet (0.93s) + --- SKIP: TestJumpIfBitsNotSet/C (0.11s) + --- SKIP: TestJumpIfBitsNotSet/eBPF (0.00s) + --- PASS: TestJumpIfBitsNotSet/kernel (0.05s) + --- SKIP: TestJumpIfBitsNotSet/C#01 (0.04s) + --- SKIP: TestJumpIfBitsNotSet/eBPF#01 (0.00s) + --- PASS: TestJumpIfBitsNotSet/kernel#01 (0.05s) + --- SKIP: TestJumpIfBitsNotSet/C#02 (0.03s) + --- SKIP: TestJumpIfBitsNotSet/eBPF#02 (0.00s) + --- PASS: TestJumpIfBitsNotSet/kernel#02 (0.05s) + --- SKIP: TestJumpIfBitsNotSet/C#03 (0.04s) + --- SKIP: TestJumpIfBitsNotSet/eBPF#03 (0.00s) + --- PASS: TestJumpIfBitsNotSet/kernel#03 (0.05s) + --- SKIP: TestJumpIfBitsNotSet/C#04 (0.03s) + --- SKIP: TestJumpIfBitsNotSet/eBPF#04 (0.00s) + --- PASS: TestJumpIfBitsNotSet/kernel#04 (0.05s) + --- SKIP: TestJumpIfBitsNotSet/C#05 (0.04s) + --- SKIP: TestJumpIfBitsNotSet/eBPF#05 (0.00s) + --- PASS: TestJumpIfBitsNotSet/kernel#05 (0.05s) + --- SKIP: TestJumpIfBitsNotSet/C#06 (0.03s) + --- SKIP: TestJumpIfBitsNotSet/eBPF#06 (0.00s) + --- PASS: TestJumpIfBitsNotSet/kernel#06 (0.05s) + --- SKIP: TestJumpIfBitsNotSet/C#07 (0.04s) + --- SKIP: TestJumpIfBitsNotSet/eBPF#07 (0.00s) + --- PASS: TestJumpIfBitsNotSet/kernel#07 (0.05s) + --- SKIP: TestJumpIfBitsNotSet/C#08 (0.04s) + --- SKIP: TestJumpIfBitsNotSet/eBPF#08 (0.00s) + --- PASS: TestJumpIfBitsNotSet/kernel#08 (0.00s) + --- SKIP: TestJumpIfBitsNotSet/C#09 (0.03s) + --- SKIP: TestJumpIfBitsNotSet/eBPF#09 (0.00s) + --- PASS: TestJumpIfBitsNotSet/kernel#09 (0.00s) + --- SKIP: TestJumpIfBitsNotSet/C#10 (0.03s) + --- SKIP: TestJumpIfBitsNotSet/eBPF#10 (0.00s) + --- PASS: TestJumpIfBitsNotSet/kernel#10 (0.00s) + --- SKIP: TestJumpIfBitsNotSet/C#11 (0.04s) + --- SKIP: TestJumpIfBitsNotSet/eBPF#11 (0.00s) + --- PASS: TestJumpIfBitsNotSet/kernel#11 (0.00s) +=== RUN TestJumpIfGreaterThan/C#08 +=== RUN TestLoadAbsoluteBigOffset/C#06 === RUN TestLoadIndirect/variable_valid/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 @@ -5769,17 +5977,17 @@ 29: Exit === RUN TestLoadIndirect/variable_valid/kernel#02 === RUN TestLoadIndirect/variable_valid/C#03 -=== RUN TestJumpIfBitsNotSet/eBPF#07 +=== RUN TestJumpIfLessThan/eBPF#07 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 6 - 3: Mov32Imm dst: r5 imm: 2 + 2: Mov32Imm dst: r4 imm: 23 + 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: - 5: JSetReg dst: r4 off: -1 src: r5 - 6: JaImm dst: r0 off: -1 imm: 0 + 5: JLTReg dst: r4 off: -1 src: r5 + 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 @@ -5795,52 +6003,55 @@ 15: MovImm dst: r0 imm: 1 return: 16: Exit -=== RUN TestJumpIfBitsNotSet/kernel#07 -=== RUN TestJumpIfLessOrEqual/eBPF#09 +=== RUN TestJumpIfLessThan/kernel#07 +=== RUN TestJumpIfGreaterThan/eBPF#08 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 - 3: JEqImm dst: r4 off: -1 imm: 0 + 3: JGTImm dst: r4 off: -1 imm: 23 filter_block_2: - 4: JLEImm dst: r4 off: -1 imm: 23 - 5: JaImm dst: r0 off: -1 imm: 0 + 4: Mov32Imm dst: r4 imm: 0 + 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 - filter_block_4: - 8: Mov32Imm dst: r4 imm: 0 - 9: JaImm dst: r0 off: -1 imm: 0 - filter_block_5: - 10: Mov32Imm dst: r4 imm: 1 - 11: JaImm dst: r0 off: -1 imm: 0 result: - 12: MovImm dst: r0 imm: 2 - 13: JEqImm dst: r4 off: -1 imm: 0 - 14: MovImm dst: r0 imm: 1 + 8: MovImm dst: r0 imm: 2 + 9: JEqImm dst: r4 off: -1 imm: 0 + 10: MovImm dst: r0 imm: 1 return: - 15: Exit -=== RUN TestJumpIfLessOrEqual/kernel#09 -=== RUN TestJumpIfLessOrEqual/C#10 -=== RUN TestJumpIfBitsSet/C#10 -=== RUN TestLoadAbsoluteBigOffset/eBPF#07 + 11: Exit +=== RUN TestJumpIfGreaterThan/kernel#08 +=== RUN TestLoadAbsoluteBigOffset/eBPF#06 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 0 - 3: JaImm dst: r0 off: -1 imm: 0 + 2: MovReg dst: r6 src: r2 + 3: AddImm dst: r6 imm: 65535 + 4: JGTReg dst: r6 off: -1 src: r3 + 5: Mov32Imm dst: r4 imm: 0 + 6: MovReg dst: r6 src: r2 + 7: AddImm dst: r6 imm: 65534 + 8: LdXMemB dst: r5 src: r6 off: 0 imm: 0 + 9: And32Imm dst: r5 imm: 15 + 10: LSh32Imm dst: r5 imm: 2 + 11: Add32Imm dst: r4 imm: 2 + 12: Mov32Reg dst: r4 src: r4 + 13: JaImm dst: r0 off: -1 imm: 0 + filter_nomatch: + 14: MovImm dst: r4 imm: 0 + 15: JaImm dst: r0 off: -1 imm: 0 result: - 4: MovImm dst: r0 imm: 2 - 5: JEqImm dst: r4 off: -1 imm: 0 - 6: MovImm dst: r0 imm: 1 + 16: MovImm dst: r0 imm: 2 + 17: JEqImm dst: r4 off: -1 imm: 0 + 18: MovImm dst: r0 imm: 1 return: - 7: Exit -=== RUN TestLoadAbsoluteBigOffset/kernel#07 + 19: Exit +=== RUN TestLoadAbsoluteBigOffset/kernel#06 === RUN TestLoadIndirect/variable_valid/eBPF#03 -=== RUN TestJumpIfGreaterOrEqual/eBPF#09 -=== NAME TestLoadIndirect/variable_valid/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 @@ -5879,199 +6090,41 @@ return: 29: Exit === RUN TestLoadIndirect/variable_valid/kernel#03 -=== NAME TestJumpIfGreaterOrEqual/eBPF#09 +=== RUN TestJumpIfLessThan/C#08 +=== RUN TestJumpIfGreaterThan/C#09 +=== RUN TestLoadAbsoluteBigOffset/C#07 +=== RUN TestLoadIndirect/variable_valid/C#04 +=== RUN TestJumpIfLessThan/eBPF#08 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 - 3: JEqImm dst: r4 off: -1 imm: 0 + 3: JLTImm dst: r4 off: -1 imm: 23 filter_block_2: - 4: JGEImm dst: r4 off: -1 imm: 23 - 5: JaImm dst: r0 off: -1 imm: 0 + 4: Mov32Imm dst: r4 imm: 0 + 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 - filter_block_4: - 8: Mov32Imm dst: r4 imm: 0 - 9: JaImm dst: r0 off: -1 imm: 0 - filter_block_5: - 10: Mov32Imm dst: r4 imm: 1 - 11: JaImm dst: r0 off: -1 imm: 0 - result: - 12: MovImm dst: r0 imm: 2 - 13: JEqImm dst: r4 off: -1 imm: 0 - 14: MovImm dst: r0 imm: 1 - return: - 15: Exit -=== RUN TestJumpIfGreaterOrEqual/kernel#09 -=== RUN TestJumpIfBitsNotSet/C#08 -=== RUN TestJumpIfLessOrEqual/eBPF#10 - ebpf_test.go:17: - 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 - 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 - filter_block_0: - 2: Mov32Imm dst: r4 imm: 22 - 3: Mov32Imm dst: r5 imm: 23 - 4: JLEReg dst: r4 off: -1 src: r5 - filter_block_3: - 5: Mov32Imm dst: r4 imm: 0 - 6: JaImm dst: r0 off: -1 imm: 0 - filter_block_4: - 7: Mov32Imm dst: r4 imm: 1 - 8: JaImm dst: r0 off: -1 imm: 0 result: - 9: MovImm dst: r0 imm: 2 - 10: JEqImm dst: r4 off: -1 imm: 0 - 11: MovImm dst: r0 imm: 1 - return: - 12: Exit -=== RUN TestJumpIfLessOrEqual/kernel#10 -=== RUN TestJumpIfLessOrEqual/C#11 -=== RUN TestJumpIfBitsSet/eBPF#10 - ebpf_test.go:17: - 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 - 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 - filter_block_0: - 2: Mov32Imm dst: r4 imm: 6 - 3: Mov32Imm dst: r5 imm: 8 - 4: JSetReg dst: r4 off: -1 src: r5 - filter_block_3: - 5: Mov32Imm dst: r4 imm: 0 - 6: JaImm dst: r0 off: -1 imm: 0 - filter_block_4: - 7: Mov32Imm dst: r4 imm: 1 - 8: JaImm dst: r0 off: -1 imm: 0 - result: - 9: MovImm dst: r0 imm: 2 - 10: JEqImm dst: r4 off: -1 imm: 0 - 11: MovImm dst: r0 imm: 1 - return: - 12: Exit -=== RUN TestJumpIfBitsSet/kernel#10 -=== RUN TestJumpIfBitsNotSet/eBPF#08 - ebpf_test.go:17: - 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 - 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 - filter_block_0: - 2: Mov32Imm dst: r4 imm: 6 - 3: JSetImm dst: r4 off: -1 imm: 8 - 4: JaImm dst: r0 off: -1 imm: 0 - filter_block_2: - 5: Mov32Imm dst: r4 imm: 0 - 6: JaImm dst: r0 off: -1 imm: 0 - filter_block_3: - 7: Mov32Imm dst: r4 imm: 1 - 8: JaImm dst: r0 off: -1 imm: 0 - result: - 9: MovImm dst: r0 imm: 2 - 10: JEqImm dst: r4 off: -1 imm: 0 - 11: MovImm dst: r0 imm: 1 + 8: MovImm dst: r0 imm: 2 + 9: JEqImm dst: r4 off: -1 imm: 0 + 10: MovImm dst: r0 imm: 1 return: - 12: Exit -=== RUN TestJumpIfBitsNotSet/kernel#08 -=== RUN TestJumpIfBitsNotSet/C#09 -=== RUN TestJumpIfLessOrEqual/eBPF#11 + 11: Exit +=== RUN TestJumpIfLessThan/kernel#08 +=== RUN TestJumpIfLessThan/C#09 +=== RUN TestJumpIfGreaterThan/eBPF#09 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 - 3: Mov32Imm dst: r5 imm: 23 - 4: JEqImm dst: r4 off: -1 imm: 0 - filter_block_3: - 5: JLEReg dst: r4 off: -1 src: r5 - 6: JaImm dst: r0 off: -1 imm: 0 - filter_block_4: - 7: Mov32Imm dst: r4 imm: 1 - 8: JaImm dst: r0 off: -1 imm: 0 - filter_block_5: - 9: Mov32Imm dst: r4 imm: 0 - 10: JaImm dst: r0 off: -1 imm: 0 - filter_block_6: - 11: Mov32Imm dst: r4 imm: 1 - 12: JaImm dst: r0 off: -1 imm: 0 - result: - 13: MovImm dst: r0 imm: 2 - 14: JEqImm dst: r4 off: -1 imm: 0 - 15: MovImm dst: r0 imm: 1 - return: - 16: Exit ---- PASS: TestLoadAbsoluteBigOffset (1.00s) - --- SKIP: TestLoadAbsoluteBigOffset/C (0.10s) - --- SKIP: TestLoadAbsoluteBigOffset/eBPF (0.00s) - --- PASS: TestLoadAbsoluteBigOffset/kernel (0.05s) - --- SKIP: TestLoadAbsoluteBigOffset/C#01 (0.06s) - --- SKIP: TestLoadAbsoluteBigOffset/eBPF#01 (0.00s) - --- PASS: TestLoadAbsoluteBigOffset/kernel#01 (0.05s) - --- SKIP: TestLoadAbsoluteBigOffset/C#02 (0.08s) - --- SKIP: TestLoadAbsoluteBigOffset/eBPF#02 (0.00s) - --- PASS: TestLoadAbsoluteBigOffset/kernel#02 (0.07s) - --- SKIP: TestLoadAbsoluteBigOffset/C#03 (0.08s) - --- SKIP: TestLoadAbsoluteBigOffset/eBPF#03 (0.00s) - --- PASS: TestLoadAbsoluteBigOffset/kernel#03 (0.07s) - --- SKIP: TestLoadAbsoluteBigOffset/C#04 (0.07s) - --- SKIP: TestLoadAbsoluteBigOffset/eBPF#04 (0.00s) - --- PASS: TestLoadAbsoluteBigOffset/kernel#04 (0.05s) - --- SKIP: TestLoadAbsoluteBigOffset/C#05 (0.05s) - --- SKIP: TestLoadAbsoluteBigOffset/eBPF#05 (0.00s) - --- PASS: TestLoadAbsoluteBigOffset/kernel#05 (0.05s) - --- SKIP: TestLoadAbsoluteBigOffset/C#06 (0.03s) - --- SKIP: TestLoadAbsoluteBigOffset/eBPF#06 (0.00s) - --- PASS: TestLoadAbsoluteBigOffset/kernel#06 (0.05s) - --- SKIP: TestLoadAbsoluteBigOffset/C#07 (0.06s) - --- SKIP: TestLoadAbsoluteBigOffset/eBPF#07 (0.00s) - --- PASS: TestLoadAbsoluteBigOffset/kernel#07 (0.05s) -=== RUN TestJumpIfLessOrEqual/kernel#11 ---- PASS: TestJumpIfLessOrEqual (0.85s) - --- SKIP: TestJumpIfLessOrEqual/C (0.12s) - --- SKIP: TestJumpIfLessOrEqual/eBPF (0.00s) - --- PASS: TestJumpIfLessOrEqual/kernel (0.05s) - --- SKIP: TestJumpIfLessOrEqual/C#01 (0.09s) - --- SKIP: TestJumpIfLessOrEqual/eBPF#01 (0.00s) - --- PASS: TestJumpIfLessOrEqual/kernel#01 (0.05s) - --- SKIP: TestJumpIfLessOrEqual/C#02 (0.06s) - --- SKIP: TestJumpIfLessOrEqual/eBPF#02 (0.00s) - --- PASS: TestJumpIfLessOrEqual/kernel#02 (0.05s) - --- SKIP: TestJumpIfLessOrEqual/C#03 (0.04s) - --- SKIP: TestJumpIfLessOrEqual/eBPF#03 (0.00s) - --- PASS: TestJumpIfLessOrEqual/kernel#03 (0.05s) - --- SKIP: TestJumpIfLessOrEqual/C#04 (0.04s) - --- SKIP: TestJumpIfLessOrEqual/eBPF#04 (0.00s) - --- PASS: TestJumpIfLessOrEqual/kernel#04 (0.00s) - --- SKIP: TestJumpIfLessOrEqual/C#05 (0.04s) - --- SKIP: TestJumpIfLessOrEqual/eBPF#05 (0.00s) - --- PASS: TestJumpIfLessOrEqual/kernel#05 (0.00s) - --- SKIP: TestJumpIfLessOrEqual/C#06 (0.05s) - --- SKIP: TestJumpIfLessOrEqual/eBPF#06 (0.00s) - --- PASS: TestJumpIfLessOrEqual/kernel#06 (0.00s) - --- SKIP: TestJumpIfLessOrEqual/C#07 (0.04s) - --- SKIP: TestJumpIfLessOrEqual/eBPF#07 (0.00s) - --- PASS: TestJumpIfLessOrEqual/kernel#07 (0.00s) - --- SKIP: TestJumpIfLessOrEqual/C#08 (0.03s) - --- SKIP: TestJumpIfLessOrEqual/eBPF#08 (0.00s) - --- PASS: TestJumpIfLessOrEqual/kernel#08 (0.00s) - --- SKIP: TestJumpIfLessOrEqual/C#09 (0.06s) - --- SKIP: TestJumpIfLessOrEqual/eBPF#09 (0.00s) - --- PASS: TestJumpIfLessOrEqual/kernel#09 (0.00s) - --- SKIP: TestJumpIfLessOrEqual/C#10 (0.04s) - --- SKIP: TestJumpIfLessOrEqual/eBPF#10 (0.00s) - --- PASS: TestJumpIfLessOrEqual/kernel#10 (0.00s) - --- SKIP: TestJumpIfLessOrEqual/C#11 (0.03s) - --- SKIP: TestJumpIfLessOrEqual/eBPF#11 (0.00s) - --- PASS: TestJumpIfLessOrEqual/kernel#11 (0.00s) -=== RUN TestJumpIfGreaterOrEqual/C#10 -=== RUN TestLoadIndirect/variable_valid/C#04 -=== RUN TestJumpIfBitsNotSet/eBPF#09 - ebpf_test.go:17: - 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 - 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 - filter_block_0: - 2: Mov32Imm dst: r4 imm: 6 3: JEqImm dst: r4 off: -1 imm: 0 filter_block_2: - 4: JSetImm dst: r4 off: -1 imm: 8 - 5: JaImm dst: r0 off: -1 imm: 0 + 4: JGTImm dst: r4 off: -1 imm: 23 + 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 @@ -6087,9 +6140,21 @@ 14: MovImm dst: r0 imm: 1 return: 15: Exit -=== RUN TestJumpIfBitsNotSet/kernel#09 -=== RUN TestJumpIfBitsNotSet/C#10 -=== RUN TestJumpIfBitsSet/C#11 +=== RUN TestJumpIfGreaterThan/kernel#09 +=== RUN TestLoadAbsoluteBigOffset/eBPF#07 + ebpf_test.go:17: + 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 + 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 + filter_block_0: + 2: Mov32Imm dst: r4 imm: 0 + 3: JaImm dst: r0 off: -1 imm: 0 + result: + 4: MovImm dst: r0 imm: 2 + 5: JEqImm dst: r4 off: -1 imm: 0 + 6: MovImm dst: r0 imm: 1 + return: + 7: Exit +=== RUN TestLoadAbsoluteBigOffset/kernel#07 === RUN TestLoadIndirect/variable_valid/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 @@ -6131,79 +6196,81 @@ 30: Exit === RUN TestLoadIndirect/variable_valid/kernel#04 === RUN TestLoadIndirect/variable_valid/C#05 -=== RUN TestJumpIfGreaterOrEqual/eBPF#10 -=== RUN TestJumpIfBitsNotSet/eBPF#10 -=== NAME TestJumpIfGreaterOrEqual/eBPF#10 +=== RUN TestJumpIfLessThan/eBPF#09 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: 2: Mov32Imm dst: r4 imm: 22 - 3: Mov32Imm dst: r5 imm: 23 - 4: JGEReg dst: r4 off: -1 src: r5 - filter_block_3: - 5: Mov32Imm dst: r4 imm: 0 - 6: JaImm dst: r0 off: -1 imm: 0 - filter_block_4: - 7: Mov32Imm dst: r4 imm: 1 - 8: JaImm dst: r0 off: -1 imm: 0 - result: - 9: MovImm dst: r0 imm: 2 - 10: JEqImm dst: r4 off: -1 imm: 0 - 11: MovImm dst: r0 imm: 1 - return: - 12: Exit -=== RUN TestJumpIfGreaterOrEqual/kernel#10 -=== NAME TestJumpIfBitsNotSet/eBPF#10 - ebpf_test.go:17: - 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 - 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 - filter_block_0: - 2: Mov32Imm dst: r4 imm: 6 - 3: Mov32Imm dst: r5 imm: 8 - 4: JSetReg dst: r4 off: -1 src: r5 + 3: JEqImm dst: r4 off: -1 imm: 0 + filter_block_2: + 4: JLTImm dst: r4 off: -1 imm: 23 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: - 6: Mov32Imm dst: r4 imm: 0 + 6: Mov32Imm dst: r4 imm: 1 7: JaImm dst: r0 off: -1 imm: 0 filter_block_4: - 8: Mov32Imm dst: r4 imm: 1 + 8: Mov32Imm dst: r4 imm: 0 9: JaImm dst: r0 off: -1 imm: 0 + filter_block_5: + 10: Mov32Imm dst: r4 imm: 1 + 11: JaImm dst: r0 off: -1 imm: 0 result: - 10: MovImm dst: r0 imm: 2 - 11: JEqImm dst: r4 off: -1 imm: 0 - 12: MovImm dst: r0 imm: 1 + 12: MovImm dst: r0 imm: 2 + 13: JEqImm dst: r4 off: -1 imm: 0 + 14: MovImm dst: r0 imm: 1 return: - 13: Exit -=== RUN TestJumpIfBitsNotSet/kernel#10 -=== RUN TestJumpIfBitsNotSet/C#11 -=== RUN TestJumpIfBitsSet/eBPF#11 + 15: Exit +=== RUN TestJumpIfLessThan/kernel#09 +=== RUN TestJumpIfLessThan/C#10 +=== RUN TestJumpIfGreaterThan/C#10 +--- PASS: TestLoadAbsoluteBigOffset (0.75s) + --- SKIP: TestLoadAbsoluteBigOffset/C (0.03s) + --- SKIP: TestLoadAbsoluteBigOffset/eBPF (0.00s) + --- PASS: TestLoadAbsoluteBigOffset/kernel (0.05s) + --- SKIP: TestLoadAbsoluteBigOffset/C#01 (0.03s) + --- SKIP: TestLoadAbsoluteBigOffset/eBPF#01 (0.00s) + --- PASS: TestLoadAbsoluteBigOffset/kernel#01 (0.05s) + --- SKIP: TestLoadAbsoluteBigOffset/C#02 (0.04s) + --- SKIP: TestLoadAbsoluteBigOffset/eBPF#02 (0.00s) + --- PASS: TestLoadAbsoluteBigOffset/kernel#02 (0.05s) + --- SKIP: TestLoadAbsoluteBigOffset/C#03 (0.04s) + --- SKIP: TestLoadAbsoluteBigOffset/eBPF#03 (0.00s) + --- PASS: TestLoadAbsoluteBigOffset/kernel#03 (0.05s) + --- SKIP: TestLoadAbsoluteBigOffset/C#04 (0.04s) + --- SKIP: TestLoadAbsoluteBigOffset/eBPF#04 (0.00s) + --- PASS: TestLoadAbsoluteBigOffset/kernel#04 (0.05s) + --- SKIP: TestLoadAbsoluteBigOffset/C#05 (0.03s) + --- SKIP: TestLoadAbsoluteBigOffset/eBPF#05 (0.00s) + --- PASS: TestLoadAbsoluteBigOffset/kernel#05 (0.05s) + --- SKIP: TestLoadAbsoluteBigOffset/C#06 (0.06s) + --- SKIP: TestLoadAbsoluteBigOffset/eBPF#06 (0.00s) + --- PASS: TestLoadAbsoluteBigOffset/kernel#06 (0.05s) + --- SKIP: TestLoadAbsoluteBigOffset/C#07 (0.06s) + --- SKIP: TestLoadAbsoluteBigOffset/eBPF#07 (0.00s) + --- PASS: TestLoadAbsoluteBigOffset/kernel#07 (0.05s) +=== RUN TestJumpIfLessThan/eBPF#10 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 6 - 3: Mov32Imm dst: r5 imm: 8 - 4: JEqImm dst: r4 off: -1 imm: 0 + 2: Mov32Imm dst: r4 imm: 22 + 3: Mov32Imm dst: r5 imm: 23 + 4: JLTReg dst: r4 off: -1 src: r5 filter_block_3: - 5: JSetReg dst: r4 off: -1 src: r5 - 6: JaImm dst: r0 off: -1 imm: 0 + 5: Mov32Imm dst: r4 imm: 0 + 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 - filter_block_5: - 9: Mov32Imm dst: r4 imm: 0 - 10: JaImm dst: r0 off: -1 imm: 0 - filter_block_6: - 11: Mov32Imm dst: r4 imm: 1 - 12: JaImm dst: r0 off: -1 imm: 0 result: - 13: MovImm dst: r0 imm: 2 - 14: JEqImm dst: r4 off: -1 imm: 0 - 15: MovImm dst: r0 imm: 1 + 9: MovImm dst: r0 imm: 2 + 10: JEqImm dst: r4 off: -1 imm: 0 + 11: MovImm dst: r0 imm: 1 return: - 16: Exit -=== RUN TestJumpIfBitsSet/kernel#11 + 12: Exit +=== RUN TestJumpIfLessThan/kernel#10 +=== RUN TestJumpIfLessThan/C#11 === RUN TestLoadIndirect/variable_valid/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 @@ -6244,111 +6311,28 @@ return: 30: Exit === RUN TestLoadIndirect/variable_valid/kernel#05 -=== RUN TestJumpIfBitsNotSet/eBPF#11 +=== RUN TestJumpIfGreaterThan/eBPF#10 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 filter_block_0: - 2: Mov32Imm dst: r4 imm: 6 - 3: Mov32Imm dst: r5 imm: 8 - 4: JEqImm dst: r4 off: -1 imm: 0 + 2: Mov32Imm dst: r4 imm: 22 + 3: Mov32Imm dst: r5 imm: 23 + 4: JGTReg dst: r4 off: -1 src: r5 filter_block_3: - 5: JSetReg dst: r4 off: -1 src: r5 - 6: JaImm dst: r0 off: -1 imm: 0 + 5: Mov32Imm dst: r4 imm: 0 + 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 - filter_block_5: - 9: Mov32Imm dst: r4 imm: 0 - 10: JaImm dst: r0 off: -1 imm: 0 - filter_block_6: - 11: Mov32Imm dst: r4 imm: 1 - 12: JaImm dst: r0 off: -1 imm: 0 result: - 13: MovImm dst: r0 imm: 2 - 14: JEqImm dst: r4 off: -1 imm: 0 - 15: MovImm dst: r0 imm: 1 + 9: MovImm dst: r0 imm: 2 + 10: JEqImm dst: r4 off: -1 imm: 0 + 11: MovImm dst: r0 imm: 1 return: - 16: Exit -=== RUN TestJumpIfBitsNotSet/kernel#11 ---- PASS: TestJumpIfBitsNotSet (1.07s) - --- SKIP: TestJumpIfBitsNotSet/C (0.04s) - --- SKIP: TestJumpIfBitsNotSet/eBPF (0.00s) - --- PASS: TestJumpIfBitsNotSet/kernel (0.05s) - --- SKIP: TestJumpIfBitsNotSet/C#01 (0.09s) - --- SKIP: TestJumpIfBitsNotSet/eBPF#01 (0.00s) - --- PASS: TestJumpIfBitsNotSet/kernel#01 (0.05s) - --- SKIP: TestJumpIfBitsNotSet/C#02 (0.09s) - --- SKIP: TestJumpIfBitsNotSet/eBPF#02 (0.00s) - --- PASS: TestJumpIfBitsNotSet/kernel#02 (0.07s) - --- SKIP: TestJumpIfBitsNotSet/C#03 (0.07s) - --- SKIP: TestJumpIfBitsNotSet/eBPF#03 (0.00s) - --- PASS: TestJumpIfBitsNotSet/kernel#03 (0.05s) - --- SKIP: TestJumpIfBitsNotSet/C#04 (0.06s) - --- SKIP: TestJumpIfBitsNotSet/eBPF#04 (0.00s) - --- PASS: TestJumpIfBitsNotSet/kernel#04 (0.05s) - --- SKIP: TestJumpIfBitsNotSet/C#05 (0.05s) - --- SKIP: TestJumpIfBitsNotSet/eBPF#05 (0.00s) - --- PASS: TestJumpIfBitsNotSet/kernel#05 (0.05s) - --- SKIP: TestJumpIfBitsNotSet/C#06 (0.04s) - --- SKIP: TestJumpIfBitsNotSet/eBPF#06 (0.00s) - --- PASS: TestJumpIfBitsNotSet/kernel#06 (0.05s) - --- SKIP: TestJumpIfBitsNotSet/C#07 (0.06s) - --- SKIP: TestJumpIfBitsNotSet/eBPF#07 (0.00s) - --- PASS: TestJumpIfBitsNotSet/kernel#07 (0.05s) - --- SKIP: TestJumpIfBitsNotSet/C#08 (0.03s) - --- SKIP: TestJumpIfBitsNotSet/eBPF#08 (0.00s) - --- PASS: TestJumpIfBitsNotSet/kernel#08 (0.00s) - --- SKIP: TestJumpIfBitsNotSet/C#09 (0.04s) - --- SKIP: TestJumpIfBitsNotSet/eBPF#09 (0.00s) - --- PASS: TestJumpIfBitsNotSet/kernel#09 (0.00s) - --- SKIP: TestJumpIfBitsNotSet/C#10 (0.04s) - --- SKIP: TestJumpIfBitsNotSet/eBPF#10 (0.00s) - --- PASS: TestJumpIfBitsNotSet/kernel#10 (0.00s) - --- SKIP: TestJumpIfBitsNotSet/C#11 (0.03s) - --- SKIP: TestJumpIfBitsNotSet/eBPF#11 (0.00s) - --- PASS: TestJumpIfBitsNotSet/kernel#11 (0.00s) -=== RUN TestJumpIfGreaterOrEqual/C#11 ---- PASS: TestJumpIfBitsSet (0.93s) - --- SKIP: TestJumpIfBitsSet/C (0.06s) - --- SKIP: TestJumpIfBitsSet/eBPF (0.00s) - --- PASS: TestJumpIfBitsSet/kernel (0.00s) - --- SKIP: TestJumpIfBitsSet/C#01 (0.07s) - --- SKIP: TestJumpIfBitsSet/eBPF#01 (0.00s) - --- PASS: TestJumpIfBitsSet/kernel#01 (0.00s) - --- SKIP: TestJumpIfBitsSet/C#02 (0.09s) - --- SKIP: TestJumpIfBitsSet/eBPF#02 (0.00s) - --- PASS: TestJumpIfBitsSet/kernel#02 (0.00s) - --- SKIP: TestJumpIfBitsSet/C#03 (0.04s) - --- SKIP: TestJumpIfBitsSet/eBPF#03 (0.00s) - --- PASS: TestJumpIfBitsSet/kernel#03 (0.00s) - --- SKIP: TestJumpIfBitsSet/C#04 (0.06s) - --- SKIP: TestJumpIfBitsSet/eBPF#04 (0.00s) - --- PASS: TestJumpIfBitsSet/kernel#04 (0.00s) - --- SKIP: TestJumpIfBitsSet/C#05 (0.05s) - --- SKIP: TestJumpIfBitsSet/eBPF#05 (0.00s) - --- PASS: TestJumpIfBitsSet/kernel#05 (0.00s) - --- SKIP: TestJumpIfBitsSet/C#06 (0.06s) - --- SKIP: TestJumpIfBitsSet/eBPF#06 (0.00s) - --- PASS: TestJumpIfBitsSet/kernel#06 (0.00s) - --- SKIP: TestJumpIfBitsSet/C#07 (0.07s) - --- SKIP: TestJumpIfBitsSet/eBPF#07 (0.00s) - --- PASS: TestJumpIfBitsSet/kernel#07 (0.00s) - --- SKIP: TestJumpIfBitsSet/C#08 (0.04s) - --- SKIP: TestJumpIfBitsSet/eBPF#08 (0.00s) - --- PASS: TestJumpIfBitsSet/kernel#08 (0.05s) - --- SKIP: TestJumpIfBitsSet/C#09 (0.06s) - --- SKIP: TestJumpIfBitsSet/eBPF#09 (0.00s) - --- PASS: TestJumpIfBitsSet/kernel#09 (0.05s) - --- SKIP: TestJumpIfBitsSet/C#10 (0.04s) - --- SKIP: TestJumpIfBitsSet/eBPF#10 (0.00s) - --- PASS: TestJumpIfBitsSet/kernel#10 (0.05s) - --- SKIP: TestJumpIfBitsSet/C#11 (0.03s) - --- SKIP: TestJumpIfBitsSet/eBPF#11 (0.00s) - --- PASS: TestJumpIfBitsSet/kernel#11 (0.05s) -=== RUN TestLoadIndirect/constant_outofbounds -=== RUN TestLoadIndirect/constant_outofbounds/C -=== RUN TestJumpIfGreaterOrEqual/eBPF#11 + 12: Exit +=== RUN TestJumpIfGreaterThan/kernel#10 +=== RUN TestJumpIfLessThan/eBPF#11 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 @@ -6357,7 +6341,7 @@ 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: - 5: JGEReg dst: r4 off: -1 src: r5 + 5: JLTReg dst: r4 off: -1 src: r5 6: JaImm dst: r0 off: -1 imm: 0 filter_block_4: 7: Mov32Imm dst: r4 imm: 1 @@ -6374,7 +6358,47 @@ 15: MovImm dst: r0 imm: 1 return: 16: Exit -=== RUN TestJumpIfGreaterOrEqual/kernel#11 +=== RUN TestJumpIfLessThan/kernel#11 +--- PASS: TestJumpIfLessThan (0.92s) + --- SKIP: TestJumpIfLessThan/C (0.04s) + --- SKIP: TestJumpIfLessThan/eBPF (0.00s) + --- PASS: TestJumpIfLessThan/kernel (0.05s) + --- SKIP: TestJumpIfLessThan/C#01 (0.03s) + --- SKIP: TestJumpIfLessThan/eBPF#01 (0.00s) + --- PASS: TestJumpIfLessThan/kernel#01 (0.05s) + --- SKIP: TestJumpIfLessThan/C#02 (0.03s) + --- SKIP: TestJumpIfLessThan/eBPF#02 (0.00s) + --- PASS: TestJumpIfLessThan/kernel#02 (0.05s) + --- SKIP: TestJumpIfLessThan/C#03 (0.04s) + --- SKIP: TestJumpIfLessThan/eBPF#03 (0.00s) + --- PASS: TestJumpIfLessThan/kernel#03 (0.05s) + --- SKIP: TestJumpIfLessThan/C#04 (0.04s) + --- SKIP: TestJumpIfLessThan/eBPF#04 (0.00s) + --- PASS: TestJumpIfLessThan/kernel#04 (0.05s) + --- SKIP: TestJumpIfLessThan/C#05 (0.03s) + --- SKIP: TestJumpIfLessThan/eBPF#05 (0.00s) + --- PASS: TestJumpIfLessThan/kernel#05 (0.05s) + --- SKIP: TestJumpIfLessThan/C#06 (0.04s) + --- SKIP: TestJumpIfLessThan/eBPF#06 (0.00s) + --- PASS: TestJumpIfLessThan/kernel#06 (0.05s) + --- SKIP: TestJumpIfLessThan/C#07 (0.06s) + --- SKIP: TestJumpIfLessThan/eBPF#07 (0.00s) + --- PASS: TestJumpIfLessThan/kernel#07 (0.05s) + --- SKIP: TestJumpIfLessThan/C#08 (0.06s) + --- SKIP: TestJumpIfLessThan/eBPF#08 (0.00s) + --- PASS: TestJumpIfLessThan/kernel#08 (0.00s) + --- SKIP: TestJumpIfLessThan/C#09 (0.05s) + --- SKIP: TestJumpIfLessThan/eBPF#09 (0.00s) + --- PASS: TestJumpIfLessThan/kernel#09 (0.00s) + --- SKIP: TestJumpIfLessThan/C#10 (0.04s) + --- SKIP: TestJumpIfLessThan/eBPF#10 (0.00s) + --- PASS: TestJumpIfLessThan/kernel#10 (0.00s) + --- SKIP: TestJumpIfLessThan/C#11 (0.04s) + --- SKIP: TestJumpIfLessThan/eBPF#11 (0.00s) + --- PASS: TestJumpIfLessThan/kernel#11 (0.00s) +=== RUN TestLoadIndirect/constant_outofbounds +=== RUN TestLoadIndirect/constant_outofbounds/C +=== RUN TestJumpIfGreaterThan/C#11 === RUN TestLoadIndirect/constant_outofbounds/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 @@ -6404,43 +6428,33 @@ 20: Exit === RUN TestLoadIndirect/constant_outofbounds/kernel === RUN TestLoadIndirect/constant_outofbounds/C#01 ---- PASS: TestJumpIfGreaterOrEqual (0.88s) - --- SKIP: TestJumpIfGreaterOrEqual/C (0.06s) - --- SKIP: TestJumpIfGreaterOrEqual/eBPF (0.00s) - --- PASS: TestJumpIfGreaterOrEqual/kernel (0.00s) - --- SKIP: TestJumpIfGreaterOrEqual/C#01 (0.07s) - --- SKIP: TestJumpIfGreaterOrEqual/eBPF#01 (0.01s) - --- PASS: TestJumpIfGreaterOrEqual/kernel#01 (0.00s) - --- SKIP: TestJumpIfGreaterOrEqual/C#02 (0.07s) - --- SKIP: TestJumpIfGreaterOrEqual/eBPF#02 (0.00s) - --- PASS: TestJumpIfGreaterOrEqual/kernel#02 (0.00s) - --- SKIP: TestJumpIfGreaterOrEqual/C#03 (0.06s) - --- SKIP: TestJumpIfGreaterOrEqual/eBPF#03 (0.00s) - --- PASS: TestJumpIfGreaterOrEqual/kernel#03 (0.00s) - --- SKIP: TestJumpIfGreaterOrEqual/C#04 (0.04s) - --- SKIP: TestJumpIfGreaterOrEqual/eBPF#04 (0.00s) - --- PASS: TestJumpIfGreaterOrEqual/kernel#04 (0.00s) - --- SKIP: TestJumpIfGreaterOrEqual/C#05 (0.06s) - --- SKIP: TestJumpIfGreaterOrEqual/eBPF#05 (0.00s) - --- PASS: TestJumpIfGreaterOrEqual/kernel#05 (0.00s) - --- SKIP: TestJumpIfGreaterOrEqual/C#06 (0.03s) - --- SKIP: TestJumpIfGreaterOrEqual/eBPF#06 (0.00s) - --- PASS: TestJumpIfGreaterOrEqual/kernel#06 (0.00s) - --- SKIP: TestJumpIfGreaterOrEqual/C#07 (0.05s) - --- SKIP: TestJumpIfGreaterOrEqual/eBPF#07 (0.00s) - --- PASS: TestJumpIfGreaterOrEqual/kernel#07 (0.00s) - --- SKIP: TestJumpIfGreaterOrEqual/C#08 (0.03s) - --- SKIP: TestJumpIfGreaterOrEqual/eBPF#08 (0.00s) - --- PASS: TestJumpIfGreaterOrEqual/kernel#08 (0.05s) - --- SKIP: TestJumpIfGreaterOrEqual/C#09 (0.07s) - --- SKIP: TestJumpIfGreaterOrEqual/eBPF#09 (0.00s) - --- PASS: TestJumpIfGreaterOrEqual/kernel#09 (0.05s) - --- SKIP: TestJumpIfGreaterOrEqual/C#10 (0.06s) - --- SKIP: TestJumpIfGreaterOrEqual/eBPF#10 (0.00s) - --- PASS: TestJumpIfGreaterOrEqual/kernel#10 (0.05s) - --- SKIP: TestJumpIfGreaterOrEqual/C#11 (0.03s) - --- SKIP: TestJumpIfGreaterOrEqual/eBPF#11 (0.00s) - --- PASS: TestJumpIfGreaterOrEqual/kernel#11 (0.05s) +=== RUN TestJumpIfGreaterThan/eBPF#11 + ebpf_test.go:17: + 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 + 1: LdXMemW dst: r3 src: r1 off: 4 imm: 0 + filter_block_0: + 2: Mov32Imm dst: r4 imm: 22 + 3: Mov32Imm dst: r5 imm: 23 + 4: JEqImm dst: r4 off: -1 imm: 0 + filter_block_3: + 5: JGTReg dst: r4 off: -1 src: r5 + 6: JaImm dst: r0 off: -1 imm: 0 + filter_block_4: + 7: Mov32Imm dst: r4 imm: 1 + 8: JaImm dst: r0 off: -1 imm: 0 + filter_block_5: + 9: Mov32Imm dst: r4 imm: 0 + 10: JaImm dst: r0 off: -1 imm: 0 + filter_block_6: + 11: Mov32Imm dst: r4 imm: 1 + 12: JaImm dst: r0 off: -1 imm: 0 + result: + 13: MovImm dst: r0 imm: 2 + 14: JEqImm dst: r4 off: -1 imm: 0 + 15: MovImm dst: r0 imm: 1 + return: + 16: Exit +=== RUN TestJumpIfGreaterThan/kernel#11 === RUN TestLoadIndirect/constant_outofbounds/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 @@ -6469,6 +6483,43 @@ return: 20: Exit === RUN TestLoadIndirect/constant_outofbounds/kernel#01 +--- PASS: TestJumpIfGreaterThan (0.94s) + --- SKIP: TestJumpIfGreaterThan/C (0.04s) + --- SKIP: TestJumpIfGreaterThan/eBPF (0.00s) + --- PASS: TestJumpIfGreaterThan/kernel (0.00s) + --- SKIP: TestJumpIfGreaterThan/C#01 (0.04s) + --- SKIP: TestJumpIfGreaterThan/eBPF#01 (0.00s) + --- PASS: TestJumpIfGreaterThan/kernel#01 (0.00s) + --- SKIP: TestJumpIfGreaterThan/C#02 (0.03s) + --- SKIP: TestJumpIfGreaterThan/eBPF#02 (0.00s) + --- PASS: TestJumpIfGreaterThan/kernel#02 (0.00s) + --- SKIP: TestJumpIfGreaterThan/C#03 (0.03s) + --- SKIP: TestJumpIfGreaterThan/eBPF#03 (0.00s) + --- PASS: TestJumpIfGreaterThan/kernel#03 (0.00s) + --- SKIP: TestJumpIfGreaterThan/C#04 (0.03s) + --- SKIP: TestJumpIfGreaterThan/eBPF#04 (0.00s) + --- PASS: TestJumpIfGreaterThan/kernel#04 (0.05s) + --- SKIP: TestJumpIfGreaterThan/C#05 (0.04s) + --- SKIP: TestJumpIfGreaterThan/eBPF#05 (0.00s) + --- PASS: TestJumpIfGreaterThan/kernel#05 (0.05s) + --- SKIP: TestJumpIfGreaterThan/C#06 (0.05s) + --- SKIP: TestJumpIfGreaterThan/eBPF#06 (0.00s) + --- PASS: TestJumpIfGreaterThan/kernel#06 (0.05s) + --- SKIP: TestJumpIfGreaterThan/C#07 (0.05s) + --- SKIP: TestJumpIfGreaterThan/eBPF#07 (0.00s) + --- PASS: TestJumpIfGreaterThan/kernel#07 (0.05s) + --- SKIP: TestJumpIfGreaterThan/C#08 (0.04s) + --- SKIP: TestJumpIfGreaterThan/eBPF#08 (0.00s) + --- PASS: TestJumpIfGreaterThan/kernel#08 (0.05s) + --- SKIP: TestJumpIfGreaterThan/C#09 (0.06s) + --- SKIP: TestJumpIfGreaterThan/eBPF#09 (0.00s) + --- PASS: TestJumpIfGreaterThan/kernel#09 (0.05s) + --- SKIP: TestJumpIfGreaterThan/C#10 (0.06s) + --- SKIP: TestJumpIfGreaterThan/eBPF#10 (0.00s) + --- PASS: TestJumpIfGreaterThan/kernel#10 (0.05s) + --- SKIP: TestJumpIfGreaterThan/C#11 (0.06s) + --- SKIP: TestJumpIfGreaterThan/eBPF#11 (0.00s) + --- PASS: TestJumpIfGreaterThan/kernel#11 (0.05s) === RUN TestLoadIndirect/constant_outofbounds/C#02 === RUN TestLoadIndirect/constant_outofbounds/eBPF#02 ebpf_test.go:17: @@ -6731,79 +6782,79 @@ return: 25: Exit === RUN TestLoadIndirect/variable_outofbounds/kernel#04 ---- PASS: TestLoadIndirect (1.97s) - --- PASS: TestLoadIndirect/constant_valid (0.63s) - --- SKIP: TestLoadIndirect/constant_valid/C (0.05s) +--- PASS: TestLoadIndirect (1.88s) + --- PASS: TestLoadIndirect/constant_valid (0.38s) + --- SKIP: TestLoadIndirect/constant_valid/C (0.04s) --- SKIP: TestLoadIndirect/constant_valid/eBPF (0.00s) --- PASS: TestLoadIndirect/constant_valid/kernel (0.00s) - --- SKIP: TestLoadIndirect/constant_valid/C#01 (0.06s) + --- SKIP: TestLoadIndirect/constant_valid/C#01 (0.04s) --- SKIP: TestLoadIndirect/constant_valid/eBPF#01 (0.00s) - --- PASS: TestLoadIndirect/constant_valid/kernel#01 (0.06s) - --- SKIP: TestLoadIndirect/constant_valid/C#02 (0.07s) + --- PASS: TestLoadIndirect/constant_valid/kernel#01 (0.05s) + --- SKIP: TestLoadIndirect/constant_valid/C#02 (0.04s) --- SKIP: TestLoadIndirect/constant_valid/eBPF#02 (0.00s) --- PASS: TestLoadIndirect/constant_valid/kernel#02 (0.00s) - --- SKIP: TestLoadIndirect/constant_valid/C#03 (0.06s) + --- SKIP: TestLoadIndirect/constant_valid/C#03 (0.04s) --- SKIP: TestLoadIndirect/constant_valid/eBPF#03 (0.00s) - --- PASS: TestLoadIndirect/constant_valid/kernel#03 (0.06s) - --- SKIP: TestLoadIndirect/constant_valid/C#04 (0.10s) + --- PASS: TestLoadIndirect/constant_valid/kernel#03 (0.05s) + --- SKIP: TestLoadIndirect/constant_valid/C#04 (0.04s) --- SKIP: TestLoadIndirect/constant_valid/eBPF#04 (0.00s) --- PASS: TestLoadIndirect/constant_valid/kernel#04 (0.00s) - --- SKIP: TestLoadIndirect/constant_valid/C#05 (0.06s) + --- SKIP: TestLoadIndirect/constant_valid/C#05 (0.04s) --- SKIP: TestLoadIndirect/constant_valid/eBPF#05 (0.00s) --- PASS: TestLoadIndirect/constant_valid/kernel#05 (0.05s) - --- PASS: TestLoadIndirect/variable_valid (0.49s) - --- SKIP: TestLoadIndirect/variable_valid/C (0.07s) + --- PASS: TestLoadIndirect/variable_valid (0.47s) + --- SKIP: TestLoadIndirect/variable_valid/C (0.04s) --- SKIP: TestLoadIndirect/variable_valid/eBPF (0.00s) --- PASS: TestLoadIndirect/variable_valid/kernel (0.00s) - --- SKIP: TestLoadIndirect/variable_valid/C#01 (0.09s) + --- SKIP: TestLoadIndirect/variable_valid/C#01 (0.04s) --- SKIP: TestLoadIndirect/variable_valid/eBPF#01 (0.00s) --- PASS: TestLoadIndirect/variable_valid/kernel#01 (0.05s) --- SKIP: TestLoadIndirect/variable_valid/C#02 (0.04s) --- SKIP: TestLoadIndirect/variable_valid/eBPF#02 (0.00s) --- PASS: TestLoadIndirect/variable_valid/kernel#02 (0.00s) - --- SKIP: TestLoadIndirect/variable_valid/C#03 (0.05s) + --- SKIP: TestLoadIndirect/variable_valid/C#03 (0.06s) --- SKIP: TestLoadIndirect/variable_valid/eBPF#03 (0.00s) --- PASS: TestLoadIndirect/variable_valid/kernel#03 (0.05s) - --- SKIP: TestLoadIndirect/variable_valid/C#04 (0.05s) + --- SKIP: TestLoadIndirect/variable_valid/C#04 (0.06s) --- SKIP: TestLoadIndirect/variable_valid/eBPF#04 (0.00s) --- PASS: TestLoadIndirect/variable_valid/kernel#04 (0.00s) - --- SKIP: TestLoadIndirect/variable_valid/C#05 (0.03s) + --- SKIP: TestLoadIndirect/variable_valid/C#05 (0.06s) --- SKIP: TestLoadIndirect/variable_valid/eBPF#05 (0.00s) --- PASS: TestLoadIndirect/variable_valid/kernel#05 (0.05s) - --- PASS: TestLoadIndirect/constant_outofbounds (0.37s) - --- SKIP: TestLoadIndirect/constant_outofbounds/C (0.03s) + --- PASS: TestLoadIndirect/constant_outofbounds (0.48s) + --- SKIP: TestLoadIndirect/constant_outofbounds/C (0.05s) --- SKIP: TestLoadIndirect/constant_outofbounds/eBPF (0.00s) --- PASS: TestLoadIndirect/constant_outofbounds/kernel (0.00s) - --- SKIP: TestLoadIndirect/constant_outofbounds/C#01 (0.03s) + --- SKIP: TestLoadIndirect/constant_outofbounds/C#01 (0.04s) --- SKIP: TestLoadIndirect/constant_outofbounds/eBPF#01 (0.00s) --- PASS: TestLoadIndirect/constant_outofbounds/kernel#01 (0.05s) - --- SKIP: TestLoadIndirect/constant_outofbounds/C#02 (0.03s) + --- SKIP: TestLoadIndirect/constant_outofbounds/C#02 (0.06s) --- SKIP: TestLoadIndirect/constant_outofbounds/eBPF#02 (0.00s) --- PASS: TestLoadIndirect/constant_outofbounds/kernel#02 (0.05s) - --- SKIP: TestLoadIndirect/constant_outofbounds/C#03 (0.03s) + --- SKIP: TestLoadIndirect/constant_outofbounds/C#03 (0.06s) --- SKIP: TestLoadIndirect/constant_outofbounds/eBPF#03 (0.00s) --- PASS: TestLoadIndirect/constant_outofbounds/kernel#03 (0.05s) - --- SKIP: TestLoadIndirect/constant_outofbounds/C#04 (0.03s) + --- SKIP: TestLoadIndirect/constant_outofbounds/C#04 (0.07s) --- SKIP: TestLoadIndirect/constant_outofbounds/eBPF#04 (0.00s) --- PASS: TestLoadIndirect/constant_outofbounds/kernel#04 (0.05s) - --- PASS: TestLoadIndirect/variable_outofbounds (0.45s) - --- SKIP: TestLoadIndirect/variable_outofbounds/C (0.04s) + --- PASS: TestLoadIndirect/variable_outofbounds (0.55s) + --- SKIP: TestLoadIndirect/variable_outofbounds/C (0.07s) --- SKIP: TestLoadIndirect/variable_outofbounds/eBPF (0.00s) --- PASS: TestLoadIndirect/variable_outofbounds/kernel (0.00s) - --- SKIP: TestLoadIndirect/variable_outofbounds/C#01 (0.04s) + --- SKIP: TestLoadIndirect/variable_outofbounds/C#01 (0.07s) --- SKIP: TestLoadIndirect/variable_outofbounds/eBPF#01 (0.00s) --- PASS: TestLoadIndirect/variable_outofbounds/kernel#01 (0.05s) - --- SKIP: TestLoadIndirect/variable_outofbounds/C#02 (0.04s) + --- SKIP: TestLoadIndirect/variable_outofbounds/C#02 (0.07s) --- SKIP: TestLoadIndirect/variable_outofbounds/eBPF#02 (0.00s) --- PASS: TestLoadIndirect/variable_outofbounds/kernel#02 (0.05s) - --- SKIP: TestLoadIndirect/variable_outofbounds/C#03 (0.06s) + --- SKIP: TestLoadIndirect/variable_outofbounds/C#03 (0.07s) --- SKIP: TestLoadIndirect/variable_outofbounds/eBPF#03 (0.00s) --- PASS: TestLoadIndirect/variable_outofbounds/kernel#03 (0.05s) - --- SKIP: TestLoadIndirect/variable_outofbounds/C#04 (0.06s) + --- SKIP: TestLoadIndirect/variable_outofbounds/C#04 (0.07s) --- SKIP: TestLoadIndirect/variable_outofbounds/eBPF#04 (0.00s) --- PASS: TestLoadIndirect/variable_outofbounds/kernel#04 (0.05s) PASS -ok github.com/cloudflare/cbpfc 3.623s +ok github.com/cloudflare/cbpfc 3.566s ? github.com/cloudflare/cbpfc/clang [no test files] make[1]: Leaving directory '/build/reproducible-path/golang-github-cloudflare-cbpfc-0.0~git20231012.992ed75' create-stamp debian/debhelper-build-stamp @@ -6832,12 +6883,14 @@ dpkg-buildpackage: info: binary-only upload (no source included) dpkg-genchanges: info: not including original source code in upload I: copying local configuration +I: user script /srv/workspace/pbuilder/2844666/tmp/hooks/B01_cleanup starting +I: user script /srv/workspace/pbuilder/2844666/tmp/hooks/B01_cleanup finished I: unmounting dev/ptmx filesystem I: unmounting dev/pts filesystem I: unmounting dev/shm filesystem I: unmounting proc filesystem I: unmounting sys filesystem I: cleaning the build env -I: removing directory /srv/workspace/pbuilder/2165263 and its subdirectories -I: Current time: Fri Feb 21 21:06:49 -12 2025 -I: pbuilder-time-stamp: 1740215209 +I: removing directory /srv/workspace/pbuilder/2844666 and its subdirectories +I: Current time: Sat Mar 28 05:30:45 +14 2026 +I: pbuilder-time-stamp: 1774625445 Compressing the 2nd log... /var/lib/jenkins/userContent/reproducible/debian/logdiffs/trixie/arm64/golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.diff: 92.0% -- replaced with /var/lib/jenkins/userContent/reproducible/debian/logdiffs/trixie/arm64/golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.diff.gz b2/build.log: 92.7% -- replaced with stdout Compressing the 1st log... b1/build.log: 93.0% -- replaced with stdout Sat Feb 22 09:07:48 UTC 2025 I: diffoscope 289 will be used to compare the two builds: ++ date -u +%s + DIFFOSCOPE_STAMP=/var/log/reproducible-builds/diffoscope_stamp_golang-github-cloudflare-cbpfc_trixie_arm64_1740215268 + touch /var/log/reproducible-builds/diffoscope_stamp_golang-github-cloudflare-cbpfc_trixie_arm64_1740215268 + RESULT=0 + systemd-run '--description=diffoscope on golang-github-cloudflare-cbpfc/0.0~git20231012.992ed75-2 in trixie/arm64' --slice=rb-build-diffoscope.slice -u rb-diffoscope-arm64_11-85051 '--property=SuccessExitStatus=1 124' --user --send-sighup --pipe --wait -E TMPDIR timeout 155m nice schroot --directory /srv/reproducible-results/rbuild-debian/r-b-build.bvEh5Q9U --run-session -c jenkins-reproducible-trixie-diffoscope-78231703-2c24-4dec-a40a-a7b40ea6c9ae -- sh -c 'export TMPDIR=/srv/reproducible-results/rbuild-debian/r-b-build.bvEh5Q9U/dbd-tmp-iHseyfG ; timeout 150m diffoscope --timeout 7200 --html /srv/reproducible-results/rbuild-debian/r-b-build.bvEh5Q9U/golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.diffoscope.html --text /srv/reproducible-results/rbuild-debian/r-b-build.bvEh5Q9U/golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.diffoscope.txt --json /srv/reproducible-results/rbuild-debian/r-b-build.bvEh5Q9U/golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.diffoscope.json --profile=- /srv/reproducible-results/rbuild-debian/r-b-build.bvEh5Q9U/b1/golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_arm64.changes /srv/reproducible-results/rbuild-debian/r-b-build.bvEh5Q9U/b2/golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_arm64.changes' + false + set +x Running as unit: rb-diffoscope-arm64_11-85051.service # Profiling output for: /usr/bin/diffoscope --timeout 7200 --html /srv/reproducible-results/rbuild-debian/r-b-build.bvEh5Q9U/golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.diffoscope.html --text /srv/reproducible-results/rbuild-debian/r-b-build.bvEh5Q9U/golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.diffoscope.txt --json /srv/reproducible-results/rbuild-debian/r-b-build.bvEh5Q9U/golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.diffoscope.json --profile=- /srv/reproducible-results/rbuild-debian/r-b-build.bvEh5Q9U/b1/golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_arm64.changes /srv/reproducible-results/rbuild-debian/r-b-build.bvEh5Q9U/b2/golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_arm64.changes ## command (total time: 0.000s) 0.000s 1 call cmp (internal) ## has_same_content_as (total time: 0.000s) 0.000s 1 call diffoscope.comparators.binary.FilesystemFile ## main (total time: 0.003s) 0.003s 2 calls outputs 0.000s 1 call cleanup Finished with result: success Main processes terminated with: code=exited/status=0 Service runtime: 223ms CPU time consumed: 224ms _ _ _ _ _ __ _ ___ | | __ _ _ __ __ _ __ _(_) |_| |__ _ _| |__ / _` |/ _ \| |/ _` | '_ \ / _` |_____ / _` | | __| '_ \| | | | '_ \ _____ | (_| | (_) | | (_| | | | | (_| |_____| (_| | | |_| | | | |_| | |_) |_____| \__, |\___/|_|\__,_|_| |_|\__, | \__, |_|\__|_| |_|\__,_|_.__/ |___/ |___/ |___/ _ _ __ _ _ __ ___| | ___ _ _ __| |/ _| | __ _ _ __ ___ ___| |__ _ __ / _| ___ / __| |/ _ \| | | |/ _` | |_| |/ _` | '__/ _ \_____ / __| '_ \| '_ \| |_ / __| | (__| | (_) | |_| | (_| | _| | (_| | | | __/_____| (__| |_) | |_) | _| (__ \___|_|\___/ \__,_|\__,_|_| |_|\__,_|_| \___| \___|_.__/| .__/|_| \___| |_| Sat Feb 22 09:07:49 UTC 2025 I: diffoscope 289 found no differences in the changes files, and a .buildinfo file also exists. Sat Feb 22 09:07:49 UTC 2025 I: golang-github-cloudflare-cbpfc from trixie built successfully and reproducibly on arm64. INSERT 0 1 INSERT 0 1 DELETE 1 [2025-02-22 09:07:50] INFO: Starting at 2025-02-22 09:07:50.105047 [2025-02-22 09:07:50] INFO: Generating the pages of 1 package(s) [2025-02-22 09:07:50] CRITICAL: https://tests.reproducible-builds.org/debian/trixie/arm64/golang-github-cloudflare-cbpfc didn't produce a buildlog, even though it has been built. [2025-02-22 09:07:50] INFO: Finished at 2025-02-22 09:07:50.273679, took: 0:00:00.168640 Sat Feb 22 09:07:50 UTC 2025 - successfully updated the database and updated https://tests.reproducible-builds.org/debian/rb-pkg/trixie/arm64/golang-github-cloudflare-cbpfc.html Sat Feb 22 09:07:50 UTC 2025 I: Submitting .buildinfo files to external archives: Sat Feb 22 09:07:50 UTC 2025 I: Submitting 8.0K b1/golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_arm64.buildinfo.asc https://buildinfo.debian.net/8c508c2b3171e5724769b1dec2ab66912b41ac57/golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_all Sat Feb 22 09:07:52 UTC 2025 I: Submitting 8.0K b2/golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_arm64.buildinfo.asc https://buildinfo.debian.net/d3b2e0667478b6ffdb8b4ac99f2c62295cfc4015/golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_all Sat Feb 22 09:07:55 UTC 2025 I: Done submitting .buildinfo files to http://buildinfo.debian.net/api/submit. Sat Feb 22 09:07:55 UTC 2025 I: Done submitting .buildinfo files. Sat Feb 22 09:07:55 UTC 2025 I: Removing signed golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_arm64.buildinfo.asc files: removed './b1/golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_arm64.buildinfo.asc' removed './b2/golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2_arm64.buildinfo.asc' 1740215275 arm64 trixie golang-github-cloudflare-cbpfc Starting cleanup. /var/lib/jenkins/userContent/reproducible/debian/rbuild/trixie/arm64/golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.rbuild.log: 92.1% -- replaced with /var/lib/jenkins/userContent/reproducible/debian/rbuild/trixie/arm64/golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.rbuild.log.gz [2025-02-22 09:07:55] INFO: Starting at 2025-02-22 09:07:55.785067 [2025-02-22 09:07:55] INFO: Generating the pages of 1 package(s) [2025-02-22 09:07:56] INFO: Finished at 2025-02-22 09:07:56.205172, took: 0:00:00.420122 All cleanup done. Sat Feb 22 09:07:56 UTC 2025 - total duration: 0h 2m 5s. Sat Feb 22 09:07:56 UTC 2025 - reproducible_build.sh stopped running as /tmp/jenkins-script-ZTsFaq1t, removing. Finished with result: success Main processes terminated with: code=exited/status=0 Service runtime: 2min 12.189s CPU time consumed: 7.280s