微机原理软件实验——问题记录
1. 堆栈不平衡:
在调用子程序的时候,必须考虑到子程序的堆栈平衡问题。这要从call和ret的机制说起。
- call:将当前语句的CS和IP压入堆栈
- ret:pop栈顶的CS和IP
如果子程序使用了堆栈,那么一定要保证堆栈平衡,也就是说,调用之前堆栈是啥样的,调用之后就该是啥样的。更直白的说,子程序中push多少次,相应的就要pop多少次,否则ret弹出的地址不是原来存入的地址,就会发生一些不可预期的错乱。
20171214_更新:
后来老师上课的时候正好讲到了那个例程,例程本身就有问题哪,堆栈用的很混乱!!害我干瞪眼一天没改对!!之后有时间再详细分析。
2. 保护现场,寄存器复用
还是跟堆栈有关,cpu里寄存器就那么几个,常常要“分时复用”,比如ax,我们可能拿他存数据,但是中途可能又要用它做别的事(比如调用dos功能),那么不得不把原来存好的数据丢掉,在丢掉这些数据之前,先把他们压入堆栈保护,要用的时候再弹出来,就解决了这个问题。
不过很麻烦的一点是,堆栈和子程序一起用,就容易出现以上的堆栈不平衡问题,暂时不知道如何能更好的解决。