# HG changeset patch # User michael # Date 1156377831 0 # Node ID 6560c84eef72cfbf33e1520f3c2361b79335adf2 # Parent f713d34d5d013a70a35af3486059df45c45dc0de use memset() instead of slow c loops diff -r f713d34d5d01 -r 6560c84eef72 mpegaudiodec.c --- a/mpegaudiodec.c Wed Aug 23 23:40:03 2006 +0000 +++ b/mpegaudiodec.c Thu Aug 24 00:03:51 2006 +0000 @@ -1686,18 +1686,20 @@ linbits = mpa_huff_data[k][1]; vlc = &huff_vlc[l]; + if(!l){ + memset(&g->sb_hybrid[s_index], 0, sizeof(*g->sb_hybrid)*j); + s_index += 2*j; + continue; + } + /* read huffcode and compute each couple */ for(;j>0;j--) { if (get_bits_count(&s->gb) >= end_pos) break; - if (l) { - y = get_vlc2(&s->gb, vlc->table, 8, 3); - x = y >> 4; - y = y & 0x0f; - } else { - x = 0; - y = 0; - } + y = get_vlc2(&s->gb, vlc->table, 8, 3); + x = y >> 4; + y = y & 0x0f; + dprintf("region=%d n=%d x=%d y=%d exp=%d\n", i, g->region_size[i] - j, x, y, exponents[s_index]); if (x) { @@ -1756,8 +1758,7 @@ g->sb_hybrid[s_index++] = v; } } - while (s_index < 576) - g->sb_hybrid[s_index++] = 0; + memset(&g->sb_hybrid[s_index], 0, sizeof(*g->sb_hybrid)*(576 - s_index)); return 0; }