解决make遇到Arguments too long

升级到了Ubuntu20.04的时候报错 Arguments too long, 最终通过降级make版本解决,接下来看看解决:

  1. 问题

Ubuntu20.04上make编译生成so的时候报错:

make[1]:execvp:/bin/sh:Arguments too long

对应makefile中的报错位置,仅仅是生成so的时候报错,伪代码如下

${build_tool} -shared -fpic -o "$@" ${OBJ_FILE} ${LDFLAGS}

然而如果不通过make执行,将后面的参数打印出来后,直接用交叉编译链执行是可以的,所以怀疑方向是在make

  1. 分析:

(1)查看系统命令缓冲区大小,通过命令

xargs --show-limits

执行结果:

limit.png

同时我也将这个库的合包段参数打出来看,确实很多 ,达到了 262 822(超过了系统 命令缓冲区的大小: 131072)

到这,也知道为什么报错了,因为执行的时候命令参数超过系统环境长度了,解决思路:

1)降低命令长度:最直接的方式肯定是降低长度,不过这个并不是最长久的,因为在这个架构下的代码去降低路径来缩减长度,无非是当前编译过了,在研发不断增长,到了某一天,就又会遇到超长

2)改编译配置:因为升级了ubuntu版本才出现编译不过,接下来查看make相关官方文献

(2)进行一系列查询,到了ubuntu官方去查询,在make的changelog中又有找到类似问题的修复说明:

ubuntu_make_changelog.png

进一步在4.1的新版本4.1.9中的diff里找到有对应的修复4.1.9-diff,但4.2.1的版本里却没看到相关补丁内容,看起来是没有合到4.2.1中,那接下来尝试回退版本试试

  1. 更新make版本实验验证

搭建虚拟机,匹配到Ubuntu 20.04,先用安装make V4.2.1版本进行编译复现问题,再降级到补丁的make版本进行编译观察是否解决

(1)make V4.2.1版本安装:装虚拟机后再 apt安装make即可

new-make-version.png

确认安装后Make版本一致,均为4.2.1,接下来进行make编译

new-make-exe.png

编译结果一致

(2)补丁版本降级安装:

下载补丁版本,地址

https://mirrors.tscak.com/ubuntu/pool/main/m/make-dfsg/

下载对应的deb,我的镜像安装包:

ubuntu-20.04.1-desktop-amd64.iso

通过:

uname -a

也看得到

root@ubuntu:~/make-4.1.9# uname -a Linux ubuntu 5.15.0-60-generic #66~20.04.1-Ubuntu SMP Wed Jan 25 09:41:30 UTC 2023 x86_64 x86_64 x86_64 GNU/Linux

所以下载:make_4.1-9.1ubuntu1_amd64.deb

下载到了直接编译好的deb,然后进行安装(中间遇到两次报错也记录了出来,也可以直接看最后一次正确安装)

root@ubuntu:~/make-4.1.9# sudo apt install make_4.1-9.1ubuntu1_amd64.deb  
Reading package lists... Done 
Building dependency tree        
Reading state information... Done 
E: Unable to locate package make_4.1-9.1ubuntu1_amd64.deb 

报错:

Unable to locate package make_4.1-9.1ubuntu1_amd64.deb

注意:(1)一定找对目录,到在deb文件目录 (2)要安装的文件需要真的在这个文件夹下,然后以相对路径去执行,即加上 ./

root@ubuntu:~/make-4.1.9# sudo apt install -y ./make_4.1-9.1ubuntu1_amd64.deb
Reading package lists... Done 
Building dependency tree        
Reading state information... Done 
Note, selecting 'make' instead of './make_4.1-9.1ubuntu1_amd64.deb' 
Suggested packages:   
make-doc 
The following packages will be DOWNGRADED:   
make 
0 upgraded, 0 newly installed, 1 downgraded, 0 to remove and 238 not upgraded. 
E: Packages were downgraded and -y was used without --allow-downgrades.

报错:

Packages were downgraded and -y was used without --allow-downgrades.

正确安装:由于 包已经下在本地了,所以不需要-y, 去掉后重新装一次:

root@ubuntu:~/make-4.1.9# sudo apt install  ./make_4.1-9.1ubuntu1_amd64.deb    
Reading package lists... Done 
Building dependency tree        
Reading state information... Done 
Note, selecting 'make' instead of './make_4.1-9.1ubuntu1_amd64.deb' 
Suggested packages:   
make-doc 
The following packages will be DOWNGRADED:   
make 
0 upgraded, 0 newly installed, 1 downgraded, 0 to remove and 238 not upgraded. 
Need to get 0 B/154 kB of archives. 
After this operation, 12.3 kB disk space will be freed. 
Do you want to continue? [Y/n] y 
Get:1 /root/make-4.1.9/make_4.1-9.1ubuntu1_amd64.deb make amd64 4.1-9.1ubuntu1 [154 kB] 
dpkg: warning: downgrading make from 4.2.1-1.2 to 4.1-9.1ubuntu1 
(Reading database ... 238557 files and directories currently installed.) 
Preparing to unpack .../make_4.1-9.1ubuntu1_amd64.deb ... 
Unpacking make (4.1-9.1ubuntu1) over (4.2.1-1.2) ... 
Setting up make (4.1-9.1ubuntu1) ... Processing triggers for man-db (2.9.1-1) ... 
N: Download is performed unsandboxed as root as file '/root/make-4.1.9/make_4.1-9.1ubuntu1_amd64.deb' couldn't be accessed by user '_apt'. - pkgAcquire::Run (13: Permission denied) 
root@ubuntu:~/make-4.1.9# make --version  
GNU Make 4.1 
Built for x86_64-pc-linux-gnu 
Copyright (C) 1988-2014 Free Software Foundation, Inc. 
License GPLv3+: GNU GPL version 3 or later <http://gnu.org/licenses/gpl.html> 
This is free software: you are free to change and redistribute it. 
There is NO WARRANTY, to the extent permitted by law. 
root@ubuntu:~/make-4.1.9# 

这里就能看到,原本是 4.2.1-1.2 降级到了 4.1-9。接下来再进行make,就能通过了

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,937评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,503评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,712评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,668评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,677评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,601评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,975评论 3 396
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,637评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,881评论 1 298
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,621评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,710评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,387评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,971评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,947评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,189评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,805评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,449评论 2 342

推荐阅读更多精彩内容