如何在android上运行与glibc.so链接的应用程序

时间:2018-04-19 05:52:33

标签: gcc glibc

编译器是gcc-linaro-5.5.0-2017.10-i686_arm-linux-gnueabihf.tar.xz,app在armv7 android4.4设备上运行

我的C代码是test.c,

#include"stdio.h"
int main(void)
{
        printf("starting...\n");
        return 0;
}

如果我编译它使用命令:

arm-linux-gnueabihf-gcc -o test_s test.c -g -Wl,-rpath=.:./lib -Wl,-rpath=.:./lib -Wl,-q -Wl,-dynamic-linker=ld-2.21.so -static

它可以很好地工作:

root@test:/data/mine # chmod 555 test_s
root@test:/data/mine # ./test_s
starting

但是,如果我编译它使用命令:

 arm-linux-gnueabihf-gcc -o test_d test.c -g -Wl,-rpath=.:./lib -Wl,-rpath=.:./lib -Wl,-q -Wl,-dynamic-linker=ld-2.21.so

它给了我错误:

root@test:/data/mine # chmod 555 test_d
root@test:/data/mine # ls -l test_d
-rwxrwxrwx root     root        12316 2018-04-19 13:37 test_d
root@test:/data/mine # ./test_d
/system/bin/sh: ./test_d: Permission denied

我已将所需的动态库复制到路径/ data / mine / lib

我该如何处理这个问题?

更新

在运行命令mount -o remount,exec / data之前 命令mount return:

/dev/block/platform/comip-mmc.1/by-name/userdata /data ext4 rw,seclabel,nosuid,nodev,noatime,noauto_da_alloc,data=ordered 0 0

运行 mount -o remount,exec / data 之后 mount 返回:

/dev/block/platform/comip-mmc.1/by-name/userdata /data ext4 rw,seclabel,relatime,noauto_da_alloc,data=ordered 0 0

我再次运行 strace ./test_d ,它给了我相同的结果EACCES。 我认为“EACCES文件系统已挂载noexec”不是根本原因,因为test_s位于同一目录中,并且运行正确

我尝试使用命令进行编译: arm-linux-gnueabihf-gcc -o test_d_ndl test.c -g -Wl,-rpath =。:。/ lib

arm-linux-gnueabihf-readelf -d test_d_ndl
  Tag        Type                         Name/Value
 0x00000001 (NEEDED)                     Shared library: [libc.so.6]
 0x0000000f (RPATH)                      Library rpath: [.:./lib]

我将libc.so.6复制到path / data / mine并运行commond

root@test:/data/mine # ls -l
-rw-rw-rw- root     root       774660 2018-04-20 13:32 ld-2.21.so
drwxrwxr-x root     root              2018-04-17 14:43 lib
-rw-rw-rw- root     root      9180280 2018-04-20 16:50 libc.so.6
-rwxrwxrwx root     root        13808 2018-04-18 16:56 test
-rwxrwxrwx root     root        12316 2018-04-20 13:31 test_d
-r-xr-xr-x root     root        10520 2018-04-20 16:46 test_d_ndl
-rwxrwxrwx root     root         3348 2018-04-20 09:47 test_ld
-rwxrwxrwx root     root      3672356 2018-04-19 09:58 test_s

root@test:/data/mine # strace  ./test_d_ndl
execve("./test_d_ndl", ["./test_d_ndl"], [/* 25 vars */]) = -1 ENOENT (No such file or directory)
write(2, "strace: exec", 12strace: exec)            = 12
write(2, ": ", 2: )                       = 2
write(2, "No such file or directory", 25No such file or directory) = 25
write(2, "\n", 1
)                       = 1
exit_group(1)                           = ?

test_d_ndl给出错误原因ENOENT,我接下来该怎么办?

更新

使用以下命令效果很好

arm-linux-gnueabihf-gcc test.c -o test_r_dl -Wl,-rpath = / data / mine / libc / lib -Wl,-dynamic-linker = / data / mine / libc / lib / ld-2.21的.so

1 个答案:

答案 0 :(得分:0)

  

如果我编译它使用命令:... -Wl,-dynamic-linker=ld-2.21.so ...

使用--dynamic-linker的相对路径是生病 - 修改:您的应用将运行IFF,当前工作目录中有./ld-2.21.so

  

我已将所需的动态库复制到路径/data/mine/lib

由于您在启动二进制文件时不在/data/mine/lib,并且假设您 ld-2.21.so复制到/data/mine,找不到动态链接器。

然而,通常这是使用ENOENT而非EPERM报告的,因此我不确定这是您真正的问题。运行strace ./test_d可能会提供更多线索。

<强>更新

  

root@test:/data/mine # strace ./test_d execve("./test_d", ["./test_d"], [/* 25 vars */]) = -1 EACCES (Permission denied) ...

execve man page说:

EACCES The filesystem is mounted noexec.

听起来这可能是导致错误的直接原因。

(一旦mount -o remount,exec /data/mine,它很可能会以ENOENT开始失败。)