Coverage Report

Created: 2026-05-04 06:08

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/libhtp/htp/lzma/LzmaDec.c
Line
Count
Source
1
/* LzmaDec.c -- LZMA Decoder
2
2018-07-04 : Igor Pavlov : Public domain */
3
4
#include "Precomp.h"
5
6
#include <string.h>
7
#include <stdlib.h>
8
#include <stdint.h>
9
10
/* #include "CpuArch.h" */
11
#include "LzmaDec.h"
12
13
817M
#define kNumTopBits 24
14
817M
#define kTopValue ((UInt32)1 << kNumTopBits)
15
16
4.99G
#define kNumBitModelTotalBits 11
17
4.18G
#define kBitModelTotal (1 << kNumBitModelTotalBits)
18
803M
#define kNumMoveBits 5
19
20
91.3k
#define RC_INIT_SIZE 5
21
22
809M
#define NORMALIZE if (range < kTopValue) { range <<= 8; code = (code << 8) | (*buf++); }
23
24
803M
#define IF_BIT_0(p) ttt = *(p); NORMALIZE; bound = (range >> kNumBitModelTotalBits) * (UInt32)ttt; if (code < bound)
25
6.66M
#define UPDATE_0(p) range = bound; *(p) = (CLzmaProb)(ttt + ((kBitModelTotal - ttt) >> kNumMoveBits));
26
797M
#define UPDATE_1(p) range -= bound; code -= bound; *(p) = (CLzmaProb)(ttt - (ttt >> kNumMoveBits));
27
430M
#define GET_BIT2(p, i, A0, A1) IF_BIT_0(p) \
28
430M
  { UPDATE_0(p); i = (i + i); A0; } else \
29
430M
  { UPDATE_1(p); i = (i + i) + 1; A1; }
30
31
430M
#define TREE_GET_BIT(probs, i) { GET_BIT2(probs + i, i, ;, ;); }
32
33
131k
#define REV_BIT(p, i, A0, A1) IF_BIT_0(p + i) \
34
131k
  { UPDATE_0(p + i); A0; } else \
35
131k
  { UPDATE_1(p + i); A1; }
36
49.1k
#define REV_BIT_VAR(  p, i, m) REV_BIT(p, i, i += m; m += m, m += m; i += m; )
37
61.9k
#define REV_BIT_CONST(p, i, m) REV_BIT(p, i, i += m;       , i += m * 2; )
38
20.6k
#define REV_BIT_LAST( p, i, m) REV_BIT(p, i, i -= m        , ; )
39
40
#define TREE_DECODE(probs, limit, i) \
41
424M
  { i = 1; do { TREE_GET_BIT(probs, i); } while (i < limit); i -= limit; }
42
43
/* #define _LZMA_SIZE_OPT */
44
45
#ifdef _LZMA_SIZE_OPT
46
#define TREE_6_DECODE(probs, i) TREE_DECODE(probs, (1 << 6), i)
47
#else
48
#define TREE_6_DECODE(probs, i) \
49
38.8k
  { i = 1; \
50
38.8k
  TREE_GET_BIT(probs, i); \
51
38.8k
  TREE_GET_BIT(probs, i); \
52
38.8k
  TREE_GET_BIT(probs, i); \
53
38.8k
  TREE_GET_BIT(probs, i); \
54
38.8k
  TREE_GET_BIT(probs, i); \
55
38.8k
  TREE_GET_BIT(probs, i); \
56
38.8k
  i -= 0x40; }
57
#endif
58
59
5.25M
#define NORMAL_LITER_DEC TREE_GET_BIT(prob, symbol)
60
#define MATCHED_LITER_DEC \
61
364k
  matchByte += matchByte; \
62
364k
  bit = offs; \
63
364k
  offs &= matchByte; \
64
364k
  probLit = prob + (offs + bit + symbol); \
65
364k
  GET_BIT2(probLit, symbol, offs ^= bit; , ;)
66
67
68
69
8.89M
#define NORMALIZE_CHECK if (range < kTopValue) { if (buf >= bufLimit) return DUMMY_ERROR; range <<= 8; code = (code << 8) | (*buf++); }
70
71
8.23M
#define IF_BIT_0_CHECK(p) ttt = *(p); NORMALIZE_CHECK; bound = (range >> kNumBitModelTotalBits) * (UInt32)ttt; if (code < bound)
72
1.02M
#define UPDATE_0_CHECK range = bound;
73
7.14M
#define UPDATE_1_CHECK range -= bound; code -= bound;
74
4.57M
#define GET_BIT2_CHECK(p, i, A0, A1) IF_BIT_0_CHECK(p) \
75
4.52M
  { UPDATE_0_CHECK; i = (i + i); A0; } else \
76
4.52M
  { UPDATE_1_CHECK; i = (i + i) + 1; A1; }
77
4.36M
#define GET_BIT_CHECK(p, i) GET_BIT2_CHECK(p, i, ; , ;)
78
#define TREE_DECODE_CHECK(probs, limit, i) \
79
3.88M
  { i = 1; do { GET_BIT_CHECK(probs + i, i) } while (i < limit); i -= limit; }
80
81
82
70.1k
#define REV_BIT_CHECK(p, i, m) IF_BIT_0_CHECK(p + i) \
83
67.5k
  { UPDATE_0_CHECK; i += m; m += m; } else \
84
67.5k
  { UPDATE_1_CHECK; m += m; i += m; }
85
86
87
1.13G
#define kNumPosBitsMax 4
88
593M
#define kNumPosStatesMax (1 << kNumPosBitsMax)
89
90
723M
#define kLenNumLowBits 3
91
76.5M
#define kLenNumLowSymbols (1 << kLenNumLowBits)
92
563M
#define kLenNumHighBits 8
93
563M
#define kLenNumHighSymbols (1 << kLenNumHighBits)
94
95
701M
#define LenLow 0
96
593M
#define LenHigh (LenLow + 2 * (kNumPosStatesMax << kLenNumLowBits))
97
540M
#define kNumLenProbs (LenHigh + kLenNumHighSymbols)
98
99
53.6M
#define LenChoice LenLow
100
53.6M
#define LenChoice2 (LenLow + (1 << kLenNumLowBits))
101
102
378M
#define kNumStates 12
103
539M
#define kNumStates2 16
104
54.0M
#define kNumLitStates 7
105
106
63.9k
#define kStartPosModelIndex 4
107
323M
#define kEndPosModelIndex 14
108
323M
#define kNumFullDistances (1 << (kEndPosModelIndex >> 1))
109
110
893k
#define kNumPosSlotBits 6
111
954k
#define kNumLenToPosStates 4
112
113
215M
#define kNumAlignBits 4
114
215M
#define kAlignTableSize (1 << kNumAlignBits)
115
116
76.1M
#define kMatchMinLen 2
117
22.9M
#define kMatchSpecLenStart (kMatchMinLen + kLenNumLowSymbols * 2 + kLenNumHighSymbols)
118
119
/* External ASM code needs same CLzmaProb array layout. So don't change it. */
120
121
/* (probs_1664) is faster and better for code size at some platforms */
122
/*
123
#ifdef MY_CPU_X86_OR_AMD64
124
*/
125
323M
#define kStartOffset 1664
126
5.57M
#define GET_PROBS p->probs_1664
127
/*
128
#define GET_PROBS p->probs + kStartOffset
129
#else
130
#define kStartOffset 0
131
#define GET_PROBS p->probs
132
#endif
133
*/
134
135
323M
#define SpecPos (-kStartOffset)
136
323M
#define IsRep0Long (SpecPos + kNumFullDistances)
137
323M
#define RepLenCoder (IsRep0Long + (kNumStates2 << kNumPosBitsMax))
138
270M
#define LenCoder (RepLenCoder + kNumLenProbs)
139
270M
#define IsMatch (LenCoder + kNumLenProbs)
140
215M
#define Align (IsMatch + (kNumStates2 << kNumPosBitsMax))
141
215M
#define IsRep (Align + kAlignTableSize)
142
161M
#define IsRepG0 (IsRep + kNumStates)
143
108M
#define IsRepG1 (IsRepG0 + kNumStates)
144
54.4M
#define IsRepG2 (IsRepG1 + kNumStates)
145
893k
#define PosSlot (IsRepG2 + kNumStates)
146
824k
#define Literal (PosSlot + (kNumLenToPosStates << kNumPosSlotBits))
147
26.6k
#define NUM_BASE_PROBS (Literal + kStartOffset)
148
149
#if Align != 0 && kStartOffset != 0
150
  #error Stop_Compiling_Bad_LZMA_kAlign
