3 /* Definitions for SH board emulation. */
5 #include "hw/sh4/sh_intc.h"
7 #define A7ADDR(x) ((x) & 0x1fffffff)
8 #define P4ADDR(x) ((x) | 0xe0000000)
14 struct SH7750State
*sh7750_init(SuperHCPU
*cpu
, struct MemoryRegion
*sysmem
);
17 /* The callback will be triggered if any of the designated lines change */
18 uint16_t portamask_trigger
;
19 uint16_t portbmask_trigger
;
20 /* Return 0 if no action was taken */
21 int (*port_change_cb
) (uint16_t porta
, uint16_t portb
,
22 uint16_t * periph_pdtra
,
23 uint16_t * periph_portdira
,
24 uint16_t * periph_pdtrb
,
25 uint16_t * periph_portdirb
);
28 int sh7750_register_io_device(struct SH7750State
*s
,
29 sh7750_io_device
* device
);
31 #define TMU012_FEAT_TOCR (1 << 0)
32 #define TMU012_FEAT_3CHAN (1 << 1)
33 #define TMU012_FEAT_EXTCLK (1 << 2)
34 void tmu012_init(struct MemoryRegion
*sysmem
, hwaddr base
,
35 int feat
, uint32_t freq
,
36 qemu_irq ch0_irq
, qemu_irq ch1_irq
,
37 qemu_irq ch2_irq0
, qemu_irq ch2_irq1
);
41 #define SH_SERIAL_FEAT_SCIF (1 << 0)
42 void sh_serial_init(MemoryRegion
*sysmem
,
43 hwaddr base
, int feat
,
44 uint32_t freq
, CharDriverState
*chr
,
52 qemu_irq
sh7750_irl(struct SH7750State
*s
);
55 int tc58128_init(struct SH7750State
*s
, const char *zone1
, const char *zone2
);