Lines Matching refs:cst

348 				     struct cstate *cst, uint16_t *p,  in process_bit0()  argument
359 if (cst->state >= LZMA_NUM_LIT_STATES) { in process_bit0()
360 int match_byte = peek_old_byte(wr, cst->rep0); in process_bit0()
381 if (cst->state < 4) in process_bit0()
382 cst->state = 0; in process_bit0()
383 else if (cst->state < 10) in process_bit0()
384 cst->state -= 3; in process_bit0()
386 cst->state -= 6; in process_bit0()
392 struct cstate *cst, uint16_t *p, in process_bit1() argument
400 prob = p + LZMA_IS_REP + cst->state; in process_bit1()
403 cst->rep3 = cst->rep2; in process_bit1()
404 cst->rep2 = cst->rep1; in process_bit1()
405 cst->rep1 = cst->rep0; in process_bit1()
406 cst->state = cst->state < LZMA_NUM_LIT_STATES ? 0 : 3; in process_bit1()
410 prob = p + LZMA_IS_REP_G0 + cst->state; in process_bit1()
414 + (cst->state << in process_bit1()
420 cst->state = cst->state < LZMA_NUM_LIT_STATES ? in process_bit1()
422 return copy_byte(wr, cst->rep0); in process_bit1()
430 prob = p + LZMA_IS_REP_G1 + cst->state; in process_bit1()
433 distance = cst->rep1; in process_bit1()
436 prob = p + LZMA_IS_REP_G2 + cst->state; in process_bit1()
439 distance = cst->rep2; in process_bit1()
442 distance = cst->rep3; in process_bit1()
443 cst->rep3 = cst->rep2; in process_bit1()
445 cst->rep2 = cst->rep1; in process_bit1()
447 cst->rep1 = cst->rep0; in process_bit1()
448 cst->rep0 = distance; in process_bit1()
450 cst->state = cst->state < LZMA_NUM_LIT_STATES ? 8 : 11; in process_bit1()
484 if (cst->state < 4) { in process_bit1()
487 cst->state += LZMA_NUM_LIT_STATES; in process_bit1()
500 cst->rep0 = 2 | (pos_slot & 1); in process_bit1()
502 cst->rep0 <<= num_bits; in process_bit1()
504 cst->rep0 - pos_slot - 1; in process_bit1()
508 cst->rep0 = (cst->rep0 << 1) | in process_bit1()
511 cst->rep0 <<= LZMA_NUM_ALIGN_BITS; in process_bit1()
518 cst->rep0 |= i; in process_bit1()
522 cst->rep0 = pos_slot; in process_bit1()
523 if (++(cst->rep0) == 0) in process_bit1()
525 if (cst->rep0 > wr->header->dict_size in process_bit1()
526 || cst->rep0 > get_pos(wr)) in process_bit1()
532 return copy_bytes(wr, cst->rep0, len); in process_bit1()
554 struct cstate cst; in unlzma() local
569 cst.state = 0; in unlzma()
570 cst.rep0 = cst.rep1 = cst.rep2 = cst.rep3 = 1; in unlzma()
634 (cst.state << LZMA_NUM_POS_BITS_MAX) + pos_state; in unlzma()
636 if (process_bit0(&wr, &rc, &cst, p, pos_state, prob, in unlzma()
642 if (process_bit1(&wr, &rc, &cst, p, pos_state, prob)) { in unlzma()
646 if (cst.rep0 == 0) in unlzma()