summaryrefslogtreecommitdiff
path: root/vp9
diff options
context:
space:
mode:
authorJohn Koleszar <jkoleszar@google.com>2013-04-05 09:16:15 -0700
committerGerrit Code Review <gerrit@gerrit.golo.chromium.org>2013-04-05 09:16:15 -0700
commit98466e896269f454ed59779e78f5d1e8a6266791 (patch)
tree20961d05443851c385031943884ed2dabd4db4e3 /vp9
parentffc92da4c229a007c2553e95e7bb0b07e863e95e (diff)
parent52128c5894b77dcde710aa606db6c3e3396fa1e9 (diff)
downloadlibvpx-98466e896269f454ed59779e78f5d1e8a6266791.tar
libvpx-98466e896269f454ed59779e78f5d1e8a6266791.tar.gz
libvpx-98466e896269f454ed59779e78f5d1e8a6266791.tar.bz2
libvpx-98466e896269f454ed59779e78f5d1e8a6266791.zip
Merge "Simplifying get_delta_q function." into experimental
Diffstat (limited to 'vp9')
-rw-r--r--vp9/decoder/vp9_decodframe.c26
1 files changed, 11 insertions, 15 deletions
diff --git a/vp9/decoder/vp9_decodframe.c b/vp9/decoder/vp9_decodframe.c
index 7d71ceba3..f6f87efae 100644
--- a/vp9/decoder/vp9_decodframe.c
+++ b/vp9/decoder/vp9_decodframe.c
@@ -910,22 +910,18 @@ static void decode_mb(VP9D_COMP *pbi, MACROBLOCKD *xd,
#endif
}
+static int get_delta_q(vp9_reader *r, int *dq) {
+ const int old_value = *dq;
-static int get_delta_q(vp9_reader *bc, int prev, int *q_update) {
- int ret_val = 0;
-
- if (vp9_read_bit(bc)) {
- ret_val = vp9_read_literal(bc, 4);
-
- if (vp9_read_bit(bc))
- ret_val = -ret_val;
+ if (vp9_read_bit(r)) { // Update bit
+ int value = vp9_read_literal(r, 4);
+ if (vp9_read_bit(r)) // Sign bit
+ value = -value;
+ *dq = value;
}
// Trigger a quantizer update if the delta-q value has changed
- if (ret_val != prev)
- *q_update = 1;
-
- return ret_val;
+ return old_value != *dq;
}
#ifdef PACKET_TESTING
@@ -1725,9 +1721,9 @@ int vp9_decode_frame(VP9D_COMP *pbi, const uint8_t **p_data_end) {
pc->base_qindex = vp9_read_literal(&header_bc, QINDEX_BITS);
// AC 1st order Q = default
- pc->y1dc_delta_q = get_delta_q(&header_bc, pc->y1dc_delta_q, &q_update);
- pc->uvdc_delta_q = get_delta_q(&header_bc, pc->uvdc_delta_q, &q_update);
- pc->uvac_delta_q = get_delta_q(&header_bc, pc->uvac_delta_q, &q_update);
+ q_update = get_delta_q(&header_bc, &pc->y1dc_delta_q) |
+ get_delta_q(&header_bc, &pc->uvdc_delta_q) |
+ get_delta_q(&header_bc, &pc->uvac_delta_q);
if (q_update)
vp9_init_de_quantizer(pbi);