Rev |
Age |
Author |
Path |
Log message |
Diff |
348 |
6905 d 16 h |
jermar |
/SPARTAN/trunk/arch/ |
Optimize some assembler functions. |
|
347 |
6905 d 17 h |
jermar |
/SPARTAN/trunk/ |
Documentation updates for amd64, mips32 and ia32.
Replace %L with %P printf() formatter in MPS and ACPI detection functions to print addresses in maximal width.
Tweak memmap.S and IA-32 and AMd64 boot.S.
Cancel unneeded instructions.
Replace cmpl $0, %ebx with testl %ebx, %ebx.
Move memmap.S data to K_DATA_START section. |
|
338 |
6907 d 22 h |
jermar |
/SPARTAN/trunk/ |
Avoid code duplication by creating generic byteorder.h.
Some naming changes in swap functions. |
|
337 |
6907 d 23 h |
jermar |
/SPARTAN/trunk/arch/ia32/ |
Uncomment LONG(0xdeadbeaf) in IA-32 linker script so that the kernel is linked correctly. |
|
334 |
6907 d 23 h |
jermar |
/SPARTAN/trunk/arch/ |
Cleanup.
Cancel __fake in pm.c and replace it with LONG(0xdeadbeaf) in linker script. Still need some to find out why it must be there.
Remove comment saying, that mips is little-endian. |
|
332 |
6908 d 0 h |
palkovsky |
/SPARTAN/trunk/ |
Updated symtab so that it works correctly with BE architectures.
Changed compiler for BE MIPS to be mips-sgi-irix5, because
mipsel -EB does not behave correctly.
Doc updates to amd64.
Added ARC BIOS support to MIPS architecture. Putchar works correctly,
kernel passed FPU & some rwlock tests. |
|
331 |
6908 d 1 h |
bondari |
/SPARTAN/trunk/ |
Generic quicksort and bubble sort implementation.
ACPI MADT parser now uses qsort() for index sorting |
|
328 |
6909 d 2 h |
jermar |
/SPARTAN/trunk/ |
IA-32 can be now cross-compiled by ./build.ia32 cross.
Unify IA-32 Makefile.inc and Makefile.inc.cross.
Update doc/requirements.
Small changes elsewere. |
|
326 |
6909 d 12 h |
palkovsky |
/SPARTAN/trunk/ |
Cleanup of makefiles to have common options in one main makefile.
Add simple build process for different simulators for MIPS.
Added FPU context & lazy FPU context switching to MIPS.
Cleanup of MIPS linker script.
Moved MIPS kernel above 1MB. Not tested on real machine yet, but it might help.
There is something broken with gcc inlined memcpy (either simulator or gcc), it is disabled on BigEndian mips now. |
|
323 |
6910 d 1 h |
jermar |
/SPARTAN/trunk/ |
Add comments for new floating point modifiers to print.c.
Remove left-over comments from AMD64 and IA-32 page.c.
Coding style clean up. |
|
316 |
6912 d 4 h |
jermar |
/SPARTAN/trunk/arch/ia32/src/ |
Optimize assembler code according to the knoweledge of IA-32 ABI. |
|
315 |
6912 d 5 h |
jermar |
/SPARTAN/trunk/arch/ia32/ |
Make IA-32 userspace stack be aligned on doubleword boundary.
In userspace(), mark "eax" as clobbered register. |
|
314 |
6912 d 14 h |
palkovsky |
/SPARTAN/trunk/ |
Small cleanups |
|
312 |
6912 d 15 h |
jermar |
/SPARTAN/trunk/arch/ia32/ |
According to IA-32 ABI, %edx and %ecx don't have to be saved accross function calls.
Remove these registers from context_t and adjust context_save() and context_restore() to make use of this fact. |
|
311 |
6912 d 15 h |
bondari |
/SPARTAN/trunk/arch/ia32/src/acpi/ |
Minor after fixes to madt parsing |
|
310 |
6912 d 15 h |
bondari |
/SPARTAN/trunk/arch/ia32/src/acpi/ |
Fixed possible non-consequentive local apic madt entries
Request for peer review - was not possible to test. |
|
309 |
6913 d 3 h |
palkovsky |
/SPARTAN/trunk/ |
Added architecture independent hooks for fpu lazy context switching.
It is enabled by defining FPU_LAZY |
|
305 |
6913 d 15 h |
jermar |
/SPARTAN/trunk/ |
Change processor type in simics.conf to x86-hammer.
This way it supports both IA-32 and AMD64.
Fix comment in i8259.c. |
|
303 |
6913 d 21 h |
palkovsky |
/SPARTAN/trunk/ |
|
|
302 |
6913 d 22 h |
palkovsky |
/SPARTAN/trunk/arch/ia32/src/drivers/ |
Fixed bad slave i8259 initialization. |
|
301 |
6914 d 0 h |
palkovsky |
/SPARTAN/trunk/arch/ |
Backported amd64 build process back to ia32. |
|
300 |
6914 d 0 h |
palkovsky |
/SPARTAN/trunk/arch/ia32/ |
Backported AMD64 linker and boot changes back to IA32. |
|
298 |
6914 d 1 h |
decky |
/SPARTAN/trunk/ |
remove lower 2 GB identity mapping (IA-32) |
|
294 |
6914 d 3 h |
jermar |
/SPARTAN/trunk/arch/ |
Add timeout to kmp() so that we don't deadlock while waiting for AP's to come up.
Improve comment in byteorder.h. |
|
293 |
6914 d 13 h |
palkovsky |
/SPARTAN/trunk/ |
Symbol table now contains static functions too.
NOTE: gcc heavily inlines, be aware of optimizations.
Removed excesive item from boot page tables. |
|
292 |
6914 d 14 h |
jermar |
/SPARTAN/trunk/ |
Add byteorder.h to support conversions between different endianesses.
Add native_le2host().
Use native_le2host() in get_symtab_entry(). |
|
291 |
6914 d 17 h |
jermar |
/SPARTAN/trunk/arch/ia32/src/smp/ |
AP cpus are not supposed to touch A20 for this bit is enabled by the BSP cpu. |
|
290 |
6914 d 17 h |
palkovsky |
/SPARTAN/trunk/arch/ia32/ |
|
|
289 |
6914 d 17 h |
palkovsky |
/SPARTAN/trunk/ |
Added preprocessed linker script to AMD architecture, so that
the constants are all only in the header files. |
|
285 |
6915 d 3 h |
decky |
/SPARTAN/trunk/arch/ia32/ |
finish GRUB booting (including memory map and SMP) |
|
282 |
6915 d 4 h |
palkovsky |
/SPARTAN/trunk/ |
Fixed gdtr naming issues after ia32 changes.
Fixed stack alignment on new thread to by multiple of 16,
we are now ABI-correct and we do not #GP on va_arg to boot.
Fixed bad exception register names reporting.
Fixed bad _hardcoded_load_addr, which caused allocation of kernel text
frames. |
|
281 |
6915 d 13 h |
palkovsky |
/SPARTAN/trunk/arch/ia32/src/ |
Fixed some stupid typos. |
|
280 |
6915 d 13 h |
decky |
/SPARTAN/trunk/arch/ia32/ |
basic GRUB memory map |
|
279 |
6915 d 14 h |
decky |
/SPARTAN/trunk/arch/ia32/ |
GRUB basic booting (IA-32) |
|
278 |
6915 d 16 h |
palkovsky |
/SPARTAN/trunk/arch/ia32/src/acpi/ |
Fixed ACPI to work correctly even in bochs. |
|
277 |
6915 d 16 h |
palkovsky |
/SPARTAN/trunk/arch/ |
Reverted APIC mapping back to identity mapping.
Added AMD64 SMP support. Works now! |
|
275 |
6915 d 17 h |
palkovsky |
/SPARTAN/trunk/arch/ |
Moved AMD64 kernel above 1MB. |
|
273 |
6915 d 18 h |
palkovsky |
/SPARTAN/trunk/ |
Changes to make ia32 smp code not architecture dependent.
Changes to accomodate new gdtr loading scheme. |
|
271 |
6915 d 20 h |
decky |
/SPARTAN/trunk/arch/ia32/src/ |
yet another GDT/IDT fix/cleanup |
|
269 |
6915 d 20 h |
decky |
/SPARTAN/trunk/arch/ia32/ |
make IA-32 SMP work again (finally) |
|