Subversion Repositories HelenOS

Rev

Hide changed files | Details | Compare with Previous | Blame | RSS feed

Filtering Options

Rev Age Author Path Log message Diff Changes
1138 6701 d 14 h jermar /kernel/trunk/ CPU stacks must have two frames on ia64.
Make sure both thread stack frames are mapped in before_thread_runs_arch().
Take STACK_FRAMES into account during kernel memory layout initialization in main_bsp().
 
/kernel/trunk/arch/ia64/include/context.h
/kernel/trunk/arch/ia64/include/mm/tlb.h
/kernel/trunk/arch/ia64/src/ivt.S
/kernel/trunk/arch/ia64/src/proc/scheduler.c
/kernel/trunk/contrib/conf/msim.conf
/kernel/trunk/generic/include/config.h
/kernel/trunk/generic/include/mm/frame.h
/kernel/trunk/generic/src/cpu/cpu.c
/kernel/trunk/generic/src/main/main.c
/kernel/trunk/generic/src/proc/thread.c
1096 6708 d 17 h palkovsky /kernel/trunk/ Cleanup of mips
- inline register reads
- better fpu disable/enable - global settings is automatically propagated to task
- fast syscall
 
/kernel/trunk/arch/mips32/include/cp0.h
/kernel/trunk/arch/mips32/include/exception.h
/kernel/trunk/arch/mips32/include/thread.h
/kernel/trunk/arch/mips32/src/asm.S
/kernel/trunk/arch/mips32/src/exception.c
/kernel/trunk/arch/mips32/src/fpu_context.c
/kernel/trunk/arch/mips32/src/start.S
/kernel/trunk/contrib/conf/gxemul.sh
/kernel/trunk/kernel.config
1059 6712 d 11 h jermar /kernel/trunk/ Clear user address space when creating new page tables.
Fix mapping of l_apic and io_apic on amd64.
 
/kernel/trunk/arch/ia32/src/smp/smp.c
/kernel/trunk/arch/ia64/Makefile.inc
/kernel/trunk/arch/ia64/src/ia64.c
/kernel/trunk/contrib/conf/ski.conf
/kernel/trunk/genarch/src/mm/as_pt.c
1047 6712 d 17 h decky /kernel/trunk/contrib/conf/ update config to use the image with boot loader  
/kernel/trunk/contrib/conf/pearpc.conf
1034 6712 d 20 h decky /kernel/trunk/contrib/conf/ more realistic simulated CPU frequency  
/kernel/trunk/contrib/conf/HelenOS.amd64.simics
/kernel/trunk/contrib/conf/HelenOS.ppc32.simics
1017 6713 d 16 h decky /kernel/trunk/ mips: remove load.bin
remove arch/boot infrastructure
 
/kernel/trunk/arch/mips32/boot
/kernel/trunk/Makefile
/kernel/trunk/contrib/conf/msim.conf
941 6716 d 12 h palkovsky /kernel/trunk/ Fixed mips elf loading.  
/kernel/trunk/arch/mips32/include/elf.h
/kernel/trunk/contrib/conf/spmips.conf
939 6716 d 12 h palkovsky /kernel/trunk/contrib/conf/ Fix msim configuration.  
/kernel/trunk/contrib/conf/msim.conf
938 6716 d 13 h jermar /kernel/trunk/ Basic support for loading ELF object files.
ia64, amd64, ia32 working.
mips32 requires some attention.
 
