summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--libavcodec/cabac.c8
-rw-r--r--libavcodec/cabac.h7
2 files changed, 12 insertions, 3 deletions
diff --git a/libavcodec/cabac.c b/libavcodec/cabac.c
index 52e6c50e47..f69b100d60 100644
--- a/libavcodec/cabac.c
+++ b/libavcodec/cabac.c
@@ -133,11 +133,19 @@ void ff_init_cabac_states(CABACContext *c, uint8_t const (*lps_range)[4],
c->mps_state[2*i+3]= 2*mps_state[i]+3;
if( i ){
+#ifdef BRANCHLESS_CABAD
+ c->mps_state[-2*i-3]= 2*lps_state[i]+2; //FIXME yes this is not valid C but iam lazy, cleanup welcome
+ c->mps_state[-2*i-4]= 2*lps_state[i]+3;
+ }else{
+ c->mps_state[-2*i-3]= 3;
+ c->mps_state[-2*i-4]= 2;
+#else
c->lps_state[2*i+2]= 2*lps_state[i]+2;
c->lps_state[2*i+3]= 2*lps_state[i]+3;
}else{
c->lps_state[2*i+2]= 3;
c->lps_state[2*i+3]= 2;
+#endif
}
}
}
diff --git a/libavcodec/cabac.h b/libavcodec/cabac.h
index 2f8a8d9fe7..58698b73d1 100644
--- a/libavcodec/cabac.h
+++ b/libavcodec/cabac.h
@@ -452,7 +452,7 @@ static int get_cabac(CABACContext *c, uint8_t * const state){
int bit, lps_mask attribute_unused;
c->range -= RangeLPS;
-#if 1
+#ifndef BRANCHLESS_CABAD
if(c->low < c->range){
bit= s&1;
*state= c->mps_state[s];
@@ -475,8 +475,9 @@ static int get_cabac(CABACContext *c, uint8_t * const state){
c->low -= c->range & lps_mask;
c->range += (RangeLPS - c->range) & lps_mask;
- bit= (s^lps_mask)&1;
- *state= c->mps_state[s - (130&lps_mask)];
+ s^=lps_mask;
+ *state= c->mps_state[s];
+ bit= s&1;
lps_mask= ff_h264_norm_shift[c->range>>(CABAC_BITS+3)];
c->range<<= lps_mask;