NetBSD/sys/arch/vax/boot/autoconf.c

187 lines
5.1 KiB
C

/* $NetBSD: autoconf.c,v 1.12 1998/08/08 16:10:41 ragge Exp $ */
/*
* Copyright (c) 1994, 1998 Ludd, University of Lule}, Sweden.
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* 3. All advertising materials mentioning features or use of this software
* must display the following acknowledgement:
* This product includes software developed at Ludd, University of Lule}.
* 4. The name of the author may not be used to endorse or promote products
* derived from this software without specific prior written permission
*
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
* IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
* NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
/* All bugs are subject to removal without further notice */
#include "sys/param.h"
#include "../include/mtpr.h"
#include "../include/sid.h"
#include "vaxstand.h"
int nmba=0, nuba=0, nbi=0,nsbi=0,nuda=0;
int *mbaaddr, *ubaaddr, *biaddr;
int *udaaddr, *uioaddr, tmsaddr, *bioaddr;
static int mba750[]={0xf28000,0xf2a000,0xf2c000};
static int uba750[]={0xf30000,0xf32000};
static int uio750[]={0xfc0000,0xf80000};
static int uda750[]={0772150};
/* 11/780's only have 4, 8600 have 8 of these. */
/* XXX - all of these should be bound to physical addresses */
static int mba780[]={0x20010000,0x20012000,0x20014000,0x20016000,
0x22010000,0x22012000,0x22014000,0x22016000};
static int uba780[]={0, 0, 0, 0x20006000,0x20008000,0x2000a000,0x2000c000, 0,
0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0x22006000,0x22008000,0x2200a000,0x2200c000};
static int uio780[]={0, 0, 0, 0x20100000,0x20140000,0x20180000,0x201c0000, 0,
0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0x22100000,0x22140000,0x22180000,0x221c0000};
static int bi8200[]={0x20000000, 0x22000000, 0x24000000, 0x26000000,
0x28000000, 0x2a000000};
static int bio8200[]={0x20400000};
static int uba630[]={0x20087800};
static int uio630[]={0x30000000};
#define qbdev(csr) (((csr) & 017777)-0x10000000)
static int uda630[]={qbdev(0772150),qbdev(0760334)};
static int uba670[]={0x20040000};
static int uio670[]={0x20000000};
static int uda670[]={0x20004030,0x20004230};
#define qb670dev(csr) (((csr) & 017777)+0x20000000)
/*
* Autoconf routine is really stupid; but it actually don't
* need any intelligence. We just assume that all possible
* devices exists on each cpu. Fast & easy.
*/
autoconf()
{
extern int memsz;
switch (vax_cputype) {
default:
printf("CPU type %d not supported by boot\n",vax_cputype);
printf("trying anyway...\n");
break;
case VAX_8600:
memsz = 0;
nmba = 8;
nuba = 32; /* XXX */
nuda = 1;
mbaaddr = mba780;
ubaaddr = uba780;
udaaddr = uda750;
uioaddr = uio780;
tmsaddr = 0774500;
break;
case VAX_780:
memsz = 0;
nmba = 4;
nuba = 4;
nuda = 1;
mbaaddr = mba780;
ubaaddr = uba780;
udaaddr = uda750;
uioaddr = uio780;
tmsaddr = 0774500;
break;
case VAX_750:
memsz = 0;
nmba = 3;
nuba = 2;
nuda = 1;
mbaaddr = mba750;
ubaaddr = uba750;
udaaddr = uda750;
uioaddr = uio750;
tmsaddr = 0774500;
break;
case VAX_650: /* the same for uvaxIII */
case VAX_78032:
nuba = 1;
nuda = 2;
ubaaddr = uba630;
udaaddr = uda630;
uioaddr = uio630;
tmsaddr = qbdev(0774500);
break;
case VAX_8200:
memsz = 0;
nbi = 1;
biaddr = bi8200;
bioaddr = bio8200;
break;
case VAX_TYP_RIGEL: /* we'll assume all Rigels are KA670s for now */
nuba = 1;
nuda = 2;
ubaaddr = uba670;
udaaddr = uda670;
uioaddr = uio670;
tmsaddr = qb670dev(0774500);
break;
case VAX_TYP_MARIAH:
switch (vax_boardtype) {
case VAX_BTYP_46: {
int *map, i;
/* Map all 16MB of I/O space to low 16MB of memory */
map = (int *)0x700000; /* XXX */
*(int *)0x20080008 = (int)map; /* XXX */
for (i = 0; i < 0x8000; i++)
map[i] = 0x80000000 | i;
}
break;
}
break;
case VAX_TYP_SOC:
break;
}
}
/*
* Return seconds since sometime...
* Some VAXen doesn't have TODR, return a fake value...
*/
getsecs()
{
static int fakesecs;
int todr = mfpr(PR_TODR);
if (todr)
return todr/100;
return ++fakesecs;
}