AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / unix / 问题 / 543205
Accepted
Shuzheng
Shuzheng
Asked: 2019-09-24 03:55:08 +0800 CST2019-09-24 03:55:08 +0800 CST 2019-09-24 03:55:08 +0800 CST

动态链接器/加载器本身如何按照“文件”的报告进行动态链接?

  • 772

考虑 的共享对象依赖关系/bin/bash,其中包括/lib64/ld-linux-x86-64.so.2(动态链接器/加载器):

ldd /bin/bash
    linux-vdso.so.1 (0x00007fffd0887000)
    libtinfo.so.6 => /lib/x86_64-linux-gnu/libtinfo.so.6 (0x00007f57a04e3000)
    libdl.so.2 => /lib/x86_64-linux-gnu/libdl.so.2 (0x00007f57a04de000)
    libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007f57a031d000)
    /lib64/ld-linux-x86-64.so.2 (0x00007f57a0652000)

检查/lib64/ld-linux-x86-64.so.2表明它是一个符号链接/lib/x86_64-linux-gnu/ld-2.28.so:

ls -la /lib64/ld-linux-x86-64.so.2 
lrwxrwxrwx 1 root root 32 May  1 19:24 /lib64/ld-linux-x86-64.so.2 -> /lib/x86_64-linux-gnu/ld-2.28.so

此外,file报告/lib/x86_64-linux-gnu/ld-2.28.so自身是动态链接的:

file -L /lib64/ld-linux-x86-64.so.2
/lib64/ld-linux-x86-64.so.2: ELF 64-bit LSB pie executable, x86-64, version 1 (SYSV), dynamically linked, BuildID[sha1]=f25dfd7b95be4ba386fd71080accae8c0732b711, stripped

我想知道:

  1. 动态链接器/加载器 ( /lib64/ld-linux-x86-64.so.2) 本身如何动态链接?它是否在运行时链接自身?
  2. /lib/x86_64-linux-gnu/ld-2.28.so记录处理 a.out 二进制文件(man ld.so),但是/bin/bashELF 可执行文件吗?

程序 ld.so 处理 a.out 二进制文件,这是一种很久以前使用的格式;ld-linux.so*(/lib/ld-linux.so.1 用于 libc5,/lib/ld-linux.so.2 用于 glibc2)处理 ELF,每个人都已经使用多年了。

linux
  • 2 2 个回答
  • 2535 Views

2 个回答

  • Voted
  1. Best Answer
    Stephen Kitt
    2019-09-24T06:23:54+08:002019-09-24T06:23:54+08:00
    1. 是的,它在初始化时会自行链接。从技术上讲,动态链接器本身不需要对象解析和重定位,因为它完全按原样解析,但它确实定义了符号,并且在解析它“解释”的二进制文件时必须处理这些符号,并且这些符号被更新指向它们在加载的库中的实现。特别是,这会影响malloc- 链接器有一个内置的最小版本,带有相应的符号,但是一旦加载和重定位它就会被 C 库的版本替换(如果有的话,甚至被插入的版本替换),需要小心采取以确保这不会发生在可能会破坏链接器的地方。

      血淋淋的细节在rtld.c函数中dl_main。

      但是请注意,ld.so它没有外部依赖项。您可以看到与nm -D;相关的符号。它们都不是未定义的。

    2. 手册页仅引用直接在 下的条目/lib,即 /lib/ld.so(支持 的 libc 5 动态链接器a.out)和/lib*/ld-linux*.so*(支持 ELF 的 libc 6 动态链接器)。手册页非常具体,而ld.so不是ld-2.28.so.

      在绝大多数当前系统上发现的动态链接器不包括a.out支持。

    file并ldd为动态链接器报告不同的内容,因为它们对构成静态链接二进制文件的定义不同。对于ldd,如果二进制文件没有DT_NEEDED符号,即没有未定义的符号,则它是静态链接的。对于file,如果 ELF 二进制文件没有PT_DYNAMIC节,则它是静态链接的(这将在file5.37 之后的版本中更改;它现在使用PT_INTERP节的存在作为动态链接二进制文件的指示符,这与中的注释相匹配编码)。

    GNU C 库动态链接器没有任何DT_NEEDED符号,但它确实有一个PT_DYNAMIC部分(因为它在技术上是一个共享库)。结果,ldd(即动态链接器)表明它是静态链接的,但file表明它是动态链接的。它没有PT_INTERP部分,因此下一个版本file也将表明它是静态链接的。

    $ ldd /lib64/ld-linux-x86-64.so.2
            statically linked
    
    $ file $(readlink /lib64/ld-linux-x86-64.so.2)
    /lib/x86_64-linux-gnu/ld-2.28.so: ELF 64-bit LSB pie executable, x86-64, version 1 (SYSV), dynamically linked, BuildID[sha1]=f25dfd7b95be4ba386fd71080accae8c0732b711, stripped
    

    (与file5.35)

    $ file $(readlink /lib64/ld-linux-x86-64.so.2)
    /lib/x86_64-linux-gnu/ld-2.28.so: ELF 64-bit LSB shared object, x86-64, version 1 (SYSV), statically linked, BuildID[sha1]=f25dfd7b95be4ba386fd71080accae8c0732b711, stripped
    

    (使用当前正在开发的版本file)。

    • 21
  2. Hkoof
    2019-09-24T05:35:14+08:002019-09-24T05:35:14+08:00
    1. 我怀疑file程序在动态链接器/加载器本身被动态链接方面是错误的。ldd程序不同意。至少不在我的系统上(Debian Stretch):

      ldd /lib/x86_64-linux-gnu/ld-2.24.so
          statically linked
      
    2. man ld.so还写着:“ld-linux.so* 处理 ELF”。在您的系统上(顺便说一下我的系统),它们都是指向同一个二进制文件的符号链接,我推断它能够处理 ELF 和(旧的过时的)a.out 格式。

    • 0

相关问题

  • 有没有办法让 ls 只显示某些目录的隐藏文件?

  • 使用键盘快捷键启动/停止 systemd 服务 [关闭]

  • 需要一些系统调用

  • astyle 不会更改源文件格式

  • 通过标签将根文件系统传递给linux内核

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    模块 i915 可能缺少固件 /lib/firmware/i915/*

    • 3 个回答
  • Marko Smith

    无法获取 jessie backports 存储库

    • 4 个回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    user12345 无法获取 jessie backports 存储库 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl 为什么大多数 systemd 示例都包含 WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve