Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/perseant-stdc-iso10646]: src/sys/arch 2302677
details: https://anonhg.NetBSD.org/src/rev/c85f01366e89
branches: perseant-stdc-iso10646
changeset: 850651:c85f01366e89
user: cherry <cherry%NetBSD.org@localhost>
date: Sun Jul 16 14:02:48 2017 +0000
description:
2302677
diffstat:
sys/arch/i386/i386/genassym.cf | 412 ++++++++++++++
sys/arch/i386/i386/vector.S | 1109 ++++++++++++++++++++++++++++++++++++++++
sys/arch/x86/include/cpu.h | 564 ++++++++++++++++++++
sys/arch/x86/include/intr.h | 229 ++++++++
4 files changed, 2314 insertions(+), 0 deletions(-)
diffs (truncated from 2330 to 300 lines):
diff -r 979849ca94cd -r c85f01366e89 sys/arch/i386/i386/genassym.cf
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/sys/arch/i386/i386/genassym.cf Sun Jul 16 14:02:48 2017 +0000
@@ -0,0 +1,412 @@
+# $NetBSD: genassym.cf,v 1.100.2.2 2017/07/16 14:02:49 cherry Exp $
+
+#
+# Copyright (c) 1998, 2006, 2007, 2008 The NetBSD Foundation, Inc.
+# All rights reserved.
+#
+# This code is derived from software contributed to The NetBSD Foundation
+# by Charles M. Hannum, and by Andrew Doran.
+#
+# 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.
+#
+# THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
+# ``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 FOUNDATION OR CONTRIBUTORS
+# 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.
+#
+
+#
+# Copyright (c) 1982, 1990 The Regents of the University of California.
+# All rights reserved.
+#
+# This code is derived from software contributed to Berkeley by
+# William Jolitz.
+#
+# 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. Neither the name of the University nor the names of its contributors
+# may be used to endorse or promote products derived from this software
+# without specific prior written permission.
+#
+# THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``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 REGENTS OR CONTRIBUTORS 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.
+#
+# @(#)genassym.c 5.11 (Berkeley) 5/10/91
+#
+
+if defined(_KERNEL_OPT)
+include "opt_compat_svr4.h"
+include "opt_compat_freebsd.h"
+include "opt_compat_linux.h"
+include "opt_compat_netbsd.h"
+include "opt_xen.h"
+endif
+
+quote #define __MUTEX_PRIVATE
+quote #define __RWLOCK_PRIVATE
+
+include <sys/param.h>
+include <sys/proc.h>
+include <sys/resourcevar.h>
+include <sys/device.h>
+include <sys/mbuf.h>
+include <sys/mutex.h>
+include <sys/rwlock.h>
+include <sys/cpu.h>
+
+include <netinet/in.h>
+include <netinet/in_systm.h>
+include <netinet/ip.h>
+include <netinet/ip6.h>
+include <netinet/ip_var.h>
+
+include <uvm/uvm.h>
+
+include <machine/trap.h>
+include <machine/pmap.h>
+include <machine/vmparam.h>
+include <machine/intr.h>
+include <machine/types.h>
+include <machine/segments.h>
+
+ifdef XEN
+include <xen/xen-public/sched.h>
+endif
+
+if defined(_KERNEL) && defined(_KERNEL_OPT)
+include "ioapic.h"
+endif
+
+include <compat/sys/signal.h>
+
+ifdef COMPAT_SVR4
+include <compat/svr4/svr4_ucontext.h>
+endif
+
+ifdef COMPAT_LINUX
+include <compat/linux/common/linux_signal.h>
+include <compat/linux/common/linux_machdep.h>
+endif
+
+ifdef COMPAT_FREEBSD
+include <machine/freebsd_machdep.h>
+endif
+
+if NIOAPIC > 0
+include <machine/i82093reg.h>
+include <machine/i82093var.h>
+endif
+
+if defined(_KERNEL) && defined(_KERNEL_OPT)
+include "isa.h"
+endif
+if NISA > 0
+include <machine/isa_machdep.h>
+endif
+
+include <machine/tlog.h>
+
+
+include <sys/bus.h>
+
+define PAGE_SIZE PAGE_SIZE
+
+define LSRUN LSRUN
+define LSONPROC LSONPROC
+
+define UPAGES UPAGES
+define USPACE USPACE
+define KSTACK_SIZE KSTACK_SIZE
+define KERNBASE KERNBASE
+define KERNTEXTOFF KERNTEXTOFF
+
+define PG_RW PG_RW
+define PG_V PG_V
+define PG_KW PG_KW
+define PG_KR PG_KR
+define PGEX_U PGEX_U
+
+define L2_SLOT_KERNBASE pl2_pi(KERNBASE)
+define L1_SLOT_KERNBASE pl1_pi(KERNBASE)
+
+define PDIR_SLOT_PTE PDIR_SLOT_PTE
+define PTE_BASE PTE_BASE
+
+define PDP_SIZE PDP_SIZE
+define PDE_SIZE sizeof(pd_entry_t)
+
+define IOMAPSIZE IOMAPSIZE
+
+define VM_MAXUSER_ADDRESS (int)VM_MAXUSER_ADDRESS
+
+define L_PCB offsetof(struct lwp, l_addr)
+define L_FLAG offsetof(struct lwp, l_flag)
+define L_PROC offsetof(struct lwp, l_proc)
+define L_MD_REGS offsetof(struct lwp, l_md.md_regs)
+define L_CTXSWTCH offsetof(struct lwp, l_ctxswtch)
+define L_MD_ASTPENDING offsetof(struct lwp, l_md.md_astpending)
+define L_CPU offsetof(struct lwp, l_cpu)
+define L_NCSW offsetof(struct lwp, l_ncsw)
+define L_NOPREEMPT offsetof(struct lwp, l_nopreempt)
+define L_DOPREEMPT offsetof(struct lwp, l_dopreempt)
+define L_KPRIORITY offsetof(struct lwp, l_kpriority)
+define P_FLAG offsetof(struct proc, p_flag)
+define P_RASLIST offsetof(struct proc, p_raslist)
+define P_MD_SYSCALL offsetof(struct proc, p_md.md_syscall)
+
+define LW_SYSTEM LW_SYSTEM
+
+define GUFS_SEL GUFS_SEL
+define GUGS_SEL GUGS_SEL
+
+define M_DATA offsetof(struct mbuf, m_data)
+define M_LEN offsetof(struct mbuf, m_len)
+define M_NEXT offsetof(struct mbuf, m_next)
+
+define IP_SRC offsetof(struct ip, ip_src)
+define IP_DST offsetof(struct ip, ip_dst)
+
+define IP6_SRC offsetof(struct ip6_hdr, ip6_src)
+define IP6_DST offsetof(struct ip6_hdr, ip6_dst)
+
+define PCB_CR3 offsetof(struct pcb, pcb_cr3)
+define PCB_EBP offsetof(struct pcb, pcb_ebp)
+define PCB_ESP offsetof(struct pcb, pcb_esp)
+define PCB_ESP0 offsetof(struct pcb, pcb_esp0)
+define PCB_CR0 offsetof(struct pcb, pcb_cr0)
+define PCB_ONFAULT offsetof(struct pcb, pcb_onfault)
+define PCB_FSD offsetof(struct pcb, pcb_fsd)
+define PCB_GSD offsetof(struct pcb, pcb_gsd)
+define PCB_IOMAP offsetof(struct pcb, pcb_iomap)
+
+define TF_CS offsetof(struct trapframe, tf_cs)
+define TF_EIP offsetof(struct trapframe, tf_eip)
+define TF_ERR offsetof(struct trapframe, tf_err)
+define TF_TRAPNO offsetof(struct trapframe, tf_trapno)
+define TF_EFLAGS offsetof(struct trapframe, tf_eflags)
+
+define TF_GS offsetof(struct trapframe, tf_gs)
+define TF_FS offsetof(struct trapframe, tf_fs)
+define TF_ES offsetof(struct trapframe, tf_es)
+define TF_DS offsetof(struct trapframe, tf_ds)
+define TF_EDI offsetof(struct trapframe, tf_edi)
+define TF_ESI offsetof(struct trapframe, tf_esi)
+define TF_EBP offsetof(struct trapframe, tf_ebp)
+define TF_EBX offsetof(struct trapframe, tf_ebx)
+define TF_EDX offsetof(struct trapframe, tf_edx)
+define TF_ECX offsetof(struct trapframe, tf_ecx)
+define TF_EAX offsetof(struct trapframe, tf_eax)
+
+define TF_PUSHSIZE offsetof(struct trapframe, tf_trapno)
+
+define FRAMESIZE sizeof(struct trapframe)
+
+ifdef COMPAT_SVR4
+define SVR4_SIGF_HANDLER offsetof(struct svr4_sigframe, sf_handler)
+define SVR4_SIGF_UC offsetof(struct svr4_sigframe, sf_uc)
+endif
+
+ifdef COMPAT_LINUX
+define LINUX_SIGF_HANDLER offsetof(struct linux_sigframe, sf_handler)
+define LINUX_SIGF_SC offsetof(struct linux_sigframe, sf_sc)
+define LINUX_RT_SIGF_HANDLER offsetof(struct linux_rt_sigframe, sf_handler)
+define LINUX_RT_SIGF_UC offsetof(struct linux_rt_sigframe, sf_uc)
+endif
+
+ifdef COMPAT_FREEBSD
+define FREEBSD_SIGF_HANDLER offsetof(struct freebsd_sigframe, sf_handler)
+define FREEBSD_SIGF_SC offsetof(struct freebsd_sigframe, sf_sc)
+endif
+
+define IH_FUN offsetof(struct intrhand, ih_fun)
+define IH_ARG offsetof(struct intrhand, ih_arg)
+define IH_LEVEL offsetof(struct intrhand, ih_level)
+define IH_NEXT offsetof(struct intrhand, ih_next)
+
+define CPU_INFO_SELF offsetof(struct cpu_info, ci_self)
+define CPU_INFO_RESCHED offsetof(struct cpu_info, ci_want_resched)
+define CPU_INFO_WANT_PMAPLOAD offsetof(struct cpu_info, ci_want_pmapload)
+define CPU_INFO_TLBSTATE offsetof(struct cpu_info, ci_tlbstate)
+define TLBSTATE_VALID TLBSTATE_VALID
+define CPU_INFO_CURLWP offsetof(struct cpu_info, ci_curlwp)
+define CPU_INFO_FPCURLWP offsetof(struct cpu_info, ci_fpcurlwp)
+define CPU_INFO_CURLDT offsetof(struct cpu_info, ci_curldt)
+define CPU_INFO_IDLELWP offsetof(struct cpu_info, ci_data.cpu_idlelwp)
+define CPU_INFO_PMAP offsetof(struct cpu_info, ci_pmap)
+define CPU_INFO_TSS offsetof(struct cpu_info, ci_tss)
+define CPU_INFO_TSS_SEL offsetof(struct cpu_info, ci_tss_sel)
+define CPU_INFO_ESP0 offsetof(struct cpu_info, ci_tss.tss_esp0)
+define CPU_INFO_IOBASE offsetof(struct cpu_info, ci_tss.tss_iobase)
+define CPU_INFO_IOMAP offsetof(struct cpu_info, ci_iomap)
+define IOMAP_INVALOFF IOMAP_INVALOFF
+define CPU_INFO_NSYSCALL offsetof(struct cpu_info, ci_data.cpu_nsyscall)
+define CPU_INFO_NTRAP offsetof(struct cpu_info, ci_data.cpu_ntrap)
+define CPU_INFO_NINTR offsetof(struct cpu_info, ci_data.cpu_nintr)
+define CPU_INFO_CURPRIORITY offsetof(struct cpu_info, ci_schedstate.spc_curpriority)
+define CPU_INFO_CC_SKEW offsetof(struct cpu_info, ci_data.cpu_cc_skew)
+
+
+define CPU_INFO_VENDOR offsetof(struct cpu_info, ci_vendor[0])
+define CPU_INFO_SIGNATURE offsetof(struct cpu_info, ci_signature)
+
+define CPU_TLOG_OFFSET offsetof(struct cpu_info, ci_tlog_offset)
+define CPU_TLOG_BASE offsetof(struct cpu_info, ci_tlog_base)
+
+define CPU_INFO_GDT offsetof(struct cpu_info, ci_gdt)
+define CPU_INFO_IPENDING offsetof(struct cpu_info, ci_ipending)
+define CPU_INFO_IMASK offsetof(struct cpu_info, ci_imask)
+define CPU_INFO_IUNMASK offsetof(struct cpu_info, ci_iunmask)
+define CPU_INFO_ILEVEL offsetof(struct cpu_info, ci_ilevel)
+define CPU_INFO_IDEPTH offsetof(struct cpu_info, ci_idepth)
+define CPU_INFO_ISOURCES offsetof(struct cpu_info, ci_isources)
+define CPU_INFO_MTX_COUNT offsetof(struct cpu_info, ci_mtx_count)
+define CPU_INFO_MTX_OLDSPL offsetof(struct cpu_info, ci_mtx_oldspl)
+define CPU_INFO_INTRSTACK offsetof(struct cpu_info, ci_intrstack)
+define CPU_INFO_ISTATE offsetof(struct cpu_info, ci_istate)
+
+define ACPI_SUSPEND_GDT offsetof(struct cpu_info, ci_suspend_gdt)
Home |
Main Index |
Thread Index |
Old Index