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;
}

有效:

aix​​7.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

但是

aix​​6.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