Subversion Repositories HelenOS-historic

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
631 6773 d 10 h palkovsky /kernel/trunk/ Fixed cpu halting in debug panic mode.  
625 6773 d 15 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.
 
623 6773 d 21 h jermar /kernel/trunk/ Add SPINLOCK_DECLARE and SPINLOCK_INITIALIZE macros.
SPINLOCK_DECLARE is to be used instead of direct spinlock_t declarations
in dynamically allocated structures on which spinlock_initialize() is called after
their creation.
SPINLOCK_INITIALIZE is to be used instead of direct spinlock_t declarations
of global spinlocks. It declares and initializes the spinlock.
Moreover, both macros are empty on UP so that -Wall warnings about unused structures
get supressed.
 
618 6775 d 9 h jermar /kernel/trunk/arch/mips32/src/mm/ Unify mips32 and sparc64 tlb_invalidate_all() semantics: do not invalidate locked/wired TLB entries.  
615 6775 d 20 h palkovsky /kernel/trunk/ Cleanups to make it compile with -Wall. Did not catch everything yet.  
614 6776 d 6 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.
 
612 6776 d 12 h jermar /kernel/trunk/arch/mips32/src/mm/ Weaken the assumption, that PageMask register contains the right mask everytime.
As a result, TLB exceptions will explicitly write this register when filling TLB entry.
Adjust tlb_print() on mips32 to print PageMask as well.
 
610 6776 d 14 h palkovsky /kernel/trunk/arch/mips32/ Cleanup of unnecessary things.  
609 6776 d 14 h palkovsky /kernel/trunk/ added support for breakpoints to mips32  
607 6776 d 15 h palkovsky /kernel/trunk/ Fixed weird simics panic.
Run kconsole, if we panic. This currently works in gxemul,
simics. In mips we need to modify the simulator.
On ia32 we need a function, that would speak directly to the chip
and fetch the character using polling.
 
606 6776 d 16 h palkovsky /kernel/trunk/ Small kconsole readline changes.
Some mips tweaks to allow for real keyboard support in indy.
 
605 6776 d 20 h palkovsky /kernel/trunk/arch/mips32/src/drivers/ Allow for different ARC frame size and kernel frame size.  
599 6777 d 17 h jermar /kernel/trunk/arch/mips32/ Fixes for mips32 invalidation functions.  
598 6777 d 17 h jermar /kernel/trunk/arch/mips32/src/mm/ TLB invalidation functions for mips32. Not deployed yet. Not tested.  
595 6778 d 12 h palkovsky /kernel/trunk/ Fixed bug in vm.c that turned off preemption. Found in versions 390:391.  
594 6778 d 12 h jermar /kernel/trunk/ ptlb command (currently usable on mips32 only).  
593 6778 d 13 h palkovsky /kernel/trunk/arch/mips32/src/ Fixed typo.  
590 6778 d 14 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.
 
588 6778 d 15 h palkovsky /kernel/trunk/ Added support for backspace
- printing '\b' should move the cursor one char to the left
- backspace key should return '\b' to application
 
577 6779 d 6 h palkovsky /kernel/trunk/ Some small fixes, basic changes to ia64 & ppc32 without testing.  
575 6779 d 7 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 6779 d 13 h palkovsky /kernel/trunk/ Merged msim & gxemul native keyboards.  
573 6779 d 13 h palkovsky /kernel/trunk/ Added MIPS ARC memory initializaiton.  
569 6780 d 9 h jermar /kernel/trunk/ sparc64 work.
Implement functions for reading IMMU and DMMU TLBs.
 
567 6781 d 7 h palkovsky /kernel/trunk/ Added simple support for arc keyboards on mips.  
548 6782 d 12 h jermar /kernel/trunk/ Cleanup and fixes.  
546 6782 d 13 h palkovsky /kernel/trunk/arch/mips32/ Fixed mips gxemul architecture.  
536 6784 d 10 h bondari /kernel/trunk/ Minor bugfix caused by invalid frame_region_not_free() usage  
534 6784 d 12 h jermar / Rename HelenOS/SPARTAN to HelenOS/kernel again.  
533 6784 d 12 h bondari /SPARTAN/trunk/ Buddy allocator for physical memory complete implementation.
Tested on IA32, AMD64, MIPS32. RWLock Test #5 is not passed.
NOTE: Other architectures could be broken (but should not be)
 
532 6784 d 12 h jermar / Revert renaming of HelenOS/SPARTAN to HelenOS/kernel because of important pending patch.  
511 6796 d 7 h jermar /kernel/trunk/ Enable dummy kconsole for ia32 and amd64 (UP mode works).  
510 6796 d 8 h jermar /kernel/trunk/ Add chardev_t.
This type is meant to abstract any input character device such as keyboard, serial port etc.
Add stdin.
Add dummy kconsole.
 
509 6796 d 10 h jermar /kernel/trunk/ Basic keyboard support for mips32 (msim).  
503 6796 d 15 h jermar /kernel/trunk/ Rename arch_late_init() to arch_pre_smp_init().
Add arch_post_smp_init().
Enable IRQ_KBD on ia-32 (doesn't work on Bochs SMP, works on Bochs UP).
 
501 6796 d 16 h jermar / Rename HelenOS/SPARTAN to HelenOS/kernel.  
492 6797 d 9 h jermar /SPARTAN/trunk/ Rename map_page_to_frame() to page_mapping_insert() and find_mapping() to page_mapping_find().
New names should make it more apparent that these two belong together.
 
484 6804 d 9 h palkovsky /SPARTAN/trunk/arch/mips32/src/ Fixed typo in context save.  
483 6804 d 12 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.
 
472 6809 d 17 h jermar /SPARTAN/trunk/ Changes in build system.
For .S targets, always do -D__ASM__.
Remove unnecessary #define __ASM__ from various *.S files.
At the end of build, generate disassembler dump for kernel.raw.

ia64 work.
Better General Exception handler.