Lines Matching +full:16 +full:- +full:bit

48 	/* Word-align the destination buffer */
64 ands ip, r1, #0x03 /* Is src also word-aligned? */
67 /* Quad-align the destination buffer */
70 stmfd sp!, {r4-r9} /* Free up some registers */
80 ldr r4, [r1], #0x04 /* LD:00-03 */
81 ldr r5, [r1], #0x04 /* LD:04-07 */
83 ldr r6, [r1], #0x04 /* LD:08-0b */
84 ldr r7, [r1], #0x04 /* LD:0c-0f */
85 ldr r8, [r1], #0x04 /* LD:10-13 */
86 ldr r9, [r1], #0x04 /* LD:14-17 */
87 strd r4, [r3], #0x08 /* ST:00-07 */
88 ldr r4, [r1], #0x04 /* LD:18-1b */
89 ldr r5, [r1], #0x04 /* LD:1c-1f */
90 strd r6, [r3], #0x08 /* ST:08-0f */
91 ldr r6, [r1], #0x04 /* LD:20-23 */
92 ldr r7, [r1], #0x04 /* LD:24-27 */
94 strd r8, [r3], #0x08 /* ST:10-17 */
95 ldr r8, [r1], #0x04 /* LD:28-2b */
96 ldr r9, [r1], #0x04 /* LD:2c-2f */
97 strd r4, [r3], #0x08 /* ST:18-1f */
98 ldr r4, [r1], #0x04 /* LD:30-33 */
99 ldr r5, [r1], #0x04 /* LD:34-37 */
100 strd r6, [r3], #0x08 /* ST:20-27 */
101 ldr r6, [r1], #0x04 /* LD:38-3b */
102 ldr r7, [r1], #0x04 /* LD:3c-3f */
103 strd r8, [r3], #0x08 /* ST:28-2f */
104 ldr r8, [r1], #0x04 /* LD:40-43 */
105 ldr r9, [r1], #0x04 /* LD:44-47 */
107 strd r4, [r3], #0x08 /* ST:30-37 */
108 ldr r4, [r1], #0x04 /* LD:48-4b */
109 ldr r5, [r1], #0x04 /* LD:4c-4f */
110 strd r6, [r3], #0x08 /* ST:38-3f */
111 ldr r6, [r1], #0x04 /* LD:50-53 */
112 ldr r7, [r1], #0x04 /* LD:54-57 */
113 strd r8, [r3], #0x08 /* ST:40-47 */
114 ldr r8, [r1], #0x04 /* LD:58-5b */
115 ldr r9, [r1], #0x04 /* LD:5c-5f */
116 strd r4, [r3], #0x08 /* ST:48-4f */
117 ldr r4, [r1], #0x04 /* LD:60-63 */
118 ldr r5, [r1], #0x04 /* LD:64-67 */
120 strd r6, [r3], #0x08 /* ST:50-57 */
121 ldr r6, [r1], #0x04 /* LD:68-6b */
122 ldr r7, [r1], #0x04 /* LD:6c-6f */
123 strd r8, [r3], #0x08 /* ST:58-5f */
124 ldr r8, [r1], #0x04 /* LD:70-73 */
125 ldr r9, [r1], #0x04 /* LD:74-77 */
126 strd r4, [r3], #0x08 /* ST:60-67 */
127 ldr r4, [r1], #0x04 /* LD:78-7b */
128 ldr r5, [r1], #0x04 /* LD:7c-7f */
129 strd r6, [r3], #0x08 /* ST:68-6f */
130 strd r8, [r3], #0x08 /* ST:70-77 */
132 strd r4, [r3], #0x08 /* ST:78-7f */
137 ldmfdeq sp!, {r4-r9}
162 ldmfdeq sp!, {r4-r9}
176 /* At least 16 bytes remaining */
189 ldmfd sp!, {r4-r9}
211 stmfd sp!, {r4-r7}
242 ldmfdeq sp!, {r4-r7}
259 mov r4, ip, lsr #16
265 orr r4, r4, r5, lsl #16
266 mov r5, r5, lsr #16
267 orr r5, r5, r6, lsl #16
268 mov r6, r6, lsr #16
269 orr r6, r6, r7, lsl #16
270 mov r7, r7, lsr #16
271 orr r7, r7, ip, lsl #16
281 ldmfdeq sp!, {r4-r7}
288 mov r4, ip, lsr #16
291 orr r4, r4, ip, lsl #16
320 ldmfdeq sp!, {r4-r7}
336 ldmfd sp!, {r4-r7}
350 * Handle short copies (less than 16 bytes), possibly misaligned.
396 * 0000: dst is 32-bit aligned, src is 32-bit aligned
404 * 0001: dst is 32-bit aligned, src is 8-bit aligned
406 ldr r3, [r1, #-1] /* BE:r3 = x012 LE:r3 = 210x */
415 * 0010: dst is 32-bit aligned, src is 16-bit aligned
419 orr r3, r2, r3, lsl #16
425 * 0011: dst is 32-bit aligned, src is 8-bit aligned
427 ldr r3, [r1, #-3] /* BE:r3 = xxx0 LE:r3 = 0xxx */
436 * 0100: dst is 8-bit aligned, src is 32-bit aligned
448 * 0101: dst is 8-bit aligned, src is 8-bit aligned
460 * 0110: dst is 8-bit aligned, src is 16-bit aligned
474 * 0111: dst is 8-bit aligned, src is 8-bit aligned
486 * 1000: dst is 16-bit aligned, src is 32-bit aligned
490 mov r3, r2, lsr #16
496 * 1001: dst is 16-bit aligned, src is 8-bit aligned
498 ldr r2, [r1, #-1] /* BE:r2 = x012 LE:r2 = 210x */
509 * 1010: dst is 16-bit aligned, src is 16-bit aligned
519 * 1011: dst is 16-bit aligned, src is 8-bit aligned
522 ldr r2, [r1, #-3] /* BE:r2 = xxx0 LE:r2 = 0xxx */
532 * 1100: dst is 8-bit aligned, src is 32-bit aligned
544 * 1101: dst is 8-bit aligned, src is 8-bit aligned
556 * 1110: dst is 8-bit aligned, src is 16-bit aligned
570 * 1111: dst is 8-bit aligned, src is 8-bit aligned
596 * 0000: dst is 32-bit aligned, src is 32-bit aligned
606 * 0001: dst is 32-bit aligned, src is 8-bit aligned
608 ldr r2, [r1, #-1] /* BE:r2 = x012 LE:r2 = 210x */
619 * 0010: dst is 32-bit aligned, src is 16-bit aligned
623 mov r1, r3, lsr #16 /* r1 = ..54 */
624 orr r2, r2, r3, lsl #16 /* r2 = 3210 */
631 * 0011: dst is 32-bit aligned, src is 8-bit aligned
633 ldr r2, [r1, #-3] /* BE:r2 = xxx0 LE:r2 = 0xxx */
646 * 0100: dst is 8-bit aligned, src is 32-bit aligned
662 * 0101: dst is 8-bit aligned, src is 8-bit aligned
676 * 0110: dst is 8-bit aligned, src is 16-bit aligned
692 * 0111: dst is 8-bit aligned, src is 8-bit aligned
706 * 1000: dst is 16-bit aligned, src is 32-bit aligned
710 mov r2, r2, lsl #16 /* r2 = 54.. */
711 orr r2, r2, r3, lsr #16 /* r2 = 5432 */
718 * 1001: dst is 16-bit aligned, src is 8-bit aligned
720 ldr r3, [r1, #-1] /* BE:r3 = x012 LE:r3 = 210x */
731 * 1010: dst is 16-bit aligned, src is 16-bit aligned
741 * 1011: dst is 16-bit aligned, src is 8-bit aligned
755 * 1100: dst is 8-bit aligned, src is 32-bit aligned
769 * 1101: dst is 8-bit aligned, src is 8-bit aligned
783 * 1110: dst is 8-bit aligned, src is 16-bit aligned
797 * 1111: dst is 8-bit aligned, src is 8-bit aligned
823 * 0000: dst is 32-bit aligned, src is 32-bit aligned
833 * 0001: dst is 32-bit aligned, src is 8-bit aligned
835 ldr r3, [r1, #-1] /* BE:r3 = x012 LE:r3 = 210x */
848 * 0010: dst is 32-bit aligned, src is 16-bit aligned
853 orr r2, r2, r3, lsl #16 /* r2 = 3210 */
854 mov r3, r3, lsr #16 /* r3 = ..54 */
855 orr r3, r3, r1, lsl #16 /* r3 = 7654 */
862 * 0011: dst is 32-bit aligned, src is 8-bit aligned
876 * 0100: dst is 8-bit aligned, src is 32-bit aligned
892 * 0101: dst is 8-bit aligned, src is 8-bit aligned
906 * 0110: dst is 8-bit aligned, src is 16-bit aligned
924 * 0111: dst is 8-bit aligned, src is 8-bit aligned
931 mov r3, ip, lsr #16 /* BE:r3 = ..12 LE:r3 = ..43 */
933 orr r2, r3, r2, lsl #16 /* r2 = 6543 */
940 * 1000: dst is 16-bit aligned, src is 32-bit aligned
944 mov r1, r2, lsr #16 /* BE:r1 = ..01 LE:r1 = ..32 */
946 orr r2, r1, r3, lsl #16 /* r2 = 5432 */
947 mov r3, r3, lsr #16 /* r3 = ..76 */
954 * 1001: dst is 16-bit aligned, src is 8-bit aligned
956 ldr r2, [r1, #-1] /* BE:r2 = x012 LE:r2 = 210x */
971 * 1010: dst is 16-bit aligned, src is 16-bit aligned
983 * 1011: dst is 16-bit aligned, src is 8-bit aligned
999 * 1100: dst is 8-bit aligned, src is 32-bit aligned
1015 * 1101: dst is 8-bit aligned, src is 8-bit aligned
1022 mov r3, ip, lsr #16 /* BE:r3 = ..34 LE:r3 = ..65 */
1024 orr r2, r2, ip, lsl #16 /* r2 = 4321 */
1031 * 1110: dst is 8-bit aligned, src is 16-bit aligned
1049 * 1111: dst is 8-bit aligned, src is 8-bit aligned
1076 * 0000: dst is 32-bit aligned, src is 32-bit aligned
1088 * 0001: dst is 32-bit aligned, src is 8-bit aligned
1093 ldr r1, [r1, #-1] /* BE:r1 = x012 LE:r1 = 210x */
1107 * 0010: dst is 32-bit aligned, src is 16-bit aligned
1113 orr r2, r2, r3, lsl #16 /* r2 = 3210 */
1115 mov r3, r3, lsr #16 /* r3 = ..54 */
1116 orr r3, r3, ip, lsl #16 /* r3 = 7654 */
1117 mov r1, r1, lsl #16 /* r1 = BA.. */
1118 orr r1, r1, ip, lsr #16 /* r1 = BA98 */
1125 * 0011: dst is 32-bit aligned, src is 8-bit aligned
1143 * 0100: dst is 8-bit aligned (byte 1), src is 32-bit aligned
1163 * 0101: dst is 8-bit aligned (byte 1), src is 8-bit aligned (byte 1)
1179 * 0110: dst is 8-bit aligned (byte 1), src is 16-bit aligned
1201 * 0111: dst is 8-bit aligned (byte 1), src is 8-bit aligned (byte 3)
1209 mov r3, r3, lsr #16 /* r3 = ..43 */
1210 orr r3, r3, ip, lsl #16 /* r3 = 6543 */
1211 mov ip, ip, lsr #16 /* ip = ..87 */
1212 orr ip, ip, r1, lsl #16 /* ip = A987 */
1213 mov r1, r1, lsr #16 /* r1 = ..xB */
1221 * 1000: dst is 16-bit aligned, src is 32-bit aligned
1226 mov r1, ip, lsr #16 /* BE:r1 = ..01 LE:r1 = ..32 */
1228 orr r1, r1, r3, lsl #16 /* r1 = 5432 */
1229 mov r3, r3, lsr #16 /* r3 = ..76 */
1230 orr r3, r3, r2, lsl #16 /* r3 = 9876 */
1231 mov r2, r2, lsr #16 /* r2 = ..BA */
1239 * 1001: dst is 16-bit aligned, src is 8-bit aligned (byte 1)
1241 ldr r2, [r1, #-1] /* BE:r2 = x012 LE:r2 = 210x */
1260 * 1010: dst is 16-bit aligned, src is 16-bit aligned
1274 * 1011: dst is 16-bit aligned, src is 8-bit aligned (byte 3)
1294 * 1100: dst is 8-bit aligned (byte 3), src is 32-bit aligned
1308 mov r1, r1, lsr #16 /* r1 = ...B */
1314 * 1101: dst is 8-bit aligned (byte 3), src is 8-bit aligned (byte 1)
1319 ldr r1, [r1, #-1] /* BE:r1 = x012 LE:r1 = 210x */
1321 mov r2, r3, lsr #16 /* r2 = ..A9 */
1323 mov r3, r3, lsl #16 /* r3 = 87.. */
1324 orr r3, r3, ip, lsr #16 /* r3 = 8765 */
1325 mov ip, ip, lsl #16 /* ip = 43.. */
1326 orr ip, ip, r1, lsr #16 /* ip = 4321 */
1335 * 1110: dst is 8-bit aligned (byte 3), src is 16-bit aligned
1357 * 1111: dst is 8-bit aligned (byte 3), src is 8-bit aligned (byte 3)
1373 .section .note.GNU-stack,"",%progbits