• Kees Cook's avatar
    lib: zstd: Fix -Wstringop-overflow warning · 780f6a9a
    Kees Cook authored
    
    
    Fix the following -Wstringop-overflow warning when building with GCC 11+:
    
    lib/zstd/decompress/huf_decompress.c: In function ‘HUF_readDTableX2_wksp’:
    lib/zstd/decompress/huf_decompress.c:700:5: warning: ‘HUF_fillDTableX2.constprop’ accessing 624 bytes in a region of size 52 [-Wstringop-overflow=]
      700 |     HUF_fillDTableX2(dt, maxTableLog,
          |     ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
      701 |                    wksp->sortedSymbol, sizeOfSort,
          |                    ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
      702 |                    wksp->rankStart0, wksp->rankVal, maxW,
          |                    ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
      703 |                    tableLog+1,
          |                    ~~~~~~~~~~~
      704 |                    wksp->calleeWksp, sizeof(wksp->calleeWksp) / sizeof(U32));
          |
    ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    lib/zstd/decompress/huf_decompress.c:700:5: note: referencing argument 6 of type ‘U32 (*)[13]’ {aka ‘unsigned int (*)[13]’}
    lib/zstd/decompress/huf_decompress.c:571:13: note: in a call to function ‘HUF_fillDTableX2.constprop’
      571 | static void HUF_fillDTableX2(HUF_DEltX2* DTable, const U32 targetLog,
          |             ^~~~~~~~~~~~~~~~
    
    by using pointer notation instead of array notation.
    
    This is one of the last remaining warnings to be fixed before globally
    enabling -Wstringop-overflow.
    Co-developed-by: default avatarGustavo A. R. Silva <gustavoars@kernel.org>
    Signed-off-by: default avatarGustavo A. R. Silva <gustavoars@kernel.org>
    Cc: Nick Terrell <terrelln@fb.com>
    Signed-off-by: default avatarKees Cook <keescook@chromium.org>
    Signed-off-by: default avatarNick Terrell <terrelln@fb.com>
    780f6a9a
huf_decompress.c 67.2 KB