Diff of the two buildlogs: -- --- b1/build.log 2024-07-10 03:46:50.296638726 +0000 +++ b2/build.log 2024-07-10 03:49:22.422188258 +0000 @@ -1,6 +1,6 @@ I: pbuilder: network access will be disabled during build -I: Current time: Tue Jul 9 15:45:04 -12 2024 -I: pbuilder-time-stamp: 1720583104 +I: Current time: Wed Jul 10 17:46:59 +14 2024 +I: pbuilder-time-stamp: 1720583219 I: Building the build Environment I: extracting base tarball [/var/cache/pbuilder/trixie-reproducible-base.tgz] I: copying local configuration @@ -28,52 +28,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/27131/tmp/hooks/D02_print_environment starting +I: user script /srv/workspace/pbuilder/28107/tmp/hooks/D01_modify_environment starting +debug: Running on virt32a. +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 Jul 10 03:47 /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/28107/tmp/hooks/D01_modify_environment finished +I: user script /srv/workspace/pbuilder/28107/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='armhf' - DEBIAN_FRONTEND='noninteractive' - DEB_BUILD_OPTIONS='buildinfo=+all reproducible=+all parallel=3 ' - DISTRIBUTION='trixie' - HOME='/root' - HOST_ARCH='armhf' + 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]="21" [3]="1" [4]="release" [5]="arm-unknown-linux-gnueabihf") + BASH_VERSION='5.2.21(1)-release' + BUILDDIR=/build/reproducible-path + BUILDUSERGECOS='second user,second room,second work-phone,second home-phone,second other' + BUILDUSERNAME=pbuilder2 + BUILD_ARCH=armhf + DEBIAN_FRONTEND=noninteractive + DEB_BUILD_OPTIONS='buildinfo=+all reproducible=+all parallel=4 ' + DIRSTACK=() + DISTRIBUTION=trixie + EUID=0 + FUNCNAME=([0]="Echo" [1]="main") + GROUPS=() + HOME=/root + HOSTNAME=i-capture-the-hostname + HOSTTYPE=arm + HOST_ARCH=armhf IFS=' ' - INVOCATION_ID='0a9ef4021bd04ec1900513d8ac9fc664' - 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='27131' - PS1='# ' - PS2='> ' + INVOCATION_ID=2f3197900b034f178cd82164cc493023 + LANG=C + LANGUAGE=it_CH:it + LC_ALL=C + MACHTYPE=arm-unknown-linux-gnueabihf + MAIL=/var/mail/root + OPTERR=1 + OPTIND=1 + OSTYPE=linux-gnueabihf + 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=28107 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.dqvlX5Y5/pbuilderrc_FwCZ --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.dqvlX5Y5/b1 --logfile b1/build.log golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.dsc' - SUDO_GID='110' - SUDO_UID='103' - SUDO_USER='jenkins' - TERM='unknown' - TZ='/usr/share/zoneinfo/Etc/GMT+12' - USER='root' - _='/usr/bin/systemd-run' - http_proxy='http://10.0.0.15:3142/' + 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.dqvlX5Y5/pbuilderrc_68ej --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.dqvlX5Y5/b2 --logfile b2/build.log golang-github-cloudflare-cbpfc_0.0~git20231012.992ed75-2.dsc' + SUDO_GID=113 + SUDO_UID=107 + SUDO_USER=jenkins + TERM=unknown + TZ=/usr/share/zoneinfo/Etc/GMT-14 + UID=0 + USER=root + _='I: set' + http_proxy=http://10.0.0.15:3142/ I: uname -a - Linux virt64z 6.1.0-22-arm64 #1 SMP Debian 6.1.94-1 (2024-06-21) aarch64 GNU/Linux + Linux i-capture-the-hostname 6.1.0-22-armmp-lpae #1 SMP Debian 6.1.94-1 (2024-06-21) armv7l GNU/Linux I: ls -l /bin lrwxrwxrwx 1 root root 7 Jun 5 22:35 /bin -> usr/bin -I: user script /srv/workspace/pbuilder/27131/tmp/hooks/D02_print_environment finished +I: user script /srv/workspace/pbuilder/28107/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: 53 http://deb.debian.org/debian trixie/main armhf golang-golang-x-text-dev all 0.15.0-1 [4006 kB] Get: 54 http://deb.debian.org/debian trixie/main armhf golang-golang-x-crypto-dev all 1:0.23.0-1 [1689 kB] Get: 55 http://deb.debian.org/debian trixie/main armhf golang-golang-x-net-dev all 1:0.25.0+dfsg-1 [895 kB] -Fetched 113 MB in 1s (101 MB/s) +Fetched 113 MB in 3s (32.6 MB/s) debconf: delaying package configuration, since apt-utils is not installed 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 ... 19413 files and directories currently installed.) @@ -413,7 +445,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/28107/tmp/hooks/A99_set_merged_usr starting +Not re-configuring usrmerge for trixie +I: user script /srv/workspace/pbuilder/28107/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 @@ -431,17 +467,17 @@ 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 3 github.com/cloudflare/cbpfc github.com/cloudflare/cbpfc/clang -internal/goarch + cd _build && go install -trimpath -v -p 4 github.com/cloudflare/cbpfc github.com/cloudflare/cbpfc/clang internal/unsafeheader +internal/goarch internal/cpu +internal/godebugs internal/coverage/rtcov internal/abi internal/chacha8rand -internal/bytealg -internal/godebugs internal/goexperiment internal/goos +internal/bytealg runtime/internal/atomic runtime/internal/math runtime/internal/sys @@ -449,52 +485,52 @@ internal/itoa math/bits unicode/utf8 -math internal/race sync/atomic -runtime unicode +math cmp slices crypto/internal/alias crypto/internal/boring/sig +runtime +sync crypto/subtle internal/reflectlite -sync internal/testlog internal/bisect internal/godebug errors sort -strconv -io internal/oserror +io +strconv syscall internal/safefilepath path hash bytes +strings reflect crypto -strings regexp/syntax internal/syscall/unix time internal/syscall/execenv regexp -internal/fmtsort -internal/poll io/fs -encoding/binary +internal/poll context -crypto/cipher +internal/fmtsort +encoding/binary os +crypto/cipher golang.org/x/sys/unix crypto/internal/boring crypto/sha1 +io/ioutil path/filepath fmt -io/ioutil os/exec encoding/hex github.com/pkg/errors @@ -502,20 +538,20 @@ net/url text/template/parse github.com/cloudflare/cbpfc/clang +text/template github.com/cilium/ebpf/internal/unix github.com/cilium/ebpf/internal/sys -text/template 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 3 --short github.com/cloudflare/cbpfc github.com/cloudflare/cbpfc/clang + cd _build && go test -vet=off -v -p 4 --short github.com/cloudflare/cbpfc github.com/cloudflare/cbpfc/clang ? github.com/cloudflare/cbpfc/clang [no test files] === RUN TestFunctionName --- PASS: TestFunctionName (0.00s) === RUN TestNoInline ---- SKIP: TestNoInline (0.12s) +--- SKIP: TestNoInline (0.16s) === RUN TestZero --- PASS: TestZero (0.00s) === RUN TestRaw @@ -612,8 +648,8 @@ return: 20: Exit === RUN TestRewriteLargePacketOffsetsDeadBlock/kernel ---- PASS: TestRewriteLargePacketOffsetsDeadBlock (0.14s) - --- SKIP: TestRewriteLargePacketOffsetsDeadBlock/C (0.09s) +--- PASS: TestRewriteLargePacketOffsetsDeadBlock (0.16s) + --- SKIP: TestRewriteLargePacketOffsetsDeadBlock/C (0.11s) --- SKIP: TestRewriteLargePacketOffsetsDeadBlock/eBPF (0.00s) --- PASS: TestRewriteLargePacketOffsetsDeadBlock/kernel (0.05s) === RUN TestAbsoluteGuardSize @@ -930,29 +966,29 @@ return: 22: Exit === RUN TestLoadIndirectBigOffset/kernel#07 ---- PASS: TestLoadIndirectBigOffset (0.89s) - --- SKIP: TestLoadIndirectBigOffset/C (0.07s) +--- PASS: TestLoadIndirectBigOffset (1.10s) + --- SKIP: TestLoadIndirectBigOffset/C (0.10s) --- SKIP: TestLoadIndirectBigOffset/eBPF (0.00s) --- PASS: TestLoadIndirectBigOffset/kernel (0.00s) - --- SKIP: TestLoadIndirectBigOffset/C#01 (0.07s) + --- SKIP: TestLoadIndirectBigOffset/C#01 (0.10s) --- SKIP: TestLoadIndirectBigOffset/eBPF#01 (0.00s) --- PASS: TestLoadIndirectBigOffset/kernel#01 (0.00s) - --- SKIP: TestLoadIndirectBigOffset/C#02 (0.07s) + --- SKIP: TestLoadIndirectBigOffset/C#02 (0.10s) --- SKIP: TestLoadIndirectBigOffset/eBPF#02 (0.00s) --- PASS: TestLoadIndirectBigOffset/kernel#02 (0.05s) - --- SKIP: TestLoadIndirectBigOffset/C#03 (0.07s) + --- SKIP: TestLoadIndirectBigOffset/C#03 (0.09s) --- SKIP: TestLoadIndirectBigOffset/eBPF#03 (0.00s) --- PASS: TestLoadIndirectBigOffset/kernel#03 (0.05s) - --- SKIP: TestLoadIndirectBigOffset/C#04 (0.08s) + --- SKIP: TestLoadIndirectBigOffset/C#04 (0.10s) --- SKIP: TestLoadIndirectBigOffset/eBPF#04 (0.00s) --- PASS: TestLoadIndirectBigOffset/kernel#04 (0.05s) - --- SKIP: TestLoadIndirectBigOffset/C#05 (0.07s) + --- SKIP: TestLoadIndirectBigOffset/C#05 (0.10s) --- SKIP: TestLoadIndirectBigOffset/eBPF#05 (0.00s) --- PASS: TestLoadIndirectBigOffset/kernel#05 (0.05s) - --- SKIP: TestLoadIndirectBigOffset/C#06 (0.07s) + --- SKIP: TestLoadIndirectBigOffset/C#06 (0.11s) --- SKIP: TestLoadIndirectBigOffset/eBPF#06 (0.00s) --- PASS: TestLoadIndirectBigOffset/kernel#06 (0.05s) - --- SKIP: TestLoadIndirectBigOffset/C#07 (0.07s) + --- SKIP: TestLoadIndirectBigOffset/C#07 (0.10s) --- SKIP: TestLoadIndirectBigOffset/eBPF#07 (0.00s) --- PASS: TestLoadIndirectBigOffset/kernel#07 (0.05s) === RUN TestLoadIndirectGuardOverflow @@ -997,8 +1033,8 @@ return: 32: Exit === RUN TestLoadIndirectGuardOverflow/kernel ---- PASS: TestLoadIndirectGuardOverflow (0.12s) - --- SKIP: TestLoadIndirectGuardOverflow/C (0.07s) +--- PASS: TestLoadIndirectGuardOverflow (0.15s) + --- SKIP: TestLoadIndirectGuardOverflow/C (0.10s) --- SKIP: TestLoadIndirectGuardOverflow/eBPF (0.00s) --- PASS: TestLoadIndirectGuardOverflow/kernel (0.05s) === RUN TestScratchZero @@ -1049,8 +1085,8 @@ return: 16: Exit === RUN TestALUDivNegative/kernel ---- PASS: TestALUDivNegative (0.07s) - --- SKIP: TestALUDivNegative/C (0.07s) +--- PASS: TestALUDivNegative (0.09s) + --- SKIP: TestALUDivNegative/C (0.09s) --- SKIP: TestALUDivNegative/eBPF (0.00s) --- PASS: TestALUDivNegative/kernel (0.00s) === RUN TestALUOr @@ -1096,21 +1132,36 @@ === RUN TestTAX === PAUSE TestTAX === CONT TestZeroInitA -=== CONT TestJumpIfLessThan +=== CONT TestALUShiftLeft === RUN TestZeroInitA/C +=== CONT TestJumpIfLessThan +=== RUN TestALUShiftLeft/C === RUN TestJumpIfLessThan/C -=== CONT TestALUMul -=== RUN TestALUMul/C -=== CONT TestScratchZero -=== RUN TestScratchZero/C -=== RUN TestALUMul/eBPF +=== CONT TestScratchX +=== RUN TestScratchX/C +=== RUN TestALUShiftLeft/eBPF +=== 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: Mul32Imm dst: r4 imm: 1 - 4: JEqImm dst: r4 off: -1 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 +=== NAME 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 @@ -1123,12 +1174,11 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestALUMul/kernel -=== RUN TestALUMul/C#01 +=== RUN TestZeroInitA/kernel +=== RUN TestALUShiftLeft/kernel +=== RUN TestALUShiftLeft/C#01 +=== RUN TestScratchX/eBPF === RUN TestJumpIfLessThan/eBPF -=== RUN TestZeroInitA/eBPF -=== RUN TestScratchZero/eBPF -=== 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 @@ -1147,68 +1197,53 @@ 10: MovImm dst: r0 imm: 1 return: 11: Exit -=== RUN TestJumpIfLessThan/kernel -=== NAME TestZeroInitA/eBPF +=== NAME 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: 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 -=== NAME 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 + 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: - 11: MovImm dst: r0 imm: 2 - 12: JEqImm dst: r4 off: -1 imm: 0 - 13: 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: - 14: Exit -=== RUN TestScratchZero/kernel ---- PASS: TestScratchZero (0.07s) - --- SKIP: TestScratchZero/C (0.07s) - --- SKIP: TestScratchZero/eBPF (0.00s) - --- PASS: TestScratchZero/kernel (0.00s) -=== CONT TestLoadIndirect -=== RUN TestLoadIndirect/constant_valid -=== RUN TestLoadIndirect/constant_valid/C -=== RUN TestJumpIfLessThan/C#01 -=== CONT TestLoadAbsoluteBigOffset -=== RUN TestLoadAbsoluteBigOffset/C ---- PASS: TestZeroInitA (0.12s) - --- SKIP: TestZeroInitA/C (0.07s) + 20: Exit +=== RUN TestScratchX/kernel +=== RUN TestJumpIfLessThan/kernel +=== RUN TestScratchX/C#01 +--- PASS: TestZeroInitA (0.16s) + --- SKIP: TestZeroInitA/C (0.11s) --- SKIP: TestZeroInitA/eBPF (0.00s) --- PASS: TestZeroInitA/kernel (0.05s) -=== RUN TestALUMul/eBPF#01 +=== CONT TestJumpIfGreaterThan +=== RUN TestJumpIfGreaterThan/C +=== RUN TestJumpIfLessThan/C#01 +=== 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: 0 - 3: Mov32Imm dst: r5 imm: 1 - 4: Mul32Reg dst: r4 src: r5 - 5: JEqImm dst: r4 off: -1 imm: 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 @@ -1221,42 +1256,66 @@ 12: MovImm dst: r0 imm: 1 return: 13: Exit -=== RUN TestALUMul/kernel#01 -=== RUN TestALUMul/C#02 -=== RUN TestLoadIndirect/constant_valid/eBPF +=== RUN TestALUShiftLeft/kernel#01 +=== RUN TestALUShiftLeft/C#02 +=== 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: -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 + 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 - 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 + 16: MovImm dst: r0 imm: 2 + 17: JEqImm dst: r4 off: -1 imm: 0 + 18: MovImm dst: r0 imm: 1 return: - 23: Exit -=== RUN TestLoadIndirect/constant_valid/kernel -=== RUN TestLoadIndirect/constant_valid/C#01 + 19: Exit +=== RUN TestScratchX/kernel#01 +--- PASS: TestScratchX (0.24s) + --- SKIP: TestScratchX/C (0.12s) + --- SKIP: TestScratchX/eBPF (0.00s) + --- PASS: TestScratchX/kernel (0.00s) + --- SKIP: TestScratchX/C#01 (0.11s) + --- SKIP: TestScratchX/eBPF#01 (0.00s) + --- PASS: TestScratchX/kernel#01 (0.00s) +=== CONT TestJumpIfNotEqual +=== RUN TestJumpIfNotEqual/C +=== 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#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 @@ -1283,38 +1342,14 @@ return: 15: Exit === RUN TestJumpIfLessThan/kernel#01 -=== 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 TestALUMul/eBPF#02 +=== 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: 4 - 3: Mul32Imm dst: r4 imm: 13 - 4: JEqImm dst: r4 off: -1 imm: 52 + 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 @@ -1327,53 +1362,66 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestALUMul/kernel#02 -=== RUN TestALUMul/C#03 -=== RUN TestLoadIndirect/constant_valid/eBPF#01 +=== RUN TestALUShiftLeft/kernel#02 +=== RUN TestALUShiftLeft/C#03 +=== 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: 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 + 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: - 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 + 6: Mov32Imm dst: r4 imm: 1 + 7: 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 + 8: MovImm dst: r0 imm: 2 + 9: JEqImm dst: r4 off: -1 imm: 0 + 10: MovImm dst: r0 imm: 1 return: - 23: Exit -=== RUN TestLoadIndirect/constant_valid/kernel#01 + 11: Exit +=== RUN TestJumpIfNotEqual/kernel === RUN TestJumpIfLessThan/C#02 -=== RUN TestLoadAbsoluteBigOffset/C#01 -=== RUN TestLoadIndirect/constant_valid/C#02 -=== RUN TestALUMul/eBPF#03 +=== 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: 4 - 3: Mov32Imm dst: r5 imm: 13 - 4: Mul32Reg dst: r4 src: r5 - 5: JEqImm dst: r4 off: -1 imm: 52 + 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 TestJumpIfNotEqual/C#01 +=== 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 @@ -1386,25 +1434,23 @@ 12: MovImm dst: r0 imm: 1 return: 13: Exit -=== RUN TestALUMul/kernel#03 -=== RUN TestALUMul/C#04 -=== RUN TestLoadAbsoluteBigOffset/eBPF#01 +=== RUN TestALUShiftLeft/kernel#03 +--- PASS: TestALUShiftLeft (0.44s) + --- SKIP: TestALUShiftLeft/C (0.11s) + --- SKIP: TestALUShiftLeft/eBPF (0.00s) + --- PASS: TestALUShiftLeft/kernel (0.00s) + --- SKIP: TestALUShiftLeft/C#01 (0.11s) + --- SKIP: TestALUShiftLeft/eBPF#01 (0.00s) + --- PASS: TestALUShiftLeft/kernel#01 (0.00s) + --- SKIP: TestALUShiftLeft/C#02 (0.11s) + --- SKIP: TestALUShiftLeft/eBPF#02 (0.00s) + --- PASS: TestALUShiftLeft/kernel#02 (0.00s) + --- SKIP: TestALUShiftLeft/C#03 (0.11s) + --- SKIP: TestALUShiftLeft/eBPF#03 (0.00s) + --- PASS: TestALUShiftLeft/kernel#03 (0.00s) +=== CONT TestJumpIfEqual +=== RUN TestJumpIfEqual/C === RUN TestJumpIfLessThan/eBPF#02 -=== 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 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 @@ -1425,49 +1471,15 @@ return: 12: Exit === RUN TestJumpIfLessThan/kernel#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 TestALUMul/eBPF#04 +=== RUN TestJumpIfNotEqual/eBPF#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: 2 - 3: Mul32Imm dst: r4 imm: -2147483648 - 4: JEqImm dst: r4 off: -1 imm: 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 @@ -1480,306 +1492,8 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestALUMul/kernel#04 -=== RUN TestALUMul/C#05 -=== RUN TestJumpIfLessThan/C#03 -=== RUN TestLoadAbsoluteBigOffset/C#02 -=== 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.44s) - --- SKIP: TestALUMul/C (0.07s) - --- 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.07s) - --- SKIP: TestALUMul/eBPF#02 (0.00s) - --- PASS: TestALUMul/kernel#02 (0.00s) - --- SKIP: TestALUMul/C#03 (0.07s) - --- SKIP: TestALUMul/eBPF#03 (0.00s) - --- PASS: TestALUMul/kernel#03 (0.00s) - --- SKIP: TestALUMul/C#04 (0.07s) - --- SKIP: TestALUMul/eBPF#04 (0.00s) - --- PASS: TestALUMul/kernel#04 (0.00s) - --- SKIP: TestALUMul/C#05 (0.07s) - --- SKIP: TestALUMul/eBPF#05 (0.00s) - --- PASS: TestALUMul/kernel#05 (0.00s) -=== CONT TestLoadAbsolute -=== RUN TestLoadAbsolute/C -=== 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 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 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 TestLoadIndirect/constant_valid/C#04 -=== RUN TestJumpIfLessThan/C#04 -=== RUN TestLoadAbsoluteBigOffset/C#03 -=== 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 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 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 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 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 TestJumpIfLessThan/C#05 -=== RUN TestLoadAbsoluteBigOffset/C#04 -=== RUN TestLoadAbsolute/C#02 -=== 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 TestLoadIndirect/variable_valid -=== RUN TestLoadIndirect/variable_valid/C -=== RUN TestJumpIfLessThan/eBPF#05 +=== RUN TestJumpIfGreaterThan/kernel#02 +=== 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 @@ -1787,7 +1501,7 @@ 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 + 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 @@ -1804,242 +1518,65 @@ 14: MovImm dst: r0 imm: 1 return: 15: Exit -=== RUN TestJumpIfLessThan/kernel#05 -=== 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 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 TestJumpIfLessThan/C#06 -=== RUN TestLoadAbsoluteBigOffset/C#05 -=== 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 TestLoadIndirect/variable_valid/C#01 -=== RUN TestLoadAbsolute/eBPF#03 +=== RUN TestJumpIfNotEqual/kernel#01 +=== RUN TestJumpIfGreaterThan/C#03 +=== RUN TestJumpIfLessThan/C#03 +=== 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: 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 + 2: Mov32Imm dst: r4 imm: 23 + 3: JEqImm dst: r4 off: -1 imm: 23 filter_block_2: - 8: Mov32Imm dst: r4 imm: 0 - 9: JaImm dst: r0 off: -1 imm: 0 + 4: Mov32Imm dst: r4 imm: 0 + 5: 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 + 6: Mov32Imm dst: r4 imm: 1 + 7: 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 + 8: MovImm dst: r0 imm: 2 + 9: JEqImm dst: r4 off: -1 imm: 0 + 10: MovImm dst: r0 imm: 1 return: - 17: Exit -=== RUN TestLoadAbsolute/kernel#03 -=== RUN TestJumpIfLessThan/eBPF#06 + 11: Exit +=== RUN TestJumpIfEqual/kernel +=== RUN TestJumpIfEqual/C#01 +=== 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: 23 + 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: Mov32Imm dst: r4 imm: 0 - 6: 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 - 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 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 TestLoadAbsolute/C#04 -=== 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/C#07 -=== RUN TestLoadAbsoluteBigOffset/C#06 -=== RUN TestLoadIndirect/variable_valid/C#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: + filter_block_6: 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 + 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 TestJumpIfLessThan/eBPF#07 -=== RUN TestLoadAbsoluteBigOffset/eBPF#06 -=== NAME TestJumpIfLessThan/eBPF#07 + 16: Exit +=== RUN TestJumpIfGreaterThan/kernel#03 +=== RUN TestJumpIfGreaterThan/C#04 +=== 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: 23 + 2: Mov32Imm dst: r4 imm: 24 3: Mov32Imm dst: r5 imm: 23 4: JEqImm dst: r4 off: -1 imm: 0 filter_block_3: @@ -2060,236 +1597,16 @@ 15: MovImm dst: r0 imm: 1 return: 16: Exit -=== RUN TestJumpIfLessThan/kernel#07 -=== NAME 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#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 TestLoadAbsolute/eBPF#05 -=== RUN TestJumpIfLessThan/C#08 -=== NAME 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 TestLoadAbsoluteBigOffset/C#07 ---- PASS: TestLoadAbsolute (0.61s) - --- SKIP: TestLoadAbsolute/C (0.07s) - --- SKIP: TestLoadAbsolute/eBPF (0.00s) - --- PASS: TestLoadAbsolute/kernel (0.00s) - --- SKIP: TestLoadAbsolute/C#01 (0.08s) - --- SKIP: TestLoadAbsolute/eBPF#01 (0.00s) - --- PASS: TestLoadAbsolute/kernel#01 (0.05s) - --- SKIP: TestLoadAbsolute/C#02 (0.08s) - --- SKIP: TestLoadAbsolute/eBPF#02 (0.00s) - --- PASS: TestLoadAbsolute/kernel#02 (0.00s) - --- SKIP: TestLoadAbsolute/C#03 (0.08s) - --- SKIP: TestLoadAbsolute/eBPF#03 (0.00s) - --- PASS: TestLoadAbsolute/kernel#03 (0.05s) - --- SKIP: TestLoadAbsolute/C#04 (0.08s) - --- SKIP: TestLoadAbsolute/eBPF#04 (0.00s) - --- PASS: TestLoadAbsolute/kernel#04 (0.00s) - --- SKIP: TestLoadAbsolute/C#05 (0.07s) - --- SKIP: TestLoadAbsolute/eBPF#05 (0.00s) - --- PASS: TestLoadAbsolute/kernel#05 (0.05s) -=== CONT TestLoadConstantX -=== RUN TestLoadConstantX/C -=== 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 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 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 ---- PASS: TestLoadAbsoluteBigOffset (1.00s) - --- SKIP: TestLoadAbsoluteBigOffset/C (0.08s) - --- SKIP: TestLoadAbsoluteBigOffset/eBPF (0.00s) - --- PASS: TestLoadAbsoluteBigOffset/kernel (0.05s) - --- SKIP: TestLoadAbsoluteBigOffset/C#01 (0.07s) - --- SKIP: TestLoadAbsoluteBigOffset/eBPF#01 (0.00s) - --- PASS: TestLoadAbsoluteBigOffset/kernel#01 (0.05s) - --- SKIP: TestLoadAbsoluteBigOffset/C#02 (0.07s) - --- SKIP: TestLoadAbsoluteBigOffset/eBPF#02 (0.00s) - --- PASS: TestLoadAbsoluteBigOffset/kernel#02 (0.05s) - --- SKIP: TestLoadAbsoluteBigOffset/C#03 (0.07s) - --- SKIP: TestLoadAbsoluteBigOffset/eBPF#03 (0.00s) - --- PASS: TestLoadAbsoluteBigOffset/kernel#03 (0.05s) - --- SKIP: TestLoadAbsoluteBigOffset/C#04 (0.07s) - --- SKIP: TestLoadAbsoluteBigOffset/eBPF#04 (0.00s) - --- PASS: TestLoadAbsoluteBigOffset/kernel#04 (0.05s) - --- SKIP: TestLoadAbsoluteBigOffset/C#05 (0.07s) - --- SKIP: TestLoadAbsoluteBigOffset/eBPF#05 (0.00s) - --- PASS: TestLoadAbsoluteBigOffset/kernel#05 (0.05s) - --- SKIP: TestLoadAbsoluteBigOffset/C#06 (0.07s) - --- SKIP: TestLoadAbsoluteBigOffset/eBPF#06 (0.00s) - --- PASS: TestLoadAbsoluteBigOffset/kernel#06 (0.05s) - --- SKIP: TestLoadAbsoluteBigOffset/C#07 (0.07s) - --- SKIP: TestLoadAbsoluteBigOffset/eBPF#07 (0.00s) - --- PASS: TestLoadAbsoluteBigOffset/kernel#07 (0.05s) -=== CONT TestLoadConstantA -=== RUN TestLoadConstantA/C -=== RUN TestLoadIndirect/variable_valid/C#04 -=== RUN TestLoadConstantX/eBPF +=== RUN TestJumpIfLessThan/kernel#03 +=== RUN TestJumpIfEqual/eBPF#01 +=== 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: 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: JNEReg dst: r4 off: -1 src: r5 filter_block_3: 5: Mov32Imm dst: r4 imm: 0 6: JaImm dst: r0 off: -1 imm: 0 @@ -2302,17 +1619,16 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestLoadConstantX/kernel -=== RUN TestLoadConstantX/C#01 -=== RUN TestJumpIfLessThan/eBPF#09 +=== RUN TestJumpIfNotEqual/kernel#02 +=== NAME 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: 22 + 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 + 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 @@ -2329,15 +1645,17 @@ 14: MovImm dst: r0 imm: 1 return: 15: Exit -=== RUN TestJumpIfLessThan/kernel#09 -=== RUN TestJumpIfLessThan/C#10 -=== RUN TestLoadConstantA/eBPF +=== RUN TestJumpIfEqual/kernel#01 +=== RUN TestJumpIfEqual/C#02 +=== RUN TestJumpIfLessThan/C#04 +=== RUN TestJumpIfNotEqual/C#03 +=== 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: 1 - 3: JEqImm dst: r4 off: -1 imm: 1 + 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 @@ -2350,101 +1668,15 @@ 10: MovImm dst: r0 imm: 1 return: 11: Exit -=== RUN TestLoadConstantA/kernel -=== RUN TestLoadConstantA/C#01 -=== 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 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#10 +=== RUN TestJumpIfGreaterThan/kernel#04 +=== 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: 22 + 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#10 -=== RUN TestJumpIfLessThan/C#11 -=== 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 + 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 @@ -2457,26 +1689,16 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestLoadConstantX/kernel#02 ---- PASS: TestLoadConstantX (0.22s) - --- SKIP: TestLoadConstantX/C (0.07s) - --- SKIP: TestLoadConstantX/eBPF (0.00s) - --- PASS: TestLoadConstantX/kernel (0.00s) - --- SKIP: TestLoadConstantX/C#01 (0.07s) - --- SKIP: TestLoadConstantX/eBPF#01 (0.00s) - --- PASS: TestLoadConstantX/kernel#01 (0.00s) - --- SKIP: TestLoadConstantX/C#02 (0.07s) - --- SKIP: TestLoadConstantX/eBPF#02 (0.00s) - --- PASS: TestLoadConstantX/kernel#02 (0.00s) -=== CONT TestPartialZeroInitX -=== RUN TestPartialZeroInitX/C -=== RUN TestLoadConstantA/eBPF#01 +=== RUN TestJumpIfEqual/kernel#02 +=== RUN TestJumpIfEqual/C#03 +=== RUN TestJumpIfGreaterThan/C#05 +=== 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: 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 @@ -2489,58 +1711,17 @@ 10: MovImm dst: r0 imm: 1 return: 11: Exit -=== RUN TestLoadConstantA/kernel#01 -=== RUN TestLoadConstantA/C#02 -=== 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 TestJumpIfLessThan/eBPF#11 +=== RUN TestJumpIfLessThan/kernel#04 +=== 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: 22 + 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 + 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 @@ -2557,321 +1738,15 @@ 15: MovImm dst: r0 imm: 1 return: 16: Exit -=== RUN TestJumpIfLessThan/kernel#11 ---- PASS: TestJumpIfLessThan (1.29s) - --- SKIP: TestJumpIfLessThan/C (0.07s) - --- SKIP: TestJumpIfLessThan/eBPF (0.00s) - --- PASS: TestJumpIfLessThan/kernel (0.05s) - --- SKIP: TestJumpIfLessThan/C#01 (0.08s) - --- SKIP: TestJumpIfLessThan/eBPF#01 (0.00s) - --- PASS: TestJumpIfLessThan/kernel#01 (0.05s) - --- SKIP: TestJumpIfLessThan/C#02 (0.07s) - --- SKIP: TestJumpIfLessThan/eBPF#02 (0.00s) - --- PASS: TestJumpIfLessThan/kernel#02 (0.05s) - --- SKIP: TestJumpIfLessThan/C#03 (0.07s) - --- SKIP: TestJumpIfLessThan/eBPF#03 (0.00s) - --- PASS: TestJumpIfLessThan/kernel#03 (0.05s) - --- SKIP: TestJumpIfLessThan/C#04 (0.07s) - --- SKIP: TestJumpIfLessThan/eBPF#04 (0.00s) - --- PASS: TestJumpIfLessThan/kernel#04 (0.05s) - --- SKIP: TestJumpIfLessThan/C#05 (0.07s) - --- SKIP: TestJumpIfLessThan/eBPF#05 (0.00s) - --- PASS: TestJumpIfLessThan/kernel#05 (0.05s) - --- SKIP: TestJumpIfLessThan/C#06 (0.07s) - --- SKIP: TestJumpIfLessThan/eBPF#06 (0.00s) - --- PASS: TestJumpIfLessThan/kernel#06 (0.05s) - --- SKIP: TestJumpIfLessThan/C#07 (0.07s) - --- SKIP: TestJumpIfLessThan/eBPF#07 (0.00s) - --- PASS: TestJumpIfLessThan/kernel#07 (0.05s) - --- SKIP: TestJumpIfLessThan/C#08 (0.07s) - --- 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.07s) - --- SKIP: TestJumpIfLessThan/eBPF#10 (0.00s) - --- PASS: TestJumpIfLessThan/kernel#10 (0.00s) - --- SKIP: TestJumpIfLessThan/C#11 (0.07s) - --- SKIP: TestJumpIfLessThan/eBPF#11 (0.00s) - --- PASS: TestJumpIfLessThan/kernel#11 (0.00s) -=== CONT TestZeroInitX -=== RUN TestZeroInitX/C -=== RUN TestLoadIndirect/constant_outofbounds -=== RUN TestLoadIndirect/constant_outofbounds/C -=== 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.23s) - --- SKIP: TestLoadConstantA/C (0.07s) - --- SKIP: TestLoadConstantA/eBPF (0.00s) - --- PASS: TestLoadConstantA/kernel (0.00s) - --- SKIP: TestLoadConstantA/C#01 (0.08s) - --- SKIP: TestLoadConstantA/eBPF#01 (0.00s) - --- PASS: TestLoadConstantA/kernel#01 (0.00s) - --- SKIP: TestLoadConstantA/C#02 (0.08s) - --- SKIP: TestLoadConstantA/eBPF#02 (0.00s) - --- PASS: TestLoadConstantA/kernel#02 (0.00s) -=== CONT TestALUMod -=== RUN TestALUMod/C -=== 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 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 TestPartialZeroInitX/C#01 -=== RUN TestLoadIndirect/constant_outofbounds/eBPF ---- PASS: TestZeroInitX (0.12s) - --- SKIP: TestZeroInitX/C (0.07s) - --- SKIP: TestZeroInitX/eBPF (0.00s) - --- PASS: TestZeroInitX/kernel (0.05s) -=== CONT TestJumpIfGreaterThan -=== RUN TestJumpIfGreaterThan/C -=== NAME 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 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 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.09s) - --- SKIP: TestPartialZeroInitX/eBPF (0.00s) - --- PASS: TestPartialZeroInitX/kernel (0.05s) - --- SKIP: TestPartialZeroInitX/C#01 (0.08s) - --- SKIP: TestPartialZeroInitX/eBPF#01 (0.00s) - --- PASS: TestPartialZeroInitX/kernel#01 (0.00s) -=== CONT TestJumpIfNotEqual -=== RUN TestJumpIfNotEqual/C -=== 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 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 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 -=== RUN TestLoadIndirect/constant_outofbounds/C#02 -=== RUN TestJumpIfNotEqual/eBPF +=== RUN TestJumpIfNotEqual/kernel#03 +=== RUN TestJumpIfLessThan/C#05 +=== RUN TestJumpIfNotEqual/C#04 +=== RUN 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: 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 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 @@ -2891,100 +1766,26 @@ 14: MovImm dst: r0 imm: 1 return: 15: Exit -=== RUN TestJumpIfGreaterThan/kernel#01 -=== RUN TestJumpIfGreaterThan/C#02 -=== 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 TestJumpIfNotEqual/C#01 -=== 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 TestJumpIfGreaterThan/eBPF#02 +=== RUN TestJumpIfGreaterThan/kernel#05 +=== 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: 24 + 2: Mov32Imm dst: r4 imm: 23 3: Mov32Imm dst: r5 imm: 23 - 4: JGTReg 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: 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 - 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 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 + 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 @@ -2992,24 +1793,10 @@ 15: MovImm dst: r0 imm: 1 return: 16: Exit -=== RUN TestALUMod/kernel#03 ---- PASS: TestALUMod (0.29s) - --- SKIP: TestALUMod/C (0.07s) - --- SKIP: TestALUMod/eBPF (0.00s) - --- PASS: TestALUMod/kernel (0.00s) - --- SKIP: TestALUMod/C#01 (0.07s) - --- SKIP: TestALUMod/eBPF#01 (0.00s) - --- PASS: TestALUMod/kernel#01 (0.00s) - --- SKIP: TestALUMod/C#02 (0.07s) - --- SKIP: TestALUMod/eBPF#02 (0.00s) - --- PASS: TestALUMod/kernel#02 (0.00s) - --- SKIP: TestALUMod/C#03 (0.07s) - --- SKIP: TestALUMod/eBPF#03 (0.00s) - --- PASS: TestALUMod/kernel#03 (0.00s) -=== CONT TestJumpIfEqual -=== RUN TestJumpIfEqual/C -=== RUN TestLoadIndirect/constant_outofbounds/C#03 -=== RUN TestJumpIfNotEqual/eBPF#01 +=== RUN TestJumpIfEqual/kernel#03 +=== RUN TestJumpIfEqual/C#04 +=== RUN TestJumpIfGreaterThan/C#06 +=== 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 @@ -3017,7 +1804,7 @@ 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 + 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 @@ -3034,42 +1821,14 @@ 14: MovImm dst: r0 imm: 1 return: 15: Exit -=== RUN TestJumpIfNotEqual/kernel#01 -=== 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 +=== RUN TestJumpIfLessThan/kernel#05 +=== 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: JEqImm dst: r4 off: -1 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 @@ -3082,45 +1841,15 @@ 10: MovImm dst: r0 imm: 1 return: 11: Exit -=== RUN TestJumpIfEqual/kernel -=== RUN TestJumpIfEqual/C#01 -=== RUN TestJumpIfNotEqual/C#02 -=== 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 TestJumpIfGreaterThan/eBPF#04 +=== RUN TestJumpIfNotEqual/kernel#04 +=== RUN TestJumpIfNotEqual/C#05 +=== 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: JGTImm dst: r4 off: -1 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 @@ -3133,65 +1862,17 @@ 10: MovImm dst: r0 imm: 1 return: 11: Exit -=== RUN TestJumpIfGreaterThan/kernel#04 -=== 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 TestLoadIndirect/constant_outofbounds/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 TestJumpIfGreaterThan/C#05 -=== RUN TestJumpIfEqual/eBPF#02 +=== RUN TestJumpIfEqual/kernel#04 +=== RUN TestJumpIfLessThan/C#06 +=== RUN TestJumpIfEqual/C#05 +=== 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: JEqReg dst: r4 off: -1 src: r5 + 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 @@ -3204,38 +1885,8 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestJumpIfEqual/kernel#02 -=== RUN TestJumpIfEqual/C#03 -=== RUN TestJumpIfNotEqual/C#03 -=== 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 TestJumpIfGreaterThan/eBPF#05 +=== RUN TestJumpIfGreaterThan/kernel#06 +=== 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 @@ -3243,7 +1894,7 @@ 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: JNEImm dst: r4 off: -1 imm: 21 5: JaImm dst: r0 off: -1 imm: 0 filter_block_3: 6: Mov32Imm dst: r4 imm: 1 @@ -3260,128 +1911,17 @@ 14: MovImm dst: r0 imm: 1 return: 15: Exit -=== RUN TestJumpIfGreaterThan/kernel#05 -=== RUN TestLoadIndirect/variable_outofbounds -=== RUN TestLoadIndirect/variable_outofbounds/C -=== 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 TestJumpIfNotEqual/kernel#03 -=== 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 TestJumpIfGreaterThan/C#06 -=== RUN TestJumpIfNotEqual/C#04 -=== 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 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 TestJumpIfGreaterThan/eBPF#06 +=== RUN TestJumpIfNotEqual/kernel#05 +=== RUN TestJumpIfNotEqual/C#06 +=== RUN TestJumpIfGreaterThan/C#07 +=== 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: JGTReg dst: r4 off: -1 src: r5 + 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 @@ -3394,64 +1934,7 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestJumpIfGreaterThan/kernel#06 -=== RUN TestJumpIfEqual/C#05 -=== 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/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 TestJumpIfGreaterThan/C#07 -=== RUN TestLoadIndirect/variable_outofbounds/C#02 +=== RUN TestJumpIfLessThan/kernel#06 === RUN TestJumpIfEqual/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 @@ -3478,34 +1961,30 @@ return: 15: Exit === RUN TestJumpIfEqual/kernel#05 -=== RUN TestJumpIfNotEqual/eBPF#05 +=== RUN TestJumpIfLessThan/C#07 +=== RUN TestJumpIfGreaterThan/eBPF#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: 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 + 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 TestJumpIfNotEqual/kernel#05 -=== RUN TestJumpIfNotEqual/C#06 -=== RUN TestJumpIfGreaterThan/eBPF#07 + 12: Exit +=== RUN TestJumpIfNotEqual/kernel#06 +=== 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 @@ -3532,65 +2011,39 @@ return: 16: Exit === RUN TestJumpIfGreaterThan/kernel#07 +=== RUN TestJumpIfNotEqual/C#07 === RUN TestJumpIfEqual/C#06 -=== RUN TestJumpIfNotEqual/eBPF#06 +=== RUN TestJumpIfGreaterThan/C#08 +=== 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: 21 - 4: JNEReg dst: r4 off: -1 src: r5 + 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: 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: - 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 TestJumpIfGreaterThan/C#08 -=== 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 + 13: MovImm dst: r0 imm: 2 + 14: JEqImm dst: r4 off: -1 imm: 0 + 15: MovImm dst: r0 imm: 1 return: - 26: Exit -=== RUN TestLoadIndirect/variable_outofbounds/kernel#02 + 16: Exit +=== RUN TestJumpIfLessThan/kernel#07 === RUN TestJumpIfEqual/eBPF#06 +=== RUN TestJumpIfNotEqual/eBPF#07 +=== NAME 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 @@ -3611,9 +2064,6 @@ return: 12: Exit === RUN TestJumpIfEqual/kernel#06 -=== RUN TestLoadIndirect/variable_outofbounds/C#03 -=== RUN TestJumpIfNotEqual/eBPF#07 -=== RUN TestJumpIfGreaterThan/eBPF#08 === NAME TestJumpIfNotEqual/eBPF#07 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 @@ -3641,89 +2091,56 @@ return: 16: Exit === RUN TestJumpIfNotEqual/kernel#07 -=== NAME 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 ---- PASS: TestJumpIfNotEqual (0.78s) - --- SKIP: TestJumpIfNotEqual/C (0.07s) +--- PASS: TestJumpIfNotEqual (1.06s) + --- SKIP: TestJumpIfNotEqual/C (0.11s) --- SKIP: TestJumpIfNotEqual/eBPF (0.00s) --- PASS: TestJumpIfNotEqual/kernel (0.05s) - --- SKIP: TestJumpIfNotEqual/C#01 (0.07s) + --- SKIP: TestJumpIfNotEqual/C#01 (0.10s) --- SKIP: TestJumpIfNotEqual/eBPF#01 (0.00s) --- PASS: TestJumpIfNotEqual/kernel#01 (0.05s) - --- SKIP: TestJumpIfNotEqual/C#02 (0.07s) + --- SKIP: TestJumpIfNotEqual/C#02 (0.11s) --- SKIP: TestJumpIfNotEqual/eBPF#02 (0.00s) --- PASS: TestJumpIfNotEqual/kernel#02 (0.05s) - --- SKIP: TestJumpIfNotEqual/C#03 (0.07s) + --- SKIP: TestJumpIfNotEqual/C#03 (0.11s) --- SKIP: TestJumpIfNotEqual/eBPF#03 (0.00s) --- PASS: TestJumpIfNotEqual/kernel#03 (0.05s) - --- SKIP: TestJumpIfNotEqual/C#04 (0.07s) + --- SKIP: TestJumpIfNotEqual/C#04 (0.11s) --- SKIP: TestJumpIfNotEqual/eBPF#04 (0.00s) --- PASS: TestJumpIfNotEqual/kernel#04 (0.00s) - --- SKIP: TestJumpIfNotEqual/C#05 (0.07s) + --- SKIP: TestJumpIfNotEqual/C#05 (0.11s) --- SKIP: TestJumpIfNotEqual/eBPF#05 (0.00s) --- PASS: TestJumpIfNotEqual/kernel#05 (0.00s) - --- SKIP: TestJumpIfNotEqual/C#06 (0.07s) + --- SKIP: TestJumpIfNotEqual/C#06 (0.10s) --- SKIP: TestJumpIfNotEqual/eBPF#06 (0.00s) --- PASS: TestJumpIfNotEqual/kernel#06 (0.00s) - --- SKIP: TestJumpIfNotEqual/C#07 (0.07s) + --- SKIP: TestJumpIfNotEqual/C#07 (0.11s) --- SKIP: TestJumpIfNotEqual/eBPF#07 (0.00s) --- PASS: TestJumpIfNotEqual/kernel#07 (0.00s) === CONT TestJump0 === RUN TestJump0/C +=== RUN TestJumpIfLessThan/C#08 === RUN TestJumpIfEqual/C#07 -=== RUN TestJumpIfGreaterThan/C#09 -=== RUN TestLoadIndirect/variable_outofbounds/eBPF#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: 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 + 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: - 23: MovImm dst: r0 imm: 2 - 24: JEqImm dst: r4 off: -1 imm: 0 - 25: 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: - 26: Exit -=== RUN TestLoadIndirect/variable_outofbounds/kernel#03 + 11: Exit +=== RUN TestJumpIfGreaterThan/kernel#08 +=== RUN TestJumpIfGreaterThan/C#09 === RUN TestJump0/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 @@ -3750,6 +2167,27 @@ return: 16: Exit === RUN TestJump0/kernel +=== 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 TestJumpIfEqual/eBPF#07 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 @@ -3777,7 +2215,34 @@ return: 16: Exit === RUN TestJumpIfEqual/kernel#07 -=== RUN TestLoadIndirect/variable_outofbounds/C#04 +=== RUN TestJump0/C#01 +--- PASS: TestJumpIfEqual (1.07s) + --- SKIP: TestJumpIfEqual/C (0.11s) + --- SKIP: TestJumpIfEqual/eBPF (0.00s) + --- PASS: TestJumpIfEqual/kernel (0.00s) + --- SKIP: TestJumpIfEqual/C#01 (0.11s) + --- SKIP: TestJumpIfEqual/eBPF#01 (0.00s) + --- PASS: TestJumpIfEqual/kernel#01 (0.00s) + --- SKIP: TestJumpIfEqual/C#02 (0.11s) + --- SKIP: TestJumpIfEqual/eBPF#02 (0.00s) + --- PASS: TestJumpIfEqual/kernel#02 (0.00s) + --- SKIP: TestJumpIfEqual/C#03 (0.11s) + --- SKIP: TestJumpIfEqual/eBPF#03 (0.00s) + --- PASS: TestJumpIfEqual/kernel#03 (0.00s) + --- SKIP: TestJumpIfEqual/C#04 (0.11s) + --- SKIP: TestJumpIfEqual/eBPF#04 (0.00s) + --- PASS: TestJumpIfEqual/kernel#04 (0.05s) + --- SKIP: TestJumpIfEqual/C#05 (0.11s) + --- 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.11s) + --- SKIP: TestJumpIfEqual/eBPF#07 (0.00s) + --- PASS: TestJumpIfEqual/kernel#07 (0.05s) +=== CONT TestJump +=== RUN TestJump/C === RUN TestJumpIfGreaterThan/eBPF#09 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 @@ -3804,68 +2269,34 @@ return: 15: Exit === RUN TestJumpIfGreaterThan/kernel#09 -=== RUN TestJump0/C#01 ---- PASS: TestJumpIfEqual (0.77s) - --- SKIP: TestJumpIfEqual/C (0.07s) - --- SKIP: TestJumpIfEqual/eBPF (0.00s) - --- PASS: TestJumpIfEqual/kernel (0.00s) - --- SKIP: TestJumpIfEqual/C#01 (0.07s) - --- SKIP: TestJumpIfEqual/eBPF#01 (0.00s) - --- PASS: TestJumpIfEqual/kernel#01 (0.00s) - --- SKIP: TestJumpIfEqual/C#02 (0.07s) - --- SKIP: TestJumpIfEqual/eBPF#02 (0.00s) - --- PASS: TestJumpIfEqual/kernel#02 (0.00s) - --- SKIP: TestJumpIfEqual/C#03 (0.07s) - --- SKIP: TestJumpIfEqual/eBPF#03 (0.00s) - --- PASS: TestJumpIfEqual/kernel#03 (0.00s) - --- SKIP: TestJumpIfEqual/C#04 (0.07s) - --- SKIP: TestJumpIfEqual/eBPF#04 (0.00s) - --- PASS: TestJumpIfEqual/kernel#04 (0.05s) - --- SKIP: TestJumpIfEqual/C#05 (0.07s) - --- SKIP: TestJumpIfEqual/eBPF#05 (0.00s) - --- PASS: TestJumpIfEqual/kernel#05 (0.05s) - --- SKIP: TestJumpIfEqual/C#06 (0.07s) - --- SKIP: TestJumpIfEqual/eBPF#06 (0.00s) - --- PASS: TestJumpIfEqual/kernel#06 (0.05s) - --- SKIP: TestJumpIfEqual/C#07 (0.07s) - --- SKIP: TestJumpIfEqual/eBPF#07 (0.00s) - --- PASS: TestJumpIfEqual/kernel#07 (0.05s) -=== CONT TestJump -=== RUN TestJump/C -=== RUN TestJumpIfGreaterThan/C#10 -=== RUN TestLoadIndirect/variable_outofbounds/eBPF#04 +=== 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: 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 + 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: - 22: MovImm dst: r0 imm: 2 - 23: JEqImm dst: r4 off: -1 imm: 0 - 24: 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: - 25: Exit -=== RUN TestLoadIndirect/variable_outofbounds/kernel#04 + 15: Exit +=== RUN TestJumpIfLessThan/kernel#09 +=== RUN TestJumpIfLessThan/C#10 +=== RUN TestJumpIfGreaterThan/C#10 === RUN TestJump0/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 @@ -3892,11 +2323,11 @@ return: 16: Exit === RUN TestJump0/kernel#01 ---- PASS: TestJump0 (0.20s) - --- SKIP: TestJump0/C (0.07s) +--- PASS: TestJump0 (0.28s) + --- SKIP: TestJump0/C (0.11s) --- SKIP: TestJump0/eBPF (0.00s) --- PASS: TestJump0/kernel (0.05s) - --- SKIP: TestJump0/C#01 (0.07s) + --- SKIP: TestJump0/C#01 (0.11s) --- SKIP: TestJump0/eBPF#01 (0.00s) --- PASS: TestJump0/kernel#01 (0.00s) === CONT TestNegateA @@ -3928,6 +2359,28 @@ return: 16: Exit === RUN TestJump/kernel +=== 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 TestJumpIfGreaterThan/eBPF#10 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 @@ -3949,77 +2402,10 @@ return: 12: Exit === RUN TestJumpIfGreaterThan/kernel#10 ---- PASS: TestLoadIndirect (2.43s) - --- PASS: TestLoadIndirect/constant_valid (0.62s) - --- SKIP: TestLoadIndirect/constant_valid/C (0.08s) - --- SKIP: TestLoadIndirect/constant_valid/eBPF (0.00s) - --- PASS: TestLoadIndirect/constant_valid/kernel (0.00s) - --- SKIP: TestLoadIndirect/constant_valid/C#01 (0.08s) - --- SKIP: TestLoadIndirect/constant_valid/eBPF#01 (0.00s) - --- PASS: TestLoadIndirect/constant_valid/kernel#01 (0.05s) - --- SKIP: TestLoadIndirect/constant_valid/C#02 (0.08s) - --- SKIP: TestLoadIndirect/constant_valid/eBPF#02 (0.00s) - --- PASS: TestLoadIndirect/constant_valid/kernel#02 (0.00s) - --- SKIP: TestLoadIndirect/constant_valid/C#03 (0.08s) - --- SKIP: TestLoadIndirect/constant_valid/eBPF#03 (0.00s) - --- PASS: TestLoadIndirect/constant_valid/kernel#03 (0.05s) - --- SKIP: TestLoadIndirect/constant_valid/C#04 (0.08s) - --- SKIP: TestLoadIndirect/constant_valid/eBPF#04 (0.00s) - --- PASS: TestLoadIndirect/constant_valid/kernel#04 (0.00s) - --- SKIP: TestLoadIndirect/constant_valid/C#05 (0.08s) - --- SKIP: TestLoadIndirect/constant_valid/eBPF#05 (0.00s) - --- PASS: TestLoadIndirect/constant_valid/kernel#05 (0.05s) - --- PASS: TestLoadIndirect/variable_valid (0.64s) - --- SKIP: TestLoadIndirect/variable_valid/C (0.08s) - --- SKIP: TestLoadIndirect/variable_valid/eBPF (0.00s) - --- PASS: TestLoadIndirect/variable_valid/kernel (0.00s) - --- SKIP: TestLoadIndirect/variable_valid/C#01 (0.08s) - --- SKIP: TestLoadIndirect/variable_valid/eBPF#01 (0.00s) - --- PASS: TestLoadIndirect/variable_valid/kernel#01 (0.05s) - --- SKIP: TestLoadIndirect/variable_valid/C#02 (0.08s) - --- SKIP: TestLoadIndirect/variable_valid/eBPF#02 (0.00s) - --- PASS: TestLoadIndirect/variable_valid/kernel#02 (0.00s) - --- SKIP: TestLoadIndirect/variable_valid/C#03 (0.08s) - --- SKIP: TestLoadIndirect/variable_valid/eBPF#03 (0.00s) - --- PASS: TestLoadIndirect/variable_valid/kernel#03 (0.05s) - --- SKIP: TestLoadIndirect/variable_valid/C#04 (0.08s) - --- SKIP: TestLoadIndirect/variable_valid/eBPF#04 (0.00s) - --- PASS: TestLoadIndirect/variable_valid/kernel#04 (0.00s) - --- SKIP: TestLoadIndirect/variable_valid/C#05 (0.08s) - --- SKIP: TestLoadIndirect/variable_valid/eBPF#05 (0.00s) - --- PASS: TestLoadIndirect/variable_valid/kernel#05 (0.05s) - --- PASS: TestLoadIndirect/constant_outofbounds (0.57s) - --- SKIP: TestLoadIndirect/constant_outofbounds/C (0.08s) - --- SKIP: TestLoadIndirect/constant_outofbounds/eBPF (0.00s) - --- PASS: TestLoadIndirect/constant_outofbounds/kernel (0.00s) - --- SKIP: TestLoadIndirect/constant_outofbounds/C#01 (0.07s) - --- SKIP: TestLoadIndirect/constant_outofbounds/eBPF#01 (0.00s) - --- PASS: TestLoadIndirect/constant_outofbounds/kernel#01 (0.05s) - --- SKIP: TestLoadIndirect/constant_outofbounds/C#02 (0.07s) - --- SKIP: TestLoadIndirect/constant_outofbounds/eBPF#02 (0.00s) - --- PASS: TestLoadIndirect/constant_outofbounds/kernel#02 (0.05s) - --- SKIP: TestLoadIndirect/constant_outofbounds/C#03 (0.07s) - --- 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.60s) - --- SKIP: TestLoadIndirect/variable_outofbounds/C (0.08s) - --- SKIP: TestLoadIndirect/variable_outofbounds/eBPF (0.00s) - --- PASS: TestLoadIndirect/variable_outofbounds/kernel (0.00s) - --- SKIP: TestLoadIndirect/variable_outofbounds/C#01 (0.08s) - --- SKIP: TestLoadIndirect/variable_outofbounds/eBPF#01 (0.00s) - --- PASS: TestLoadIndirect/variable_outofbounds/kernel#01 (0.05s) - --- SKIP: TestLoadIndirect/variable_outofbounds/C#02 (0.08s) - --- SKIP: TestLoadIndirect/variable_outofbounds/eBPF#02 (0.00s) - --- PASS: TestLoadIndirect/variable_outofbounds/kernel#02 (0.05s) - --- SKIP: TestLoadIndirect/variable_outofbounds/C#03 (0.08s) - --- SKIP: TestLoadIndirect/variable_outofbounds/eBPF#03 (0.00s) - --- PASS: TestLoadIndirect/variable_outofbounds/kernel#03 (0.05s) - --- SKIP: TestLoadIndirect/variable_outofbounds/C#04 (0.08s) - --- SKIP: TestLoadIndirect/variable_outofbounds/eBPF#04 (0.00s) - --- PASS: TestLoadIndirect/variable_outofbounds/kernel#04 (0.05s) +--- PASS: TestJump (0.17s) + --- SKIP: TestJump/C (0.12s) + --- SKIP: TestJump/eBPF (0.00s) + --- PASS: TestJump/kernel (0.05s) === CONT TestALUXor === RUN TestALUXor/C === RUN TestNegateA/eBPF @@ -4044,53 +2430,91 @@ return: 13: Exit === RUN TestNegateA/kernel ---- PASS: TestJump (0.13s) - --- SKIP: TestJump/C (0.07s) - --- SKIP: TestJump/eBPF (0.00s) - --- PASS: TestJump/kernel (0.05s) -=== CONT TestJumpIfBitsNotSet -=== RUN TestJumpIfBitsNotSet/C === RUN TestJumpIfGreaterThan/C#11 -=== RUN TestALUXor/eBPF +--- PASS: TestNegateA (0.16s) + --- SKIP: TestNegateA/C (0.11s) + --- SKIP: TestNegateA/eBPF (0.00s) + --- PASS: TestNegateA/kernel (0.05s) +=== CONT TestALUMod +=== RUN TestALUMod/C +=== 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: 1 - 3: Xor32Imm dst: r4 imm: 1 + 2: Mov32Imm dst: r4 imm: 22 + 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: 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: - 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 TestALUXor/kernel -=== RUN TestALUXor/C#01 ---- PASS: TestNegateA (0.13s) - --- SKIP: TestNegateA/C (0.07s) - --- SKIP: TestNegateA/eBPF (0.00s) - --- PASS: TestNegateA/kernel (0.05s) -=== CONT TestTAX -=== RUN TestTAX/C -=== RUN TestJumpIfBitsNotSet/eBPF + 16: Exit +=== RUN TestJumpIfLessThan/kernel#11 +--- PASS: TestJumpIfLessThan (1.77s) + --- SKIP: TestJumpIfLessThan/C (0.12s) + --- SKIP: TestJumpIfLessThan/eBPF (0.00s) + --- PASS: TestJumpIfLessThan/kernel (0.05s) + --- SKIP: TestJumpIfLessThan/C#01 (0.12s) + --- SKIP: TestJumpIfLessThan/eBPF#01 (0.00s) + --- PASS: TestJumpIfLessThan/kernel#01 (0.05s) + --- SKIP: TestJumpIfLessThan/C#02 (0.11s) + --- SKIP: TestJumpIfLessThan/eBPF#02 (0.00s) + --- PASS: TestJumpIfLessThan/kernel#02 (0.05s) + --- SKIP: TestJumpIfLessThan/C#03 (0.11s) + --- SKIP: TestJumpIfLessThan/eBPF#03 (0.00s) + --- PASS: TestJumpIfLessThan/kernel#03 (0.05s) + --- SKIP: TestJumpIfLessThan/C#04 (0.11s) + --- SKIP: TestJumpIfLessThan/eBPF#04 (0.00s) + --- PASS: TestJumpIfLessThan/kernel#04 (0.05s) + --- SKIP: TestJumpIfLessThan/C#05 (0.11s) + --- SKIP: TestJumpIfLessThan/eBPF#05 (0.00s) + --- PASS: TestJumpIfLessThan/kernel#05 (0.05s) + --- SKIP: TestJumpIfLessThan/C#06 (0.11s) + --- SKIP: TestJumpIfLessThan/eBPF#06 (0.00s) + --- PASS: TestJumpIfLessThan/kernel#06 (0.05s) + --- SKIP: TestJumpIfLessThan/C#07 (0.11s) + --- SKIP: TestJumpIfLessThan/eBPF#07 (0.00s) + --- PASS: TestJumpIfLessThan/kernel#07 (0.05s) + --- SKIP: TestJumpIfLessThan/C#08 (0.11s) + --- SKIP: TestJumpIfLessThan/eBPF#08 (0.00s) + --- PASS: TestJumpIfLessThan/kernel#08 (0.00s) + --- SKIP: TestJumpIfLessThan/C#09 (0.11s) + --- SKIP: TestJumpIfLessThan/eBPF#09 (0.00s) + --- PASS: TestJumpIfLessThan/kernel#09 (0.00s) + --- SKIP: TestJumpIfLessThan/C#10 (0.11s) + --- SKIP: TestJumpIfLessThan/eBPF#10 (0.00s) + --- PASS: TestJumpIfLessThan/kernel#10 (0.00s) + --- SKIP: TestJumpIfLessThan/C#11 (0.11s) + --- SKIP: TestJumpIfLessThan/eBPF#11 (0.00s) + --- PASS: TestJumpIfLessThan/kernel#11 (0.00s) +=== CONT TestALUShiftRight +=== RUN TestALUShiftRight/C +=== 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: 6 - 3: JSetImm dst: r4 off: -1 imm: 4 - 4: JaImm dst: r0 off: -1 imm: 0 - filter_block_2: + 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_3: + filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: @@ -4099,7 +2523,8 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestJumpIfBitsNotSet/kernel +=== RUN TestALUXor/kernel +=== RUN TestALUXor/C#01 === RUN TestJumpIfGreaterThan/eBPF#11 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 @@ -4127,92 +2552,183 @@ return: 16: Exit === RUN TestJumpIfGreaterThan/kernel#11 -=== RUN TestALUXor/eBPF#01 +=== 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: 1 - 3: Mov32Imm dst: r5 imm: 1 - 4: Xor32Reg dst: r4 src: r5 - 5: JEqImm dst: r4 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: + 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 TestALUXor/kernel#01 -=== RUN TestALUXor/C#02 -=== RUN TestTAX/eBPF + 12: Exit +=== RUN TestALUMod/kernel +=== RUN TestALUMod/C#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: 1 - 3: Mov32Reg dst: r5 src: r4 - 4: Mov32Reg dst: r4 src: r5 - 5: Mov32Reg dst: r4 src: r4 + 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: - 7: MovImm dst: r0 imm: 2 - 8: JEqImm dst: r4 off: -1 imm: 0 - 9: 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: - 10: Exit -=== RUN TestTAX/kernel ---- PASS: TestTAX (0.07s) - --- SKIP: TestTAX/C (0.07s) - --- SKIP: TestTAX/eBPF (0.00s) - --- PASS: TestTAX/kernel (0.00s) -=== CONT TestTXA -=== RUN TestTXA/C -=== RUN TestJumpIfBitsNotSet/C#01 ---- PASS: TestJumpIfGreaterThan (1.27s) - --- SKIP: TestJumpIfGreaterThan/C (0.07s) + 12: Exit +=== RUN TestALUShiftRight/kernel +=== RUN TestALUShiftRight/C#01 +--- PASS: TestJumpIfGreaterThan (1.74s) + --- SKIP: TestJumpIfGreaterThan/C (0.12s) --- SKIP: TestJumpIfGreaterThan/eBPF (0.00s) --- PASS: TestJumpIfGreaterThan/kernel (0.00s) - --- SKIP: TestJumpIfGreaterThan/C#01 (0.07s) + --- SKIP: TestJumpIfGreaterThan/C#01 (0.11s) --- SKIP: TestJumpIfGreaterThan/eBPF#01 (0.00s) --- PASS: TestJumpIfGreaterThan/kernel#01 (0.00s) - --- SKIP: TestJumpIfGreaterThan/C#02 (0.07s) + --- SKIP: TestJumpIfGreaterThan/C#02 (0.11s) --- SKIP: TestJumpIfGreaterThan/eBPF#02 (0.00s) --- PASS: TestJumpIfGreaterThan/kernel#02 (0.00s) - --- SKIP: TestJumpIfGreaterThan/C#03 (0.07s) + --- SKIP: TestJumpIfGreaterThan/C#03 (0.11s) --- SKIP: TestJumpIfGreaterThan/eBPF#03 (0.00s) --- PASS: TestJumpIfGreaterThan/kernel#03 (0.00s) - --- SKIP: TestJumpIfGreaterThan/C#04 (0.07s) + --- SKIP: TestJumpIfGreaterThan/C#04 (0.11s) --- SKIP: TestJumpIfGreaterThan/eBPF#04 (0.00s) --- PASS: TestJumpIfGreaterThan/kernel#04 (0.05s) - --- SKIP: TestJumpIfGreaterThan/C#05 (0.07s) + --- SKIP: TestJumpIfGreaterThan/C#05 (0.10s) --- SKIP: TestJumpIfGreaterThan/eBPF#05 (0.00s) --- PASS: TestJumpIfGreaterThan/kernel#05 (0.05s) - --- SKIP: TestJumpIfGreaterThan/C#06 (0.08s) + --- SKIP: TestJumpIfGreaterThan/C#06 (0.11s) --- SKIP: TestJumpIfGreaterThan/eBPF#06 (0.00s) --- PASS: TestJumpIfGreaterThan/kernel#06 (0.05s) - --- SKIP: TestJumpIfGreaterThan/C#07 (0.07s) + --- SKIP: TestJumpIfGreaterThan/C#07 (0.10s) --- SKIP: TestJumpIfGreaterThan/eBPF#07 (0.00s) --- PASS: TestJumpIfGreaterThan/kernel#07 (0.05s) - --- SKIP: TestJumpIfGreaterThan/C#08 (0.07s) + --- SKIP: TestJumpIfGreaterThan/C#08 (0.11s) --- SKIP: TestJumpIfGreaterThan/eBPF#08 (0.00s) --- PASS: TestJumpIfGreaterThan/kernel#08 (0.05s) - --- SKIP: TestJumpIfGreaterThan/C#09 (0.07s) + --- SKIP: TestJumpIfGreaterThan/C#09 (0.11s) --- SKIP: TestJumpIfGreaterThan/eBPF#09 (0.00s) --- PASS: TestJumpIfGreaterThan/kernel#09 (0.05s) - --- SKIP: TestJumpIfGreaterThan/C#10 (0.07s) + --- SKIP: TestJumpIfGreaterThan/C#10 (0.11s) --- SKIP: TestJumpIfGreaterThan/eBPF#10 (0.00s) --- PASS: TestJumpIfGreaterThan/kernel#10 (0.05s) - --- SKIP: TestJumpIfGreaterThan/C#11 (0.07s) + --- SKIP: TestJumpIfGreaterThan/C#11 (0.11s) --- SKIP: TestJumpIfGreaterThan/eBPF#11 (0.00s) --- PASS: TestJumpIfGreaterThan/kernel#11 (0.05s) -=== CONT TestRetConstant -=== RUN TestRetConstant/C +=== CONT TestRetA +=== RUN TestRetA/C +=== 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 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 +=== 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 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 +--- PASS: TestRetA (0.11s) + --- SKIP: TestRetA/C (0.11s) + --- SKIP: TestRetA/eBPF (0.00s) + --- PASS: TestRetA/kernel (0.00s) +=== CONT TestTAX +=== RUN TestTAX/C === RUN TestALUXor/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 @@ -4235,72 +2751,53 @@ 12: Exit === RUN TestALUXor/kernel#02 === RUN TestALUXor/C#03 -=== 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) -=== RUN TestJumpIfBitsNotSet/eBPF#01 -=== CONT TestRetA -=== RUN TestRetA/C -=== NAME TestJumpIfBitsNotSet/eBPF#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: 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: 17 + 3: Mod32Imm dst: r4 imm: 4 + 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 TestJumpIfBitsNotSet/kernel#01 -=== RUN TestRetConstant/eBPF + 12: Exit +=== RUN TestALUMod/kernel#02 +=== RUN TestALUMod/C#03 +=== 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: 1 - 3: JaImm dst: r0 off: -1 imm: 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: - 4: MovImm dst: r0 imm: 2 - 5: JEqImm dst: r4 off: -1 imm: 0 - 6: 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: - 7: Exit -=== RUN TestRetConstant/kernel -=== RUN TestRetConstant/C#01 -=== RUN TestJumpIfBitsNotSet/C#02 + 12: Exit +=== RUN TestALUShiftRight/kernel#02 +=== RUN TestALUShiftRight/C#03 === RUN TestALUXor/eBPF#03 +=== RUN TestTAX/eBPF +=== NAME 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 @@ -4325,70 +2822,99 @@ 15: MovImm dst: r0 imm: 1 return: 16: Exit +=== NAME 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 === RUN TestALUXor/kernel#03 ---- PASS: TestALUXor (0.28s) - --- SKIP: TestALUXor/C (0.07s) +--- PASS: TestTAX (0.12s) + --- SKIP: TestTAX/C (0.11s) + --- SKIP: TestTAX/eBPF (0.00s) + --- PASS: TestTAX/kernel (0.00s) +=== CONT TestTXA +=== RUN TestTXA/C +--- PASS: TestALUXor (0.44s) + --- SKIP: TestALUXor/C (0.11s) --- SKIP: TestALUXor/eBPF (0.00s) --- PASS: TestALUXor/kernel (0.00s) - --- SKIP: TestALUXor/C#01 (0.07s) + --- SKIP: TestALUXor/C#01 (0.12s) --- SKIP: TestALUXor/eBPF#01 (0.00s) --- PASS: TestALUXor/kernel#01 (0.00s) - --- SKIP: TestALUXor/C#02 (0.07s) + --- SKIP: TestALUXor/C#02 (0.11s) --- SKIP: TestALUXor/eBPF#02 (0.00s) --- PASS: TestALUXor/kernel#02 (0.00s) - --- SKIP: TestALUXor/C#03 (0.07s) + --- SKIP: TestALUXor/C#03 (0.10s) --- SKIP: TestALUXor/eBPF#03 (0.00s) --- PASS: TestALUXor/kernel#03 (0.00s) -=== CONT TestJumpIfLessOrEqual -=== RUN TestJumpIfLessOrEqual/C -=== RUN TestRetA/eBPF +=== CONT TestRetConstant +=== RUN TestRetConstant/C +=== 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: 1 - 3: Mov32Reg dst: r4 src: r4 - 4: 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: - 5: MovImm dst: r0 imm: 2 - 6: JEqImm dst: r4 off: -1 imm: 0 - 7: 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: - 8: Exit -=== RUN TestRetA/kernel ---- PASS: TestRetA (0.07s) - --- SKIP: TestRetA/C (0.07s) - --- SKIP: TestRetA/eBPF (0.00s) - --- PASS: TestRetA/kernel (0.00s) + 16: Exit +=== RUN TestALUMod/kernel#03 +--- PASS: TestALUMod (0.47s) + --- SKIP: TestALUMod/C (0.11s) + --- SKIP: TestALUMod/eBPF (0.00s) + --- PASS: TestALUMod/kernel (0.00s) + --- SKIP: TestALUMod/C#01 (0.11s) + --- SKIP: TestALUMod/eBPF#01 (0.00s) + --- PASS: TestALUMod/kernel#01 (0.00s) + --- SKIP: TestALUMod/C#02 (0.12s) + --- SKIP: TestALUMod/eBPF#02 (0.00s) + --- PASS: TestALUMod/kernel#02 (0.00s) + --- SKIP: TestALUMod/C#03 (0.12s) + --- SKIP: TestALUMod/eBPF#03 (0.00s) + --- PASS: TestALUMod/kernel#03 (0.00s) === CONT TestJumpIfBitsSet === RUN TestJumpIfBitsSet/C -=== 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 TestJumpIfBitsNotSet/eBPF#02 +=== 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: 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: + 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_4: + filter_block_5: 8: Mov32Imm dst: r4 imm: 1 9: JaImm dst: r0 off: -1 imm: 0 result: @@ -4397,27 +2923,61 @@ 12: MovImm dst: r0 imm: 1 return: 13: Exit -=== RUN TestJumpIfBitsNotSet/kernel#02 -=== RUN TestJumpIfLessOrEqual/eBPF +=== RUN TestALUShiftRight/kernel#03 +--- PASS: TestALUShiftRight (0.46s) + --- SKIP: TestALUShiftRight/C (0.11s) + --- SKIP: TestALUShiftRight/eBPF (0.00s) + --- PASS: TestALUShiftRight/kernel (0.00s) + --- SKIP: TestALUShiftRight/C#01 (0.11s) + --- SKIP: TestALUShiftRight/eBPF#01 (0.00s) + --- PASS: TestALUShiftRight/kernel#01 (0.00s) + --- SKIP: TestALUShiftRight/C#02 (0.12s) + --- SKIP: TestALUShiftRight/eBPF#02 (0.00s) + --- PASS: TestALUShiftRight/kernel#02 (0.00s) + --- SKIP: TestALUShiftRight/C#03 (0.11s) + --- SKIP: TestALUShiftRight/eBPF#03 (0.00s) + --- PASS: TestALUShiftRight/kernel#03 (0.00s) +=== CONT TestJumpIfBitsNotSet +=== RUN TestJumpIfBitsNotSet/C +=== RUN TestTXA/eBPF +=== RUN TestRetConstant/eBPF +=== NAME 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: r4 imm: 24 - 3: JLEImm dst: r4 off: -1 imm: 23 - filter_block_2: - 4: Mov32Imm dst: r4 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 - 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 + 6: MovImm dst: r0 imm: 2 + 7: JEqImm dst: r4 off: -1 imm: 0 + 8: MovImm dst: r0 imm: 1 return: - 11: Exit -=== RUN TestJumpIfLessOrEqual/kernel + 9: Exit +=== 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 TestTXA/kernel +=== RUN TestRetConstant/kernel +=== RUN TestRetConstant/C#01 +--- PASS: TestTXA (0.11s) + --- SKIP: TestTXA/C (0.10s) + --- SKIP: TestTXA/eBPF (0.00s) + --- PASS: TestTXA/kernel (0.00s) +=== CONT TestScratchA +=== RUN TestScratchA/C === RUN TestJumpIfBitsSet/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 @@ -4439,17 +2999,83 @@ 11: Exit === RUN TestJumpIfBitsSet/kernel === RUN TestJumpIfBitsSet/C#01 ---- PASS: TestRetConstant (0.20s) - --- SKIP: TestRetConstant/C (0.07s) +=== RUN TestRetConstant/eBPF#01 +=== RUN TestJumpIfBitsNotSet/eBPF +=== RUN TestScratchA/eBPF +=== NAME 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 +=== 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 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 +--- PASS: TestRetConstant (0.26s) + --- SKIP: TestRetConstant/C (0.10s) --- SKIP: TestRetConstant/eBPF (0.00s) --- PASS: TestRetConstant/kernel (0.00s) - --- SKIP: TestRetConstant/C#01 (0.07s) + --- SKIP: TestRetConstant/C#01 (0.10s) --- SKIP: TestRetConstant/eBPF#01 (0.00s) --- PASS: TestRetConstant/kernel#01 (0.05s) -=== CONT TestMemShift -=== RUN TestMemShift/C -=== RUN TestJumpIfBitsNotSet/C#03 -=== RUN TestJumpIfLessOrEqual/C#01 +=== CONT TestALUMul +=== RUN TestALUMul/C +=== RUN TestJumpIfBitsNotSet/C#01 === RUN TestJumpIfBitsSet/eBPF#01 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 @@ -4477,48 +3103,75 @@ 15: Exit === RUN TestJumpIfBitsSet/kernel#01 === RUN TestJumpIfBitsSet/C#02 -=== RUN TestMemShift/eBPF +=== 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: 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 + 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.21s) + --- SKIP: TestScratchA/C (0.10s) + --- SKIP: TestScratchA/eBPF (0.00s) + --- PASS: TestScratchA/kernel (0.00s) + --- SKIP: TestScratchA/C#01 (0.11s) + --- SKIP: TestScratchA/eBPF#01 (0.00s) + --- PASS: TestScratchA/kernel#01 (0.00s) +=== CONT TestScratchZero +=== RUN TestScratchZero/C +=== RUN TestALUMul/eBPF +=== RUN TestJumpIfBitsNotSet/eBPF#01 +=== 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: - 10: Mov32Imm dst: r4 imm: 0 - 11: JaImm dst: r0 off: -1 imm: 0 + 5: Mov32Imm dst: r4 imm: 0 + 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 + 7: Mov32Imm dst: r4 imm: 1 + 8: 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 + 9: MovImm dst: r0 imm: 2 + 10: JEqImm dst: r4 off: -1 imm: 0 + 11: MovImm dst: r0 imm: 1 return: - 19: Exit -=== RUN TestMemShift/kernel -=== RUN TestMemShift/C#01 -=== RUN TestJumpIfLessOrEqual/eBPF#01 -=== RUN TestJumpIfBitsNotSet/eBPF#03 -=== NAME TestJumpIfLessOrEqual/eBPF#01 + 12: Exit +=== RUN TestALUMul/kernel +=== NAME 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: 24 + 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: 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 @@ -4534,34 +3187,8 @@ 14: MovImm dst: r0 imm: 1 return: 15: Exit -=== RUN TestJumpIfLessOrEqual/kernel#01 -=== NAME 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 TestJumpIfBitsNotSet/kernel#01 +=== RUN TestALUMul/C#01 === RUN TestJumpIfBitsSet/eBPF#02 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 @@ -4584,47 +3211,84 @@ 12: Exit === RUN TestJumpIfBitsSet/kernel#02 === RUN TestJumpIfBitsSet/C#03 -=== RUN TestMemShift/eBPF#01 +=== RUN TestJumpIfBitsNotSet/C#02 +=== 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: 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 + 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.11s) + --- SKIP: TestScratchZero/C (0.11s) + --- SKIP: TestScratchZero/eBPF (0.00s) + --- PASS: TestScratchZero/kernel (0.00s) +=== CONT TestALUAnd +=== RUN TestALUAnd/C +=== 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: - 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 + 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: - 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 TestMemShift/kernel#01 ---- PASS: TestMemShift (0.15s) - --- SKIP: TestMemShift/C (0.08s) - --- SKIP: TestMemShift/eBPF (0.00s) - --- PASS: TestMemShift/kernel (0.00s) - --- SKIP: TestMemShift/C#01 (0.07s) - --- SKIP: TestMemShift/eBPF#01 (0.00s) - --- PASS: TestMemShift/kernel#01 (0.00s) -=== CONT TestALUSub -=== RUN TestALUSub/C -=== RUN TestJumpIfBitsNotSet/C#04 -=== RUN TestJumpIfLessOrEqual/C#02 + 13: Exit +=== RUN TestALUMul/kernel#01 +=== RUN TestALUMul/C#02 +=== RUN TestJumpIfBitsNotSet/eBPF#02 === RUN TestJumpIfBitsSet/eBPF#03 +=== NAME 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 +=== NAME 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 @@ -4652,13 +3316,13 @@ 16: Exit === RUN TestJumpIfBitsSet/kernel#03 === RUN TestJumpIfBitsSet/C#04 -=== RUN TestALUSub/eBPF +=== 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: Sub32Imm 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 @@ -4672,37 +3336,17 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestALUSub/kernel -=== RUN TestALUSub/C#01 -=== 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#02 +=== RUN TestALUAnd/kernel +=== RUN TestALUAnd/C#01 +=== RUN TestJumpIfBitsNotSet/C#03 +=== 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: 24 - 3: Mov32Imm dst: r5 imm: 23 - 4: JLEReg dst: r4 off: -1 src: r5 + 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 @@ -4715,9 +3359,11 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestJumpIfLessOrEqual/kernel#02 -=== RUN TestJumpIfBitsNotSet/C#05 +=== RUN TestALUMul/kernel#02 +=== RUN TestALUMul/C#03 === RUN TestJumpIfBitsSet/eBPF#04 +=== RUN TestALUAnd/eBPF#01 +=== NAME 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 @@ -4737,16 +3383,14 @@ return: 11: Exit === RUN TestJumpIfBitsSet/kernel#04 -=== RUN TestJumpIfLessOrEqual/C#03 -=== RUN TestJumpIfBitsSet/C#05 -=== RUN TestALUSub/eBPF#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: 1 - 4: Sub32Reg dst: r4 src: r5 + 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 @@ -4760,19 +3404,43 @@ 12: MovImm dst: r0 imm: 1 return: 13: Exit -=== RUN TestALUSub/kernel#01 -=== RUN TestALUSub/C#02 -=== RUN TestJumpIfLessOrEqual/eBPF#03 +=== RUN TestALUAnd/kernel#01 +=== RUN TestJumpIfBitsSet/C#05 +=== RUN TestALUAnd/C#02 +=== RUN TestALUMul/eBPF#03 +=== RUN TestJumpIfBitsNotSet/eBPF#03 +=== NAME 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: 24 - 3: Mov32Imm dst: r5 imm: 23 + 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 +=== NAME 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: JLEReg dst: r4 off: -1 src: r5 - 6: 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 @@ -4788,8 +3456,13 @@ 15: MovImm dst: r0 imm: 1 return: 16: Exit -=== RUN TestJumpIfLessOrEqual/kernel#03 +=== RUN TestALUMul/kernel#03 +=== RUN TestJumpIfBitsNotSet/kernel#03 +=== RUN TestALUMul/C#04 === RUN TestJumpIfBitsSet/eBPF#05 +=== RUN TestALUAnd/eBPF#02 +=== RUN TestJumpIfBitsNotSet/C#04 +=== 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 @@ -4814,43 +3487,38 @@ 14: MovImm dst: r0 imm: 1 return: 15: Exit -=== RUN TestJumpIfBitsSet/kernel#05 -=== RUN TestJumpIfBitsNotSet/eBPF#05 -=== RUN TestJumpIfBitsSet/C#06 -=== NAME TestJumpIfBitsNotSet/eBPF#05 +=== NAME 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: 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: 240 + 3: And32Imm dst: r4 imm: 128 + 4: JEqImm dst: r4 off: -1 imm: 128 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#05 -=== RUN TestALUSub/eBPF#02 + 12: Exit +=== RUN TestJumpIfBitsSet/kernel#05 +=== RUN TestALUAnd/kernel#02 +=== RUN TestALUAnd/C#03 +=== RUN TestJumpIfBitsSet/C#06 +=== 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 @@ -4863,34 +3531,10 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestALUSub/kernel#02 -=== RUN TestALUSub/C#03 -=== RUN TestJumpIfLessOrEqual/C#04 -=== RUN TestJumpIfBitsNotSet/C#06 -=== RUN TestALUSub/eBPF#03 +=== RUN TestALUMul/kernel#04 +=== RUN TestALUMul/C#05 === RUN TestJumpIfBitsSet/eBPF#06 -=== NAME 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 +=== RUN TestJumpIfBitsNotSet/eBPF#04 === NAME TestJumpIfBitsSet/eBPF#06 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 @@ -4912,57 +3556,65 @@ return: 12: Exit === RUN TestJumpIfBitsSet/kernel#06 -=== RUN TestJumpIfBitsSet/C#07 ---- PASS: TestALUSub (0.29s) - --- SKIP: TestALUSub/C (0.07s) - --- SKIP: TestALUSub/eBPF (0.00s) - --- PASS: TestALUSub/kernel (0.00s) - --- SKIP: TestALUSub/C#01 (0.07s) - --- SKIP: TestALUSub/eBPF#01 (0.00s) - --- PASS: TestALUSub/kernel#01 (0.00s) - --- SKIP: TestALUSub/C#02 (0.07s) - --- SKIP: TestALUSub/eBPF#02 (0.00s) - --- PASS: TestALUSub/kernel#02 (0.00s) - --- SKIP: TestALUSub/C#03 (0.07s) - --- SKIP: TestALUSub/eBPF#03 (0.00s) - --- PASS: TestALUSub/kernel#03 (0.00s) -=== CONT TestALUAdd -=== RUN TestALUAdd/C -=== RUN TestJumpIfLessOrEqual/eBPF#04 -=== RUN TestJumpIfBitsNotSet/eBPF#06 -=== NAME TestJumpIfLessOrEqual/eBPF#04 +=== NAME 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: 23 - 3: JLEImm dst: r4 off: -1 imm: 23 + 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: - 4: Mov32Imm dst: r4 imm: 0 - 5: JaImm dst: r0 off: -1 imm: 0 + 5: Mov32Imm dst: r4 imm: 0 + 6: JaImm dst: r0 off: -1 imm: 0 filter_block_3: - 6: Mov32Imm dst: r4 imm: 1 - 7: JaImm dst: r0 off: -1 imm: 0 + 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 TestJumpIfLessOrEqual/kernel#04 -=== NAME TestJumpIfBitsNotSet/eBPF#06 + 12: Exit +=== RUN TestJumpIfBitsNotSet/kernel#04 +=== RUN TestJumpIfBitsSet/C#07 +=== 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: 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: + 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 TestJumpIfBitsNotSet/C#05 +=== 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: @@ -4971,8 +3623,29 @@ 12: MovImm dst: r0 imm: 1 return: 13: Exit -=== RUN TestJumpIfBitsNotSet/kernel#06 -=== RUN TestJumpIfLessOrEqual/C#05 +=== RUN TestALUMul/kernel#05 +--- PASS: TestALUMul (0.66s) + --- SKIP: TestALUMul/C (0.11s) + --- SKIP: TestALUMul/eBPF (0.00s) + --- PASS: TestALUMul/kernel (0.00s) + --- SKIP: TestALUMul/C#01 (0.11s) + --- SKIP: TestALUMul/eBPF#01 (0.00s) + --- PASS: TestALUMul/kernel#01 (0.00s) + --- SKIP: TestALUMul/C#02 (0.11s) + --- SKIP: TestALUMul/eBPF#02 (0.00s) + --- PASS: TestALUMul/kernel#02 (0.00s) + --- SKIP: TestALUMul/C#03 (0.10s) + --- 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.11s) + --- SKIP: TestALUMul/eBPF#05 (0.00s) + --- PASS: TestALUMul/kernel#05 (0.00s) +=== CONT TestLoadIndirect +=== RUN TestLoadIndirect/constant_valid +=== RUN TestLoadIndirect/constant_valid/C === RUN TestJumpIfBitsSet/eBPF#07 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 @@ -5000,16 +3673,15 @@ return: 16: Exit === RUN TestJumpIfBitsSet/kernel#07 -=== RUN TestALUAdd/eBPF === RUN TestJumpIfBitsSet/C#08 -=== NAME TestALUAdd/eBPF +=== 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: 1 - 3: Add32Imm dst: r4 imm: 0 - 4: JEqImm dst: r4 off: -1 imm: 1 + 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 @@ -5022,19 +3694,18 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestALUAdd/kernel -=== RUN TestALUAdd/C#01 -=== RUN TestJumpIfBitsNotSet/C#07 -=== RUN TestJumpIfLessOrEqual/eBPF#05 +=== RUN TestALUAnd/kernel#04 +=== RUN TestALUAnd/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: 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: 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 @@ -5050,17 +3721,52 @@ 14: MovImm dst: r0 imm: 1 return: 15: Exit -=== RUN TestJumpIfLessOrEqual/kernel#05 -=== RUN TestJumpIfLessOrEqual/C#06 -=== RUN TestALUAdd/eBPF#01 +=== RUN TestJumpIfBitsNotSet/kernel#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: r4 imm: 1 - 3: Mov32Imm dst: r5 imm: 0 - 4: Add32Reg dst: r4 src: r5 - 5: JEqImm dst: r4 off: -1 imm: 1 + 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 TestJumpIfBitsSet/eBPF#08 +=== RUN TestJumpIfBitsNotSet/C#06 +=== 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 @@ -5073,9 +3779,8 @@ 12: MovImm dst: r0 imm: 1 return: 13: Exit -=== RUN TestALUAdd/kernel#01 -=== RUN TestALUAdd/C#02 -=== RUN TestJumpIfBitsSet/eBPF#08 +=== RUN TestALUAnd/kernel#05 +=== 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 @@ -5095,64 +3800,69 @@ return: 11: Exit === RUN TestJumpIfBitsSet/kernel#08 -=== 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#06 +--- PASS: TestALUAnd (0.65s) + --- SKIP: TestALUAnd/C (0.10s) + --- SKIP: TestALUAnd/eBPF (0.00s) + --- PASS: TestALUAnd/kernel (0.00s) + --- SKIP: TestALUAnd/C#01 (0.11s) + --- SKIP: TestALUAnd/eBPF#01 (0.00s) + --- PASS: TestALUAnd/kernel#01 (0.00s) + --- SKIP: TestALUAnd/C#02 (0.11s) + --- SKIP: TestALUAnd/eBPF#02 (0.00s) + --- PASS: TestALUAnd/kernel#02 (0.00s) + --- SKIP: TestALUAnd/C#03 (0.11s) + --- SKIP: TestALUAnd/eBPF#03 (0.00s) + --- PASS: TestALUAnd/kernel#03 (0.00s) + --- SKIP: TestALUAnd/C#04 (0.11s) + --- SKIP: TestALUAnd/eBPF#04 (0.00s) + --- PASS: TestALUAnd/kernel#04 (0.00s) + --- SKIP: TestALUAnd/C#05 (0.11s) + --- SKIP: TestALUAnd/eBPF#05 (0.00s) + --- PASS: TestALUAnd/kernel#05 (0.00s) +=== CONT TestALUOr +=== RUN TestALUOr/C +=== RUN TestJumpIfBitsSet/C#09 +=== 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: r4 imm: 23 - 3: Mov32Imm dst: r5 imm: 23 - 4: JLEReg dst: r4 off: -1 src: r5 + 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: - 5: Mov32Imm dst: r4 imm: 0 - 6: JaImm dst: r0 off: -1 imm: 0 + 14: Mov32Imm dst: r4 imm: 0 + 15: JaImm dst: r0 off: -1 imm: 0 filter_block_4: - 7: Mov32Imm dst: r4 imm: 1 - 8: JaImm dst: r0 off: -1 imm: 0 + 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: - 9: MovImm dst: r0 imm: 2 - 10: JEqImm dst: r4 off: -1 imm: 0 - 11: MovImm dst: r0 imm: 1 + 20: MovImm dst: r0 imm: 2 + 21: JEqImm dst: r4 off: -1 imm: 0 + 22: MovImm dst: r0 imm: 1 return: - 12: Exit -=== RUN TestJumpIfLessOrEqual/kernel#06 -=== RUN TestJumpIfLessOrEqual/C#07 -=== RUN TestJumpIfBitsSet/C#09 -=== RUN TestALUAdd/eBPF#02 + 23: Exit +=== RUN TestLoadIndirect/constant_valid/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: 4 - 3: Add32Imm dst: r4 imm: 13 - 4: JEqImm dst: r4 off: -1 imm: 17 + 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 @@ -5165,37 +3875,31 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestALUAdd/kernel#02 -=== RUN TestALUAdd/C#03 -=== RUN TestJumpIfBitsNotSet/C#08 -=== RUN TestJumpIfLessOrEqual/eBPF#07 +=== RUN TestALUOr/kernel +=== RUN TestALUOr/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: 23 - 3: Mov32Imm dst: r5 imm: 23 - 4: JEqImm dst: r4 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: - 5: JLEReg dst: r4 off: -1 src: r5 - 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 - 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 + 8: Mov32Imm dst: r4 imm: 1 + 9: 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 + 10: MovImm dst: r0 imm: 2 + 11: JEqImm dst: r4 off: -1 imm: 0 + 12: MovImm dst: r0 imm: 1 return: - 16: Exit -=== RUN TestJumpIfLessOrEqual/kernel#07 -=== RUN TestJumpIfLessOrEqual/C#08 + 13: Exit +=== RUN TestJumpIfBitsNotSet/kernel#06 +=== RUN TestLoadIndirect/constant_valid/C#02 === RUN TestJumpIfBitsSet/eBPF#09 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 @@ -5222,15 +3926,17 @@ return: 15: Exit === RUN TestJumpIfBitsSet/kernel#09 -=== RUN TestALUAdd/eBPF#03 +=== RUN TestJumpIfBitsNotSet/C#07 +=== RUN TestJumpIfBitsSet/C#10 +=== 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: 4 - 3: Mov32Imm dst: r5 imm: 13 - 4: Add32Reg dst: r4 src: r5 - 5: JEqImm dst: r4 off: -1 imm: 17 + 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 @@ -5243,78 +3949,105 @@ 12: MovImm dst: r0 imm: 1 return: 13: Exit -=== RUN TestALUAdd/kernel#03 ---- PASS: TestALUAdd (0.29s) - --- SKIP: TestALUAdd/C (0.07s) - --- SKIP: TestALUAdd/eBPF (0.00s) - --- PASS: TestALUAdd/kernel (0.00s) - --- SKIP: TestALUAdd/C#01 (0.07s) - --- SKIP: TestALUAdd/eBPF#01 (0.00s) - --- PASS: TestALUAdd/kernel#01 (0.00s) - --- SKIP: TestALUAdd/C#02 (0.07s) - --- SKIP: TestALUAdd/eBPF#02 (0.00s) - --- PASS: TestALUAdd/kernel#02 (0.00s) - --- SKIP: TestALUAdd/C#03 (0.07s) - --- SKIP: TestALUAdd/eBPF#03 (0.00s) - --- PASS: TestALUAdd/kernel#03 (0.00s) -=== CONT TestLoadExtLen -=== RUN TestLoadExtLen/C -=== RUN TestJumpIfBitsNotSet/eBPF#08 +=== RUN TestALUOr/kernel#01 +=== RUN TestALUOr/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 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: 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 + 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: - 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 TestJumpIfBitsNotSet/kernel#08 -=== RUN TestJumpIfBitsNotSet/C#09 -=== RUN TestJumpIfBitsSet/C#10 -=== RUN TestJumpIfLessOrEqual/eBPF#08 + 16: Exit +=== RUN TestJumpIfBitsNotSet/kernel#07 +=== RUN TestJumpIfBitsSet/eBPF#10 +=== RUN TestALUOr/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: 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 + 2: Mov32Imm dst: r4 imm: 6 + 3: Mov32Imm dst: r5 imm: 8 + 4: JSetReg 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: + 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 TestJumpIfLessOrEqual/kernel#08 -=== RUN TestJumpIfLessOrEqual/C#09 -=== RUN TestLoadExtLen/eBPF + 12: Exit +=== RUN TestJumpIfBitsSet/kernel#10 +=== NAME 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: MovReg dst: r4 src: r3 - 3: Sub32Reg dst: r4 src: r2 - 4: JEqImm dst: r4 off: -1 imm: 16 - filter_block_2: + 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_3: + filter_block_4: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: @@ -5323,52 +4056,107 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestLoadExtLen/kernel ---- PASS: TestLoadExtLen (0.08s) - --- SKIP: TestLoadExtLen/C (0.08s) - --- SKIP: TestLoadExtLen/eBPF (0.00s) - --- PASS: TestLoadExtLen/kernel (0.00s) -=== CONT TestScratchA -=== RUN TestScratchA/C -=== RUN TestJumpIfBitsNotSet/eBPF#09 +=== RUN TestALUOr/kernel#02 +=== RUN TestALUOr/C#03 +=== RUN TestJumpIfBitsNotSet/C#08 +=== RUN TestJumpIfBitsSet/C#11 +=== 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: 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 + 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: - 6: Mov32Imm dst: r4 imm: 1 - 7: JaImm dst: r0 off: -1 imm: 0 + 15: Mov32Imm dst: r4 imm: 0 + 16: JaImm dst: r0 off: -1 imm: 0 filter_block_4: - 8: Mov32Imm dst: r4 imm: 0 - 9: JaImm dst: r0 off: -1 imm: 0 + 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 TestJumpIfBitsSet/eBPF#11 +=== RUN TestALUOr/eBPF#03 +=== RUN TestJumpIfBitsNotSet/eBPF#08 +=== 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: - 10: Mov32Imm dst: r4 imm: 1 - 11: JaImm dst: r0 off: -1 imm: 0 + 8: Mov32Imm dst: r4 imm: 1 + 9: 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 TestJumpIfBitsNotSet/kernel#09 -=== RUN TestJumpIfBitsNotSet/C#10 -=== RUN TestJumpIfBitsSet/eBPF#10 + 13: Exit +=== NAME 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: JSetReg dst: r4 off: -1 src: r5 + 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 TestALUOr/kernel#03 +=== NAME 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_4: + filter_block_3: 7: Mov32Imm dst: r4 imm: 1 8: JaImm dst: r0 off: -1 imm: 0 result: @@ -5377,17 +4165,98 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestJumpIfBitsSet/kernel#10 -=== RUN TestJumpIfLessOrEqual/eBPF#09 +=== RUN TestJumpIfBitsNotSet/kernel#08 +=== RUN TestJumpIfBitsSet/kernel#11 +=== RUN TestJumpIfBitsNotSet/C#09 +--- PASS: TestALUOr (0.48s) + --- SKIP: TestALUOr/C (0.10s) + --- SKIP: TestALUOr/eBPF (0.00s) + --- PASS: TestALUOr/kernel (0.00s) + --- SKIP: TestALUOr/C#01 (0.10s) + --- SKIP: TestALUOr/eBPF#01 (0.00s) + --- PASS: TestALUOr/kernel#01 (0.00s) + --- SKIP: TestALUOr/C#02 (0.10s) + --- SKIP: TestALUOr/eBPF#02 (0.00s) + --- PASS: TestALUOr/kernel#02 (0.00s) + --- SKIP: TestALUOr/C#03 (0.16s) + --- SKIP: TestALUOr/eBPF#03 (0.00s) + --- PASS: TestALUOr/kernel#03 (0.00s) +=== CONT TestLoadAbsoluteBigOffset +=== RUN TestLoadAbsoluteBigOffset/C +=== RUN TestLoadIndirect/constant_valid/C#04 +--- PASS: TestJumpIfBitsSet (1.52s) + --- SKIP: TestJumpIfBitsSet/C (0.11s) + --- SKIP: TestJumpIfBitsSet/eBPF (0.00s) + --- PASS: TestJumpIfBitsSet/kernel (0.00s) + --- SKIP: TestJumpIfBitsSet/C#01 (0.11s) + --- SKIP: TestJumpIfBitsSet/eBPF#01 (0.00s) + --- PASS: TestJumpIfBitsSet/kernel#01 (0.00s) + --- SKIP: TestJumpIfBitsSet/C#02 (0.11s) + --- SKIP: TestJumpIfBitsSet/eBPF#02 (0.00s) + --- PASS: TestJumpIfBitsSet/kernel#02 (0.00s) + --- SKIP: TestJumpIfBitsSet/C#03 (0.11s) + --- SKIP: TestJumpIfBitsSet/eBPF#03 (0.00s) + --- PASS: TestJumpIfBitsSet/kernel#03 (0.00s) + --- SKIP: TestJumpIfBitsSet/C#04 (0.11s) + --- SKIP: TestJumpIfBitsSet/eBPF#04 (0.00s) + --- PASS: TestJumpIfBitsSet/kernel#04 (0.00s) + --- SKIP: TestJumpIfBitsSet/C#05 (0.11s) + --- SKIP: TestJumpIfBitsSet/eBPF#05 (0.00s) + --- PASS: TestJumpIfBitsSet/kernel#05 (0.00s) + --- SKIP: TestJumpIfBitsSet/C#06 (0.11s) + --- SKIP: TestJumpIfBitsSet/eBPF#06 (0.00s) + --- PASS: TestJumpIfBitsSet/kernel#06 (0.00s) + --- SKIP: TestJumpIfBitsSet/C#07 (0.11s) + --- SKIP: TestJumpIfBitsSet/eBPF#07 (0.00s) + --- PASS: TestJumpIfBitsSet/kernel#07 (0.00s) + --- SKIP: TestJumpIfBitsSet/C#08 (0.11s) + --- SKIP: TestJumpIfBitsSet/eBPF#08 (0.00s) + --- PASS: TestJumpIfBitsSet/kernel#08 (0.05s) + --- SKIP: TestJumpIfBitsSet/C#09 (0.11s) + --- SKIP: TestJumpIfBitsSet/eBPF#09 (0.00s) + --- PASS: TestJumpIfBitsSet/kernel#09 (0.05s) + --- SKIP: TestJumpIfBitsSet/C#10 (0.11s) + --- SKIP: TestJumpIfBitsSet/eBPF#10 (0.00s) + --- PASS: TestJumpIfBitsSet/kernel#10 (0.05s) + --- SKIP: TestJumpIfBitsSet/C#11 (0.11s) + --- SKIP: TestJumpIfBitsSet/eBPF#11 (0.00s) + --- PASS: TestJumpIfBitsSet/kernel#11 (0.05s) +=== CONT TestALUDivZero +=== RUN TestALUDivZero/C +=== RUN TestJumpIfBitsNotSet/eBPF#09 +=== 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: 22 + 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 +=== NAME 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: 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 @@ -5403,37 +4272,71 @@ 14: MovImm dst: r0 imm: 1 return: 15: Exit -=== RUN TestJumpIfLessOrEqual/kernel#09 -=== RUN TestJumpIfLessOrEqual/C#10 -=== RUN TestScratchA/eBPF +=== RUN TestLoadAbsoluteBigOffset/kernel +=== RUN TestJumpIfBitsNotSet/kernel#09 +=== RUN TestJumpIfBitsNotSet/C#10 +=== 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: 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 + 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/C#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 - 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 + 14: MovImm dst: r0 imm: 2 + 15: JEqImm dst: r4 off: -1 imm: 0 + 16: MovImm dst: r0 imm: 1 return: - 19: Exit -=== RUN TestScratchA/kernel -=== RUN TestScratchA/C#01 + 17: Exit +=== RUN TestALUDivZero/kernel === RUN TestJumpIfBitsNotSet/eBPF#10 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 @@ -5457,65 +4360,59 @@ 13: Exit === RUN TestJumpIfBitsNotSet/kernel#10 === RUN TestJumpIfBitsNotSet/C#11 -=== RUN TestJumpIfBitsSet/C#11 -=== RUN TestJumpIfLessOrEqual/eBPF#10 +=== RUN TestALUDivZero/C#01 +=== 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: r4 imm: 22 - 3: Mov32Imm dst: r5 imm: 23 - 4: JLEReg dst: r4 off: -1 src: r5 + 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: - 5: Mov32Imm dst: r4 imm: 0 - 6: JaImm dst: r0 off: -1 imm: 0 + 16: Mov32Imm dst: r4 imm: 0 + 17: JaImm dst: r0 off: -1 imm: 0 filter_block_4: - 7: Mov32Imm dst: r4 imm: 1 - 8: JaImm dst: r0 off: -1 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: - 9: MovImm dst: r0 imm: 2 - 10: JEqImm dst: r4 off: -1 imm: 0 - 11: MovImm dst: r0 imm: 1 + 22: MovImm dst: r0 imm: 2 + 23: JEqImm dst: r4 off: -1 imm: 0 + 24: MovImm dst: r0 imm: 1 return: - 12: Exit -=== RUN TestJumpIfLessOrEqual/kernel#10 -=== RUN TestJumpIfLessOrEqual/C#11 -=== RUN TestScratchA/eBPF#01 + 25: Exit +=== RUN TestLoadIndirect/constant_valid/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: 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 + 3: 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 + 4: MovImm dst: r0 imm: 2 + 5: JEqImm dst: r4 off: -1 imm: 0 + 6: MovImm dst: r0 imm: 1 return: - 18: Exit -=== RUN TestScratchA/kernel#01 ---- PASS: TestScratchA (0.15s) - --- SKIP: TestScratchA/C (0.07s) - --- SKIP: TestScratchA/eBPF (0.00s) - --- PASS: TestScratchA/kernel (0.00s) - --- SKIP: TestScratchA/C#01 (0.07s) - --- SKIP: TestScratchA/eBPF#01 (0.00s) - --- PASS: TestScratchA/kernel#01 (0.00s) -=== CONT TestScratchX -=== RUN TestScratchX/C + 7: Exit +=== RUN TestLoadAbsoluteBigOffset/kernel#01 +=== RUN TestLoadIndirect/variable_valid +=== RUN TestLoadIndirect/variable_valid/C +=== RUN TestLoadAbsoluteBigOffset/C#02 === RUN TestJumpIfBitsNotSet/eBPF#11 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 @@ -5543,91 +4440,138 @@ return: 16: Exit === RUN TestJumpIfBitsNotSet/kernel#11 ---- PASS: TestJumpIfBitsNotSet (1.29s) - --- SKIP: TestJumpIfBitsNotSet/C (0.07s) +--- PASS: TestJumpIfBitsNotSet (1.77s) + --- SKIP: TestJumpIfBitsNotSet/C (0.11s) --- SKIP: TestJumpIfBitsNotSet/eBPF (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel (0.05s) - --- SKIP: TestJumpIfBitsNotSet/C#01 (0.07s) + --- SKIP: TestJumpIfBitsNotSet/C#01 (0.11s) --- SKIP: TestJumpIfBitsNotSet/eBPF#01 (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel#01 (0.05s) - --- SKIP: TestJumpIfBitsNotSet/C#02 (0.08s) + --- SKIP: TestJumpIfBitsNotSet/C#02 (0.11s) --- SKIP: TestJumpIfBitsNotSet/eBPF#02 (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel#02 (0.05s) - --- SKIP: TestJumpIfBitsNotSet/C#03 (0.08s) + --- SKIP: TestJumpIfBitsNotSet/C#03 (0.12s) --- SKIP: TestJumpIfBitsNotSet/eBPF#03 (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel#03 (0.05s) - --- SKIP: TestJumpIfBitsNotSet/C#04 (0.07s) + --- SKIP: TestJumpIfBitsNotSet/C#04 (0.11s) --- SKIP: TestJumpIfBitsNotSet/eBPF#04 (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel#04 (0.05s) - --- SKIP: TestJumpIfBitsNotSet/C#05 (0.08s) + --- SKIP: TestJumpIfBitsNotSet/C#05 (0.12s) --- SKIP: TestJumpIfBitsNotSet/eBPF#05 (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel#05 (0.05s) - --- SKIP: TestJumpIfBitsNotSet/C#06 (0.07s) + --- SKIP: TestJumpIfBitsNotSet/C#06 (0.11s) --- SKIP: TestJumpIfBitsNotSet/eBPF#06 (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel#06 (0.05s) - --- SKIP: TestJumpIfBitsNotSet/C#07 (0.07s) + --- SKIP: TestJumpIfBitsNotSet/C#07 (0.11s) --- SKIP: TestJumpIfBitsNotSet/eBPF#07 (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel#07 (0.05s) - --- SKIP: TestJumpIfBitsNotSet/C#08 (0.08s) + --- SKIP: TestJumpIfBitsNotSet/C#08 (0.15s) --- SKIP: TestJumpIfBitsNotSet/eBPF#08 (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel#08 (0.00s) - --- SKIP: TestJumpIfBitsNotSet/C#09 (0.07s) + --- SKIP: TestJumpIfBitsNotSet/C#09 (0.11s) --- SKIP: TestJumpIfBitsNotSet/eBPF#09 (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel#09 (0.00s) - --- SKIP: TestJumpIfBitsNotSet/C#10 (0.07s) + --- SKIP: TestJumpIfBitsNotSet/C#10 (0.11s) --- SKIP: TestJumpIfBitsNotSet/eBPF#10 (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel#10 (0.00s) - --- SKIP: TestJumpIfBitsNotSet/C#11 (0.07s) + --- SKIP: TestJumpIfBitsNotSet/C#11 (0.11s) --- SKIP: TestJumpIfBitsNotSet/eBPF#11 (0.00s) --- PASS: TestJumpIfBitsNotSet/kernel#11 (0.00s) -=== CONT TestALUOr -=== RUN TestALUOr/C -=== RUN TestJumpIfBitsSet/eBPF#11 +=== CONT TestLoadAbsolute +=== RUN TestLoadAbsolute/C +=== RUN 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: 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 + 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: TestALUDivZero (0.28s) + --- SKIP: TestALUDivZero/C (0.12s) + --- SKIP: TestALUDivZero/eBPF (0.00s) + --- PASS: TestALUDivZero/kernel (0.05s) + --- SKIP: TestALUDivZero/C#01 (0.11s) + --- SKIP: TestALUDivZero/eBPF#01 (0.00s) + --- PASS: TestALUDivZero/kernel#01 (0.00s) +=== CONT TestALUDiv +=== RUN TestALUDiv/C +=== 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: - 7: Mov32Imm dst: r4 imm: 1 - 8: JaImm dst: r0 off: -1 imm: 0 + 19: Mov32Imm dst: r4 imm: 0 + 20: 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 + 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: - 13: MovImm dst: r0 imm: 2 - 14: JEqImm dst: r4 off: -1 imm: 0 - 15: MovImm dst: r0 imm: 1 + 25: MovImm dst: r0 imm: 2 + 26: JEqImm dst: r4 off: -1 imm: 0 + 27: MovImm dst: r0 imm: 1 return: - 16: Exit -=== RUN TestJumpIfBitsSet/kernel#11 -=== RUN TestJumpIfLessOrEqual/eBPF#11 + 28: Exit +=== RUN TestLoadIndirect/variable_valid/kernel +=== RUN TestLoadIndirect/variable_valid/C#01 +=== RUN TestLoadAbsolute/eBPF +=== RUN TestLoadAbsoluteBigOffset/eBPF#02 +=== 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: 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 + 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: - 9: Mov32Imm dst: r4 imm: 0 + filter_block_3: + 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 @@ -5635,92 +4579,40 @@ 15: MovImm dst: r0 imm: 1 return: 16: Exit -=== RUN TestJumpIfLessOrEqual/kernel#11 ---- PASS: TestJumpIfLessOrEqual (1.08s) - --- SKIP: TestJumpIfLessOrEqual/C (0.07s) - --- SKIP: TestJumpIfLessOrEqual/eBPF (0.00s) - --- PASS: TestJumpIfLessOrEqual/kernel (0.05s) - --- SKIP: TestJumpIfLessOrEqual/C#01 (0.07s) - --- SKIP: TestJumpIfLessOrEqual/eBPF#01 (0.00s) - --- PASS: TestJumpIfLessOrEqual/kernel#01 (0.05s) - --- SKIP: TestJumpIfLessOrEqual/C#02 (0.07s) - --- SKIP: TestJumpIfLessOrEqual/eBPF#02 (0.00s) - --- PASS: TestJumpIfLessOrEqual/kernel#02 (0.05s) - --- SKIP: TestJumpIfLessOrEqual/C#03 (0.07s) - --- SKIP: TestJumpIfLessOrEqual/eBPF#03 (0.00s) - --- PASS: TestJumpIfLessOrEqual/kernel#03 (0.05s) - --- SKIP: TestJumpIfLessOrEqual/C#04 (0.07s) - --- SKIP: TestJumpIfLessOrEqual/eBPF#04 (0.00s) - --- PASS: TestJumpIfLessOrEqual/kernel#04 (0.00s) - --- SKIP: TestJumpIfLessOrEqual/C#05 (0.07s) - --- SKIP: TestJumpIfLessOrEqual/eBPF#05 (0.00s) - --- PASS: TestJumpIfLessOrEqual/kernel#05 (0.00s) - --- SKIP: TestJumpIfLessOrEqual/C#06 (0.07s) - --- SKIP: TestJumpIfLessOrEqual/eBPF#06 (0.00s) - --- PASS: TestJumpIfLessOrEqual/kernel#06 (0.00s) - --- SKIP: TestJumpIfLessOrEqual/C#07 (0.07s) - --- SKIP: TestJumpIfLessOrEqual/eBPF#07 (0.00s) - --- PASS: TestJumpIfLessOrEqual/kernel#07 (0.00s) - --- SKIP: TestJumpIfLessOrEqual/C#08 (0.07s) - --- SKIP: TestJumpIfLessOrEqual/eBPF#08 (0.00s) - --- PASS: TestJumpIfLessOrEqual/kernel#08 (0.00s) - --- SKIP: TestJumpIfLessOrEqual/C#09 (0.07s) - --- SKIP: TestJumpIfLessOrEqual/eBPF#09 (0.00s) - --- PASS: TestJumpIfLessOrEqual/kernel#09 (0.00s) - --- SKIP: TestJumpIfLessOrEqual/C#10 (0.07s) - --- SKIP: TestJumpIfLessOrEqual/eBPF#10 (0.00s) - --- PASS: TestJumpIfLessOrEqual/kernel#10 (0.00s) - --- SKIP: TestJumpIfLessOrEqual/C#11 (0.07s) - --- SKIP: TestJumpIfLessOrEqual/eBPF#11 (0.00s) - --- PASS: TestJumpIfLessOrEqual/kernel#11 (0.00s) -=== CONT TestALUShiftRight -=== RUN TestALUShiftRight/C ---- PASS: TestJumpIfBitsSet (1.10s) - --- SKIP: TestJumpIfBitsSet/C (0.07s) - --- 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.07s) - --- SKIP: TestJumpIfBitsSet/eBPF#02 (0.00s) - --- PASS: TestJumpIfBitsSet/kernel#02 (0.00s) - --- SKIP: TestJumpIfBitsSet/C#03 (0.07s) - --- SKIP: TestJumpIfBitsSet/eBPF#03 (0.00s) - --- PASS: TestJumpIfBitsSet/kernel#03 (0.00s) - --- SKIP: TestJumpIfBitsSet/C#04 (0.07s) - --- SKIP: TestJumpIfBitsSet/eBPF#04 (0.00s) - --- PASS: TestJumpIfBitsSet/kernel#04 (0.00s) - --- SKIP: TestJumpIfBitsSet/C#05 (0.07s) - --- SKIP: TestJumpIfBitsSet/eBPF#05 (0.00s) - --- PASS: TestJumpIfBitsSet/kernel#05 (0.00s) - --- SKIP: TestJumpIfBitsSet/C#06 (0.07s) - --- 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.07s) - --- SKIP: TestJumpIfBitsSet/eBPF#08 (0.00s) - --- PASS: TestJumpIfBitsSet/kernel#08 (0.05s) - --- SKIP: TestJumpIfBitsSet/C#09 (0.07s) - --- SKIP: TestJumpIfBitsSet/eBPF#09 (0.00s) - --- PASS: TestJumpIfBitsSet/kernel#09 (0.05s) - --- SKIP: TestJumpIfBitsSet/C#10 (0.09s) - --- SKIP: TestJumpIfBitsSet/eBPF#10 (0.00s) - --- PASS: TestJumpIfBitsSet/kernel#10 (0.05s) - --- SKIP: TestJumpIfBitsSet/C#11 (0.08s) - --- SKIP: TestJumpIfBitsSet/eBPF#11 (0.00s) - --- PASS: TestJumpIfBitsSet/kernel#11 (0.05s) -=== CONT TestALUShiftLeft -=== RUN TestALUShiftLeft/C -=== RUN TestALUOr/eBPF +=== RUN TestLoadAbsolute/kernel +=== 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: Mov32Imm dst: r4 imm: 1 - 3: Or32Imm dst: r4 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: 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 TestLoadAbsolute/C#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 @@ -5734,68 +4626,126 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestALUOr/kernel -=== RUN TestALUOr/C#01 -=== RUN TestScratchX/eBPF +=== RUN TestALUDiv/kernel +=== RUN TestALUDiv/C#01 +=== RUN TestLoadAbsoluteBigOffset/C#03 +=== RUN TestLoadIndirect/variable_valid/eBPF#01 +=== 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: 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 + 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: - 17: MovImm dst: r0 imm: 2 - 18: JEqImm dst: r4 off: -1 imm: 0 - 19: 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: - 20: Exit -=== RUN TestScratchX/kernel -=== RUN TestScratchX/C#01 -=== RUN TestALUShiftRight/eBPF + 16: Exit +=== RUN TestALUDiv/kernel#01 +=== NAME 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: 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 + 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: - 7: Mov32Imm dst: r4 imm: 1 + 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 TestALUDiv/C#02 +=== 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: - 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 TestALUShiftRight/kernel -=== RUN TestALUShiftRight/C#01 -=== RUN TestALUShiftLeft/eBPF + 16: Exit +=== RUN TestLoadAbsolute/kernel#01 +=== 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: 1 - 3: LSh32Imm dst: r4 imm: 0 - 4: JEqImm dst: r4 off: -1 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#03 +=== RUN TestLoadIndirect/variable_valid/C#02 +=== RUN TestLoadAbsolute/C#02 +=== RUN TestLoadAbsoluteBigOffset/C#04 +=== 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 @@ -5808,123 +4758,220 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestALUShiftLeft/kernel -=== RUN TestALUShiftLeft/C#01 -=== RUN TestScratchX/eBPF#01 +=== RUN TestALUDiv/kernel#02 +=== RUN TestALUDiv/C#03 +=== RUN TestLoadAbsolute/eBPF#02 +=== RUN TestLoadIndirect/variable_valid/eBPF#02 +=== NAME 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: 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 + 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 - 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 + 14: MovImm dst: r0 imm: 2 + 15: JEqImm dst: r4 off: -1 imm: 0 + 16: MovImm dst: r0 imm: 1 return: - 19: Exit -=== RUN TestScratchX/kernel#01 -=== RUN TestALUOr/eBPF#01 ---- PASS: TestScratchX (0.15s) - --- SKIP: TestScratchX/C (0.08s) - --- SKIP: TestScratchX/eBPF (0.00s) - --- PASS: TestScratchX/kernel (0.00s) - --- SKIP: TestScratchX/C#01 (0.07s) - --- SKIP: TestScratchX/eBPF#01 (0.00s) - --- PASS: TestScratchX/kernel#01 (0.00s) -=== CONT TestALUAnd -=== RUN TestALUAnd/C -=== NAME TestALUOr/eBPF#01 + 17: Exit +=== RUN TestLoadAbsolute/kernel#02 +=== NAME 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: 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 + 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: - 6: Mov32Imm dst: r4 imm: 0 - 7: JaImm dst: r0 off: -1 imm: 0 + 20: Mov32Imm dst: r4 imm: 0 + 21: JaImm dst: r0 off: -1 imm: 0 filter_block_5: - 8: Mov32Imm dst: r4 imm: 1 - 9: JaImm dst: r0 off: -1 imm: 0 + 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: - 10: MovImm dst: r0 imm: 2 - 11: JEqImm dst: r4 off: -1 imm: 0 - 12: MovImm dst: r0 imm: 1 + 26: MovImm dst: r0 imm: 2 + 27: JEqImm dst: r4 off: -1 imm: 0 + 28: MovImm dst: r0 imm: 1 return: - 13: Exit -=== RUN TestALUOr/kernel#01 -=== RUN TestALUOr/C#02 -=== RUN TestALUShiftRight/eBPF#01 + 29: Exit +=== RUN TestLoadIndirect/variable_valid/kernel#02 +=== RUN TestLoadAbsolute/C#03 +=== RUN TestLoadIndirect/variable_valid/C#03 +=== RUN TestALUDiv/eBPF#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: 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: 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 +=== 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: - 6: Mov32Imm dst: r4 imm: 0 - 7: JaImm dst: r0 off: -1 imm: 0 + 7: Mov32Imm dst: r4 imm: 0 + 8: JaImm dst: r0 off: -1 imm: 0 filter_block_5: - 8: Mov32Imm dst: r4 imm: 1 + 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.43s) + --- SKIP: TestALUDiv/C (0.11s) + --- SKIP: TestALUDiv/eBPF (0.00s) + --- PASS: TestALUDiv/kernel (0.00s) + --- SKIP: TestALUDiv/C#01 (0.10s) + --- SKIP: TestALUDiv/eBPF#01 (0.00s) + --- PASS: TestALUDiv/kernel#01 (0.00s) + --- SKIP: TestALUDiv/C#02 (0.10s) + --- SKIP: TestALUDiv/eBPF#02 (0.00s) + --- PASS: TestALUDiv/kernel#02 (0.00s) + --- SKIP: TestALUDiv/C#03 (0.11s) + --- SKIP: TestALUDiv/eBPF#03 (0.00s) + --- PASS: TestALUDiv/kernel#03 (0.00s) +=== CONT TestLoadConstantX +=== RUN TestLoadConstantX/C +=== RUN TestLoadAbsoluteBigOffset/C#05 +=== RUN 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: - 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 TestALUShiftRight/kernel#01 -=== RUN TestALUShiftRight/C#02 -=== RUN TestALUShiftLeft/eBPF#01 + 17: Exit +=== RUN TestLoadAbsolute/kernel#03 +=== 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: 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 + 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: - 6: Mov32Imm dst: r4 imm: 0 - 7: JaImm dst: r0 off: -1 imm: 0 + 20: Mov32Imm dst: r4 imm: 0 + 21: JaImm dst: r0 off: -1 imm: 0 filter_block_5: - 8: Mov32Imm dst: r4 imm: 1 - 9: JaImm dst: r0 off: -1 imm: 0 + 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: - 10: MovImm dst: r0 imm: 2 - 11: JEqImm dst: r4 off: -1 imm: 0 - 12: MovImm dst: r0 imm: 1 + 26: MovImm dst: r0 imm: 2 + 27: JEqImm dst: r4 off: -1 imm: 0 + 28: MovImm dst: r0 imm: 1 return: - 13: Exit -=== RUN TestALUShiftLeft/kernel#01 -=== RUN TestALUShiftLeft/C#02 -=== RUN TestALUOr/eBPF#02 + 29: Exit +=== RUN TestLoadIndirect/variable_valid/kernel#03 +=== 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: 240 - 3: Or32Imm dst: r4 imm: 15 - 4: JEqImm dst: r4 off: -1 imm: 255 + 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 @@ -5937,16 +4984,33 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestALUOr/kernel#02 -=== RUN TestALUOr/C#03 -=== RUN TestALUAnd/eBPF +=== RUN TestLoadConstantX/kernel +=== RUN TestLoadConstantX/C#01 +=== RUN TestLoadAbsolute/C#04 +=== RUN TestLoadIndirect/variable_valid/C#04 +=== 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: 1 - 3: And32Imm dst: r4 imm: 0 - 4: JEqImm dst: r4 off: -1 imm: 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 TestLoadAbsoluteBigOffset/C#06 +=== 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 @@ -5959,38 +5023,86 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestALUAnd/kernel -=== RUN TestALUAnd/C#01 -=== RUN TestALUShiftRight/eBPF#02 +=== RUN TestLoadConstantX/kernel#01 +=== RUN TestLoadConstantX/C#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: Mov32Imm dst: r4 imm: 240 - 3: RSh32Imm dst: r4 imm: 8 - 4: JEqImm dst: r4 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: -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: - 5: Mov32Imm dst: r4 imm: 0 - 6: JaImm dst: r0 off: -1 imm: 0 + 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 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: - 7: Mov32Imm dst: r4 imm: 1 - 8: JaImm dst: r0 off: -1 imm: 0 + 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: - 9: MovImm dst: r0 imm: 2 - 10: JEqImm dst: r4 off: -1 imm: 0 - 11: MovImm dst: r0 imm: 1 + 27: MovImm dst: r0 imm: 2 + 28: JEqImm dst: r4 off: -1 imm: 0 + 29: MovImm dst: r0 imm: 1 return: - 12: Exit -=== RUN TestALUShiftRight/kernel#02 -=== RUN TestALUShiftRight/C#03 -=== RUN TestALUShiftLeft/eBPF#02 + 30: Exit +=== RUN TestLoadIndirect/variable_valid/kernel#04 +=== RUN TestLoadIndirect/variable_valid/C#05 +=== 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: 1 - 3: LSh32Imm dst: r4 imm: 4 - 4: JEqImm dst: r4 off: -1 imm: 16 + 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 @@ -6003,189 +5115,442 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestALUShiftLeft/kernel#02 -=== RUN TestALUShiftLeft/C#03 -=== RUN TestALUOr/eBPF#03 -=== RUN TestALUAnd/eBPF#01 -=== NAME TestALUOr/eBPF#03 +=== RUN TestLoadConstantX/kernel#02 +--- PASS: TestLoadConstantX (0.32s) + --- SKIP: TestLoadConstantX/C (0.10s) + --- SKIP: TestLoadConstantX/eBPF (0.00s) + --- PASS: TestLoadConstantX/kernel (0.00s) + --- SKIP: TestLoadConstantX/C#01 (0.11s) + --- SKIP: TestLoadConstantX/eBPF#01 (0.00s) + --- PASS: TestLoadConstantX/kernel#01 (0.00s) + --- SKIP: TestLoadConstantX/C#02 (0.11s) + --- SKIP: TestLoadConstantX/eBPF#02 (0.00s) + --- PASS: TestLoadConstantX/kernel#02 (0.00s) +=== CONT TestLoadConstantA +=== RUN TestLoadConstantA/C +=== 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: 240 - 3: Mov32Imm dst: r5 imm: 15 - 4: Or32Reg dst: r4 src: r5 - 5: JEqImm dst: r4 off: -1 imm: 255 + 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 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/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: - 6: Mov32Imm dst: r4 imm: 0 - 7: JaImm dst: r0 off: -1 imm: 0 + 21: Mov32Imm dst: r4 imm: 0 + 22: JaImm dst: r0 off: -1 imm: 0 filter_block_5: - 8: Mov32Imm dst: r4 imm: 1 - 9: JaImm dst: r0 off: -1 imm: 0 + 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: - 10: MovImm dst: r0 imm: 2 - 11: JEqImm dst: r4 off: -1 imm: 0 - 12: MovImm dst: r0 imm: 1 + 27: MovImm dst: r0 imm: 2 + 28: JEqImm dst: r4 off: -1 imm: 0 + 29: MovImm dst: r0 imm: 1 return: - 13: Exit -=== RUN TestALUOr/kernel#03 -=== NAME TestALUAnd/eBPF#01 + 30: Exit +=== RUN TestLoadIndirect/variable_valid/kernel#05 +=== RUN TestLoadAbsoluteBigOffset/C#07 +--- PASS: TestLoadAbsolute (0.85s) + --- SKIP: TestLoadAbsolute/C (0.11s) + --- SKIP: TestLoadAbsolute/eBPF (0.00s) + --- PASS: TestLoadAbsolute/kernel (0.00s) + --- SKIP: TestLoadAbsolute/C#01 (0.11s) + --- SKIP: TestLoadAbsolute/eBPF#01 (0.00s) + --- PASS: TestLoadAbsolute/kernel#01 (0.05s) + --- SKIP: TestLoadAbsolute/C#02 (0.11s) + --- SKIP: TestLoadAbsolute/eBPF#02 (0.00s) + --- PASS: TestLoadAbsolute/kernel#02 (0.00s) + --- SKIP: TestLoadAbsolute/C#03 (0.11s) + --- SKIP: TestLoadAbsolute/eBPF#03 (0.00s) + --- PASS: TestLoadAbsolute/kernel#03 (0.05s) + --- SKIP: TestLoadAbsolute/C#04 (0.12s) + --- SKIP: TestLoadAbsolute/eBPF#04 (0.00s) + --- PASS: TestLoadAbsolute/kernel#04 (0.00s) + --- SKIP: TestLoadAbsolute/C#05 (0.12s) + --- SKIP: TestLoadAbsolute/eBPF#05 (0.00s) + --- PASS: TestLoadAbsolute/kernel#05 (0.05s) +=== CONT TestJumpIfLessOrEqual +=== RUN TestJumpIfLessOrEqual/C +=== RUN TestLoadIndirect/constant_outofbounds +=== RUN TestLoadIndirect/constant_outofbounds/C +=== 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: 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 + 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 - 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 TestALUAnd/kernel#01 -=== RUN TestALUAnd/C#02 ---- PASS: TestALUOr (0.29s) - --- SKIP: TestALUOr/C (0.07s) - --- SKIP: TestALUOr/eBPF (0.00s) - --- PASS: TestALUOr/kernel (0.00s) - --- SKIP: TestALUOr/C#01 (0.07s) - --- SKIP: TestALUOr/eBPF#01 (0.00s) - --- PASS: TestALUOr/kernel#01 (0.00s) - --- SKIP: TestALUOr/C#02 (0.07s) - --- SKIP: TestALUOr/eBPF#02 (0.00s) - --- PASS: TestALUOr/kernel#02 (0.00s) - --- SKIP: TestALUOr/C#03 (0.07s) - --- SKIP: TestALUOr/eBPF#03 (0.00s) - --- PASS: TestALUOr/kernel#03 (0.00s) -=== CONT TestALUDiv -=== RUN TestALUDiv/C -=== RUN TestALUShiftRight/eBPF#03 + 11: Exit +=== RUN TestLoadConstantA/kernel +=== RUN TestLoadConstantA/C#01 +=== 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: 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: 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 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 - 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.29s) - --- SKIP: TestALUShiftRight/C (0.07s) - --- SKIP: TestALUShiftRight/eBPF (0.00s) - --- PASS: TestALUShiftRight/kernel (0.00s) - --- SKIP: TestALUShiftRight/C#01 (0.07s) - --- SKIP: TestALUShiftRight/eBPF#01 (0.00s) - --- PASS: TestALUShiftRight/kernel#01 (0.00s) - --- SKIP: TestALUShiftRight/C#02 (0.07s) - --- SKIP: TestALUShiftRight/eBPF#02 (0.00s) - --- PASS: TestALUShiftRight/kernel#02 (0.00s) - --- SKIP: TestALUShiftRight/C#03 (0.07s) - --- SKIP: TestALUShiftRight/eBPF#03 (0.00s) - --- PASS: TestALUShiftRight/kernel#03 (0.00s) -=== CONT TestALUDivZero -=== RUN TestALUDivZero/C -=== RUN TestALUShiftLeft/eBPF#03 + 11: Exit +=== RUN TestJumpIfLessOrEqual/kernel +=== 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: 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 + 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 - 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 TestALUShiftLeft/kernel#03 ---- PASS: TestALUShiftLeft (0.29s) - --- SKIP: TestALUShiftLeft/C (0.07s) - --- SKIP: TestALUShiftLeft/eBPF (0.00s) - --- PASS: TestALUShiftLeft/kernel (0.00s) - --- SKIP: TestALUShiftLeft/C#01 (0.07s) - --- SKIP: TestALUShiftLeft/eBPF#01 (0.00s) - --- PASS: TestALUShiftLeft/kernel#01 (0.00s) - --- SKIP: TestALUShiftLeft/C#02 (0.07s) - --- SKIP: TestALUShiftLeft/eBPF#02 (0.00s) - --- PASS: TestALUShiftLeft/kernel#02 (0.00s) - --- SKIP: TestALUShiftLeft/C#03 (0.07s) - --- SKIP: TestALUShiftLeft/eBPF#03 (0.00s) - --- PASS: TestALUShiftLeft/kernel#03 (0.00s) -=== CONT TestJumpIfGreaterOrEqual -=== RUN TestJumpIfGreaterOrEqual/C -=== RUN TestALUDiv/eBPF + 11: Exit +=== RUN TestLoadConstantA/kernel#01 +=== RUN TestLoadIndirect/constant_outofbounds/eBPF +=== RUN TestLoadConstantA/C#02 +=== NAME 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: r4 imm: 2 - 3: Div32Imm dst: r4 imm: 2 - 4: JEqImm dst: r4 off: -1 imm: 1 + 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: TestLoadAbsoluteBigOffset (1.31s) + --- SKIP: TestLoadAbsoluteBigOffset/C (0.11s) + --- SKIP: TestLoadAbsoluteBigOffset/eBPF (0.00s) + --- PASS: TestLoadAbsoluteBigOffset/kernel (0.05s) + --- SKIP: TestLoadAbsoluteBigOffset/C#01 (0.11s) + --- SKIP: TestLoadAbsoluteBigOffset/eBPF#01 (0.00s) + --- PASS: TestLoadAbsoluteBigOffset/kernel#01 (0.05s) + --- SKIP: TestLoadAbsoluteBigOffset/C#02 (0.11s) + --- SKIP: TestLoadAbsoluteBigOffset/eBPF#02 (0.00s) + --- PASS: TestLoadAbsoluteBigOffset/kernel#02 (0.05s) + --- SKIP: TestLoadAbsoluteBigOffset/C#03 (0.10s) + --- SKIP: TestLoadAbsoluteBigOffset/eBPF#03 (0.00s) + --- PASS: TestLoadAbsoluteBigOffset/kernel#03 (0.05s) + --- SKIP: TestLoadAbsoluteBigOffset/C#04 (0.12s) + --- SKIP: TestLoadAbsoluteBigOffset/eBPF#04 (0.00s) + --- PASS: TestLoadAbsoluteBigOffset/kernel#04 (0.05s) + --- SKIP: TestLoadAbsoluteBigOffset/C#05 (0.11s) + --- SKIP: TestLoadAbsoluteBigOffset/eBPF#05 (0.00s) + --- PASS: TestLoadAbsoluteBigOffset/kernel#05 (0.05s) + --- SKIP: TestLoadAbsoluteBigOffset/C#06 (0.11s) + --- SKIP: TestLoadAbsoluteBigOffset/eBPF#06 (0.00s) + --- PASS: TestLoadAbsoluteBigOffset/kernel#06 (0.05s) + --- SKIP: TestLoadAbsoluteBigOffset/C#07 (0.12s) + --- SKIP: TestLoadAbsoluteBigOffset/eBPF#07 (0.00s) + --- PASS: TestLoadAbsoluteBigOffset/kernel#07 (0.05s) +=== CONT TestPartialZeroInitX +=== RUN TestPartialZeroInitX/C +=== RUN TestJumpIfLessOrEqual/C#01 +=== RUN TestLoadConstantA/eBPF#02 +=== RUN TestLoadIndirect/constant_outofbounds/eBPF#01 +=== NAME 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: - 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 TestALUDiv/kernel -=== RUN TestALUDiv/C#01 -=== RUN TestALUAnd/eBPF#02 + 11: Exit +=== RUN TestLoadConstantA/kernel#02 +=== NAME 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: r4 imm: 240 - 3: And32Imm dst: r4 imm: 128 - 4: JEqImm dst: r4 off: -1 imm: 128 + 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: TestLoadConstantA (0.32s) + --- SKIP: TestLoadConstantA/C (0.11s) + --- 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.11s) + --- SKIP: TestLoadConstantA/eBPF#02 (0.00s) + --- PASS: TestLoadConstantA/kernel#02 (0.00s) +=== CONT TestZeroInitX +=== RUN TestZeroInitX/C +=== 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: - 5: Mov32Imm dst: r4 imm: 0 - 6: JaImm dst: r0 off: -1 imm: 0 + 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 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: - 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 TestALUAnd/kernel#02 -=== RUN TestALUAnd/C#03 -=== RUN TestALUDivZero/eBPF + 15: Exit +=== RUN TestJumpIfLessOrEqual/kernel#01 +=== RUN TestLoadIndirect/constant_outofbounds/C#02 +=== RUN TestPartialZeroInitX/C#01 +=== RUN TestJumpIfLessOrEqual/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 +--- PASS: TestZeroInitX (0.15s) + --- SKIP: TestZeroInitX/C (0.10s) + --- SKIP: TestZeroInitX/eBPF (0.00s) + --- PASS: TestZeroInitX/kernel (0.05s) +=== CONT TestJumpIfGreaterOrEqual +=== RUN TestJumpIfGreaterOrEqual/C +=== 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 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 @@ -6193,12 +5558,14 @@ 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 + 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 @@ -6209,7 +5576,39 @@ 16: MovImm dst: r0 imm: 1 return: 17: Exit -=== RUN TestALUDivZero/kernel +=== RUN TestPartialZeroInitX/kernel#01 +--- PASS: TestPartialZeroInitX (0.29s) + --- SKIP: TestPartialZeroInitX/C (0.12s) + --- SKIP: TestPartialZeroInitX/eBPF (0.00s) + --- PASS: TestPartialZeroInitX/kernel (0.05s) + --- SKIP: TestPartialZeroInitX/C#01 (0.11s) + --- SKIP: TestPartialZeroInitX/eBPF#01 (0.00s) + --- PASS: TestPartialZeroInitX/kernel#01 (0.00s) +=== CONT TestALUAdd +=== RUN TestALUAdd/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 TestLoadIndirect/constant_outofbounds/C#03 +=== RUN TestJumpIfLessOrEqual/C#03 === RUN TestJumpIfGreaterOrEqual/eBPF ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 @@ -6231,47 +5630,78 @@ 11: Exit === RUN TestJumpIfGreaterOrEqual/kernel === RUN TestJumpIfGreaterOrEqual/C#01 -=== RUN TestALUAnd/eBPF#03 +=== RUN 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: 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: 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: - 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 TestALUAnd/kernel#03 -=== RUN TestALUAnd/C#04 -=== RUN TestALUDiv/eBPF#01 + 12: Exit +=== RUN TestALUAdd/kernel +=== RUN TestALUAdd/C#01 +=== 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: 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 + 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 TestJumpIfLessOrEqual/eBPF#03 +=== RUN TestJumpIfGreaterOrEqual/eBPF#01 +=== NAME 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: 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 @@ -6279,10 +5709,8 @@ 15: MovImm dst: r0 imm: 1 return: 16: Exit -=== RUN TestALUDiv/kernel#01 -=== RUN TestALUDiv/C#02 -=== RUN TestALUDivZero/C#01 -=== RUN TestJumpIfGreaterOrEqual/eBPF#01 +=== RUN TestJumpIfLessOrEqual/kernel#03 +=== 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 @@ -6309,36 +5737,39 @@ 15: Exit === RUN TestJumpIfGreaterOrEqual/kernel#01 === RUN TestJumpIfGreaterOrEqual/C#02 -=== RUN TestALUAnd/eBPF#04 +=== RUN TestLoadIndirect/constant_outofbounds/C#04 +=== RUN TestJumpIfLessOrEqual/C#04 +=== 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: 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 + 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: - 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 TestALUAnd/kernel#04 -=== RUN TestALUAnd/C#05 -=== RUN TestALUDiv/eBPF#02 + 13: Exit +=== RUN TestALUAdd/kernel#01 +=== RUN TestALUAdd/C#02 +=== 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: 19 - 3: Div32Imm dst: r4 imm: 3 - 4: JEqImm dst: r4 off: -1 imm: 6 + 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 @@ -6351,48 +5782,46 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestALUDiv/kernel#02 -=== RUN TestALUDiv/C#03 -=== RUN TestALUDivZero/eBPF#01 +=== RUN TestJumpIfGreaterOrEqual/kernel#02 +=== RUN TestJumpIfGreaterOrEqual/C#03 +=== 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: 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 + 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: - 12: MovImm dst: r4 imm: 0 - 13: JaImm dst: r0 off: -1 imm: 0 + 15: MovImm dst: r4 imm: 0 + 16: 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 + 17: MovImm dst: r0 imm: 2 + 18: JEqImm dst: r4 off: -1 imm: 0 + 19: MovImm dst: r0 imm: 1 return: - 17: Exit -=== RUN TestALUDivZero/kernel#01 ---- PASS: TestALUDivZero (0.21s) - --- SKIP: TestALUDivZero/C (0.08s) - --- SKIP: TestALUDivZero/eBPF (0.00s) - --- PASS: TestALUDivZero/kernel (0.05s) - --- SKIP: TestALUDivZero/C#01 (0.08s) - --- SKIP: TestALUDivZero/eBPF#01 (0.00s) - --- PASS: TestALUDivZero/kernel#01 (0.00s) -=== RUN TestJumpIfGreaterOrEqual/eBPF#02 + 20: Exit +=== RUN TestLoadIndirect/constant_outofbounds/kernel#04 +=== RUN TestALUAdd/eBPF#02 +=== RUN TestJumpIfLessOrEqual/eBPF#04 +=== NAME 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: 24 - 3: Mov32Imm dst: r5 imm: 23 - 4: JGEReg dst: r4 off: -1 src: r5 + 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 @@ -6405,88 +5834,31 @@ 11: MovImm dst: r0 imm: 1 return: 12: Exit -=== RUN TestJumpIfGreaterOrEqual/kernel#02 -=== RUN TestJumpIfGreaterOrEqual/C#03 -=== RUN TestALUAnd/eBPF#05 +=== RUN TestALUAdd/kernel#02 +=== 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: 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 + 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 - 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.44s) - --- SKIP: TestALUAnd/C (0.08s) - --- SKIP: TestALUAnd/eBPF (0.00s) - --- PASS: TestALUAnd/kernel (0.00s) - --- SKIP: TestALUAnd/C#01 (0.07s) - --- SKIP: TestALUAnd/eBPF#01 (0.00s) - --- PASS: TestALUAnd/kernel#01 (0.00s) - --- SKIP: TestALUAnd/C#02 (0.07s) - --- 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.07s) - --- SKIP: TestALUAnd/eBPF#04 (0.00s) - --- PASS: TestALUAnd/kernel#04 (0.00s) - --- SKIP: TestALUAnd/C#05 (0.07s) - --- SKIP: TestALUAnd/eBPF#05 (0.00s) - --- PASS: TestALUAnd/kernel#05 (0.00s) -=== 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 + 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.29s) - --- SKIP: TestALUDiv/C (0.07s) - --- SKIP: TestALUDiv/eBPF (0.00s) - --- PASS: TestALUDiv/kernel (0.00s) - --- SKIP: TestALUDiv/C#01 (0.07s) - --- SKIP: TestALUDiv/eBPF#01 (0.00s) - --- PASS: TestALUDiv/kernel#01 (0.00s) - --- SKIP: TestALUDiv/C#02 (0.07s) - --- SKIP: TestALUDiv/eBPF#02 (0.00s) - --- PASS: TestALUDiv/kernel#02 (0.00s) - --- SKIP: TestALUDiv/C#03 (0.07s) - --- SKIP: TestALUDiv/eBPF#03 (0.00s) - --- PASS: TestALUDiv/kernel#03 (0.00s) + 11: Exit +=== RUN TestJumpIfLessOrEqual/kernel#04 +=== RUN TestALUAdd/C#03 +=== RUN TestJumpIfLessOrEqual/C#05 +=== RUN TestLoadIndirect/variable_outofbounds +=== RUN TestLoadIndirect/variable_outofbounds/C === RUN TestJumpIfGreaterOrEqual/eBPF#03 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 @@ -6515,6 +5887,106 @@ 16: Exit === RUN TestJumpIfGreaterOrEqual/kernel#03 === RUN TestJumpIfGreaterOrEqual/C#04 +=== RUN TestJumpIfLessOrEqual/eBPF#05 +=== RUN TestALUAdd/eBPF#03 +=== NAME 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 +=== NAME 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 TestJumpIfLessOrEqual/kernel#05 +=== RUN TestALUAdd/kernel#03 +=== RUN TestJumpIfLessOrEqual/C#06 +=== CONT TestALUSub +=== RUN TestALUSub/C +--- PASS: TestALUAdd (0.44s) + --- SKIP: TestALUAdd/C (0.11s) + --- SKIP: TestALUAdd/eBPF (0.00s) + --- PASS: TestALUAdd/kernel (0.00s) + --- SKIP: TestALUAdd/C#01 (0.11s) + --- SKIP: TestALUAdd/eBPF#01 (0.00s) + --- PASS: TestALUAdd/kernel#01 (0.00s) + --- SKIP: TestALUAdd/C#02 (0.11s) + --- SKIP: TestALUAdd/eBPF#02 (0.00s) + --- PASS: TestALUAdd/kernel#02 (0.00s) + --- SKIP: TestALUAdd/C#03 (0.11s) + --- SKIP: TestALUAdd/eBPF#03 (0.00s) + --- PASS: TestALUAdd/kernel#03 (0.00s) +=== 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 TestJumpIfGreaterOrEqual/eBPF#04 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 @@ -6536,6 +6008,85 @@ 11: Exit === RUN TestJumpIfGreaterOrEqual/kernel#04 === RUN TestJumpIfGreaterOrEqual/C#05 +=== RUN TestALUSub/eBPF +=== RUN TestJumpIfLessOrEqual/eBPF#06 +=== 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 +=== NAME 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 TestALUSub/kernel +=== RUN TestJumpIfLessOrEqual/C#07 +=== RUN TestALUSub/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 TestJumpIfGreaterOrEqual/eBPF#05 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 @@ -6563,6 +6114,59 @@ 15: Exit === RUN TestJumpIfGreaterOrEqual/kernel#05 === RUN TestJumpIfGreaterOrEqual/C#06 +=== RUN TestJumpIfLessOrEqual/eBPF#07 +=== 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 +=== 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 TestALUSub/C#02 +=== RUN TestJumpIfLessOrEqual/C#08 +=== RUN TestLoadIndirect/variable_outofbounds/C#02 === RUN TestJumpIfGreaterOrEqual/eBPF#06 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 @@ -6585,6 +6189,86 @@ 12: Exit === RUN TestJumpIfGreaterOrEqual/kernel#06 === RUN TestJumpIfGreaterOrEqual/C#07 +=== RUN TestJumpIfLessOrEqual/eBPF#08 +=== RUN TestALUSub/eBPF#02 +=== NAME 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 +=== 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 +=== RUN TestALUSub/C#03 +=== RUN TestJumpIfLessOrEqual/C#09 +=== 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 TestJumpIfGreaterOrEqual/eBPF#07 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 @@ -6613,6 +6297,106 @@ 16: Exit === RUN TestJumpIfGreaterOrEqual/kernel#07 === RUN TestJumpIfGreaterOrEqual/C#08 +=== RUN TestJumpIfLessOrEqual/eBPF#09 +=== RUN TestALUSub/eBPF#03 +=== NAME 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 +=== NAME 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 +=== RUN TestJumpIfLessOrEqual/C#10 +--- PASS: TestALUSub (0.43s) + --- SKIP: TestALUSub/C (0.11s) + --- SKIP: TestALUSub/eBPF (0.00s) + --- PASS: TestALUSub/kernel (0.00s) + --- SKIP: TestALUSub/C#01 (0.10s) + --- SKIP: TestALUSub/eBPF#01 (0.00s) + --- PASS: TestALUSub/kernel#01 (0.00s) + --- SKIP: TestALUSub/C#02 (0.11s) + --- SKIP: TestALUSub/eBPF#02 (0.00s) + --- PASS: TestALUSub/kernel#02 (0.00s) + --- SKIP: TestALUSub/C#03 (0.10s) + --- SKIP: TestALUSub/eBPF#03 (0.00s) + --- PASS: TestALUSub/kernel#03 (0.00s) +=== CONT TestLoadExtLen +=== RUN TestLoadExtLen/C +=== 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 TestJumpIfGreaterOrEqual/eBPF#08 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 @@ -6633,8 +6417,154 @@ return: 11: Exit === RUN TestJumpIfGreaterOrEqual/kernel#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 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.11s) + --- SKIP: TestLoadExtLen/C (0.11s) + --- SKIP: TestLoadExtLen/eBPF (0.00s) + --- PASS: TestLoadExtLen/kernel (0.00s) +=== CONT TestMemShift +=== RUN TestMemShift/C +=== RUN TestLoadIndirect/variable_outofbounds/C#04 === RUN TestJumpIfGreaterOrEqual/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 +=== RUN TestJumpIfLessOrEqual/kernel#11 +--- PASS: TestJumpIfLessOrEqual (1.50s) + --- SKIP: TestJumpIfLessOrEqual/C (0.11s) + --- SKIP: TestJumpIfLessOrEqual/eBPF (0.00s) + --- PASS: TestJumpIfLessOrEqual/kernel (0.05s) + --- SKIP: TestJumpIfLessOrEqual/C#01 (0.11s) + --- SKIP: TestJumpIfLessOrEqual/eBPF#01 (0.00s) + --- PASS: TestJumpIfLessOrEqual/kernel#01 (0.05s) + --- SKIP: TestJumpIfLessOrEqual/C#02 (0.11s) + --- SKIP: TestJumpIfLessOrEqual/eBPF#02 (0.00s) + --- PASS: TestJumpIfLessOrEqual/kernel#02 (0.05s) + --- SKIP: TestJumpIfLessOrEqual/C#03 (0.11s) + --- SKIP: TestJumpIfLessOrEqual/eBPF#03 (0.00s) + --- PASS: TestJumpIfLessOrEqual/kernel#03 (0.05s) + --- SKIP: TestJumpIfLessOrEqual/C#04 (0.11s) + --- SKIP: TestJumpIfLessOrEqual/eBPF#04 (0.00s) + --- PASS: TestJumpIfLessOrEqual/kernel#04 (0.00s) + --- SKIP: TestJumpIfLessOrEqual/C#05 (0.11s) + --- SKIP: TestJumpIfLessOrEqual/eBPF#05 (0.00s) + --- PASS: TestJumpIfLessOrEqual/kernel#05 (0.00s) + --- SKIP: TestJumpIfLessOrEqual/C#06 (0.11s) + --- SKIP: TestJumpIfLessOrEqual/eBPF#06 (0.00s) + --- PASS: TestJumpIfLessOrEqual/kernel#06 (0.00s) + --- SKIP: TestJumpIfLessOrEqual/C#07 (0.10s) + --- SKIP: TestJumpIfLessOrEqual/eBPF#07 (0.00s) + --- PASS: TestJumpIfLessOrEqual/kernel#07 (0.00s) + --- SKIP: TestJumpIfLessOrEqual/C#08 (0.11s) + --- SKIP: TestJumpIfLessOrEqual/eBPF#08 (0.00s) + --- PASS: TestJumpIfLessOrEqual/kernel#08 (0.00s) + --- SKIP: TestJumpIfLessOrEqual/C#09 (0.10s) + --- SKIP: TestJumpIfLessOrEqual/eBPF#09 (0.00s) + --- PASS: TestJumpIfLessOrEqual/kernel#09 (0.00s) + --- SKIP: TestJumpIfLessOrEqual/C#10 (0.10s) + --- SKIP: TestJumpIfLessOrEqual/eBPF#10 (0.00s) + --- PASS: TestJumpIfLessOrEqual/kernel#10 (0.00s) + --- SKIP: TestJumpIfLessOrEqual/C#11 (0.11s) + --- SKIP: TestJumpIfLessOrEqual/eBPF#11 (0.00s) + --- PASS: TestJumpIfLessOrEqual/kernel#11 (0.00s) +=== 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 TestJumpIfGreaterOrEqual/eBPF#09 +=== RUN TestLoadIndirect/variable_outofbounds/eBPF#04 +=== 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 @@ -6660,7 +6590,147 @@ return: 15: Exit === RUN TestJumpIfGreaterOrEqual/kernel#09 +=== NAME 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 (3.40s) + --- PASS: TestLoadIndirect/constant_valid (0.93s) + --- SKIP: TestLoadIndirect/constant_valid/C (0.11s) + --- SKIP: TestLoadIndirect/constant_valid/eBPF (0.00s) + --- PASS: TestLoadIndirect/constant_valid/kernel (0.00s) + --- SKIP: TestLoadIndirect/constant_valid/C#01 (0.12s) + --- SKIP: TestLoadIndirect/constant_valid/eBPF#01 (0.00s) + --- PASS: TestLoadIndirect/constant_valid/kernel#01 (0.05s) + --- SKIP: TestLoadIndirect/constant_valid/C#02 (0.13s) + --- SKIP: TestLoadIndirect/constant_valid/eBPF#02 (0.00s) + --- PASS: TestLoadIndirect/constant_valid/kernel#02 (0.00s) + --- SKIP: TestLoadIndirect/constant_valid/C#03 (0.18s) + --- SKIP: TestLoadIndirect/constant_valid/eBPF#03 (0.00s) + --- PASS: TestLoadIndirect/constant_valid/kernel#03 (0.05s) + --- SKIP: TestLoadIndirect/constant_valid/C#04 (0.11s) + --- SKIP: TestLoadIndirect/constant_valid/eBPF#04 (0.00s) + --- PASS: TestLoadIndirect/constant_valid/kernel#04 (0.00s) + --- SKIP: TestLoadIndirect/constant_valid/C#05 (0.11s) + --- SKIP: TestLoadIndirect/constant_valid/eBPF#05 (0.00s) + --- PASS: TestLoadIndirect/constant_valid/kernel#05 (0.05s) + --- PASS: TestLoadIndirect/variable_valid (0.88s) + --- SKIP: TestLoadIndirect/variable_valid/C (0.12s) + --- SKIP: TestLoadIndirect/variable_valid/eBPF (0.00s) + --- PASS: TestLoadIndirect/variable_valid/kernel (0.00s) + --- SKIP: TestLoadIndirect/variable_valid/C#01 (0.12s) + --- SKIP: TestLoadIndirect/variable_valid/eBPF#01 (0.00s) + --- PASS: TestLoadIndirect/variable_valid/kernel#01 (0.05s) + --- SKIP: TestLoadIndirect/variable_valid/C#02 (0.12s) + --- SKIP: TestLoadIndirect/variable_valid/eBPF#02 (0.00s) + --- PASS: TestLoadIndirect/variable_valid/kernel#02 (0.00s) + --- SKIP: TestLoadIndirect/variable_valid/C#03 (0.12s) + --- SKIP: TestLoadIndirect/variable_valid/eBPF#03 (0.00s) + --- PASS: TestLoadIndirect/variable_valid/kernel#03 (0.05s) + --- SKIP: TestLoadIndirect/variable_valid/C#04 (0.12s) + --- SKIP: TestLoadIndirect/variable_valid/eBPF#04 (0.00s) + --- PASS: TestLoadIndirect/variable_valid/kernel#04 (0.00s) + --- SKIP: TestLoadIndirect/variable_valid/C#05 (0.12s) + --- SKIP: TestLoadIndirect/variable_valid/eBPF#05 (0.00s) + --- PASS: TestLoadIndirect/variable_valid/kernel#05 (0.05s) + --- PASS: TestLoadIndirect/constant_outofbounds (0.77s) + --- SKIP: TestLoadIndirect/constant_outofbounds/C (0.11s) + --- SKIP: TestLoadIndirect/constant_outofbounds/eBPF (0.00s) + --- PASS: TestLoadIndirect/constant_outofbounds/kernel (0.00s) + --- SKIP: TestLoadIndirect/constant_outofbounds/C#01 (0.11s) + --- SKIP: TestLoadIndirect/constant_outofbounds/eBPF#01 (0.00s) + --- PASS: TestLoadIndirect/constant_outofbounds/kernel#01 (0.05s) + --- SKIP: TestLoadIndirect/constant_outofbounds/C#02 (0.12s) + --- SKIP: TestLoadIndirect/constant_outofbounds/eBPF#02 (0.00s) + --- PASS: TestLoadIndirect/constant_outofbounds/kernel#02 (0.05s) + --- SKIP: TestLoadIndirect/constant_outofbounds/C#03 (0.11s) + --- SKIP: TestLoadIndirect/constant_outofbounds/eBPF#03 (0.00s) + --- PASS: TestLoadIndirect/constant_outofbounds/kernel#03 (0.05s) + --- SKIP: TestLoadIndirect/constant_outofbounds/C#04 (0.11s) + --- SKIP: TestLoadIndirect/constant_outofbounds/eBPF#04 (0.00s) + --- PASS: TestLoadIndirect/constant_outofbounds/kernel#04 (0.05s) + --- PASS: TestLoadIndirect/variable_outofbounds (0.82s) + --- SKIP: TestLoadIndirect/variable_outofbounds/C (0.12s) + --- SKIP: TestLoadIndirect/variable_outofbounds/eBPF (0.00s) + --- PASS: TestLoadIndirect/variable_outofbounds/kernel (0.00s) + --- SKIP: TestLoadIndirect/variable_outofbounds/C#01 (0.12s) + --- SKIP: TestLoadIndirect/variable_outofbounds/eBPF#01 (0.00s) + --- PASS: TestLoadIndirect/variable_outofbounds/kernel#01 (0.05s) + --- SKIP: TestLoadIndirect/variable_outofbounds/C#02 (0.12s) + --- SKIP: TestLoadIndirect/variable_outofbounds/eBPF#02 (0.00s) + --- PASS: TestLoadIndirect/variable_outofbounds/kernel#02 (0.05s) + --- SKIP: TestLoadIndirect/variable_outofbounds/C#03 (0.13s) + --- SKIP: TestLoadIndirect/variable_outofbounds/eBPF#03 (0.00s) + --- PASS: TestLoadIndirect/variable_outofbounds/kernel#03 (0.05s) + --- SKIP: TestLoadIndirect/variable_outofbounds/C#04 (0.12s) + --- SKIP: TestLoadIndirect/variable_outofbounds/eBPF#04 (0.00s) + --- PASS: TestLoadIndirect/variable_outofbounds/kernel#04 (0.05s) === RUN TestJumpIfGreaterOrEqual/C#10 +=== 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.21s) + --- SKIP: TestMemShift/C (0.11s) + --- SKIP: TestMemShift/eBPF (0.00s) + --- PASS: TestMemShift/kernel (0.00s) + --- SKIP: TestMemShift/C#01 (0.10s) + --- SKIP: TestMemShift/eBPF#01 (0.00s) + --- PASS: TestMemShift/kernel#01 (0.00s) === RUN TestJumpIfGreaterOrEqual/eBPF#10 ebpf_test.go:17: 0: LdXMemW dst: r2 src: r1 off: 0 imm: 0 @@ -6710,45 +6780,45 @@ return: 16: Exit === RUN TestJumpIfGreaterOrEqual/kernel#11 ---- PASS: TestJumpIfGreaterOrEqual (1.04s) - --- SKIP: TestJumpIfGreaterOrEqual/C (0.07s) +--- PASS: TestJumpIfGreaterOrEqual (1.50s) + --- SKIP: TestJumpIfGreaterOrEqual/C (0.11s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF (0.00s) --- PASS: TestJumpIfGreaterOrEqual/kernel (0.00s) - --- SKIP: TestJumpIfGreaterOrEqual/C#01 (0.07s) + --- SKIP: TestJumpIfGreaterOrEqual/C#01 (0.10s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF#01 (0.00s) --- PASS: TestJumpIfGreaterOrEqual/kernel#01 (0.00s) - --- SKIP: TestJumpIfGreaterOrEqual/C#02 (0.07s) + --- SKIP: TestJumpIfGreaterOrEqual/C#02 (0.11s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF#02 (0.00s) --- PASS: TestJumpIfGreaterOrEqual/kernel#02 (0.00s) - --- SKIP: TestJumpIfGreaterOrEqual/C#03 (0.07s) + --- SKIP: TestJumpIfGreaterOrEqual/C#03 (0.12s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF#03 (0.00s) --- PASS: TestJumpIfGreaterOrEqual/kernel#03 (0.00s) - --- SKIP: TestJumpIfGreaterOrEqual/C#04 (0.07s) + --- SKIP: TestJumpIfGreaterOrEqual/C#04 (0.11s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF#04 (0.00s) --- PASS: TestJumpIfGreaterOrEqual/kernel#04 (0.00s) - --- SKIP: TestJumpIfGreaterOrEqual/C#05 (0.07s) + --- SKIP: TestJumpIfGreaterOrEqual/C#05 (0.11s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF#05 (0.00s) --- PASS: TestJumpIfGreaterOrEqual/kernel#05 (0.00s) - --- SKIP: TestJumpIfGreaterOrEqual/C#06 (0.07s) + --- SKIP: TestJumpIfGreaterOrEqual/C#06 (0.11s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF#06 (0.00s) --- PASS: TestJumpIfGreaterOrEqual/kernel#06 (0.00s) - --- SKIP: TestJumpIfGreaterOrEqual/C#07 (0.07s) + --- SKIP: TestJumpIfGreaterOrEqual/C#07 (0.11s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF#07 (0.00s) --- PASS: TestJumpIfGreaterOrEqual/kernel#07 (0.00s) - --- SKIP: TestJumpIfGreaterOrEqual/C#08 (0.07s) + --- SKIP: TestJumpIfGreaterOrEqual/C#08 (0.11s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF#08 (0.00s) --- PASS: TestJumpIfGreaterOrEqual/kernel#08 (0.05s) - --- SKIP: TestJumpIfGreaterOrEqual/C#09 (0.07s) + --- SKIP: TestJumpIfGreaterOrEqual/C#09 (0.11s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF#09 (0.00s) --- PASS: TestJumpIfGreaterOrEqual/kernel#09 (0.05s) - --- SKIP: TestJumpIfGreaterOrEqual/C#10 (0.07s) + --- SKIP: TestJumpIfGreaterOrEqual/C#10 (0.09s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF#10 (0.00s) --- PASS: TestJumpIfGreaterOrEqual/kernel#10 (0.05s) - --- SKIP: TestJumpIfGreaterOrEqual/C#11 (0.07s) + --- SKIP: TestJumpIfGreaterOrEqual/C#11 (0.09s) --- SKIP: TestJumpIfGreaterOrEqual/eBPF#11 (0.00s) --- PASS: TestJumpIfGreaterOrEqual/kernel#11 (0.05s) PASS -ok github.com/cloudflare/cbpfc 6.594s +ok github.com/cloudflare/cbpfc 8.435s 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 @@ -6776,12 +6846,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/28107/tmp/hooks/B01_cleanup starting +I: user script /srv/workspace/pbuilder/28107/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/27131 and its subdirectories -I: Current time: Tue Jul 9 15:46:45 -12 2024 -I: pbuilder-time-stamp: 1720583205 +I: removing directory /srv/workspace/pbuilder/28107 and its subdirectories +I: Current time: Wed Jul 10 17:49:16 +14 2024 +I: pbuilder-time-stamp: 1720583356