summaryrefslogtreecommitdiff
path: root/sys/arch/vax/include
diff options
context:
space:
mode:
Diffstat (limited to 'sys/arch/vax/include')
-rw-r--r--sys/arch/vax/include/frame.h (renamed from sys/arch/vax/include/loconf.h)47
-rw-r--r--sys/arch/vax/include/ioa.h36
-rw-r--r--sys/arch/vax/include/ka750.h15
-rw-r--r--sys/arch/vax/include/kg.h36
-rw-r--r--sys/arch/vax/include/nexus.h21
-rw-r--r--sys/arch/vax/include/param.h27
-rw-r--r--sys/arch/vax/include/pmap.h17
-rw-r--r--sys/arch/vax/include/pte.h37
-rw-r--r--sys/arch/vax/include/scb.h8
-rw-r--r--sys/arch/vax/include/sid.h3
-rw-r--r--sys/arch/vax/include/trap.h23
-rw-r--r--sys/arch/vax/include/types.h3
12 files changed, 103 insertions, 170 deletions
diff --git a/sys/arch/vax/include/loconf.h b/sys/arch/vax/include/frame.h
index 62fb2f2b802..0031315aa5d 100644
--- a/sys/arch/vax/include/loconf.h
+++ b/sys/arch/vax/include/frame.h
@@ -1,7 +1,6 @@
-/* $NetBSD: loconf.h,v 1.2 1994/10/26 08:02:13 cgd Exp $ */
-
+/* $NetBSD: frame.h,v 1.1 1995/11/12 15:07:30 ragge Exp $ */
/*
- * Copyright (c) 1994 Ludd, University of Lule}, Sweden.
+ * Copyright (c) 1995 Ludd, University of Lule}, Sweden.
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
@@ -14,7 +13,8 @@
* documentation and/or other materials provided with the distribution.
* 3. All advertising materials mentioning features or use of this software
* must display the following acknowledgement:
- * This product includes software developed at Ludd, University of Lule}.
+ * This product includes software developed at Ludd, University of
+ * Lule}, Sweden and its contributors.
* 4. The name of the author may not be used to endorse or promote products
* derived from this software without specific prior written permission
*
@@ -30,28 +30,21 @@
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
- /* All bugs are subject to removal without further notice */
-
-
-
-
-
-#define ISTACK_SIZE 4*NBPG
-
-/* XXX If kernel never crashes with kernel stack overflow trap
- * kstack can be removed altogether. (Was 4*NBPG)
+/*
+ * Description of calls frame on stack. This is the
+ * standard way of making procedure calls on vax systems.
*/
+struct callsframe {
+ unsigned int ca_cond; /* condition handler */
+ unsigned int ca_maskpsw; /* register mask and saved psw */
+ unsigned int ca_ap; /* argument pointer */
+ unsigned int ca_fp; /* frame pointer */
+ unsigned int ca_pc; /* program counter */
+ unsigned int ca_argno; /* argument count on stack */
+ unsigned int ca_arg1; /* first arg on stack */
+ /* This can be followed by more arguments */
+};
+
+/* Offset to beginning of calls frame from first arg */
+#define FRAMEOFFSET(arg1) ((struct callsframe *)((unsigned int)&(arg1) - 24))
-#define PROC_PAGES 0
-
-#define MAX_UCODE 1024*1024*6
-#define MAX_UDATA 1024*1024*32
-#define MAX_USTCK 1024*1024*8
-
-#define MAX_PROCESSES 32
-
-#define PROCOFFSET (MAX_UCODE+MAX_UDATA+MAX_USTCK)/16384
-
-/* Add 1 to USERPAGES if (MAX_PROCESSES mod 8) != 0 */
-
-#define USERPAGES (MAX_UCODE+MAX_UDATA+MAX_USTCK)*MAX_PROCESSES/(512*128*128)
diff --git a/sys/arch/vax/include/ioa.h b/sys/arch/vax/include/ioa.h
deleted file mode 100644
index b09da95056f..00000000000
--- a/sys/arch/vax/include/ioa.h
+++ /dev/null
@@ -1,36 +0,0 @@
-/* $NetBSD: ioa.h,v 1.2 1994/10/26 08:02:09 cgd Exp $ */
-
-/*
- * Copyright (c) 1994 Ludd, University of Lule}, Sweden.
- * All rights reserved.
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions
- * are met:
- * 1. Redistributions of source code must retain the above copyright
- * notice, this list of conditions and the following disclaimer.
- * 2. Redistributions in binary form must reproduce the above copyright
- * notice, this list of conditions and the following disclaimer in the
- * documentation and/or other materials provided with the distribution.
- * 3. All advertising materials mentioning features or use of this software
- * must display the following acknowledgement:
- * This product includes software developed at Ludd, University of Lule}.
- * 4. The name of the author may not be used to endorse or promote products
- * derived from this software without specific prior written permission
- *
- * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
- * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
- * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
- * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
- * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
- * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
- * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
- * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
- * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
- * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
- */
-
- /* All bugs are subject to removal without further notice */
-
-
-
diff --git a/sys/arch/vax/include/ka750.h b/sys/arch/vax/include/ka750.h
index c6c0b494fa4..9b5f71b0745 100644
--- a/sys/arch/vax/include/ka750.h
+++ b/sys/arch/vax/include/ka750.h
@@ -1,4 +1,4 @@
-/* $NetBSD: ka750.h,v 1.2 1994/10/26 08:02:10 cgd Exp $ */
+/* $NetBSD: ka750.h,v 1.3 1995/11/12 14:37:20 ragge Exp $ */
/*
* Copyright (c) 1994 Ludd, University of Lule}, Sweden.
@@ -30,12 +30,15 @@
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
- /* All bugs are subject to removal without further notice */
-
-
-
-/* ka750.h - definitioner enbart f|r VAX 750 940328/ragge */
+#include "machine/nexus.h"
#define V750UCODE(x) ((x>>8)&255)
#define V750HARDW(x) (x&255)
+#define NNEX750 NNEXSBI
+#define NEX750 (0xf20000)
+#define NEX750SZ (NNEX750 * sizeof(struct nexus))
+
+/* 11/750 specific pages needed to be stolen when bootstrapping */
+#define V750PGS 4
+
diff --git a/sys/arch/vax/include/kg.h b/sys/arch/vax/include/kg.h
deleted file mode 100644
index e37e6f94c2c..00000000000
--- a/sys/arch/vax/include/kg.h
+++ /dev/null
@@ -1,36 +0,0 @@
-/* $NetBSD: kg.h,v 1.2 1994/10/26 08:02:11 cgd Exp $ */
-
-/*
- * Copyright (c) 1994 Ludd, University of Lule}, Sweden.
- * All rights reserved.
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions
- * are met:
- * 1. Redistributions of source code must retain the above copyright
- * notice, this list of conditions and the following disclaimer.
- * 2. Redistributions in binary form must reproduce the above copyright
- * notice, this list of conditions and the following disclaimer in the
- * documentation and/or other materials provided with the distribution.
- * 3. All advertising materials mentioning features or use of this software
- * must display the following acknowledgement:
- * This product includes software developed at Ludd, University of Lule}.
- * 4. The name of the author may not be used to endorse or promote products
- * derived from this software without specific prior written permission
- *
- * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
- * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
- * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
- * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
- * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
- * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
- * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
- * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
- * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
- * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
- */
-
- /* All bugs are subject to removal without further notice */
-
-
-
diff --git a/sys/arch/vax/include/nexus.h b/sys/arch/vax/include/nexus.h
index a4c9a8ce678..9586ae7f41b 100644
--- a/sys/arch/vax/include/nexus.h
+++ b/sys/arch/vax/include/nexus.h
@@ -1,4 +1,4 @@
-/* $NetBSD: nexus.h,v 1.4 1995/02/23 17:51:42 ragge Exp $ */
+/* $NetBSD: nexus.h,v 1.5 1995/11/12 14:37:22 ragge Exp $ */
/*-
* Copyright (c) 1982, 1986 The Regents of the University of California.
@@ -57,14 +57,6 @@
#define NNEX780 NNEXSBI
#define NEX780 ((struct nexus *)0x20000000)
#endif
-#if VAX750
-#define NNEX750 NNEXSBI
-#ifndef ASSEMBLER
-#define NEX750 ((struct nexus*)0xf20000)
-#else
-#define NEX750 (0xF20000)
-#endif
-#endif
#if VAX730
#define NNEX730 NNEXSBI
#define NEX730 ((struct nexus *)0xf20000)
@@ -94,9 +86,10 @@ struct nexus {
};
struct sbi_attach_args {
- u_int nexnum;
- u_int type;
- void *nexaddr;
+ u_int nexnum; /* This nexus TR number */
+ u_int type; /* This nexus type */
+ int nexinfo; /* Some info sent between attach & match */
+ void *nexaddr; /* Virtual address of this nexus */
};
struct iobus {
@@ -177,3 +170,7 @@ extern caddr_t *nex_vec;
#define NEX_MEM256U 0x72 /* 256K chips, non-interleaved, upper */
#define NEX_MEM256UI 0x73 /* 256K chips, ext-interleaved, upper */
#define NEX_MEM256I 0x74 /* 256K chips, interleaved */
+
+#ifndef ASSEMBLER
+struct nexus *nexus;
+#endif
diff --git a/sys/arch/vax/include/param.h b/sys/arch/vax/include/param.h
index 208a254711a..9829484dddd 100644
--- a/sys/arch/vax/include/param.h
+++ b/sys/arch/vax/include/param.h
@@ -1,11 +1,9 @@
-/* $NetBSD: param.h,v 1.12 1995/08/13 00:45:21 mycroft Exp $ */
+/* $NetBSD: param.h,v 1.13 1995/12/04 22:32:53 ragge Exp $ */
/*-
* Copyright (c) 1990 The Regents of the University of California.
* All rights reserved.
*
- * Modified for VAX 940213/Ragge
- *
* This code is derived from software contributed to Berkeley by
* William Jolitz.
*
@@ -44,15 +42,15 @@
#define _VAX_PARAM_H_
#include "machine/macros.h"
-#include "psl.h"
+#include "machine/psl.h"
/*
* Machine dependent constants for VAX.
*/
#define MACHINE "vax"
+#define MACHINE_ARCH "vax"
#define MID_MACHINE MID_VAX
-#define UNIX "vmunix"
/*
* Round p (pointer or byte index) up to a correctly-aligned value
@@ -132,6 +130,7 @@
/* clicks to bytes */
#define ctob(x) ((x) << PGSHIFT)
#define btoc(x) (((x) + PGOFSET) >> PGSHIFT)
+#define btop(x) (((unsigned)(x)) >> PGSHIFT)
/* bytes to disk blocks */
#define btodb(x) ((x) >> DEV_BSHIFT)
@@ -146,19 +145,6 @@
#define bdbtofsb(bn) ((bn) / (BLKDEV_IOSIZE/DEV_BSIZE))
-/*
- * Mach derived conversion macros
- */
-
-#define vax_round_pdr(x) ((((unsigned)(x)) + NBPDR - 1) & ~(NBPDR-1))
-#define vax_trunc_pdr(x) ((unsigned)(x) & ~(NBPDR-1))
-#define vax_round_page(x) ((((unsigned)(x)) + NBPG - 1) & ~(NBPG-1))
-#define vax_trunc_page(x) ((unsigned)(x) & ~(NBPG-1))
-#define vax_btod(x) ((unsigned)(x) >> PDRSHIFT)
-#define vax_dtob(x) ((unsigned)(x) << PDRSHIFT)
-#define vax_btop(x) ((unsigned)(x) >> PGSHIFT)
-#define vax_ptob(x) ((unsigned)(x) << PGSHIFT)
-
#define splx(reg) \
({ \
register int val; \
@@ -187,9 +173,6 @@
#define vmapbuf(p,q)
#define vunmapbuf(p,q)
-#if !defined(VAX630) && !defined(VAX410)
-#define todr() mfpr(PR_TODR)
-#endif
-#define DELAY(x) {int N=todr()+(x/1000)+1;while(todr()!=N);}
+#define DELAY(x) delay(x)
#endif /* _VAX_PARAM_H_ */
diff --git a/sys/arch/vax/include/pmap.h b/sys/arch/vax/include/pmap.h
index a753c873e51..bfc1996e920 100644
--- a/sys/arch/vax/include/pmap.h
+++ b/sys/arch/vax/include/pmap.h
@@ -1,4 +1,4 @@
-/* $NetBSD: pmap.h,v 1.10 1995/05/11 16:53:14 jtc Exp $ */
+/* $NetBSD: pmap.h,v 1.11 1995/11/12 14:41:41 ragge Exp $ */
/*
* Copyright (c) 1987 Carnegie-Mellon University
@@ -83,6 +83,21 @@ typedef struct pv_entry {
#define PHYS_TO_PV(phys_page) (&pv_table[((phys_page)>>PAGE_SHIFT)])
+/* ROUND_PAGE used before vm system is initialized */
+#define ROUND_PAGE(x) (((uint)(x) + PAGE_SIZE-1)& ~(PAGE_SIZE - 1))
+
+/* Mapping macros used when allocating SPT */
+#define MAPVIRT(ptr, count) \
+ (vm_offset_t)ptr = virtual_avail; \
+ virtual_avail += (count) * NBPG;
+
+#define MAPPHYS(ptr, count, perm) \
+ pmap_map(virtual_avail, avail_start, avail_start + \
+ (count) * NBPG, perm); \
+ (vm_offset_t)ptr = virtual_avail; \
+ virtual_avail += (count) * NBPG; \
+ avail_start += (count) * NBPG;
+
#ifdef _KERNEL
pv_entry_t pv_table; /* array of entries,
one per LOGICAL page */
diff --git a/sys/arch/vax/include/pte.h b/sys/arch/vax/include/pte.h
index f99839e1931..fb5bd91a5aa 100644
--- a/sys/arch/vax/include/pte.h
+++ b/sys/arch/vax/include/pte.h
@@ -1,4 +1,4 @@
-/* $NetBSD: pte.h,v 1.5 1995/08/21 03:28:50 ragge Exp $ */
+/* $NetBSD: pte.h,v 1.6 1995/11/12 14:40:26 ragge Exp $ */
/*
* Copyright (c) 1994 Ludd, University of Lule}, Sweden.
@@ -30,10 +30,7 @@
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
- /* All bugs are subject to removal without further notice */
-
-
-#include "vax/include/param.h"
+#include "machine/param.h"
#ifndef ASSEMBLER
@@ -41,19 +38,19 @@
* VAX page table entries
*/
struct pte {
- unsigned int pg_pfn:21; /* Page Frame Number or 0 */
- unsigned int pg_u:1; /* Uniform bit, does WHAT?? XXX */
- unsigned int pg_w:1; /* Wired bit */
- unsigned int pg_sref:1; /* Help for ref simulation */
- unsigned int pg_ref:1; /* Simulated reference bit */
- unsigned int pg_z:1; /* Zero DIGITAL = 0 */
- unsigned int pg_m:1; /* Modify DIGITAL */
- unsigned int pg_prot:4; /* reserved at zero */
- unsigned int pg_v:1; /* valid bit */
+ unsigned int pg_pfn:21; /* Page Frame Number or 0 */
+ unsigned int pg_u:1; /* Uniform bit, does WHAT?? XXX */
+ unsigned int pg_w:1; /* Wired bit */
+ unsigned int pg_sref:1; /* Help for ref simulation */
+ unsigned int pg_ref:1; /* Simulated reference bit */
+ unsigned int pg_z:1; /* Zero DIGITAL = 0 */
+ unsigned int pg_m:1; /* Modify DIGITAL */
+ unsigned int pg_prot:4; /* reserved at zero */
+ unsigned int pg_v:1; /* valid bit */
};
-typedef unsigned int pt_entry_t; /* Mach page table entry */
+typedef struct pte pt_entry_t; /* Mach page table entry */
#endif ASSEMBLER
@@ -74,11 +71,7 @@ typedef unsigned int pt_entry_t; /* Mach page table entry */
#define PG_W 0x00400000
#define PG_U 0x00200000
#define PG_FRAME 0x001fffff
-#define PG_SHIFT 9
-#define PG_PFNUM(x) ((x) >> PG_SHIFT)
-
-
-#define VAX_MAX_KPTSIZE VM_KERNEL_PT_PAGES
+#define PG_PFNUM(x) ((x) >> PGSHIFT)
#ifndef ASSEMBLER
extern pt_entry_t *Sysmap;
@@ -88,8 +81,8 @@ extern pt_entry_t *Sysmap;
#endif
#define kvtopte(va) \
- (&Sysmap[((unsigned)(va) - KERNBASE) >> PGSHIFT])
+ (&Sysmap[((unsigned)(va) & ~KERNBASE) >> PGSHIFT])
#define ptetokv(pt) \
((((pt_entry_t *)(pt) - Sysmap) << PGSHIFT) + 0x80000000)
#define kvtophys(va) \
- ((kvtopte(va)->pg_pfnum << PGSHIFT) | ((int)(va) & PGOFSET))
+ (((kvtopte(va))->pg_pfn << PGSHIFT) | ((int)(va) & PGOFSET))
diff --git a/sys/arch/vax/include/scb.h b/sys/arch/vax/include/scb.h
index f5663183149..6d5234088b7 100644
--- a/sys/arch/vax/include/scb.h
+++ b/sys/arch/vax/include/scb.h
@@ -1,4 +1,4 @@
-/* $NetBSD: scb.h,v 1.2 1994/10/26 08:02:26 cgd Exp $ */
+/* $NetBSD: scb.h,v 1.3 1995/11/12 14:38:31 ragge Exp $ */
/*
* Copyright (c) 1994 Ludd, University of Lule}, Sweden.
@@ -30,10 +30,10 @@
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
- /* All bugs are subject to removal without further notice */
-
-
struct scb {
};
+#ifdef _KERNEL
+extern struct scb *scb;
+#endif
diff --git a/sys/arch/vax/include/sid.h b/sys/arch/vax/include/sid.h
index 91f89399156..2888b904525 100644
--- a/sys/arch/vax/include/sid.h
+++ b/sys/arch/vax/include/sid.h
@@ -1,4 +1,4 @@
-/* $NetBSD: sid.h,v 1.5 1995/02/23 17:51:44 ragge Exp $ */
+/* $NetBSD: sid.h,v 1.6 1995/11/12 14:37:18 ragge Exp $ */
/*
* Copyright (c) 1994 Ludd, University of Lule}, Sweden.
@@ -48,7 +48,6 @@
#define MACHID(x) ((x>>24)&255)
#define V750UCODE(x) ((x>>8)&255)
-#define V750HARDW(x) (cpu_type&255)
/*
* The MicroVAXII CPU chip (78032) is used on more than one type of system
diff --git a/sys/arch/vax/include/trap.h b/sys/arch/vax/include/trap.h
index b1cafc13785..2eb245a4de4 100644
--- a/sys/arch/vax/include/trap.h
+++ b/sys/arch/vax/include/trap.h
@@ -1,4 +1,4 @@
-/* $NetBSD: trap.h,v 1.8 1995/06/16 15:17:40 ragge Exp $ */
+/* $NetBSD: trap.h,v 1.9 1995/11/12 14:33:11 ragge Exp $ */
/*-
* Copyright (c) 1990 The Regents of the University of California.
@@ -104,6 +104,27 @@ struct trapframe {
u_int pc; /* User pc */
u_int psl; /* User psl */
};
+
+/*
+ * This struct is used when setting up interrupt vectors dynamically.
+ * It pushes a longword between 0-63 on the stack; this number is
+ * normally used as the ctlr number on devices. This use effectively
+ * limits the number of interruptable ctlrs on the unibus to 64.
+ */
+struct ivec_dsp {
+ char pushr; /* pushr */
+ char pushrarg; /* $3f */
+ char pushl; /* pushl */
+ char pushlarg; /* $? */
+ char nop; /* nop, for foolish gcc */
+ char calls[3]; /* calls $1,? */
+ u_int hoppaddr; /* jump for calls */
+ char popr; /* popr $0x3f */
+ char poprarg;
+ char rei; /* rei */
+ char pad; /* sizeof(struct ivec_dsp) == 16 */
+};
+
#endif /* ASSEMBLER */
#endif _VAX_TRAP_H_
diff --git a/sys/arch/vax/include/types.h b/sys/arch/vax/include/types.h
index dbf36014062..89497fc4862 100644
--- a/sys/arch/vax/include/types.h
+++ b/sys/arch/vax/include/types.h
@@ -1,4 +1,4 @@
-/* $NetBSD: types.h,v 1.5 1995/07/06 03:39:45 cgd Exp $ */
+/* $NetBSD: types.h,v 1.6 1995/12/09 04:41:57 mycroft Exp $ */
/*-
* Copyright (c) 1990 The Regents of the University of California.
@@ -73,5 +73,6 @@ typedef unsigned long long u_int64_t;
typedef int32_t register_t;
#define __BDEVSW_DUMP_OLD_TYPE
+#define __FORK_BRAINDAMAGE
#endif /* _MACHTYPES_H_ */