/* * VMI interface definition * * Copyright (C) 2005, VMware, Inc. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE, GOOD TITLE or * NON INFRINGEMENT. See the GNU General Public License for more * details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. * * Maintained by: Zachary Amsden zach@vmware.com * */ #include <linux/types.h> /* *--------------------------------------------------------------------- * * VMI Option ROM API * *--------------------------------------------------------------------- */ #define VMI_SIGNATURE 0x696d5663 /* "cVmi" */ #define PCI_VENDOR_ID_VMWARE 0x15AD #define PCI_DEVICE_ID_VMWARE_VMI 0x0801 /* * We use two version numbers for compatibility, with the major * number signifying interface breakages, and the minor number * interface extensions. */ #define VMI_API_REV_MAJOR 3 #define VMI_API_REV_MINOR 0 #define VMI_CALL_CPUID 0 #define VMI_CALL_WRMSR 1 #define VMI_CALL_RDMSR 2 #define VMI_CALL_SetGDT 3 #define VMI_CALL_SetLDT 4 #define VMI_CALL_SetIDT 5 #define VMI_CALL_SetTR 6 #define VMI_CALL_GetGDT 7 #define VMI_CALL_GetLDT 8 #define VMI_CALL_GetIDT 9 #define VMI_CALL_GetTR 10 #define VMI_CALL_WriteGDTEntry 11 #define VMI_CALL_WriteLDTEntry 12 #define VMI_CALL_WriteIDTEntry 13 #define VMI_CALL_UpdateKernelStack 14 #define VMI_CALL_SetCR0 15 #define VMI_CALL_SetCR2 16 #define VMI_CALL_SetCR3 17 #define VMI_CALL_SetCR4 18 #define VMI_CALL_GetCR0 19 #define VMI_CALL_GetCR2 20 #define VMI_CALL_GetCR3 21 #define VMI_CALL_GetCR4 22 #define VMI_CALL_WBINVD 23 #define VMI_CALL_SetDR 24 #define VMI_CALL_GetDR 25 #define VMI_CALL_RDPMC 26 #define VMI_CALL_RDTSC 27 #define VMI_CALL_CLTS 28 #define VMI_CALL_EnableInterrupts 29 #define VMI_CALL_DisableInterrupts 30 #define VMI_CALL_GetInterruptMask 31 #define VMI_CALL_SetInterruptMask 32 #define VMI_CALL_IRET 33 #define VMI_CALL_SYSEXIT 34 #define VMI_CALL_Halt 35 #define VMI_CALL_Reboot 36 #define VMI_CALL_Shutdown 37 #define VMI_CALL_SetPxE 38 #define VMI_CALL_SetPxELong 39 #define VMI_CALL_UpdatePxE 40 #define VMI_CALL_UpdatePxELong 41 #define VMI_CALL_MachineToPhysical 42 #define VMI_CALL_PhysicalToMachine 43 #define VMI_CALL_AllocatePage 44 #define VMI_CALL_ReleasePage 45 #define VMI_CALL_InvalPage 46 #define VMI_CALL_FlushTLB 47 #define VMI_CALL_SetLinearMapping 48 #define VMI_CALL_SetIOPLMask 61 #define VMI_CALL_SetInitialAPState 62 #define VMI_CALL_APICWrite 63 #define VMI_CALL_APICRead 64 #define VMI_CALL_IODelay 65 #define VMI_CALL_SetLazyMode 73 /* *--------------------------------------------------------------------- * * MMU operation flags * *--------------------------------------------------------------------- */ /* Flags used by VMI_{Allocate|Release}Page call */ #define VMI_PAGE_PAE 0x10 /* Allocate PAE shadow */ #define VMI_PAGE_CLONE 0x20 /* Clone from another shadow */ #define VMI_PAGE_ZEROED 0x40 /* Page is pre-zeroed */ /* Flags shared by Allocate|Release Page and PTE updates */ #define VMI_PAGE_PT 0x01 #define VMI_PAGE_PD 0x02 #define VMI_PAGE_PDP 0x04 #define VMI_PAGE_PML4 0x08 #define VMI_PAGE_NORMAL 0x00 /* for debugging */ /* Flags used by PTE updates */ #define VMI_PAGE_CURRENT_AS 0x10 /* implies VMI_PAGE_VA_MASK is valid */ #define VMI_PAGE_DEFER 0x20 /* may queue update until TLB inval */ #define VMI_PAGE_VA_MASK 0xfffff000 #ifdef CONFIG_X86_PAE #define VMI_PAGE_L1 (VMI_PAGE_PT | VMI_PAGE_PAE | VMI_PAGE_ZEROED) #define VMI_PAGE_L2 (VMI_PAGE_PD | VMI_PAGE_PAE | VMI_PAGE_ZEROED) #else #define VMI_PAGE_L1 (VMI_PAGE_PT | VMI_PAGE_ZEROED) #define VMI_PAGE_L2 (VMI_PAGE_PD | VMI_PAGE_ZEROED) #endif /* Flags used by VMI_FlushTLB call */ #define VMI_FLUSH_TLB 0x01 #define VMI_FLUSH_GLOBAL 0x02 /* *--------------------------------------------------------------------- * * VMI relocation definitions for ROM call get_reloc * *--------------------------------------------------------------------- */ /* VMI Relocation types */ #define VMI_RELOCATION_NONE 0 #define VMI_RELOCATION_CALL_REL 1 #define VMI_RELOCATION_JUMP_REL 2 #define VMI_RELOCATION_NOP 3 #ifndef __ASSEMBLY__ struct vmi_relocation_info { unsigned char *eip; unsigned char type; unsigned char reserved[3]; }; #endif /* *--------------------------------------------------------------------- * * Generic ROM structures and definitions * *--------------------------------------------------------------------- */ #ifndef __ASSEMBLY__ struct vrom_header { u16 rom_signature; // option ROM signature u8 rom_length; // ROM length in 512 byte chunks u8 rom_entry[4]; // 16-bit code entry point u8 rom_pad0; // 4-byte align pad u32 vrom_signature; // VROM identification signature u8 api_version_min;// Minor version of API u8 api_version_maj;// Major version of API u8 jump_slots; // Number of jump slots u8 reserved1; // Reserved for expansion u32 virtual_top; // Hypervisor virtual address start u16 reserved2; // Reserved for expansion u16 license_offs; // Offset to License string u16 pci_header_offs;// Offset to PCI OPROM header u16 pnp_header_offs;// Offset to PnP OPROM header u32 rom_pad3; // PnP reserverd / VMI reserved u8 reserved[96]; // Reserved for headers char vmi_init[8]; // VMI_Init jump point char get_reloc[8]; // VMI_GetRelocationInfo jump point } __attribute__((packed)); struct pnp_header { char sig[4]; char rev; char size; short next; short res; long devID; unsigned short manufacturer_offset; unsigned short product_offset; } __attribute__((packed)); struct pci_header { char sig[4]; short vendorID; short deviceID; short vpdData; short size; char rev; char class; char subclass; char interface; short chunks; char rom_version_min; char rom_version_maj; char codetype; char lastRom; short reserved; } __attribute__((packed)); /* Function prototypes for bootstrapping */ extern void vmi_init(void); extern void vmi_bringup(void); extern void vmi_apply_boot_page_allocations(void); /* State needed to start an application processor in an SMP system. */ struct vmi_ap_state { u32 cr0; u32 cr2; u32 cr3; u32 cr4; u64 efer; u32 eip; u32 eflags; u32 eax; u32 ebx; u32 ecx; u32 edx; u32 esp; u32 ebp; u32 esi; u32 edi; u16 cs; u16 ss; u16 ds; u16 es; u16 fs; u16 gs; u16 ldtr; u16 gdtr_limit; u32 gdtr_base; u32 idtr_base; u16 idtr_limit; }; #endif