对包装 6502 间接 x 和 y 感到困惑

Bri*_*ker 1 assembly 6502

我不确定在索引 x 和 y 地址模式下包装是如何工作的。我发现的文档很清楚索引部分被包裹在零页内,但是实际取消引用的 16 位地址呢,它是否也被限制在零页上?

假设我有这个代码:

LDX #$00
LDA #$05
STA $ff
LDA #$07
STA $0100
LDA #$08
STA $00
LDY #$0a
STY $0705
LDY #$0b
STY $0805
LDA ($ff,X)
Run Code Online (Sandbox Code Playgroud)

A不会装$0a,或者$0b

很明显,如果X加载了$01,那么地址将从$00( $ff + $01 == $00) 中查找。但是在这种情况下,我们将从中读取 16 位地址 lo 字节$ff- 是从 读取 hi 字节$0100还是从$00

同样对于间接 y,假设我有以下代码:

LDY #$00
LDA #$30
STA $ff
LDA #$04
STA $00
LDA #$05
STA $0100
LDX #$0a
STX $0430
LDX #$0b
STX $0530
LDA ($ff),Y
Run Code Online (Sandbox Code Playgroud)

我们从 读取了一个 16 位地址$ff,高字节是从$0100还是从读取$00

最后,还有间接 y:

LDY #$01
LDA #$ff
STA $01
STA $02
LDX #$0a
STX $00
LDA ($01),Y
Run Code Online (Sandbox Code Playgroud)

我们取消引用$01,并得到$ffff,然后加入$01,确实来自这意味着我们的负载$00,并得到$0aA

Mic*_*ael 6

中的地址()是一个 8 位地址。实际有效地址是一个 16 位地址。

所以如果你有LDA ($FF,X)with X=0,那么 16 位有效地址将从$FF(LSB) 和$00(MSB)A加载,并从该地址加载。

如果您有,LDA ($FF),Y那么将从$FF和加载一个 16 位地址$00,然后Y将其添加到该 16 位地址,并A从结果地址加载。的加法Y不会在 8 位边界处回绕(但会在 16 位边界处回绕,即$00FF + 1 = $0100但是$FFFF + 1 = $0000)。