LDIを実行するときに、レジストラのデータの内容をレジストラにロードしたり、値のアドレスをレジスタに間接的にロードしたりするために、天気を把握するのに問題があります。
例:
x3000 LDI R6, far
x3001 ...(some command)
x3002 ...(some command)
x3003 far x6000
...
x6000 xf000
x3000を実行した後のR6のデータは何ですか?
LDIを実行するときに、レジストラのデータの内容をレジストラにロードしたり、値のアドレスをレジスタに間接的にロードしたりするために、天気を把握するのに問題があります。
例:
x3000 LDI R6, far
x3001 ...(some command)
x3002 ...(some command)
x3003 far x6000
...
x6000 xf000
x3000を実行した後のR6のデータは何ですか?
これを例にとります
.orig x3000
LDI R6, far
ADD R0,R0,#0
ADD R0,R0,#0
far .fill x6000
.end
組み立てて捨てる
hexdump -C test.obj
00000000 30 00 ac 02 10 20 10 20 60 00 |0.... . `.|
0000000a
そして手分解
0x3000: 0xAC02 ldi r6,#+2
0x3001: 0x1020 add r0,r0,#0
0x3002: 0x1020 add r0,r0,#0
0x3003: 0x6000
LDI 命令はこれを行います。
DR = mem[mem[PC† + SEXT(PCoffset9)]];
setcc();
命令の下位 9 ビットは 0x002 で、符号は 0x0002 に拡張されます。pc は変更された pc であるため、アドレス 0x3000 で命令を実行すると、pc は実際には 0x3001 なので
DR = mem[mem[0x3001+0x0002]]
DR = mem[mem[0x3003]]
DR = mem[0x6000]
DR = 0xF000 using your definition for what lives at address x6000.
DR is r6 so 0xF000 is stored in r6.
0xF000 is considered a negative so the flags are N = 1, Z = 0, P = 0 if I understand the flags correctly.