询问在设计我的手臂模拟器功能表示格式1
inquiry in designing my Arm simulator function representing format 1
以下函数表示ARM Thumb中的格式1。我不明白在格式字段的每个声明中移位后使用AND(&(的部分,为什么我们在AND之后使用这些数字?ARM体系结构中的格式1表示
int simulate(unsigned short instr)
{
unsigned char fmt, op, offset5, rd, rs, offset3, rn;
fmt = (instr) >> 13;
switch(fmt){
case 0: // format 1/2
op = (instr >> 11) & 3;
rd = instr & 7;
rs = (instr >> 3) & 7;
offset5 = (instr >> 6) & 0x1F;
if(op!=3) { // format 1
/*
switch(op){
case 0: printf("lsltr%d, r%d, #%dn", rd, rs, offset5); break;
case 1: printf("lsrtr%d, r%d, #%dn", rd, rs, offset5); break;
case 2: printf("asrtr%d, r%d, #%dn", rd, rs, offset5); break;
}*/
对于类似op
的东西,它应该是2位长,但它在指令中有一定的偏移量。因此,您需要将op
位一直移动到最低有效位,然后移除任何剩余的位。
移位会将位移动到op
unsigned char
中的最低有效位位置,并将其与3(二进制中为11
,意味着只保留2个最低有效位(进行"与"运算,可以消除高位位置中的任何内容(对于op
,这些应该都是0
,但对于类似offset5
的内容,则不会(。
指令的其他部分都是一样的。offset5
是5位长,所以我们需要二进制的11111
,也就是0x1F
,依此类推
相关文章:
- 在执行其他功能的同时播放动画(LED矩阵和Arduino/ESP8266)
- 多态性和功能结合
- 如何在c++中实现处理器调度模拟器
- 带内存和隔离功能的SQLite
- 在CMakeLists.txt的安装功能中使用.cmake文件有什么用
- 类模板的成员功能的定义在单独的TU中完全专业化
- 有没有一种方法可以创建一个带有哈希表的数据库,该哈希表具有恒定时间查找功能
- 如何在C++中获得"静态纯虚拟"功能?
- 两个文件使用彼此的功能-如何解决
- 我应该实现右值推送功能吗?我应该使用std::move吗
- QML按钮点击功能执行顺序
- 无法理解此 return 语句的功能,没有它就会发生运行时错误
- 有没有可能有一个只有ADL才能找到的非好友功能
- 功能样式转换从 'int' 到 'ItemType' 的匹配转换
- 文件系统:复制功能的速度秘诀是什么
- 在用于格式4的arm模拟器中实现功能时的一个问题
- 如何在Directwrite中获得给定字体的可用OpenType功能
- 对可变参数使用声明.如何选择正确的功能
- 询问在设计我的手臂模拟器功能表示格式1
- Opencv 功能匹配在 iPhone 上中断,但在模拟器上不会中断