aboutsummaryrefslogtreecommitdiff
path: root/sim/testsuite/bpf/endbe.s
blob: 2b2de96f0baae6e39adc348c98035d924aeb2635 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
# mach: bpf
# as: --EB
# ld: --EB
# sim: -E big
# output: pass\nexit 0 (0x0)\n
/* endbe.s
   Tests for BPF endianness-conversion instructions in simulator
   running in BIG ENDIAN

   Both 'be' and 'le' ISAs have both endbe and endle instructions.  */

    .include "testutils.inc"

    .text
    .global main
    .type main, @function
main:
    lddw        %r1, 0x12345678deadbeef
    endle       %r1, 64
    fail_ne     %r1, 0xefbeadde78563412
    endle       %r1, 64
    fail_ne     %r1, 0x12345678deadbeef

    /* `bitsize` < 64 will truncate  */
    endle       %r1, 32
    fail_ne     %r1, 0xefbeadde
    endle       %r1, 32
    fail_ne     %r1, 0xdeadbeef

    endle       %r1, 16
    fail_ne     %r1, 0xefbe
    endle       %r1, 16
    fail_ne     %r1, 0xbeef

    /* endbe on be should be noop (except truncate)  */
    lddw        %r1, 0x12345678deadbeef
    endbe       %r1, 64
    fail_ne     %r1, 0x12345678deadbeef

    endbe       %r1, 32
    fail_ne     %r1, 0xdeadbeef

    endbe       %r1, 16
    fail_ne     %r1, 0xbeef

    pass