kern
changeset 8:78d5c304ddd0
minor changes
author | John Tsiombikas <nuclear@member.fsf.org> |
---|---|
date | Wed, 16 Feb 2011 07:50:25 +0200 (2011-02-16) |
parents | 611b2d66420b |
children | af6f4adc43d6 |
files | src/segm-asm.S src/segm.c src/segm.h |
diffstat | 3 files changed, 18 insertions(+), 17 deletions(-) [+] |
line diff
1.1 --- a/src/segm-asm.S Wed Feb 16 07:26:03 2011 +0200 1.2 +++ b/src/segm-asm.S Wed Feb 16 07:50:25 2011 +0200 1.3 @@ -1,27 +1,25 @@ 1.4 .data 1.5 + .align 4 1.6 +/* memory reserved for setup_selectors */ 1.7 off:.long 0 1.8 seg:.short 0 1.9 - 1.10 - .align 1.11 - .short 0 1.12 -gdt_lim: 1.13 - .short 0 1.14 -gdt_addr: 1.15 - .long 0 1.16 +/* memory reserved for set_gdt */ 1.17 +lim:.short 0 1.18 +addr:.long 0 1.19 1.20 .text 1.21 /* setup_selectors(uint16_t code, uint16_t data) 1.22 * loads the requested selectors to all the selector registers */ 1.23 .globl setup_selectors 1.24 setup_selectors: 1.25 - /* setup data selectors */ 1.26 + /* set data selectors directly */ 1.27 movl 8(%esp), %eax 1.28 movw %ax, %ss 1.29 movw %ax, %es 1.30 movw %ax, %ds 1.31 movw %ax, %gs 1.32 movw %ax, %fs 1.33 - /* setup code selector */ 1.34 + /* set cs using a long jump */ 1.35 movl 4(%esp), %eax 1.36 movw %ax, (seg) 1.37 movl $ldcs, (off) 1.38 @@ -34,8 +32,8 @@ 1.39 .globl set_gdt 1.40 set_gdt: 1.41 movl 4(%esp), %eax 1.42 - movl %eax, (gdt_addr) 1.43 + movl %eax, (addr) 1.44 movw 8(%esp), %ax 1.45 - movw %ax, (gdt_lim) 1.46 - lgdt (gdt_lim) 1.47 + movw %ax, (lim) 1.48 + lgdt (lim) 1.49 ret
2.1 --- a/src/segm.c Wed Feb 16 07:26:03 2011 +0200 2.2 +++ b/src/segm.c Wed Feb 16 07:50:25 2011 +0200 2.3 @@ -1,6 +1,7 @@ 2.4 #include <string.h> 2.5 #include "segm.h" 2.6 2.7 +/* bits for the 3rd 16bt part of the descriptor */ 2.8 #define BIT_ACCESSED (1 << 8) 2.9 #define BIT_WR (1 << 9) 2.10 #define BIT_RD (1 << 9) 2.11 @@ -10,6 +11,7 @@ 2.12 #define BIT_NOSYS (1 << 12) 2.13 #define BIT_PRESENT (1 << 15) 2.14 2.15 +/* bits for the last 16bit part of the descriptor */ 2.16 #define BIT_BIG (1 << 6) 2.17 #define BIT_DEFAULT (1 << 6) 2.18 #define BIT_GRAN (1 << 7) 2.19 @@ -18,7 +20,12 @@ 2.20 2.21 static void segm_desc(desc_t *desc, uint32_t base, uint32_t limit, int dpl, int type); 2.22 2.23 +/* these functions are implemented in segm-asm.S */ 2.24 +void setup_selectors(uint16_t code, uint16_t data); 2.25 +void set_gdt(uint32_t addr, uint16_t limit); 2.26 2.27 + 2.28 +/* our global descriptor table */ 2.29 static desc_t gdt[4]; 2.30 2.31 2.32 @@ -33,6 +40,7 @@ 2.33 setup_selectors(selector(SEGM_KCODE, 0), selector(SEGM_KDATA, 0)); 2.34 } 2.35 2.36 +/* constructs a GDT selector based on index and priviledge level */ 2.37 uint16_t selector(int idx, int rpl) 2.38 { 2.39 return (idx << 3) | (rpl & 3);
3.1 --- a/src/segm.h Wed Feb 16 07:26:03 2011 +0200 3.2 +++ b/src/segm.h Wed Feb 16 07:50:25 2011 +0200 3.3 @@ -12,10 +12,5 @@ 3.4 3.5 uint16_t selector(int idx, int rpl); 3.6 3.7 -/* these functions are implemented in segm-asm.S */ 3.8 -void setup_selectors(uint16_t code, uint16_t data); 3.9 -void set_gdt(uint32_t addr, uint16_t limit); 3.10 - 3.11 - 3.12 3.13 #endif /* SEGM_H_ */