1 1.1 christos # mach: aarch64 2 1.1 christos 3 1.1 christos # Check the FP store unscaled offset instructions: fsturs, fsturd, fsturq. 4 1.1 christos # Check the values -1, and XXX_MAX, which tests all bits. 5 1.1 christos # Check with offsets -256 and 255, which tests all bits. 6 1.1 christos # Also tests the FP load unscaled offset instructions: fldurs, fldurd, fldurq. 7 1.1 christos 8 1.1 christos .include "testutils.inc" 9 1.1 christos 10 1.1 christos .data 11 1.1 christos .align 4 12 1.1 christos fm1: 13 1.1 christos .word 3212836864 14 1.1 christos fmax: 15 1.1 christos .word 2139095039 16 1.1 christos ftmp: 17 1.1 christos .word 0 18 1.1 christos 19 1.1 christos dm1: 20 1.1 christos .word 0 21 1.1 christos .word -1074790400 22 1.1 christos dmax: 23 1.1 christos .word 4294967295 24 1.1 christos .word 2146435071 25 1.1 christos dtmp: 26 1.1 christos .word 0 27 1.1 christos .word 0 28 1.1 christos 29 1.1 christos ldm1: 30 1.1 christos .word 0 31 1.1 christos .word 0 32 1.1 christos .word 0 33 1.1 christos .word -1073807360 34 1.1 christos ldmax: 35 1.1 christos .word 4294967295 36 1.1 christos .word 4294967295 37 1.1 christos .word 4294967295 38 1.1 christos .word 2147418111 39 1.1 christos ldtmp: 40 1.1 christos .word 0 41 1.1 christos .word 0 42 1.1 christos .word 0 43 1.1 christos .word 0 44 1.1 christos 45 1.1 christos start 46 1.1 christos adrp x1, ftmp 47 1.1 christos add x1, x1, :lo12:ftmp 48 1.1 christos 49 1.1 christos adrp x0, fm1 50 1.1 christos add x0, x0, :lo12:fm1 51 1.1 christos sub x5, x0, #255 52 1.1 christos sub x6, x1, #255 53 1.1 christos movi d2, #0 54 1.1 christos ldur s2, [x5, #255] 55 1.1 christos stur s2, [x6, #255] 56 1.1 christos ldr w3, [x0] 57 1.1 christos ldr w4, [x1] 58 1.1 christos cmp w3, w4 59 1.1 christos bne .Lfailure 60 1.1 christos 61 1.1 christos adrp x0, fmax 62 1.1 christos add x0, x0, :lo12:fmax 63 1.1 christos add x5, x0, #256 64 1.1 christos add x6, x1, #256 65 1.1 christos movi d2, #0 66 1.1 christos ldur s2, [x5, #-256] 67 1.1 christos stur s2, [x6, #-256] 68 1.1 christos ldr w3, [x0] 69 1.1 christos ldr w4, [x1] 70 1.1 christos cmp w3, w4 71 1.1 christos bne .Lfailure 72 1.1 christos 73 1.1 christos adrp x1, dtmp 74 1.1 christos add x1, x1, :lo12:dtmp 75 1.1 christos 76 1.1 christos adrp x0, dm1 77 1.1 christos add x0, x0, :lo12:dm1 78 1.1 christos sub x5, x0, #255 79 1.1 christos sub x6, x1, #255 80 1.1 christos movi d2, #0 81 1.1 christos ldur d2, [x5, #255] 82 1.1 christos stur d2, [x6, #255] 83 1.1 christos ldr x3, [x0] 84 1.1 christos ldr x4, [x1] 85 1.1 christos cmp x3, x4 86 1.1 christos bne .Lfailure 87 1.1 christos 88 1.1 christos adrp x0, dmax 89 1.1 christos add x0, x0, :lo12:dmax 90 1.1 christos add x5, x0, #256 91 1.1 christos add x6, x1, #256 92 1.1 christos movi d2, #0 93 1.1 christos ldur d2, [x5, #-256] 94 1.1 christos stur d2, [x6, #-256] 95 1.1 christos ldr x3, [x0] 96 1.1 christos ldr x4, [x1] 97 1.1 christos cmp x3, x4 98 1.1 christos bne .Lfailure 99 1.1 christos 100 1.1 christos adrp x1, ldtmp 101 1.1 christos add x1, x1, :lo12:ldtmp 102 1.1 christos 103 1.1 christos adrp x0, ldm1 104 1.1 christos add x0, x0, :lo12:ldm1 105 1.1 christos sub x5, x0, #255 106 1.1 christos sub x6, x1, #255 107 1.1 christos movi v2.2d, #0 108 1.1 christos ldur q2, [x5, #255] 109 1.1 christos stur q2, [x6, #255] 110 1.1 christos ldr x3, [x0] 111 1.1 christos ldr x4, [x1] 112 1.1 christos cmp x3, x4 113 1.1 christos bne .Lfailure 114 1.1 christos ldr x3, [x0, 8] 115 1.1 christos ldr x4, [x1, 8] 116 1.1 christos cmp x3, x4 117 1.1 christos bne .Lfailure 118 1.1 christos 119 1.1 christos adrp x0, ldmax 120 1.1 christos add x0, x0, :lo12:ldmax 121 1.1 christos add x5, x0, #256 122 1.1 christos add x6, x1, #256 123 1.1 christos movi v2.2d, #0 124 1.1 christos ldur q2, [x5, #-256] 125 1.1 christos stur q2, [x6, #-256] 126 1.1 christos ldr x3, [x0] 127 1.1 christos ldr x4, [x1] 128 1.1 christos cmp x3, x4 129 1.1 christos bne .Lfailure 130 1.1 christos ldr x3, [x0, 8] 131 1.1 christos ldr x4, [x1, 8] 132 1.1 christos cmp x3, x4 133 1.1 christos bne .Lfailure 134 1.1 christos 135 1.1 christos pass 136 1.1 christos .Lfailure: 137 1.1 christos fail 138