Subversion Repositories HelenOS

Rev

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

Filtering Options

Rev Age Author Path Log message Diff
806 6691 d 14 h palkovsky /kernel/trunk/arch/amd64/ Added (finally!) userspace to AMD64.
It does not work on Simics *$U&%&$&*#. Broken simics!!!
There should be probably LEA instead of MOV/ADD, but LEA does not
work in neither qemu nor bochs. Any other simulator to test? :-/
 
803 6691 d 17 h palkovsky /kernel/trunk/arch/amd64/ Basic amd syscall support.  
802 6691 d 18 h palkovsky /kernel/trunk/arch/amd64/ Userspace now starts executing correctly.  
800 6691 d 19 h palkovsky /kernel/trunk/arch/amd64/include/ Split AMD interrupt.h from ia32 version.  
799 6691 d 19 h palkovsky /kernel/trunk/ Preliminary work on AMD userspace.  
798 6691 d 20 h decky /kernel/trunk/arch/amd64/src/boot/ fix init_addr virtual address  
793 6692 d 1 h jermar /kernel/trunk/ Use hash_table_get_instance instead of list_get_instance.
Rename page_operations to page_mapping_operations.
Rename page_pt_operations to pt_mapping_operations.
Rename page_ht_operations to ht_mapping_operations.
 
778 6693 d 22 h palkovsky /kernel/trunk/ Fixed boot process not to call malloc when slab not initialized.
Added simics workaround.
 
769 6695 d 14 h palkovsky /kernel/trunk/ SLAB allocator now uses itself for all its internal structures.
Added description of allocator.
Removed messy_stack_trace from amd64, as it would scroll away important
part of exception.
 
765 6695 d 19 h jermar /kernel/trunk/ Add PAGE_WIDTH to aid divisions by PAGE_SIZE.  
763 6696 d 2 h jermar /kernel/trunk/ Modify frame.h to use shifting instead of multiplication and division.
Define FRAME_WIDTH for all architectures.
 
760 6696 d 4 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 6697 d 17 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.
 
755 6698 d 16 h jermar /kernel/trunk/ Change page_mapping_find/insert interfaces to take as_t * as first argument
and not asid_t as second argument. This change was necessitated by the
removal of mapping array from as_area_t and the fact that an address
space doesn't have an ASID when it is created.
 
727 6709 d 18 h jermar /kernel/trunk/ New ASID management subsystem (initial work, more is required).
Some TLB invalidation changes.
 
717 6713 d 22 h decky /kernel/trunk/ remove obsolete in-kernel userspace code
remove CONFIG_USERSPACE switch, uspace support is configured at run-time
 
703 6716 d 4 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().
 
702 6716 d 4 h jermar /kernel/trunk/arch/amd64/src/ Fix amd64 interrupt_handler to properly remove error code from stack before iretq.  
696 6720 d 21 h decky /kernel/trunk/arch/amd64/ AMD64 SMP boots again  
695 6720 d 22 h decky /kernel/trunk/arch/amd64/ make AMD64 boot again (using grub, see /boot tree), SMP is still broken  
694 6720 d 22 h decky /kernel/trunk/arch/amd64/ break AMD64, will be fixed soon  
691 6721 d 0 h jermar /kernel/trunk/arch/ Cleanup.  
690 6721 d 0 h bondari /kernel/trunk/arch/ Fixes of 3-param frame_alloc() function calls  
687 6721 d 0 h jermar /kernel/trunk/ Memory management work.
Pass address space identifier to functions in page_operations to support single global page hash table.
 
685 6721 d 1 h decky /kernel/trunk/arch/amd64/ AMD64 PM initialization  
684 6721 d 2 h jermar /kernel/trunk/ Memory management work.
Move generic 4-level page table interface to genarch
and enable architectures to use different virtual memory
mechanisms (e.g. page hash tables).
Start page hash table support.
Switch ia64 and sparc64 to page hash tables.
Other architectures keep on using 4-level page table interface.
 
680 6724 d 18 h decky /kernel/trunk/arch/ remove deprecated pre-grub stuff on ia32
prepare for the same on amd64
 
674 6725 d 5 h cejka /kernel/trunk/ Support for printing float numbers in kernel removed.  
633 6744 d 19 h palkovsky /kernel/trunk/arch/ Fixes of compilation of atomic.  
625 6745 d 0 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.
 
602 6748 d 19 h palkovsky /kernel/trunk/ Symtab returns correct addresses even when symtab is befor bss.
Some tab completion optimization.
 
597 6749 d 3 h jermar /kernel/trunk/ Finer grained TLB invalidate functions for ia32 and amd64. Not yet deployed.  
581 6750 d 4 h palkovsky /kernel/trunk/ Small debug changes.  
576 6750 d 16 h palkovsky /kernel/trunk/ Changed ia32 & amd64 to use exc_register instead of trap_register.

Fixed dependency list building. I hope you all have 'makedepend' installed,
if you don't it's time to install it, as CC -M builds the dependency
list without directory names..and it just does not work.
 
569 6751 d 18 h jermar /kernel/trunk/ sparc64 work.
Implement functions for reading IMMU and DMMU TLBs.
 
568 6752 d 0 h palkovsky /kernel/trunk/ Configuration tweaks, now supports both CNF and DNF in config.file.  
566 6752 d 17 h palkovsky /kernel/trunk/ Fixed bug in Intel32/AMD64 boot, that could cause page fault on boot.
Fixes of configuration program.
 
548 6753 d 21 h jermar /kernel/trunk/ Cleanup and fixes.  
540 6754 d 17 h jermar /kernel/trunk/arch/ Map all available frames of memory on ia32 and amd64 (ticket #10).  
534 6755 d 21 h jermar / Rename HelenOS/SPARTAN to HelenOS/kernel again.