解释# Makefile ROOTDIR = .. include $(ROOTDIR)/Rules.make CC=$(MVTOOL_PREFIX)gcc #CC=gcc EXEC = helloworld_arm OBJS = helloworld.o all: $(EXEC) $(EXEC): $(OBJS) $(CC) -o $@ $(OBJS) clean: rm -f $(EXEC) *.o
时间: 2024-04-29 21:20:16 浏览: 123
gcc.rar_gcc makefile_gcc 使用_makefile_makefile gcc_makefile in en
这是一个 Makefile 文件,用于编译一个名为 helloworld_arm 的可执行文件。以下是 Makefile 文件的各个部分的解释:
1. ROOTDIR = ..:定义一个名为 ROOTDIR 的变量,其值为 "..",即上层目录。
2. include $(ROOTDIR)/Rules.make:包含名为 Rules.make 的文件,该文件中定义了编译的规则和一些变量。
3. CC=$(MVTOOL_PREFIX)gcc:定义一个名为 CC 的变量,其值为 "$(MVTOOL_PREFIX)gcc",即交叉编译器的路径。
4. #CC=gcc:注释掉一个名为 CC 的变量,其值为 "gcc",即本地编译器的路径。
5. EXEC = helloworld_arm:定义一个名为 EXEC 的变量,其值为 "helloworld_arm",即要编译的可执行文件的名称。
6. OBJS = helloworld.o:定义一个名为 OBJS 的变量,其值为 "helloworld.o",即要编译的目标文件的名称。
7. all: $(EXEC):定义一个名为 all 的目标,该目标依赖于 EXEC 变量所指定的可执行文件。
8. $(EXEC): $(OBJS):定义一个名为 $(EXEC) 的目标,该目标依赖于 OBJS 变量所指定的目标文件。
9. $(CC) -o $@ $(OBJS):定义一个生成 $(EXEC) 文件的命令,该命令使用 CC 变量所指定的编译器,链接 OBJS 变量所指定的目标文件。
10. clean: rm -f $(EXEC) *.o:定义一个名为 clean 的目标,该目标用于清理编译过程中生成的文件,包括 $(EXEC) 文件和所有 .o 文件。
阅读全文