linux-makefile

本文介绍了一个简单的技巧,用于调试Makefile中的变量。通过创建一个专用的Makefile(名为vars.mk),可以轻松查看和理解Makefile中变量的定义、来源及类型。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


六、七年前写过一篇《跟我一起写Makefile》,直到今天,还有一些朋友问我一些Makefile的问题,老实说,我有一段时间没有用Makefile了,生疏了。回顾,这几年来大家问题我的问题,其实很多时候是makefile的调试问题。所以,就像我在之前的那篇关于GDB的技巧的文章中做的一样,在这里向大家介绍一个小小的调试变量的技巧。相信一定对你有用。

对于Makefile中的各种变量,可能是我们比较头痛的事了。我们要查看他们并不是很方便,需要修改makefile加入echo命令。这有时候很不方便。其实我们可以制作下面一个专门用来输出变量的makefile(假设名字叫:vars.mk)

vars.mk

%:       

        @echo '$*=$($*)' 

d-%:

        @echo '$*=$($*)'

        @echo '  origin = $(origin $*)'

        @echo '   value = $(value  $*)'

        @echo '  flavor = $(flavor $*)'

这样一来,我们可以使用make命令的-f参数来查看makefile中的相关变量(包括make的内建变量,比如:COMPILE.c或MAKE_VERSION之类的)。注意:第二个以“d-”为前缀的目标可以用来打印关于这个变量更为详细的东西(后面有详细说明)

假设我们的makefile是这个样子(test.mk)

test.mk

OBJDIR := objdir

OBJS := $(addprefix $(OBJDIR)/,foo.o bar.o baz.o) 

foo = $(bar)bar = $(ugh)ugh = Huh? 

CFLAGS = $(include_dirs) -O

include_dirs = -Ifoo -Ibar

CFLAGS := $(CFLAGS) -Wall 

MYOBJ := a.o b.o c.o

MYSRC := $(MYOBJ:.o=.c)

那么,我们可以这样进行调试:

演示

[hchen@RHELSVR5]$ make -f test.mk -f var.mk OBJS

OBJS=objdir/foo.o objdir/bar.o objdir/baz.o 

[hchen@RHELSVR5]$ make -f test.mk -f var.mk d-foo

foo=Huh?

  origin = file

  value = $(bar)

  flavor = recursive 

[hchen@RHELSVR5]$ make -f test.mk -f var.mk d-CFLAGS

CFLAGS=-Ifoo -Ibar -O -O

  origin = file

  value = -Ifoo -Ibar -O -O

  flavor = simple 

[hchen@RHELSVR5]$  make -f test.mk -f var.mk d-COMPILE.c

COMPILE.c=cc -Ifoo -Ibar -O -Wall   -c

  origin = default

  flavor = recursive

   value = $(CC) $(CFLAGS) $(CPPFLAGS) $(TARGET_ARCH) -c

我们可以看到:

  • make的第一个-f后是要测试的makefile,第二个是我们的debug makefile。

  • 后面直接跟变量名,如果在变量名前加”d-”,则输出更为详细的东西。

说一说”d-” 前缀(其意为details),其中调用了下面三个参数。

  • $(origin):告诉你这个变量是来自哪儿,file表示文件,environment表示环境变量,还有environment override,command line,override,automatic等。

  • $(value):打出这个变量没有被展开的样子。比如上述示例中的 foo 变量。

  • $(flavor):有两个值,simple表示是一般展开的变量,recursive表示递归展开的变量。

(全文完)


