#include <sys/param.h>
#include <sys/device.h>
#include <sys/systm.h>
#include <machine/cpuconf.h>
#include <machine/rpb.h>
#ifdef DEC_3000_500
extern void dec_3000_500_init(void);
#else
#define dec_3000_500_init platform_not_configured
#endif
#ifdef DEC_3000_300
extern void dec_3000_300_init(void);
#else
#define dec_3000_300_init platform_not_configured
#endif
#ifdef DEC_AXPPCI_33
extern void dec_axppci_33_init(void);
#else
#define dec_axppci_33_init platform_not_configured
#endif
#ifdef DEC_2100_A50
extern void dec_2100_a50_init(void);
#else
#define dec_2100_a50_init platform_not_configured
#endif
#ifdef DEC_KN20AA
extern void dec_kn20aa_init(void);
#else
#define dec_kn20aa_init platform_not_configured
#endif
#ifdef DEC_EB164
extern void dec_eb164_init(void);
#else
#define dec_eb164_init platform_not_configured
#endif
#ifdef DEC_EB64PLUS
extern void dec_eb64plus_init(void);
#else
#define dec_eb64plus_init platform_not_configured
#endif
#ifdef DEC_KN300
extern void dec_kn300_init(void);
#else
#define dec_kn300_init platform_not_configured
#endif
#ifdef DEC_550
extern void dec_550_init(void);
#else
#define dec_550_init platform_not_configured
#endif
#if defined(DEC_1000) || defined(DEC_1000A)
extern void _dec_1000a_init(void);
#endif
#ifdef DEC_1000A
#define dec_1000a_init _dec_1000a_init
#else
#define dec_1000a_init platform_not_configured
#endif
#ifdef DEC_1000
#define dec_1000_init _dec_1000a_init
#else
#define dec_1000_init platform_not_configured
#endif
#ifdef DEC_6600
extern void dec_6600_init(void);
#else
#define dec_6600_init platform_not_configured
#endif
#ifdef DEC_ALPHABOOK1
extern void dec_alphabook1_init(void);
#else
#define dec_alphabook1_init platform_not_configured
#endif
#ifdef API_UP1000
extern void api_up1000_init(void);
#else
#define api_up1000_init platform_not_configured
#endif
static const struct cpuinit cpuinit[] = {
cpu_notsupp(ST_ADU, "Alpha Demo Unit"),
cpu_notsupp(ST_DEC_4000, "DEC 4000 (``Cobra'')"),
cpu_notsupp(ST_DEC_7000, "DEC 7000 (``Ruby'')"),
cpu_init(ST_DEC_3000_500, dec_3000_500_init, "DEC_3000_500"),
cpu_notsupp(ST_DEC_2000_300, "DEC_2000_300"),
cpu_init(ST_DEC_3000_300, dec_3000_300_init, "DEC_3000_300"),
cpu_notsupp(ST_AVALON_A12, "AVALON_A12"),
cpu_notsupp(ST_DEC_2100_A500, "DEC_2100_A500"),
cpu_notsupp(ST_DEC_APXVME_64, "AXPvme 64"),
cpu_init(ST_DEC_AXPPCI_33, dec_axppci_33_init, "DEC_AXPPCI_33"),
cpu_notsupp(ST_DEC_21000, "DEC_KN8AE"),
cpu_init(ST_DEC_2100_A50, dec_2100_a50_init, "DEC_2100_A50"),
cpu_notsupp(ST_DEC_MUSTANG, "Mustang"),
cpu_init(ST_DEC_KN20AA, dec_kn20aa_init, "DEC_KN20AA"),
cpu_init(ST_DEC_1000, dec_1000_init, "DEC_1000"),
cpu_notsupp(ST_EB66, "DEC_EB66"),
cpu_init(ST_ALPHABOOK1, dec_alphabook1_init, "DEC_ALPHABOOK1"),
cpu_init(ST_DEC_4100, dec_kn300_init, "DEC_KN300"),
cpu_notsupp(ST_DEC_EV45_PBP, "EV45 Passive Backplane Board"),
cpu_notsupp(ST_DEC_2100A_A500, "DEC_2100A_A500"),
cpu_init(ST_EB164, dec_eb164_init, "DEC_EB164"),
cpu_init(ST_DEC_1000A, dec_1000a_init, "DEC_1000A"),
cpu_notsupp(ST_DEC_ALPHAVME_224, "AlphaVME 224"),
cpu_init(ST_DEC_550, dec_550_init, "DEC_550"),
cpu_notsupp(ST_DEC_EV56_PBP, "EV56 Passive Backplane Board"),
cpu_notsupp(ST_DEC_ALPHAVME_320, "AlphaVME 320"),
cpu_init(ST_DEC_6600, dec_6600_init, "DEC_6600"),
cpu_init(ST_DEC_TITAN, dec_6600_init, "DEC_6600"),
cpu_init(ST_API_NAUTILUS, api_up1000_init, "API_UP1000"),
};
static const int ncpuinit = (sizeof(cpuinit) / sizeof(cpuinit[0]));
const struct cpuinit *
platform_lookup(int systype)
{
const struct cpuinit *c;
int i;
for (i = 0; i < ncpuinit; i++) {
c = &cpuinit[i];
if (c->systype == systype)
return (c);
}
return (NULL);
}
void
platform_not_configured(void)
{
const struct cpuinit *c = platform_lookup(cputype);
printf("\nSupport for system type %d is not present in this kernel.\n",
cputype);
printf("Please build a kernel with \"options %s\" and reboot.\n",
c->option);
panic("platform not configured");
}
void
platform_not_supported(void)
{
const struct cpuinit *c = platform_lookup(cputype);
printf("\nOpenBSD does not yet support system type %d (%s).\n", cputype,
(c != NULL) ? c->option : "???");
panic("platform not supported");
}