sigsegv 发生在 posix_memalign 紧接在某些设备和 AIX 中的编译选项之后
sigsegv occured when posix_memalign immediately after free in some devices and compile option in AIX
我被分配到一个指针,它立即空闲,但根据某些设备和 xlc 选项,会出现 sigsegv。
xlC_r -o cc.o c.c -lhm 发生了 sigsegv,但 xlC_r -o cc.o c.c 有效。
( lhm 选项正在链接 libhm.a libhu.a。)
( malloc 和免费的作品。只发生 posix_memalign 和免费的 sigsegv。)
源代码:
#include<stdlib.h>
#include<stdio.h>
int main()
{
void * sPtr = NULL;
size_t sAlign = 8388608;
size_t sSize = 8388648;
int sRet = 0;
sRet = posix_memalign(&sPtr, sAlign, sSize);
printf( "after malloc : %p return : %d\n", sPtr, sRet );
free(sPtr);
printf( "after free\n" );
return 0;
}
有效:
aix7.1 tl3 IBM XL C/C++ 用于 AIX,V12.1(5765-J02、5725-C72)版本:12.01.0000.0000
aix6.1 tl9 IBM XL C/C++ 用于 AIX,V10.1 版本:10.01.0000.0008
结果是:
after malloc : 22000000 return : 0
after free
但是
aix6.1 tl3 IBM XL C/C++ 用于 AIX,V10.1 版本:10.01.0000.0008
aix5.3 tl9 IBM XL C/C++ 用于 AIX,V10.1 版本:10.01.0000.0000
aix5.3 tl1 C 用于 AIX 版本 6.0.0.0
版本:10.01.0000.0000
结果是
after malloc : 22000000 return : 0
Segmentation fault (core dumped)
% dbx cc.o core
Type 'help' for help.
[using memory image in core]
reading symbolic information ...
Segmentation fault in _ufree at 0xd3c0fcc4 ($t1)
0xd3c0fcc4 (_ufree+0x44) 80be0000 lwz r5,0x0(r30)
(dbx) where
_ufree(??) at 0xd3c0fcc4
cbase.free(??) at 0xd2b7c048
main(), line 16 in "c.c"
虽然我已经尝试了一个多星期,但我还没有解决这个问题。我搜索了 AIX 的错误报告,但找不到。
无法同时删除 posix_memalign 和 lhm 选项。
您知道解决方法或解决方法吗?
libhm 和 libhmd 是调试内存管理库。他们通过在 malloc 之后保留额外的信息来检测错误,然后在释放之前检查该块之前没有被释放并且它是通过 malloc 分配的。这些库不处理 posix_memalign 并且不为其保留额外信息。因此,当您在 posix_memalign 之后调用 free 时,他们认为您正在尝试释放未正确分配的内存。也就是说,我不记得会导致分段错误,而是误报错误消息。 (比起 libhm,我更习惯 libhmd。)
不再维护这些库。例如,请参阅 XLF compiler manual page for them. The official recommendation is to use AIX's native debug malloc tool。
我被分配到一个指针,它立即空闲,但根据某些设备和 xlc 选项,会出现 sigsegv。
xlC_r -o cc.o c.c -lhm 发生了 sigsegv,但 xlC_r -o cc.o c.c 有效。
( lhm 选项正在链接 libhm.a libhu.a。)
( malloc 和免费的作品。只发生 posix_memalign 和免费的 sigsegv。)
源代码:
#include<stdlib.h>
#include<stdio.h>
int main()
{
void * sPtr = NULL;
size_t sAlign = 8388608;
size_t sSize = 8388648;
int sRet = 0;
sRet = posix_memalign(&sPtr, sAlign, sSize);
printf( "after malloc : %p return : %d\n", sPtr, sRet );
free(sPtr);
printf( "after free\n" );
return 0;
}
有效:
aix7.1 tl3 IBM XL C/C++ 用于 AIX,V12.1(5765-J02、5725-C72)版本:12.01.0000.0000
aix6.1 tl9 IBM XL C/C++ 用于 AIX,V10.1 版本:10.01.0000.0008
结果是:
after malloc : 22000000 return : 0
after free
但是
aix6.1 tl3 IBM XL C/C++ 用于 AIX,V10.1 版本:10.01.0000.0008
aix5.3 tl9 IBM XL C/C++ 用于 AIX,V10.1 版本:10.01.0000.0000
aix5.3 tl1 C 用于 AIX 版本 6.0.0.0
版本:10.01.0000.0000
结果是
after malloc : 22000000 return : 0
Segmentation fault (core dumped)
% dbx cc.o core
Type 'help' for help.
[using memory image in core]
reading symbolic information ...
Segmentation fault in _ufree at 0xd3c0fcc4 ($t1)
0xd3c0fcc4 (_ufree+0x44) 80be0000 lwz r5,0x0(r30)
(dbx) where
_ufree(??) at 0xd3c0fcc4
cbase.free(??) at 0xd2b7c048
main(), line 16 in "c.c"
虽然我已经尝试了一个多星期,但我还没有解决这个问题。我搜索了 AIX 的错误报告,但找不到。
无法同时删除 posix_memalign 和 lhm 选项。
您知道解决方法或解决方法吗?
libhm 和 libhmd 是调试内存管理库。他们通过在 malloc 之后保留额外的信息来检测错误,然后在释放之前检查该块之前没有被释放并且它是通过 malloc 分配的。这些库不处理 posix_memalign 并且不为其保留额外信息。因此,当您在 posix_memalign 之后调用 free 时,他们认为您正在尝试释放未正确分配的内存。也就是说,我不记得会导致分段错误,而是误报错误消息。 (比起 libhm,我更习惯 libhmd。)
不再维护这些库。例如,请参阅 XLF compiler manual page for them. The official recommendation is to use AIX's native debug malloc tool。