Blame view

kernel/linux-rt-4.4.41/arch/x86/include/uapi/asm/ldt.h 1.21 KB
5113f6f70   김현기   kernel add
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
  /*
   * ldt.h
   *
   * Definitions of structures used with the modify_ldt system call.
   */
  #ifndef _ASM_X86_LDT_H
  #define _ASM_X86_LDT_H
  
  /* Maximum number of LDT entries supported. */
  #define LDT_ENTRIES	8192
  /* The size of each LDT entry. */
  #define LDT_ENTRY_SIZE	8
  
  #ifndef __ASSEMBLY__
  /*
   * Note on 64bit base and limit is ignored and you cannot set DS/ES/CS
   * not to the default values if you still want to do syscalls. This
   * call is more for 32bit mode therefore.
   */
  struct user_desc {
  	unsigned int  entry_number;
  	unsigned int  base_addr;
  	unsigned int  limit;
  	unsigned int  seg_32bit:1;
  	unsigned int  contents:2;
  	unsigned int  read_exec_only:1;
  	unsigned int  limit_in_pages:1;
  	unsigned int  seg_not_present:1;
  	unsigned int  useable:1;
  #ifdef __x86_64__
  	/*
  	 * Because this bit is not present in 32-bit user code, user
  	 * programs can pass uninitialized values here.  Therefore, in
  	 * any context in which a user_desc comes from a 32-bit program,
  	 * the kernel must act as though lm == 0, regardless of the
  	 * actual value.
  	 */
  	unsigned int  lm:1;
  #endif
  };
  
  #define MODIFY_LDT_CONTENTS_DATA	0
  #define MODIFY_LDT_CONTENTS_STACK	1
  #define MODIFY_LDT_CONTENTS_CODE	2
  
  #endif /* !__ASSEMBLY__ */
  #endif /* _ASM_X86_LDT_H */