1da673940SJordan Gordeev /* 2da673940SJordan Gordeev * Copyright (c) 2006 The DragonFly Project. All rights reserved. 3da673940SJordan Gordeev * 4da673940SJordan Gordeev * This code is derived from software contributed to The DragonFly Project 5da673940SJordan Gordeev * by Matthew Dillon <dillon@backplane.com> 6da673940SJordan Gordeev * 7da673940SJordan Gordeev * Redistribution and use in source and binary forms, with or without 8da673940SJordan Gordeev * modification, are permitted provided that the following conditions 9da673940SJordan Gordeev * are met: 10da673940SJordan Gordeev * 11da673940SJordan Gordeev * 1. Redistributions of source code must retain the above copyright 12da673940SJordan Gordeev * notice, this list of conditions and the following disclaimer. 13da673940SJordan Gordeev * 2. Redistributions in binary form must reproduce the above copyright 14da673940SJordan Gordeev * notice, this list of conditions and the following disclaimer in 15da673940SJordan Gordeev * the documentation and/or other materials provided with the 16da673940SJordan Gordeev * distribution. 17da673940SJordan Gordeev * 3. Neither the name of The DragonFly Project nor the names of its 18da673940SJordan Gordeev * contributors may be used to endorse or promote products derived 19da673940SJordan Gordeev * from this software without specific, prior written permission. 20da673940SJordan Gordeev * 21da673940SJordan Gordeev * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 22da673940SJordan Gordeev * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 23da673940SJordan Gordeev * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS 24da673940SJordan Gordeev * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE 25da673940SJordan Gordeev * COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, 26da673940SJordan Gordeev * INCIDENTAL, SPECIAL, EXEMPLARY OR CONSEQUENTIAL DAMAGES (INCLUDING, 27da673940SJordan Gordeev * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; 28da673940SJordan Gordeev * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED 29da673940SJordan Gordeev * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, 30da673940SJordan Gordeev * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT 31da673940SJordan Gordeev * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 32da673940SJordan Gordeev * SUCH DAMAGE. 33da673940SJordan Gordeev * 34da673940SJordan Gordeev * $DragonFly: src/sys/platform/vkernel/include/md_var.h,v 1.24 2008/03/20 02:14:54 dillon Exp $ 35da673940SJordan Gordeev */ 36da673940SJordan Gordeev 37da673940SJordan Gordeev #ifndef _MACHINE_MD_VAR_H_ 38da673940SJordan Gordeev #define _MACHINE_MD_VAR_H_ 39da673940SJordan Gordeev 40da673940SJordan Gordeev #ifndef _SYS_TYPES_H_ 41da673940SJordan Gordeev #include <sys/types.h> 42da673940SJordan Gordeev #endif 43da673940SJordan Gordeev #ifndef _SYS_VKERNEL_H_ 44da673940SJordan Gordeev #include <sys/vkernel.h> 45da673940SJordan Gordeev #endif 4686d2b040SAntonio Huete Jimenez #ifndef _NET_ETHERNET_H_ 4786d2b040SAntonio Huete Jimenez #include <net/ethernet.h> 4886d2b040SAntonio Huete Jimenez #endif 49da673940SJordan Gordeev 50da673940SJordan Gordeev #define VKNETIF_MAX 16 51da673940SJordan Gordeev #define VKDISK_MAX 16 522a4f37b8SAntonio Huete Jimenez #define SERNOLEN 30 53da673940SJordan Gordeev 54d3769e83SSascha Wildner #define pagezero(addr) bzero((addr), PAGE_SIZE) 55d3769e83SSascha Wildner 56da673940SJordan Gordeev struct vknetif_info { 57da673940SJordan Gordeev int tap_fd; 58da673940SJordan Gordeev int tap_unit; 59da673940SJordan Gordeev in_addr_t netif_addr; 60da673940SJordan Gordeev in_addr_t netif_mask; 6186d2b040SAntonio Huete Jimenez u_char *enaddr; 62da673940SJordan Gordeev }; 63da673940SJordan Gordeev 64da673940SJordan Gordeev struct vkdisk_info { 65da673940SJordan Gordeev int fd; 66da673940SJordan Gordeev int unit; 6754ea00b8SMatthew Dillon int flags; 6854ea00b8SMatthew Dillon int reserved01; 69da673940SJordan Gordeev enum vkdisk_type { VKD_EMPTY, VKD_DISK, VKD_CD } type; 70da673940SJordan Gordeev char fname[MAXPATHLEN]; 712a4f37b8SAntonio Huete Jimenez char *serno; 72da673940SJordan Gordeev }; 73da673940SJordan Gordeev 74da673940SJordan Gordeev extern char sigcode[]; 75da673940SJordan Gordeev extern int szsigcode; 76da673940SJordan Gordeev extern vpte_t *KernelPTA; /* NOTE: Offset for direct VA translation */ 77da673940SJordan Gordeev extern vpte_t *KernelPTD; 78da673940SJordan Gordeev extern vm_offset_t crashdumpmap; 79da673940SJordan Gordeev extern int cpu_fxsr; 80*c91894e0SMatthew Dillon extern pthread_t ap_tids[MAXCPU]; 81da673940SJordan Gordeev 82da673940SJordan Gordeev extern char cpu_vendor[]; /* XXX belongs in i386 */ 83ea9728caSSepherosa Ziehau extern u_int cpu_vendor_id; /* XXX belongs in i386 */ 84da673940SJordan Gordeev extern u_int cpu_id; /* XXX belongs in i386 */ 85da673940SJordan Gordeev 86da673940SJordan Gordeev extern struct vkdisk_info DiskInfo[VKDISK_MAX]; 87da673940SJordan Gordeev extern int DiskNum; 88da673940SJordan Gordeev extern int MemImageFd; 89da673940SJordan Gordeev extern struct vknetif_info NetifInfo[VKNETIF_MAX]; 90da673940SJordan Gordeev extern int NetifNum; 91da673940SJordan Gordeev extern int _ucodesel, _udatasel; 92da673940SJordan Gordeev 93da673940SJordan Gordeev extern int via_feature_xcrypt; 94da673940SJordan Gordeev extern int via_feature_rng; 95da673940SJordan Gordeev 96da673940SJordan Gordeev struct mdglobaldata; 97da673940SJordan Gordeev struct __mcontext; 98da673940SJordan Gordeev 99da673940SJordan Gordeev vpte_t *pmap_kpte(vm_offset_t va); 100da673940SJordan Gordeev void cpu_gdinit (struct mdglobaldata *gd, int cpu); 101da673940SJordan Gordeev 102da673940SJordan Gordeev void cpu_heavy_restore(void); /* cannot be called from C */ 103da673940SJordan Gordeev void cpu_lwkt_restore(void); /* cannot be called from C */ 104da673940SJordan Gordeev void cpu_idle_restore(void); /* cannot be called from C */ 105da673940SJordan Gordeev void cpu_kthread_restore(void); /* cannot be called from C */ 106cc9b6223SMatthew Dillon thread_t cpu_exit_switch (struct thread *next); 107da673940SJordan Gordeev void cpu_setregs (void); 108da673940SJordan Gordeev void cpu_idle (void); 109da673940SJordan Gordeev void cpu_mask_all_signals (void); 110da673940SJordan Gordeev void cpu_unmask_all_signals (void); 111da673940SJordan Gordeev void go_user (struct intrframe *frame); 112da673940SJordan Gordeev 113da673940SJordan Gordeev void init_exceptions(void); 114da673940SJordan Gordeev void init_kqueue(void); 115da673940SJordan Gordeev void init_fpu(int supports_sse); 116da673940SJordan Gordeev void kern_trap(struct trapframe *); 117da673940SJordan Gordeev void user_trap(struct trapframe *); 118da673940SJordan Gordeev void syscall2 (struct trapframe *); 119da673940SJordan Gordeev void vcons_set_mode(int); 120da673940SJordan Gordeev int npxdna(struct trapframe *); 121da673940SJordan Gordeev void npxpush(struct __mcontext *mctx); 122da673940SJordan Gordeev void npxpop(struct __mcontext *mctx); 123*c91894e0SMatthew Dillon void kqueue_intr(struct intrframe *); 124*c91894e0SMatthew Dillon void vktimer_intr(struct intrframe *); 125da673940SJordan Gordeev 126da673940SJordan Gordeev void signalintr(int intr); 127da673940SJordan Gordeev 128da673940SJordan Gordeev struct kqueue_info; 129da673940SJordan Gordeev struct kqueue_info *kqueue_add(int, void (*)(void *, struct intrframe *), void *); 130da673940SJordan Gordeev void kqueue_del(struct kqueue_info *); 131da673940SJordan Gordeev 132da673940SJordan Gordeev #endif 133