Lines Matching +full:4 +full:x12
39 X12 .req r10
58 ldr \b, [\src, #\offset + 4]
67 str \b, [\dst, #\offset + 4]
106 // quarterrounds: (x0, x4, x8, x12) and (x1, x5, x9, x13)
107 _halfround X0, X4, X8_X10, X12, X1, X5, X9_X11, X13
121 // quarterrounds: (x0, x5, x10, x15) and (x1, x6, x11, x12)
122 _halfround X0, X5, X8_X10, X15, X1, X6, X9_X11, X12
144 // Registers contain x0-x9,x12-x15.
151 // Registers contain x0-x9,x12-x15.
152 // x4-x7 are rotated by 'brot'; x12-x15 are rotated by 'drot'.
154 // Free up some registers (r8-r12,r14) by pushing (x8-x9,x12-x15).
155 push {X8_X10, X9_X11, X12, X13, X14, X15}
168 // Use slow path if IN and/or OUT isn't 4-byte aligned. Needed even on
175 // Stack: x8-x9 x12-x15 x10-x11 orig_x0-orig_x15 OUT IN LEN
177 // x4-x7 are rotated by 'brot'; x12-x15 are rotated by 'drot'.
210 pop {r0-r7} // (x8-x9,x12-x15,x10-x11)
227 add r2, r8, r2, ror #drot // x12
233 eor r2, r2, r0 // x12
246 // Increment block counter (x12)
256 // Store updated block counter (x12)
264 ldmia r14, {r10-r12,r14} // load x12-x15
276 // Stack: ks0-ks15 x8-x9 x12-x15 x10-x11 orig_x0-orig_x15 OUT IN LEN
278 // x4-x7 are rotated by 'brot'; x12-x15 are rotated by 'drot'.
302 ldm r8, {r0-r7} // (x8-x9,x12-x15,x10-x11)
313 add r2, r8, r2, ror #drot // x12
339 subs r1, #4
341 ldr r2, [r12], #4
342 ldr r3, [r0], #4
344 str r2, [r14], #4
384 add X12, r3, #48
385 ldm X12, {X12,X13,X14,X15}
386 push {X12,X13,X14,X15}
420 ldm r14, {r10-r12,r14} // load x12-x15
429 // Fix up rotations of x12-x15
430 ror X12, X12, #drot
436 // Store (x0-x3,x12-x15) to 'out'
437 stm r4, {X0,X1,X2,X3,X12,X13,X14,X15}