summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
Diffstat (limited to 'sys')
-rw-r--r--sys/arch/hppa/hppa/machdep.c597
1 files changed, 413 insertions, 184 deletions
diff --git a/sys/arch/hppa/hppa/machdep.c b/sys/arch/hppa/hppa/machdep.c
index dcab7118d73..a8b74f1e184 100644
--- a/sys/arch/hppa/hppa/machdep.c
+++ b/sys/arch/hppa/hppa/machdep.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: machdep.c,v 1.4 1999/02/17 03:51:43 mickey Exp $ */
+/* $OpenBSD: machdep.c,v 1.5 1999/04/20 20:55:38 mickey Exp $ */
/*
* Copyright (c) 1998 Michael Shalayeff
@@ -115,7 +115,8 @@
#include <vm/vm.h>
#include <vm/vm_kern.h>
-#include <vm/vm_page.h>
+#include <uvm/uvm_page.h>
+#include <uvm/uvm.h>
#include <dev/cons.h>
@@ -125,6 +126,11 @@
#include <machine/reg.h>
#include <machine/cpufunc.h>
#include <machine/autoconf.h>
+#include <machine/kcore.h>
+
+#ifdef COMPAT_HPUX
+#include <compat/hpux/hpux.h>
+#endif
#ifdef DDB
#include <machine/db_machdep.h>
@@ -133,8 +139,8 @@
#include <ddb/db_extern.h>
#endif
-#include <hppa/dev/boards.h>
-#include <hppa/dev/boards_data.h>
+#include <hppa/dev/cpudevs.h>
+#include <hppa/dev/cpudevs_data.h>
/*
* Declare these as initialized data so we can patch them.
@@ -150,16 +156,24 @@ int msgbufmapped; /* set when safe to use msgbuf */
/*
* used in locore.S
*/
-struct pdc_cache pdc_cache PDC_ALIGNMENT;
int icache_stride;
int dcache_stride;
int dcache_line_mask;
int dcache_size;
double fpu_zero = 0.0;
+/*
+ * CPU params
+ */
+struct pdc_cache pdc_cache PDC_ALIGNMENT;
+struct pdc_btlb pdc_btlb PDC_ALIGNMENT;
+
/* the following is used externally (sysctl_hw) */
char machine[] = "hppa";
char cpu_model[128];
+#ifdef COMPAT_HPUX
+int cpu_model_hpux; /* contains HPUX_SYSCONF_CPU* kind of value */
+#endif
u_int cpu_ticksnum, cpu_ticksdenom, cpu_hzticks;
dev_t bootdev;
int totalphysmem, physmem, resvmem, esym;
@@ -173,12 +187,17 @@ struct itlb_stats itlb_stats;
struct tlbd_stats tlbd_stats;
#endif
+vm_map_t exec_map = NULL;
+vm_map_t mb_map = NULL;
+vm_map_t phys_map = NULL;
+
int hppa_malloc_ok;
struct extent *hppa_ex;
static long mem_ex_storage[EXTENT_FIXED_STORAGE_SIZE(8) / sizeof(long)];
void delay_init __P((void));
static __inline void fall __P((int, int, int, int, int));
+void dumpsys __P((void));
int bus_mem_add_mapping __P((bus_addr_t bpa, bus_size_t size, int cacheable,
bus_space_handle_t *bshp));
@@ -215,6 +234,16 @@ hppa_init()
icache_stride = pdc_cache.ic_stride;
/*
+ * Fetch BTLB params
+ */
+ if ((pdcerr = pdc_call((iodcio_t)pdc, 0, PDC_BLOCK_TLB,
+ PDC_BTLB_DEFAULT, &pdc_btlb)) < 0) {
+#ifdef DEBUG
+ printf("WARNING: PDC_BTLB call Ret'd %d\n", pdcerr);
+#endif
+ }
+
+ /*
* purge TLBs and flush caches
*/
if (pdc_call((iodcio_t)pdc, 0, PDC_BLOCK_TLB, PDC_BTLB_PURGE_ALL) < 0)
@@ -328,7 +357,9 @@ hppa_init()
nswbuf = 256; /* sanity */
}
+#ifndef UVM
valloc(swbuf, struct buf, nswbuf);
+#endif
valloc(buf, struct buf, nbuf);
#undef valloc
bzero ((void *)vstart, (v - vstart));
@@ -400,8 +431,7 @@ hppa_init()
void
cpu_startup()
{
- struct pdc_model pdc_model;
- register const struct hppa_board_info *bip;
+ struct pdc_model pdc_model PDC_ALIGNMENT;
vm_offset_t minaddr, maxaddr;
vm_size_t size;
int base, residual;
@@ -423,22 +453,36 @@ cpu_startup()
printf("WARNING: PDC_MODEL failed (%d)\n", err);
#endif
} else {
- i = pdc_model.hvers >> 4; /* board type */
- for (bip = hppa_knownboards;
- bip->bi_id >= 0 && bip->bi_id != i; bip++);
- if (bip->bi_id >= 0) {
- char *p;
- switch(pdc_model.arch_rev) {
- case 0: p = "1.0"; break;
- case 4: p = "1.1"; break;
- case 8: p = "2.0"; break;
- default: p = "?.?"; break;
- }
- /* my babe said: 6010, 481, 0, 0, 77b657b1, 0, 4 */
- sprintf(cpu_model, "HP9000/%s PA-RISC %s",
- bip->bi_name, p);
- } else
- sprintf(cpu_model, "HP9000/(UNKNOWN %x)", i);
+ const char *p, *q;
+ i = pdc_model.hvers >> 4;
+ p = hppa_mod_info(HPPA_TYPE_BOARD, i);
+ switch (pdc_model.arch_rev) {
+ default:
+ case 0:
+ q = "1.0";
+#ifdef COMPAT_HPUX
+ cpu_model_hpux = HPUX_SYSCONF_CPUPA10;
+#endif
+ break;
+ case 4:
+ q = "1.1";
+#ifdef COMPAT_HPUX
+ cpu_model_hpux = HPUX_SYSCONF_CPUPA11;
+#endif
+ break;
+ case 8:
+ q = "2.0";
+#ifdef COMPAT_HPUX
+ cpu_model_hpux = HPUX_SYSCONF_CPUPA20;
+#endif
+ break;
+ }
+
+ if (p)
+ sprintf(cpu_model, "HP9000/%s PA-RISC %s", p, q);
+ else
+ sprintf(cpu_model, "HP9000/(UNKNOWN %x) PA-RISC %s",
+ i, q);
printf("%s\n", cpu_model);
}
@@ -450,16 +494,19 @@ cpu_startup()
* in that they usually occupy more virtual memory than physical.
*/
size = MAXBSIZE * nbuf;
- buffer_map = kmem_suballoc(kernel_map, (vm_offset_t *)&buffers,
- &maxaddr, size, TRUE);
- minaddr = (vm_offset_t)buffers;
- if (vm_map_find(buffer_map, vm_object_allocate(size), (vm_offset_t)0,
- &minaddr, size, FALSE) != KERN_SUCCESS)
- panic("cpu_startup: cannot allocate buffers");
-
+ if (uvm_map(kernel_map, (vaddr_t *) &buffers, round_page(size),
+ NULL, UVM_UNKNOWN_OFFSET,
+ UVM_MAPFLAG(UVM_PROT_NONE, UVM_PROT_NONE, UVM_INH_NONE,
+ UVM_ADV_NORMAL, 0)) != KERN_SUCCESS)
+ panic("cpu_startup: cannot allocate VM for buffers");
+ minaddr = (vaddr_t)buffers;
base = bufpages / nbuf;
residual = bufpages % nbuf;
for (i = 0; i < nbuf; i++) {
+ vsize_t curbufsize;
+ vaddr_t curbuf;
+ struct vm_page *pg;
+
/*
* First <residual> buffers get (base+1) physical pages
* allocated for them. The rest get (base) physical pages.
@@ -467,24 +514,36 @@ cpu_startup()
* The rest of each buffer occupies virtual space,
* but has no physical memory allocated for it.
*/
- vm_map_pageable(buffer_map, minaddr, minaddr +
- CLBYTES * (base + (i < residual)), FALSE);
- vm_map_simplify(buffer_map, minaddr);
- minaddr += MAXBSIZE;
+ curbuf = (vaddr_t) buffers + (i * MAXBSIZE);
+ curbufsize = CLBYTES * ((i < residual) ? (base+1) : base);
+
+ while (curbufsize) {
+ if ((pg = uvm_pagealloc(NULL, 0, NULL)) == NULL)
+ panic("cpu_startup: not enough memory for "
+ "buffer cache");
+#ifdef PMAP_NEW
+ pmap_kenter_pgs(curbuf, &pg, 1);
+#else
+ pmap_enter(kernel_map->pmap, curbuf,
+ VM_PAGE_TO_PHYS(pg), VM_PROT_ALL, TRUE);
+#endif
+ curbuf += PAGE_SIZE;
+ curbufsize -= PAGE_SIZE;
+ }
}
/*
* Allocate a submap for exec arguments. This map effectively
* limits the number of processes exec'ing at any time.
*/
- exec_map = kmem_suballoc(kernel_map, &minaddr, &maxaddr,
- 16*NCARGS, TRUE);
+ exec_map = uvm_km_suballoc(kernel_map, &minaddr, &maxaddr,
+ 16*NCARGS, TRUE, FALSE, NULL);
/*
* Allocate a submap for physio
*/
- phys_map = kmem_suballoc(kernel_map, &minaddr, &maxaddr,
- VM_PHYS_SIZE, TRUE);
+ phys_map = uvm_km_suballoc(kernel_map, &minaddr, &maxaddr,
+ VM_PHYS_SIZE, TRUE, FALSE, NULL);
/*
* Finally, allocate mbuf pool. Since mclrefcnt is an off-size
@@ -493,8 +552,8 @@ cpu_startup()
mclrefcnt = (char *)malloc(NMBCLUSTERS+CLBYTES/MCLBYTES,
M_MBUF, M_NOWAIT);
bzero(mclrefcnt, NMBCLUSTERS+CLBYTES/MCLBYTES);
- mb_map = kmem_suballoc(kernel_map, (vm_offset_t *)&mbutl, &maxaddr,
- VM_MBUF_SIZE, FALSE);
+ mb_map = uvm_km_suballoc(kernel_map, (vm_offset_t *)&mbutl, &maxaddr,
+ VM_MBUF_SIZE, FALSE, FALSE, NULL);
/*
* Initialize callouts
@@ -507,7 +566,7 @@ cpu_startup()
#ifdef DEBUG
pmapdebug = opmapdebug;
#endif
- printf("avail mem = %ld\n", ptoa(cnt.v_free_count));
+ printf("avail mem = %ld\n", ptoa(uvmexp.free));
printf("using %d buffers containing %d bytes of memory\n",
nbuf, bufpages * CLBYTES);
@@ -528,6 +587,12 @@ cpu_startup()
}
hppa_malloc_ok = 1;
configure();
+#if 0
+ /* TODO: map SysCall gateways page once for everybody */
+ pmap_enter_pv(pmap_kernel(), SYSCALLGATE, TLB_GATE_PROT,
+ tlbbtop((paddr_t)&gateway_page),
+ pmap_find_va(HPPA_SID_KERNEL, SYSCALLGATE));
+#endif
}
/*
@@ -653,29 +718,21 @@ ptlball()
int
btlb_insert(space, va, pa, lenp, prot)
pa_space_t space;
- vm_offset_t va, pa;
+ vaddr_t va;
+ paddr_t pa;
vm_size_t *lenp;
u_int prot;
{
static u_int32_t mask;
- struct pdc_btlb pdc_btlb PDC_ALIGNMENT;
register vm_size_t len;
register int pdcerr, i;
- if ((pdcerr = pdc_call((iodcio_t)pdc, 0, PDC_BLOCK_TLB,
- PDC_BTLB_DEFAULT, &pdc_btlb)) < 0) {
-#ifdef DEBUG
- printf("WARNING: PDC_BTLB call Ret'd %d\n", pdcerr);
-#endif
- return -1;
- }
-
/* align size */
for (len = pdc_btlb.min_size << PGSHIFT; len < *lenp; len <<= 1);
len >>= PGSHIFT;
i = ffs(~mask) - 1;
if (len > pdc_btlb.max_size || i < 0) {
-#ifdef DEBUG
+#ifdef BTLBDEBUG
printf("btln_insert: too big (%u < %u < %u)\n",
pdc_btlb.min_size, len, pdc_btlb.max_size);
#endif
@@ -693,13 +750,13 @@ btlb_insert(space, va, pa, lenp, prot)
if ((pa & 0xF0000) == 0xF0000)
prot |= TLB_UNCACHEABLE;
-#ifdef DEBUG
- printf ("btlb_insert(%d): %x:%x, %x, %x, %x\n",
+#ifdef BTLBDEBUG
+ printf ("btlb_insert(%d): %x:%x=%x[%x,%x]\n",
i, space, va, pa, len, prot);
#endif
- if (pdc_call((iodcio_t)pdc, 0, PDC_BLOCK_TLB, PDC_BTLB_INSERT,
- space, va, pa, len, prot, i) < 0) {
-#ifdef DEBUG
+ if ((pdcerr = pdc_call((iodcio_t)pdc, 0, PDC_BLOCK_TLB,PDC_BTLB_INSERT,
+ space, va, pa, len, prot, i)) < 0) {
+#ifdef BTLBDEBUG
printf("WARNING: BTLB insert failed (%d)\n", pdcerr);
#endif
return -(EINVAL);
@@ -717,7 +774,6 @@ bus_space_map (t, bpa, size, cacheable, bshp)
int cacheable;
bus_space_handle_t *bshp;
{
- extern u_int virtual_avail;
register int error;
bpa += HPPA_BUS_TAG_BASE(t);
@@ -725,12 +781,6 @@ bus_space_map (t, bpa, size, cacheable, bshp)
(hppa_malloc_ok? EX_MALLOCOK : 0))))
return (error);
- if ((bpa > 0 && bpa < virtual_avail) ||
- (bpa > HPPA_IOBEGIN)) {
- *bshp = bpa;
- return 0;
- }
-
if ((error = bus_mem_add_mapping(bpa, size, cacheable, bshp))) {
if (extent_free(hppa_ex, bpa, size, EX_NOWAIT |
(hppa_malloc_ok? EX_MALLOCOK : 0))) {
@@ -762,7 +812,7 @@ bus_space_unmap (t, bsh, size)
bpa = kvtop((caddr_t)bsh);
if (bpa != bsh)
- kmem_free(kernel_map, sva, eva - sva);
+ uvm_km_free(kernel_map, sva, eva - sva);
if (extent_free(hppa_ex, bpa, size, EX_NOWAIT |
(hppa_malloc_ok? EX_MALLOCOK : 0))) {
@@ -781,7 +831,30 @@ bus_space_alloc (t, rstart, rend, size, align, bndary, cacheable, addrp, bshp)
bus_addr_t *addrp;
bus_space_handle_t *bshp;
{
- return -1;
+ u_long bpa;
+ int error;
+
+ if (rstart < hppa_ex->ex_start || rend > hppa_ex->ex_end)
+ panic("bus_space_alloc: bad region start/end");
+
+ if ((error = extent_alloc_subregion(hppa_ex, rstart, rend, size,
+ align, bndary, EX_NOWAIT |
+ (hppa_malloc_ok? EX_MALLOCOK:0),
+ &bpa)))
+ return (error);
+
+ if ((error = bus_mem_add_mapping(bpa, size, cacheable, bshp))) {
+ if (extent_free(hppa_ex, bpa, size, EX_NOWAIT |
+ (hppa_malloc_ok ? EX_MALLOCOK : 0))) {
+ printf("bus_space_alloc: pa 0x%lx, size 0x%lx\n",
+ bpa, size);
+ printf("bus_space_alloc: can't free region\n");
+ }
+ }
+
+ *addrp = bpa;
+
+ return error;
}
void
@@ -790,7 +863,8 @@ bus_space_free(t, bsh, size)
bus_space_handle_t bsh;
bus_size_t size;
{
-
+ /* bus_space_unmap() does all that we need to do. */
+ bus_space_unmap(t, bsh, size);
}
int
@@ -800,29 +874,89 @@ bus_mem_add_mapping(bpa, size, cacheable, bshp)
int cacheable;
bus_space_handle_t *bshp;
{
- register u_long spa, epa;
- register vm_offset_t va;
+ extern u_int virtual_avail;
+ register u_int64_t spa, epa;
+ int bank, off;
- spa = hppa_trunc_page(bpa);
- epa = hppa_round_page(bpa + size);
+ if (bpa > 0 && bpa < virtual_avail)
+ *bshp = bpa;
+ else if ((bank = vm_physseg_find(atop(bpa), &off)) < 0) {
+ /*
+ * determine if we are mapping IO space, or beyond the physmem
+ * region. use block mapping then
+ *
+ * we map the whole bus module (there are 1024 of those max)
+ * so, check here if it's mapped already, map if needed.
+ * all mappings a equal mappings.
+ */
+ static u_int8_t bmm[1024/8];
+ int flex = HPPA_FLEX(bpa);
+
+ /* need a new mapping */
+ if (!(bmm[flex / 8] & (1 << (flex & 3)))) {
+ spa = bpa & FLEX_MASK;
+ epa = ((u_long)((u_int64_t)bpa + size +
+ ~FLEX_MASK - 1) & FLEX_MASK) - 1;
+#ifdef BTLBDEBUG
+ printf ("bus_mem_add_mapping: adding flex=%x "
+ "%qx-%qx, ", flex, spa, epa);
+#endif
+ while (spa < epa) {
+ vm_size_t len = epa - spa;
+ u_int64_t pa;
+ if (len > pdc_btlb.max_size << PGSHIFT)
+ len = pdc_btlb.max_size << PGSHIFT;
+ if (btlb_insert(kernel_pmap->pmap_space, spa,
+ spa, &len,
+ kernel_pmap->pmap_pid |
+ pmap_prot(kernel_pmap,
+ VM_PROT_ALL)) < 0)
+ return -1;
+ pa = spa += len - 1;
+#ifdef BTLBDEBUG
+ printf ("------ %d/%d, %qx, %qx-%qx",
+ flex, HPPA_FLEX(pa), pa, spa, epa);
+#endif
+ /* do the mask */
+ for (; flex <= HPPA_FLEX(pa); flex++) {
+#ifdef BTLBDEBUG
+ printf ("mask %x ", flex);
+#endif
+ bmm[flex / 8] |= (1 << (flex & 3));
+ }
+ }
+#ifdef BTLBDEBUG
+ printf ("\n");
+#endif
+ }
+ *bshp = bpa;
+ } else {
+ register vm_offset_t va;
+
+#ifdef PMAPDEBUG
+ printf ("%d, %d, %x\n", bank, off, vm_physmem[0].end);
+#endif
+ spa = hppa_trunc_page(bpa);
+ epa = hppa_round_page(bpa + size);
#ifdef DIAGNOSTIC
- if (epa <= spa)
- panic("bus_mem_add_mapping: overflow");
+ if (epa <= spa)
+ panic("bus_mem_add_mapping: overflow");
#endif
- if (!(va = kmem_alloc_pageable(kernel_map, epa - spa)))
- return (ENOMEM);
+ if (!(va = uvm_km_valloc(kernel_map, epa - spa)))
+ return (ENOMEM);
- *bshp = (bus_space_handle_t)(va + (bpa & PGOFSET));
+ *bshp = (bus_space_handle_t)(va + (bpa & PGOFSET));
- for (; spa < epa; spa += NBPG, va += NBPG) {
- pmap_enter(pmap_kernel(), va, spa,
- VM_PROT_READ | VM_PROT_WRITE, TRUE);
- if (!cacheable)
- pmap_changebit(spa, TLB_UNCACHEABLE, ~0);
- else
- pmap_changebit(spa, 0, ~TLB_UNCACHEABLE);
+ for (; spa < epa; spa += NBPG, va += NBPG) {
+ pmap_enter(pmap_kernel(), va, spa,
+ VM_PROT_READ | VM_PROT_WRITE, TRUE);
+ if (!cacheable)
+ pmap_changebit(spa, TLB_UNCACHEABLE, ~0);
+ else
+ pmap_changebit(spa, 0, ~TLB_UNCACHEABLE);
+ }
}
return 0;
@@ -853,15 +987,46 @@ flush_cache(tag, h, off, l, op)
}
#endif
+int waittime = -1;
+
void
boot(howto)
int howto;
{
- /* TODO: probably save howto into stable storage */
+ extern int cold;
+
+ if (cold)
+ howto |= RB_HALT;
+ else {
+ boothowto = howto | (boothowto & RB_HALT);
+
+ if (!(howto & RB_NOSYNC) && waittime < 0) {
+ extern struct proc proc0;
+
+ /* protect against curproc->p_stats refs in sync XXX */
+ if (curproc == NULL)
+ curproc = &proc0;
+
+ waittime = 0;
+ vfs_shutdown();
+ if ((howto & RB_TIMEBAD) == 0)
+ resettodr();
+ else
+ printf("WARNING: not updating battery clock\n");
+ }
+ }
+
+ /* XXX probably save howto into stable storage */
+
+ splhigh();
+
+ if ((howto & (RB_DUMP /* | RB_HALT */)) == RB_DUMP)
+ dumpsys();
+
+ doshutdownhooks();
if (howto & RB_HALT) {
printf("System halted!\n");
- splhigh();
__asm __volatile("stwas %0, 0(%1)"
:: "r" (CMD_STOP),
"r" (LBCAST_ADDR + iomod_command));
@@ -877,6 +1042,135 @@ boot(howto)
/* NOTREACHED */
}
+u_long dumpmag = 0x8fca0101; /* magic number */
+int dumpsize = 0; /* pages */
+long dumplo = 0; /* blocks */
+
+/*
+ * cpu_dumpsize: calculate size of machine-dependent kernel core dump headers.
+ */
+int
+cpu_dumpsize()
+{
+ int size;
+
+ size = ALIGN(sizeof(kcore_seg_t)) + ALIGN(sizeof(cpu_kcore_hdr_t));
+ if (roundup(size, dbtob(1)) != dbtob(1))
+ return -1;
+
+ return 1;
+}
+
+int
+cpu_dump()
+{
+ long buf[dbtob(1) / sizeof (long)];
+ kcore_seg_t *segp;
+ cpu_kcore_hdr_t *cpuhdrp;
+
+ segp = (kcore_seg_t *)buf;
+ cpuhdrp = (cpu_kcore_hdr_t *)&buf[ALIGN(sizeof(*segp)) / sizeof (long)];
+
+ /*
+ * Generate a segment header.
+ */
+ CORE_SETMAGIC(*segp, KCORE_MAGIC, MID_MACHINE, CORE_CPU);
+ segp->c_size = dbtob(1) - ALIGN(sizeof(*segp));
+
+ /*
+ * Add the machine-dependent header info
+ */
+ /* nothing for now */
+
+ return (bdevsw[major(dumpdev)].d_dump)
+ (dumpdev, dumplo, (caddr_t)buf, dbtob(1));
+}
+
+/*
+ * Dump the kernel's image to the swap partition.
+ */
+#define BYTES_PER_DUMP NBPG
+
+void
+dumpsys()
+{
+ int psize, bytes, i, n;
+ register caddr_t maddr;
+ register daddr_t blkno;
+ register int (*dump) __P((dev_t, daddr_t, caddr_t, size_t));
+ register int error;
+
+ /* Save registers
+ savectx(&dumppcb); */
+
+ if (dumpsize == 0)
+ dumpconf();
+ if (dumplo <= 0) {
+ printf("\ndump to dev %x not possible\n", dumpdev);
+ return;
+ }
+ printf("\ndumping to dev %x, offset %ld\n", dumpdev, dumplo);
+
+ psize = (*bdevsw[major(dumpdev)].d_psize)(dumpdev);
+ printf("dump ");
+ if (psize == -1) {
+ printf("area unavailable\n");
+ return;
+ }
+
+ if (!(error = cpu_dump())) {
+
+ bytes = ctob(physmem);
+ maddr = NULL;
+ blkno = dumplo + cpu_dumpsize();
+ dump = bdevsw[major(dumpdev)].d_dump;
+ /* TODO block map the whole memory */
+ for (i = 0; i < bytes; i += n) {
+
+ /* Print out how many MBs we to go. */
+ n = bytes - i;
+ if (n && (n % (1024*1024)) == 0)
+ printf("%d ", n / (1024 * 1024));
+
+ /* Limit size for next transfer. */
+
+ if (n > BYTES_PER_DUMP)
+ n = BYTES_PER_DUMP;
+
+ if ((error = (*dump)(dumpdev, blkno, maddr, n)))
+ break;
+ maddr += n;
+ blkno += btodb(n);
+ }
+ }
+
+ switch (error) {
+ case ENXIO: printf("device bad\n"); break;
+ case EFAULT: printf("device not ready\n"); break;
+ case EINVAL: printf("area improper\n"); break;
+ case EIO: printf("i/o error\n"); break;
+ case EINTR: printf("aborted from console\n"); break;
+ case 0: printf("succeeded\n"); break;
+ default: printf("error %d\n", error); break;
+ }
+}
+
+/* bcopy(), error on fault */
+int
+kcopy(from, to, size)
+ const void *from;
+ void *to;
+ size_t size;
+{
+ register void *oldh = curproc->p_addr->u_pcb.pcb_onfault;
+
+ curproc->p_addr->u_pcb.pcb_onfault = &copy_on_fault;
+ bcopy(from, to, size);
+ curproc->p_addr->u_pcb.pcb_onfault = oldh;
+
+ return 0;
+}
+
int
copystr(src, dst, size, lenp)
const void *src;
@@ -884,7 +1178,8 @@ copystr(src, dst, size, lenp)
size_t size;
size_t *lenp;
{
- return 0;
+ return spstrcpy(HPPA_SID_KERNEL, src,
+ HPPA_SID_KERNEL, dst, size, lenp);
}
int
@@ -894,7 +1189,8 @@ copyinstr(src, dst, size, lenp)
size_t size;
size_t *lenp;
{
- return 0;
+ return spstrcpy(curproc->p_addr->u_pcb.pcb_space, src,
+ HPPA_SID_KERNEL, dst, size, lenp);
}
@@ -905,7 +1201,8 @@ copyoutstr(src, dst, size, lenp)
size_t size;
size_t *lenp;
{
- return 0;
+ return spstrcpy(HPPA_SID_KERNEL, src,
+ curproc->p_addr->u_pcb.pcb_space, dst, size, lenp);
}
@@ -915,7 +1212,8 @@ copyin(src, dst, size)
void *dst;
size_t size;
{
- return 0;
+ return spcopy(curproc->p_addr->u_pcb.pcb_space, src,
+ HPPA_SID_KERNEL, dst, size);
}
int
@@ -924,100 +1222,8 @@ copyout(src, dst, size)
void *dst;
size_t size;
{
- return 0;
-}
-
-int
-fubyte(addr)
- const void *addr;
-{
- return 0;
-}
-
-int
-subyte(addr, val)
- void *addr;
- int val;
-{
- return 0;
-}
-
-int
-suibyte(addr, val)
- void *addr;
- int val;
-{
- return 0;
-}
-
-long
-fuword(addr)
- const void *addr;
-{
- return 0;
-}
-
-long
-fuiword(addr)
- const void *addr;
-{
- return 0;
-}
-
-int
-suword(addr, val)
- void *addr;
- long val;
-{
- return 0;
-}
-
-int
-suiword(addr, val)
- void *addr;
- long val;
-{
- return 0;
-}
-
-int
-fuswintr(addr)
- const caddr_t addr;
-{
- return 0;
-}
-
-int
-suswintr(addr, val)
- caddr_t addr;
- u_int val;
-{
- return 0;
-}
-
-
-/*
- * setrunqueue(p)
- * proc *p;
- *
- * Call should be made at splclock(), and p->p_stat should be SRUN.
- */
-void
-setrunqueue(p)
-struct proc *p;
-{
-
-}
-
-/*
- * remrunqueue(p)
- *
- * Call should be made at splclock().
- */
-void
-remrunqueue(p)
- struct proc *p;
-{
+ return spcopy(HPPA_SID_KERNEL, src,
+ curproc->p_addr->u_pcb.pcb_space, dst, size);
}
/*
@@ -1030,6 +1236,28 @@ setregs(p, pack, stack, retval)
u_long stack;
register_t *retval;
{
+ register struct trapframe *tf;
+
+ /* FPU: setup regs */
+
+ tf = p->p_md.md_regs;
+ /* tf->tf_r??? = PS_STRINGS */
+ tf->tf_ipsw = PSW_C | PSW_Q | PSW_P | PSW_D | PSW_I;
+ tf->tf_iioq_head = tf->tf_iioq_tail = pack->ep_entry;
+ tf->tf_iisq_head = tf->tf_iisq_tail = p->p_addr->u_pcb.pcb_space;
+ tf->tf_sp = stack;
+ tf->tf_rp = 0;
+ tf->tf_eiem = 0;
+ tf->tf_sr4 = p->p_addr->u_pcb.pcb_space;
+ tf->tf_sr5 = p->p_addr->u_pcb.pcb_space;
+ tf->tf_sr6 = p->p_addr->u_pcb.pcb_space;
+ tf->tf_sr7 = HPPA_SID_KERNEL;
+ tf->tf_pidr1 = p->p_vmspace->vm_pmap.pmap_pid;
+ tf->tf_pidr2 = p->p_vmspace->vm_pmap.pmap_pid;
+ tf->tf_pidr3 = p->p_vmspace->vm_pmap.pmap_pid;
+ tf->tf_pidr4 = p->p_vmspace->vm_pmap.pmap_pid;
+
+ retval[1] = 0;
}
/*
@@ -1043,7 +1271,7 @@ sendsig(catcher, sig, mask, code, type, val)
int type;
union sigval val;
{
-
+ /* TODO */
}
int
@@ -1052,6 +1280,7 @@ sys_sigreturn(p, v, retval)
void *v;
register_t *retval;
{
+ /* TODO */
return EINVAL;
}