最近寫代碼,碰到一個奇葩問題,memcpy函數用起來,編譯居然提示我stackoverflow,簡直是對寫C的碼農的最大羞辱,WTF!
UINT8 numBuffers = 0;
UINT16 cpLength = 0;
// TPM2B_DIGEST *bufferList;
if(length%(MAX_DIGEST_BUFFER) != 0)
numBuffers = length/(MAX_DIGEST_BUFFER) + 1;
else
numBuffers = length/(MAX_DIGEST_BUFFER);
TPM2B_DIGEST *bufferList[numBuffers];
for(UINT8 i = 0; i < numBuffers; i++)
{
(bufferList)[i] = (TPM2B_DIGEST *)calloc(1,sizeof(TPM2B_DIGEST));
if(i < numBuffers-1)
{
// memcpy(bufferList[i]->t.buffer, &buffer[cpLength], MAX_DIGEST_BUFFER);
for( UINT16 m = 0; m < MAX_DIGEST_BUFFER; m++)
{
bufferList[i]->t.buffer[m] = buffer[m + cpLength];
}
cpLength = i * MAX_DIGEST_BUFFER;
}
if(i == numBuffers-1 )
{
for(UINT16 j= 0; j < (length-cpLength); j++)
{
bufferList[i]->t.buffer[j] = buffer[cpLength + j];
}
}
}
就是上面註釋掉的
memcpy(bufferList[i]->t.buffer, &buffer[cpLength], MAX_DIGEST_BUFFER);
編譯的時候,結果如下:
In file included from /usr/include/string.h:639:0,
from tpm2_sign.cpp:61:
In function ‘void* memcpy(void*, const void*, size_t)’,
inlined from ‘int computeDataHash(BYTE*, UINT16, TPMI_ALG_HASH, TPM2B_DIGEST*)’ at tpm2_sign.cpp:669:73:
/usr/include/x86_64-linux-gnu/bits/string3.h:53:71: error: call to void* __builtin___memcpy_chk(void*, const void*, long unsigned int, long unsigned int) will always overflow destination buffer [-Werror]
return __builtin___memcpy_chk (__dest, __src, __len, __bos0 (__dest));
自查半天,沒覺得有什麼錯,網上查了半天,居然查到一個“GCC Bugzilla – Bug 37060”,翻到最後跟我說是“fixed in GCC 4.7.0”
我gcc -v 查自己的gcc版本, 媽蛋, 都4.9.2了啊,我勒個去。
只好折衷,選個別的辦法解決問題,一位位的複製吧,不用memcpy了。
for( UINT16 m = 0; m < MAX_DIGEST_BUFFER; m++)
{
bufferList[i]->t.buffer[m] = buffer[m + cpLength];
}
尼瑪,現在還沒弄明白,到底是個神馬情況,有時間好好扒一扒這傢伙的老底,奶奶個腿兒的,先記下來!