processor_32.h

来自「linux 内核源代码」· C头文件 代码 · 共 787 行 · 第 1/2 页

H
787
字号
/* * include/asm-i386/processor.h * * Copyright (C) 1994 Linus Torvalds */#ifndef __ASM_I386_PROCESSOR_H#define __ASM_I386_PROCESSOR_H#include <asm/vm86.h>#include <asm/math_emu.h>#include <asm/segment.h>#include <asm/page.h>#include <asm/types.h>#include <asm/sigcontext.h>#include <asm/cpufeature.h>#include <asm/msr.h>#include <asm/system.h>#include <linux/cache.h>#include <linux/threads.h>#include <asm/percpu.h>#include <linux/cpumask.h>#include <linux/init.h>#include <asm/processor-flags.h>/* flag for disabling the tsc */extern int tsc_disable;struct desc_struct {	unsigned long a,b;};#define desc_empty(desc) \		(!((desc)->a | (desc)->b))#define desc_equal(desc1, desc2) \		(((desc1)->a == (desc2)->a) && ((desc1)->b == (desc2)->b))/* * Default implementation of macro that returns current * instruction pointer ("program counter"). */#define current_text_addr() ({ void *pc; __asm__("movl $1f,%0\n1:":"=g" (pc)); pc; })/* *  CPU type and hardware bug flags. Kept separately for each CPU. *  Members of this structure are referenced in head.S, so think twice *  before touching them. [mj] */struct cpuinfo_x86 {	__u8	x86;		/* CPU family */	__u8	x86_vendor;	/* CPU vendor */	__u8	x86_model;	__u8	x86_mask;	char	wp_works_ok;	/* It doesn't on 386's */	char	hlt_works_ok;	/* Problems on some 486Dx4's and old 386's */	char	hard_math;	char	rfu;       	int	cpuid_level;	/* Maximum supported CPUID level, -1=no CPUID */	unsigned long	x86_capability[NCAPINTS];	char	x86_vendor_id[16];	char	x86_model_id[64];	int 	x86_cache_size;  /* in KB - valid for CPUS which support this				    call  */	int 	x86_cache_alignment;	/* In bytes */	char	fdiv_bug;	char	f00f_bug;	char	coma_bug;	char	pad0;	int	x86_power;	unsigned long loops_per_jiffy;#ifdef CONFIG_SMP	cpumask_t llc_shared_map;	/* cpus sharing the last level cache */#endif	unsigned char x86_max_cores;	/* cpuid returned max cores value */	unsigned char apicid;	unsigned short x86_clflush_size;#ifdef CONFIG_SMP	unsigned char booted_cores;	/* number of cores as seen by OS */	__u8 phys_proc_id; 		/* Physical processor id. */	__u8 cpu_core_id;  		/* Core id */	__u8 cpu_index;			/* index into per_cpu list */#endif} __attribute__((__aligned__(SMP_CACHE_BYTES)));#define X86_VENDOR_INTEL 0#define X86_VENDOR_CYRIX 1#define X86_VENDOR_AMD 2#define X86_VENDOR_UMC 3#define X86_VENDOR_NEXGEN 4#define X86_VENDOR_CENTAUR 5#define X86_VENDOR_TRANSMETA 7#define X86_VENDOR_NSC 8#define X86_VENDOR_NUM 9#define X86_VENDOR_UNKNOWN 0xff/* * capabilities of CPUs */extern struct cpuinfo_x86 boot_cpu_data;extern struct cpuinfo_x86 new_cpu_data;extern struct tss_struct doublefault_tss;DECLARE_PER_CPU(struct tss_struct, init_tss);#ifdef CONFIG_SMPDECLARE_PER_CPU(struct cpuinfo_x86, cpu_info);#define cpu_data(cpu)		per_cpu(cpu_info, cpu)#define current_cpu_data	cpu_data(smp_processor_id())#else#define cpu_data(cpu)		boot_cpu_data#define current_cpu_data	boot_cpu_data#endif/* * the following now lives in the per cpu area: * extern	int cpu_llc_id[NR_CPUS]; */DECLARE_PER_CPU(u8, cpu_llc_id);extern char ignore_fpu_irq;void __init cpu_detect(struct cpuinfo_x86 *c);extern void identify_boot_cpu(void);extern void identify_secondary_cpu(struct cpuinfo_x86 *);extern void print_cpu_info(struct cpuinfo_x86 *);extern void init_scattered_cpuid_features(struct cpuinfo_x86 *c);extern unsigned int init_intel_cacheinfo(struct cpuinfo_x86 *c);extern unsigned short num_cache_leaves;#ifdef CONFIG_X86_HTextern void detect_ht(struct cpuinfo_x86 *c);#elsestatic inline void detect_ht(struct cpuinfo_x86 *c) {}#endifstatic inline void native_cpuid(unsigned int *eax, unsigned int *ebx,					 unsigned int *ecx, unsigned int *edx){	/* ecx is often an input as well as an output. */	__asm__("cpuid"		: "=a" (*eax),		  "=b" (*ebx),		  "=c" (*ecx),		  "=d" (*edx)		: "0" (*eax), "2" (*ecx));}#define load_cr3(pgdir) write_cr3(__pa(pgdir))/* * Save the cr4 feature set we're using (ie * Pentium 4MB enable and PPro Global page * enable), so that any CPU's that boot up * after us can get the correct flags. */extern unsigned long mmu_cr4_features;static inline void set_in_cr4 (unsigned long mask){	unsigned cr4;	mmu_cr4_features |= mask;	cr4 = read_cr4();	cr4 |= mask;	write_cr4(cr4);}static inline void clear_in_cr4 (unsigned long mask){	unsigned cr4;	mmu_cr4_features &= ~mask;	cr4 = read_cr4();	cr4 &= ~mask;	write_cr4(cr4);}/* Stop speculative execution */static inline void sync_core(void){	int tmp;	asm volatile("cpuid" : "=a" (tmp) : "0" (1) : "ebx","ecx","edx","memory");}static inline void __monitor(const void *eax, unsigned long ecx,		unsigned long edx){	/* "monitor %eax,%ecx,%edx;" */	asm volatile(		".byte 0x0f,0x01,0xc8;"		: :"a" (eax), "c" (ecx), "d"(edx));}static inline void __mwait(unsigned long eax, unsigned long ecx){	/* "mwait %eax,%ecx;" */	asm volatile(		".byte 0x0f,0x01,0xc9;"		: :"a" (eax), "c" (ecx));}extern void mwait_idle_with_hints(unsigned long eax, unsigned long ecx);/* from system description table in BIOS.  Mostly for MCA use, butothers may find it useful. */extern unsigned int machine_id;extern unsigned int machine_submodel_id;extern unsigned int BIOS_revision;extern unsigned int mca_pentium_flag;/* Boot loader type from the setup header */extern int bootloader_type;/* * User space process size: 3GB (default). */#define TASK_SIZE	(PAGE_OFFSET)/* This decides where the kernel will search for a free chunk of vm * space during mmap's. */#define TASK_UNMAPPED_BASE	(PAGE_ALIGN(TASK_SIZE / 3))#define HAVE_ARCH_PICK_MMAP_LAYOUTextern void hard_disable_TSC(void);extern void disable_TSC(void);extern void hard_enable_TSC(void);/* * Size of io_bitmap. */#define IO_BITMAP_BITS  65536#define IO_BITMAP_BYTES (IO_BITMAP_BITS/8)#define IO_BITMAP_LONGS (IO_BITMAP_BYTES/sizeof(long))#define IO_BITMAP_OFFSET offsetof(struct tss_struct,io_bitmap)#define INVALID_IO_BITMAP_OFFSET 0x8000#define INVALID_IO_BITMAP_OFFSET_LAZY 0x9000struct i387_fsave_struct {	long	cwd;	long	swd;	long	twd;	long	fip;	long	fcs;	long	foo;	long	fos;	long	st_space[20];	/* 8*10 bytes for each FP-reg = 80 bytes */	long	status;		/* software status information */};struct i387_fxsave_struct {	unsigned short	cwd;	unsigned short	swd;	unsigned short	twd;	unsigned short	fop;	long	fip;	long	fcs;	long	foo;	long	fos;	long	mxcsr;	long	mxcsr_mask;	long	st_space[32];	/* 8*16 bytes for each FP-reg = 128 bytes */	long	xmm_space[32];	/* 8*16 bytes for each XMM-reg = 128 bytes */	long	padding[56];} __attribute__ ((aligned (16)));struct i387_soft_struct {	long	cwd;	long	swd;	long	twd;	long	fip;	long	fcs;	long	foo;	long	fos;	long	st_space[20];	/* 8*10 bytes for each FP-reg = 80 bytes */	unsigned char	ftop, changed, lookahead, no_update, rm, alimit;	struct info	*info;	unsigned long	entry_eip;};union i387_union {	struct i387_fsave_struct	fsave;	struct i387_fxsave_struct	fxsave;	struct i387_soft_struct soft;};typedef struct {	unsigned long seg;} mm_segment_t;struct thread_struct;/* This is the TSS defined by the hardware. */struct i386_hw_tss {	unsigned short	back_link,__blh;	unsigned long	esp0;	unsigned short	ss0,__ss0h;	unsigned long	esp1;	unsigned short	ss1,__ss1h;	/* ss1 is used to cache MSR_IA32_SYSENTER_CS */	unsigned long	esp2;	unsigned short	ss2,__ss2h;	unsigned long	__cr3;	unsigned long	eip;	unsigned long	eflags;	unsigned long	eax,ecx,edx,ebx;	unsigned long	esp;	unsigned long	ebp;	unsigned long	esi;	unsigned long	edi;	unsigned short	es, __esh;	unsigned short	cs, __csh;	unsigned short	ss, __ssh;	unsigned short	ds, __dsh;	unsigned short	fs, __fsh;	unsigned short	gs, __gsh;	unsigned short	ldt, __ldth;	unsigned short	trace, io_bitmap_base;} __attribute__((packed));struct tss_struct {	struct i386_hw_tss x86_tss;	/*	 * The extra 1 is there because the CPU will access an	 * additional byte beyond the end of the IO permission	 * bitmap. The extra byte must be all 1 bits, and must	 * be within the limit.	 */	unsigned long	io_bitmap[IO_BITMAP_LONGS + 1];	/*	 * Cache the current maximum and the last task that used the bitmap:	 */	unsigned long io_bitmap_max;	struct thread_struct *io_bitmap_owner;	/*	 * pads the TSS to be cacheline-aligned (size is 0x100)	 */	unsigned long __cacheline_filler[35];	/*	 * .. and then another 0x100 bytes for emergency kernel stack	 */	unsigned long stack[64];} __attribute__((packed));#define ARCH_MIN_TASKALIGN	16struct thread_struct {/* cached TLS descriptors. */	struct desc_struct tls_array[GDT_ENTRY_TLS_ENTRIES];	unsigned long	esp0;	unsigned long	sysenter_cs;	unsigned long	eip;	unsigned long	esp;	unsigned long	fs;	unsigned long	gs;/* Hardware debugging registers */	unsigned long	debugreg[8];  /* %%db0-7 debug registers *//* fault info */	unsigned long	cr2, trap_no, error_code;/* floating point info */	union i387_union	i387;/* virtual 86 mode info */	struct vm86_struct __user * vm86_info;	unsigned long		screen_bitmap;	unsigned long		v86flags, v86mask, saved_esp0;	unsigned int		saved_fs, saved_gs;/* IO permissions */	unsigned long	*io_bitmap_ptr; 	unsigned long	iopl;/* max allowed port in the bitmap, in bytes: */	unsigned long	io_bitmap_max;};#define INIT_THREAD  {							\	.esp0 = sizeof(init_stack) + (long)&init_stack,			\	.vm86_info = NULL,						\	.sysenter_cs = __KERNEL_CS,					\	.io_bitmap_ptr = NULL,						\	.fs = __KERNEL_PERCPU,						\}/* * Note that the .io_bitmap member must be extra-big. This is because * the CPU will access an additional byte beyond the end of the IO * permission bitmap. The extra byte must be all 1 bits, and must * be within the limit. */#define INIT_TSS  {							\	.x86_tss = {							\		.esp0		= sizeof(init_stack) + (long)&init_stack, \		.ss0		= __KERNEL_DS,				\		.ss1		= __KERNEL_CS,				\		.io_bitmap_base	= INVALID_IO_BITMAP_OFFSET,		\	 },								\

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?