Makefile万能写法(gcc程序以及arm-linux-gcc程序)

简介:

在linux下使用gcc 编译时,Makefile的万能写法 ,每次只需更改要生成的目标文件名称(test)尽可:

 

1
2
3
4
5
6
7
objs := $(patsubst %c, %o, $(shell  ls  *.c))
test .all:$(objs)
gcc -o $@ $^
%.o:%.c
gcc -c -o $@ $<
clean:
rm  -f  *.all *.o

在arm交叉编译时的makefile的万能写法,只需更改int.bin,以及int_elf,int.dis名称即可

1
2
3
4
5
6
7
8
9
10
11
objs := $(addsuffix .o, $( basename  $(shell  ls  -U *.S *.c)))
int.bin: $(objs)
arm-linux-ld -Ttext 0x00000000 -o int_elf $^
arm-linux-objcopy -O binary -S int_elf $@
arm-linux-objdump -D -m arm int_elf > int.dis
%.o:%.c
arm-linux-gcc -Wall -O2 -c -o $@ $<
%.o:%.S
arm-linux-gcc -Wall -O2 -c -o $@ $<
clean:
rm  -f *.bin *_elf *.dis *.o

更多Makefile学习可百度:GUN MAKE 手册


Makefile的规则 

1
2
3
4
Makefile的规则:
目标文件:依赖文件
target ... : prerequisites ..
command

  target要求  

    1、要生成的可执行文件或obj文件;

    2、也可以是一个执行的动作名称:clean

  Makefile执行规则:  

    1、执行make时,仅当hell.c文件比hello.o文件更新,才会执行命令:arm-linux-gcc -o hello.o hello.c;

    2、如果没有hello.o文件也会执行

    3、运行 make clean 时,由于clean 没有依赖,它的命令也会被强制执行

 

makefile赋值:

142808483.jpg

 

 

Makefile中的"="":="、"?="和"+="区别是:
    "="是直接给变量赋值。
    ":="是将":="右边中包含的变量直接展开给左边的变量赋值。
    "?="是在该变量没有被赋值 的情况下为其赋值。
    "+="是给该变量追加值。
  例:
    a = 1
    b = 2
    c := $(a) 3
    d = 4
    d ?= 5
    b += 6
  结果:
    a=1
    c=1 3
    d=4
    b=2 6

 

使用makefile 编译c程序:

  1、一些make函数的巧用

    1、$(patsubst pattern, replacement,text) 

      原理:用replacement替换text中符合格式"pattern" 的字

      如:$(patsubst %.c, %.o, b.a.c hello.c helloworld.c)

        结果为字符串:b.a.o hello.o helloworld.o

    2、$(shell command arguments) 145807616.jpg

 

    3、$(basename names.....)

    原理:抽取除"names...."中每一个文件名中除后缀外的一切字符

    比如:

    $(basename head.S hello.c helloworld.c)

    结果为:head hello helloworld

    4、$(addsuffix suffix,names...) 

      如:$(addsuffix .c, head hello helloworld)

      结果为:head.o hello.o hello.o helloworld.o

 

在linux中编译c程序时写make文件就有一些技巧了

151748333.jpg

 

152252974.jpg

 

152421367.jpg

152617585.jpg

 

 

在 arm 嵌入式交叉编译时,就可以这样编写Makefile。相应的程序名称相应修改

 

1
2
3
4
5
6
7
8
9
10
11
objs := $(addsuffix .o, $( basename  $(shell  ls  *.S *.c)))
int.bin: $(objs)
arm-linux-ld -Ttext 0x00000000 -o int_elf $^
arm-linux-objcopy -O binary -S int_elf $@
arm-linux-objdump -D -m arm int_elf > int.dis
%.o:%.c
arm-linux-gcc -Wall -O2 -c -o $@ $<
%.o:%.S
arm-linux-gcc -Wall -O2 -c -o $@ $<
clean:
rm  -f *.bin *_elf *.dis *.o

 


本文转自lilin9105 51CTO博客,原文链接:http://blog.51cto.com/7071976/1322211,如需转载请自行联系原作者

相关文章
|
8月前
|
安全 Linux iOS开发
Nessus Professional 10.10 Auto Installer for RHEL 10, AlmaLinux 10, Rocky Linux 10 - Nessus 自动化安装程序
Nessus Professional 10.10 Auto Installer for RHEL 10, AlmaLinux 10, Rocky Linux 10 - Nessus 自动化安装程序
595 6
Nessus Professional 10.10 Auto Installer for RHEL 10, AlmaLinux 10, Rocky Linux 10 - Nessus 自动化安装程序
|
安全 Linux Shell
Linux上执行内存中的脚本和程序
【9月更文挑战第3天】在 Linux 系统中,可以通过多种方式执行内存中的脚本和程序:一是使用 `eval` 命令直接执行内存中的脚本内容;二是利用管道将脚本内容传递给 `bash` 解释器执行;三是将编译好的程序复制到 `/dev/shm` 并执行。这些方法虽便捷,但也需谨慎操作以避免安全风险。
549 7
|
网络协议 Linux
Linux查看端口监听情况,以及Linux查看某个端口对应的进程号和程序
Linux查看端口监听情况,以及Linux查看某个端口对应的进程号和程序
2140 2
|
Linux Python
linux上根据运行程序的进程号,查看程序所在的绝对路径。linux查看进程启动的时间
linux上根据运行程序的进程号,查看程序所在的绝对路径。linux查看进程启动的时间
884 2
|
Rust Ubuntu Java
[Linux工具] Makefile
Makefile是Linux环境下用于自动化编译和链接程序的配置文件,常用于简化大型项目的编译流程。通过定义目标文件、依赖文件及生成命令,Makefile能高效管理编译任务。它不仅适用于C语言项目,还可扩展到其他编程语言和非编程任务中。
[Linux工具] Makefile
|
NoSQL Linux 开发工具
Linux环境基础开发工具的使用(yum、vim、gcc、g++、gdb、make/Makefile)
本文介绍了yum 包管理工具、Vim 编辑器、gcc/g++ 编译器、gdb 调试器、编译原理及 Makefile 的使用,同时还配备了如何使用,以及图解。旨在帮助读者更好地理解和应用这些工具与技术。
611 0
|
Unix Linux C语言
【Linux】 Linux makefile 教程
本文详细介绍了 Linux 环境下 Makefile 的基本结构、语法和使用方法,并通过一个简单的 C++ 项目示例演示了 Makefile 的实际应用。Makefile 是一个强大而灵活的工具,通过合理配置,可以极大地简化项目的编译和管理过程,提高开发效率。希望本文能帮助您更好地理解和应用 Makefile,在实际项目中高效管理代码的编译和构建。
976 20
|
Unix Linux C语言
【Linux】 Linux makefile 教程
本文详细介绍了 Linux 环境下 Makefile 的基本结构、语法和使用方法,并通过一个简单的 C++ 项目示例演示了 Makefile 的实际应用。Makefile 是一个强大而灵活的工具,通过合理配置,可以极大地简化项目的编译和管理过程,提高开发效率。希望本文能帮助您更好地理解和应用 Makefile,在实际项目中高效管理代码的编译和构建。
403 16
|
Linux 编译器 C语言
【Linux快速入门(一)】Linux与ROS学习之编译基础(gcc编译)
【Linux快速入门(一)】Linux与ROS学习之编译基础(gcc编译)
548 2