pa1代码➕思路,pa2代码+思路,pa3仙剑奇侠传仅完整代码打包自己看。需要的见评论区
PA2.1
1填写eflags
用位域去做。
2写rtl指令
rtl.h中所有内容都需要填。
3make_EHelper
call将要读取的下一条指令首地址压栈,设置跳转地址;
sub就是在sbb的基础上删去获取cf位和减去cf位的两行代码;
xor就是异或操作之后再根据i386手册写的更新标志位;
leave 将esp ebp恢复为最近一次enter之前的值;
cltd:将eax或ax的最左边一位赋给edx或dx的每一位。读取eax的值,算术右移;
add:相加。更新zf,sf。判断两个加数与和的大小,若两个加数都大于和,说明有进位或者借位,cf=1。判断两个加数的最高位是否相同,若不相同则不会溢出,若加数的最高位相同,判断加数与和的最高位是否相同,若不相同则不会溢出,否则溢出,of=1;
inc: dest<-dest+1,类似add;
sub:根据sbb来写;
dec:dest<-dest-1,类似sub;
cmp:相当于sub,只是不改变操作数,只修改eflags;
neg:如果dest为0,则cf=0,否则为1;将dest取反加一,也就相当于0-dest;
adc的eflags:同add的eflags;
剩余的:用rtl实现,然后按照i386手册所说修改eflags;
setcc:在cc.c中,根据i