We've just updated MediaWiki and its underlying software. If anything doesn't look or work quite right, please mention it to us. --RanAS

PHP: Difference between revisions

From SnesLab
Jump to: navigation, search
(linkify stack)
(→‎External Links: hid archive URL for Leventhal)
 
(16 intermediate revisions by the same user not shown)
Line 28: Line 28:
|.
|.
|.
|.
|.
|.?
|.
|.
|.
|.
Line 35: Line 35:
|}
|}


'''PHP''' is a 65x instruction that pushes the value of the [[processor status register]] onto the [[stack]].  The e bit is omitted from this operation.
'''PHP''' is a 65x instruction that pushes the value of the [[processor status register]] onto the [[stack]].  The [[e bit]] is omitted from this operation. PHP always pushes a single byte.
 
The [[stack pointer]] will then point directly below the byte pushed.
 
No flags are affected according to Eyes & Lichty.
But [[fullsnes]] claims that PHP always writes a one into the [[break flag]].
 
==== Syntax ====
<pre>
PHP
</pre>


=== See Also ===
=== See Also ===
Line 46: Line 56:


=== External Links ===
=== External Links ===
* [[Eyes & Lichty]] page 480, on PHP: https://archive.org/details/0893037893ProgrammingThe65816/page/n506
* [[Eyes & Lichty]], [https://archive.org/details/0893037893ProgrammingThe65816/page/480 page 480] on PHP
* [[Labiak]] page 164 on PHP: https://archive.org/details/Programming_the_65816/page/n174
* [[Labiak]], [https://archive.org/details/Programming_the_65816/page/n174 page 164] on PHP
* [[MCS6500 Manual]] page on PHP: https://archive.org/details/mos_microcomputers_programming_manual/page/n141
* 8.11 on [[MCS6500 Manual]], [https://archive.org/details/mos_microcomputers_programming_manual/page/n141 page 122] on PHP
* [[Carr]] page on PHP: https://archive.org/details/6502UsersManual/page/n280
* [[Carr]], [https://archive.org/details/6502UsersManual/page/n280 page 267] on PHP
* [[Leventhal]] page on PHP: https://archive.org/details/6502-assembly-language-programming/page/n131
* [[Leventhal]], [https://archive.org/details/6502-assembly-language-programming/page/n131 page 3-82] on PHP
* snes9x implementation of PHP: https://github.com/snes9xgit/snes9x/blob/master/cpuops.cpp#L1844
* snes9x implementation of PHP: https://github.com/snes9xgit/snes9x/blob/master/cpuops.cpp#L1844
* Clark, Bruce. http://www.6502.org/tutorials/65c816opcodes.html#6.8.3


[[Category:ASM]]
[[Category:ASM]]
[[Category:Inherited from 6502]]
[[Category:Inherited from 6502]]
[[Category:Push Instructions]]
[[Category:Push Instructions]]
[[Category:One-byte Instructions]]

Latest revision as of 14:20, 8 August 2024

Basic Info
Addressing Mode Opcode Length Speed
Stack (Push) 08 1 byte 3 cycles
Flags Affected
N V M X D I Z C
. . . .? . . . .

PHP is a 65x instruction that pushes the value of the processor status register onto the stack. The e bit is omitted from this operation. PHP always pushes a single byte.

The stack pointer will then point directly below the byte pushed.

No flags are affected according to Eyes & Lichty. But fullsnes claims that PHP always writes a one into the break flag.

Syntax

PHP

See Also

External Links