Lines Matching +full:0 +full:e

16  *	E	- either cluster
31 .frame $30,0,$26,0
32 .prologue 0
34 mov $16, $0 # E : copy dest to return
36 xor $16, $17, $1 # E : are source and dest alignments the same?
37 and $1, 7, $1 # E : are they the same mod 8?
41 and $16, 7, $1 # E : Are both 0mod8?
43 nop # E :
47 * until a 0mod8 alignment for both is reached.
52 ldbu $1, 0($17) # L : grab a byte
53 subq $18, 1, $18 # E : count--
54 addq $17, 1, $17 # E : src++
55 stb $1, 0($16) # L :
56 addq $16, 1, $16 # E : dest++
57 and $16, 7, $1 # E : Are we at 0mod8 yet?
62 cmple $18, 127, $1 # E : Can we unroll the loop?
64 and $16, 63, $1 # E : get mod64 alignment
68 ldq $1, 0($17) # L : get 8 bytes
69 subq $18, 8, $18 # E : count -= 8
70 addq $17, 8, $17 # E : src += 8
71 nop # E :
73 stq $1, 0($16) # L : store
74 addq $16, 8, $16 # E : dest += 8
75 and $16, 63, $1 # E : get mod64 alignment
79 addq $16, 64, $7 # E : Initial (+1 trip) wh64 address
80 cmple $18, 127, $1 # E : Can we go through the unrolled loop?
82 nop # E :
87 ldq $6, 0($17) # L0 : bytes 0..7
88 nop # E :
89 nop # E :
93 addq $7, 64, $7 # E : Update next wh64 address
94 nop # E :
97 addq $16, 64, $1 # E : fallback value for wh64
98 nop # E :
99 nop # E :
101 addq $17, 32, $17 # E : src += 32 bytes
102 stq $6, 0($16) # L : bytes 0..7
103 nop # E :
104 nop # E :
108 subq $18, 192, $2 # E : At least two more trips to go?
109 nop # E :
112 addq $16, 32, $16 # E : dest += 32 bytes
113 nop # E :
114 nop # E :
116 ldq $6, 0($17) # L : bytes 0..7
118 cmovlt $2, $1, $7 # E : Latency 2, extra map slot - Use
120 nop # E :
124 addq $16, 32, $16 # E : dest += 32
125 subq $18, 64, $18 # E : count -= 64
127 addq $17, 32, $17 # E : src += 32
128 stq $6, -32($16) # L : bytes 0..7
130 cmple $18, 63, $1 # E : At least one more trip?
134 nop # E :
140 subq $18, 8, $18 # E : At least a quad left?
142 nop # E :
143 nop # E :
146 ldq $1, 0($17) # L : fetch 8
147 subq $18, 8, $18 # E : count -= 8
148 addq $17, 8, $17 # E : src += 8
149 nop # E :
151 stq $1, 0($16) # L : store 8
152 addq $16, 8, $16 # E : dest += 8
154 nop # E :
158 addq $18, 8, $18 # E : add back for trailing bytes
160 nop # E :
161 nop # E :
165 subq $18, 1, $18 # E : count--
166 ldbu $1, 0($17) # L : fetch a byte
167 addq $17, 1, $17 # E : src++
168 nop # E :
170 stb $1, 0($16) # L : store a byte
171 addq $16, 1, $16 # E : dest++
173 nop # E :
177 nop # E :
178 nop # E :
179 nop # E :
182 mov $0, $4 # E : dest temp
183 and $0, 7, $1 # E : dest alignment mod8
189 ldbu $1, 0($17) # L : fetch a byte
190 subq $18, 1, $18 # E : count--
191 addq $17, 1, $17 # E : src++
193 stb $1, 0($4) # L : store it
194 addq $4, 1, $4 # E : dest++
195 and $4, 7, $1 # E : dest 0mod8 yet?
198 /* Source has unknown alignment, but dest is known to be 0mod8 */
200 subq $18, 8, $18 # E : At least a quad left?
202 ldq_u $3, 0($17) # L : seed (rotating load) of 8 bytes
203 nop # E :
209 bis $3, $1, $1 # E : merged bytes to store
211 subq $18, 8, $18 # E : count -= 8
212 addq $17, 8, $17 # E : src += 8
213 stq $1, 0($4) # L : store 8 (aligned)
214 mov $16, $3 # E : "rotate" source data
216 addq $4, 8, $4 # E : dest += 8
222 addq $18, 8, $18 # E : account for tail stuff
228 ldbu $1, 0($17) # L : fetch 1
229 subq $18, 1, $18 # E : count--
230 addq $17, 1, $17 # E : src++
231 nop # E :
233 stb $1, 0($4) # L : store
234 addq $4, 1, $4 # E : dest++
241 nop # E :
242 nop # E :
243 nop # E :