Changes in kernel/arch/amd64/src/pm.c [dc0b964:1d3d2cf] in mainline
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
kernel/arch/amd64/src/pm.c
rdc0b964 r1d3d2cf 28 28 */ 29 29 30 /** @addtogroup amd64 30 /** @addtogroup amd64 31 31 * @{ 32 32 */ … … 52 52 { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 }, 53 53 /* KTEXT descriptor */ 54 { .limit_0_15 = 0xffff U,55 .base_0_15 = 0, 56 .base_16_23 = 0, 57 .access = AR_PRESENT | AR_CODE | DPL_KERNEL | AR_READABLE, 58 .limit_16_19 = 0x 0fU,59 .available = 0, 60 .longmode = 1, 54 { .limit_0_15 = 0xffff, 55 .base_0_15 = 0, 56 .base_16_23 = 0, 57 .access = AR_PRESENT | AR_CODE | DPL_KERNEL | AR_READABLE, 58 .limit_16_19 = 0xf, 59 .available = 0, 60 .longmode = 1, 61 61 .special = 0, 62 .granularity = 1, 62 .granularity = 1, 63 63 .base_24_31 = 0 }, 64 64 /* KDATA descriptor */ 65 { .limit_0_15 = 0xffff U,66 .base_0_15 = 0, 67 .base_16_23 = 0, 68 .access = AR_PRESENT | AR_DATA | AR_WRITABLE | DPL_KERNEL, 69 .limit_16_19 = 0x 0fU,70 .available = 0, 71 .longmode = 0, 72 .special = 0, 73 .granularity = 1, 65 { .limit_0_15 = 0xffff, 66 .base_0_15 = 0, 67 .base_16_23 = 0, 68 .access = AR_PRESENT | AR_DATA | AR_WRITABLE | DPL_KERNEL, 69 .limit_16_19 = 0xf, 70 .available = 0, 71 .longmode = 0, 72 .special = 0, 73 .granularity = 1, 74 74 .base_24_31 = 0 }, 75 75 /* UDATA descriptor */ 76 { .limit_0_15 = 0xffffU, 77 .base_0_15 = 0, 78 .base_16_23 = 0, 79 .access = AR_PRESENT | AR_DATA | AR_WRITABLE | DPL_USER, 80 .limit_16_19 = 0x0fU, 81 .available = 0, 82 .longmode = 0, 76 { .limit_0_15 = 0xffff, 77 .base_0_15 = 0, 78 .base_16_23 = 0, 79 .access = AR_PRESENT | AR_DATA | AR_WRITABLE | DPL_USER, 80 .limit_16_19 = 0xf, 81 .available = 0, 82 .longmode = 0, 83 .special = 1, 84 .granularity = 1, 85 .base_24_31 = 0 }, 86 /* UTEXT descriptor */ 87 { .limit_0_15 = 0xffff, 88 .base_0_15 = 0, 89 .base_16_23 = 0, 90 .access = AR_PRESENT | AR_CODE | DPL_USER, 91 .limit_16_19 = 0xf, 92 .available = 0, 93 .longmode = 1, 94 .special = 0, 95 .granularity = 1, 96 .base_24_31 = 0 }, 97 /* KTEXT 32-bit protected, for protected mode before long mode */ 98 { .limit_0_15 = 0xffff, 99 .base_0_15 = 0, 100 .base_16_23 = 0, 101 .access = AR_PRESENT | AR_CODE | DPL_KERNEL | AR_READABLE, 102 .limit_16_19 = 0xf, 103 .available = 0, 104 .longmode = 0, 83 105 .special = 1, 84 .granularity = 1, 85 .base_24_31 = 0 }, 86 /* UTEXT descriptor */ 87 { .limit_0_15 = 0xffffU, 88 .base_0_15 = 0, 89 .base_16_23 = 0, 90 .access = AR_PRESENT | AR_CODE | DPL_USER, 91 .limit_16_19 = 0x0fU, 92 .available = 0, 93 .longmode = 1, 94 .special = 0, 95 .granularity = 1, 96 .base_24_31 = 0 }, 97 /* KTEXT 32-bit protected, for protected mode before long mode */ 98 { .limit_0_15 = 0xffffU, 99 .base_0_15 = 0, 100 .base_16_23 = 0, 101 .access = AR_PRESENT | AR_CODE | DPL_KERNEL | AR_READABLE, 102 .limit_16_19 = 0x0fU, 103 .available = 0, 104 .longmode = 0, 105 .special = 1, 106 .granularity = 1, 106 .granularity = 1, 107 107 .base_24_31 = 0 }, 108 108 /* TSS descriptor - set up will be completed later, … … 111 111 { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 }, 112 112 /* VESA Init descriptor */ 113 #ifdef CONFIG_FB 114 { 115 0xffff, 0, VESA_INIT_SEGMENT >> 12, AR_PRESENT | AR_CODE | DPL_KERNEL, 116 0xf, 0, 0, 0, 0, 0 113 #ifdef CONFIG_FB 114 { 0xffff, 0, VESA_INIT_SEGMENT >> 12, AR_PRESENT | AR_CODE | DPL_KERNEL, 115 0xf, 0, 0, 0, 0, 0 117 116 } 118 117 #endif … … 130 129 { 131 130 tss_descriptor_t *td = (tss_descriptor_t *) d; 132 133 td->base_0_15 = base & 0xffff U;134 td->base_16_23 = ((base) >> 16) & 0xff U;135 td->base_24_31 = ((base) >> 24) & 0xff U;131 132 td->base_0_15 = base & 0xffff; 133 td->base_16_23 = ((base) >> 16) & 0xff; 134 td->base_24_31 = ((base) >> 24) & 0xff; 136 135 td->base_32_63 = ((base) >> 32); 137 136 } … … 141 140 tss_descriptor_t *td = (tss_descriptor_t *) d; 142 141 143 td->limit_0_15 = limit & 0xffff U;144 td->limit_16_19 = (limit >> 16) & 0x 0fU;142 td->limit_0_15 = limit & 0xffff; 143 td->limit_16_19 = (limit >> 16) & 0xf; 145 144 } 146 145 … … 150 149 * Offset is a linear address. 151 150 */ 152 d->offset_0_15 = offset & 0xffff U;153 d->offset_16_31 = (offset >> 16) & 0xffffU;151 d->offset_0_15 = offset & 0xffff; 152 d->offset_16_31 = offset >> 16 & 0xffff; 154 153 d->offset_32_63 = offset >> 32; 155 154 } … … 166 165 { 167 166 idescriptor_t *d; 168 unsignedint i;169 167 int i; 168 170 169 for (i = 0; i < IDT_ITEMS; i++) { 171 170 d = &idt[i]; 172 171 173 172 d->unused = 0; 174 173 d->selector = GDT_SELECTOR(KTEXT_DES); 175 174 176 175 d->present = 1; 177 d->type = AR_INTERRUPT; 176 d->type = AR_INTERRUPT; /* masking interrupt */ 178 177 } 179 178 180 179 d = &idt[0]; 181 180 idt_setoffset(d++, (uintptr_t) &int_0);
Note:
See TracChangeset
for help on using the changeset viewer.