Lines Matching full:src
22 #define src a1 macro
28 * memcpy copies len bytes from src to dst and sets v0 to dst.
30 * - src and dst don't overlap
31 * - src is readable
35 * __copy_user copies up to len bytes from src to dst and sets a2 (len) to
37 * __copy_user assumes that src and dst don't overlap, and that the call is
40 * - src is readable (no exceptions when reading src)
59 * 2- src_entry <= src < AT, and
60 * 3- (dst - src) == (dst_entry - src_entry),
64 * (2) is met by incrementing src by the number of bytes copied
65 * (3) is met by not doing loads between a pair of increments of dst and src
149 LEAF(memcpy) /* a0=dst a1=src a2=len */
158 * Note: dst & src may be unaligned, len may be 0
165 pref 0, 0(src)
168 and t0, src, ADDRMASK # Check if src unaligned
180 pref 0, 128(src) # We must not prefetch invalid addresses
183 2: pref 0, 256(src) # We must not prefetch invalid addresses
187 EXC( LOAD t0, UNIT(0)(src), l_exc)
188 EXC( LOAD t1, UNIT(1)(src), l_exc_copy)
189 EXC( LOAD t2, UNIT(2)(src), l_exc_copy)
190 EXC( LOAD t3, UNIT(3)(src), l_exc_copy)
196 EXC( LOAD t0, UNIT(4)(src), l_exc_copy)
197 EXC( LOAD t1, UNIT(5)(src), l_exc_copy)
198 EXC( LOAD t2, UNIT(6)(src), l_exc_copy)
199 EXC( LOAD t3, UNIT(7)(src), l_exc_copy)
203 ADD src, src, 16*NBYTES
206 EXC( LOAD t0, UNIT(-8)(src), l_exc_copy_rewind16)
207 EXC( LOAD t1, UNIT(-7)(src), l_exc_copy_rewind16)
208 EXC( LOAD t2, UNIT(-6)(src), l_exc_copy_rewind16)
209 EXC( LOAD t3, UNIT(-5)(src), l_exc_copy_rewind16)
214 EXC( LOAD t0, UNIT(-4)(src), l_exc_copy_rewind16)
215 EXC( LOAD t1, UNIT(-3)(src), l_exc_copy_rewind16)
216 EXC( LOAD t2, UNIT(-2)(src), l_exc_copy_rewind16)
217 EXC( LOAD t3, UNIT(-1)(src), l_exc_copy_rewind16)
235 EXC( LOAD t0, UNIT(0)(src), l_exc)
236 EXC( LOAD t1, UNIT(1)(src), l_exc_copy)
237 EXC( LOAD t2, UNIT(2)(src), l_exc_copy)
238 EXC( LOAD t3, UNIT(3)(src), l_exc_copy)
244 EXC( LOAD t0, UNIT(4)(src), l_exc_copy)
245 EXC( LOAD t1, UNIT(5)(src), l_exc_copy)
246 EXC( LOAD t2, UNIT(6)(src), l_exc_copy)
247 EXC( LOAD t3, UNIT(7)(src), l_exc_copy)
252 ADD src, src, 8*NBYTES
262 EXC( LOAD t0, UNIT(0)(src), l_exc)
263 EXC( LOAD t1, UNIT(1)(src), l_exc_copy)
264 EXC( LOAD t2, UNIT(2)(src), l_exc_copy)
265 EXC( LOAD t3, UNIT(3)(src), l_exc_copy)
271 ADD src, src, 4*NBYTES
285 EXC( LOAD t0, 0(src), l_exc)
289 ADD src, src, NBYTES
295 EXC( LOAD t0, 0(src), l_exc)
299 ADD src, src, NBYTES
305 EXC( LOAD t0, 0(src), l_exc)
307 ADD src, src, NBYTES
322 * are to the same unit (unless src is aligned, but it's not).
324 EXC( LDFIRST t0, FIRST(0)(src), l_exc)
325 EXC( LDFIRST t1, FIRST(1)(src), l_exc_copy)
327 EXC( LDREST t0, REST(0)(src), l_exc_copy)
328 EXC( LDREST t1, REST(1)(src), l_exc_copy)
329 EXC( LDFIRST t2, FIRST(2)(src), l_exc_copy)
330 EXC( LDFIRST t3, FIRST(3)(src), l_exc_copy)
331 EXC( LDREST t2, REST(2)(src), l_exc_copy)
332 EXC( LDREST t3, REST(3)(src), l_exc_copy)
333 ADD src, src, 4*NBYTES
347 EXC( LDFIRST t0, FIRST(0)(src), l_exc)
348 EXC( LDREST t0, REST(0)(src), l_exc_copy)
351 ADD src, src, NBYTES
361 EXC( lb t0, N(src), l_exc); \
372 EXC( lb t0, NBYTES-2(src), l_exc)
382 /* Rewind src and dst by 16*NBYTES for l_exc_copy */
383 SUB src, src, 16*NBYTES
387 * Copy bytes from src until faulting load address (or until a
394 * Assumes src < THREAD_BUADDR($28)
399 EXC( lb t1, 0(src), l_exc)
400 ADD src, src, 1
402 bne src, t0, 1b
446 sltu t0, a1, t0 # dst + len <= src -> memcpy
447 sltu t1, a0, t1 # dst >= src + len -> memcpy
455 LEAF(__rmemcpy) /* a0=dst a1=src a2=len */
457 beqz t0, r_end_bytes_up # src >= dst
460 ADD a1, a2 # src = src + len