summaryrefslogtreecommitdiff
path: root/sys/arch/sparc64
diff options
context:
space:
mode:
Diffstat (limited to 'sys/arch/sparc64')
-rw-r--r--sys/arch/sparc64/include/cpu.h5
-rw-r--r--sys/arch/sparc64/sparc64/cpu.c85
2 files changed, 2 insertions, 88 deletions
diff --git a/sys/arch/sparc64/include/cpu.h b/sys/arch/sparc64/include/cpu.h
index b29f112e679..9347a7c338e 100644
--- a/sys/arch/sparc64/include/cpu.h
+++ b/sys/arch/sparc64/include/cpu.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: cpu.h,v 1.11 2002/06/07 21:33:43 nordin Exp $ */
+/* $OpenBSD: cpu.h,v 1.12 2002/06/11 10:57:51 art Exp $ */
/* $NetBSD: cpu.h,v 1.28 2001/06/14 22:56:58 thorpej Exp $ */
/*
@@ -253,9 +253,6 @@ extern struct intrhand *intrlev[MAXINTNUM];
void intr_establish(int level, struct intrhand *);
-/* cpu.c */
-paddr_t cpu_alloc(void);
-u_int64_t cpu_init(paddr_t, int);
/* disksubr.c */
struct dkbad;
int isbad(struct dkbad *bt, int, int, int);
diff --git a/sys/arch/sparc64/sparc64/cpu.c b/sys/arch/sparc64/sparc64/cpu.c
index eb558d6535a..4cd0b713792 100644
--- a/sys/arch/sparc64/sparc64/cpu.c
+++ b/sys/arch/sparc64/sparc64/cpu.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: cpu.c,v 1.7 2002/03/14 01:26:45 millert Exp $ */
+/* $OpenBSD: cpu.c,v 1.8 2002/06/11 10:57:51 art Exp $ */
/* $NetBSD: cpu.c,v 1.13 2001/05/26 21:27:15 chs Exp $ */
/*
@@ -123,89 +123,6 @@ static char *iu_vendor[16] = {
};
#endif
-/*
- * Overhead involved in firing up a new CPU:
- *
- * Allocate a cpuinfo/interrupt stack
- * Map that into the kernel
- * Initialize the cpuinfo
- * Return the TLB entry for the cpuinfo.
- */
-u_int64_t
-cpu_init(pa, cpu_num)
- paddr_t pa;
- int cpu_num;
-{
- struct cpu_info *ci;
- u_int64_t pagesize;
- u_int64_t pte;
- struct vm_page *m;
- psize_t size;
- vaddr_t va;
- struct pglist mlist;
- int error;
-
- size = NBPG; /* XXXX 8K, 64K, 512K, or 4MB */
- TAILQ_INIT(&mlist);
- if ((error = uvm_pglistalloc((psize_t)size, (paddr_t)0, (paddr_t)-1,
- (paddr_t)size, (paddr_t)0, &mlist, 1, 0)) != 0)
- panic("cpu_start: no memory, error %d", error);
-
- va = uvm_km_valloc(kernel_map, size);
- if (va == 0)
- panic("cpu_start: no memory");
-
- m = TAILQ_FIRST(&mlist);
- pa = VM_PAGE_TO_PHYS(m);
- pte = TSB_DATA(0 /* global */,
- pagesize,
- pa,
- 1 /* priv */,
- 1 /* Write */,
- 1 /* Cacheable */,
- 1 /* ALIAS -- Disable D$ */,
- 1 /* valid */,
- 0 /* IE */);
-
- /* Map the pages */
- for (; m != NULL; m = TAILQ_NEXT(m,pageq)) {
- pa = VM_PAGE_TO_PHYS(m);
- pmap_zero_page(pa);
- pmap_enter(pmap_kernel(), va, pa | PMAP_NVC,
- VM_PROT_READ|VM_PROT_WRITE,
- VM_PROT_READ|VM_PROT_WRITE|PMAP_WIRED);
- va += NBPG;
- }
- pmap_update(pmap_kernel());
-
- if (!cpus) cpus = (struct cpu_info *)va;
- else {
- for (ci = cpus; ci->ci_next; ci=ci->ci_next);
- ci->ci_next = (struct cpu_info *)va;
- }
-
- switch (size) {
-#define K *1024
- case 8 K:
- pagesize = TLB_8K;
- break;
- case 64 K:
- pagesize = TLB_64K;
- break;
- case 512 K:
- pagesize = TLB_512K;
- break;
- case 4 K K:
- pagesize = TLB_4M;
- break;
- default:
- panic("cpu_start: stack size %x not a machine page size\n",
- (unsigned)size);
- }
- return (pte|TLB_L);
-}
-
-
int
cpu_match(parent, vcf, aux)
struct device *parent;