今天编译驱动时突然出现以下错误信息,后面经检查是因为我更换了之前的内核源码导致的。
以下是编译错误输出信息:
make -C /mnt/hgfs/Ubuntu/ebf_6ull_linux M=/mnt/hgfs/Ubuntu/imx6ULL/imx6ULL/source modules
make[1]: Entering directory '/mnt/hgfs/Ubuntu/ebf_6ull_linux'
CC [M] /mnt/hgfs/Ubuntu/imx6ULL/imx6ULL/source/mydevice.o
In file included from ./arch/x86/include/asm/bitops.h:16:0,
from include/linux/bitops.h:36,
from include/linux/kernel.h:10,
from /mnt/hgfs/Ubuntu/imx6ULL/imx6ULL/source/mydevice.c:2:
./arch/x86/include/asm/arch_hweight.h: In function ‘__arch_hweight64’:
./arch/x86/include/asm/arch_hweight.h:53:42: error: expected ‘:’ or ‘)’ before ‘POPCNT64’
asm (ALTERNATIVE("call __sw_hweight64", POPCNT64, X86_FEATURE_POPCNT)
^
./arch/x86/include/asm/alternative.h:125:28: note: in definition of macro ‘ALTINSTR_REPLACEMENT’
b_replacement(num)":\n\t" newinstr "\n" e_replacement(num) ":\n\t"
^
./arch/x86/include/asm/arch_hweight.h:53:7: note: in expansion of macro ‘ALTERNATIVE’
asm (ALTERNATIVE("call __sw_hweight64", POPCNT64, X86_FEATURE_POPCNT)
^
In file included from ./arch/x86/include/asm/pgtable_types.h:250:0,
from ./arch/x86/include/asm/processor.h:18,
from ./arch/x86/include/asm/thread_info.h:49,
from include/linux/thread_info.h:54,
from ./arch/x86/include/asm/preempt.h:6,
from include/linux/preempt.h:18,
from include/linux/spinlock.h:50,
from include/linux/seqlock.h:35,
from include/linux/time.h:5,
from include/uapi/linux/timex.h:56,
from include/linux/timex.h:56,
from include/linux/sched.h:19,
from include/linux/blkdev.h:4,
from include/linux/ide.h:12,
from /mnt/hgfs/Ubuntu/imx6ULL/imx6ULL/source/mydevice.c:4:
include/asm-generic/pgtable-nopud.h: At top level:
include/asm-generic/pgtable-nopud.h:15:0: warning: "PUD_SHIFT" redefined
#define PUD_SHIFT PGDIR_SHIFT
^
In file included from ./arch/x86/include/asm/pgtable_types.h:205:0,
from ./arch/x86/include/asm/processor.h:18,
from ./arch/x86/include/asm/thread_info.h:49,
from include/linux/thread_info.h:54,
from ./arch/x86/include/asm/preempt.h:6,
from include/linux/preempt.h:18,
from include/linux/spinlock.h:50,
from include/linux/seqlock.h:35,
from include/linux/time.h:5,
from include/uapi/linux/timex.h:56,
from include/linux/timex.h:56,
from include/linux/sched.h:19,
from include/linux/blkdev.h:4,
from include/linux/ide.h:12,
from /mnt/hgfs/Ubuntu/imx6ULL/imx6ULL/source/mydevice.c:4:
./arch/x86/include/asm/pgtable_64_types.h:33:0: note: this is the location of the previous definition
#define PUD_SHIFT 30
^
In file included from ./arch/x86/include/asm/pgtable_types.h:250:0,
from ./arch/x86/include/asm/processor.h:18,
from ./arch/x86/include/asm/thread_info.h:49,
from include/linux/thread_info.h:54,
from ./arch/x86/include/asm/preempt.h:6,
from include/linux/preempt.h:18,
from include/linux/spinlock.h:50,
from include/linux/seqlock.h:35,
from include/linux/time.h:5,
from include/uapi/linux/timex.h:56,
from include/linux/timex.h:56,
from include/linux/sched.h:19,
from include/linux/blkdev.h:4,
from include/linux/ide.h:12,
from /mnt/hgfs/Ubuntu/imx6ULL/imx6ULL/source/mydevice.c:4:
include/asm-generic/pgtable-nopud.h:16:0: warning: "PTRS_PER_PUD" redefined
#define PTRS_PER_PUD 1
...
...
./arch/x86/include/asm/processor.h:270:27: note: in expansion of macro ‘____cacheline_aligned’
} __attribute__((packed)) ____cacheline_aligned;
^
In file included from ./arch/x86/include/asm/preempt.h:5:0,
from include/linux/preempt.h:18,
from include/linux/spinlock.h:50,
from include/linux/seqlock.h:35,
from include/linux/time.h:5,
from include/uapi/linux/timex.h:56,
from include/linux/timex.h:56,
from include/linux/sched.h:19,
from include/linux/blkdev.h:4,
from include/linux/ide.h:12,
from /mnt/hgfs/Ubuntu/imx6ULL/imx6ULL/source/mydevice.c:4:
./arch/x86/include/asm/processor.h: In function ‘current_top_of_stack’:
./arch/x86/include/asm/processor.h:594:30: error: ‘cpu_current_top_of_stack’ undeclared (first use in this function)
return this_cpu_read_stable(cpu_current_top_of_stack);
^
./arch/x86/include/asm/percpu.h:213:9: note: in definition of macro ‘percpu_stable_op’
typeof(var) pfo_ret__; \
^
./arch/x86/include/asm/processor.h:594:9: note: in expansion of macro ‘this_cpu_read_stable’
return this_cpu_read_stable(cpu_current_top_of_stack);
^
./arch/x86/include/asm/processor.h:594:30: note: each undeclared identifier is reported only once for each function it appears in
return this_cpu_read_stable(cpu_current_top_of_stack);
^
./arch/x86/include/asm/percpu.h:213:9: note: in definition of macro ‘percpu_stable_op’
typeof(var) pfo_ret__; \
^
./arch/x86/include/asm/processor.h:594:9: note: in expansion of macro ‘this_cpu_read_stable’
return this_cpu_read_stable(cpu_current_top_of_stack);
^
In file included from ./arch/x86/include/asm/atomic.h:235:0,
from include/linux/atomic.h:4,
from ./arch/x86/include/asm/thread_info.h:50,
from include/linux/thread_info.h:54,
from ./arch/x86/include/asm/preempt.h:6,
from include/linux/preempt.h:18,
from include/linux/spinlock.h:50,
from include/linux/seqlock.h:35,
from include/linux/time.h:5,
from include/uapi/linux/timex.h:56,
from include/linux/timex.h:56,
from include/linux/sched.h:19,
from include/linux/blkdev.h:4,
from include/linux/ide.h:12,
from /mnt/hgfs/Ubuntu/imx6ULL/imx6ULL/source/mydevice.c:4:
./arch/x86/include/asm/atomic64_64.h: At top level:
./arch/x86/include/asm/atomic64_64.h:19:40: error: unknown type name ‘atomic64_t’
static inline long atomic64_read(const atomic64_t *v)
^
In file included from include/uapi/linux/stddef.h:1:0,
from include/linux/stddef.h:4,
from ./include/uapi/linux/posix_types.h:4,
from include/uapi/linux/types.h:13,
from include/linux/types.h:5,
from /mnt/hgfs/Ubuntu/imx6ULL/imx6ULL/source/mydevice.c:1:
./arch/x86/include/asm/atomic64_64.h: In function ‘atomic64_read’:
./arch/x86/include/asm/atomic64_64.h:21:24: error: request for member ‘counter’ in something not a structure or union
return ACCESS_ONCE((v)->counter);
^
include/linux/compiler.h:456:25: note: in definition of macro ‘__ACCESS_ONCE’
__maybe_unused typeof(x) __var = (__force typeof(x)) 0; \
^
./arch/x86/include/asm/atomic64_64.h:21:9: note: in expansion of macro ‘ACCESS_ONCE’
return ACCESS_ONCE((v)->counter);
^
./arch/x86/include/asm/atomic64_64.h:21:24: error: request for member ‘counter’ in something not a structure or union
return ACCESS_ONCE((v)->counter);
^
include/linux/compiler.h:456:52: note: in definition of macro ‘__ACCESS_ONCE’
__maybe_unused typeof(x) __var = (__force typeof(x)) 0; \
^
./arch/x86/include/asm/atomic64_64.h:21:9: note: in expansion of macro ‘ACCESS_ONCE’
return ACCESS_ONCE((v)->counter);
^
./arch/x86/include/asm/atomic64_64.h:21:24: error: request for member ‘counter’ in something not a structure or union
return ACCESS_ONCE((v)->counter);
^
include/linux/compiler.h:457:19: note: in definition of macro ‘__ACCESS_ONCE’
(volatile typeof(x) *)&(x); })
^
./arch/x86/include/asm/atomic64_64.h:21:9: note: in expansion of macro ‘ACCESS_ONCE’
return ACCESS_ONCE((v)->counter);
^
./arch/x86/include/asm/atomic64_64.h:21:24: error: request for member ‘counter’ in something not a structure or union
return ACCESS_ONCE((v)->counter);
^
include/linux/compiler.h:457:26: note: in definition of macro ‘__ACCESS_ONCE’
(volatile typeof(x) *)&(x); })
^
./arch/x86/include/asm/atomic64_64.h:21:9: note: in expansion of macro ‘ACCESS_ONCE’
return ACCESS_ONCE((v)->counter);
^
In file included from ./arch/x86/include/asm/atomic.h:235:0,
from include/linux/atomic.h:4,
from ./arch/x86/include/asm/thread_info.h:50,
from include/linux/thread_info.h:54,
from ./arch/x86/include/asm/preempt.h:6,
from include/linux/preempt.h:18,
from include/linux/spinlock.h:50,
from include/linux/seqlock.h:35,
from include/linux/time.h:5,
from include/uapi/linux/timex.h:56,
from include/linux/timex.h:56,
from include/linux/sched.h:19,
from include/linux/blkdev.h:4,
from include/linux/ide.h:12,
from /mnt/hgfs/Ubuntu/imx6ULL/imx6ULL/source/mydevice.c:4:
./arch/x86/include/asm/atomic64_64.h: At top level:
./arch/x86/include/asm/atomic64_64.h:31:33: error: unknown type name ‘atomic64_t’
static inline void atomic64_set(atomic64_t *v, long i)
^
./arch/x86/include/asm/atomic64_64.h:43:41: error: unknown type name ‘atomic64_t’
static inline void atomic64_add(long i, atomic64_t *v)
^
./arch/x86/include/asm/atomic64_64.h:57:41: error: unknown type name ‘atomic64_t’
static inline void atomic64_sub(long i, atomic64_t *v)
^
./arch/x86/include/asm/atomic64_64.h:73:49: error: unknown type name ‘atomic64_t’
static inline int atomic64_sub_and_test(long i, atomic64_t *v)
^
./arch/x86/include/asm/atomic64_64.h:84:33: error: unknown type name ‘atomic64_t’
static inline void atomic64_inc(atomic64_t *v)
^
./arch/x86/include/asm/atomic64_64.h:97:33: error: unknown type name ‘atomic64_t’
static inline void atomic64_dec(atomic64_t *v)
^
./arch/x86/include/asm/atomic64_64.h:112:41: error: unknown type name ‘atomic64_t’
static inline int atomic64_dec_and_test(atomic64_t *v)
^
./arch/x86/include/asm/atomic64_64.h:125:41: error: unknown type name ‘atomic64_t’
static inline int atomic64_inc_and_test(atomic64_t *v)
^
./arch/x86/include/asm/atomic64_64.h:139:49: error: unknown type name ‘atomic64_t’
static inline int atomic64_add_negative(long i, atomic64_t *v)
^
./arch/x86/include/asm/atomic64_64.h:151:48: error: unknown type name ‘atomic64_t’
static inline long atomic64_add_return(long i, atomic64_t *v)
^
./arch/x86/include/asm/atomic64_64.h:156:48: error: unknown type name ‘atomic64_t’
static inline long atomic64_sub_return(long i, atomic64_t *v)
^
./arch/x86/include/asm/atomic64_64.h:164:37: error: unknown type name ‘atomic64_t’
static inline long atomic64_cmpxchg(atomic64_t *v, long old, long new)
^
./arch/x86/include/asm/atomic64_64.h:169:34: error: unknown type name ‘atomic64_t’
static inline long atomic64_xchg(atomic64_t *v, long new)
^
./arch/x86/include/asm/atomic64_64.h:183:39: error: unknown type name ‘atomic64_t’
static inline int atomic64_add_unless(atomic64_t *v, long a, long u)
^
./arch/x86/include/asm/atomic64_64.h:207:45: error: unknown type name ‘atomic64_t’
static inline long atomic64_dec_if_positive(atomic64_t *v)
^
In file included from include/linux/sched.h:32:0,
from include/linux/blkdev.h:4,
from include/linux/ide.h:12,
from /mnt/hgfs/Ubuntu/imx6ULL/imx6ULL/source/mydevice.c:4:
include/linux/cputime.h:4:25: fatal error: asm/cputime.h: No such file or directory
compilation terminated.
scripts/Makefile.build:264: recipe for target '/mnt/hgfs/Ubuntu/imx6ULL/imx6ULL/source/mydevice.o' failed
make[2]: *** [/mnt/hgfs/Ubuntu/imx6ULL/imx6ULL/source/mydevice.o] Error 1
Makefile:1383: recipe for target '_module_/mnt/hgfs/Ubuntu/imx6ULL/imx6ULL/source' failed
make[1]: *** [_module_/mnt/hgfs/Ubuntu/imx6ULL/imx6ULL/source] Error 2
make[1]: Leaving directory '/mnt/hgfs/Ubuntu/ebf_6ull_linux'
Makefile:10: recipe for target 'kernel_modules' failed
make: *** [kernel_modules] Error 2
解决办法
修改内核源码Makefile文件
我个人是不推荐这样做的,因为之前图方便就直接修改了内核源码根目录下的Makefile文件,导致时间久了忘记这回事,今天突然更换内核源码后就报错了。
修改方法
打开内核源码根目录下的Makefile,定位到如下位置:
ARCH ?= $(SUBARCH)
CROSS_COMPILE ?= $(CONFIG_CROSS_COMPILE:"%"=%)
修改为:
ARCH ?= arm
CROSS_COMPILE ?= arm-linux-gnueabihf-
上述位置的arm
/arm-linux-gnueabihf-
取决你你自己使用的架构和交叉编译工具
修改驱动程序工程下的Makefile文件(推荐)
假如你的Makefile如下:
KERNELDIR := /mnt/hgfs/Ubuntu/ebf_6ull_linux
CURRENT_PATH := $(shell pwd)
obj-m := xxx.o
build: kernel_modules
kernel_modules:
$(MAKE) -C $(KERNELDIR) M=$(CURRENT_PATH) modules
clean:
$(MAKE) -C $(KERNELDIR) M=$(CURRENT_PATH) clean
请添加两个编译变量在make命令后方
KERNELDIR := /mnt/hgfs/Ubuntu/ebf_6ull_linux
CURRENT_PATH := $(shell pwd)
ENV:=ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf-
obj-m := xxx.o
build: kernel_modules
kernel_modules:
$(MAKE) $(ENV) -C $(KERNELDIR) M=$(CURRENT_PATH) modules
clean:
$(MAKE) $(ENV) -C $(KERNELDIR) M=$(CURRENT_PATH) clean
这样的话无论内核源码如何替换都不会影响驱动程序的正常编译