John Koleszar | 0ea50ce | 2010-05-18 11:58:33 -0400 | [diff] [blame] | 1 | /* |
John Koleszar | c2140b8 | 2010-09-09 08:16:39 -0400 | [diff] [blame] | 2 | * Copyright (c) 2010 The WebM project authors. All Rights Reserved. |
John Koleszar | 0ea50ce | 2010-05-18 11:58:33 -0400 | [diff] [blame] | 3 | * |
John Koleszar | 94c52e4 | 2010-06-18 12:39:21 -0400 | [diff] [blame] | 4 | * Use of this source code is governed by a BSD-style license |
John Koleszar | 09202d8 | 2010-06-04 16:19:40 -0400 | [diff] [blame] | 5 | * that can be found in the LICENSE file in the root of the source |
| 6 | * tree. An additional intellectual property rights grant can be found |
John Koleszar | 94c52e4 | 2010-06-18 12:39:21 -0400 | [diff] [blame] | 7 | * in the file PATENTS. All contributing project authors may |
John Koleszar | 09202d8 | 2010-06-04 16:19:40 -0400 | [diff] [blame] | 8 | * be found in the AUTHORS file in the root of the source tree. |
John Koleszar | 0ea50ce | 2010-05-18 11:58:33 -0400 | [diff] [blame] | 9 | */ |
| 10 | |
| 11 | |
| 12 | #include "dboolhuff.h" |
John Koleszar | 0ea50ce | 2010-05-18 11:58:33 -0400 | [diff] [blame] | 13 | |
Johann | bb9c95e | 2011-02-04 16:00:00 -0500 | [diff] [blame] | 14 | int vp8dx_start_decode(BOOL_DECODER *br, |
| 15 | const unsigned char *source, |
Dmitry Kovalev | 26cec5c | 2013-03-15 18:21:55 -0700 | [diff] [blame] | 16 | unsigned int source_sz, |
Jeff Petkau | 368c723 | 2013-06-13 12:16:58 -0700 | [diff] [blame^] | 17 | vp8_decrypt_cb *decrypt_cb, |
| 18 | void *decrypt_state) |
John Koleszar | 0ea50ce | 2010-05-18 11:58:33 -0400 | [diff] [blame] | 19 | { |
Timothy B. Terriberry | c17b62e | 2010-05-05 17:58:19 -0400 | [diff] [blame] | 20 | br->user_buffer_end = source+source_sz; |
| 21 | br->user_buffer = source; |
| 22 | br->value = 0; |
| 23 | br->count = -8; |
John Koleszar | 0ea50ce | 2010-05-18 11:58:33 -0400 | [diff] [blame] | 24 | br->range = 255; |
Jeff Petkau | 368c723 | 2013-06-13 12:16:58 -0700 | [diff] [blame^] | 25 | br->decrypt_cb = decrypt_cb; |
| 26 | br->decrypt_state = decrypt_state; |
John Koleszar | 0ea50ce | 2010-05-18 11:58:33 -0400 | [diff] [blame] | 27 | |
| 28 | if (source_sz && !source) |
| 29 | return 1; |
| 30 | |
John Koleszar | 0ea50ce | 2010-05-18 11:58:33 -0400 | [diff] [blame] | 31 | /* Populate the buffer */ |
Johann | bb9c95e | 2011-02-04 16:00:00 -0500 | [diff] [blame] | 32 | vp8dx_bool_decoder_fill(br); |
John Koleszar | 0ea50ce | 2010-05-18 11:58:33 -0400 | [diff] [blame] | 33 | |
John Koleszar | 0ea50ce | 2010-05-18 11:58:33 -0400 | [diff] [blame] | 34 | return 0; |
| 35 | } |
| 36 | |
Johann | bb9c95e | 2011-02-04 16:00:00 -0500 | [diff] [blame] | 37 | void vp8dx_bool_decoder_fill(BOOL_DECODER *br) |
John Koleszar | 0ea50ce | 2010-05-18 11:58:33 -0400 | [diff] [blame] | 38 | { |
Dmitry Kovalev | 33efdfe | 2013-03-04 16:53:00 -0800 | [diff] [blame] | 39 | const unsigned char *bufptr = br->user_buffer; |
Dmitry Kovalev | 33efdfe | 2013-03-04 16:53:00 -0800 | [diff] [blame] | 40 | VP8_BD_VALUE value = br->value; |
| 41 | int count = br->count; |
| 42 | int shift = VP8_BD_VALUE_SIZE - 8 - (count + 8); |
Jeff Petkau | 368c723 | 2013-06-13 12:16:58 -0700 | [diff] [blame^] | 43 | size_t bytes_left = br->user_buffer_end - bufptr; |
| 44 | size_t bits_left = bytes_left * CHAR_BIT; |
Dmitry Kovalev | 33efdfe | 2013-03-04 16:53:00 -0800 | [diff] [blame] | 45 | int x = (int)(shift + CHAR_BIT - bits_left); |
| 46 | int loop_end = 0; |
Jeff Petkau | 368c723 | 2013-06-13 12:16:58 -0700 | [diff] [blame^] | 47 | unsigned char decrypted[sizeof(VP8_BD_VALUE) + 1]; |
| 48 | |
| 49 | if (br->decrypt_cb) { |
| 50 | int n = bytes_left > sizeof(decrypted) ? sizeof(decrypted) : bytes_left; |
| 51 | br->decrypt_cb(br->decrypt_state, bufptr, decrypted, n); |
| 52 | bufptr = decrypted; |
| 53 | } |
John Koleszar | 0ea50ce | 2010-05-18 11:58:33 -0400 | [diff] [blame] | 54 | |
Dmitry Kovalev | 33efdfe | 2013-03-04 16:53:00 -0800 | [diff] [blame] | 55 | if(x >= 0) |
| 56 | { |
| 57 | count += VP8_LOTS_OF_BITS; |
| 58 | loop_end = x; |
| 59 | } |
| 60 | |
| 61 | if (x < 0 || bits_left) |
| 62 | { |
| 63 | while(shift >= loop_end) |
| 64 | { |
| 65 | count += CHAR_BIT; |
Jeff Petkau | 368c723 | 2013-06-13 12:16:58 -0700 | [diff] [blame^] | 66 | value |= (VP8_BD_VALUE)*bufptr << shift; |
Dmitry Kovalev | 26cec5c | 2013-03-15 18:21:55 -0700 | [diff] [blame] | 67 | ++bufptr; |
Jeff Petkau | 368c723 | 2013-06-13 12:16:58 -0700 | [diff] [blame^] | 68 | ++br->user_buffer; |
Dmitry Kovalev | 33efdfe | 2013-03-04 16:53:00 -0800 | [diff] [blame] | 69 | shift -= CHAR_BIT; |
| 70 | } |
| 71 | } |
John Koleszar | 0ea50ce | 2010-05-18 11:58:33 -0400 | [diff] [blame] | 72 | |
Timothy B. Terriberry | c17b62e | 2010-05-05 17:58:19 -0400 | [diff] [blame] | 73 | br->value = value; |
| 74 | br->count = count; |
John Koleszar | 0ea50ce | 2010-05-18 11:58:33 -0400 | [diff] [blame] | 75 | } |