# $NetBSD: genassym.cf,v 1.3.16.8 2008/03/17 09:14:14 yamt Exp $ # # Copyright (c) 1998, 2006, 2007 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. # 3. All advertising materials mentioning features or use of this software # must display the following acknowledgement: # This product includes software developed by the NetBSD # Foundation, Inc. and its contributors. # 4. Neither the name of The NetBSD Foundation 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 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. All advertising materials mentioning features or use of this software # must display the following acknowledgement: # This product includes software developed by the University of # California, Berkeley and its contributors. # 4. 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_netbsd32.h" include "opt_compat_linux32.h" include "opt_multiprocessor.h" include "opt_xen.h" endif quote #define __MUTEX_PRIVATE quote #define __RWLOCK_PRIVATE include include include include include include include include include include include include include include include include include include include include include if defined(COMPAT_NETBSD32) include endif if defined(COMPAT_LINUX32) include endif if defined(_KERNEL) && !defined(_LKM) include "isa.h" include "ioapic.h" endif if NISA > 0 include endif ifdef MULTIPROCESSOR include endif if NIOAPIC > 0 include include endif ifdef XEN include endif include define LSRUN LSRUN define LSONPROC LSONPROC define UPAGES UPAGES define USPACE USPACE define KERNBASE_LO KERNBASE_LO define KERNBASE_HI KERNBASE_HI define KERNBASE KERNBASE define KERNTEXTOFF_LO KERNTEXTOFF_LO define KERNTEXTOFF KERNTEXTOFF define NBPG NBPG define L4_SLOT_KERNBASE L4_SLOT_KERNBASE define L3_SLOT_KERNBASE pl3_pi(KERNBASE) define L2_SLOT_KERNBASE pl2_pi(KERNBASE) define L1_SLOT_KERNBASE pl1_pi(KERNBASE) define PDIR_SLOT_PTE PDIR_SLOT_PTE define VM_MAXUSER_ADDRESS (unsigned long long)VM_MAXUSER_ADDRESS define UVM_PAGE_IDLE_ZERO offsetof(struct uvm, page_idle_zero) define L_ADDR offsetof(struct lwp, l_addr) define L_FLAG offsetof(struct lwp, l_flag) define L_PROC offsetof(struct lwp, l_proc) define L_CTXSWTCH offsetof(struct lwp, l_ctxswtch) define L_NCSW offsetof(struct lwp, l_ncsw) define L_CPU offsetof(struct lwp, l_cpu) define L_MD_REGS offsetof(struct lwp, l_md.md_regs) define L_MD_FLAGS offsetof(struct lwp, l_md.md_flags) define L_MD_ASTPENDING offsetof(struct lwp, l_md.md_astpending) define PAGE_SIZE PAGE_SIZE define MDP_IRET MDP_IRET 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 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 V_TRAP offsetof(struct uvmexp, traps) define V_INTR offsetof(struct uvmexp, intrs) define PCB_CR3 offsetof(struct pcb, pcb_cr3) define PCB_RBP offsetof(struct pcb, pcb_rbp) define PCB_RSP offsetof(struct pcb, pcb_rsp) define PCB_USERSP offsetof(struct pcb, pcb_usersp) define PCB_RSP0 offsetof(struct pcb, pcb_rsp0) define PCB_CR0 offsetof(struct pcb, pcb_cr0) define PCB_ONFAULT offsetof(struct pcb, pcb_onfault) define PCB_FPCPU offsetof(struct pcb, pcb_fpcpu) define TF_RDI offsetof(struct trapframe, tf_rdi) define TF_RSI offsetof(struct trapframe, tf_rsi) define TF_RDX offsetof(struct trapframe, tf_rdx) define TF_RCX offsetof(struct trapframe, tf_rcx) define TF_R8 offsetof(struct trapframe, tf_r8) define TF_R9 offsetof(struct trapframe, tf_r9) define TF_R10 offsetof(struct trapframe, tf_r10) define TF_R11 offsetof(struct trapframe, tf_r11) define TF_R12 offsetof(struct trapframe, tf_r12) define TF_R13 offsetof(struct trapframe, tf_r13) define TF_R14 offsetof(struct trapframe, tf_r14) define TF_R15 offsetof(struct trapframe, tf_r15) define TF_RBP offsetof(struct trapframe, tf_rbp) define TF_RBX offsetof(struct trapframe, tf_rbx) define TF_RAX offsetof(struct trapframe, tf_rax) 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_TRAPNO offsetof(struct trapframe, tf_trapno) define TF_ERR offsetof(struct trapframe, tf_err) define TF_RIP offsetof(struct trapframe, tf_rip) define TF_CS offsetof(struct trapframe, tf_cs) define TF_RFLAGS offsetof(struct trapframe, tf_rflags) define TF_RSP offsetof(struct trapframe, tf_rsp) define TF_SS offsetof(struct trapframe, tf_ss) # Size of stack area needed for saving registers define TF_REGSIZE offsetof(struct trapframe, tf_trapno) # Total size includes regsisters pushed by hardware define FRAMESIZE sizeof(struct trapframe) define CPU_INFO_SCRATCH offsetof(struct cpu_info, ci_scratch) 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_PMAP_CPU offsetof(struct cpu_info, ci_pmap_cpu) define CPU_INFO_TLBSTATE offsetof(struct cpu_info, ci_tlbstate) define TLBSTATE_VALID TLBSTATE_VALID define TLBSTATE_LAZY TLBSTATE_LAZY define TLBSTATE_STALE TLBSTATE_STALE define CPU_INFO_TLB_EVCNT offsetof(struct cpu_info, ci_tlb_evcnt) define CPU_INFO_CURLWP offsetof(struct cpu_info, ci_curlwp) 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_CPUMASK offsetof(struct cpu_info, ci_cpumask) define CPU_INFO_RSP0 offsetof(struct cpu_info, ci_tss.tss_rsp0) define CPU_INFO_CC offsetof(struct cpu_info, ci_cc) define CPU_INFO_NSYSCALL offsetof(struct cpu_info, ci_data.cpu_nsyscall) 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_CPUID offsetof(struct cpu_info, ci_cpuid) define CPU_INFO_ISTATE offsetof(struct cpu_info, ci_istate) define CC_DENOM offsetof(struct cc_microtime_state, cc_denom) define CC_DELTA offsetof(struct cc_microtime_state, cc_denom) define CC_VAL offsetof(struct cc_microtime_state, cc_val) define CC_GEN offsetof(struct cc_microtime_state, cc_gen) define CC_CC offsetof(struct cc_microtime_state, cc_cc) define ACPI_SUSPEND_GDT offsetof(struct cpu_info, ci_suspend_gdt) define ACPI_SUSPEND_IDT offsetof(struct cpu_info, ci_suspend_idt) define ACPI_SUSPEND_TR offsetof(struct cpu_info, ci_suspend_tr) define ACPI_SUSPEND_LDT offsetof(struct cpu_info, ci_suspend_ldt) define ACPI_SUSPEND_FS_BASE_L offsetof(struct cpu_info, ci_suspend_fs_base_l) define ACPI_SUSPEND_FS_BASE_H offsetof(struct cpu_info, ci_suspend_fs_base_h) define ACPI_SUSPEND_GS_BASE_L offsetof(struct cpu_info, ci_suspend_gs_base_l) define ACPI_SUSPEND_GS_BASE_H offsetof(struct cpu_info, ci_suspend_gs_base_h) define ACPI_SUSPEND_GS_KERNELBASE_L offsetof(struct cpu_info, ci_suspend_gs_kernelbase_l) define ACPI_SUSPEND_GS_KERNELBASE_H offsetof(struct cpu_info, ci_suspend_gs_kernelbase_h) define ACPI_SUSPEND_MSR_EFER offsetof(struct cpu_info, ci_suspend_msr_efer) define ACPI_SUSPEND_RBX offsetof(struct cpu_info, ci_suspend_rbx) define ACPI_SUSPEND_RBP offsetof(struct cpu_info, ci_suspend_rbp) define ACPI_SUSPEND_RSP offsetof(struct cpu_info, ci_suspend_rsp) define ACPI_SUSPEND_R12 offsetof(struct cpu_info, ci_suspend_r12) define ACPI_SUSPEND_R13 offsetof(struct cpu_info, ci_suspend_r13) define ACPI_SUSPEND_R14 offsetof(struct cpu_info, ci_suspend_r14) define ACPI_SUSPEND_R15 offsetof(struct cpu_info, ci_suspend_r15) define ACPI_SUSPEND_RFL offsetof(struct cpu_info, ci_suspend_rfl) define ACPI_SUSPEND_CR0 offsetof(struct cpu_info, ci_suspend_cr0) define ACPI_SUSPEND_CR2 offsetof(struct cpu_info, ci_suspend_cr2) define ACPI_SUSPEND_CR3 offsetof(struct cpu_info, ci_suspend_cr3) define ACPI_SUSPEND_CR4 offsetof(struct cpu_info, ci_suspend_cr4) define ACPI_SUSPEND_CR8 offsetof(struct cpu_info, ci_suspend_cr8) if NIOAPIC > 0 define IOAPIC_SC_REG offsetof(struct ioapic_softc, sc_reg) define IOAPIC_SC_DATA offsetof(struct ioapic_softc, sc_data) define PIC_LOCK offsetof(struct pic, pic_lock) 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) ifdef XEN define IH_IPL_NEXT offsetof(struct intrhand, ih_ipl_next) else define IH_NEXT offsetof(struct intrhand, ih_next) endif ifdef COMPAT_NETBSD32 define SC_FS32 offsetof(struct netbsd32_sigcontext, sc_fs) define SC_GS32 offsetof(struct netbsd32_sigcontext, sc_gs) endif ifdef COMPAT_LINUX32 define LINUX32_SF_HANDLER offsetof(struct linux32_sigframe, sf_handler) define LINUX32_SF_SC offsetof(struct linux32_sigframe, sf_sc) define LINUX32_RT_SF_HANDLER offsetof(struct linux32_rt_sigframe, sf_handler) define LINUX32_RT_SF_UC offsetof(struct linux32_rt_sigframe, sf_uc) define LINUX32_SYS_rt_sigreturn LINUX32_SYS_rt_sigreturn define LINUX32_SYS_sigreturn LINUX32_SYS_sigreturn define LINUX32_SYS_exit LINUX32_SYS_netbsd32_exit endif ifdef XEN define SIZEOF_IPLSOURCE sizeof(struct iplsource) define IS_RECURSE offsetof(struct iplsource, ipl_recurse) define IS_RESUME offsetof(struct iplsource, ipl_resume) define IS_HANDLERS offsetof(struct iplsource, ipl_handlers) define EV_EVCNTL offsetof(struct evcnt, ev_count) else define IS_RECURSE offsetof(struct intrsource, is_recurse) define IS_RESUME offsetof(struct intrsource, is_resume) define IS_EVCNT offsetof(struct intrsource, is_evcnt.ev_count) define IS_HANDLERS offsetof(struct intrsource, is_handlers) define IS_PIC offsetof(struct intrsource, is_pic) define IS_FLAGS offsetof(struct intrsource, is_flags) define IS_PIN offsetof(struct intrsource, is_pin) define IS_TYPE offsetof(struct intrsource, is_type) define IS_MAXLEVEL offsetof(struct intrsource, is_maxlevel) define IS_LWP offsetof(struct intrsource, is_lwp) endif define IPL_NONE IPL_NONE define IPL_CLOCK IPL_CLOCK define IPL_HIGH IPL_HIGH define IPL_IPI IPL_IPI define LIR_IPI LIR_IPI define LIR_TIMER LIR_TIMER define SIR_NET SIR_NET define SIR_CLOCK SIR_CLOCK define SIR_SERIAL SIR_SERIAL define IREENT_MAGIC IREENT_MAGIC define PSL_MBO PSL_MBO define MTX_IPL offsetof(struct kmutex, u.s.mtxs_ipl) define MTX_LOCK offsetof(struct kmutex, u.s.mtxs_lock) define MTX_OWNER offsetof(struct kmutex, u.mtxa_owner) define RW_OWNER offsetof(struct krwlock, rw_owner) define RW_WRITE_LOCKED RW_WRITE_LOCKED define RW_WRITE_WANTED RW_WRITE_WANTED define RW_READ_INCR RW_READ_INCR define RW_HAS_WAITERS RW_HAS_WAITERS define RW_THREAD RW_THREAD define RW_READER RW_READER define RW_WRITER RW_WRITER define MB_POINTER offsetof(struct pmap_mbox, mb_pointer) define MB_GLOBAL offsetof(struct pmap_mbox, mb_global) define MB_ADDR1 offsetof(struct pmap_mbox, mb_addr1) define MB_ADDR2 offsetof(struct pmap_mbox, mb_addr2) define MB_HEAD offsetof(struct pmap_mbox, mb_head) define MB_TAIL offsetof(struct pmap_mbox, mb_tail) define PM_CPUS offsetof(struct pmap, pm_cpus) define EV_COUNT offsetof(struct evcnt, ev_count) define OPTERON_MSR_PASSCODE OPTERON_MSR_PASSCODE define X86_BUS_SPACE_IO X86_BUS_SPACE_IO ifdef XEN define EVTCHN_UPCALL_MASK offsetof(struct vcpu_info, evtchn_upcall_mask) define XEN_PT_BASE offsetof(struct start_info, pt_base) define XEN_NR_PT_FRAMES offsetof(struct start_info, nr_pt_frames) define __HYPERVISOR_iret __HYPERVISOR_iret endif define NKL4_KIMG_ENTRIES NKL4_KIMG_ENTRIES define NKL3_KIMG_ENTRIES NKL3_KIMG_ENTRIES define NKL2_KIMG_ENTRIES NKL2_KIMG_ENTRIES define PGOFSET PGOFSET define PGSHIFT PGSHIFT define VM_MIN_KERNEL_ADDRESS_HIGH32 (VM_MIN_KERNEL_ADDRESS >> 32)