// BEGIN Generated code -- do not edit // Generated by aarch64-asmtest.py Label back, forth; __ bind(back); // ArithOp __ add(r26, r23, r13, Assembler::LSL, 32); // add x26, x23, x13, LSL #32 __ sub(r12, r24, r9, Assembler::LSR, 37); // sub x12, x24, x9, LSR #37 __ adds(r28, r15, r8, Assembler::ASR, 39); // adds x28, x15, x8, ASR #39 __ subs(r7, r28, r30, Assembler::ASR, 57); // subs x7, x28, x30, ASR #57 __ addw(r9, r22, r27, Assembler::ASR, 15); // add w9, w22, w27, ASR #15 __ subw(r3, r13, r17, Assembler::ASR, 30); // sub w3, w13, w17, ASR #30 __ addsw(r14, r26, r8, Assembler::ASR, 17); // adds w14, w26, w8, ASR #17 __ subsw(r0, r22, r12, Assembler::ASR, 21); // subs w0, w22, w12, ASR #21 __ andr(r0, r15, r26, Assembler::LSL, 20); // and x0, x15, x26, LSL #20 __ orr(r26, r5, r17, Assembler::LSL, 61); // orr x26, x5, x17, LSL #61 __ eor(r24, r13, r2, Assembler::LSL, 32); // eor x24, x13, x2, LSL #32 __ ands(r28, r3, r17, Assembler::ASR, 35); // ands x28, x3, x17, ASR #35 __ andw(r25, r16, r29, Assembler::LSR, 18); // and w25, w16, w29, LSR #18 __ orrw(r13, r17, r11, Assembler::LSR, 9); // orr w13, w17, w11, LSR #9 __ eorw(r5, r5, r17, Assembler::LSR, 15); // eor w5, w5, w17, LSR #15 __ andsw(r2, r23, r27, Assembler::ASR, 26); // ands w2, w23, w27, ASR #26 __ bic(r27, r28, r16, Assembler::LSR, 45); // bic x27, x28, x16, LSR #45 __ orn(r8, r25, r26, Assembler::ASR, 37); // orn x8, x25, x26, ASR #37 __ eon(r29, r17, r13, Assembler::LSR, 63); // eon x29, x17, x13, LSR #63 __ bics(r28, r24, r2, Assembler::LSR, 31); // bics x28, x24, x2, LSR #31 __ bicw(r19, r26, r7, Assembler::ASR, 3); // bic w19, w26, w7, ASR #3 __ ornw(r6, r24, r10, Assembler::ASR, 3); // orn w6, w24, w10, ASR #3 __ eonw(r4, r21, r1, Assembler::LSR, 29); // eon w4, w21, w1, LSR #29 __ bicsw(r16, r21, r0, Assembler::LSR, 19); // bics w16, w21, w0, LSR #19 // AddSubImmOp __ addw(r17, r12, 379u); // add w17, w12, #379 __ addsw(r30, r1, 22u); // adds w30, w1, #22 __ subw(r29, r5, 126u); // sub w29, w5, #126 __ subsw(r6, r24, 960u); // subs w6, w24, #960 __ add(r0, r13, 104u); // add x0, x13, #104 __ adds(r8, r6, 663u); // adds x8, x6, #663 __ sub(r10, r5, 516u); // sub x10, x5, #516 __ subs(r1, r3, 1012u); // subs x1, x3, #1012 // LogicalImmOp __ andw(r6, r11, 4294049777ull); // and w6, w11, #0xfff1fff1 __ orrw(r28, r5, 4294966791ull); // orr w28, w5, #0xfffffe07 __ eorw(r1, r20, 134217216ull); // eor w1, w20, #0x7fffe00 __ andsw(r7, r17, 1048576ull); // ands w7, w17, #0x100000 __ andr(r14, r12, 9223372036854775808ull); // and x14, x12, #0x8000000000000000 __ orr(r9, r11, 562675075514368ull); // orr x9, x11, #0x1ffc000000000 __ eor(r17, r0, 18014398509481728ull); // eor x17, x0, #0x3fffffffffff00 __ ands(r1, r8, 18446744073705357315ull); // ands x1, x8, #0xffffffffffc00003 // AbsOp __ b(__ pc()); // b . __ b(back); // b back __ b(forth); // b forth __ bl(__ pc()); // bl . __ bl(back); // bl back __ bl(forth); // bl forth // RegAndAbsOp __ cbzw(r10, __ pc()); // cbz w10, . __ cbzw(r10, back); // cbz w10, back __ cbzw(r10, forth); // cbz w10, forth __ cbnzw(r8, __ pc()); // cbnz w8, . __ cbnzw(r8, back); // cbnz w8, back __ cbnzw(r8, forth); // cbnz w8, forth __ cbz(r11, __ pc()); // cbz x11, . __ cbz(r11, back); // cbz x11, back __ cbz(r11, forth); // cbz x11, forth __ cbnz(r29, __ pc()); // cbnz x29, . __ cbnz(r29, back); // cbnz x29, back __ cbnz(r29, forth); // cbnz x29, forth __ adr(r19, __ pc()); // adr x19, . __ adr(r19, back); // adr x19, back __ adr(r19, forth); // adr x19, forth __ _adrp(r19, __ pc()); // adrp x19, . // RegImmAbsOp __ tbz(r22, 6, __ pc()); // tbz x22, #6, . __ tbz(r22, 6, back); // tbz x22, #6, back __ tbz(r22, 6, forth); // tbz x22, #6, forth __ tbnz(r12, 11, __ pc()); // tbnz x12, #11, . __ tbnz(r12, 11, back); // tbnz x12, #11, back __ tbnz(r12, 11, forth); // tbnz x12, #11, forth // MoveWideImmOp __ movnw(r0, 6301, 0); // movn w0, #6301, lsl 0 __ movzw(r7, 20886, 0); // movz w7, #20886, lsl 0 __ movkw(r27, 18617, 0); // movk w27, #18617, lsl 0 __ movn(r12, 22998, 16); // movn x12, #22998, lsl 16 __ movz(r20, 1532, 16); // movz x20, #1532, lsl 16 __ movk(r8, 5167, 32); // movk x8, #5167, lsl 32 // BitfieldOp __ sbfm(r15, r17, 24, 28); // sbfm x15, x17, #24, #28 __ bfmw(r15, r9, 14, 25); // bfm w15, w9, #14, #25 __ ubfmw(r27, r25, 6, 31); // ubfm w27, w25, #6, #31 __ sbfm(r19, r2, 23, 31); // sbfm x19, x2, #23, #31 __ bfm(r12, r21, 10, 6); // bfm x12, x21, #10, #6 __ ubfm(r22, r0, 26, 16); // ubfm x22, x0, #26, #16 // ExtractOp __ extrw(r3, r3, r20, 27); // extr w3, w3, w20, #27 __ extr(r8, r30, r3, 54); // extr x8, x30, x3, #54 // CondBranchOp __ br(Assembler::EQ, __ pc()); // b.EQ . __ br(Assembler::EQ, back); // b.EQ back __ br(Assembler::EQ, forth); // b.EQ forth __ br(Assembler::NE, __ pc()); // b.NE . __ br(Assembler::NE, back); // b.NE back __ br(Assembler::NE, forth); // b.NE forth __ br(Assembler::HS, __ pc()); // b.HS . __ br(Assembler::HS, back); // b.HS back __ br(Assembler::HS, forth); // b.HS forth __ br(Assembler::CS, __ pc()); // b.CS . __ br(Assembler::CS, back); // b.CS back __ br(Assembler::CS, forth); // b.CS forth __ br(Assembler::LO, __ pc()); // b.LO . __ br(Assembler::LO, back); // b.LO back __ br(Assembler::LO, forth); // b.LO forth __ br(Assembler::CC, __ pc()); // b.CC . __ br(Assembler::CC, back); // b.CC back __ br(Assembler::CC, forth); // b.CC forth __ br(Assembler::MI, __ pc()); // b.MI . __ br(Assembler::MI, back); // b.MI back __ br(Assembler::MI, forth); // b.MI forth __ br(Assembler::PL, __ pc()); // b.PL . __ br(Assembler::PL, back); // b.PL back __ br(Assembler::PL, forth); // b.PL forth __ br(Assembler::VS, __ pc()); // b.VS . __ br(Assembler::VS, back); // b.VS back __ br(Assembler::VS, forth); // b.VS forth __ br(Assembler::VC, __ pc()); // b.VC . __ br(Assembler::VC, back); // b.VC back __ br(Assembler::VC, forth); // b.VC forth __ br(Assembler::HI, __ pc()); // b.HI . __ br(Assembler::HI, back); // b.HI back __ br(Assembler::HI, forth); // b.HI forth __ br(Assembler::LS, __ pc()); // b.LS . __ br(Assembler::LS, back); // b.LS back __ br(Assembler::LS, forth); // b.LS forth __ br(Assembler::GE, __ pc()); // b.GE . __ br(Assembler::GE, back); // b.GE back __ br(Assembler::GE, forth); // b.GE forth __ br(Assembler::LT, __ pc()); // b.LT . __ br(Assembler::LT, back); // b.LT back __ br(Assembler::LT, forth); // b.LT forth __ br(Assembler::GT, __ pc()); // b.GT . __ br(Assembler::GT, back); // b.GT back __ br(Assembler::GT, forth); // b.GT forth __ br(Assembler::LE, __ pc()); // b.LE . __ br(Assembler::LE, back); // b.LE back __ br(Assembler::LE, forth); // b.LE forth __ br(Assembler::AL, __ pc()); // b.AL . __ br(Assembler::AL, back); // b.AL back __ br(Assembler::AL, forth); // b.AL forth __ br(Assembler::NV, __ pc()); // b.NV . __ br(Assembler::NV, back); // b.NV back __ br(Assembler::NV, forth); // b.NV forth // ImmOp __ svc(12999); // svc #12999 __ hvc(2665); // hvc #2665 __ smc(9002); // smc #9002 __ brk(14843); // brk #14843 __ hlt(25964); // hlt #25964 // Op __ nop(); // nop __ eret(); // eret __ drps(); // drps __ isb(); // isb // SystemOp __ dsb(Assembler::ST); // dsb ST __ dmb(Assembler::OSHST); // dmb OSHST // OneRegOp __ br(r16); // br x16 __ blr(r20); // blr x20 // LoadStoreExclusiveOp __ stxr(r10, r27, r8); // stxr w10, x27, [x8] __ stlxr(r0, r1, r21); // stlxr w0, x1, [x21] __ ldxr(r17, r29); // ldxr x17, [x29] __ ldaxr(r29, r28); // ldaxr x29, [x28] __ stlr(r1, r23); // stlr x1, [x23] __ ldar(r21, r20); // ldar x21, [x20] // LoadStoreExclusiveOp __ stxrw(r22, r27, r19); // stxr w22, w27, [x19] __ stlxrw(r11, r16, r6); // stlxr w11, w16, [x6] __ ldxrw(r17, r0); // ldxr w17, [x0] __ ldaxrw(r4, r10); // ldaxr w4, [x10] __ stlrw(r24, r22); // stlr w24, [x22] __ ldarw(r10, r19); // ldar w10, [x19] // LoadStoreExclusiveOp __ stxrh(r1, r5, r30); // stxrh w1, w5, [x30] __ stlxrh(r8, r12, r17); // stlxrh w8, w12, [x17] __ ldxrh(r9, r14); // ldxrh w9, [x14] __ ldaxrh(r7, r1); // ldaxrh w7, [x1] __ stlrh(r5, r16); // stlrh w5, [x16] __ ldarh(r2, r12); // ldarh w2, [x12] // LoadStoreExclusiveOp __ stxrb(r10, r12, r3); // stxrb w10, w12, [x3] __ stlxrb(r28, r14, r26); // stlxrb w28, w14, [x26] __ ldxrb(r30, r10); // ldxrb w30, [x10] __ ldaxrb(r14, r21); // ldaxrb w14, [x21] __ stlrb(r13, r9); // stlrb w13, [x9] __ ldarb(r22, r27); // ldarb w22, [x27] // LoadStoreExclusiveOp __ ldxp(r28, r19, r11); // ldxp x28, x19, [x11] __ ldaxp(r30, r19, r2); // ldaxp x30, x19, [x2] __ stxp(r2, r23, r1, r0); // stxp w2, x23, x1, [x0] __ stlxp(r12, r16, r13, r15); // stlxp w12, x16, x13, [x15] // LoadStoreExclusiveOp __ ldxpw(r17, r21, r13); // ldxp w17, w21, [x13] __ ldaxpw(r11, r30, r8); // ldaxp w11, w30, [x8] __ stxpw(r24, r13, r11, r1); // stxp w24, w13, w11, [x1] __ stlxpw(r26, r21, r27, r13); // stlxp w26, w21, w27, [x13] // base_plus_unscaled_offset // LoadStoreOp __ str(r11, Address(r20, -103)); // str x11, [x20, -103] __ strw(r28, Address(r16, 62)); // str w28, [x16, 62] __ strb(r27, Address(r9, -9)); // strb w27, [x9, -9] __ strh(r2, Address(r25, -50)); // strh w2, [x25, -50] __ ldr(r4, Address(r2, -241)); // ldr x4, [x2, -241] __ ldrw(r30, Address(r20, -31)); // ldr w30, [x20, -31] __ ldrb(r17, Address(r23, -23)); // ldrb w17, [x23, -23] __ ldrh(r29, Address(r26, -1)); // ldrh w29, [x26, -1] __ ldrsb(r1, Address(r9, 6)); // ldrsb x1, [x9, 6] __ ldrsh(r11, Address(r12, 19)); // ldrsh x11, [x12, 19] __ ldrshw(r11, Address(r1, -50)); // ldrsh w11, [x1, -50] __ ldrsw(r19, Address(r24, 41)); // ldrsw x19, [x24, 41] __ ldrd(v24, Address(r24, 95)); // ldr d24, [x24, 95] __ ldrs(v15, Address(r5, -43)); // ldr s15, [x5, -43] __ strd(v21, Address(r27, 1)); // str d21, [x27, 1] __ strs(v23, Address(r13, -107)); // str s23, [x13, -107] // pre // LoadStoreOp __ str(r10, Address(__ pre(r0, 8))); // str x10, [x0, 8]! __ strw(r3, Address(__ pre(r0, 29))); // str w3, [x0, 29]! __ strb(r10, Address(__ pre(r14, 9))); // strb w10, [x14, 9]! __ strh(r29, Address(__ pre(r25, -3))); // strh w29, [x25, -3]! __ ldr(r12, Address(__ pre(r16, -144))); // ldr x12, [x16, -144]! __ ldrw(r12, Address(__ pre(r22, -6))); // ldr w12, [x22, -6]! __ ldrb(r13, Address(__ pre(r11, -10))); // ldrb w13, [x11, -10]! __ ldrh(r0, Address(__ pre(r21, -21))); // ldrh w0, [x21, -21]! __ ldrsb(r23, Address(__ pre(r6, 4))); // ldrsb x23, [x6, 4]! __ ldrsh(r3, Address(__ pre(r7, -53))); // ldrsh x3, [x7, -53]! __ ldrshw(r28, Address(__ pre(r4, -7))); // ldrsh w28, [x4, -7]! __ ldrsw(r24, Address(__ pre(r8, -18))); // ldrsw x24, [x8, -18]! __ ldrd(v14, Address(__ pre(r11, 12))); // ldr d14, [x11, 12]! __ ldrs(v19, Address(__ pre(r12, -67))); // ldr s19, [x12, -67]! __ strd(v20, Address(__ pre(r0, -253))); // str d20, [x0, -253]! __ strs(v8, Address(__ pre(r0, 64))); // str s8, [x0, 64]! // post // LoadStoreOp __ str(r3, Address(__ post(r28, -94))); // str x3, [x28], -94 __ strw(r11, Address(__ post(r7, -54))); // str w11, [x7], -54 __ strb(r27, Address(__ post(r10, -24))); // strb w27, [x10], -24 __ strh(r6, Address(__ post(r7, 27))); // strh w6, [x7], 27 __ ldr(r13, Address(__ post(r10, -202))); // ldr x13, [x10], -202 __ ldrw(r15, Address(__ post(r5, -41))); // ldr w15, [x5], -41 __ ldrb(r2, Address(__ post(r13, 9))); // ldrb w2, [x13], 9 __ ldrh(r28, Address(__ post(r13, -20))); // ldrh w28, [x13], -20 __ ldrsb(r9, Address(__ post(r13, -31))); // ldrsb x9, [x13], -31 __ ldrsh(r3, Address(__ post(r24, -36))); // ldrsh x3, [x24], -36 __ ldrshw(r20, Address(__ post(r3, 6))); // ldrsh w20, [x3], 6 __ ldrsw(r7, Address(__ post(r19, -1))); // ldrsw x7, [x19], -1 __ ldrd(v30, Address(__ post(r8, -130))); // ldr d30, [x8], -130 __ ldrs(v25, Address(__ post(r15, 21))); // ldr s25, [x15], 21 __ strd(v14, Address(__ post(r23, 90))); // str d14, [x23], 90 __ strs(v8, Address(__ post(r0, -33))); // str s8, [x0], -33 // base_plus_reg // LoadStoreOp __ str(r10, Address(r17, r21, Address::sxtw(3))); // str x10, [x17, w21, sxtw #3] __ strw(r4, Address(r13, r22, Address::sxtw(2))); // str w4, [x13, w22, sxtw #2] __ strb(r13, Address(r0, r19, Address::uxtw(0))); // strb w13, [x0, w19, uxtw #0] __ strh(r12, Address(r27, r6, Address::sxtw(0))); // strh w12, [x27, w6, sxtw #0] __ ldr(r0, Address(r8, r16, Address::lsl(0))); // ldr x0, [x8, x16, lsl #0] __ ldrw(r0, Address(r4, r26, Address::sxtx(0))); // ldr w0, [x4, x26, sxtx #0] __ ldrb(r14, Address(r25, r5, Address::sxtw(0))); // ldrb w14, [x25, w5, sxtw #0] __ ldrh(r9, Address(r4, r17, Address::uxtw(0))); // ldrh w9, [x4, w17, uxtw #0] __ ldrsb(r27, Address(r4, r7, Address::lsl(0))); // ldrsb x27, [x4, x7, lsl #0] __ ldrsh(r15, Address(r17, r30, Address::sxtw(0))); // ldrsh x15, [x17, w30, sxtw #0] __ ldrshw(r16, Address(r0, r22, Address::sxtw(0))); // ldrsh w16, [x0, w22, sxtw #0] __ ldrsw(r22, Address(r10, r30, Address::sxtx(2))); // ldrsw x22, [x10, x30, sxtx #2] __ ldrd(v29, Address(r21, r10, Address::sxtx(3))); // ldr d29, [x21, x10, sxtx #3] __ ldrs(v3, Address(r11, r19, Address::uxtw(0))); // ldr s3, [x11, w19, uxtw #0] __ strd(v13, Address(r28, r29, Address::uxtw(3))); // str d13, [x28, w29, uxtw #3] __ strs(v23, Address(r29, r5, Address::sxtx(2))); // str s23, [x29, x5, sxtx #2] // base_plus_scaled_offset // LoadStoreOp __ str(r5, Address(r8, 12600)); // str x5, [x8, 12600] __ strw(r29, Address(r24, 7880)); // str w29, [x24, 7880] __ strb(r19, Address(r17, 1566)); // strb w19, [x17, 1566] __ strh(r13, Address(r19, 3984)); // strh w13, [x19, 3984] __ ldr(r19, Address(r23, 13632)); // ldr x19, [x23, 13632] __ ldrw(r23, Address(r29, 6264)); // ldr w23, [x29, 6264] __ ldrb(r22, Address(r11, 2012)); // ldrb w22, [x11, 2012] __ ldrh(r3, Address(r10, 3784)); // ldrh w3, [x10, 3784] __ ldrsb(r8, Address(r16, 1951)); // ldrsb x8, [x16, 1951] __ ldrsh(r23, Address(r20, 3346)); // ldrsh x23, [x20, 3346] __ ldrshw(r2, Address(r1, 3994)); // ldrsh w2, [x1, 3994] __ ldrsw(r4, Address(r17, 7204)); // ldrsw x4, [x17, 7204] __ ldrd(v20, Address(r27, 14400)); // ldr d20, [x27, 14400] __ ldrs(v25, Address(r14, 8096)); // ldr s25, [x14, 8096] __ strd(v26, Address(r10, 15024)); // str d26, [x10, 15024] __ strs(v9, Address(r3, 6936)); // str s9, [x3, 6936] // pcrel // LoadStoreOp __ ldr(r27, forth); // ldr x27, forth __ ldrw(r11, __ pc()); // ldr w11, . // LoadStoreOp __ prfm(Address(r3, -187)); // prfm PLDL1KEEP, [x3, -187] // LoadStoreOp __ prfm(__ pc()); // prfm PLDL1KEEP, . // LoadStoreOp __ prfm(Address(r29, r14, Address::lsl(0))); // prfm PLDL1KEEP, [x29, x14, lsl #0] // LoadStoreOp __ prfm(Address(r4, 13312)); // prfm PLDL1KEEP, [x4, 13312] // AddSubCarryOp __ adcw(r21, r1, r7); // adc w21, w1, w7 __ adcsw(r8, r5, r7); // adcs w8, w5, w7 __ sbcw(r7, r27, r14); // sbc w7, w27, w14 __ sbcsw(r27, r4, r17); // sbcs w27, w4, w17 __ adc(r0, r28, r0); // adc x0, x28, x0 __ adcs(r12, r24, r30); // adcs x12, x24, x30 __ sbc(r0, r25, r15); // sbc x0, x25, x15 __ sbcs(r1, r24, r3); // sbcs x1, x24, x3 // AddSubExtendedOp __ addw(r17, r24, r20, ext::uxtb, 2); // add w17, w24, w20, uxtb #2 __ addsw(r13, r28, r10, ext::uxth, 1); // adds w13, w28, w10, uxth #1 __ sub(r15, r16, r2, ext::sxth, 2); // sub x15, x16, x2, sxth #2 __ subsw(r29, r13, r13, ext::uxth, 2); // subs w29, w13, w13, uxth #2 __ add(r12, r20, r12, ext::sxtw, 3); // add x12, x20, x12, sxtw #3 __ adds(r30, r27, r11, ext::sxtb, 1); // adds x30, x27, x11, sxtb #1 __ sub(r14, r7, r1, ext::sxtw, 2); // sub x14, x7, x1, sxtw #2 __ subs(r29, r3, r27, ext::sxth, 1); // subs x29, x3, x27, sxth #1 // ConditionalCompareOp __ ccmnw(r0, r13, 14u, Assembler::MI); // ccmn w0, w13, #14, MI __ ccmpw(r22, r17, 6u, Assembler::CC); // ccmp w22, w17, #6, CC __ ccmn(r17, r30, 14u, Assembler::VS); // ccmn x17, x30, #14, VS __ ccmp(r10, r19, 12u, Assembler::HI); // ccmp x10, x19, #12, HI // ConditionalCompareImmedOp __ ccmnw(r6, 18, 2, Assembler::LE); // ccmn w6, #18, #2, LE __ ccmpw(r9, 13, 4, Assembler::HI); // ccmp w9, #13, #4, HI __ ccmn(r21, 11, 11, Assembler::LO); // ccmn x21, #11, #11, LO __ ccmp(r4, 13, 2, Assembler::VC); // ccmp x4, #13, #2, VC // ConditionalSelectOp __ cselw(r12, r2, r22, Assembler::HI); // csel w12, w2, w22, HI __ csincw(r24, r16, r17, Assembler::HS); // csinc w24, w16, w17, HS __ csinvw(r6, r7, r16, Assembler::LT); // csinv w6, w7, w16, LT __ csnegw(r11, r27, r22, Assembler::LS); // csneg w11, w27, w22, LS __ csel(r10, r3, r29, Assembler::LT); // csel x10, x3, x29, LT __ csinc(r12, r26, r27, Assembler::CC); // csinc x12, x26, x27, CC __ csinv(r15, r10, r21, Assembler::GT); // csinv x15, x10, x21, GT __ csneg(r30, r23, r9, Assembler::GT); // csneg x30, x23, x9, GT // TwoRegOp __ rbitw(r30, r10); // rbit w30, w10 __ rev16w(r29, r15); // rev16 w29, w15 __ revw(r29, r30); // rev w29, w30 __ clzw(r25, r21); // clz w25, w21 __ clsw(r4, r0); // cls w4, w0 __ rbit(r17, r21); // rbit x17, x21 __ rev16(r29, r16); // rev16 x29, x16 __ rev32(r21, r20); // rev32 x21, x20 __ rev(r6, r19); // rev x6, x19 __ clz(r30, r3); // clz x30, x3 __ cls(r21, r19); // cls x21, x19 // ThreeRegOp __ udivw(r11, r24, r0); // udiv w11, w24, w0 __ sdivw(r27, r25, r14); // sdiv w27, w25, w14 __ lslvw(r3, r14, r17); // lslv w3, w14, w17 __ lsrvw(r7, r15, r24); // lsrv w7, w15, w24 __ asrvw(r28, r17, r25); // asrv w28, w17, w25 __ rorvw(r2, r26, r28); // rorv w2, w26, w28 __ udiv(r5, r25, r26); // udiv x5, x25, x26 __ sdiv(r27, r16, r17); // sdiv x27, x16, x17 __ lslv(r6, r21, r12); // lslv x6, x21, x12 __ lsrv(r0, r4, r12); // lsrv x0, x4, x12 __ asrv(r27, r17, r28); // asrv x27, x17, x28 __ rorv(r28, r2, r17); // rorv x28, x2, x17 __ umulh(r10, r15, r14); // umulh x10, x15, x14 __ smulh(r14, r3, r25); // smulh x14, x3, x25 // FourRegMulOp __ maddw(r15, r19, r14, r5); // madd w15, w19, w14, w5 __ msubw(r16, r4, r26, r25); // msub w16, w4, w26, w25 __ madd(r4, r2, r2, r12); // madd x4, x2, x2, x12 __ msub(r29, r17, r8, r7); // msub x29, x17, x8, x7 __ smaddl(r3, r4, r25, r4); // smaddl x3, w4, w25, x4 __ smsubl(r26, r25, r4, r17); // smsubl x26, w25, w4, x17 __ umaddl(r0, r26, r17, r23); // umaddl x0, w26, w17, x23 __ umsubl(r15, r21, r28, r17); // umsubl x15, w21, w28, x17 // ThreeRegFloatOp __ fabds(v27, v10, v3); // fabd s27, s10, s3 __ fmuls(v0, v7, v25); // fmul s0, s7, s25 __ fdivs(v9, v6, v15); // fdiv s9, s6, s15 __ fadds(v29, v15, v10); // fadd s29, s15, s10 __ fsubs(v2, v17, v7); // fsub s2, s17, s7 __ fabdd(v11, v11, v23); // fabd d11, d11, d23 __ fmuld(v7, v29, v23); // fmul d7, d29, d23 __ fdivd(v14, v27, v11); // fdiv d14, d27, d11 __ faddd(v11, v4, v24); // fadd d11, d4, d24 __ fsubd(v12, v15, v14); // fsub d12, d15, d14 // FourRegFloatOp __ fmadds(v20, v11, v28, v13); // fmadd s20, s11, s28, s13 __ fmsubs(v11, v12, v23, v30); // fmsub s11, s12, s23, s30 __ fnmadds(v26, v14, v9, v13); // fnmadd s26, s14, s9, s13 __ fnmadds(v10, v7, v5, v29); // fnmadd s10, s7, s5, s29 __ fmaddd(v15, v3, v11, v12); // fmadd d15, d3, d11, d12 __ fmsubd(v15, v30, v30, v17); // fmsub d15, d30, d30, d17 __ fnmaddd(v19, v20, v15, v15); // fnmadd d19, d20, d15, d15 __ fnmaddd(v9, v21, v2, v9); // fnmadd d9, d21, d2, d9 // TwoRegFloatOp __ fmovs(v27, v7); // fmov s27, s7 __ fabss(v29, v30); // fabs s29, s30 __ fnegs(v17, v1); // fneg s17, s1 __ fsqrts(v2, v6); // fsqrt s2, s6 __ fcvts(v10, v3); // fcvt d10, s3 __ fmovd(v24, v11); // fmov d24, d11 __ fabsd(v7, v1); // fabs d7, d1 __ fnegd(v11, v0); // fneg d11, d0 __ fsqrtd(v3, v17); // fsqrt d3, d17 __ fcvtd(v28, v6); // fcvt s28, d6 // FloatConvertOp __ fcvtzsw(r22, v6); // fcvtzs w22, s6 __ fcvtzs(r0, v27); // fcvtzs x0, s27 __ fcvtzdw(r26, v2); // fcvtzs w26, d2 __ fcvtzd(r5, v7); // fcvtzs x5, d7 __ scvtfws(v28, r11); // scvtf s28, w11 __ scvtfs(v25, r13); // scvtf s25, x13 __ scvtfwd(v11, r23); // scvtf d11, w23 __ scvtfd(v19, r8); // scvtf d19, x8 __ fmovs(r17, v21); // fmov w17, s21 __ fmovd(r25, v20); // fmov x25, d20 __ fmovs(v19, r17); // fmov s19, w17 __ fmovd(v2, r29); // fmov d2, x29 // TwoRegFloatOp __ fcmps(v22, v8); // fcmp s22, s8 __ fcmpd(v21, v19); // fcmp d21, d19 __ fcmps(v20, 0.0); // fcmp s20, #0.0 __ fcmpd(v11, 0.0); // fcmp d11, #0.0 // LoadStorePairOp __ stpw(r20, r6, Address(r15, -32)); // stp w20, w6, [x15, #-32] __ ldpw(r27, r14, Address(r3, -208)); // ldp w27, w14, [x3, #-208] __ ldpsw(r16, r10, Address(r11, -80)); // ldpsw x16, x10, [x11, #-80] __ stp(r7, r7, Address(r14, 64)); // stp x7, x7, [x14, #64] __ ldp(r12, r23, Address(r0, 112)); // ldp x12, x23, [x0, #112] // LoadStorePairOp __ stpw(r13, r7, Address(__ pre(r6, -80))); // stp w13, w7, [x6, #-80]! __ ldpw(r30, r15, Address(__ pre(r2, -144))); // ldp w30, w15, [x2, #-144]! __ ldpsw(r4, r1, Address(__ pre(r27, -144))); // ldpsw x4, x1, [x27, #-144]! __ stp(r23, r14, Address(__ pre(r11, 64))); // stp x23, x14, [x11, #64]! __ ldp(r29, r27, Address(__ pre(r21, -192))); // ldp x29, x27, [x21, #-192]! // LoadStorePairOp __ stpw(r22, r5, Address(__ post(r21, -48))); // stp w22, w5, [x21], #-48 __ ldpw(r27, r17, Address(__ post(r6, -32))); // ldp w27, w17, [x6], #-32 __ ldpsw(r16, r5, Address(__ post(r1, -80))); // ldpsw x16, x5, [x1], #-80 __ stp(r13, r20, Address(__ post(r22, -208))); // stp x13, x20, [x22], #-208 __ ldp(r30, r27, Address(__ post(r10, 80))); // ldp x30, x27, [x10], #80 // LoadStorePairOp __ stnpw(r5, r17, Address(r11, 16)); // stnp w5, w17, [x11, #16] __ ldnpw(r14, r4, Address(r26, -96)); // ldnp w14, w4, [x26, #-96] __ stnp(r23, r29, Address(r12, 32)); // stnp x23, x29, [x12, #32] __ ldnp(r0, r6, Address(r21, -80)); // ldnp x0, x6, [x21, #-80] // LdStNEONOp __ ld1(v15, __ T8B, Address(r26)); // ld1 {v15.8B}, [x26] __ ld1(v23, v24, __ T16B, Address(__ post(r11, 32))); // ld1 {v23.16B, v24.16B}, [x11], 32 __ ld1(v8, v9, v10, __ T1D, Address(__ post(r23, r7))); // ld1 {v8.1D, v9.1D, v10.1D}, [x23], x7 __ ld1(v19, v20, v21, v22, __ T8H, Address(__ post(r25, 64))); // ld1 {v19.8H, v20.8H, v21.8H, v22.8H}, [x25], 64 __ ld1r(v29, __ T8B, Address(r17)); // ld1r {v29.8B}, [x17] __ ld1r(v24, __ T4S, Address(__ post(r23, 4))); // ld1r {v24.4S}, [x23], 4 __ ld1r(v10, __ T1D, Address(__ post(r5, r25))); // ld1r {v10.1D}, [x5], x25 __ ld2(v17, v18, __ T2D, Address(r10)); // ld2 {v17.2D, v18.2D}, [x10] __ ld2(v12, v13, __ T4H, Address(__ post(r15, 16))); // ld2 {v12.4H, v13.4H}, [x15], 16 __ ld2r(v25, v26, __ T16B, Address(r17)); // ld2r {v25.16B, v26.16B}, [x17] __ ld2r(v1, v2, __ T2S, Address(__ post(r30, 8))); // ld2r {v1.2S, v2.2S}, [x30], 8 __ ld2r(v16, v17, __ T2D, Address(__ post(r17, r9))); // ld2r {v16.2D, v17.2D}, [x17], x9 __ ld3(v25, v26, v27, __ T4S, Address(__ post(r12, r2))); // ld3 {v25.4S, v26.4S, v27.4S}, [x12], x2 __ ld3(v26, v27, v28, __ T2S, Address(r19)); // ld3 {v26.2S, v27.2S, v28.2S}, [x19] __ ld3r(v15, v16, v17, __ T8H, Address(r21)); // ld3r {v15.8H, v16.8H, v17.8H}, [x21] __ ld3r(v25, v26, v27, __ T4S, Address(__ post(r13, 12))); // ld3r {v25.4S, v26.4S, v27.4S}, [x13], 12 __ ld3r(v14, v15, v16, __ T1D, Address(__ post(r28, r29))); // ld3r {v14.1D, v15.1D, v16.1D}, [x28], x29 __ ld4(v17, v18, v19, v20, __ T8H, Address(__ post(r29, 64))); // ld4 {v17.8H, v18.8H, v19.8H, v20.8H}, [x29], 64 __ ld4(v27, v28, v29, v30, __ T8B, Address(__ post(r7, r0))); // ld4 {v27.8B, v28.8B, v29.8B, v30.8B}, [x7], x0 __ ld4r(v24, v25, v26, v27, __ T8B, Address(r17)); // ld4r {v24.8B, v25.8B, v26.8B, v27.8B}, [x17] __ ld4r(v0, v1, v2, v3, __ T4H, Address(__ post(r26, 8))); // ld4r {v0.4H, v1.4H, v2.4H, v3.4H}, [x26], 8 __ ld4r(v12, v13, v14, v15, __ T2S, Address(__ post(r25, r2))); // ld4r {v12.2S, v13.2S, v14.2S, v15.2S}, [x25], x2 // NEONReduceInstruction __ addv(v22, __ T8B, v23); // addv b22, v23.8B __ addv(v27, __ T16B, v28); // addv b27, v28.16B __ addv(v4, __ T4H, v5); // addv h4, v5.4H __ addv(v7, __ T8H, v8); // addv h7, v8.8H __ addv(v6, __ T4S, v7); // addv s6, v7.4S __ smaxv(v1, __ T8B, v2); // smaxv b1, v2.8B __ smaxv(v26, __ T16B, v27); // smaxv b26, v27.16B __ smaxv(v15, __ T4H, v16); // smaxv h15, v16.4H __ smaxv(v2, __ T8H, v3); // smaxv h2, v3.8H __ smaxv(v13, __ T4S, v14); // smaxv s13, v14.4S __ fmaxv(v13, __ T4S, v14); // fmaxv s13, v14.4S __ sminv(v24, __ T8B, v25); // sminv b24, v25.8B __ sminv(v23, __ T16B, v24); // sminv b23, v24.16B __ sminv(v4, __ T4H, v5); // sminv h4, v5.4H __ sminv(v19, __ T8H, v20); // sminv h19, v20.8H __ sminv(v15, __ T4S, v16); // sminv s15, v16.4S __ fminv(v0, __ T4S, v1); // fminv s0, v1.4S __ fmaxp(v4, v5, __ S); // fmaxp s4, v5.2S __ fmaxp(v20, v21, __ D); // fmaxp d20, v21.2D __ fminp(v11, v12, __ S); // fminp s11, v12.2S __ fminp(v29, v30, __ D); // fminp d29, v30.2D // TwoRegNEONOp __ absr(v15, __ T8B, v16); // abs v15.8B, v16.8B __ absr(v21, __ T16B, v22); // abs v21.16B, v22.16B __ absr(v4, __ T4H, v5); // abs v4.4H, v5.4H __ absr(v14, __ T8H, v15); // abs v14.8H, v15.8H __ absr(v22, __ T2S, v23); // abs v22.2S, v23.2S __ absr(v25, __ T4S, v26); // abs v25.4S, v26.4S __ absr(v6, __ T2D, v7); // abs v6.2D, v7.2D __ fabs(v12, __ T2S, v13); // fabs v12.2S, v13.2S __ fabs(v14, __ T4S, v15); // fabs v14.4S, v15.4S __ fabs(v13, __ T2D, v14); // fabs v13.2D, v14.2D __ fneg(v14, __ T2S, v15); // fneg v14.2S, v15.2S __ fneg(v9, __ T4S, v10); // fneg v9.4S, v10.4S __ fneg(v25, __ T2D, v26); // fneg v25.2D, v26.2D __ fsqrt(v28, __ T2S, v29); // fsqrt v28.2S, v29.2S __ fsqrt(v10, __ T4S, v11); // fsqrt v10.4S, v11.4S __ fsqrt(v19, __ T2D, v20); // fsqrt v19.2D, v20.2D __ notr(v11, __ T8B, v12); // not v11.8B, v12.8B __ notr(v17, __ T16B, v18); // not v17.16B, v18.16B // ThreeRegNEONOp __ andr(v21, __ T8B, v22, v23); // and v21.8B, v22.8B, v23.8B __ andr(v15, __ T16B, v16, v17); // and v15.16B, v16.16B, v17.16B __ orr(v20, __ T8B, v21, v22); // orr v20.8B, v21.8B, v22.8B __ orr(v23, __ T16B, v24, v25); // orr v23.16B, v24.16B, v25.16B __ eor(v26, __ T8B, v27, v28); // eor v26.8B, v27.8B, v28.8B __ eor(v5, __ T16B, v6, v7); // eor v5.16B, v6.16B, v7.16B __ addv(v6, __ T8B, v7, v8); // add v6.8B, v7.8B, v8.8B __ addv(v15, __ T16B, v16, v17); // add v15.16B, v16.16B, v17.16B __ addv(v15, __ T4H, v16, v17); // add v15.4H, v16.4H, v17.4H __ addv(v25, __ T8H, v26, v27); // add v25.8H, v26.8H, v27.8H __ addv(v16, __ T2S, v17, v18); // add v16.2S, v17.2S, v18.2S __ addv(v27, __ T4S, v28, v29); // add v27.4S, v28.4S, v29.4S __ addv(v24, __ T2D, v25, v26); // add v24.2D, v25.2D, v26.2D __ fadd(v15, __ T2S, v16, v17); // fadd v15.2S, v16.2S, v17.2S __ fadd(v25, __ T4S, v26, v27); // fadd v25.4S, v26.4S, v27.4S __ fadd(v14, __ T2D, v15, v16); // fadd v14.2D, v15.2D, v16.2D __ subv(v10, __ T8B, v11, v12); // sub v10.8B, v11.8B, v12.8B __ subv(v13, __ T16B, v14, v15); // sub v13.16B, v14.16B, v15.16B __ subv(v14, __ T4H, v15, v16); // sub v14.4H, v15.4H, v16.4H __ subv(v20, __ T8H, v21, v22); // sub v20.8H, v21.8H, v22.8H __ subv(v1, __ T2S, v2, v3); // sub v1.2S, v2.2S, v3.2S __ subv(v22, __ T4S, v23, v24); // sub v22.4S, v23.4S, v24.4S __ subv(v30, __ T2D, v31, v0); // sub v30.2D, v31.2D, v0.2D __ fsub(v14, __ T2S, v15, v16); // fsub v14.2S, v15.2S, v16.2S __ fsub(v2, __ T4S, v3, v4); // fsub v2.4S, v3.4S, v4.4S __ fsub(v6, __ T2D, v7, v8); // fsub v6.2D, v7.2D, v8.2D __ mulv(v3, __ T8B, v4, v5); // mul v3.8B, v4.8B, v5.8B __ mulv(v7, __ T16B, v8, v9); // mul v7.16B, v8.16B, v9.16B __ mulv(v24, __ T4H, v25, v26); // mul v24.4H, v25.4H, v26.4H __ mulv(v0, __ T8H, v1, v2); // mul v0.8H, v1.8H, v2.8H __ mulv(v27, __ T2S, v28, v29); // mul v27.2S, v28.2S, v29.2S __ mulv(v29, __ T4S, v30, v31); // mul v29.4S, v30.4S, v31.4S __ fabd(v5, __ T2S, v6, v7); // fabd v5.2S, v6.2S, v7.2S __ fabd(v5, __ T4S, v6, v7); // fabd v5.4S, v6.4S, v7.4S __ fabd(v29, __ T2D, v30, v31); // fabd v29.2D, v30.2D, v31.2D __ fmul(v11, __ T2S, v12, v13); // fmul v11.2S, v12.2S, v13.2S __ fmul(v25, __ T4S, v26, v27); // fmul v25.4S, v26.4S, v27.4S __ fmul(v0, __ T2D, v1, v2); // fmul v0.2D, v1.2D, v2.2D __ mlav(v30, __ T4H, v31, v0); // mla v30.4H, v31.4H, v0.4H __ mlav(v0, __ T8H, v1, v2); // mla v0.8H, v1.8H, v2.8H __ mlav(v17, __ T2S, v18, v19); // mla v17.2S, v18.2S, v19.2S __ mlav(v28, __ T4S, v29, v30); // mla v28.4S, v29.4S, v30.4S __ fmla(v25, __ T2S, v26, v27); // fmla v25.2S, v26.2S, v27.2S __ fmla(v9, __ T4S, v10, v11); // fmla v9.4S, v10.4S, v11.4S __ fmla(v25, __ T2D, v26, v27); // fmla v25.2D, v26.2D, v27.2D __ mlsv(v12, __ T4H, v13, v14); // mls v12.4H, v13.4H, v14.4H __ mlsv(v15, __ T8H, v16, v17); // mls v15.8H, v16.8H, v17.8H __ mlsv(v11, __ T2S, v12, v13); // mls v11.2S, v12.2S, v13.2S __ mlsv(v10, __ T4S, v11, v12); // mls v10.4S, v11.4S, v12.4S __ fmls(v17, __ T2S, v18, v19); // fmls v17.2S, v18.2S, v19.2S __ fmls(v24, __ T4S, v25, v26); // fmls v24.4S, v25.4S, v26.4S __ fmls(v21, __ T2D, v22, v23); // fmls v21.2D, v22.2D, v23.2D __ fdiv(v23, __ T2S, v24, v25); // fdiv v23.2S, v24.2S, v25.2S __ fdiv(v0, __ T4S, v1, v2); // fdiv v0.4S, v1.4S, v2.4S __ fdiv(v16, __ T2D, v17, v18); // fdiv v16.2D, v17.2D, v18.2D __ maxv(v10, __ T8B, v11, v12); // smax v10.8B, v11.8B, v12.8B __ maxv(v6, __ T16B, v7, v8); // smax v6.16B, v7.16B, v8.16B __ maxv(v28, __ T4H, v29, v30); // smax v28.4H, v29.4H, v30.4H __ maxv(v6, __ T8H, v7, v8); // smax v6.8H, v7.8H, v8.8H __ maxv(v5, __ T2S, v6, v7); // smax v5.2S, v6.2S, v7.2S __ maxv(v5, __ T4S, v6, v7); // smax v5.4S, v6.4S, v7.4S __ fmax(v20, __ T2S, v21, v22); // fmax v20.2S, v21.2S, v22.2S __ fmax(v17, __ T4S, v18, v19); // fmax v17.4S, v18.4S, v19.4S __ fmax(v15, __ T2D, v16, v17); // fmax v15.2D, v16.2D, v17.2D __ minv(v17, __ T8B, v18, v19); // smin v17.8B, v18.8B, v19.8B __ minv(v29, __ T16B, v30, v31); // smin v29.16B, v30.16B, v31.16B __ minv(v26, __ T4H, v27, v28); // smin v26.4H, v27.4H, v28.4H __ minv(v28, __ T8H, v29, v30); // smin v28.8H, v29.8H, v30.8H __ minv(v1, __ T2S, v2, v3); // smin v1.2S, v2.2S, v3.2S __ minv(v27, __ T4S, v28, v29); // smin v27.4S, v28.4S, v29.4S __ fmin(v0, __ T2S, v1, v2); // fmin v0.2S, v1.2S, v2.2S __ fmin(v20, __ T4S, v21, v22); // fmin v20.4S, v21.4S, v22.4S __ fmin(v28, __ T2D, v29, v30); // fmin v28.2D, v29.2D, v30.2D __ cmeq(v15, __ T8B, v16, v17); // cmeq v15.8B, v16.8B, v17.8B __ cmeq(v12, __ T16B, v13, v14); // cmeq v12.16B, v13.16B, v14.16B __ cmeq(v10, __ T4H, v11, v12); // cmeq v10.4H, v11.4H, v12.4H __ cmeq(v28, __ T8H, v29, v30); // cmeq v28.8H, v29.8H, v30.8H __ cmeq(v28, __ T2S, v29, v30); // cmeq v28.2S, v29.2S, v30.2S __ cmeq(v19, __ T4S, v20, v21); // cmeq v19.4S, v20.4S, v21.4S __ cmeq(v22, __ T2D, v23, v24); // cmeq v22.2D, v23.2D, v24.2D __ fcmeq(v10, __ T2S, v11, v12); // fcmeq v10.2S, v11.2S, v12.2S __ fcmeq(v4, __ T4S, v5, v6); // fcmeq v4.4S, v5.4S, v6.4S __ fcmeq(v30, __ T2D, v31, v0); // fcmeq v30.2D, v31.2D, v0.2D __ cmgt(v20, __ T8B, v21, v22); // cmgt v20.8B, v21.8B, v22.8B __ cmgt(v8, __ T16B, v9, v10); // cmgt v8.16B, v9.16B, v10.16B __ cmgt(v30, __ T4H, v31, v0); // cmgt v30.4H, v31.4H, v0.4H __ cmgt(v17, __ T8H, v18, v19); // cmgt v17.8H, v18.8H, v19.8H __ cmgt(v10, __ T2S, v11, v12); // cmgt v10.2S, v11.2S, v12.2S __ cmgt(v27, __ T4S, v28, v29); // cmgt v27.4S, v28.4S, v29.4S __ cmgt(v2, __ T2D, v3, v4); // cmgt v2.2D, v3.2D, v4.2D __ fcmgt(v24, __ T2S, v25, v26); // fcmgt v24.2S, v25.2S, v26.2S __ fcmgt(v4, __ T4S, v5, v6); // fcmgt v4.4S, v5.4S, v6.4S __ fcmgt(v3, __ T2D, v4, v5); // fcmgt v3.2D, v4.2D, v5.2D __ cmge(v8, __ T8B, v9, v10); // cmge v8.8B, v9.8B, v10.8B __ cmge(v22, __ T16B, v23, v24); // cmge v22.16B, v23.16B, v24.16B __ cmge(v17, __ T4H, v18, v19); // cmge v17.4H, v18.4H, v19.4H __ cmge(v13, __ T8H, v14, v15); // cmge v13.8H, v14.8H, v15.8H __ cmge(v4, __ T2S, v5, v6); // cmge v4.2S, v5.2S, v6.2S __ cmge(v28, __ T4S, v29, v30); // cmge v28.4S, v29.4S, v30.4S __ cmge(v23, __ T2D, v24, v25); // cmge v23.2D, v24.2D, v25.2D __ fcmge(v21, __ T2S, v22, v23); // fcmge v21.2S, v22.2S, v23.2S __ fcmge(v25, __ T4S, v26, v27); // fcmge v25.4S, v26.4S, v27.4S __ fcmge(v24, __ T2D, v25, v26); // fcmge v24.2D, v25.2D, v26.2D // SpecialCases __ ccmn(zr, zr, 3u, Assembler::LE); // ccmn xzr, xzr, #3, LE __ ccmnw(zr, zr, 5u, Assembler::EQ); // ccmn wzr, wzr, #5, EQ __ ccmp(zr, 1, 4u, Assembler::NE); // ccmp xzr, 1, #4, NE __ ccmpw(zr, 2, 2, Assembler::GT); // ccmp wzr, 2, #2, GT __ extr(zr, zr, zr, 0); // extr xzr, xzr, xzr, 0 __ stlxp(r0, zr, zr, sp); // stlxp w0, xzr, xzr, [sp] __ stlxpw(r2, zr, zr, r3); // stlxp w2, wzr, wzr, [x3] __ stxp(r4, zr, zr, r5); // stxp w4, xzr, xzr, [x5] __ stxpw(r6, zr, zr, sp); // stxp w6, wzr, wzr, [sp] __ dup(v0, __ T16B, zr); // dup v0.16b, wzr __ mov(v1, __ T1D, 0, zr); // mov v1.d[0], xzr __ mov(v1, __ T2S, 1, zr); // mov v1.s[1], wzr __ mov(v1, __ T4H, 2, zr); // mov v1.h[2], wzr __ mov(v1, __ T8B, 3, zr); // mov v1.b[3], wzr __ smov(r0, v1, __ S, 0); // smov x0, v1.s[0] __ smov(r0, v1, __ H, 1); // smov x0, v1.h[1] __ smov(r0, v1, __ B, 2); // smov x0, v1.b[2] __ umov(r0, v1, __ D, 0); // umov x0, v1.d[0] __ umov(r0, v1, __ S, 1); // umov w0, v1.s[1] __ umov(r0, v1, __ H, 2); // umov w0, v1.h[2] __ umov(r0, v1, __ B, 3); // umov w0, v1.b[3] __ ld1(v31, v0, __ T2D, Address(__ post(r1, r0))); // ld1 {v31.2d, v0.2d}, [x1], x0 __ sve_cpy(z0, __ S, p0, v1); // mov z0.s, p0/m, s1 __ sve_inc(r0, __ S); // incw x0 __ sve_dec(r1, __ H); // dech x1 __ sve_lsl(z0, __ B, z1, 7); // lsl z0.b, z1.b, #7 __ sve_lsl(z21, __ H, z1, 15); // lsl z21.h, z1.h, #15 __ sve_lsl(z0, __ S, z1, 31); // lsl z0.s, z1.s, #31 __ sve_lsl(z0, __ D, z1, 63); // lsl z0.d, z1.d, #63 __ sve_lsr(z0, __ B, z1, 7); // lsr z0.b, z1.b, #7 __ sve_asr(z0, __ H, z11, 15); // asr z0.h, z11.h, #15 __ sve_lsr(z30, __ S, z1, 31); // lsr z30.s, z1.s, #31 __ sve_asr(z0, __ D, z1, 63); // asr z0.d, z1.d, #63 __ sve_addvl(sp, r0, 31); // addvl sp, x0, #31 __ sve_addpl(r1, sp, -32); // addpl x1, sp, -32 __ sve_cntp(r8, __ B, p0, p1); // cntp x8, p0, p1.b __ sve_dup(z0, __ B, 127); // dup z0.b, 127 __ sve_dup(z1, __ H, -128); // dup z1.h, -128 __ sve_dup(z2, __ S, 32512); // dup z2.s, 32512 __ sve_dup(z7, __ D, -32768); // dup z7.d, -32768 __ sve_ld1b(z0, __ B, p0, Address(sp)); // ld1b {z0.b}, p0/z, [sp] __ sve_ld1h(z10, __ H, p1, Address(sp, -8)); // ld1h {z10.h}, p1/z, [sp, #-8, MUL VL] __ sve_ld1w(z20, __ S, p2, Address(r0, 7)); // ld1w {z20.s}, p2/z, [x0, #7, MUL VL] __ sve_ld1b(z30, __ B, p3, Address(sp, r8)); // ld1b {z30.b}, p3/z, [sp, x8] __ sve_ld1w(z0, __ S, p4, Address(sp, r28)); // ld1w {z0.s}, p4/z, [sp, x28, LSL #2] __ sve_ld1d(z11, __ D, p5, Address(r0, r1)); // ld1d {z11.d}, p5/z, [x0, x1, LSL #3] __ sve_st1b(z22, __ B, p6, Address(sp)); // st1b {z22.b}, p6, [sp] __ sve_st1b(z31, __ B, p7, Address(sp, -8)); // st1b {z31.b}, p7, [sp, #-8, MUL VL] __ sve_st1w(z0, __ S, p1, Address(r0, 7)); // st1w {z0.s}, p1, [x0, #7, MUL VL] __ sve_st1b(z0, __ B, p2, Address(sp, r1)); // st1b {z0.b}, p2, [sp, x1] __ sve_st1h(z0, __ H, p3, Address(sp, r8)); // st1h {z0.h}, p3, [sp, x8, LSL #1] __ sve_st1d(z0, __ D, p4, Address(r0, r17)); // st1d {z0.d}, p4, [x0, x17, LSL #3] __ sve_ldr(z0, Address(sp)); // ldr z0, [sp] __ sve_ldr(z31, Address(sp, -256)); // ldr z31, [sp, #-256, MUL VL] __ sve_str(z8, Address(r8, 255)); // str z8, [x8, #255, MUL VL] // FloatImmediateOp __ fmovd(v0, 2.0); // fmov d0, #2.0 __ fmovd(v0, 2.125); // fmov d0, #2.125 __ fmovd(v0, 4.0); // fmov d0, #4.0 __ fmovd(v0, 4.25); // fmov d0, #4.25 __ fmovd(v0, 8.0); // fmov d0, #8.0 __ fmovd(v0, 8.5); // fmov d0, #8.5 __ fmovd(v0, 16.0); // fmov d0, #16.0 __ fmovd(v0, 17.0); // fmov d0, #17.0 __ fmovd(v0, 0.125); // fmov d0, #0.125 __ fmovd(v0, 0.1328125); // fmov d0, #0.1328125 __ fmovd(v0, 0.25); // fmov d0, #0.25 __ fmovd(v0, 0.265625); // fmov d0, #0.265625 __ fmovd(v0, 0.5); // fmov d0, #0.5 __ fmovd(v0, 0.53125); // fmov d0, #0.53125 __ fmovd(v0, 1.0); // fmov d0, #1.0 __ fmovd(v0, 1.0625); // fmov d0, #1.0625 __ fmovd(v0, -2.0); // fmov d0, #-2.0 __ fmovd(v0, -2.125); // fmov d0, #-2.125 __ fmovd(v0, -4.0); // fmov d0, #-4.0 __ fmovd(v0, -4.25); // fmov d0, #-4.25 __ fmovd(v0, -8.0); // fmov d0, #-8.0 __ fmovd(v0, -8.5); // fmov d0, #-8.5 __ fmovd(v0, -16.0); // fmov d0, #-16.0 __ fmovd(v0, -17.0); // fmov d0, #-17.0 __ fmovd(v0, -0.125); // fmov d0, #-0.125 __ fmovd(v0, -0.1328125); // fmov d0, #-0.1328125 __ fmovd(v0, -0.25); // fmov d0, #-0.25 __ fmovd(v0, -0.265625); // fmov d0, #-0.265625 __ fmovd(v0, -0.5); // fmov d0, #-0.5 __ fmovd(v0, -0.53125); // fmov d0, #-0.53125 __ fmovd(v0, -1.0); // fmov d0, #-1.0 __ fmovd(v0, -1.0625); // fmov d0, #-1.0625 // LSEOp __ swp(Assembler::xword, r3, r24, r26); // swp x3, x24, [x26] __ ldadd(Assembler::xword, r23, r15, r21); // ldadd x23, x15, [x21] __ ldbic(Assembler::xword, r3, r24, r8); // ldclr x3, x24, [x8] __ ldeor(Assembler::xword, r25, r20, r16); // ldeor x25, x20, [x16] __ ldorr(Assembler::xword, r17, r2, r1); // ldset x17, x2, [x1] __ ldsmin(Assembler::xword, r0, r24, r4); // ldsmin x0, x24, [x4] __ ldsmax(Assembler::xword, r3, r12, sp); // ldsmax x3, x12, [sp] __ ldumin(Assembler::xword, r28, r10, r26); // ldumin x28, x10, [x26] __ ldumax(Assembler::xword, r2, r12, r15); // ldumax x2, x12, [x15] // LSEOp __ swpa(Assembler::xword, zr, r1, r13); // swpa xzr, x1, [x13] __ ldadda(Assembler::xword, r29, r0, r19); // ldadda x29, x0, [x19] __ ldbica(Assembler::xword, r12, r17, r22); // ldclra x12, x17, [x22] __ ldeora(Assembler::xword, r13, r28, r30); // ldeora x13, x28, [x30] __ ldorra(Assembler::xword, zr, r1, r26); // ldseta xzr, x1, [x26] __ ldsmina(Assembler::xword, r28, r4, r30); // ldsmina x28, x4, [x30] __ ldsmaxa(Assembler::xword, r4, r6, r30); // ldsmaxa x4, x6, [x30] __ ldumina(Assembler::xword, r26, r16, r9); // ldumina x26, x16, [x9] __ ldumaxa(Assembler::xword, r8, r12, r0); // ldumaxa x8, x12, [x0] // LSEOp __ swpal(Assembler::xword, r20, r1, r24); // swpal x20, x1, [x24] __ ldaddal(Assembler::xword, r2, r0, r9); // ldaddal x2, x0, [x9] __ ldbical(Assembler::xword, r24, r26, r16); // ldclral x24, x26, [x16] __ ldeoral(Assembler::xword, r30, r3, r10); // ldeoral x30, x3, [x10] __ ldorral(Assembler::xword, r23, r10, r4); // ldsetal x23, x10, [x4] __ ldsminal(Assembler::xword, r16, r2, r11); // ldsminal x16, x2, [x11] __ ldsmaxal(Assembler::xword, r8, r10, r15); // ldsmaxal x8, x10, [x15] __ lduminal(Assembler::xword, r17, r2, r10); // lduminal x17, x2, [x10] __ ldumaxal(Assembler::xword, r12, r12, r15); // ldumaxal x12, x12, [x15] // LSEOp __ swpl(Assembler::xword, r13, r2, r7); // swpl x13, x2, [x7] __ ldaddl(Assembler::xword, r20, r26, r16); // ldaddl x20, x26, [x16] __ ldbicl(Assembler::xword, r4, r2, r4); // ldclrl x4, x2, [x4] __ ldeorl(Assembler::xword, r12, r16, r21); // ldeorl x12, x16, [x21] __ ldorrl(Assembler::xword, r16, r16, r11); // ldsetl x16, x16, [x11] __ ldsminl(Assembler::xword, r21, r23, r12); // ldsminl x21, x23, [x12] __ ldsmaxl(Assembler::xword, r26, r23, r28); // ldsmaxl x26, x23, [x28] __ lduminl(Assembler::xword, r14, r11, r24); // lduminl x14, x11, [x24] __ ldumaxl(Assembler::xword, r1, r12, sp); // ldumaxl x1, x12, [sp] // LSEOp __ swp(Assembler::word, r10, r16, r7); // swp w10, w16, [x7] __ ldadd(Assembler::word, r2, r3, r13); // ldadd w2, w3, [x13] __ ldbic(Assembler::word, r19, r17, r16); // ldclr w19, w17, [x16] __ ldeor(Assembler::word, r3, r1, r11); // ldeor w3, w1, [x11] __ ldorr(Assembler::word, r30, r5, r8); // ldset w30, w5, [x8] __ ldsmin(Assembler::word, r15, r29, r30); // ldsmin w15, w29, [x30] __ ldsmax(Assembler::word, r0, r20, r7); // ldsmax w0, w20, [x7] __ ldumin(Assembler::word, r20, r23, r28); // ldumin w20, w23, [x28] __ ldumax(Assembler::word, r21, r27, r25); // ldumax w21, w27, [x25] // LSEOp __ swpa(Assembler::word, r5, r1, r23); // swpa w5, w1, [x23] __ ldadda(Assembler::word, r16, zr, r5); // ldadda w16, wzr, [x5] __ ldbica(Assembler::word, r12, r9, r28); // ldclra w12, w9, [x28] __ ldeora(Assembler::word, r15, r29, r22); // ldeora w15, w29, [x22] __ ldorra(Assembler::word, zr, r19, sp); // ldseta wzr, w19, [sp] __ ldsmina(Assembler::word, r5, r14, r15); // ldsmina w5, w14, [x15] __ ldsmaxa(Assembler::word, zr, r16, r27); // ldsmaxa wzr, w16, [x27] __ ldumina(Assembler::word, r20, r16, r12); // ldumina w20, w16, [x12] __ ldumaxa(Assembler::word, r11, r9, r6); // ldumaxa w11, w9, [x6] // LSEOp __ swpal(Assembler::word, r30, r17, r27); // swpal w30, w17, [x27] __ ldaddal(Assembler::word, r28, r30, r7); // ldaddal w28, w30, [x7] __ ldbical(Assembler::word, r10, r20, r10); // ldclral w10, w20, [x10] __ ldeoral(Assembler::word, r4, r24, r17); // ldeoral w4, w24, [x17] __ ldorral(Assembler::word, r17, r22, r3); // ldsetal w17, w22, [x3] __ ldsminal(Assembler::word, r29, r15, r22); // ldsminal w29, w15, [x22] __ ldsmaxal(Assembler::word, r19, r19, r22); // ldsmaxal w19, w19, [x22] __ lduminal(Assembler::word, r2, r15, r6); // lduminal w2, w15, [x6] __ ldumaxal(Assembler::word, r12, r16, r11); // ldumaxal w12, w16, [x11] // LSEOp __ swpl(Assembler::word, r13, r23, r1); // swpl w13, w23, [x1] __ ldaddl(Assembler::word, r30, r19, r5); // ldaddl w30, w19, [x5] __ ldbicl(Assembler::word, r17, r2, r16); // ldclrl w17, w2, [x16] __ ldeorl(Assembler::word, r22, r13, r10); // ldeorl w22, w13, [x10] __ ldorrl(Assembler::word, r21, r29, r27); // ldsetl w21, w29, [x27] __ ldsminl(Assembler::word, r12, r27, r3); // ldsminl w12, w27, [x3] __ ldsmaxl(Assembler::word, r1, zr, r24); // ldsmaxl w1, wzr, [x24] __ lduminl(Assembler::word, r19, r17, r9); // lduminl w19, w17, [x9] __ ldumaxl(Assembler::word, r28, r27, r15); // ldumaxl w28, w27, [x15] // SHA3SIMDOp __ bcax(v6, __ T16B, v20, v22, v30); // bcax v6.16B, v20.16B, v22.16B, v30.16B __ eor3(v24, __ T16B, v2, v30, v26); // eor3 v24.16B, v2.16B, v30.16B, v26.16B __ rax1(v17, __ T2D, v10, v22); // rax1 v17.2D, v10.2D, v22.2D __ xar(v17, __ T2D, v2, v17, 1); // xar v17.2D, v2.2D, v17.2D, #1 // SHA512SIMDOp __ sha512h(v24, __ T2D, v25, v22); // sha512h q24, q25, v22.2D __ sha512h2(v2, __ T2D, v17, v12); // sha512h2 q2, q17, v12.2D __ sha512su0(v3, __ T2D, v27); // sha512su0 v3.2D, v27.2D __ sha512su1(v29, __ T2D, v28, v16); // sha512su1 v29.2D, v28.2D, v16.2D // SVEVectorOp __ sve_add(z26, __ D, z6, z9); // add z26.d, z6.d, z9.d __ sve_sub(z17, __ B, z7, z4); // sub z17.b, z7.b, z4.b __ sve_fadd(z15, __ S, z9, z22); // fadd z15.s, z9.s, z22.s __ sve_fmul(z2, __ D, z27, z20); // fmul z2.d, z27.d, z20.d __ sve_fsub(z5, __ D, z26, z0); // fsub z5.d, z26.d, z0.d __ sve_abs(z14, __ H, p1, z25); // abs z14.h, p1/m, z25.h __ sve_add(z27, __ D, p5, z26); // add z27.d, p5/m, z27.d, z26.d __ sve_asr(z24, __ B, p5, z0); // asr z24.b, p5/m, z24.b, z0.b __ sve_cnt(z6, __ B, p4, z0); // cnt z6.b, p4/m, z0.b __ sve_lsl(z15, __ B, p0, z9); // lsl z15.b, p0/m, z15.b, z9.b __ sve_lsr(z5, __ B, p2, z27); // lsr z5.b, p2/m, z5.b, z27.b __ sve_mul(z20, __ B, p5, z20); // mul z20.b, p5/m, z20.b, z20.b __ sve_neg(z10, __ D, p2, z16); // neg z10.d, p2/m, z16.d __ sve_not(z6, __ H, p4, z2); // not z6.h, p4/m, z2.h __ sve_smax(z29, __ D, p7, z2); // smax z29.d, p7/m, z29.d, z2.d __ sve_smin(z22, __ H, p7, z14); // smin z22.h, p7/m, z22.h, z14.h __ sve_sub(z27, __ B, p4, z23); // sub z27.b, p4/m, z27.b, z23.b __ sve_fabs(z2, __ D, p3, z10); // fabs z2.d, p3/m, z10.d __ sve_fadd(z10, __ S, p6, z22); // fadd z10.s, p6/m, z10.s, z22.s __ sve_fdiv(z3, __ S, p5, z16); // fdiv z3.s, p5/m, z3.s, z16.s __ sve_fmax(z1, __ D, p4, z16); // fmax z1.d, p4/m, z1.d, z16.d __ sve_fmin(z12, __ S, p3, z12); // fmin z12.s, p3/m, z12.s, z12.s __ sve_fmul(z16, __ D, p0, z20); // fmul z16.d, p0/m, z16.d, z20.d __ sve_fneg(z5, __ D, p1, z7); // fneg z5.d, p1/m, z7.d __ sve_frintm(z12, __ D, p7, z16); // frintm z12.d, p7/m, z16.d __ sve_frintn(z6, __ S, p0, z28); // frintn z6.s, p0/m, z28.s __ sve_frintp(z4, __ D, p1, z17); // frintp z4.d, p1/m, z17.d __ sve_fsqrt(z13, __ S, p3, z19); // fsqrt z13.s, p3/m, z19.s __ sve_fsub(z24, __ S, p5, z17); // fsub z24.s, p5/m, z24.s, z17.s __ sve_fmla(z10, __ D, p6, z6, z19); // fmla z10.d, p6/m, z6.d, z19.d __ sve_fmls(z13, __ S, p4, z6, z0); // fmls z13.s, p4/m, z6.s, z0.s __ sve_fnmla(z14, __ S, p4, z25, z8); // fnmla z14.s, p4/m, z25.s, z8.s __ sve_fnmls(z22, __ S, p5, z22, z27); // fnmls z22.s, p5/m, z22.s, z27.s __ sve_mla(z3, __ B, p3, z17, z20); // mla z3.b, p3/m, z17.b, z20.b __ sve_mls(z4, __ H, p7, z7, z0); // mls z4.h, p7/m, z7.h, z0.h __ sve_and(z16, z19, z22); // and z16.d, z19.d, z22.d __ sve_eor(z15, z9, z22); // eor z15.d, z9.d, z22.d __ sve_orr(z25, z5, z30); // orr z25.d, z5.d, z30.d // SVEReductionOp __ sve_andv(v13, __ B, p5, z11); // andv b13, p5, z11.b __ sve_orv(v13, __ S, p2, z20); // orv s13, p2, z20.s __ sve_eorv(v25, __ B, p3, z4); // eorv b25, p3, z4.b __ sve_smaxv(v17, __ D, p2, z6); // smaxv d17, p2, z6.d __ sve_sminv(v4, __ D, p7, z16); // sminv d4, p7, z16.d __ sve_fminv(v26, __ S, p2, z14); // fminv s26, p2, z14.s __ sve_fmaxv(v11, __ S, p7, z3); // fmaxv s11, p7, z3.s __ sve_fadda(v1, __ D, p6, z21); // fadda d1, p6, d1, z21.d __ sve_uaddv(v14, __ S, p2, z17); // uaddv d14, p2, z17.s __ bind(forth); /* */ static const unsigned int insns[] = { 0x8b0d82fa, 0xcb49970c, 0xab889dfc, 0xeb9ee787, 0x0b9b3ec9, 0x4b9179a3, 0x2b88474e, 0x6b8c56c0, 0x8a1a51e0, 0xaa11f4ba, 0xca0281b8, 0xea918c7c, 0x0a5d4a19, 0x2a4b262d, 0x4a513ca5, 0x6a9b6ae2, 0x8a70b79b, 0xaaba9728, 0xca6dfe3d, 0xea627f1c, 0x0aa70f53, 0x2aaa0f06, 0x4a6176a4, 0x6a604eb0, 0x1105ed91, 0x3100583e, 0x5101f8bd, 0x710f0306, 0x9101a1a0, 0xb10a5cc8, 0xd10810aa, 0xf10fd061, 0x120cb166, 0x321764bc, 0x52174681, 0x720c0227, 0x9241018e, 0xb25a2969, 0xd278b411, 0xf26aad01, 0x14000000, 0x17ffffd7, 0x140002db, 0x94000000, 0x97ffffd4, 0x940002d8, 0x3400000a, 0x34fffa2a, 0x34005aaa, 0x35000008, 0x35fff9c8, 0x35005a48, 0xb400000b, 0xb4fff96b, 0xb40059eb, 0xb500001d, 0xb5fff91d, 0xb500599d, 0x10000013, 0x10fff8b3, 0x10005933, 0x90000013, 0x36300016, 0x3637f836, 0x363058b6, 0x3758000c, 0x375ff7cc, 0x3758584c, 0x128313a0, 0x528a32c7, 0x7289173b, 0x92ab3acc, 0xd2a0bf94, 0xf2c285e8, 0x9358722f, 0x330e652f, 0x53067f3b, 0x93577c53, 0xb34a1aac, 0xd35a4016, 0x13946c63, 0x93c3dbc8, 0x54000000, 0x54fff5a0, 0x54005620, 0x54000001, 0x54fff541, 0x540055c1, 0x54000002, 0x54fff4e2, 0x54005562, 0x54000002, 0x54fff482, 0x54005502, 0x54000003, 0x54fff423, 0x540054a3, 0x54000003, 0x54fff3c3, 0x54005443, 0x54000004, 0x54fff364, 0x540053e4, 0x54000005, 0x54fff305, 0x54005385, 0x54000006, 0x54fff2a6, 0x54005326, 0x54000007, 0x54fff247, 0x540052c7, 0x54000008, 0x54fff1e8, 0x54005268, 0x54000009, 0x54fff189, 0x54005209, 0x5400000a, 0x54fff12a, 0x540051aa, 0x5400000b, 0x54fff0cb, 0x5400514b, 0x5400000c, 0x54fff06c, 0x540050ec, 0x5400000d, 0x54fff00d, 0x5400508d, 0x5400000e, 0x54ffefae, 0x5400502e, 0x5400000f, 0x54ffef4f, 0x54004fcf, 0xd40658e1, 0xd4014d22, 0xd4046543, 0xd4273f60, 0xd44cad80, 0xd503201f, 0xd69f03e0, 0xd6bf03e0, 0xd5033fdf, 0xd5033e9f, 0xd50332bf, 0xd61f0200, 0xd63f0280, 0xc80a7d1b, 0xc800fea1, 0xc85f7fb1, 0xc85fff9d, 0xc89ffee1, 0xc8dffe95, 0x88167e7b, 0x880bfcd0, 0x885f7c11, 0x885ffd44, 0x889ffed8, 0x88dffe6a, 0x48017fc5, 0x4808fe2c, 0x485f7dc9, 0x485ffc27, 0x489ffe05, 0x48dffd82, 0x080a7c6c, 0x081cff4e, 0x085f7d5e, 0x085ffeae, 0x089ffd2d, 0x08dfff76, 0xc87f4d7c, 0xc87fcc5e, 0xc8220417, 0xc82cb5f0, 0x887f55b1, 0x887ff90b, 0x88382c2d, 0x883aedb5, 0xf819928b, 0xb803e21c, 0x381f713b, 0x781ce322, 0xf850f044, 0xb85e129e, 0x385e92f1, 0x785ff35d, 0x39801921, 0x7881318b, 0x78dce02b, 0xb8829313, 0xfc45f318, 0xbc5d50af, 0xfc001375, 0xbc1951b7, 0xf8008c0a, 0xb801dc03, 0x38009dca, 0x781fdf3d, 0xf8570e0c, 0xb85faecc, 0x385f6d6d, 0x785ebea0, 0x38804cd7, 0x789cbce3, 0x78df9c9c, 0xb89eed18, 0xfc40cd6e, 0xbc5bdd93, 0xfc103c14, 0xbc040c08, 0xf81a2783, 0xb81ca4eb, 0x381e855b, 0x7801b4e6, 0xf853654d, 0xb85d74af, 0x384095a2, 0x785ec5bc, 0x389e15a9, 0x789dc703, 0x78c06474, 0xb89ff667, 0xfc57e51e, 0xbc4155f9, 0xfc05a6ee, 0xbc1df408, 0xf835da2a, 0xb836d9a4, 0x3833580d, 0x7826cb6c, 0xf8706900, 0xb87ae880, 0x3865db2e, 0x78714889, 0x38a7789b, 0x78beca2f, 0x78f6c810, 0xb8bef956, 0xfc6afabd, 0xbc734963, 0xfc3d5b8d, 0xbc25fbb7, 0xf9189d05, 0xb91ecb1d, 0x39187a33, 0x791f226d, 0xf95aa2f3, 0xb9587bb7, 0x395f7176, 0x795d9143, 0x399e7e08, 0x799a2697, 0x79df3422, 0xb99c2624, 0xfd5c2374, 0xbd5fa1d9, 0xfd1d595a, 0xbd1b1869, 0x5800401b, 0x1800000b, 0xf8945060, 0xd8000000, 0xf8ae6ba0, 0xf99a0080, 0x1a070035, 0x3a0700a8, 0x5a0e0367, 0x7a11009b, 0x9a000380, 0xba1e030c, 0xda0f0320, 0xfa030301, 0x0b340b11, 0x2b2a278d, 0xcb22aa0f, 0x6b2d29bd, 0x8b2cce8c, 0xab2b877e, 0xcb21c8ee, 0xeb3ba47d, 0x3a4d400e, 0x7a5132c6, 0xba5e622e, 0xfa53814c, 0x3a52d8c2, 0x7a4d8924, 0xba4b3aab, 0xfa4d7882, 0x1a96804c, 0x1a912618, 0x5a90b0e6, 0x5a96976b, 0x9a9db06a, 0x9a9b374c, 0xda95c14f, 0xda89c6fe, 0x5ac0015e, 0x5ac005fd, 0x5ac00bdd, 0x5ac012b9, 0x5ac01404, 0xdac002b1, 0xdac0061d, 0xdac00a95, 0xdac00e66, 0xdac0107e, 0xdac01675, 0x1ac00b0b, 0x1ace0f3b, 0x1ad121c3, 0x1ad825e7, 0x1ad92a3c, 0x1adc2f42, 0x9ada0b25, 0x9ad10e1b, 0x9acc22a6, 0x9acc2480, 0x9adc2a3b, 0x9ad12c5c, 0x9bce7dea, 0x9b597c6e, 0x1b0e166f, 0x1b1ae490, 0x9b023044, 0x9b089e3d, 0x9b391083, 0x9b24c73a, 0x9bb15f40, 0x9bbcc6af, 0x7ea3d55b, 0x1e3908e0, 0x1e2f18c9, 0x1e2a29fd, 0x1e273a22, 0x7ef7d56b, 0x1e770ba7, 0x1e6b1b6e, 0x1e78288b, 0x1e6e39ec, 0x1f1c3574, 0x1f17f98b, 0x1f2935da, 0x1f2574ea, 0x1f4b306f, 0x1f5ec7cf, 0x1f6f3e93, 0x1f6226a9, 0x1e2040fb, 0x1e20c3dd, 0x1e214031, 0x1e21c0c2, 0x1e22c06a, 0x1e604178, 0x1e60c027, 0x1e61400b, 0x1e61c223, 0x1e6240dc, 0x1e3800d6, 0x9e380360, 0x1e78005a, 0x9e7800e5, 0x1e22017c, 0x9e2201b9, 0x1e6202eb, 0x9e620113, 0x1e2602b1, 0x9e660299, 0x1e270233, 0x9e6703a2, 0x1e2822c0, 0x1e7322a0, 0x1e202288, 0x1e602168, 0x293c19f4, 0x2966387b, 0x69762970, 0xa9041dc7, 0xa9475c0c, 0x29b61ccd, 0x29ee3c5e, 0x69ee0764, 0xa9843977, 0xa9f46ebd, 0x28ba16b6, 0x28fc44db, 0x68f61430, 0xa8b352cd, 0xa8c56d5e, 0x28024565, 0x2874134e, 0xa8027597, 0xa87b1aa0, 0x0c40734f, 0x4cdfa177, 0x0cc76ee8, 0x4cdf2733, 0x0d40c23d, 0x4ddfcaf8, 0x0dd9ccaa, 0x4c408d51, 0x0cdf85ec, 0x4d60c239, 0x0dffcbc1, 0x4de9ce30, 0x4cc24999, 0x0c404a7a, 0x4d40e6af, 0x4ddfe9b9, 0x0dddef8e, 0x4cdf07b1, 0x0cc000fb, 0x0d60e238, 0x0dffe740, 0x0de2eb2c, 0x0e31baf6, 0x4e31bb9b, 0x0e71b8a4, 0x4e71b907, 0x4eb1b8e6, 0x0e30a841, 0x4e30ab7a, 0x0e70aa0f, 0x4e70a862, 0x4eb0a9cd, 0x6e30f9cd, 0x0e31ab38, 0x4e31ab17, 0x0e71a8a4, 0x4e71aa93, 0x4eb1aa0f, 0x6eb0f820, 0x7e30f8a4, 0x7e70fab4, 0x7eb0f98b, 0x7ef0fbdd, 0x0e20ba0f, 0x4e20bad5, 0x0e60b8a4, 0x4e60b9ee, 0x0ea0baf6, 0x4ea0bb59, 0x4ee0b8e6, 0x0ea0f9ac, 0x4ea0f9ee, 0x4ee0f9cd, 0x2ea0f9ee, 0x6ea0f949, 0x6ee0fb59, 0x2ea1fbbc, 0x6ea1f96a, 0x6ee1fa93, 0x2e20598b, 0x6e205a51, 0x0e371ed5, 0x4e311e0f, 0x0eb61eb4, 0x4eb91f17, 0x2e3c1f7a, 0x6e271cc5, 0x0e2884e6, 0x4e31860f, 0x0e71860f, 0x4e7b8759, 0x0eb28630, 0x4ebd879b, 0x4efa8738, 0x0e31d60f, 0x4e3bd759, 0x4e70d5ee, 0x2e2c856a, 0x6e2f85cd, 0x2e7085ee, 0x6e7686b4, 0x2ea38441, 0x6eb886f6, 0x6ee087fe, 0x0eb0d5ee, 0x4ea4d462, 0x4ee8d4e6, 0x0e259c83, 0x4e299d07, 0x0e7a9f38, 0x4e629c20, 0x0ebd9f9b, 0x4ebf9fdd, 0x2ea7d4c5, 0x6ea7d4c5, 0x6effd7dd, 0x2e2ddd8b, 0x6e3bdf59, 0x6e62dc20, 0x0e6097fe, 0x4e629420, 0x0eb39651, 0x4ebe97bc, 0x0e3bcf59, 0x4e2bcd49, 0x4e7bcf59, 0x2e6e95ac, 0x6e71960f, 0x2ead958b, 0x6eac956a, 0x0eb3ce51, 0x4ebacf38, 0x4ef7ced5, 0x2e39ff17, 0x6e22fc20, 0x6e72fe30, 0x0e2c656a, 0x4e2864e6, 0x0e7e67bc, 0x4e6864e6, 0x0ea764c5, 0x4ea764c5, 0x0e36f6b4, 0x4e33f651, 0x4e71f60f, 0x0e336e51, 0x4e3f6fdd, 0x0e7c6f7a, 0x4e7e6fbc, 0x0ea36c41, 0x4ebd6f9b, 0x0ea2f420, 0x4eb6f6b4, 0x4efef7bc, 0x2e318e0f, 0x6e2e8dac, 0x2e6c8d6a, 0x6e7e8fbc, 0x2ebe8fbc, 0x6eb58e93, 0x6ef88ef6, 0x0e2ce56a, 0x4e26e4a4, 0x4e60e7fe, 0x0e3636b4, 0x4e2a3528, 0x0e6037fe, 0x4e733651, 0x0eac356a, 0x4ebd379b, 0x4ee43462, 0x2ebae738, 0x6ea6e4a4, 0x6ee5e483, 0x0e2a3d28, 0x4e383ef6, 0x0e733e51, 0x4e6f3dcd, 0x0ea63ca4, 0x4ebe3fbc, 0x4ef93f17, 0x2e37e6d5, 0x6e3be759, 0x6e7ae738, 0xba5fd3e3, 0x3a5f03e5, 0xfa411be4, 0x7a42cbe2, 0x93df03ff, 0xc820ffff, 0x8822fc7f, 0xc8247cbf, 0x88267fff, 0x4e010fe0, 0x4e081fe1, 0x4e0c1fe1, 0x4e0a1fe1, 0x4e071fe1, 0x4e042c20, 0x4e062c20, 0x4e052c20, 0x4e083c20, 0x0e0c3c20, 0x0e0a3c20, 0x0e073c20, 0x4cc0ac3f, 0x05a08020, 0x04b0e3e0, 0x0470e7e1, 0x042f9c20, 0x043f9c35, 0x047f9c20, 0x04ff9c20, 0x04299420, 0x04319160, 0x0461943e, 0x04a19020, 0x042053ff, 0x047f5401, 0x25208028, 0x2538cfe0, 0x2578d001, 0x25b8efe2, 0x25f8f007, 0xa400a3e0, 0xa4a8a7ea, 0xa547a814, 0xa4084ffe, 0xa55c53e0, 0xa5e1540b, 0xe400fbf6, 0xe408ffff, 0xe547e400, 0xe4014be0, 0xe4a84fe0, 0xe5f15000, 0x858043e0, 0x85a043ff, 0xe59f5d08, 0x1e601000, 0x1e603000, 0x1e621000, 0x1e623000, 0x1e641000, 0x1e643000, 0x1e661000, 0x1e663000, 0x1e681000, 0x1e683000, 0x1e6a1000, 0x1e6a3000, 0x1e6c1000, 0x1e6c3000, 0x1e6e1000, 0x1e6e3000, 0x1e701000, 0x1e703000, 0x1e721000, 0x1e723000, 0x1e741000, 0x1e743000, 0x1e761000, 0x1e763000, 0x1e781000, 0x1e783000, 0x1e7a1000, 0x1e7a3000, 0x1e7c1000, 0x1e7c3000, 0x1e7e1000, 0x1e7e3000, 0xf8238358, 0xf83702af, 0xf8231118, 0xf8392214, 0xf8313022, 0xf8205098, 0xf82343ec, 0xf83c734a, 0xf82261ec, 0xf8bf81a1, 0xf8bd0260, 0xf8ac12d1, 0xf8ad23dc, 0xf8bf3341, 0xf8bc53c4, 0xf8a443c6, 0xf8ba7130, 0xf8a8600c, 0xf8f48301, 0xf8e20120, 0xf8f8121a, 0xf8fe2143, 0xf8f7308a, 0xf8f05162, 0xf8e841ea, 0xf8f17142, 0xf8ec61ec, 0xf86d80e2, 0xf874021a, 0xf8641082, 0xf86c22b0, 0xf8703170, 0xf8755197, 0xf87a4397, 0xf86e730b, 0xf86163ec, 0xb82a80f0, 0xb82201a3, 0xb8331211, 0xb8232161, 0xb83e3105, 0xb82f53dd, 0xb82040f4, 0xb8347397, 0xb835633b, 0xb8a582e1, 0xb8b000bf, 0xb8ac1389, 0xb8af22dd, 0xb8bf33f3, 0xb8a551ee, 0xb8bf4370, 0xb8b47190, 0xb8ab60c9, 0xb8fe8371, 0xb8fc00fe, 0xb8ea1154, 0xb8e42238, 0xb8f13076, 0xb8fd52cf, 0xb8f342d3, 0xb8e270cf, 0xb8ec6170, 0xb86d8037, 0xb87e00b3, 0xb8711202, 0xb876214d, 0xb875337d, 0xb86c507b, 0xb861431f, 0xb8737131, 0xb87c61fb, 0xce367a86, 0xce1e6858, 0xce768d51, 0xce910451, 0xce768338, 0xce6c8622, 0xcec08363, 0xce708b9d, 0x04e900da, 0x042404f1, 0x6596012f, 0x65d40b62, 0x65c00745, 0x0456a72e, 0x04c0175b, 0x04109418, 0x041ab006, 0x0413812f, 0x04118b65, 0x04101694, 0x04d7aa0a, 0x045eb046, 0x04c81c5d, 0x044a1dd6, 0x040112fb, 0x04dcad42, 0x65809aca, 0x658d9603, 0x65c69201, 0x65878d8c, 0x65c28290, 0x04dda4e5, 0x65c2be0c, 0x6580a386, 0x65c1a624, 0x658dae6d, 0x65819638, 0x65f318ca, 0x65a030cd, 0x65a8532e, 0x65bb76d6, 0x04144e23, 0x04407ce4, 0x04363270, 0x04b6312f, 0x047e30b9, 0x041a356d, 0x04982a8d, 0x04192c99, 0x04c828d1, 0x04ca3e04, 0x658729da, 0x65863c6b, 0x65d83aa1, 0x04812a2e, }; // END Generated code -- do not edit