#include <sys/param.h>
#include <sys/systm.h>
#include <uvm/uvm_extern.h>
#include <machine/board.h>
#include <machine/pmap_table.h>
#define R PROT_READ
#define RW (PROT_READ | PROT_WRITE)
const struct pmap_table
luna88k_board_table[] = {
#if 0
{ PROM_ADDR, PROM_SPACE, R },
#endif
{ FUSE_ROM_ADDR, FUSE_ROM_SPACE, R },
{ NVRAM_ADDR, NVRAM_SPACE, RW },
{ NVRAM_ADDR_88K2, PAGE_SIZE, RW },
{ OBIO_PIO0_BASE, PAGE_SIZE, RW },
{ OBIO_PIO1_BASE, PAGE_SIZE, RW },
{ OBIO_SIO, PAGE_SIZE, RW },
{ OBIO_TAS, PAGE_SIZE, RW },
{ OBIO_CLOCK0, PAGE_SIZE, RW },
{ INT_ST_MASK0, PAGE_SIZE, RW },
{ SOFT_INT0, PAGE_SIZE, RW },
{ SOFT_INT_FLAG0, PAGE_SIZE, RW },
{ RESET_CPU0, PAGE_SIZE, RW },
{ TRI_PORT_RAM, TRI_PORT_RAM_SPACE, RW },
#if 0
{ EXT_A_ADDR, EXT_A_SPACE, RW },
{ EXT_B_ADDR, EXT_B_SPACE, RW },
#endif
{ PC_BASE, PC_SPACE, RW },
#if 0
{ MROM_ADDR, MROM_SPACE, R },
#endif
{ BMAP_RFCNT, PAGE_SIZE, RW },
{ BMAP_BMSEL, PAGE_SIZE, RW },
{ BMAP_BMP, BMAP_BMAP0 - BMAP_BMP, RW, TRUE },
{ BMAP_BMAP0, BMAP_BMAP1 - BMAP_BMAP0, RW, TRUE },
{ BMAP_BMAP1, BMAP_BMAP2 - BMAP_BMAP1, RW, TRUE },
{ BMAP_BMAP2, BMAP_BMAP3 - BMAP_BMAP2, RW, TRUE },
{ BMAP_BMAP3, BMAP_BMAP4 - BMAP_BMAP3, RW, TRUE },
{ BMAP_BMAP4, BMAP_BMAP5 - BMAP_BMAP4, RW, TRUE },
{ BMAP_BMAP5, BMAP_BMAP6 - BMAP_BMAP5, RW, TRUE },
{ BMAP_BMAP6, BMAP_BMAP7 - BMAP_BMAP6, RW, TRUE },
{ BMAP_BMAP7, BMAP_FN - BMAP_BMAP7, RW, TRUE },
{ BMAP_FN, PAGE_SIZE, RW },
#if 0
{ BMAP_FN0, PAGE_SIZE, RW },
{ BMAP_FN1, PAGE_SIZE, RW },
{ BMAP_FN2, PAGE_SIZE, RW },
{ BMAP_FN3, PAGE_SIZE, RW },
{ BMAP_FN4, PAGE_SIZE, RW },
{ BMAP_FN5, PAGE_SIZE, RW },
{ BMAP_FN6, PAGE_SIZE, RW },
{ BMAP_FN7, PAGE_SIZE, RW },
{ BMAP_PALLET0, PAGE_SIZE, RW },
{ BMAP_PALLET1, PAGE_SIZE, RW },
#endif
{ BMAP_PALLET2, PAGE_SIZE, RW },
#if 0
{ BOARD_CHECK_REG, PAGE_SIZE, RW },
{ BMAP_CRTC, PAGE_SIZE, RW },
#endif
{ SCSI_ADDR, PAGE_SIZE, RW },
{ LANCE_ADDR, PAGE_SIZE, RW },
{ 0, 0, 0 },
};
const struct pmap_table *
pmap_table_build()
{
return luna88k_board_table;
}