mem.s 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. # mach: bpf
  2. # output: pass\nexit 0 (0x0)\n
  3. ;;; mem.s
  4. ;;; Tests for BPF memory (ldx, stx, ..) instructions in simulator
  5. .include "testutils.inc"
  6. .text
  7. .global main
  8. .type main, @function
  9. main:
  10. lddw %r1, 0x1234deadbeef5678
  11. mov %r2, 0x1000
  12. ;; basic store/load check
  13. stxb [%r2+0], %r1
  14. stxh [%r2+2], %r1
  15. stxw [%r2+4], %r1
  16. stxdw [%r2+8], %r1
  17. stb [%r2+16], 0x5a
  18. sth [%r2+18], 0xcafe
  19. stw [%r2+20], 0xbeefface
  20. stdw [%r2+24], 0x7eadbeef
  21. ldxb %r1, [%r2+16]
  22. fail_ne %r1, 0x5a
  23. ldxh %r1, [%r2+18]
  24. fail_ne %r1, 0xffffffffffffcafe
  25. ldxw %r1, [%r2+20]
  26. fail_ne %r1, 0xffffffffbeefface
  27. ldxdw %r1, [%r2+24]
  28. fail_ne %r1, 0x7eadbeef
  29. ldxb %r3, [%r2+0]
  30. fail_ne %r3, 0x78
  31. ldxh %r3, [%r2+2]
  32. fail_ne %r3, 0x5678
  33. ldxw %r3, [%r2+4]
  34. fail_ne %r3, 0xffffffffbeef5678
  35. ldxdw %r3, [%r2+8]
  36. fail_ne %r3, 0x1234deadbeef5678
  37. ldxw %r4, [%r2+10]
  38. fail_ne %r4, 0xffffffffdeadbeef
  39. ;; negative offsets
  40. add %r2, 16
  41. ldxh %r5, [%r2+-14]
  42. fail_ne %r5, 0x5678
  43. ldxw %r5, [%r2+-12]
  44. fail_ne %r5, 0xffffffffbeef5678
  45. ldxdw %r5, [%r2+-8]
  46. fail_ne %r5, 0x1234deadbeef5678
  47. pass