Модуль ядра Hello world для Android и неизвестное перемещение :27, когда insmod

Я пытаюсь создать простой модуль ядра. Я пытаюсь напечатать сообщения в dmesg, но получаю

insmod :инициализация _модуль '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 за помощь.

13
задан casperOne 25 July 2012 в 15:51
поделиться