/* SPDX-License-Identifier: GPL-2.0 */ /****************************************************************************** * x86_emulate.h * * Generic x86 (32-bit and 64-bit) instruction decoder and emulator. * * Copyright (c) 2005 Keir Fraser * * From: xen-unstable 10676:af9809f51f81a3c43f276f00c81a52ef558afda4 */ #ifndef _ASM_X86_KVM_X86_EMULATE_H #define _ASM_X86_KVM_X86_EMULATE_H #include <asm/desc_defs.h> struct x86_emulate_ctxt; enum x86_intercept; enum x86_intercept_stage; struct x86_exception { u8 vector; bool error_code_valid; u16 error_code; bool nested_page_fault; u64 address; /* cr2 or nested page fault gpa */ u8 async_page_fault; }; /* * This struct is used to carry enough information from the instruction * decoder to main KVM so that a decision can be made whether the * instruction needs to be intercepted or not. */ struct x86_instruction_info { u8 intercept; /* which intercept */ u8 rep_prefix; /* rep prefix? */ u8 modrm_mod; /* mod part of modrm */ u8 modrm_reg; /* index of register used */ u8 modrm_rm; /* rm part of modrm */ u64 src_val; /* value of source operand */ u64 dst_val; /* value of destination operand */ u8 src_bytes; /* size of source operand */ u8 dst_bytes; /* size of destination operand */ u8 ad_bytes; /* size of src/dst address */ u64 next_rip; /* rip following the instruction */ }; /* * x86_emulate_ops: * * These operations represent the instruction emulator's interface to memory. * There are two categories of operation: those that act on ordinary memory * regions (*_std), and those that act on memory regions known to require * special treatment or emulation (*_emulated). * * The emulator assumes that an instruction accesses only one 'emulated memory' * location, that this location is the given linear faulting address (cr2), and * that this is one of the instruction's data operands. Instruction fetches and * stack operations are assumed never to access emulated memory. The emulator * automatically deduces which operand of a string-move operation is accessing * emulated memory, and assumes that the other operand accesses normal memory. * * NOTES: * 1. The emulator isn't very smart about emulated vs. standard memory. * 'Emulated memory' access addresses should be checked for sanity. * 'Normal memory' accesses may fault, and the caller must arrange to * detect and handle reentrancy into the emulator via recursive faults. * Accesses may be unaligned and may cross page boundaries. * 2. If the access fails (cannot emulate, or a standard access faults) then * it is up to the memop to propagate the fault to the guest VM via * some out-of-band mechanism, unknown to the emulator. The memop signals * failure by returning X86EMUL_PROPAGATE_FAULT to the emulator, which will * then immediately bail. * 3. Valid access sizes are 1, 2, 4 and 8 bytes. On x86/32 systems only * cmpxchg8b_emulated need support 8-byte accesses. * 4. The emulator cannot handle 64-bit mode emulation on an x86/32 system. */ /* Access completed successfully: continue emulation as normal. */ #define X86EMUL_CONTINUE 0 /* Access is unhandleable: bail from emulation and return error to caller. */ #define X86EMUL_UNHANDLEABLE 1 /* Terminate emulation but return success to the caller. */ #define X86EMUL_PROPAGATE_FAULT 2 /* propagate a generated fault to guest */ #define X86EMUL_RETRY_INSTR 3 /* retry the instruction for some reason */ #define X86EMUL_CMPXCHG_FAILED 4 /* cmpxchg did not see expected value */ #define X86EMUL_IO_NEEDED 5 /* IO is needed to complete emulation */ #define X86EMUL_INTERCEPTED 6 /* Intercepted by nested VMCB/VMCS */ struct x86_emulate_ops { /* * read_gpr: read a general purpose register (rax - r15) * * @reg: gpr number. */ ulong (*read_gpr)(struct x86_emulate_ctxt *ctxt, unsigned reg); /* * write_gpr: write a general purpose register (rax - r15) * * @reg: gpr number. * @val: value to write. */ void (*write_gpr)(struct x86_emulate_ctxt *ctxt, unsigned reg, ulong val); /* * read_std: Read bytes of standard (non-emulated/special) memory. * Used for descriptor reading. * @addr: [IN ] Linear address from which to read. * @val: [OUT] Value read from memory, zero-extended to 'u_long'. * @bytes: [IN ] Number of bytes to read from memory. * @system:[IN ] Whether the access is forced to be at CPL0. */ int (*read_std)(struct x86_emulate_ctxt *ctxt, unsigned long addr, void *val, unsigned int bytes, struct x86_exception *fault, bool system); /* * read_phys: Read bytes of standard (non-emulated/special) memory. * Used for descriptor reading. * @addr: [IN ] Physical address from which to read. * @val: [OUT] Value read from memory. * @bytes: [IN ] Number of bytes to read from memory. */ int (*read_phys)(struct x86_emulate_ctxt *ctxt, unsigned long addr, void *val, unsigned int bytes); /* * write_std: Write bytes of standard (non-emulated/special) memory. * Used for descriptor writing. * @addr: [IN ] Linear address to which to write. * @val: [OUT] Value write to memory, zero-extended to 'u_long'. * @bytes: [IN ] Number of bytes to write to memory. * @system:[IN ] Whether the access is forced to be at CPL0. */ int (*write_std)(struct x86_emulate_ctxt *ctxt, unsigned long addr, void *val, unsigned int bytes, struct x86_exception *fault, bool system); /* * fetch: Read bytes of standard (non-emulated/special) memory. * Used for instruction fetch. * @addr: [IN ] Linear address from which to read. * @val: [OUT] Value read from memory, zero-extended to 'u_long'. * @bytes: [IN ] Number of bytes to read from memory. */ int (*fetch)(struct x86_emulate_ctxt *ctxt, unsigned long addr, void *val, unsigned int bytes, struct x86_exception *fault); /* * read_emulated: Read bytes from emulated/special memory area. * @addr: [IN ] Linear address from which to read. * @val: [OUT] Value read from memory, zero-extended to 'u_long'. * @bytes: [IN ] Number of bytes to read from memory. */ int (*read_emulated)(struct x86_emulate_ctxt *ctxt, unsigned long addr, void *val, unsigned int bytes, struct x86_exception *fault); /* * write_emulated: Write bytes to emulated/special memory area. * @addr: [IN ] Linear address to which to write. * @val: [IN ] Value to write to memory (low-order bytes used as * required). * @bytes: [IN ] Number of bytes to write to memory. */ int (*write_emulated)(struct x86_emulate_ctxt *ctxt, unsigned long addr, const void *val, unsigned int bytes, struct x86_exception *fault); /* * cmpxchg_emulated: Emulate an atomic (LOCKed) CMPXCHG operation on an * emulated/special memory area. * @addr: [IN ] Linear address to access. * @old: [IN ] Value expected to be current at @addr. * @new: [IN ] Value to write to @addr. * @bytes: [IN ] Number of bytes to access using CMPXCHG. */ int (*cmpxchg_emulated)(struct x86_emulate_ctxt *ctxt, unsigned long addr, const void *old, const void *new, unsigned int bytes, struct x86_exception *fault); void (*invlpg)(struct x86_emulate_ctxt *ctxt, ulong addr); int (*pio_in_emulated)(struct x86_emulate_ctxt *ctxt, int size, unsigned short port, void *val, unsigned int count); int (*pio_out_emulated)(struct x86_emulate_ctxt *ctxt, int size, unsigned short port, const void *val, unsigned int count); bool (*get_segment)(struct x86_emulate_ctxt *ctxt, u16 *selector, struct desc_struct *desc, u32 *base3, int seg); void (*set_segment)(struct x86_emulate_ctxt *ctxt, u16 selector, struct desc_struct *desc, u32 base3, int seg); unsigned long (*get_cached_segment_base)(struct x86_emulate_ctxt *ctxt, int seg); void (*get_gdt)(struct x86_emulate_ctxt *ctxt, struct desc_ptr *dt); void (*get_idt)(struct x86_emulate_ctxt *ctxt, struct desc_ptr *dt); void (*set_gdt)(struct x86_emulate_ctxt *ctxt, struct desc_ptr *dt); void (*set_idt)(struct x86_emulate_ctxt *ctxt, struct desc_ptr *dt); ulong (*get_cr)(struct x86_emulate_ctxt *ctxt, int cr); int (*set_cr)(struct x86_emulate_ctxt *ctxt, int cr, ulong val); int (*cpl)(struct x86_emulate_ctxt *ctxt); int (*get_dr)(struct x86_emulate_ctxt *ctxt, int dr, ulong *dest); int (*set_dr)(struct x86_emulate_ctxt *ctxt, int dr, ulong value); u64 (*get_smbase)(struct x86_emulate_ctxt *ctxt); void (*set_smbase)(struct x86_emulate_ctxt *ctxt, u64 smbase); int (*set_msr)(struct x86_emulate_ctxt *ctxt, u32 msr_index, u64 data); int (*get_msr)(struct x86_emulate_ctxt *ctxt, u32 msr_index, u64 *pdata); int (*check_pmc)(struct x86_emulate_ctxt *ctxt, u32 pmc); int (*read_pmc)(struct x86_emulate_ctxt *ctxt, u32 pmc, u64 *pdata); void (*halt)(struct x86_emulate_ctxt *ctxt); void (*wbinvd)(struct x86_emulate_ctxt *ctxt); int (*fix_hypercall)(struct x86_emulate_ctxt *ctxt); int (*intercept)(struct x86_emulate_ctxt *ctxt, struct x86_instruction_info *info, enum x86_intercept_stage stage); bool (*get_cpuid)(struct x86_emulate_ctxt *ctxt, u32 *eax, u32 *ebx, u32 *ecx, u32 *edx, bool check_limit); void (*set_nmi_mask)(struct x86_emulate_ctxt *ctxt, bool masked); unsigned (*get_hflags)(struct x86_emulate_ctxt *ctxt); void (*set_hflags)(struct x86_emulate_ctxt *ctxt, unsigned hflags); int (*pre_leave_smm)(struct x86_emulate_ctxt *ctxt, u64 smbase); }; typedef u32 __attribute__((vector_size(16))) sse128_t; /* Type, address-of, and value of an instruction's operand. */ struct operand { enum { OP_REG, OP_MEM, OP_MEM_STR, OP_IMM, OP_XMM, OP_MM, OP_NONE } type; unsigned int bytes; unsigned int count; union { unsigned long orig_val; u64 orig_val64; }; union { unsigned long *reg; struct segmented_address { ulong ea; unsigned seg; } mem; unsigned xmm; unsigned mm; } addr; union { unsigned long val; u64 val64; char valptr[sizeof(sse128_t)]; sse128_t vec_val; u64 mm_val; void *data; }; }; struct fetch_cache { u8 data[15]; u8 *ptr; u8 *end; }; struct read_cache { u8 data[1024]; unsigned long pos; unsigned long end; }; /* Execution mode, passed to the emulator. */ enum x86emul_mode { X86EMUL_MODE_REAL, /* Real mode. */ X86EMUL_MODE_VM86, /* Virtual 8086 mode. */ X86EMUL_MODE_PROT16, /* 16-bit protected mode. */ X86EMUL_MODE_PROT32, /* 32-bit protected mode. */ X86EMUL_MODE_PROT64, /* 64-bit (long) mode. */ }; /* These match some of the HF_* flags defined in kvm_host.h */ #define X86EMUL_GUEST_MASK (1 << 5) /* VCPU is in guest-mode */ #define X86EMUL_SMM_MASK (1 << 6) #define X86EMUL_SMM_INSIDE_NMI_MASK (1 << 7) struct x86_emulate_ctxt { const struct x86_emulate_ops *ops; /* Register state before/after emulation. */ unsigned long eflags; unsigned long eip; /* eip before instruction emulation */ /* Emulated execution mode, represented by an X86EMUL_MODE value. */ enum x86emul_mode mode; /* interruptibility state, as a result of execution of STI or MOV SS */ int interruptibility; bool perm_ok; /* do not check permissions if true */ bool ud; /* inject an #UD if host doesn't support insn */ bool tf; /* TF value before instruction (after for syscall/sysret) */ bool have_exception; struct x86_exception exception; /* * decode cache */ /* current opcode length in bytes */ u8 opcode_len; u8 b; u8 intercept; u8 op_bytes; u8 ad_bytes; struct operand src; struct operand src2; struct operand dst; int (*execute)(struct x86_emulate_ctxt *ctxt); int (*check_perm)(struct x86_emulate_ctxt *ctxt); /* * The following six fields are cleared together, * the rest are initialized unconditionally in x86_decode_insn * or elsewhere */ bool rip_relative; u8 rex_prefix; u8 lock_prefix; u8 rep_prefix; /* bitmaps of registers in _regs[] that can be read */ u32 regs_valid; /* bitmaps of registers in _regs[] that have been written */ u32 regs_dirty; /* modrm */ u8 modrm; u8 modrm_mod; u8 modrm_reg; u8 modrm_rm; u8 modrm_seg; u8 seg_override; u64 d; unsigned long _eip; struct operand memop; /* Fields above regs are cleared together. */ unsigned long _regs[NR_VCPU_REGS]; struct operand *memopp; struct fetch_cache fetch; struct read_cache io_read; struct read_cache mem_read; }; /* Repeat String Operation Prefix */ #define REPE_PREFIX 0xf3 #define REPNE_PREFIX 0xf2 /* CPUID vendors */ #define X86EMUL_CPUID_VENDOR_AuthenticAMD_ebx 0x68747541 #define X86EMUL_CPUID_VENDOR_AuthenticAMD_ecx 0x444d4163 #define X86EMUL_CPUID_VENDOR_AuthenticAMD_edx 0x69746e65 #define X86EMUL_CPUID_VENDOR_AMDisbetterI_ebx 0x69444d41 #define X86EMUL_CPUID_VENDOR_AMDisbetterI_ecx 0x21726574 #define X86EMUL_CPUID_VENDOR_AMDisbetterI_edx 0x74656273 #define X86EMUL_CPUID_VENDOR_GenuineIntel_ebx 0x756e6547 #define X86EMUL_CPUID_VENDOR_GenuineIntel_ecx 0x6c65746e #define X86EMUL_CPUID_VENDOR_GenuineIntel_edx 0x49656e69 enum x86_intercept_stage { X86_ICTP_NONE = 0, /* Allow zero-init to not match anything */ X86_ICPT_PRE_EXCEPT, X86_ICPT_POST_EXCEPT, X86_ICPT_POST_MEMACCESS, }; enum x86_intercept { x86_intercept_none, x86_intercept_cr_read, x86_intercept_cr_write, x86_intercept_clts, x86_intercept_lmsw, x86_intercept_smsw, x86_intercept_dr_read, x86_intercept_dr_write, x86_intercept_lidt, x86_intercept_sidt, x86_intercept_lgdt, x86_intercept_sgdt, x86_intercept_lldt, x86_intercept_sldt, x86_intercept_ltr, x86_intercept_str, x86_intercept_rdtsc, x86_intercept_rdpmc, x86_intercept_pushf, x86_intercept_popf, x86_intercept_cpuid, x86_intercept_rsm, x86_intercept_iret, x86_intercept_intn, x86_intercept_invd, x86_intercept_pause, x86_intercept_hlt, x86_intercept_invlpg, x86_intercept_invlpga, x86_intercept_vmrun, x86_intercept_vmload, x86_intercept_vmsave, x86_intercept_vmmcall, x86_intercept_stgi, x86_intercept_clgi, x86_intercept_skinit, x86_intercept_rdtscp, x86_intercept_icebp, x86_intercept_wbinvd, x86_intercept_monitor, x86_intercept_mwait, x86_intercept_rdmsr, x86_intercept_wrmsr, x86_intercept_in, x86_intercept_ins, x86_intercept_out, x86_intercept_outs, nr_x86_intercepts }; /* Host execution mode. */ #if defined(CONFIG_X86_32) #define X86EMUL_MODE_HOST X86EMUL_MODE_PROT32 #elif defined(CONFIG_X86_64) #define X86EMUL_MODE_HOST X86EMUL_MODE_PROT64 #endif int x86_decode_insn(struct x86_emulate_ctxt *ctxt, void *insn, int insn_len); bool x86_page_table_writing_insn(struct x86_emulate_ctxt *ctxt); #define EMULATION_FAILED -1 #define EMULATION_OK 0 #define EMULATION_RESTART 1 #define EMULATION_INTERCEPTED 2 void init_decode_cache(struct x86_emulate_ctxt *ctxt); int x86_emulate_insn(struct x86_emulate_ctxt *ctxt); int emulator_task_switch(struct x86_emulate_ctxt *ctxt, u16 tss_selector, int idt_index, int reason, bool has_error_code, u32 error_code); int emulate_int_real(struct x86_emulate_ctxt *ctxt, int irq); void emulator_invalidate_register_cache(struct x86_emulate_ctxt *ctxt); void emulator_writeback_register_cache(struct x86_emulate_ctxt *ctxt); bool emulator_can_use_gpa(struct x86_emulate_ctxt *ctxt); #endif /* _ASM_X86_KVM_X86_EMULATE_H */
Name | Type | Size | Permission | Actions |
---|---|---|---|---|
crypto | Folder | 0755 |
|
|
e820 | Folder | 0755 |
|
|
fpu | Folder | 0755 |
|
|
numachip | Folder | 0755 |
|
|
trace | Folder | 0755 |
|
|
uv | Folder | 0755 |
|
|
xen | Folder | 0755 |
|
|
Kbuild | File | 294 B | 0644 |
|
a.out-core.h | File | 1.89 KB | 0644 |
|
acenv.h | File | 1.56 KB | 0644 |
|
acpi.h | File | 4.76 KB | 0644 |
|
agp.h | File | 1.04 KB | 0644 |
|
alternative-asm.h | File | 2.43 KB | 0644 |
|
alternative.h | File | 8.28 KB | 0644 |
|
amd_nb.h | File | 2.98 KB | 0644 |
|
apb_timer.h | File | 1.43 KB | 0644 |
|
apic.h | File | 14.53 KB | 0644 |
|
apic_flat_64.h | File | 151 B | 0644 |
|
apicdef.h | File | 11.26 KB | 0644 |
|
apm.h | File | 1.8 KB | 0644 |
|
arch_hweight.h | File | 1.28 KB | 0644 |
|
archrandom.h | File | 3.03 KB | 0644 |
|
asm-offsets.h | File | 35 B | 0644 |
|
asm-prototypes.h | File | 946 B | 0644 |
|
asm.h | File | 4.97 KB | 0644 |
|
atomic.h | File | 6.02 KB | 0644 |
|
atomic64_32.h | File | 8.71 KB | 0644 |
|
atomic64_64.h | File | 6.31 KB | 0644 |
|
barrier.h | File | 3.6 KB | 0644 |
|
bios_ebda.h | File | 914 B | 0644 |
|
bitops.h | File | 13.78 KB | 0644 |
|
boot.h | File | 1.53 KB | 0644 |
|
bootparam_utils.h | File | 2.86 KB | 0644 |
|
bug.h | File | 2.07 KB | 0644 |
|
bugs.h | File | 493 B | 0644 |
|
cache.h | File | 641 B | 0644 |
|
cacheflush.h | File | 306 B | 0644 |
|
cacheinfo.h | File | 209 B | 0644 |
|
calgary.h | File | 2.31 KB | 0644 |
|
ce4100.h | File | 121 B | 0644 |
|
checksum.h | File | 133 B | 0644 |
|
checksum_32.h | File | 4.86 KB | 0644 |
|
checksum_64.h | File | 5.41 KB | 0644 |
|
clocksource.h | File | 488 B | 0644 |
|
cmdline.h | File | 302 B | 0644 |
|
cmpxchg.h | File | 7.68 KB | 0644 |
|
cmpxchg_32.h | File | 3.15 KB | 0644 |
|
cmpxchg_64.h | File | 543 B | 0644 |
|
compat.h | File | 7.37 KB | 0644 |
|
cpu.h | File | 975 B | 0644 |
|
cpu_device_id.h | File | 1.38 KB | 0644 |
|
cpu_entry_area.h | File | 2.27 KB | 0644 |
|
cpufeature.h | File | 7.75 KB | 0644 |
|
cpufeatures.h | File | 24.62 KB | 0644 |
|
cpumask.h | File | 408 B | 0644 |
|
crash.h | File | 320 B | 0644 |
|
current.h | File | 443 B | 0644 |
|
debugreg.h | File | 2.67 KB | 0644 |
|
delay.h | File | 208 B | 0644 |
|
desc.h | File | 11.42 KB | 0644 |
|
desc_defs.h | File | 3.16 KB | 0644 |
|
device.h | File | 568 B | 0644 |
|
disabled-features.h | File | 2.31 KB | 0644 |
|
div64.h | File | 1.79 KB | 0644 |
|
dma-mapping.h | File | 2.4 KB | 0644 |
|
dma.h | File | 9.58 KB | 0644 |
|
dmi.h | File | 556 B | 0644 |
|
dwarf2.h | File | 2.43 KB | 0644 |
|
edac.h | File | 474 B | 0644 |
|
efi.h | File | 6.9 KB | 0644 |
|
elf.h | File | 10.82 KB | 0644 |
|
emergency-restart.h | File | 202 B | 0644 |
|
entry_arch.h | File | 1.88 KB | 0644 |
|
espfix.h | File | 426 B | 0644 |
|
exec.h | File | 37 B | 0644 |
|
export.h | File | 120 B | 0644 |
|
extable.h | File | 1.27 KB | 0644 |
|
fb.h | File | 540 B | 0644 |
|
fixmap.h | File | 6.04 KB | 0644 |
|
floppy.h | File | 6.59 KB | 0644 |
|
frame.h | File | 815 B | 0644 |
|
ftrace.h | File | 1.8 KB | 0644 |
|
futex.h | File | 2.2 KB | 0644 |
|
gart.h | File | 2.64 KB | 0644 |
|
genapic.h | File | 22 B | 0644 |
|
geode.h | File | 842 B | 0644 |
|
hardirq.h | File | 2.3 KB | 0644 |
|
highmem.h | File | 2.6 KB | 0644 |
|
hpet.h | File | 3.38 KB | 0644 |
|
hugetlb.h | File | 2.15 KB | 0644 |
|
hw_breakpoint.h | File | 1.96 KB | 0644 |
|
hw_irq.h | File | 3.85 KB | 0644 |
|
hypervisor.h | File | 1.84 KB | 0644 |
|
i8259.h | File | 1.93 KB | 0644 |
|
ia32.h | File | 1.46 KB | 0644 |
|
ia32_unistd.h | File | 313 B | 0644 |
|
imr.h | File | 1.81 KB | 0644 |
|
inat.h | File | 6.58 KB | 0644 |
|
inat_types.h | File | 1013 B | 0644 |
|
init.h | File | 632 B | 0644 |
|
insn-eval.h | File | 837 B | 0644 |
|
insn.h | File | 7.46 KB | 0644 |
|
inst.h | File | 5.07 KB | 0644 |
|
intel-family.h | File | 3.29 KB | 0644 |
|
intel-mid.h | File | 4.91 KB | 0644 |
|
intel_ds.h | File | 793 B | 0644 |
|
intel_mid_vrtc.h | File | 326 B | 0644 |
|
intel_pmc_ipc.h | File | 2.08 KB | 0644 |
|
intel_pt.h | File | 292 B | 0644 |
|
intel_punit_ipc.h | File | 4.56 KB | 0644 |
|
intel_rdt_sched.h | File | 2.59 KB | 0644 |
|
intel_scu_ipc.h | File | 2.3 KB | 0644 |
|
intel_telemetry.h | File | 3.96 KB | 0644 |
|
invpcid.h | File | 1.57 KB | 0644 |
|
io.h | File | 12.21 KB | 0644 |
|
io_apic.h | File | 5.63 KB | 0644 |
|
iomap.h | File | 1.22 KB | 0644 |
|
iommu.h | File | 392 B | 0644 |
|
iommu_table.h | File | 3.82 KB | 0644 |
|
iosf_mbi.h | File | 5.74 KB | 0644 |
|
ipi.h | File | 2.84 KB | 0644 |
|
irq.h | File | 1.12 KB | 0644 |
|
irq_regs.h | File | 679 B | 0644 |
|
irq_remapping.h | File | 2.96 KB | 0644 |
|
irq_vectors.h | File | 4.12 KB | 0644 |
|
irq_work.h | File | 397 B | 0644 |
|
irqdomain.h | File | 1.61 KB | 0644 |
|
irqflags.h | File | 4.38 KB | 0644 |
|
ist.h | File | 735 B | 0644 |
|
jump_label.h | File | 2.44 KB | 0644 |
|
kasan.h | File | 966 B | 0644 |
|
kaslr.h | File | 424 B | 0644 |
|
kbdleds.h | File | 454 B | 0644 |
|
kdebug.h | File | 752 B | 0644 |
|
kexec-bzimage64.h | File | 189 B | 0644 |
|
kexec.h | File | 6.69 KB | 0644 |
|
kgdb.h | File | 2.09 KB | 0644 |
|
kmap_types.h | File | 289 B | 0644 |
|
kprobes.h | File | 3.82 KB | 0644 |
|
kvm_emulate.h | File | 15.23 KB | 0644 |
|
kvm_guest.h | File | 172 B | 0644 |
|
kvm_host.h | File | 42.72 KB | 0644 |
|
kvm_page_track.h | File | 2.48 KB | 0644 |
|
kvm_para.h | File | 3 KB | 0644 |
|
kvmclock.h | File | 170 B | 0644 |
|
linkage.h | File | 581 B | 0644 |
|
livepatch.h | File | 1.12 KB | 0644 |
|
local.h | File | 3.83 KB | 0644 |
|
local64.h | File | 33 B | 0644 |
|
mach_timer.h | File | 1.55 KB | 0644 |
|
mach_traps.h | File | 1013 B | 0644 |
|
math_emu.h | File | 395 B | 0644 |
|
mc146818rtc.h | File | 2.76 KB | 0644 |
|
mce.h | File | 12.54 KB | 0644 |
|
mem_encrypt.h | File | 2.83 KB | 0644 |
|
microcode.h | File | 4.14 KB | 0644 |
|
microcode_amd.h | File | 1.41 KB | 0644 |
|
microcode_intel.h | File | 2.46 KB | 0644 |
|
misc.h | File | 143 B | 0644 |
|
mmconfig.h | File | 374 B | 0644 |
|
mmu.h | File | 1.57 KB | 0644 |
|
mmu_context.h | File | 10.27 KB | 0644 |
|
mmx.h | File | 337 B | 0644 |
|
mmzone.h | File | 129 B | 0644 |
|
mmzone_32.h | File | 1.16 KB | 0644 |
|
mmzone_64.h | File | 430 B | 0644 |
|
module.h | File | 2.05 KB | 0644 |
|
mpspec.h | File | 3.93 KB | 0644 |
|
mpspec_def.h | File | 3.93 KB | 0644 |
|
mpx.h | File | 2.97 KB | 0644 |
|
mshyperv.h | File | 10.69 KB | 0644 |
|
msi.h | File | 392 B | 0644 |
|
msidef.h | File | 1.77 KB | 0644 |
|
msr-index.h | File | 30.36 KB | 0644 |
|
msr-trace.h | File | 1.35 KB | 0644 |
|
msr.h | File | 10.85 KB | 0644 |
|
mtrr.h | File | 4.62 KB | 0644 |
|
mwait.h | File | 3.74 KB | 0644 |
|
nmi.h | File | 1.39 KB | 0644 |
|
nops.h | File | 4.31 KB | 0644 |
|
nospec-branch.h | File | 10.87 KB | 0644 |
|
numa.h | File | 2.18 KB | 0644 |
|
numa_32.h | File | 256 B | 0644 |
|
olpc.h | File | 3.16 KB | 0644 |
|
olpc_ofw.h | File | 1.1 KB | 0644 |
|
orc_lookup.h | File | 1.63 KB | 0644 |
|
orc_types.h | File | 3.47 KB | 0644 |
|
page.h | File | 2.18 KB | 0644 |
|
page_32.h | File | 1.01 KB | 0644 |
|
page_32_types.h | File | 1.7 KB | 0644 |
|
page_64.h | File | 1.42 KB | 0644 |
|
page_64_types.h | File | 2.34 KB | 0644 |
|
page_types.h | File | 2.29 KB | 0644 |
|
paravirt.h | File | 23.31 KB | 0644 |
|
paravirt_types.h | File | 22.15 KB | 0644 |
|
parport.h | File | 314 B | 0644 |
|
pat.h | File | 768 B | 0644 |
|
pci-direct.h | File | 995 B | 0644 |
|
pci-functions.h | File | 654 B | 0644 |
|
pci.h | File | 3.51 KB | 0644 |
|
pci_64.h | File | 684 B | 0644 |
|
pci_x86.h | File | 5.71 KB | 0644 |
|
percpu.h | File | 18.97 KB | 0644 |
|
perf_event.h | File | 8.82 KB | 0644 |
|
perf_event_p4.h | File | 26.1 KB | 0644 |
|
pgalloc.h | File | 5.57 KB | 0644 |
|
pgtable-2level.h | File | 2.75 KB | 0644 |
|
pgtable-2level_types.h | File | 867 B | 0644 |
|
pgtable-3level.h | File | 10.24 KB | 0644 |
|
pgtable-3level_types.h | File | 1.06 KB | 0644 |
|
pgtable-invert.h | File | 1.07 KB | 0644 |
|
pgtable.h | File | 33.91 KB | 0644 |
|
pgtable_32.h | File | 3.1 KB | 0644 |
|
pgtable_32_types.h | File | 2.01 KB | 0644 |
|
pgtable_64.h | File | 7.37 KB | 0644 |
|
pgtable_64_types.h | File | 3.67 KB | 0644 |
|
pgtable_types.h | File | 16.75 KB | 0644 |
|
pkeys.h | File | 3.17 KB | 0644 |
|
platform_sst_audio.h | File | 3.18 KB | 0644 |
|
pm-trace.h | File | 611 B | 0644 |
|
posix_types.h | File | 144 B | 0644 |
|
preempt.h | File | 3.04 KB | 0644 |
|
probe_roms.h | File | 273 B | 0644 |
|
processor-cyrix.h | File | 879 B | 0644 |
|
processor-flags.h | File | 1.71 KB | 0644 |
|
processor.h | File | 24.54 KB | 0644 |
|
prom.h | File | 1 KB | 0644 |
|
proto.h | File | 1003 B | 0644 |
|
pti.h | File | 369 B | 0644 |
|
ptrace.h | File | 8.52 KB | 0644 |
|
purgatory.h | File | 571 B | 0644 |
|
pvclock-abi.h | File | 1.49 KB | 0644 |
|
pvclock.h | File | 2.64 KB | 0644 |
|
qrwlock.h | File | 199 B | 0644 |
|
qspinlock.h | File | 2.54 KB | 0644 |
|
qspinlock_paravirt.h | File | 1.85 KB | 0644 |
|
realmode.h | File | 1.76 KB | 0644 |
|
reboot.h | File | 850 B | 0644 |
|
reboot_fixups.h | File | 183 B | 0644 |
|
refcount.h | File | 2.83 KB | 0644 |
|
required-features.h | File | 2.81 KB | 0644 |
|
rio.h | File | 2.57 KB | 0644 |
|
rmwcc.h | File | 1.62 KB | 0644 |
|
rwsem.h | File | 7.02 KB | 0644 |
|
seccomp.h | File | 510 B | 0644 |
|
sections.h | File | 465 B | 0644 |
|
segment.h | File | 9.47 KB | 0644 |
|
serial.h | File | 1.11 KB | 0644 |
|
set_memory.h | File | 3.86 KB | 0644 |
|
setup.h | File | 3.4 KB | 0644 |
|
setup_arch.h | File | 77 B | 0644 |
|
shmparam.h | File | 193 B | 0644 |
|
sigcontext.h | File | 261 B | 0644 |
|
sigframe.h | File | 2.25 KB | 0644 |
|
sighandling.h | File | 649 B | 0644 |
|
signal.h | File | 2.37 KB | 0644 |
|
simd.h | File | 287 B | 0644 |
|
smap.h | File | 1.71 KB | 0644 |
|
smp.h | File | 4.73 KB | 0644 |
|
sparsemem.h | File | 1.01 KB | 0644 |
|
spec-ctrl.h | File | 2.81 KB | 0644 |
|
special_insns.h | File | 5.04 KB | 0644 |
|
spinlock.h | File | 1.19 KB | 0644 |
|
spinlock_types.h | File | 719 B | 0644 |
|
sta2x11.h | File | 352 B | 0644 |
|
stackprotector.h | File | 4.13 KB | 0644 |
|
stacktrace.h | File | 2.57 KB | 0644 |
|
string.h | File | 129 B | 0644 |
|
string_32.h | File | 7.74 KB | 0644 |
|
string_64.h | File | 3.56 KB | 0644 |
|
suspend.h | File | 131 B | 0644 |
|
suspend_32.h | File | 822 B | 0644 |
|
suspend_64.h | File | 1.79 KB | 0644 |
|
svm.h | File | 7.06 KB | 0644 |
|
swiotlb.h | File | 991 B | 0644 |
|
switch_to.h | File | 2.98 KB | 0644 |
|
sync_bitops.h | File | 3.42 KB | 0644 |
|
sys_ia32.h | File | 1.8 KB | 0644 |
|
syscall.h | File | 5.14 KB | 0644 |
|
syscalls.h | File | 1.39 KB | 0644 |
|
sysfb.h | File | 2.54 KB | 0644 |
|
tce.h | File | 1.68 KB | 0644 |
|
text-patching.h | File | 2.3 KB | 0644 |
|
thread_info.h | File | 9.33 KB | 0644 |
|
time.h | File | 331 B | 0644 |
|
timer.h | File | 1 KB | 0644 |
|
timex.h | File | 546 B | 0644 |
|
tlb.h | File | 1.05 KB | 0644 |
|
tlbbatch.h | File | 332 B | 0644 |
|
tlbflush.h | File | 17.09 KB | 0644 |
|
topology.h | File | 4.84 KB | 0644 |
|
trace_clock.h | File | 406 B | 0644 |
|
traps.h | File | 5.74 KB | 0644 |
|
tsc.h | File | 1.93 KB | 0644 |
|
uaccess.h | File | 21.69 KB | 0644 |
|
uaccess_32.h | File | 1.54 KB | 0644 |
|
uaccess_64.h | File | 5.32 KB | 0644 |
|
umip.h | File | 329 B | 0644 |
|
unaligned.h | File | 345 B | 0644 |
|
unistd.h | File | 1.45 KB | 0644 |
|
unwind.h | File | 3.13 KB | 0644 |
|
unwind_hints.h | File | 3.01 KB | 0644 |
|
uprobes.h | File | 1.57 KB | 0644 |
|
user.h | File | 2.2 KB | 0644 |
|
user32.h | File | 2.11 KB | 0644 |
|
user_32.h | File | 4.92 KB | 0644 |
|
user_64.h | File | 5.21 KB | 0644 |
|
vdso.h | File | 1.09 KB | 0644 |
|
vga.h | File | 740 B | 0644 |
|
vgtod.h | File | 2.13 KB | 0644 |
|
virtext.h | File | 2.62 KB | 0644 |
|
vm86.h | File | 2.16 KB | 0644 |
|
vmx.h | File | 23.5 KB | 0644 |
|
vsyscall.h | File | 635 B | 0644 |
|
vvar.h | File | 1.38 KB | 0644 |
|
word-at-a-time.h | File | 2.54 KB | 0644 |
|
x86_init.h | File | 9.25 KB | 0644 |
|
xor.h | File | 10.26 KB | 0644 |
|
xor_32.h | File | 14.4 KB | 0644 |
|
xor_64.h | File | 716 B | 0644 |
|
xor_avx.h | File | 4.5 KB | 0644 |
|