We've just updated MediaWiki and its underlying software. If anything doesn't look or work quite right, please mention it to us. --RanAS
Processor Status Register: Difference between revisions
From SnesLab
(bit numbers) |
(→References: page 29) |
||
(5 intermediate revisions by the same user not shown) | |||
Line 13: | Line 13: | ||
There are nine instructions that directly modify these flags, including:<sup>[3]</sup> | There are nine instructions that directly modify these flags, including:<sup>[3]</sup> | ||
* [[REP]] | * [[REP]] (can clear multiple) | ||
* [[SEP]] | * [[SEP]] (can set multiple) | ||
* [[CLC]] | * [[CLC]] | ||
* [[SEC]] | * [[SEC]] | ||
Line 22: | Line 22: | ||
* [[SEI]] | * [[SEI]] | ||
* [[CLV]] | * [[CLV]] | ||
LDP does not exist, and STP does not store the register anywhere. | |||
Several other instructions affect the flags as a side effect. The only transfer instructions that do not modify these flags are [[TCS]] and [[TXS]]. | Several other instructions affect the flags as a side effect. The only transfer instructions that do not modify these flags are [[TCS]] and [[TXS]]. | ||
Line 71: | Line 73: | ||
=== References === | === References === | ||
# Table 18.2 [[Eyes & Lichty]], | # Table 18.2 [[Eyes & Lichty]], [https://archive.org/details/0893037893ProgrammingThe65816/page/422 page 422] | ||
# Figure 17.3, Lbid, | # Figure 17.3, Lbid, [https://archive.org/details/0893037893ProgrammingThe65816/page/377 page 377] | ||
# page 262, https://archive.org/details/0893037893ProgrammingThe65816/page/ | # lbid, Status Register Control Instructions, [https://archive.org/details/0893037893ProgrammingThe65816/page/262 page 262] | ||
# lbid, [https://archive.org/details/0893037893ProgrammingThe65816/page/29 page 29] | |||
[[Category:Registers]] | [[Category:Registers]] | ||
[[Category:Flags]] | [[Category:Flags]] | ||
[[Category:ASM]] |
Latest revision as of 14:31, 16 August 2024
The Processor Status Register (P) is on the 65c816 and contains several flags:
- 7: Negative Flag - N
- 6: Overflow Flag - V
- 5: Memory/Accumulator Select - M
- 4: Index Register Select - X
- 3: Decimal Mode - D
- 2: Interrupt Disable Flag - I
- 1: Zero Flag - Z
- 0: Carry Flag - C
It can be pulled from the stack via PLP and RTI.
There are nine instructions that directly modify these flags, including:[3]
LDP does not exist, and STP does not store the register anywhere.
Several other instructions affect the flags as a side effect. The only transfer instructions that do not modify these flags are TCS and TXS.
These instructions do not modify any status flags:
- BCC
- BCS
- BEQ
- BMI
- BNE
- BPL
- BRA
- BRL
- BVC
- BVS
- JMP
- JSL
- JSR
- MVN
- MVP
- NOP
- PEA
- PEI
- PER
- PHA
- PHB
- PHD
- PHK
- PHP (fullsnes claims the break flag is set)
- PHX
- PHY
- RTL
- RTS
- STA
- STP
- STX
- STY
- STZ
- TCS
- TXS
- WAI
- WDM
See Also
References
- Table 18.2 Eyes & Lichty, page 422
- Figure 17.3, Lbid, page 377
- lbid, Status Register Control Instructions, page 262
- lbid, page 29