PA2 PA3

pa1代码➕思路17元,pa2代码+思路30元,pa3仙剑奇侠传仅代码自己看13元。扫码备注邮箱,一般立刻发,如果有事24小时内发。

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中,根据i386中每条跳转指令对应的条件eflags填写;

make_EHelper函数要在all-instr.h中声明。

4opcode_table

根据decode.c的函数的注释和i386手册的opcode map,在opcode_table中进行填写。表opcode中的小写字母,Ev,这个v就是操作数的宽度。你去看i386的附录会发现v指的是word or double word,也就是2或4字节。如果传进去的width是0,那么它会判断操作数是2字节还是4字节,如果不是0,那么就直接把width设为操作数宽度。所以,遇到v,那么第三个参数应该是0,如果遇到Eb,b的意思是byte,就是1。

PA2.2

1实现differential testing

在ics2017\nemu\src\monitor\diff-test\diff-test.c文件下。就是把NEMU的8个通用寄存器和eip与从QEMU中读出的寄存器的值进行比较,如果发现不一致,就讲diff标志设置为true,并且输出不一致的值。

PA2.3

这个吧,不知道怎么说,思路就是讲义里面的,如果有问题可以留言问。

PA3 思路不写了,有问题可以留言问。

你可能感兴趣的:(PA,and,Lab)