Subversion Repositories HelenOS

Rev

Go to most recent revision | Show changed files | Details | Compare with Previous | Blame | RSS feed

Filtering Options

Rev Age Author Path Log message Diff
1856 6701 d 16 h jermar /trunk/kernel/ sparc64 work.
- Modify before_thread_runs_arch() to store addresses of the kernel stack and
userspace window buffer, resp., to registers %g6 and %g7, resp, in the
alternate and interrupt global sets.
- Modify after_thread_ran_arch() to sample %g7 from the alternate globals.
- Implement trap handler for spilling register windows into userspace window buffer.
- Implement assembly language functions to access %g6 and %g7 registers in the alternate sets.
- Initialize the trap table so that there are now also spill_1_normal, spill_2_normal,
spill_0_other and fill_1_normal handlers. These handlers are used in different situations
and for different purposes.
 
1851 6710 d 14 h jermar /trunk/kernel/ sparc64 work.
Define the istate structure.
Move the identity-mapping handler to assembly.
Make the preemptible handler more general so that TL=1 MMU exceptions can make use of it.

Little bit of formatting and indentation.
 
1787 6751 d 9 h decky / move kernel/trunk, uspace/trunk and boot/trunk to trunk/kernel, trunk/uspace and trunk/boot  
1780 6758 d 10 h jermar /kernel/trunk/ Replace old __u?? types with respective C99 variants (e.g. uint32_t, int64_t, uintptr_t etc.).  
1702 6779 d 13 h cejka /kernel/trunk/ Kernel doxygen comments updated.  
666 6947 d 6 h jermar /kernel/trunk/ sparc64 work.
Fix clean_window trap handler so that it clears output registers instead of input registers!
Fix interrupt handlers to save global registers.
 
657 6953 d 4 h jermar /kernel/trunk/ sparc64 work.
Context again. It turns out, according to SCD 2.4, that registers that didn't have to be saved were saved (%o1 - %o5) and
registers that had to be saved were not saved (%i0 - %i5, %l0 - %l7).
 
650 6955 d 4 h jermar /kernel/trunk/ sparc64 work.
Implement interrupt_disable(), interrupt_enable(), interrupt_restore() and interrupt_read() functions.
Fix context save/restore to save/restore register %i7.
 
564 6967 d 4 h jermar /kernel/trunk/ Send in some improvements.  
534 6970 d 8 h jermar / Rename HelenOS/SPARTAN to HelenOS/kernel again.  
532 6970 d 8 h jermar / Revert renaming of HelenOS/SPARTAN to HelenOS/kernel because of important pending patch.  
528 6973 d 7 h jermar /kernel/trunk/ sparc64 work.
The context_save/context_restore needed two other improvements.
First, storing of %fp because of window_fills.
Second, flushing all active windows before CONTEXT_LOAD to make CWP - 1 the overlap window.
 
527 6973 d 13 h jermar /kernel/trunk/ saprc64 work.
Perform leaf-procedure optimization for context_save and context_restore.
 
526 6973 d 14 h jermar /kernel/trunk/ sparc64 work.
No need to save/restore local registers.
 
525 6973 d 17 h jermar /kernel/trunk/arch/sparc64/ sparc64 work.
Add stack.h.
 
501 6982 d 12 h jermar / Rename HelenOS/SPARTAN to HelenOS/kernel.  
427 7005 d 10 h jermar /SPARTAN/trunk/arch/sparc64/include/ sparc64 work.
Adjust context_set() to be SCD compliant.
 
426 7005 d 13 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.
 
420 7010 d 5 h jermar /SPARTAN/trunk/arch/sparc64/ Small sparc64 changes.
Start native boot loader.
 
418 7013 d 6 h jermar /SPARTAN/trunk/ sparc64 infrastructure.