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
(Split by category)
(Split by category)
Line 32: Line 32:
== 65c816 SA-1 CPU ==
== 65c816 SA-1 CPU ==


=== Unsigned 16 bit x 16 bit = 32 bit multiplication ===
=== General ===
 
==== Unsigned 16 bit x 16 bit = 32 bit multiplication ====
by [[User:Akaginite|Akaginite]]
by [[User:Akaginite|Akaginite]]



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

General

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