1 1.1 christos #include "arm_asm.h" 2 1.1 christos #include "arm_arch.h" 3 1.1 christos 4 1.1 christos .text 5 1.1 christos 6 1.1 christos 7 1.1 christos .hidden OPENSSL_armcap_P 8 1.1 christos .globl sha1_block_data_order 9 1.1 christos .type sha1_block_data_order,%function 10 1.1 christos .align 6 11 1.1 christos sha1_block_data_order: 12 1.1 christos #ifdef __ILP32__ 13 1.1 christos ldrsw x16,.LOPENSSL_armcap_P 14 1.1 christos #else 15 1.1 christos ldr x16,.LOPENSSL_armcap_P 16 1.1 christos #endif 17 1.1 christos adr x17,.LOPENSSL_armcap_P 18 1.1 christos add x16,x16,x17 19 1.1 christos ldr w16,[x16] 20 1.1 christos tst w16,#ARMV8_SHA1 21 1.1 christos b.ne .Lv8_entry 22 1.1 christos 23 1.1 christos stp x29,x30,[sp,#-96]! 24 1.1 christos add x29,sp,#0 25 1.1 christos stp x19,x20,[sp,#16] 26 1.1 christos stp x21,x22,[sp,#32] 27 1.1 christos stp x23,x24,[sp,#48] 28 1.1 christos stp x25,x26,[sp,#64] 29 1.1 christos stp x27,x28,[sp,#80] 30 1.1 christos 31 1.1 christos ldp w20,w21,[x0] 32 1.1 christos ldp w22,w23,[x0,#8] 33 1.1 christos ldr w24,[x0,#16] 34 1.1 christos 35 1.1 christos .Loop: 36 1.1 christos ldr x3,[x1],#64 37 1.1 christos movz w28,#0x7999 38 1.1 christos sub x2,x2,#1 39 1.1 christos movk w28,#0x5a82,lsl#16 40 1.1 christos #ifdef __ARMEB__ 41 1.1 christos ror x3,x3,#32 42 1.1 christos #else 43 1.1 christos rev32 x3,x3 44 1.1 christos #endif 45 1.1 christos add w24,w24,w28 // warm it up 46 1.1 christos add w24,w24,w3 47 1.1 christos lsr x4,x3,#32 48 1.1 christos ldr x5,[x1,#-56] 49 1.1 christos bic w25,w23,w21 50 1.1 christos and w26,w22,w21 51 1.1 christos ror w27,w20,#27 52 1.1 christos add w23,w23,w28 // future e+=K 53 1.1 christos orr w25,w25,w26 54 1.1 christos add w24,w24,w27 // e+=rot(a,5) 55 1.1 christos ror w21,w21,#2 56 1.1 christos add w23,w23,w4 // future e+=X[i] 57 1.1 christos add w24,w24,w25 // e+=F(b,c,d) 58 1.1 christos #ifdef __ARMEB__ 59 1.1 christos ror x5,x5,#32 60 1.1 christos #else 61 1.1 christos rev32 x5,x5 62 1.1 christos #endif 63 1.1 christos bic w25,w22,w20 64 1.1 christos and w26,w21,w20 65 1.1 christos ror w27,w24,#27 66 1.1 christos add w22,w22,w28 // future e+=K 67 1.1 christos orr w25,w25,w26 68 1.1 christos add w23,w23,w27 // e+=rot(a,5) 69 1.1 christos ror w20,w20,#2 70 1.1 christos add w22,w22,w5 // future e+=X[i] 71 1.1 christos add w23,w23,w25 // e+=F(b,c,d) 72 1.1 christos lsr x6,x5,#32 73 1.1 christos ldr x7,[x1,#-48] 74 1.1 christos bic w25,w21,w24 75 1.1 christos and w26,w20,w24 76 1.1 christos ror w27,w23,#27 77 1.1 christos add w21,w21,w28 // future e+=K 78 1.1 christos orr w25,w25,w26 79 1.1 christos add w22,w22,w27 // e+=rot(a,5) 80 1.1 christos ror w24,w24,#2 81 1.1 christos add w21,w21,w6 // future e+=X[i] 82 1.1 christos add w22,w22,w25 // e+=F(b,c,d) 83 1.1 christos #ifdef __ARMEB__ 84 1.1 christos ror x7,x7,#32 85 1.1 christos #else 86 1.1 christos rev32 x7,x7 87 1.1 christos #endif 88 1.1 christos bic w25,w20,w23 89 1.1 christos and w26,w24,w23 90 1.1 christos ror w27,w22,#27 91 1.1 christos add w20,w20,w28 // future e+=K 92 1.1 christos orr w25,w25,w26 93 1.1 christos add w21,w21,w27 // e+=rot(a,5) 94 1.1 christos ror w23,w23,#2 95 1.1 christos add w20,w20,w7 // future e+=X[i] 96 1.1 christos add w21,w21,w25 // e+=F(b,c,d) 97 1.1 christos lsr x8,x7,#32 98 1.1 christos ldr x9,[x1,#-40] 99 1.1 christos bic w25,w24,w22 100 1.1 christos and w26,w23,w22 101 1.1 christos ror w27,w21,#27 102 1.1 christos add w24,w24,w28 // future e+=K 103 1.1 christos orr w25,w25,w26 104 1.1 christos add w20,w20,w27 // e+=rot(a,5) 105 1.1 christos ror w22,w22,#2 106 1.1 christos add w24,w24,w8 // future e+=X[i] 107 1.1 christos add w20,w20,w25 // e+=F(b,c,d) 108 1.1 christos #ifdef __ARMEB__ 109 1.1 christos ror x9,x9,#32 110 1.1 christos #else 111 1.1 christos rev32 x9,x9 112 1.1 christos #endif 113 1.1 christos bic w25,w23,w21 114 1.1 christos and w26,w22,w21 115 1.1 christos ror w27,w20,#27 116 1.1 christos add w23,w23,w28 // future e+=K 117 1.1 christos orr w25,w25,w26 118 1.1 christos add w24,w24,w27 // e+=rot(a,5) 119 1.1 christos ror w21,w21,#2 120 1.1 christos add w23,w23,w9 // future e+=X[i] 121 1.1 christos add w24,w24,w25 // e+=F(b,c,d) 122 1.1 christos lsr x10,x9,#32 123 1.1 christos ldr x11,[x1,#-32] 124 1.1 christos bic w25,w22,w20 125 1.1 christos and w26,w21,w20 126 1.1 christos ror w27,w24,#27 127 1.1 christos add w22,w22,w28 // future e+=K 128 1.1 christos orr w25,w25,w26 129 1.1 christos add w23,w23,w27 // e+=rot(a,5) 130 1.1 christos ror w20,w20,#2 131 1.1 christos add w22,w22,w10 // future e+=X[i] 132 1.1 christos add w23,w23,w25 // e+=F(b,c,d) 133 1.1 christos #ifdef __ARMEB__ 134 1.1 christos ror x11,x11,#32 135 1.1 christos #else 136 1.1 christos rev32 x11,x11 137 1.1 christos #endif 138 1.1 christos bic w25,w21,w24 139 1.1 christos and w26,w20,w24 140 1.1 christos ror w27,w23,#27 141 1.1 christos add w21,w21,w28 // future e+=K 142 1.1 christos orr w25,w25,w26 143 1.1 christos add w22,w22,w27 // e+=rot(a,5) 144 1.1 christos ror w24,w24,#2 145 1.1 christos add w21,w21,w11 // future e+=X[i] 146 1.1 christos add w22,w22,w25 // e+=F(b,c,d) 147 1.1 christos lsr x12,x11,#32 148 1.1 christos ldr x13,[x1,#-24] 149 1.1 christos bic w25,w20,w23 150 1.1 christos and w26,w24,w23 151 1.1 christos ror w27,w22,#27 152 1.1 christos add w20,w20,w28 // future e+=K 153 1.1 christos orr w25,w25,w26 154 1.1 christos add w21,w21,w27 // e+=rot(a,5) 155 1.1 christos ror w23,w23,#2 156 1.1 christos add w20,w20,w12 // future e+=X[i] 157 1.1 christos add w21,w21,w25 // e+=F(b,c,d) 158 1.1 christos #ifdef __ARMEB__ 159 1.1 christos ror x13,x13,#32 160 1.1 christos #else 161 1.1 christos rev32 x13,x13 162 1.1 christos #endif 163 1.1 christos bic w25,w24,w22 164 1.1 christos and w26,w23,w22 165 1.1 christos ror w27,w21,#27 166 1.1 christos add w24,w24,w28 // future e+=K 167 1.1 christos orr w25,w25,w26 168 1.1 christos add w20,w20,w27 // e+=rot(a,5) 169 1.1 christos ror w22,w22,#2 170 1.1 christos add w24,w24,w13 // future e+=X[i] 171 1.1 christos add w20,w20,w25 // e+=F(b,c,d) 172 1.1 christos lsr x14,x13,#32 173 1.1 christos ldr x15,[x1,#-16] 174 1.1 christos bic w25,w23,w21 175 1.1 christos and w26,w22,w21 176 1.1 christos ror w27,w20,#27 177 1.1 christos add w23,w23,w28 // future e+=K 178 1.1 christos orr w25,w25,w26 179 1.1 christos add w24,w24,w27 // e+=rot(a,5) 180 1.1 christos ror w21,w21,#2 181 1.1 christos add w23,w23,w14 // future e+=X[i] 182 1.1 christos add w24,w24,w25 // e+=F(b,c,d) 183 1.1 christos #ifdef __ARMEB__ 184 1.1 christos ror x15,x15,#32 185 1.1 christos #else 186 1.1 christos rev32 x15,x15 187 1.1 christos #endif 188 1.1 christos bic w25,w22,w20 189 1.1 christos and w26,w21,w20 190 1.1 christos ror w27,w24,#27 191 1.1 christos add w22,w22,w28 // future e+=K 192 1.1 christos orr w25,w25,w26 193 1.1 christos add w23,w23,w27 // e+=rot(a,5) 194 1.1 christos ror w20,w20,#2 195 1.1 christos add w22,w22,w15 // future e+=X[i] 196 1.1 christos add w23,w23,w25 // e+=F(b,c,d) 197 1.1 christos lsr x16,x15,#32 198 1.1 christos ldr x17,[x1,#-8] 199 1.1 christos bic w25,w21,w24 200 1.1 christos and w26,w20,w24 201 1.1 christos ror w27,w23,#27 202 1.1 christos add w21,w21,w28 // future e+=K 203 1.1 christos orr w25,w25,w26 204 1.1 christos add w22,w22,w27 // e+=rot(a,5) 205 1.1 christos ror w24,w24,#2 206 1.1 christos add w21,w21,w16 // future e+=X[i] 207 1.1 christos add w22,w22,w25 // e+=F(b,c,d) 208 1.1 christos #ifdef __ARMEB__ 209 1.1 christos ror x17,x17,#32 210 1.1 christos #else 211 1.1 christos rev32 x17,x17 212 1.1 christos #endif 213 1.1 christos bic w25,w20,w23 214 1.1 christos and w26,w24,w23 215 1.1 christos ror w27,w22,#27 216 1.1 christos add w20,w20,w28 // future e+=K 217 1.1 christos orr w25,w25,w26 218 1.1 christos add w21,w21,w27 // e+=rot(a,5) 219 1.1 christos ror w23,w23,#2 220 1.1 christos add w20,w20,w17 // future e+=X[i] 221 1.1 christos add w21,w21,w25 // e+=F(b,c,d) 222 1.1 christos lsr x19,x17,#32 223 1.1 christos eor w3,w3,w5 224 1.1 christos bic w25,w24,w22 225 1.1 christos and w26,w23,w22 226 1.1 christos ror w27,w21,#27 227 1.1 christos eor w3,w3,w11 228 1.1 christos add w24,w24,w28 // future e+=K 229 1.1 christos orr w25,w25,w26 230 1.1 christos add w20,w20,w27 // e+=rot(a,5) 231 1.1 christos eor w3,w3,w16 232 1.1 christos ror w22,w22,#2 233 1.1 christos add w24,w24,w19 // future e+=X[i] 234 1.1 christos add w20,w20,w25 // e+=F(b,c,d) 235 1.1 christos ror w3,w3,#31 236 1.1 christos eor w4,w4,w6 237 1.1 christos bic w25,w23,w21 238 1.1 christos and w26,w22,w21 239 1.1 christos ror w27,w20,#27 240 1.1 christos eor w4,w4,w12 241 1.1 christos add w23,w23,w28 // future e+=K 242 1.1 christos orr w25,w25,w26 243 1.1 christos add w24,w24,w27 // e+=rot(a,5) 244 1.1 christos eor w4,w4,w17 245 1.1 christos ror w21,w21,#2 246 1.1 christos add w23,w23,w3 // future e+=X[i] 247 1.1 christos add w24,w24,w25 // e+=F(b,c,d) 248 1.1 christos ror w4,w4,#31 249 1.1 christos eor w5,w5,w7 250 1.1 christos bic w25,w22,w20 251 1.1 christos and w26,w21,w20 252 1.1 christos ror w27,w24,#27 253 1.1 christos eor w5,w5,w13 254 1.1 christos add w22,w22,w28 // future e+=K 255 1.1 christos orr w25,w25,w26 256 1.1 christos add w23,w23,w27 // e+=rot(a,5) 257 1.1 christos eor w5,w5,w19 258 1.1 christos ror w20,w20,#2 259 1.1 christos add w22,w22,w4 // future e+=X[i] 260 1.1 christos add w23,w23,w25 // e+=F(b,c,d) 261 1.1 christos ror w5,w5,#31 262 1.1 christos eor w6,w6,w8 263 1.1 christos bic w25,w21,w24 264 1.1 christos and w26,w20,w24 265 1.1 christos ror w27,w23,#27 266 1.1 christos eor w6,w6,w14 267 1.1 christos add w21,w21,w28 // future e+=K 268 1.1 christos orr w25,w25,w26 269 1.1 christos add w22,w22,w27 // e+=rot(a,5) 270 1.1 christos eor w6,w6,w3 271 1.1 christos ror w24,w24,#2 272 1.1 christos add w21,w21,w5 // future e+=X[i] 273 1.1 christos add w22,w22,w25 // e+=F(b,c,d) 274 1.1 christos ror w6,w6,#31 275 1.1 christos eor w7,w7,w9 276 1.1 christos bic w25,w20,w23 277 1.1 christos and w26,w24,w23 278 1.1 christos ror w27,w22,#27 279 1.1 christos eor w7,w7,w15 280 1.1 christos add w20,w20,w28 // future e+=K 281 1.1 christos orr w25,w25,w26 282 1.1 christos add w21,w21,w27 // e+=rot(a,5) 283 1.1 christos eor w7,w7,w4 284 1.1 christos ror w23,w23,#2 285 1.1 christos add w20,w20,w6 // future e+=X[i] 286 1.1 christos add w21,w21,w25 // e+=F(b,c,d) 287 1.1 christos ror w7,w7,#31 288 1.1 christos movz w28,#0xeba1 289 1.1 christos movk w28,#0x6ed9,lsl#16 290 1.1 christos eor w8,w8,w10 291 1.1 christos bic w25,w24,w22 292 1.1 christos and w26,w23,w22 293 1.1 christos ror w27,w21,#27 294 1.1 christos eor w8,w8,w16 295 1.1 christos add w24,w24,w28 // future e+=K 296 1.1 christos orr w25,w25,w26 297 1.1 christos add w20,w20,w27 // e+=rot(a,5) 298 1.1 christos eor w8,w8,w5 299 1.1 christos ror w22,w22,#2 300 1.1 christos add w24,w24,w7 // future e+=X[i] 301 1.1 christos add w20,w20,w25 // e+=F(b,c,d) 302 1.1 christos ror w8,w8,#31 303 1.1 christos eor w9,w9,w11 304 1.1 christos eor w25,w23,w21 305 1.1 christos ror w27,w20,#27 306 1.1 christos add w23,w23,w28 // future e+=K 307 1.1 christos eor w9,w9,w17 308 1.1 christos eor w25,w25,w22 309 1.1 christos add w24,w24,w27 // e+=rot(a,5) 310 1.1 christos ror w21,w21,#2 311 1.1 christos eor w9,w9,w6 312 1.1 christos add w23,w23,w8 // future e+=X[i] 313 1.1 christos add w24,w24,w25 // e+=F(b,c,d) 314 1.1 christos ror w9,w9,#31 315 1.1 christos eor w10,w10,w12 316 1.1 christos eor w25,w22,w20 317 1.1 christos ror w27,w24,#27 318 1.1 christos add w22,w22,w28 // future e+=K 319 1.1 christos eor w10,w10,w19 320 1.1 christos eor w25,w25,w21 321 1.1 christos add w23,w23,w27 // e+=rot(a,5) 322 1.1 christos ror w20,w20,#2 323 1.1 christos eor w10,w10,w7 324 1.1 christos add w22,w22,w9 // future e+=X[i] 325 1.1 christos add w23,w23,w25 // e+=F(b,c,d) 326 1.1 christos ror w10,w10,#31 327 1.1 christos eor w11,w11,w13 328 1.1 christos eor w25,w21,w24 329 1.1 christos ror w27,w23,#27 330 1.1 christos add w21,w21,w28 // future e+=K 331 1.1 christos eor w11,w11,w3 332 1.1 christos eor w25,w25,w20 333 1.1 christos add w22,w22,w27 // e+=rot(a,5) 334 1.1 christos ror w24,w24,#2 335 1.1 christos eor w11,w11,w8 336 1.1 christos add w21,w21,w10 // future e+=X[i] 337 1.1 christos add w22,w22,w25 // e+=F(b,c,d) 338 1.1 christos ror w11,w11,#31 339 1.1 christos eor w12,w12,w14 340 1.1 christos eor w25,w20,w23 341 1.1 christos ror w27,w22,#27 342 1.1 christos add w20,w20,w28 // future e+=K 343 1.1 christos eor w12,w12,w4 344 1.1 christos eor w25,w25,w24 345 1.1 christos add w21,w21,w27 // e+=rot(a,5) 346 1.1 christos ror w23,w23,#2 347 1.1 christos eor w12,w12,w9 348 1.1 christos add w20,w20,w11 // future e+=X[i] 349 1.1 christos add w21,w21,w25 // e+=F(b,c,d) 350 1.1 christos ror w12,w12,#31 351 1.1 christos eor w13,w13,w15 352 1.1 christos eor w25,w24,w22 353 1.1 christos ror w27,w21,#27 354 1.1 christos add w24,w24,w28 // future e+=K 355 1.1 christos eor w13,w13,w5 356 1.1 christos eor w25,w25,w23 357 1.1 christos add w20,w20,w27 // e+=rot(a,5) 358 1.1 christos ror w22,w22,#2 359 1.1 christos eor w13,w13,w10 360 1.1 christos add w24,w24,w12 // future e+=X[i] 361 1.1 christos add w20,w20,w25 // e+=F(b,c,d) 362 1.1 christos ror w13,w13,#31 363 1.1 christos eor w14,w14,w16 364 1.1 christos eor w25,w23,w21 365 1.1 christos ror w27,w20,#27 366 1.1 christos add w23,w23,w28 // future e+=K 367 1.1 christos eor w14,w14,w6 368 1.1 christos eor w25,w25,w22 369 1.1 christos add w24,w24,w27 // e+=rot(a,5) 370 1.1 christos ror w21,w21,#2 371 1.1 christos eor w14,w14,w11 372 1.1 christos add w23,w23,w13 // future e+=X[i] 373 1.1 christos add w24,w24,w25 // e+=F(b,c,d) 374 1.1 christos ror w14,w14,#31 375 1.1 christos eor w15,w15,w17 376 1.1 christos eor w25,w22,w20 377 1.1 christos ror w27,w24,#27 378 1.1 christos add w22,w22,w28 // future e+=K 379 1.1 christos eor w15,w15,w7 380 1.1 christos eor w25,w25,w21 381 1.1 christos add w23,w23,w27 // e+=rot(a,5) 382 1.1 christos ror w20,w20,#2 383 1.1 christos eor w15,w15,w12 384 1.1 christos add w22,w22,w14 // future e+=X[i] 385 1.1 christos add w23,w23,w25 // e+=F(b,c,d) 386 1.1 christos ror w15,w15,#31 387 1.1 christos eor w16,w16,w19 388 1.1 christos eor w25,w21,w24 389 1.1 christos ror w27,w23,#27 390 1.1 christos add w21,w21,w28 // future e+=K 391 1.1 christos eor w16,w16,w8 392 1.1 christos eor w25,w25,w20 393 1.1 christos add w22,w22,w27 // e+=rot(a,5) 394 1.1 christos ror w24,w24,#2 395 1.1 christos eor w16,w16,w13 396 1.1 christos add w21,w21,w15 // future e+=X[i] 397 1.1 christos add w22,w22,w25 // e+=F(b,c,d) 398 1.1 christos ror w16,w16,#31 399 1.1 christos eor w17,w17,w3 400 1.1 christos eor w25,w20,w23 401 1.1 christos ror w27,w22,#27 402 1.1 christos add w20,w20,w28 // future e+=K 403 1.1 christos eor w17,w17,w9 404 1.1 christos eor w25,w25,w24 405 1.1 christos add w21,w21,w27 // e+=rot(a,5) 406 1.1 christos ror w23,w23,#2 407 1.1 christos eor w17,w17,w14 408 1.1 christos add w20,w20,w16 // future e+=X[i] 409 1.1 christos add w21,w21,w25 // e+=F(b,c,d) 410 1.1 christos ror w17,w17,#31 411 1.1 christos eor w19,w19,w4 412 1.1 christos eor w25,w24,w22 413 1.1 christos ror w27,w21,#27 414 1.1 christos add w24,w24,w28 // future e+=K 415 1.1 christos eor w19,w19,w10 416 1.1 christos eor w25,w25,w23 417 1.1 christos add w20,w20,w27 // e+=rot(a,5) 418 1.1 christos ror w22,w22,#2 419 1.1 christos eor w19,w19,w15 420 1.1 christos add w24,w24,w17 // future e+=X[i] 421 1.1 christos add w20,w20,w25 // e+=F(b,c,d) 422 1.1 christos ror w19,w19,#31 423 1.1 christos eor w3,w3,w5 424 1.1 christos eor w25,w23,w21 425 1.1 christos ror w27,w20,#27 426 1.1 christos add w23,w23,w28 // future e+=K 427 1.1 christos eor w3,w3,w11 428 1.1 christos eor w25,w25,w22 429 1.1 christos add w24,w24,w27 // e+=rot(a,5) 430 1.1 christos ror w21,w21,#2 431 1.1 christos eor w3,w3,w16 432 1.1 christos add w23,w23,w19 // future e+=X[i] 433 1.1 christos add w24,w24,w25 // e+=F(b,c,d) 434 1.1 christos ror w3,w3,#31 435 1.1 christos eor w4,w4,w6 436 1.1 christos eor w25,w22,w20 437 1.1 christos ror w27,w24,#27 438 1.1 christos add w22,w22,w28 // future e+=K 439 1.1 christos eor w4,w4,w12 440 1.1 christos eor w25,w25,w21 441 1.1 christos add w23,w23,w27 // e+=rot(a,5) 442 1.1 christos ror w20,w20,#2 443 1.1 christos eor w4,w4,w17 444 1.1 christos add w22,w22,w3 // future e+=X[i] 445 1.1 christos add w23,w23,w25 // e+=F(b,c,d) 446 1.1 christos ror w4,w4,#31 447 1.1 christos eor w5,w5,w7 448 1.1 christos eor w25,w21,w24 449 1.1 christos ror w27,w23,#27 450 1.1 christos add w21,w21,w28 // future e+=K 451 1.1 christos eor w5,w5,w13 452 1.1 christos eor w25,w25,w20 453 1.1 christos add w22,w22,w27 // e+=rot(a,5) 454 1.1 christos ror w24,w24,#2 455 1.1 christos eor w5,w5,w19 456 1.1 christos add w21,w21,w4 // future e+=X[i] 457 1.1 christos add w22,w22,w25 // e+=F(b,c,d) 458 1.1 christos ror w5,w5,#31 459 1.1 christos eor w6,w6,w8 460 1.1 christos eor w25,w20,w23 461 1.1 christos ror w27,w22,#27 462 1.1 christos add w20,w20,w28 // future e+=K 463 1.1 christos eor w6,w6,w14 464 1.1 christos eor w25,w25,w24 465 1.1 christos add w21,w21,w27 // e+=rot(a,5) 466 1.1 christos ror w23,w23,#2 467 1.1 christos eor w6,w6,w3 468 1.1 christos add w20,w20,w5 // future e+=X[i] 469 1.1 christos add w21,w21,w25 // e+=F(b,c,d) 470 1.1 christos ror w6,w6,#31 471 1.1 christos eor w7,w7,w9 472 1.1 christos eor w25,w24,w22 473 1.1 christos ror w27,w21,#27 474 1.1 christos add w24,w24,w28 // future e+=K 475 1.1 christos eor w7,w7,w15 476 1.1 christos eor w25,w25,w23 477 1.1 christos add w20,w20,w27 // e+=rot(a,5) 478 1.1 christos ror w22,w22,#2 479 1.1 christos eor w7,w7,w4 480 1.1 christos add w24,w24,w6 // future e+=X[i] 481 1.1 christos add w20,w20,w25 // e+=F(b,c,d) 482 1.1 christos ror w7,w7,#31 483 1.1 christos eor w8,w8,w10 484 1.1 christos eor w25,w23,w21 485 1.1 christos ror w27,w20,#27 486 1.1 christos add w23,w23,w28 // future e+=K 487 1.1 christos eor w8,w8,w16 488 1.1 christos eor w25,w25,w22 489 1.1 christos add w24,w24,w27 // e+=rot(a,5) 490 1.1 christos ror w21,w21,#2 491 1.1 christos eor w8,w8,w5 492 1.1 christos add w23,w23,w7 // future e+=X[i] 493 1.1 christos add w24,w24,w25 // e+=F(b,c,d) 494 1.1 christos ror w8,w8,#31 495 1.1 christos eor w9,w9,w11 496 1.1 christos eor w25,w22,w20 497 1.1 christos ror w27,w24,#27 498 1.1 christos add w22,w22,w28 // future e+=K 499 1.1 christos eor w9,w9,w17 500 1.1 christos eor w25,w25,w21 501 1.1 christos add w23,w23,w27 // e+=rot(a,5) 502 1.1 christos ror w20,w20,#2 503 1.1 christos eor w9,w9,w6 504 1.1 christos add w22,w22,w8 // future e+=X[i] 505 1.1 christos add w23,w23,w25 // e+=F(b,c,d) 506 1.1 christos ror w9,w9,#31 507 1.1 christos eor w10,w10,w12 508 1.1 christos eor w25,w21,w24 509 1.1 christos ror w27,w23,#27 510 1.1 christos add w21,w21,w28 // future e+=K 511 1.1 christos eor w10,w10,w19 512 1.1 christos eor w25,w25,w20 513 1.1 christos add w22,w22,w27 // e+=rot(a,5) 514 1.1 christos ror w24,w24,#2 515 1.1 christos eor w10,w10,w7 516 1.1 christos add w21,w21,w9 // future e+=X[i] 517 1.1 christos add w22,w22,w25 // e+=F(b,c,d) 518 1.1 christos ror w10,w10,#31 519 1.1 christos eor w11,w11,w13 520 1.1 christos eor w25,w20,w23 521 1.1 christos ror w27,w22,#27 522 1.1 christos add w20,w20,w28 // future e+=K 523 1.1 christos eor w11,w11,w3 524 1.1 christos eor w25,w25,w24 525 1.1 christos add w21,w21,w27 // e+=rot(a,5) 526 1.1 christos ror w23,w23,#2 527 1.1 christos eor w11,w11,w8 528 1.1 christos add w20,w20,w10 // future e+=X[i] 529 1.1 christos add w21,w21,w25 // e+=F(b,c,d) 530 1.1 christos ror w11,w11,#31 531 1.1 christos movz w28,#0xbcdc 532 1.1 christos movk w28,#0x8f1b,lsl#16 533 1.1 christos eor w12,w12,w14 534 1.1 christos eor w25,w24,w22 535 1.1 christos ror w27,w21,#27 536 1.1 christos add w24,w24,w28 // future e+=K 537 1.1 christos eor w12,w12,w4 538 1.1 christos eor w25,w25,w23 539 1.1 christos add w20,w20,w27 // e+=rot(a,5) 540 1.1 christos ror w22,w22,#2 541 1.1 christos eor w12,w12,w9 542 1.1 christos add w24,w24,w11 // future e+=X[i] 543 1.1 christos add w20,w20,w25 // e+=F(b,c,d) 544 1.1 christos ror w12,w12,#31 545 1.1 christos orr w25,w21,w22 546 1.1 christos and w26,w21,w22 547 1.1 christos eor w13,w13,w15 548 1.1 christos ror w27,w20,#27 549 1.1 christos and w25,w25,w23 550 1.1 christos add w23,w23,w28 // future e+=K 551 1.1 christos eor w13,w13,w5 552 1.1 christos add w24,w24,w27 // e+=rot(a,5) 553 1.1 christos orr w25,w25,w26 554 1.1 christos ror w21,w21,#2 555 1.1 christos eor w13,w13,w10 556 1.1 christos add w23,w23,w12 // future e+=X[i] 557 1.1 christos add w24,w24,w25 // e+=F(b,c,d) 558 1.1 christos ror w13,w13,#31 559 1.1 christos orr w25,w20,w21 560 1.1 christos and w26,w20,w21 561 1.1 christos eor w14,w14,w16 562 1.1 christos ror w27,w24,#27 563 1.1 christos and w25,w25,w22 564 1.1 christos add w22,w22,w28 // future e+=K 565 1.1 christos eor w14,w14,w6 566 1.1 christos add w23,w23,w27 // e+=rot(a,5) 567 1.1 christos orr w25,w25,w26 568 1.1 christos ror w20,w20,#2 569 1.1 christos eor w14,w14,w11 570 1.1 christos add w22,w22,w13 // future e+=X[i] 571 1.1 christos add w23,w23,w25 // e+=F(b,c,d) 572 1.1 christos ror w14,w14,#31 573 1.1 christos orr w25,w24,w20 574 1.1 christos and w26,w24,w20 575 1.1 christos eor w15,w15,w17 576 1.1 christos ror w27,w23,#27 577 1.1 christos and w25,w25,w21 578 1.1 christos add w21,w21,w28 // future e+=K 579 1.1 christos eor w15,w15,w7 580 1.1 christos add w22,w22,w27 // e+=rot(a,5) 581 1.1 christos orr w25,w25,w26 582 1.1 christos ror w24,w24,#2 583 1.1 christos eor w15,w15,w12 584 1.1 christos add w21,w21,w14 // future e+=X[i] 585 1.1 christos add w22,w22,w25 // e+=F(b,c,d) 586 1.1 christos ror w15,w15,#31 587 1.1 christos orr w25,w23,w24 588 1.1 christos and w26,w23,w24 589 1.1 christos eor w16,w16,w19 590 1.1 christos ror w27,w22,#27 591 1.1 christos and w25,w25,w20 592 1.1 christos add w20,w20,w28 // future e+=K 593 1.1 christos eor w16,w16,w8 594 1.1 christos add w21,w21,w27 // e+=rot(a,5) 595 1.1 christos orr w25,w25,w26 596 1.1 christos ror w23,w23,#2 597 1.1 christos eor w16,w16,w13 598 1.1 christos add w20,w20,w15 // future e+=X[i] 599 1.1 christos add w21,w21,w25 // e+=F(b,c,d) 600 1.1 christos ror w16,w16,#31 601 1.1 christos orr w25,w22,w23 602 1.1 christos and w26,w22,w23 603 1.1 christos eor w17,w17,w3 604 1.1 christos ror w27,w21,#27 605 1.1 christos and w25,w25,w24 606 1.1 christos add w24,w24,w28 // future e+=K 607 1.1 christos eor w17,w17,w9 608 1.1 christos add w20,w20,w27 // e+=rot(a,5) 609 1.1 christos orr w25,w25,w26 610 1.1 christos ror w22,w22,#2 611 1.1 christos eor w17,w17,w14 612 1.1 christos add w24,w24,w16 // future e+=X[i] 613 1.1 christos add w20,w20,w25 // e+=F(b,c,d) 614 1.1 christos ror w17,w17,#31 615 1.1 christos orr w25,w21,w22 616 1.1 christos and w26,w21,w22 617 1.1 christos eor w19,w19,w4 618 1.1 christos ror w27,w20,#27 619 1.1 christos and w25,w25,w23 620 1.1 christos add w23,w23,w28 // future e+=K 621 1.1 christos eor w19,w19,w10 622 1.1 christos add w24,w24,w27 // e+=rot(a,5) 623 1.1 christos orr w25,w25,w26 624 1.1 christos ror w21,w21,#2 625 1.1 christos eor w19,w19,w15 626 1.1 christos add w23,w23,w17 // future e+=X[i] 627 1.1 christos add w24,w24,w25 // e+=F(b,c,d) 628 1.1 christos ror w19,w19,#31 629 1.1 christos orr w25,w20,w21 630 1.1 christos and w26,w20,w21 631 1.1 christos eor w3,w3,w5 632 1.1 christos ror w27,w24,#27 633 1.1 christos and w25,w25,w22 634 1.1 christos add w22,w22,w28 // future e+=K 635 1.1 christos eor w3,w3,w11 636 1.1 christos add w23,w23,w27 // e+=rot(a,5) 637 1.1 christos orr w25,w25,w26 638 1.1 christos ror w20,w20,#2 639 1.1 christos eor w3,w3,w16 640 1.1 christos add w22,w22,w19 // future e+=X[i] 641 1.1 christos add w23,w23,w25 // e+=F(b,c,d) 642 1.1 christos ror w3,w3,#31 643 1.1 christos orr w25,w24,w20 644 1.1 christos and w26,w24,w20 645 1.1 christos eor w4,w4,w6 646 1.1 christos ror w27,w23,#27 647 1.1 christos and w25,w25,w21 648 1.1 christos add w21,w21,w28 // future e+=K 649 1.1 christos eor w4,w4,w12 650 1.1 christos add w22,w22,w27 // e+=rot(a,5) 651 1.1 christos orr w25,w25,w26 652 1.1 christos ror w24,w24,#2 653 1.1 christos eor w4,w4,w17 654 1.1 christos add w21,w21,w3 // future e+=X[i] 655 1.1 christos add w22,w22,w25 // e+=F(b,c,d) 656 1.1 christos ror w4,w4,#31 657 1.1 christos orr w25,w23,w24 658 1.1 christos and w26,w23,w24 659 1.1 christos eor w5,w5,w7 660 1.1 christos ror w27,w22,#27 661 1.1 christos and w25,w25,w20 662 1.1 christos add w20,w20,w28 // future e+=K 663 1.1 christos eor w5,w5,w13 664 1.1 christos add w21,w21,w27 // e+=rot(a,5) 665 1.1 christos orr w25,w25,w26 666 1.1 christos ror w23,w23,#2 667 1.1 christos eor w5,w5,w19 668 1.1 christos add w20,w20,w4 // future e+=X[i] 669 1.1 christos add w21,w21,w25 // e+=F(b,c,d) 670 1.1 christos ror w5,w5,#31 671 1.1 christos orr w25,w22,w23 672 1.1 christos and w26,w22,w23 673 1.1 christos eor w6,w6,w8 674 1.1 christos ror w27,w21,#27 675 1.1 christos and w25,w25,w24 676 1.1 christos add w24,w24,w28 // future e+=K 677 1.1 christos eor w6,w6,w14 678 1.1 christos add w20,w20,w27 // e+=rot(a,5) 679 1.1 christos orr w25,w25,w26 680 1.1 christos ror w22,w22,#2 681 1.1 christos eor w6,w6,w3 682 1.1 christos add w24,w24,w5 // future e+=X[i] 683 1.1 christos add w20,w20,w25 // e+=F(b,c,d) 684 1.1 christos ror w6,w6,#31 685 1.1 christos orr w25,w21,w22 686 1.1 christos and w26,w21,w22 687 1.1 christos eor w7,w7,w9 688 1.1 christos ror w27,w20,#27 689 1.1 christos and w25,w25,w23 690 1.1 christos add w23,w23,w28 // future e+=K 691 1.1 christos eor w7,w7,w15 692 1.1 christos add w24,w24,w27 // e+=rot(a,5) 693 1.1 christos orr w25,w25,w26 694 1.1 christos ror w21,w21,#2 695 1.1 christos eor w7,w7,w4 696 1.1 christos add w23,w23,w6 // future e+=X[i] 697 1.1 christos add w24,w24,w25 // e+=F(b,c,d) 698 1.1 christos ror w7,w7,#31 699 1.1 christos orr w25,w20,w21 700 1.1 christos and w26,w20,w21 701 1.1 christos eor w8,w8,w10 702 1.1 christos ror w27,w24,#27 703 1.1 christos and w25,w25,w22 704 1.1 christos add w22,w22,w28 // future e+=K 705 1.1 christos eor w8,w8,w16 706 1.1 christos add w23,w23,w27 // e+=rot(a,5) 707 1.1 christos orr w25,w25,w26 708 1.1 christos ror w20,w20,#2 709 1.1 christos eor w8,w8,w5 710 1.1 christos add w22,w22,w7 // future e+=X[i] 711 1.1 christos add w23,w23,w25 // e+=F(b,c,d) 712 1.1 christos ror w8,w8,#31 713 1.1 christos orr w25,w24,w20 714 1.1 christos and w26,w24,w20 715 1.1 christos eor w9,w9,w11 716 1.1 christos ror w27,w23,#27 717 1.1 christos and w25,w25,w21 718 1.1 christos add w21,w21,w28 // future e+=K 719 1.1 christos eor w9,w9,w17 720 1.1 christos add w22,w22,w27 // e+=rot(a,5) 721 1.1 christos orr w25,w25,w26 722 1.1 christos ror w24,w24,#2 723 1.1 christos eor w9,w9,w6 724 1.1 christos add w21,w21,w8 // future e+=X[i] 725 1.1 christos add w22,w22,w25 // e+=F(b,c,d) 726 1.1 christos ror w9,w9,#31 727 1.1 christos orr w25,w23,w24 728 1.1 christos and w26,w23,w24 729 1.1 christos eor w10,w10,w12 730 1.1 christos ror w27,w22,#27 731 1.1 christos and w25,w25,w20 732 1.1 christos add w20,w20,w28 // future e+=K 733 1.1 christos eor w10,w10,w19 734 1.1 christos add w21,w21,w27 // e+=rot(a,5) 735 1.1 christos orr w25,w25,w26 736 1.1 christos ror w23,w23,#2 737 1.1 christos eor w10,w10,w7 738 1.1 christos add w20,w20,w9 // future e+=X[i] 739 1.1 christos add w21,w21,w25 // e+=F(b,c,d) 740 1.1 christos ror w10,w10,#31 741 1.1 christos orr w25,w22,w23 742 1.1 christos and w26,w22,w23 743 1.1 christos eor w11,w11,w13 744 1.1 christos ror w27,w21,#27 745 1.1 christos and w25,w25,w24 746 1.1 christos add w24,w24,w28 // future e+=K 747 1.1 christos eor w11,w11,w3 748 1.1 christos add w20,w20,w27 // e+=rot(a,5) 749 1.1 christos orr w25,w25,w26 750 1.1 christos ror w22,w22,#2 751 1.1 christos eor w11,w11,w8 752 1.1 christos add w24,w24,w10 // future e+=X[i] 753 1.1 christos add w20,w20,w25 // e+=F(b,c,d) 754 1.1 christos ror w11,w11,#31 755 1.1 christos orr w25,w21,w22 756 1.1 christos and w26,w21,w22 757 1.1 christos eor w12,w12,w14 758 1.1 christos ror w27,w20,#27 759 1.1 christos and w25,w25,w23 760 1.1 christos add w23,w23,w28 // future e+=K 761 1.1 christos eor w12,w12,w4 762 1.1 christos add w24,w24,w27 // e+=rot(a,5) 763 1.1 christos orr w25,w25,w26 764 1.1 christos ror w21,w21,#2 765 1.1 christos eor w12,w12,w9 766 1.1 christos add w23,w23,w11 // future e+=X[i] 767 1.1 christos add w24,w24,w25 // e+=F(b,c,d) 768 1.1 christos ror w12,w12,#31 769 1.1 christos orr w25,w20,w21 770 1.1 christos and w26,w20,w21 771 1.1 christos eor w13,w13,w15 772 1.1 christos ror w27,w24,#27 773 1.1 christos and w25,w25,w22 774 1.1 christos add w22,w22,w28 // future e+=K 775 1.1 christos eor w13,w13,w5 776 1.1 christos add w23,w23,w27 // e+=rot(a,5) 777 1.1 christos orr w25,w25,w26 778 1.1 christos ror w20,w20,#2 779 1.1 christos eor w13,w13,w10 780 1.1 christos add w22,w22,w12 // future e+=X[i] 781 1.1 christos add w23,w23,w25 // e+=F(b,c,d) 782 1.1 christos ror w13,w13,#31 783 1.1 christos orr w25,w24,w20 784 1.1 christos and w26,w24,w20 785 1.1 christos eor w14,w14,w16 786 1.1 christos ror w27,w23,#27 787 1.1 christos and w25,w25,w21 788 1.1 christos add w21,w21,w28 // future e+=K 789 1.1 christos eor w14,w14,w6 790 1.1 christos add w22,w22,w27 // e+=rot(a,5) 791 1.1 christos orr w25,w25,w26 792 1.1 christos ror w24,w24,#2 793 1.1 christos eor w14,w14,w11 794 1.1 christos add w21,w21,w13 // future e+=X[i] 795 1.1 christos add w22,w22,w25 // e+=F(b,c,d) 796 1.1 christos ror w14,w14,#31 797 1.1 christos orr w25,w23,w24 798 1.1 christos and w26,w23,w24 799 1.1 christos eor w15,w15,w17 800 1.1 christos ror w27,w22,#27 801 1.1 christos and w25,w25,w20 802 1.1 christos add w20,w20,w28 // future e+=K 803 1.1 christos eor w15,w15,w7 804 1.1 christos add w21,w21,w27 // e+=rot(a,5) 805 1.1 christos orr w25,w25,w26 806 1.1 christos ror w23,w23,#2 807 1.1 christos eor w15,w15,w12 808 1.1 christos add w20,w20,w14 // future e+=X[i] 809 1.1 christos add w21,w21,w25 // e+=F(b,c,d) 810 1.1 christos ror w15,w15,#31 811 1.1 christos movz w28,#0xc1d6 812 1.1 christos movk w28,#0xca62,lsl#16 813 1.1 christos orr w25,w22,w23 814 1.1 christos and w26,w22,w23 815 1.1 christos eor w16,w16,w19 816 1.1 christos ror w27,w21,#27 817 1.1 christos and w25,w25,w24 818 1.1 christos add w24,w24,w28 // future e+=K 819 1.1 christos eor w16,w16,w8 820 1.1 christos add w20,w20,w27 // e+=rot(a,5) 821 1.1 christos orr w25,w25,w26 822 1.1 christos ror w22,w22,#2 823 1.1 christos eor w16,w16,w13 824 1.1 christos add w24,w24,w15 // future e+=X[i] 825 1.1 christos add w20,w20,w25 // e+=F(b,c,d) 826 1.1 christos ror w16,w16,#31 827 1.1 christos eor w17,w17,w3 828 1.1 christos eor w25,w23,w21 829 1.1 christos ror w27,w20,#27 830 1.1 christos add w23,w23,w28 // future e+=K 831 1.1 christos eor w17,w17,w9 832 1.1 christos eor w25,w25,w22 833 1.1 christos add w24,w24,w27 // e+=rot(a,5) 834 1.1 christos ror w21,w21,#2 835 1.1 christos eor w17,w17,w14 836 1.1 christos add w23,w23,w16 // future e+=X[i] 837 1.1 christos add w24,w24,w25 // e+=F(b,c,d) 838 1.1 christos ror w17,w17,#31 839 1.1 christos eor w19,w19,w4 840 1.1 christos eor w25,w22,w20 841 1.1 christos ror w27,w24,#27 842 1.1 christos add w22,w22,w28 // future e+=K 843 1.1 christos eor w19,w19,w10 844 1.1 christos eor w25,w25,w21 845 1.1 christos add w23,w23,w27 // e+=rot(a,5) 846 1.1 christos ror w20,w20,#2 847 1.1 christos eor w19,w19,w15 848 1.1 christos add w22,w22,w17 // future e+=X[i] 849 1.1 christos add w23,w23,w25 // e+=F(b,c,d) 850 1.1 christos ror w19,w19,#31 851 1.1 christos eor w3,w3,w5 852 1.1 christos eor w25,w21,w24 853 1.1 christos ror w27,w23,#27 854 1.1 christos add w21,w21,w28 // future e+=K 855 1.1 christos eor w3,w3,w11 856 1.1 christos eor w25,w25,w20 857 1.1 christos add w22,w22,w27 // e+=rot(a,5) 858 1.1 christos ror w24,w24,#2 859 1.1 christos eor w3,w3,w16 860 1.1 christos add w21,w21,w19 // future e+=X[i] 861 1.1 christos add w22,w22,w25 // e+=F(b,c,d) 862 1.1 christos ror w3,w3,#31 863 1.1 christos eor w4,w4,w6 864 1.1 christos eor w25,w20,w23 865 1.1 christos ror w27,w22,#27 866 1.1 christos add w20,w20,w28 // future e+=K 867 1.1 christos eor w4,w4,w12 868 1.1 christos eor w25,w25,w24 869 1.1 christos add w21,w21,w27 // e+=rot(a,5) 870 1.1 christos ror w23,w23,#2 871 1.1 christos eor w4,w4,w17 872 1.1 christos add w20,w20,w3 // future e+=X[i] 873 1.1 christos add w21,w21,w25 // e+=F(b,c,d) 874 1.1 christos ror w4,w4,#31 875 1.1 christos eor w5,w5,w7 876 1.1 christos eor w25,w24,w22 877 1.1 christos ror w27,w21,#27 878 1.1 christos add w24,w24,w28 // future e+=K 879 1.1 christos eor w5,w5,w13 880 1.1 christos eor w25,w25,w23 881 1.1 christos add w20,w20,w27 // e+=rot(a,5) 882 1.1 christos ror w22,w22,#2 883 1.1 christos eor w5,w5,w19 884 1.1 christos add w24,w24,w4 // future e+=X[i] 885 1.1 christos add w20,w20,w25 // e+=F(b,c,d) 886 1.1 christos ror w5,w5,#31 887 1.1 christos eor w6,w6,w8 888 1.1 christos eor w25,w23,w21 889 1.1 christos ror w27,w20,#27 890 1.1 christos add w23,w23,w28 // future e+=K 891 1.1 christos eor w6,w6,w14 892 1.1 christos eor w25,w25,w22 893 1.1 christos add w24,w24,w27 // e+=rot(a,5) 894 1.1 christos ror w21,w21,#2 895 1.1 christos eor w6,w6,w3 896 1.1 christos add w23,w23,w5 // future e+=X[i] 897 1.1 christos add w24,w24,w25 // e+=F(b,c,d) 898 1.1 christos ror w6,w6,#31 899 1.1 christos eor w7,w7,w9 900 1.1 christos eor w25,w22,w20 901 1.1 christos ror w27,w24,#27 902 1.1 christos add w22,w22,w28 // future e+=K 903 1.1 christos eor w7,w7,w15 904 1.1 christos eor w25,w25,w21 905 1.1 christos add w23,w23,w27 // e+=rot(a,5) 906 1.1 christos ror w20,w20,#2 907 1.1 christos eor w7,w7,w4 908 1.1 christos add w22,w22,w6 // future e+=X[i] 909 1.1 christos add w23,w23,w25 // e+=F(b,c,d) 910 1.1 christos ror w7,w7,#31 911 1.1 christos eor w8,w8,w10 912 1.1 christos eor w25,w21,w24 913 1.1 christos ror w27,w23,#27 914 1.1 christos add w21,w21,w28 // future e+=K 915 1.1 christos eor w8,w8,w16 916 1.1 christos eor w25,w25,w20 917 1.1 christos add w22,w22,w27 // e+=rot(a,5) 918 1.1 christos ror w24,w24,#2 919 1.1 christos eor w8,w8,w5 920 1.1 christos add w21,w21,w7 // future e+=X[i] 921 1.1 christos add w22,w22,w25 // e+=F(b,c,d) 922 1.1 christos ror w8,w8,#31 923 1.1 christos eor w9,w9,w11 924 1.1 christos eor w25,w20,w23 925 1.1 christos ror w27,w22,#27 926 1.1 christos add w20,w20,w28 // future e+=K 927 1.1 christos eor w9,w9,w17 928 1.1 christos eor w25,w25,w24 929 1.1 christos add w21,w21,w27 // e+=rot(a,5) 930 1.1 christos ror w23,w23,#2 931 1.1 christos eor w9,w9,w6 932 1.1 christos add w20,w20,w8 // future e+=X[i] 933 1.1 christos add w21,w21,w25 // e+=F(b,c,d) 934 1.1 christos ror w9,w9,#31 935 1.1 christos eor w10,w10,w12 936 1.1 christos eor w25,w24,w22 937 1.1 christos ror w27,w21,#27 938 1.1 christos add w24,w24,w28 // future e+=K 939 1.1 christos eor w10,w10,w19 940 1.1 christos eor w25,w25,w23 941 1.1 christos add w20,w20,w27 // e+=rot(a,5) 942 1.1 christos ror w22,w22,#2 943 1.1 christos eor w10,w10,w7 944 1.1 christos add w24,w24,w9 // future e+=X[i] 945 1.1 christos add w20,w20,w25 // e+=F(b,c,d) 946 1.1 christos ror w10,w10,#31 947 1.1 christos eor w11,w11,w13 948 1.1 christos eor w25,w23,w21 949 1.1 christos ror w27,w20,#27 950 1.1 christos add w23,w23,w28 // future e+=K 951 1.1 christos eor w11,w11,w3 952 1.1 christos eor w25,w25,w22 953 1.1 christos add w24,w24,w27 // e+=rot(a,5) 954 1.1 christos ror w21,w21,#2 955 1.1 christos eor w11,w11,w8 956 1.1 christos add w23,w23,w10 // future e+=X[i] 957 1.1 christos add w24,w24,w25 // e+=F(b,c,d) 958 1.1 christos ror w11,w11,#31 959 1.1 christos eor w12,w12,w14 960 1.1 christos eor w25,w22,w20 961 1.1 christos ror w27,w24,#27 962 1.1 christos add w22,w22,w28 // future e+=K 963 1.1 christos eor w12,w12,w4 964 1.1 christos eor w25,w25,w21 965 1.1 christos add w23,w23,w27 // e+=rot(a,5) 966 1.1 christos ror w20,w20,#2 967 1.1 christos eor w12,w12,w9 968 1.1 christos add w22,w22,w11 // future e+=X[i] 969 1.1 christos add w23,w23,w25 // e+=F(b,c,d) 970 1.1 christos ror w12,w12,#31 971 1.1 christos eor w13,w13,w15 972 1.1 christos eor w25,w21,w24 973 1.1 christos ror w27,w23,#27 974 1.1 christos add w21,w21,w28 // future e+=K 975 1.1 christos eor w13,w13,w5 976 1.1 christos eor w25,w25,w20 977 1.1 christos add w22,w22,w27 // e+=rot(a,5) 978 1.1 christos ror w24,w24,#2 979 1.1 christos eor w13,w13,w10 980 1.1 christos add w21,w21,w12 // future e+=X[i] 981 1.1 christos add w22,w22,w25 // e+=F(b,c,d) 982 1.1 christos ror w13,w13,#31 983 1.1 christos eor w14,w14,w16 984 1.1 christos eor w25,w20,w23 985 1.1 christos ror w27,w22,#27 986 1.1 christos add w20,w20,w28 // future e+=K 987 1.1 christos eor w14,w14,w6 988 1.1 christos eor w25,w25,w24 989 1.1 christos add w21,w21,w27 // e+=rot(a,5) 990 1.1 christos ror w23,w23,#2 991 1.1 christos eor w14,w14,w11 992 1.1 christos add w20,w20,w13 // future e+=X[i] 993 1.1 christos add w21,w21,w25 // e+=F(b,c,d) 994 1.1 christos ror w14,w14,#31 995 1.1 christos eor w15,w15,w17 996 1.1 christos eor w25,w24,w22 997 1.1 christos ror w27,w21,#27 998 1.1 christos add w24,w24,w28 // future e+=K 999 1.1 christos eor w15,w15,w7 1000 1.1 christos eor w25,w25,w23 1001 1.1 christos add w20,w20,w27 // e+=rot(a,5) 1002 1.1 christos ror w22,w22,#2 1003 1.1 christos eor w15,w15,w12 1004 1.1 christos add w24,w24,w14 // future e+=X[i] 1005 1.1 christos add w20,w20,w25 // e+=F(b,c,d) 1006 1.1 christos ror w15,w15,#31 1007 1.1 christos eor w16,w16,w19 1008 1.1 christos eor w25,w23,w21 1009 1.1 christos ror w27,w20,#27 1010 1.1 christos add w23,w23,w28 // future e+=K 1011 1.1 christos eor w16,w16,w8 1012 1.1 christos eor w25,w25,w22 1013 1.1 christos add w24,w24,w27 // e+=rot(a,5) 1014 1.1 christos ror w21,w21,#2 1015 1.1 christos eor w16,w16,w13 1016 1.1 christos add w23,w23,w15 // future e+=X[i] 1017 1.1 christos add w24,w24,w25 // e+=F(b,c,d) 1018 1.1 christos ror w16,w16,#31 1019 1.1 christos eor w17,w17,w3 1020 1.1 christos eor w25,w22,w20 1021 1.1 christos ror w27,w24,#27 1022 1.1 christos add w22,w22,w28 // future e+=K 1023 1.1 christos eor w17,w17,w9 1024 1.1 christos eor w25,w25,w21 1025 1.1 christos add w23,w23,w27 // e+=rot(a,5) 1026 1.1 christos ror w20,w20,#2 1027 1.1 christos eor w17,w17,w14 1028 1.1 christos add w22,w22,w16 // future e+=X[i] 1029 1.1 christos add w23,w23,w25 // e+=F(b,c,d) 1030 1.1 christos ror w17,w17,#31 1031 1.1 christos eor w19,w19,w4 1032 1.1 christos eor w25,w21,w24 1033 1.1 christos ror w27,w23,#27 1034 1.1 christos add w21,w21,w28 // future e+=K 1035 1.1 christos eor w19,w19,w10 1036 1.1 christos eor w25,w25,w20 1037 1.1 christos add w22,w22,w27 // e+=rot(a,5) 1038 1.1 christos ror w24,w24,#2 1039 1.1 christos eor w19,w19,w15 1040 1.1 christos add w21,w21,w17 // future e+=X[i] 1041 1.1 christos add w22,w22,w25 // e+=F(b,c,d) 1042 1.1 christos ror w19,w19,#31 1043 1.1 christos ldp w4,w5,[x0] 1044 1.1 christos eor w25,w20,w23 1045 1.1 christos ror w27,w22,#27 1046 1.1 christos add w20,w20,w28 // future e+=K 1047 1.1 christos eor w25,w25,w24 1048 1.1 christos add w21,w21,w27 // e+=rot(a,5) 1049 1.1 christos ror w23,w23,#2 1050 1.1 christos add w20,w20,w19 // future e+=X[i] 1051 1.1 christos add w21,w21,w25 // e+=F(b,c,d) 1052 1.1 christos ldp w6,w7,[x0,#8] 1053 1.1 christos eor w25,w24,w22 1054 1.1 christos ror w27,w21,#27 1055 1.1 christos eor w25,w25,w23 1056 1.1 christos add w20,w20,w27 // e+=rot(a,5) 1057 1.1 christos ror w22,w22,#2 1058 1.1 christos ldr w8,[x0,#16] 1059 1.1 christos add w20,w20,w25 // e+=F(b,c,d) 1060 1.1 christos add w21,w21,w5 1061 1.1 christos add w22,w22,w6 1062 1.1 christos add w20,w20,w4 1063 1.1 christos add w23,w23,w7 1064 1.1 christos add w24,w24,w8 1065 1.1 christos stp w20,w21,[x0] 1066 1.1 christos stp w22,w23,[x0,#8] 1067 1.1 christos str w24,[x0,#16] 1068 1.1 christos cbnz x2,.Loop 1069 1.1 christos 1070 1.1 christos ldp x19,x20,[sp,#16] 1071 1.1 christos ldp x21,x22,[sp,#32] 1072 1.1 christos ldp x23,x24,[sp,#48] 1073 1.1 christos ldp x25,x26,[sp,#64] 1074 1.1 christos ldp x27,x28,[sp,#80] 1075 1.1 christos ldr x29,[sp],#96 1076 1.1 christos ret 1077 1.1 christos .size sha1_block_data_order,.-sha1_block_data_order 1078 1.1 christos .type sha1_block_armv8,%function 1079 1.1 christos .align 6 1080 1.1 christos sha1_block_armv8: 1081 1.1 christos .Lv8_entry: 1082 1.1 christos stp x29,x30,[sp,#-16]! 1083 1.1 christos add x29,sp,#0 1084 1.1 christos 1085 1.1 christos adr x4,.Lconst 1086 1.1 christos eor v1.16b,v1.16b,v1.16b 1087 1.1 christos ld1 {v0.4s},[x0],#16 1088 1.1 christos ld1 {v1.s}[0],[x0] 1089 1.1 christos sub x0,x0,#16 1090 1.1 christos ld1 {v16.4s,v17.4s,v18.4s,v19.4s},[x4] 1091 1.1 christos 1092 1.1 christos .Loop_hw: 1093 1.1 christos ld1 {v4.16b,v5.16b,v6.16b,v7.16b},[x1],#64 1094 1.1 christos sub x2,x2,#1 1095 1.1 christos rev32 v4.16b,v4.16b 1096 1.1 christos rev32 v5.16b,v5.16b 1097 1.1 christos 1098 1.1 christos add v20.4s,v16.4s,v4.4s 1099 1.1 christos rev32 v6.16b,v6.16b 1100 1.1 christos orr v22.16b,v0.16b,v0.16b // offload 1101 1.1 christos 1102 1.1 christos add v21.4s,v16.4s,v5.4s 1103 1.1 christos rev32 v7.16b,v7.16b 1104 1.1 christos .inst 0x5e280803 //sha1h v3.16b,v0.16b 1105 1.1 christos .inst 0x5e140020 //sha1c v0.16b,v1.16b,v20.4s // 0 1106 1.1 christos add v20.4s,v16.4s,v6.4s 1107 1.1 christos .inst 0x5e0630a4 //sha1su0 v4.16b,v5.16b,v6.16b 1108 1.1 christos .inst 0x5e280802 //sha1h v2.16b,v0.16b // 1 1109 1.1 christos .inst 0x5e150060 //sha1c v0.16b,v3.16b,v21.4s 1110 1.1 christos add v21.4s,v16.4s,v7.4s 1111 1.1 christos .inst 0x5e2818e4 //sha1su1 v4.16b,v7.16b 1112 1.1 christos .inst 0x5e0730c5 //sha1su0 v5.16b,v6.16b,v7.16b 1113 1.1 christos .inst 0x5e280803 //sha1h v3.16b,v0.16b // 2 1114 1.1 christos .inst 0x5e140040 //sha1c v0.16b,v2.16b,v20.4s 1115 1.1 christos add v20.4s,v16.4s,v4.4s 1116 1.1 christos .inst 0x5e281885 //sha1su1 v5.16b,v4.16b 1117 1.1 christos .inst 0x5e0430e6 //sha1su0 v6.16b,v7.16b,v4.16b 1118 1.1 christos .inst 0x5e280802 //sha1h v2.16b,v0.16b // 3 1119 1.1 christos .inst 0x5e150060 //sha1c v0.16b,v3.16b,v21.4s 1120 1.1 christos add v21.4s,v17.4s,v5.4s 1121 1.1 christos .inst 0x5e2818a6 //sha1su1 v6.16b,v5.16b 1122 1.1 christos .inst 0x5e053087 //sha1su0 v7.16b,v4.16b,v5.16b 1123 1.1 christos .inst 0x5e280803 //sha1h v3.16b,v0.16b // 4 1124 1.1 christos .inst 0x5e140040 //sha1c v0.16b,v2.16b,v20.4s 1125 1.1 christos add v20.4s,v17.4s,v6.4s 1126 1.1 christos .inst 0x5e2818c7 //sha1su1 v7.16b,v6.16b 1127 1.1 christos .inst 0x5e0630a4 //sha1su0 v4.16b,v5.16b,v6.16b 1128 1.1 christos .inst 0x5e280802 //sha1h v2.16b,v0.16b // 5 1129 1.1 christos .inst 0x5e151060 //sha1p v0.16b,v3.16b,v21.4s 1130 1.1 christos add v21.4s,v17.4s,v7.4s 1131 1.1 christos .inst 0x5e2818e4 //sha1su1 v4.16b,v7.16b 1132 1.1 christos .inst 0x5e0730c5 //sha1su0 v5.16b,v6.16b,v7.16b 1133 1.1 christos .inst 0x5e280803 //sha1h v3.16b,v0.16b // 6 1134 1.1 christos .inst 0x5e141040 //sha1p v0.16b,v2.16b,v20.4s 1135 1.1 christos add v20.4s,v17.4s,v4.4s 1136 1.1 christos .inst 0x5e281885 //sha1su1 v5.16b,v4.16b 1137 1.1 christos .inst 0x5e0430e6 //sha1su0 v6.16b,v7.16b,v4.16b 1138 1.1 christos .inst 0x5e280802 //sha1h v2.16b,v0.16b // 7 1139 1.1 christos .inst 0x5e151060 //sha1p v0.16b,v3.16b,v21.4s 1140 1.1 christos add v21.4s,v17.4s,v5.4s 1141 1.1 christos .inst 0x5e2818a6 //sha1su1 v6.16b,v5.16b 1142 1.1 christos .inst 0x5e053087 //sha1su0 v7.16b,v4.16b,v5.16b 1143 1.1 christos .inst 0x5e280803 //sha1h v3.16b,v0.16b // 8 1144 1.1 christos .inst 0x5e141040 //sha1p v0.16b,v2.16b,v20.4s 1145 1.1 christos add v20.4s,v18.4s,v6.4s 1146 1.1 christos .inst 0x5e2818c7 //sha1su1 v7.16b,v6.16b 1147 1.1 christos .inst 0x5e0630a4 //sha1su0 v4.16b,v5.16b,v6.16b 1148 1.1 christos .inst 0x5e280802 //sha1h v2.16b,v0.16b // 9 1149 1.1 christos .inst 0x5e151060 //sha1p v0.16b,v3.16b,v21.4s 1150 1.1 christos add v21.4s,v18.4s,v7.4s 1151 1.1 christos .inst 0x5e2818e4 //sha1su1 v4.16b,v7.16b 1152 1.1 christos .inst 0x5e0730c5 //sha1su0 v5.16b,v6.16b,v7.16b 1153 1.1 christos .inst 0x5e280803 //sha1h v3.16b,v0.16b // 10 1154 1.1 christos .inst 0x5e142040 //sha1m v0.16b,v2.16b,v20.4s 1155 1.1 christos add v20.4s,v18.4s,v4.4s 1156 1.1 christos .inst 0x5e281885 //sha1su1 v5.16b,v4.16b 1157 1.1 christos .inst 0x5e0430e6 //sha1su0 v6.16b,v7.16b,v4.16b 1158 1.1 christos .inst 0x5e280802 //sha1h v2.16b,v0.16b // 11 1159 1.1 christos .inst 0x5e152060 //sha1m v0.16b,v3.16b,v21.4s 1160 1.1 christos add v21.4s,v18.4s,v5.4s 1161 1.1 christos .inst 0x5e2818a6 //sha1su1 v6.16b,v5.16b 1162 1.1 christos .inst 0x5e053087 //sha1su0 v7.16b,v4.16b,v5.16b 1163 1.1 christos .inst 0x5e280803 //sha1h v3.16b,v0.16b // 12 1164 1.1 christos .inst 0x5e142040 //sha1m v0.16b,v2.16b,v20.4s 1165 1.1 christos add v20.4s,v18.4s,v6.4s 1166 1.1 christos .inst 0x5e2818c7 //sha1su1 v7.16b,v6.16b 1167 1.1 christos .inst 0x5e0630a4 //sha1su0 v4.16b,v5.16b,v6.16b 1168 1.1 christos .inst 0x5e280802 //sha1h v2.16b,v0.16b // 13 1169 1.1 christos .inst 0x5e152060 //sha1m v0.16b,v3.16b,v21.4s 1170 1.1 christos add v21.4s,v19.4s,v7.4s 1171 1.1 christos .inst 0x5e2818e4 //sha1su1 v4.16b,v7.16b 1172 1.1 christos .inst 0x5e0730c5 //sha1su0 v5.16b,v6.16b,v7.16b 1173 1.1 christos .inst 0x5e280803 //sha1h v3.16b,v0.16b // 14 1174 1.1 christos .inst 0x5e142040 //sha1m v0.16b,v2.16b,v20.4s 1175 1.1 christos add v20.4s,v19.4s,v4.4s 1176 1.1 christos .inst 0x5e281885 //sha1su1 v5.16b,v4.16b 1177 1.1 christos .inst 0x5e0430e6 //sha1su0 v6.16b,v7.16b,v4.16b 1178 1.1 christos .inst 0x5e280802 //sha1h v2.16b,v0.16b // 15 1179 1.1 christos .inst 0x5e151060 //sha1p v0.16b,v3.16b,v21.4s 1180 1.1 christos add v21.4s,v19.4s,v5.4s 1181 1.1 christos .inst 0x5e2818a6 //sha1su1 v6.16b,v5.16b 1182 1.1 christos .inst 0x5e053087 //sha1su0 v7.16b,v4.16b,v5.16b 1183 1.1 christos .inst 0x5e280803 //sha1h v3.16b,v0.16b // 16 1184 1.1 christos .inst 0x5e141040 //sha1p v0.16b,v2.16b,v20.4s 1185 1.1 christos add v20.4s,v19.4s,v6.4s 1186 1.1 christos .inst 0x5e2818c7 //sha1su1 v7.16b,v6.16b 1187 1.1 christos .inst 0x5e280802 //sha1h v2.16b,v0.16b // 17 1188 1.1 christos .inst 0x5e151060 //sha1p v0.16b,v3.16b,v21.4s 1189 1.1 christos add v21.4s,v19.4s,v7.4s 1190 1.1 christos 1191 1.1 christos .inst 0x5e280803 //sha1h v3.16b,v0.16b // 18 1192 1.1 christos .inst 0x5e141040 //sha1p v0.16b,v2.16b,v20.4s 1193 1.1 christos 1194 1.1 christos .inst 0x5e280802 //sha1h v2.16b,v0.16b // 19 1195 1.1 christos .inst 0x5e151060 //sha1p v0.16b,v3.16b,v21.4s 1196 1.1 christos 1197 1.1 christos add v1.4s,v1.4s,v2.4s 1198 1.1 christos add v0.4s,v0.4s,v22.4s 1199 1.1 christos 1200 1.1 christos cbnz x2,.Loop_hw 1201 1.1 christos 1202 1.1 christos st1 {v0.4s},[x0],#16 1203 1.1 christos st1 {v1.s}[0],[x0] 1204 1.1 christos 1205 1.1 christos ldr x29,[sp],#16 1206 1.1 christos ret 1207 1.1 christos .size sha1_block_armv8,.-sha1_block_armv8 1208 1.1 christos .align 6 1209 1.1 christos .Lconst: 1210 1.1 christos .long 0x5a827999,0x5a827999,0x5a827999,0x5a827999 //K_00_19 1211 1.1 christos .long 0x6ed9eba1,0x6ed9eba1,0x6ed9eba1,0x6ed9eba1 //K_20_39 1212 1.1 christos .long 0x8f1bbcdc,0x8f1bbcdc,0x8f1bbcdc,0x8f1bbcdc //K_40_59 1213 1.1 christos .long 0xca62c1d6,0xca62c1d6,0xca62c1d6,0xca62c1d6 //K_60_79 1214 1.1 christos .LOPENSSL_armcap_P: 1215 1.1 christos #ifdef __ILP32__ 1216 1.1 christos .long OPENSSL_armcap_P-. 1217 1.1 christos #else 1218 1.1 christos .quad OPENSSL_armcap_P-. 1219 1.1 christos #endif 1220 1.1 christos .byte 83,72,65,49,32,98,108,111,99,107,32,116,114,97,110,115,102,111,114,109,32,102,111,114,32,65,82,77,118,56,44,32,67,82,89,80,84,79,71,65,77,83,32,98,121,32,60,97,112,112,114,111,64,111,112,101,110,115,115,108,46,111,114,103,62,0 1221 1.1 christos .align 2 1222 1.1 christos .align 2 1223