Модуль ядра Hello world для android и неизвестного перемещения: 27 при insmod
Я пытаюсь создать простой модуль ядра. Я пытаюсь напечатать сообщения в dmesg, но продолжаю получать
insmod: init_module "hello.ko" не удалось (ошибка формата Exec) в Android
после : dmesg: неизвестное перемещение: 27
#include <linux/module.h>
#include <linux/kdb.h>
int init_module(void)
{
printk(KERN_ALERT "Hello world!\n");
return 1;
}
void cleanup_module(void)
{
printk(KERN_INFO "Goodbye world 1.\n");
}
MODULE_AUTHOR("Robert P. J. Day");
MODULE_LICENSE("Dual BSD/GPL");
MODULE_VERSION("2:1.0") ;
MODULE_DESCRIPTION("You have to start somewhere.");
Файл make
obj-m +=hello.o
KERNELDIR ?= ~/android/kernel/common
#KERNELDIR ?= /lib/modules/$(shell uname -r)/build
PWD := $(shell pwd)
CROSS_COMPILE=~/android-ndk-r8/toolchains/arm-linux-androideabi-4.4.3/prebuilt/linux-x86/bin/arm-linux-androideabi-
ARCH=arm
default:
$(MAKE) -C $(KERNELDIR) M=$(PWD) ARCH=arm CROSS_COMPILE=$(CROSS_COMPILE) modules
clean:
$(MAKE) -C $(KERNELDIR) M=$(PWD) clean
rm *.symvers
кто-нибудь знает почему? И как заставить это работать?
После того, как я выполнил readelf, я обнаружил, что когда он компилируется, раздел перемещения указывает на неправильные направления.
Offset Info Type Sym.Value Sym. Name
00000008 0000171b R_ARM_PLT32 00000000 printk
Когда на самом деле это должно быть:
Offset Info Type Sym.Value Sym. Name
00000008 0000171c R_ARM_CALL 00000000 printk
Может кто-то угадать / знать, как это может быть? Спасибо @Chris Stratton за помощь в этом.
После того, как я выполнил readelf, я обнаружил, что когда он компилируется, раздел перемещения указывает на неправильные направления.
Offset Info Type Sym.Value Sym. Name
00000008 0000171b R_ARM_PLT32 00000000 printk
Когда на самом деле это должно быть:
Offset Info Type Sym.Value Sym. Name
00000008 0000171c R_ARM_CALL 00000000 printk
Может кто-то угадать / знать, как это может быть? Спасибо @Chris Stratton за помощь в этом.