Home | History | Annotate | Line # | Download | only in aarch64
      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