Chinaunix首页 | 论坛 | 博客
  • 博客访问: 178960
  • 博文数量: 42
  • 博客积分: 2185
  • 博客等级: 大尉
  • 技术积分: 455
  • 用 户 组: 普通用户
  • 注册时间: 2009-06-11 21:32
文章分类

全部博文(42)

文章存档

2012年(5)

2011年(13)

2010年(6)

2009年(18)

我的朋友

分类: C/C++

2011-12-17 12:12:43

ARM32 instruction MOV, #imm will use the immed_8r encoding, basically immed_8r we cared is:

xxxxxxxx xxxxxxxx xxxxrrrr bbbbbbbb

Here rrrr is number of bits need do right shift, bbbbbbbb is 8bit immediate. The final immediate using immed_8r encoding is:

  1. static unsigned ror(unsigned x, unsigned b)
  2. {
  3.         unsigned ret;

  4.         ret = (x >> b) | (( x & ( (1 << b) -1 ) ) << (32 - b) );

  5.         return ret;
  6. }

  7. static unsigned immed_8r(unsigned imm, unsigned sh)
  8. {
  9.         unsigned i;

  10.         for (i = 0; i < sh; i++) {
  11.                 imm = ror(imm, 2); /* we can do 2*15 == 30 ROR totally */
  12.         }

  13.         return imm;
  14. }

阅读(1345) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~