151
#endif
152
153
#if NUM_BASE_PROBS != 1984
154
  #error Stop_Compiling_Bad_LZMA_PROBS
155
#endif
156
157
158
114k
#define LZMA_LIT_SIZE 0x300
159
160
26.6k
#define LzmaProps_GetNumProbs(p) (NUM_BASE_PROBS + ((UInt32)LZMA_LIT_SIZE << ((p)->lc + (p)->lp)))
161
162
163
54.5M
#define CALC_POS_STATE(processedPos, pbMask) (((processedPos) & (pbMask)) << 4)
164
54.5M
#define COMBINED_PS_STATE (posState + state)
165
132k
#define GET_LEN_STATE (posState)
166
167
43.8k
#define LZMA_DIC_MIN (1 << 12)
168
169
/*
170
p->remainLen : shows status of LZMA decoder:
171
    < kMatchSpecLenStart : normal remain
172
    = kMatchSpecLenStart : finished
173
    = kMatchSpecLenStart + 1 : need init range coder
174
    = kMatchSpecLenStart + 2 : need init range coder and state
175
*/
176
177
/* ---------- LZMA_DECODE_REAL ---------- */
178
/*
179
LzmaDec_DecodeReal_3() can be implemented in external ASM file.
180
3 - is the code compatibility version of that function for check at link time.
181
*/
182
183
#define LZMA_DECODE_REAL LzmaDec_DecodeReal_3
184
185
/*
186
LZMA_DECODE_REAL()
187
In:
188
  RangeCoder is normalized
189
  if (p->dicPos == limit)
190
  {
191
    LzmaDec_TryDummy() was called before to exclude LITERAL and MATCH-REP cases.
192
    So first symbol can be only MATCH-NON-REP. And if that MATCH-NON-REP symbol
193
    is not END_OF_PAYALOAD_MARKER, then function returns error code.
194
  }
195
196
Processing:
197
  first LZMA symbol will be decoded in any case
198
  All checks for limits are at the end of main loop,
199
  It will decode new LZMA-symbols while (p->buf < bufLimit && dicPos < limit),
200
  RangeCoder is still without last normalization when (p->buf < bufLimit) is being checked.
201
202
Out:
203
  RangeCoder is normalized
204
  Result:
205
    SZ_OK - OK
206
    SZ_ERROR_DATA - Error
207
  p->remainLen:
208
    < kMatchSpecLenStart : normal remain
209
    = kMatchSpecLenStart : finished
210
*/
211
212
213
#ifdef _LZMA_DEC_OPT
214
215
int MY_FAST_CALL LZMA_DECODE_REAL(CLzmaDec *p, SizeT limit, const Byte *bufLimit);
216
217
#else
218
219
static
220
int MY_FAST_CALL LZMA_DECODE_REAL(CLzmaDec *p, SizeT limit, const Byte *bufLimit)
221
4.94M
{
222
4.94M
  CLzmaProb *probs = GET_PROBS;
223
4.94M
  unsigned state = (unsigned)p->state;
224
4.94M
  UInt32 rep0 = p->reps[0], rep1 = p->reps[1], rep2 = p->reps[2], rep3 = p->reps[3];
225
4.94M
  unsigned pbMask = ((unsigned)1 << (p->prop.pb)) - 1;
226
4.94M
  unsigned lc = p->prop.lc;
227
4.94M
  unsigned lpMask = ((unsigned)0x100 << p->prop.lp) - ((unsigned)0x100 >> lc);
228
229
4.94M
  Byte *dic = p->dic;
230
4.94M
  SizeT dicBufSize = p->dicBufSize;
231
4.94M
  SizeT dicPos = p->dicPos;
232
  
233
4.94M
  UInt32 processedPos = p->processedPos;
234
4.94M
  UInt32 checkDicSize = p->checkDicSize;
235
4.94M
  unsigned len = 0;
236
237
4.94M
  const Byte *buf = p->buf;
238
4.94M
  UInt32 range = p->range;
239
4.94M
  UInt32 code = p->code;
240
241
4.94M
  do
242
53.9M
  {
243
53.9M
    CLzmaProb *prob;
244
53.9M
    UInt32 bound;
245
53.9M
    unsigned ttt;
246
53.9M
    unsigned posState = CALC_POS_STATE(processedPos, pbMask);
247
248
53.9M
    prob = probs + IsMatch + COMBINED_PS_STATE;
249
53.9M
    IF_BIT_0(prob)
250
702k
    {
251
702k
      unsigned symbol;
252
702k
      UPDATE_0(prob);
253
702k
      prob = probs + Literal;
254
702k
      if (processedPos != 0 || checkDicSize != 0)
255
691k
        prob += (UInt32)3 * ((((processedPos << 8) + dic[(dicPos == 0 ? dicBufSize : dicPos) - 1]) & lpMask) << lc);
256
702k
      processedPos++;
257
258
702k
      if (state < kNumLitStates)
259
657k
      {
260
657k
        state -= (state < 4) ? state : 3;
261
657k
        symbol = 1;
262
        #ifdef _LZMA_SIZE_OPT
263
        do { NORMAL_LITER_DEC } while (symbol < 0x100);
264
        #else
265
657k
        NORMAL_LITER_DEC
266
657k
        NORMAL_LITER_DEC
267
657k
        NORMAL_LITER_DEC
268
657k
        NORMAL_LITER_DEC
269
657k
        NORMAL_LITER_DEC
270
657k
        NORMAL_LITER_DEC
271
657k
        NORMAL_LITER_DEC
272
657k
        NORMAL_LITER_DEC
273
657k
        #endif
274
657k
      }
275
45.5k
      else
276
45.5k
      {
277
45.5k
        unsigned matchByte = dic[dicPos - rep0 + (dicPos < rep0 ? dicBufSize : 0)];
278
45.5k
        unsigned offs = 0x100;
279
45.5k
        state -= (state < 10) ? 3 : 6;
280
45.5k
        symbol = 1;
281
        #ifdef _LZMA_SIZE_OPT
282
        do
283
        {
284
          unsigned bit;
285
          CLzmaProb *probLit;
286
          MATCHED_LITER_DEC
287
        }
288
        while (symbol < 0x100);
289
        #else
290
45.5k
        {
291
45.5k
          unsigned bit;
292
45.5k
          CLzmaProb *probLit;
293
45.5k
          MATCHED_LITER_DEC
294
45.5k
          MATCHED_LITER_DEC
295
45.5k
          MATCHED_LITER_DEC
296
45.5k
          MATCHED_LITER_DEC
297
45.5k
          MATCHED_LITER_DEC
298
45.5k
          MATCHED_LITER_DEC
299
45.5k
          MATCHED_LITER_DEC
300
45.5k
          MATCHED_LITER_DEC
301
45.5k
        }
302
45.5k
        #endif
303
45.5k
      }
304
305
702k
      dic[dicPos++] = (Byte)symbol;
306
702k
      continue;
307
702k
    }
308
    
309
53.2M
    {
310
53.2M
      UPDATE_1(prob);
311
53.2M
      prob = probs + IsRep + state;
312
53.2M
      IF_BIT_0(prob)
313
38.8k
      {
314
38.8k
        UPDATE_0(prob);
315
38.8k
        state += kNumStates;
316
38.8k
        prob = probs + LenCoder;
317
38.8k
      }
318
53.1M
      else
319
53.1M
      {
320
53.1M
        UPDATE_1(prob);
321
        /*
322
        // that case was checked before with kBadRepCode
323
        if (checkDicSize == 0 && processedPos == 0)
324
          return SZ_ERROR_DATA;
325
        */
326
53.1M
        prob = probs + IsRepG0 + state;
327
53.1M
        IF_BIT_0(prob)
328
35.0k
        {
329
35.0k
          UPDATE_0(prob);
330
35.0k
          prob = probs + IsRep0Long + COMBINED_PS_STATE;
331
35.0k
          IF_BIT_0(prob)
332
17.0k
          {
333
17.0k
            UPDATE_0(prob);
334
17.0k
            dic[dicPos] = dic[dicPos - rep0 + (dicPos < rep0 ? dicBufSize : 0)];
335
17.0k
            dicPos++;
336
17.0k
            processedPos++;
337
17.0k
            state = state < kNumLitStates ? 9 : 11;
338
17.0k
            continue;
339
17.0k
          }
340
18.0k
          UPDATE_1(prob);
341
18.0k
        }
342
53.1M
        else
343
53.1M
        {
344
53.1M
          UInt32 distance;
345
53.1M
          UPDATE_1(prob);
346
53.1M
          prob = probs + IsRepG1 + state;
347
53.1M
          IF_BIT_0(prob)
348
21.1k
          {
349
21.1k
            UPDATE_0(prob);
350
21.1k
            distance = rep1;
351
21.1k
          }
352
53.1M
          else
353
53.1M
          {
354
53.1M
            UPDATE_1(prob);
355
53.1M
            prob = probs + IsRepG2 + state;
356
53.1M
            IF_BIT_0(prob)
357
13.2k
            {
358
13.2k
              UPDATE_0(prob);
359
13.2k
              distance = rep2;
360
13.2k
            }
361
53.0M
            else
362
53.0M
            {
363
53.0M
              UPDATE_1(prob);
364
53.0M
              distance = rep3;
365
53.0M
              rep3 = rep2;
366
53.0M
            }
367
53.1M
            rep2 = rep1;
368
53.1M
          }
369
53.1M
          rep1 = rep0;
370
53.1M
          rep0 = distance;
371
53.1M
        }
372
53.1M
        state = state < kNumLitStates ? 8 : 11;
373
53.1M
        prob = probs + RepLenCoder;
374
53.1M
      }
375
      
376
      #ifdef _LZMA_SIZE_OPT
377
      {
378
        unsigned lim, offset;
379
        CLzmaProb *probLen = prob + LenChoice;
380
        IF_BIT_0(probLen)
381
        {
382
          UPDATE_0(probLen);
383
          probLen = prob + LenLow + GET_LEN_STATE;
384
          offset = 0;
385
          lim = (1 << kLenNumLowBits);
386
        }
387
        else
388
        {
389
          UPDATE_1(probLen);
390
          probLen = prob + LenChoice2;
391
          IF_BIT_0(probLen)
392
          {
393
            UPDATE_0(probLen);
394
            probLen = prob + LenLow + GET_LEN_STATE + (1 << kLenNumLowBits);
395
            offset = kLenNumLowSymbols;
396
            lim = (1 << kLenNumLowBits);
397
          }
398
          else
399
          {
400
            UPDATE_1(probLen);
401
            probLen = prob + LenHigh;
402
            offset = kLenNumLowSymbols * 2;
403
            lim = (1 << kLenNumHighBits);
404
          }
405
        }
406
        TREE_DECODE(probLen, lim, len);
407
        len += offset;
408
      }
409
      #else
410
53.1M
      {
411
53.1M
        CLzmaProb *probLen = prob + LenChoice;
412
53.1M
        IF_BIT_0(probLen)
413
44.8k
        {
414
44.8k
          UPDATE_0(probLen);
415
44.8k
          probLen = prob + LenLow + GET_LEN_STATE;
416
44.8k
          len = 1;
417
44.8k
          TREE_GET_BIT(probLen, len);
418
44.8k
          TREE_GET_BIT(probLen, len);
419
44.8k
          TREE_GET_BIT(probLen, len);
420
44.8k
          len -= 8;
421
44.8k
        }
422
53.1M
        else
423
53.1M
        {
424
53.1M
          UPDATE_1(probLen);
425
53.1M
          probLen = prob + LenChoice2;
426
53.1M
          IF_BIT_0(probLen)
427
32.1k
          {
428
32.1k
            UPDATE_0(probLen);
429
32.1k
            probLen = prob + LenLow + GET_LEN_STATE + (1 << kLenNumLowBits);
430
32.1k
            len = 1;
431
32.1k
            TREE_GET_BIT(probLen, len);
432
32.1k
            TREE_GET_BIT(probLen, len);
433
32.1k
            TREE_GET_BIT(probLen, len);
434
32.1k
          }
435
53.1M
          else
436
53.1M
          {
437
53.1M
            UPDATE_1(probLen);
438
53.1M
            probLen = prob + LenHigh;
439
53.1M
            TREE_DECODE(probLen, (1 << kLenNumHighBits), len);
440
53.1M
            len += kLenNumLowSymbols * 2;
441
53.1M
          }
442
53.1M
        }
443
53.1M
      }
444
53.1M
      #endif
445
446
53.1M
      if (state >= kNumStates)
447
38.8k
      {
448
38.8k
        UInt32 distance;
449
38.8k
        prob = probs + PosSlot +
450
38.8k
            ((len < kNumLenToPosStates ? len : kNumLenToPosStates - 1) << kNumPosSlotBits);
451
38.8k
        TREE_6_DECODE(prob, distance);
452
38.8k
        if (distance >= kStartPosModelIndex)
453
34.5k
        {
454
34.5k
          unsigned posSlot = (unsigned)distance;
455
34.5k
          unsigned numDirectBits = (unsigned)(((distance >> 1) - 1));
456
34.5k
          distance = (2 | (distance & 1));
457
34.5k
          if (posSlot < kEndPosModelIndex)
458
13.9k
          {
459
13.9k
            distance <<= numDirectBits;
460
13.9k
            prob = probs + SpecPos;
461
13.9k
            {
462
13.9k
              UInt32 m = 1;
463
13.9k
              distance++;
464
13.9k
              do
465
49.1k
              {
466
49.1k
                REV_BIT_VAR(prob, distance, m);
467
49.1k
              }
468
49.1k
              while (--numDirectBits);
469
13.9k
              distance -= m;
470
13.9k
            }
471
13.9k
          }
472
20.6k
          else
473
20.6k
          {
474
20.6k
            numDirectBits -= kNumAlignBits;
475
20.6k
            do
476
128k
            {
477
128k
              NORMALIZE
478
128k
              range >>= 1;
479
              
480
128k
              {
481
128k
                UInt32 t;
482
128k
                code -= range;
483
128k
                t = (0 - ((UInt32)code >> 31)); /* (UInt32)((Int32)code >> 31) */
484
128k
                distance = (distance << 1) + (t + 1);
485
128k
                code += range & t;
486
128k
              }
487
              /*
488
              distance <<= 1;
489
              if (code >= range)
490
              {
491
                code -= range;
492
                distance |= 1;
493
              }
494
              */
495
128k
            }
496
128k
            while (--numDirectBits);
497
20.6k
            prob = probs + Align;
498
20.6k
            distance <<= kNumAlignBits;
499
20.6k
            {
500
20.6k
              unsigned i = 1;
501
20.6k
              REV_BIT_CONST(prob, i, 1);
502
20.6k
              REV_BIT_CONST(prob, i, 2);
503
20.6k
              REV_BIT_CONST(prob, i, 4);
504
20.6k
              REV_BIT_LAST (prob, i, 8);
505
20.6k
              distance |= i;
506
20.6k
            }
507
20.6k
            if (distance == (UInt32)0xFFFFFFFF)
508
571
            {
509
571
              len = kMatchSpecLenStart;
510
571
              state -= kNumStates;
511
571
              break;
512
571
            }
513
20.6k
          }
514
34.5k
        }
515
        
516
38.2k
        rep3 = rep2;
517
38.2k
        rep2 = rep1;
518
38.2k
        rep1 = rep0;
519
38.2k
        rep0 = distance + 1;
520
38.2k
        state = (state < kNumStates + kNumLitStates) ? kNumLitStates : kNumLitStates + 3;
521
38.2k
        if (distance >= (checkDicSize == 0 ? processedPos: checkDicSize))
522
3.05k
        {
523
3.05k
          p->dicPos = dicPos;
524
3.05k
          return SZ_ERROR_DATA;
525
3.05k
        }
526
38.2k
      }
527
528
53.1M
      len += kMatchMinLen;
529
530
53.1M
      {
531
53.1M
        SizeT rem;
532
53.1M
        unsigned curLen;
533
53.1M
        SizeT pos;
534
        
535
53.1M
        if ((rem = limit - dicPos) == 0)
536
0
        {
537
0
          p->dicPos = dicPos;
538
0
          return SZ_ERROR_DATA;
539
0
        }
540
        
541
53.1M
        curLen = ((rem < len) ? (unsigned)rem : len);
542
53.1M
        pos = dicPos - rep0 + (dicPos < rep0 ? dicBufSize : 0);
543
544
53.1M
        processedPos += (UInt32)curLen;
545
546
53.1M
        len -= curLen;
547
53.1M
        if (curLen <= dicBufSize - pos)
548
53.0M
        {
549
53.0M
          Byte *dest = dic + dicPos;
550
53.0M
          ptrdiff_t src = (ptrdiff_t)pos - (ptrdiff_t)dicPos;
551
53.0M
          const Byte *lim = dest + curLen;
552
53.0M
          dicPos += (SizeT)curLen;
553
53.0M
          do
554
13.8G
            *(dest) = (Byte)*(dest + src);
555
13.8G
          while (++dest != lim);
556
53.0M
        }
557
81.1k
        else
558
81.1k
        {
559
81.1k
          do
560
21.8M
          {
561
21.8M
            dic[dicPos++] = dic[pos];
562
21.8M
            if (++pos == dicBufSize)
563
81.1k
              pos = 0;
564
21.8M
          }
565
21.8M
          while (--curLen != 0);
566
81.1k
        }
567
53.1M
      }
568
53.1M
    }
569
53.1M
  }
570
53.9M
  while (dicPos < limit && buf < bufLimit);
571
572
4.94M
  NORMALIZE;
573
  
574
4.94M
  p->buf = buf;
575
4.94M
  p->range = range;
576
4.94M
  p->code = code;
577
4.94M
  p->remainLen = (UInt32)len;
578
4.94M
  p->dicPos = dicPos;
579
4.94M
  p->processedPos = processedPos;
580
4.94M
  p->reps[0] = rep0;
581
4.94M
  p->reps[1] = rep1;
582
4.94M
  p->reps[2] = rep2;
583
4.94M
  p->reps[3] = rep3;
584
4.94M
  p->state = (UInt32)state;
585
586
4.94M
  return SZ_OK;
587
4.94M
}
588
#endif
589
590
static void MY_FAST_CALL LzmaDec_WriteRem(CLzmaDec *p, SizeT limit)
591
9.51M
{
592
9.51M
  if (p->remainLen != 0 && p->remainLen < kMatchSpecLenStart)
593
8.82M
  {
594
8.82M
    Byte *dic = p->dic;
595
8.82M
    SizeT dicPos = p->dicPos;
596
8.82M
    SizeT dicBufSize = p->dicBufSize;
597
8.82M
    unsigned len = (unsigned)p->remainLen;
598
8.82M
    SizeT rep0 = p->reps[0]; /* we use SizeT to avoid the BUG of VC14 for AMD64 */
599
8.82M
    SizeT rem = limit - dicPos;
600
8.82M
    if (rem < len)
601
4.45M
      len = (unsigned)(rem);
602
603
8.82M
    if (p->checkDicSize == 0 && p->prop.dicSize - p->processedPos <= len)
604
388
      p->checkDicSize = p->prop.dicSize;
605
606
8.82M
    p->processedPos += (UInt32)len;
607
8.82M
    p->remainLen -= (UInt32)len;
608
612M
    while (len != 0)
609
603M
    {
610
603M
      len--;
611
603M
      dic[dicPos] = dic[dicPos - rep0 + (dicPos < rep0 ? dicBufSize : 0)];
612
603M
      dicPos++;
613
603M
    }
614
8.82M
    p->dicPos = dicPos;
615
8.82M
  }
616
9.51M
}
617
618
619
36.2k
#define kRange0 0xFFFFFFFF
620
24.1k
#define kBound0 ((kRange0 >> kNumBitModelTotalBits) << (kNumBitModelTotalBits - 1))
621
12.0k
#define kBadRepCode (kBound0 + (((kRange0 - kBound0) >> kNumBitModelTotalBits) << (kNumBitModelTotalBits - 1)))
622
#if kBadRepCode != (0xC0000000 - 0x400)
623
  #error Stop_Compiling_Bad_LZMA_Check
624
#endif
625
626
static int MY_FAST_CALL LzmaDec_DecodeReal2(CLzmaDec *p, SizeT limit, const Byte *bufLimit, SizeT memlimit)
627
4.94M
{
628
4.94M
  do
629
4.94M
  {
630
4.94M
    SizeT limit2 = limit;
631
4.94M
    if (p->checkDicSize == 0)
632
568k
    {
633
568k
      UInt32 rem = p->prop.dicSize - p->processedPos;
634
568k
      if (limit - p->dicPos > rem) {
635
0
          if (p->dicBufSize < p->prop.dicSize) {
636
0
              p->dicBufSize = p->prop.dicSize;
637
0
              if (p->dicBufSize > memlimit) {
638
0
                  return SZ_ERROR_MEM;
639
0
              }
640
0
              Byte *tmp = realloc(p->dic, p->dicBufSize);
641
0
              if (!tmp) {
642
0
                  return SZ_ERROR_MEM;
643
0
              }
644
0
              p->dic = tmp;
645
0
          }
646
0
        limit2 = p->dicPos + rem;
647
0
        }
648
649
568k
      if (p->processedPos == 0)
650
12.0k
        if (p->code >= kBadRepCode)
651
255
          return SZ_ERROR_DATA;
652
568k
    }
653
654
4.94M
    RINOK(LZMA_DECODE_REAL(p, limit2, bufLimit));
655
    
656
4.94M
    if (p->checkDicSize == 0 && p->processedPos >= p->prop.dicSize)
657
1.95k
      p->checkDicSize = p->prop.dicSize;
658
    
659
4.94M
    LzmaDec_WriteRem(p, limit);
660
4.94M
  }
661
4.94M
  while (p->dicPos < limit && p->buf < bufLimit && p->remainLen < kMatchSpecLenStart);
662
663
4.94M
  return 0;
664
4.94M
}
665
666
typedef enum
667
{
668
  DUMMY_ERROR, /* unexpected end of input stream */
669
  DUMMY_LIT,
670
  DUMMY_MATCH,
671
  DUMMY_REP
672
} ELzmaDummy;
673
674
static ELzmaDummy LzmaDec_TryDummy(const CLzmaDec *p, const Byte *buf, SizeT inSize)
675
629k
{
676
629k
  UInt32 range = p->range;
677
629k
  UInt32 code = p->code;
678
629k
  const Byte *bufLimit = buf + inSize;
679
629k
  const CLzmaProb *probs = GET_PROBS;
680
629k
  unsigned state = (unsigned)p->state;
681
629k
  ELzmaDummy res;
682
683
629k
  {
684
629k
    const CLzmaProb *prob;
685
629k
    UInt32 bound;
686
629k
    unsigned ttt;
687
629k
    unsigned posState = CALC_POS_STATE(p->processedPos, (1 << p->prop.pb) - 1);
688
689
629k
    prob = probs + IsMatch + COMBINED_PS_STATE;
690
629k
    IF_BIT_0_CHECK(prob)
691
94.7k
    {
692
94.7k
      UPDATE_0_CHECK
693
694
      /* if (bufLimit - buf >= 7) return DUMMY_LIT; */
695
696
94.7k
      prob = probs + Literal;
697
94.7k
      if (p->checkDicSize != 0 || p->processedPos != 0)
698
87.7k
        prob += ((UInt32)LZMA_LIT_SIZE *
699
87.7k
            ((((p->processedPos) & ((1 << (p->prop.lp)) - 1)) << p->prop.lc) +
700
87.7k
            (p->dic[(p->dicPos == 0 ? p->dicBufSize : p->dicPos) - 1] >> (8 - p->prop.lc))));
701
702
94.7k
      if (state < kNumLitStates)
703
63.1k
      {
704
63.1k
        unsigned symbol = 1;
705
475k
        do { GET_BIT_CHECK(prob + symbol, symbol) } while (symbol < 0x100);
706
63.1k
      }
707
31.5k
      else
708
31.5k
      {
709
31.5k
        unsigned matchByte = p->dic[p->dicPos - p->reps[0] +
710
31.5k
            (p->dicPos < p->reps[0] ? p->dicBufSize : 0)];
711
31.5k
        unsigned offs = 0x100;
712
31.5k
        unsigned symbol = 1;
713
31.5k
        do
714
214k
        {
715
214k
          unsigned bit;
716
214k
          const CLzmaProb *probLit;
717
214k
          matchByte += matchByte;
718
214k
          bit = offs;
719
214k
          offs &= matchByte;
720
214k
          probLit = prob + (offs + bit + symbol);
721
214k
          GET_BIT2_CHECK(probLit, symbol, offs ^= bit; , ; )
722
204k
        }
723
204k
        while (symbol < 0x100);
724
31.5k
      }
725
71.3k
      res = DUMMY_LIT;
726
71.3k
    }
727
535k
    else
728
535k
    {
729
535k
      unsigned len;
730
535k
      UPDATE_1_CHECK;
731
732
535k
      prob = probs + IsRep + state;
733
535k
      IF_BIT_0_CHECK(prob)
734
36.8k
      {
735
36.8k
        UPDATE_0_CHECK;
736
36.8k
        state = 0;
737
36.8k
        prob = probs + LenCoder;
738
36.8k
        res = DUMMY_MATCH;
739
36.8k
      }
740
495k
      else
741
495k
      {
742
495k
        UPDATE_1_CHECK;
743
495k
        res = DUMMY_REP;
744
495k
        prob = probs + IsRepG0 + state;
745
495k
        IF_BIT_0_CHECK(prob)
746
26.5k
        {
747
26.5k
          UPDATE_0_CHECK;
748
26.5k
          prob = probs + IsRep0Long + COMBINED_PS_STATE;
749
26.5k
          IF_BIT_0_CHECK(prob)
750
11.3k
          {
751
11.3k
            UPDATE_0_CHECK;
752
11.3k
            NORMALIZE_CHECK;
753
10.7k
            return DUMMY_REP;
754
11.3k
          }
755
13.4k
          else
756
13.4k
          {
757
13.4k
            UPDATE_1_CHECK;
758
13.4k
          }
759
24.7k
        }
760
466k
        else
761
466k
        {
762
466k
          UPDATE_1_CHECK;
763
466k
          prob = probs + IsRepG1 + state;
764
466k
          IF_BIT_0_CHECK(prob)
765
15.6k
          {
766
15.6k
            UPDATE_0_CHECK;
767
15.6k
          }
768
449k
          else
769
449k
          {
770
449k
            UPDATE_1_CHECK;
771
449k
            prob = probs + IsRepG2 + state;
772
449k
            IF_BIT_0_CHECK(prob)
773
10.5k
            {
774
10.5k
              UPDATE_0_CHECK;
775
10.5k
            }
776
437k
            else
777
437k
            {
778
437k
              UPDATE_1_CHECK;
779
437k
            }
780
448k
          }
781
464k
        }
782
477k
        state = kNumStates;
783
477k
        prob = probs + RepLenCoder;
784
477k
      }
785
514k
      {
786
514k
        unsigned limit, offset;
787
514k
        const CLzmaProb *probLen = prob + LenChoice;
788
514k
        IF_BIT_0_CHECK(probLen)
789
34.1k
        {
790
34.1k
          UPDATE_0_CHECK;
791
34.1k
          probLen = prob + LenLow + GET_LEN_STATE;
792
34.1k
          offset = 0;
793
34.1k
          limit = 1 << kLenNumLowBits;
794
34.1k
        }
795
474k
        else
796
474k
        {
797
474k
          UPDATE_1_CHECK;
798
474k
          probLen = prob + LenChoice2;
799
474k
          IF_BIT_0_CHECK(probLen)
800
21.2k
          {
801
21.2k
            UPDATE_0_CHECK;
802
21.2k
            probLen = prob + LenLow + GET_LEN_STATE + (1 << kLenNumLowBits);
803
21.2k
            offset = kLenNumLowSymbols;
804
21.2k
            limit = 1 << kLenNumLowBits;
805
21.2k
          }
806
450k
          else
807
450k
          {
808
450k
            UPDATE_1_CHECK;
809
450k
            probLen = prob + LenHigh;
810
450k
            offset = kLenNumLowSymbols * 2;
811
450k
            limit = 1 << kLenNumHighBits;
812
450k
          }
813
471k
        }
814
989k
        TREE_DECODE_CHECK(probLen, limit, len);
815
989k
        len += offset;
816
989k
      }
817
818
483k
      if (state < 4)
819
30.2k
      {
820
30.2k
        unsigned posSlot;
821
30.2k
        prob = probs + PosSlot +
822
30.2k
            ((len < kNumLenToPosStates - 1 ? len : kNumLenToPosStates - 1) <<
823
30.2k
            kNumPosSlotBits);
824
30.2k
        TREE_DECODE_CHECK(prob, 1 << kNumPosSlotBits, posSlot);
825
25.1k
        if (posSlot >= kStartPosModelIndex)
826
22.3k
        {
827
22.3k
          unsigned numDirectBits = ((posSlot >> 1) - 1);
828
829
          /* if (bufLimit - buf >= 8) return DUMMY_MATCH; */
830
831
22.3k
          if (posSlot < kEndPosModelIndex)
832
8.24k
          {
833
8.24k
            prob = probs + SpecPos + ((2 | (posSlot & 1)) << numDirectBits);
834
8.24k
          }
835
14.1k
          else
836
14.1k
          {
837
14.1k
            numDirectBits -= kNumAlignBits;
838
14.1k
            do
839
99.6k
            {
840
99.6k
              NORMALIZE_CHECK
841
96.8k
              range >>= 1;
842
96.8k
              code -= range & (((code - range) >> 31) - 1);
843
              /* if (code >= range) code -= range; */
844
96.8k
            }
845
96.8k
            while (--numDirectBits);
846
11.3k
            prob = probs + Align;
847
11.3k
            numDirectBits = kNumAlignBits;
848
11.3k
          }
849
19.5k
          {
850
19.5k
            unsigned i = 1;
851
19.5k
            unsigned m = 1;
852
19.5k
            do
853
70.1k
            {
854
70.1k
              REV_BIT_CHECK(prob, i, m);
855
67.5k
            }
856
67.5k
            while (--numDirectBits);
857
19.5k
          }
858
19.5k
        }
859
25.1k
      }
860
989k
    }
861
629k
  }
862
544k
  NORMALIZE_CHECK;
863
538k
  return res;
864
544k
}
865
866
867
static void LzmaDec_InitDicAndState(CLzmaDec *p, BoolInt initDic, BoolInt initState)
868
14.2k
{
869
14.2k
  p->remainLen = kMatchSpecLenStart + 1;
870
14.2k
  p->tempBufSize = 0;
871
872
14.2k
  if (initDic)
873
14.2k
  {
874
14.2k
    p->processedPos = 0;
875
14.2k
    p->checkDicSize = 0;
876
14.2k
    p->remainLen = kMatchSpecLenStart + 2;
877
14.2k
  }
878
14.2k
  if (initState)
879
14.2k
    p->remainLen = kMatchSpecLenStart + 2;
880
14.2k
}
881
882
void LzmaDec_Init(CLzmaDec *p)
883
14.2k
{
884
14.2k
  p->dicPos = 0;
885
14.2k
  LzmaDec_InitDicAndState(p, True, True);
886
14.2k
}
887
888
889
SRes LzmaDec_DecodeToDic(CLzmaDec *p, SizeT dicLimit, const Byte *src, SizeT *srcLen,
890
    ELzmaFinishMode finishMode, ELzmaStatus *status, SizeT memlimit)