<think>好的,我需要帮助用户正确配置和使用arm-linux-gnueabihf-gcc在Makefile中进行交叉编译。首先,我得回顾用户提供的引用内容,看看有哪些关键点需要涵盖。 根据引用[1]和[2],用户提到了在Makefile中设置交叉编译工具链的命令,比如CC和LD变量的定义,特别是静态链接的使用。引用[3]和[4]则涉及交叉编译器的安装和路径配置。所以,我需要将这些步骤整合成一个清晰的流程。 首先,安装交叉编译器。用户提供的引用3提到根据系统选择32位或64位的版本,并正确解压到指定目录。然后设置环境变量,如引用4中的PATH导出,这样才能在终端中找到arm-linux-gnueabihf-gcc命令。 接下来是Makefile的配置。引用2中的模板显示需要定义CROSS变量,然后设置CC、LD等工具链变量。引用1中的例子展示了如何修改Makefile中的CC和LD,特别是添加-static参数进行静态链接。需要注意的是,用户可能需要根据具体项目调整编译选项,比如CFLAGS和LDFLAGS。 然后,用户可能需要了解如何执行编译,比如使用make命令,以及如何处理依赖库的问题,如引用3提到的openssl静态库和动态库的编译。这部分可能需要指导用户如何链接这些库,或者如何交叉编译依赖项。 最后,常见问题部分应该涵盖路径错误、静态链接问题、依赖库缺失和清理构建环境。这些都是用户在配置过程中可能遇到的典型问题,需要逐一解答。 需要确保步骤清晰,语言简洁,并正确引用提供的资料。同时,生成的相关问题要围绕交叉编译的配置、优化和应用场景展开,帮助用户进一步学习。</think>### 配置和使用 `arm-linux-gnueabihf-gcc` 在 Makefile 中进行交叉编译 #### 1. **安装交叉编译工具链** - **下载工具链**:根据系统架构选择对应的版本(32位或64位),例如: ```bash wget https://releases.linaro.org/components/toolchain/binaries/5.5-2017.10/arm-linux-gnueabihf/gcc-linaro-5.5.0-2017.10-x86_64_arm-linux-gnueabihf.tar.xz ``` - **解压并安装**: ```bash tar -xvf gcc-linaro-5.5.0-2017.10-x86_64_arm-linux-gnueabihf.tar.xz -C /opt ``` - **添加环境变量**:在 `~/.bashrc` 或终端中临时设置: ```bash export PATH=/opt/gcc-linaro-5.5.0-2017.10-x86_64_arm-linux-gnueabihf/bin:$PATH ``` 然后执行 `source ~/.bashrc` 生效[^3][^4]。 --- #### 2. **配置 Makefile** - **定义交叉编译工具链**: ```makefile CROSS = arm-linux-gnueabihf- CC = $(CROSS)gcc LD = $(CROSS)ld ``` 若需静态编译(避免动态库依赖),添加 `-static` 参数: ```makefile CC = $(CROSS)gcc -static LD = $(CROSS)ld -static ``` 引用示例中的修改方法[^1][^2]。 - **设置编译选项**: ```makefile CFLAGS = -Wall -O2 LDFLAGS = -L/path/to/arm-libs ``` --- #### 3. **编译与链接** - **编译目标**:在 Makefile 中指定目标文件与依赖关系: ```makefile TARGET = my_program OBJS = main.o utils.o $(TARGET): $(OBJS) $(CC) $(CFLAGS) $(LDFLAGS) -o $@ $^ ``` - **执行编译**: ```bash make ``` - **验证二进制文件**: ```bash file my_program # 应显示 "ARM EABI" 或类似标识 ``` --- #### 4. **处理依赖库** - **交叉编译第三方库**:例如 OpenSSL: ```bash ./Configure linux-armv4 -static --prefix=/opt/arm-openssl --cross-compile-prefix=arm-linux-gnueabihf- make && make install ``` 在 Makefile 中指定库路径: ```makefile CFLAGS += -I/opt/arm-openssl/include LDFLAGS += -L/opt/arm-openssl/lib -lssl -lcrypto ``` 参考 OpenSSL 交叉编译方法[^3]。 --- #### 5. **常见问题** - **路径错误**:确保 `arm-linux-gnueabihf-gcc` 在 `PATH` 中,否则报错 "command not found"。 - **静态链接失败**:检查工具链是否支持静态库,或手动安装静态库版本。 - **依赖库缺失**:交叉编译时需为 ARM 架构重新编译所有依赖库。 - **清理构建**:在 Makefile 中添加: ```makefile clean: rm -f $(TARGET) $(OBJS) ``` --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值