summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sys/arch/mac68k/mac68k/locore.s42
-rw-r--r--sys/arch/mac68k/mac68k/machdep.c375
-rw-r--r--sys/arch/mac68k/mac68k/trap.c19
3 files changed, 319 insertions, 117 deletions
diff --git a/sys/arch/mac68k/mac68k/locore.s b/sys/arch/mac68k/mac68k/locore.s
index e85614e6ba6..670d07d1144 100644
--- a/sys/arch/mac68k/mac68k/locore.s
+++ b/sys/arch/mac68k/mac68k/locore.s
@@ -1,5 +1,5 @@
-/* $OpenBSD: locore.s,v 1.13 1996/10/14 01:20:38 briggs Exp $ */
-/* $NetBSD: locore.s,v 1.68 1996/10/07 01:37:20 scottr Exp $ */
+/* $OpenBSD: locore.s,v 1.14 1996/10/23 04:49:47 briggs Exp $ */
+/* $NetBSD: locore.s,v 1.70 1996/10/17 06:32:13 scottr Exp $ */
/*
* Copyright (c) 1988 University of Utah.
@@ -280,7 +280,7 @@ _fpfline:
cmpl #FPU_68040,_fputype | 68040? (see fpu.c)
jne Lfp_unimp | no, skip FPSP
cmpw #0x202c,sp@(6) | format type 2?
- jne _illinst | no, treat as illinst
+ jne Lfp_unimp | no, FPEMUL or illinst
Ldofp_unimp:
#ifdef FPSP
.globl fpsp_unimp
@@ -970,9 +970,11 @@ Lloaddone:
/* init mem sizes */
-/* set kernel stack, user SP, and initial pcb */
+/* set kernel stack, user SP, proc0, and initial pcb */
movl _proc0paddr,a1 | get proc0 pcb addr
lea a1@(USPACE-4),sp | set kernel stack to end of area
+ lea _proc0,a2 | initialize proc0.p_addr so that
+ movl a1,a2@(P_ADDR) | we don't deref NULL in trap()
movl #USRSTACK-4,a2
movl a2,usp | init user SP
movl a1,_curpcb | proc0 is running
@@ -1003,6 +1005,13 @@ Lnocache0:
jra _main
+ pea Lmainreturned | Yow! Main returned!
+ jbsr _panic
+ /* NOTREACHED */
+Lmainreturned:
+ .asciz "main() returned"
+ .even
+
/*
* proc_trampoline
* Call function in register a2 with a3 as an arg and then rei. Note
@@ -1847,6 +1856,31 @@ Ldoboot1:
jra a1@ | and jump to ROM to reset machine
/*
+ * ptest040() does an 040 PTESTR (addr) and returns the 040 MMUSR iff
+ * translation is enabled. This allows us to find the physical address
+ * corresponding to a MacOS logical address for get_physical().
+ * sar 01-oct-1996
+ */
+ .globl _ptest040
+_ptest040:
+#if defined(M68040)
+ .long 0x4e7a0003 | movec tc,d0
+ andw #0x8000,d0
+ jeq Lget_phys1 | MMU is disabled
+ movc sfc,d1
+ movql #1,d0 | FC for ptestr
+ movc d0,sfc
+ movl sp@(4),a0 | logical address to look up
+ .word 0xf568 | ptestr (a0)
+ .long 0x4e7a0805 | movec mmusr,d0
+ movc d1,sfc
+ rts
+Lget_phys1:
+#endif
+ movql #0,d0 | return failure
+ rts
+
+/*
* LAK: (7/24/94) This routine was added so that the
* C routine that runs at startup can figure out how MacOS
* had mapped memory. We want to keep the same mapping so
diff --git a/sys/arch/mac68k/mac68k/machdep.c b/sys/arch/mac68k/mac68k/machdep.c
index eb47f33b673..b9d60762b95 100644
--- a/sys/arch/mac68k/mac68k/machdep.c
+++ b/sys/arch/mac68k/mac68k/machdep.c
@@ -1,5 +1,5 @@
-/* $OpenBSD: machdep.c,v 1.20 1996/10/14 01:24:58 briggs Exp $ */
-/* $NetBSD: machdep.c,v 1.121 1996/10/13 03:21:39 christos Exp $ */
+/* $OpenBSD: machdep.c,v 1.21 1996/10/23 04:49:48 briggs Exp $ */
+/* $NetBSD: machdep.c,v 1.122 1996/10/15 06:40:39 scottr Exp $ */
/*
* Copyright (c) 1988 University of Utah.
@@ -561,7 +561,7 @@ sendsig(catcher, sig, mask, code)
(void) grow(p, (unsigned) fp);
#ifdef DEBUG
if ((sigdebug & SDB_KSTACK) && p->p_pid == sigpid)
- printf("sendsig(%d): sig %d ssp %x usp %x scp %x ft %d\n",
+ printf("sendsig(%d): sig %d ssp %p usp %p scp %p ft %d\n",
p->p_pid, sig, &oonstack, fp, &fp->sf_sc, ft);
#endif
if (useracc((caddr_t) fp, sizeof(struct sigframe), B_WRITE) == 0) {
@@ -631,7 +631,7 @@ sendsig(catcher, sig, mask, code)
}
#ifdef DEBUG
if ((sigdebug & SDB_FPSTATE) && *(char *) &kfp->sf_state.ss_fpstate)
- printf("sendsig(%d): copy out FP state (%x) to %x\n",
+ printf("sendsig(%d): copy out FP state (%x) to %p\n",
p->p_pid, *(u_int *) & kfp->sf_state.ss_fpstate,
&kfp->sf_state.ss_fpstate);
#endif
@@ -650,7 +650,7 @@ sendsig(catcher, sig, mask, code)
frame->f_regs[SP] = (int) fp;
#ifdef DEBUG
if (sigdebug & SDB_FOLLOW)
- printf("sendsig(%d): sig %d scp %x fp %x sc_sp %x sc_ap %x\n",
+ printf("sendsig(%d): sig %d scp %p fp %p sc_sp %x sc_ap %x\n",
p->p_pid, sig, kfp->sf_scp, fp,
kfp->sf_sc.sc_sp, kfp->sf_sc.sc_ap);
#endif
@@ -695,7 +695,7 @@ sys_sigreturn(p, v, retval)
scp = SCARG(uap, sigcntxp);
#ifdef DEBUG
if (sigdebug & SDB_FOLLOW)
- printf("sigreturn: pid %d, scp %x\n", p->p_pid, scp);
+ printf("sigreturn: pid %d, scp %p\n", p->p_pid, scp);
#endif
if ((int) scp & 1)
return (EINVAL);
@@ -748,7 +748,7 @@ sys_sigreturn(p, v, retval)
return (EJUSTRETURN);
#ifdef DEBUG
if ((sigdebug & SDB_KSTACK) && p->p_pid == sigpid)
- printf("sigreturn(%d): ssp %x usp %x scp %x ft %d\n",
+ printf("sigreturn(%d): ssp %p usp %x scp %p ft %d\n",
p->p_pid, &flags, scp->sc_sp, SCARG(uap, sigcntxp),
(flags & SS_RTEFRAME) ? tstate.ss_frame.f_format : -1);
#endif
@@ -788,7 +788,7 @@ sys_sigreturn(p, v, retval)
m68881_restore(&tstate.ss_fpstate);
#ifdef DEBUG
if ((sigdebug & SDB_FPSTATE) && *(char *) &tstate.ss_fpstate)
- printf("sigreturn(%d): copied in FP state (%x) at %x\n",
+ printf("sigreturn(%d): copied in FP state (%x) at %p\n",
p->p_pid, *(u_int *) & tstate.ss_fpstate,
&tstate.ss_fpstate);
if ((sigdebug & SDB_FOLLOW) ||
@@ -1124,6 +1124,9 @@ straytrap(pc, evec)
{
printf("unexpected trap; vector offset 0x%x from 0x%x.\n",
(int) (evec & 0xfff), pc);
+#ifdef DDB
+ Debugger();
+#endif
}
int *nofault;
@@ -1515,21 +1518,66 @@ getenv(str)
/*
* ROM Vector information for calling drivers in ROMs
*
- * Egret, ADBReInit_JTBL and ROMResourceMap were added to these
- * tables. Egret probably isn't used anyplace anymore, but I was
- * inspired by the default value that was used in "macrom.c". That
- * value was most likely non-functional for all but a few systems,
- * so putting it here will hopefully localize system-specific ROM
- * addresses. Likewise ADBReInit_JTBL and ROMResourceMap are
- * currently used on only a few systems, but changes in the Booter
- * and changes in ROM Mapping were causing problems. Hopefully
- * those problems will be eliminated by having the proper addresses
- * for those machines in this table.
+ * According to information published on the Web by Apple, there have
+ * been 9 different ROM families used in the Mac since the introduction
+ * of the Lisa/XL through the latest PowerMacs (May 96). Each family
+ * has zero or more version variants and in some cases a version variant
+ * may exist in one than one length format. Generally any one specific
+ * Mac will use a common set of routines within the ROM and a model-specific
+ * set also in the ROM. Luckily most of the routines used by NetBSD fall
+ * into the common set and can therefore be defined in the ROM Family.
+ * The offset addresses (address minus the ROM Base) of these common routines
+ * is the same for all machines which use that ROM. The offset addresses of
+ * the machine-specific routines is generally different for each machine.
+ * The machine-specific routines currently used by NetBSD/mac68k include:
+ * ADB_interrupt, PM_interrpt, ADBBase+130_interrupt,
+ * PMgrOp, jClkNoMem, Egret, InitEgret, and ADBReInit_JTBL
+ *
+ * It is possible that the routine at "jClkNoMem" is a common routine, but
+ * some variation in addresses has been seen. Also, execept for the very
+ * earliest machines which used Egret, the machine-specific value of the
+ * Egret routine may be unimportant as the machine-specific InitEgret code
+ * seems to always set the OS Trap vector for Egret.
+ *
+ * Only three of the nine different ROMs are important to NetBSD/mac68k.
+ * All other ROMs are used in early model Macs which are unable to run
+ * NetBSD due to other hardware limitations such as 68000 CPU, no MMU
+ * capability, or used only in PowerMacs. The three that we are interested
+ * in are:
+ *
+ * ROM Family $0178 - used in the II, IIx, IIcx, and SE/30
+ * All machines which use this ROM are now supported by NetBSD.
+ * There are no machine-dependent routines in these ROMs used by
+ * NetBSD/mac68k. This ROM is always 256K in length.
+ *
+ * ROM Family $067c - used in Classic, Color Classic, Color Classic II,
+ * IIci, IIsi, IIvi, IIvx, IIfx, LC, LC II, LC III,
+ * LC III+, LC475, LC520, LC550, LC575, LC580, LC630,
+ * MacTV, P200, P250, P275, P400/405/410/430, P450,
+ * P460/466/467, P475/476, P520, P550/560, P575/577/578,
+ * P580/588, P600, P630/631/635/636/637/638/640, Q605,
+ * Q610, C610, Q630, C650, Q650, Q700, Q800, Q900, Q950,
+ * PB140, PB145/145B, PB150, PB160, PB165, PB165c, PB170,
+ * PB180, PB180c, Duo 210, Duo 230, Duo 250, Duo 270c,
+ * Duo280, Duo 280c, PB 520/520c/540/540c/550
+ * This is the so-called "Universal" ROM used in almost all 68K
+ * machines. There are machine-dependent and machine-independent
+ * routines used by NetBSD/mac68k in this ROM, and except for the
+ * PowerBooks and the Duos, this ROM seems to be fairly well
+ * known by NetBSD/mac68k. Desktop machines listed here that are
+ * not yet running NetBSD probably only lack the necessary
+ * addresses for the machine-dependent routines, or are waiting
+ * for IDE disk support. This ROM is generally 1Meg in length,
+ * however when used in the IIci, IIfx, IIsi, LC, Classic II, and
+ * P400/405/410/430 it is 512K in length, and when used in the
+ * PB 520/520c/540/540c/550 it is 2Meg in length.
+ *
+ * ROM Family - $077d - used in C660AV/Q660AV, Q840AV
+ * The "Universal" ROM used on the PowerMacs and used in the
+ * 68K line for the AV Macs only. When used in the 68K AV
+ * machines the ROM is 2Meg in length; all uses in the PowerMac
+ * use a length of 4Meg.
*
- * What we probably need is a little MacOS Utility that can suck all
- * these addresses from the System, tell the user if his/er system
- * is currently supported via the romvec tables, and provide a
- * formatted output file for inclusion here if it isn't.
* Bob Nestor - <rnestor@metronet.com>
*/
static romvec_t romvecs[] =
@@ -1587,7 +1635,7 @@ static romvec_t romvecs[] =
(caddr_t) 0x40814800, /* Egret */
(caddr_t) 0x408147c4, /* InitEgret */
(caddr_t) 0x0, /* ADBReInit_JTBL */
- (caddr_t) 0x0, /* ROMResourceMap List Head */
+ (caddr_t) 0x4087eb90, /* ROMResourceMap List Head */
(caddr_t) 0x4081c406, /* FixDiv */
(caddr_t) 0x4081c312, /* FixMul */
},
@@ -1606,19 +1654,19 @@ static romvec_t romvecs[] =
(caddr_t) 0x4080a752, /* ADBReInit */
(caddr_t) 0x4080a3dc, /* ADBOp */
(caddr_t) 0x0, /* PMgrOp */
- (caddr_t) 0x40a0c05c, /* WriteParam */
- (caddr_t) 0x40a0c086, /* SetDateTime */
- (caddr_t) 0x40a0c5cc, /* InitUtil */
- (caddr_t) 0x40a0b186, /* ReadXPRam */
- (caddr_t) 0x40a0b190, /* WriteXPRam */
- (caddr_t) 0x40ab39b6, /* jClkNoMem */
- (caddr_t) 0x40a0a818, /* ADBAlternateInit */
- (caddr_t) 0x40a14800, /* Egret */
- (caddr_t) 0x40a147c4, /* InitEgret */
+ (caddr_t) 0x4080c05c, /* WriteParam */
+ (caddr_t) 0x4080c086, /* SetDateTime */
+ (caddr_t) 0x4080c5cc, /* InitUtil */
+ (caddr_t) 0x4080b186, /* ReadXPRam */
+ (caddr_t) 0x4080b190, /* WriteXPRam */
+ (caddr_t) 0x4080b1e4, /* jClkNoMem */
+ (caddr_t) 0x4080a818, /* ADBAlternateInit */
+ (caddr_t) 0x40814800, /* Egret */
+ (caddr_t) 0x408147c4, /* InitEgret */
(caddr_t) 0x0, /* ADBReInit_JTBL */
- (caddr_t) 0x0, /* ROMResourceMap List Head */
- (caddr_t) 0x40a1c406, /* FixDiv */
- (caddr_t) 0x40a1c312, /* FixMul */
+ (caddr_t) 0x4087eb90, /* ROMResourceMap List Head */
+ (caddr_t) 0x4081c406, /* FixDiv */
+ (caddr_t) 0x4081c312, /* FixMul */
},
/*
* Vectors verified for Mac Classic II and LC II
@@ -1635,15 +1683,20 @@ static romvec_t romvecs[] =
(caddr_t) 0x40a0a3ac, /* SetADBInfo */
(caddr_t) 0x40a0a752, /* ADBReInit */
(caddr_t) 0x40a0a3dc, /* ADBOp */
- (caddr_t) 0, /* PMgrOp */
- (caddr_t) 0x4080c05c, /* WriteParam */
- (caddr_t) 0x4080c086, /* SetDateTime */
- (caddr_t) 0x4080c5cc, /* InitUtil */
- (caddr_t) 0x4080b186, /* ReadXPRam */
- (caddr_t) 0x4080b190, /* WriteXPRam */
- (caddr_t) 0x408b39b6, /* jClkNoMem */
- (caddr_t) 0x4080a818, /* ADBAlternateInit */
- (caddr_t) 0x408147c4, /* InitEgret */
+ (caddr_t) 0x0, /* PMgrOp */
+ (caddr_t) 0x40a0c05c, /* WriteParam */
+ (caddr_t) 0x40a0c086, /* SetDateTime */
+ (caddr_t) 0x40a0c5cc, /* InitUtil */
+ (caddr_t) 0x40a0b186, /* ReadXPRam */
+ (caddr_t) 0x40a0b190, /* WriteXPRam */
+ (caddr_t) 0x40a0b1e4, /* jClkNoMem */
+ (caddr_t) 0x40a0a818, /* ADBAlternateInit */
+ (caddr_t) 0x40a14800, /* Egret */
+ (caddr_t) 0x40a147c4, /* InitEgret */
+ (caddr_t) 0x40a03ba6, /* ADBReInit_JTBL */
+ (caddr_t) 0x40a7eb90, /* ROMResourceMap List Head */
+ (caddr_t) 0x40a1c406, /* FixDiv, wild guess */
+ (caddr_t) 0x40a1c312, /* FixMul, wild guess */
},
/*
* Vectors verified for IIci, Q700
@@ -1670,13 +1723,13 @@ static romvec_t romvecs[] =
(caddr_t) 0x0, /* Egret */
(caddr_t) 0x408147c4, /* InitEgret */
(caddr_t) 0x0, /* ADBReInit_JTBL */
- (caddr_t) 0x0, /* ROMResourceMap List Head */
+ (caddr_t) 0x4087eb90, /* ROMResourceMap List Head */
(caddr_t) 0x4081c406, /* FixDiv */
(caddr_t) 0x4081c312, /* FixMul */
},
/*
- * Vectors verified for Duo 230, PB 180, PB 165
- * (Duo 210? PB 165? PB 160? Duo 250? Duo 270?)
+ * Vectors verified for Duo 230, PB 180, PB 160, PB 165/165C
+ * (Duo 210? Duo 250? Duo 270?)
*/
{ /* 5 */
"2nd Powerbook class ROMs",
@@ -1705,7 +1758,8 @@ static romvec_t romvecs[] =
(caddr_t) 0x4081c312, /* FixMul, wild guess */
},
/*
- * Quadra, Centris merged table (C650, 610, Q800?)
+ * Vectors verified for the Quadra, Centris 650
+ * (610, Q800?)
*/
{ /* 6 */
"Quadra/Centris ROMs",
@@ -1728,14 +1782,14 @@ static romvec_t romvecs[] =
(caddr_t) 0x4080a818, /* ADBAlternateInit */
(caddr_t) 0x40814800, /* Egret */
(caddr_t) 0x408147c4, /* InitEgret */
- (caddr_t) 0x0, /* ADBReInit_JTBL */
- (caddr_t) 0x0, /* ROMResourceMap List Head */
+ (caddr_t) 0x408d2b64, /* ADBReInit_JTBL */
+ (caddr_t) 0x4087eb90, /* ROMResourceMap List Head */
(caddr_t) 0x4081c406, /* FixDiv, wild guess */
(caddr_t) 0x4081c312, /* FixMul, wild guess */
},
/*
- * Quadra 840AV (but ADBBase + 130 intr is unknown)
- * (PM intr is known to be 0, PMgrOp is guessed to be 0)
+ * Vectors verified for the Quadra 660AV
+ * (Quadra 840AV?)
*/
{ /* 7 */
"Quadra AV ROMs",
@@ -1794,13 +1848,13 @@ static romvec_t romvecs[] =
(caddr_t) 0x4001c312, /* FixMul, wild guess */
},
/*
- * Q 605 (but guessing at ADBBase + 130, based on Q 650)
+ * Verified for the Q605
*/
{ /* 9 */
"Quadra/Centris 605 ROMs",
(caddr_t) 0x408a9b56, /* ADB int */
(caddr_t) 0x0, /* PM int */
- (caddr_t) 0x408a99de, /* ADBBase + 130 */
+ (caddr_t) 0x408b2f94, /* ADBBase + 130 */
(caddr_t) 0x4080a360, /* CountADBs */
(caddr_t) 0x4080a37a, /* GetIndADB */
(caddr_t) 0x4080a3a6, /* GetADBInfo */
@@ -1813,14 +1867,14 @@ static romvec_t romvecs[] =
(caddr_t) 0x4080c5cc, /* InitUtil */
(caddr_t) 0x4080b186, /* ReadXPRam */
(caddr_t) 0x4080b190, /* WriteXPRam */
- (caddr_t) 0x0, /* jClkNoMem */
+ (caddr_t) 0x408b3bf8, /* jClkNoMem */
(caddr_t) 0x4080a818, /* ADBAlternateInit */
- (caddr_t) 0x40814800, /* Egret */
+ (caddr_t) 0x408a99c0, /* Egret */
(caddr_t) 0x408147c4, /* InitEgret */
- (caddr_t) 0x0, /* ADBReInit_JTBL */
- (caddr_t) 0x0, /* ROMResourceMap List Head */
- (caddr_t) 0x4081c406, /* FixDiv, wild guess */
- (caddr_t) 0x4081c312, /* FixMul, wild guess */
+ (caddr_t) 0x408a82c0, /* ADBReInit_JTBL */
+ (caddr_t) 0x4087eb90, /* ROMResourceMap List Head */
+ (caddr_t) 0x4081c406, /* FixDiv */
+ (caddr_t) 0x4081c312, /* FixMul */
},
/*
* Vectors verified for Duo 270c, PB150
@@ -1847,7 +1901,7 @@ static romvec_t romvecs[] =
(caddr_t) 0x40814800, /* Egret */
(caddr_t) 0x408147c4, /* InitEgret */
(caddr_t) 0x0, /* ADBReInit_JTBL */
- (caddr_t) 0x0, /* ROMResourceMap List Head */
+ (caddr_t) 0x4087eb90, /* ROMResourceMap List Head */
(caddr_t) 0x4081c406, /* FixDiv, wild guess */
(caddr_t) 0x4081c312, /* FixMul, wild guess */
},
@@ -1881,7 +1935,7 @@ static romvec_t romvecs[] =
(caddr_t) 0x4081c312, /* FixMul for P550 */
},
/*
- * Vectors for the MacTV
+ * Vectors verified for the MacTV
*/
{ /* 12 */
"MacTV ROMs",
@@ -1909,9 +1963,8 @@ static romvec_t romvecs[] =
(caddr_t) 0x40a1c406, /* FixDiv */
(caddr_t) 0x40a1c312, /* FixMul */
},
-
/*
- * Vectors verified for Quadra 630
+ * Vectors verified for the Quadra630
*/
{ /* 13 */
"Quadra630 ROMs",
@@ -1928,6 +1981,7 @@ static romvec_t romvecs[] =
(caddr_t) 0x4080c05c, /* WriteParam */
(caddr_t) 0x4080c086, /* SetDateTime */
(caddr_t) 0x4080c5cc, /* InitUtil */
+ (caddr_t) 0x4080b186, /* Wild guess at ReadXPRam */
(caddr_t) 0x4080b190, /* Wild guess at WriteXPRam */
(caddr_t) 0x408b39f4, /* jClkNoMem */
(caddr_t) 0x4080a818, /* ADBAlternateInit */
@@ -1940,7 +1994,6 @@ static romvec_t romvecs[] =
},
/*
* Vectors verified for LC III
- * (Universal ROM version 0x067c)
*/
{ /* 14 */
"LC III ROMs",
@@ -1968,6 +2021,93 @@ static romvec_t romvecs[] =
(caddr_t) 0x4081c406, /* FixDiv */
(caddr_t) 0x4081c312, /* FixMul */
},
+ /*
+ * Vectors verified for the LC520
+ */
+ { /* 15 */
+ "MacLC520 ROMs",
+ (caddr_t) 0x408d16d6, /* ADB interrupt */
+ (caddr_t) 0x0, /* PB ADB interrupt */
+ (caddr_t) 0x408b2f84, /* ADBBase + 130 interrupt; whatzit? */
+ (caddr_t) 0x4080a360, /* CountADBs */
+ (caddr_t) 0x4080a37a, /* GetIndADB */
+ (caddr_t) 0x4080a3a6, /* GetADBInfo */
+ (caddr_t) 0x4080a3ac, /* SetADBInfo */
+ (caddr_t) 0x4080a752, /* ADBReInit */
+ (caddr_t) 0x4080a3dc, /* ADBOp */
+ (caddr_t) 0x0, /* PMgrOp */
+ (caddr_t) 0x4080c05c, /* WriteParam */
+ (caddr_t) 0x4080c086, /* SetDateTime */
+ (caddr_t) 0x4080c5cc, /* InitUtil */
+ (caddr_t) 0x4080b186, /* ReadXPRam */
+ (caddr_t) 0x4080b190, /* WriteXPRam */
+ (caddr_t) 0x408b3c04, /* jClkNoMem */
+ (caddr_t) 0x4080a818, /* ADBAlternateInit */
+ (caddr_t) 0x408d1450, /* Egret */
+ (caddr_t) 0x408147c4, /* InitEgret */
+ (caddr_t) 0x408d2460, /* ADBReInit_JTBL */
+ (caddr_t) 0x4087eb90, /* ROMResourceMap List Head */
+ (caddr_t) 0x4081c406, /* FixDiv for P520 */
+ (caddr_t) 0x4081c312, /* FixMul for P520 */
+ },
+ /*
+ * Vectors verified for the LC 575/577/578
+ */
+ { /* 16 */
+ "MacLC575 ROMs",
+ (caddr_t) 0x408a9b56, /* ADB interrupt */
+ (caddr_t) 0x0, /* PB ADB interrupt */
+ (caddr_t) 0x408b2f94, /* ADBBase + 130 interrupt; whatzit? */
+ (caddr_t) 0x4080a360, /* CountADBs */
+ (caddr_t) 0x4080a37a, /* GetIndADB */
+ (caddr_t) 0x4080a3a6, /* GetADBInfo */
+ (caddr_t) 0x4080a3ac, /* SetADBInfo */
+ (caddr_t) 0x4080a752, /* ADBReInit */
+ (caddr_t) 0x4080a3dc, /* ADBOp */
+ (caddr_t) 0x0, /* PMgrOp */
+ (caddr_t) 0x4080c05c, /* WriteParam */
+ (caddr_t) 0x4080c086, /* SetDateTime */
+ (caddr_t) 0x4080c5cc, /* InitUtil */
+ (caddr_t) 0x4080b186, /* ReadXPRam */
+ (caddr_t) 0x4080b190, /* WriteXPRam */
+ (caddr_t) 0x408b3bf8, /* jClkNoMem */
+ (caddr_t) 0x4080a818, /* ADBAlternateInit */
+ (caddr_t) 0x408a99c0, /* Egret */
+ (caddr_t) 0x408147c4, /* InitEgret */
+ (caddr_t) 0x408a81a0, /* ADBReInit_JTBL */
+ (caddr_t) 0x4087eb90, /* ROMResourceMap List Head */
+ (caddr_t) 0x4081c406, /* FixDiv for P520 */
+ (caddr_t) 0x4081c312, /* FixMul for P520 */
+ },
+ /*
+ * Vectors verified for the Quadra 950
+ */
+ { /* 17 */
+ "Quadra950 class ROMs",
+ (caddr_t) 0x40814912, /* ADB interrupt */
+ (caddr_t) 0x0, /* PM ADB interrupt */
+ (caddr_t) 0x4080a4d8, /* ADBBase + 130 interrupt; whatzit? */
+ (caddr_t) 0x4080a360, /* CountADBs */
+ (caddr_t) 0x4080a37a, /* GetIndADB */
+ (caddr_t) 0x4080a3a6, /* GetADBInfo */
+ (caddr_t) 0x4080a3ac, /* SetADBInfo */
+ (caddr_t) 0x4080a752, /* ADBReInit */
+ (caddr_t) 0x4080a3dc, /* ADBOp */
+ (caddr_t) 0x0, /* PMgrOp */
+ (caddr_t) 0x4080c05c, /* WriteParam */
+ (caddr_t) 0x4080c086, /* SetDateTime */
+ (caddr_t) 0x4080c5cc, /* InitUtil */
+ (caddr_t) 0x4080b186, /* ReadXPRam */
+ (caddr_t) 0x4080b190, /* WriteXPRam */
+ (caddr_t) 0x4080b1e4, /* jClkNoMem */
+ (caddr_t) 0x4080a818, /* ADBAlternateInit */
+ (caddr_t) 0x40814800, /* Egret */
+ (caddr_t) 0x408147c4, /* InitEgret */
+ (caddr_t) 0x408038bc, /* ADBReInit_JTBL */
+ (caddr_t) 0x4087eb90, /* ROMResourceMap List Head */
+ (caddr_t) 0x4081c406, /* FixDiv */
+ (caddr_t) 0x4081c312, /* FixMul */
+ },
/* Please fill these in! -BG */
};
@@ -1990,11 +2130,11 @@ struct cpu_model_info cpu_models[] = {
/* The Centris/Quadra series. */
{MACH_MACQ700, "Quadra", " 700 ", MACH_CLASSQ, &romvecs[4]},
{MACH_MACQ900, "Quadra", " 900 ", MACH_CLASSQ, &romvecs[6]},
- {MACH_MACQ950, "Quadra", " 950 ", MACH_CLASSQ, &romvecs[2]},
+ {MACH_MACQ950, "Quadra", " 950 ", MACH_CLASSQ, &romvecs[17]},
{MACH_MACQ800, "Quadra", " 800 ", MACH_CLASSQ, &romvecs[6]},
{MACH_MACQ650, "Quadra", " 650 ", MACH_CLASSQ, &romvecs[6]},
{MACH_MACC650, "Centris", " 650 ", MACH_CLASSQ, &romvecs[6]},
- {MACH_MACQ605, "Quadra", " 605", MACH_CLASSQ, &romvecs[9]},
+ {MACH_MACQ605, "Quadra", " 605 ", MACH_CLASSQ, &romvecs[9]},
{MACH_MACC610, "Centris", " 610 ", MACH_CLASSQ, &romvecs[6]},
{MACH_MACQ610, "Quadra", " 610 ", MACH_CLASSQ, &romvecs[6]},
{MACH_MACQ630, "Quadra", " 630 ", MACH_CLASSQ, &romvecs[13]},
@@ -2019,7 +2159,7 @@ struct cpu_model_info cpu_models[] = {
{MACH_MACPB210, "PowerBook Duo", " 210 ", MACH_CLASSDUO, &romvecs[5]},
{MACH_MACPB230, "PowerBook Duo", " 230 ", MACH_CLASSDUO, &romvecs[5]},
{MACH_MACPB250, "PowerBook Duo", " 250 ", MACH_CLASSDUO, &romvecs[5]},
- {MACH_MACPB270, "PowerBook Duo", " 270 ", MACH_CLASSDUO, &romvecs[5]},
+ {MACH_MACPB270, "PowerBook Duo", " 270C ", MACH_CLASSDUO, &romvecs[5]},
{MACH_MACPB280, "PowerBook Duo", " 280 ", MACH_CLASSDUO, &romvecs[5]},
{MACH_MACPB280C, "PowerBook Duo", " 280C ", MACH_CLASSDUO, &romvecs[5]},
@@ -2033,9 +2173,10 @@ struct cpu_model_info cpu_models[] = {
{MACH_MACLCII, "LC", " II ", MACH_CLASSLC, &romvecs[3]},
{MACH_MACLCIII, "LC", " III ", MACH_CLASSLC, &romvecs[14]},
{MACH_MACLC475, "LC", " 475 ", MACH_CLASSQ, &romvecs[9]},
- {MACH_MACLC520, "LC", " 520 ", MACH_CLASSLC, &romvecs[3]},
- {MACH_MACLC575, "LC", " 575 ", MACH_CLASSLC, &romvecs[3]},
+ {MACH_MACLC520, "LC", " 520 ", MACH_CLASSLC, &romvecs[15]},
+ {MACH_MACLC575, "LC", " 575 ", MACH_CLASSQ2, &romvecs[16]},
{MACH_MACCCLASSIC, "Color Classic ", "", MACH_CLASSLC, &romvecs[3]},
+ {MACH_MACCCLASSICII, "Color Classic"," II ", MACH_CLASSLC, &romvecs[3]},
/* Does this belong here? */
{MACH_MACCLASSICII, "Classic", " II ", MACH_CLASSLC, &romvecs[3]},
@@ -2292,6 +2433,7 @@ setmachdep()
via_reg(VIA2, rIER) = 0x7f; /* disable VIA2 int */
break;
case MACH_CLASSQ:
+ case MACH_CLASSQ2:
case MACH_CLASSAV:
VIA2 = 1;
IOBase = 0x50f00000;
@@ -2375,11 +2517,27 @@ mac68k_set_io_offsets(base)
Via1Base = (volatile u_char *) base;
sccA = (volatile u_char *) base + 0xc000;
ASCBase = (volatile u_char *) base + 0x14000;
- SCSIBase = base;
+ SCSIBase = base + 0xf000;
+ break;
+ case MACH_CLASSQ2:
+ /*
+ * Note the different offset for sccA for this class of
+ * machines. This seems to be common on many of the
+ * Quadra-type machines.
+ */
+ Via1Base = (volatile u_char *) base;
+ sccA = (volatile u_char *) base + 0xc020;
+ ASCBase = (volatile u_char *) base + 0x14000;
+ SCSIBase = base + 0xf000;
+ break;
+ case MACH_CLASSAV:
+ Via1Base = (volatile u_char *) base;
+ sccA = (volatile u_char *) base + 0x4000;
+ ASCBase = NULL;
+ SCSIBase = base + 0x18000;
break;
case MACH_CLASSII:
case MACH_CLASSPB:
- case MACH_CLASSAV:
case MACH_CLASSIIci:
case MACH_CLASSIIsi:
case MACH_CLASSIIvx:
@@ -2438,6 +2596,7 @@ gray_bar()
#endif
/* in locore */
+extern int ptest040 __P((u_int addr));
extern int get_pte __P((u_int addr, u_long pte[2], u_short * psr));
/*
@@ -2454,46 +2613,46 @@ get_physical(u_int addr, u_long * phys)
int i, numbits;
extern u_int macos_tc;
- /* This can not work for the 040, yet */
- if (mmutype == MMU_68040)
- return 0;
-
- if (mmutype == MMU_68040)
- return 0;
-
- i = get_pte(addr, pte, &psr);
-
- switch (i) {
- case -1:
- return 0;
- case 0:
- ph = pte[0] & 0xFFFFFF00;
- break;
- case 1:
- ph = pte[1] & 0xFFFFFF00;
- break;
- default:
- panic("get_physical(): bad get_pte()");
- }
+ if (mmutype == MMU_68040) {
+ ph = ptest040(addr);
+ if (!(ph & MMU40_RES))
+ return 0;
- /*
- * We must now figure out how many levels down we went and
- * mask the bits appropriately -- the returned value may only
- * be the upper n bits, and we've got to take the rest from addr.
- */
+ *phys = ph;
+ mask = 0x00000fff;
+ } else {
+ i = get_pte(addr, pte, &psr);
- numbits = 0;
- psr &= 0x0007; /* Number of levels we went */
- for (i = 0; i < psr; i++)
- numbits += (macos_tc >> (12 - i * 4)) & 0x0f;
+ switch (i) {
+ case -1:
+ return 0;
+ case 0:
+ ph = pte[0] & 0xFFFFFF00;
+ break;
+ case 1:
+ ph = pte[1] & 0xFFFFFF00;
+ break;
+ default:
+ panic("get_physical(): bad get_pte()");
+ }
- /*
- * We have to take the most significant "numbits" from
- * the returned value "ph", and the rest from our addr.
- * Assume that numbits != 0.
- */
+ /*
+ * We must now figure out how many levels down we went and
+ * mask the bits appropriately -- the returned value may only
+ * be the upper n bits, and we have to take the rest from addr.
+ */
+ numbits = 0;
+ psr &= 0x0007; /* Number of levels we went */
+ for (i = 0; i < psr; i++)
+ numbits += (macos_tc >> (12 - i * 4)) & 0x0f;
- mask = (1 << (32 - numbits)) - 1;
+ /*
+ * We have to take the most significant "numbits" from
+ * the returned value "ph", and the rest from our addr.
+ * Assume that numbits != 0.
+ */
+ mask = (1 << (32 - numbits)) - 1;
+ }
*phys = (ph & ~mask) | (addr & mask);
return 1;
diff --git a/sys/arch/mac68k/mac68k/trap.c b/sys/arch/mac68k/mac68k/trap.c
index fc51008ff74..7585e221717 100644
--- a/sys/arch/mac68k/mac68k/trap.c
+++ b/sys/arch/mac68k/mac68k/trap.c
@@ -1,5 +1,5 @@
-/* $OpenBSD: trap.c,v 1.4 1996/05/26 18:36:35 briggs Exp $ */
-/* $NetBSD: trap.c,v 1.37 1996/05/05 06:54:23 briggs Exp $ */
+/* $OpenBSD: trap.c,v 1.5 1996/10/23 04:49:49 briggs Exp $ */
+/* $NetBSD: trap.c,v 1.41 1996/10/17 06:42:44 scottr Exp $ */
/*
* Copyright (c) 1988 University of Utah.
@@ -126,7 +126,7 @@ int mmupid = -1;
#define MDB_FOLLOW 1
#define MDB_WBFOLLOW 2
#define MDB_WBFAILED 4
-#define MDB_ISPID(p) (p) == mmupid
+#define MDB_ISPID(pid) ((pid) == mmupid)
#endif
/* trap() and syscall() only called from locore */
@@ -256,6 +256,14 @@ trap(type, code, v, frame)
p->p_md.md_regs = frame.f_regs;
}
+ /* I have verified that this DOES happen! -gwr */
+ if (p == NULL)
+ p = &proc0;
+#ifdef DIAGNOSTIC
+ if (p->p_addr == NULL)
+ panic("trap: no pcb");
+#endif
+
switch (type) {
default:
dopanic:
@@ -515,7 +523,7 @@ copyfault:
(!p->p_addr->u_pcb.pcb_onfault || KDFAULT(code)))
map = kernel_map;
else
- map = &vm->vm_map;
+ map = vm ? &vm->vm_map : kernel_map;
if (WRFAULT(code))
ftype = VM_PROT_READ | VM_PROT_WRITE;
else
@@ -540,7 +548,8 @@ copyfault:
* the current limit and we need to reflect that as an access
* error.
*/
- if ((caddr_t)va >= vm->vm_maxsaddr && map != kernel_map) {
+ if ((vm != NULL && (caddr_t)va >= vm->vm_maxsaddr)
+ && map != kernel_map) {
if (rv == KERN_SUCCESS) {
unsigned nss;