byte x = 0x0c;
byte y = 0x05;
System.out.println((x&0xf) + (y&0xf)); // if > 15 then af on
System.out.println((b&0xf) - (c&0xf));
System.out.println((int)(b&0xff) + (c&0xff)); // if > 255 then cf on
System.out.println(((int)(b&0xff) + (c&0xff)) & 0b10000000); // if 128 sign flag set
System.out.println((int)(b&0xff) - (c&0xff)); // if less than 0 then cf set
System.out.println(((int)(b&0xff) - (c&0xff)) & 0b10000000); //if 128 then sign flag set
我正在构建8085仿真器,并且在算术和逻辑指令下,我试图找到一种可靠的方法来检查何时设置或取消设置5个标志。
在5个符号中,很容易检查符号标志,零标志和奇偶校验标志,但是进位和辅助进位标志变得复杂。我上面提到的检查进位标志和辅助进位标志的方法似乎不太可靠。
欢迎任何更好/更清洁/更优化的解决方案。我也一直在使用www.sim8085.com来检查我的迷你代码段,并检查打开了哪些标志,这是我遇到下一个问题的地方:
mvi a, ffh
mvi b, cch
sub b
hlt
运行此代码时,将设置辅助标志。据我所知,只有从低位半字节到高位半字节有进位时,才设置辅助标志。因此,我无法理解其背后的逻辑。
还想知道所有标志是否仅受累加器更改的影响吗?
编辑:
byte b = 0x2f;
byte c = 0x2c;
byte d = (byte) ((byte) (b&0xf) + (c&0xf));
byte e = (byte) ((byte) (b&0xf) + ((~c)&0xf) + 1);
int x = (int) ((b&0xff) + (c&0xff));
int y = (int) ((int) (b&0xff) + ((~c)&0xff) + 1);
System.out.println(y);
System.out.println((d>0xf) + "\t" + (e>0xf));
System.out.println((x>0xff) + "\t" + (y>0xff));
我尝试使用此逻辑来查看它是否适用于所有数学运算,显然这无法可靠地检查是否应设置进位或辅助进位标志。请帮我弄清楚如何可靠地检查操作是否导致进位标志和辅助进位标志被设置或未设置。
答案 0 :(得分:0)
byte b = (byte) 0x1c;
byte c = (byte) 0xff;
char a = (char) (Byte.toUnsignedInt(b) + Byte.toUnsignedInt(c));
char d = (char) (Byte.toUnsignedInt(b) - Byte.toUnsignedInt(c));
System.out.println(Integer.toHexString(a));
System.out.println(Integer.toHexString(d));
if(a > 0xff) {
System.out.println("Add Carry");
}
if(d > 0xff) {
System.out.println("Sub Carry");
}
if((Byte.toUnsignedInt(b) & 0xf) + (Byte.toUnsignedInt(c) & 0xf) > 0xf) {
System.out.println("Add Aux Carry");
}
if((Byte.toUnsignedInt(b) & 0xf) + (Byte.toUnsignedInt((byte) ~c) & 0xf) + 1 > 0xf) {
System.out.println("Sub Aux Carry");
}
我做了进一步的检查,发现char数据类型在Java中是无符号的,因此可以与上面的逻辑一起使用以获得所需的结果。