Security code: Difference between revisions

From NeoGeo Development Wiki
Jump to navigation Jump to search
mNo edit summary
(Add security code from SNK official doc)
Line 4: Line 4:


There is some jsr to the security location inside the bios code but it seems to never be called (at least for the euro v2 one).
There is some jsr to the security location inside the bios code but it seems to never be called (at least for the euro v2 one).
From Official SNK doc :
<pre>
dc.w 07600H, 04A6DH, 00A14H, 06600H
dc.w 0003CH, 0206DH, 00A04H, 03E2DH
dc.w 00A08H, 013C0H, 00030H, 00001H
dc.w 03210H, 00C01H, 000FFH, 0671AH
dc.w 03028H, 00002H, 0D02DH, 00ACEH
dc.w 06610H, 03028H, 00004H, 0B02DH
dc.w 00ACFH, 00606H, 0B22DH, 00AD0H
dc.w 06708H, 05088H, 051CFH, 0FFD4H
dc.w 03607H, 04E75H, 0206DH, 00A04H
dc.w 03E2DH, 00A08H, 03210H, 0E049H
dc.w 00C01H, 000FFH, 0671AH, 03010H
dc.w 0B02DH, 00ACEH, 06612H, 03028H
dc.w 00002H, 0E048H, 0B02DH, 00ACFH
dc.w 06606H, 0B22DH, 00AD0H, 06708H
dc.w 05888H, 051CFH, 0FFD8H, 03607H
dc.w 04E75H
</pre>


From KOF96 (CD):
From KOF96 (CD):

Revision as of 12:02, 24 June 2011

Pointed to by $182.

The bios will simple compare bytes per bytes this code with the one inside itself (at 0xC146A2 for the euro v2 one).

There is some jsr to the security location inside the bios code but it seems to never be called (at least for the euro v2 one).

From Official SNK doc :

dc.w	07600H, 04A6DH, 00A14H, 06600H
dc.w	0003CH, 0206DH, 00A04H, 03E2DH
dc.w	00A08H, 013C0H, 00030H, 00001H
dc.w	03210H, 00C01H, 000FFH, 0671AH
dc.w	03028H, 00002H, 0D02DH, 00ACEH
dc.w	06610H, 03028H, 00004H, 0B02DH
dc.w	00ACFH, 00606H, 0B22DH, 00AD0H
dc.w	06708H, 05088H, 051CFH, 0FFD4H
dc.w	03607H, 04E75H, 0206DH, 00A04H
dc.w	03E2DH, 00A08H, 03210H, 0E049H
dc.w	00C01H, 000FFH, 0671AH, 03010H
dc.w	0B02DH, 00ACEH, 06612H, 03028H
dc.w	00002H, 0E048H, 0B02DH, 00ACFH
dc.w	06606H, 0B22DH, 00AD0H, 06708H
dc.w	05888H, 051CFH, 0FFD8H, 03607H
dc.w	04E75H

From KOF96 (CD):

	moveq	#0,d3
	tst	2580(a5)		;$10FD14.w
	bne	LAB_20F3		;
	movea.l	2564(a5),a0		;$10FD04.l
	move	2568(a5),d7		;$10FD08.w
LAB_20F0:
	move.b	d0,EXT_03E5		;watchdog
	move	(a0),d1
	cmpi.b	#$FF,d1
	beq.s	LAB_20F1		;skip
	move	2(a0),d0
	cmp.b	2766(a5),d0		;$10FDCE.b
	bne.s	LAB_20F1		;skip
	move	4(a0),d0
	cmp.b	2767(a5),d0		;$10FDCF.b
	bne.s	LAB_20F1		;skip
	cmp.b	2768(a5),d1		;$10FDD0.b
	beq.s	LAB_20F2
LAB_20F1:
	addq.l	#8,a0
	dbf	d7,LAB_20F0
	move	d7,d3
LAB_20F2:
	rts

LAB_20F3:
	movea.l	2564(a5),a0		;$10FD04.l
	move	2568(a5),d7		;$10FD08.w
LAB_20F4:
	move	(a0),d1
	lsr	#8,d1
	cmpi.b	#$FF,d1
	beq.s	LAB_20F5		;skip
	move	(a0),d0
	cmp.b	2766(a5),d0		;$10FDCE.b
	bne.s	LAB_20F5		;skip
	move	2(a0),d0
	lsr	#8,d0
	cmp.b	2767(a5),d0		;$10FDCF.b
	bne.s	LAB_20F5		;skip
	cmp.b	2768(a5),d1		;$10FDD0.b
	beq.s	LAB_20F6
LAB_20F5:
	addq.l	#4,a0
	dbf	d7,LAB_20F4
	move	d7,d3
LAB_20F6:
	rts

From sp-s2.sp1 :

Security:
                moveq   #0, d3
                tst.w   0xA14(a5)
                bne.w   loc_C146E6
                movea.l 0xA04(a5), a0
                move.w  0xA08(a5), d7

loc_C146B4:
                move.b  d0, (0x300001).l
                move.w  (a0), d1
                cmpi.b  #0xFF, d1
                beq.s   loc_C146DC
                move.w  2(a0), d0
                cmp.b   0xACE(a5), d0
                bne.s   loc_C146DC
                move.w  4(a0), d0
                cmp.b   0xACF(a5), d0
                bne.s   loc_C146DC
                cmp.b   0xAD0(a5), d1
                beq.s   locret_C146E4

loc_C146DC:
                addq.l  #8, a0
                dbf     d7, loc_C146B4
                move.w  d7, d3

locret_C146E4:
                rts

loc_C146E6:
                movea.l 0xA04(a5), a0
                move.w  0xA08(a5), d7

loc_C146EE:
                move.w  (a0), d1
                lsr.w   #8, d1
                cmpi.b  #0xFF, d1
                beq.s   loc_C14712
                move.w  (a0), d0
                cmp.b   0xACE(a5), d0
                bne.s   loc_C14712
                move.w  2(a0), d0
                lsr.w   #8, d0
                cmp.b   0xACF(a5), d0
                bne.s   loc_C14712
                cmp.b   0xAD0(a5), d1
                beq.s   locret_C1471A

loc_C14712:
                addq.l  #4, a0
                dbf     d7, loc_C146EE
                move.w  d7, d3

locret_C1471A:
                rts