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

Useful Code Snippets: Difference between revisions

From SnesLab
Jump to: navigation, search
m (Ladida is silly)
(Split by category)
Line 3: Line 3:
== 65c816 S-CPU ==
== 65c816 S-CPU ==


=== Wait for H-Blank ===
=== General ===
 
==== Wait for H-Blank ====


<pre>
<pre>
Line 14: Line 16:
</pre>
</pre>


=== Inverse the accumulator (8-bit) ===
==== Inverse the accumulator (8-bit) ====


<pre>
<pre>
Line 21: Line 23:
</pre>
</pre>


=== Inverse the accumulator (16-bit) ===
==== Inverse the accumulator (16-bit) ====


<pre>
<pre>

Revision as of 01:19, 26 July 2019

Useful code snippets for the 65c816 ASM and general SNES hardware.

65c816 S-CPU

General

Wait for H-Blank

-
BIT $4212
BVS -
-
BIT $4212
BVC -

Inverse the accumulator (8-bit)

EOR #$FF
INC

Inverse the accumulator (16-bit)

EOR #$FFFF
INC

65c816 SA-1 CPU

Unsigned 16 bit x 16 bit = 32 bit multiplication

by Akaginite

;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
; 16bit * 16bit Multiplication SA-1 version
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
; Parameters
; $00-$01 : Multiplicand
; $02-$03 : Multiplier
; Return values
; $04-$07 : Product
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

MathMul16_16:	STZ $2250
		REP #$20
		LDA $00
		STA $2251
		ASL A
		LDA $02
		STA $2253
		BCS +
		LDA.w #$0000
+		BIT $02
		BPL +
		CLC
		ADC $00
+		CLC
		ADC $2308
		STA $06
		LDA $2306
		STA $04
		SEP #$20
		RTS