JAAman
i have similar problem. can any one pls help to find the answer.
i want code segment base = 0x6000 and limit as 0x6F00 with Granularity G bit as 0.
Code: Select all
// GDT(kgdt) setup written in .c source file
0x0 // NULL selector
0x00C09B0060006F00 // CODE selector
0x00CF93000000FFFF // DATA
0x00C0970000000000 // stack
// To install GDT
void GDTInstall() {
desc gdtp;
gdtp.limit = (sizeof (gdt_entry) * MAX_GDT_ENTRIES) - 1;
gdtp.base = (uint32)kgdt;
InstallGdt((uint32)&gdtp);
}
// asm.s file
InstallGdt:
mov 4(%esp), %eax
lgdt (%eax)
mov $DATA_SEL, %ax // load 0x10
mov %ax, %ds
mov %ax, %es
mov %ax, %fs
mov %ax, %gs
mov $STACK_SEL, %ax // load 0x18
mov %ax, %ss
// below 3 lines are byte code like : ljmp $CODE_SEL, $0x0
.byte 0xEA
.long done
.word CODE_SEL
done:
ret
test:
// some code
i built this source into BINARY file using GCC compiler. Here CS Register is loaded with CS segment selector and jump happens to label 'done'.
But the probelm is , then instead of returning to GDTInstall function , ecexution continue at label 'test' .
But then Is there any problem with GCC compiler? When FAR JUMP is converted to "ljump 0x08:0x5fa2", then why does not address is calculated as 0x6000(base)+0x5fa2(offset) ? Why base address is ignored ?
Thanks,