summaryrefslogtreecommitdiff
path: root/emu/6522.h
blob: 853bd3e81e2b7a2c90aa1b9a0d7f81bb62b3bf41 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
#ifndef VIA_6522_H
#define VIA_6522_H

#include "device.h"
#include "bus.h"

#include <stdint.h>
#include <stdbool.h>

#ifdef WITH_GUI
#include <SDL.h>
#endif

// the VIA connects to sub-devices itself via the bus. It also
// has things like timers and internal registers
// the VIA is initialized with a base address, the addresses for
// the registers are relative to this base.
enum {
	PORTA = 0x01,
	DDRA  = 0x03
};

typedef struct via_6522_t
{
	device_t base;
	
	uint16_t addr;
	
	uint8_t ddra;

	bool debug;
	
	bus_t bus;
} via_6522_t;

void via_6522_init( via_6522_t *via, uint16_t addr, bool initialize );
void via_6522_register( via_6522_t *via, device_t *device );

uint8_t via_6522_read( void *obj, uint16_t addr );
void via_6522_write( void *obj, uint16_t addr, uint8_t data );
#ifdef WITH_GUI
void via_6522_draw( void *obj, SDL_Renderer *renderer );
#endif
void via_6522_deinit( void *obj );

#endif