mirror of
https://github.com/yuzu-emu/FasTC.git
synced 2025-01-23 19:11:05 +00:00
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:
parent
168c6a0071
commit
19b5d478a0
|
@ -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);
|
||||||
|
|
Loading…
Reference in a new issue