无法从共享目录中映射段 linux,dopen():未作为root用户运行时,“无法从共享对象映射段”...

我正在尝试在自制的Yocto Linux下加载一些自行编写的库。

当以root身份运行同一程序,但不能以另一个后来添加的用户身份运行该程序时,它运行良好。for ()

{

m_HModule = dlopen(Filename.c_str(), RTLD_NOW | RTLD_GLOBAL);

if (m_HModule == NULL)

{

fprintf(stderr, "Error: %s\n", dlerror());

}

else

{

cout << "Loaded module " << Filename << endl;

}

}

不幸的是,我的dlerror()版本没有返回非常精确的信息:Loaded module /opt/epic/libepicGpioToggle.so

Loaded module /opt/epic/libepicSaveImage.so

Error: libboost_filesystem.so.1.66.0: failed to map segment from shared object

Loaded module /opt/epic/libepicFpgaCommunicatorUserDemo.so

Error: /opt/epic/libepicCommunicatorFpga.so: failed to map segment from shared object

Error: /opt/epic/libepicDataproviderTimedData.so: failed to map segment from shared object

Error: /opt/epic/libepicDataproviderFromCamera.so: failed to map segment from shared object

Loaded module /opt/epic/libepicFramework.so

Error: /opt/epic/libepicTriggerMonitor.so: failed to map segment from shared object

Error: /opt/epic/libepicTemplate.so: failed to map segment from shared object

即使具有最大文件权限chmod 777 *且所有库均由调用用户拥有,它也不起作用。 以root用户或通过sudo运行时,一切正常。

是的,其中一些库使用boost元素,这些元素在/ lib下都可用,并且可由调用用户访问。 如果我不尝试加载引用boost的库,则其他故障仍然存在。

总是相同的库无法加载; 顺序似乎无关紧要。 我所有库的编译器设置看起来都一样,并且都在同一“模板项目”中缩写。

我使用ldd检查了依赖项, straced所有系统调用进行了straced ,除了错误消息之外,没有发现任何区别。

用户的外壳环境env与root用户的环境相同。

使用export LD_DEBUG=files ,我看到了4231: file=/opt/epic/libepicSaveImage.so [0]; dynamically loaded by ./libepicFramework.so [0]

4231: file=/opt/epic/libepicSaveImage.so [0]; generating link map

4231: dynamic: 0x0000ffff8b56fd60 base: 0x0000ffff8b524000 size: 0x000000000004d608

4231: entry: 0x0000ffff8b5487a0 phdr: 0x0000ffff8b524040 phnum: 7

4231:

4231:

4231: file=/opt/epic/libepicGpioToggle.so [0]; needed by /opt/epic/libepicSaveImage.so [0] (relocation dependency)

4231:

4231:

4231: calling init: /opt/epic/libepicSaveImage.so

4231:

4231: opening file=/opt/epic/libepicSaveImage.so [0]; direct_opencount=1

4231:

Loaded module /opt/epic/libepicSaveImage.s

成功加载,但4231: file=/opt/epic/libepicCommunicatorFpga.so [0]; dynamically loaded by ./libepicFramework.so [0]

4231: file=/opt/epic/libepicCommunicatorFpga.so [0]; generating link map

Error: /opt/epic/libepicCommunicatorFpga.so: failed to map segment from shared object

对于失败。

用户限制ulimits -a对root和user看起来都一样:core file size (blocks, -c) unlimited

data seg size (kbytes, -d) unlimited

scheduling priority (-e) 0

file size (blocks, -f) unlimited

pending signals (-i) 10974

max locked memory (kbytes, -l) 16384

max memory size (kbytes, -m) unlimited

open files (-n) 1024

pipe size (512 bytes, -p) 8

POSIX message queues (bytes, -q) 819200

real-time priority (-r) 0

stack size (kbytes, -s) 8192

cpu time (seconds, -t) unlimited

max user processes (-u) 10974

virtual memory (kbytes, -v) unlimited

file locks (-x) unlimited

我将max locked memory增加到100 MB,但是没有任何变化。

从用户的角度来看有什么不同?

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值