megadrive_test2

changeset 1:2560a8be8cb8

hblank interrupt test
author John Tsiombikas <nuclear@member.fsf.org>
date Tue, 14 Mar 2017 09:02:43 +0200 (2017-03-14)
parents ce1b05082ac4
children 1d35c3b3a525
files Makefile src/intr.s src/main.c src/startup.s src/vdp.h src/vdpdefs.inc
diffstat 6 files changed, 83 insertions(+), 17 deletions(-) [+]
line diff
     1.1 --- a/Makefile	Tue Mar 14 05:59:33 2017 +0200
     1.2 +++ b/Makefile	Tue Mar 14 09:02:43 2017 +0200
     1.3 @@ -10,7 +10,7 @@
     1.4  warn = -pedantic -Wall
     1.5  dbg = -g
     1.6  def = -DGAMENAME=\"testgame\" -DVERSTR=\"01\" -D__NO_CTYPE
     1.7 -inc = -Isrc/libc
     1.8 +inc = -Isrc -Isrc/libc
     1.9  
    1.10  tool_prefix = m68k-linux-gnu-
    1.11  
    1.12 @@ -21,7 +21,7 @@
    1.13  
    1.14  CFLAGS = -m68000 -ffreestanding -fno-builtin $(warn) $(dbg) $(opt) $(def) $(inc)
    1.15  CPPFLAGS = $(def)
    1.16 -ASFLAGS = -m68000
    1.17 +ASFLAGS = -m68000 $(inc)
    1.18  LDFLAGS = -T megadrive.ldscript -print-gc-sections \
    1.19  		  -L/usr/lib/gcc-cross/m68k-linux-gnu/6 -lgcc
    1.20  
     2.1 --- a/src/intr.s	Tue Mar 14 05:59:33 2017 +0200
     2.2 +++ b/src/intr.s	Tue Mar 14 09:02:43 2017 +0200
     2.3 @@ -71,12 +71,36 @@
     2.4  | from here on we continue in the regular .text section since we don't care
     2.5  | where this code ends up.
     2.6  	.text
     2.7 +
     2.8 +.global enable_intr
     2.9 +enable_intr:
    2.10 +	andi.w #0xf8ff, %sr
    2.11 +	rts
    2.12 +
    2.13 +.global disable_intr
    2.14 +disable_intr:
    2.15 +	ori.w #0x0300, %sr
    2.16 +	rts
    2.17 +
    2.18  | interrupt handlers
    2.19  intr_fatal:
    2.20  	stop #0x2700
    2.21  
    2.22 -| TODO hblank/vblank code
    2.23 +	.include "vdpdefs.inc"
    2.24 +	.extern hblank_handler
    2.25 +	.extern vblank_handler
    2.26 +	.extern palval
    2.27 +
    2.28  intr_hblank:
    2.29 +	move.l #0xc0020000, VDP_PORT_CTL
    2.30 +
    2.31 +	move.w testcol, %d0
    2.32 +	move.w %d0, VDP_PORT_DATA
    2.33 +	rol.b #4, %d0
    2.34 +	move.w %d0, testcol
    2.35 +
    2.36  	rte
    2.37 +
    2.38  intr_vblank:
    2.39 +	jsr vblank_handler
    2.40  	rte
     3.1 --- a/src/main.c	Tue Mar 14 05:59:33 2017 +0200
     3.2 +++ b/src/main.c	Tue Mar 14 09:02:43 2017 +0200
     3.3 @@ -1,13 +1,31 @@
     3.4 +#include <stdint.h>
     3.5  #include "vdp.h"
     3.6  
     3.7  int main(void)
     3.8  {
     3.9  	vdp_init();
    3.10  
    3.11 +	vdp_set_pal_entry(0, 0, 0, 0, 0);
    3.12  	vdp_set_pal_entry(0, 1, 7, 0, 3);
    3.13  	vdp_set_bgcolor(0, 1);
    3.14  
    3.15 +	vdp_enable_hintr(12);
    3.16 +	vdp_enable_vintr();
    3.17 +
    3.18  	for(;;);
    3.19  
    3.20  	return 0;
    3.21  }
    3.22 +
    3.23 +uint16_t testcol = 0x00c0;
    3.24 +
    3.25 +void hblank_handler(void)
    3.26 +{
    3.27 +	vdp_set_pal_entry(0, 1, ~testcol, 0, testcol);
    3.28 +	testcol = ~testcol;
    3.29 +}
    3.30 +
    3.31 +void vblank_handler(void)
    3.32 +{
    3.33 +	testcol = 0x00c0;
    3.34 +}
     4.1 --- a/src/startup.s	Tue Mar 14 05:59:33 2017 +0200
     4.2 +++ b/src/startup.s	Tue Mar 14 09:02:43 2017 +0200
     4.3 @@ -4,7 +4,7 @@
     4.4  	.global start
     4.5  	.global halt_cpu
     4.6  start:
     4.7 -	bsr.s disable_intr
     4.8 +	jsr disable_intr
     4.9  
    4.10  	| copy .data section from ROM to RAM
    4.11  	move.l #_data_lma, %a0
    4.12 @@ -30,18 +30,8 @@
    4.13  	| setup the stack pointer stack
    4.14  	move.l #_stacktop, %sp
    4.15  	| now that we have a stack, we can enable interrupts
    4.16 -	bsr.s enable_intr
    4.17 +	jsr enable_intr
    4.18  
    4.19  	jsr main
    4.20  halt_cpu:
    4.21  	stop #0x2700
    4.22 -
    4.23 -.global enable_intr
    4.24 -enable_intr:
    4.25 -	andi.w #0xf8ff, %sr
    4.26 -	rts
    4.27 -
    4.28 -.global disable_intr
    4.29 -disable_intr:
    4.30 -	ori.w #0x0300, %sr
    4.31 -	rts
     5.1 --- a/src/vdp.h	Tue Mar 14 05:59:33 2017 +0200
     5.2 +++ b/src/vdp.h	Tue Mar 14 09:02:43 2017 +0200
     5.3 @@ -20,7 +20,7 @@
     5.4  	VDP_REG_NAMETAB_B		= 4,
     5.5  	VDP_REG_SPRITE_TAB		= 5,
     5.6  	VDP_REG_BGCOL			= 7,
     5.7 -	VDP_REG_INTR			= 10,
     5.8 +	VDP_REG_HINTR			= 10,
     5.9  	VDP_REG_MODE3			= 11,
    5.10  	VDP_REG_MODE4			= 12,
    5.11  	VDP_REG_SCROLL_TAB		= 13,
    5.12 @@ -120,7 +120,7 @@
    5.13  
    5.14  static inline void vdp_setreg(int reg, uint8_t value)
    5.15  {
    5.16 -	/*vdp_reg_shadow[reg] = value;*/
    5.17 +	vdp_reg_shadow[reg] = value;
    5.18  	VDP_PORT_CTL = (uint16_t)value | (reg << 8) | (uint16_t)0x8000;
    5.19  }
    5.20  
    5.21 @@ -152,6 +152,27 @@
    5.22  	VDP_PORT_DATA = VDP_PACK_RGB(r, g, b);
    5.23  }
    5.24  
    5.25 +static inline void vdp_enable_vintr(void)
    5.26 +{
    5.27 +	vdp_setreg(VDP_REG_MODE2, vdp_getreg(VDP_REG_MODE2) | VDP_MODE2_VINTR);
    5.28 +}
    5.29 +
    5.30 +static inline void vdp_disable_vintr(void)
    5.31 +{
    5.32 +	vdp_setreg(VDP_REG_MODE2, vdp_getreg(VDP_REG_MODE2) & ~VDP_MODE2_VINTR);
    5.33 +}
    5.34 +
    5.35 +static inline void vdp_enable_hintr(int counter)
    5.36 +{
    5.37 +	vdp_setreg(VDP_REG_HINTR, counter);
    5.38 +	vdp_setreg(VDP_REG_MODE1, vdp_getreg(VDP_REG_MODE1) | VDP_MODE1_HINTR);
    5.39 +}
    5.40 +
    5.41 +static inline void vdp_disable_hintr(void)
    5.42 +{
    5.43 +	vdp_setreg(VDP_REG_MODE1, vdp_getreg(VDP_REG_MODE1) & ~VDP_MODE1_HINTR);
    5.44 +}
    5.45 +
    5.46  void vdp_init(void);
    5.47  
    5.48  #endif	/* VDP_H_ */
     6.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     6.2 +++ b/src/vdpdefs.inc	Tue Mar 14 09:02:43 2017 +0200
     6.3 @@ -0,0 +1,13 @@
     6.4 +| vi:filetype=asm68k:
     6.5 +	.equ VDP_PORT_DATA, 0xc00000
     6.6 +	.equ VDP_PORT_CTL, 0xc00004
     6.7 +
     6.8 +	.equ VDP_REG_MODE1, 0
     6.9 +	.equ VDP_REG_MODE2, 1
    6.10 +
    6.11 +	.equ VDP_WRITE_VRAM, 0x40000000
    6.12 +	.equ VDP_WRITE_CRAM, 0xc0000000
    6.13 +	.equ VDP_WRITE_VSRAM, 0x40000010
    6.14 +	.equ VDP_READ_VRAM, 0
    6.15 +	.equ VDP_READ_CRAM, 0x00000020
    6.16 +	.equ VDP_READ_VSRAM, 0x00000010