免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 3366 | 回复: 12

RTL转换 [复制链接]

论坛徽章:
0
发表于 2014-03-14 21:02 来自手机 |显示全部楼层
(mem(+(mem) const))
RTL代码中如何将第二个mem节点转为一条mov指令?
需要在哪里判断?

论坛徽章:
0
发表于 2014-03-15 21:06 来自手机 |显示全部楼层
现在进行p->v;操作时出现无法匹配的RTL

move reg,[p]
move reg,[reg+v]

GCC没有将p加载,变成

move reg,[p+v]

论坛徽章:
2
摩羯座
日期:2013-10-10 14:29:04天蝎座
日期:2014-01-03 09:14:49
发表于 2014-03-17 17:50 |显示全部楼层
gdb调试下吧

论坛徽章:
0
发表于 2014-03-17 22:58 |显示全部楼层
/home/abcde/gccsrc/libgcc/unwind-dw2-fde.c: In function ‘frame_heapsort’:
/home/abcde/gccsrc/libgcc/unwind-dw2-fde.c:537:1: error: insn does not satisfy its constraints:
(insn 48 47 163 2 (set (reg:SI 4 X4)
        (mem:SI (plus:SI (mem/f/c:SI (plus:SI (reg/f:SI 22 FP)
                        (const_int 16 [0x10])) [6 erratic+0 S4 A32])
                (const_int 4 [0x4])) [4 erratic_3(D)->count+0 S4 A32])) /home/abcde/gccsrc/libgcc/unwind-dw2-fde.c:519 3 {load_store_si}
     (nil))
/home/abcde/gccsrc/libgcc/unwind-dw2-fde.c:537:1: internal compiler error: in reload_cse_simplify_operands, at postreload.c:403

论坛徽章:
0
发表于 2014-03-17 22:59 |显示全部楼层
/home/abcde/gccsrc/libgcc/unwind-dw2-fde.c: In function ‘frame_heapsort’:
/home/abcde/gccsrc/libgcc/unwind-dw2-fde.c:537:1: error: insn does not satisfy its constraints:
(insn 48 47 163 2 (set (reg:SI 4 X4)
        (mem:SI (plus:SI (mem/f/c:SI (plus:SI (reg/f:SI 22 FP)
                        (const_int 16 [0x10])) [6 erratic+0 S4 A32])
                (const_int 4 [0x4])) [4 erratic_3(D)->count+0 S4 A32])) /home/abcde/gccsrc/libgcc/unwind-dw2-fde.c:519 3 {load_store_si}
     (nil))
/home/abcde/gccsrc/libgcc/unwind-dw2-fde.c:537:1: internal compiler error: in reload_cse_simplify_operands, at postreload.c:403

论坛徽章:
2
摩羯座
日期:2013-10-10 14:29:04天蝎座
日期:2014-01-03 09:14:49
发表于 2014-03-18 09:37 |显示全部楼层
估计还是RTL pattern描述的问题。

论坛徽章:
0
发表于 2014-03-18 11:06 |显示全部楼层
I do think so. But I tried own test code, it works fine. It's pretty weird.

  1. struct new
  2. {
  3. int a;
  4. int b;
  5. };

  6. int main(struct new * p)
  7. {
  8. p->b += 123;
  9. }
复制代码

论坛徽章:
2
摩羯座
日期:2013-10-10 14:29:04天蝎座
日期:2014-01-03 09:14:49
发表于 2014-03-18 11:49 |显示全部楼层
也许只是你这个例子没有暴露这个问题。如果reload阶段没有找到合适的RTL模式,就会报错了。

论坛徽章:
0
发表于 2014-03-19 12:25 来自手机 |显示全部楼层
指定参数入栈传递一般需要设置哪些选项?

论坛徽章:
2
摩羯座
日期:2013-10-10 14:29:04天蝎座
日期:2014-01-03 09:14:49
发表于 2014-03-19 16:38 |显示全部楼层
http://gcc.gnu.org/onlinedocs/gc ... tml#Stack-Arguments

17.10.6 Passing Function Arguments on the Stack

我也就是纸上谈兵,具体的还是需要查看gccint文档和现有的代码,呵呵。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

SACC2019中国系统架构师大会

【数字转型 架构演进】SACC2019中国系统架构师大会
2019年10月31日~11月2日第11届中国系统架构师大会(SACC2019)将在北京隆重召开。四大主线并行的演讲模式,1个主会场、20个技术专场、超千人参与的会议规模,100+来自互联网、金融、制造业、电商等领域的嘉宾阵容,将为广大参会者提供一场最具价值的技术交流盛会。




----------------------------------------

大会官网>>
  

北京盛拓优讯信息技术有限公司. 版权所有 16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122
中国互联网协会会员  联系我们:huangweiwei@it168.com
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP