如何在不使用共享库的情况下将 C 程序编译为 FDPIC_ELF
how to compile a C program as FDPIC_ELF without using Shared Libs
我的平台:
Host:
| OS: Ubuntu 20 LTS
| Kernel: Microsoft WSL2 Linux Kernel
| Cross compile Toolchain: arm-linux-gnueabi-gcc
|__
Target:
| Board: Waveshare CoreH7XXI
| SOC: stm32h743 (Single Core Cortex M7 @400MHz)
| Architecture: ARMV7e-M
| Onboard DRAM: 8MB - 2.9MB(u-boot and kernel) = 5.1MB Free Space
| Linux Kernel: 5.8.10 (stable 2020-09-17)
| Busybox: latest stable version
|__
首先,我的平台是无MMU的,无MMU平台不能运行正常ET_EXEC类型elf和可执行文件的格式应该是 FDPIC_ELF(具有 ET_DYN
类型的 ELF,应该是 PICPIE/(与位置无关 Code/Executable))。
这是我的示例程序:
#include <stdio.h>
int main() {
printf("Hello World!");
return 0;
}
我想以一种不依赖外部共享库(例如 ld-linux.so.3 和 libc.so.6)的方式编译它,因为内核会加载整个将库放入 ram,它们会消耗大量 RAM!
如何在不使用外部共享库的情况下将我的程序编译为具有 ET_DYN
类型和 PIC/PIE
的精灵。注意,如果我使用-static
,生成的精灵不能是ET_DYN
和PIC/PIE
类型。那么,我该怎么办呢???
您想要实现的目标在规定的限制条件下是不可能的。
ld-linux.so.3
是动态加载器(ld.so
),确实表示为动态库
任何 ET_DYN
ELF 文件都需要一个动态加载器——这就是为什么它是一个 动态 文件。不需要动态加载器的唯一方法是拥有一个静态文件——但那样你就不会得到一个 ET_DYN
,而是一个 ET_EXEC
.
我的平台:
Host:
| OS: Ubuntu 20 LTS
| Kernel: Microsoft WSL2 Linux Kernel
| Cross compile Toolchain: arm-linux-gnueabi-gcc
|__
Target:
| Board: Waveshare CoreH7XXI
| SOC: stm32h743 (Single Core Cortex M7 @400MHz)
| Architecture: ARMV7e-M
| Onboard DRAM: 8MB - 2.9MB(u-boot and kernel) = 5.1MB Free Space
| Linux Kernel: 5.8.10 (stable 2020-09-17)
| Busybox: latest stable version
|__
首先,我的平台是无MMU的,无MMU平台不能运行正常ET_EXEC类型elf和可执行文件的格式应该是 FDPIC_ELF(具有 ET_DYN
类型的 ELF,应该是 PICPIE/(与位置无关 Code/Executable))。
这是我的示例程序:
#include <stdio.h>
int main() {
printf("Hello World!");
return 0;
}
我想以一种不依赖外部共享库(例如 ld-linux.so.3 和 libc.so.6)的方式编译它,因为内核会加载整个将库放入 ram,它们会消耗大量 RAM!
如何在不使用外部共享库的情况下将我的程序编译为具有 ET_DYN
类型和 PIC/PIE
的精灵。注意,如果我使用-static
,生成的精灵不能是ET_DYN
和PIC/PIE
类型。那么,我该怎么办呢???
您想要实现的目标在规定的限制条件下是不可能的。
ld-linux.so.3
是动态加载器(ld.so
),确实表示为动态库
任何 ET_DYN
ELF 文件都需要一个动态加载器——这就是为什么它是一个 动态 文件。不需要动态加载器的唯一方法是拥有一个静态文件——但那样你就不会得到一个 ET_DYN
,而是一个 ET_EXEC
.