summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorbriggs <briggs@cvs.openbsd.org>1997-04-05 15:29:14 +0000
committerbriggs <briggs@cvs.openbsd.org>1997-04-05 15:29:14 +0000
commit81640a3269a5061e59e8fbceb20da2e792f992ae (patch)
tree8172de8d914ac29c6a07f84198c7c0e47e022af2
parent152f2c4ce1cabc6180e12ba57ff54d68023d9472 (diff)
MRG-based ADB support for the PowerBook series. Contributed by
hamada@next.etron.kanazawa-it.ac.jp (Takashi Hamada)
-rw-r--r--sys/arch/mac68k/mac68k/machdep.c8
-rw-r--r--sys/arch/mac68k/mac68k/macrom.c155
-rw-r--r--sys/arch/mac68k/mac68k/macrom.h4
-rw-r--r--sys/arch/mac68k/mac68k/macromasm.s3
4 files changed, 155 insertions, 15 deletions
diff --git a/sys/arch/mac68k/mac68k/machdep.c b/sys/arch/mac68k/mac68k/machdep.c
index 25530b37c22..ee99de35e36 100644
--- a/sys/arch/mac68k/mac68k/machdep.c
+++ b/sys/arch/mac68k/mac68k/machdep.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: machdep.c,v 1.34 1997/03/28 12:38:59 briggs Exp $ */
+/* $OpenBSD: machdep.c,v 1.35 1997/04/05 15:29:10 briggs Exp $ */
/* $NetBSD: machdep.c,v 1.134 1997/02/14 06:15:30 scottr Exp $ */
/*
@@ -2153,8 +2153,7 @@ setmachdep()
Via1Base = (volatile u_char *) IOBase;
mac68k_machine.scsi80 = 1;
mac68k_machine.sccClkConst = 115200;
- /* Disable everything but PM; we need it. */
- via_reg(VIA1, vIER) = 0x6f; /* disable VIA1 int */
+ via_reg(VIA1, vIER) = 0x7f; /* disable VIA1 int */
/* Are we disabling something important? */
via_reg(VIA2, vIER) = 0x7f; /* disable VIA2 int */
if (cputype == CPU_68040)
@@ -2171,8 +2170,7 @@ setmachdep()
Via1Base = (volatile u_char *) IOBase;
mac68k_machine.scsi80 = 1;
mac68k_machine.sccClkConst = 115200;
- /* Disable everything but PM; we need it. */
- via_reg(VIA1, vIER) = 0x6f; /* disable VIA1 int */
+ via_reg(VIA1, vIER) = 0x7f; /* disable VIA1 int */
/* Are we disabling something important? */
via_reg(VIA2, rIER) = 0x7f; /* disable VIA2 int */
break;
diff --git a/sys/arch/mac68k/mac68k/macrom.c b/sys/arch/mac68k/mac68k/macrom.c
index 2b8469828f1..e94cd912cdd 100644
--- a/sys/arch/mac68k/mac68k/macrom.c
+++ b/sys/arch/mac68k/mac68k/macrom.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: macrom.c,v 1.11 1997/03/30 21:53:25 briggs Exp $ */
+/* $OpenBSD: macrom.c,v 1.12 1997/04/05 15:29:12 briggs Exp $ */
/* $NetBSD: macrom.c,v 1.31 1997/03/01 17:20:34 scottr Exp $ */
/*-
@@ -111,6 +111,7 @@ caddr_t mrg_rompmintr = 0; /* ROM PM (?) interrupt */
char *mrg_romident = NULL; /* ident string for ROMs */
caddr_t mrg_ADBAlternateInit = 0;
caddr_t mrg_InitEgret = 0;
+caddr_t mrg_InitPM = 0;
caddr_t mrg_ADBIntrPtr = (caddr_t)0x0; /* ADB interrupt taken from MacOS vector table*/
caddr_t ROMResourceMap = 0;
extern romvec_t *mrg_MacOSROMVectors;
@@ -601,6 +602,23 @@ mrg_SetTrapAddress()
return 0;
}
+int
+mrg_GetTrapAddress()
+{
+ extern caddr_t mrg_OStraps[];
+ caddr_t ptr;
+ int trap_num;
+
+ asm(" movl d0, %0"
+ : "=g" (trap_num) : : "d0");
+
+ ptr = mrg_OStraps[trap_num];
+
+ asm(" movl %0, a0"
+ : : "g" (ptr) : "a0");
+ return 0;
+}
+
/*
* trap jump address tables (different per machine?)
* Can I just use the tables stored in the ROMs?
@@ -622,6 +640,7 @@ caddr_t mrg_OStraps[256] = {
(caddr_t)mrg_GetPtrSize,
[0x2f] (caddr_t)mrg_PostEvent,
[0x3b] (caddr_t)mrg_Delay,
+ [0x46] (caddr_t)mrg_GetTrapAddress,
[0x47] (caddr_t)mrg_SetTrapAddress,
[0x55] (caddr_t)mrg_StripAddress,
[0x82] (caddr_t)mrg_DTInstall,
@@ -906,8 +925,12 @@ mrg_init()
#endif
/* expected globals */
ExpandMem = &mrg_ExpandMem[0];
- *((u_int16_t *)(mrg_ExpandMem + 0x00) ) = 0x0123; /* magic (word) */
- *((u_int32_t *)(mrg_ExpandMem + 0x02) ) = 0x000001ea; /* Length of table (long) */
+
+ /* magic (word) */
+ *((u_int16_t *)(mrg_ExpandMem + 0x00) ) = 0x0123;
+ /* Length of table (long) */
+ *((u_int32_t *)(mrg_ExpandMem + 0x02) ) = 0x000001ea;
+
*((u_int32_t *)(mrg_ExpandMem + 0x1e0)) = (u_int32_t) &mrg_adbstore4[0];
*((u_int32_t *)(mrg_adbstore4 + 0x8)) = (u_int32_t) mrg_init_stub_1;
@@ -1031,6 +1054,18 @@ mrg_init()
#endif
pmap_map(0x50f00000, 0x50f00000, 0x50f00000 + 0x4000,
VM_PROT_READ|VM_PROT_WRITE);
+ if ( (current_mac_model->class == MACH_CLASSPB)
+ || (current_mac_model->class == MACH_CLASSDUO)) {
+ /* CPU GLU */
+ pmap_map(0x50080000, 0x50080000, 0x50080000 + 0x10000,
+ VM_PROT_READ|VM_PROT_WRITE);
+ /* Modem slot for PB500 */
+ pmap_map(0xfb000000, 0xfb000000, 0xfb000000 + 0x10000,
+ VM_PROT_READ|VM_PROT_WRITE);
+ /* ??? */
+ pmap_map(0x50f80000, 0x50f80000, 0x50f80000 + 0x40000,
+ VM_PROT_READ|VM_PROT_WRITE);
+ }
}
}
@@ -1049,7 +1084,8 @@ setup_egret(void)
:
: "g" (mrg_InitEgret), "g" (ADBState)
: "a0", "a1");
- jEgret = (void (*)) mrg_OStraps[0x92]; /* may have been set in asm() */
+ /* may have been set in asm() */
+ jEgret = (void (*)) mrg_OStraps[0x92];
}
else printf("Help ... No vector for InitEgret!!\n");
@@ -1062,12 +1098,33 @@ setup_egret(void)
#endif
}
+static void setup_pm __P((void));
+
+static void
+setup_pm(void)
+{
+ if (0 != mrg_InitPM){
+
+ /* This initializes the Power Manager system and
+ enables interrupts */
+ asm("
+ movml #0xffff, sp@-
+ moval %0, a0
+ jbsr a0@
+ movml sp@+, #0xffff"
+ :
+ : "g" (mrg_InitPM)
+ : "a0"
+ );
+ } else printf("Help ... No vector for InitPM!!\n");
+}
+
void
mrg_initadbintr()
{
if (mac68k_machine.do_graybars)
printf("Got following HwCfgFlags: 0x%4x, 0x%8x, 0x%8x, 0x%8x\n",
- HwCfgFlags, HwCfgFlags2, HwCfgFlags3, ADBReInit_JTBL);
+ HwCfgFlags, HwCfgFlags2, HwCfgFlags3, ADBReInit_JTBL);
if ( (HwCfgFlags == 0) && (HwCfgFlags2 == 0) && (HwCfgFlags3 == 0) ){
@@ -1106,9 +1163,18 @@ mrg_initadbintr()
if (mac68k_machine.do_graybars)
printf("mrg: setup_egret: done.\n");
- } else {
+ } else if ( (current_mac_model->class == MACH_CLASSPB)
+ || (current_mac_model->class == MACH_CLASSDUO)) {
+ if (mac68k_machine.do_graybars)
+ printf("mrg: setup_pm:\n");
+
+ setup_pm();
if (mac68k_machine.do_graybars)
+ printf("mrg: setup_pm: done.\n");
+
+ } else {
+ if (mac68k_machine.do_graybars)
printf("mrg: Not setting up egret.\n");
via_reg(VIA1, vIFR) = 0x4;
@@ -1203,9 +1269,82 @@ mrg_fixupROMBase(obase, nbase)
mrg_InitEgret = rom->InitEgret == 0 ?
0 : rom->InitEgret - oldbase + newbase;
+ if ( (current_mac_model->class == MACH_CLASSPB)
+ || (current_mac_model->class == MACH_CLASSDUO)) {
+ switch( mac68k_machine.machineid ) {
+ case MACH_MACPB140:
+ case MACH_MACPB145:
+ case MACH_MACPB170:
+ mrg_InitPM = /* PMgrInit */
+ (caddr_t)0x40888400 - oldbase + newbase;
+ jCacheFlush = (caddr_t)0x40809a7c - oldbase + newbase;
+ mrg_OStraps[0x33] = /* VInstall */
+ (caddr_t)0x4082ea80 - oldbase + newbase;
+ mrg_OStraps[0x55] = /* MemoryDispatch */
+ (caddr_t)0x4082eada - oldbase + newbase;
+ mrg_OStraps[0x5e] = /* NMInstall */
+ (caddr_t)0x4082eafe - oldbase + newbase;
+ mrg_OStraps[0x5f] = /* NMRemove */
+ (caddr_t)0x4082eb08 - oldbase + newbase;
+ mrg_OStraps[0x8d] = /* EnterSuperVisor */
+ (caddr_t)0x4082914a - oldbase + newbase;
+ mrg_OStraps[0x9e] = /* FullProcessorSpeed */
+ (caddr_t)0x40829868 - oldbase + newbase;
+ mrg_OStraps[0x9f] = /* PMgrDispatch */
+ (caddr_t)0x408888d8 - oldbase + newbase;
+ break;
+ case MACH_MACPB160:
+ case MACH_MACPB165:
+ case MACH_MACPB165C:
+ case MACH_MACPB180:
+ case MACH_MACPB180C:
+ case MACH_MACPB210:
+ case MACH_MACPB230:
+ case MACH_MACPB250:
+ case MACH_MACPB270:
+ case MACH_MACPB280:
+ case MACH_MACPB280C:
+ mrg_InitPM = /* PMgrInit */
+ (caddr_t)0x40888400 - oldbase + newbase;
+ jCacheFlush = (caddr_t)0x40809a7c - oldbase + newbase;
+ mrg_OStraps[0x33] = /* VInstall */
+ (caddr_t)0x4080a230 - oldbase + newbase;
+ mrg_OStraps[0x55] = /* MemoryDispatch */
+ (caddr_t)0x40805538 - oldbase + newbase;
+ mrg_OStraps[0x5e] = /* NMInstall */
+ (caddr_t)0x4082eafe - oldbase + newbase;
+ mrg_OStraps[0x5f] = /* NMRemove */
+ (caddr_t)0x4082eb08 - oldbase + newbase;
+ mrg_OStraps[0x8d] = /* EnterSuperVisor */
+ (caddr_t)0x4082914a - oldbase + newbase;
+ mrg_OStraps[0x9e] = /* FullProcessorSpeed */
+ (caddr_t)0x40829868 - oldbase + newbase;
+ mrg_OStraps[0x9f] = /* PMgrDispatch */
+ (caddr_t)0x408888d8 - oldbase + newbase;
+ break;
+ case MACH_MACPB500:
+ mrg_InitPM = /* PMgrInit */
+ (caddr_t)0x400d8800 - oldbase + newbase;
+ jCacheFlush = (caddr_t)0x40085030 - oldbase + newbase;
+ mrg_OStraps[0x33] = /* VInstall */
+ (caddr_t)0x4000a230 - oldbase + newbase;
+ mrg_OStraps[0x5e] = /* NMInstall */
+ (caddr_t)0x4002eafe - oldbase + newbase;
+ mrg_OStraps[0x5f] = /* NMRemove */
+ (caddr_t)0x4002eb08 - oldbase + newbase;
+ mrg_OStraps[0x8d] = /* EnterSuperVisor */
+ (caddr_t)0x4000a0f0 - oldbase + newbase;
+ mrg_OStraps[0x9e] = /* FullProcessorSpeed */
+ (caddr_t)0x400da254 - oldbase + newbase;
+ mrg_OStraps[0x9f] = /* PMgrDispatch */
+ (caddr_t)0x400d8fc0 - oldbase + newbase;
+ break;
+ }
+ }
+
if (rom->jClkNoMem == 0) {
- printf("WARNING: don't have a value for jClkNoMem, please contac
-t: walter@ghpc8.ihf.rwth-aachen.de\n");
+ printf("WARNING: don't have a value for jClkNoMem, please ");
+ printf("contact: walter@ghpc8.ihf.rwth-aachen.de\n");
printf("Can't read RTC without it. Using MacOS boot time.\n");
jClkNoMem = 0;
}
diff --git a/sys/arch/mac68k/mac68k/macrom.h b/sys/arch/mac68k/mac68k/macrom.h
index 79ee820fee9..71314a66754 100644
--- a/sys/arch/mac68k/mac68k/macrom.h
+++ b/sys/arch/mac68k/mac68k/macrom.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: macrom.h,v 1.6 1997/03/30 21:53:26 briggs Exp $ */
+/* $OpenBSD: macrom.h,v 1.7 1997/04/05 15:29:12 briggs Exp $ */
/* $NetBSD: macrom.h,v 1.9 1996/05/25 14:45:35 briggs Exp $ */
/*-
@@ -83,6 +83,7 @@ extern caddr_t jDTInstall; /* short-cut to deferred task mgr */
extern u_int32_t **InitEgretJTVec; /* pointer to a jump table for */
/* InitEgret on AV machines */
+extern caddr_t jCacheFlush; /* pointer to CacheFlush */
/* Types */
@@ -250,6 +251,7 @@ int mrg_DisposPtr __P((void));
int mrg_GetPtrSize __P((void));
int mrg_SetPtrSize __P((void));
int mrg_PostEvent __P((void));
+int mrg_GetTrapAddress __P((void));
int mrg_SetTrapAddress __P((void));
void mrg_StripAddress __P((void));
void mrg_aline_super __P((struct frame *));
diff --git a/sys/arch/mac68k/mac68k/macromasm.s b/sys/arch/mac68k/mac68k/macromasm.s
index 62b04034ad0..76e83a4d08f 100644
--- a/sys/arch/mac68k/mac68k/macromasm.s
+++ b/sys/arch/mac68k/mac68k/macromasm.s
@@ -1,4 +1,4 @@
-/* $OpenBSD: macromasm.s,v 1.6 1997/03/30 21:56:54 briggs Exp $ */
+/* $OpenBSD: macromasm.s,v 1.7 1997/04/05 15:29:13 briggs Exp $ */
/* $NetBSD: macromasm.s,v 1.11 1996/05/25 14:45:37 briggs Exp $ */
/*-
@@ -109,6 +109,7 @@
loglob(InitEgretJTVec, 0x2010) /* pointer to a jump table for */
/* InitEgret on AV machines */
+ loglob(jCacheFlush, 0x6f4) /* setup_pm() needs this */
#if 0
/* I wish I knew what these things were */