1*4724848cSchristos#include "mips_arch.h" 2*4724848cSchristos 3*4724848cSchristos.text 4*4724848cSchristos#if !defined(__mips_eabi) && (!defined(__vxworks) || defined(__pic__)) 5*4724848cSchristos.option pic2 6*4724848cSchristos#endif 7*4724848cSchristos.set noat 8*4724848cSchristos.align 5 9*4724848cSchristos.ent _mips_AES_encrypt 10*4724848cSchristos_mips_AES_encrypt: 11*4724848cSchristos .frame $29,0,$31 12*4724848cSchristos .set reorder 13*4724848cSchristos lw $12,0($6) 14*4724848cSchristos lw $13,4($6) 15*4724848cSchristos lw $14,8($6) 16*4724848cSchristos lw $15,12($6) 17*4724848cSchristos lw $30,240($6) 18*4724848cSchristos addu $3,$6,16 19*4724848cSchristos 20*4724848cSchristos xor $8,$12 21*4724848cSchristos xor $9,$13 22*4724848cSchristos xor $10,$14 23*4724848cSchristos xor $11,$15 24*4724848cSchristos 25*4724848cSchristos subu $30,1 26*4724848cSchristos#if defined(__mips_smartmips) 27*4724848cSchristos ext $1,$9,8,8 28*4724848cSchristos.Loop_enc: 29*4724848cSchristos ext $2,$10,8,8 30*4724848cSchristos ext $24,$11,8,8 31*4724848cSchristos ext $25,$8,8,8 32*4724848cSchristos lwxs $12,$1($7) # Te1[s1>>16] 33*4724848cSchristos ext $1,$10,16,8 34*4724848cSchristos lwxs $13,$2($7) # Te1[s2>>16] 35*4724848cSchristos ext $2,$11,16,8 36*4724848cSchristos lwxs $14,$24($7) # Te1[s3>>16] 37*4724848cSchristos ext $24,$8,16,8 38*4724848cSchristos lwxs $15,$25($7) # Te1[s0>>16] 39*4724848cSchristos ext $25,$9,16,8 40*4724848cSchristos 41*4724848cSchristos lwxs $16,$1($7) # Te2[s2>>8] 42*4724848cSchristos ext $1,$11,24,8 43*4724848cSchristos lwxs $17,$2($7) # Te2[s3>>8] 44*4724848cSchristos ext $2,$8,24,8 45*4724848cSchristos lwxs $18,$24($7) # Te2[s0>>8] 46*4724848cSchristos ext $24,$9,24,8 47*4724848cSchristos lwxs $19,$25($7) # Te2[s1>>8] 48*4724848cSchristos ext $25,$10,24,8 49*4724848cSchristos 50*4724848cSchristos lwxs $20,$1($7) # Te3[s3] 51*4724848cSchristos ext $1,$8,0,8 52*4724848cSchristos lwxs $21,$2($7) # Te3[s0] 53*4724848cSchristos ext $2,$9,0,8 54*4724848cSchristos lwxs $22,$24($7) # Te3[s1] 55*4724848cSchristos ext $24,$10,0,8 56*4724848cSchristos lwxs $23,$25($7) # Te3[s2] 57*4724848cSchristos ext $25,$11,0,8 58*4724848cSchristos 59*4724848cSchristos rotr $12,$12,24 60*4724848cSchristos rotr $13,$13,24 61*4724848cSchristos rotr $14,$14,24 62*4724848cSchristos rotr $15,$15,24 63*4724848cSchristos 64*4724848cSchristos rotr $16,$16,16 65*4724848cSchristos rotr $17,$17,16 66*4724848cSchristos rotr $18,$18,16 67*4724848cSchristos rotr $19,$19,16 68*4724848cSchristos 69*4724848cSchristos xor $12,$16 70*4724848cSchristos lwxs $16,$1($7) # Te0[s0>>24] 71*4724848cSchristos xor $13,$17 72*4724848cSchristos lwxs $17,$2($7) # Te0[s1>>24] 73*4724848cSchristos xor $14,$18 74*4724848cSchristos lwxs $18,$24($7) # Te0[s2>>24] 75*4724848cSchristos xor $15,$19 76*4724848cSchristos lwxs $19,$25($7) # Te0[s3>>24] 77*4724848cSchristos 78*4724848cSchristos rotr $20,$20,8 79*4724848cSchristos lw $8,0($3) 80*4724848cSchristos rotr $21,$21,8 81*4724848cSchristos lw $9,4($3) 82*4724848cSchristos rotr $22,$22,8 83*4724848cSchristos lw $10,8($3) 84*4724848cSchristos rotr $23,$23,8 85*4724848cSchristos lw $11,12($3) 86*4724848cSchristos 87*4724848cSchristos xor $12,$20 88*4724848cSchristos xor $13,$21 89*4724848cSchristos xor $14,$22 90*4724848cSchristos xor $15,$23 91*4724848cSchristos 92*4724848cSchristos xor $12,$16 93*4724848cSchristos xor $13,$17 94*4724848cSchristos xor $14,$18 95*4724848cSchristos xor $15,$19 96*4724848cSchristos 97*4724848cSchristos subu $30,1 98*4724848cSchristos addu $3,16 99*4724848cSchristos xor $8,$12 100*4724848cSchristos xor $9,$13 101*4724848cSchristos xor $10,$14 102*4724848cSchristos xor $11,$15 103*4724848cSchristos .set noreorder 104*4724848cSchristos bnez $30,.Loop_enc 105*4724848cSchristos ext $1,$9,8,8 106*4724848cSchristos 107*4724848cSchristos srl $1,$9,6 108*4724848cSchristos#else 109*4724848cSchristos srl $1,$9,6 110*4724848cSchristos.Loop_enc: 111*4724848cSchristos srl $2,$10,6 112*4724848cSchristos srl $24,$11,6 113*4724848cSchristos srl $25,$8,6 114*4724848cSchristos and $1,0x3fc 115*4724848cSchristos and $2,0x3fc 116*4724848cSchristos and $24,0x3fc 117*4724848cSchristos and $25,0x3fc 118*4724848cSchristos addu $1,$7 119*4724848cSchristos addu $2,$7 120*4724848cSchristos addu $24,$7 121*4724848cSchristos addu $25,$7 122*4724848cSchristos#if defined(_MIPS_ARCH_MIPS32R2) || defined(_MIPS_ARCH_MIPS64R2) 123*4724848cSchristos lw $12,0($1) # Te1[s1>>16] 124*4724848cSchristos srl $1,$10,14 125*4724848cSchristos lw $13,0($2) # Te1[s2>>16] 126*4724848cSchristos srl $2,$11,14 127*4724848cSchristos lw $14,0($24) # Te1[s3>>16] 128*4724848cSchristos srl $24,$8,14 129*4724848cSchristos lw $15,0($25) # Te1[s0>>16] 130*4724848cSchristos srl $25,$9,14 131*4724848cSchristos#else 132*4724848cSchristos lwl $12,2($1) # Te1[s1>>16] 133*4724848cSchristos lwl $13,2($2) # Te1[s2>>16] 134*4724848cSchristos lwl $14,2($24) # Te1[s3>>16] 135*4724848cSchristos lwl $15,2($25) # Te1[s0>>16] 136*4724848cSchristos lwr $12,3($1) # Te1[s1>>16] 137*4724848cSchristos srl $1,$10,14 138*4724848cSchristos lwr $13,3($2) # Te1[s2>>16] 139*4724848cSchristos srl $2,$11,14 140*4724848cSchristos lwr $14,3($24) # Te1[s3>>16] 141*4724848cSchristos srl $24,$8,14 142*4724848cSchristos lwr $15,3($25) # Te1[s0>>16] 143*4724848cSchristos srl $25,$9,14 144*4724848cSchristos#endif 145*4724848cSchristos and $1,0x3fc 146*4724848cSchristos and $2,0x3fc 147*4724848cSchristos and $24,0x3fc 148*4724848cSchristos and $25,0x3fc 149*4724848cSchristos addu $1,$7 150*4724848cSchristos addu $2,$7 151*4724848cSchristos addu $24,$7 152*4724848cSchristos addu $25,$7 153*4724848cSchristos#if defined(_MIPS_ARCH_MIPS32R2) || defined(_MIPS_ARCH_MIPS64R2) 154*4724848cSchristos rotr $12,$12,24 155*4724848cSchristos rotr $13,$13,24 156*4724848cSchristos rotr $14,$14,24 157*4724848cSchristos rotr $15,$15,24 158*4724848cSchristos# if defined(_MIPSEL) 159*4724848cSchristos lw $16,0($1) # Te2[s2>>8] 160*4724848cSchristos srl $1,$11,22 161*4724848cSchristos lw $17,0($2) # Te2[s3>>8] 162*4724848cSchristos srl $2,$8,22 163*4724848cSchristos lw $18,0($24) # Te2[s0>>8] 164*4724848cSchristos srl $24,$9,22 165*4724848cSchristos lw $19,0($25) # Te2[s1>>8] 166*4724848cSchristos srl $25,$10,22 167*4724848cSchristos 168*4724848cSchristos and $1,0x3fc 169*4724848cSchristos and $2,0x3fc 170*4724848cSchristos and $24,0x3fc 171*4724848cSchristos and $25,0x3fc 172*4724848cSchristos addu $1,$7 173*4724848cSchristos addu $2,$7 174*4724848cSchristos addu $24,$7 175*4724848cSchristos addu $25,$7 176*4724848cSchristos lw $20,0($1) # Te3[s3] 177*4724848cSchristos ins $1,$8,2,8 178*4724848cSchristos lw $21,0($2) # Te3[s0] 179*4724848cSchristos ins $2,$9,2,8 180*4724848cSchristos lw $22,0($24) # Te3[s1] 181*4724848cSchristos ins $24,$10,2,8 182*4724848cSchristos lw $23,0($25) # Te3[s2] 183*4724848cSchristos ins $25,$11,2,8 184*4724848cSchristos# else 185*4724848cSchristos lw $16,0($1) # Te2[s2>>8] 186*4724848cSchristos ins $1,$11,2,8 187*4724848cSchristos lw $17,0($2) # Te2[s3>>8] 188*4724848cSchristos ins $2,$8,2,8 189*4724848cSchristos lw $18,0($24) # Te2[s0>>8] 190*4724848cSchristos ins $24,$9,2,8 191*4724848cSchristos lw $19,0($25) # Te2[s1>>8] 192*4724848cSchristos ins $25,$10,2,8 193*4724848cSchristos 194*4724848cSchristos lw $20,0($1) # Te3[s3] 195*4724848cSchristos sll $1,$8,2 196*4724848cSchristos lw $21,0($2) # Te3[s0] 197*4724848cSchristos sll $2,$9,2 198*4724848cSchristos lw $22,0($24) # Te3[s1] 199*4724848cSchristos sll $24,$10,2 200*4724848cSchristos lw $23,0($25) # Te3[s2] 201*4724848cSchristos sll $25,$11,2 202*4724848cSchristos 203*4724848cSchristos and $1,0x3fc 204*4724848cSchristos and $2,0x3fc 205*4724848cSchristos and $24,0x3fc 206*4724848cSchristos and $25,0x3fc 207*4724848cSchristos addu $1,$7 208*4724848cSchristos addu $2,$7 209*4724848cSchristos addu $24,$7 210*4724848cSchristos addu $25,$7 211*4724848cSchristos# endif 212*4724848cSchristos rotr $16,$16,16 213*4724848cSchristos rotr $17,$17,16 214*4724848cSchristos rotr $18,$18,16 215*4724848cSchristos rotr $19,$19,16 216*4724848cSchristos 217*4724848cSchristos rotr $20,$20,8 218*4724848cSchristos rotr $21,$21,8 219*4724848cSchristos rotr $22,$22,8 220*4724848cSchristos rotr $23,$23,8 221*4724848cSchristos#else 222*4724848cSchristos lwl $16,1($1) # Te2[s2>>8] 223*4724848cSchristos lwl $17,1($2) # Te2[s3>>8] 224*4724848cSchristos lwl $18,1($24) # Te2[s0>>8] 225*4724848cSchristos lwl $19,1($25) # Te2[s1>>8] 226*4724848cSchristos lwr $16,2($1) # Te2[s2>>8] 227*4724848cSchristos srl $1,$11,22 228*4724848cSchristos lwr $17,2($2) # Te2[s3>>8] 229*4724848cSchristos srl $2,$8,22 230*4724848cSchristos lwr $18,2($24) # Te2[s0>>8] 231*4724848cSchristos srl $24,$9,22 232*4724848cSchristos lwr $19,2($25) # Te2[s1>>8] 233*4724848cSchristos srl $25,$10,22 234*4724848cSchristos 235*4724848cSchristos and $1,0x3fc 236*4724848cSchristos and $2,0x3fc 237*4724848cSchristos and $24,0x3fc 238*4724848cSchristos and $25,0x3fc 239*4724848cSchristos addu $1,$7 240*4724848cSchristos addu $2,$7 241*4724848cSchristos addu $24,$7 242*4724848cSchristos addu $25,$7 243*4724848cSchristos lwl $20,0($1) # Te3[s3] 244*4724848cSchristos lwl $21,0($2) # Te3[s0] 245*4724848cSchristos lwl $22,0($24) # Te3[s1] 246*4724848cSchristos lwl $23,0($25) # Te3[s2] 247*4724848cSchristos lwr $20,1($1) # Te3[s3] 248*4724848cSchristos sll $1,$8,2 249*4724848cSchristos lwr $21,1($2) # Te3[s0] 250*4724848cSchristos sll $2,$9,2 251*4724848cSchristos lwr $22,1($24) # Te3[s1] 252*4724848cSchristos sll $24,$10,2 253*4724848cSchristos lwr $23,1($25) # Te3[s2] 254*4724848cSchristos sll $25,$11,2 255*4724848cSchristos 256*4724848cSchristos and $1,0x3fc 257*4724848cSchristos and $2,0x3fc 258*4724848cSchristos and $24,0x3fc 259*4724848cSchristos and $25,0x3fc 260*4724848cSchristos addu $1,$7 261*4724848cSchristos addu $2,$7 262*4724848cSchristos addu $24,$7 263*4724848cSchristos addu $25,$7 264*4724848cSchristos#endif 265*4724848cSchristos xor $12,$16 266*4724848cSchristos lw $16,0($1) # Te0[s0>>24] 267*4724848cSchristos xor $13,$17 268*4724848cSchristos lw $17,0($2) # Te0[s1>>24] 269*4724848cSchristos xor $14,$18 270*4724848cSchristos lw $18,0($24) # Te0[s2>>24] 271*4724848cSchristos xor $15,$19 272*4724848cSchristos lw $19,0($25) # Te0[s3>>24] 273*4724848cSchristos 274*4724848cSchristos xor $12,$20 275*4724848cSchristos lw $8,0($3) 276*4724848cSchristos xor $13,$21 277*4724848cSchristos lw $9,4($3) 278*4724848cSchristos xor $14,$22 279*4724848cSchristos lw $10,8($3) 280*4724848cSchristos xor $15,$23 281*4724848cSchristos lw $11,12($3) 282*4724848cSchristos 283*4724848cSchristos xor $12,$16 284*4724848cSchristos xor $13,$17 285*4724848cSchristos xor $14,$18 286*4724848cSchristos xor $15,$19 287*4724848cSchristos 288*4724848cSchristos subu $30,1 289*4724848cSchristos addu $3,16 290*4724848cSchristos xor $8,$12 291*4724848cSchristos xor $9,$13 292*4724848cSchristos xor $10,$14 293*4724848cSchristos xor $11,$15 294*4724848cSchristos .set noreorder 295*4724848cSchristos bnez $30,.Loop_enc 296*4724848cSchristos srl $1,$9,6 297*4724848cSchristos#endif 298*4724848cSchristos 299*4724848cSchristos .set reorder 300*4724848cSchristos srl $2,$10,6 301*4724848cSchristos srl $24,$11,6 302*4724848cSchristos srl $25,$8,6 303*4724848cSchristos and $1,0x3fc 304*4724848cSchristos and $2,0x3fc 305*4724848cSchristos and $24,0x3fc 306*4724848cSchristos and $25,0x3fc 307*4724848cSchristos addu $1,$7 308*4724848cSchristos addu $2,$7 309*4724848cSchristos addu $24,$7 310*4724848cSchristos addu $25,$7 311*4724848cSchristos lbu $12,2($1) # Te4[s1>>16] 312*4724848cSchristos srl $1,$10,14 313*4724848cSchristos lbu $13,2($2) # Te4[s2>>16] 314*4724848cSchristos srl $2,$11,14 315*4724848cSchristos lbu $14,2($24) # Te4[s3>>16] 316*4724848cSchristos srl $24,$8,14 317*4724848cSchristos lbu $15,2($25) # Te4[s0>>16] 318*4724848cSchristos srl $25,$9,14 319*4724848cSchristos 320*4724848cSchristos and $1,0x3fc 321*4724848cSchristos and $2,0x3fc 322*4724848cSchristos and $24,0x3fc 323*4724848cSchristos and $25,0x3fc 324*4724848cSchristos addu $1,$7 325*4724848cSchristos addu $2,$7 326*4724848cSchristos addu $24,$7 327*4724848cSchristos addu $25,$7 328*4724848cSchristos#if defined(_MIPS_ARCH_MIPS32R2) || defined(_MIPS_ARCH_MIPS64R2) 329*4724848cSchristos# if defined(_MIPSEL) 330*4724848cSchristos lbu $16,2($1) # Te4[s2>>8] 331*4724848cSchristos ins $1,$8,2,8 332*4724848cSchristos lbu $17,2($2) # Te4[s3>>8] 333*4724848cSchristos ins $2,$9,2,8 334*4724848cSchristos lbu $18,2($24) # Te4[s0>>8] 335*4724848cSchristos ins $24,$10,2,8 336*4724848cSchristos lbu $19,2($25) # Te4[s1>>8] 337*4724848cSchristos ins $25,$11,2,8 338*4724848cSchristos 339*4724848cSchristos lbu $20,2($1) # Te4[s0>>24] 340*4724848cSchristos srl $1,$11,22 341*4724848cSchristos lbu $21,2($2) # Te4[s1>>24] 342*4724848cSchristos srl $2,$8,22 343*4724848cSchristos lbu $22,2($24) # Te4[s2>>24] 344*4724848cSchristos srl $24,$9,22 345*4724848cSchristos lbu $23,2($25) # Te4[s3>>24] 346*4724848cSchristos srl $25,$10,22 347*4724848cSchristos 348*4724848cSchristos and $1,0x3fc 349*4724848cSchristos and $2,0x3fc 350*4724848cSchristos and $24,0x3fc 351*4724848cSchristos and $25,0x3fc 352*4724848cSchristos addu $1,$7 353*4724848cSchristos addu $2,$7 354*4724848cSchristos addu $24,$7 355*4724848cSchristos addu $25,$7 356*4724848cSchristos# else 357*4724848cSchristos lbu $16,2($1) # Te4[s2>>8] 358*4724848cSchristos sll $1,$8,2 359*4724848cSchristos lbu $17,2($2) # Te4[s3>>8] 360*4724848cSchristos sll $2,$9,2 361*4724848cSchristos lbu $18,2($24) # Te4[s0>>8] 362*4724848cSchristos sll $24,$10,2 363*4724848cSchristos lbu $19,2($25) # Te4[s1>>8] 364*4724848cSchristos sll $25,$11,2 365*4724848cSchristos 366*4724848cSchristos and $1,0x3fc 367*4724848cSchristos and $2,0x3fc 368*4724848cSchristos and $24,0x3fc 369*4724848cSchristos and $25,0x3fc 370*4724848cSchristos addu $1,$7 371*4724848cSchristos addu $2,$7 372*4724848cSchristos addu $24,$7 373*4724848cSchristos addu $25,$7 374*4724848cSchristos lbu $20,2($1) # Te4[s0>>24] 375*4724848cSchristos ins $1,$11,2,8 376*4724848cSchristos lbu $21,2($2) # Te4[s1>>24] 377*4724848cSchristos ins $2,$8,2,8 378*4724848cSchristos lbu $22,2($24) # Te4[s2>>24] 379*4724848cSchristos ins $24,$9,2,8 380*4724848cSchristos lbu $23,2($25) # Te4[s3>>24] 381*4724848cSchristos ins $25,$10,2,8 382*4724848cSchristos# endif 383*4724848cSchristos sll $12,$12,8 384*4724848cSchristos sll $13,$13,8 385*4724848cSchristos sll $14,$14,8 386*4724848cSchristos sll $15,$15,8 387*4724848cSchristos 388*4724848cSchristos ins $12,$16,16,8 389*4724848cSchristos lbu $16,2($1) # Te4[s3] 390*4724848cSchristos ins $13,$17,16,8 391*4724848cSchristos lbu $17,2($2) # Te4[s0] 392*4724848cSchristos ins $14,$18,16,8 393*4724848cSchristos lbu $18,2($24) # Te4[s1] 394*4724848cSchristos ins $15,$19,16,8 395*4724848cSchristos lbu $19,2($25) # Te4[s2] 396*4724848cSchristos 397*4724848cSchristos ins $12,$20,0,8 398*4724848cSchristos lw $8,0($3) 399*4724848cSchristos ins $13,$21,0,8 400*4724848cSchristos lw $9,4($3) 401*4724848cSchristos ins $14,$22,0,8 402*4724848cSchristos lw $10,8($3) 403*4724848cSchristos ins $15,$23,0,8 404*4724848cSchristos lw $11,12($3) 405*4724848cSchristos 406*4724848cSchristos ins $12,$16,24,8 407*4724848cSchristos ins $13,$17,24,8 408*4724848cSchristos ins $14,$18,24,8 409*4724848cSchristos ins $15,$19,24,8 410*4724848cSchristos#else 411*4724848cSchristos lbu $16,2($1) # Te4[s2>>8] 412*4724848cSchristos sll $1,$8,2 413*4724848cSchristos lbu $17,2($2) # Te4[s3>>8] 414*4724848cSchristos sll $2,$9,2 415*4724848cSchristos lbu $18,2($24) # Te4[s0>>8] 416*4724848cSchristos sll $24,$10,2 417*4724848cSchristos lbu $19,2($25) # Te4[s1>>8] 418*4724848cSchristos sll $25,$11,2 419*4724848cSchristos 420*4724848cSchristos and $1,0x3fc 421*4724848cSchristos and $2,0x3fc 422*4724848cSchristos and $24,0x3fc 423*4724848cSchristos and $25,0x3fc 424*4724848cSchristos addu $1,$7 425*4724848cSchristos addu $2,$7 426*4724848cSchristos addu $24,$7 427*4724848cSchristos addu $25,$7 428*4724848cSchristos lbu $20,2($1) # Te4[s0>>24] 429*4724848cSchristos srl $1,$11,22 430*4724848cSchristos lbu $21,2($2) # Te4[s1>>24] 431*4724848cSchristos srl $2,$8,22 432*4724848cSchristos lbu $22,2($24) # Te4[s2>>24] 433*4724848cSchristos srl $24,$9,22 434*4724848cSchristos lbu $23,2($25) # Te4[s3>>24] 435*4724848cSchristos srl $25,$10,22 436*4724848cSchristos 437*4724848cSchristos and $1,0x3fc 438*4724848cSchristos and $2,0x3fc 439*4724848cSchristos and $24,0x3fc 440*4724848cSchristos and $25,0x3fc 441*4724848cSchristos addu $1,$7 442*4724848cSchristos addu $2,$7 443*4724848cSchristos addu $24,$7 444*4724848cSchristos addu $25,$7 445*4724848cSchristos 446*4724848cSchristos sll $12,$12,8 447*4724848cSchristos sll $13,$13,8 448*4724848cSchristos sll $14,$14,8 449*4724848cSchristos sll $15,$15,8 450*4724848cSchristos 451*4724848cSchristos sll $16,$16,16 452*4724848cSchristos sll $17,$17,16 453*4724848cSchristos sll $18,$18,16 454*4724848cSchristos sll $19,$19,16 455*4724848cSchristos 456*4724848cSchristos xor $12,$16 457*4724848cSchristos lbu $16,2($1) # Te4[s3] 458*4724848cSchristos xor $13,$17 459*4724848cSchristos lbu $17,2($2) # Te4[s0] 460*4724848cSchristos xor $14,$18 461*4724848cSchristos lbu $18,2($24) # Te4[s1] 462*4724848cSchristos xor $15,$19 463*4724848cSchristos lbu $19,2($25) # Te4[s2] 464*4724848cSchristos 465*4724848cSchristos #sll $20,$20,0 466*4724848cSchristos lw $8,0($3) 467*4724848cSchristos #sll $21,$21,0 468*4724848cSchristos lw $9,4($3) 469*4724848cSchristos #sll $22,$22,0 470*4724848cSchristos lw $10,8($3) 471*4724848cSchristos #sll $23,$23,0 472*4724848cSchristos lw $11,12($3) 473*4724848cSchristos 474*4724848cSchristos xor $12,$20 475*4724848cSchristos xor $13,$21 476*4724848cSchristos xor $14,$22 477*4724848cSchristos xor $15,$23 478*4724848cSchristos 479*4724848cSchristos sll $16,$16,24 480*4724848cSchristos sll $17,$17,24 481*4724848cSchristos sll $18,$18,24 482*4724848cSchristos sll $19,$19,24 483*4724848cSchristos 484*4724848cSchristos xor $12,$16 485*4724848cSchristos xor $13,$17 486*4724848cSchristos xor $14,$18 487*4724848cSchristos xor $15,$19 488*4724848cSchristos#endif 489*4724848cSchristos xor $8,$12 490*4724848cSchristos xor $9,$13 491*4724848cSchristos xor $10,$14 492*4724848cSchristos xor $11,$15 493*4724848cSchristos 494*4724848cSchristos jr $31 495*4724848cSchristos.end _mips_AES_encrypt 496*4724848cSchristos 497*4724848cSchristos.align 5 498*4724848cSchristos.globl AES_encrypt 499*4724848cSchristos.ent AES_encrypt 500*4724848cSchristosAES_encrypt: 501*4724848cSchristos .frame $29,64,$31 502*4724848cSchristos .mask 0xc0ff0000,-4 503*4724848cSchristos .set noreorder 504*4724848cSchristos .cpload $25 505*4724848cSchristos subu $29,64 506*4724848cSchristos sw $31,64-1*4($29) 507*4724848cSchristos sw $30,64-2*4($29) 508*4724848cSchristos sw $23,64-3*4($29) 509*4724848cSchristos sw $22,64-4*4($29) 510*4724848cSchristos sw $21,64-5*4($29) 511*4724848cSchristos sw $20,64-6*4($29) 512*4724848cSchristos sw $19,64-7*4($29) 513*4724848cSchristos sw $18,64-8*4($29) 514*4724848cSchristos sw $17,64-9*4($29) 515*4724848cSchristos sw $16,64-10*4($29) 516*4724848cSchristos .set reorder 517*4724848cSchristos la $7,AES_Te # PIC-ified 'load address' 518*4724848cSchristos 519*4724848cSchristos#if defined(_MIPS_ARCH_MIPS32R6) || defined(_MIPS_ARCH_MIPS64R6) 520*4724848cSchristos lw $8,0($4) 521*4724848cSchristos lw $9,4($4) 522*4724848cSchristos lw $10,8($4) 523*4724848cSchristos lw $11,12($4) 524*4724848cSchristos#else 525*4724848cSchristos lwl $8,0+3($4) 526*4724848cSchristos lwl $9,4+3($4) 527*4724848cSchristos lwl $10,8+3($4) 528*4724848cSchristos lwl $11,12+3($4) 529*4724848cSchristos lwr $8,0+0($4) 530*4724848cSchristos lwr $9,4+0($4) 531*4724848cSchristos lwr $10,8+0($4) 532*4724848cSchristos lwr $11,12+0($4) 533*4724848cSchristos#endif 534*4724848cSchristos 535*4724848cSchristos bal _mips_AES_encrypt 536*4724848cSchristos 537*4724848cSchristos#if defined(_MIPS_ARCH_MIPS32R6) || defined(_MIPS_ARCH_MIPS64R6) 538*4724848cSchristos sw $8,0($5) 539*4724848cSchristos sw $9,4($5) 540*4724848cSchristos sw $10,8($5) 541*4724848cSchristos sw $11,12($5) 542*4724848cSchristos#else 543*4724848cSchristos swr $8,0+0($5) 544*4724848cSchristos swr $9,4+0($5) 545*4724848cSchristos swr $10,8+0($5) 546*4724848cSchristos swr $11,12+0($5) 547*4724848cSchristos swl $8,0+3($5) 548*4724848cSchristos swl $9,4+3($5) 549*4724848cSchristos swl $10,8+3($5) 550*4724848cSchristos swl $11,12+3($5) 551*4724848cSchristos#endif 552*4724848cSchristos 553*4724848cSchristos .set noreorder 554*4724848cSchristos lw $31,64-1*4($29) 555*4724848cSchristos lw $30,64-2*4($29) 556*4724848cSchristos lw $23,64-3*4($29) 557*4724848cSchristos lw $22,64-4*4($29) 558*4724848cSchristos lw $21,64-5*4($29) 559*4724848cSchristos lw $20,64-6*4($29) 560*4724848cSchristos lw $19,64-7*4($29) 561*4724848cSchristos lw $18,64-8*4($29) 562*4724848cSchristos lw $17,64-9*4($29) 563*4724848cSchristos lw $16,64-10*4($29) 564*4724848cSchristos jr $31 565*4724848cSchristos addu $29,64 566*4724848cSchristos.end AES_encrypt 567*4724848cSchristos.align 5 568*4724848cSchristos.ent _mips_AES_decrypt 569*4724848cSchristos_mips_AES_decrypt: 570*4724848cSchristos .frame $29,0,$31 571*4724848cSchristos .set reorder 572*4724848cSchristos lw $12,0($6) 573*4724848cSchristos lw $13,4($6) 574*4724848cSchristos lw $14,8($6) 575*4724848cSchristos lw $15,12($6) 576*4724848cSchristos lw $30,240($6) 577*4724848cSchristos addu $3,$6,16 578*4724848cSchristos 579*4724848cSchristos xor $8,$12 580*4724848cSchristos xor $9,$13 581*4724848cSchristos xor $10,$14 582*4724848cSchristos xor $11,$15 583*4724848cSchristos 584*4724848cSchristos subu $30,1 585*4724848cSchristos#if defined(__mips_smartmips) 586*4724848cSchristos ext $1,$11,8,8 587*4724848cSchristos.Loop_dec: 588*4724848cSchristos ext $2,$8,8,8 589*4724848cSchristos ext $24,$9,8,8 590*4724848cSchristos ext $25,$10,8,8 591*4724848cSchristos lwxs $12,$1($7) # Td1[s3>>16] 592*4724848cSchristos ext $1,$10,16,8 593*4724848cSchristos lwxs $13,$2($7) # Td1[s0>>16] 594*4724848cSchristos ext $2,$11,16,8 595*4724848cSchristos lwxs $14,$24($7) # Td1[s1>>16] 596*4724848cSchristos ext $24,$8,16,8 597*4724848cSchristos lwxs $15,$25($7) # Td1[s2>>16] 598*4724848cSchristos ext $25,$9,16,8 599*4724848cSchristos 600*4724848cSchristos lwxs $16,$1($7) # Td2[s2>>8] 601*4724848cSchristos ext $1,$9,24,8 602*4724848cSchristos lwxs $17,$2($7) # Td2[s3>>8] 603*4724848cSchristos ext $2,$10,24,8 604*4724848cSchristos lwxs $18,$24($7) # Td2[s0>>8] 605*4724848cSchristos ext $24,$11,24,8 606*4724848cSchristos lwxs $19,$25($7) # Td2[s1>>8] 607*4724848cSchristos ext $25,$8,24,8 608*4724848cSchristos 609*4724848cSchristos lwxs $20,$1($7) # Td3[s1] 610*4724848cSchristos ext $1,$8,0,8 611*4724848cSchristos lwxs $21,$2($7) # Td3[s2] 612*4724848cSchristos ext $2,$9,0,8 613*4724848cSchristos lwxs $22,$24($7) # Td3[s3] 614*4724848cSchristos ext $24,$10,0,8 615*4724848cSchristos lwxs $23,$25($7) # Td3[s0] 616*4724848cSchristos ext $25,$11,0,8 617*4724848cSchristos 618*4724848cSchristos rotr $12,$12,24 619*4724848cSchristos rotr $13,$13,24 620*4724848cSchristos rotr $14,$14,24 621*4724848cSchristos rotr $15,$15,24 622*4724848cSchristos 623*4724848cSchristos rotr $16,$16,16 624*4724848cSchristos rotr $17,$17,16 625*4724848cSchristos rotr $18,$18,16 626*4724848cSchristos rotr $19,$19,16 627*4724848cSchristos 628*4724848cSchristos xor $12,$16 629*4724848cSchristos lwxs $16,$1($7) # Td0[s0>>24] 630*4724848cSchristos xor $13,$17 631*4724848cSchristos lwxs $17,$2($7) # Td0[s1>>24] 632*4724848cSchristos xor $14,$18 633*4724848cSchristos lwxs $18,$24($7) # Td0[s2>>24] 634*4724848cSchristos xor $15,$19 635*4724848cSchristos lwxs $19,$25($7) # Td0[s3>>24] 636*4724848cSchristos 637*4724848cSchristos rotr $20,$20,8 638*4724848cSchristos lw $8,0($3) 639*4724848cSchristos rotr $21,$21,8 640*4724848cSchristos lw $9,4($3) 641*4724848cSchristos rotr $22,$22,8 642*4724848cSchristos lw $10,8($3) 643*4724848cSchristos rotr $23,$23,8 644*4724848cSchristos lw $11,12($3) 645*4724848cSchristos 646*4724848cSchristos xor $12,$20 647*4724848cSchristos xor $13,$21 648*4724848cSchristos xor $14,$22 649*4724848cSchristos xor $15,$23 650*4724848cSchristos 651*4724848cSchristos xor $12,$16 652*4724848cSchristos xor $13,$17 653*4724848cSchristos xor $14,$18 654*4724848cSchristos xor $15,$19 655*4724848cSchristos 656*4724848cSchristos subu $30,1 657*4724848cSchristos addu $3,16 658*4724848cSchristos xor $8,$12 659*4724848cSchristos xor $9,$13 660*4724848cSchristos xor $10,$14 661*4724848cSchristos xor $11,$15 662*4724848cSchristos .set noreorder 663*4724848cSchristos bnez $30,.Loop_dec 664*4724848cSchristos ext $1,$11,8,8 665*4724848cSchristos 666*4724848cSchristos srl $1,$11,6 667*4724848cSchristos#else 668*4724848cSchristos srl $1,$11,6 669*4724848cSchristos.Loop_dec: 670*4724848cSchristos srl $2,$8,6 671*4724848cSchristos srl $24,$9,6 672*4724848cSchristos srl $25,$10,6 673*4724848cSchristos and $1,0x3fc 674*4724848cSchristos and $2,0x3fc 675*4724848cSchristos and $24,0x3fc 676*4724848cSchristos and $25,0x3fc 677*4724848cSchristos addu $1,$7 678*4724848cSchristos addu $2,$7 679*4724848cSchristos addu $24,$7 680*4724848cSchristos addu $25,$7 681*4724848cSchristos#if defined(_MIPS_ARCH_MIPS32R2) || defined(_MIPS_ARCH_MIPS64R2) 682*4724848cSchristos lw $12,0($1) # Td1[s3>>16] 683*4724848cSchristos srl $1,$10,14 684*4724848cSchristos lw $13,0($2) # Td1[s0>>16] 685*4724848cSchristos srl $2,$11,14 686*4724848cSchristos lw $14,0($24) # Td1[s1>>16] 687*4724848cSchristos srl $24,$8,14 688*4724848cSchristos lw $15,0($25) # Td1[s2>>16] 689*4724848cSchristos srl $25,$9,14 690*4724848cSchristos#else 691*4724848cSchristos lwl $12,2($1) # Td1[s3>>16] 692*4724848cSchristos lwl $13,2($2) # Td1[s0>>16] 693*4724848cSchristos lwl $14,2($24) # Td1[s1>>16] 694*4724848cSchristos lwl $15,2($25) # Td1[s2>>16] 695*4724848cSchristos lwr $12,3($1) # Td1[s3>>16] 696*4724848cSchristos srl $1,$10,14 697*4724848cSchristos lwr $13,3($2) # Td1[s0>>16] 698*4724848cSchristos srl $2,$11,14 699*4724848cSchristos lwr $14,3($24) # Td1[s1>>16] 700*4724848cSchristos srl $24,$8,14 701*4724848cSchristos lwr $15,3($25) # Td1[s2>>16] 702*4724848cSchristos srl $25,$9,14 703*4724848cSchristos#endif 704*4724848cSchristos 705*4724848cSchristos and $1,0x3fc 706*4724848cSchristos and $2,0x3fc 707*4724848cSchristos and $24,0x3fc 708*4724848cSchristos and $25,0x3fc 709*4724848cSchristos addu $1,$7 710*4724848cSchristos addu $2,$7 711*4724848cSchristos addu $24,$7 712*4724848cSchristos addu $25,$7 713*4724848cSchristos#if defined(_MIPS_ARCH_MIPS32R2) || defined(_MIPS_ARCH_MIPS64R2) 714*4724848cSchristos rotr $12,$12,24 715*4724848cSchristos rotr $13,$13,24 716*4724848cSchristos rotr $14,$14,24 717*4724848cSchristos rotr $15,$15,24 718*4724848cSchristos# if defined(_MIPSEL) 719*4724848cSchristos lw $16,0($1) # Td2[s2>>8] 720*4724848cSchristos srl $1,$9,22 721*4724848cSchristos lw $17,0($2) # Td2[s3>>8] 722*4724848cSchristos srl $2,$10,22 723*4724848cSchristos lw $18,0($24) # Td2[s0>>8] 724*4724848cSchristos srl $24,$11,22 725*4724848cSchristos lw $19,0($25) # Td2[s1>>8] 726*4724848cSchristos srl $25,$8,22 727*4724848cSchristos 728*4724848cSchristos and $1,0x3fc 729*4724848cSchristos and $2,0x3fc 730*4724848cSchristos and $24,0x3fc 731*4724848cSchristos and $25,0x3fc 732*4724848cSchristos addu $1,$7 733*4724848cSchristos addu $2,$7 734*4724848cSchristos addu $24,$7 735*4724848cSchristos addu $25,$7 736*4724848cSchristos lw $20,0($1) # Td3[s1] 737*4724848cSchristos ins $1,$8,2,8 738*4724848cSchristos lw $21,0($2) # Td3[s2] 739*4724848cSchristos ins $2,$9,2,8 740*4724848cSchristos lw $22,0($24) # Td3[s3] 741*4724848cSchristos ins $24,$10,2,8 742*4724848cSchristos lw $23,0($25) # Td3[s0] 743*4724848cSchristos ins $25,$11,2,8 744*4724848cSchristos#else 745*4724848cSchristos lw $16,0($1) # Td2[s2>>8] 746*4724848cSchristos ins $1,$9,2,8 747*4724848cSchristos lw $17,0($2) # Td2[s3>>8] 748*4724848cSchristos ins $2,$10,2,8 749*4724848cSchristos lw $18,0($24) # Td2[s0>>8] 750*4724848cSchristos ins $24,$11,2,8 751*4724848cSchristos lw $19,0($25) # Td2[s1>>8] 752*4724848cSchristos ins $25,$8,2,8 753*4724848cSchristos 754*4724848cSchristos lw $20,0($1) # Td3[s1] 755*4724848cSchristos sll $1,$8,2 756*4724848cSchristos lw $21,0($2) # Td3[s2] 757*4724848cSchristos sll $2,$9,2 758*4724848cSchristos lw $22,0($24) # Td3[s3] 759*4724848cSchristos sll $24,$10,2 760*4724848cSchristos lw $23,0($25) # Td3[s0] 761*4724848cSchristos sll $25,$11,2 762*4724848cSchristos 763*4724848cSchristos and $1,0x3fc 764*4724848cSchristos and $2,0x3fc 765*4724848cSchristos and $24,0x3fc 766*4724848cSchristos and $25,0x3fc 767*4724848cSchristos addu $1,$7 768*4724848cSchristos addu $2,$7 769*4724848cSchristos addu $24,$7 770*4724848cSchristos addu $25,$7 771*4724848cSchristos#endif 772*4724848cSchristos rotr $16,$16,16 773*4724848cSchristos rotr $17,$17,16 774*4724848cSchristos rotr $18,$18,16 775*4724848cSchristos rotr $19,$19,16 776*4724848cSchristos 777*4724848cSchristos rotr $20,$20,8 778*4724848cSchristos rotr $21,$21,8 779*4724848cSchristos rotr $22,$22,8 780*4724848cSchristos rotr $23,$23,8 781*4724848cSchristos#else 782*4724848cSchristos lwl $16,1($1) # Td2[s2>>8] 783*4724848cSchristos lwl $17,1($2) # Td2[s3>>8] 784*4724848cSchristos lwl $18,1($24) # Td2[s0>>8] 785*4724848cSchristos lwl $19,1($25) # Td2[s1>>8] 786*4724848cSchristos lwr $16,2($1) # Td2[s2>>8] 787*4724848cSchristos srl $1,$9,22 788*4724848cSchristos lwr $17,2($2) # Td2[s3>>8] 789*4724848cSchristos srl $2,$10,22 790*4724848cSchristos lwr $18,2($24) # Td2[s0>>8] 791*4724848cSchristos srl $24,$11,22 792*4724848cSchristos lwr $19,2($25) # Td2[s1>>8] 793*4724848cSchristos srl $25,$8,22 794*4724848cSchristos 795*4724848cSchristos and $1,0x3fc 796*4724848cSchristos and $2,0x3fc 797*4724848cSchristos and $24,0x3fc 798*4724848cSchristos and $25,0x3fc 799*4724848cSchristos addu $1,$7 800*4724848cSchristos addu $2,$7 801*4724848cSchristos addu $24,$7 802*4724848cSchristos addu $25,$7 803*4724848cSchristos lwl $20,0($1) # Td3[s1] 804*4724848cSchristos lwl $21,0($2) # Td3[s2] 805*4724848cSchristos lwl $22,0($24) # Td3[s3] 806*4724848cSchristos lwl $23,0($25) # Td3[s0] 807*4724848cSchristos lwr $20,1($1) # Td3[s1] 808*4724848cSchristos sll $1,$8,2 809*4724848cSchristos lwr $21,1($2) # Td3[s2] 810*4724848cSchristos sll $2,$9,2 811*4724848cSchristos lwr $22,1($24) # Td3[s3] 812*4724848cSchristos sll $24,$10,2 813*4724848cSchristos lwr $23,1($25) # Td3[s0] 814*4724848cSchristos sll $25,$11,2 815*4724848cSchristos 816*4724848cSchristos and $1,0x3fc 817*4724848cSchristos and $2,0x3fc 818*4724848cSchristos and $24,0x3fc 819*4724848cSchristos and $25,0x3fc 820*4724848cSchristos addu $1,$7 821*4724848cSchristos addu $2,$7 822*4724848cSchristos addu $24,$7 823*4724848cSchristos addu $25,$7 824*4724848cSchristos#endif 825*4724848cSchristos 826*4724848cSchristos xor $12,$16 827*4724848cSchristos lw $16,0($1) # Td0[s0>>24] 828*4724848cSchristos xor $13,$17 829*4724848cSchristos lw $17,0($2) # Td0[s1>>24] 830*4724848cSchristos xor $14,$18 831*4724848cSchristos lw $18,0($24) # Td0[s2>>24] 832*4724848cSchristos xor $15,$19 833*4724848cSchristos lw $19,0($25) # Td0[s3>>24] 834*4724848cSchristos 835*4724848cSchristos xor $12,$20 836*4724848cSchristos lw $8,0($3) 837*4724848cSchristos xor $13,$21 838*4724848cSchristos lw $9,4($3) 839*4724848cSchristos xor $14,$22 840*4724848cSchristos lw $10,8($3) 841*4724848cSchristos xor $15,$23 842*4724848cSchristos lw $11,12($3) 843*4724848cSchristos 844*4724848cSchristos xor $12,$16 845*4724848cSchristos xor $13,$17 846*4724848cSchristos xor $14,$18 847*4724848cSchristos xor $15,$19 848*4724848cSchristos 849*4724848cSchristos subu $30,1 850*4724848cSchristos addu $3,16 851*4724848cSchristos xor $8,$12 852*4724848cSchristos xor $9,$13 853*4724848cSchristos xor $10,$14 854*4724848cSchristos xor $11,$15 855*4724848cSchristos .set noreorder 856*4724848cSchristos bnez $30,.Loop_dec 857*4724848cSchristos srl $1,$11,6 858*4724848cSchristos#endif 859*4724848cSchristos 860*4724848cSchristos .set reorder 861*4724848cSchristos lw $16,1024($7) # prefetch Td4 862*4724848cSchristos srl $1,$11,8 863*4724848cSchristos lw $17,1024+32($7) 864*4724848cSchristos srl $2,$8,8 865*4724848cSchristos lw $18,1024+64($7) 866*4724848cSchristos srl $24,$9,8 867*4724848cSchristos lw $19,1024+96($7) 868*4724848cSchristos srl $25,$10,8 869*4724848cSchristos lw $20,1024+128($7) 870*4724848cSchristos and $1,0xff 871*4724848cSchristos lw $21,1024+160($7) 872*4724848cSchristos and $2,0xff 873*4724848cSchristos lw $22,1024+192($7) 874*4724848cSchristos and $24,0xff 875*4724848cSchristos lw $23,1024+224($7) 876*4724848cSchristos and $25,0xff 877*4724848cSchristos 878*4724848cSchristos addu $1,$7 879*4724848cSchristos addu $2,$7 880*4724848cSchristos addu $24,$7 881*4724848cSchristos addu $25,$7 882*4724848cSchristos lbu $12,1024($1) # Td4[s3>>16] 883*4724848cSchristos srl $1,$10,16 884*4724848cSchristos lbu $13,1024($2) # Td4[s0>>16] 885*4724848cSchristos srl $2,$11,16 886*4724848cSchristos lbu $14,1024($24) # Td4[s1>>16] 887*4724848cSchristos srl $24,$8,16 888*4724848cSchristos lbu $15,1024($25) # Td4[s2>>16] 889*4724848cSchristos srl $25,$9,16 890*4724848cSchristos 891*4724848cSchristos and $1,0xff 892*4724848cSchristos and $2,0xff 893*4724848cSchristos and $24,0xff 894*4724848cSchristos and $25,0xff 895*4724848cSchristos addu $1,$7 896*4724848cSchristos addu $2,$7 897*4724848cSchristos addu $24,$7 898*4724848cSchristos addu $25,$7 899*4724848cSchristos#if defined(_MIPS_ARCH_MIPS32R2) || defined(_MIPS_ARCH_MIPS64R2) 900*4724848cSchristos# if defined(_MIPSEL) 901*4724848cSchristos lbu $16,1024($1) # Td4[s2>>8] 902*4724848cSchristos ins $1,$8,0,8 903*4724848cSchristos lbu $17,1024($2) # Td4[s3>>8] 904*4724848cSchristos ins $2,$9,0,8 905*4724848cSchristos lbu $18,1024($24) # Td4[s0>>8] 906*4724848cSchristos ins $24,$10,0,8 907*4724848cSchristos lbu $19,1024($25) # Td4[s1>>8] 908*4724848cSchristos ins $25,$11,0,8 909*4724848cSchristos 910*4724848cSchristos lbu $20,1024($1) # Td4[s0>>24] 911*4724848cSchristos srl $1,$9,24 912*4724848cSchristos lbu $21,1024($2) # Td4[s1>>24] 913*4724848cSchristos srl $2,$10,24 914*4724848cSchristos lbu $22,1024($24) # Td4[s2>>24] 915*4724848cSchristos srl $24,$11,24 916*4724848cSchristos lbu $23,1024($25) # Td4[s3>>24] 917*4724848cSchristos srl $25,$8,24 918*4724848cSchristos 919*4724848cSchristos addu $1,$7 920*4724848cSchristos addu $2,$7 921*4724848cSchristos addu $24,$7 922*4724848cSchristos addu $25,$7 923*4724848cSchristos# else 924*4724848cSchristos lbu $16,1024($1) # Td4[s2>>8] 925*4724848cSchristos and $1,$8,0xff 926*4724848cSchristos lbu $17,1024($2) # Td4[s3>>8] 927*4724848cSchristos and $2,$9,0xff 928*4724848cSchristos lbu $18,1024($24) # Td4[s0>>8] 929*4724848cSchristos and $24,$10,0xff 930*4724848cSchristos lbu $19,1024($25) # Td4[s1>>8] 931*4724848cSchristos and $25,$11,0xff 932*4724848cSchristos 933*4724848cSchristos addu $1,$7 934*4724848cSchristos addu $2,$7 935*4724848cSchristos addu $24,$7 936*4724848cSchristos addu $25,$7 937*4724848cSchristos lbu $20,1024($1) # Td4[s0>>24] 938*4724848cSchristos ins $1,$9,0,8 939*4724848cSchristos lbu $21,1024($2) # Td4[s1>>24] 940*4724848cSchristos ins $2,$10,0,8 941*4724848cSchristos lbu $22,1024($24) # Td4[s2>>24] 942*4724848cSchristos ins $24,$11,0,8 943*4724848cSchristos lbu $23,1024($25) # Td4[s3>>24] 944*4724848cSchristos ins $25,$8,0,8 945*4724848cSchristos# endif 946*4724848cSchristos sll $12,$12,8 947*4724848cSchristos sll $13,$13,8 948*4724848cSchristos sll $14,$14,8 949*4724848cSchristos sll $15,$15,8 950*4724848cSchristos 951*4724848cSchristos ins $12,$16,16,8 952*4724848cSchristos lbu $16,1024($1) # Td4[s1] 953*4724848cSchristos ins $13,$17,16,8 954*4724848cSchristos lbu $17,1024($2) # Td4[s2] 955*4724848cSchristos ins $14,$18,16,8 956*4724848cSchristos lbu $18,1024($24) # Td4[s3] 957*4724848cSchristos ins $15,$19,16,8 958*4724848cSchristos lbu $19,1024($25) # Td4[s0] 959*4724848cSchristos 960*4724848cSchristos ins $12,$20,0,8 961*4724848cSchristos lw $8,0($3) 962*4724848cSchristos ins $13,$21,0,8 963*4724848cSchristos lw $9,4($3) 964*4724848cSchristos ins $14,$22,0,8 965*4724848cSchristos lw $10,8($3) 966*4724848cSchristos ins $15,$23,0,8 967*4724848cSchristos lw $11,12($3) 968*4724848cSchristos 969*4724848cSchristos ins $12,$16,24,8 970*4724848cSchristos ins $13,$17,24,8 971*4724848cSchristos ins $14,$18,24,8 972*4724848cSchristos ins $15,$19,24,8 973*4724848cSchristos#else 974*4724848cSchristos lbu $16,1024($1) # Td4[s2>>8] 975*4724848cSchristos and $1,$8,0xff 976*4724848cSchristos lbu $17,1024($2) # Td4[s3>>8] 977*4724848cSchristos and $2,$9,0xff 978*4724848cSchristos lbu $18,1024($24) # Td4[s0>>8] 979*4724848cSchristos and $24,$10,0xff 980*4724848cSchristos lbu $19,1024($25) # Td4[s1>>8] 981*4724848cSchristos and $25,$11,0xff 982*4724848cSchristos 983*4724848cSchristos addu $1,$7 984*4724848cSchristos addu $2,$7 985*4724848cSchristos addu $24,$7 986*4724848cSchristos addu $25,$7 987*4724848cSchristos lbu $20,1024($1) # Td4[s0>>24] 988*4724848cSchristos srl $1,$9,24 989*4724848cSchristos lbu $21,1024($2) # Td4[s1>>24] 990*4724848cSchristos srl $2,$10,24 991*4724848cSchristos lbu $22,1024($24) # Td4[s2>>24] 992*4724848cSchristos srl $24,$11,24 993*4724848cSchristos lbu $23,1024($25) # Td4[s3>>24] 994*4724848cSchristos srl $25,$8,24 995*4724848cSchristos 996*4724848cSchristos addu $1,$7 997*4724848cSchristos addu $2,$7 998*4724848cSchristos addu $24,$7 999*4724848cSchristos addu $25,$7 1000*4724848cSchristos 1001*4724848cSchristos sll $12,$12,8 1002*4724848cSchristos sll $13,$13,8 1003*4724848cSchristos sll $14,$14,8 1004*4724848cSchristos sll $15,$15,8 1005*4724848cSchristos 1006*4724848cSchristos sll $16,$16,16 1007*4724848cSchristos sll $17,$17,16 1008*4724848cSchristos sll $18,$18,16 1009*4724848cSchristos sll $19,$19,16 1010*4724848cSchristos 1011*4724848cSchristos xor $12,$16 1012*4724848cSchristos lbu $16,1024($1) # Td4[s1] 1013*4724848cSchristos xor $13,$17 1014*4724848cSchristos lbu $17,1024($2) # Td4[s2] 1015*4724848cSchristos xor $14,$18 1016*4724848cSchristos lbu $18,1024($24) # Td4[s3] 1017*4724848cSchristos xor $15,$19 1018*4724848cSchristos lbu $19,1024($25) # Td4[s0] 1019*4724848cSchristos 1020*4724848cSchristos #sll $20,$20,0 1021*4724848cSchristos lw $8,0($3) 1022*4724848cSchristos #sll $21,$21,0 1023*4724848cSchristos lw $9,4($3) 1024*4724848cSchristos #sll $22,$22,0 1025*4724848cSchristos lw $10,8($3) 1026*4724848cSchristos #sll $23,$23,0 1027*4724848cSchristos lw $11,12($3) 1028*4724848cSchristos 1029*4724848cSchristos xor $12,$20 1030*4724848cSchristos xor $13,$21 1031*4724848cSchristos xor $14,$22 1032*4724848cSchristos xor $15,$23 1033*4724848cSchristos 1034*4724848cSchristos sll $16,$16,24 1035*4724848cSchristos sll $17,$17,24 1036*4724848cSchristos sll $18,$18,24 1037*4724848cSchristos sll $19,$19,24 1038*4724848cSchristos 1039*4724848cSchristos xor $12,$16 1040*4724848cSchristos xor $13,$17 1041*4724848cSchristos xor $14,$18 1042*4724848cSchristos xor $15,$19 1043*4724848cSchristos#endif 1044*4724848cSchristos 1045*4724848cSchristos xor $8,$12 1046*4724848cSchristos xor $9,$13 1047*4724848cSchristos xor $10,$14 1048*4724848cSchristos xor $11,$15 1049*4724848cSchristos 1050*4724848cSchristos jr $31 1051*4724848cSchristos.end _mips_AES_decrypt 1052*4724848cSchristos 1053*4724848cSchristos.align 5 1054*4724848cSchristos.globl AES_decrypt 1055*4724848cSchristos.ent AES_decrypt 1056*4724848cSchristosAES_decrypt: 1057*4724848cSchristos .frame $29,64,$31 1058*4724848cSchristos .mask 0xc0ff0000,-4 1059*4724848cSchristos .set noreorder 1060*4724848cSchristos .cpload $25 1061*4724848cSchristos subu $29,64 1062*4724848cSchristos sw $31,64-1*4($29) 1063*4724848cSchristos sw $30,64-2*4($29) 1064*4724848cSchristos sw $23,64-3*4($29) 1065*4724848cSchristos sw $22,64-4*4($29) 1066*4724848cSchristos sw $21,64-5*4($29) 1067*4724848cSchristos sw $20,64-6*4($29) 1068*4724848cSchristos sw $19,64-7*4($29) 1069*4724848cSchristos sw $18,64-8*4($29) 1070*4724848cSchristos sw $17,64-9*4($29) 1071*4724848cSchristos sw $16,64-10*4($29) 1072*4724848cSchristos .set reorder 1073*4724848cSchristos la $7,AES_Td # PIC-ified 'load address' 1074*4724848cSchristos 1075*4724848cSchristos#if defined(_MIPS_ARCH_MIPS32R6) || defined(_MIPS_ARCH_MIPS64R6) 1076*4724848cSchristos lw $8,0($4) 1077*4724848cSchristos lw $9,4($4) 1078*4724848cSchristos lw $10,8($4) 1079*4724848cSchristos lw $11,12($4) 1080*4724848cSchristos#else 1081*4724848cSchristos lwl $8,0+3($4) 1082*4724848cSchristos lwl $9,4+3($4) 1083*4724848cSchristos lwl $10,8+3($4) 1084*4724848cSchristos lwl $11,12+3($4) 1085*4724848cSchristos lwr $8,0+0($4) 1086*4724848cSchristos lwr $9,4+0($4) 1087*4724848cSchristos lwr $10,8+0($4) 1088*4724848cSchristos lwr $11,12+0($4) 1089*4724848cSchristos#endif 1090*4724848cSchristos 1091*4724848cSchristos bal _mips_AES_decrypt 1092*4724848cSchristos 1093*4724848cSchristos#if defined(_MIPS_ARCH_MIPS32R6) || defined(_MIPS_ARCH_MIPS64R6) 1094*4724848cSchristos sw $8,0($5) 1095*4724848cSchristos sw $9,4($5) 1096*4724848cSchristos sw $10,8($5) 1097*4724848cSchristos sw $11,12($5) 1098*4724848cSchristos#else 1099*4724848cSchristos swr $8,0+0($5) 1100*4724848cSchristos swr $9,4+0($5) 1101*4724848cSchristos swr $10,8+0($5) 1102*4724848cSchristos swr $11,12+0($5) 1103*4724848cSchristos swl $8,0+3($5) 1104*4724848cSchristos swl $9,4+3($5) 1105*4724848cSchristos swl $10,8+3($5) 1106*4724848cSchristos swl $11,12+3($5) 1107*4724848cSchristos#endif 1108*4724848cSchristos 1109*4724848cSchristos .set noreorder 1110*4724848cSchristos lw $31,64-1*4($29) 1111*4724848cSchristos lw $30,64-2*4($29) 1112*4724848cSchristos lw $23,64-3*4($29) 1113*4724848cSchristos lw $22,64-4*4($29) 1114*4724848cSchristos lw $21,64-5*4($29) 1115*4724848cSchristos lw $20,64-6*4($29) 1116*4724848cSchristos lw $19,64-7*4($29) 1117*4724848cSchristos lw $18,64-8*4($29) 1118*4724848cSchristos lw $17,64-9*4($29) 1119*4724848cSchristos lw $16,64-10*4($29) 1120*4724848cSchristos jr $31 1121*4724848cSchristos addu $29,64 1122*4724848cSchristos.end AES_decrypt 1123*4724848cSchristos.align 5 1124*4724848cSchristos.ent _mips_AES_set_encrypt_key 1125*4724848cSchristos_mips_AES_set_encrypt_key: 1126*4724848cSchristos .frame $29,0,$31 1127*4724848cSchristos .set noreorder 1128*4724848cSchristos beqz $4,.Lekey_done 1129*4724848cSchristos li $2,-1 1130*4724848cSchristos beqz $6,.Lekey_done 1131*4724848cSchristos addu $3,$7,256 1132*4724848cSchristos 1133*4724848cSchristos .set reorder 1134*4724848cSchristos#if defined(_MIPS_ARCH_MIPS32R6) || defined(_MIPS_ARCH_MIPS64R6) 1135*4724848cSchristos lw $8,0($4) # load 128 bits 1136*4724848cSchristos lw $9,4($4) 1137*4724848cSchristos lw $10,8($4) 1138*4724848cSchristos lw $11,12($4) 1139*4724848cSchristos#else 1140*4724848cSchristos lwl $8,0+3($4) # load 128 bits 1141*4724848cSchristos lwl $9,4+3($4) 1142*4724848cSchristos lwl $10,8+3($4) 1143*4724848cSchristos lwl $11,12+3($4) 1144*4724848cSchristos lwr $8,0+0($4) 1145*4724848cSchristos lwr $9,4+0($4) 1146*4724848cSchristos lwr $10,8+0($4) 1147*4724848cSchristos lwr $11,12+0($4) 1148*4724848cSchristos#endif 1149*4724848cSchristos li $1,128 1150*4724848cSchristos .set noreorder 1151*4724848cSchristos beq $5,$1,.L128bits 1152*4724848cSchristos li $30,10 1153*4724848cSchristos 1154*4724848cSchristos .set reorder 1155*4724848cSchristos#if defined(_MIPS_ARCH_MIPS32R6) || defined(_MIPS_ARCH_MIPS64R6) 1156*4724848cSchristos lw $12,16($4) # load 192 bits 1157*4724848cSchristos lw $13,20($4) 1158*4724848cSchristos#else 1159*4724848cSchristos lwl $12,16+3($4) # load 192 bits 1160*4724848cSchristos lwl $13,20+3($4) 1161*4724848cSchristos lwr $12,16+0($4) 1162*4724848cSchristos lwr $13,20+0($4) 1163*4724848cSchristos#endif 1164*4724848cSchristos li $1,192 1165*4724848cSchristos .set noreorder 1166*4724848cSchristos beq $5,$1,.L192bits 1167*4724848cSchristos li $30,8 1168*4724848cSchristos 1169*4724848cSchristos .set reorder 1170*4724848cSchristos#if defined(_MIPS_ARCH_MIPS32R6) || defined(_MIPS_ARCH_MIPS64R6) 1171*4724848cSchristos lw $14,24($4) # load 256 bits 1172*4724848cSchristos lw $15,28($4) 1173*4724848cSchristos#else 1174*4724848cSchristos lwl $14,24+3($4) # load 256 bits 1175*4724848cSchristos lwl $15,28+3($4) 1176*4724848cSchristos lwr $14,24+0($4) 1177*4724848cSchristos lwr $15,28+0($4) 1178*4724848cSchristos#endif 1179*4724848cSchristos li $1,256 1180*4724848cSchristos .set noreorder 1181*4724848cSchristos beq $5,$1,.L256bits 1182*4724848cSchristos li $30,7 1183*4724848cSchristos 1184*4724848cSchristos b .Lekey_done 1185*4724848cSchristos li $2,-2 1186*4724848cSchristos 1187*4724848cSchristos.align 4 1188*4724848cSchristos.L128bits: 1189*4724848cSchristos .set reorder 1190*4724848cSchristos srl $1,$11,16 1191*4724848cSchristos srl $2,$11,8 1192*4724848cSchristos and $1,0xff 1193*4724848cSchristos and $2,0xff 1194*4724848cSchristos and $24,$11,0xff 1195*4724848cSchristos srl $25,$11,24 1196*4724848cSchristos addu $1,$7 1197*4724848cSchristos addu $2,$7 1198*4724848cSchristos addu $24,$7 1199*4724848cSchristos addu $25,$7 1200*4724848cSchristos lbu $1,0($1) 1201*4724848cSchristos lbu $2,0($2) 1202*4724848cSchristos lbu $24,0($24) 1203*4724848cSchristos lbu $25,0($25) 1204*4724848cSchristos 1205*4724848cSchristos sw $8,0($6) 1206*4724848cSchristos sw $9,4($6) 1207*4724848cSchristos sw $10,8($6) 1208*4724848cSchristos sw $11,12($6) 1209*4724848cSchristos subu $30,1 1210*4724848cSchristos addu $6,16 1211*4724848cSchristos 1212*4724848cSchristos sll $1,$1,8 1213*4724848cSchristos #sll $2,$2,0 1214*4724848cSchristos sll $24,$24,24 1215*4724848cSchristos sll $25,$25,16 1216*4724848cSchristos 1217*4724848cSchristos xor $8,$1 1218*4724848cSchristos lw $1,0($3) 1219*4724848cSchristos xor $8,$2 1220*4724848cSchristos xor $8,$24 1221*4724848cSchristos xor $8,$25 1222*4724848cSchristos xor $8,$1 1223*4724848cSchristos 1224*4724848cSchristos xor $9,$8 1225*4724848cSchristos xor $10,$9 1226*4724848cSchristos xor $11,$10 1227*4724848cSchristos 1228*4724848cSchristos .set noreorder 1229*4724848cSchristos bnez $30,.L128bits 1230*4724848cSchristos addu $3,4 1231*4724848cSchristos 1232*4724848cSchristos sw $8,0($6) 1233*4724848cSchristos sw $9,4($6) 1234*4724848cSchristos sw $10,8($6) 1235*4724848cSchristos li $30,10 1236*4724848cSchristos sw $11,12($6) 1237*4724848cSchristos li $2,0 1238*4724848cSchristos sw $30,80($6) 1239*4724848cSchristos b .Lekey_done 1240*4724848cSchristos subu $6,10*16 1241*4724848cSchristos 1242*4724848cSchristos.align 4 1243*4724848cSchristos.L192bits: 1244*4724848cSchristos .set reorder 1245*4724848cSchristos srl $1,$13,16 1246*4724848cSchristos srl $2,$13,8 1247*4724848cSchristos and $1,0xff 1248*4724848cSchristos and $2,0xff 1249*4724848cSchristos and $24,$13,0xff 1250*4724848cSchristos srl $25,$13,24 1251*4724848cSchristos addu $1,$7 1252*4724848cSchristos addu $2,$7 1253*4724848cSchristos addu $24,$7 1254*4724848cSchristos addu $25,$7 1255*4724848cSchristos lbu $1,0($1) 1256*4724848cSchristos lbu $2,0($2) 1257*4724848cSchristos lbu $24,0($24) 1258*4724848cSchristos lbu $25,0($25) 1259*4724848cSchristos 1260*4724848cSchristos sw $8,0($6) 1261*4724848cSchristos sw $9,4($6) 1262*4724848cSchristos sw $10,8($6) 1263*4724848cSchristos sw $11,12($6) 1264*4724848cSchristos sw $12,16($6) 1265*4724848cSchristos sw $13,20($6) 1266*4724848cSchristos subu $30,1 1267*4724848cSchristos addu $6,24 1268*4724848cSchristos 1269*4724848cSchristos sll $1,$1,8 1270*4724848cSchristos #sll $2,$2,0 1271*4724848cSchristos sll $24,$24,24 1272*4724848cSchristos sll $25,$25,16 1273*4724848cSchristos 1274*4724848cSchristos xor $8,$1 1275*4724848cSchristos lw $1,0($3) 1276*4724848cSchristos xor $8,$2 1277*4724848cSchristos xor $8,$24 1278*4724848cSchristos xor $8,$25 1279*4724848cSchristos xor $8,$1 1280*4724848cSchristos 1281*4724848cSchristos xor $9,$8 1282*4724848cSchristos xor $10,$9 1283*4724848cSchristos xor $11,$10 1284*4724848cSchristos xor $12,$11 1285*4724848cSchristos xor $13,$12 1286*4724848cSchristos 1287*4724848cSchristos .set noreorder 1288*4724848cSchristos bnez $30,.L192bits 1289*4724848cSchristos addu $3,4 1290*4724848cSchristos 1291*4724848cSchristos sw $8,0($6) 1292*4724848cSchristos sw $9,4($6) 1293*4724848cSchristos sw $10,8($6) 1294*4724848cSchristos li $30,12 1295*4724848cSchristos sw $11,12($6) 1296*4724848cSchristos li $2,0 1297*4724848cSchristos sw $30,48($6) 1298*4724848cSchristos b .Lekey_done 1299*4724848cSchristos subu $6,12*16 1300*4724848cSchristos 1301*4724848cSchristos.align 4 1302*4724848cSchristos.L256bits: 1303*4724848cSchristos .set reorder 1304*4724848cSchristos srl $1,$15,16 1305*4724848cSchristos srl $2,$15,8 1306*4724848cSchristos and $1,0xff 1307*4724848cSchristos and $2,0xff 1308*4724848cSchristos and $24,$15,0xff 1309*4724848cSchristos srl $25,$15,24 1310*4724848cSchristos addu $1,$7 1311*4724848cSchristos addu $2,$7 1312*4724848cSchristos addu $24,$7 1313*4724848cSchristos addu $25,$7 1314*4724848cSchristos lbu $1,0($1) 1315*4724848cSchristos lbu $2,0($2) 1316*4724848cSchristos lbu $24,0($24) 1317*4724848cSchristos lbu $25,0($25) 1318*4724848cSchristos 1319*4724848cSchristos sw $8,0($6) 1320*4724848cSchristos sw $9,4($6) 1321*4724848cSchristos sw $10,8($6) 1322*4724848cSchristos sw $11,12($6) 1323*4724848cSchristos sw $12,16($6) 1324*4724848cSchristos sw $13,20($6) 1325*4724848cSchristos sw $14,24($6) 1326*4724848cSchristos sw $15,28($6) 1327*4724848cSchristos subu $30,1 1328*4724848cSchristos 1329*4724848cSchristos sll $1,$1,8 1330*4724848cSchristos #sll $2,$2,0 1331*4724848cSchristos sll $24,$24,24 1332*4724848cSchristos sll $25,$25,16 1333*4724848cSchristos 1334*4724848cSchristos xor $8,$1 1335*4724848cSchristos lw $1,0($3) 1336*4724848cSchristos xor $8,$2 1337*4724848cSchristos xor $8,$24 1338*4724848cSchristos xor $8,$25 1339*4724848cSchristos xor $8,$1 1340*4724848cSchristos 1341*4724848cSchristos xor $9,$8 1342*4724848cSchristos xor $10,$9 1343*4724848cSchristos xor $11,$10 1344*4724848cSchristos beqz $30,.L256bits_done 1345*4724848cSchristos 1346*4724848cSchristos srl $1,$11,24 1347*4724848cSchristos srl $2,$11,16 1348*4724848cSchristos srl $24,$11,8 1349*4724848cSchristos and $25,$11,0xff 1350*4724848cSchristos and $2,0xff 1351*4724848cSchristos and $24,0xff 1352*4724848cSchristos addu $1,$7 1353*4724848cSchristos addu $2,$7 1354*4724848cSchristos addu $24,$7 1355*4724848cSchristos addu $25,$7 1356*4724848cSchristos lbu $1,0($1) 1357*4724848cSchristos lbu $2,0($2) 1358*4724848cSchristos lbu $24,0($24) 1359*4724848cSchristos lbu $25,0($25) 1360*4724848cSchristos sll $1,24 1361*4724848cSchristos sll $2,16 1362*4724848cSchristos sll $24,8 1363*4724848cSchristos 1364*4724848cSchristos xor $12,$1 1365*4724848cSchristos xor $12,$2 1366*4724848cSchristos xor $12,$24 1367*4724848cSchristos xor $12,$25 1368*4724848cSchristos 1369*4724848cSchristos xor $13,$12 1370*4724848cSchristos xor $14,$13 1371*4724848cSchristos xor $15,$14 1372*4724848cSchristos 1373*4724848cSchristos addu $6,32 1374*4724848cSchristos .set noreorder 1375*4724848cSchristos b .L256bits 1376*4724848cSchristos addu $3,4 1377*4724848cSchristos 1378*4724848cSchristos.L256bits_done: 1379*4724848cSchristos sw $8,32($6) 1380*4724848cSchristos sw $9,36($6) 1381*4724848cSchristos sw $10,40($6) 1382*4724848cSchristos li $30,14 1383*4724848cSchristos sw $11,44($6) 1384*4724848cSchristos li $2,0 1385*4724848cSchristos sw $30,48($6) 1386*4724848cSchristos subu $6,12*16 1387*4724848cSchristos 1388*4724848cSchristos.Lekey_done: 1389*4724848cSchristos jr $31 1390*4724848cSchristos nop 1391*4724848cSchristos.end _mips_AES_set_encrypt_key 1392*4724848cSchristos 1393*4724848cSchristos.globl AES_set_encrypt_key 1394*4724848cSchristos.ent AES_set_encrypt_key 1395*4724848cSchristosAES_set_encrypt_key: 1396*4724848cSchristos .frame $29,32,$31 1397*4724848cSchristos .mask 0xc0000000,-4 1398*4724848cSchristos .set noreorder 1399*4724848cSchristos .cpload $25 1400*4724848cSchristos subu $29,32 1401*4724848cSchristos sw $31,32-1*4($29) 1402*4724848cSchristos sw $30,32-2*4($29) 1403*4724848cSchristos .set reorder 1404*4724848cSchristos la $7,AES_Te4 # PIC-ified 'load address' 1405*4724848cSchristos 1406*4724848cSchristos bal _mips_AES_set_encrypt_key 1407*4724848cSchristos 1408*4724848cSchristos .set noreorder 1409*4724848cSchristos move $4,$2 1410*4724848cSchristos lw $31,32-1*4($29) 1411*4724848cSchristos lw $30,32-2*4($29) 1412*4724848cSchristos jr $31 1413*4724848cSchristos addu $29,32 1414*4724848cSchristos.end AES_set_encrypt_key 1415*4724848cSchristos.align 5 1416*4724848cSchristos.globl AES_set_decrypt_key 1417*4724848cSchristos.ent AES_set_decrypt_key 1418*4724848cSchristosAES_set_decrypt_key: 1419*4724848cSchristos .frame $29,32,$31 1420*4724848cSchristos .mask 0xc0000000,-4 1421*4724848cSchristos .set noreorder 1422*4724848cSchristos .cpload $25 1423*4724848cSchristos subu $29,32 1424*4724848cSchristos sw $31,32-1*4($29) 1425*4724848cSchristos sw $30,32-2*4($29) 1426*4724848cSchristos .set reorder 1427*4724848cSchristos la $7,AES_Te4 # PIC-ified 'load address' 1428*4724848cSchristos 1429*4724848cSchristos bal _mips_AES_set_encrypt_key 1430*4724848cSchristos 1431*4724848cSchristos bltz $2,.Ldkey_done 1432*4724848cSchristos 1433*4724848cSchristos sll $1,$30,4 1434*4724848cSchristos addu $4,$6,0 1435*4724848cSchristos addu $5,$6,$1 1436*4724848cSchristos.align 4 1437*4724848cSchristos.Lswap: 1438*4724848cSchristos lw $8,0($4) 1439*4724848cSchristos lw $9,4($4) 1440*4724848cSchristos lw $10,8($4) 1441*4724848cSchristos lw $11,12($4) 1442*4724848cSchristos lw $12,0($5) 1443*4724848cSchristos lw $13,4($5) 1444*4724848cSchristos lw $14,8($5) 1445*4724848cSchristos lw $15,12($5) 1446*4724848cSchristos sw $8,0($5) 1447*4724848cSchristos sw $9,4($5) 1448*4724848cSchristos sw $10,8($5) 1449*4724848cSchristos sw $11,12($5) 1450*4724848cSchristos addu $4,16 1451*4724848cSchristos subu $5,16 1452*4724848cSchristos sw $12,-16($4) 1453*4724848cSchristos sw $13,-12($4) 1454*4724848cSchristos sw $14,-8($4) 1455*4724848cSchristos sw $15,-4($4) 1456*4724848cSchristos bne $4,$5,.Lswap 1457*4724848cSchristos 1458*4724848cSchristos lw $8,16($6) # modulo-scheduled 1459*4724848cSchristos lui $2,0x8080 1460*4724848cSchristos subu $30,1 1461*4724848cSchristos or $2,0x8080 1462*4724848cSchristos sll $30,2 1463*4724848cSchristos addu $6,16 1464*4724848cSchristos lui $25,0x1b1b 1465*4724848cSchristos nor $24,$0,$2 1466*4724848cSchristos or $25,0x1b1b 1467*4724848cSchristos.align 4 1468*4724848cSchristos.Lmix: 1469*4724848cSchristos and $1,$8,$2 1470*4724848cSchristos and $9,$8,$24 1471*4724848cSchristos srl $10,$1,7 1472*4724848cSchristos addu $9,$9 # tp2<<1 1473*4724848cSchristos subu $1,$10 1474*4724848cSchristos and $1,$25 1475*4724848cSchristos xor $9,$1 1476*4724848cSchristos 1477*4724848cSchristos and $1,$9,$2 1478*4724848cSchristos and $10,$9,$24 1479*4724848cSchristos srl $11,$1,7 1480*4724848cSchristos addu $10,$10 # tp4<<1 1481*4724848cSchristos subu $1,$11 1482*4724848cSchristos and $1,$25 1483*4724848cSchristos xor $10,$1 1484*4724848cSchristos 1485*4724848cSchristos and $1,$10,$2 1486*4724848cSchristos and $11,$10,$24 1487*4724848cSchristos srl $12,$1,7 1488*4724848cSchristos addu $11,$11 # tp8<<1 1489*4724848cSchristos subu $1,$12 1490*4724848cSchristos and $1,$25 1491*4724848cSchristos xor $11,$1 1492*4724848cSchristos 1493*4724848cSchristos xor $12,$11,$8 1494*4724848cSchristos xor $15,$11,$10 1495*4724848cSchristos xor $13,$12,$9 1496*4724848cSchristos xor $14,$12,$10 1497*4724848cSchristos 1498*4724848cSchristos#if defined(_MIPS_ARCH_MIPS32R2) || defined(_MIPS_ARCH_MIPS64R2) 1499*4724848cSchristos rotr $8,$14,16 1500*4724848cSchristos xor $15,$9 1501*4724848cSchristos rotr $9,$12,24 1502*4724848cSchristos xor $15,$8 1503*4724848cSchristos rotr $10,$13,8 1504*4724848cSchristos xor $15,$9 1505*4724848cSchristos lw $8,4($6) # modulo-scheduled 1506*4724848cSchristos xor $15,$10 1507*4724848cSchristos#else 1508*4724848cSchristos sll $8,$14,16 1509*4724848cSchristos xor $15,$9 1510*4724848cSchristos srl $9,$14,16 1511*4724848cSchristos xor $15,$8 1512*4724848cSchristos sll $8,$12,8 1513*4724848cSchristos xor $15,$9 1514*4724848cSchristos srl $9,$12,24 1515*4724848cSchristos xor $15,$8 1516*4724848cSchristos sll $8,$13,24 1517*4724848cSchristos xor $15,$9 1518*4724848cSchristos srl $9,$13,8 1519*4724848cSchristos xor $15,$8 1520*4724848cSchristos lw $8,4($6) # modulo-scheduled 1521*4724848cSchristos xor $15,$9 1522*4724848cSchristos#endif 1523*4724848cSchristos subu $30,1 1524*4724848cSchristos sw $15,0($6) 1525*4724848cSchristos addu $6,4 1526*4724848cSchristos bnez $30,.Lmix 1527*4724848cSchristos 1528*4724848cSchristos li $2,0 1529*4724848cSchristos.Ldkey_done: 1530*4724848cSchristos .set noreorder 1531*4724848cSchristos move $4,$2 1532*4724848cSchristos lw $31,32-1*4($29) 1533*4724848cSchristos lw $30,32-2*4($29) 1534*4724848cSchristos jr $31 1535*4724848cSchristos addu $29,32 1536*4724848cSchristos.end AES_set_decrypt_key 1537*4724848cSchristos.rdata 1538*4724848cSchristos.align 10 1539*4724848cSchristosAES_Te: 1540*4724848cSchristos.byte 0xc6,0x63,0x63,0xa5, 0xf8,0x7c,0x7c,0x84 # Te0 1541*4724848cSchristos.byte 0xee,0x77,0x77,0x99, 0xf6,0x7b,0x7b,0x8d 1542*4724848cSchristos.byte 0xff,0xf2,0xf2,0x0d, 0xd6,0x6b,0x6b,0xbd 1543*4724848cSchristos.byte 0xde,0x6f,0x6f,0xb1, 0x91,0xc5,0xc5,0x54 1544*4724848cSchristos.byte 0x60,0x30,0x30,0x50, 0x02,0x01,0x01,0x03 1545*4724848cSchristos.byte 0xce,0x67,0x67,0xa9, 0x56,0x2b,0x2b,0x7d 1546*4724848cSchristos.byte 0xe7,0xfe,0xfe,0x19, 0xb5,0xd7,0xd7,0x62 1547*4724848cSchristos.byte 0x4d,0xab,0xab,0xe6, 0xec,0x76,0x76,0x9a 1548*4724848cSchristos.byte 0x8f,0xca,0xca,0x45, 0x1f,0x82,0x82,0x9d 1549*4724848cSchristos.byte 0x89,0xc9,0xc9,0x40, 0xfa,0x7d,0x7d,0x87 1550*4724848cSchristos.byte 0xef,0xfa,0xfa,0x15, 0xb2,0x59,0x59,0xeb 1551*4724848cSchristos.byte 0x8e,0x47,0x47,0xc9, 0xfb,0xf0,0xf0,0x0b 1552*4724848cSchristos.byte 0x41,0xad,0xad,0xec, 0xb3,0xd4,0xd4,0x67 1553*4724848cSchristos.byte 0x5f,0xa2,0xa2,0xfd, 0x45,0xaf,0xaf,0xea 1554*4724848cSchristos.byte 0x23,0x9c,0x9c,0xbf, 0x53,0xa4,0xa4,0xf7 1555*4724848cSchristos.byte 0xe4,0x72,0x72,0x96, 0x9b,0xc0,0xc0,0x5b 1556*4724848cSchristos.byte 0x75,0xb7,0xb7,0xc2, 0xe1,0xfd,0xfd,0x1c 1557*4724848cSchristos.byte 0x3d,0x93,0x93,0xae, 0x4c,0x26,0x26,0x6a 1558*4724848cSchristos.byte 0x6c,0x36,0x36,0x5a, 0x7e,0x3f,0x3f,0x41 1559*4724848cSchristos.byte 0xf5,0xf7,0xf7,0x02, 0x83,0xcc,0xcc,0x4f 1560*4724848cSchristos.byte 0x68,0x34,0x34,0x5c, 0x51,0xa5,0xa5,0xf4 1561*4724848cSchristos.byte 0xd1,0xe5,0xe5,0x34, 0xf9,0xf1,0xf1,0x08 1562*4724848cSchristos.byte 0xe2,0x71,0x71,0x93, 0xab,0xd8,0xd8,0x73 1563*4724848cSchristos.byte 0x62,0x31,0x31,0x53, 0x2a,0x15,0x15,0x3f 1564*4724848cSchristos.byte 0x08,0x04,0x04,0x0c, 0x95,0xc7,0xc7,0x52 1565*4724848cSchristos.byte 0x46,0x23,0x23,0x65, 0x9d,0xc3,0xc3,0x5e 1566*4724848cSchristos.byte 0x30,0x18,0x18,0x28, 0x37,0x96,0x96,0xa1 1567*4724848cSchristos.byte 0x0a,0x05,0x05,0x0f, 0x2f,0x9a,0x9a,0xb5 1568*4724848cSchristos.byte 0x0e,0x07,0x07,0x09, 0x24,0x12,0x12,0x36 1569*4724848cSchristos.byte 0x1b,0x80,0x80,0x9b, 0xdf,0xe2,0xe2,0x3d 1570*4724848cSchristos.byte 0xcd,0xeb,0xeb,0x26, 0x4e,0x27,0x27,0x69 1571*4724848cSchristos.byte 0x7f,0xb2,0xb2,0xcd, 0xea,0x75,0x75,0x9f 1572*4724848cSchristos.byte 0x12,0x09,0x09,0x1b, 0x1d,0x83,0x83,0x9e 1573*4724848cSchristos.byte 0x58,0x2c,0x2c,0x74, 0x34,0x1a,0x1a,0x2e 1574*4724848cSchristos.byte 0x36,0x1b,0x1b,0x2d, 0xdc,0x6e,0x6e,0xb2 1575*4724848cSchristos.byte 0xb4,0x5a,0x5a,0xee, 0x5b,0xa0,0xa0,0xfb 1576*4724848cSchristos.byte 0xa4,0x52,0x52,0xf6, 0x76,0x3b,0x3b,0x4d 1577*4724848cSchristos.byte 0xb7,0xd6,0xd6,0x61, 0x7d,0xb3,0xb3,0xce 1578*4724848cSchristos.byte 0x52,0x29,0x29,0x7b, 0xdd,0xe3,0xe3,0x3e 1579*4724848cSchristos.byte 0x5e,0x2f,0x2f,0x71, 0x13,0x84,0x84,0x97 1580*4724848cSchristos.byte 0xa6,0x53,0x53,0xf5, 0xb9,0xd1,0xd1,0x68 1581*4724848cSchristos.byte 0x00,0x00,0x00,0x00, 0xc1,0xed,0xed,0x2c 1582*4724848cSchristos.byte 0x40,0x20,0x20,0x60, 0xe3,0xfc,0xfc,0x1f 1583*4724848cSchristos.byte 0x79,0xb1,0xb1,0xc8, 0xb6,0x5b,0x5b,0xed 1584*4724848cSchristos.byte 0xd4,0x6a,0x6a,0xbe, 0x8d,0xcb,0xcb,0x46 1585*4724848cSchristos.byte 0x67,0xbe,0xbe,0xd9, 0x72,0x39,0x39,0x4b 1586*4724848cSchristos.byte 0x94,0x4a,0x4a,0xde, 0x98,0x4c,0x4c,0xd4 1587*4724848cSchristos.byte 0xb0,0x58,0x58,0xe8, 0x85,0xcf,0xcf,0x4a 1588*4724848cSchristos.byte 0xbb,0xd0,0xd0,0x6b, 0xc5,0xef,0xef,0x2a 1589*4724848cSchristos.byte 0x4f,0xaa,0xaa,0xe5, 0xed,0xfb,0xfb,0x16 1590*4724848cSchristos.byte 0x86,0x43,0x43,0xc5, 0x9a,0x4d,0x4d,0xd7 1591*4724848cSchristos.byte 0x66,0x33,0x33,0x55, 0x11,0x85,0x85,0x94 1592*4724848cSchristos.byte 0x8a,0x45,0x45,0xcf, 0xe9,0xf9,0xf9,0x10 1593*4724848cSchristos.byte 0x04,0x02,0x02,0x06, 0xfe,0x7f,0x7f,0x81 1594*4724848cSchristos.byte 0xa0,0x50,0x50,0xf0, 0x78,0x3c,0x3c,0x44 1595*4724848cSchristos.byte 0x25,0x9f,0x9f,0xba, 0x4b,0xa8,0xa8,0xe3 1596*4724848cSchristos.byte 0xa2,0x51,0x51,0xf3, 0x5d,0xa3,0xa3,0xfe 1597*4724848cSchristos.byte 0x80,0x40,0x40,0xc0, 0x05,0x8f,0x8f,0x8a 1598*4724848cSchristos.byte 0x3f,0x92,0x92,0xad, 0x21,0x9d,0x9d,0xbc 1599*4724848cSchristos.byte 0x70,0x38,0x38,0x48, 0xf1,0xf5,0xf5,0x04 1600*4724848cSchristos.byte 0x63,0xbc,0xbc,0xdf, 0x77,0xb6,0xb6,0xc1 1601*4724848cSchristos.byte 0xaf,0xda,0xda,0x75, 0x42,0x21,0x21,0x63 1602*4724848cSchristos.byte 0x20,0x10,0x10,0x30, 0xe5,0xff,0xff,0x1a 1603*4724848cSchristos.byte 0xfd,0xf3,0xf3,0x0e, 0xbf,0xd2,0xd2,0x6d 1604*4724848cSchristos.byte 0x81,0xcd,0xcd,0x4c, 0x18,0x0c,0x0c,0x14 1605*4724848cSchristos.byte 0x26,0x13,0x13,0x35, 0xc3,0xec,0xec,0x2f 1606*4724848cSchristos.byte 0xbe,0x5f,0x5f,0xe1, 0x35,0x97,0x97,0xa2 1607*4724848cSchristos.byte 0x88,0x44,0x44,0xcc, 0x2e,0x17,0x17,0x39 1608*4724848cSchristos.byte 0x93,0xc4,0xc4,0x57, 0x55,0xa7,0xa7,0xf2 1609*4724848cSchristos.byte 0xfc,0x7e,0x7e,0x82, 0x7a,0x3d,0x3d,0x47 1610*4724848cSchristos.byte 0xc8,0x64,0x64,0xac, 0xba,0x5d,0x5d,0xe7 1611*4724848cSchristos.byte 0x32,0x19,0x19,0x2b, 0xe6,0x73,0x73,0x95 1612*4724848cSchristos.byte 0xc0,0x60,0x60,0xa0, 0x19,0x81,0x81,0x98 1613*4724848cSchristos.byte 0x9e,0x4f,0x4f,0xd1, 0xa3,0xdc,0xdc,0x7f 1614*4724848cSchristos.byte 0x44,0x22,0x22,0x66, 0x54,0x2a,0x2a,0x7e 1615*4724848cSchristos.byte 0x3b,0x90,0x90,0xab, 0x0b,0x88,0x88,0x83 1616*4724848cSchristos.byte 0x8c,0x46,0x46,0xca, 0xc7,0xee,0xee,0x29 1617*4724848cSchristos.byte 0x6b,0xb8,0xb8,0xd3, 0x28,0x14,0x14,0x3c 1618*4724848cSchristos.byte 0xa7,0xde,0xde,0x79, 0xbc,0x5e,0x5e,0xe2 1619*4724848cSchristos.byte 0x16,0x0b,0x0b,0x1d, 0xad,0xdb,0xdb,0x76 1620*4724848cSchristos.byte 0xdb,0xe0,0xe0,0x3b, 0x64,0x32,0x32,0x56 1621*4724848cSchristos.byte 0x74,0x3a,0x3a,0x4e, 0x14,0x0a,0x0a,0x1e 1622*4724848cSchristos.byte 0x92,0x49,0x49,0xdb, 0x0c,0x06,0x06,0x0a 1623*4724848cSchristos.byte 0x48,0x24,0x24,0x6c, 0xb8,0x5c,0x5c,0xe4 1624*4724848cSchristos.byte 0x9f,0xc2,0xc2,0x5d, 0xbd,0xd3,0xd3,0x6e 1625*4724848cSchristos.byte 0x43,0xac,0xac,0xef, 0xc4,0x62,0x62,0xa6 1626*4724848cSchristos.byte 0x39,0x91,0x91,0xa8, 0x31,0x95,0x95,0xa4 1627*4724848cSchristos.byte 0xd3,0xe4,0xe4,0x37, 0xf2,0x79,0x79,0x8b 1628*4724848cSchristos.byte 0xd5,0xe7,0xe7,0x32, 0x8b,0xc8,0xc8,0x43 1629*4724848cSchristos.byte 0x6e,0x37,0x37,0x59, 0xda,0x6d,0x6d,0xb7 1630*4724848cSchristos.byte 0x01,0x8d,0x8d,0x8c, 0xb1,0xd5,0xd5,0x64 1631*4724848cSchristos.byte 0x9c,0x4e,0x4e,0xd2, 0x49,0xa9,0xa9,0xe0 1632*4724848cSchristos.byte 0xd8,0x6c,0x6c,0xb4, 0xac,0x56,0x56,0xfa 1633*4724848cSchristos.byte 0xf3,0xf4,0xf4,0x07, 0xcf,0xea,0xea,0x25 1634*4724848cSchristos.byte 0xca,0x65,0x65,0xaf, 0xf4,0x7a,0x7a,0x8e 1635*4724848cSchristos.byte 0x47,0xae,0xae,0xe9, 0x10,0x08,0x08,0x18 1636*4724848cSchristos.byte 0x6f,0xba,0xba,0xd5, 0xf0,0x78,0x78,0x88 1637*4724848cSchristos.byte 0x4a,0x25,0x25,0x6f, 0x5c,0x2e,0x2e,0x72 1638*4724848cSchristos.byte 0x38,0x1c,0x1c,0x24, 0x57,0xa6,0xa6,0xf1 1639*4724848cSchristos.byte 0x73,0xb4,0xb4,0xc7, 0x97,0xc6,0xc6,0x51 1640*4724848cSchristos.byte 0xcb,0xe8,0xe8,0x23, 0xa1,0xdd,0xdd,0x7c 1641*4724848cSchristos.byte 0xe8,0x74,0x74,0x9c, 0x3e,0x1f,0x1f,0x21 1642*4724848cSchristos.byte 0x96,0x4b,0x4b,0xdd, 0x61,0xbd,0xbd,0xdc 1643*4724848cSchristos.byte 0x0d,0x8b,0x8b,0x86, 0x0f,0x8a,0x8a,0x85 1644*4724848cSchristos.byte 0xe0,0x70,0x70,0x90, 0x7c,0x3e,0x3e,0x42 1645*4724848cSchristos.byte 0x71,0xb5,0xb5,0xc4, 0xcc,0x66,0x66,0xaa 1646*4724848cSchristos.byte 0x90,0x48,0x48,0xd8, 0x06,0x03,0x03,0x05 1647*4724848cSchristos.byte 0xf7,0xf6,0xf6,0x01, 0x1c,0x0e,0x0e,0x12 1648*4724848cSchristos.byte 0xc2,0x61,0x61,0xa3, 0x6a,0x35,0x35,0x5f 1649*4724848cSchristos.byte 0xae,0x57,0x57,0xf9, 0x69,0xb9,0xb9,0xd0 1650*4724848cSchristos.byte 0x17,0x86,0x86,0x91, 0x99,0xc1,0xc1,0x58 1651*4724848cSchristos.byte 0x3a,0x1d,0x1d,0x27, 0x27,0x9e,0x9e,0xb9 1652*4724848cSchristos.byte 0xd9,0xe1,0xe1,0x38, 0xeb,0xf8,0xf8,0x13 1653*4724848cSchristos.byte 0x2b,0x98,0x98,0xb3, 0x22,0x11,0x11,0x33 1654*4724848cSchristos.byte 0xd2,0x69,0x69,0xbb, 0xa9,0xd9,0xd9,0x70 1655*4724848cSchristos.byte 0x07,0x8e,0x8e,0x89, 0x33,0x94,0x94,0xa7 1656*4724848cSchristos.byte 0x2d,0x9b,0x9b,0xb6, 0x3c,0x1e,0x1e,0x22 1657*4724848cSchristos.byte 0x15,0x87,0x87,0x92, 0xc9,0xe9,0xe9,0x20 1658*4724848cSchristos.byte 0x87,0xce,0xce,0x49, 0xaa,0x55,0x55,0xff 1659*4724848cSchristos.byte 0x50,0x28,0x28,0x78, 0xa5,0xdf,0xdf,0x7a 1660*4724848cSchristos.byte 0x03,0x8c,0x8c,0x8f, 0x59,0xa1,0xa1,0xf8 1661*4724848cSchristos.byte 0x09,0x89,0x89,0x80, 0x1a,0x0d,0x0d,0x17 1662*4724848cSchristos.byte 0x65,0xbf,0xbf,0xda, 0xd7,0xe6,0xe6,0x31 1663*4724848cSchristos.byte 0x84,0x42,0x42,0xc6, 0xd0,0x68,0x68,0xb8 1664*4724848cSchristos.byte 0x82,0x41,0x41,0xc3, 0x29,0x99,0x99,0xb0 1665*4724848cSchristos.byte 0x5a,0x2d,0x2d,0x77, 0x1e,0x0f,0x0f,0x11 1666*4724848cSchristos.byte 0x7b,0xb0,0xb0,0xcb, 0xa8,0x54,0x54,0xfc 1667*4724848cSchristos.byte 0x6d,0xbb,0xbb,0xd6, 0x2c,0x16,0x16,0x3a 1668*4724848cSchristos 1669*4724848cSchristosAES_Td: 1670*4724848cSchristos.byte 0x51,0xf4,0xa7,0x50, 0x7e,0x41,0x65,0x53 # Td0 1671*4724848cSchristos.byte 0x1a,0x17,0xa4,0xc3, 0x3a,0x27,0x5e,0x96 1672*4724848cSchristos.byte 0x3b,0xab,0x6b,0xcb, 0x1f,0x9d,0x45,0xf1 1673*4724848cSchristos.byte 0xac,0xfa,0x58,0xab, 0x4b,0xe3,0x03,0x93 1674*4724848cSchristos.byte 0x20,0x30,0xfa,0x55, 0xad,0x76,0x6d,0xf6 1675*4724848cSchristos.byte 0x88,0xcc,0x76,0x91, 0xf5,0x02,0x4c,0x25 1676*4724848cSchristos.byte 0x4f,0xe5,0xd7,0xfc, 0xc5,0x2a,0xcb,0xd7 1677*4724848cSchristos.byte 0x26,0x35,0x44,0x80, 0xb5,0x62,0xa3,0x8f 1678*4724848cSchristos.byte 0xde,0xb1,0x5a,0x49, 0x25,0xba,0x1b,0x67 1679*4724848cSchristos.byte 0x45,0xea,0x0e,0x98, 0x5d,0xfe,0xc0,0xe1 1680*4724848cSchristos.byte 0xc3,0x2f,0x75,0x02, 0x81,0x4c,0xf0,0x12 1681*4724848cSchristos.byte 0x8d,0x46,0x97,0xa3, 0x6b,0xd3,0xf9,0xc6 1682*4724848cSchristos.byte 0x03,0x8f,0x5f,0xe7, 0x15,0x92,0x9c,0x95 1683*4724848cSchristos.byte 0xbf,0x6d,0x7a,0xeb, 0x95,0x52,0x59,0xda 1684*4724848cSchristos.byte 0xd4,0xbe,0x83,0x2d, 0x58,0x74,0x21,0xd3 1685*4724848cSchristos.byte 0x49,0xe0,0x69,0x29, 0x8e,0xc9,0xc8,0x44 1686*4724848cSchristos.byte 0x75,0xc2,0x89,0x6a, 0xf4,0x8e,0x79,0x78 1687*4724848cSchristos.byte 0x99,0x58,0x3e,0x6b, 0x27,0xb9,0x71,0xdd 1688*4724848cSchristos.byte 0xbe,0xe1,0x4f,0xb6, 0xf0,0x88,0xad,0x17 1689*4724848cSchristos.byte 0xc9,0x20,0xac,0x66, 0x7d,0xce,0x3a,0xb4 1690*4724848cSchristos.byte 0x63,0xdf,0x4a,0x18, 0xe5,0x1a,0x31,0x82 1691*4724848cSchristos.byte 0x97,0x51,0x33,0x60, 0x62,0x53,0x7f,0x45 1692*4724848cSchristos.byte 0xb1,0x64,0x77,0xe0, 0xbb,0x6b,0xae,0x84 1693*4724848cSchristos.byte 0xfe,0x81,0xa0,0x1c, 0xf9,0x08,0x2b,0x94 1694*4724848cSchristos.byte 0x70,0x48,0x68,0x58, 0x8f,0x45,0xfd,0x19 1695*4724848cSchristos.byte 0x94,0xde,0x6c,0x87, 0x52,0x7b,0xf8,0xb7 1696*4724848cSchristos.byte 0xab,0x73,0xd3,0x23, 0x72,0x4b,0x02,0xe2 1697*4724848cSchristos.byte 0xe3,0x1f,0x8f,0x57, 0x66,0x55,0xab,0x2a 1698*4724848cSchristos.byte 0xb2,0xeb,0x28,0x07, 0x2f,0xb5,0xc2,0x03 1699*4724848cSchristos.byte 0x86,0xc5,0x7b,0x9a, 0xd3,0x37,0x08,0xa5 1700*4724848cSchristos.byte 0x30,0x28,0x87,0xf2, 0x23,0xbf,0xa5,0xb2 1701*4724848cSchristos.byte 0x02,0x03,0x6a,0xba, 0xed,0x16,0x82,0x5c 1702*4724848cSchristos.byte 0x8a,0xcf,0x1c,0x2b, 0xa7,0x79,0xb4,0x92 1703*4724848cSchristos.byte 0xf3,0x07,0xf2,0xf0, 0x4e,0x69,0xe2,0xa1 1704*4724848cSchristos.byte 0x65,0xda,0xf4,0xcd, 0x06,0x05,0xbe,0xd5 1705*4724848cSchristos.byte 0xd1,0x34,0x62,0x1f, 0xc4,0xa6,0xfe,0x8a 1706*4724848cSchristos.byte 0x34,0x2e,0x53,0x9d, 0xa2,0xf3,0x55,0xa0 1707*4724848cSchristos.byte 0x05,0x8a,0xe1,0x32, 0xa4,0xf6,0xeb,0x75 1708*4724848cSchristos.byte 0x0b,0x83,0xec,0x39, 0x40,0x60,0xef,0xaa 1709*4724848cSchristos.byte 0x5e,0x71,0x9f,0x06, 0xbd,0x6e,0x10,0x51 1710*4724848cSchristos.byte 0x3e,0x21,0x8a,0xf9, 0x96,0xdd,0x06,0x3d 1711*4724848cSchristos.byte 0xdd,0x3e,0x05,0xae, 0x4d,0xe6,0xbd,0x46 1712*4724848cSchristos.byte 0x91,0x54,0x8d,0xb5, 0x71,0xc4,0x5d,0x05 1713*4724848cSchristos.byte 0x04,0x06,0xd4,0x6f, 0x60,0x50,0x15,0xff 1714*4724848cSchristos.byte 0x19,0x98,0xfb,0x24, 0xd6,0xbd,0xe9,0x97 1715*4724848cSchristos.byte 0x89,0x40,0x43,0xcc, 0x67,0xd9,0x9e,0x77 1716*4724848cSchristos.byte 0xb0,0xe8,0x42,0xbd, 0x07,0x89,0x8b,0x88 1717*4724848cSchristos.byte 0xe7,0x19,0x5b,0x38, 0x79,0xc8,0xee,0xdb 1718*4724848cSchristos.byte 0xa1,0x7c,0x0a,0x47, 0x7c,0x42,0x0f,0xe9 1719*4724848cSchristos.byte 0xf8,0x84,0x1e,0xc9, 0x00,0x00,0x00,0x00 1720*4724848cSchristos.byte 0x09,0x80,0x86,0x83, 0x32,0x2b,0xed,0x48 1721*4724848cSchristos.byte 0x1e,0x11,0x70,0xac, 0x6c,0x5a,0x72,0x4e 1722*4724848cSchristos.byte 0xfd,0x0e,0xff,0xfb, 0x0f,0x85,0x38,0x56 1723*4724848cSchristos.byte 0x3d,0xae,0xd5,0x1e, 0x36,0x2d,0x39,0x27 1724*4724848cSchristos.byte 0x0a,0x0f,0xd9,0x64, 0x68,0x5c,0xa6,0x21 1725*4724848cSchristos.byte 0x9b,0x5b,0x54,0xd1, 0x24,0x36,0x2e,0x3a 1726*4724848cSchristos.byte 0x0c,0x0a,0x67,0xb1, 0x93,0x57,0xe7,0x0f 1727*4724848cSchristos.byte 0xb4,0xee,0x96,0xd2, 0x1b,0x9b,0x91,0x9e 1728*4724848cSchristos.byte 0x80,0xc0,0xc5,0x4f, 0x61,0xdc,0x20,0xa2 1729*4724848cSchristos.byte 0x5a,0x77,0x4b,0x69, 0x1c,0x12,0x1a,0x16 1730*4724848cSchristos.byte 0xe2,0x93,0xba,0x0a, 0xc0,0xa0,0x2a,0xe5 1731*4724848cSchristos.byte 0x3c,0x22,0xe0,0x43, 0x12,0x1b,0x17,0x1d 1732*4724848cSchristos.byte 0x0e,0x09,0x0d,0x0b, 0xf2,0x8b,0xc7,0xad 1733*4724848cSchristos.byte 0x2d,0xb6,0xa8,0xb9, 0x14,0x1e,0xa9,0xc8 1734*4724848cSchristos.byte 0x57,0xf1,0x19,0x85, 0xaf,0x75,0x07,0x4c 1735*4724848cSchristos.byte 0xee,0x99,0xdd,0xbb, 0xa3,0x7f,0x60,0xfd 1736*4724848cSchristos.byte 0xf7,0x01,0x26,0x9f, 0x5c,0x72,0xf5,0xbc 1737*4724848cSchristos.byte 0x44,0x66,0x3b,0xc5, 0x5b,0xfb,0x7e,0x34 1738*4724848cSchristos.byte 0x8b,0x43,0x29,0x76, 0xcb,0x23,0xc6,0xdc 1739*4724848cSchristos.byte 0xb6,0xed,0xfc,0x68, 0xb8,0xe4,0xf1,0x63 1740*4724848cSchristos.byte 0xd7,0x31,0xdc,0xca, 0x42,0x63,0x85,0x10 1741*4724848cSchristos.byte 0x13,0x97,0x22,0x40, 0x84,0xc6,0x11,0x20 1742*4724848cSchristos.byte 0x85,0x4a,0x24,0x7d, 0xd2,0xbb,0x3d,0xf8 1743*4724848cSchristos.byte 0xae,0xf9,0x32,0x11, 0xc7,0x29,0xa1,0x6d 1744*4724848cSchristos.byte 0x1d,0x9e,0x2f,0x4b, 0xdc,0xb2,0x30,0xf3 1745*4724848cSchristos.byte 0x0d,0x86,0x52,0xec, 0x77,0xc1,0xe3,0xd0 1746*4724848cSchristos.byte 0x2b,0xb3,0x16,0x6c, 0xa9,0x70,0xb9,0x99 1747*4724848cSchristos.byte 0x11,0x94,0x48,0xfa, 0x47,0xe9,0x64,0x22 1748*4724848cSchristos.byte 0xa8,0xfc,0x8c,0xc4, 0xa0,0xf0,0x3f,0x1a 1749*4724848cSchristos.byte 0x56,0x7d,0x2c,0xd8, 0x22,0x33,0x90,0xef 1750*4724848cSchristos.byte 0x87,0x49,0x4e,0xc7, 0xd9,0x38,0xd1,0xc1 1751*4724848cSchristos.byte 0x8c,0xca,0xa2,0xfe, 0x98,0xd4,0x0b,0x36 1752*4724848cSchristos.byte 0xa6,0xf5,0x81,0xcf, 0xa5,0x7a,0xde,0x28 1753*4724848cSchristos.byte 0xda,0xb7,0x8e,0x26, 0x3f,0xad,0xbf,0xa4 1754*4724848cSchristos.byte 0x2c,0x3a,0x9d,0xe4, 0x50,0x78,0x92,0x0d 1755*4724848cSchristos.byte 0x6a,0x5f,0xcc,0x9b, 0x54,0x7e,0x46,0x62 1756*4724848cSchristos.byte 0xf6,0x8d,0x13,0xc2, 0x90,0xd8,0xb8,0xe8 1757*4724848cSchristos.byte 0x2e,0x39,0xf7,0x5e, 0x82,0xc3,0xaf,0xf5 1758*4724848cSchristos.byte 0x9f,0x5d,0x80,0xbe, 0x69,0xd0,0x93,0x7c 1759*4724848cSchristos.byte 0x6f,0xd5,0x2d,0xa9, 0xcf,0x25,0x12,0xb3 1760*4724848cSchristos.byte 0xc8,0xac,0x99,0x3b, 0x10,0x18,0x7d,0xa7 1761*4724848cSchristos.byte 0xe8,0x9c,0x63,0x6e, 0xdb,0x3b,0xbb,0x7b 1762*4724848cSchristos.byte 0xcd,0x26,0x78,0x09, 0x6e,0x59,0x18,0xf4 1763*4724848cSchristos.byte 0xec,0x9a,0xb7,0x01, 0x83,0x4f,0x9a,0xa8 1764*4724848cSchristos.byte 0xe6,0x95,0x6e,0x65, 0xaa,0xff,0xe6,0x7e 1765*4724848cSchristos.byte 0x21,0xbc,0xcf,0x08, 0xef,0x15,0xe8,0xe6 1766*4724848cSchristos.byte 0xba,0xe7,0x9b,0xd9, 0x4a,0x6f,0x36,0xce 1767*4724848cSchristos.byte 0xea,0x9f,0x09,0xd4, 0x29,0xb0,0x7c,0xd6 1768*4724848cSchristos.byte 0x31,0xa4,0xb2,0xaf, 0x2a,0x3f,0x23,0x31 1769*4724848cSchristos.byte 0xc6,0xa5,0x94,0x30, 0x35,0xa2,0x66,0xc0 1770*4724848cSchristos.byte 0x74,0x4e,0xbc,0x37, 0xfc,0x82,0xca,0xa6 1771*4724848cSchristos.byte 0xe0,0x90,0xd0,0xb0, 0x33,0xa7,0xd8,0x15 1772*4724848cSchristos.byte 0xf1,0x04,0x98,0x4a, 0x41,0xec,0xda,0xf7 1773*4724848cSchristos.byte 0x7f,0xcd,0x50,0x0e, 0x17,0x91,0xf6,0x2f 1774*4724848cSchristos.byte 0x76,0x4d,0xd6,0x8d, 0x43,0xef,0xb0,0x4d 1775*4724848cSchristos.byte 0xcc,0xaa,0x4d,0x54, 0xe4,0x96,0x04,0xdf 1776*4724848cSchristos.byte 0x9e,0xd1,0xb5,0xe3, 0x4c,0x6a,0x88,0x1b 1777*4724848cSchristos.byte 0xc1,0x2c,0x1f,0xb8, 0x46,0x65,0x51,0x7f 1778*4724848cSchristos.byte 0x9d,0x5e,0xea,0x04, 0x01,0x8c,0x35,0x5d 1779*4724848cSchristos.byte 0xfa,0x87,0x74,0x73, 0xfb,0x0b,0x41,0x2e 1780*4724848cSchristos.byte 0xb3,0x67,0x1d,0x5a, 0x92,0xdb,0xd2,0x52 1781*4724848cSchristos.byte 0xe9,0x10,0x56,0x33, 0x6d,0xd6,0x47,0x13 1782*4724848cSchristos.byte 0x9a,0xd7,0x61,0x8c, 0x37,0xa1,0x0c,0x7a 1783*4724848cSchristos.byte 0x59,0xf8,0x14,0x8e, 0xeb,0x13,0x3c,0x89 1784*4724848cSchristos.byte 0xce,0xa9,0x27,0xee, 0xb7,0x61,0xc9,0x35 1785*4724848cSchristos.byte 0xe1,0x1c,0xe5,0xed, 0x7a,0x47,0xb1,0x3c 1786*4724848cSchristos.byte 0x9c,0xd2,0xdf,0x59, 0x55,0xf2,0x73,0x3f 1787*4724848cSchristos.byte 0x18,0x14,0xce,0x79, 0x73,0xc7,0x37,0xbf 1788*4724848cSchristos.byte 0x53,0xf7,0xcd,0xea, 0x5f,0xfd,0xaa,0x5b 1789*4724848cSchristos.byte 0xdf,0x3d,0x6f,0x14, 0x78,0x44,0xdb,0x86 1790*4724848cSchristos.byte 0xca,0xaf,0xf3,0x81, 0xb9,0x68,0xc4,0x3e 1791*4724848cSchristos.byte 0x38,0x24,0x34,0x2c, 0xc2,0xa3,0x40,0x5f 1792*4724848cSchristos.byte 0x16,0x1d,0xc3,0x72, 0xbc,0xe2,0x25,0x0c 1793*4724848cSchristos.byte 0x28,0x3c,0x49,0x8b, 0xff,0x0d,0x95,0x41 1794*4724848cSchristos.byte 0x39,0xa8,0x01,0x71, 0x08,0x0c,0xb3,0xde 1795*4724848cSchristos.byte 0xd8,0xb4,0xe4,0x9c, 0x64,0x56,0xc1,0x90 1796*4724848cSchristos.byte 0x7b,0xcb,0x84,0x61, 0xd5,0x32,0xb6,0x70 1797*4724848cSchristos.byte 0x48,0x6c,0x5c,0x74, 0xd0,0xb8,0x57,0x42 1798*4724848cSchristos 1799*4724848cSchristos.byte 0x52, 0x09, 0x6a, 0xd5, 0x30, 0x36, 0xa5, 0x38 # Td4 1800*4724848cSchristos.byte 0xbf, 0x40, 0xa3, 0x9e, 0x81, 0xf3, 0xd7, 0xfb 1801*4724848cSchristos.byte 0x7c, 0xe3, 0x39, 0x82, 0x9b, 0x2f, 0xff, 0x87 1802*4724848cSchristos.byte 0x34, 0x8e, 0x43, 0x44, 0xc4, 0xde, 0xe9, 0xcb 1803*4724848cSchristos.byte 0x54, 0x7b, 0x94, 0x32, 0xa6, 0xc2, 0x23, 0x3d 1804*4724848cSchristos.byte 0xee, 0x4c, 0x95, 0x0b, 0x42, 0xfa, 0xc3, 0x4e 1805*4724848cSchristos.byte 0x08, 0x2e, 0xa1, 0x66, 0x28, 0xd9, 0x24, 0xb2 1806*4724848cSchristos.byte 0x76, 0x5b, 0xa2, 0x49, 0x6d, 0x8b, 0xd1, 0x25 1807*4724848cSchristos.byte 0x72, 0xf8, 0xf6, 0x64, 0x86, 0x68, 0x98, 0x16 1808*4724848cSchristos.byte 0xd4, 0xa4, 0x5c, 0xcc, 0x5d, 0x65, 0xb6, 0x92 1809*4724848cSchristos.byte 0x6c, 0x70, 0x48, 0x50, 0xfd, 0xed, 0xb9, 0xda 1810*4724848cSchristos.byte 0x5e, 0x15, 0x46, 0x57, 0xa7, 0x8d, 0x9d, 0x84 1811*4724848cSchristos.byte 0x90, 0xd8, 0xab, 0x00, 0x8c, 0xbc, 0xd3, 0x0a 1812*4724848cSchristos.byte 0xf7, 0xe4, 0x58, 0x05, 0xb8, 0xb3, 0x45, 0x06 1813*4724848cSchristos.byte 0xd0, 0x2c, 0x1e, 0x8f, 0xca, 0x3f, 0x0f, 0x02 1814*4724848cSchristos.byte 0xc1, 0xaf, 0xbd, 0x03, 0x01, 0x13, 0x8a, 0x6b 1815*4724848cSchristos.byte 0x3a, 0x91, 0x11, 0x41, 0x4f, 0x67, 0xdc, 0xea 1816*4724848cSchristos.byte 0x97, 0xf2, 0xcf, 0xce, 0xf0, 0xb4, 0xe6, 0x73 1817*4724848cSchristos.byte 0x96, 0xac, 0x74, 0x22, 0xe7, 0xad, 0x35, 0x85 1818*4724848cSchristos.byte 0xe2, 0xf9, 0x37, 0xe8, 0x1c, 0x75, 0xdf, 0x6e 1819*4724848cSchristos.byte 0x47, 0xf1, 0x1a, 0x71, 0x1d, 0x29, 0xc5, 0x89 1820*4724848cSchristos.byte 0x6f, 0xb7, 0x62, 0x0e, 0xaa, 0x18, 0xbe, 0x1b 1821*4724848cSchristos.byte 0xfc, 0x56, 0x3e, 0x4b, 0xc6, 0xd2, 0x79, 0x20 1822*4724848cSchristos.byte 0x9a, 0xdb, 0xc0, 0xfe, 0x78, 0xcd, 0x5a, 0xf4 1823*4724848cSchristos.byte 0x1f, 0xdd, 0xa8, 0x33, 0x88, 0x07, 0xc7, 0x31 1824*4724848cSchristos.byte 0xb1, 0x12, 0x10, 0x59, 0x27, 0x80, 0xec, 0x5f 1825*4724848cSchristos.byte 0x60, 0x51, 0x7f, 0xa9, 0x19, 0xb5, 0x4a, 0x0d 1826*4724848cSchristos.byte 0x2d, 0xe5, 0x7a, 0x9f, 0x93, 0xc9, 0x9c, 0xef 1827*4724848cSchristos.byte 0xa0, 0xe0, 0x3b, 0x4d, 0xae, 0x2a, 0xf5, 0xb0 1828*4724848cSchristos.byte 0xc8, 0xeb, 0xbb, 0x3c, 0x83, 0x53, 0x99, 0x61 1829*4724848cSchristos.byte 0x17, 0x2b, 0x04, 0x7e, 0xba, 0x77, 0xd6, 0x26 1830*4724848cSchristos.byte 0xe1, 0x69, 0x14, 0x63, 0x55, 0x21, 0x0c, 0x7d 1831*4724848cSchristos 1832*4724848cSchristosAES_Te4: 1833*4724848cSchristos.byte 0x63, 0x7c, 0x77, 0x7b, 0xf2, 0x6b, 0x6f, 0xc5 # Te4 1834*4724848cSchristos.byte 0x30, 0x01, 0x67, 0x2b, 0xfe, 0xd7, 0xab, 0x76 1835*4724848cSchristos.byte 0xca, 0x82, 0xc9, 0x7d, 0xfa, 0x59, 0x47, 0xf0 1836*4724848cSchristos.byte 0xad, 0xd4, 0xa2, 0xaf, 0x9c, 0xa4, 0x72, 0xc0 1837*4724848cSchristos.byte 0xb7, 0xfd, 0x93, 0x26, 0x36, 0x3f, 0xf7, 0xcc 1838*4724848cSchristos.byte 0x34, 0xa5, 0xe5, 0xf1, 0x71, 0xd8, 0x31, 0x15 1839*4724848cSchristos.byte 0x04, 0xc7, 0x23, 0xc3, 0x18, 0x96, 0x05, 0x9a 1840*4724848cSchristos.byte 0x07, 0x12, 0x80, 0xe2, 0xeb, 0x27, 0xb2, 0x75 1841*4724848cSchristos.byte 0x09, 0x83, 0x2c, 0x1a, 0x1b, 0x6e, 0x5a, 0xa0 1842*4724848cSchristos.byte 0x52, 0x3b, 0xd6, 0xb3, 0x29, 0xe3, 0x2f, 0x84 1843*4724848cSchristos.byte 0x53, 0xd1, 0x00, 0xed, 0x20, 0xfc, 0xb1, 0x5b 1844*4724848cSchristos.byte 0x6a, 0xcb, 0xbe, 0x39, 0x4a, 0x4c, 0x58, 0xcf 1845*4724848cSchristos.byte 0xd0, 0xef, 0xaa, 0xfb, 0x43, 0x4d, 0x33, 0x85 1846*4724848cSchristos.byte 0x45, 0xf9, 0x02, 0x7f, 0x50, 0x3c, 0x9f, 0xa8 1847*4724848cSchristos.byte 0x51, 0xa3, 0x40, 0x8f, 0x92, 0x9d, 0x38, 0xf5 1848*4724848cSchristos.byte 0xbc, 0xb6, 0xda, 0x21, 0x10, 0xff, 0xf3, 0xd2 1849*4724848cSchristos.byte 0xcd, 0x0c, 0x13, 0xec, 0x5f, 0x97, 0x44, 0x17 1850*4724848cSchristos.byte 0xc4, 0xa7, 0x7e, 0x3d, 0x64, 0x5d, 0x19, 0x73 1851*4724848cSchristos.byte 0x60, 0x81, 0x4f, 0xdc, 0x22, 0x2a, 0x90, 0x88 1852*4724848cSchristos.byte 0x46, 0xee, 0xb8, 0x14, 0xde, 0x5e, 0x0b, 0xdb 1853*4724848cSchristos.byte 0xe0, 0x32, 0x3a, 0x0a, 0x49, 0x06, 0x24, 0x5c 1854*4724848cSchristos.byte 0xc2, 0xd3, 0xac, 0x62, 0x91, 0x95, 0xe4, 0x79 1855*4724848cSchristos.byte 0xe7, 0xc8, 0x37, 0x6d, 0x8d, 0xd5, 0x4e, 0xa9 1856*4724848cSchristos.byte 0x6c, 0x56, 0xf4, 0xea, 0x65, 0x7a, 0xae, 0x08 1857*4724848cSchristos.byte 0xba, 0x78, 0x25, 0x2e, 0x1c, 0xa6, 0xb4, 0xc6 1858*4724848cSchristos.byte 0xe8, 0xdd, 0x74, 0x1f, 0x4b, 0xbd, 0x8b, 0x8a 1859*4724848cSchristos.byte 0x70, 0x3e, 0xb5, 0x66, 0x48, 0x03, 0xf6, 0x0e 1860*4724848cSchristos.byte 0x61, 0x35, 0x57, 0xb9, 0x86, 0xc1, 0x1d, 0x9e 1861*4724848cSchristos.byte 0xe1, 0xf8, 0x98, 0x11, 0x69, 0xd9, 0x8e, 0x94 1862*4724848cSchristos.byte 0x9b, 0x1e, 0x87, 0xe9, 0xce, 0x55, 0x28, 0xdf 1863*4724848cSchristos.byte 0x8c, 0xa1, 0x89, 0x0d, 0xbf, 0xe6, 0x42, 0x68 1864*4724848cSchristos.byte 0x41, 0x99, 0x2d, 0x0f, 0xb0, 0x54, 0xbb, 0x16 1865*4724848cSchristos 1866*4724848cSchristos.byte 0x01,0x00,0x00,0x00, 0x02,0x00,0x00,0x00 # rcon 1867*4724848cSchristos.byte 0x04,0x00,0x00,0x00, 0x08,0x00,0x00,0x00 1868*4724848cSchristos.byte 0x10,0x00,0x00,0x00, 0x20,0x00,0x00,0x00 1869*4724848cSchristos.byte 0x40,0x00,0x00,0x00, 0x80,0x00,0x00,0x00 1870*4724848cSchristos.byte 0x1B,0x00,0x00,0x00, 0x36,0x00,0x00,0x00 1871