init: cannot execve(‘/system/bin/logd‘): No such file or directory

当遇到此类log时,第一反应就是去探究文件系统的该目录下是否真的没有这个文件,经过一番折腾之后你会发现,文件是存在的。可是为什么errno却暴露出来:No such file or directory.
遇到这种情况一般是系统的动态链接器与XXX这个程序中的动态链接器的名字或路径不对,可以在你的编译目录下找到报对应的文件/system/bin/logd,然后用readelf -l logd:

Program Headers:
Type Offset VirtAddr PhysAddr
FileSiz MemSiz Flags Align
PHDR 0x0000000000000040 0x0000000000000040 0x0000000000000040
0x0000000000000230 0x0000000000000230 R 8
INTERP 0x0000000000000270 0x0000000000000270 0x0000000000000270
0x0000000000000015 0x0000000000000015 R 1
[Requesting program interpreter: /system/bin/linker64]

LOAD 0x0000000000000000 0x0000000000000000 0x0000000000000000
0x000000000000c6fc 0x000000000000c6fc R 1000
LOAD 0x000000000000d000 0x000000000000d000 0x000000000000d000
0x000000000002ea70 0x000000000002ea70 R E 1000
LOAD 0x000000000003c000 0x000000000003c000 0x000000000003c000
0x0000000000002210 0x0000000000003284 RW 1000
DYNAMIC 0x000000000003d740 0x000000000003d740 0x000000000003d740
0x0000000000000260 0x0000000000000260 RW 8
GNU_RELRO 0x000000000003d000 0x000000000003d000 0x000000000003d000
0x0000000000001210 0x0000000000002000 R 1
GNU_EH_FRAME 0x000000000000630c 0x000000000000630c 0x000000000000630c
0x0000000000000cbc 0x0000000000000cbc R 4
GNU_STACK 0x0000000000000000 0x0000000000000000 0x0000000000000000
0x0000000000000000 0x0000000000000000 RW 0
NOTE 0x0000000000000288 0x0000000000000288 0x0000000000000288
0x0000000000000038 0x0000000000000038 R 4

注意这一行 INTERP 这里的**[Requesting program interpreter: /system/bin/linker64]**就是rootcause. 把对应的文件编译到这个指定的地方,问题即可解决。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值