Detabify. Remove trailing whitespace.

This commit is contained in:
Markus F.X.J. Oberhumer 2010-03-01 01:28:03 +01:00
parent f03f42ca4d
commit 3bc3b3d10e
2 changed files with 314 additions and 312 deletions

View File

@ -113,7 +113,7 @@ L90:
pop %arg1 # ADRU
pop %rcx # JMPU
pop %rcx # breadcrumb size in pages
shl $12,%ecx
shl $12,%ecx
addl %ecx,%arg1l # addr += crumb XXX 4GB
subl %ecx,%arg2l # len -= crumb XXX 4GB
push %rax # &entry

View File

@ -1,5 +1,5 @@
// In LZMA SDK 4.63 file lzma.txt (2008-12-30):
// LZMA SDK is written and placed in the public domain by Igor Pavlov.
// LZMA SDK is written and placed in the public domain by Igor Pavlov.
// The creative expression of this hand compilation into assembly language,
// including (but not limited to) code organization and register assignment,
// remains copyright by John F. Reiser and licensed under GNU Lesser General
@ -82,38 +82,38 @@ Literal= (RepLenCoder + kNumLenProbs)
#define call bl /* subroutine call */
#define symbol mi
#define mo mi
#define symbol mi
#define mo mi
#define mi r0
#define p_in r1
#define t1 r2
#define t0 r3
#define mi r0
#define p_in r1
#define t1 r2
#define t0 r3
#define bit r4
#define i r5
#define state r6
#define Range r7
#define bit r4
#define i r5
#define state r6
#define Range r7
#define inPtr r8
#define outPtr r9
#define prob r10
#define p r11
#define inPtr r8
#define outPtr r9
#define prob r10
#define p r11
#define Code r12
#define Code r12
#define nowPos bit /* temporary only */
#define distance bit
#define numDirectBits bit
#define hibit bit
#define matchB i
#define probLen i
#define probLit i
#define posSlot posState
#define r_posSlot t0
#define nowPos bit /* temporary only */
#define distance bit
#define numDirectBits bit
#define hibit bit
#define matchB i
#define probLen i
#define probLit i
#define posSlot posState
#define r_posSlot t0
#define r_len i
#define r_rep0 p_in
#define r_len i
#define r_rep0 p_in
#define vs r0
vs_ps= 2
@ -123,390 +123,392 @@ vs_lc= 0
#if !defined(PARAMETER_STYLE) /*{*/
#define PARAMETER_STYLE 1
// Possible choices:
// 1 /* 0 bytes; 1-byte encoding of pb,lp,lc [default] */
// 2 /* -24 bytes; 2-byte encoding requires no division */
// 3 /* -32 bytes; separate bytes lc,lp,pb,xx at -4+ probs */
// 1 /* 0 bytes; 1-byte encoding of pb,lp,lc [default] */
// 2 /* -24 bytes; 2-byte encoding requires no division */
// 3 /* -32 bytes; separate bytes lc,lp,pb,xx at -4+ probs */
#endif /*}*/
/* LzmaDecode(r0=vs, r1=inStream, r2=inSize, r3= &inSizeProcessed,
[sp,#0]= outStream, [sp,#4]= outSize, [sp,#8]= &outSizeProcessed)
[sp,#0]= outStream, [sp,#4]= outSize, [sp,#8]= &outSizeProcessed)
*/
LzmaDecode: .globl LzmaDecode
// save &inSizeProcesesed and caller registers
stmdb sp!,{r3, r4,r5,r6,r7, r8,r9,r10,r11, lr}
add r12,r2,r1 // inLim
ldr outPtr,[sp, #10*4 + 0*4] // outStream
ldr r7,[sp, #10*4 + 1*4] // outSize
mov inPtr,r1
add r10,r7,outPtr // outLim
// save &inSizeProcesesed and caller registers
stmdb sp!,{r3, r4,r5,r6,r7, r8,r9,r10,r11, lr}
add r12,r2,r1 // inLim
ldr outPtr,[sp, #10*4 + 0*4] // outStream
ldr r7,[sp, #10*4 + 1*4] // outSize
mov inPtr,r1
add r10,r7,outPtr // outLim
#if 1==PARAMETER_STYLE /*{ [0]: pb*45 + lp*9 + lc */
mov p,vs
ldrb r6,[inPtr],#1
mov p,vs
ldrb r6,[inPtr],#1
mov r4,#0 // r4= pb;
mov r4,#0 // r4= pb;
1:
cmp r6,#45; subhs r6,r6,#45; addhs r4,r4,#1; bhs 1b
cmp r6,#45; subhs r6,r6,#45; addhs r4,r4,#1; bhs 1b
mov r5,#0 // r5= lp;
mov r5,#0 // r5= lp;
1:
cmp r6,#9; subhs r6,r6, #9; addhs r5,r5,#1; bhs 1b // r6= lc;
cmp r6,#9; subhs r6,r6, #9; addhs r5,r5,#1; bhs 1b // r6= lc;
#endif /*}*/
#if 2==PARAMETER_STYLE /*{ [0]: ((lc + lp)<<3) | pb; [1]: (lp<<4) | lc */
mov p,vs
ldrb r4,[inPtr],#1; and r4,r4,#7 // pb
ldrb r6,[inPtr],#1; mov r5,r6,lsr #4 // lp
and r6,r6,#0xf // lc
mov p,vs
ldrb r4,[inPtr],#1; and r4,r4,#7 // pb
ldrb r6,[inPtr],#1; mov r5,r6,lsr #4 // lp
and r6,r6,#0xf // lc
#endif /*}*/
#if 3==PARAMETER_STYLE /*{ lc,lp,pb,xx in separate bytes before probs[] */
add p,vs,#4
ldrb r6,[vs, #vs_lc]
ldrb r5,[vs, #vs_lp]
ldrb r4,[vs, #vs_ps]
add p,vs,#4
ldrb r6,[vs, #vs_lc]
ldrb r5,[vs, #vs_lp]
ldrb r4,[vs, #vs_ps]
#endif /*}*/
#undef vs
add r14,r5,r6 // lp + lc
mvn Range,#0 // ~0
mvn r5,Range,lsl r5 // ~(~0<<lp) == litPosMask
mvn r4,Range,lsl r4 // ~(~0<<ps) == posStateMask
mov r3,#1
mov r2,#1
mov r1,#1
mov r0,#1
stmdb sp!,{r0,r1,r2,r3, r4,r5,r6,r7, r8,r9,r10,r11, r12,r14}
#define rep0 [sp, #0*4]
#define rep1 [sp, #1*4]
#define rep2 [sp, #2*4]
#define rep3 [sp, #3*4]
#define posStateMask [sp, #4*4]
#define litPosMask [sp, #5*4]
#define lc [sp, #6*4]
#define prevB [sp, #7*4]
#define inBuf [sp, #8*4]
#define outBuf [sp, #9*4]
#define outLim [sp, #10*4]
add r14,r5,r6 // lp + lc
mvn Range,#0 // ~0
mvn r5,Range,lsl r5 // ~(~0<<lp) == litPosMask
mvn r4,Range,lsl r4 // ~(~0<<ps) == posStateMask
mov r3,#1
mov r2,#1
mov r1,#1
mov r0,#1
stmdb sp!,{r0,r1,r2,r3, r4,r5,r6,r7, r8,r9,r10,r11, r12,r14}
#define rep0 [sp, #0*4]
#define rep1 [sp, #1*4]
#define rep2 [sp, #2*4]
#define rep3 [sp, #3*4]
#define posStateMask [sp, #4*4]
#define litPosMask [sp, #5*4]
#define lc [sp, #6*4]
#define prevB [sp, #7*4]
#define inBuf [sp, #8*4]
#define outBuf [sp, #9*4]
#define outLim [sp, #10*4]
#define posState [sp, #11*4]
#define inLim [sp, #12*4]
#define m_len [sp, #13*4]
#define inLim [sp, #12*4]
#define m_len [sp, #13*4]
#define inSizeProcessed [sp, #(14 )*4]
#define outSizeProcessed [sp, #(14+10+2)*4]
mov state,#0
str state,prevB
mov state,#0
str state,prevB
mov r2,#LZMA_LIT_SIZE
mov r2,r2, lsl r14 // LZMA_LIT_SIZE << (lp + lc)
add r2,r2,#lo8(LZMA_BASE_SIZE)
add r2,r2,#hi8(LZMA_BASE_SIZE) // nProbs
mov r1,p
mov r0, #(kBitModelTotal>>1)
orr r0,r0,#(kBitModelTotal>>1)<<16
mov r2,#LZMA_LIT_SIZE
mov r2,r2, lsl r14 // LZMA_LIT_SIZE << (lp + lc)
add r2,r2,#lo8(LZMA_BASE_SIZE)
add r2,r2,#hi8(LZMA_BASE_SIZE) // nProbs
mov r1,p
mov r0, #(kBitModelTotal>>1)
orr r0,r0,#(kBitModelTotal>>1)<<16
L10:
str r0,[r1],#4
subs r2,r2,#2; bgt L10
str r0,[r1],#4
subs r2,r2,#2; bgt L10
add r0,inPtr,#5 // sentinel
add r0,inPtr,#5 // sentinel
L14:
call rcInit2; cmp r0,inPtr; bne L14
call rcInit2; cmp r0,inPtr; bne L14
L200: // main loop
ldr t0,outBuf
ldr t1,posStateMask
sub nowPos,outPtr,t0
and mi,nowPos,t1
str mi,posState
add mi,mi,state, lsl #kNumPosBitsMax
add p_in,p,#IsMatch<<1
call rcGetBit_mi0; bne L270
ldr t0,outBuf
ldr t1,posStateMask
sub nowPos,outPtr,t0
and mi,nowPos,t1
str mi,posState
add mi,mi,state, lsl #kNumPosBitsMax
add p_in,p,#IsMatch<<1
call rcGetBit_mi0; bne L270
ldr t0,litPosMask
ldr t1,lc
and t0,t0,nowPos
ldrb mi,prevB
mov t0,t0,lsl t1 // (nowPos & litPosMask)<<lc
rsb t1,t1,#8
add t0,t0,mi,lsr t1 // + (prevB >> (8- lc))
add prob, p,#lo8(Literal<<1)
add t0,t0,t0,lsl #1 // *3
add prob,prob,#hi8(Literal<<1)
mov symbol,#1
add prob,prob,t0,lsl #1+ 8 // *768 *2
ldr t0,litPosMask
ldr t1,lc
and t0,t0,nowPos
ldrb mi,prevB
mov t0,t0,lsl t1 // (nowPos & litPosMask)<<lc
rsb t1,t1,#8
add t0,t0,mi,lsr t1 // + (prevB >> (8- lc))
add prob, p,#lo8(Literal<<1)
add t0,t0,t0,lsl #1 // *3
add prob,prob,#hi8(Literal<<1)
mov symbol,#1
add prob,prob,t0,lsl #1+ 8 // *768 *2
cmp state,#kNumLitStates; blo L240
cmp state,#kNumLitStates; blo L240
L205:
ldr r_rep0,rep0
ldrb matchB,[outPtr, -r_rep0]
ldr r_rep0,rep0
ldrb matchB,[outPtr, -r_rep0]
L210: // symbol === mi === mo
mov matchB,matchB,lsl #1
add p_in,prob,#0x100<<1
and bit,matchB,#0x100
add p_in,p_in,bit,lsl #1
call rcGetBit_mi
and t0,symbol,#1
cmp t0,bit,lsr #8; bne L243 // break
cmp symbol,#0x100; blo L210
b L245
mov matchB,matchB,lsl #1
add p_in,prob,#0x100<<1
and bit,matchB,#0x100
add p_in,p_in,bit,lsl #1
call rcGetBit_mi
and t0,symbol,#1
cmp t0,bit,lsr #8; bne L243 // break
cmp symbol,#0x100; blo L210
b L245
L240: // symbol === mi === mo
mov p_in,prob
call rcGetBit_mi
mov p_in,prob
call rcGetBit_mi
L243:
cmp symbol,#0x100; blo L240
cmp symbol,#0x100; blo L240
L245:
mov t0,#6
cmp state,#10; movlo t0,#3
cmp state,# 4; movlo t0,state
sub state,state,t0
b L298 // assumes symbol===r0
mov t0,#6
cmp state,#10; movlo t0,#3
cmp state,# 4; movlo t0,state
sub state,state,t0
b L298 // assumes symbol===r0
L270:
add p_in,p,#IsRep<<1
call rcGetBit_state0; bne L290
ldr t0,rep2
ldr t1,rep1
ldr r_rep0,rep0
str t0,rep3
str t1,rep2
str r_rep0,rep1
cmp state,#kNumLitStates
mov state,#3
movlo state,#0
add prob, p,#lo8(LenCoder<<1)
add prob,prob,#hi8(LenCoder<<1)
b L350
add p_in,p,#IsRep<<1
call rcGetBit_state0; bne L290
ldr t0,rep2
ldr t1,rep1
ldr r_rep0,rep0
str t0,rep3
str t1,rep2
str r_rep0,rep1
cmp state,#kNumLitStates
mov state,#3
movlo state,#0
add prob, p,#lo8(LenCoder<<1)
add prob,prob,#hi8(LenCoder<<1)
b L350
L290:
add p_in,p,#IsRepG0<<1
call rcGetBit_state0; bne L300
add p_in,p,#IsRepG0<<1
call rcGetBit_state0; bne L300
L293:
ldr t0,posState
add p_in,p,#IsRep0Long<<1
add mi,t0,state,lsl #kNumPosBitsMax
call rcGetBit_mi0; bne L340
ldr t0,posState
add p_in,p,#IsRep0Long<<1
add mi,t0,state,lsl #kNumPosBitsMax
call rcGetBit_mi0; bne L340
L295:
cmp state,#kNumLitStates
mov state,#11
movlo state,#9
cmp state,#kNumLitStates
mov state,#11
movlo state,#9
L297:
ldr t0,outBuf
ldr r_rep0,rep0
sub nowPos,outPtr,t0
cmp nowPos,r_rep0; blo lzmaDataError
ldrb r0,[outPtr, -r_rep0]
ldr t0,outBuf
ldr r_rep0,rep0
sub nowPos,outPtr,t0
cmp nowPos,r_rep0; blo lzmaDataError
ldrb r0,[outPtr, -r_rep0]
L298:
strb r0,[outPtr],#1
b L519
strb r0,[outPtr],#1
b L519
L300:
add p_in,p,#IsRepG1<<1
call rcGetBit_state0; ldr distance,rep1; beq L330
add p_in,p,#IsRepG1<<1
call rcGetBit_state0; ldr distance,rep1; beq L330
L310:
add p_in,p,#IsRepG2<<1
call rcGetBit_state0; ldr distance,rep2; beq L325
add p_in,p,#IsRepG2<<1
call rcGetBit_state0; ldr distance,rep2; beq L325
L320:
ldr t0,rep2
ldr distance,rep3
str t0,rep3
ldr t0,rep2
ldr distance,rep3
str t0,rep3
L325:
ldr t0,rep1
str t0,rep2
ldr t0,rep1
str t0,rep2
L330:
ldr r_rep0,rep0
str distance,rep0
str r_rep0,rep1
ldr r_rep0,rep0
str distance,rep0
str r_rep0,rep1
L340:
cmp state,#kNumLitStates
mov state,#11
movlo state,#8
add prob, p,#lo8(RepLenCoder<<1)
add prob,prob,#hi8(RepLenCoder<<1)
cmp state,#kNumLitStates
mov state,#11
movlo state,#8
add prob, p,#lo8(RepLenCoder<<1)
add prob,prob,#hi8(RepLenCoder<<1)
L350:
add p_in,prob,#LenChoice<<1
call rcGetBit_0; bne L360
ldr t0,posState
add probLen,prob,#LenLow<<1
mov t1,#0
add probLen,probLen,t0,lsl #1+ kLenNumLowBits
mov hibit,#1<<kLenNumLowBits
b L390
add p_in,prob,#LenChoice<<1
call rcGetBit_0; bne L360
ldr t0,posState
add probLen,prob,#LenLow<<1
mov t1,#0
add probLen,probLen,t0,lsl #1+ kLenNumLowBits
mov hibit,#1<<kLenNumLowBits
b L390
L360:
add p_in,prob,#LenChoice2<<1
call rcGetBit_0; bne L370
ldr t0,posState
add probLen,prob,#LenMid<<1
mov t1,#kLenNumLowSymbols
add probLen,probLen,t0,lsl #1+ kLenNumMidBits
mov hibit,#1<<kLenNumMidBits
b L390
add p_in,prob,#LenChoice2<<1
call rcGetBit_0; bne L370
ldr t0,posState
add probLen,prob,#LenMid<<1
mov t1,#kLenNumLowSymbols
add probLen,probLen,t0,lsl #1+ kLenNumMidBits
mov hibit,#1<<kLenNumMidBits
b L390
L370:
add probLen,prob,#LenHigh<<1
mov t1,#kLenNumLowSymbols + kLenNumMidSymbols
mov hibit,$1<<kLenNumHighBits
add probLen,prob,#LenHigh<<1
mov t1,#kLenNumLowSymbols + kLenNumMidSymbols
mov hibit,$1<<kLenNumHighBits
L390:
str t1,m_len
mov mi,#1
str t1,m_len
mov mi,#1
L395: // RangeDecoderBitTreeDecode
mov p_in,probLen
call rcGetBit_mi; subs t0,mo,hibit; blo L395
ldr r_len,m_len
add r_len,r_len,t0
str r_len,m_len
ldr r_rep0,rep0 // rep0 in register from L400 to L500(L510)
cmp state,#4; bhs L500
mov p_in,probLen
call rcGetBit_mi; subs t0,mo,hibit; blo L395
ldr r_len,m_len
add r_len,r_len,t0
str r_len,m_len
ldr r_rep0,rep0 // rep0 in register from L400 to L500(L510)
cmp state,#4; bhs L500
/*L400:*/
add state,state,#kNumLitStates
cmp r_len,#kNumLenToPosStates
movhs r_len,#kNumLenToPosStates -1
add probLit,p,r_len,lsl #1+ kNumPosSlotBits
add probLit,probLit,#PosSlot<<1
mov mi,#1
mov hibit,#1<<kNumPosSlotBits
add state,state,#kNumLitStates
cmp r_len,#kNumLenToPosStates
movhs r_len,#kNumLenToPosStates -1
add probLit,p,r_len,lsl #1+ kNumPosSlotBits
add probLit,probLit,#PosSlot<<1
mov mi,#1
mov hibit,#1<<kNumPosSlotBits
L403: // RangeDecoderBitTreeDecode
mov p_in,probLit
call rcGetBit_mi; subs r_posSlot,mo,hibit; blo L403
str r_posSlot,posSlot
mov p_in,probLit
call rcGetBit_mi; subs r_posSlot,mo,hibit; blo L403
str r_posSlot,posSlot
cmp r_posSlot,#kStartPosModelIndex; blo L460
cmp r_posSlot,#kStartPosModelIndex; blo L460
L405:
mov numDirectBits,r_posSlot,lsr #1
sub numDirectBits,numDirectBits,#1
and r_rep0,r_posSlot,#1
orr r_rep0,r_rep0,#2
cmp r_posSlot,#kEndPosModelIndex; bhs L410
mov numDirectBits,r_posSlot,lsr #1
sub numDirectBits,numDirectBits,#1
and r_rep0,r_posSlot,#1
orr r_rep0,r_rep0,#2
cmp r_posSlot,#kEndPosModelIndex; bhs L410
L407:
mov r_rep0,r_rep0,lsl numDirectBits
add prob,p, #lo8((SpecPos -1)<<1)
sub t0,r_rep0,r_posSlot // r_posSlot dies
add prob,prob,#hi8((SpecPos -1)<<1)
add prob,prob,t0,lsl #1
b L438
mov r_rep0,r_rep0,lsl numDirectBits
add prob,p, #lo8((SpecPos -1)<<1)
sub t0,r_rep0,r_posSlot // r_posSlot dies
add prob,prob,#hi8((SpecPos -1)<<1)
add prob,prob,t0,lsl #1
b L438
L410:
sub numDirectBits,numDirectBits,#kNumAlignBits
sub numDirectBits,numDirectBits,#kNumAlignBits
L420:
call rcNormalize
mov Range,Range,lsr #1
cmp Code,Range
subhs Code,Code,Range // if (Code>=Range) Code-=Range;
adc r_rep0,r_rep0,r_rep0 // r_rep0 = (r_rep0<<1) + (Code>=Range)
call rcNormalize
mov Range,Range,lsr #1
cmp Code,Range
subhs Code,Code,Range // if (Code>=Range) Code-=Range;
adc r_rep0,r_rep0,r_rep0 // r_rep0 = (r_rep0<<1) + (Code>=Range)
L430:
subs numDirectBits,numDirectBits,#1; bne L420
add prob,p, #lo8(Align<<1)
add prob,prob,#hi8(Align<<1)
mov r_rep0,r_rep0,lsl #kNumAlignBits
mov numDirectBits,#kNumAlignBits
subs numDirectBits,numDirectBits,#1; bne L420
add prob,p, #lo8(Align<<1)
add prob,prob,#hi8(Align<<1)
mov r_rep0,r_rep0,lsl #kNumAlignBits
mov numDirectBits,#kNumAlignBits
L438:
str r_rep0,rep0
mov i,#1
mov mi,#1
str r_rep0,rep0
mov i,#1
mov mi,#1
L440:
mov p_in,prob; call rcGetBit_mi
tst mo,#1; beq L445
ldr r_rep0,rep0
orr r_rep0,r_rep0,i
str r_rep0,rep0
mov p_in,prob; call rcGetBit_mi
tst mo,#1; beq L445
ldr r_rep0,rep0
orr r_rep0,r_rep0,i
str r_rep0,rep0
L445:
mov i,i,lsl #1
subs numDirectBits,numDirectBits,#1; bne L440
ldr r_rep0,rep0
b L465
mov i,i,lsl #1
subs numDirectBits,numDirectBits,#1; bne L440
ldr r_rep0,rep0
b L465
L450:
L460:
ldr r_rep0,posSlot
ldr r_rep0,posSlot
L465:
adds r_rep0,r_rep0,#1
adds r_rep0,r_rep0,#1
#if 0 /*{ only for the stream version */
bne L470
mov t0,#kLzmaStreamWasFinishedId
str t0,m_len
b L530
bne L470
mov t0,#kLzmaStreamWasFinishedId
str t0,m_len
b L530
L470:
#endif /*}*/
str r_rep0,rep0
ldr r_len,m_len
str r_rep0,rep0
ldr r_len,m_len
L500:
ldr t0,outBuf
add r_len,r_len,#kMatchMinLen
sub t0,outPtr,t0 // nowPos
cmp r_rep0,t0; bhi lzmaDataError
ldr t1,outLim
ldr t0,outBuf
add r_len,r_len,#kMatchMinLen
sub t0,outPtr,t0 // nowPos
cmp r_rep0,t0; bhi lzmaDataError
ldr t1,outLim
L510:
ldrb r0,[outPtr, -r_rep0]
strb r0,[outPtr],#1
cmp outPtr,t1; bhs L530
subs r_len,r_len,#1; bne L510
ldrb r0,[outPtr, -r_rep0]
strb r0,[outPtr],#1
cmp outPtr,t1; bhs L530
subs r_len,r_len,#1; bne L510
#if HAS_ARM_PLD /*{*/
pld [outPtr,#32] // fetch next cache line
pld [outPtr,#32] // fetch next cache line
#endif /*}*/
L519:
strb r0,prevB // implicit &0xFF
strb r0,prevB // implicit &0xFF
L520: // bottom of while loop
ldr t1,outLim
cmp outPtr,t1; blo L200
ldr t1,outLim
cmp outPtr,t1; blo L200
L530:
call rcNormalize
mov r0,#0 // success
call rcNormalize
mov r0,#0 // success
lzmaExit:
ldr t1,inBuf
sub t0,inPtr,t1
ldr t1,inSizeProcessed
str t0,[t1]
ldr t1,inBuf
sub t0,inPtr,t1
ldr t1,inSizeProcessed
str t0,[t1]
ldr t1,outBuf
sub t0,outPtr,t1
ldr t1,outSizeProcessed
str t0,[t1]
ldr t1,outBuf
sub t0,outPtr,t1
ldr t1,outSizeProcessed
str t0,[t1]
add sp,sp,#(14+1)*4
ldmia sp!,{r4,r5,r6,r7, r8,r9,r10,r11, pc}
add sp,sp,#(14+1)*4
ldmia sp!,{r4,r5,r6,r7, r8,r9,r10,r11, pc}
lzmaDataError:
mov r0,#1 // failure
b lzmaExit
mov r0,#1 // failure
b lzmaExit
rcNormalize:
cmp Range,#kTopValue
movhs pc,lr
cmp Range,#kTopValue
movhs pc,lr
rcLoad:
ldr t0,inLim
mov Range,Range, lsl #8
cmp t0,inPtr
beq lzmaDataError
ldr t0,inLim
mov Range,Range, lsl #8
cmp t0,inPtr
beq lzmaDataError
rcInit2:
ldrb t0,[inPtr],#1
orr Code,t0,Code, lsl #8
mov pc,lr
ldrb t0,[inPtr],#1
orr Code,t0,Code, lsl #8
mov pc,lr
rcGetBit_state0: // rcGetBit(0, state + p_in)
mov mi,state
mov mi,state
rcGetBit_mi0: // rcGetBit(0, mi + p_in)
add p_in,p_in,mi, lsl #1
add p_in,p_in,mi, lsl #1
rcGetBit_0: // rcGetBit(0, p_in)
mov mi,#0
mov mi,#0
rcGetBit_mi: // rcGetBit(mi, mi + p_in)
add p_in,p_in,mi, lsl #1
add p_in,p_in,mi, lsl #1
rcGetBit: // Out: CC set on mo
cmp Range,#kTopValue
mov t1,lr
bllo rcLoad // conditional subroutine call
cmp Range,#kTopValue
mov t1,lr
bllo rcLoad // conditional subroutine call
#define starp t0
#define bound lr
#define y0tmp lr
ldrh starp,[p_in]
mov y0tmp,Range, lsr #kNumBitModelTotalBits
mul bound,starp,y0tmp
cmp Code,bound
movlo Range, bound
subhs Range,Range,bound
rsblo y0tmp,starp,#kBitModelTotal
subhs Code, Code, bound
addlo starp,starp,y0tmp, lsr #kNumMoveBits
subhs starp,starp,starp, lsr #kNumMoveBits
adcs mo,mi,mi // mo = (mi<<1) | (Code >= bound); set CC
strh starp,[p_in]
ldrh starp,[p_in]
mov y0tmp,Range, lsr #kNumBitModelTotalBits
mul bound,starp,y0tmp
cmp Code,bound
movlo Range, bound
subhs Range,Range,bound
rsblo y0tmp,starp,#kBitModelTotal
subhs Code, Code, bound
addlo starp,starp,y0tmp, lsr #kNumMoveBits
subhs starp,starp,starp, lsr #kNumMoveBits
adcs mo,mi,mi // mo = (mi<<1) | (Code >= bound); set CC
strh starp,[p_in]
#undef y0tmp
#undef bound
#undef starp
mov pc,t1
mov pc,t1
// vi:ts=8:et