Fix small bug:

Set the bits that aren't being used in the texel data to zero so that
the integer decoding sequence recreates the proper texel values for
trits and quints that don't have as many bits as there are expected
values.
This commit is contained in:
Pavel Krajcevski 2014-11-04 18:22:05 -05:00
parent 168c6a0071
commit 19b5d478a0

View file

@ -912,6 +912,18 @@ namespace ASTCC {
} }
assert(strm.GetBitsRead() + weightParams.GetPackedBitSize() == 128); assert(strm.GetBitsRead() + weightParams.GetPackedBitSize() == 128);
// Decode both color data and texel weight data
uint32 colorValues[32]; // Four values, two endpoints, four maximum paritions
DecodeColorValues(colorValues, colorEndpointData, colorEndpointMode,
nPartitions, colorDataBits);
FasTC::Pixel endpoints[4][2];
const uint32 *colorValuesPtr = colorValues;
for(uint32 i = 0; i < nPartitions; i++) {
ComputeEndpoints(endpoints[i][0], endpoints[i][1],
colorValuesPtr, colorEndpointMode[i]);
}
// Read the texel weight data.. // Read the texel weight data..
uint8 texelWeightData[16]; uint8 texelWeightData[16];
memcpy(texelWeightData, inBuf, sizeof(texelWeightData)); memcpy(texelWeightData, inBuf, sizeof(texelWeightData));
@ -928,10 +940,10 @@ namespace ASTCC {
texelWeightData[15-i] = a; texelWeightData[15-i] = a;
} }
// Decode both color data and texel weight data // Make sure that higher non-texel bits are set to zero
uint32 colorValues[32]; // Four values, two endpoints, four maximum paritions const uint32 clearByteStart = (weightParams.GetPackedBitSize() >> 3) + 1;
DecodeColorValues(colorValues, colorEndpointData, colorEndpointMode, texelWeightData[clearByteStart - 1] &= (1 << (weightParams.GetPackedBitSize() % 8)) - 1;
nPartitions, colorDataBits); memset(texelWeightData + clearByteStart, 0, 16 - clearByteStart);
std::vector<IntegerEncodedValue> texelWeightValues; std::vector<IntegerEncodedValue> texelWeightValues;
FasTC::BitStreamReadOnly weightStream (texelWeightData); FasTC::BitStreamReadOnly weightStream (texelWeightData);
@ -941,13 +953,6 @@ namespace ASTCC {
weightParams.m_MaxWeight, weightParams.m_MaxWeight,
weightParams.GetNumWeightValues()); weightParams.GetNumWeightValues());
FasTC::Pixel endpoints[4][2];
const uint32 *colorValuesPtr = colorValues;
for(uint32 i = 0; i < nPartitions; i++) {
ComputeEndpoints(endpoints[i][0], endpoints[i][1],
colorValuesPtr, colorEndpointMode[i]);
}
// Blocks can be at most 12x12, so we can have as many as 144 weights // Blocks can be at most 12x12, so we can have as many as 144 weights
uint32 weights[2][144]; uint32 weights[2][144];
UnquantizeTexelWeights(weights, texelWeightValues, weightParams, blockWidth, blockHeight); UnquantizeTexelWeights(weights, texelWeightValues, weightParams, blockWidth, blockHeight);