891
4.56M
{
892
4.56M
  SizeT inSize = *srcLen;
893
4.56M
  (*srcLen) = 0;
894
  
895
4.56M
  *status = LZMA_STATUS_NOT_SPECIFIED;
896
897
4.56M
  if (p->remainLen > kMatchSpecLenStart)
898
15.5k
  {
899
81.0k
    for (; inSize > 0 && p->tempBufSize < RC_INIT_SIZE; (*srcLen)++, inSize--)
900
65.5k
      p->tempBuf[p->tempBufSize++] = *src++;
901
15.5k
    if (p->tempBufSize != 0 && p->tempBuf[0] != 0)
902
1.35k
      return SZ_ERROR_DATA;
903
14.1k
    if (p->tempBufSize < RC_INIT_SIZE)
904
1.82k
    {
905
1.82k
      *status = LZMA_STATUS_NEEDS_MORE_INPUT;
906
1.82k
      return SZ_OK;
907
1.82k
    }
908
12.3k
    p->code =
909
12.3k
        ((UInt32)p->tempBuf[1] << 24)
910
12.3k
      | ((UInt32)p->tempBuf[2] << 16)
911
12.3k
      | ((UInt32)p->tempBuf[3] << 8)
912
12.3k
      | ((UInt32)p->tempBuf[4]);
913
12.3k
    p->range = 0xFFFFFFFF;
914
12.3k
    p->tempBufSize = 0;
915
916
12.3k
    if (p->remainLen > kMatchSpecLenStart + 1)
917
12.3k
    {
918
12.3k
      SizeT numProbs = LzmaProps_GetNumProbs(&p->prop);
919
12.3k
      SizeT i;
920
12.3k
      CLzmaProb *probs = p->probs;
921
4.17G
      for (i = 0; i < numProbs; i++)
922
4.17G
        probs[i] = kBitModelTotal >> 1;
923
12.3k
      p->reps[0] = p->reps[1] = p->reps[2] = p->reps[3] = 1;
924
12.3k
      p->state = 0;
925
12.3k
    }
926
927
12.3k
    p->remainLen = 0;
928
12.3k
  }
929
930
4.56M
  LzmaDec_WriteRem(p, dicLimit);
931
932
9.51M
  while (p->remainLen != kMatchSpecLenStart)
933
9.50M
  {
934
9.50M
      int checkEndMarkNow = 0;
935
936
9.50M
      if (p->dicPos >= dicLimit)
937
4.47M
      {
938
4.47M
        if (p->remainLen == 0 && p->code == 0)
939
204
        {
940
204
          *status = LZMA_STATUS_MAYBE_FINISHED_WITHOUT_MARK;
941
204
          return SZ_OK;
942
204
        }
943
4.47M
        if (finishMode == LZMA_FINISH_ANY)
944
4.47M
        {
945
4.47M
          *status = LZMA_STATUS_NOT_FINISHED;
946
4.47M
          return SZ_OK;
947
4.47M
        }
948
0
        if (p->remainLen != 0)
949
0
        {
950
0
          *status = LZMA_STATUS_NOT_FINISHED;
951
0
          return SZ_ERROR_DATA;
952
0
        }
953
0
        checkEndMarkNow = 1;
954
0
      }
955
956
5.03M
      if (p->tempBufSize == 0)
957
5.01M
      {
958
5.01M
        SizeT processed;
959
5.01M
        const Byte *bufLimit;
960
5.01M
        if (inSize < LZMA_REQUIRED_INPUT_MAX || checkEndMarkNow)
961
615k
        {
962
615k
          int dummyRes = LzmaDec_TryDummy(p, src, inSize);
963
615k
          if (dummyRes == DUMMY_ERROR)
964
74.5k
          {
965
74.5k
            memcpy(p->tempBuf, src, inSize);
966
74.5k
            p->tempBufSize = (unsigned)inSize;
967
74.5k
            (*srcLen) += inSize;
968
74.5k
            *status = LZMA_STATUS_NEEDS_MORE_INPUT;
969
74.5k
            return SZ_OK;
970
74.5k
          }
971
541k
          if (checkEndMarkNow && dummyRes != DUMMY_MATCH)
972
0
          {
973
0
            *status = LZMA_STATUS_NOT_FINISHED;
974
0
            return SZ_ERROR_DATA;
975
0
          }
976
541k
          bufLimit = src;
977
541k
        }
978
4.40M
        else
979
4.40M
          bufLimit = src + inSize - LZMA_REQUIRED_INPUT_MAX;
980
4.94M
        p->buf = src;
981
4.94M
        if (LzmaDec_DecodeReal2(p, dicLimit, bufLimit, memlimit) != 0)
982
2.30k
          return SZ_ERROR_DATA;
983
4.93M
        processed = (SizeT)(p->buf - src);
984
4.93M
        (*srcLen) += processed;
985
4.93M
        src += processed;
986
4.93M
        inSize -= processed;
987
4.93M
      }
988
15.1k
      else
989
15.1k
      {
990
15.1k
        unsigned rem = p->tempBufSize, lookAhead = 0;
991
59.6k
        while (rem < LZMA_REQUIRED_INPUT_MAX && lookAhead < inSize)
992
44.4k
          p->tempBuf[rem++] = src[lookAhead++];
993
15.1k
        p->tempBufSize = rem;
994
15.1k
        if (rem < LZMA_REQUIRED_INPUT_MAX || checkEndMarkNow)
995
14.1k
        {
996
14.1k
          int dummyRes = LzmaDec_TryDummy(p, p->tempBuf, (SizeT)rem);
997
14.1k
          if (dummyRes == DUMMY_ERROR)
998
6.53k
          {
999
6.53k
            (*srcLen) += (SizeT)lookAhead;
1000
6.53k
            *status = LZMA_STATUS_NEEDS_MORE_INPUT;
1001
6.53k
            return SZ_OK;
1002
6.53k
          }
1003
7.60k
          if (checkEndMarkNow && dummyRes != DUMMY_MATCH)
1004
0
          {
1005
0
            *status = LZMA_STATUS_NOT_FINISHED;
1006
0
            return SZ_ERROR_DATA;
1007
0
          }
1008
7.60k
        }
1009
8.65k
        p->buf = p->tempBuf;
1010
8.65k
        if (LzmaDec_DecodeReal2(p, dicLimit, p->buf, memlimit) != 0)
1011
1.00k
          return SZ_ERROR_DATA;
1012
        
1013
7.65k
        {
1014
7.65k
          unsigned kkk = (unsigned)(p->buf - p->tempBuf);
1015
7.65k
          if (rem < kkk)
1016
0
            return SZ_ERROR_FAIL; /* some internal error */
1017
7.65k
          rem -= kkk;
1018
7.65k
          if (lookAhead < rem)
1019
0
            return SZ_ERROR_FAIL; /* some internal error */
1020
7.65k
          lookAhead -= rem;
1021
7.65k
        }
1022
0
        (*srcLen) += (SizeT)lookAhead;
1023
7.65k
        src += lookAhead;
1024
7.65k
        inSize -= (SizeT)lookAhead;
1025
7.65k
        p->tempBufSize = 0;
1026
7.65k
      }
1027
5.03M
  }
1028
  
1029
946
  if (p->code != 0)
1030
555
    return SZ_ERROR_DATA;
1031
391
  *status = LZMA_STATUS_FINISHED_WITH_MARK;
1032
391
  return SZ_OK;
1033
946
}
1034
1035
1036
SRes LzmaDec_DecodeToBuf(CLzmaDec *p, Byte *dest, SizeT *destLen, const Byte *src, SizeT *srcLen, ELzmaFinishMode finishMode, ELzmaStatus *status, SizeT memlimit)
1037
1.82M
{
1038
1.82M
  SizeT outSize = *destLen;
1039
1.82M
  SizeT inSize = *srcLen;
1040
1.82M
  *srcLen = *destLen = 0;
1041
1.82M
  for (;;)
1042
4.56M
  {
1043
4.56M
    SizeT inSizeCur = inSize, outSizeCur, dicPos;
1044
4.56M
    ELzmaFinishMode curFinishMode;
1045
4.56M
    SRes res;
1046
4.56M
    if (p->dicPos == p->dicBufSize) {
1047
2.78M
      if (p->dicBufSize < p->prop.dicSize) {
1048
7.23k
        if (p->dicBufSize < memlimit) {
1049
6.44k
          p->dicBufSize = p->dicBufSize << 2;
1050
6.44k
          if (p->dicBufSize > memlimit) {
1051
0
            p->dicBufSize = memlimit;
1052
0
          }
1053
6.44k
          if (p->dicBufSize > p->prop.dicSize) {
1054
1.08k
            p->dicBufSize = p->prop.dicSize;
1055
1.08k
          }
1056
6.44k
          Byte *tmp = realloc(p->dic, p->dicBufSize);
1057
6.44k
          if (!tmp) {
1058
0
            return SZ_ERROR_MEM;
1059
0
          }
1060
6.44k
          p->dic = tmp;
1061
6.44k
        } else {
1062
786
          return SZ_ERROR_MEM;
1063
786
        }
1064
2.78M
      } else {
1065
2.78M
        p->dicPos = 0;
1066
2.78M
      }
1067
2.78M
    }
1068
4.56M
    dicPos = p->dicPos;
1069
4.56M
    if (outSize > p->dicBufSize - dicPos)
1070
2.75M
    {
1071
2.75M
      outSizeCur = p->dicBufSize;
1072
2.75M
      curFinishMode = LZMA_FINISH_ANY;
1073
2.75M
    }
1074
1.80M
    else
1075
1.80M
    {
1076
1.80M
      outSizeCur = dicPos + outSize;
1077
1.80M
      curFinishMode = finishMode;
1078
1.80M
    }
1079
1080
4.56M
    res = LzmaDec_DecodeToDic(p, outSizeCur, src, &inSizeCur, curFinishMode, status, memlimit);
1081
4.56M
    src += inSizeCur;
1082
4.56M
    inSize -= inSizeCur;
1083
4.56M
    *srcLen += inSizeCur;
1084
4.56M
    outSizeCur = p->dicPos - dicPos;
1085
4.56M
    memcpy(dest, p->dic + dicPos, outSizeCur);
1086
4.56M
    dest += outSizeCur;
1087
4.56M
    outSize -= outSizeCur;
1088
4.56M
    *destLen += outSizeCur;
1089
4.56M
    if (res != 0)
1090
5.22k
      return res;
1091
4.56M
    if (outSizeCur == 0 || outSize == 0)
1092
1.81M
      return SZ_OK;
1093
4.56M
  }
1094
1.82M
}
1095
1096
void LzmaDec_FreeProbs(CLzmaDec *p, ISzAllocPtr alloc)
1097
29.9k
{
1098
29.9k
  ISzAlloc_Free(alloc, p->probs);
1099
29.9k
  p->probs = NULL;
1100
29.9k
}
1101
1102
static void LzmaDec_FreeDict(CLzmaDec *p, ISzAllocPtr alloc)
1103
29.9k
{
1104
29.9k
  ISzAlloc_Free(alloc, p->dic);
1105
29.9k
  p->dic = NULL;
1106
29.9k
}
1107
1108
void LzmaDec_Free(CLzmaDec *p, ISzAllocPtr alloc)
1109
15.6k
{
1110
15.6k
  LzmaDec_FreeProbs(p, alloc);
1111
15.6k
  LzmaDec_FreeDict(p, alloc);
1112
15.6k
}
1113
1114
SRes LzmaProps_Decode(CLzmaProps *p, const Byte *data, unsigned size)
1115
14.9k
{
1116
14.9k
  UInt32 dicSize;
1117
14.9k
  Byte d;
1118
  
1119
14.9k
  if (size < LZMA_PROPS_SIZE)
1120
0
    return SZ_ERROR_UNSUPPORTED;
1121
14.9k
  else
1122
14.9k
    dicSize = data[1] | ((UInt32)data[2] << 8) | ((UInt32)data[3] << 16) | ((UInt32)data[4] << 24);
1123
 
1124
14.9k
  if (dicSize < LZMA_DIC_MIN)
1125
3.98k
    dicSize = LZMA_DIC_MIN;
1126
14.9k
  p->dicSize = dicSize;
1127
1128
14.9k
  d = data[0];
1129
14.9k
  if (d >= (9 * 5 * 5))
1130
662
    return SZ_ERROR_UNSUPPORTED;
1131
1132
14.2k
  p->lc = (Byte)(d % 9);
1133
14.2k
  d /= 9;
1134
14.2k
  p->pb = (Byte)(d / 5);
1135
14.2k
  p->lp = (Byte)(d % 5);
1136
14.2k
  p->_pad_ = 0;
1137
1138
14.2k
  return SZ_OK;
1139
14.9k
}
1140
1141
static SRes LzmaDec_AllocateProbs2(CLzmaDec *p, const CLzmaProps *propNew, ISzAllocPtr alloc)
1142
14.2k
{
1143
14.2k
  UInt32 numProbs = LzmaProps_GetNumProbs(propNew);
1144
14.2k
  if (!p->probs || numProbs != p->numProbs)
1145
14.2k
  {
1146
14.2k
    LzmaDec_FreeProbs(p, alloc);
1147
14.2k
    p->probs = (CLzmaProb *)ISzAlloc_Alloc(alloc, numProbs * sizeof(CLzmaProb));
1148
14.2k
    if (!p->probs)
1149
0
      return SZ_ERROR_MEM;
1150
14.2k
    p->probs_1664 = p->probs + 1664;
1151
14.2k
    p->numProbs = numProbs;
1152
14.2k
  }
1153
14.2k
  return SZ_OK;
1154
14.2k
}
1155
1156
SRes LzmaDec_AllocateProbs(CLzmaDec *p, const Byte *props, unsigned propsSize, ISzAllocPtr alloc)
1157
0
{
1158
0
  CLzmaProps propNew;
1159
0
  RINOK(LzmaProps_Decode(&propNew, props, propsSize));
1160
0
  RINOK(LzmaDec_AllocateProbs2(p, &propNew, alloc));
1161
0
  p->prop = propNew;
1162
0
  return SZ_OK;
1163
0
}
1164
1165
SRes LzmaDec_Allocate(CLzmaDec *p, const Byte *props, unsigned propsSize, ISzAllocPtr alloc)
1166
14.9k
{
1167
14.9k
  CLzmaProps propNew;
1168
14.9k
  SizeT dicBufSize;
1169
14.9k
  RINOK(LzmaProps_Decode(&propNew, props, propsSize));
1170
14.2k
  RINOK(LzmaDec_AllocateProbs2(p, &propNew, alloc));
1171
1172
14.2k
  {
1173
14.2k
    UInt32 dictSize = propNew.dicSize;
1174
14.2k
    SizeT mask = ((UInt32)1 << 12) - 1;
1175
14.2k
         if (dictSize >= ((UInt32)1 << 30)) mask = ((UInt32)1 << 22) - 1;
1176
9.27k
    else if (dictSize >= ((UInt32)1 << 22)) mask = ((UInt32)1 << 20) - 1;;
1177
14.2k
    dicBufSize = ((SizeT)dictSize + mask) & ~mask;
1178
14.2k
    if (dicBufSize < dictSize)
1179
0
      dicBufSize = dictSize;
1180
14.2k
  }
1181
14.2k
    if (dicBufSize > LZMA_DIC_MIN) {
1182
10.6k
        dicBufSize = LZMA_DIC_MIN;
1183
10.6k
    }
1184
1185
14.2k
  if (!p->dic || dicBufSize != p->dicBufSize)
1186
14.2k
  {
1187
14.2k
    LzmaDec_FreeDict(p, alloc);
1188
14.2k
    p->dic = (Byte *)ISzAlloc_Alloc(alloc, dicBufSize);
1189
14.2k
    if (!p->dic)
1190
0
    {
1191
0
      LzmaDec_FreeProbs(p, alloc);
1192
0
      return SZ_ERROR_MEM;
1193
0
    }
1194
14.2k
  }
1195
14.2k
  p->dicBufSize = dicBufSize;
1196
14.2k
  p->prop = propNew;
1197
14.2k
  return SZ_OK;
1198
14.2k
}
1199
1200
SRes LzmaDecode(Byte *dest, SizeT *destLen, const Byte *src, SizeT *srcLen,
1201
    const Byte *propData, unsigned propSize, ELzmaFinishMode finishMode,
1202
    ELzmaStatus *status, ISzAllocPtr alloc)
1203
0
{
1204
0
  CLzmaDec p;
1205
0
  SRes res;
1206
0
  SizeT outSize = *destLen, inSize = *srcLen;
1207
0
  *destLen = *srcLen = 0;
1208
0
  *status = LZMA_STATUS_NOT_SPECIFIED;
1209
0
  if (inSize < RC_INIT_SIZE)
1210
0
    return SZ_ERROR_INPUT_EOF;
1211
0
  LzmaDec_Construct(&p);
1212
0
  RINOK(LzmaDec_AllocateProbs(&p, propData, propSize, alloc));
1213
0
  p.dic = dest;
1214
0
  p.dicBufSize = outSize;
1215
0
  LzmaDec_Init(&p);
1216
0
  *srcLen = inSize;
1217
0
  res = LzmaDec_DecodeToDic(&p, outSize, src, srcLen, finishMode, status, SIZE_MAX);
1218
0
  *destLen = p.dicPos;
1219
0
  if (res == SZ_OK && *status == LZMA_STATUS_NEEDS_MORE_INPUT)
1220
0
    res = SZ_ERROR_INPUT_EOF;
1221
0
  LzmaDec_FreeProbs(&p, alloc);
1222
0
  return res;
1223
0
}