我已经在Z80内核上实现了ADD A,r组操作码。我对我认为已经钉上的进位标志和溢出标志感到有些困惑,但是我想将其发布给社区,以检查我是否正确。
基本上,从我所看到的来看,Z80中的ALU并不关心有符号/无符号操作,它只是添加一些位。这意味着,如果将两个8位值相加并导致9位值相加,则进位标志将被置位。这包括将两个负的二进制补码相加,例如-20(11101100)和-40(11011000),尽管结果为-60(11000100),结果实际上是9位值1 11000100。这肯定意味着如果将两个负的二进制补码值相加,即使没有溢出条件,进位标志也将始终置位-是吗?
其次,我决定要检测该指令中的溢出,我将两个操作数的位7进行XOR,如果结果为10000000,则绝对没有溢出-如果结果为00000000,则可能存在溢出这些符号相同,因此我将加法运算结果的第7位与任一操作数的第7位进行XOR运算,如果运算结果为10000000,则发生了溢出,并设置了P / V溢出标志。我也是在这里吗?
很抱歉遇到这样一个令人费解的问题,我很确定我是对的,但是在基于此逻辑继续进行更多的说明之前,我需要知道。非常感谢。
慕勒3428872
哆啦的时光机