Subversion Repositories HelenOS-historic

Rev

Go to most recent revision | Show changed files | Directory listing | RSS feed

Filtering Options

Rev Age Author Path Log message Diff
763 6709 d 19 h jermar /kernel/trunk/ Modify frame.h to use shifting instead of multiplication and division.
Define FRAME_WIDTH for all architectures.
 
760 6709 d 21 h jermar /kernel/trunk/ mips32 is not supposed to allocate page table.
This is done by the generic code now.
Remove PTL0 pointer as it is not needed.

Remove GET_PTL0_ADDRESS from kernel.

Update sparc64 comments in barrier.h.
 
756 6711 d 10 h jermar /kernel/trunk/ Memory management work.
Remove the last (i.e. 'root') argument from page_mapping_insert() and page_mapping_find().
Page table address is now extracted from the first (i.e. 'as') argument.
Add a lot of infrastructure to make the above possible.
sparc64 is now broken, most likely because of insufficient identity mapping of physical memory.
 
753 6712 d 17 h jermar /kernel/trunk/ Convert ASID management of ia64 to ASID FIFO mechanism.
18-bit RIDs are supported.
 
743 6718 d 13 h jermar /kernel/trunk/arch/ sparc64 work.
13 bits wide means the max value is 8191 and not 0x8191.
 
741 6718 d 13 h jermar /kernel/trunk/ Unlock address space prior TLB shootdown in get_asid() to unify
the locking order among mips32, sparc64 and ia64.

Add ASID_STEALING_ENABLED macro to disable the stealing part on ia64
in a clean way.
 
727 6723 d 12 h jermar /kernel/trunk/ New ASID management subsystem (initial work, more is required).
Some TLB invalidation changes.
 
703 6729 d 21 h jermar /kernel/trunk/ Memory management work.
- vm.* -> as.* (as like address space is, imho, more fitting)
- Don't do TLB shootdown on vm_install(). Some architectures only need to call tlb_invalidate_asid().
- Don't allocate all frames for as_area in as_area_create(), but let them be allocated on-demand by as_page_fault().
- Add high-level page fault handler as_page_fault().
- Add as_area_load_mapping().
 
674 6738 d 22 h cejka /kernel/trunk/ Support for printing float numbers in kernel removed.  
655 6753 d 15 h jermar /kernel/trunk/arch/ Compilation fixes.  
635 6757 d 10 h palkovsky /kernel/trunk/ Fixed kconsole resolution of similar commands.
Add commands to debugger to allow for simple profiling or
calling debug actions if needed.
 
627 6758 d 17 h jermar /kernel/trunk/ Fix ia64 and sparc64 to compile with new atomic_t.
Fix rwlock test #5 and semaphore test #1 to compile with new atomic_t.

sparc64 work.
TBA must be set before a function call when MMU is switched off.
 
625 6758 d 18 h palkovsky /kernel/trunk/ We are now almost -Wall clean.
- redefined atomic_t
- deleted many, many unused variables
- some minor code cleanups found using compiler warning.
 
622 6759 d 13 h palkovsky /kernel/trunk/ Better gcc CALLER implementation  
614 6761 d 8 h palkovsky /kernel/trunk/ Added support for mips breakpoints.
We have a kind of kernel debugger :-)
Breakpoints on JMP/Branch instructions are not supported and
they are reported after the breakpoint is fired and exited as
a BranchDelay exception. If we found a way, how to detect these
instructions, we would be able to support them as 'one-time' breakpoints.
 
610 6761 d 16 h palkovsky /kernel/trunk/arch/mips32/ Cleanup of unnecessary things.  
606 6761 d 18 h palkovsky /kernel/trunk/ Small kconsole readline changes.
Some mips tweaks to allow for real keyboard support in indy.
 
600 6762 d 19 h jermar /kernel/trunk/arch/mips32/ Different sizes of TLB on mips32.
R4000 has 48 entries, 4kc has only 16 entries.
 
599 6762 d 19 h jermar /kernel/trunk/arch/mips32/ Fixes for mips32 invalidation functions.  
594 6763 d 15 h jermar /kernel/trunk/ ptlb command (currently usable on mips32 only).  
590 6763 d 16 h palkovsky /kernel/trunk/ Move all MIPS exceptions to generic dispatcher.
Align size in malloc() to __native size, some architectures
don't like it unaligned.
 
581 6763 d 22 h palkovsky /kernel/trunk/ Small debug changes.  
578 6764 d 8 h palkovsky /kernel/trunk/ Added exception printing.
It does not work correctly on SMP architectures :-/
Preemption error....
 
575 6764 d 9 h palkovsky /kernel/trunk/ Added generic exc_register/exc_dispatch functions,
copied from ia32 architecture. Currently only mips32 uses them.

The chardev_t can now be both input & output device (was
needed for serial driver).

Broken other architectures - ia64, sparc, powerpc will not compile.

Mips32 supports input on all msim, gxemul, indy(tested emulation
in gxemul, loses characters), simics. Simics serial line
is done using polling, I was unable to make it produce
an interrupt when the key was pressed.
 
574 6764 d 15 h palkovsky /kernel/trunk/ Merged msim & gxemul native keyboards.  
573 6764 d 15 h palkovsky /kernel/trunk/ Added MIPS ARC memory initializaiton.  
567 6766 d 9 h palkovsky /kernel/trunk/ Added simple support for arc keyboards on mips.  
534 6769 d 14 h jermar / Rename HelenOS/SPARTAN to HelenOS/kernel again.  
532 6769 d 14 h jermar / Revert renaming of HelenOS/SPARTAN to HelenOS/kernel because of important pending patch.  
509 6781 d 12 h jermar /kernel/trunk/ Basic keyboard support for mips32 (msim).  
501 6781 d 19 h jermar / Rename HelenOS/SPARTAN to HelenOS/kernel.  
483 6789 d 14 h jermar /SPARTAN/trunk/ For now, each architecture must use its own -O switch (-O2 doesn't work for ia64, -O3 doesn't work for mips32).

New mips32 atomic_add() function.

Cleanup.
 
477 6792 d 20 h vana /SPARTAN/trunk/ Atomic inc & dec functions synchronized on all ia32,ia64 and mips platforms. Now there are 3 versions which returns no value, new value and old value och changed variable.  
475 6793 d 20 h jermar /SPARTAN/trunk/ Define atomic_t type.  
457 6795 d 22 h decky /SPARTAN/trunk/ new build system almost finished  
426 6804 d 20 h jermar /SPARTAN/trunk/ sparc64 work.
Add context_save(), context_set() and context_restore().
Remove putchar() definition from ofw.c.
Add sparc64 putchar().
Add ppc32 putchar() (i.e. the original ofw.c putchar()).
Make arg.h use the builtin va_* constructs.
 
425 6805 d 18 h cejka /SPARTAN/trunk/arch/mips32/include/ Fixed problem with va_arg macro for mips32. This solves problem with printing 64bit values on it.  
414 6817 d 0 h jermar /SPARTAN/trunk/ Create generic context_save() and context_restore().
These two functions are defined inline and only call context_save_arch() and context_restore_arch(), respectively.
The main purpose of this is to enable centralized commenting of these important and tricky functions.
 
413 6817 d 10 h jermar /SPARTAN/trunk/ Rename cpu_priority_{high|low|restore|read} functions to interrupts_{disable|enable|restore|read}.
Rename pri_t to ipl_t (Interrupt Priority Level).
Rename thread_t::pri to thread_t::priority.
 
403 6824 d 13 h jermar /SPARTAN/trunk/arch/ Small improvement in pte_t type definition.