/kernel/trunk/generic/src/lib/elf.c
/kernel/trunk/generic/include/elf32.h
/kernel/trunk/generic/include/elf64.h
/kernel/trunk/generic/src/lib/elf32.c
/kernel/trunk/generic/src/lib/elf64.c
/kernel/trunk/Makefile
/kernel/trunk/arch/amd64/Makefile.inc
/kernel/trunk/arch/amd64/_link.ld.in
/kernel/trunk/arch/amd64/include/elf.h
/kernel/trunk/arch/amd64/include/types.h
/kernel/trunk/arch/amd64/src/userspace.c
/kernel/trunk/arch/ia32/Makefile.inc
/kernel/trunk/arch/ia32/include/elf.h
/kernel/trunk/arch/ia32/include/types.h
/kernel/trunk/arch/ia32/src/userspace.c
/kernel/trunk/arch/ia64/Makefile.inc
/kernel/trunk/arch/ia64/include/elf.h
/kernel/trunk/arch/ia64/src/ia64.c
/kernel/trunk/arch/mips32/Makefile.inc
/kernel/trunk/arch/mips32/include/elf.h
/kernel/trunk/arch/mips32/src/mips32.c
/kernel/trunk/arch/ppc32/Makefile.inc
/kernel/trunk/arch/ppc32/include/elf.h
/kernel/trunk/arch/ppc32/include/types.h
/kernel/trunk/arch/sparc64/Makefile.inc
/kernel/trunk/arch/sparc64/include/elf.h
/kernel/trunk/contrib/conf/msim.conf
/kernel/trunk/contrib/conf/ski.conf
/kernel/trunk/contrib/conf/spmips.conf
/kernel/trunk/generic/include/elf.h
/kernel/trunk/generic/include/userspace.h
/kernel/trunk/generic/src/main/kinit.c
/kernel/trunk/generic/src/main/uinit.c
930 6716 d 17 h decky /kernel/trunk/contrib/conf/ preliminary Simics 3.0 configuration for Simics  
/kernel/trunk/contrib/conf/HelenOS.ppc32.simics
927 6716 d 19 h decky /kernel/trunk/contrib/conf/ Simics 3.0 IA32/AMD64 component configuration  
/kernel/trunk/contrib/conf/HelenOS.amd64.simics
919 6719 d 18 h jermar /kernel/trunk/ ia64 work.
Changes to make userspace work (kernel part).
Use ski.conf from contrib directory to run Ski.

There is actually no appropriate syscall handler yet.
 
/kernel/trunk/arch/ia64/Makefile.inc
/kernel/trunk/arch/ia64/include/asm.h
/kernel/trunk/arch/ia64/include/context.h
/kernel/trunk/arch/ia64/include/mm/as.h
/kernel/trunk/arch/ia64/include/register.h
/kernel/trunk/arch/ia64/src/asm.S
/kernel/trunk/arch/ia64/src/dummy.s
/kernel/trunk/arch/ia64/src/ia64.c
/kernel/trunk/arch/ia64/src/ivt.S
/kernel/trunk/arch/ia64/src/mm/tlb.c
/kernel/trunk/arch/ia64/src/start.S
/kernel/trunk/contrib/conf/ski.conf
852 6738 d 16 h palkovsky /kernel/trunk/ Fixes in memory allocator
- proper kernel blacklisting, when kernel not loaded on page boundary
- correct zone adding in zone list (how could this work??)
 
/kernel/trunk/contrib/conf/bootindy
/kernel/trunk/arch/mips32/include/mm/tlb.h
/kernel/trunk/arch/mips32/src/console.c
/kernel/trunk/arch/mips32/src/drivers/arc.c
/kernel/trunk/arch/mips32/src/exception.c
/kernel/trunk/generic/src/mm/frame.c
836 6743 d 8 h palkovsky /kernel/trunk/ Added support for 24-bit framebuffer.  
/kernel/trunk/generic/include/fb/fb.h
/kernel/trunk/generic/src/fb/fb.c
/kernel/trunk/Makefile
/kernel/trunk/arch/mips32/src/console.c
/kernel/trunk/arch/mips32/src/mm/frame.c
/kernel/trunk/arch/ppc32/src/mm/frame.c
/kernel/trunk/contrib/conf/gxemul.sh
/kernel/trunk/kernel.config
825 6747 d 14 h jermar /kernel/trunk/ Remove WAKEUP_IPI stuff.

Make it possible to use PAGE_GLOBAL on ia32, amd64 and mips32.
Make ia32 and amd64 map the kernel using PAGE_GLOBAL.
 
/kernel/trunk/arch/amd64/include/interrupt.h
/kernel/trunk/arch/amd64/include/mm/page.h
/kernel/trunk/arch/amd64/src/amd64.c
/kernel/trunk/arch/amd64/src/interrupt.c
/kernel/trunk/arch/amd64/src/mm/page.c
/kernel/trunk/arch/ia32/include/interrupt.h
/kernel/trunk/arch/ia32/include/mm/page.h
/kernel/trunk/arch/ia32/src/ia32.c
/kernel/trunk/arch/ia32/src/interrupt.c
/kernel/trunk/arch/ia32/src/mm/page.c
/kernel/trunk/arch/mips32/include/mm/page.h
/kernel/trunk/contrib/conf/msim.conf
814 6748 d 19 h palkovsky /kernel/trunk/ Cleanup o frame allocator.
Removed early_malloc & initial heap.
Will break ia64, ppc & sparc.
Added e820 table print.
 
/kernel/trunk/generic/include/mm/heap.h
/kernel/trunk/generic/src/mm/heap.c
/kernel/trunk/Makefile
/kernel/trunk/arch/amd64/include/types.h
/kernel/trunk/arch/amd64/src/mm/page.c
/kernel/trunk/arch/amd64/src/pm.c
/kernel/trunk/arch/ia32/include/types.h
/kernel/trunk/arch/ia32/src/mm/frame.c
/kernel/trunk/arch/ia32/src/pm.c
/kernel/trunk/arch/ia32/src/smp/smp.c
/kernel/trunk/arch/mips32/Makefile.inc
/kernel/trunk/arch/mips32/include/types.h
/kernel/trunk/arch/mips32/src/drivers/arc.c
/kernel/trunk/arch/mips32/src/mips32.c
/kernel/trunk/arch/mips32/src/mm/frame.c
/kernel/trunk/contrib/conf/msim.conf
/kernel/trunk/genarch/src/acpi/matd.c
/kernel/trunk/genarch/src/mm/as_pt.c
/kernel/trunk/genarch/src/mm/page_pt.c
/kernel/trunk/generic/include/mm/buddy.h
/kernel/trunk/generic/include/mm/frame.h
/kernel/trunk/generic/include/mm/slab.h
/kernel/trunk/generic/include/proc/thread.h
/kernel/trunk/generic/include/typedefs.h
/kernel/trunk/generic/src/adt/hash_table.c
/kernel/trunk/generic/src/cpu/cpu.c
/kernel/trunk/generic/src/lib/sort.c
/kernel/trunk/generic/src/main/main.c
/kernel/trunk/generic/src/mm/as.c
/kernel/trunk/generic/src/mm/buddy.c
/kernel/trunk/generic/src/mm/frame.c
/kernel/trunk/generic/src/mm/slab.c
/kernel/trunk/generic/src/proc/scheduler.c
/kernel/trunk/generic/src/proc/task.c
/kernel/trunk/generic/src/proc/thread.c
/kernel/trunk/test/mm/falloc1/test.c
/kernel/trunk/test/mm/falloc2/test.c
812 6749 d 9 h jermar /kernel/trunk/ Documentation and dot.bochsrc upgrade.  
/kernel/trunk/arch/ia32/src/smp/apic.c
/kernel/trunk/arch/mips32/src/mips32.c
/kernel/trunk/contrib/conf/dot.bochsrc
/kernel/trunk/doc/arch/amd64
/kernel/trunk/doc/arch/ia32
796 6750 d 14 h palkovsky /kernel/trunk/ Gxemul support for mips userspace. MIPS now _must_ be started
always with userspace, there is (almost) no way how to pass parameters
to kernel.
 
/kernel/trunk/contrib/conf/gxemul.sh
/kernel/trunk/arch/mips32/Makefile.inc
/kernel/trunk/arch/mips32/src/mips32.c
794 6750 d 15 h palkovsky /kernel/trunk/ Added MIPS userspace. Currently can't make it work in gxemul.  
/kernel/trunk/arch/mips32/include/asm/regname.h
/kernel/trunk/arch/mips32/src/exception.c
/kernel/trunk/arch/mips32/src/mips32.c
/kernel/trunk/contrib/conf/msim.conf
/kernel/trunk/contrib/conf/spmips.conf
/kernel/trunk/generic/src/main/kinit.c
718 6772 d 10 h decky /kernel/trunk/ interface change: as_area_load_mapping -> as_area_set_mapping (set single page mapping)
map init directly from the physical frames it is loaded in
 
/kernel/trunk/contrib/conf/dot.bochsrc
/kernel/trunk/contrib/conf/simics.conf
/kernel/trunk/generic/include/mm/as.h
/kernel/trunk/generic/src/main/kinit.c
/kernel/trunk/generic/src/mm/as.c
574 6809 d 12 h palkovsky /kernel/trunk/ Merged msim & gxemul native keyboards.  
/kernel/trunk/arch/mips32/include/drivers/keyboard.h
/kernel/trunk/arch/mips32/include/interrupt.h
/kernel/trunk/arch/mips32/src/drivers/keyboard.c
/kernel/trunk/arch/mips32/src/interrupt.c
/kernel/trunk/contrib/conf/msim.conf
534 6814 d 11 h jermar / Rename HelenOS/SPARTAN to HelenOS/kernel again.  
/kernel
/SPARTAN
532 6814 d 12 h jermar / Revert renaming of HelenOS/SPARTAN to HelenOS/kernel because of important pending patch.  
/SPARTAN
/kernel
509 6826 d 10 h jermar /kernel/trunk/ Basic keyboard support for mips32 (msim).  
/kernel/trunk/arch/mips32/include/drivers/keyboard.h
/kernel/trunk/arch/mips32/src/drivers/keyboard.c
/kernel/trunk/arch/ia32/src/drivers/i8042.c
/kernel/trunk/arch/mips32/Makefile.inc
/kernel/trunk/arch/mips32/include/interrupt.h
/kernel/trunk/arch/mips32/src/interrupt.c
/kernel/trunk/arch/mips32/src/mips32.c
/kernel/trunk/contrib/conf/msim.conf
506 6826 d 12 h decky /kernel/trunk/ preparation for init task loading  
/kernel/trunk/arch/ia32/include/boot/memmapasm.h
/kernel/trunk/arch/ia32/include/boot/boot.h
/kernel/trunk/arch/ia32/include/boot/memmap.h
/kernel/trunk/arch/ia32/src/boot/boot.S
/kernel/trunk/arch/ia32/src/boot/memmap.S
/kernel/trunk/arch/mips32/Makefile.inc
/kernel/trunk/contrib/conf/msim.conf
/kernel/trunk/generic/src/main/main.c
501 6826 d 16 h jermar / Rename HelenOS/SPARTAN to HelenOS/kernel.  
/kernel
/SPARTAN
408 6864 d 17 h decky /SPARTAN/trunk/ IA32 has_cpuid() inline
minor indentation fixes
 
/SPARTAN/trunk/arch/ia32/src/cpuid.s
/SPARTAN/trunk/arch/ia32/Makefile.inc
/SPARTAN/trunk/arch/ia32/include/cpuid.h
/SPARTAN/trunk/contrib/conf/dot.bochsrc
376 6884 d 14 h jermar /SPARTAN/trunk/ Move kernel build files one level up the directory tree.
Fix paths in your testing environment!
 
/SPARTAN/trunk/Makefile
/SPARTAN/trunk/Makefile.config
/SPARTAN/trunk/build.amd64
/SPARTAN/trunk/build.ia32
/SPARTAN/trunk/build.ia64
/SPARTAN/trunk/build.mips32
/SPARTAN/trunk/build.ppc32
/SPARTAN/trunk/clean.amd64
/SPARTAN/trunk/clean.ia32
/SPARTAN/trunk/clean.ia64
/SPARTAN/trunk/clean.mips32
/SPARTAN/trunk/clean.ppc32
/SPARTAN/trunk/src/Makefile
/SPARTAN/trunk/src/Makefile.config
/SPARTAN/trunk/src/build.amd64
/SPARTAN/trunk/src/build.ia32
/SPARTAN/trunk/src/build.ia64
/SPARTAN/trunk/src/build.mips32
/SPARTAN/trunk/src/build.ppc32
/SPARTAN/trunk/src/clean.amd64
/SPARTAN/trunk/src/clean.ia32
/SPARTAN/trunk/src/clean.ia64
/SPARTAN/trunk/src/clean.mips32
/SPARTAN/trunk/src/clean.ppc32
/SPARTAN/trunk/arch/amd64/Makefile.inc
/SPARTAN/trunk/arch/amd64/boot/Makefile
/SPARTAN/trunk/arch/ia32/Makefile.inc
/SPARTAN/trunk/arch/ia32/boot/Makefile
/SPARTAN/trunk/arch/ia64/Makefile.inc
/SPARTAN/trunk/arch/ia64/boot/Makefile
/SPARTAN/trunk/arch/mips32/Makefile.inc
/SPARTAN/trunk/arch/mips32/boot/Makefile
/SPARTAN/trunk/arch/ppc32/Makefile.inc
/SPARTAN/trunk/arch/ppc32/boot/Makefile
/SPARTAN/trunk/contrib/conf/SPMIPS.simics
/SPARTAN/trunk/contrib/conf/dot.bochsrc
/SPARTAN/trunk/contrib/conf/ski.conf
326 6900 d 6 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.
 
