我在使用带有新FFI的PHP中的第三方.so库时遇到问题。当我运行这段代码时:
<?php
$ffi = FFI::cdef('typedef int (*NFE_Nome)(const char* sNome, int* esTamanho);', 'libacbrnfe64.so');
PHP向我输出此错误:
double free or corruption (out)
Aborted (core dumped)
这是库本身,我的PHP配置或其他问题吗?这让我感到困惑,因为我通常可以将此同一个库与此C ++代码一起使用:
#include <iostream>
#include <dlfcn.h>
typedef int (*NFE_Nome)(const char* sNome, int* esTamanho);
#define BUFFER_LEN 256
int main() {
void *lib = dlopen("libacbrnfe64.so", RTLD_LAZY);
auto libMethod = (NFE_Nome) dlsym(lib, "NFE_Nome");
const std::string bufferNome(BUFFER_LEN, ' ');
int bufferNomeLength = BUFFER_LEN;
libMethod(bufferNome.c_str(), &bufferNomeLength);
std::cout << bufferNome << std::endl;
return 0;
}
我知道PHP代码不会执行NFE_Nome函数,但是在尝试调用函数本身之前遇到了错误。
-编辑-
此问题是两个不同程序中的两个错误的结果。
链接共享对象时,fpc-3.0.0(或更高版本)会将其添加到依赖项中(作为第一个依赖项): /lib64/ld-linux-x86-64.so.2
ld-linux-x86-64.so.2导出一个calloc
变体,该变体不会(总是)清除它返回的内存(详细信息如下)
建议的解决方法OP是在单独的过程中链接(使用的-E
(或-Cn
)选项fpc
),但在运行./ppas.sh
修订link.res
文件之前。为此,我修改了这个awk脚本,但确实感到有些笨拙:
#!/usr/bin/awk -f
$0=="INPUT(" { state=1; next; }
$0=="/lib64/ld-linux-x86-64.so.2" { state=2; next; }
$0==")" && state>0 { state=0;next; }
state==1 { print "INPUT("; state=0; }
{ print $0; }
-原始答案-
听起来像是一个链接问题:您可能已将其添加/lib64/ld-linux-x86-64.so.2
到依赖的共享库中,这既不是必需的,也不是有用的。
实际上,它导致了一个calloc
返回非零内存的版本。此处描述了详细信息:https : //www.linuxquestions.org/questions/programming-9/debugging-dlopen-4175668676/此处:为什么在gdb中调用calloc似乎不会使内存清零?
建议的解决方案:根据示例更改链接:
- gcc -shared -o demodule.so demodule.o /lib64/ld-linux-x86-64.so.2 -lglib-2.0
+ gcc -shared -o demodule.so demodule.o -lglib-2.0
可以使用来检查差异readelf -d
。错误:
Dynamic section at offset 0x828 contains 26 entries:
Tag Type Name/Value
0x0000000000000001 (NEEDED) Shared library: [ld-linux-x86-64.so.2]
0x0000000000000001 (NEEDED) Shared library: [libglib-2.0.so.0]
0x0000000000000001 (NEEDED) Shared library: [libc.so.6]
正确的输出:
Dynamic section at offset 0x7f8 contains 25 entries:
Tag Type Name/Value
0x0000000000000001 (NEEDED) Shared library: [libglib-2.0.so.0]
0x0000000000000001 (NEEDED) Shared library: [libc.so.6]
同样,使用命令ldd demodule.so
,包含的行/lib64/ld-linux-x86-64.so.2
应该是最后一行。
编辑:关于此问题的关于sourceware.org的讨论:https ://sourceware.org/bugzilla/show_bug.cgi?id = 25486
编辑:在Freepascal方面:https ://bugs.freepascal.org/view.php ? id = 36706
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句