【问题标题】:Why sum of symbol size much less than ".text" section size?为什么符号大小的总和远小于“.text”部分的大小?
【发布时间】:2020-05-20 03:51:34
【问题描述】:

我在linux中调试一个动态共享库,库的名字是libMNN.so

这是libMNN.so的所有部分的大小size -A ./libMNN.so

section                  size      addr
.note.gnu.build-id         36       512
.hash                    2288       552
.dynsym                  7368      2840
.dynstr                 11637     10208
.gnu.version              614     21846
.gnu.version_r             64     22464
.rela.dyn               78720     22528
.rela.plt                3960    101248
.plt                     2672    105216
.text                  804416    107904
.rodata                 17772    912320
.eh_frame_hdr           21460    930092
.eh_frame               79160    951552
.note.android.ident       152   1030712
.init_array              1400   1097864
.fini_array                16   1099264
.data.rel.ro            33232   1099280
.dynamic                  560   1132512
.got                     1512   1133072
.data                       8   1134592
.bss                      392   1134608
.comment                  100         0
Total                 1067539

我们可以看到“.text”的大小是804416,“.rodata”的大小是17772。

这是通过命令readelf -D -sW ./libMNN.so | awk '{print $4}' | awk '{s+=$1} END {print s}'得到的符号大小的总和:

79000

符号大小之和远小于“.text”和“.rodata”,为什么?

libMNN.so可以从https://github.com/alibaba/MNN/releases/download/1.0.0/Android.zip下载

【问题讨论】:

  • 您是否尝试过使用objdump 查看文本部分的实际内容?

标签: linux gcc compilation elf readelf


【解决方案1】:

LibMNN 不导出静态、内部和内联函数(通过将它们的可见性设置为“隐藏”),因此您看不到它们的符号。由于符号对齐和文字池(存储在 ARM 上的 .text 中),浪费了更多空间。

【讨论】:

    猜你喜欢
    • 2016-01-19
    • 2021-06-12
    • 1970-01-01
    • 1970-01-01
    • 2013-08-06
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2012-12-19
    相关资源
    最近更新 更多