[MPlayer-cvslog] r25167 - trunk/libmpcodecs/ad_hwac3.c
reimar
subversion at mplayerhq.hu
Mon Nov 26 20:01:35 CET 2007
Author: reimar
Date: Mon Nov 26 20:01:34 2007
New Revision: 25167
Log:
Simplify convert_14bits_to_16bits function in ad_hwac3
Modified:
trunk/libmpcodecs/ad_hwac3.c
Modified: trunk/libmpcodecs/ad_hwac3.c
==============================================================================
--- trunk/libmpcodecs/ad_hwac3.c (original)
+++ trunk/libmpcodecs/ad_hwac3.c Mon Nov 26 20:01:34 2007
@@ -424,35 +424,27 @@ static int convert_14bits_to_16bits(cons
int is_le)
{
uint16_t *p = (uint16_t *)dest;
+ uint16_t buf = 0;
int spacebits = 16;
- int leftbits;
+ if (len <= 0) return 0;
while (len > 0) {
uint16_t v;
if (len == 1)
v = is_le ? src[0] : src[0] << 8;
else
v = is_le ? src[1] << 8 | src[0] : src[0] << 8 | src[1];
- leftbits = 14;
+ v <<= 2;
src += 2;
len -= 2;
- if (spacebits == 0) {
- ++p;
- spacebits = 16;
- }
- if (spacebits == 16)
- *p = 0;
- if (spacebits < leftbits) {
- leftbits -= spacebits;
- *p |= (v & 0x3FFF) >> leftbits;
- ++p;
- *p = 0;
- spacebits = 16;
+ buf |= v >> (16 - spacebits);
+ spacebits -= 14;
+ if (spacebits < 0) {
+ *p++ = buf;
+ spacebits += 16;
+ buf = v << (spacebits - 2);
}
- *p |= ((v << (16 - leftbits)) & 0xFFFF) >> (16 - spacebits);
- spacebits -= leftbits;
}
- if (spacebits < 16)
- ++p;
+ *p++ = buf;
return (unsigned char *)p - dest;
}
More information about the MPlayer-cvslog
mailing list