登录
注册
开源
企业版
高校版
搜索
帮助中心
使用条款
关于我们
开源
企业版
高校版
私有云
模力方舟
我知道了
查看详情
登录
注册
代码拉取完成,页面将自动刷新
捐赠
捐赠前请先登录
取消
前往登录
扫描微信二维码支付
取消
支付完成
支付提示
将跳转至支付宝完成支付
确定
取消
Watch
不关注
关注所有动态
仅关注版本发行动态
关注但不提醒动态
21
Star
27
Fork
158
src-openEuler
/
gcc
代码
Issues
25
Pull Requests
4
Wiki
统计
流水线
服务
Gitee Pages
JavaDoc
PHPDoc
质量分析
Jenkins for Gitee
腾讯云托管
腾讯云 Serverless
悬镜安全
阿里云 SAE
Codeblitz
SBOM
我知道了,不再自动展开
263
解决riscv显式-latomic问题
草稿
用户已删除:master
src-openEuler:master
laokz
创建于 2023-03-28 20:40
克隆/下载
HTTPS
SSH
复制
下载 Email Patch
下载 Diff 文件
1. 问题 RISC-V没有1、2字节的原子指令,Gcc截止当前也没有inlining subword atomic函数。为解决这一问题,Gcc通过specs串[将atomic关联到了与其紧密相关的pthread选项](https://gcc.gnu.org/git/?p=gcc.git;a=blob;f=gcc/config/riscv/linux.h;h=b9557a75dc72bc451005a8292da9d4829030ba8d;hb=HEAD), ``` #define LIB_SPEC GNU_USER_TARGET_LIB_SPEC \ 43 " %{pthread:" LD_AS_NEEDED_OPTION " -latomic " LD_NO_AS_NEEDED_OPTION "}" ``` 即有pthread选项时按需链接libatomic.so。但随着Gcc的不断升级优化,很多应用已无需显式给出pthread选项,这就打破了前述努力:当程序需要这些原子操作时,仍要显式-latomic。 2. 解决的方法 riscv社区讨论了很长时间,有建议给Gcc增加内联函数的,但当前还处于[WIP状态](https://gcc.gnu.org/bugzilla/show_bug.cgi?id=104338),有建议发行厂商做[workaround](https://github.com/riscv-collab/riscv-gcc/issues/12),即无条件as-needed -latomic,不再要求pthread这个前置条件;有建议直接针对有需求的各个软件,修改构建过程参数。 这三种方式各有利弊:第一种补丁方式一劳永逸比较理想,但缺少验证,补丁当前也有一些疑问;第三种单包处理方式无风险,但需要逐个包地修改,并且随着软件包升级或打补丁,相应地-latomic取舍可能变化,在GCC和RISC-V彻底解决这个问题后,还要逐个包地修改回来,维护成本很高;第二种无条件as-needed方式基本没有风险,可一劳永逸地解决问题,但由于gcc二阶段构建特点,修改Gcc的specs串[比较困难](https://git.alpinelinux.org/aports/tree/main/gcc/0035-configure-Add-enable-autolink-libatomic-use-in-LINK_.patch),相当于hack了Gcc的构建过程。 3. 友商做法及我们的建议 openSUSE采用了第一种补丁方式(只查看了它的一个版本),Debian采用了第三种单包处理方式,Alpine和Archlinux采用了第二种方式。其中Archlinux是直接修改了二进制文件中的[specs串](https://github.com/felixonmars/archriscv-packages/blob/master/gcc/riscv64.patch#L82)。 我们建议采用Archlinux的做法(据了解应用效果比较好。),主要考虑它的优点与第一种补丁方式相同,比Alpine的简洁。从原理上来说,虽然hack二进制很“不正规”,但实际作用与objcopy、strip类同,并且修改的是静态串。修改后gcc就依赖了libatomic库,为此增加了gcc主包的Requires。 为验证这种做法的正确性和有效性,在RISC-V架构上用修改后的Gcc编译测试了相关的[8个软件包都成功了](https://build.tarsier-infra.com/project/show/home:laokz:23.03gcc-need-atomic),打包结果中的Requires正确地按需依赖了libatomic.so。同时也查看了gen_digest_list和build-id有关流程,未发现影响。 修改进行了架构隔离保护,请审核
怎样手动合并此 Pull Request
git checkout master
git pull https://gitee.com/src-openeuler/gcc.git master
git push origin master
评论
48
提交
1
文件
1
检查
代码问题
0
批量操作
展开设置
折叠设置
审查
Code Owner
审查人员
Noah
jvmboy
eastb233
eastb233
kuen
kuenking111_admin
编译小伙
li-yancheng
huangxiaoquan
huang-xiaoquan
cf-zhao
cf-zhao
周磊
alexanderbill
stubCode
stubCode
熊洲
xiongzhou4
Lin
lin-4682
未设置
最少人数
0
测试
Noah
jvmboy
eastb233
eastb233
kuen
kuenking111_admin
编译小伙
li-yancheng
huangxiaoquan
huang-xiaoquan
cf-zhao
cf-zhao
周磊
alexanderbill
stubCode
stubCode
熊洲
xiongzhou4
Lin
lin-4682
未设置
最少人数
0
优先级
不指定
严重
主要
次要
不重要
标签
openeuler-cla/yes
lgtm
ci_successful
sig/Compiler
关联 Issue
未关联
Pull Request 合并后将关闭上述关联 Issue
里程碑
未关联里程碑
openEuler-20.03-LTS-SP1-whole
openEuler-20.03-LTS-SP3-whole
openEuler-20.03-LTS-SP4-whole
openEuler-22.03-LTS-whole
openEuler-22.03-LTS-SP1-whole
openEuler-22.03-LTS-SP2-whole
openEuler-22.03-LTS-SP3-whole
参与者
(5)
Cherry-pick 提交
Cherry-pick 可以将
特定提交(Commit)
从某个分支挑选并应用到另一个分支,实现快速集成特定更改,而无需合并整个分支。
请选择应用 Cherry-pick 提交 (Commit) 的目标分支
新建分支
当前账号不存在 Fork 仓库,建议 cherry-pick 到 Fork 仓库。
Fork 仓库
提交列表
Commit SHA
Commit Message
基于 Cherry-pick 后的分支发起 Pull Request
取消
Cherry-pick
1
https://gitee.com/src-openeuler/gcc.git
git@gitee.com:src-openeuler/gcc.git
src-openeuler
gcc
gcc
点此查找更多帮助
搜索帮助
Git 命令在线学习
如何在 Gitee 导入 GitHub 仓库
Git 仓库基础操作
企业版和社区版功能对比
SSH 公钥设置
如何处理代码冲突
仓库体积过大,如何减小?
如何找回被删除的仓库数据
Gitee 产品配额说明
GitHub仓库快速导入Gitee及同步更新
什么是 Release(发行版)
将 PHP 项目自动发布到 packagist.org
仓库举报
回到顶部
登录提示
该操作需登录 Gitee 帐号,请先登录后再操作。
立即登录
没有帐号,去注册