如何检查为 8085 模拟器设置的标志
How to check for flags being set for 8085 simulator
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 个中,符号标志、零标志和奇偶标志很容易检查,但是进位和辅助进位标志变得复杂。上面贴了我查carry flag & auxiliary carry flag的方法,好像不太靠谱
欢迎任何better/cleaner/more最佳解决方案。我也一直在使用 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));
我尝试使用这个逻辑来查看它是否适用于所有数学运算,显然这并不能可靠地检查是否应该设置进位或辅助进位标志。请帮助我弄清楚如何可靠地检查操作是否导致进位标志和辅助进位标志被设置或取消设置。
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 中是无符号的,因此它可以与上面的逻辑一起使用以获得所需的结果。
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 个中,符号标志、零标志和奇偶标志很容易检查,但是进位和辅助进位标志变得复杂。上面贴了我查carry flag & auxiliary carry flag的方法,好像不太靠谱
欢迎任何better/cleaner/more最佳解决方案。我也一直在使用 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));
我尝试使用这个逻辑来查看它是否适用于所有数学运算,显然这并不能可靠地检查是否应该设置进位或辅助进位标志。请帮助我弄清楚如何可靠地检查操作是否导致进位标志和辅助进位标志被设置或取消设置。
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 中是无符号的,因此它可以与上面的逻辑一起使用以获得所需的结果。