-rw-r--r-- 191066 lib25519-20220426/crypto_hashblocks/sha512/m4mult/inner32.S raw
# qhasm: int32 input_0 # qhasm: int32 input_1 # qhasm: int32 input_2 # qhasm: int32 input_3 # qhasm: stack32 input_4 # qhasm: stack32 input_5 # qhasm: stack32 input_6 # qhasm: stack32 input_7 # qhasm: int32 caller_r4 # qhasm: int32 caller_r5 # qhasm: int32 caller_r6 # qhasm: int32 caller_r7 # qhasm: int32 caller_r8 # qhasm: int32 caller_r9 # qhasm: int32 caller_r10 # qhasm: int32 caller_r11 # qhasm: int32 caller_r12 # qhasm: int32 caller_r14 # qhasm: startcode .text .arch armv7 .fpu fpv4-sp-d16 .syntax unified # qhasm: int32 two13 # qhasm: int32 two23 # qhasm: int32 two24 # qhasm: int32 two25 # qhasm: int32 lotmp # qhasm: int32 lotmp2 # qhasm: int32 hitmp # qhasm: int32 hitmp2 # qhasm: int32 lou0 # qhasm: int32 lou1 # qhasm: int32 lou2 # qhasm: int32 lou3 # qhasm: int32 lou4 # qhasm: int32 lou5 # qhasm: int32 hiu0 # qhasm: int32 hiu1 # qhasm: int32 hiu2 # qhasm: int32 hiu3 # qhasm: int32 hiu4 # qhasm: int32 hiu5 # qhasm: float32 hid0 # qhasm: float32 hid1 # qhasm: float32 hid2 # qhasm: float32 hid3 # qhasm: float32 hid4 # qhasm: float32 hid5 # qhasm: float32 hid6 # qhasm: float32 hid7 # qhasm: float32 hid8 # qhasm: float32 hid9 # qhasm: float32 hid10 # qhasm: float32 hid11 # qhasm: float32 hid12 # qhasm: float32 hid13 # qhasm: float32 hid14 # qhasm: float32 hid15 # qhasm: float32 lod0 # qhasm: float32 lod1 # qhasm: float32 lod2 # qhasm: float32 lod3 # qhasm: float32 lod4 # qhasm: float32 lod5 # qhasm: float32 lod6 # qhasm: float32 lod7 # qhasm: float32 lod8 # qhasm: float32 lod9 # qhasm: float32 lod10 # qhasm: float32 lod11 # qhasm: float32 lod12 # qhasm: float32 lod13 # qhasm: float32 lod14 # qhasm: float32 lod15 # qhasm: stack32 him0 # qhasm: stack32 him1 # qhasm: stack32 him2 # qhasm: stack32 him3 # qhasm: stack32 him4 # qhasm: stack32 him5 # qhasm: stack32 him6 # qhasm: stack32 him7 # qhasm: stack32 him8 # qhasm: stack32 him9 # qhasm: stack32 him10 # qhasm: stack32 him11 # qhasm: stack32 him12 # qhasm: stack32 him13 # qhasm: stack32 him14 # qhasm: stack32 him15 # qhasm: stack32 lom0 # qhasm: stack32 lom1 # qhasm: stack32 lom2 # qhasm: stack32 lom3 # qhasm: stack32 lom4 # qhasm: stack32 lom5 # qhasm: stack32 lom6 # qhasm: stack32 lom7 # qhasm: stack32 lom8 # qhasm: stack32 lom9 # qhasm: stack32 lom10 # qhasm: stack32 lom11 # qhasm: stack32 lom12 # qhasm: stack32 lom13 # qhasm: stack32 lom14 # qhasm: stack32 lom15 # qhasm: stack32 o0 # qhasm: stack32 o1 # qhasm: stack32 o2 # qhasm: stack32 o3 # qhasm: stack32 o4 # qhasm: pushenter CRYPTO_NAMESPACE(inner) .p2align 2 .global CRYPTO_NAMESPACE(inner) .type CRYPTO_NAMESPACE(inner),%function .thumb .thumb_func CRYPTO_NAMESPACE(inner): push {r4,r5,r6,r7,r8,r9,r10,r11,r14} vpush {d8-d15} sub.w sp,sp,#160 # qhasm: o0 = input_0 # asm 1: str <input_0=int32#1,>o0=stack32#1 # asm 2: str <input_0=r0,>o0=[sp,#0] # copy-collector input: str r0,[sp,#0] # qhasm: o1 = input_1 # asm 1: str <input_1=int32#2,>o1=stack32#2 # asm 2: str <input_1=r1,>o1=[sp,#4] # copy-collector input: str r1,[sp,#4] # qhasm: input_1 = input_2 - 128 # asm 1: sub >input_1=int32#2,<input_2=int32#3,#128 # asm 2: sub >input_1=r1,<input_2=r2,#128 # copy-collector output starts strd r0,r1,[sp,#0] # copy-collector output ends sub r1,r2,#128 # qhasm: o2 = input_1 # asm 1: str <input_1=int32#2,>o2=stack32#3 # asm 2: str <input_1=r1,>o2=[sp,#8] # copy-collector input: str r1,[sp,#8] # qhasm: o3 = input_3 # asm 1: str <input_3=int32#4,>o3=stack32#4 # asm 2: str <input_3=r3,>o3=[sp,#12] # copy-collector input: str r3,[sp,#12] # qhasm: hiu0 = mem32[input_0] # asm 1: ldr >hiu0=int32#2,[<input_0=int32#1] # asm 2: ldr >hiu0=r1,[<input_0=r0] # copy-collector input: ldr r1,[r0] # qhasm: lou0 = mem32[input_0+4] # asm 1: ldr >lou0=int32#3,[<input_0=int32#1,#4] # asm 2: ldr >lou0=r2,[<input_0=r0,#4] # copy-collector input: ldr r2,[r0,#4] # qhasm: hiu1 = mem32[input_0+8] # asm 1: ldr >hiu1=int32#4,[<input_0=int32#1,#8] # asm 2: ldr >hiu1=r3,[<input_0=r0,#8] # copy-collector input: ldr r3,[r0,#8] # qhasm: lou1 = mem32[input_0+12] # asm 1: ldr >lou1=int32#5,[<input_0=int32#1,#12] # asm 2: ldr >lou1=r4,[<input_0=r0,#12] # copy-collector input: ldr r4,[r0,#12] # qhasm: hiu2 = mem32[input_0+16] # asm 1: ldr >hiu2=int32#6,[<input_0=int32#1,#16] # asm 2: ldr >hiu2=r5,[<input_0=r0,#16] # copy-collector input: ldr r5,[r0,#16] # qhasm: lou2 = mem32[input_0+20] # asm 1: ldr >lou2=int32#7,[<input_0=int32#1,#20] # asm 2: ldr >lou2=r6,[<input_0=r0,#20] # copy-collector input: ldr r6,[r0,#20] # qhasm: hiu3 = mem32[input_0+24] # asm 1: ldr >hiu3=int32#8,[<input_0=int32#1,#24] # asm 2: ldr >hiu3=r7,[<input_0=r0,#24] # copy-collector input: ldr r7,[r0,#24] # qhasm: lou3 = mem32[input_0+28] # asm 1: ldr >lou3=int32#9,[<input_0=int32#1,#28] # asm 2: ldr >lou3=r8,[<input_0=r0,#28] # copy-collector input: ldr r8,[r0,#28] # qhasm: lou0 = lou0[3]lou0[2]lou0[1]lou0[0] # asm 1: rev >lou0=int32#3,<lou0=int32#3 # asm 2: rev >lou0=r2,<lou0=r2 # copy-collector output starts strd r1,r3,[sp,#8] ldr r1,[r0] ldr r2,[r0,#4] ldr r3,[r0,#8] ldr r4,[r0,#12] ldr r5,[r0,#16] ldr r6,[r0,#20] ldr.w r7,[r0,#24] ldr r8,[r0,#28] # copy-collector output ends rev r2,r2 # qhasm: hiu0 = hiu0[3]hiu0[2]hiu0[1]hiu0[0] # asm 1: rev >hiu0=int32#2,<hiu0=int32#2 # asm 2: rev >hiu0=r1,<hiu0=r1 rev r1,r1 # qhasm: lou1 = lou1[3]lou1[2]lou1[1]lou1[0] # asm 1: rev >lou1=int32#5,<lou1=int32#5 # asm 2: rev >lou1=r4,<lou1=r4 rev r4,r4 # qhasm: hiu1 = hiu1[3]hiu1[2]hiu1[1]hiu1[0] # asm 1: rev >hiu1=int32#4,<hiu1=int32#4 # asm 2: rev >hiu1=r3,<hiu1=r3 rev r3,r3 # qhasm: lou2 = lou2[3]lou2[2]lou2[1]lou2[0] # asm 1: rev >lou2=int32#7,<lou2=int32#7 # asm 2: rev >lou2=r6,<lou2=r6 rev r6,r6 # qhasm: hiu2 = hiu2[3]hiu2[2]hiu2[1]hiu2[0] # asm 1: rev >hiu2=int32#6,<hiu2=int32#6 # asm 2: rev >hiu2=r5,<hiu2=r5 rev r5,r5 # qhasm: lou3 = lou3[3]lou3[2]lou3[1]lou3[0] # asm 1: rev >lou3=int32#9,<lou3=int32#9 # asm 2: rev >lou3=r8,<lou3=r8 rev r8,r8 # qhasm: hiu3 = hiu3[3]hiu3[2]hiu3[1]hiu3[0] # asm 1: rev >hiu3=int32#8,<hiu3=int32#8 # asm 2: rev >hiu3=r7,<hiu3=r7 rev.w r7,r7 # qhasm: lom0 = lou0 # asm 1: str <lou0=int32#3,>lom0=stack32#5 # asm 2: str <lou0=r2,>lom0=[sp,#16] # copy-collector input: str r2,[sp,#16] # qhasm: him0 = hiu0 # asm 1: str <hiu0=int32#2,>him0=stack32#6 # asm 2: str <hiu0=r1,>him0=[sp,#20] # copy-collector input: str r1,[sp,#20] # qhasm: lom1 = lou1 # asm 1: str <lou1=int32#5,>lom1=stack32#7 # asm 2: str <lou1=r4,>lom1=[sp,#24] # copy-collector input: str r4,[sp,#24] # qhasm: him1 = hiu1 # asm 1: str <hiu1=int32#4,>him1=stack32#8 # asm 2: str <hiu1=r3,>him1=[sp,#28] # copy-collector input: str r3,[sp,#28] # qhasm: lom2 = lou2 # asm 1: str <lou2=int32#7,>lom2=stack32#9 # asm 2: str <lou2=r6,>lom2=[sp,#32] # copy-collector input: str r6,[sp,#32] # qhasm: him2 = hiu2 # asm 1: str <hiu2=int32#6,>him2=stack32#10 # asm 2: str <hiu2=r5,>him2=[sp,#36] # copy-collector input: str r5,[sp,#36] # qhasm: lom3 = lou3 # asm 1: str <lou3=int32#9,>lom3=stack32#11 # asm 2: str <lou3=r8,>lom3=[sp,#40] # copy-collector input: str r8,[sp,#40] # qhasm: him3 = hiu3 # asm 1: str <hiu3=int32#8,>him3=stack32#12 # asm 2: str <hiu3=r7,>him3=[sp,#44] # copy-collector input: str r7,[sp,#44] # qhasm: lod0 = lou0 # asm 1: vmov >lod0=float32#1,<lou0=int32#3 # asm 2: vmov >lod0=s0,<lou0=r2 # copy-collector input: vmov s0,r2 # qhasm: hid0 = hiu0 # asm 1: vmov >hid0=float32#2,<hiu0=int32#2 # asm 2: vmov >hid0=s1,<hiu0=r1 # copy-collector input: vmov s1,r1 # qhasm: lod1 = lou1 # asm 1: vmov >lod1=float32#3,<lou1=int32#5 # asm 2: vmov >lod1=s2,<lou1=r4 # copy-collector input: vmov s2,r4 # qhasm: hid1 = hiu1 # asm 1: vmov >hid1=float32#4,<hiu1=int32#4 # asm 2: vmov >hid1=s3,<hiu1=r3 # copy-collector input: vmov s3,r3 # qhasm: lod2 = lou2 # asm 1: vmov >lod2=float32#5,<lou2=int32#7 # asm 2: vmov >lod2=s4,<lou2=r6 # copy-collector input: vmov s4,r6 # qhasm: hid2 = hiu2 # asm 1: vmov >hid2=float32#6,<hiu2=int32#6 # asm 2: vmov >hid2=s5,<hiu2=r5 # copy-collector input: vmov s5,r5 # qhasm: lod3 = lou3 # asm 1: vmov >lod3=float32#7,<lou3=int32#9 # asm 2: vmov >lod3=s6,<lou3=r8 # copy-collector input: vmov s6,r8 # qhasm: hid3 = hiu3 # asm 1: vmov >hid3=float32#8,<hiu3=int32#8 # asm 2: vmov >hid3=s7,<hiu3=r7 # copy-collector input: vmov s7,r7 # qhasm: hiu0 = mem32[input_0+32] # asm 1: ldr >hiu0=int32#2,[<input_0=int32#1,#32] # asm 2: ldr >hiu0=r1,[<input_0=r0,#32] # copy-collector input: ldr r1,[r0,#32] # qhasm: lou0 = mem32[input_0+36] # asm 1: ldr >lou0=int32#3,[<input_0=int32#1,#36] # asm 2: ldr >lou0=r2,[<input_0=r0,#36] # copy-collector input: ldr r2,[r0,#36] # qhasm: hiu1 = mem32[input_0+40] # asm 1: ldr >hiu1=int32#4,[<input_0=int32#1,#40] # asm 2: ldr >hiu1=r3,[<input_0=r0,#40] # copy-collector input: ldr r3,[r0,#40] # qhasm: lou1 = mem32[input_0+44] # asm 1: ldr >lou1=int32#5,[<input_0=int32#1,#44] # asm 2: ldr >lou1=r4,[<input_0=r0,#44] # copy-collector input: ldr r4,[r0,#44] # qhasm: hiu2 = mem32[input_0+48] # asm 1: ldr >hiu2=int32#6,[<input_0=int32#1,#48] # asm 2: ldr >hiu2=r5,[<input_0=r0,#48] # copy-collector input: ldr r5,[r0,#48] # qhasm: lou2 = mem32[input_0+52] # asm 1: ldr >lou2=int32#7,[<input_0=int32#1,#52] # asm 2: ldr >lou2=r6,[<input_0=r0,#52] # copy-collector input: ldr r6,[r0,#52] # qhasm: hiu3 = mem32[input_0+56] # asm 1: ldr >hiu3=int32#8,[<input_0=int32#1,#56] # asm 2: ldr >hiu3=r7,[<input_0=r0,#56] # copy-collector input: ldr r7,[r0,#56] # qhasm: lou3 = mem32[input_0+60] # asm 1: ldr >lou3=int32#1,[<input_0=int32#1,#60] # asm 2: ldr >lou3=r0,[<input_0=r0,#60] # copy-collector input: ldr r0,[r0,#60] # qhasm: lou0 = lou0[3]lou0[2]lou0[1]lou0[0] # asm 1: rev >lou0=int32#3,<lou0=int32#3 # asm 2: rev >lou0=r2,<lou0=r2 # copy-collector output starts strd r2,r1,[sp,#16] strd r4,r3,[sp,#24] strd r6,r5,[sp,#32] strd r8,r7,[sp,#40] vmov d0,r2,r1 vmov d1,r4,r3 vmov d2,r6,r5 vmov d3,r8,r7 ldr r1,[r0,#32] ldr r2,[r0,#36] ldr r3,[r0,#40] ldr r4,[r0,#44] ldr r5,[r0,#48] ldr r6,[r0,#52] ldr r7,[r0,#56] ldr r0,[r0,#60] # copy-collector output ends rev r2,r2 # qhasm: hiu0 = hiu0[3]hiu0[2]hiu0[1]hiu0[0] # asm 1: rev >hiu0=int32#2,<hiu0=int32#2 # asm 2: rev >hiu0=r1,<hiu0=r1 rev r1,r1 # qhasm: lou1 = lou1[3]lou1[2]lou1[1]lou1[0] # asm 1: rev >lou1=int32#5,<lou1=int32#5 # asm 2: rev >lou1=r4,<lou1=r4 rev r4,r4 # qhasm: hiu1 = hiu1[3]hiu1[2]hiu1[1]hiu1[0] # asm 1: rev >hiu1=int32#4,<hiu1=int32#4 # asm 2: rev >hiu1=r3,<hiu1=r3 rev r3,r3 # qhasm: lou2 = lou2[3]lou2[2]lou2[1]lou2[0] # asm 1: rev >lou2=int32#7,<lou2=int32#7 # asm 2: rev >lou2=r6,<lou2=r6 rev r6,r6 # qhasm: hiu2 = hiu2[3]hiu2[2]hiu2[1]hiu2[0] # asm 1: rev >hiu2=int32#6,<hiu2=int32#6 # asm 2: rev >hiu2=r5,<hiu2=r5 rev r5,r5 # qhasm: lou3 = lou3[3]lou3[2]lou3[1]lou3[0] # asm 1: rev >lou3=int32#1,<lou3=int32#1 # asm 2: rev >lou3=r0,<lou3=r0 rev r0,r0 # qhasm: hiu3 = hiu3[3]hiu3[2]hiu3[1]hiu3[0] # asm 1: rev >hiu3=int32#8,<hiu3=int32#8 # asm 2: rev >hiu3=r7,<hiu3=r7 rev r7,r7 # qhasm: lom4 = lou0 # asm 1: str <lou0=int32#3,>lom4=stack32#13 # asm 2: str <lou0=r2,>lom4=[sp,#48] # copy-collector input: str r2,[sp,#48] # qhasm: him4 = hiu0 # asm 1: str <hiu0=int32#2,>him4=stack32#14 # asm 2: str <hiu0=r1,>him4=[sp,#52] # copy-collector input: str r1,[sp,#52] # qhasm: lom5 = lou1 # asm 1: str <lou1=int32#5,>lom5=stack32#15 # asm 2: str <lou1=r4,>lom5=[sp,#56] # copy-collector input: str r4,[sp,#56] # qhasm: him5 = hiu1 # asm 1: str <hiu1=int32#4,>him5=stack32#16 # asm 2: str <hiu1=r3,>him5=[sp,#60] # copy-collector input: str r3,[sp,#60] # qhasm: lom6 = lou2 # asm 1: str <lou2=int32#7,>lom6=stack32#17 # asm 2: str <lou2=r6,>lom6=[sp,#64] # copy-collector input: str r6,[sp,#64] # qhasm: him6 = hiu2 # asm 1: str <hiu2=int32#6,>him6=stack32#18 # asm 2: str <hiu2=r5,>him6=[sp,#68] # copy-collector input: str r5,[sp,#68] # qhasm: lom7 = lou3 # asm 1: str <lou3=int32#1,>lom7=stack32#19 # asm 2: str <lou3=r0,>lom7=[sp,#72] # copy-collector input: str r0,[sp,#72] # qhasm: him7 = hiu3 # asm 1: str <hiu3=int32#8,>him7=stack32#20 # asm 2: str <hiu3=r7,>him7=[sp,#76] # copy-collector input: str r7,[sp,#76] # qhasm: lod4 = lou0 # asm 1: vmov >lod4=float32#9,<lou0=int32#3 # asm 2: vmov >lod4=s8,<lou0=r2 # copy-collector input: vmov s8,r2 # qhasm: hid4 = hiu0 # asm 1: vmov >hid4=float32#10,<hiu0=int32#2 # asm 2: vmov >hid4=s9,<hiu0=r1 # copy-collector input: vmov s9,r1 # qhasm: lod5 = lou1 # asm 1: vmov >lod5=float32#11,<lou1=int32#5 # asm 2: vmov >lod5=s10,<lou1=r4 # copy-collector input: vmov s10,r4 # qhasm: hid5 = hiu1 # asm 1: vmov >hid5=float32#12,<hiu1=int32#4 # asm 2: vmov >hid5=s11,<hiu1=r3 # copy-collector input: vmov s11,r3 # qhasm: lod6 = lou2 # asm 1: vmov >lod6=float32#13,<lou2=int32#7 # asm 2: vmov >lod6=s12,<lou2=r6 # copy-collector input: vmov s12,r6 # qhasm: hid6 = hiu2 # asm 1: vmov >hid6=float32#14,<hiu2=int32#6 # asm 2: vmov >hid6=s13,<hiu2=r5 # copy-collector input: vmov s13,r5 # qhasm: lod7 = lou3 # asm 1: vmov >lod7=float32#15,<lou3=int32#1 # asm 2: vmov >lod7=s14,<lou3=r0 # copy-collector input: vmov s14,r0 # qhasm: hid7 = hiu3 # asm 1: vmov >hid7=float32#16,<hiu3=int32#8 # asm 2: vmov >hid7=s15,<hiu3=r7 # copy-collector input: vmov s15,r7 # qhasm: mainloop: # copy-collector output starts strd r2,r1,[sp,#48] strd r4,r3,[sp,#56] strd r6,r5,[sp,#64] strd r0,r7,[sp,#72] vmov d4,r2,r1 vmov d5,r4,r3 vmov d6,r6,r5 vmov d7,r0,r7 # copy-collector output ends ._mainloop: # qhasm: input_0 = o1 # asm 1: ldr >input_0=int32#1,<o1=stack32#2 # asm 2: ldr >input_0=r0,<o1=[sp,#4] # copy-collector input: ldr r0,[sp,#4] # qhasm: hiu0 = mem32[input_0]; input_0 += 4 # asm 1: ldr >hiu0=int32#2,[<input_0=int32#1],#4 # asm 2: ldr >hiu0=r1,[<input_0=r0],#4 # copy-collector input: ldr r1,[r0],#4 # qhasm: lou0 = mem32[input_0]; input_0 += 4 # asm 1: ldr >lou0=int32#3,[<input_0=int32#1],#4 # asm 2: ldr >lou0=r2,[<input_0=r0],#4 # copy-collector input: ldr r2,[r0],#4 # qhasm: hiu1 = mem32[input_0]; input_0 += 4 # asm 1: ldr >hiu1=int32#4,[<input_0=int32#1],#4 # asm 2: ldr >hiu1=r3,[<input_0=r0],#4 # copy-collector input: ldr r3,[r0],#4 # qhasm: lou1 = mem32[input_0]; input_0 += 4 # asm 1: ldr >lou1=int32#5,[<input_0=int32#1],#4 # asm 2: ldr >lou1=r4,[<input_0=r0],#4 # copy-collector input: ldr r4,[r0],#4 # qhasm: hiu2 = mem32[input_0]; input_0 += 4 # asm 1: ldr >hiu2=int32#6,[<input_0=int32#1],#4 # asm 2: ldr >hiu2=r5,[<input_0=r0],#4 # copy-collector input: ldr r5,[r0],#4 # qhasm: lou2 = mem32[input_0]; input_0 += 4 # asm 1: ldr >lou2=int32#7,[<input_0=int32#1],#4 # asm 2: ldr >lou2=r6,[<input_0=r0],#4 # copy-collector input: ldr r6,[r0],#4 # qhasm: hiu3 = mem32[input_0]; input_0 += 4 # asm 1: ldr >hiu3=int32#8,[<input_0=int32#1],#4 # asm 2: ldr >hiu3=r7,[<input_0=r0],#4 # copy-collector input: ldr r7,[r0],#4 # qhasm: lou3 = mem32[input_0]; input_0 += 4 # asm 1: ldr >lou3=int32#9,[<input_0=int32#1],#4 # asm 2: ldr >lou3=r8,[<input_0=r0],#4 # copy-collector input: ldr r8,[r0],#4 # qhasm: lou0 = lou0[3]lou0[2]lou0[1]lou0[0] # asm 1: rev >lou0=int32#3,<lou0=int32#3 # asm 2: rev >lou0=r2,<lou0=r2 # copy-collector output starts ldr.w r0,[sp,#4] ldr r1,[r0],#4 ldr r2,[r0],#4 ldr r3,[r0],#4 ldr r4,[r0],#4 ldr r5,[r0],#4 ldr r6,[r0],#4 ldr r7,[r0],#4 ldr r8,[r0],#4 # copy-collector output ends rev r2,r2 # qhasm: hiu0 = hiu0[3]hiu0[2]hiu0[1]hiu0[0] # asm 1: rev >hiu0=int32#2,<hiu0=int32#2 # asm 2: rev >hiu0=r1,<hiu0=r1 rev r1,r1 # qhasm: lou1 = lou1[3]lou1[2]lou1[1]lou1[0] # asm 1: rev >lou1=int32#5,<lou1=int32#5 # asm 2: rev >lou1=r4,<lou1=r4 rev r4,r4 # qhasm: hiu1 = hiu1[3]hiu1[2]hiu1[1]hiu1[0] # asm 1: rev >hiu1=int32#4,<hiu1=int32#4 # asm 2: rev >hiu1=r3,<hiu1=r3 rev r3,r3 # qhasm: lou2 = lou2[3]lou2[2]lou2[1]lou2[0] # asm 1: rev >lou2=int32#7,<lou2=int32#7 # asm 2: rev >lou2=r6,<lou2=r6 rev r6,r6 # qhasm: hiu2 = hiu2[3]hiu2[2]hiu2[1]hiu2[0] # asm 1: rev >hiu2=int32#6,<hiu2=int32#6 # asm 2: rev >hiu2=r5,<hiu2=r5 rev r5,r5 # qhasm: lou3 = lou3[3]lou3[2]lou3[1]lou3[0] # asm 1: rev >lou3=int32#9,<lou3=int32#9 # asm 2: rev >lou3=r8,<lou3=r8 rev r8,r8 # qhasm: hiu3 = hiu3[3]hiu3[2]hiu3[1]hiu3[0] # asm 1: rev >hiu3=int32#8,<hiu3=int32#8 # asm 2: rev >hiu3=r7,<hiu3=r7 rev.w r7,r7 # qhasm: lod8 = lou0 # asm 1: vmov >lod8=float32#17,<lou0=int32#3 # asm 2: vmov >lod8=s16,<lou0=r2 # copy-collector input: vmov s16,r2 # qhasm: hid8 = hiu0 # asm 1: vmov >hid8=float32#18,<hiu0=int32#2 # asm 2: vmov >hid8=s17,<hiu0=r1 # copy-collector input: vmov s17,r1 # qhasm: lod9 = lou1 # asm 1: vmov >lod9=float32#19,<lou1=int32#5 # asm 2: vmov >lod9=s18,<lou1=r4 # copy-collector input: vmov s18,r4 # qhasm: hid9 = hiu1 # asm 1: vmov >hid9=float32#20,<hiu1=int32#4 # asm 2: vmov >hid9=s19,<hiu1=r3 # copy-collector input: vmov s19,r3 # qhasm: lod10 = lou2 # asm 1: vmov >lod10=float32#21,<lou2=int32#7 # asm 2: vmov >lod10=s20,<lou2=r6 # copy-collector input: vmov s20,r6 # qhasm: hid10 = hiu2 # asm 1: vmov >hid10=float32#22,<hiu2=int32#6 # asm 2: vmov >hid10=s21,<hiu2=r5 # copy-collector input: vmov s21,r5 # qhasm: lod11 = lou3 # asm 1: vmov >lod11=float32#23,<lou3=int32#9 # asm 2: vmov >lod11=s22,<lou3=r8 # copy-collector input: vmov s22,r8 # qhasm: hid11 = hiu3 # asm 1: vmov >hid11=float32#24,<hiu3=int32#8 # asm 2: vmov >hid11=s23,<hiu3=r7 # copy-collector input: vmov s23,r7 # qhasm: hiu0 = mem32[input_0]; input_0 += 4 # asm 1: ldr >hiu0=int32#2,[<input_0=int32#1],#4 # asm 2: ldr >hiu0=r1,[<input_0=r0],#4 # copy-collector input: ldr r1,[r0],#4 # qhasm: lou0 = mem32[input_0]; input_0 += 4 # asm 1: ldr >lou0=int32#3,[<input_0=int32#1],#4 # asm 2: ldr >lou0=r2,[<input_0=r0],#4 # copy-collector input: ldr r2,[r0],#4 # qhasm: hiu1 = mem32[input_0]; input_0 += 4 # asm 1: ldr >hiu1=int32#4,[<input_0=int32#1],#4 # asm 2: ldr >hiu1=r3,[<input_0=r0],#4 # copy-collector input: ldr r3,[r0],#4 # qhasm: lou1 = mem32[input_0]; input_0 += 4 # asm 1: ldr >lou1=int32#5,[<input_0=int32#1],#4 # asm 2: ldr >lou1=r4,[<input_0=r0],#4 # copy-collector input: ldr r4,[r0],#4 # qhasm: hiu2 = mem32[input_0]; input_0 += 4 # asm 1: ldr >hiu2=int32#6,[<input_0=int32#1],#4 # asm 2: ldr >hiu2=r5,[<input_0=r0],#4 # copy-collector input: ldr r5,[r0],#4 # qhasm: lou2 = mem32[input_0]; input_0 += 4 # asm 1: ldr >lou2=int32#7,[<input_0=int32#1],#4 # asm 2: ldr >lou2=r6,[<input_0=r0],#4 # copy-collector input: ldr r6,[r0],#4 # qhasm: hiu3 = mem32[input_0]; input_0 += 4 # asm 1: ldr >hiu3=int32#8,[<input_0=int32#1],#4 # asm 2: ldr >hiu3=r7,[<input_0=r0],#4 # copy-collector input: ldr r7,[r0],#4 # qhasm: lou3 = mem32[input_0]; input_0 += 4 # asm 1: ldr >lou3=int32#9,[<input_0=int32#1],#4 # asm 2: ldr >lou3=r8,[<input_0=r0],#4 # copy-collector input: ldr r8,[r0],#4 # qhasm: lou0 = lou0[3]lou0[2]lou0[1]lou0[0] # asm 1: rev >lou0=int32#3,<lou0=int32#3 # asm 2: rev >lou0=r2,<lou0=r2 # copy-collector output starts vmov d8,r2,r1 vmov d9,r4,r3 vmov d10,r6,r5 vmov d11,r8,r7 ldr r1,[r0],#4 ldr r2,[r0],#4 ldr r3,[r0],#4 ldr r4,[r0],#4 ldr r5,[r0],#4 ldr r6,[r0],#4 ldr r7,[r0],#4 ldr r8,[r0],#4 # copy-collector output ends rev r2,r2 # qhasm: hiu0 = hiu0[3]hiu0[2]hiu0[1]hiu0[0] # asm 1: rev >hiu0=int32#2,<hiu0=int32#2 # asm 2: rev >hiu0=r1,<hiu0=r1 rev r1,r1 # qhasm: lou1 = lou1[3]lou1[2]lou1[1]lou1[0] # asm 1: rev >lou1=int32#5,<lou1=int32#5 # asm 2: rev >lou1=r4,<lou1=r4 rev r4,r4 # qhasm: hiu1 = hiu1[3]hiu1[2]hiu1[1]hiu1[0] # asm 1: rev >hiu1=int32#4,<hiu1=int32#4 # asm 2: rev >hiu1=r3,<hiu1=r3 rev r3,r3 # qhasm: lou2 = lou2[3]lou2[2]lou2[1]lou2[0] # asm 1: rev >lou2=int32#7,<lou2=int32#7 # asm 2: rev >lou2=r6,<lou2=r6 rev r6,r6 # qhasm: hiu2 = hiu2[3]hiu2[2]hiu2[1]hiu2[0] # asm 1: rev >hiu2=int32#6,<hiu2=int32#6 # asm 2: rev >hiu2=r5,<hiu2=r5 rev r5,r5 # qhasm: lou3 = lou3[3]lou3[2]lou3[1]lou3[0] # asm 1: rev >lou3=int32#9,<lou3=int32#9 # asm 2: rev >lou3=r8,<lou3=r8 rev r8,r8 # qhasm: hiu3 = hiu3[3]hiu3[2]hiu3[1]hiu3[0] # asm 1: rev >hiu3=int32#8,<hiu3=int32#8 # asm 2: rev >hiu3=r7,<hiu3=r7 rev.w r7,r7 # qhasm: lod12 = lou0 # asm 1: vmov >lod12=float32#25,<lou0=int32#3 # asm 2: vmov >lod12=s24,<lou0=r2 # copy-collector input: vmov s24,r2 # qhasm: hid12 = hiu0 # asm 1: vmov >hid12=float32#26,<hiu0=int32#2 # asm 2: vmov >hid12=s25,<hiu0=r1 # copy-collector input: vmov s25,r1 # qhasm: lod13 = lou1 # asm 1: vmov >lod13=float32#27,<lou1=int32#5 # asm 2: vmov >lod13=s26,<lou1=r4 # copy-collector input: vmov s26,r4 # qhasm: hid13 = hiu1 # asm 1: vmov >hid13=float32#28,<hiu1=int32#4 # asm 2: vmov >hid13=s27,<hiu1=r3 # copy-collector input: vmov s27,r3 # qhasm: lod14 = lou2 # asm 1: vmov >lod14=float32#29,<lou2=int32#7 # asm 2: vmov >lod14=s28,<lou2=r6 # copy-collector input: vmov s28,r6 # qhasm: hid14 = hiu2 # asm 1: vmov >hid14=float32#30,<hiu2=int32#6 # asm 2: vmov >hid14=s29,<hiu2=r5 # copy-collector input: vmov s29,r5 # qhasm: lod15 = lou3 # asm 1: vmov >lod15=float32#31,<lou3=int32#9 # asm 2: vmov >lod15=s30,<lou3=r8 # copy-collector input: vmov s30,r8 # qhasm: hid15 = hiu3 # asm 1: vmov >hid15=float32#32,<hiu3=int32#8 # asm 2: vmov >hid15=s31,<hiu3=r7 # copy-collector input: vmov s31,r7 # qhasm: hiu0 = mem32[input_0]; input_0 += 4 # asm 1: ldr >hiu0=int32#2,[<input_0=int32#1],#4 # asm 2: ldr >hiu0=r1,[<input_0=r0],#4 # copy-collector input: ldr r1,[r0],#4 # qhasm: lou0 = mem32[input_0]; input_0 += 4 # asm 1: ldr >lou0=int32#3,[<input_0=int32#1],#4 # asm 2: ldr >lou0=r2,[<input_0=r0],#4 # copy-collector input: ldr r2,[r0],#4 # qhasm: hiu1 = mem32[input_0]; input_0 += 4 # asm 1: ldr >hiu1=int32#4,[<input_0=int32#1],#4 # asm 2: ldr >hiu1=r3,[<input_0=r0],#4 # copy-collector input: ldr r3,[r0],#4 # qhasm: lou1 = mem32[input_0]; input_0 += 4 # asm 1: ldr >lou1=int32#5,[<input_0=int32#1],#4 # asm 2: ldr >lou1=r4,[<input_0=r0],#4 # copy-collector input: ldr r4,[r0],#4 # qhasm: hiu2 = mem32[input_0]; input_0 += 4 # asm 1: ldr >hiu2=int32#6,[<input_0=int32#1],#4 # asm 2: ldr >hiu2=r5,[<input_0=r0],#4 # copy-collector input: ldr r5,[r0],#4 # qhasm: lou2 = mem32[input_0]; input_0 += 4 # asm 1: ldr >lou2=int32#7,[<input_0=int32#1],#4 # asm 2: ldr >lou2=r6,[<input_0=r0],#4 # copy-collector input: ldr r6,[r0],#4 # qhasm: hiu3 = mem32[input_0]; input_0 += 4 # asm 1: ldr >hiu3=int32#8,[<input_0=int32#1],#4 # asm 2: ldr >hiu3=r7,[<input_0=r0],#4 # copy-collector input: ldr r7,[r0],#4 # qhasm: lou3 = mem32[input_0]; input_0 += 4 # asm 1: ldr >lou3=int32#9,[<input_0=int32#1],#4 # asm 2: ldr >lou3=r8,[<input_0=r0],#4 # copy-collector input: ldr r8,[r0],#4 # qhasm: lou0 = lou0[3]lou0[2]lou0[1]lou0[0] # asm 1: rev >lou0=int32#3,<lou0=int32#3 # asm 2: rev >lou0=r2,<lou0=r2 # copy-collector output starts vmov d12,r2,r1 vmov d13,r4,r3 vmov d14,r6,r5 vmov d15,r8,r7 ldr r1,[r0],#4 ldr r2,[r0],#4 ldr r3,[r0],#4 ldr r4,[r0],#4 ldr r5,[r0],#4 ldr r6,[r0],#4 ldr r7,[r0],#4 ldr r8,[r0],#4 # copy-collector output ends rev r2,r2 # qhasm: hiu0 = hiu0[3]hiu0[2]hiu0[1]hiu0[0] # asm 1: rev >hiu0=int32#2,<hiu0=int32#2 # asm 2: rev >hiu0=r1,<hiu0=r1 rev r1,r1 # qhasm: lou1 = lou1[3]lou1[2]lou1[1]lou1[0] # asm 1: rev >lou1=int32#5,<lou1=int32#5 # asm 2: rev >lou1=r4,<lou1=r4 rev r4,r4 # qhasm: hiu1 = hiu1[3]hiu1[2]hiu1[1]hiu1[0] # asm 1: rev >hiu1=int32#4,<hiu1=int32#4 # asm 2: rev >hiu1=r3,<hiu1=r3 rev r3,r3 # qhasm: lou2 = lou2[3]lou2[2]lou2[1]lou2[0] # asm 1: rev >lou2=int32#7,<lou2=int32#7 # asm 2: rev >lou2=r6,<lou2=r6 rev r6,r6 # qhasm: hiu2 = hiu2[3]hiu2[2]hiu2[1]hiu2[0] # asm 1: rev >hiu2=int32#6,<hiu2=int32#6 # asm 2: rev >hiu2=r5,<hiu2=r5 rev r5,r5 # qhasm: lou3 = lou3[3]lou3[2]lou3[1]lou3[0] # asm 1: rev >lou3=int32#9,<lou3=int32#9 # asm 2: rev >lou3=r8,<lou3=r8 rev r8,r8 # qhasm: hiu3 = hiu3[3]hiu3[2]hiu3[1]hiu3[0] # asm 1: rev >hiu3=int32#8,<hiu3=int32#8 # asm 2: rev >hiu3=r7,<hiu3=r7 rev.w r7,r7 # qhasm: lom8 = lou0 # asm 1: str <lou0=int32#3,>lom8=stack32#21 # asm 2: str <lou0=r2,>lom8=[sp,#80] # copy-collector input: str r2,[sp,#80] # qhasm: him8 = hiu0 # asm 1: str <hiu0=int32#2,>him8=stack32#22 # asm 2: str <hiu0=r1,>him8=[sp,#84] # copy-collector input: str r1,[sp,#84] # qhasm: lom9 = lou1 # asm 1: str <lou1=int32#5,>lom9=stack32#23 # asm 2: str <lou1=r4,>lom9=[sp,#88] # copy-collector input: str r4,[sp,#88] # qhasm: him9 = hiu1 # asm 1: str <hiu1=int32#4,>him9=stack32#24 # asm 2: str <hiu1=r3,>him9=[sp,#92] # copy-collector input: str r3,[sp,#92] # qhasm: lom10 = lou2 # asm 1: str <lou2=int32#7,>lom10=stack32#25 # asm 2: str <lou2=r6,>lom10=[sp,#96] # copy-collector input: str r6,[sp,#96] # qhasm: him10 = hiu2 # asm 1: str <hiu2=int32#6,>him10=stack32#26 # asm 2: str <hiu2=r5,>him10=[sp,#100] # copy-collector input: str r5,[sp,#100] # qhasm: lom11 = lou3 # asm 1: str <lou3=int32#9,>lom11=stack32#27 # asm 2: str <lou3=r8,>lom11=[sp,#104] # copy-collector input: str r8,[sp,#104] # qhasm: him11 = hiu3 # asm 1: str <hiu3=int32#8,>him11=stack32#28 # asm 2: str <hiu3=r7,>him11=[sp,#108] # copy-collector input: str r7,[sp,#108] # qhasm: hiu0 = mem32[input_0]; input_0 += 4 # asm 1: ldr >hiu0=int32#2,[<input_0=int32#1],#4 # asm 2: ldr >hiu0=r1,[<input_0=r0],#4 # copy-collector input: ldr r1,[r0],#4 # qhasm: lou0 = mem32[input_0]; input_0 += 4 # asm 1: ldr >lou0=int32#3,[<input_0=int32#1],#4 # asm 2: ldr >lou0=r2,[<input_0=r0],#4 # copy-collector input: ldr r2,[r0],#4 # qhasm: hiu1 = mem32[input_0]; input_0 += 4 # asm 1: ldr >hiu1=int32#4,[<input_0=int32#1],#4 # asm 2: ldr >hiu1=r3,[<input_0=r0],#4 # copy-collector input: ldr r3,[r0],#4 # qhasm: lou1 = mem32[input_0]; input_0 += 4 # asm 1: ldr >lou1=int32#5,[<input_0=int32#1],#4 # asm 2: ldr >lou1=r4,[<input_0=r0],#4 # copy-collector input: ldr r4,[r0],#4 # qhasm: hiu2 = mem32[input_0]; input_0 += 4 # asm 1: ldr >hiu2=int32#6,[<input_0=int32#1],#4 # asm 2: ldr >hiu2=r5,[<input_0=r0],#4 # copy-collector input: ldr r5,[r0],#4 # qhasm: lou2 = mem32[input_0]; input_0 += 4 # asm 1: ldr >lou2=int32#7,[<input_0=int32#1],#4 # asm 2: ldr >lou2=r6,[<input_0=r0],#4 # copy-collector input: ldr r6,[r0],#4 # qhasm: hiu3 = mem32[input_0]; input_0 += 4 # asm 1: ldr >hiu3=int32#8,[<input_0=int32#1],#4 # asm 2: ldr >hiu3=r7,[<input_0=r0],#4 # copy-collector input: ldr r7,[r0],#4 # qhasm: lou3 = mem32[input_0]; input_0 += 4 # asm 1: ldr >lou3=int32#9,[<input_0=int32#1],#4 # asm 2: ldr >lou3=r8,[<input_0=r0],#4 # copy-collector input: ldr r8,[r0],#4 # qhasm: lou0 = lou0[3]lou0[2]lou0[1]lou0[0] # asm 1: rev >lou0=int32#3,<lou0=int32#3 # asm 2: rev >lou0=r2,<lou0=r2 # copy-collector output starts strd r2,r1,[sp,#80] strd r4,r3,[sp,#88] strd r6,r5,[sp,#96] strd r8,r7,[sp,#104] ldr r1,[r0],#4 ldr r2,[r0],#4 ldr r3,[r0],#4 ldr r4,[r0],#4 ldr r5,[r0],#4 ldr r6,[r0],#4 ldr r7,[r0],#4 ldr r8,[r0],#4 # copy-collector output ends rev r2,r2 # qhasm: hiu0 = hiu0[3]hiu0[2]hiu0[1]hiu0[0] # asm 1: rev >hiu0=int32#2,<hiu0=int32#2 # asm 2: rev >hiu0=r1,<hiu0=r1 rev r1,r1 # qhasm: lou1 = lou1[3]lou1[2]lou1[1]lou1[0] # asm 1: rev >lou1=int32#5,<lou1=int32#5 # asm 2: rev >lou1=r4,<lou1=r4 rev r4,r4 # qhasm: hiu1 = hiu1[3]hiu1[2]hiu1[1]hiu1[0] # asm 1: rev >hiu1=int32#4,<hiu1=int32#4 # asm 2: rev >hiu1=r3,<hiu1=r3 rev r3,r3 # qhasm: lou2 = lou2[3]lou2[2]lou2[1]lou2[0] # asm 1: rev >lou2=int32#7,<lou2=int32#7 # asm 2: rev >lou2=r6,<lou2=r6 rev r6,r6 # qhasm: hiu2 = hiu2[3]hiu2[2]hiu2[1]hiu2[0] # asm 1: rev >hiu2=int32#6,<hiu2=int32#6 # asm 2: rev >hiu2=r5,<hiu2=r5 rev r5,r5 # qhasm: lou3 = lou3[3]lou3[2]lou3[1]lou3[0] # asm 1: rev >lou3=int32#9,<lou3=int32#9 # asm 2: rev >lou3=r8,<lou3=r8 rev r8,r8 # qhasm: hiu3 = hiu3[3]hiu3[2]hiu3[1]hiu3[0] # asm 1: rev >hiu3=int32#8,<hiu3=int32#8 # asm 2: rev >hiu3=r7,<hiu3=r7 rev.w r7,r7 # qhasm: lom12 = lou0 # asm 1: str <lou0=int32#3,>lom12=stack32#29 # asm 2: str <lou0=r2,>lom12=[sp,#112] # copy-collector input: str r2,[sp,#112] # qhasm: him12 = hiu0 # asm 1: str <hiu0=int32#2,>him12=stack32#30 # asm 2: str <hiu0=r1,>him12=[sp,#116] # copy-collector input: str r1,[sp,#116] # qhasm: lom13 = lou1 # asm 1: str <lou1=int32#5,>lom13=stack32#31 # asm 2: str <lou1=r4,>lom13=[sp,#120] # copy-collector input: str r4,[sp,#120] # qhasm: him13 = hiu1 # asm 1: str <hiu1=int32#4,>him13=stack32#32 # asm 2: str <hiu1=r3,>him13=[sp,#124] # copy-collector input: str r3,[sp,#124] # qhasm: lom14 = lou2 # asm 1: str <lou2=int32#7,>lom14=stack32#33 # asm 2: str <lou2=r6,>lom14=[sp,#128] # copy-collector input: str r6,[sp,#128] # qhasm: him14 = hiu2 # asm 1: str <hiu2=int32#6,>him14=stack32#34 # asm 2: str <hiu2=r5,>him14=[sp,#132] # copy-collector input: str r5,[sp,#132] # qhasm: lom15 = lou3 # asm 1: str <lou3=int32#9,>lom15=stack32#35 # asm 2: str <lou3=r8,>lom15=[sp,#136] # copy-collector input: str r8,[sp,#136] # qhasm: him15 = hiu3 # asm 1: str <hiu3=int32#8,>him15=stack32#36 # asm 2: str <hiu3=r7,>him15=[sp,#140] # copy-collector input: str r7,[sp,#140] # qhasm: o1 = input_0 # asm 1: str <input_0=int32#1,>o1=stack32#2 # asm 2: str <input_0=r0,>o1=[sp,#4] # copy-collector input: str r0,[sp,#4] # qhasm: input_0 = 80 simple # asm 1: mov >input_0=int32#1,80 # asm 2: mov >input_0=r0,80 # copy-collector output starts strd r2,r1,[sp,#112] strd r4,r3,[sp,#120] strd r6,r5,[sp,#128] strd r8,r7,[sp,#136] str r0,[sp,#4] # copy-collector output ends mov r0,80 # qhasm: o4 = input_0 # asm 1: str <input_0=int32#1,>o4=stack32#37 # asm 2: str <input_0=r0,>o4=[sp,#144] # copy-collector input: str r0,[sp,#144] # qhasm: innerloop: # copy-collector output starts str r0,[sp,#144] # copy-collector output ends ._innerloop: # qhasm: assign 0 to lod0 # qhasm: assign 1 to hid0 # qhasm: assign 2 to lod1 # qhasm: assign 3 to hid1 # qhasm: assign 4 to lod2 # qhasm: assign 5 to hid2 # qhasm: assign 6 to lod3 # qhasm: assign 7 to hid3 # qhasm: assign 8 to lod4 # qhasm: assign 9 to hid4 # qhasm: assign 10 to lod5 # qhasm: assign 11 to hid5 # qhasm: assign 12 to lod6 # qhasm: assign 13 to hid6 # qhasm: assign 14 to lod7 # qhasm: assign 15 to hid7 # qhasm: input_0 = o3 # asm 1: ldr >input_0=int32#1,<o3=stack32#4 # asm 2: ldr >input_0=r0,<o3=[sp,#12] # copy-collector input: ldr r0,[sp,#12] # qhasm: lou0 = lod3 # asm 1: vmov >lou0=int32#2,<lod3=float32#7 # asm 2: vmov >lou0=r1,<lod3=s6 # copy-collector input: vmov r1,s6 # qhasm: hiu0 = hid3 # asm 1: vmov >hiu0=int32#3,<hid3=float32#8 # asm 2: vmov >hiu0=r2,<hid3=s7 # copy-collector input: vmov r2,s7 # qhasm: lou1 = lod4 # asm 1: vmov >lou1=int32#4,<lod4=float32#9 # asm 2: vmov >lou1=r3,<lod4=s8 # copy-collector input: vmov r3,s8 # qhasm: hiu1 = hid4 # asm 1: vmov >hiu1=int32#5,<hid4=float32#10 # asm 2: vmov >hiu1=r4,<hid4=s9 # copy-collector input: vmov r4,s9 # qhasm: lou2 = lod5 # asm 1: vmov >lou2=int32#6,<lod5=float32#11 # asm 2: vmov >lou2=r5,<lod5=s10 # copy-collector input: vmov r5,s10 # qhasm: hiu2 = hid5 # asm 1: vmov >hiu2=int32#7,<hid5=float32#12 # asm 2: vmov >hiu2=r6,<hid5=s11 # copy-collector input: vmov r6,s11 # qhasm: lou3 = lod6 # asm 1: vmov >lou3=int32#8,<lod6=float32#13 # asm 2: vmov >lou3=r7,<lod6=s12 # copy-collector input: vmov r7,s12 # qhasm: hiu3 = hid6 # asm 1: vmov >hiu3=int32#9,<hid6=float32#14 # asm 2: vmov >hiu3=r8,<hid6=s13 # copy-collector input: vmov r8,s13 # qhasm: lou4 = lod7 # asm 1: vmov >lou4=int32#10,<lod7=float32#15 # asm 2: vmov >lou4=r9,<lod7=s14 # copy-collector input: vmov r9,s14 # qhasm: hiu4 = hid7 # asm 1: vmov >hiu4=int32#11,<hid7=float32#16 # asm 2: vmov >hiu4=r10,<hid7=s15 # copy-collector input: vmov r10,s15 # qhasm: lou5 = lod8 # asm 1: vmov >lou5=int32#12,<lod8=float32#17 # asm 2: vmov >lou5=r11,<lod8=s16 # copy-collector input: vmov r11,s16 # qhasm: hiu5 = hid8 # asm 1: vmov >hiu5=int32#13,<hid8=float32#18 # asm 2: vmov >hiu5=r12,<hid8=s17 # copy-collector input: vmov r12,s17 # qhasm: two23 = 0x800000 simple # asm 1: mov >two23=int32#14,0x800000 # asm 2: mov >two23=r14,0x800000 # copy-collector output starts ldr.w r0,[sp,#12] vmov r1,r2,d3 vmov r3,r4,d4 vmov r5,r6,d5 vmov r7,r8,d6 vmov r9,r10,d7 vmov r11,r12,d8 # copy-collector output ends mov r14,0x800000 # qhasm: carry? lou4 += lou5 # asm 1: adds >lou4=int32#10,<lou4=int32#10,<lou5=int32#12 # asm 2: adds >lou4=r9,<lou4=r9,<lou5=r11 adds r9,r9,r11 # qhasm: hiu4 += hiu5 + carry # asm 1: adc >hiu4=int32#11,<hiu4=int32#11,<hiu5=int32#13 # asm 2: adc >hiu4=r10,<hiu4=r10,<hiu5=r12 adc r10,r10,r12 # qhasm: lotmp = mem32[input_0]; input_0 += 4 # asm 1: ldr >lotmp=int32#12,[<input_0=int32#1],#4 # asm 2: ldr >lotmp=r11,[<input_0=r0],#4 # copy-collector input: ldr r11,[r0],#4 # qhasm: hitmp = mem32[input_0]; input_0 += 4 # asm 1: ldr >hitmp=int32#13,[<input_0=int32#1],#4 # asm 2: ldr >hitmp=r12,[<input_0=r0],#4 # copy-collector input: ldr r12,[r0],#4 # qhasm: carry? lou4 += lotmp # asm 1: adds >lou4=int32#10,<lou4=int32#10,<lotmp=int32#12 # asm 2: adds >lou4=r9,<lou4=r9,<lotmp=r11 # copy-collector output starts ldr r11,[r0],#4 ldr r12,[r0],#4 # copy-collector output ends adds r9,r9,r11 # qhasm: hiu4 += hitmp + carry # asm 1: adc >hiu4=int32#11,<hiu4=int32#11,<hitmp=int32#13 # asm 2: adc >hiu4=r10,<hiu4=r10,<hitmp=r12 adc r10,r10,r12 # qhasm: hitmp lotmp = lou1 * two23 # asm 1: umull >lotmp=int32#13,>hitmp=int32#12,<lou1=int32#4,<two23=int32#14 # asm 2: umull >lotmp=r12,>hitmp=r11,<lou1=r3,<two23=r14 umull r12,r11,r3,r14 # qhasm: lotmp hitmp += hiu1 * two23 # asm 1: umlal <hitmp=int32#12,<lotmp=int32#13,<hiu1=int32#5,<two23=int32#14 # asm 2: umlal <hitmp=r11,<lotmp=r12,<hiu1=r4,<two23=r14 umlal r11,r12,r4,r14 # qhasm: lotmp ^= (lou1 unsigned>> 18) # asm 1: eor >lotmp=int32#13,<lotmp=int32#13,<lou1=int32#4,LSR #18 # asm 2: eor >lotmp=r12,<lotmp=r12,<lou1=r3,LSR #18 eor r12,r12,r3,LSR #18 # qhasm: lotmp ^= (hiu1 << 14) # asm 1: eor >lotmp=int32#13,<lotmp=int32#13,<hiu1=int32#5,LSL #14 # asm 2: eor >lotmp=r12,<lotmp=r12,<hiu1=r4,LSL #14 eor r12,r12,r4,LSL #14 # qhasm: lotmp ^= (lou1 unsigned>> 14) # asm 1: eor >lotmp=int32#13,<lotmp=int32#13,<lou1=int32#4,LSR #14 # asm 2: eor >lotmp=r12,<lotmp=r12,<lou1=r3,LSR #14 eor r12,r12,r3,LSR #14 # qhasm: lotmp ^= (hiu1 << 18) # asm 1: eor >lotmp=int32#13,<lotmp=int32#13,<hiu1=int32#5,LSL #18 # asm 2: eor >lotmp=r12,<lotmp=r12,<hiu1=r4,LSL #18 eor r12,r12,r4,LSL #18 # qhasm: hitmp ^= (hiu1 unsigned>> 18) # asm 1: eor >hitmp=int32#12,<hitmp=int32#12,<hiu1=int32#5,LSR #18 # asm 2: eor >hitmp=r11,<hitmp=r11,<hiu1=r4,LSR #18 eor r11,r11,r4,LSR #18 # qhasm: hitmp ^= (lou1 << 14) # asm 1: eor >hitmp=int32#12,<hitmp=int32#12,<lou1=int32#4,LSL #14 # asm 2: eor >hitmp=r11,<hitmp=r11,<lou1=r3,LSL #14 eor r11,r11,r3,LSL #14 # qhasm: hitmp ^= (hiu1 unsigned>> 14) # asm 1: eor >hitmp=int32#12,<hitmp=int32#12,<hiu1=int32#5,LSR #14 # asm 2: eor >hitmp=r11,<hitmp=r11,<hiu1=r4,LSR #14 eor r11,r11,r4,LSR #14 # qhasm: hitmp ^= (lou1 << 18) # asm 1: eor >hitmp=int32#12,<hitmp=int32#12,<lou1=int32#4,LSL #18 # asm 2: eor >hitmp=r11,<hitmp=r11,<lou1=r3,LSL #18 eor r11,r11,r3,LSL #18 # qhasm: carry? lou4 += lotmp # asm 1: adds >lou4=int32#10,<lou4=int32#10,<lotmp=int32#13 # asm 2: adds >lou4=r9,<lou4=r9,<lotmp=r12 adds r9,r9,r12 # qhasm: hiu4 += hitmp + carry # asm 1: adc >hiu4=int32#11,<hiu4=int32#11,<hitmp=int32#12 # asm 2: adc >hiu4=r10,<hiu4=r10,<hitmp=r11 adc r10,r10,r11 # qhasm: lotmp = lou1 & lou2 # asm 1: and >lotmp=int32#6,<lou1=int32#4,<lou2=int32#6 # asm 2: and >lotmp=r5,<lou1=r3,<lou2=r5 and r5,r3,r5 # qhasm: lotmp2 = lou3 & ~lou1 # asm 1: bic >lotmp2=int32#4,<lou3=int32#8,<lou1=int32#4 # asm 2: bic >lotmp2=r3,<lou3=r7,<lou1=r3 bic r3,r7,r3 # qhasm: lotmp ^= lotmp2 # asm 1: eor >lotmp=int32#4,<lotmp=int32#6,<lotmp2=int32#4 # asm 2: eor >lotmp=r3,<lotmp=r5,<lotmp2=r3 eor r3,r5,r3 # qhasm: carry? lou4 += lotmp # asm 1: adds >lou4=int32#4,<lou4=int32#10,<lotmp=int32#4 # asm 2: adds >lou4=r3,<lou4=r9,<lotmp=r3 adds r3,r9,r3 # qhasm: hitmp = hiu1 & hiu2 # asm 1: and >hitmp=int32#6,<hiu1=int32#5,<hiu2=int32#7 # asm 2: and >hitmp=r5,<hiu1=r4,<hiu2=r6 and r5,r4,r6 # qhasm: hitmp2 = hiu3 & ~hiu1 # asm 1: bic >hitmp2=int32#5,<hiu3=int32#9,<hiu1=int32#5 # asm 2: bic >hitmp2=r4,<hiu3=r8,<hiu1=r4 bic r4,r8,r4 # qhasm: hitmp ^= hitmp2 # asm 1: eor >hitmp=int32#5,<hitmp=int32#6,<hitmp2=int32#5 # asm 2: eor >hitmp=r4,<hitmp=r5,<hitmp2=r4 eor r4,r5,r4 # qhasm: hiu4 += hitmp + carry # asm 1: adc >hiu4=int32#5,<hiu4=int32#11,<hitmp=int32#5 # asm 2: adc >hiu4=r4,<hiu4=r10,<hitmp=r4 adc r4,r10,r4 # qhasm: carry? lou0 += lou4 # asm 1: adds >lou0=int32#2,<lou0=int32#2,<lou4=int32#4 # asm 2: adds >lou0=r1,<lou0=r1,<lou4=r3 adds r1,r1,r3 # qhasm: hiu0 += hiu4 + carry # asm 1: adc >hiu0=int32#3,<hiu0=int32#3,<hiu4=int32#5 # asm 2: adc >hiu0=r2,<hiu0=r2,<hiu4=r4 adc r2,r2,r4 # qhasm: lod3 = lou0 # asm 1: vmov >lod3=float32#7,<lou0=int32#2 # asm 2: vmov >lod3=s6,<lou0=r1 # copy-collector input: vmov s6,r1 # qhasm: hid3 = hiu0 # asm 1: vmov >hid3=float32#8,<hiu0=int32#3 # asm 2: vmov >hid3=s7,<hiu0=r2 # copy-collector input: vmov s7,r2 # qhasm: lou1 = lod0 # asm 1: vmov >lou1=int32#6,<lod0=float32#1 # asm 2: vmov >lou1=r5,<lod0=s0 # copy-collector input: vmov r5,s0 # qhasm: hiu1 = hid0 # asm 1: vmov >hiu1=int32#7,<hid0=float32#2 # asm 2: vmov >hiu1=r6,<hid0=s1 # copy-collector input: vmov r6,s1 # qhasm: lou2 = lod1 # asm 1: vmov >lou2=int32#8,<lod1=float32#3 # asm 2: vmov >lou2=r7,<lod1=s2 # copy-collector input: vmov r7,s2 # qhasm: hiu2 = hid1 # asm 1: vmov >hiu2=int32#9,<hid1=float32#4 # asm 2: vmov >hiu2=r8,<hid1=s3 # copy-collector input: vmov r8,s3 # qhasm: lou3 = lod2 # asm 1: vmov >lou3=int32#10,<lod2=float32#5 # asm 2: vmov >lou3=r9,<lod2=s4 # copy-collector input: vmov r9,s4 # qhasm: hiu3 = hid2 # asm 1: vmov >hiu3=int32#11,<hid2=float32#6 # asm 2: vmov >hiu3=r10,<hid2=s5 # copy-collector input: vmov r10,s5 # qhasm: two25 = 0x2000000 simple # asm 1: mov >two25=int32#12,0x2000000 # asm 2: mov >two25=r11,0x2000000 # copy-collector output starts vmov d3,r1,r2 vmov r5,r6,d0 vmov r7,r8,d1 vmov r9,r10,d2 # copy-collector output ends mov r11,0x2000000 # qhasm: hitmp lotmp = lou1 * two25 # asm 1: umull >lotmp=int32#14,>hitmp=int32#13,<lou1=int32#6,<two25=int32#12 # asm 2: umull >lotmp=r14,>hitmp=r12,<lou1=r5,<two25=r11 umull r14,r12,r5,r11 # qhasm: lotmp hitmp += hiu1 * two25 # asm 1: umlal <hitmp=int32#13,<lotmp=int32#14,<hiu1=int32#7,<two25=int32#12 # asm 2: umlal <hitmp=r12,<lotmp=r14,<hiu1=r6,<two25=r11 umlal r12,r14,r6,r11 # qhasm: lotmp ^= (hiu1 unsigned>> 2) # asm 1: eor >lotmp=int32#12,<lotmp=int32#14,<hiu1=int32#7,LSR #2 # asm 2: eor >lotmp=r11,<lotmp=r14,<hiu1=r6,LSR #2 eor r11,r14,r6,LSR #2 # qhasm: lotmp ^= (lou1 << 30) # asm 1: eor >lotmp=int32#12,<lotmp=int32#12,<lou1=int32#6,LSL #30 # asm 2: eor >lotmp=r11,<lotmp=r11,<lou1=r5,LSL #30 eor r11,r11,r5,LSL #30 # qhasm: lotmp ^= (lou1 unsigned>> 28) # asm 1: eor >lotmp=int32#12,<lotmp=int32#12,<lou1=int32#6,LSR #28 # asm 2: eor >lotmp=r11,<lotmp=r11,<lou1=r5,LSR #28 eor r11,r11,r5,LSR #28 # qhasm: lotmp ^= (hiu1 << 4) # asm 1: eor >lotmp=int32#12,<lotmp=int32#12,<hiu1=int32#7,LSL #4 # asm 2: eor >lotmp=r11,<lotmp=r11,<hiu1=r6,LSL #4 eor r11,r11,r6,LSL #4 # qhasm: hitmp ^= (lou1 unsigned>> 2) # asm 1: eor >hitmp=int32#13,<hitmp=int32#13,<lou1=int32#6,LSR #2 # asm 2: eor >hitmp=r12,<hitmp=r12,<lou1=r5,LSR #2 eor r12,r12,r5,LSR #2 # qhasm: hitmp ^= (hiu1 << 30) # asm 1: eor >hitmp=int32#13,<hitmp=int32#13,<hiu1=int32#7,LSL #30 # asm 2: eor >hitmp=r12,<hitmp=r12,<hiu1=r6,LSL #30 eor r12,r12,r6,LSL #30 # qhasm: hitmp ^= (hiu1 unsigned>> 28) # asm 1: eor >hitmp=int32#13,<hitmp=int32#13,<hiu1=int32#7,LSR #28 # asm 2: eor >hitmp=r12,<hitmp=r12,<hiu1=r6,LSR #28 eor r12,r12,r6,LSR #28 # qhasm: hitmp ^= (lou1 << 4) # asm 1: eor >hitmp=int32#13,<hitmp=int32#13,<lou1=int32#6,LSL #4 # asm 2: eor >hitmp=r12,<hitmp=r12,<lou1=r5,LSL #4 eor r12,r12,r5,LSL #4 # qhasm: carry? lou4 += lotmp # asm 1: adds >lou4=int32#4,<lou4=int32#4,<lotmp=int32#12 # asm 2: adds >lou4=r3,<lou4=r3,<lotmp=r11 adds r3,r3,r11 # qhasm: hiu4 += hitmp + carry # asm 1: adc >hiu4=int32#5,<hiu4=int32#5,<hitmp=int32#13 # asm 2: adc >hiu4=r4,<hiu4=r4,<hitmp=r12 adc r4,r4,r12 # qhasm: lotmp = lou2 ^ lou3 # asm 1: eor >lotmp=int32#12,<lou2=int32#8,<lou3=int32#10 # asm 2: eor >lotmp=r11,<lou2=r7,<lou3=r9 eor r11,r7,r9 # qhasm: lotmp &= lou1 # asm 1: and >lotmp=int32#6,<lotmp=int32#12,<lou1=int32#6 # asm 2: and >lotmp=r5,<lotmp=r11,<lou1=r5 and r5,r11,r5 # qhasm: lotmp2 = lou2 & lou3 # asm 1: and >lotmp2=int32#8,<lou2=int32#8,<lou3=int32#10 # asm 2: and >lotmp2=r7,<lou2=r7,<lou3=r9 and r7,r7,r9 # qhasm: lotmp ^= lotmp2 # asm 1: eor >lotmp=int32#6,<lotmp=int32#6,<lotmp2=int32#8 # asm 2: eor >lotmp=r5,<lotmp=r5,<lotmp2=r7 eor r5,r5,r7 # qhasm: carry? lou4 += lotmp # asm 1: adds >lou4=int32#4,<lou4=int32#4,<lotmp=int32#6 # asm 2: adds >lou4=r3,<lou4=r3,<lotmp=r5 adds r3,r3,r5 # qhasm: hitmp = hiu2 ^ hiu3 # asm 1: eor >hitmp=int32#6,<hiu2=int32#9,<hiu3=int32#11 # asm 2: eor >hitmp=r5,<hiu2=r8,<hiu3=r10 eor r5,r8,r10 # qhasm: hitmp &= hiu1 # asm 1: and >hitmp=int32#6,<hitmp=int32#6,<hiu1=int32#7 # asm 2: and >hitmp=r5,<hitmp=r5,<hiu1=r6 and r5,r5,r6 # qhasm: hitmp2 = hiu2 & hiu3 # asm 1: and >hitmp2=int32#7,<hiu2=int32#9,<hiu3=int32#11 # asm 2: and >hitmp2=r6,<hiu2=r8,<hiu3=r10 and r6,r8,r10 # qhasm: hitmp ^= hitmp2 # asm 1: eor >hitmp=int32#6,<hitmp=int32#6,<hitmp2=int32#7 # asm 2: eor >hitmp=r5,<hitmp=r5,<hitmp2=r6 eor r5,r5,r6 # qhasm: hiu4 += hitmp + carry # asm 1: adc >hiu4=int32#5,<hiu4=int32#5,<hitmp=int32#6 # asm 2: adc >hiu4=r4,<hiu4=r4,<hitmp=r5 adc r4,r4,r5 # qhasm: lod7 = lou4 # asm 1: vmov >lod7=float32#15,<lou4=int32#4 # asm 2: vmov >lod7=s14,<lou4=r3 # copy-collector input: vmov s14,r3 # qhasm: hid7 = hiu4 # asm 1: vmov >hid7=float32#16,<hiu4=int32#5 # asm 2: vmov >hid7=s15,<hiu4=r4 # copy-collector input: vmov s15,r4 # qhasm: lou1 = lod4 # asm 1: vmov >lou1=int32#4,<lod4=float32#9 # asm 2: vmov >lou1=r3,<lod4=s8 # copy-collector input: vmov r3,s8 # qhasm: hiu1 = hid4 # asm 1: vmov >hiu1=int32#5,<hid4=float32#10 # asm 2: vmov >hiu1=r4,<hid4=s9 # copy-collector input: vmov r4,s9 # qhasm: lou2 = lod5 # asm 1: vmov >lou2=int32#6,<lod5=float32#11 # asm 2: vmov >lou2=r5,<lod5=s10 # copy-collector input: vmov r5,s10 # qhasm: hiu2 = hid5 # asm 1: vmov >hiu2=int32#7,<hid5=float32#12 # asm 2: vmov >hiu2=r6,<hid5=s11 # copy-collector input: vmov r6,s11 # qhasm: lou4 = lod6 # asm 1: vmov >lou4=int32#8,<lod6=float32#13 # asm 2: vmov >lou4=r7,<lod6=s12 # copy-collector input: vmov r7,s12 # qhasm: hiu4 = hid6 # asm 1: vmov >hiu4=int32#9,<hid6=float32#14 # asm 2: vmov >hiu4=r8,<hid6=s13 # copy-collector input: vmov r8,s13 # qhasm: lou5 = lod9 # asm 1: vmov >lou5=int32#12,<lod9=float32#19 # asm 2: vmov >lou5=r11,<lod9=s18 # copy-collector input: vmov r11,s18 # qhasm: hiu5 = hid9 # asm 1: vmov >hiu5=int32#13,<hid9=float32#20 # asm 2: vmov >hiu5=r12,<hid9=s19 # copy-collector input: vmov r12,s19 # qhasm: two23 = 0x800000 simple # asm 1: mov >two23=int32#14,0x800000 # asm 2: mov >two23=r14,0x800000 # copy-collector output starts vmov d7,r3,r4 vmov r3,r4,d4 vmov r5,r6,d5 vmov r7,r8,d6 vmov r11,r12,d9 # copy-collector output ends mov r14,0x800000 # qhasm: carry? lou4 += lou5 # asm 1: adds >lou4=int32#8,<lou4=int32#8,<lou5=int32#12 # asm 2: adds >lou4=r7,<lou4=r7,<lou5=r11 adds r7,r7,r11 # qhasm: hiu4 += hiu5 + carry # asm 1: adc >hiu4=int32#9,<hiu4=int32#9,<hiu5=int32#13 # asm 2: adc >hiu4=r8,<hiu4=r8,<hiu5=r12 adc r8,r8,r12 # qhasm: lotmp = mem32[input_0]; input_0 += 4 # asm 1: ldr >lotmp=int32#12,[<input_0=int32#1],#4 # asm 2: ldr >lotmp=r11,[<input_0=r0],#4 # copy-collector input: ldr r11,[r0],#4 # qhasm: hitmp = mem32[input_0]; input_0 += 4 # asm 1: ldr >hitmp=int32#13,[<input_0=int32#1],#4 # asm 2: ldr >hitmp=r12,[<input_0=r0],#4 # copy-collector input: ldr r12,[r0],#4 # qhasm: carry? lou4 += lotmp # asm 1: adds >lou4=int32#8,<lou4=int32#8,<lotmp=int32#12 # asm 2: adds >lou4=r7,<lou4=r7,<lotmp=r11 # copy-collector output starts ldr r11,[r0],#4 ldr r12,[r0],#4 # copy-collector output ends adds r7,r7,r11 # qhasm: hiu4 += hitmp + carry # asm 1: adc >hiu4=int32#9,<hiu4=int32#9,<hitmp=int32#13 # asm 2: adc >hiu4=r8,<hiu4=r8,<hitmp=r12 adc r8,r8,r12 # qhasm: hitmp lotmp = lou0 * two23 # asm 1: umull >lotmp=int32#13,>hitmp=int32#12,<lou0=int32#2,<two23=int32#14 # asm 2: umull >lotmp=r12,>hitmp=r11,<lou0=r1,<two23=r14 umull r12,r11,r1,r14 # qhasm: lotmp hitmp += hiu0 * two23 # asm 1: umlal <hitmp=int32#12,<lotmp=int32#13,<hiu0=int32#3,<two23=int32#14 # asm 2: umlal <hitmp=r11,<lotmp=r12,<hiu0=r2,<two23=r14 umlal r11,r12,r2,r14 # qhasm: lotmp ^= (lou0 unsigned>> 18) # asm 1: eor >lotmp=int32#13,<lotmp=int32#13,<lou0=int32#2,LSR #18 # asm 2: eor >lotmp=r12,<lotmp=r12,<lou0=r1,LSR #18 eor r12,r12,r1,LSR #18 # qhasm: lotmp ^= (hiu0 << 14) # asm 1: eor >lotmp=int32#13,<lotmp=int32#13,<hiu0=int32#3,LSL #14 # asm 2: eor >lotmp=r12,<lotmp=r12,<hiu0=r2,LSL #14 eor r12,r12,r2,LSL #14 # qhasm: lotmp ^= (lou0 unsigned>> 14) # asm 1: eor >lotmp=int32#13,<lotmp=int32#13,<lou0=int32#2,LSR #14 # asm 2: eor >lotmp=r12,<lotmp=r12,<lou0=r1,LSR #14 eor r12,r12,r1,LSR #14 # qhasm: lotmp ^= (hiu0 << 18) # asm 1: eor >lotmp=int32#13,<lotmp=int32#13,<hiu0=int32#3,LSL #18 # asm 2: eor >lotmp=r12,<lotmp=r12,<hiu0=r2,LSL #18 eor r12,r12,r2,LSL #18 # qhasm: hitmp ^= (hiu0 unsigned>> 18) # asm 1: eor >hitmp=int32#12,<hitmp=int32#12,<hiu0=int32#3,LSR #18 # asm 2: eor >hitmp=r11,<hitmp=r11,<hiu0=r2,LSR #18 eor r11,r11,r2,LSR #18 # qhasm: hitmp ^= (lou0 << 14) # asm 1: eor >hitmp=int32#12,<hitmp=int32#12,<lou0=int32#2,LSL #14 # asm 2: eor >hitmp=r11,<hitmp=r11,<lou0=r1,LSL #14 eor r11,r11,r1,LSL #14 # qhasm: hitmp ^= (hiu0 unsigned>> 14) # asm 1: eor >hitmp=int32#12,<hitmp=int32#12,<hiu0=int32#3,LSR #14 # asm 2: eor >hitmp=r11,<hitmp=r11,<hiu0=r2,LSR #14 eor r11,r11,r2,LSR #14 # qhasm: hitmp ^= (lou0 << 18) # asm 1: eor >hitmp=int32#12,<hitmp=int32#12,<lou0=int32#2,LSL #18 # asm 2: eor >hitmp=r11,<hitmp=r11,<lou0=r1,LSL #18 eor r11,r11,r1,LSL #18 # qhasm: carry? lou4 += lotmp # asm 1: adds >lou4=int32#8,<lou4=int32#8,<lotmp=int32#13 # asm 2: adds >lou4=r7,<lou4=r7,<lotmp=r12 adds r7,r7,r12 # qhasm: hiu4 += hitmp + carry # asm 1: adc >hiu4=int32#9,<hiu4=int32#9,<hitmp=int32#12 # asm 2: adc >hiu4=r8,<hiu4=r8,<hitmp=r11 adc r8,r8,r11 # qhasm: lotmp = lou0 & lou1 # asm 1: and >lotmp=int32#4,<lou0=int32#2,<lou1=int32#4 # asm 2: and >lotmp=r3,<lou0=r1,<lou1=r3 and r3,r1,r3 # qhasm: lotmp2 = lou2 & ~lou0 # asm 1: bic >lotmp2=int32#2,<lou2=int32#6,<lou0=int32#2 # asm 2: bic >lotmp2=r1,<lou2=r5,<lou0=r1 bic r1,r5,r1 # qhasm: lotmp ^= lotmp2 # asm 1: eor >lotmp=int32#2,<lotmp=int32#4,<lotmp2=int32#2 # asm 2: eor >lotmp=r1,<lotmp=r3,<lotmp2=r1 eor r1,r3,r1 # qhasm: carry? lou4 += lotmp # asm 1: adds >lou4=int32#2,<lou4=int32#8,<lotmp=int32#2 # asm 2: adds >lou4=r1,<lou4=r7,<lotmp=r1 adds r1,r7,r1 # qhasm: hitmp = hiu0 & hiu1 # asm 1: and >hitmp=int32#4,<hiu0=int32#3,<hiu1=int32#5 # asm 2: and >hitmp=r3,<hiu0=r2,<hiu1=r4 and r3,r2,r4 # qhasm: hitmp2 = hiu2 & ~hiu0 # asm 1: bic >hitmp2=int32#3,<hiu2=int32#7,<hiu0=int32#3 # asm 2: bic >hitmp2=r2,<hiu2=r6,<hiu0=r2 bic r2,r6,r2 # qhasm: hitmp ^= hitmp2 # asm 1: eor >hitmp=int32#3,<hitmp=int32#4,<hitmp2=int32#3 # asm 2: eor >hitmp=r2,<hitmp=r3,<hitmp2=r2 eor r2,r3,r2 # qhasm: hiu4 += hitmp + carry # asm 1: adc >hiu4=int32#3,<hiu4=int32#9,<hitmp=int32#3 # asm 2: adc >hiu4=r2,<hiu4=r8,<hitmp=r2 adc r2,r8,r2 # qhasm: carry? lou3 += lou4 # asm 1: adds >lou3=int32#4,<lou3=int32#10,<lou4=int32#2 # asm 2: adds >lou3=r3,<lou3=r9,<lou4=r1 adds r3,r9,r1 # qhasm: hiu3 += hiu4 + carry # asm 1: adc >hiu3=int32#5,<hiu3=int32#11,<hiu4=int32#3 # asm 2: adc >hiu3=r4,<hiu3=r10,<hiu4=r2 adc r4,r10,r2 # qhasm: lod2 = lou3 # asm 1: vmov >lod2=float32#5,<lou3=int32#4 # asm 2: vmov >lod2=s4,<lou3=r3 # copy-collector input: vmov s4,r3 # qhasm: hid2 = hiu3 # asm 1: vmov >hid2=float32#6,<hiu3=int32#5 # asm 2: vmov >hid2=s5,<hiu3=r4 # copy-collector input: vmov s5,r4 # qhasm: lou0 = lod7 # asm 1: vmov >lou0=int32#6,<lod7=float32#15 # asm 2: vmov >lou0=r5,<lod7=s14 # copy-collector input: vmov r5,s14 # qhasm: hiu0 = hid7 # asm 1: vmov >hiu0=int32#7,<hid7=float32#16 # asm 2: vmov >hiu0=r6,<hid7=s15 # copy-collector input: vmov r6,s15 # qhasm: lou1 = lod0 # asm 1: vmov >lou1=int32#8,<lod0=float32#1 # asm 2: vmov >lou1=r7,<lod0=s0 # copy-collector input: vmov r7,s0 # qhasm: hiu1 = hid0 # asm 1: vmov >hiu1=int32#9,<hid0=float32#2 # asm 2: vmov >hiu1=r8,<hid0=s1 # copy-collector input: vmov r8,s1 # qhasm: lou2 = lod1 # asm 1: vmov >lou2=int32#10,<lod1=float32#3 # asm 2: vmov >lou2=r9,<lod1=s2 # copy-collector input: vmov r9,s2 # qhasm: hiu2 = hid1 # asm 1: vmov >hiu2=int32#11,<hid1=float32#4 # asm 2: vmov >hiu2=r10,<hid1=s3 # copy-collector input: vmov r10,s3 # qhasm: two25 = 0x2000000 simple # asm 1: mov >two25=int32#12,0x2000000 # asm 2: mov >two25=r11,0x2000000 # copy-collector output starts vmov d2,r3,r4 vmov r5,r6,d7 vmov r7,r8,d0 vmov r9,r10,d1 # copy-collector output ends mov r11,0x2000000 # qhasm: hitmp lotmp = lou0 * two25 # asm 1: umull >lotmp=int32#14,>hitmp=int32#13,<lou0=int32#6,<two25=int32#12 # asm 2: umull >lotmp=r14,>hitmp=r12,<lou0=r5,<two25=r11 umull r14,r12,r5,r11 # qhasm: lotmp hitmp += hiu0 * two25 # asm 1: umlal <hitmp=int32#13,<lotmp=int32#14,<hiu0=int32#7,<two25=int32#12 # asm 2: umlal <hitmp=r12,<lotmp=r14,<hiu0=r6,<two25=r11 umlal r12,r14,r6,r11 # qhasm: lotmp ^= (hiu0 unsigned>> 2) # asm 1: eor >lotmp=int32#12,<lotmp=int32#14,<hiu0=int32#7,LSR #2 # asm 2: eor >lotmp=r11,<lotmp=r14,<hiu0=r6,LSR #2 eor r11,r14,r6,LSR #2 # qhasm: lotmp ^= (lou0 << 30) # asm 1: eor >lotmp=int32#12,<lotmp=int32#12,<lou0=int32#6,LSL #30 # asm 2: eor >lotmp=r11,<lotmp=r11,<lou0=r5,LSL #30 eor r11,r11,r5,LSL #30 # qhasm: lotmp ^= (lou0 unsigned>> 28) # asm 1: eor >lotmp=int32#12,<lotmp=int32#12,<lou0=int32#6,LSR #28 # asm 2: eor >lotmp=r11,<lotmp=r11,<lou0=r5,LSR #28 eor r11,r11,r5,LSR #28 # qhasm: lotmp ^= (hiu0 << 4) # asm 1: eor >lotmp=int32#12,<lotmp=int32#12,<hiu0=int32#7,LSL #4 # asm 2: eor >lotmp=r11,<lotmp=r11,<hiu0=r6,LSL #4 eor r11,r11,r6,LSL #4 # qhasm: hitmp ^= (lou0 unsigned>> 2) # asm 1: eor >hitmp=int32#13,<hitmp=int32#13,<lou0=int32#6,LSR #2 # asm 2: eor >hitmp=r12,<hitmp=r12,<lou0=r5,LSR #2 eor r12,r12,r5,LSR #2 # qhasm: hitmp ^= (hiu0 << 30) # asm 1: eor >hitmp=int32#13,<hitmp=int32#13,<hiu0=int32#7,LSL #30 # asm 2: eor >hitmp=r12,<hitmp=r12,<hiu0=r6,LSL #30 eor r12,r12,r6,LSL #30 # qhasm: hitmp ^= (hiu0 unsigned>> 28) # asm 1: eor >hitmp=int32#13,<hitmp=int32#13,<hiu0=int32#7,LSR #28 # asm 2: eor >hitmp=r12,<hitmp=r12,<hiu0=r6,LSR #28 eor r12,r12,r6,LSR #28 # qhasm: hitmp ^= (lou0 << 4) # asm 1: eor >hitmp=int32#13,<hitmp=int32#13,<lou0=int32#6,LSL #4 # asm 2: eor >hitmp=r12,<hitmp=r12,<lou0=r5,LSL #4 eor r12,r12,r5,LSL #4 # qhasm: carry? lou4 += lotmp # asm 1: adds >lou4=int32#2,<lou4=int32#2,<lotmp=int32#12 # asm 2: adds >lou4=r1,<lou4=r1,<lotmp=r11 adds r1,r1,r11 # qhasm: hiu4 += hitmp + carry # asm 1: adc >hiu4=int32#3,<hiu4=int32#3,<hitmp=int32#13 # asm 2: adc >hiu4=r2,<hiu4=r2,<hitmp=r12 adc r2,r2,r12 # qhasm: lotmp = lou1 ^ lou2 # asm 1: eor >lotmp=int32#12,<lou1=int32#8,<lou2=int32#10 # asm 2: eor >lotmp=r11,<lou1=r7,<lou2=r9 eor r11,r7,r9 # qhasm: lotmp &= lou0 # asm 1: and >lotmp=int32#6,<lotmp=int32#12,<lou0=int32#6 # asm 2: and >lotmp=r5,<lotmp=r11,<lou0=r5 and r5,r11,r5 # qhasm: lotmp2 = lou1 & lou2 # asm 1: and >lotmp2=int32#8,<lou1=int32#8,<lou2=int32#10 # asm 2: and >lotmp2=r7,<lou1=r7,<lou2=r9 and r7,r7,r9 # qhasm: lotmp ^= lotmp2 # asm 1: eor >lotmp=int32#6,<lotmp=int32#6,<lotmp2=int32#8 # asm 2: eor >lotmp=r5,<lotmp=r5,<lotmp2=r7 eor r5,r5,r7 # qhasm: carry? lou4 += lotmp # asm 1: adds >lou4=int32#2,<lou4=int32#2,<lotmp=int32#6 # asm 2: adds >lou4=r1,<lou4=r1,<lotmp=r5 adds r1,r1,r5 # qhasm: hitmp = hiu1 ^ hiu2 # asm 1: eor >hitmp=int32#6,<hiu1=int32#9,<hiu2=int32#11 # asm 2: eor >hitmp=r5,<hiu1=r8,<hiu2=r10 eor r5,r8,r10 # qhasm: hitmp &= hiu0 # asm 1: and >hitmp=int32#6,<hitmp=int32#6,<hiu0=int32#7 # asm 2: and >hitmp=r5,<hitmp=r5,<hiu0=r6 and r5,r5,r6 # qhasm: hitmp2 = hiu1 & hiu2 # asm 1: and >hitmp2=int32#7,<hiu1=int32#9,<hiu2=int32#11 # asm 2: and >hitmp2=r6,<hiu1=r8,<hiu2=r10 and r6,r8,r10 # qhasm: hitmp ^= hitmp2 # asm 1: eor >hitmp=int32#6,<hitmp=int32#6,<hitmp2=int32#7 # asm 2: eor >hitmp=r5,<hitmp=r5,<hitmp2=r6 eor r5,r5,r6 # qhasm: hiu4 += hitmp + carry # asm 1: adc >hiu4=int32#3,<hiu4=int32#3,<hitmp=int32#6 # asm 2: adc >hiu4=r2,<hiu4=r2,<hitmp=r5 adc r2,r2,r5 # qhasm: lod6 = lou4 # asm 1: vmov >lod6=float32#13,<lou4=int32#2 # asm 2: vmov >lod6=s12,<lou4=r1 # copy-collector input: vmov s12,r1 # qhasm: hid6 = hiu4 # asm 1: vmov >hid6=float32#14,<hiu4=int32#3 # asm 2: vmov >hid6=s13,<hiu4=r2 # copy-collector input: vmov s13,r2 # qhasm: assign 0 to lod0 # qhasm: assign 1 to hid0 # qhasm: assign 2 to lod1 # qhasm: assign 3 to hid1 # qhasm: assign 4 to lod2 # qhasm: assign 5 to hid2 # qhasm: assign 6 to lod3 # qhasm: assign 7 to hid3 # qhasm: assign 8 to lod4 # qhasm: assign 9 to hid4 # qhasm: assign 10 to lod5 # qhasm: assign 11 to hid5 # qhasm: assign 12 to lod6 # qhasm: assign 13 to hid6 # qhasm: assign 14 to lod7 # qhasm: assign 15 to hid7 # qhasm: lou0 = lod3 # asm 1: vmov >lou0=int32#2,<lod3=float32#7 # asm 2: vmov >lou0=r1,<lod3=s6 # copy-collector input: vmov r1,s6 # qhasm: hiu0 = hid3 # asm 1: vmov >hiu0=int32#3,<hid3=float32#8 # asm 2: vmov >hiu0=r2,<hid3=s7 # copy-collector input: vmov r2,s7 # qhasm: lou1 = lod4 # asm 1: vmov >lou1=int32#6,<lod4=float32#9 # asm 2: vmov >lou1=r5,<lod4=s8 # copy-collector input: vmov r5,s8 # qhasm: hiu1 = hid4 # asm 1: vmov >hiu1=int32#7,<hid4=float32#10 # asm 2: vmov >hiu1=r6,<hid4=s9 # copy-collector input: vmov r6,s9 # qhasm: lou4 = lod5 # asm 1: vmov >lou4=int32#8,<lod5=float32#11 # asm 2: vmov >lou4=r7,<lod5=s10 # copy-collector input: vmov r7,s10 # qhasm: hiu4 = hid5 # asm 1: vmov >hiu4=int32#9,<hid5=float32#12 # asm 2: vmov >hiu4=r8,<hid5=s11 # copy-collector input: vmov r8,s11 # qhasm: lou5 = lod10 # asm 1: vmov >lou5=int32#12,<lod10=float32#21 # asm 2: vmov >lou5=r11,<lod10=s20 # copy-collector input: vmov r11,s20 # qhasm: hiu5 = hid10 # asm 1: vmov >hiu5=int32#13,<hid10=float32#22 # asm 2: vmov >hiu5=r12,<hid10=s21 # copy-collector input: vmov r12,s21 # qhasm: two23 = 0x800000 simple # asm 1: mov >two23=int32#14,0x800000 # asm 2: mov >two23=r14,0x800000 # copy-collector output starts vmov d6,r1,r2 vmov r1,r2,d3 vmov r5,r6,d4 vmov r7,r8,d5 vmov r11,r12,d10 # copy-collector output ends mov r14,0x800000 # qhasm: carry? lou4 += lou5 # asm 1: adds >lou4=int32#8,<lou4=int32#8,<lou5=int32#12 # asm 2: adds >lou4=r7,<lou4=r7,<lou5=r11 adds r7,r7,r11 # qhasm: hiu4 += hiu5 + carry # asm 1: adc >hiu4=int32#9,<hiu4=int32#9,<hiu5=int32#13 # asm 2: adc >hiu4=r8,<hiu4=r8,<hiu5=r12 adc r8,r8,r12 # qhasm: lotmp = mem32[input_0]; input_0 += 4 # asm 1: ldr >lotmp=int32#12,[<input_0=int32#1],#4 # asm 2: ldr >lotmp=r11,[<input_0=r0],#4 # copy-collector input: ldr r11,[r0],#4 # qhasm: hitmp = mem32[input_0]; input_0 += 4 # asm 1: ldr >hitmp=int32#13,[<input_0=int32#1],#4 # asm 2: ldr >hitmp=r12,[<input_0=r0],#4 # copy-collector input: ldr r12,[r0],#4 # qhasm: carry? lou4 += lotmp # asm 1: adds >lou4=int32#8,<lou4=int32#8,<lotmp=int32#12 # asm 2: adds >lou4=r7,<lou4=r7,<lotmp=r11 # copy-collector output starts ldr r11,[r0],#4 ldr r12,[r0],#4 # copy-collector output ends adds r7,r7,r11 # qhasm: hiu4 += hitmp + carry # asm 1: adc >hiu4=int32#9,<hiu4=int32#9,<hitmp=int32#13 # asm 2: adc >hiu4=r8,<hiu4=r8,<hitmp=r12 adc r8,r8,r12 # qhasm: hitmp lotmp = lou3 * two23 # asm 1: umull >lotmp=int32#13,>hitmp=int32#12,<lou3=int32#4,<two23=int32#14 # asm 2: umull >lotmp=r12,>hitmp=r11,<lou3=r3,<two23=r14 umull r12,r11,r3,r14 # qhasm: lotmp hitmp += hiu3 * two23 # asm 1: umlal <hitmp=int32#12,<lotmp=int32#13,<hiu3=int32#5,<two23=int32#14 # asm 2: umlal <hitmp=r11,<lotmp=r12,<hiu3=r4,<two23=r14 umlal r11,r12,r4,r14 # qhasm: lotmp ^= (lou3 unsigned>> 18) # asm 1: eor >lotmp=int32#13,<lotmp=int32#13,<lou3=int32#4,LSR #18 # asm 2: eor >lotmp=r12,<lotmp=r12,<lou3=r3,LSR #18 eor r12,r12,r3,LSR #18 # qhasm: lotmp ^= (hiu3 << 14) # asm 1: eor >lotmp=int32#13,<lotmp=int32#13,<hiu3=int32#5,LSL #14 # asm 2: eor >lotmp=r12,<lotmp=r12,<hiu3=r4,LSL #14 eor r12,r12,r4,LSL #14 # qhasm: lotmp ^= (lou3 unsigned>> 14) # asm 1: eor >lotmp=int32#13,<lotmp=int32#13,<lou3=int32#4,LSR #14 # asm 2: eor >lotmp=r12,<lotmp=r12,<lou3=r3,LSR #14 eor r12,r12,r3,LSR #14 # qhasm: lotmp ^= (hiu3 << 18) # asm 1: eor >lotmp=int32#13,<lotmp=int32#13,<hiu3=int32#5,LSL #18 # asm 2: eor >lotmp=r12,<lotmp=r12,<hiu3=r4,LSL #18 eor r12,r12,r4,LSL #18 # qhasm: hitmp ^= (hiu3 unsigned>> 18) # asm 1: eor >hitmp=int32#12,<hitmp=int32#12,<hiu3=int32#5,LSR #18 # asm 2: eor >hitmp=r11,<hitmp=r11,<hiu3=r4,LSR #18 eor r11,r11,r4,LSR #18 # qhasm: hitmp ^= (lou3 << 14) # asm 1: eor >hitmp=int32#12,<hitmp=int32#12,<lou3=int32#4,LSL #14 # asm 2: eor >hitmp=r11,<hitmp=r11,<lou3=r3,LSL #14 eor r11,r11,r3,LSL #14 # qhasm: hitmp ^= (hiu3 unsigned>> 14) # asm 1: eor >hitmp=int32#12,<hitmp=int32#12,<hiu3=int32#5,LSR #14 # asm 2: eor >hitmp=r11,<hitmp=r11,<hiu3=r4,LSR #14 eor r11,r11,r4,LSR #14 # qhasm: hitmp ^= (lou3 << 18) # asm 1: eor >hitmp=int32#12,<hitmp=int32#12,<lou3=int32#4,LSL #18 # asm 2: eor >hitmp=r11,<hitmp=r11,<lou3=r3,LSL #18 eor r11,r11,r3,LSL #18 # qhasm: carry? lou4 += lotmp # asm 1: adds >lou4=int32#8,<lou4=int32#8,<lotmp=int32#13 # asm 2: adds >lou4=r7,<lou4=r7,<lotmp=r12 adds r7,r7,r12 # qhasm: hiu4 += hitmp + carry # asm 1: adc >hiu4=int32#9,<hiu4=int32#9,<hitmp=int32#12 # asm 2: adc >hiu4=r8,<hiu4=r8,<hitmp=r11 adc r8,r8,r11 # qhasm: lotmp = lou3 & lou0 # asm 1: and >lotmp=int32#2,<lou3=int32#4,<lou0=int32#2 # asm 2: and >lotmp=r1,<lou3=r3,<lou0=r1 and r1,r3,r1 # qhasm: lotmp2 = lou1 & ~lou3 # asm 1: bic >lotmp2=int32#4,<lou1=int32#6,<lou3=int32#4 # asm 2: bic >lotmp2=r3,<lou1=r5,<lou3=r3 bic r3,r5,r3 # qhasm: lotmp ^= lotmp2 # asm 1: eor >lotmp=int32#2,<lotmp=int32#2,<lotmp2=int32#4 # asm 2: eor >lotmp=r1,<lotmp=r1,<lotmp2=r3 eor r1,r1,r3 # qhasm: carry? lou4 += lotmp # asm 1: adds >lou4=int32#2,<lou4=int32#8,<lotmp=int32#2 # asm 2: adds >lou4=r1,<lou4=r7,<lotmp=r1 adds r1,r7,r1 # qhasm: hitmp = hiu3 & hiu0 # asm 1: and >hitmp=int32#3,<hiu3=int32#5,<hiu0=int32#3 # asm 2: and >hitmp=r2,<hiu3=r4,<hiu0=r2 and r2,r4,r2 # qhasm: hitmp2 = hiu1 & ~hiu3 # asm 1: bic >hitmp2=int32#4,<hiu1=int32#7,<hiu3=int32#5 # asm 2: bic >hitmp2=r3,<hiu1=r6,<hiu3=r4 bic r3,r6,r4 # qhasm: hitmp ^= hitmp2 # asm 1: eor >hitmp=int32#3,<hitmp=int32#3,<hitmp2=int32#4 # asm 2: eor >hitmp=r2,<hitmp=r2,<hitmp2=r3 eor r2,r2,r3 # qhasm: hiu4 += hitmp + carry # asm 1: adc >hiu4=int32#3,<hiu4=int32#9,<hitmp=int32#3 # asm 2: adc >hiu4=r2,<hiu4=r8,<hitmp=r2 adc r2,r8,r2 # qhasm: carry? lou2 += lou4 # asm 1: adds >lou2=int32#4,<lou2=int32#10,<lou4=int32#2 # asm 2: adds >lou2=r3,<lou2=r9,<lou4=r1 adds r3,r9,r1 # qhasm: hiu2 += hiu4 + carry # asm 1: adc >hiu2=int32#5,<hiu2=int32#11,<hiu4=int32#3 # asm 2: adc >hiu2=r4,<hiu2=r10,<hiu4=r2 adc r4,r10,r2 # qhasm: lod1 = lou2 # asm 1: vmov >lod1=float32#3,<lou2=int32#4 # asm 2: vmov >lod1=s2,<lou2=r3 # copy-collector input: vmov s2,r3 # qhasm: hid1 = hiu2 # asm 1: vmov >hid1=float32#4,<hiu2=int32#5 # asm 2: vmov >hid1=s3,<hiu2=r4 # copy-collector input: vmov s3,r4 # qhasm: lou0 = lod6 # asm 1: vmov >lou0=int32#6,<lod6=float32#13 # asm 2: vmov >lou0=r5,<lod6=s12 # copy-collector input: vmov r5,s12 # qhasm: hiu0 = hid6 # asm 1: vmov >hiu0=int32#7,<hid6=float32#14 # asm 2: vmov >hiu0=r6,<hid6=s13 # copy-collector input: vmov r6,s13 # qhasm: lou1 = lod7 # asm 1: vmov >lou1=int32#8,<lod7=float32#15 # asm 2: vmov >lou1=r7,<lod7=s14 # copy-collector input: vmov r7,s14 # qhasm: hiu1 = hid7 # asm 1: vmov >hiu1=int32#9,<hid7=float32#16 # asm 2: vmov >hiu1=r8,<hid7=s15 # copy-collector input: vmov r8,s15 # qhasm: lou3 = lod0 # asm 1: vmov >lou3=int32#10,<lod0=float32#1 # asm 2: vmov >lou3=r9,<lod0=s0 # copy-collector input: vmov r9,s0 # qhasm: hiu3 = hid0 # asm 1: vmov >hiu3=int32#11,<hid0=float32#2 # asm 2: vmov >hiu3=r10,<hid0=s1 # copy-collector input: vmov r10,s1 # qhasm: two25 = 0x2000000 simple # asm 1: mov >two25=int32#12,0x2000000 # asm 2: mov >two25=r11,0x2000000 # copy-collector output starts vmov d1,r3,r4 vmov r5,r6,d6 vmov r7,r8,d7 vmov r9,r10,d0 # copy-collector output ends mov r11,0x2000000 # qhasm: hitmp lotmp = lou0 * two25 # asm 1: umull >lotmp=int32#14,>hitmp=int32#13,<lou0=int32#6,<two25=int32#12 # asm 2: umull >lotmp=r14,>hitmp=r12,<lou0=r5,<two25=r11 umull r14,r12,r5,r11 # qhasm: lotmp hitmp += hiu0 * two25 # asm 1: umlal <hitmp=int32#13,<lotmp=int32#14,<hiu0=int32#7,<two25=int32#12 # asm 2: umlal <hitmp=r12,<lotmp=r14,<hiu0=r6,<two25=r11 umlal r12,r14,r6,r11 # qhasm: lotmp ^= (hiu0 unsigned>> 2) # asm 1: eor >lotmp=int32#12,<lotmp=int32#14,<hiu0=int32#7,LSR #2 # asm 2: eor >lotmp=r11,<lotmp=r14,<hiu0=r6,LSR #2 eor r11,r14,r6,LSR #2 # qhasm: lotmp ^= (lou0 << 30) # asm 1: eor >lotmp=int32#12,<lotmp=int32#12,<lou0=int32#6,LSL #30 # asm 2: eor >lotmp=r11,<lotmp=r11,<lou0=r5,LSL #30 eor r11,r11,r5,LSL #30 # qhasm: lotmp ^= (lou0 unsigned>> 28) # asm 1: eor >lotmp=int32#12,<lotmp=int32#12,<lou0=int32#6,LSR #28 # asm 2: eor >lotmp=r11,<lotmp=r11,<lou0=r5,LSR #28 eor r11,r11,r5,LSR #28 # qhasm: lotmp ^= (hiu0 << 4) # asm 1: eor >lotmp=int32#12,<lotmp=int32#12,<hiu0=int32#7,LSL #4 # asm 2: eor >lotmp=r11,<lotmp=r11,<hiu0=r6,LSL #4 eor r11,r11,r6,LSL #4 # qhasm: hitmp ^= (lou0 unsigned>> 2) # asm 1: eor >hitmp=int32#13,<hitmp=int32#13,<lou0=int32#6,LSR #2 # asm 2: eor >hitmp=r12,<hitmp=r12,<lou0=r5,LSR #2 eor r12,r12,r5,LSR #2 # qhasm: hitmp ^= (hiu0 << 30) # asm 1: eor >hitmp=int32#13,<hitmp=int32#13,<hiu0=int32#7,LSL #30 # asm 2: eor >hitmp=r12,<hitmp=r12,<hiu0=r6,LSL #30 eor r12,r12,r6,LSL #30 # qhasm: hitmp ^= (hiu0 unsigned>> 28) # asm 1: eor >hitmp=int32#13,<hitmp=int32#13,<hiu0=int32#7,LSR #28 # asm 2: eor >hitmp=r12,<hitmp=r12,<hiu0=r6,LSR #28 eor r12,r12,r6,LSR #28 # qhasm: hitmp ^= (lou0 << 4) # asm 1: eor >hitmp=int32#13,<hitmp=int32#13,<lou0=int32#6,LSL #4 # asm 2: eor >hitmp=r12,<hitmp=r12,<lou0=r5,LSL #4 eor r12,r12,r5,LSL #4 # qhasm: carry? lou4 += lotmp # asm 1: adds >lou4=int32#2,<lou4=int32#2,<lotmp=int32#12 # asm 2: adds >lou4=r1,<lou4=r1,<lotmp=r11 adds r1,r1,r11 # qhasm: hiu4 += hitmp + carry # asm 1: adc >hiu4=int32#3,<hiu4=int32#3,<hitmp=int32#13 # asm 2: adc >hiu4=r2,<hiu4=r2,<hitmp=r12 adc r2,r2,r12 # qhasm: lotmp = lou1 ^ lou3 # asm 1: eor >lotmp=int32#12,<lou1=int32#8,<lou3=int32#10 # asm 2: eor >lotmp=r11,<lou1=r7,<lou3=r9 eor r11,r7,r9 # qhasm: lotmp &= lou0 # asm 1: and >lotmp=int32#6,<lotmp=int32#12,<lou0=int32#6 # asm 2: and >lotmp=r5,<lotmp=r11,<lou0=r5 and r5,r11,r5 # qhasm: lotmp2 = lou1 & lou3 # asm 1: and >lotmp2=int32#8,<lou1=int32#8,<lou3=int32#10 # asm 2: and >lotmp2=r7,<lou1=r7,<lou3=r9 and r7,r7,r9 # qhasm: lotmp ^= lotmp2 # asm 1: eor >lotmp=int32#6,<lotmp=int32#6,<lotmp2=int32#8 # asm 2: eor >lotmp=r5,<lotmp=r5,<lotmp2=r7 eor r5,r5,r7 # qhasm: carry? lou4 += lotmp # asm 1: adds >lou4=int32#2,<lou4=int32#2,<lotmp=int32#6 # asm 2: adds >lou4=r1,<lou4=r1,<lotmp=r5 adds r1,r1,r5 # qhasm: hitmp = hiu1 ^ hiu3 # asm 1: eor >hitmp=int32#6,<hiu1=int32#9,<hiu3=int32#11 # asm 2: eor >hitmp=r5,<hiu1=r8,<hiu3=r10 eor r5,r8,r10 # qhasm: hitmp &= hiu0 # asm 1: and >hitmp=int32#6,<hitmp=int32#6,<hiu0=int32#7 # asm 2: and >hitmp=r5,<hitmp=r5,<hiu0=r6 and r5,r5,r6 # qhasm: hitmp2 = hiu1 & hiu3 # asm 1: and >hitmp2=int32#7,<hiu1=int32#9,<hiu3=int32#11 # asm 2: and >hitmp2=r6,<hiu1=r8,<hiu3=r10 and r6,r8,r10 # qhasm: hitmp ^= hitmp2 # asm 1: eor >hitmp=int32#6,<hitmp=int32#6,<hitmp2=int32#7 # asm 2: eor >hitmp=r5,<hitmp=r5,<hitmp2=r6 eor r5,r5,r6 # qhasm: hiu4 += hitmp + carry # asm 1: adc >hiu4=int32#3,<hiu4=int32#3,<hitmp=int32#6 # asm 2: adc >hiu4=r2,<hiu4=r2,<hitmp=r5 adc r2,r2,r5 # qhasm: lod5 = lou4 # asm 1: vmov >lod5=float32#11,<lou4=int32#2 # asm 2: vmov >lod5=s10,<lou4=r1 # copy-collector input: vmov s10,r1 # qhasm: hid5 = hiu4 # asm 1: vmov >hid5=float32#12,<hiu4=int32#3 # asm 2: vmov >hid5=s11,<hiu4=r2 # copy-collector input: vmov s11,r2 # qhasm: lou0 = lod2 # asm 1: vmov >lou0=int32#2,<lod2=float32#5 # asm 2: vmov >lou0=r1,<lod2=s4 # copy-collector input: vmov r1,s4 # qhasm: hiu0 = hid2 # asm 1: vmov >hiu0=int32#3,<hid2=float32#6 # asm 2: vmov >hiu0=r2,<hid2=s5 # copy-collector input: vmov r2,s5 # qhasm: lou1 = lod3 # asm 1: vmov >lou1=int32#6,<lod3=float32#7 # asm 2: vmov >lou1=r5,<lod3=s6 # copy-collector input: vmov r5,s6 # qhasm: hiu1 = hid3 # asm 1: vmov >hiu1=int32#7,<hid3=float32#8 # asm 2: vmov >hiu1=r6,<hid3=s7 # copy-collector input: vmov r6,s7 # qhasm: lou4 = lod4 # asm 1: vmov >lou4=int32#8,<lod4=float32#9 # asm 2: vmov >lou4=r7,<lod4=s8 # copy-collector input: vmov r7,s8 # qhasm: hiu4 = hid4 # asm 1: vmov >hiu4=int32#9,<hid4=float32#10 # asm 2: vmov >hiu4=r8,<hid4=s9 # copy-collector input: vmov r8,s9 # qhasm: lou5 = lod11 # asm 1: vmov >lou5=int32#12,<lod11=float32#23 # asm 2: vmov >lou5=r11,<lod11=s22 # copy-collector input: vmov r11,s22 # qhasm: hiu5 = hid11 # asm 1: vmov >hiu5=int32#13,<hid11=float32#24 # asm 2: vmov >hiu5=r12,<hid11=s23 # copy-collector input: vmov r12,s23 # qhasm: two23 = 0x800000 simple # asm 1: mov >two23=int32#14,0x800000 # asm 2: mov >two23=r14,0x800000 # copy-collector output starts vmov d5,r1,r2 vmov r1,r2,d2 vmov r5,r6,d3 vmov r7,r8,d4 vmov r11,r12,d11 # copy-collector output ends mov r14,0x800000 # qhasm: carry? lou4 += lou5 # asm 1: adds >lou4=int32#8,<lou4=int32#8,<lou5=int32#12 # asm 2: adds >lou4=r7,<lou4=r7,<lou5=r11 adds r7,r7,r11 # qhasm: hiu4 += hiu5 + carry # asm 1: adc >hiu4=int32#9,<hiu4=int32#9,<hiu5=int32#13 # asm 2: adc >hiu4=r8,<hiu4=r8,<hiu5=r12 adc r8,r8,r12 # qhasm: lotmp = mem32[input_0]; input_0 += 4 # asm 1: ldr >lotmp=int32#12,[<input_0=int32#1],#4 # asm 2: ldr >lotmp=r11,[<input_0=r0],#4 # copy-collector input: ldr r11,[r0],#4 # qhasm: hitmp = mem32[input_0]; input_0 += 4 # asm 1: ldr >hitmp=int32#13,[<input_0=int32#1],#4 # asm 2: ldr >hitmp=r12,[<input_0=r0],#4 # copy-collector input: ldr r12,[r0],#4 # qhasm: carry? lou4 += lotmp # asm 1: adds >lou4=int32#8,<lou4=int32#8,<lotmp=int32#12 # asm 2: adds >lou4=r7,<lou4=r7,<lotmp=r11 # copy-collector output starts ldr r11,[r0],#4 ldr r12,[r0],#4 # copy-collector output ends adds r7,r7,r11 # qhasm: hiu4 += hitmp + carry # asm 1: adc >hiu4=int32#9,<hiu4=int32#9,<hitmp=int32#13 # asm 2: adc >hiu4=r8,<hiu4=r8,<hitmp=r12 adc r8,r8,r12 # qhasm: hitmp lotmp = lou2 * two23 # asm 1: umull >lotmp=int32#13,>hitmp=int32#12,<lou2=int32#4,<two23=int32#14 # asm 2: umull >lotmp=r12,>hitmp=r11,<lou2=r3,<two23=r14 umull r12,r11,r3,r14 # qhasm: lotmp hitmp += hiu2 * two23 # asm 1: umlal <hitmp=int32#12,<lotmp=int32#13,<hiu2=int32#5,<two23=int32#14 # asm 2: umlal <hitmp=r11,<lotmp=r12,<hiu2=r4,<two23=r14 umlal r11,r12,r4,r14 # qhasm: lotmp ^= (lou2 unsigned>> 18) # asm 1: eor >lotmp=int32#13,<lotmp=int32#13,<lou2=int32#4,LSR #18 # asm 2: eor >lotmp=r12,<lotmp=r12,<lou2=r3,LSR #18 eor r12,r12,r3,LSR #18 # qhasm: lotmp ^= (hiu2 << 14) # asm 1: eor >lotmp=int32#13,<lotmp=int32#13,<hiu2=int32#5,LSL #14 # asm 2: eor >lotmp=r12,<lotmp=r12,<hiu2=r4,LSL #14 eor r12,r12,r4,LSL #14 # qhasm: lotmp ^= (lou2 unsigned>> 14) # asm 1: eor >lotmp=int32#13,<lotmp=int32#13,<lou2=int32#4,LSR #14 # asm 2: eor >lotmp=r12,<lotmp=r12,<lou2=r3,LSR #14 eor r12,r12,r3,LSR #14 # qhasm: lotmp ^= (hiu2 << 18) # asm 1: eor >lotmp=int32#13,<lotmp=int32#13,<hiu2=int32#5,LSL #18 # asm 2: eor >lotmp=r12,<lotmp=r12,<hiu2=r4,LSL #18 eor r12,r12,r4,LSL #18 # qhasm: hitmp ^= (hiu2 unsigned>> 18) # asm 1: eor >hitmp=int32#12,<hitmp=int32#12,<hiu2=int32#5,LSR #18 # asm 2: eor >hitmp=r11,<hitmp=r11,<hiu2=r4,LSR #18 eor r11,r11,r4,LSR #18 # qhasm: hitmp ^= (lou2 << 14) # asm 1: eor >hitmp=int32#12,<hitmp=int32#12,<lou2=int32#4,LSL #14 # asm 2: eor >hitmp=r11,<hitmp=r11,<lou2=r3,LSL #14 eor r11,r11,r3,LSL #14 # qhasm: hitmp ^= (hiu2 unsigned>> 14) # asm 1: eor >hitmp=int32#12,<hitmp=int32#12,<hiu2=int32#5,LSR #14 # asm 2: eor >hitmp=r11,<hitmp=r11,<hiu2=r4,LSR #14 eor r11,r11,r4,LSR #14 # qhasm: hitmp ^= (lou2 << 18) # asm 1: eor >hitmp=int32#12,<hitmp=int32#12,<lou2=int32#4,LSL #18 # asm 2: eor >hitmp=r11,<hitmp=r11,<lou2=r3,LSL #18 eor r11,r11,r3,LSL #18 # qhasm: carry? lou4 += lotmp # asm 1: adds >lou4=int32#8,<lou4=int32#8,<lotmp=int32#13 # asm 2: adds >lou4=r7,<lou4=r7,<lotmp=r12 adds r7,r7,r12 # qhasm: hiu4 += hitmp + carry # asm 1: adc >hiu4=int32#9,<hiu4=int32#9,<hitmp=int32#12 # asm 2: adc >hiu4=r8,<hiu4=r8,<hitmp=r11 adc r8,r8,r11 # qhasm: lotmp = lou2 & lou0 # asm 1: and >lotmp=int32#2,<lou2=int32#4,<lou0=int32#2 # asm 2: and >lotmp=r1,<lou2=r3,<lou0=r1 and r1,r3,r1 # qhasm: lotmp2 = lou1 & ~lou2 # asm 1: bic >lotmp2=int32#4,<lou1=int32#6,<lou2=int32#4 # asm 2: bic >lotmp2=r3,<lou1=r5,<lou2=r3 bic r3,r5,r3 # qhasm: lotmp ^= lotmp2 # asm 1: eor >lotmp=int32#2,<lotmp=int32#2,<lotmp2=int32#4 # asm 2: eor >lotmp=r1,<lotmp=r1,<lotmp2=r3 eor r1,r1,r3 # qhasm: carry? lou4 += lotmp # asm 1: adds >lou4=int32#2,<lou4=int32#8,<lotmp=int32#2 # asm 2: adds >lou4=r1,<lou4=r7,<lotmp=r1 adds r1,r7,r1 # qhasm: hitmp = hiu2 & hiu0 # asm 1: and >hitmp=int32#3,<hiu2=int32#5,<hiu0=int32#3 # asm 2: and >hitmp=r2,<hiu2=r4,<hiu0=r2 and r2,r4,r2 # qhasm: hitmp2 = hiu1 & ~hiu2 # asm 1: bic >hitmp2=int32#4,<hiu1=int32#7,<hiu2=int32#5 # asm 2: bic >hitmp2=r3,<hiu1=r6,<hiu2=r4 bic r3,r6,r4 # qhasm: hitmp ^= hitmp2 # asm 1: eor >hitmp=int32#3,<hitmp=int32#3,<hitmp2=int32#4 # asm 2: eor >hitmp=r2,<hitmp=r2,<hitmp2=r3 eor r2,r2,r3 # qhasm: hiu4 += hitmp + carry # asm 1: adc >hiu4=int32#3,<hiu4=int32#9,<hitmp=int32#3 # asm 2: adc >hiu4=r2,<hiu4=r8,<hitmp=r2 adc r2,r8,r2 # qhasm: carry? lou3 += lou4 # asm 1: adds >lou3=int32#4,<lou3=int32#10,<lou4=int32#2 # asm 2: adds >lou3=r3,<lou3=r9,<lou4=r1 adds r3,r9,r1 # qhasm: hiu3 += hiu4 + carry # asm 1: adc >hiu3=int32#5,<hiu3=int32#11,<hiu4=int32#3 # asm 2: adc >hiu3=r4,<hiu3=r10,<hiu4=r2 adc r4,r10,r2 # qhasm: lod0 = lou3 # asm 1: vmov >lod0=float32#1,<lou3=int32#4 # asm 2: vmov >lod0=s0,<lou3=r3 # copy-collector input: vmov s0,r3 # qhasm: hid0 = hiu3 # asm 1: vmov >hid0=float32#2,<hiu3=int32#5 # asm 2: vmov >hid0=s1,<hiu3=r4 # copy-collector input: vmov s1,r4 # qhasm: lou0 = lod5 # asm 1: vmov >lou0=int32#6,<lod5=float32#11 # asm 2: vmov >lou0=r5,<lod5=s10 # copy-collector input: vmov r5,s10 # qhasm: hiu0 = hid5 # asm 1: vmov >hiu0=int32#7,<hid5=float32#12 # asm 2: vmov >hiu0=r6,<hid5=s11 # copy-collector input: vmov r6,s11 # qhasm: lou1 = lod6 # asm 1: vmov >lou1=int32#8,<lod6=float32#13 # asm 2: vmov >lou1=r7,<lod6=s12 # copy-collector input: vmov r7,s12 # qhasm: hiu1 = hid6 # asm 1: vmov >hiu1=int32#9,<hid6=float32#14 # asm 2: vmov >hiu1=r8,<hid6=s13 # copy-collector input: vmov r8,s13 # qhasm: lou2 = lod7 # asm 1: vmov >lou2=int32#10,<lod7=float32#15 # asm 2: vmov >lou2=r9,<lod7=s14 # copy-collector input: vmov r9,s14 # qhasm: hiu2 = hid7 # asm 1: vmov >hiu2=int32#11,<hid7=float32#16 # asm 2: vmov >hiu2=r10,<hid7=s15 # copy-collector input: vmov r10,s15 # qhasm: two25 = 0x2000000 simple # asm 1: mov >two25=int32#12,0x2000000 # asm 2: mov >two25=r11,0x2000000 # copy-collector output starts vmov d0,r3,r4 vmov r5,r6,d5 vmov r7,r8,d6 vmov r9,r10,d7 # copy-collector output ends mov r11,0x2000000 # qhasm: hitmp lotmp = lou0 * two25 # asm 1: umull >lotmp=int32#14,>hitmp=int32#13,<lou0=int32#6,<two25=int32#12 # asm 2: umull >lotmp=r14,>hitmp=r12,<lou0=r5,<two25=r11 umull r14,r12,r5,r11 # qhasm: lotmp hitmp += hiu0 * two25 # asm 1: umlal <hitmp=int32#13,<lotmp=int32#14,<hiu0=int32#7,<two25=int32#12 # asm 2: umlal <hitmp=r12,<lotmp=r14,<hiu0=r6,<two25=r11 umlal r12,r14,r6,r11 # qhasm: lotmp ^= (hiu0 unsigned>> 2) # asm 1: eor >lotmp=int32#12,<lotmp=int32#14,<hiu0=int32#7,LSR #2 # asm 2: eor >lotmp=r11,<lotmp=r14,<hiu0=r6,LSR #2 eor r11,r14,r6,LSR #2 # qhasm: lotmp ^= (lou0 << 30) # asm 1: eor >lotmp=int32#12,<lotmp=int32#12,<lou0=int32#6,LSL #30 # asm 2: eor >lotmp=r11,<lotmp=r11,<lou0=r5,LSL #30 eor r11,r11,r5,LSL #30 # qhasm: lotmp ^= (lou0 unsigned>> 28) # asm 1: eor >lotmp=int32#12,<lotmp=int32#12,<lou0=int32#6,LSR #28 # asm 2: eor >lotmp=r11,<lotmp=r11,<lou0=r5,LSR #28 eor r11,r11,r5,LSR #28 # qhasm: lotmp ^= (hiu0 << 4) # asm 1: eor >lotmp=int32#12,<lotmp=int32#12,<hiu0=int32#7,LSL #4 # asm 2: eor >lotmp=r11,<lotmp=r11,<hiu0=r6,LSL #4 eor r11,r11,r6,LSL #4 # qhasm: hitmp ^= (lou0 unsigned>> 2) # asm 1: eor >hitmp=int32#13,<hitmp=int32#13,<lou0=int32#6,LSR #2 # asm 2: eor >hitmp=r12,<hitmp=r12,<lou0=r5,LSR #2 eor r12,r12,r5,LSR #2 # qhasm: hitmp ^= (hiu0 << 30) # asm 1: eor >hitmp=int32#13,<hitmp=int32#13,<hiu0=int32#7,LSL #30 # asm 2: eor >hitmp=r12,<hitmp=r12,<hiu0=r6,LSL #30 eor r12,r12,r6,LSL #30 # qhasm: hitmp ^= (hiu0 unsigned>> 28) # asm 1: eor >hitmp=int32#13,<hitmp=int32#13,<hiu0=int32#7,LSR #28 # asm 2: eor >hitmp=r12,<hitmp=r12,<hiu0=r6,LSR #28 eor r12,r12,r6,LSR #28 # qhasm: hitmp ^= (lou0 << 4) # asm 1: eor >hitmp=int32#13,<hitmp=int32#13,<lou0=int32#6,LSL #4 # asm 2: eor >hitmp=r12,<hitmp=r12,<lou0=r5,LSL #4 eor r12,r12,r5,LSL #4 # qhasm: carry? lou4 += lotmp # asm 1: adds >lou4=int32#2,<lou4=int32#2,<lotmp=int32#12 # asm 2: adds >lou4=r1,<lou4=r1,<lotmp=r11 adds r1,r1,r11 # qhasm: hiu4 += hitmp + carry # asm 1: adc >hiu4=int32#3,<hiu4=int32#3,<hitmp=int32#13 # asm 2: adc >hiu4=r2,<hiu4=r2,<hitmp=r12 adc r2,r2,r12 # qhasm: lotmp = lou1 ^ lou2 # asm 1: eor >lotmp=int32#12,<lou1=int32#8,<lou2=int32#10 # asm 2: eor >lotmp=r11,<lou1=r7,<lou2=r9 eor r11,r7,r9 # qhasm: lotmp &= lou0 # asm 1: and >lotmp=int32#6,<lotmp=int32#12,<lou0=int32#6 # asm 2: and >lotmp=r5,<lotmp=r11,<lou0=r5 and r5,r11,r5 # qhasm: lotmp2 = lou1 & lou2 # asm 1: and >lotmp2=int32#8,<lou1=int32#8,<lou2=int32#10 # asm 2: and >lotmp2=r7,<lou1=r7,<lou2=r9 and r7,r7,r9 # qhasm: lotmp ^= lotmp2 # asm 1: eor >lotmp=int32#6,<lotmp=int32#6,<lotmp2=int32#8 # asm 2: eor >lotmp=r5,<lotmp=r5,<lotmp2=r7 eor r5,r5,r7 # qhasm: carry? lou4 += lotmp # asm 1: adds >lou4=int32#2,<lou4=int32#2,<lotmp=int32#6 # asm 2: adds >lou4=r1,<lou4=r1,<lotmp=r5 adds r1,r1,r5 # qhasm: hitmp = hiu1 ^ hiu2 # asm 1: eor >hitmp=int32#6,<hiu1=int32#9,<hiu2=int32#11 # asm 2: eor >hitmp=r5,<hiu1=r8,<hiu2=r10 eor r5,r8,r10 # qhasm: hitmp &= hiu0 # asm 1: and >hitmp=int32#6,<hitmp=int32#6,<hiu0=int32#7 # asm 2: and >hitmp=r5,<hitmp=r5,<hiu0=r6 and r5,r5,r6 # qhasm: hitmp2 = hiu1 & hiu2 # asm 1: and >hitmp2=int32#7,<hiu1=int32#9,<hiu2=int32#11 # asm 2: and >hitmp2=r6,<hiu1=r8,<hiu2=r10 and r6,r8,r10 # qhasm: hitmp ^= hitmp2 # asm 1: eor >hitmp=int32#6,<hitmp=int32#6,<hitmp2=int32#7 # asm 2: eor >hitmp=r5,<hitmp=r5,<hitmp2=r6 eor r5,r5,r6 # qhasm: hiu4 += hitmp + carry # asm 1: adc >hiu4=int32#3,<hiu4=int32#3,<hitmp=int32#6 # asm 2: adc >hiu4=r2,<hiu4=r2,<hitmp=r5 adc r2,r2,r5 # qhasm: lod4 = lou4 # asm 1: vmov >lod4=float32#9,<lou4=int32#2 # asm 2: vmov >lod4=s8,<lou4=r1 # copy-collector input: vmov s8,r1 # qhasm: hid4 = hiu4 # asm 1: vmov >hid4=float32#10,<hiu4=int32#3 # asm 2: vmov >hid4=s9,<hiu4=r2 # copy-collector input: vmov s9,r2 # qhasm: assign 0 to lod0 # qhasm: assign 1 to hid0 # qhasm: assign 2 to lod1 # qhasm: assign 3 to hid1 # qhasm: assign 4 to lod2 # qhasm: assign 5 to hid2 # qhasm: assign 6 to lod3 # qhasm: assign 7 to hid3 # qhasm: assign 8 to lod4 # qhasm: assign 9 to hid4 # qhasm: assign 10 to lod5 # qhasm: assign 11 to hid5 # qhasm: assign 12 to lod6 # qhasm: assign 13 to hid6 # qhasm: assign 14 to lod7 # qhasm: assign 15 to hid7 # qhasm: lou0 = lod1 # asm 1: vmov >lou0=int32#2,<lod1=float32#3 # asm 2: vmov >lou0=r1,<lod1=s2 # copy-collector input: vmov r1,s2 # qhasm: hiu0 = hid1 # asm 1: vmov >hiu0=int32#3,<hid1=float32#4 # asm 2: vmov >hiu0=r2,<hid1=s3 # copy-collector input: vmov r2,s3 # qhasm: lou1 = lod2 # asm 1: vmov >lou1=int32#6,<lod2=float32#5 # asm 2: vmov >lou1=r5,<lod2=s4 # copy-collector input: vmov r5,s4 # qhasm: hiu1 = hid2 # asm 1: vmov >hiu1=int32#7,<hid2=float32#6 # asm 2: vmov >hiu1=r6,<hid2=s5 # copy-collector input: vmov r6,s5 # qhasm: lou4 = lod3 # asm 1: vmov >lou4=int32#8,<lod3=float32#7 # asm 2: vmov >lou4=r7,<lod3=s6 # copy-collector input: vmov r7,s6 # qhasm: hiu4 = hid3 # asm 1: vmov >hiu4=int32#9,<hid3=float32#8 # asm 2: vmov >hiu4=r8,<hid3=s7 # copy-collector input: vmov r8,s7 # qhasm: lou5 = lod12 # asm 1: vmov >lou5=int32#12,<lod12=float32#25 # asm 2: vmov >lou5=r11,<lod12=s24 # copy-collector input: vmov r11,s24 # qhasm: hiu5 = hid12 # asm 1: vmov >hiu5=int32#13,<hid12=float32#26 # asm 2: vmov >hiu5=r12,<hid12=s25 # copy-collector input: vmov r12,s25 # qhasm: two23 = 0x800000 simple # asm 1: mov >two23=int32#14,0x800000 # asm 2: mov >two23=r14,0x800000 # copy-collector output starts vmov d4,r1,r2 vmov r1,r2,d1 vmov r5,r6,d2 vmov r7,r8,d3 vmov r11,r12,d12 # copy-collector output ends mov r14,0x800000 # qhasm: carry? lou4 += lou5 # asm 1: adds >lou4=int32#8,<lou4=int32#8,<lou5=int32#12 # asm 2: adds >lou4=r7,<lou4=r7,<lou5=r11 adds r7,r7,r11 # qhasm: hiu4 += hiu5 + carry # asm 1: adc >hiu4=int32#9,<hiu4=int32#9,<hiu5=int32#13 # asm 2: adc >hiu4=r8,<hiu4=r8,<hiu5=r12 adc r8,r8,r12 # qhasm: lotmp = mem32[input_0]; input_0 += 4 # asm 1: ldr >lotmp=int32#12,[<input_0=int32#1],#4 # asm 2: ldr >lotmp=r11,[<input_0=r0],#4 # copy-collector input: ldr r11,[r0],#4 # qhasm: hitmp = mem32[input_0]; input_0 += 4 # asm 1: ldr >hitmp=int32#13,[<input_0=int32#1],#4 # asm 2: ldr >hitmp=r12,[<input_0=r0],#4 # copy-collector input: ldr r12,[r0],#4 # qhasm: carry? lou4 += lotmp # asm 1: adds >lou4=int32#8,<lou4=int32#8,<lotmp=int32#12 # asm 2: adds >lou4=r7,<lou4=r7,<lotmp=r11 # copy-collector output starts ldr r11,[r0],#4 ldr r12,[r0],#4 # copy-collector output ends adds r7,r7,r11 # qhasm: hiu4 += hitmp + carry # asm 1: adc >hiu4=int32#9,<hiu4=int32#9,<hitmp=int32#13 # asm 2: adc >hiu4=r8,<hiu4=r8,<hitmp=r12 adc r8,r8,r12 # qhasm: hitmp lotmp = lou3 * two23 # asm 1: umull >lotmp=int32#13,>hitmp=int32#12,<lou3=int32#4,<two23=int32#14 # asm 2: umull >lotmp=r12,>hitmp=r11,<lou3=r3,<two23=r14 umull r12,r11,r3,r14 # qhasm: lotmp hitmp += hiu3 * two23 # asm 1: umlal <hitmp=int32#12,<lotmp=int32#13,<hiu3=int32#5,<two23=int32#14 # asm 2: umlal <hitmp=r11,<lotmp=r12,<hiu3=r4,<two23=r14 umlal r11,r12,r4,r14 # qhasm: lotmp ^= (lou3 unsigned>> 18) # asm 1: eor >lotmp=int32#13,<lotmp=int32#13,<lou3=int32#4,LSR #18 # asm 2: eor >lotmp=r12,<lotmp=r12,<lou3=r3,LSR #18 eor r12,r12,r3,LSR #18 # qhasm: lotmp ^= (hiu3 << 14) # asm 1: eor >lotmp=int32#13,<lotmp=int32#13,<hiu3=int32#5,LSL #14 # asm 2: eor >lotmp=r12,<lotmp=r12,<hiu3=r4,LSL #14 eor r12,r12,r4,LSL #14 # qhasm: lotmp ^= (lou3 unsigned>> 14) # asm 1: eor >lotmp=int32#13,<lotmp=int32#13,<lou3=int32#4,LSR #14 # asm 2: eor >lotmp=r12,<lotmp=r12,<lou3=r3,LSR #14 eor r12,r12,r3,LSR #14 # qhasm: lotmp ^= (hiu3 << 18) # asm 1: eor >lotmp=int32#13,<lotmp=int32#13,<hiu3=int32#5,LSL #18 # asm 2: eor >lotmp=r12,<lotmp=r12,<hiu3=r4,LSL #18 eor r12,r12,r4,LSL #18 # qhasm: hitmp ^= (hiu3 unsigned>> 18) # asm 1: eor >hitmp=int32#12,<hitmp=int32#12,<hiu3=int32#5,LSR #18 # asm 2: eor >hitmp=r11,<hitmp=r11,<hiu3=r4,LSR #18 eor r11,r11,r4,LSR #18 # qhasm: hitmp ^= (lou3 << 14) # asm 1: eor >hitmp=int32#12,<hitmp=int32#12,<lou3=int32#4,LSL #14 # asm 2: eor >hitmp=r11,<hitmp=r11,<lou3=r3,LSL #14 eor r11,r11,r3,LSL #14 # qhasm: hitmp ^= (hiu3 unsigned>> 14) # asm 1: eor >hitmp=int32#12,<hitmp=int32#12,<hiu3=int32#5,LSR #14 # asm 2: eor >hitmp=r11,<hitmp=r11,<hiu3=r4,LSR #14 eor r11,r11,r4,LSR #14 # qhasm: hitmp ^= (lou3 << 18) # asm 1: eor >hitmp=int32#12,<hitmp=int32#12,<lou3=int32#4,LSL #18 # asm 2: eor >hitmp=r11,<hitmp=r11,<lou3=r3,LSL #18 eor r11,r11,r3,LSL #18 # qhasm: carry? lou4 += lotmp # asm 1: adds >lou4=int32#8,<lou4=int32#8,<lotmp=int32#13 # asm 2: adds >lou4=r7,<lou4=r7,<lotmp=r12 adds r7,r7,r12 # qhasm: hiu4 += hitmp + carry # asm 1: adc >hiu4=int32#9,<hiu4=int32#9,<hitmp=int32#12 # asm 2: adc >hiu4=r8,<hiu4=r8,<hitmp=r11 adc r8,r8,r11 # qhasm: lotmp = lou3 & lou0 # asm 1: and >lotmp=int32#2,<lou3=int32#4,<lou0=int32#2 # asm 2: and >lotmp=r1,<lou3=r3,<lou0=r1 and r1,r3,r1 # qhasm: lotmp2 = lou1 & ~lou3 # asm 1: bic >lotmp2=int32#4,<lou1=int32#6,<lou3=int32#4 # asm 2: bic >lotmp2=r3,<lou1=r5,<lou3=r3 bic r3,r5,r3 # qhasm: lotmp ^= lotmp2 # asm 1: eor >lotmp=int32#2,<lotmp=int32#2,<lotmp2=int32#4 # asm 2: eor >lotmp=r1,<lotmp=r1,<lotmp2=r3 eor r1,r1,r3 # qhasm: carry? lou4 += lotmp # asm 1: adds >lou4=int32#2,<lou4=int32#8,<lotmp=int32#2 # asm 2: adds >lou4=r1,<lou4=r7,<lotmp=r1 adds r1,r7,r1 # qhasm: hitmp = hiu3 & hiu0 # asm 1: and >hitmp=int32#3,<hiu3=int32#5,<hiu0=int32#3 # asm 2: and >hitmp=r2,<hiu3=r4,<hiu0=r2 and r2,r4,r2 # qhasm: hitmp2 = hiu1 & ~hiu3 # asm 1: bic >hitmp2=int32#4,<hiu1=int32#7,<hiu3=int32#5 # asm 2: bic >hitmp2=r3,<hiu1=r6,<hiu3=r4 bic r3,r6,r4 # qhasm: hitmp ^= hitmp2 # asm 1: eor >hitmp=int32#3,<hitmp=int32#3,<hitmp2=int32#4 # asm 2: eor >hitmp=r2,<hitmp=r2,<hitmp2=r3 eor r2,r2,r3 # qhasm: hiu4 += hitmp + carry # asm 1: adc >hiu4=int32#3,<hiu4=int32#9,<hitmp=int32#3 # asm 2: adc >hiu4=r2,<hiu4=r8,<hitmp=r2 adc r2,r8,r2 # qhasm: carry? lou2 += lou4 # asm 1: adds >lou2=int32#4,<lou2=int32#10,<lou4=int32#2 # asm 2: adds >lou2=r3,<lou2=r9,<lou4=r1 adds r3,r9,r1 # qhasm: hiu2 += hiu4 + carry # asm 1: adc >hiu2=int32#5,<hiu2=int32#11,<hiu4=int32#3 # asm 2: adc >hiu2=r4,<hiu2=r10,<hiu4=r2 adc r4,r10,r2 # qhasm: lod7 = lou2 # asm 1: vmov >lod7=float32#15,<lou2=int32#4 # asm 2: vmov >lod7=s14,<lou2=r3 # copy-collector input: vmov s14,r3 # qhasm: hid7 = hiu2 # asm 1: vmov >hid7=float32#16,<hiu2=int32#5 # asm 2: vmov >hid7=s15,<hiu2=r4 # copy-collector input: vmov s15,r4 # qhasm: lou0 = lod4 # asm 1: vmov >lou0=int32#6,<lod4=float32#9 # asm 2: vmov >lou0=r5,<lod4=s8 # copy-collector input: vmov r5,s8 # qhasm: hiu0 = hid4 # asm 1: vmov >hiu0=int32#7,<hid4=float32#10 # asm 2: vmov >hiu0=r6,<hid4=s9 # copy-collector input: vmov r6,s9 # qhasm: lou1 = lod5 # asm 1: vmov >lou1=int32#8,<lod5=float32#11 # asm 2: vmov >lou1=r7,<lod5=s10 # copy-collector input: vmov r7,s10 # qhasm: hiu1 = hid5 # asm 1: vmov >hiu1=int32#9,<hid5=float32#12 # asm 2: vmov >hiu1=r8,<hid5=s11 # copy-collector input: vmov r8,s11 # qhasm: lou3 = lod6 # asm 1: vmov >lou3=int32#10,<lod6=float32#13 # asm 2: vmov >lou3=r9,<lod6=s12 # copy-collector input: vmov r9,s12 # qhasm: hiu3 = hid6 # asm 1: vmov >hiu3=int32#11,<hid6=float32#14 # asm 2: vmov >hiu3=r10,<hid6=s13 # copy-collector input: vmov r10,s13 # qhasm: two25 = 0x2000000 simple # asm 1: mov >two25=int32#12,0x2000000 # asm 2: mov >two25=r11,0x2000000 # copy-collector output starts vmov d7,r3,r4 vmov r5,r6,d4 vmov r7,r8,d5 vmov r9,r10,d6 # copy-collector output ends mov r11,0x2000000 # qhasm: hitmp lotmp = lou0 * two25 # asm 1: umull >lotmp=int32#14,>hitmp=int32#13,<lou0=int32#6,<two25=int32#12 # asm 2: umull >lotmp=r14,>hitmp=r12,<lou0=r5,<two25=r11 umull r14,r12,r5,r11 # qhasm: lotmp hitmp += hiu0 * two25 # asm 1: umlal <hitmp=int32#13,<lotmp=int32#14,<hiu0=int32#7,<two25=int32#12 # asm 2: umlal <hitmp=r12,<lotmp=r14,<hiu0=r6,<two25=r11 umlal r12,r14,r6,r11 # qhasm: lotmp ^= (hiu0 unsigned>> 2) # asm 1: eor >lotmp=int32#12,<lotmp=int32#14,<hiu0=int32#7,LSR #2 # asm 2: eor >lotmp=r11,<lotmp=r14,<hiu0=r6,LSR #2 eor r11,r14,r6,LSR #2 # qhasm: lotmp ^= (lou0 << 30) # asm 1: eor >lotmp=int32#12,<lotmp=int32#12,<lou0=int32#6,LSL #30 # asm 2: eor >lotmp=r11,<lotmp=r11,<lou0=r5,LSL #30 eor r11,r11,r5,LSL #30 # qhasm: lotmp ^= (lou0 unsigned>> 28) # asm 1: eor >lotmp=int32#12,<lotmp=int32#12,<lou0=int32#6,LSR #28 # asm 2: eor >lotmp=r11,<lotmp=r11,<lou0=r5,LSR #28 eor r11,r11,r5,LSR #28 # qhasm: lotmp ^= (hiu0 << 4) # asm 1: eor >lotmp=int32#12,<lotmp=int32#12,<hiu0=int32#7,LSL #4 # asm 2: eor >lotmp=r11,<lotmp=r11,<hiu0=r6,LSL #4 eor r11,r11,r6,LSL #4 # qhasm: hitmp ^= (lou0 unsigned>> 2) # asm 1: eor >hitmp=int32#13,<hitmp=int32#13,<lou0=int32#6,LSR #2 # asm 2: eor >hitmp=r12,<hitmp=r12,<lou0=r5,LSR #2 eor r12,r12,r5,LSR #2 # qhasm: hitmp ^= (hiu0 << 30) # asm 1: eor >hitmp=int32#13,<hitmp=int32#13,<hiu0=int32#7,LSL #30 # asm 2: eor >hitmp=r12,<hitmp=r12,<hiu0=r6,LSL #30 eor r12,r12,r6,LSL #30 # qhasm: hitmp ^= (hiu0 unsigned>> 28) # asm 1: eor >hitmp=int32#13,<hitmp=int32#13,<hiu0=int32#7,LSR #28 # asm 2: eor >hitmp=r12,<hitmp=r12,<hiu0=r6,LSR #28 eor r12,r12,r6,LSR #28 # qhasm: hitmp ^= (lou0 << 4) # asm 1: eor >hitmp=int32#13,<hitmp=int32#13,<lou0=int32#6,LSL #4 # asm 2: eor >hitmp=r12,<hitmp=r12,<lou0=r5,LSL #4 eor r12,r12,r5,LSL #4 # qhasm: carry? lou4 += lotmp # asm 1: adds >lou4=int32#2,<lou4=int32#2,<lotmp=int32#12 # asm 2: adds >lou4=r1,<lou4=r1,<lotmp=r11 adds r1,r1,r11 # qhasm: hiu4 += hitmp + carry # asm 1: adc >hiu4=int32#3,<hiu4=int32#3,<hitmp=int32#13 # asm 2: adc >hiu4=r2,<hiu4=r2,<hitmp=r12 adc r2,r2,r12 # qhasm: lotmp = lou1 ^ lou3 # asm 1: eor >lotmp=int32#12,<lou1=int32#8,<lou3=int32#10 # asm 2: eor >lotmp=r11,<lou1=r7,<lou3=r9 eor r11,r7,r9 # qhasm: lotmp &= lou0 # asm 1: and >lotmp=int32#6,<lotmp=int32#12,<lou0=int32#6 # asm 2: and >lotmp=r5,<lotmp=r11,<lou0=r5 and r5,r11,r5 # qhasm: lotmp2 = lou1 & lou3 # asm 1: and >lotmp2=int32#8,<lou1=int32#8,<lou3=int32#10 # asm 2: and >lotmp2=r7,<lou1=r7,<lou3=r9 and r7,r7,r9 # qhasm: lotmp ^= lotmp2 # asm 1: eor >lotmp=int32#6,<lotmp=int32#6,<lotmp2=int32#8 # asm 2: eor >lotmp=r5,<lotmp=r5,<lotmp2=r7 eor r5,r5,r7 # qhasm: carry? lou4 += lotmp # asm 1: adds >lou4=int32#2,<lou4=int32#2,<lotmp=int32#6 # asm 2: adds >lou4=r1,<lou4=r1,<lotmp=r5 adds r1,r1,r5 # qhasm: hitmp = hiu1 ^ hiu3 # asm 1: eor >hitmp=int32#6,<hiu1=int32#9,<hiu3=int32#11 # asm 2: eor >hitmp=r5,<hiu1=r8,<hiu3=r10 eor r5,r8,r10 # qhasm: hitmp &= hiu0 # asm 1: and >hitmp=int32#6,<hitmp=int32#6,<hiu0=int32#7 # asm 2: and >hitmp=r5,<hitmp=r5,<hiu0=r6 and r5,r5,r6 # qhasm: hitmp2 = hiu1 & hiu3 # asm 1: and >hitmp2=int32#7,<hiu1=int32#9,<hiu3=int32#11 # asm 2: and >hitmp2=r6,<hiu1=r8,<hiu3=r10 and r6,r8,r10 # qhasm: hitmp ^= hitmp2 # asm 1: eor >hitmp=int32#6,<hitmp=int32#6,<hitmp2=int32#7 # asm 2: eor >hitmp=r5,<hitmp=r5,<hitmp2=r6 eor r5,r5,r6 # qhasm: hiu4 += hitmp + carry # asm 1: adc >hiu4=int32#3,<hiu4=int32#3,<hitmp=int32#6 # asm 2: adc >hiu4=r2,<hiu4=r2,<hitmp=r5 adc r2,r2,r5 # qhasm: lod3 = lou4 # asm 1: vmov >lod3=float32#7,<lou4=int32#2 # asm 2: vmov >lod3=s6,<lou4=r1 # copy-collector input: vmov s6,r1 # qhasm: hid3 = hiu4 # asm 1: vmov >hid3=float32#8,<hiu4=int32#3 # asm 2: vmov >hid3=s7,<hiu4=r2 # copy-collector input: vmov s7,r2 # qhasm: lou0 = lod0 # asm 1: vmov >lou0=int32#2,<lod0=float32#1 # asm 2: vmov >lou0=r1,<lod0=s0 # copy-collector input: vmov r1,s0 # qhasm: hiu0 = hid0 # asm 1: vmov >hiu0=int32#3,<hid0=float32#2 # asm 2: vmov >hiu0=r2,<hid0=s1 # copy-collector input: vmov r2,s1 # qhasm: lou1 = lod1 # asm 1: vmov >lou1=int32#6,<lod1=float32#3 # asm 2: vmov >lou1=r5,<lod1=s2 # copy-collector input: vmov r5,s2 # qhasm: hiu1 = hid1 # asm 1: vmov >hiu1=int32#7,<hid1=float32#4 # asm 2: vmov >hiu1=r6,<hid1=s3 # copy-collector input: vmov r6,s3 # qhasm: lou4 = lod2 # asm 1: vmov >lou4=int32#8,<lod2=float32#5 # asm 2: vmov >lou4=r7,<lod2=s4 # copy-collector input: vmov r7,s4 # qhasm: hiu4 = hid2 # asm 1: vmov >hiu4=int32#9,<hid2=float32#6 # asm 2: vmov >hiu4=r8,<hid2=s5 # copy-collector input: vmov r8,s5 # qhasm: lou5 = lod13 # asm 1: vmov >lou5=int32#12,<lod13=float32#27 # asm 2: vmov >lou5=r11,<lod13=s26 # copy-collector input: vmov r11,s26 # qhasm: hiu5 = hid13 # asm 1: vmov >hiu5=int32#13,<hid13=float32#28 # asm 2: vmov >hiu5=r12,<hid13=s27 # copy-collector input: vmov r12,s27 # qhasm: two23 = 0x800000 simple # asm 1: mov >two23=int32#14,0x800000 # asm 2: mov >two23=r14,0x800000 # copy-collector output starts vmov d3,r1,r2 vmov r1,r2,d0 vmov r5,r6,d1 vmov r7,r8,d2 vmov r11,r12,d13 # copy-collector output ends mov r14,0x800000 # qhasm: carry? lou4 += lou5 # asm 1: adds >lou4=int32#8,<lou4=int32#8,<lou5=int32#12 # asm 2: adds >lou4=r7,<lou4=r7,<lou5=r11 adds r7,r7,r11 # qhasm: hiu4 += hiu5 + carry # asm 1: adc >hiu4=int32#9,<hiu4=int32#9,<hiu5=int32#13 # asm 2: adc >hiu4=r8,<hiu4=r8,<hiu5=r12 adc r8,r8,r12 # qhasm: lotmp = mem32[input_0]; input_0 += 4 # asm 1: ldr >lotmp=int32#12,[<input_0=int32#1],#4 # asm 2: ldr >lotmp=r11,[<input_0=r0],#4 # copy-collector input: ldr r11,[r0],#4 # qhasm: hitmp = mem32[input_0]; input_0 += 4 # asm 1: ldr >hitmp=int32#13,[<input_0=int32#1],#4 # asm 2: ldr >hitmp=r12,[<input_0=r0],#4 # copy-collector input: ldr r12,[r0],#4 # qhasm: carry? lou4 += lotmp # asm 1: adds >lou4=int32#8,<lou4=int32#8,<lotmp=int32#12 # asm 2: adds >lou4=r7,<lou4=r7,<lotmp=r11 # copy-collector output starts ldr r11,[r0],#4 ldr r12,[r0],#4 # copy-collector output ends adds r7,r7,r11 # qhasm: hiu4 += hitmp + carry # asm 1: adc >hiu4=int32#9,<hiu4=int32#9,<hitmp=int32#13 # asm 2: adc >hiu4=r8,<hiu4=r8,<hitmp=r12 adc r8,r8,r12 # qhasm: hitmp lotmp = lou2 * two23 # asm 1: umull >lotmp=int32#13,>hitmp=int32#12,<lou2=int32#4,<two23=int32#14 # asm 2: umull >lotmp=r12,>hitmp=r11,<lou2=r3,<two23=r14 umull r12,r11,r3,r14 # qhasm: lotmp hitmp += hiu2 * two23 # asm 1: umlal <hitmp=int32#12,<lotmp=int32#13,<hiu2=int32#5,<two23=int32#14 # asm 2: umlal <hitmp=r11,<lotmp=r12,<hiu2=r4,<two23=r14 umlal r11,r12,r4,r14 # qhasm: lotmp ^= (lou2 unsigned>> 18) # asm 1: eor >lotmp=int32#13,<lotmp=int32#13,<lou2=int32#4,LSR #18 # asm 2: eor >lotmp=r12,<lotmp=r12,<lou2=r3,LSR #18 eor r12,r12,r3,LSR #18 # qhasm: lotmp ^= (hiu2 << 14) # asm 1: eor >lotmp=int32#13,<lotmp=int32#13,<hiu2=int32#5,LSL #14 # asm 2: eor >lotmp=r12,<lotmp=r12,<hiu2=r4,LSL #14 eor r12,r12,r4,LSL #14 # qhasm: lotmp ^= (lou2 unsigned>> 14) # asm 1: eor >lotmp=int32#13,<lotmp=int32#13,<lou2=int32#4,LSR #14 # asm 2: eor >lotmp=r12,<lotmp=r12,<lou2=r3,LSR #14 eor r12,r12,r3,LSR #14 # qhasm: lotmp ^= (hiu2 << 18) # asm 1: eor >lotmp=int32#13,<lotmp=int32#13,<hiu2=int32#5,LSL #18 # asm 2: eor >lotmp=r12,<lotmp=r12,<hiu2=r4,LSL #18 eor r12,r12,r4,LSL #18 # qhasm: hitmp ^= (hiu2 unsigned>> 18) # asm 1: eor >hitmp=int32#12,<hitmp=int32#12,<hiu2=int32#5,LSR #18 # asm 2: eor >hitmp=r11,<hitmp=r11,<hiu2=r4,LSR #18 eor r11,r11,r4,LSR #18 # qhasm: hitmp ^= (lou2 << 14) # asm 1: eor >hitmp=int32#12,<hitmp=int32#12,<lou2=int32#4,LSL #14 # asm 2: eor >hitmp=r11,<hitmp=r11,<lou2=r3,LSL #14 eor r11,r11,r3,LSL #14 # qhasm: hitmp ^= (hiu2 unsigned>> 14) # asm 1: eor >hitmp=int32#12,<hitmp=int32#12,<hiu2=int32#5,LSR #14 # asm 2: eor >hitmp=r11,<hitmp=r11,<hiu2=r4,LSR #14 eor r11,r11,r4,LSR #14 # qhasm: hitmp ^= (lou2 << 18) # asm 1: eor >hitmp=int32#12,<hitmp=int32#12,<lou2=int32#4,LSL #18 # asm 2: eor >hitmp=r11,<hitmp=r11,<lou2=r3,LSL #18 eor r11,r11,r3,LSL #18 # qhasm: carry? lou4 += lotmp # asm 1: adds >lou4=int32#8,<lou4=int32#8,<lotmp=int32#13 # asm 2: adds >lou4=r7,<lou4=r7,<lotmp=r12 adds r7,r7,r12 # qhasm: hiu4 += hitmp + carry # asm 1: adc >hiu4=int32#9,<hiu4=int32#9,<hitmp=int32#12 # asm 2: adc >hiu4=r8,<hiu4=r8,<hitmp=r11 adc r8,r8,r11 # qhasm: lotmp = lou2 & lou0 # asm 1: and >lotmp=int32#2,<lou2=int32#4,<lou0=int32#2 # asm 2: and >lotmp=r1,<lou2=r3,<lou0=r1 and r1,r3,r1 # qhasm: lotmp2 = lou1 & ~lou2 # asm 1: bic >lotmp2=int32#4,<lou1=int32#6,<lou2=int32#4 # asm 2: bic >lotmp2=r3,<lou1=r5,<lou2=r3 bic r3,r5,r3 # qhasm: lotmp ^= lotmp2 # asm 1: eor >lotmp=int32#2,<lotmp=int32#2,<lotmp2=int32#4 # asm 2: eor >lotmp=r1,<lotmp=r1,<lotmp2=r3 eor r1,r1,r3 # qhasm: carry? lou4 += lotmp # asm 1: adds >lou4=int32#2,<lou4=int32#8,<lotmp=int32#2 # asm 2: adds >lou4=r1,<lou4=r7,<lotmp=r1 adds r1,r7,r1 # qhasm: hitmp = hiu2 & hiu0 # asm 1: and >hitmp=int32#3,<hiu2=int32#5,<hiu0=int32#3 # asm 2: and >hitmp=r2,<hiu2=r4,<hiu0=r2 and r2,r4,r2 # qhasm: hitmp2 = hiu1 & ~hiu2 # asm 1: bic >hitmp2=int32#4,<hiu1=int32#7,<hiu2=int32#5 # asm 2: bic >hitmp2=r3,<hiu1=r6,<hiu2=r4 bic r3,r6,r4 # qhasm: hitmp ^= hitmp2 # asm 1: eor >hitmp=int32#3,<hitmp=int32#3,<hitmp2=int32#4 # asm 2: eor >hitmp=r2,<hitmp=r2,<hitmp2=r3 eor r2,r2,r3 # qhasm: hiu4 += hitmp + carry # asm 1: adc >hiu4=int32#3,<hiu4=int32#9,<hitmp=int32#3 # asm 2: adc >hiu4=r2,<hiu4=r8,<hitmp=r2 adc r2,r8,r2 # qhasm: carry? lou3 += lou4 # asm 1: adds >lou3=int32#4,<lou3=int32#10,<lou4=int32#2 # asm 2: adds >lou3=r3,<lou3=r9,<lou4=r1 adds r3,r9,r1 # qhasm: hiu3 += hiu4 + carry # asm 1: adc >hiu3=int32#5,<hiu3=int32#11,<hiu4=int32#3 # asm 2: adc >hiu3=r4,<hiu3=r10,<hiu4=r2 adc r4,r10,r2 # qhasm: lod6 = lou3 # asm 1: vmov >lod6=float32#13,<lou3=int32#4 # asm 2: vmov >lod6=s12,<lou3=r3 # copy-collector input: vmov s12,r3 # qhasm: hid6 = hiu3 # asm 1: vmov >hid6=float32#14,<hiu3=int32#5 # asm 2: vmov >hid6=s13,<hiu3=r4 # copy-collector input: vmov s13,r4 # qhasm: lou0 = lod3 # asm 1: vmov >lou0=int32#6,<lod3=float32#7 # asm 2: vmov >lou0=r5,<lod3=s6 # copy-collector input: vmov r5,s6 # qhasm: hiu0 = hid3 # asm 1: vmov >hiu0=int32#7,<hid3=float32#8 # asm 2: vmov >hiu0=r6,<hid3=s7 # copy-collector input: vmov r6,s7 # qhasm: lou1 = lod4 # asm 1: vmov >lou1=int32#8,<lod4=float32#9 # asm 2: vmov >lou1=r7,<lod4=s8 # copy-collector input: vmov r7,s8 # qhasm: hiu1 = hid4 # asm 1: vmov >hiu1=int32#9,<hid4=float32#10 # asm 2: vmov >hiu1=r8,<hid4=s9 # copy-collector input: vmov r8,s9 # qhasm: lou2 = lod5 # asm 1: vmov >lou2=int32#10,<lod5=float32#11 # asm 2: vmov >lou2=r9,<lod5=s10 # copy-collector input: vmov r9,s10 # qhasm: hiu2 = hid5 # asm 1: vmov >hiu2=int32#11,<hid5=float32#12 # asm 2: vmov >hiu2=r10,<hid5=s11 # copy-collector input: vmov r10,s11 # qhasm: two25 = 0x2000000 simple # asm 1: mov >two25=int32#12,0x2000000 # asm 2: mov >two25=r11,0x2000000 # copy-collector output starts vmov d6,r3,r4 vmov r5,r6,d3 vmov r7,r8,d4 vmov r9,r10,d5 # copy-collector output ends mov r11,0x2000000 # qhasm: hitmp lotmp = lou0 * two25 # asm 1: umull >lotmp=int32#14,>hitmp=int32#13,<lou0=int32#6,<two25=int32#12 # asm 2: umull >lotmp=r14,>hitmp=r12,<lou0=r5,<two25=r11 umull r14,r12,r5,r11 # qhasm: lotmp hitmp += hiu0 * two25 # asm 1: umlal <hitmp=int32#13,<lotmp=int32#14,<hiu0=int32#7,<two25=int32#12 # asm 2: umlal <hitmp=r12,<lotmp=r14,<hiu0=r6,<two25=r11 umlal r12,r14,r6,r11 # qhasm: lotmp ^= (hiu0 unsigned>> 2) # asm 1: eor >lotmp=int32#12,<lotmp=int32#14,<hiu0=int32#7,LSR #2 # asm 2: eor >lotmp=r11,<lotmp=r14,<hiu0=r6,LSR #2 eor r11,r14,r6,LSR #2 # qhasm: lotmp ^= (lou0 << 30) # asm 1: eor >lotmp=int32#12,<lotmp=int32#12,<lou0=int32#6,LSL #30 # asm 2: eor >lotmp=r11,<lotmp=r11,<lou0=r5,LSL #30 eor r11,r11,r5,LSL #30 # qhasm: lotmp ^= (lou0 unsigned>> 28) # asm 1: eor >lotmp=int32#12,<lotmp=int32#12,<lou0=int32#6,LSR #28 # asm 2: eor >lotmp=r11,<lotmp=r11,<lou0=r5,LSR #28 eor r11,r11,r5,LSR #28 # qhasm: lotmp ^= (hiu0 << 4) # asm 1: eor >lotmp=int32#12,<lotmp=int32#12,<hiu0=int32#7,LSL #4 # asm 2: eor >lotmp=r11,<lotmp=r11,<hiu0=r6,LSL #4 eor r11,r11,r6,LSL #4 # qhasm: hitmp ^= (lou0 unsigned>> 2) # asm 1: eor >hitmp=int32#13,<hitmp=int32#13,<lou0=int32#6,LSR #2 # asm 2: eor >hitmp=r12,<hitmp=r12,<lou0=r5,LSR #2 eor r12,r12,r5,LSR #2 # qhasm: hitmp ^= (hiu0 << 30) # asm 1: eor >hitmp=int32#13,<hitmp=int32#13,<hiu0=int32#7,LSL #30 # asm 2: eor >hitmp=r12,<hitmp=r12,<hiu0=r6,LSL #30 eor r12,r12,r6,LSL #30 # qhasm: hitmp ^= (hiu0 unsigned>> 28) # asm 1: eor >hitmp=int32#13,<hitmp=int32#13,<hiu0=int32#7,LSR #28 # asm 2: eor >hitmp=r12,<hitmp=r12,<hiu0=r6,LSR #28 eor r12,r12,r6,LSR #28 # qhasm: hitmp ^= (lou0 << 4) # asm 1: eor >hitmp=int32#13,<hitmp=int32#13,<lou0=int32#6,LSL #4 # asm 2: eor >hitmp=r12,<hitmp=r12,<lou0=r5,LSL #4 eor r12,r12,r5,LSL #4 # qhasm: carry? lou4 += lotmp # asm 1: adds >lou4=int32#2,<lou4=int32#2,<lotmp=int32#12 # asm 2: adds >lou4=r1,<lou4=r1,<lotmp=r11 adds r1,r1,r11 # qhasm: hiu4 += hitmp + carry # asm 1: adc >hiu4=int32#3,<hiu4=int32#3,<hitmp=int32#13 # asm 2: adc >hiu4=r2,<hiu4=r2,<hitmp=r12 adc r2,r2,r12 # qhasm: lotmp = lou1 ^ lou2 # asm 1: eor >lotmp=int32#12,<lou1=int32#8,<lou2=int32#10 # asm 2: eor >lotmp=r11,<lou1=r7,<lou2=r9 eor r11,r7,r9 # qhasm: lotmp &= lou0 # asm 1: and >lotmp=int32#6,<lotmp=int32#12,<lou0=int32#6 # asm 2: and >lotmp=r5,<lotmp=r11,<lou0=r5 and r5,r11,r5 # qhasm: lotmp2 = lou1 & lou2 # asm 1: and >lotmp2=int32#8,<lou1=int32#8,<lou2=int32#10 # asm 2: and >lotmp2=r7,<lou1=r7,<lou2=r9 and r7,r7,r9 # qhasm: lotmp ^= lotmp2 # asm 1: eor >lotmp=int32#6,<lotmp=int32#6,<lotmp2=int32#8 # asm 2: eor >lotmp=r5,<lotmp=r5,<lotmp2=r7 eor r5,r5,r7 # qhasm: carry? lou4 += lotmp # asm 1: adds >lou4=int32#2,<lou4=int32#2,<lotmp=int32#6 # asm 2: adds >lou4=r1,<lou4=r1,<lotmp=r5 adds r1,r1,r5 # qhasm: hitmp = hiu1 ^ hiu2 # asm 1: eor >hitmp=int32#6,<hiu1=int32#9,<hiu2=int32#11 # asm 2: eor >hitmp=r5,<hiu1=r8,<hiu2=r10 eor r5,r8,r10 # qhasm: hitmp &= hiu0 # asm 1: and >hitmp=int32#6,<hitmp=int32#6,<hiu0=int32#7 # asm 2: and >hitmp=r5,<hitmp=r5,<hiu0=r6 and r5,r5,r6 # qhasm: hitmp2 = hiu1 & hiu2 # asm 1: and >hitmp2=int32#7,<hiu1=int32#9,<hiu2=int32#11 # asm 2: and >hitmp2=r6,<hiu1=r8,<hiu2=r10 and r6,r8,r10 # qhasm: hitmp ^= hitmp2 # asm 1: eor >hitmp=int32#6,<hitmp=int32#6,<hitmp2=int32#7 # asm 2: eor >hitmp=r5,<hitmp=r5,<hitmp2=r6 eor r5,r5,r6 # qhasm: hiu4 += hitmp + carry # asm 1: adc >hiu4=int32#3,<hiu4=int32#3,<hitmp=int32#6 # asm 2: adc >hiu4=r2,<hiu4=r2,<hitmp=r5 adc r2,r2,r5 # qhasm: lod2 = lou4 # asm 1: vmov >lod2=float32#5,<lou4=int32#2 # asm 2: vmov >lod2=s4,<lou4=r1 # copy-collector input: vmov s4,r1 # qhasm: hid2 = hiu4 # asm 1: vmov >hid2=float32#6,<hiu4=int32#3 # asm 2: vmov >hid2=s5,<hiu4=r2 # copy-collector input: vmov s5,r2 # qhasm: assign 0 to lod0 # qhasm: assign 1 to hid0 # qhasm: assign 2 to lod1 # qhasm: assign 3 to hid1 # qhasm: assign 4 to lod2 # qhasm: assign 5 to hid2 # qhasm: assign 6 to lod3 # qhasm: assign 7 to hid3 # qhasm: assign 8 to lod4 # qhasm: assign 9 to hid4 # qhasm: assign 10 to lod5 # qhasm: assign 11 to hid5 # qhasm: assign 12 to lod6 # qhasm: assign 13 to hid6 # qhasm: assign 14 to lod7 # qhasm: assign 15 to hid7 # qhasm: lou0 = lod7 # asm 1: vmov >lou0=int32#2,<lod7=float32#15 # asm 2: vmov >lou0=r1,<lod7=s14 # copy-collector input: vmov r1,s14 # qhasm: hiu0 = hid7 # asm 1: vmov >hiu0=int32#3,<hid7=float32#16 # asm 2: vmov >hiu0=r2,<hid7=s15 # copy-collector input: vmov r2,s15 # qhasm: lou1 = lod0 # asm 1: vmov >lou1=int32#6,<lod0=float32#1 # asm 2: vmov >lou1=r5,<lod0=s0 # copy-collector input: vmov r5,s0 # qhasm: hiu1 = hid0 # asm 1: vmov >hiu1=int32#7,<hid0=float32#2 # asm 2: vmov >hiu1=r6,<hid0=s1 # copy-collector input: vmov r6,s1 # qhasm: lou4 = lod1 # asm 1: vmov >lou4=int32#8,<lod1=float32#3 # asm 2: vmov >lou4=r7,<lod1=s2 # copy-collector input: vmov r7,s2 # qhasm: hiu4 = hid1 # asm 1: vmov >hiu4=int32#9,<hid1=float32#4 # asm 2: vmov >hiu4=r8,<hid1=s3 # copy-collector input: vmov r8,s3 # qhasm: lou5 = lod14 # asm 1: vmov >lou5=int32#12,<lod14=float32#29 # asm 2: vmov >lou5=r11,<lod14=s28 # copy-collector input: vmov r11,s28 # qhasm: hiu5 = hid14 # asm 1: vmov >hiu5=int32#13,<hid14=float32#30 # asm 2: vmov >hiu5=r12,<hid14=s29 # copy-collector input: vmov r12,s29 # qhasm: two23 = 0x800000 simple # asm 1: mov >two23=int32#14,0x800000 # asm 2: mov >two23=r14,0x800000 # copy-collector output starts vmov d2,r1,r2 vmov r1,r2,d7 vmov r5,r6,d0 vmov r7,r8,d1 vmov r11,r12,d14 # copy-collector output ends mov r14,0x800000 # qhasm: carry? lou4 += lou5 # asm 1: adds >lou4=int32#8,<lou4=int32#8,<lou5=int32#12 # asm 2: adds >lou4=r7,<lou4=r7,<lou5=r11 adds r7,r7,r11 # qhasm: hiu4 += hiu5 + carry # asm 1: adc >hiu4=int32#9,<hiu4=int32#9,<hiu5=int32#13 # asm 2: adc >hiu4=r8,<hiu4=r8,<hiu5=r12 adc r8,r8,r12 # qhasm: lotmp = mem32[input_0]; input_0 += 4 # asm 1: ldr >lotmp=int32#12,[<input_0=int32#1],#4 # asm 2: ldr >lotmp=r11,[<input_0=r0],#4 # copy-collector input: ldr r11,[r0],#4 # qhasm: hitmp = mem32[input_0]; input_0 += 4 # asm 1: ldr >hitmp=int32#13,[<input_0=int32#1],#4 # asm 2: ldr >hitmp=r12,[<input_0=r0],#4 # copy-collector input: ldr r12,[r0],#4 # qhasm: carry? lou4 += lotmp # asm 1: adds >lou4=int32#8,<lou4=int32#8,<lotmp=int32#12 # asm 2: adds >lou4=r7,<lou4=r7,<lotmp=r11 # copy-collector output starts ldr r11,[r0],#4 ldr r12,[r0],#4 # copy-collector output ends adds r7,r7,r11 # qhasm: hiu4 += hitmp + carry # asm 1: adc >hiu4=int32#9,<hiu4=int32#9,<hitmp=int32#13 # asm 2: adc >hiu4=r8,<hiu4=r8,<hitmp=r12 adc r8,r8,r12 # qhasm: hitmp lotmp = lou3 * two23 # asm 1: umull >lotmp=int32#13,>hitmp=int32#12,<lou3=int32#4,<two23=int32#14 # asm 2: umull >lotmp=r12,>hitmp=r11,<lou3=r3,<two23=r14 umull r12,r11,r3,r14 # qhasm: lotmp hitmp += hiu3 * two23 # asm 1: umlal <hitmp=int32#12,<lotmp=int32#13,<hiu3=int32#5,<two23=int32#14 # asm 2: umlal <hitmp=r11,<lotmp=r12,<hiu3=r4,<two23=r14 umlal r11,r12,r4,r14 # qhasm: lotmp ^= (lou3 unsigned>> 18) # asm 1: eor >lotmp=int32#13,<lotmp=int32#13,<lou3=int32#4,LSR #18 # asm 2: eor >lotmp=r12,<lotmp=r12,<lou3=r3,LSR #18 eor r12,r12,r3,LSR #18 # qhasm: lotmp ^= (hiu3 << 14) # asm 1: eor >lotmp=int32#13,<lotmp=int32#13,<hiu3=int32#5,LSL #14 # asm 2: eor >lotmp=r12,<lotmp=r12,<hiu3=r4,LSL #14 eor r12,r12,r4,LSL #14 # qhasm: lotmp ^= (lou3 unsigned>> 14) # asm 1: eor >lotmp=int32#13,<lotmp=int32#13,<lou3=int32#4,LSR #14 # asm 2: eor >lotmp=r12,<lotmp=r12,<lou3=r3,LSR #14 eor r12,r12,r3,LSR #14 # qhasm: lotmp ^= (hiu3 << 18) # asm 1: eor >lotmp=int32#13,<lotmp=int32#13,<hiu3=int32#5,LSL #18 # asm 2: eor >lotmp=r12,<lotmp=r12,<hiu3=r4,LSL #18 eor r12,r12,r4,LSL #18 # qhasm: hitmp ^= (hiu3 unsigned>> 18) # asm 1: eor >hitmp=int32#12,<hitmp=int32#12,<hiu3=int32#5,LSR #18 # asm 2: eor >hitmp=r11,<hitmp=r11,<hiu3=r4,LSR #18 eor r11,r11,r4,LSR #18 # qhasm: hitmp ^= (lou3 << 14) # asm 1: eor >hitmp=int32#12,<hitmp=int32#12,<lou3=int32#4,LSL #14 # asm 2: eor >hitmp=r11,<hitmp=r11,<lou3=r3,LSL #14 eor r11,r11,r3,LSL #14 # qhasm: hitmp ^= (hiu3 unsigned>> 14) # asm 1: eor >hitmp=int32#12,<hitmp=int32#12,<hiu3=int32#5,LSR #14 # asm 2: eor >hitmp=r11,<hitmp=r11,<hiu3=r4,LSR #14 eor r11,r11,r4,LSR #14 # qhasm: hitmp ^= (lou3 << 18) # asm 1: eor >hitmp=int32#12,<hitmp=int32#12,<lou3=int32#4,LSL #18 # asm 2: eor >hitmp=r11,<hitmp=r11,<lou3=r3,LSL #18 eor r11,r11,r3,LSL #18 # qhasm: carry? lou4 += lotmp # asm 1: adds >lou4=int32#8,<lou4=int32#8,<lotmp=int32#13 # asm 2: adds >lou4=r7,<lou4=r7,<lotmp=r12 adds r7,r7,r12 # qhasm: hiu4 += hitmp + carry # asm 1: adc >hiu4=int32#9,<hiu4=int32#9,<hitmp=int32#12 # asm 2: adc >hiu4=r8,<hiu4=r8,<hitmp=r11 adc r8,r8,r11 # qhasm: lotmp = lou3 & lou0 # asm 1: and >lotmp=int32#2,<lou3=int32#4,<lou0=int32#2 # asm 2: and >lotmp=r1,<lou3=r3,<lou0=r1 and r1,r3,r1 # qhasm: lotmp2 = lou1 & ~lou3 # asm 1: bic >lotmp2=int32#4,<lou1=int32#6,<lou3=int32#4 # asm 2: bic >lotmp2=r3,<lou1=r5,<lou3=r3 bic r3,r5,r3 # qhasm: lotmp ^= lotmp2 # asm 1: eor >lotmp=int32#2,<lotmp=int32#2,<lotmp2=int32#4 # asm 2: eor >lotmp=r1,<lotmp=r1,<lotmp2=r3 eor r1,r1,r3 # qhasm: carry? lou4 += lotmp # asm 1: adds >lou4=int32#2,<lou4=int32#8,<lotmp=int32#2 # asm 2: adds >lou4=r1,<lou4=r7,<lotmp=r1 adds r1,r7,r1 # qhasm: hitmp = hiu3 & hiu0 # asm 1: and >hitmp=int32#3,<hiu3=int32#5,<hiu0=int32#3 # asm 2: and >hitmp=r2,<hiu3=r4,<hiu0=r2 and r2,r4,r2 # qhasm: hitmp2 = hiu1 & ~hiu3 # asm 1: bic >hitmp2=int32#4,<hiu1=int32#7,<hiu3=int32#5 # asm 2: bic >hitmp2=r3,<hiu1=r6,<hiu3=r4 bic r3,r6,r4 # qhasm: hitmp ^= hitmp2 # asm 1: eor >hitmp=int32#3,<hitmp=int32#3,<hitmp2=int32#4 # asm 2: eor >hitmp=r2,<hitmp=r2,<hitmp2=r3 eor r2,r2,r3 # qhasm: hiu4 += hitmp + carry # asm 1: adc >hiu4=int32#3,<hiu4=int32#9,<hitmp=int32#3 # asm 2: adc >hiu4=r2,<hiu4=r8,<hitmp=r2 adc r2,r8,r2 # qhasm: carry? lou2 += lou4 # asm 1: adds >lou2=int32#4,<lou2=int32#10,<lou4=int32#2 # asm 2: adds >lou2=r3,<lou2=r9,<lou4=r1 adds r3,r9,r1 # qhasm: hiu2 += hiu4 + carry # asm 1: adc >hiu2=int32#5,<hiu2=int32#11,<hiu4=int32#3 # asm 2: adc >hiu2=r4,<hiu2=r10,<hiu4=r2 adc r4,r10,r2 # qhasm: lod5 = lou2 # asm 1: vmov >lod5=float32#11,<lou2=int32#4 # asm 2: vmov >lod5=s10,<lou2=r3 # copy-collector input: vmov s10,r3 # qhasm: hid5 = hiu2 # asm 1: vmov >hid5=float32#12,<hiu2=int32#5 # asm 2: vmov >hid5=s11,<hiu2=r4 # copy-collector input: vmov s11,r4 # qhasm: lou0 = lod2 # asm 1: vmov >lou0=int32#6,<lod2=float32#5 # asm 2: vmov >lou0=r5,<lod2=s4 # copy-collector input: vmov r5,s4 # qhasm: hiu0 = hid2 # asm 1: vmov >hiu0=int32#7,<hid2=float32#6 # asm 2: vmov >hiu0=r6,<hid2=s5 # copy-collector input: vmov r6,s5 # qhasm: lou1 = lod3 # asm 1: vmov >lou1=int32#8,<lod3=float32#7 # asm 2: vmov >lou1=r7,<lod3=s6 # copy-collector input: vmov r7,s6 # qhasm: hiu1 = hid3 # asm 1: vmov >hiu1=int32#9,<hid3=float32#8 # asm 2: vmov >hiu1=r8,<hid3=s7 # copy-collector input: vmov r8,s7 # qhasm: lou3 = lod4 # asm 1: vmov >lou3=int32#10,<lod4=float32#9 # asm 2: vmov >lou3=r9,<lod4=s8 # copy-collector input: vmov r9,s8 # qhasm: hiu3 = hid4 # asm 1: vmov >hiu3=int32#11,<hid4=float32#10 # asm 2: vmov >hiu3=r10,<hid4=s9 # copy-collector input: vmov r10,s9 # qhasm: two25 = 0x2000000 simple # asm 1: mov >two25=int32#12,0x2000000 # asm 2: mov >two25=r11,0x2000000 # copy-collector output starts vmov d5,r3,r4 vmov r5,r6,d2 vmov r7,r8,d3 vmov r9,r10,d4 # copy-collector output ends mov r11,0x2000000 # qhasm: hitmp lotmp = lou0 * two25 # asm 1: umull >lotmp=int32#14,>hitmp=int32#13,<lou0=int32#6,<two25=int32#12 # asm 2: umull >lotmp=r14,>hitmp=r12,<lou0=r5,<two25=r11 umull r14,r12,r5,r11 # qhasm: lotmp hitmp += hiu0 * two25 # asm 1: umlal <hitmp=int32#13,<lotmp=int32#14,<hiu0=int32#7,<two25=int32#12 # asm 2: umlal <hitmp=r12,<lotmp=r14,<hiu0=r6,<two25=r11 umlal r12,r14,r6,r11 # qhasm: lotmp ^= (hiu0 unsigned>> 2) # asm 1: eor >lotmp=int32#12,<lotmp=int32#14,<hiu0=int32#7,LSR #2 # asm 2: eor >lotmp=r11,<lotmp=r14,<hiu0=r6,LSR #2 eor r11,r14,r6,LSR #2 # qhasm: lotmp ^= (lou0 << 30) # asm 1: eor >lotmp=int32#12,<lotmp=int32#12,<lou0=int32#6,LSL #30 # asm 2: eor >lotmp=r11,<lotmp=r11,<lou0=r5,LSL #30 eor r11,r11,r5,LSL #30 # qhasm: lotmp ^= (lou0 unsigned>> 28) # asm 1: eor >lotmp=int32#12,<lotmp=int32#12,<lou0=int32#6,LSR #28 # asm 2: eor >lotmp=r11,<lotmp=r11,<lou0=r5,LSR #28 eor r11,r11,r5,LSR #28 # qhasm: lotmp ^= (hiu0 << 4) # asm 1: eor >lotmp=int32#12,<lotmp=int32#12,<hiu0=int32#7,LSL #4 # asm 2: eor >lotmp=r11,<lotmp=r11,<hiu0=r6,LSL #4 eor r11,r11,r6,LSL #4 # qhasm: hitmp ^= (lou0 unsigned>> 2) # asm 1: eor >hitmp=int32#13,<hitmp=int32#13,<lou0=int32#6,LSR #2 # asm 2: eor >hitmp=r12,<hitmp=r12,<lou0=r5,LSR #2 eor r12,r12,r5,LSR #2 # qhasm: hitmp ^= (hiu0 << 30) # asm 1: eor >hitmp=int32#13,<hitmp=int32#13,<hiu0=int32#7,LSL #30 # asm 2: eor >hitmp=r12,<hitmp=r12,<hiu0=r6,LSL #30 eor r12,r12,r6,LSL #30 # qhasm: hitmp ^= (hiu0 unsigned>> 28) # asm 1: eor >hitmp=int32#13,<hitmp=int32#13,<hiu0=int32#7,LSR #28 # asm 2: eor >hitmp=r12,<hitmp=r12,<hiu0=r6,LSR #28 eor r12,r12,r6,LSR #28 # qhasm: hitmp ^= (lou0 << 4) # asm 1: eor >hitmp=int32#13,<hitmp=int32#13,<lou0=int32#6,LSL #4 # asm 2: eor >hitmp=r12,<hitmp=r12,<lou0=r5,LSL #4 eor r12,r12,r5,LSL #4 # qhasm: carry? lou4 += lotmp # asm 1: adds >lou4=int32#2,<lou4=int32#2,<lotmp=int32#12 # asm 2: adds >lou4=r1,<lou4=r1,<lotmp=r11 adds r1,r1,r11 # qhasm: hiu4 += hitmp + carry # asm 1: adc >hiu4=int32#3,<hiu4=int32#3,<hitmp=int32#13 # asm 2: adc >hiu4=r2,<hiu4=r2,<hitmp=r12 adc r2,r2,r12 # qhasm: lotmp = lou1 ^ lou3 # asm 1: eor >lotmp=int32#12,<lou1=int32#8,<lou3=int32#10 # asm 2: eor >lotmp=r11,<lou1=r7,<lou3=r9 eor r11,r7,r9 # qhasm: lotmp &= lou0 # asm 1: and >lotmp=int32#6,<lotmp=int32#12,<lou0=int32#6 # asm 2: and >lotmp=r5,<lotmp=r11,<lou0=r5 and r5,r11,r5 # qhasm: lotmp2 = lou1 & lou3 # asm 1: and >lotmp2=int32#8,<lou1=int32#8,<lou3=int32#10 # asm 2: and >lotmp2=r7,<lou1=r7,<lou3=r9 and r7,r7,r9 # qhasm: lotmp ^= lotmp2 # asm 1: eor >lotmp=int32#6,<lotmp=int32#6,<lotmp2=int32#8 # asm 2: eor >lotmp=r5,<lotmp=r5,<lotmp2=r7 eor r5,r5,r7 # qhasm: carry? lou4 += lotmp # asm 1: adds >lou4=int32#2,<lou4=int32#2,<lotmp=int32#6 # asm 2: adds >lou4=r1,<lou4=r1,<lotmp=r5 adds r1,r1,r5 # qhasm: hitmp = hiu1 ^ hiu3 # asm 1: eor >hitmp=int32#6,<hiu1=int32#9,<hiu3=int32#11 # asm 2: eor >hitmp=r5,<hiu1=r8,<hiu3=r10 eor r5,r8,r10 # qhasm: hitmp &= hiu0 # asm 1: and >hitmp=int32#6,<hitmp=int32#6,<hiu0=int32#7 # asm 2: and >hitmp=r5,<hitmp=r5,<hiu0=r6 and r5,r5,r6 # qhasm: hitmp2 = hiu1 & hiu3 # asm 1: and >hitmp2=int32#7,<hiu1=int32#9,<hiu3=int32#11 # asm 2: and >hitmp2=r6,<hiu1=r8,<hiu3=r10 and r6,r8,r10 # qhasm: hitmp ^= hitmp2 # asm 1: eor >hitmp=int32#6,<hitmp=int32#6,<hitmp2=int32#7 # asm 2: eor >hitmp=r5,<hitmp=r5,<hitmp2=r6 eor r5,r5,r6 # qhasm: hiu4 += hitmp + carry # asm 1: adc >hiu4=int32#3,<hiu4=int32#3,<hitmp=int32#6 # asm 2: adc >hiu4=r2,<hiu4=r2,<hitmp=r5 adc r2,r2,r5 # qhasm: lod1 = lou4 # asm 1: vmov >lod1=float32#3,<lou4=int32#2 # asm 2: vmov >lod1=s2,<lou4=r1 # copy-collector input: vmov s2,r1 # qhasm: hid1 = hiu4 # asm 1: vmov >hid1=float32#4,<hiu4=int32#3 # asm 2: vmov >hid1=s3,<hiu4=r2 # copy-collector input: vmov s3,r2 # qhasm: lou0 = lod6 # asm 1: vmov >lou0=int32#2,<lod6=float32#13 # asm 2: vmov >lou0=r1,<lod6=s12 # copy-collector input: vmov r1,s12 # qhasm: hiu0 = hid6 # asm 1: vmov >hiu0=int32#3,<hid6=float32#14 # asm 2: vmov >hiu0=r2,<hid6=s13 # copy-collector input: vmov r2,s13 # qhasm: lou1 = lod7 # asm 1: vmov >lou1=int32#6,<lod7=float32#15 # asm 2: vmov >lou1=r5,<lod7=s14 # copy-collector input: vmov r5,s14 # qhasm: hiu1 = hid7 # asm 1: vmov >hiu1=int32#7,<hid7=float32#16 # asm 2: vmov >hiu1=r6,<hid7=s15 # copy-collector input: vmov r6,s15 # qhasm: lou4 = lod0 # asm 1: vmov >lou4=int32#8,<lod0=float32#1 # asm 2: vmov >lou4=r7,<lod0=s0 # copy-collector input: vmov r7,s0 # qhasm: hiu4 = hid0 # asm 1: vmov >hiu4=int32#9,<hid0=float32#2 # asm 2: vmov >hiu4=r8,<hid0=s1 # copy-collector input: vmov r8,s1 # qhasm: lou5 = lod15 # asm 1: vmov >lou5=int32#12,<lod15=float32#31 # asm 2: vmov >lou5=r11,<lod15=s30 # copy-collector input: vmov r11,s30 # qhasm: hiu5 = hid15 # asm 1: vmov >hiu5=int32#13,<hid15=float32#32 # asm 2: vmov >hiu5=r12,<hid15=s31 # copy-collector input: vmov r12,s31 # qhasm: two23 = 0x800000 simple # asm 1: mov >two23=int32#14,0x800000 # asm 2: mov >two23=r14,0x800000 # copy-collector output starts vmov d1,r1,r2 vmov r1,r2,d6 vmov r5,r6,d7 vmov r7,r8,d0 vmov r11,r12,d15 # copy-collector output ends mov r14,0x800000 # qhasm: carry? lou4 += lou5 # asm 1: adds >lou4=int32#8,<lou4=int32#8,<lou5=int32#12 # asm 2: adds >lou4=r7,<lou4=r7,<lou5=r11 adds r7,r7,r11 # qhasm: hiu4 += hiu5 + carry # asm 1: adc >hiu4=int32#9,<hiu4=int32#9,<hiu5=int32#13 # asm 2: adc >hiu4=r8,<hiu4=r8,<hiu5=r12 adc r8,r8,r12 # qhasm: lotmp = mem32[input_0]; input_0 += 4 # asm 1: ldr >lotmp=int32#12,[<input_0=int32#1],#4 # asm 2: ldr >lotmp=r11,[<input_0=r0],#4 # copy-collector input: ldr r11,[r0],#4 # qhasm: hitmp = mem32[input_0]; input_0 += 4 # asm 1: ldr >hitmp=int32#13,[<input_0=int32#1],#4 # asm 2: ldr >hitmp=r12,[<input_0=r0],#4 # copy-collector input: ldr r12,[r0],#4 # qhasm: carry? lou4 += lotmp # asm 1: adds >lou4=int32#8,<lou4=int32#8,<lotmp=int32#12 # asm 2: adds >lou4=r7,<lou4=r7,<lotmp=r11 # copy-collector output starts ldr r11,[r0],#4 ldr r12,[r0],#4 # copy-collector output ends adds r7,r7,r11 # qhasm: hiu4 += hitmp + carry # asm 1: adc >hiu4=int32#9,<hiu4=int32#9,<hitmp=int32#13 # asm 2: adc >hiu4=r8,<hiu4=r8,<hitmp=r12 adc r8,r8,r12 # qhasm: hitmp lotmp = lou2 * two23 # asm 1: umull >lotmp=int32#13,>hitmp=int32#12,<lou2=int32#4,<two23=int32#14 # asm 2: umull >lotmp=r12,>hitmp=r11,<lou2=r3,<two23=r14 umull r12,r11,r3,r14 # qhasm: lotmp hitmp += hiu2 * two23 # asm 1: umlal <hitmp=int32#12,<lotmp=int32#13,<hiu2=int32#5,<two23=int32#14 # asm 2: umlal <hitmp=r11,<lotmp=r12,<hiu2=r4,<two23=r14 umlal r11,r12,r4,r14 # qhasm: lotmp ^= (lou2 unsigned>> 18) # asm 1: eor >lotmp=int32#13,<lotmp=int32#13,<lou2=int32#4,LSR #18 # asm 2: eor >lotmp=r12,<lotmp=r12,<lou2=r3,LSR #18 eor r12,r12,r3,LSR #18 # qhasm: lotmp ^= (hiu2 << 14) # asm 1: eor >lotmp=int32#13,<lotmp=int32#13,<hiu2=int32#5,LSL #14 # asm 2: eor >lotmp=r12,<lotmp=r12,<hiu2=r4,LSL #14 eor r12,r12,r4,LSL #14 # qhasm: lotmp ^= (lou2 unsigned>> 14) # asm 1: eor >lotmp=int32#13,<lotmp=int32#13,<lou2=int32#4,LSR #14 # asm 2: eor >lotmp=r12,<lotmp=r12,<lou2=r3,LSR #14 eor r12,r12,r3,LSR #14 # qhasm: lotmp ^= (hiu2 << 18) # asm 1: eor >lotmp=int32#13,<lotmp=int32#13,<hiu2=int32#5,LSL #18 # asm 2: eor >lotmp=r12,<lotmp=r12,<hiu2=r4,LSL #18 eor r12,r12,r4,LSL #18 # qhasm: hitmp ^= (hiu2 unsigned>> 18) # asm 1: eor >hitmp=int32#12,<hitmp=int32#12,<hiu2=int32#5,LSR #18 # asm 2: eor >hitmp=r11,<hitmp=r11,<hiu2=r4,LSR #18 eor r11,r11,r4,LSR #18 # qhasm: hitmp ^= (lou2 << 14) # asm 1: eor >hitmp=int32#12,<hitmp=int32#12,<lou2=int32#4,LSL #14 # asm 2: eor >hitmp=r11,<hitmp=r11,<lou2=r3,LSL #14 eor r11,r11,r3,LSL #14 # qhasm: hitmp ^= (hiu2 unsigned>> 14) # asm 1: eor >hitmp=int32#12,<hitmp=int32#12,<hiu2=int32#5,LSR #14 # asm 2: eor >hitmp=r11,<hitmp=r11,<hiu2=r4,LSR #14 eor r11,r11,r4,LSR #14 # qhasm: hitmp ^= (lou2 << 18) # asm 1: eor >hitmp=int32#12,<hitmp=int32#12,<lou2=int32#4,LSL #18 # asm 2: eor >hitmp=r11,<hitmp=r11,<lou2=r3,LSL #18 eor r11,r11,r3,LSL #18 # qhasm: carry? lou4 += lotmp # asm 1: adds >lou4=int32#8,<lou4=int32#8,<lotmp=int32#13 # asm 2: adds >lou4=r7,<lou4=r7,<lotmp=r12 adds r7,r7,r12 # qhasm: hiu4 += hitmp + carry # asm 1: adc >hiu4=int32#9,<hiu4=int32#9,<hitmp=int32#12 # asm 2: adc >hiu4=r8,<hiu4=r8,<hitmp=r11 adc r8,r8,r11 # qhasm: lotmp = lou2 & lou0 # asm 1: and >lotmp=int32#2,<lou2=int32#4,<lou0=int32#2 # asm 2: and >lotmp=r1,<lou2=r3,<lou0=r1 and r1,r3,r1 # qhasm: lotmp2 = lou1 & ~lou2 # asm 1: bic >lotmp2=int32#4,<lou1=int32#6,<lou2=int32#4 # asm 2: bic >lotmp2=r3,<lou1=r5,<lou2=r3 bic r3,r5,r3 # qhasm: lotmp ^= lotmp2 # asm 1: eor >lotmp=int32#2,<lotmp=int32#2,<lotmp2=int32#4 # asm 2: eor >lotmp=r1,<lotmp=r1,<lotmp2=r3 eor r1,r1,r3 # qhasm: carry? lou4 += lotmp # asm 1: adds >lou4=int32#2,<lou4=int32#8,<lotmp=int32#2 # asm 2: adds >lou4=r1,<lou4=r7,<lotmp=r1 adds r1,r7,r1 # qhasm: hitmp = hiu2 & hiu0 # asm 1: and >hitmp=int32#3,<hiu2=int32#5,<hiu0=int32#3 # asm 2: and >hitmp=r2,<hiu2=r4,<hiu0=r2 and r2,r4,r2 # qhasm: hitmp2 = hiu1 & ~hiu2 # asm 1: bic >hitmp2=int32#4,<hiu1=int32#7,<hiu2=int32#5 # asm 2: bic >hitmp2=r3,<hiu1=r6,<hiu2=r4 bic r3,r6,r4 # qhasm: hitmp ^= hitmp2 # asm 1: eor >hitmp=int32#3,<hitmp=int32#3,<hitmp2=int32#4 # asm 2: eor >hitmp=r2,<hitmp=r2,<hitmp2=r3 eor r2,r2,r3 # qhasm: hiu4 += hitmp + carry # asm 1: adc >hiu4=int32#3,<hiu4=int32#9,<hitmp=int32#3 # asm 2: adc >hiu4=r2,<hiu4=r8,<hitmp=r2 adc r2,r8,r2 # qhasm: carry? lou3 += lou4 # asm 1: adds >lou3=int32#4,<lou3=int32#10,<lou4=int32#2 # asm 2: adds >lou3=r3,<lou3=r9,<lou4=r1 adds r3,r9,r1 # qhasm: hiu3 += hiu4 + carry # asm 1: adc >hiu3=int32#5,<hiu3=int32#11,<hiu4=int32#3 # asm 2: adc >hiu3=r4,<hiu3=r10,<hiu4=r2 adc r4,r10,r2 # qhasm: lod4 = lou3 # asm 1: vmov >lod4=float32#9,<lou3=int32#4 # asm 2: vmov >lod4=s8,<lou3=r3 # copy-collector input: vmov s8,r3 # qhasm: hid4 = hiu3 # asm 1: vmov >hid4=float32#10,<hiu3=int32#5 # asm 2: vmov >hid4=s9,<hiu3=r4 # copy-collector input: vmov s9,r4 # qhasm: lou0 = lod1 # asm 1: vmov >lou0=int32#4,<lod1=float32#3 # asm 2: vmov >lou0=r3,<lod1=s2 # copy-collector input: vmov r3,s2 # qhasm: hiu0 = hid1 # asm 1: vmov >hiu0=int32#5,<hid1=float32#4 # asm 2: vmov >hiu0=r4,<hid1=s3 # copy-collector input: vmov r4,s3 # qhasm: lou1 = lod2 # asm 1: vmov >lou1=int32#6,<lod2=float32#5 # asm 2: vmov >lou1=r5,<lod2=s4 # copy-collector input: vmov r5,s4 # qhasm: hiu1 = hid2 # asm 1: vmov >hiu1=int32#7,<hid2=float32#6 # asm 2: vmov >hiu1=r6,<hid2=s5 # copy-collector input: vmov r6,s5 # qhasm: lou2 = lod3 # asm 1: vmov >lou2=int32#8,<lod3=float32#7 # asm 2: vmov >lou2=r7,<lod3=s6 # copy-collector input: vmov r7,s6 # qhasm: hiu2 = hid3 # asm 1: vmov >hiu2=int32#9,<hid3=float32#8 # asm 2: vmov >hiu2=r8,<hid3=s7 # copy-collector input: vmov r8,s7 # qhasm: two25 = 0x2000000 simple # asm 1: mov >two25=int32#10,0x2000000 # asm 2: mov >two25=r9,0x2000000 # copy-collector output starts vmov d4,r3,r4 vmov r3,r4,d1 vmov r5,r6,d2 vmov r7,r8,d3 # copy-collector output ends mov r9,0x2000000 # qhasm: hitmp lotmp = lou0 * two25 # asm 1: umull >lotmp=int32#12,>hitmp=int32#11,<lou0=int32#4,<two25=int32#10 # asm 2: umull >lotmp=r11,>hitmp=r10,<lou0=r3,<two25=r9 umull r11,r10,r3,r9 # qhasm: lotmp hitmp += hiu0 * two25 # asm 1: umlal <hitmp=int32#11,<lotmp=int32#12,<hiu0=int32#5,<two25=int32#10 # asm 2: umlal <hitmp=r10,<lotmp=r11,<hiu0=r4,<two25=r9 umlal r10,r11,r4,r9 # qhasm: lotmp ^= (hiu0 unsigned>> 2) # asm 1: eor >lotmp=int32#10,<lotmp=int32#12,<hiu0=int32#5,LSR #2 # asm 2: eor >lotmp=r9,<lotmp=r11,<hiu0=r4,LSR #2 eor r9,r11,r4,LSR #2 # qhasm: lotmp ^= (lou0 << 30) # asm 1: eor >lotmp=int32#10,<lotmp=int32#10,<lou0=int32#4,LSL #30 # asm 2: eor >lotmp=r9,<lotmp=r9,<lou0=r3,LSL #30 eor r9,r9,r3,LSL #30 # qhasm: lotmp ^= (lou0 unsigned>> 28) # asm 1: eor >lotmp=int32#10,<lotmp=int32#10,<lou0=int32#4,LSR #28 # asm 2: eor >lotmp=r9,<lotmp=r9,<lou0=r3,LSR #28 eor r9,r9,r3,LSR #28 # qhasm: lotmp ^= (hiu0 << 4) # asm 1: eor >lotmp=int32#10,<lotmp=int32#10,<hiu0=int32#5,LSL #4 # asm 2: eor >lotmp=r9,<lotmp=r9,<hiu0=r4,LSL #4 eor r9,r9,r4,LSL #4 # qhasm: hitmp ^= (lou0 unsigned>> 2) # asm 1: eor >hitmp=int32#11,<hitmp=int32#11,<lou0=int32#4,LSR #2 # asm 2: eor >hitmp=r10,<hitmp=r10,<lou0=r3,LSR #2 eor r10,r10,r3,LSR #2 # qhasm: hitmp ^= (hiu0 << 30) # asm 1: eor >hitmp=int32#11,<hitmp=int32#11,<hiu0=int32#5,LSL #30 # asm 2: eor >hitmp=r10,<hitmp=r10,<hiu0=r4,LSL #30 eor r10,r10,r4,LSL #30 # qhasm: hitmp ^= (hiu0 unsigned>> 28) # asm 1: eor >hitmp=int32#11,<hitmp=int32#11,<hiu0=int32#5,LSR #28 # asm 2: eor >hitmp=r10,<hitmp=r10,<hiu0=r4,LSR #28 eor r10,r10,r4,LSR #28 # qhasm: hitmp ^= (lou0 << 4) # asm 1: eor >hitmp=int32#11,<hitmp=int32#11,<lou0=int32#4,LSL #4 # asm 2: eor >hitmp=r10,<hitmp=r10,<lou0=r3,LSL #4 eor r10,r10,r3,LSL #4 # qhasm: carry? lou4 += lotmp # asm 1: adds >lou4=int32#2,<lou4=int32#2,<lotmp=int32#10 # asm 2: adds >lou4=r1,<lou4=r1,<lotmp=r9 adds r1,r1,r9 # qhasm: hiu4 += hitmp + carry # asm 1: adc >hiu4=int32#3,<hiu4=int32#3,<hitmp=int32#11 # asm 2: adc >hiu4=r2,<hiu4=r2,<hitmp=r10 adc r2,r2,r10 # qhasm: lotmp = lou1 ^ lou2 # asm 1: eor >lotmp=int32#10,<lou1=int32#6,<lou2=int32#8 # asm 2: eor >lotmp=r9,<lou1=r5,<lou2=r7 eor r9,r5,r7 # qhasm: lotmp &= lou0 # asm 1: and >lotmp=int32#4,<lotmp=int32#10,<lou0=int32#4 # asm 2: and >lotmp=r3,<lotmp=r9,<lou0=r3 and r3,r9,r3 # qhasm: lotmp2 = lou1 & lou2 # asm 1: and >lotmp2=int32#6,<lou1=int32#6,<lou2=int32#8 # asm 2: and >lotmp2=r5,<lou1=r5,<lou2=r7 and r5,r5,r7 # qhasm: lotmp ^= lotmp2 # asm 1: eor >lotmp=int32#4,<lotmp=int32#4,<lotmp2=int32#6 # asm 2: eor >lotmp=r3,<lotmp=r3,<lotmp2=r5 eor r3,r3,r5 # qhasm: carry? lou4 += lotmp # asm 1: adds >lou4=int32#2,<lou4=int32#2,<lotmp=int32#4 # asm 2: adds >lou4=r1,<lou4=r1,<lotmp=r3 adds r1,r1,r3 # qhasm: hitmp = hiu1 ^ hiu2 # asm 1: eor >hitmp=int32#4,<hiu1=int32#7,<hiu2=int32#9 # asm 2: eor >hitmp=r3,<hiu1=r6,<hiu2=r8 eor r3,r6,r8 # qhasm: hitmp &= hiu0 # asm 1: and >hitmp=int32#4,<hitmp=int32#4,<hiu0=int32#5 # asm 2: and >hitmp=r3,<hitmp=r3,<hiu0=r4 and r3,r3,r4 # qhasm: hitmp2 = hiu1 & hiu2 # asm 1: and >hitmp2=int32#5,<hiu1=int32#7,<hiu2=int32#9 # asm 2: and >hitmp2=r4,<hiu1=r6,<hiu2=r8 and r4,r6,r8 # qhasm: hitmp ^= hitmp2 # asm 1: eor >hitmp=int32#4,<hitmp=int32#4,<hitmp2=int32#5 # asm 2: eor >hitmp=r3,<hitmp=r3,<hitmp2=r4 eor r3,r3,r4 # qhasm: hiu4 += hitmp + carry # asm 1: adc >hiu4=int32#3,<hiu4=int32#3,<hitmp=int32#4 # asm 2: adc >hiu4=r2,<hiu4=r2,<hitmp=r3 adc r2,r2,r3 # qhasm: lod0 = lou4 # asm 1: vmov >lod0=float32#1,<lou4=int32#2 # asm 2: vmov >lod0=s0,<lou4=r1 # copy-collector input: vmov s0,r1 # qhasm: hid0 = hiu4 # asm 1: vmov >hid0=float32#2,<hiu4=int32#3 # asm 2: vmov >hid0=s1,<hiu4=r2 # copy-collector input: vmov s1,r2 # qhasm: o3 = input_0 # asm 1: str <input_0=int32#1,>o3=stack32#4 # asm 2: str <input_0=r0,>o3=[sp,#12] # copy-collector input: str r0,[sp,#12] # qhasm: assign 16 to lod8 # qhasm: assign 17 to hid8 # qhasm: assign 18 to lod9 # qhasm: assign 19 to hid9 # qhasm: assign 20 to lod10 # qhasm: assign 21 to hid10 # qhasm: assign 22 to lod11 # qhasm: assign 23 to hid11 # qhasm: assign 24 to lod12 # qhasm: assign 25 to hid12 # qhasm: assign 26 to lod13 # qhasm: assign 27 to hid13 # qhasm: assign 28 to lod14 # qhasm: assign 29 to hid14 # qhasm: assign 30 to lod15 # qhasm: assign 31 to hid15 # qhasm: input_0 = o4 # asm 1: ldr >input_0=int32#1,<o4=stack32#37 # asm 2: ldr >input_0=r0,<o4=[sp,#144] # copy-collector input: ldr r0,[sp,#144] # qhasm: =? unsigned<? input_0 -= 8 # asm 1: subs >input_0=int32#1,<input_0=int32#1,#8 # asm 2: subs >input_0=r0,<input_0=r0,#8 # copy-collector output starts vmov d0,r1,r2 str r0,[sp,#12] ldr r0,[sp,#144] # copy-collector output ends subs r0,r0,#8 # qhasm: goto endinnerloop if = beq ._endinnerloop # qhasm: o4 = input_0 # asm 1: str <input_0=int32#1,>o4=stack32#37 # asm 2: str <input_0=r0,>o4=[sp,#144] # copy-collector input: str r0,[sp,#144] # qhasm: =? input_0 - 8 # asm 1: cmp <input_0=int32#1,#8 # asm 2: cmp <input_0=r0,#8 # copy-collector output starts str r0,[sp,#144] # copy-collector output ends cmp r0,#8 # qhasm: goto nearend if = beq ._nearend # qhasm: two24 = 0x1000000 simple # asm 1: mov >two24=int32#1,0x1000000 # asm 2: mov >two24=r0,0x1000000 mov r0,0x1000000 # qhasm: two13 = 0x2000 simple # asm 1: mov >two13=int32#2,0x2000 # asm 2: mov >two13=r1,0x2000 mov r1,0x2000 # qhasm: lou0 = lod8 # asm 1: vmov >lou0=int32#3,<lod8=float32#17 # asm 2: vmov >lou0=r2,<lod8=s16 # copy-collector input: vmov r2,s16 # qhasm: hiu0 = hid8 # asm 1: vmov >hiu0=int32#4,<hid8=float32#18 # asm 2: vmov >hiu0=r3,<hid8=s17 # copy-collector input: vmov r3,s17 # qhasm: lou1 = lod9 # asm 1: vmov >lou1=int32#5,<lod9=float32#19 # asm 2: vmov >lou1=r4,<lod9=s18 # copy-collector input: vmov r4,s18 # qhasm: hiu1 = hid9 # asm 1: vmov >hiu1=int32#6,<hid9=float32#20 # asm 2: vmov >hiu1=r5,<hid9=s19 # copy-collector input: vmov r5,s19 # qhasm: lou2 = lom14 # asm 1: ldr >lou2=int32#7,<lom14=stack32#33 # asm 2: ldr >lou2=r6,<lom14=[sp,#128] # copy-collector input: ldr r6,[sp,#128] # qhasm: hiu2 = him14 # asm 1: ldr >hiu2=int32#8,<him14=stack32#34 # asm 2: ldr >hiu2=r7,<him14=[sp,#132] # copy-collector input: ldr r7,[sp,#132] # qhasm: lou3 = lom9 # asm 1: ldr >lou3=int32#9,<lom9=stack32#23 # asm 2: ldr >lou3=r8,<lom9=[sp,#88] # copy-collector input: ldr r8,[sp,#88] # qhasm: hiu3 = him9 # asm 1: ldr >hiu3=int32#10,<him9=stack32#24 # asm 2: ldr >hiu3=r9,<him9=[sp,#92] # copy-collector input: ldr r9,[sp,#92] # qhasm: hitmp lotmp = hiu2 * two13 # asm 1: umull >lotmp=int32#12,>hitmp=int32#11,<hiu2=int32#8,<two13=int32#2 # asm 2: umull >lotmp=r11,>hitmp=r10,<hiu2=r7,<two13=r1 # copy-collector output starts vmov r2,r3,d8 vmov r4,r5,d9 ldr r6,[sp,#128] ldr.w r7,[sp,#132] ldr r8,[sp,#88] ldr r9,[sp,#92] # copy-collector output ends umull r11,r10,r7,r1 # qhasm: lotmp hitmp += lou2 * two13 # asm 1: umlal <hitmp=int32#11,<lotmp=int32#12,<lou2=int32#7,<two13=int32#2 # asm 2: umlal <hitmp=r10,<lotmp=r11,<lou2=r6,<two13=r1 umlal r10,r11,r6,r1 # qhasm: lotmp ^= (lou2 unsigned>> 6) # asm 1: eor >lotmp=int32#12,<lotmp=int32#12,<lou2=int32#7,LSR #6 # asm 2: eor >lotmp=r11,<lotmp=r11,<lou2=r6,LSR #6 eor r11,r11,r6,LSR #6 # qhasm: lotmp ^= (hiu2 << 26) # asm 1: eor >lotmp=int32#12,<lotmp=int32#12,<hiu2=int32#8,LSL #26 # asm 2: eor >lotmp=r11,<lotmp=r11,<hiu2=r7,LSL #26 eor r11,r11,r7,LSL #26 # qhasm: lotmp ^= (hiu2 unsigned>> 29) # asm 1: eor >lotmp=int32#12,<lotmp=int32#12,<hiu2=int32#8,LSR #29 # asm 2: eor >lotmp=r11,<lotmp=r11,<hiu2=r7,LSR #29 eor r11,r11,r7,LSR #29 # qhasm: lotmp ^= (lou2 << 3) # asm 1: eor >lotmp=int32#12,<lotmp=int32#12,<lou2=int32#7,LSL #3 # asm 2: eor >lotmp=r11,<lotmp=r11,<lou2=r6,LSL #3 eor r11,r11,r6,LSL #3 # qhasm: hitmp ^= (hiu2 unsigned>> 6) # asm 1: eor >hitmp=int32#11,<hitmp=int32#11,<hiu2=int32#8,LSR #6 # asm 2: eor >hitmp=r10,<hitmp=r10,<hiu2=r7,LSR #6 eor r10,r10,r7,LSR #6 # qhasm: hitmp ^= (lou2 unsigned>> 29) # asm 1: eor >hitmp=int32#11,<hitmp=int32#11,<lou2=int32#7,LSR #29 # asm 2: eor >hitmp=r10,<hitmp=r10,<lou2=r6,LSR #29 eor r10,r10,r6,LSR #29 # qhasm: hitmp ^= (hiu2 << 3) # asm 1: eor >hitmp=int32#11,<hitmp=int32#11,<hiu2=int32#8,LSL #3 # asm 2: eor >hitmp=r10,<hitmp=r10,<hiu2=r7,LSL #3 eor r10,r10,r7,LSL #3 # qhasm: carry? lou0 += lotmp # asm 1: adds >lou0=int32#3,<lou0=int32#3,<lotmp=int32#12 # asm 2: adds >lou0=r2,<lou0=r2,<lotmp=r11 adds r2,r2,r11 # qhasm: hiu0 += hitmp + carry # asm 1: adc >hiu0=int32#4,<hiu0=int32#4,<hitmp=int32#11 # asm 2: adc >hiu0=r3,<hiu0=r3,<hitmp=r10 adc r3,r3,r10 # qhasm: hitmp lotmp = hiu1 * two24 # asm 1: umull >lotmp=int32#12,>hitmp=int32#11,<hiu1=int32#6,<two24=int32#1 # asm 2: umull >lotmp=r11,>hitmp=r10,<hiu1=r5,<two24=r0 umull r11,r10,r5,r0 # qhasm: lotmp hitmp += lou1 * two24 # asm 1: umlal <hitmp=int32#11,<lotmp=int32#12,<lou1=int32#5,<two24=int32#1 # asm 2: umlal <hitmp=r10,<lotmp=r11,<lou1=r4,<two24=r0 umlal r10,r11,r4,r0 # qhasm: carry? lotmp ^= (lou1 unsigned>> 1) # asm 1: eors >lotmp=int32#12,<lotmp=int32#12,<lou1=int32#5,LSR #1 # asm 2: eors >lotmp=r11,<lotmp=r11,<lou1=r4,LSR #1 eors r11,r11,r4,LSR #1 # qhasm: hitmp ^= (carry,hiu1 unsigned>> 1) # asm 1: eors >hitmp=int32#11,<hitmp=int32#11,<hiu1=int32#6,RRX # asm 2: eors >hitmp=r10,<hitmp=r10,<hiu1=r5,RRX eors r10,r10,r5,RRX # qhasm: lotmp ^= (hiu1 << 31) # asm 1: eor >lotmp=int32#12,<lotmp=int32#12,<hiu1=int32#6,LSL #31 # asm 2: eor >lotmp=r11,<lotmp=r11,<hiu1=r5,LSL #31 eor r11,r11,r5,LSL #31 # qhasm: lotmp ^= (lou1 unsigned>>7) # asm 1: eor >lotmp=int32#12,<lotmp=int32#12,<lou1=int32#5,LSR #7 # asm 2: eor >lotmp=r11,<lotmp=r11,<lou1=r4,LSR #7 eor r11,r11,r4,LSR #7 # qhasm: lotmp ^= (hiu1 << 25) # asm 1: eor >lotmp=int32#12,<lotmp=int32#12,<hiu1=int32#6,LSL #25 # asm 2: eor >lotmp=r11,<lotmp=r11,<hiu1=r5,LSL #25 eor r11,r11,r5,LSL #25 # qhasm: hitmp ^= (hiu1 unsigned>>7) # asm 1: eor >hitmp=int32#11,<hitmp=int32#11,<hiu1=int32#6,LSR #7 # asm 2: eor >hitmp=r10,<hitmp=r10,<hiu1=r5,LSR #7 eor r10,r10,r5,LSR #7 # qhasm: carry? lou0 += lotmp # asm 1: adds >lou0=int32#3,<lou0=int32#3,<lotmp=int32#12 # asm 2: adds >lou0=r2,<lou0=r2,<lotmp=r11 adds r2,r2,r11 # qhasm: hiu0 += hitmp + carry # asm 1: adc >hiu0=int32#4,<hiu0=int32#4,<hitmp=int32#11 # asm 2: adc >hiu0=r3,<hiu0=r3,<hitmp=r10 adc r3,r3,r10 # qhasm: carry? lou0 += lou3 # asm 1: adds >lou0=int32#3,<lou0=int32#3,<lou3=int32#9 # asm 2: adds >lou0=r2,<lou0=r2,<lou3=r8 adds r2,r2,r8 # qhasm: hiu0 += hiu3 + carry # asm 1: adc >hiu0=int32#4,<hiu0=int32#4,<hiu3=int32#10 # asm 2: adc >hiu0=r3,<hiu0=r3,<hiu3=r9 adc r3,r3,r9 # qhasm: lod9 = lou3 # asm 1: vmov >lod9=float32#19,<lou3=int32#9 # asm 2: vmov >lod9=s18,<lou3=r8 # copy-collector input: vmov s18,r8 # qhasm: hid9 = hiu3 # asm 1: vmov >hid9=float32#20,<hiu3=int32#10 # asm 2: vmov >hid9=s19,<hiu3=r9 # copy-collector input: vmov s19,r9 # qhasm: lou3 = lom15 # asm 1: ldr >lou3=int32#9,<lom15=stack32#35 # asm 2: ldr >lou3=r8,<lom15=[sp,#136] # copy-collector input: ldr r8,[sp,#136] # qhasm: hiu3 = him15 # asm 1: ldr >hiu3=int32#10,<him15=stack32#36 # asm 2: ldr >hiu3=r9,<him15=[sp,#140] # copy-collector input: ldr r9,[sp,#140] # qhasm: lom15 = lou0 # asm 1: str <lou0=int32#3,>lom15=stack32#35 # asm 2: str <lou0=r2,>lom15=[sp,#136] # copy-collector input: str r2,[sp,#136] # qhasm: him15 = hiu0 # asm 1: str <hiu0=int32#4,>him15=stack32#36 # asm 2: str <hiu0=r3,>him15=[sp,#140] # copy-collector input: str r3,[sp,#140] # qhasm: hitmp lotmp = hiu3 * two13 # asm 1: umull >lotmp=int32#12,>hitmp=int32#11,<hiu3=int32#10,<two13=int32#2 # asm 2: umull >lotmp=r11,>hitmp=r10,<hiu3=r9,<two13=r1 # copy-collector output starts vmov d9,r8,r9 ldrd r8,r9,[sp,#136] strd r2,r3,[sp,#136] # copy-collector output ends umull r11,r10,r9,r1 # qhasm: lotmp hitmp += lou3 * two13 # asm 1: umlal <hitmp=int32#11,<lotmp=int32#12,<lou3=int32#9,<two13=int32#2 # asm 2: umlal <hitmp=r10,<lotmp=r11,<lou3=r8,<two13=r1 umlal r10,r11,r8,r1 # qhasm: lotmp ^= (lou3 unsigned>> 6) # asm 1: eor >lotmp=int32#12,<lotmp=int32#12,<lou3=int32#9,LSR #6 # asm 2: eor >lotmp=r11,<lotmp=r11,<lou3=r8,LSR #6 eor r11,r11,r8,LSR #6 # qhasm: lotmp ^= (hiu3 << 26) # asm 1: eor >lotmp=int32#12,<lotmp=int32#12,<hiu3=int32#10,LSL #26 # asm 2: eor >lotmp=r11,<lotmp=r11,<hiu3=r9,LSL #26 eor r11,r11,r9,LSL #26 # qhasm: lotmp ^= (hiu3 unsigned>> 29) # asm 1: eor >lotmp=int32#12,<lotmp=int32#12,<hiu3=int32#10,LSR #29 # asm 2: eor >lotmp=r11,<lotmp=r11,<hiu3=r9,LSR #29 eor r11,r11,r9,LSR #29 # qhasm: lotmp ^= (lou3 << 3) # asm 1: eor >lotmp=int32#12,<lotmp=int32#12,<lou3=int32#9,LSL #3 # asm 2: eor >lotmp=r11,<lotmp=r11,<lou3=r8,LSL #3 eor r11,r11,r8,LSL #3 # qhasm: hitmp ^= (hiu3 unsigned>> 6) # asm 1: eor >hitmp=int32#11,<hitmp=int32#11,<hiu3=int32#10,LSR #6 # asm 2: eor >hitmp=r10,<hitmp=r10,<hiu3=r9,LSR #6 eor r10,r10,r9,LSR #6 # qhasm: hitmp ^= (lou3 unsigned>> 29) # asm 1: eor >hitmp=int32#11,<hitmp=int32#11,<lou3=int32#9,LSR #29 # asm 2: eor >hitmp=r10,<hitmp=r10,<lou3=r8,LSR #29 eor r10,r10,r8,LSR #29 # qhasm: hitmp ^= (hiu3 << 3) # asm 1: eor >hitmp=int32#11,<hitmp=int32#11,<hiu3=int32#10,LSL #3 # asm 2: eor >hitmp=r10,<hitmp=r10,<hiu3=r9,LSL #3 eor r10,r10,r9,LSL #3 # qhasm: carry? lou1 += lotmp # asm 1: adds >lou1=int32#5,<lou1=int32#5,<lotmp=int32#12 # asm 2: adds >lou1=r4,<lou1=r4,<lotmp=r11 adds r4,r4,r11 # qhasm: hiu1 += hitmp + carry # asm 1: adc >hiu1=int32#6,<hiu1=int32#6,<hitmp=int32#11 # asm 2: adc >hiu1=r5,<hiu1=r5,<hitmp=r10 adc r5,r5,r10 # qhasm: lou4 = lod10 # asm 1: vmov >lou4=int32#11,<lod10=float32#21 # asm 2: vmov >lou4=r10,<lod10=s20 # copy-collector input: vmov r10,s20 # qhasm: hiu4 = hid10 # asm 1: vmov >hiu4=int32#12,<hid10=float32#22 # asm 2: vmov >hiu4=r11,<hid10=s21 # copy-collector input: vmov r11,s21 # qhasm: hitmp lotmp = hiu4 * two24 # asm 1: umull >lotmp=int32#14,>hitmp=int32#13,<hiu4=int32#12,<two24=int32#1 # asm 2: umull >lotmp=r14,>hitmp=r12,<hiu4=r11,<two24=r0 # copy-collector output starts vmov r10,r11,d10 # copy-collector output ends umull r14,r12,r11,r0 # qhasm: lotmp hitmp += lou4 * two24 # asm 1: umlal <hitmp=int32#13,<lotmp=int32#14,<lou4=int32#11,<two24=int32#1 # asm 2: umlal <hitmp=r12,<lotmp=r14,<lou4=r10,<two24=r0 umlal r12,r14,r10,r0 # qhasm: carry? lotmp ^= (lou4 unsigned>> 1) # asm 1: eors >lotmp=int32#14,<lotmp=int32#14,<lou4=int32#11,LSR #1 # asm 2: eors >lotmp=r14,<lotmp=r14,<lou4=r10,LSR #1 eors r14,r14,r10,LSR #1 # qhasm: hitmp ^= (carry,hiu4 unsigned>> 1) # asm 1: eors >hitmp=int32#13,<hitmp=int32#13,<hiu4=int32#12,RRX # asm 2: eors >hitmp=r12,<hitmp=r12,<hiu4=r11,RRX eors r12,r12,r11,RRX # qhasm: lotmp ^= (hiu4 << 31) # asm 1: eor >lotmp=int32#14,<lotmp=int32#14,<hiu4=int32#12,LSL #31 # asm 2: eor >lotmp=r14,<lotmp=r14,<hiu4=r11,LSL #31 eor r14,r14,r11,LSL #31 # qhasm: lotmp ^= (lou4 unsigned>>7) # asm 1: eor >lotmp=int32#14,<lotmp=int32#14,<lou4=int32#11,LSR #7 # asm 2: eor >lotmp=r14,<lotmp=r14,<lou4=r10,LSR #7 eor r14,r14,r10,LSR #7 # qhasm: lotmp ^= (hiu4 << 25) # asm 1: eor >lotmp=int32#14,<lotmp=int32#14,<hiu4=int32#12,LSL #25 # asm 2: eor >lotmp=r14,<lotmp=r14,<hiu4=r11,LSL #25 eor r14,r14,r11,LSL #25 # qhasm: hitmp ^= (hiu4 unsigned>>7) # asm 1: eor >hitmp=int32#13,<hitmp=int32#13,<hiu4=int32#12,LSR #7 # asm 2: eor >hitmp=r12,<hitmp=r12,<hiu4=r11,LSR #7 eor r12,r12,r11,LSR #7 # qhasm: carry? lou1 += lotmp # asm 1: adds >lou1=int32#5,<lou1=int32#5,<lotmp=int32#14 # asm 2: adds >lou1=r4,<lou1=r4,<lotmp=r14 adds r4,r4,r14 # qhasm: hiu1 += hitmp + carry # asm 1: adc >hiu1=int32#6,<hiu1=int32#6,<hitmp=int32#13 # asm 2: adc >hiu1=r5,<hiu1=r5,<hitmp=r12 adc r5,r5,r12 # qhasm: lou5 = lom10 # asm 1: ldr >lou5=int32#13,<lom10=stack32#25 # asm 2: ldr >lou5=r12,<lom10=[sp,#96] # copy-collector input: ldr r12,[sp,#96] # qhasm: hiu5 = him10 # asm 1: ldr >hiu5=int32#14,<him10=stack32#26 # asm 2: ldr >hiu5=r14,<him10=[sp,#100] # copy-collector input: ldr r14,[sp,#100] # qhasm: carry? lou1 += lou5 # asm 1: adds >lou1=int32#5,<lou1=int32#5,<lou5=int32#13 # asm 2: adds >lou1=r4,<lou1=r4,<lou5=r12 # copy-collector output starts ldrd r12,r14,[sp,#96] # copy-collector output ends adds r4,r4,r12 # qhasm: hiu1 += hiu5 + carry # asm 1: adc >hiu1=int32#6,<hiu1=int32#6,<hiu5=int32#14 # asm 2: adc >hiu1=r5,<hiu1=r5,<hiu5=r14 adc r5,r5,r14 # qhasm: lod10 = lou5 # asm 1: vmov >lod10=float32#21,<lou5=int32#13 # asm 2: vmov >lod10=s20,<lou5=r12 # copy-collector input: vmov s20,r12 # qhasm: hid10 = hiu5 # asm 1: vmov >hid10=float32#22,<hiu5=int32#14 # asm 2: vmov >hid10=s21,<hiu5=r14 # copy-collector input: vmov s21,r14 # qhasm: lom9 = lou1 # asm 1: str <lou1=int32#5,>lom9=stack32#23 # asm 2: str <lou1=r4,>lom9=[sp,#88] # copy-collector input: str r4,[sp,#88] # qhasm: him9 = hiu1 # asm 1: str <hiu1=int32#6,>him9=stack32#24 # asm 2: str <hiu1=r5,>him9=[sp,#92] # copy-collector input: str r5,[sp,#92] # qhasm: hitmp lotmp = hiu0 * two13 # asm 1: umull >lotmp=int32#14,>hitmp=int32#13,<hiu0=int32#4,<two13=int32#2 # asm 2: umull >lotmp=r14,>hitmp=r12,<hiu0=r3,<two13=r1 # copy-collector output starts vmov d10,r12,r14 strd r4,r5,[sp,#88] # copy-collector output ends umull r14,r12,r3,r1 # qhasm: lotmp hitmp += lou0 * two13 # asm 1: umlal <hitmp=int32#13,<lotmp=int32#14,<lou0=int32#3,<two13=int32#2 # asm 2: umlal <hitmp=r12,<lotmp=r14,<lou0=r2,<two13=r1 umlal r12,r14,r2,r1 # qhasm: lotmp ^= (lou0 unsigned>> 6) # asm 1: eor >lotmp=int32#14,<lotmp=int32#14,<lou0=int32#3,LSR #6 # asm 2: eor >lotmp=r14,<lotmp=r14,<lou0=r2,LSR #6 eor r14,r14,r2,LSR #6 # qhasm: lotmp ^= (hiu0 << 26) # asm 1: eor >lotmp=int32#14,<lotmp=int32#14,<hiu0=int32#4,LSL #26 # asm 2: eor >lotmp=r14,<lotmp=r14,<hiu0=r3,LSL #26 eor r14,r14,r3,LSL #26 # qhasm: lotmp ^= (hiu0 unsigned>> 29) # asm 1: eor >lotmp=int32#14,<lotmp=int32#14,<hiu0=int32#4,LSR #29 # asm 2: eor >lotmp=r14,<lotmp=r14,<hiu0=r3,LSR #29 eor r14,r14,r3,LSR #29 # qhasm: lotmp ^= (lou0 << 3) # asm 1: eor >lotmp=int32#14,<lotmp=int32#14,<lou0=int32#3,LSL #3 # asm 2: eor >lotmp=r14,<lotmp=r14,<lou0=r2,LSL #3 eor r14,r14,r2,LSL #3 # qhasm: hitmp ^= (hiu0 unsigned>> 6) # asm 1: eor >hitmp=int32#13,<hitmp=int32#13,<hiu0=int32#4,LSR #6 # asm 2: eor >hitmp=r12,<hitmp=r12,<hiu0=r3,LSR #6 eor r12,r12,r3,LSR #6 # qhasm: hitmp ^= (lou0 unsigned>> 29) # asm 1: eor >hitmp=int32#3,<hitmp=int32#13,<lou0=int32#3,LSR #29 # asm 2: eor >hitmp=r2,<hitmp=r12,<lou0=r2,LSR #29 eor r2,r12,r2,LSR #29 # qhasm: hitmp ^= (hiu0 << 3) # asm 1: eor >hitmp=int32#3,<hitmp=int32#3,<hiu0=int32#4,LSL #3 # asm 2: eor >hitmp=r2,<hitmp=r2,<hiu0=r3,LSL #3 eor r2,r2,r3,LSL #3 # qhasm: carry? lou4 += lotmp # asm 1: adds >lou4=int32#4,<lou4=int32#11,<lotmp=int32#14 # asm 2: adds >lou4=r3,<lou4=r10,<lotmp=r14 adds r3,r10,r14 # qhasm: hiu4 += hitmp + carry # asm 1: adc >hiu4=int32#3,<hiu4=int32#12,<hitmp=int32#3 # asm 2: adc >hiu4=r2,<hiu4=r11,<hitmp=r2 adc r2,r11,r2 # qhasm: lou0 = lod11 # asm 1: vmov >lou0=int32#11,<lod11=float32#23 # asm 2: vmov >lou0=r10,<lod11=s22 # copy-collector input: vmov r10,s22 # qhasm: hiu0 = hid11 # asm 1: vmov >hiu0=int32#12,<hid11=float32#24 # asm 2: vmov >hiu0=r11,<hid11=s23 # copy-collector input: vmov r11,s23 # qhasm: hitmp lotmp = hiu0 * two24 # asm 1: umull >lotmp=int32#14,>hitmp=int32#13,<hiu0=int32#12,<two24=int32#1 # asm 2: umull >lotmp=r14,>hitmp=r12,<hiu0=r11,<two24=r0 # copy-collector output starts vmov r10,r11,d11 # copy-collector output ends umull r14,r12,r11,r0 # qhasm: lotmp hitmp += lou0 * two24 # asm 1: umlal <hitmp=int32#13,<lotmp=int32#14,<lou0=int32#11,<two24=int32#1 # asm 2: umlal <hitmp=r12,<lotmp=r14,<lou0=r10,<two24=r0 umlal r12,r14,r10,r0 # qhasm: carry? lotmp ^= (lou0 unsigned>> 1) # asm 1: eors >lotmp=int32#14,<lotmp=int32#14,<lou0=int32#11,LSR #1 # asm 2: eors >lotmp=r14,<lotmp=r14,<lou0=r10,LSR #1 eors r14,r14,r10,LSR #1 # qhasm: hitmp ^= (carry,hiu0 unsigned>> 1) # asm 1: eors >hitmp=int32#13,<hitmp=int32#13,<hiu0=int32#12,RRX # asm 2: eors >hitmp=r12,<hitmp=r12,<hiu0=r11,RRX eors r12,r12,r11,RRX # qhasm: lotmp ^= (hiu0 << 31) # asm 1: eor >lotmp=int32#14,<lotmp=int32#14,<hiu0=int32#12,LSL #31 # asm 2: eor >lotmp=r14,<lotmp=r14,<hiu0=r11,LSL #31 eor r14,r14,r11,LSL #31 # qhasm: lotmp ^= (lou0 unsigned>>7) # asm 1: eor >lotmp=int32#14,<lotmp=int32#14,<lou0=int32#11,LSR #7 # asm 2: eor >lotmp=r14,<lotmp=r14,<lou0=r10,LSR #7 eor r14,r14,r10,LSR #7 # qhasm: lotmp ^= (hiu0 << 25) # asm 1: eor >lotmp=int32#14,<lotmp=int32#14,<hiu0=int32#12,LSL #25 # asm 2: eor >lotmp=r14,<lotmp=r14,<hiu0=r11,LSL #25 eor r14,r14,r11,LSL #25 # qhasm: hitmp ^= (hiu0 unsigned>>7) # asm 1: eor >hitmp=int32#13,<hitmp=int32#13,<hiu0=int32#12,LSR #7 # asm 2: eor >hitmp=r12,<hitmp=r12,<hiu0=r11,LSR #7 eor r12,r12,r11,LSR #7 # qhasm: carry? lou4 += lotmp # asm 1: adds >lou4=int32#4,<lou4=int32#4,<lotmp=int32#14 # asm 2: adds >lou4=r3,<lou4=r3,<lotmp=r14 adds r3,r3,r14 # qhasm: hiu4 += hitmp + carry # asm 1: adc >hiu4=int32#3,<hiu4=int32#3,<hitmp=int32#13 # asm 2: adc >hiu4=r2,<hiu4=r2,<hitmp=r12 adc r2,r2,r12 # qhasm: lou5 = lom11 # asm 1: ldr >lou5=int32#13,<lom11=stack32#27 # asm 2: ldr >lou5=r12,<lom11=[sp,#104] # copy-collector input: ldr r12,[sp,#104] # qhasm: hiu5 = him11 # asm 1: ldr >hiu5=int32#14,<him11=stack32#28 # asm 2: ldr >hiu5=r14,<him11=[sp,#108] # copy-collector input: ldr r14,[sp,#108] # qhasm: carry? lou4 += lou5 # asm 1: adds >lou4=int32#4,<lou4=int32#4,<lou5=int32#13 # asm 2: adds >lou4=r3,<lou4=r3,<lou5=r12 # copy-collector output starts ldrd r12,r14,[sp,#104] # copy-collector output ends adds r3,r3,r12 # qhasm: hiu4 += hiu5 + carry # asm 1: adc >hiu4=int32#3,<hiu4=int32#3,<hiu5=int32#14 # asm 2: adc >hiu4=r2,<hiu4=r2,<hiu5=r14 adc r2,r2,r14 # qhasm: lod11 = lou5 # asm 1: vmov >lod11=float32#23,<lou5=int32#13 # asm 2: vmov >lod11=s22,<lou5=r12 # copy-collector input: vmov s22,r12 # qhasm: hid11 = hiu5 # asm 1: vmov >hid11=float32#24,<hiu5=int32#14 # asm 2: vmov >hid11=s23,<hiu5=r14 # copy-collector input: vmov s23,r14 # qhasm: lom10 = lou4 # asm 1: str <lou4=int32#4,>lom10=stack32#25 # asm 2: str <lou4=r3,>lom10=[sp,#96] # copy-collector input: str r3,[sp,#96] # qhasm: him10 = hiu4 # asm 1: str <hiu4=int32#3,>him10=stack32#26 # asm 2: str <hiu4=r2,>him10=[sp,#100] # copy-collector input: str r2,[sp,#100] # qhasm: hitmp lotmp = hiu1 * two13 # asm 1: umull >lotmp=int32#14,>hitmp=int32#13,<hiu1=int32#6,<two13=int32#2 # asm 2: umull >lotmp=r14,>hitmp=r12,<hiu1=r5,<two13=r1 # copy-collector output starts vmov d11,r12,r14 strd r3,r2,[sp,#96] # copy-collector output ends umull r14,r12,r5,r1 # qhasm: lotmp hitmp += lou1 * two13 # asm 1: umlal <hitmp=int32#13,<lotmp=int32#14,<lou1=int32#5,<two13=int32#2 # asm 2: umlal <hitmp=r12,<lotmp=r14,<lou1=r4,<two13=r1 umlal r12,r14,r4,r1 # qhasm: lotmp ^= (lou1 unsigned>> 6) # asm 1: eor >lotmp=int32#14,<lotmp=int32#14,<lou1=int32#5,LSR #6 # asm 2: eor >lotmp=r14,<lotmp=r14,<lou1=r4,LSR #6 eor r14,r14,r4,LSR #6 # qhasm: lotmp ^= (hiu1 << 26) # asm 1: eor >lotmp=int32#14,<lotmp=int32#14,<hiu1=int32#6,LSL #26 # asm 2: eor >lotmp=r14,<lotmp=r14,<hiu1=r5,LSL #26 eor r14,r14,r5,LSL #26 # qhasm: lotmp ^= (hiu1 unsigned>> 29) # asm 1: eor >lotmp=int32#14,<lotmp=int32#14,<hiu1=int32#6,LSR #29 # asm 2: eor >lotmp=r14,<lotmp=r14,<hiu1=r5,LSR #29 eor r14,r14,r5,LSR #29 # qhasm: lotmp ^= (lou1 << 3) # asm 1: eor >lotmp=int32#14,<lotmp=int32#14,<lou1=int32#5,LSL #3 # asm 2: eor >lotmp=r14,<lotmp=r14,<lou1=r4,LSL #3 eor r14,r14,r4,LSL #3 # qhasm: hitmp ^= (hiu1 unsigned>> 6) # asm 1: eor >hitmp=int32#13,<hitmp=int32#13,<hiu1=int32#6,LSR #6 # asm 2: eor >hitmp=r12,<hitmp=r12,<hiu1=r5,LSR #6 eor r12,r12,r5,LSR #6 # qhasm: hitmp ^= (lou1 unsigned>> 29) # asm 1: eor >hitmp=int32#5,<hitmp=int32#13,<lou1=int32#5,LSR #29 # asm 2: eor >hitmp=r4,<hitmp=r12,<lou1=r4,LSR #29 eor r4,r12,r4,LSR #29 # qhasm: hitmp ^= (hiu1 << 3) # asm 1: eor >hitmp=int32#5,<hitmp=int32#5,<hiu1=int32#6,LSL #3 # asm 2: eor >hitmp=r4,<hitmp=r4,<hiu1=r5,LSL #3 eor r4,r4,r5,LSL #3 # qhasm: carry? lou0 += lotmp # asm 1: adds >lou0=int32#6,<lou0=int32#11,<lotmp=int32#14 # asm 2: adds >lou0=r5,<lou0=r10,<lotmp=r14 adds r5,r10,r14 # qhasm: hiu0 += hitmp + carry # asm 1: adc >hiu0=int32#5,<hiu0=int32#12,<hitmp=int32#5 # asm 2: adc >hiu0=r4,<hiu0=r11,<hitmp=r4 adc r4,r11,r4 # qhasm: lou1 = lod12 # asm 1: vmov >lou1=int32#11,<lod12=float32#25 # asm 2: vmov >lou1=r10,<lod12=s24 # copy-collector input: vmov r10,s24 # qhasm: hiu1 = hid12 # asm 1: vmov >hiu1=int32#12,<hid12=float32#26 # asm 2: vmov >hiu1=r11,<hid12=s25 # copy-collector input: vmov r11,s25 # qhasm: hitmp lotmp = hiu1 * two24 # asm 1: umull >lotmp=int32#14,>hitmp=int32#13,<hiu1=int32#12,<two24=int32#1 # asm 2: umull >lotmp=r14,>hitmp=r12,<hiu1=r11,<two24=r0 # copy-collector output starts vmov r10,r11,d12 # copy-collector output ends umull r14,r12,r11,r0 # qhasm: lotmp hitmp += lou1 * two24 # asm 1: umlal <hitmp=int32#13,<lotmp=int32#14,<lou1=int32#11,<two24=int32#1 # asm 2: umlal <hitmp=r12,<lotmp=r14,<lou1=r10,<two24=r0 umlal r12,r14,r10,r0 # qhasm: carry? lotmp ^= (lou1 unsigned>> 1) # asm 1: eors >lotmp=int32#14,<lotmp=int32#14,<lou1=int32#11,LSR #1 # asm 2: eors >lotmp=r14,<lotmp=r14,<lou1=r10,LSR #1 eors r14,r14,r10,LSR #1 # qhasm: hitmp ^= (carry,hiu1 unsigned>> 1) # asm 1: eors >hitmp=int32#13,<hitmp=int32#13,<hiu1=int32#12,RRX # asm 2: eors >hitmp=r12,<hitmp=r12,<hiu1=r11,RRX eors r12,r12,r11,RRX # qhasm: lotmp ^= (hiu1 << 31) # asm 1: eor >lotmp=int32#14,<lotmp=int32#14,<hiu1=int32#12,LSL #31 # asm 2: eor >lotmp=r14,<lotmp=r14,<hiu1=r11,LSL #31 eor r14,r14,r11,LSL #31 # qhasm: lotmp ^= (lou1 unsigned>>7) # asm 1: eor >lotmp=int32#14,<lotmp=int32#14,<lou1=int32#11,LSR #7 # asm 2: eor >lotmp=r14,<lotmp=r14,<lou1=r10,LSR #7 eor r14,r14,r10,LSR #7 # qhasm: lotmp ^= (hiu1 << 25) # asm 1: eor >lotmp=int32#14,<lotmp=int32#14,<hiu1=int32#12,LSL #25 # asm 2: eor >lotmp=r14,<lotmp=r14,<hiu1=r11,LSL #25 eor r14,r14,r11,LSL #25 # qhasm: hitmp ^= (hiu1 unsigned>>7) # asm 1: eor >hitmp=int32#13,<hitmp=int32#13,<hiu1=int32#12,LSR #7 # asm 2: eor >hitmp=r12,<hitmp=r12,<hiu1=r11,LSR #7 eor r12,r12,r11,LSR #7 # qhasm: carry? lou0 += lotmp # asm 1: adds >lou0=int32#6,<lou0=int32#6,<lotmp=int32#14 # asm 2: adds >lou0=r5,<lou0=r5,<lotmp=r14 adds r5,r5,r14 # qhasm: hiu0 += hitmp + carry # asm 1: adc >hiu0=int32#5,<hiu0=int32#5,<hitmp=int32#13 # asm 2: adc >hiu0=r4,<hiu0=r4,<hitmp=r12 adc r4,r4,r12 # qhasm: lou5 = lom12 # asm 1: ldr >lou5=int32#13,<lom12=stack32#29 # asm 2: ldr >lou5=r12,<lom12=[sp,#112] # copy-collector input: ldr r12,[sp,#112] # qhasm: hiu5 = him12 # asm 1: ldr >hiu5=int32#14,<him12=stack32#30 # asm 2: ldr >hiu5=r14,<him12=[sp,#116] # copy-collector input: ldr r14,[sp,#116] # qhasm: carry? lou0 += lou5 # asm 1: adds >lou0=int32#6,<lou0=int32#6,<lou5=int32#13 # asm 2: adds >lou0=r5,<lou0=r5,<lou5=r12 # copy-collector output starts ldrd r12,r14,[sp,#112] # copy-collector output ends adds r5,r5,r12 # qhasm: hiu0 += hiu5 + carry # asm 1: adc >hiu0=int32#5,<hiu0=int32#5,<hiu5=int32#14 # asm 2: adc >hiu0=r4,<hiu0=r4,<hiu5=r14 adc r4,r4,r14 # qhasm: lod12 = lou5 # asm 1: vmov >lod12=float32#25,<lou5=int32#13 # asm 2: vmov >lod12=s24,<lou5=r12 # copy-collector input: vmov s24,r12 # qhasm: hid12 = hiu5 # asm 1: vmov >hid12=float32#26,<hiu5=int32#14 # asm 2: vmov >hid12=s25,<hiu5=r14 # copy-collector input: vmov s25,r14 # qhasm: lom11 = lou0 # asm 1: str <lou0=int32#6,>lom11=stack32#27 # asm 2: str <lou0=r5,>lom11=[sp,#104] # copy-collector input: str r5,[sp,#104] # qhasm: him11 = hiu0 # asm 1: str <hiu0=int32#5,>him11=stack32#28 # asm 2: str <hiu0=r4,>him11=[sp,#108] # copy-collector input: str r4,[sp,#108] # qhasm: hitmp lotmp = hiu4 * two13 # asm 1: umull >lotmp=int32#14,>hitmp=int32#13,<hiu4=int32#3,<two13=int32#2 # asm 2: umull >lotmp=r14,>hitmp=r12,<hiu4=r2,<two13=r1 # copy-collector output starts vmov d12,r12,r14 strd r5,r4,[sp,#104] # copy-collector output ends umull r14,r12,r2,r1 # qhasm: lotmp hitmp += lou4 * two13 # asm 1: umlal <hitmp=int32#13,<lotmp=int32#14,<lou4=int32#4,<two13=int32#2 # asm 2: umlal <hitmp=r12,<lotmp=r14,<lou4=r3,<two13=r1 umlal r12,r14,r3,r1 # qhasm: lotmp ^= (lou4 unsigned>> 6) # asm 1: eor >lotmp=int32#14,<lotmp=int32#14,<lou4=int32#4,LSR #6 # asm 2: eor >lotmp=r14,<lotmp=r14,<lou4=r3,LSR #6 eor r14,r14,r3,LSR #6 # qhasm: lotmp ^= (hiu4 << 26) # asm 1: eor >lotmp=int32#14,<lotmp=int32#14,<hiu4=int32#3,LSL #26 # asm 2: eor >lotmp=r14,<lotmp=r14,<hiu4=r2,LSL #26 eor r14,r14,r2,LSL #26 # qhasm: lotmp ^= (hiu4 unsigned>> 29) # asm 1: eor >lotmp=int32#14,<lotmp=int32#14,<hiu4=int32#3,LSR #29 # asm 2: eor >lotmp=r14,<lotmp=r14,<hiu4=r2,LSR #29 eor r14,r14,r2,LSR #29 # qhasm: lotmp ^= (lou4 << 3) # asm 1: eor >lotmp=int32#14,<lotmp=int32#14,<lou4=int32#4,LSL #3 # asm 2: eor >lotmp=r14,<lotmp=r14,<lou4=r3,LSL #3 eor r14,r14,r3,LSL #3 # qhasm: hitmp ^= (hiu4 unsigned>> 6) # asm 1: eor >hitmp=int32#13,<hitmp=int32#13,<hiu4=int32#3,LSR #6 # asm 2: eor >hitmp=r12,<hitmp=r12,<hiu4=r2,LSR #6 eor r12,r12,r2,LSR #6 # qhasm: hitmp ^= (lou4 unsigned>> 29) # asm 1: eor >hitmp=int32#4,<hitmp=int32#13,<lou4=int32#4,LSR #29 # asm 2: eor >hitmp=r3,<hitmp=r12,<lou4=r3,LSR #29 eor r3,r12,r3,LSR #29 # qhasm: hitmp ^= (hiu4 << 3) # asm 1: eor >hitmp=int32#3,<hitmp=int32#4,<hiu4=int32#3,LSL #3 # asm 2: eor >hitmp=r2,<hitmp=r3,<hiu4=r2,LSL #3 eor r2,r3,r2,LSL #3 # qhasm: carry? lou1 += lotmp # asm 1: adds >lou1=int32#4,<lou1=int32#11,<lotmp=int32#14 # asm 2: adds >lou1=r3,<lou1=r10,<lotmp=r14 adds r3,r10,r14 # qhasm: hiu1 += hitmp + carry # asm 1: adc >hiu1=int32#3,<hiu1=int32#12,<hitmp=int32#3 # asm 2: adc >hiu1=r2,<hiu1=r11,<hitmp=r2 adc r2,r11,r2 # qhasm: lou4 = lod13 # asm 1: vmov >lou4=int32#11,<lod13=float32#27 # asm 2: vmov >lou4=r10,<lod13=s26 # copy-collector input: vmov r10,s26 # qhasm: hiu4 = hid13 # asm 1: vmov >hiu4=int32#12,<hid13=float32#28 # asm 2: vmov >hiu4=r11,<hid13=s27 # copy-collector input: vmov r11,s27 # qhasm: hitmp lotmp = hiu4 * two24 # asm 1: umull >lotmp=int32#14,>hitmp=int32#13,<hiu4=int32#12,<two24=int32#1 # asm 2: umull >lotmp=r14,>hitmp=r12,<hiu4=r11,<two24=r0 # copy-collector output starts vmov r10,r11,d13 # copy-collector output ends umull r14,r12,r11,r0 # qhasm: lotmp hitmp += lou4 * two24 # asm 1: umlal <hitmp=int32#13,<lotmp=int32#14,<lou4=int32#11,<two24=int32#1 # asm 2: umlal <hitmp=r12,<lotmp=r14,<lou4=r10,<two24=r0 umlal r12,r14,r10,r0 # qhasm: carry? lotmp ^= (lou4 unsigned>> 1) # asm 1: eors >lotmp=int32#14,<lotmp=int32#14,<lou4=int32#11,LSR #1 # asm 2: eors >lotmp=r14,<lotmp=r14,<lou4=r10,LSR #1 eors r14,r14,r10,LSR #1 # qhasm: hitmp ^= (carry,hiu4 unsigned>> 1) # asm 1: eors >hitmp=int32#13,<hitmp=int32#13,<hiu4=int32#12,RRX # asm 2: eors >hitmp=r12,<hitmp=r12,<hiu4=r11,RRX eors r12,r12,r11,RRX # qhasm: lotmp ^= (hiu4 << 31) # asm 1: eor >lotmp=int32#14,<lotmp=int32#14,<hiu4=int32#12,LSL #31 # asm 2: eor >lotmp=r14,<lotmp=r14,<hiu4=r11,LSL #31 eor r14,r14,r11,LSL #31 # qhasm: lotmp ^= (lou4 unsigned>>7) # asm 1: eor >lotmp=int32#14,<lotmp=int32#14,<lou4=int32#11,LSR #7 # asm 2: eor >lotmp=r14,<lotmp=r14,<lou4=r10,LSR #7 eor r14,r14,r10,LSR #7 # qhasm: lotmp ^= (hiu4 << 25) # asm 1: eor >lotmp=int32#14,<lotmp=int32#14,<hiu4=int32#12,LSL #25 # asm 2: eor >lotmp=r14,<lotmp=r14,<hiu4=r11,LSL #25 eor r14,r14,r11,LSL #25 # qhasm: hitmp ^= (hiu4 unsigned>>7) # asm 1: eor >hitmp=int32#13,<hitmp=int32#13,<hiu4=int32#12,LSR #7 # asm 2: eor >hitmp=r12,<hitmp=r12,<hiu4=r11,LSR #7 eor r12,r12,r11,LSR #7 # qhasm: carry? lou1 += lotmp # asm 1: adds >lou1=int32#4,<lou1=int32#4,<lotmp=int32#14 # asm 2: adds >lou1=r3,<lou1=r3,<lotmp=r14 adds r3,r3,r14 # qhasm: hiu1 += hitmp + carry # asm 1: adc >hiu1=int32#3,<hiu1=int32#3,<hitmp=int32#13 # asm 2: adc >hiu1=r2,<hiu1=r2,<hitmp=r12 adc r2,r2,r12 # qhasm: lou5 = lom13 # asm 1: ldr >lou5=int32#13,<lom13=stack32#31 # asm 2: ldr >lou5=r12,<lom13=[sp,#120] # copy-collector input: ldr r12,[sp,#120] # qhasm: hiu5 = him13 # asm 1: ldr >hiu5=int32#14,<him13=stack32#32 # asm 2: ldr >hiu5=r14,<him13=[sp,#124] # copy-collector input: ldr r14,[sp,#124] # qhasm: carry? lou1 += lou5 # asm 1: adds >lou1=int32#4,<lou1=int32#4,<lou5=int32#13 # asm 2: adds >lou1=r3,<lou1=r3,<lou5=r12 # copy-collector output starts ldrd r12,r14,[sp,#120] # copy-collector output ends adds r3,r3,r12 # qhasm: hiu1 += hiu5 + carry # asm 1: adc >hiu1=int32#3,<hiu1=int32#3,<hiu5=int32#14 # asm 2: adc >hiu1=r2,<hiu1=r2,<hiu5=r14 adc r2,r2,r14 # qhasm: lod13 = lou5 # asm 1: vmov >lod13=float32#27,<lou5=int32#13 # asm 2: vmov >lod13=s26,<lou5=r12 # copy-collector input: vmov s26,r12 # qhasm: hid13 = hiu5 # asm 1: vmov >hid13=float32#28,<hiu5=int32#14 # asm 2: vmov >hid13=s27,<hiu5=r14 # copy-collector input: vmov s27,r14 # qhasm: lom12 = lou1 # asm 1: str <lou1=int32#4,>lom12=stack32#29 # asm 2: str <lou1=r3,>lom12=[sp,#112] # copy-collector input: str r3,[sp,#112] # qhasm: him12 = hiu1 # asm 1: str <hiu1=int32#3,>him12=stack32#30 # asm 2: str <hiu1=r2,>him12=[sp,#116] # copy-collector input: str r2,[sp,#116] # qhasm: hitmp lotmp = hiu0 * two13 # asm 1: umull >lotmp=int32#14,>hitmp=int32#13,<hiu0=int32#5,<two13=int32#2 # asm 2: umull >lotmp=r14,>hitmp=r12,<hiu0=r4,<two13=r1 # copy-collector output starts vmov d13,r12,r14 strd r3,r2,[sp,#112] # copy-collector output ends umull r14,r12,r4,r1 # qhasm: lotmp hitmp += lou0 * two13 # asm 1: umlal <hitmp=int32#13,<lotmp=int32#14,<lou0=int32#6,<two13=int32#2 # asm 2: umlal <hitmp=r12,<lotmp=r14,<lou0=r5,<two13=r1 umlal r12,r14,r5,r1 # qhasm: lotmp ^= (lou0 unsigned>> 6) # asm 1: eor >lotmp=int32#14,<lotmp=int32#14,<lou0=int32#6,LSR #6 # asm 2: eor >lotmp=r14,<lotmp=r14,<lou0=r5,LSR #6 eor r14,r14,r5,LSR #6 # qhasm: lotmp ^= (hiu0 << 26) # asm 1: eor >lotmp=int32#14,<lotmp=int32#14,<hiu0=int32#5,LSL #26 # asm 2: eor >lotmp=r14,<lotmp=r14,<hiu0=r4,LSL #26 eor r14,r14,r4,LSL #26 # qhasm: lotmp ^= (hiu0 unsigned>> 29) # asm 1: eor >lotmp=int32#14,<lotmp=int32#14,<hiu0=int32#5,LSR #29 # asm 2: eor >lotmp=r14,<lotmp=r14,<hiu0=r4,LSR #29 eor r14,r14,r4,LSR #29 # qhasm: lotmp ^= (lou0 << 3) # asm 1: eor >lotmp=int32#14,<lotmp=int32#14,<lou0=int32#6,LSL #3 # asm 2: eor >lotmp=r14,<lotmp=r14,<lou0=r5,LSL #3 eor r14,r14,r5,LSL #3 # qhasm: hitmp ^= (hiu0 unsigned>> 6) # asm 1: eor >hitmp=int32#13,<hitmp=int32#13,<hiu0=int32#5,LSR #6 # asm 2: eor >hitmp=r12,<hitmp=r12,<hiu0=r4,LSR #6 eor r12,r12,r4,LSR #6 # qhasm: hitmp ^= (lou0 unsigned>> 29) # asm 1: eor >hitmp=int32#6,<hitmp=int32#13,<lou0=int32#6,LSR #29 # asm 2: eor >hitmp=r5,<hitmp=r12,<lou0=r5,LSR #29 eor r5,r12,r5,LSR #29 # qhasm: hitmp ^= (hiu0 << 3) # asm 1: eor >hitmp=int32#5,<hitmp=int32#6,<hiu0=int32#5,LSL #3 # asm 2: eor >hitmp=r4,<hitmp=r5,<hiu0=r4,LSL #3 eor r4,r5,r4,LSL #3 # qhasm: carry? lou4 += lotmp # asm 1: adds >lou4=int32#6,<lou4=int32#11,<lotmp=int32#14 # asm 2: adds >lou4=r5,<lou4=r10,<lotmp=r14 adds r5,r10,r14 # qhasm: hiu4 += hitmp + carry # asm 1: adc >hiu4=int32#5,<hiu4=int32#12,<hitmp=int32#5 # asm 2: adc >hiu4=r4,<hiu4=r11,<hitmp=r4 adc r4,r11,r4 # qhasm: lou0 = lod14 # asm 1: vmov >lou0=int32#11,<lod14=float32#29 # asm 2: vmov >lou0=r10,<lod14=s28 # copy-collector input: vmov r10,s28 # qhasm: hiu0 = hid14 # asm 1: vmov >hiu0=int32#12,<hid14=float32#30 # asm 2: vmov >hiu0=r11,<hid14=s29 # copy-collector input: vmov r11,s29 # qhasm: lod14 = lou2 # asm 1: vmov >lod14=float32#29,<lou2=int32#7 # asm 2: vmov >lod14=s28,<lou2=r6 # copy-collector input: vmov s28,r6 # qhasm: hid14 = hiu2 # asm 1: vmov >hid14=float32#30,<hiu2=int32#8 # asm 2: vmov >hid14=s29,<hiu2=r7 # copy-collector input: vmov s29,r7 # qhasm: hitmp lotmp = hiu0 * two24 # asm 1: umull >lotmp=int32#14,>hitmp=int32#13,<hiu0=int32#12,<two24=int32#1 # asm 2: umull >lotmp=r14,>hitmp=r12,<hiu0=r11,<two24=r0 # copy-collector output starts vmov r10,r11,d14 vmov d14,r6,r7 # copy-collector output ends umull r14,r12,r11,r0 # qhasm: lotmp hitmp += lou0 * two24 # asm 1: umlal <hitmp=int32#13,<lotmp=int32#14,<lou0=int32#11,<two24=int32#1 # asm 2: umlal <hitmp=r12,<lotmp=r14,<lou0=r10,<two24=r0 umlal r12,r14,r10,r0 # qhasm: carry? lotmp ^= (lou0 unsigned>> 1) # asm 1: eors >lotmp=int32#14,<lotmp=int32#14,<lou0=int32#11,LSR #1 # asm 2: eors >lotmp=r14,<lotmp=r14,<lou0=r10,LSR #1 eors r14,r14,r10,LSR #1 # qhasm: hitmp ^= (carry,hiu0 unsigned>> 1) # asm 1: eors >hitmp=int32#13,<hitmp=int32#13,<hiu0=int32#12,RRX # asm 2: eors >hitmp=r12,<hitmp=r12,<hiu0=r11,RRX eors r12,r12,r11,RRX # qhasm: lotmp ^= (hiu0 << 31) # asm 1: eor >lotmp=int32#14,<lotmp=int32#14,<hiu0=int32#12,LSL #31 # asm 2: eor >lotmp=r14,<lotmp=r14,<hiu0=r11,LSL #31 eor r14,r14,r11,LSL #31 # qhasm: lotmp ^= (lou0 unsigned>>7) # asm 1: eor >lotmp=int32#14,<lotmp=int32#14,<lou0=int32#11,LSR #7 # asm 2: eor >lotmp=r14,<lotmp=r14,<lou0=r10,LSR #7 eor r14,r14,r10,LSR #7 # qhasm: lotmp ^= (hiu0 << 25) # asm 1: eor >lotmp=int32#14,<lotmp=int32#14,<hiu0=int32#12,LSL #25 # asm 2: eor >lotmp=r14,<lotmp=r14,<hiu0=r11,LSL #25 eor r14,r14,r11,LSL #25 # qhasm: hitmp ^= (hiu0 unsigned>>7) # asm 1: eor >hitmp=int32#13,<hitmp=int32#13,<hiu0=int32#12,LSR #7 # asm 2: eor >hitmp=r12,<hitmp=r12,<hiu0=r11,LSR #7 eor r12,r12,r11,LSR #7 # qhasm: carry? lou4 += lotmp # asm 1: adds >lou4=int32#6,<lou4=int32#6,<lotmp=int32#14 # asm 2: adds >lou4=r5,<lou4=r5,<lotmp=r14 adds r5,r5,r14 # qhasm: hiu4 += hitmp + carry # asm 1: adc >hiu4=int32#5,<hiu4=int32#5,<hitmp=int32#13 # asm 2: adc >hiu4=r4,<hiu4=r4,<hitmp=r12 adc r4,r4,r12 # qhasm: carry? lou4 += lou2 # asm 1: adds >lou4=int32#6,<lou4=int32#6,<lou2=int32#7 # asm 2: adds >lou4=r5,<lou4=r5,<lou2=r6 adds.w r5,r5,r6 # qhasm: hiu4 += hiu2 + carry # asm 1: adc >hiu4=int32#5,<hiu4=int32#5,<hiu2=int32#8 # asm 2: adc >hiu4=r4,<hiu4=r4,<hiu2=r7 adc r4,r4,r7 # qhasm: lom13 = lou4 # asm 1: str <lou4=int32#6,>lom13=stack32#31 # asm 2: str <lou4=r5,>lom13=[sp,#120] # copy-collector input: str r5,[sp,#120] # qhasm: him13 = hiu4 # asm 1: str <hiu4=int32#5,>him13=stack32#32 # asm 2: str <hiu4=r4,>him13=[sp,#124] # copy-collector input: str r4,[sp,#124] # qhasm: hitmp lotmp = hiu1 * two13 # asm 1: umull >lotmp=int32#8,>hitmp=int32#7,<hiu1=int32#3,<two13=int32#2 # asm 2: umull >lotmp=r7,>hitmp=r6,<hiu1=r2,<two13=r1 # copy-collector output starts strd r5,r4,[sp,#120] # copy-collector output ends umull r7,r6,r2,r1 # qhasm: lotmp hitmp += lou1 * two13 # asm 1: umlal <hitmp=int32#7,<lotmp=int32#8,<lou1=int32#4,<two13=int32#2 # asm 2: umlal <hitmp=r6,<lotmp=r7,<lou1=r3,<two13=r1 umlal r6,r7,r3,r1 # qhasm: lotmp ^= (lou1 unsigned>> 6) # asm 1: eor >lotmp=int32#8,<lotmp=int32#8,<lou1=int32#4,LSR #6 # asm 2: eor >lotmp=r7,<lotmp=r7,<lou1=r3,LSR #6 eor r7,r7,r3,LSR #6 # qhasm: lotmp ^= (hiu1 << 26) # asm 1: eor >lotmp=int32#8,<lotmp=int32#8,<hiu1=int32#3,LSL #26 # asm 2: eor >lotmp=r7,<lotmp=r7,<hiu1=r2,LSL #26 eor r7,r7,r2,LSL #26 # qhasm: lotmp ^= (hiu1 unsigned>> 29) # asm 1: eor >lotmp=int32#8,<lotmp=int32#8,<hiu1=int32#3,LSR #29 # asm 2: eor >lotmp=r7,<lotmp=r7,<hiu1=r2,LSR #29 eor r7,r7,r2,LSR #29 # qhasm: lotmp ^= (lou1 << 3) # asm 1: eor >lotmp=int32#8,<lotmp=int32#8,<lou1=int32#4,LSL #3 # asm 2: eor >lotmp=r7,<lotmp=r7,<lou1=r3,LSL #3 eor r7,r7,r3,LSL #3 # qhasm: hitmp ^= (hiu1 unsigned>> 6) # asm 1: eor >hitmp=int32#7,<hitmp=int32#7,<hiu1=int32#3,LSR #6 # asm 2: eor >hitmp=r6,<hitmp=r6,<hiu1=r2,LSR #6 eor r6,r6,r2,LSR #6 # qhasm: hitmp ^= (lou1 unsigned>> 29) # asm 1: eor >hitmp=int32#4,<hitmp=int32#7,<lou1=int32#4,LSR #29 # asm 2: eor >hitmp=r3,<hitmp=r6,<lou1=r3,LSR #29 eor r3,r6,r3,LSR #29 # qhasm: hitmp ^= (hiu1 << 3) # asm 1: eor >hitmp=int32#3,<hitmp=int32#4,<hiu1=int32#3,LSL #3 # asm 2: eor >hitmp=r2,<hitmp=r3,<hiu1=r2,LSL #3 eor r2,r3,r2,LSL #3 # qhasm: carry? lou0 += lotmp # asm 1: adds >lou0=int32#4,<lou0=int32#11,<lotmp=int32#8 # asm 2: adds >lou0=r3,<lou0=r10,<lotmp=r7 adds r3,r10,r7 # qhasm: hiu0 += hitmp + carry # asm 1: adc >hiu0=int32#3,<hiu0=int32#12,<hitmp=int32#3 # asm 2: adc >hiu0=r2,<hiu0=r11,<hitmp=r2 adc r2,r11,r2 # qhasm: lou1 = lod15 # asm 1: vmov >lou1=int32#7,<lod15=float32#31 # asm 2: vmov >lou1=r6,<lod15=s30 # copy-collector input: vmov r6,s30 # qhasm: hiu1 = hid15 # asm 1: vmov >hiu1=int32#8,<hid15=float32#32 # asm 2: vmov >hiu1=r7,<hid15=s31 # copy-collector input: vmov r7,s31 # qhasm: lod15 = lou3 # asm 1: vmov >lod15=float32#31,<lou3=int32#9 # asm 2: vmov >lod15=s30,<lou3=r8 # copy-collector input: vmov s30,r8 # qhasm: hid15 = hiu3 # asm 1: vmov >hid15=float32#32,<hiu3=int32#10 # asm 2: vmov >hid15=s31,<hiu3=r9 # copy-collector input: vmov s31,r9 # qhasm: hitmp lotmp = hiu1 * two24 # asm 1: umull >lotmp=int32#12,>hitmp=int32#11,<hiu1=int32#8,<two24=int32#1 # asm 2: umull >lotmp=r11,>hitmp=r10,<hiu1=r7,<two24=r0 # copy-collector output starts vmov r6,r7,d15 vmov d15,r8,r9 # copy-collector output ends umull r11,r10,r7,r0 # qhasm: lotmp hitmp += lou1 * two24 # asm 1: umlal <hitmp=int32#11,<lotmp=int32#12,<lou1=int32#7,<two24=int32#1 # asm 2: umlal <hitmp=r10,<lotmp=r11,<lou1=r6,<two24=r0 umlal r10,r11,r6,r0 # qhasm: carry? lotmp ^= (lou1 unsigned>> 1) # asm 1: eors >lotmp=int32#12,<lotmp=int32#12,<lou1=int32#7,LSR #1 # asm 2: eors >lotmp=r11,<lotmp=r11,<lou1=r6,LSR #1 eors r11,r11,r6,LSR #1 # qhasm: hitmp ^= (carry,hiu1 unsigned>> 1) # asm 1: eors >hitmp=int32#11,<hitmp=int32#11,<hiu1=int32#8,RRX # asm 2: eors >hitmp=r10,<hitmp=r10,<hiu1=r7,RRX eors r10,r10,r7,RRX # qhasm: lotmp ^= (hiu1 << 31) # asm 1: eor >lotmp=int32#12,<lotmp=int32#12,<hiu1=int32#8,LSL #31 # asm 2: eor >lotmp=r11,<lotmp=r11,<hiu1=r7,LSL #31 eor r11,r11,r7,LSL #31 # qhasm: lotmp ^= (lou1 unsigned>>7) # asm 1: eor >lotmp=int32#12,<lotmp=int32#12,<lou1=int32#7,LSR #7 # asm 2: eor >lotmp=r11,<lotmp=r11,<lou1=r6,LSR #7 eor r11,r11,r6,LSR #7 # qhasm: lotmp ^= (hiu1 << 25) # asm 1: eor >lotmp=int32#12,<lotmp=int32#12,<hiu1=int32#8,LSL #25 # asm 2: eor >lotmp=r11,<lotmp=r11,<hiu1=r7,LSL #25 eor r11,r11,r7,LSL #25 # qhasm: hitmp ^= (hiu1 unsigned>>7) # asm 1: eor >hitmp=int32#11,<hitmp=int32#11,<hiu1=int32#8,LSR #7 # asm 2: eor >hitmp=r10,<hitmp=r10,<hiu1=r7,LSR #7 eor r10,r10,r7,LSR #7 # qhasm: carry? lou0 += lotmp # asm 1: adds >lou0=int32#4,<lou0=int32#4,<lotmp=int32#12 # asm 2: adds >lou0=r3,<lou0=r3,<lotmp=r11 adds r3,r3,r11 # qhasm: hiu0 += hitmp + carry # asm 1: adc >hiu0=int32#3,<hiu0=int32#3,<hitmp=int32#11 # asm 2: adc >hiu0=r2,<hiu0=r2,<hitmp=r10 adc r2,r2,r10 # qhasm: carry? lou0 += lou3 # asm 1: adds >lou0=int32#4,<lou0=int32#4,<lou3=int32#9 # asm 2: adds >lou0=r3,<lou0=r3,<lou3=r8 adds r3,r3,r8 # qhasm: hiu0 += hiu3 + carry # asm 1: adc >hiu0=int32#3,<hiu0=int32#3,<hiu3=int32#10 # asm 2: adc >hiu0=r2,<hiu0=r2,<hiu3=r9 adc r2,r2,r9 # qhasm: lom14 = lou0 # asm 1: str <lou0=int32#4,>lom14=stack32#33 # asm 2: str <lou0=r3,>lom14=[sp,#128] # copy-collector input: str r3,[sp,#128] # qhasm: him14 = hiu0 # asm 1: str <hiu0=int32#3,>him14=stack32#34 # asm 2: str <hiu0=r2,>him14=[sp,#132] # copy-collector input: str r2,[sp,#132] # qhasm: hitmp lotmp = hiu4 * two13 # asm 1: umull >lotmp=int32#4,>hitmp=int32#3,<hiu4=int32#5,<two13=int32#2 # asm 2: umull >lotmp=r3,>hitmp=r2,<hiu4=r4,<two13=r1 # copy-collector output starts strd r3,r2,[sp,#128] # copy-collector output ends umull r3,r2,r4,r1 # qhasm: lotmp hitmp += lou4 * two13 # asm 1: umlal <hitmp=int32#3,<lotmp=int32#4,<lou4=int32#6,<two13=int32#2 # asm 2: umlal <hitmp=r2,<lotmp=r3,<lou4=r5,<two13=r1 umlal r2,r3,r5,r1 # qhasm: lotmp ^= (lou4 unsigned>> 6) # asm 1: eor >lotmp=int32#2,<lotmp=int32#4,<lou4=int32#6,LSR #6 # asm 2: eor >lotmp=r1,<lotmp=r3,<lou4=r5,LSR #6 eor r1,r3,r5,LSR #6 # qhasm: lotmp ^= (hiu4 << 26) # asm 1: eor >lotmp=int32#2,<lotmp=int32#2,<hiu4=int32#5,LSL #26 # asm 2: eor >lotmp=r1,<lotmp=r1,<hiu4=r4,LSL #26 eor r1,r1,r4,LSL #26 # qhasm: lotmp ^= (hiu4 unsigned>> 29) # asm 1: eor >lotmp=int32#2,<lotmp=int32#2,<hiu4=int32#5,LSR #29 # asm 2: eor >lotmp=r1,<lotmp=r1,<hiu4=r4,LSR #29 eor r1,r1,r4,LSR #29 # qhasm: lotmp ^= (lou4 << 3) # asm 1: eor >lotmp=int32#2,<lotmp=int32#2,<lou4=int32#6,LSL #3 # asm 2: eor >lotmp=r1,<lotmp=r1,<lou4=r5,LSL #3 eor r1,r1,r5,LSL #3 # qhasm: hitmp ^= (hiu4 unsigned>> 6) # asm 1: eor >hitmp=int32#3,<hitmp=int32#3,<hiu4=int32#5,LSR #6 # asm 2: eor >hitmp=r2,<hitmp=r2,<hiu4=r4,LSR #6 eor r2,r2,r4,LSR #6 # qhasm: hitmp ^= (lou4 unsigned>> 29) # asm 1: eor >hitmp=int32#3,<hitmp=int32#3,<lou4=int32#6,LSR #29 # asm 2: eor >hitmp=r2,<hitmp=r2,<lou4=r5,LSR #29 eor r2,r2,r5,LSR #29 # qhasm: hitmp ^= (hiu4 << 3) # asm 1: eor >hitmp=int32#3,<hitmp=int32#3,<hiu4=int32#5,LSL #3 # asm 2: eor >hitmp=r2,<hitmp=r2,<hiu4=r4,LSL #3 eor r2,r2,r4,LSL #3 # qhasm: carry? lou1 += lotmp # asm 1: adds >lou1=int32#2,<lou1=int32#7,<lotmp=int32#2 # asm 2: adds >lou1=r1,<lou1=r6,<lotmp=r1 adds r1,r6,r1 # qhasm: hiu1 += hitmp + carry # asm 1: adc >hiu1=int32#3,<hiu1=int32#8,<hitmp=int32#3 # asm 2: adc >hiu1=r2,<hiu1=r7,<hitmp=r2 adc r2,r7,r2 # qhasm: lou0 = lom8 # asm 1: ldr >lou0=int32#4,<lom8=stack32#21 # asm 2: ldr >lou0=r3,<lom8=[sp,#80] # copy-collector input: ldr r3,[sp,#80] # qhasm: hiu0 = him8 # asm 1: ldr >hiu0=int32#5,<him8=stack32#22 # asm 2: ldr >hiu0=r4,<him8=[sp,#84] # copy-collector input: ldr r4,[sp,#84] # qhasm: lou2 = lom15 # asm 1: ldr >lou2=int32#6,<lom15=stack32#35 # asm 2: ldr >lou2=r5,<lom15=[sp,#136] # copy-collector input: ldr r5,[sp,#136] # qhasm: hiu2 = him15 # asm 1: ldr >hiu2=int32#7,<him15=stack32#36 # asm 2: ldr >hiu2=r6,<him15=[sp,#140] # copy-collector input: ldr r6,[sp,#140] # qhasm: lom8 = lou2 # asm 1: str <lou2=int32#6,>lom8=stack32#21 # asm 2: str <lou2=r5,>lom8=[sp,#80] # copy-collector input: str r5,[sp,#80] # qhasm: him8 = hiu2 # asm 1: str <hiu2=int32#7,>him8=stack32#22 # asm 2: str <hiu2=r6,>him8=[sp,#84] # copy-collector input: str r6,[sp,#84] # qhasm: hitmp lotmp = hiu0 * two24 # asm 1: umull >lotmp=int32#9,>hitmp=int32#8,<hiu0=int32#5,<two24=int32#1 # asm 2: umull >lotmp=r8,>hitmp=r7,<hiu0=r4,<two24=r0 # copy-collector output starts ldr r3,[sp,#80] ldr r4,[sp,#84] ldr r5,[sp,#136] ldr.w r6,[sp,#140] strd r5,r6,[sp,#80] # copy-collector output ends umull r8,r7,r4,r0 # qhasm: lotmp hitmp += lou0 * two24 # asm 1: umlal <hitmp=int32#8,<lotmp=int32#9,<lou0=int32#4,<two24=int32#1 # asm 2: umlal <hitmp=r7,<lotmp=r8,<lou0=r3,<two24=r0 umlal r7,r8,r3,r0 # qhasm: carry? lotmp ^= (lou0 unsigned>> 1) # asm 1: eors >lotmp=int32#1,<lotmp=int32#9,<lou0=int32#4,LSR #1 # asm 2: eors >lotmp=r0,<lotmp=r8,<lou0=r3,LSR #1 eors r0,r8,r3,LSR #1 # qhasm: hitmp ^= (carry,hiu0 unsigned>> 1) # asm 1: eors >hitmp=int32#8,<hitmp=int32#8,<hiu0=int32#5,RRX # asm 2: eors >hitmp=r7,<hitmp=r7,<hiu0=r4,RRX eors r7,r7,r4,RRX # qhasm: lotmp ^= (hiu0 << 31) # asm 1: eor >lotmp=int32#1,<lotmp=int32#1,<hiu0=int32#5,LSL #31 # asm 2: eor >lotmp=r0,<lotmp=r0,<hiu0=r4,LSL #31 eor r0,r0,r4,LSL #31 # qhasm: lotmp ^= (lou0 unsigned>>7) # asm 1: eor >lotmp=int32#1,<lotmp=int32#1,<lou0=int32#4,LSR #7 # asm 2: eor >lotmp=r0,<lotmp=r0,<lou0=r3,LSR #7 eor r0,r0,r3,LSR #7 # qhasm: lotmp ^= (hiu0 << 25) # asm 1: eor >lotmp=int32#1,<lotmp=int32#1,<hiu0=int32#5,LSL #25 # asm 2: eor >lotmp=r0,<lotmp=r0,<hiu0=r4,LSL #25 eor r0,r0,r4,LSL #25 # qhasm: hitmp ^= (hiu0 unsigned>>7) # asm 1: eor >hitmp=int32#8,<hitmp=int32#8,<hiu0=int32#5,LSR #7 # asm 2: eor >hitmp=r7,<hitmp=r7,<hiu0=r4,LSR #7 eor r7,r7,r4,LSR #7 # qhasm: carry? lou1 += lotmp # asm 1: adds >lou1=int32#1,<lou1=int32#2,<lotmp=int32#1 # asm 2: adds >lou1=r0,<lou1=r1,<lotmp=r0 adds r0,r1,r0 # qhasm: hiu1 += hitmp + carry # asm 1: adc >hiu1=int32#2,<hiu1=int32#3,<hitmp=int32#8 # asm 2: adc >hiu1=r1,<hiu1=r2,<hitmp=r7 adc r1,r2,r7 # qhasm: carry? lou1 += lou2 # asm 1: adds >lou1=int32#1,<lou1=int32#1,<lou2=int32#6 # asm 2: adds >lou1=r0,<lou1=r0,<lou2=r5 adds r0,r0,r5 # qhasm: hiu1 += hiu2 + carry # asm 1: adc >hiu1=int32#2,<hiu1=int32#2,<hiu2=int32#7 # asm 2: adc >hiu1=r1,<hiu1=r1,<hiu2=r6 adc r1,r1,r6 # qhasm: lom15 = lou1 # asm 1: str <lou1=int32#1,>lom15=stack32#35 # asm 2: str <lou1=r0,>lom15=[sp,#136] # copy-collector input: str r0,[sp,#136] # qhasm: him15 = hiu1 # asm 1: str <hiu1=int32#2,>him15=stack32#36 # asm 2: str <hiu1=r1,>him15=[sp,#140] # copy-collector input: str r1,[sp,#140] # qhasm: lod8 = lou0 # asm 1: vmov >lod8=float32#17,<lou0=int32#4 # asm 2: vmov >lod8=s16,<lou0=r3 # copy-collector input: vmov s16,r3 # qhasm: hid8 = hiu0 # asm 1: vmov >hid8=float32#18,<hiu0=int32#5 # asm 2: vmov >hid8=s17,<hiu0=r4 # copy-collector input: vmov s17,r4 # qhasm: goto innerloop # copy-collector output starts strd r0,r1,[sp,#136] vmov d8,r3,r4 # copy-collector output ends b ._innerloop # qhasm: nearend: ._nearend: # qhasm: lou0 = lom8 # asm 1: ldr >lou0=int32#1,<lom8=stack32#21 # asm 2: ldr >lou0=r0,<lom8=[sp,#80] # copy-collector input: ldr r0,[sp,#80] # qhasm: hiu0 = him8 # asm 1: ldr >hiu0=int32#2,<him8=stack32#22 # asm 2: ldr >hiu0=r1,<him8=[sp,#84] # copy-collector input: ldr r1,[sp,#84] # qhasm: lou1 = lom9 # asm 1: ldr >lou1=int32#3,<lom9=stack32#23 # asm 2: ldr >lou1=r2,<lom9=[sp,#88] # copy-collector input: ldr r2,[sp,#88] # qhasm: hiu1 = him9 # asm 1: ldr >hiu1=int32#4,<him9=stack32#24 # asm 2: ldr >hiu1=r3,<him9=[sp,#92] # copy-collector input: ldr r3,[sp,#92] # qhasm: lou2 = lom10 # asm 1: ldr >lou2=int32#5,<lom10=stack32#25 # asm 2: ldr >lou2=r4,<lom10=[sp,#96] # copy-collector input: ldr r4,[sp,#96] # qhasm: hiu2 = him10 # asm 1: ldr >hiu2=int32#6,<him10=stack32#26 # asm 2: ldr >hiu2=r5,<him10=[sp,#100] # copy-collector input: ldr r5,[sp,#100] # qhasm: lou3 = lom11 # asm 1: ldr >lou3=int32#7,<lom11=stack32#27 # asm 2: ldr >lou3=r6,<lom11=[sp,#104] # copy-collector input: ldr r6,[sp,#104] # qhasm: hiu3 = him11 # asm 1: ldr >hiu3=int32#8,<him11=stack32#28 # asm 2: ldr >hiu3=r7,<him11=[sp,#108] # copy-collector input: ldr r7,[sp,#108] # qhasm: lod8 = lou0 # asm 1: vmov >lod8=float32#17,<lou0=int32#1 # asm 2: vmov >lod8=s16,<lou0=r0 # copy-collector input: vmov s16,r0 # qhasm: hid8 = hiu0 # asm 1: vmov >hid8=float32#18,<hiu0=int32#2 # asm 2: vmov >hid8=s17,<hiu0=r1 # copy-collector input: vmov s17,r1 # qhasm: lod9 = lou1 # asm 1: vmov >lod9=float32#19,<lou1=int32#3 # asm 2: vmov >lod9=s18,<lou1=r2 # copy-collector input: vmov s18,r2 # qhasm: hid9 = hiu1 # asm 1: vmov >hid9=float32#20,<hiu1=int32#4 # asm 2: vmov >hid9=s19,<hiu1=r3 # copy-collector input: vmov s19,r3 # qhasm: lod10 = lou2 # asm 1: vmov >lod10=float32#21,<lou2=int32#5 # asm 2: vmov >lod10=s20,<lou2=r4 # copy-collector input: vmov s20,r4 # qhasm: hid10 = hiu2 # asm 1: vmov >hid10=float32#22,<hiu2=int32#6 # asm 2: vmov >hid10=s21,<hiu2=r5 # copy-collector input: vmov s21,r5 # qhasm: lod11 = lou3 # asm 1: vmov >lod11=float32#23,<lou3=int32#7 # asm 2: vmov >lod11=s22,<lou3=r6 # copy-collector input: vmov s22,r6 # qhasm: hid11 = hiu3 # asm 1: vmov >hid11=float32#24,<hiu3=int32#8 # asm 2: vmov >hid11=s23,<hiu3=r7 # copy-collector input: vmov s23,r7 # qhasm: lou0 = lom12 # asm 1: ldr >lou0=int32#1,<lom12=stack32#29 # asm 2: ldr >lou0=r0,<lom12=[sp,#112] # copy-collector input: ldr r0,[sp,#112] # qhasm: hiu0 = him12 # asm 1: ldr >hiu0=int32#2,<him12=stack32#30 # asm 2: ldr >hiu0=r1,<him12=[sp,#116] # copy-collector input: ldr r1,[sp,#116] # qhasm: lou1 = lom13 # asm 1: ldr >lou1=int32#3,<lom13=stack32#31 # asm 2: ldr >lou1=r2,<lom13=[sp,#120] # copy-collector input: ldr r2,[sp,#120] # qhasm: hiu1 = him13 # asm 1: ldr >hiu1=int32#4,<him13=stack32#32 # asm 2: ldr >hiu1=r3,<him13=[sp,#124] # copy-collector input: ldr r3,[sp,#124] # qhasm: lou2 = lom14 # asm 1: ldr >lou2=int32#5,<lom14=stack32#33 # asm 2: ldr >lou2=r4,<lom14=[sp,#128] # copy-collector input: ldr r4,[sp,#128] # qhasm: hiu2 = him14 # asm 1: ldr >hiu2=int32#6,<him14=stack32#34 # asm 2: ldr >hiu2=r5,<him14=[sp,#132] # copy-collector input: ldr r5,[sp,#132] # qhasm: lou3 = lom15 # asm 1: ldr >lou3=int32#7,<lom15=stack32#35 # asm 2: ldr >lou3=r6,<lom15=[sp,#136] # copy-collector input: ldr r6,[sp,#136] # qhasm: hiu3 = him15 # asm 1: ldr >hiu3=int32#8,<him15=stack32#36 # asm 2: ldr >hiu3=r7,<him15=[sp,#140] # copy-collector input: ldr r7,[sp,#140] # qhasm: lod12 = lou0 # asm 1: vmov >lod12=float32#25,<lou0=int32#1 # asm 2: vmov >lod12=s24,<lou0=r0 # copy-collector input: vmov s24,r0 # qhasm: hid12 = hiu0 # asm 1: vmov >hid12=float32#26,<hiu0=int32#2 # asm 2: vmov >hid12=s25,<hiu0=r1 # copy-collector input: vmov s25,r1 # qhasm: lod13 = lou1 # asm 1: vmov >lod13=float32#27,<lou1=int32#3 # asm 2: vmov >lod13=s26,<lou1=r2 # copy-collector input: vmov s26,r2 # qhasm: hid13 = hiu1 # asm 1: vmov >hid13=float32#28,<hiu1=int32#4 # asm 2: vmov >hid13=s27,<hiu1=r3 # copy-collector input: vmov s27,r3 # qhasm: lod14 = lou2 # asm 1: vmov >lod14=float32#29,<lou2=int32#5 # asm 2: vmov >lod14=s28,<lou2=r4 # copy-collector input: vmov s28,r4 # qhasm: hid14 = hiu2 # asm 1: vmov >hid14=float32#30,<hiu2=int32#6 # asm 2: vmov >hid14=s29,<hiu2=r5 # copy-collector input: vmov s29,r5 # qhasm: lod15 = lou3 # asm 1: vmov >lod15=float32#31,<lou3=int32#7 # asm 2: vmov >lod15=s30,<lou3=r6 # copy-collector input: vmov s30,r6 # qhasm: hid15 = hiu3 # asm 1: vmov >hid15=float32#32,<hiu3=int32#8 # asm 2: vmov >hid15=s31,<hiu3=r7 # copy-collector input: vmov s31,r7 # qhasm: goto innerloop # copy-collector output starts ldr r0,[sp,#80] ldr r1,[sp,#84] ldr r2,[sp,#88] ldr r3,[sp,#92] ldr r4,[sp,#96] ldr r5,[sp,#100] ldr r6,[sp,#104] ldr r7,[sp,#108] vmov d8,r0,r1 vmov d9,r2,r3 vmov d10,r4,r5 vmov d11,r6,r7 ldr r0,[sp,#112] ldr r1,[sp,#116] ldr r2,[sp,#120] ldr r3,[sp,#124] ldr r4,[sp,#128] ldr r5,[sp,#132] ldr r6,[sp,#136] ldr r7,[sp,#140] vmov d12,r0,r1 vmov d13,r2,r3 vmov d14,r4,r5 vmov d15,r6,r7 # copy-collector output ends b ._innerloop # qhasm: endinnerloop: ._endinnerloop: # qhasm: input_0 = o3 # asm 1: ldr >input_0=int32#1,<o3=stack32#4 # asm 2: ldr >input_0=r0,<o3=[sp,#12] # copy-collector input: ldr r0,[sp,#12] # qhasm: input_0 -= 640 # asm 1: sub >input_0=int32#1,<input_0=int32#1,#640 # asm 2: sub >input_0=r0,<input_0=r0,#640 # copy-collector output starts ldr r0,[sp,#12] # copy-collector output ends sub r0,r0,#640 # qhasm: o3 = input_0 # asm 1: str <input_0=int32#1,>o3=stack32#4 # asm 2: str <input_0=r0,>o3=[sp,#12] # copy-collector input: str r0,[sp,#12] # qhasm: lou0 = lod0 # asm 1: vmov >lou0=int32#1,<lod0=float32#1 # asm 2: vmov >lou0=r0,<lod0=s0 # copy-collector input: vmov r0,s0 # qhasm: hiu0 = hid0 # asm 1: vmov >hiu0=int32#2,<hid0=float32#2 # asm 2: vmov >hiu0=r1,<hid0=s1 # copy-collector input: vmov r1,s1 # qhasm: lou1 = lod1 # asm 1: vmov >lou1=int32#3,<lod1=float32#3 # asm 2: vmov >lou1=r2,<lod1=s2 # copy-collector input: vmov r2,s2 # qhasm: hiu1 = hid1 # asm 1: vmov >hiu1=int32#4,<hid1=float32#4 # asm 2: vmov >hiu1=r3,<hid1=s3 # copy-collector input: vmov r3,s3 # qhasm: lou2 = lod2 # asm 1: vmov >lou2=int32#5,<lod2=float32#5 # asm 2: vmov >lou2=r4,<lod2=s4 # copy-collector input: vmov r4,s4 # qhasm: hiu2 = hid2 # asm 1: vmov >hiu2=int32#6,<hid2=float32#6 # asm 2: vmov >hiu2=r5,<hid2=s5 # copy-collector input: vmov r5,s5 # qhasm: lou3 = lod3 # asm 1: vmov >lou3=int32#7,<lod3=float32#7 # asm 2: vmov >lou3=r6,<lod3=s6 # copy-collector input: vmov r6,s6 # qhasm: hiu3 = hid3 # asm 1: vmov >hiu3=int32#8,<hid3=float32#8 # asm 2: vmov >hiu3=r7,<hid3=s7 # copy-collector input: vmov r7,s7 # qhasm: lotmp = lom0 # asm 1: ldr >lotmp=int32#9,<lom0=stack32#5 # asm 2: ldr >lotmp=r8,<lom0=[sp,#16] # copy-collector input: ldr r8,[sp,#16] # qhasm: hitmp = him0 # asm 1: ldr >hitmp=int32#10,<him0=stack32#6 # asm 2: ldr >hitmp=r9,<him0=[sp,#20] # copy-collector input: ldr r9,[sp,#20] # qhasm: carry? lou0 += lotmp # asm 1: adds >lou0=int32#1,<lou0=int32#1,<lotmp=int32#9 # asm 2: adds >lou0=r0,<lou0=r0,<lotmp=r8 # copy-collector output starts str r0,[sp,#12] vmov r0,r1,d0 vmov r2,r3,d1 vmov r4,r5,d2 vmov r6,r7,d3 ldrd r8,r9,[sp,#16] # copy-collector output ends adds r0,r0,r8 # qhasm: hiu0 += hitmp + carry # asm 1: adc >hiu0=int32#2,<hiu0=int32#2,<hitmp=int32#10 # asm 2: adc >hiu0=r1,<hiu0=r1,<hitmp=r9 adc r1,r1,r9 # qhasm: lotmp = lom1 # asm 1: ldr >lotmp=int32#9,<lom1=stack32#7 # asm 2: ldr >lotmp=r8,<lom1=[sp,#24] # copy-collector input: ldr r8,[sp,#24] # qhasm: hitmp = him1 # asm 1: ldr >hitmp=int32#10,<him1=stack32#8 # asm 2: ldr >hitmp=r9,<him1=[sp,#28] # copy-collector input: ldr r9,[sp,#28] # qhasm: carry? lou1 += lotmp # asm 1: adds >lou1=int32#3,<lou1=int32#3,<lotmp=int32#9 # asm 2: adds >lou1=r2,<lou1=r2,<lotmp=r8 # copy-collector output starts ldrd r8,r9,[sp,#24] # copy-collector output ends adds r2,r2,r8 # qhasm: hiu1 += hitmp + carry # asm 1: adc >hiu1=int32#4,<hiu1=int32#4,<hitmp=int32#10 # asm 2: adc >hiu1=r3,<hiu1=r3,<hitmp=r9 adc r3,r3,r9 # qhasm: lotmp = lom2 # asm 1: ldr >lotmp=int32#9,<lom2=stack32#9 # asm 2: ldr >lotmp=r8,<lom2=[sp,#32] # copy-collector input: ldr r8,[sp,#32] # qhasm: hitmp = him2 # asm 1: ldr >hitmp=int32#10,<him2=stack32#10 # asm 2: ldr >hitmp=r9,<him2=[sp,#36] # copy-collector input: ldr r9,[sp,#36] # qhasm: carry? lou2 += lotmp # asm 1: adds >lou2=int32#5,<lou2=int32#5,<lotmp=int32#9 # asm 2: adds >lou2=r4,<lou2=r4,<lotmp=r8 # copy-collector output starts ldrd r8,r9,[sp,#32] # copy-collector output ends adds r4,r4,r8 # qhasm: hiu2 += hitmp + carry # asm 1: adc >hiu2=int32#6,<hiu2=int32#6,<hitmp=int32#10 # asm 2: adc >hiu2=r5,<hiu2=r5,<hitmp=r9 adc r5,r5,r9 # qhasm: lotmp = lom3 # asm 1: ldr >lotmp=int32#9,<lom3=stack32#11 # asm 2: ldr >lotmp=r8,<lom3=[sp,#40] # copy-collector input: ldr r8,[sp,#40] # qhasm: hitmp = him3 # asm 1: ldr >hitmp=int32#10,<him3=stack32#12 # asm 2: ldr >hitmp=r9,<him3=[sp,#44] # copy-collector input: ldr r9,[sp,#44] # qhasm: carry? lou3 += lotmp # asm 1: adds >lou3=int32#7,<lou3=int32#7,<lotmp=int32#9 # asm 2: adds >lou3=r6,<lou3=r6,<lotmp=r8 # copy-collector output starts ldrd r8,r9,[sp,#40] # copy-collector output ends adds r6,r6,r8 # qhasm: hiu3 += hitmp + carry # asm 1: adc >hiu3=int32#8,<hiu3=int32#8,<hitmp=int32#10 # asm 2: adc >hiu3=r7,<hiu3=r7,<hitmp=r9 adc r7,r7,r9 # qhasm: lom0 = lou0 # asm 1: str <lou0=int32#1,>lom0=stack32#5 # asm 2: str <lou0=r0,>lom0=[sp,#16] # copy-collector input: str r0,[sp,#16] # qhasm: him0 = hiu0 # asm 1: str <hiu0=int32#2,>him0=stack32#6 # asm 2: str <hiu0=r1,>him0=[sp,#20] # copy-collector input: str r1,[sp,#20] # qhasm: lom1 = lou1 # asm 1: str <lou1=int32#3,>lom1=stack32#7 # asm 2: str <lou1=r2,>lom1=[sp,#24] # copy-collector input: str r2,[sp,#24] # qhasm: him1 = hiu1 # asm 1: str <hiu1=int32#4,>him1=stack32#8 # asm 2: str <hiu1=r3,>him1=[sp,#28] # copy-collector input: str r3,[sp,#28] # qhasm: lom2 = lou2 # asm 1: str <lou2=int32#5,>lom2=stack32#9 # asm 2: str <lou2=r4,>lom2=[sp,#32] # copy-collector input: str r4,[sp,#32] # qhasm: him2 = hiu2 # asm 1: str <hiu2=int32#6,>him2=stack32#10 # asm 2: str <hiu2=r5,>him2=[sp,#36] # copy-collector input: str r5,[sp,#36] # qhasm: lom3 = lou3 # asm 1: str <lou3=int32#7,>lom3=stack32#11 # asm 2: str <lou3=r6,>lom3=[sp,#40] # copy-collector input: str r6,[sp,#40] # qhasm: him3 = hiu3 # asm 1: str <hiu3=int32#8,>him3=stack32#12 # asm 2: str <hiu3=r7,>him3=[sp,#44] # copy-collector input: str r7,[sp,#44] # qhasm: lod0 = lou0 # asm 1: vmov >lod0=float32#1,<lou0=int32#1 # asm 2: vmov >lod0=s0,<lou0=r0 # copy-collector input: vmov s0,r0 # qhasm: hid0 = hiu0 # asm 1: vmov >hid0=float32#2,<hiu0=int32#2 # asm 2: vmov >hid0=s1,<hiu0=r1 # copy-collector input: vmov s1,r1 # qhasm: lod1 = lou1 # asm 1: vmov >lod1=float32#3,<lou1=int32#3 # asm 2: vmov >lod1=s2,<lou1=r2 # copy-collector input: vmov s2,r2 # qhasm: hid1 = hiu1 # asm 1: vmov >hid1=float32#4,<hiu1=int32#4 # asm 2: vmov >hid1=s3,<hiu1=r3 # copy-collector input: vmov s3,r3 # qhasm: lod2 = lou2 # asm 1: vmov >lod2=float32#5,<lou2=int32#5 # asm 2: vmov >lod2=s4,<lou2=r4 # copy-collector input: vmov s4,r4 # qhasm: hid2 = hiu2 # asm 1: vmov >hid2=float32#6,<hiu2=int32#6 # asm 2: vmov >hid2=s5,<hiu2=r5 # copy-collector input: vmov s5,r5 # qhasm: lod3 = lou3 # asm 1: vmov >lod3=float32#7,<lou3=int32#7 # asm 2: vmov >lod3=s6,<lou3=r6 # copy-collector input: vmov s6,r6 # qhasm: hid3 = hiu3 # asm 1: vmov >hid3=float32#8,<hiu3=int32#8 # asm 2: vmov >hid3=s7,<hiu3=r7 # copy-collector input: vmov s7,r7 # qhasm: lou0 = lod4 # asm 1: vmov >lou0=int32#1,<lod4=float32#9 # asm 2: vmov >lou0=r0,<lod4=s8 # copy-collector input: vmov r0,s8 # qhasm: hiu0 = hid4 # asm 1: vmov >hiu0=int32#2,<hid4=float32#10 # asm 2: vmov >hiu0=r1,<hid4=s9 # copy-collector input: vmov r1,s9 # qhasm: lou1 = lod5 # asm 1: vmov >lou1=int32#3,<lod5=float32#11 # asm 2: vmov >lou1=r2,<lod5=s10 # copy-collector input: vmov r2,s10 # qhasm: hiu1 = hid5 # asm 1: vmov >hiu1=int32#4,<hid5=float32#12 # asm 2: vmov >hiu1=r3,<hid5=s11 # copy-collector input: vmov r3,s11 # qhasm: lou2 = lod6 # asm 1: vmov >lou2=int32#5,<lod6=float32#13 # asm 2: vmov >lou2=r4,<lod6=s12 # copy-collector input: vmov r4,s12 # qhasm: hiu2 = hid6 # asm 1: vmov >hiu2=int32#6,<hid6=float32#14 # asm 2: vmov >hiu2=r5,<hid6=s13 # copy-collector input: vmov r5,s13 # qhasm: lou3 = lod7 # asm 1: vmov >lou3=int32#7,<lod7=float32#15 # asm 2: vmov >lou3=r6,<lod7=s14 # copy-collector input: vmov r6,s14 # qhasm: hiu3 = hid7 # asm 1: vmov >hiu3=int32#8,<hid7=float32#16 # asm 2: vmov >hiu3=r7,<hid7=s15 # copy-collector input: vmov r7,s15 # qhasm: lotmp = lom4 # asm 1: ldr >lotmp=int32#9,<lom4=stack32#13 # asm 2: ldr >lotmp=r8,<lom4=[sp,#48] # copy-collector input: ldr r8,[sp,#48] # qhasm: hitmp = him4 # asm 1: ldr >hitmp=int32#10,<him4=stack32#14 # asm 2: ldr >hitmp=r9,<him4=[sp,#52] # copy-collector input: ldr r9,[sp,#52] # qhasm: carry? lou0 += lotmp # asm 1: adds >lou0=int32#1,<lou0=int32#1,<lotmp=int32#9 # asm 2: adds >lou0=r0,<lou0=r0,<lotmp=r8 # copy-collector output starts strd r0,r1,[sp,#16] strd r2,r3,[sp,#24] strd r4,r5,[sp,#32] strd r6,r7,[sp,#40] vmov d0,r0,r1 vmov d1,r2,r3 vmov d2,r4,r5 vmov d3,r6,r7 vmov r0,r1,d4 vmov r2,r3,d5 vmov r4,r5,d6 vmov r6,r7,d7 ldrd r8,r9,[sp,#48] # copy-collector output ends adds r0,r0,r8 # qhasm: hiu0 += hitmp + carry # asm 1: adc >hiu0=int32#2,<hiu0=int32#2,<hitmp=int32#10 # asm 2: adc >hiu0=r1,<hiu0=r1,<hitmp=r9 adc r1,r1,r9 # qhasm: lotmp = lom5 # asm 1: ldr >lotmp=int32#9,<lom5=stack32#15 # asm 2: ldr >lotmp=r8,<lom5=[sp,#56] # copy-collector input: ldr r8,[sp,#56] # qhasm: hitmp = him5 # asm 1: ldr >hitmp=int32#10,<him5=stack32#16 # asm 2: ldr >hitmp=r9,<him5=[sp,#60] # copy-collector input: ldr r9,[sp,#60] # qhasm: carry? lou1 += lotmp # asm 1: adds >lou1=int32#3,<lou1=int32#3,<lotmp=int32#9 # asm 2: adds >lou1=r2,<lou1=r2,<lotmp=r8 # copy-collector output starts ldrd r8,r9,[sp,#56] # copy-collector output ends adds r2,r2,r8 # qhasm: hiu1 += hitmp + carry # asm 1: adc >hiu1=int32#4,<hiu1=int32#4,<hitmp=int32#10 # asm 2: adc >hiu1=r3,<hiu1=r3,<hitmp=r9 adc r3,r3,r9 # qhasm: lotmp = lom6 # asm 1: ldr >lotmp=int32#9,<lom6=stack32#17 # asm 2: ldr >lotmp=r8,<lom6=[sp,#64] # copy-collector input: ldr r8,[sp,#64] # qhasm: hitmp = him6 # asm 1: ldr >hitmp=int32#10,<him6=stack32#18 # asm 2: ldr >hitmp=r9,<him6=[sp,#68] # copy-collector input: ldr r9,[sp,#68] # qhasm: carry? lou2 += lotmp # asm 1: adds >lou2=int32#5,<lou2=int32#5,<lotmp=int32#9 # asm 2: adds >lou2=r4,<lou2=r4,<lotmp=r8 # copy-collector output starts ldrd r8,r9,[sp,#64] # copy-collector output ends adds r4,r4,r8 # qhasm: hiu2 += hitmp + carry # asm 1: adc >hiu2=int32#6,<hiu2=int32#6,<hitmp=int32#10 # asm 2: adc >hiu2=r5,<hiu2=r5,<hitmp=r9 adc r5,r5,r9 # qhasm: lotmp = lom7 # asm 1: ldr >lotmp=int32#9,<lom7=stack32#19 # asm 2: ldr >lotmp=r8,<lom7=[sp,#72] # copy-collector input: ldr r8,[sp,#72] # qhasm: hitmp = him7 # asm 1: ldr >hitmp=int32#10,<him7=stack32#20 # asm 2: ldr >hitmp=r9,<him7=[sp,#76] # copy-collector input: ldr r9,[sp,#76] # qhasm: carry? lou3 += lotmp # asm 1: adds >lou3=int32#7,<lou3=int32#7,<lotmp=int32#9 # asm 2: adds >lou3=r6,<lou3=r6,<lotmp=r8 # copy-collector output starts ldrd r8,r9,[sp,#72] # copy-collector output ends adds r6,r6,r8 # qhasm: hiu3 += hitmp + carry # asm 1: adc >hiu3=int32#8,<hiu3=int32#8,<hitmp=int32#10 # asm 2: adc >hiu3=r7,<hiu3=r7,<hitmp=r9 adc r7,r7,r9 # qhasm: lom4 = lou0 # asm 1: str <lou0=int32#1,>lom4=stack32#13 # asm 2: str <lou0=r0,>lom4=[sp,#48] # copy-collector input: str r0,[sp,#48] # qhasm: him4 = hiu0 # asm 1: str <hiu0=int32#2,>him4=stack32#14 # asm 2: str <hiu0=r1,>him4=[sp,#52] # copy-collector input: str r1,[sp,#52] # qhasm: lom5 = lou1 # asm 1: str <lou1=int32#3,>lom5=stack32#15 # asm 2: str <lou1=r2,>lom5=[sp,#56] # copy-collector input: str r2,[sp,#56] # qhasm: him5 = hiu1 # asm 1: str <hiu1=int32#4,>him5=stack32#16 # asm 2: str <hiu1=r3,>him5=[sp,#60] # copy-collector input: str r3,[sp,#60] # qhasm: lom6 = lou2 # asm 1: str <lou2=int32#5,>lom6=stack32#17 # asm 2: str <lou2=r4,>lom6=[sp,#64] # copy-collector input: str r4,[sp,#64] # qhasm: him6 = hiu2 # asm 1: str <hiu2=int32#6,>him6=stack32#18 # asm 2: str <hiu2=r5,>him6=[sp,#68] # copy-collector input: str r5,[sp,#68] # qhasm: lom7 = lou3 # asm 1: str <lou3=int32#7,>lom7=stack32#19 # asm 2: str <lou3=r6,>lom7=[sp,#72] # copy-collector input: str r6,[sp,#72] # qhasm: him7 = hiu3 # asm 1: str <hiu3=int32#8,>him7=stack32#20 # asm 2: str <hiu3=r7,>him7=[sp,#76] # copy-collector input: str r7,[sp,#76] # qhasm: lod4 = lou0 # asm 1: vmov >lod4=float32#9,<lou0=int32#1 # asm 2: vmov >lod4=s8,<lou0=r0 # copy-collector input: vmov s8,r0 # qhasm: hid4 = hiu0 # asm 1: vmov >hid4=float32#10,<hiu0=int32#2 # asm 2: vmov >hid4=s9,<hiu0=r1 # copy-collector input: vmov s9,r1 # qhasm: lod5 = lou1 # asm 1: vmov >lod5=float32#11,<lou1=int32#3 # asm 2: vmov >lod5=s10,<lou1=r2 # copy-collector input: vmov s10,r2 # qhasm: hid5 = hiu1 # asm 1: vmov >hid5=float32#12,<hiu1=int32#4 # asm 2: vmov >hid5=s11,<hiu1=r3 # copy-collector input: vmov s11,r3 # qhasm: lod6 = lou2 # asm 1: vmov >lod6=float32#13,<lou2=int32#5 # asm 2: vmov >lod6=s12,<lou2=r4 # copy-collector input: vmov s12,r4 # qhasm: hid6 = hiu2 # asm 1: vmov >hid6=float32#14,<hiu2=int32#6 # asm 2: vmov >hid6=s13,<hiu2=r5 # copy-collector input: vmov s13,r5 # qhasm: lod7 = lou3 # asm 1: vmov >lod7=float32#15,<lou3=int32#7 # asm 2: vmov >lod7=s14,<lou3=r6 # copy-collector input: vmov s14,r6 # qhasm: hid7 = hiu3 # asm 1: vmov >hid7=float32#16,<hiu3=int32#8 # asm 2: vmov >hid7=s15,<hiu3=r7 # copy-collector input: vmov s15,r7 # qhasm: input_0 = o2 # asm 1: ldr >input_0=int32#1,<o2=stack32#3 # asm 2: ldr >input_0=r0,<o2=[sp,#8] # copy-collector input: ldr r0,[sp,#8] # qhasm: =? unsigned<? input_0 -= 128 # asm 1: subs >input_0=int32#1,<input_0=int32#1,#128 # asm 2: subs >input_0=r0,<input_0=r0,#128 # copy-collector output starts strd r0,r1,[sp,#48] strd r2,r3,[sp,#56] strd r4,r5,[sp,#64] strd r6,r7,[sp,#72] vmov d4,r0,r1 vmov d5,r2,r3 vmov d6,r4,r5 vmov d7,r6,r7 ldr r0,[sp,#8] # copy-collector output ends subs r0,r0,#128 # qhasm: o2 = input_0 # asm 1: str <input_0=int32#1,>o2=stack32#3 # asm 2: str <input_0=r0,>o2=[sp,#8] # copy-collector input: str r0,[sp,#8] # qhasm: goto mainloop if !unsigned< # copy-collector output starts str r0,[sp,#8] # copy-collector output ends bhs ._mainloop # qhasm: endmainloop: ._endmainloop: # qhasm: input_1 = o0 # asm 1: ldr >input_1=int32#2,<o0=stack32#1 # asm 2: ldr >input_1=r1,<o0=[sp,#0] # copy-collector input: ldr r1,[sp,#0] # qhasm: lou0 = lom0 # asm 1: ldr >lou0=int32#3,<lom0=stack32#5 # asm 2: ldr >lou0=r2,<lom0=[sp,#16] # copy-collector input: ldr r2,[sp,#16] # qhasm: hiu0 = him0 # asm 1: ldr >hiu0=int32#4,<him0=stack32#6 # asm 2: ldr >hiu0=r3,<him0=[sp,#20] # copy-collector input: ldr r3,[sp,#20] # qhasm: lou1 = lom1 # asm 1: ldr >lou1=int32#5,<lom1=stack32#7 # asm 2: ldr >lou1=r4,<lom1=[sp,#24] # copy-collector input: ldr r4,[sp,#24] # qhasm: hiu1 = him1 # asm 1: ldr >hiu1=int32#6,<him1=stack32#8 # asm 2: ldr >hiu1=r5,<him1=[sp,#28] # copy-collector input: ldr r5,[sp,#28] # qhasm: lou2 = lom2 # asm 1: ldr >lou2=int32#7,<lom2=stack32#9 # asm 2: ldr >lou2=r6,<lom2=[sp,#32] # copy-collector input: ldr r6,[sp,#32] # qhasm: hiu2 = him2 # asm 1: ldr >hiu2=int32#8,<him2=stack32#10 # asm 2: ldr >hiu2=r7,<him2=[sp,#36] # copy-collector input: ldr r7,[sp,#36] # qhasm: lou3 = lom3 # asm 1: ldr >lou3=int32#9,<lom3=stack32#11 # asm 2: ldr >lou3=r8,<lom3=[sp,#40] # copy-collector input: ldr r8,[sp,#40] # qhasm: hiu3 = him3 # asm 1: ldr >hiu3=int32#10,<him3=stack32#12 # asm 2: ldr >hiu3=r9,<him3=[sp,#44] # copy-collector input: ldr r9,[sp,#44] # qhasm: lou0 = lou0[3]lou0[2]lou0[1]lou0[0] # asm 1: rev >lou0=int32#3,<lou0=int32#3 # asm 2: rev >lou0=r2,<lou0=r2 # copy-collector output starts ldr r1,[sp,#0] ldr r2,[sp,#16] ldr r3,[sp,#20] ldr r4,[sp,#24] ldr r5,[sp,#28] ldr r6,[sp,#32] ldr r7,[sp,#36] ldr r8,[sp,#40] ldr r9,[sp,#44] # copy-collector output ends rev r2,r2 # qhasm: hiu0 = hiu0[3]hiu0[2]hiu0[1]hiu0[0] # asm 1: rev >hiu0=int32#4,<hiu0=int32#4 # asm 2: rev >hiu0=r3,<hiu0=r3 rev r3,r3 # qhasm: lou1 = lou1[3]lou1[2]lou1[1]lou1[0] # asm 1: rev >lou1=int32#5,<lou1=int32#5 # asm 2: rev >lou1=r4,<lou1=r4 rev r4,r4 # qhasm: hiu1 = hiu1[3]hiu1[2]hiu1[1]hiu1[0] # asm 1: rev >hiu1=int32#6,<hiu1=int32#6 # asm 2: rev >hiu1=r5,<hiu1=r5 rev r5,r5 # qhasm: lou2 = lou2[3]lou2[2]lou2[1]lou2[0] # asm 1: rev >lou2=int32#7,<lou2=int32#7 # asm 2: rev >lou2=r6,<lou2=r6 rev r6,r6 # qhasm: hiu2 = hiu2[3]hiu2[2]hiu2[1]hiu2[0] # asm 1: rev >hiu2=int32#8,<hiu2=int32#8 # asm 2: rev >hiu2=r7,<hiu2=r7 rev r7,r7 # qhasm: lou3 = lou3[3]lou3[2]lou3[1]lou3[0] # asm 1: rev >lou3=int32#9,<lou3=int32#9 # asm 2: rev >lou3=r8,<lou3=r8 rev r8,r8 # qhasm: hiu3 = hiu3[3]hiu3[2]hiu3[1]hiu3[0] # asm 1: rev >hiu3=int32#10,<hiu3=int32#10 # asm 2: rev >hiu3=r9,<hiu3=r9 rev r9,r9 # qhasm: mem32[input_1] = hiu0 # asm 1: str <hiu0=int32#4,[<input_1=int32#2] # asm 2: str <hiu0=r3,[<input_1=r1] # copy-collector input: str r3,[r1] # qhasm: mem32[input_1+4] = lou0 # asm 1: str <lou0=int32#3,[<input_1=int32#2,#4] # asm 2: str <lou0=r2,[<input_1=r1,#4] # copy-collector input: str r2,[r1,#4] # qhasm: mem32[input_1+8] = hiu1 # asm 1: str <hiu1=int32#6,[<input_1=int32#2,#8] # asm 2: str <hiu1=r5,[<input_1=r1,#8] # copy-collector input: str r5,[r1,#8] # qhasm: mem32[input_1+12] = lou1 # asm 1: str <lou1=int32#5,[<input_1=int32#2,#12] # asm 2: str <lou1=r4,[<input_1=r1,#12] # copy-collector input: str r4,[r1,#12] # qhasm: mem32[input_1+16] = hiu2 # asm 1: str <hiu2=int32#8,[<input_1=int32#2,#16] # asm 2: str <hiu2=r7,[<input_1=r1,#16] # copy-collector input: str r7,[r1,#16] # qhasm: mem32[input_1+20] = lou2 # asm 1: str <lou2=int32#7,[<input_1=int32#2,#20] # asm 2: str <lou2=r6,[<input_1=r1,#20] # copy-collector input: str r6,[r1,#20] # qhasm: mem32[input_1+24] = hiu3 # asm 1: str <hiu3=int32#10,[<input_1=int32#2,#24] # asm 2: str <hiu3=r9,[<input_1=r1,#24] # copy-collector input: str r9,[r1,#24] # qhasm: mem32[input_1+28] = lou3 # asm 1: str <lou3=int32#9,[<input_1=int32#2,#28] # asm 2: str <lou3=r8,[<input_1=r1,#28] # copy-collector input: str r8,[r1,#28] # qhasm: lou0 = lom4 # asm 1: ldr >lou0=int32#3,<lom4=stack32#13 # asm 2: ldr >lou0=r2,<lom4=[sp,#48] # copy-collector input: ldr r2,[sp,#48] # qhasm: hiu0 = him4 # asm 1: ldr >hiu0=int32#4,<him4=stack32#14 # asm 2: ldr >hiu0=r3,<him4=[sp,#52] # copy-collector input: ldr r3,[sp,#52] # qhasm: lou1 = lom5 # asm 1: ldr >lou1=int32#5,<lom5=stack32#15 # asm 2: ldr >lou1=r4,<lom5=[sp,#56] # copy-collector input: ldr r4,[sp,#56] # qhasm: hiu1 = him5 # asm 1: ldr >hiu1=int32#6,<him5=stack32#16 # asm 2: ldr >hiu1=r5,<him5=[sp,#60] # copy-collector input: ldr r5,[sp,#60] # qhasm: lou2 = lom6 # asm 1: ldr >lou2=int32#7,<lom6=stack32#17 # asm 2: ldr >lou2=r6,<lom6=[sp,#64] # copy-collector input: ldr r6,[sp,#64] # qhasm: hiu2 = him6 # asm 1: ldr >hiu2=int32#8,<him6=stack32#18 # asm 2: ldr >hiu2=r7,<him6=[sp,#68] # copy-collector input: ldr r7,[sp,#68] # qhasm: lou3 = lom7 # asm 1: ldr >lou3=int32#9,<lom7=stack32#19 # asm 2: ldr >lou3=r8,<lom7=[sp,#72] # copy-collector input: ldr r8,[sp,#72] # qhasm: hiu3 = him7 # asm 1: ldr >hiu3=int32#10,<him7=stack32#20 # asm 2: ldr >hiu3=r9,<him7=[sp,#76] # copy-collector input: ldr r9,[sp,#76] # qhasm: lou0 = lou0[3]lou0[2]lou0[1]lou0[0] # asm 1: rev >lou0=int32#3,<lou0=int32#3 # asm 2: rev >lou0=r2,<lou0=r2 # copy-collector output starts str r3,[r1] str r2,[r1,#4] str r5,[r1,#8] str r4,[r1,#12] str r7,[r1,#16] str r6,[r1,#20] str r9,[r1,#24] str r8,[r1,#28] ldr r2,[sp,#48] ldr r3,[sp,#52] ldr r4,[sp,#56] ldr r5,[sp,#60] ldr r6,[sp,#64] ldr r7,[sp,#68] ldr r8,[sp,#72] ldr r9,[sp,#76] # copy-collector output ends rev r2,r2 # qhasm: hiu0 = hiu0[3]hiu0[2]hiu0[1]hiu0[0] # asm 1: rev >hiu0=int32#4,<hiu0=int32#4 # asm 2: rev >hiu0=r3,<hiu0=r3 rev r3,r3 # qhasm: lou1 = lou1[3]lou1[2]lou1[1]lou1[0] # asm 1: rev >lou1=int32#5,<lou1=int32#5 # asm 2: rev >lou1=r4,<lou1=r4 rev r4,r4 # qhasm: hiu1 = hiu1[3]hiu1[2]hiu1[1]hiu1[0] # asm 1: rev >hiu1=int32#6,<hiu1=int32#6 # asm 2: rev >hiu1=r5,<hiu1=r5 rev r5,r5 # qhasm: lou2 = lou2[3]lou2[2]lou2[1]lou2[0] # asm 1: rev >lou2=int32#7,<lou2=int32#7 # asm 2: rev >lou2=r6,<lou2=r6 rev r6,r6 # qhasm: hiu2 = hiu2[3]hiu2[2]hiu2[1]hiu2[0] # asm 1: rev >hiu2=int32#8,<hiu2=int32#8 # asm 2: rev >hiu2=r7,<hiu2=r7 rev r7,r7 # qhasm: lou3 = lou3[3]lou3[2]lou3[1]lou3[0] # asm 1: rev >lou3=int32#9,<lou3=int32#9 # asm 2: rev >lou3=r8,<lou3=r8 rev r8,r8 # qhasm: hiu3 = hiu3[3]hiu3[2]hiu3[1]hiu3[0] # asm 1: rev >hiu3=int32#10,<hiu3=int32#10 # asm 2: rev >hiu3=r9,<hiu3=r9 rev r9,r9 # qhasm: mem32[input_1+32] = hiu0 # asm 1: str <hiu0=int32#4,[<input_1=int32#2,#32] # asm 2: str <hiu0=r3,[<input_1=r1,#32] # copy-collector input: str r3,[r1,#32] # qhasm: mem32[input_1+36] = lou0 # asm 1: str <lou0=int32#3,[<input_1=int32#2,#36] # asm 2: str <lou0=r2,[<input_1=r1,#36] # copy-collector input: str r2,[r1,#36] # qhasm: mem32[input_1+40] = hiu1 # asm 1: str <hiu1=int32#6,[<input_1=int32#2,#40] # asm 2: str <hiu1=r5,[<input_1=r1,#40] # copy-collector input: str r5,[r1,#40] # qhasm: mem32[input_1+44] = lou1 # asm 1: str <lou1=int32#5,[<input_1=int32#2,#44] # asm 2: str <lou1=r4,[<input_1=r1,#44] # copy-collector input: str r4,[r1,#44] # qhasm: mem32[input_1+48] = hiu2 # asm 1: str <hiu2=int32#8,[<input_1=int32#2,#48] # asm 2: str <hiu2=r7,[<input_1=r1,#48] # copy-collector input: str r7,[r1,#48] # qhasm: mem32[input_1+52] = lou2 # asm 1: str <lou2=int32#7,[<input_1=int32#2,#52] # asm 2: str <lou2=r6,[<input_1=r1,#52] # copy-collector input: str r6,[r1,#52] # qhasm: mem32[input_1+56] = hiu3 # asm 1: str <hiu3=int32#10,[<input_1=int32#2,#56] # asm 2: str <hiu3=r9,[<input_1=r1,#56] # copy-collector input: str r9,[r1,#56] # qhasm: mem32[input_1+60] = lou3 # asm 1: str <lou3=int32#9,[<input_1=int32#2,#60] # asm 2: str <lou3=r8,[<input_1=r1,#60] # copy-collector input: str r8,[r1,#60] # qhasm: input_0 += 128 # asm 1: add >input_0=int32#1,<input_0=int32#1,#128 # asm 2: add >input_0=r0,<input_0=r0,#128 # copy-collector output starts str r3,[r1,#32] str r2,[r1,#36] str r5,[r1,#40] str r4,[r1,#44] str r7,[r1,#48] str r6,[r1,#52] str r9,[r1,#56] str r8,[r1,#60] # copy-collector output ends add r0,r0,#128 # qhasm: popreturn input_0 add.w sp,sp,#160 vpop {d8-d15} pop {r4,r5,r6,r7,r8,r9,r10,r11,r14} bx lr