[英]Cross compiling a kernel module ARM
我正在尝试为ARM交叉编译模块。 我将Sabrelite用作具有3.0.35内核版本的主板。 我正在使用开放式嵌入式生成内核映像。
我有交叉引用所需的所有工具链,如下所示:
回声$ CC:
arm-oe-linux-gnueabi-gcc -march = armv7-a -mthumb-interwork -mfloat-abi = hard -mfpu = neon -mtune = cortex-a9 --sysroot = / usr / local / oecore-x86_64 / sysroots / cortexa9hf-VFP氖-OE-Linux的gnueabi
回声$ CROSS_COMPILE:arm-oe-linux-gnueabi-
echo ARCH:手臂
(这只是我的工具链的一部分。)
这是我的makefile的一部分:
KSRC = kaodv-mod.c kaodv-debug.c kaodv-netlink.c kaodv-queue.c kaodv-ipenc.c kaodv-expl.c
KERNEL_DIR = /家庭/用户/ script_emulation / AODV /内核
KERNEL_INC = $(KERNEL_DIR)/包括THIS_DIR = $(shell pwd)
obj-m + = kaodv.o kaodv-objs:= kaodv-mod.o kaodv-debug.o kaodv-netlink.o kaodv-queue.o kaodv-ipenc.o kaodv-expl.o
默认:
$(MAKE)-C $(KERNEL_DIR)SUBDIRS = $(THIS_DIR)个模块
当我使用make命令启动它时,我得到了一个模块(.ko),但是奇怪的是生成的模块是使用主机工具链编译的,这意味着makefile会调用本机编译器而不是交叉编译器。 我究竟做错了什么? 交叉编译器的二进制文件在我的路径中。
这是我在终端上获得的输出的一部分:
抄送/home/user/script_emulation/AODV/aodv-uu/lnx/kaodv.mod.o
LD [M] /home/user/script_emulation/AODV/aodv-uu/lnx/kaodv.ko
我们可以看到那里使用了本机CC和LD而不是交叉编译器工具
有人可以提出解决方案吗?
谢谢
更新:
$ readelf -h kaodv.ko
ELF Header:
Magic: 7f 45 4c 46 01 01 01 00 00 00 00 00 00 00 00 00
Class: ELF32
Data: 2's complement, little endian
Version: 1 (current)
OS/ABI: UNIX - System V
ABI Version: 0
Type: REL (Relocatable file)
Machine: ARM
Version: 0x1
Entry point address: 0x0
Start of program headers: 0 (bytes into file)
Start of section headers: 13480 (bytes into file)
Flags: 0x5000000, Version5 EABI
Size of this header: 52 (bytes)
Size of program headers: 0 (bytes)
Number of program headers: 0
Size of section headers: 40 (bytes)
Number of section headers: 33
Section header string table index: 30
要快速修复,请如下更改Makefile。
KERNEL_DIR = /家庭/用户/ script_emulation / AODV /内核
KERNEL_INC = $(KERNEL_DIR)/包括THIS_DIR = $(shell pwd)
obj-m + = kaodv.o kaodv-objs:= kaodv-mod.o kaodv-debug.o kaodv-netlink.o kaodv-queue.o kaodv-ipenc.o kaodv-expl.o
默认:
$ {MAKE) ARCH = arm CROSS_COMPILE = arm-oe-linux-gnueabi- -C $ {KERNEL_DIR)SUBDIRS = $ {THIS_DIR)模块
还请确保在运行make using之前设置交叉编译器工具链路径
导出PATH = $ PATH:PathToToolchain 。
还要检查您先前编译的内核是否也针对ARM体系结构进行了编译。
如标题所示,它实际上是可以很好地交叉编译的。 如果它是使用本机工具链构建的,则“ Machine”字段将包含x86_64(或任何您的主机系统),并且尝试在目标上对其进行insmod将会给出错误。
默认的KBuild输出仅使用“ CC”,“ LD”作为方便的指示符-这些仅代表正在执行的步骤,而不代表正在调用的特定命令行(请参阅Makefile.build中的quiet_cmd_*
的定义)。
代码实际上不能正常工作的事实是一个完全不同的问题。 鉴于您是从较早的内核移植此模块的,因此可能需要对其进行更新以考虑其使用的某些内部接口的更改 。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.