2

我正在尝试在 Android JellyBean 上构建一个简单的内核模块。

代码:

#include <linux/module.h>  /* Needed by all modules */
#include <linux/kernel.h>  /* Needed for KERN_ALERT */

MODULE_LICENSE("GPL");
MODULE_AUTHOR("test");
MODULE_DESCRIPTION("Android ko test");

int init_module(void)
{
   printk(KERN_ALERT, "Hello world\n");

   // A non 0 return means init_module failed; module can't be loaded.
   return 0;
}

void cleanup_module(void)
{
  printk(KERN_ALERT "Goodbye world 1.\n");
}

生成文件:

obj-m +=hello.o

KERNELDIR ?= ~/android/kernel
PWD := $(shell pwd)
CROSS_COMPILE=~/android/prebuilt/linux-x86/toolchain/arm-eabi-4.4.3/bin/arm-eabi-
ARCH=arm

default:
    $(MAKE) -C $(KERNELDIR) M=$(PWD) ARCH=arm CROSS_COMPILE=$(CROSS_COMPILE) modules

clean:
    $(MAKE) -C $(KERNELDIR) M=$(PWD) clean

输出:

make -C ~/android/kernel M=/home/test/testmod ARCH=arm CROSS_COMPILE=~/android/prebuilt/linux-x86/toolchain/arm-eabi-4.4.3/bin/arm-eabi- modules
make[1]: Entering directory `/home/test/android/kernel'

  ERROR: Kernel configuration is invalid.
         include/generated/autoconf.h or include/config/auto.conf are missing.
         Run 'make oldconfig && make prepare' on kernel src to fix it.


  WARNING: Symbol version dump /home/test/android/kernel/Module.symvers
           is missing; modules will have no dependencies and modversions.

  CC [M]  /home/test/testmod/hello.o
In file included from <command-line>:0:
/home/test/android/kernel/include/linux/kconfig.h:4:32: error: generated/autoconf.h: No such file or directory
In file included from /home/test/android/kernel/arch/arm/include/asm/types.h:4,
                 from include/linux/types.h:4,
                 from include/linux/list.h:4,
                 from include/linux/module.h:9,
                 from /home/test/testmod/hello.c:1:
include/asm-generic/int-ll64.h:11:29: error: asm/bitsperlong.h: No such file or directory
In file included from /home/test/android/kernel/arch/arm/include/asm/posix_types.h:38,
                 from include/linux/posix_types.h:47,
                 from include/linux/types.h:17,
                 from include/linux/list.h:4,
                 from include/linux/module.h:9,
                 from /home/test/testmod/hello.c:1:
include/asm-generic/posix_types.h:70:5: warning: "__BITS_PER_LONG" is not defined
error, forbidden warning: posix_types.h:70
make[2]: *** [/home/test/testmod/hello.o] Error 1
make[1]: *** [_module_/home/test/testmod] Error 2
make[1]: Leaving directory `/home/test/android/kernel'
make: *** [default] Error 2

如果我按照输出中的建议,在内核上运行“make oldconfig && make prepare”,它会引导我完成几十个内核配置是/否问题。在那之后,编译仍然失败,下一个错误是关于 bitsperlong.h 的。

4

3 回答 3

5

Android 将输出二进制文件放在 out 目录下。因此,例如一个可以拥有out/target/product/<target name>/obj/KERNEL_OBJ/$ANDROID_PRODUCT_OUT/obj/KERNEL_OBJ/如果$ANDROID_PRODUCT_OUT被定义。该目录的名称可能与不同的供应商不同,但就是包含vmlinux.

make因此,当您在 Android repo 下编译内核模块时,您应该在模块目录中提交如下命令。

make -C $ANDROID_PRODUCT_OUT/obj/KERNEL_OBJ/ M=`pwd` ARCH=arm CROSS_COMPILE=arm-eabi- modules
于 2013-01-28T15:19:44.987 回答
2

Make modules 应该在编译内核至少一次之后完成。您还没有编译内核,这就是 Module.symvers 缺失的原因。在编译过程中,会创建某些头文件,例如 asm/bitsperlong.h。

于 2013-01-27T04:28:53.290 回答
1

首先确保您已在指定路径中编译内核。那是

" /home/test/android/kernel" but you are using 
" /home/android/kernel "     during compilation of module
KERNELDIR ?= ~/android/kernel has to be KERNELDIR ?= ~/test/android/kernel

如果没有,则在~/android/kernel目录中运行以下命令来编译内核。

make ARCH=arm CROSS_COMPILE=~/test/android/prebuilt/linux-x86/toolchain/arm-eabi-4.4.3/bin/arm-eabi

编译内核后,您将在内核的 System.map 文件中定义此“__BITS_PER_LONG”变量,即

~/test/android/kernel/System.map

在此之后,您将能够毫无障碍地编译您的模块

于 2013-01-22T17:37:41.747 回答