00001 
00002 
00003 
00004 
00005 
00006 
00007 
00008 
00009 
00010 
00011 
00012 
00013 
00014 
00015 
00016 
00017 
00018 
00019 
#include    "ki.h"
00020 
00021 
#if defined(WX86)
00022 
00023 
VOID
00024 
KiInitializeGdtEntry (
00025     OUT PKGDTENTRY GdtEntry,
00026     IN ULONG Base,
00027     IN ULONG Limit,
00028     IN USHORT Type,
00029     IN USHORT Dpl,
00030     IN USHORT Granularity
00031     )
00032 
00033 
00034 
00035 
00036 
00037 
00038 
00039 
00040 
00041 
00042 
00043 
00044 
00045 
00046 
00047 
00048 
00049 
00050 
00051 
00052 
00053 
00054 
00055 
00056 
00057 
00058 
00059 
00060 
00061 
00062 
00063 {
00064     GdtEntry->LimitLow = (
USHORT)(Limit & 0xffff);
00065     GdtEntry->BaseLow = (
USHORT)(Base & 0xffff);
00066     GdtEntry->HighWord.Bytes.BaseMid = (UCHAR)((Base & 0xff0000) >> 16);
00067     GdtEntry->HighWord.Bits.Type = Type;
00068     GdtEntry->HighWord.Bits.Dpl = Dpl;
00069     GdtEntry->HighWord.Bits.Pres = 1;
00070     GdtEntry->HighWord.Bits.LimitHi = (Limit & 0xf0000) >> 16;
00071     GdtEntry->HighWord.Bits.Sys = 0;
00072     GdtEntry->HighWord.Bits.Reserved_0 = 0;
00073     GdtEntry->HighWord.Bits.Default_Big = 1;
00074     GdtEntry->HighWord.Bits.Granularity = Granularity;
00075     GdtEntry->HighWord.Bytes.BaseHi = (UCHAR)((Base & 0xff000000) >> 24);
00076 }
00077 
00078 
00079 
VOID
00080 KiInitializeXDescriptor (
00081     OUT PKXDESCRIPTOR Descriptor,
00082     IN ULONG Base,
00083     IN ULONG Limit,
00084     IN USHORT Type,
00085     IN USHORT Dpl,
00086     IN USHORT Granularity
00087     )
00088 
00089 
00090 
00091 
00092 
00093 
00094 
00095 
00096 
00097 
00098 
00099 
00100 
00101 
00102 
00103 
00104 
00105 
00106 
00107 
00108 
00109 
00110 
00111 
00112 
00113 
00114 
00115 
00116 
00117 
00118 
00119 
00120 
00121 {
00122     Descriptor->Words.DescriptorWords = 0;  
00123 
00124     Descriptor->Words.Bits.Base = Base;
00125     Descriptor->Words.Bits.Limit = Limit;
00126     Descriptor->Words.Bits.Type = Type;
00127     Descriptor->Words.Bits.Dpl = Dpl;
00128     Descriptor->Words.Bits.Pres = 1;
00129     Descriptor->Words.Bits.Default_Big = 1;
00130     Descriptor->Words.Bits.Granularity = Granularity;
00131 }
00132 
00133 
VOID
00134 KeiA32ResourceCreate (
00135     IN 
PEPROCESS Process,
00136     IN PTEB Teb
00137     )
00138 
00139 
00140 
00141 
00142 
00143 
00144 
00145 
00146 
00147 
00148 
00149 
00150 
00151 
00152 
00153 
00154 {
00155     ULONG i;
00156     PUCHAR Gdt;
00157 
00158 
00159     
ASSERT (
sizeof(KTRAP_FRAME) == 
sizeof(KIA32_FRAME));
00160 
00161     
00162     
00163     
00164 
00165     Gdt = (PUCHAR) Teb->Gdt;
00166 
00167     RtlZeroMemory(Gdt, GDT_TABLE_SIZE);
00168 
00169     
KiInitializeGdtEntry((PKGDTENTRY)(Gdt + KGDT_R3_CODE), 0,
00170         (ULONG)-1, TYPE_CODE_USER, DPL_USER, GRAN_PAGE);
00171 
00172     
KiInitializeGdtEntry((PKGDTENTRY)(Gdt + KGDT_R3_DATA), 0,
00173         (ULONG)-1, TYPE_DATA_USER, DPL_USER, GRAN_PAGE);
00174 
00175     
00176     
00177     
00178 
00179     
KiInitializeGdtEntry((PKGDTENTRY)(Gdt + KGDT_R3_TEB), Teb,
00180         
sizeof(TEB)-1, TYPE_DATA_USER, DPL_USER, GRAN_BYTE);
00181 
00182     
00183     
00184     
00185     
00186 
00187     KiInitializeXDescriptor((PKXDESCRIPTOR)&(Teb->FsDescriptor), Teb,
00188         
sizeof(TEB)-1, TYPE_DATA_USER, DPL_USER, GRAN_BYTE);
00189 
00190     
00191 
00192     
00193     
00194     
00195     *(PKGDTENTRY)(Gdt+KGDT_LDT) = (Process->Pcb).LdtDescriptor;
00196 
00197     
00198 
00199     
00200     
00201     
00202     
00203     
00204 
00205     KiInitializeXDescriptor((PKXDESCRIPTOR)&(Teb->GdtDescriptor), (ULONG)Gdt,
00206         GDT_TABLE_SIZE-1, TYPE_DATA_USER, DPL_USER, GRAN_BYTE);
00207     
00208     
00209     
00210 
00211     Teb->LdtDescriptor = (ULONGLONG)((Process->Pcb).UnscrambledLdtDescriptor);
00212 }
00213 
00214 
#endif  // defined(WX86)