/SPARTAN/trunk/arch/mips/_link.ld.in
/SPARTAN/trunk/test/fpu/mips1
/SPARTAN/trunk/test/fpu/mips1/test.c
/SPARTAN/trunk/arch/mips/_link.ld
/SPARTAN/trunk/arch/amd64/Makefile.inc
/SPARTAN/trunk/arch/amd64/src/fpu_context.c
/SPARTAN/trunk/arch/ia32/Makefile.inc
/SPARTAN/trunk/arch/ia64/Makefile.inc
/SPARTAN/trunk/arch/mips/Makefile.inc
/SPARTAN/trunk/arch/mips/boot/boot.S
/SPARTAN/trunk/arch/mips/include/asm.h
/SPARTAN/trunk/arch/mips/include/asm/boot.h
/SPARTAN/trunk/arch/mips/include/byteorder.h
/SPARTAN/trunk/arch/mips/include/cp0.h
/SPARTAN/trunk/arch/mips/include/exception.h
/SPARTAN/trunk/arch/mips/include/fpu_context.h
/SPARTAN/trunk/arch/mips/include/thread.h
/SPARTAN/trunk/arch/mips/src/asm.S
/SPARTAN/trunk/arch/mips/src/console.c
/SPARTAN/trunk/arch/mips/src/dummy.S
/SPARTAN/trunk/arch/mips/src/exception.c
/SPARTAN/trunk/arch/mips/src/fpu_context.c
/SPARTAN/trunk/arch/mips/src/mips.c
/SPARTAN/trunk/arch/mips/src/mm/frame.c
/SPARTAN/trunk/arch/mips/src/panic.S
/SPARTAN/trunk/arch/mips/src/start.S
/SPARTAN/trunk/arch/ppc/Makefile.inc
/SPARTAN/trunk/contrib/conf/msim.conf
/SPARTAN/trunk/src/Makefile
/SPARTAN/trunk/src/build.mips
/SPARTAN/trunk/src/clean.mips
324 6900 d 17 h palkovsky /SPARTAN/trunk/ MIPS architecture now works without any problems in
- msim: compile as OUTPUT_FORMAT(binary)
- gxemul: compile as OUTPUT_FORMAT(ecoff-littlemips), or create
configuration file for binary format (will be done later)
- simics: compile as OUTPUT_FORMAT(elf32-little), might work with binary
format, didn't try yet.
 
/SPARTAN/trunk/arch/mips/src/console.c
/SPARTAN/trunk/contrib/conf/SPMIPS.simics
/SPARTAN/trunk/contrib/conf/spmips.conf
/SPARTAN/trunk/arch/mips/src/putchar.c
/SPARTAN/trunk/arch/mips/Makefile.inc
/SPARTAN/trunk/arch/mips/_link.ld
/SPARTAN/trunk/arch/mips/src/cpu/cpu.c
/SPARTAN/trunk/arch/mips/src/interrupt.c
/SPARTAN/trunk/arch/mips/src/mips.c
/SPARTAN/trunk/arch/mips/src/mm/tlb.c
305 6904 d 9 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.
 
/SPARTAN/trunk/arch/ia32/src/drivers/i8259.c
/SPARTAN/trunk/contrib/conf/simics.conf
304 6904 d 10 h decky /SPARTAN/trunk/contrib/conf/ sample Simics configuration  
/SPARTAN/trunk/contrib/conf/simics.conf
261 6906 d 19 h decky /SPARTAN/trunk/contrib/conf/ typo fix in file name  
/SPARTAN/trunk/contrib/conf/dot.bochsrc
/SPARTAN/trunk/contrib/conf/dot.bochrc
255 6906 d 22 h jermar /SPARTAN/trunk/contrib/ Break contrib/ directory into contrib/conf/ and contrib/toolchain.  
/SPARTAN/trunk/contrib/conf
/SPARTAN/trunk/contrib/conf/dot.bochrc
/SPARTAN/trunk/contrib/conf/msim.conf
/SPARTAN/trunk/contrib/conf/pearpc.conf
/SPARTAN/trunk/contrib/conf/ski.conf
/SPARTAN/trunk/contrib/conf/vmware.conf
/SPARTAN/trunk/contrib/toolchain
/SPARTAN/trunk/contrib/toolchain/toolchain.amd64.sh
/SPARTAN/trunk/contrib/toolchain/toolchain.ia32.sh
/SPARTAN/trunk/contrib/toolchain/toolchain.ia64.sh
/SPARTAN/trunk/contrib/toolchain/toolchain.mips.sh
/SPARTAN/trunk/contrib/toolchain/toolchain.ppc.sh
/SPARTAN/trunk/contrib/toolchain/toolchain.ppc64.sh
/SPARTAN/trunk/contrib/dot.bochrc
/SPARTAN/trunk/contrib/msim.conf
/SPARTAN/trunk/contrib/pearpc.conf
/SPARTAN/trunk/contrib/ski.conf
/SPARTAN/trunk/contrib/toolchain.amd64.sh
/SPARTAN/trunk/contrib/toolchain.ia32.sh
/SPARTAN/trunk/contrib/toolchain.ia64.sh
/SPARTAN/trunk/contrib/toolchain.mips.sh
/SPARTAN/trunk/contrib/toolchain.ppc.sh
/SPARTAN/trunk/contrib/toolchain.ppc64.sh
/SPARTAN/trunk/contrib/vmware.conf