summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKenji Aoyama <aoyama@cvs.openbsd.org>2012-01-08 01:26:38 +0000
committerKenji Aoyama <aoyama@cvs.openbsd.org>2012-01-08 01:26:38 +0000
commit86f176c96d5dafb2e0858a6a2cd283b4bc336f69 (patch)
tree2b5c1a33e3696b87bf6e17b4f89622c5a0e1ece2
parent22808d2c653fcedb4305e4bb7429ec4a70e35503 (diff)
Preliminary multi-processor support for luna88k. It is
work-in-progress and is not stable yet... "Please commit" miod@
-rw-r--r--sys/arch/luna88k/luna88k/locore.S12
-rw-r--r--sys/arch/luna88k/luna88k/machdep.c74
2 files changed, 66 insertions, 20 deletions
diff --git a/sys/arch/luna88k/luna88k/locore.S b/sys/arch/luna88k/luna88k/locore.S
index 43209809346..b123b36c012 100644
--- a/sys/arch/luna88k/luna88k/locore.S
+++ b/sys/arch/luna88k/luna88k/locore.S
@@ -1,4 +1,4 @@
-/* $OpenBSD: locore.S,v 1.22 2011/11/19 20:40:10 miod Exp $ */
+/* $OpenBSD: locore.S,v 1.23 2012/01/08 01:26:37 aoyama Exp $ */
/*
* Copyright (c) 1998 Steve Murphree, Jr.
* Copyright (c) 1996 Nivas Madhur
@@ -276,6 +276,16 @@ ASLOCAL(secondary_init)
#endif /* MULTIPROCESSOR */
+#ifdef MULTIPROCESSOR
+ /*
+ * Dummy mp_atomic_begin() and mp_atomic_end() routine, so that
+ * we can interact with ddb if things go wrong very early during
+ * bootstrap. Of course this should never happen (-:
+ */
+ASLOCAL(dummy_mplock)
+ jmp r1
+#endif /* MULTIPROCESSOR */
+
/*
* void delay(int count)
*
diff --git a/sys/arch/luna88k/luna88k/machdep.c b/sys/arch/luna88k/luna88k/machdep.c
index fdd98d6ebfc..d70892d0fac 100644
--- a/sys/arch/luna88k/luna88k/machdep.c
+++ b/sys/arch/luna88k/luna88k/machdep.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: machdep.c,v 1.78 2011/06/26 22:39:59 deraadt Exp $ */
+/* $OpenBSD: machdep.c,v 1.79 2012/01/08 01:26:37 aoyama Exp $ */
/*
* Copyright (c) 1998, 1999, 2000, 2001 Steve Murphree, Jr.
* Copyright (c) 1996 Nivas Madhur
@@ -119,7 +119,7 @@ void powerdown(void);
void get_fuse_rom_data(void);
void get_nvram_data(void);
char *nvram_by_symbol(char *);
-void get_autoboot_device(void); /* in disksubr.c */
+void get_autoboot_device(void); /* in autoconf.c */
int clockintr(void *); /* in clock.c */
/*
@@ -283,19 +283,12 @@ size_memory()
* count it up.
*/
max = (void *)MAXPHYSMEM;
-#if 0
- for (look = (void *)Roundup(end, STRIDE); look < max;
-#else
for (look = (void *)first_addr; look < max;
-#endif
look = (int *)((unsigned)look + STRIDE)) {
unsigned save;
/* if can't access, we've reached the end */
if (badaddr((vaddr_t)look, 4)) {
-#if defined(DEBUG)
- printf("%x\n", look);
-#endif
look = (int *)((int)look - STRIDE);
break;
}
@@ -694,12 +687,27 @@ vaddr_t
secondary_pre_main()
{
struct cpu_info *ci;
+ vaddr_t init_stack;
+
+ /*
+ * Invoke the CMMU initialization routine as early as possible,
+ * so that we do not risk any memory writes to be lost during
+ * cache setup.
+ */
+ cmmu_initialize_cpu(cmmu_cpu_number());
+ /*
+ * Now initialize your cpu_info structure.
+ */
set_cpu_number(cmmu_cpu_number());
ci = curcpu();
+ ci->ci_curproc = &proc0;
+ m88100_smp_setup(ci);
+
+ splhigh();
/*
- * Setup CMMUs and translation tables (shared with the master cpu).
+ * Enable MMU on this processor.
*/
pmap_bootstrap_cpu(ci->ci_cpuid);
@@ -710,6 +718,7 @@ secondary_pre_main()
if (init_stack == (vaddr_t)NULL) {
printf("cpu%d: unable to allocate startup stack\n",
ci->ci_cpuid);
+ __cpu_simple_unlock(&cpu_mutex);
for (;;) ;
}
@@ -729,17 +738,21 @@ secondary_main()
int s;
cpu_configuration_print(0);
- sched_init_cpu(ci);
ncpus++;
- __cpu_simple_unlock(&cpu_mutex);
+ sched_init_cpu(ci);
microuptime(&ci->ci_schedstate.spc_runtime);
ci->ci_curproc = NULL;
+ ci->ci_randseed = random();
- set_psr(get_psr() & ~PSR_IND);
- spl0();
+ __cpu_simple_unlock(&cpu_mutex);
+ spl0();
SCHED_LOCK(s);
+ set_psr(get_psr() & ~PSR_IND);
+
+ SET(ci->ci_flags, CIF_ALIVE);
+
cpu_switchto(NULL, sched_chooseproc());
}
@@ -752,7 +765,7 @@ secondary_main()
void
luna88k_ext_int(struct trapframe *eframe)
{
- int cpu = cpu_number();
+ u_int cpu = cpu_number();
u_int32_t cur_mask, cur_int;
u_int level, old_spl;
@@ -804,7 +817,13 @@ luna88k_ext_int(struct trapframe *eframe)
case 5:
case 4:
case 3:
- isrdispatch_autovec(cur_int);
+#ifdef MULTIPROCESSOR
+ if (cpu == master_cpu) {
+#endif
+ isrdispatch_autovec(cur_int);
+#ifdef MULTIPROCESSOR
+ }
+#endif
break;
default:
printf("luna88k_ext_int(): level %d interrupt.\n", cur_int);
@@ -900,8 +919,6 @@ luna88k_bootstrap()
#ifndef MULTIPROCESSOR
cpuid_t master_cpu;
#endif
- extern void m8820x_initialize_cpu(cpuid_t);
- extern void m8820x_set_sapr(cpuid_t, apr_t);
cmmu = &cmmu8820x;
@@ -921,6 +938,9 @@ luna88k_bootstrap()
setup_board_config();
master_cpu = cmmu_init();
set_cpu_number(master_cpu);
+#ifdef MULTIPROCESSOR
+ m88100_smp_setup(curcpu());
+#endif
SET(curcpu()->ci_flags, CIF_ALIVE | CIF_PRIMARY);
m88100_apply_patches();
@@ -961,8 +981,10 @@ luna88k_bootstrap()
/* Initialize the "u-area" pages. */
bzero((caddr_t)curpcb, USPACE);
+#ifndef MULTIPROCESSOR
/* Release the cpu_mutex */
cpu_boot_secondary_processors();
+#endif
#ifdef DEBUG
printf("leaving luna88k_bootstrap()\n");
@@ -1156,7 +1178,7 @@ void
setlevel(u_int level)
{
u_int32_t set_value;
- int cpu = cpu_number();
+ u_int cpu = cpu_number();
set_value = int_set_val[level];
@@ -1206,3 +1228,17 @@ raiseipl(int level)
set_psr(psr);
return (int)curspl;
}
+
+#ifdef MULTIPROCESSOR
+void
+m88k_send_ipi(int ipi, cpuid_t cpu)
+{
+ /* nothing to do on luna88k!? */
+}
+
+void
+m88k_broadcast_ipi(int ipi)
+{
+ /* nothing to do on luna88k!? */
+}
+#endif