未定义的主要错误参考

时间:2016-12-05 19:34:46

标签: c makefile compiler-errors

我正在尝试制作bitcount基准测试应用程序的Makefile。原始的Makefile可以工作,但我想根据需要更改Makefile。我想先创建一个目标文件,然后用它来创建.elf和.bin文件。

bitcnts: ${FILE} Makefile
    gcc -static ${FILE} -O3 -o bitcnts

但我收到的错误是undefined reference to main'

/opt/riscv/bin/../lib/gcc/riscv64-unknown elf/4.9.2/../../../../riscv64-unknown-
elf/lib/soft-float/32/crt0.o: 
In function `.L0 ': (.text+0x40): undefined reference to `main'
collect2: error: ld returned 1 exit status
Makefile:23: recipe for target 'prog.elf' failed
make[1]: *** [prog.elf] Error 1

尝试的Makefile如下所示:

CROSS=riscv64-unknown-elf-
CC=$(CROSS)gcc    
LD=$(CROSS)g++
OBJCOPY=$(CROSS)objcopy
LIB_O=$(LIB)mutex.o $(LIB)wrap_malloc.o

CFLAGS_SYS=-m32 -msoft-float
LDFLAGS_SYS=-m32 -msoft-float -T$(LDFILE) -Wl,--wrap,malloc -Wl,--wrap,free -Wl,
--wrap,calloc -Wl,--wrap,realloc -Wl,--wrap,_malloc_r -Wl,--wrap,_free_r -Wl,
--wrap,_calloc_r -Wl,--wrap,_realloc_r

CFLAGS=-g $(CFLAGS_SYS) -O2 -std=gnu99 -Wall -I$(LIB) -I./
LDFLAGS=-g $(LDFLAGS_SYS)


FILE = bitcnt_1.c bitcnt_2.c bitcnt_3.c bitcnt_4.c bitcnts.c bitfiles.c 
bitstrng.c bstr_i.c

MAIN = bitcnts

.PHONY : all
all: prog.elf

prog.bin : prog.elf
   @${OBJCOPY} -R .uncached -R .tileram -O binary $< $@

prog.elf : $(MAIN).o $(LIB_O)
   @${LD} $^ -o $@ ${LDFLAGS}

$(MAIN).o : $(FILE)
   @${CC} ${CFLAGS} -c $< -o $@

.PHONY: build
build: all

然后建立:

# Build
.PHONY: bitcount-build
bitcount-build:
  @make -C $(MIBENCH)/automotive/bitcount build
# Run
.PHONY: bitcount-run
bitcount-run:
  @make -C $(MIBENCH)/automotive/bitcount run

1 个答案:

答案 0 :(得分:1)

此规则

$(MAIN).o : $(FILE)
   @${CC} ${CFLAGS} -c $< -o $@

扩展为

bitcnts.o: bitcnt_1.c bitcnt_2.c bitcnt_3.c bitcnt_4.c bitcnts.c bitfiles.c bitstrng.c bstr_i.c
    ...-gcc [all the flags] -c bitcnt_1.c -o bitcnts.o
                               ^^^^^^^^^^ $< is this only

其他文件bitcnt_2.cbitcnt_3.cbitcnt_4.cbitcnts.cbitfiles.cbitstrng.cbstr_i.c,观察了修改但从未编入对象,如果main()位于bitcnts.cbitcnts.o将不包含它。

实际上,你想要做的事情不能那么简单(抱歉我的答案的先前版本错了)。 One object file comes from one translation unit(基本上来自一个C文件)。因此,您必须制作其中的8个。幸运的是,使用static patterns

,Makefiles不会太难
OBJECTS = $(FILE:%.c=%.o)

$(OBJECTS): %.o: %.c
    @${CC} ${CFLAGS} -c $< -o $@

prog.elf : $(OBJECTS) $(LIB_O)
    @${LD} $^ -o $@ ${LDFLAGS}