github.com/powerman/golang-tools@v0.1.11-0.20220410185822-5ad214d8d803/go/analysis/passes/asmdecl/testdata/src/a/asm8.s (about) 1 // Copyright 2016 The Go Authors. All rights reserved. 2 // Use of this source code is governed by a BSD-style 3 // license that can be found in the LICENSE file. 4 5 // +build mipsle 6 7 TEXT ·arg1(SB),0,$0-2 8 MOVB x+0(FP), R1 9 MOVBU y+1(FP), R2 10 MOVH x+0(FP), R1 // want `\[mipsle\] arg1: invalid MOVH of x\+0\(FP\); int8 is 1-byte value` 11 MOVHU y+1(FP), R1 // want `invalid MOVHU of y\+1\(FP\); uint8 is 1-byte value` 12 MOVW x+0(FP), R1 // want `invalid MOVW of x\+0\(FP\); int8 is 1-byte value` 13 MOVWU y+1(FP), R1 // want `invalid MOVWU of y\+1\(FP\); uint8 is 1-byte value` 14 MOVW y+1(FP), R1 // want `invalid MOVW of y\+1\(FP\); uint8 is 1-byte value` 15 MOVB x+1(FP), R1 // want `invalid offset x\+1\(FP\); expected x\+0\(FP\)` 16 MOVBU y+2(FP), R1 // want `invalid offset y\+2\(FP\); expected y\+1\(FP\)` 17 MOVB 8(R29), R1 // want `8\(R29\) should be x\+0\(FP\)` 18 MOVB 9(R29), R1 // want `9\(R29\) should be y\+1\(FP\)` 19 MOVB 10(R29), R1 // want `use of 10\(R29\) points beyond argument frame` 20 RET 21 22 TEXT ·arg2(SB),0,$0-4 23 MOVBU x+0(FP), R1 // want `arg2: invalid MOVBU of x\+0\(FP\); int16 is 2-byte value` 24 MOVB y+2(FP), R1 // want `invalid MOVB of y\+2\(FP\); uint16 is 2-byte value` 25 MOVHU x+0(FP), R1 26 MOVH y+2(FP), R2 27 MOVWU x+0(FP), R1 // want `invalid MOVWU of x\+0\(FP\); int16 is 2-byte value` 28 MOVW y+2(FP), R1 // want `invalid MOVW of y\+2\(FP\); uint16 is 2-byte value` 29 MOVHU x+2(FP), R1 // want `invalid offset x\+2\(FP\); expected x\+0\(FP\)` 30 MOVH y+0(FP), R1 // want `invalid offset y\+0\(FP\); expected y\+2\(FP\)` 31 RET 32 33 TEXT ·arg4(SB),0,$0-2 // want `arg4: wrong argument size 2; expected \$\.\.\.-8` 34 MOVB x+0(FP), R1 // want `invalid MOVB of x\+0\(FP\); int32 is 4-byte value` 35 MOVB y+4(FP), R2 // want `invalid MOVB of y\+4\(FP\); uint32 is 4-byte value` 36 MOVH x+0(FP), R1 // want `invalid MOVH of x\+0\(FP\); int32 is 4-byte value` 37 MOVH y+4(FP), R1 // want `invalid MOVH of y\+4\(FP\); uint32 is 4-byte value` 38 MOVW x+0(FP), R1 39 MOVW y+4(FP), R1 40 MOVW x+4(FP), R1 // want `invalid offset x\+4\(FP\); expected x\+0\(FP\)` 41 MOVW y+2(FP), R1 // want `invalid offset y\+2\(FP\); expected y\+4\(FP\)` 42 RET 43 44 TEXT ·arg8(SB),7,$0-2 // want `wrong argument size 2; expected \$\.\.\.-16` 45 MOVB x+0(FP), R1 // want `invalid MOVB of x\+0\(FP\); int64 is 8-byte value` 46 MOVB y+8(FP), R2 // want `invalid MOVB of y\+8\(FP\); uint64 is 8-byte value` 47 MOVH x+0(FP), R1 // want `invalid MOVH of x\+0\(FP\); int64 is 8-byte value` 48 MOVH y+8(FP), R1 // want `invalid MOVH of y\+8\(FP\); uint64 is 8-byte value` 49 MOVW x+0(FP), R1 // want `invalid MOVW of x\+0\(FP\); int64 is 8-byte value containing x_lo\+0\(FP\) and x_hi\+4\(FP\)` 50 MOVW $x+0(FP), R1 // ok 51 MOVW x_lo+0(FP), R1 52 MOVW x_hi+4(FP), R1 53 MOVW y+8(FP), R1 // want `invalid MOVW of y\+8\(FP\); uint64 is 8-byte value containing y_lo\+8\(FP\) and y_hi\+12\(FP\)` 54 MOVW y_lo+8(FP), R1 55 MOVW y_hi+12(FP), R1 56 RET 57 58 TEXT ·argint(SB),0,$0-2 // want `wrong argument size 2; expected \$\.\.\.-8` 59 MOVB x+0(FP), R1 // want `invalid MOVB of x\+0\(FP\); int is 4-byte value` 60 MOVB y+4(FP), R2 // want `invalid MOVB of y\+4\(FP\); uint is 4-byte value` 61 MOVH x+0(FP), R1 // want `invalid MOVH of x\+0\(FP\); int is 4-byte value` 62 MOVH y+4(FP), R1 // want `invalid MOVH of y\+4\(FP\); uint is 4-byte value` 63 MOVW x+0(FP), R1 64 MOVW y+4(FP), R1 65 MOVW x+4(FP), R1 // want `invalid offset x\+4\(FP\); expected x\+0\(FP\)` 66 MOVW y+2(FP), R1 // want `invalid offset y\+2\(FP\); expected y\+4\(FP\)` 67 RET 68 69 TEXT ·argptr(SB),7,$0-2 // want `wrong argument size 2; expected \$\.\.\.-20` 70 MOVB x+0(FP), R1 // want `invalid MOVB of x\+0\(FP\); \*byte is 4-byte value` 71 MOVB y+4(FP), R2 // want `invalid MOVB of y\+4\(FP\); \*byte is 4-byte value` 72 MOVH x+0(FP), R1 // want `invalid MOVH of x\+0\(FP\); \*byte is 4-byte value` 73 MOVH y+4(FP), R1 // want `invalid MOVH of y\+4\(FP\); \*byte is 4-byte value` 74 MOVW x+0(FP), R1 75 MOVW y+4(FP), R1 76 MOVW x+4(FP), R1 // want `invalid offset x\+4\(FP\); expected x\+0\(FP\)` 77 MOVW y+2(FP), R1 // want `invalid offset y\+2\(FP\); expected y\+4\(FP\)` 78 MOVH c+8(FP), R1 // want `invalid MOVH of c\+8\(FP\); chan int is 4-byte value` 79 MOVH m+12(FP), R1 // want `invalid MOVH of m\+12\(FP\); map\[int\]int is 4-byte value` 80 MOVH f+16(FP), R1 // want `invalid MOVH of f\+16\(FP\); func\(\) is 4-byte value` 81 RET 82 83 TEXT ·argstring(SB),0,$16 // want `wrong argument size 0; expected \$\.\.\.-16` 84 MOVH x+0(FP), R1 // want `invalid MOVH of x\+0\(FP\); string base is 4-byte value` 85 MOVW x+0(FP), R1 86 MOVH x_base+0(FP), R1 // want `invalid MOVH of x_base\+0\(FP\); string base is 4-byte value` 87 MOVW x_base+0(FP), R1 88 MOVH x_len+0(FP), R1 // want `invalid offset x_len\+0\(FP\); expected x_len\+4\(FP\)` 89 MOVW x_len+0(FP), R1 // want `invalid offset x_len\+0\(FP\); expected x_len\+4\(FP\)` 90 MOVH x_len+4(FP), R1 // want `invalid MOVH of x_len\+4\(FP\); string len is 4-byte value` 91 MOVW x_len+4(FP), R1 92 MOVW y+0(FP), R1 // want `invalid offset y\+0\(FP\); expected y\+8\(FP\)` 93 MOVW y_len+4(FP), R1 // want `invalid offset y_len\+4\(FP\); expected y_len\+12\(FP\)` 94 RET 95 96 TEXT ·argslice(SB),0,$24 // want `wrong argument size 0; expected \$\.\.\.-24` 97 MOVH x+0(FP), R1 // want `invalid MOVH of x\+0\(FP\); slice base is 4-byte value` 98 MOVW x+0(FP), R1 99 MOVH x_base+0(FP), R1 // want `invalid MOVH of x_base\+0\(FP\); slice base is 4-byte value` 100 MOVW x_base+0(FP), R1 101 MOVH x_len+0(FP), R1 // want `invalid offset x_len\+0\(FP\); expected x_len\+4\(FP\)` 102 MOVW x_len+0(FP), R1 // want `invalid offset x_len\+0\(FP\); expected x_len\+4\(FP\)` 103 MOVH x_len+4(FP), R1 // want `invalid MOVH of x_len\+4\(FP\); slice len is 4-byte value` 104 MOVW x_len+4(FP), R1 105 MOVH x_cap+0(FP), R1 // want `invalid offset x_cap\+0\(FP\); expected x_cap\+8\(FP\)` 106 MOVW x_cap+0(FP), R1 // want `invalid offset x_cap\+0\(FP\); expected x_cap\+8\(FP\)` 107 MOVH x_cap+8(FP), R1 // want `invalid MOVH of x_cap\+8\(FP\); slice cap is 4-byte value` 108 MOVW x_cap+8(FP), R1 109 MOVW y+0(FP), R1 // want `invalid offset y\+0\(FP\); expected y\+12\(FP\)` 110 MOVW y_len+4(FP), R1 // want `invalid offset y_len\+4\(FP\); expected y_len\+16\(FP\)` 111 MOVW y_cap+8(FP), R1 // want `invalid offset y_cap\+8\(FP\); expected y_cap\+20\(FP\)` 112 RET 113 114 TEXT ·argiface(SB),0,$0-16 115 MOVH x+0(FP), R1 // want `invalid MOVH of x\+0\(FP\); interface type is 4-byte value` 116 MOVW x+0(FP), R1 117 MOVH x_type+0(FP), R1 // want `invalid MOVH of x_type\+0\(FP\); interface type is 4-byte value` 118 MOVW x_type+0(FP), R1 119 MOVQ x_itable+0(FP), R1 // want `unknown variable x_itable; offset 0 is x_type\+0\(FP\)` 120 MOVQ x_itable+1(FP), R1 // want `unknown variable x_itable; offset 1 is x_type\+0\(FP\)` 121 MOVH x_data+0(FP), R1 // want `invalid offset x_data\+0\(FP\); expected x_data\+4\(FP\)` 122 MOVW x_data+0(FP), R1 // want `invalid offset x_data\+0\(FP\); expected x_data\+4\(FP\)` 123 MOVQ x_data+0(FP), R1 // want `invalid offset x_data\+0\(FP\); expected x_data\+4\(FP\)` 124 MOVH x_data+4(FP), R1 // want `invalid MOVH of x_data\+4\(FP\); interface data is 4-byte value` 125 MOVW x_data+4(FP), R1 126 MOVH y+8(FP), R1 // want `invalid MOVH of y\+8\(FP\); interface itable is 4-byte value` 127 MOVW y+8(FP), R1 128 MOVH y_itable+8(FP), R1 // want `invalid MOVH of y_itable\+8\(FP\); interface itable is 4-byte value` 129 MOVW y_itable+8(FP), R1 130 MOVW y_type+8(FP), AX // want `unknown variable y_type; offset 8 is y_itable\+8\(FP\)` 131 MOVH y_data+8(FP), AX // want `invalid offset y_data\+8\(FP\); expected y_data\+12\(FP\)` 132 MOVW y_data+8(FP), AX // want `invalid offset y_data\+8\(FP\); expected y_data\+12\(FP\)` 133 MOVH y_data+12(FP), AX // want `invalid MOVH of y_data\+12\(FP\); interface data is 4-byte value` 134 MOVW y_data+12(FP), AX 135 RET 136 137 TEXT ·returnbyte(SB),0,$0-5 138 MOVW x+0(FP), R1 139 MOVB R1, ret+4(FP) 140 MOVH R1, ret+4(FP) // want `invalid MOVH of ret\+4\(FP\); byte is 1-byte value` 141 MOVW R1, ret+4(FP) // want `invalid MOVW of ret\+4\(FP\); byte is 1-byte value` 142 MOVB R1, ret+3(FP) // want `invalid offset ret\+3\(FP\); expected ret\+4\(FP\)` 143 RET 144 145 TEXT ·returnbyte(SB),0,$0-5 146 MOVW x+0(FP), R1 147 MOVB R1, ret+4(FP) 148 MOVH R1, ret+4(FP) // want `invalid MOVH of ret\+4\(FP\); byte is 1-byte value` 149 MOVW R1, ret+4(FP) // want `invalid MOVW of ret\+4\(FP\); byte is 1-byte value` 150 MOVB R1, ret+3(FP) // want `invalid offset ret\+3\(FP\); expected ret\+4\(FP\)` 151 RET 152 153 TEXT ·returnnamed(SB),0,$0-21 154 MOVB x+0(FP), AX 155 MOVW R1, r1+4(FP) 156 MOVH R1, r2+8(FP) 157 MOVW R1, r3+12(FP) 158 MOVW R1, r3_base+12(FP) 159 MOVW R1, r3_len+16(FP) 160 MOVB R1, r4+20(FP) 161 MOVB R1, r1+4(FP) // want `invalid MOVB of r1\+4\(FP\); int is 4-byte value` 162 RET 163 164 TEXT ·returnintmissing(SB),0,$0-4 165 RET // want `RET without writing to 4-byte ret\+0\(FP\)`