打印

奇怪的Makefile现象

奇怪的Makefile现象

为了测试多文件连接成一个模式,写了个HelloWorld的模块,分成两个文件存放在同一目录,一个main.c,一个other.c
然后写一个Makefile,下面这样写是可以编译的(make前面实际是Tab,这里输入不了,用空格代替):
.PHONY += all
TARGET := helloworld
obj-m += $(TARGET).o
$(TARGET)-objs := main.o other.o

all:
     make -C /lib/modules/`uname -r`/build M=$(shell pwd) modules

但下面这样写就不行了(make前面实际是Tab,这里输入不了,用空格代替):
.PHONY += all
TARGET := helloworld
obj-m += $(TARGET).o

BLD := $(patsubst %.c,%.o,$(wildcard *.c))
$(TARGET)-objs := $(BLD)

all:
     @echo "$(TARGET)-objs = $($(TARGET)-objs)"
     make -C /lib/modules/`uname -r`/build M=$(shell pwd) modules

make前面那句打印出来的内容是:helloworld-objs := main.o other.o
make语句编译错误说是找不到helloworld.c

难道$(TARGET)-objs的内容就不能用自动生成的?那再添加一个.c文件不就又要改makefile了么?makefile不可能这么死板吧?求解释!谢谢!

TOP