2006-03-31 18:30:19 +08:00
|
|
|
#ifndef __ASM_HOST_LDT_X86_64_H
|
|
|
|
#define __ASM_HOST_LDT_X86_64_H
|
2005-11-07 16:58:55 +08:00
|
|
|
|
|
|
|
#include "asm/arch/ldt.h"
|
|
|
|
|
|
|
|
/*
|
2006-02-01 19:06:28 +08:00
|
|
|
* macros stolen from include/asm-x86_64/desc.h
|
2005-11-07 16:58:55 +08:00
|
|
|
*/
|
|
|
|
#define LDT_entry_a(info) \
|
|
|
|
((((info)->base_addr & 0x0000ffff) << 16) | ((info)->limit & 0x0ffff))
|
|
|
|
|
2006-02-01 19:06:28 +08:00
|
|
|
/* Don't allow setting of the lm bit. It is useless anyways because
|
|
|
|
* 64bit system calls require __USER_CS. */
|
2005-11-07 16:58:55 +08:00
|
|
|
#define LDT_entry_b(info) \
|
|
|
|
(((info)->base_addr & 0xff000000) | \
|
|
|
|
(((info)->base_addr & 0x00ff0000) >> 16) | \
|
|
|
|
((info)->limit & 0xf0000) | \
|
|
|
|
(((info)->read_exec_only ^ 1) << 9) | \
|
|
|
|
((info)->contents << 10) | \
|
|
|
|
(((info)->seg_not_present ^ 1) << 15) | \
|
|
|
|
((info)->seg_32bit << 22) | \
|
|
|
|
((info)->limit_in_pages << 23) | \
|
|
|
|
((info)->useable << 20) | \
|
2006-02-01 19:06:28 +08:00
|
|
|
/* ((info)->lm << 21) | */ \
|
2005-11-07 16:58:55 +08:00
|
|
|
0x7000)
|
|
|
|
|
|
|
|
#define LDT_empty(info) (\
|
|
|
|
(info)->base_addr == 0 && \
|
|
|
|
(info)->limit == 0 && \
|
|
|
|
(info)->contents == 0 && \
|
|
|
|
(info)->read_exec_only == 1 && \
|
|
|
|
(info)->seg_32bit == 0 && \
|
|
|
|
(info)->limit_in_pages == 0 && \
|
|
|
|
(info)->seg_not_present == 1 && \
|
2006-02-01 19:06:28 +08:00
|
|
|
(info)->useable == 0 && \
|
|
|
|
(info)->lm == 0)
|
2005-11-07 16:58:55 +08:00
|
|
|
|
|
|
|
#endif
|