Fix alignment warnings with pointer casting

This commit is contained in:
Stella Lau 2017-06-29 12:39:34 -07:00
parent 99e315999c
commit c6a5275a28

View File

@ -103,18 +103,17 @@ size_t HUF_readDTableX2_wksp(HUF_DTable* DTable, const void* src, size_t srcSize
U32* rankVal;
BYTE* huffWeight;
size_t spaceUsed = 0;
size_t spaceUsed32 = 0;
rankVal = (U32 *)((BYTE *)workSpace + spaceUsed);
spaceUsed += sizeof(U32) * (HUF_TABLELOG_ABSOLUTEMAX + 1);
huffWeight = (BYTE *)workSpace + spaceUsed;
spaceUsed += HUF_SYMBOLVALUE_MAX + 1;
spaceUsed = ALIGN(spaceUsed, sizeof(U32));
rankVal = (U32 *)workSpace + spaceUsed32;
spaceUsed32 += HUF_TABLELOG_ABSOLUTEMAX + 1;
huffWeight = (BYTE *)((U32 *)workSpace + spaceUsed32);
spaceUsed32 += ALIGN(HUF_SYMBOLVALUE_MAX + 1, sizeof(U32)) >> 2;
if (spaceUsed > wkspSize)
if ((spaceUsed32 >> 2) > wkspSize)
return ERROR(tableLog_tooLarge);
workSpace = (BYTE *)workSpace + spaceUsed;
wkspSize -= spaceUsed;
workSpace = (U32 *)workSpace + spaceUsed32;
wkspSize -= (spaceUsed32 << 2);
HUF_STATIC_ASSERT(sizeof(DTableDesc) == sizeof(HUF_DTable));
/* memset(huffWeight, 0, sizeof(huffWeight)); */ /* is not necessary, even though some analyzer complain ... */
@ -512,24 +511,23 @@ size_t HUF_readDTableX4_wksp(HUF_DTable* DTable, const void* src,
U32* rankStart0;
sortedSymbol_t* sortedSymbol;
BYTE* weightList;
size_t spaceUsed = 0;
size_t spaceUsed32 = 0;
rankVal = (rankValCol_t *)((BYTE *)workSpace + spaceUsed);
spaceUsed += sizeof(rankValCol_t) * HUF_TABLELOG_MAX;
rankStats = (U32 *)((BYTE *)workSpace + spaceUsed);
spaceUsed += sizeof(U32) * (HUF_TABLELOG_MAX + 1);
rankStart0 = (U32 *)((BYTE *)workSpace + spaceUsed);
spaceUsed += sizeof(U32) * (HUF_TABLELOG_MAX + 2);
sortedSymbol = (sortedSymbol_t *)((BYTE *)workSpace + spaceUsed);
spaceUsed += sizeof(sortedSymbol_t) * (HUF_SYMBOLVALUE_MAX + 1);
weightList = (BYTE *)workSpace + spaceUsed;
spaceUsed += HUF_SYMBOLVALUE_MAX + 1;
spaceUsed = ALIGN(spaceUsed, sizeof(U32));
rankVal = (rankValCol_t *)((U32 *)workSpace + spaceUsed32);
spaceUsed32 += (sizeof(rankValCol_t) * HUF_TABLELOG_MAX) >> 2;
rankStats = (U32 *)workSpace + spaceUsed32;
spaceUsed32 += HUF_TABLELOG_MAX + 1;
rankStart0 = (U32 *)workSpace + spaceUsed32;
spaceUsed32 += HUF_TABLELOG_MAX + 2;
sortedSymbol = (sortedSymbol_t *)((U32 *)workSpace + spaceUsed32);
spaceUsed32 += ALIGN(sizeof(sortedSymbol_t) * (HUF_SYMBOLVALUE_MAX + 1), sizeof(U32)) >> 2;
weightList = (BYTE *)((U32 *)workSpace + spaceUsed32);
spaceUsed32 += ALIGN(HUF_SYMBOLVALUE_MAX + 1, sizeof(U32)) >> 2;
if (spaceUsed > wkspSize)
if ((spaceUsed32 >> 2) > wkspSize)
return ERROR(tableLog_tooLarge);
workSpace = (BYTE *)workSpace + spaceUsed;
wkspSize -= spaceUsed;
workSpace = (U32 *)workSpace + spaceUsed32;
wkspSize -= (spaceUsed32 << 2);
rankStart = rankStart0 + 1;
memset(rankStats, 0, sizeof(U32) * (2 * HUF_TABLELOG_MAX + 2 + 1));