Rev |
Age |
Author |
Path |
Log message |
Diff |
3586 |
5835 d 8 h |
jermar |
/trunk/kernel/arch/ |
Do not print "Page fault.\n" if a mapping is not found during TLB refill. |
|
3393 |
5901 d 0 h |
jermar |
/trunk/kernel/arch/mips32/src/mm/ |
Write protection fault should not panic the mips32 kernel if it happens during
copy_to_uspace(). |
|
3392 |
5901 d 0 h |
jermar |
/trunk/kernel/arch/mips32/src/mm/ |
cstyle for mips32's tlb.c |
|
3228 |
5944 d 17 h |
decky |
/trunk/ |
physical memory detection in MSIM (discontinous regions supported)
remove Sgi Indy (ARC) support -- it was unmaintaned, untested for years and without uspace support |
|
2745 |
6095 d 9 h |
decky |
/trunk/ |
code cleanup (mostly signed/unsigned)
allow extra compiler warnings |
|
2720 |
6117 d 10 h |
decky |
/trunk/kernel/arch/mips32/src/mm/ |
prettyprint tlb command |
|
2071 |
6501 d 0 h |
jermar |
/trunk/ |
(c) versus (C) |
|
1787 |
6691 d 2 h |
decky |
/ |
move kernel/trunk, uspace/trunk and boot/trunk to trunk/kernel, trunk/uspace and trunk/boot |
|
1780 |
6698 d 3 h |
jermar |
/kernel/trunk/ |
Replace old __u?? types with respective C99 variants (e.g. uint32_t, int64_t, uintptr_t etc.). |
|
1776 |
6698 d 6 h |
jermar |
/kernel/trunk/arch/mips32/ |
Typos and indentation fixes for mips32 and some generic files as well. |
|
1735 |
6714 d 10 h |
decky |
/kernel/trunk/ |
make kernel prints case consistent |
|
1702 |
6719 d 6 h |
cejka |
/kernel/trunk/ |
Kernel doxygen comments updated. |
|
1595 |
6726 d 13 h |
palkovsky |
/kernel/trunk/ |
Added kernel circular buffer klog.
Added automatic killing of tasks raising inappropriate exceptions.
TODO: Fix vsnprintf return value(and behaviour according to specs) and remove workaround in klog. |
|
1411 |
6739 d 4 h |
jermar |
/kernel/trunk/ |
Modify the hierarchy of page fault handlers to pass access mode that caused the fault.
Architectures are required to pass either PF_ACCESS_READ, PF_ACCESS_WRITE or PF_ACCESS_EXEC
to as_page_fault(), depending on the cause of the fault. |
|
1288 |
6758 d 9 h |
jermar |
/kernel/trunk/ |
Complete implementation of copy_from_uspace() and copy_to_uspace()
for amd64 and ia32. Other architectures still compile and run,
but need to implement their own assembly-only memcpy(), memcpy_from_uspace(),
memcpy_to_uspace() and their failover parts. For these architectures
only dummy implementations are provided. |
|
1196 |
6777 d 7 h |
cejka |
/kernel/trunk/ |
Printf ported back from uspace to kernel.
Printf calls changed to match new conventions. |
|
1044 |
6808 d 8 h |
jermar |
/kernel/trunk/ |
Page table locking. |
|
983 |
6810 d 5 h |
palkovsky |
/kernel/trunk/ |
Fixed shrinking of as area. |
|
958 |
6811 d 0 h |
jermar |
/kernel/trunk/ |
Nicer ia32 interrupt handlers and structures holding interrupted context data.
Unify the name holding interrupted context data on all architectures to be istate. |
|
831 |
6842 d 4 h |
jermar |
/kernel/trunk/ |
Make use of one unused bit in PTE formats of amd64, ia32 and mips32 to store 1 in valid mappings.
This helps to distinguish valid entries from not present entries with 0 content (i.e. not present
entries with PFN 0 and other bits cleared). |
|
830 |
6842 d 6 h |
jermar |
/kernel/trunk/ |
Make ASID FIFO for mips32 be allocated statically.
Make ASID FIFO for sparc64 and ia64 be allocated dynamically.
Fix ia64 to call asid_fifo_init().
All three architectures now call asid_fifo_init() from as_arch_init(). |
|
765 |
6849 d 23 h |
jermar |
/kernel/trunk/ |
Add PAGE_WIDTH to aid divisions by PAGE_SIZE. |
|
764 |
6850 d 4 h |
palkovsky |
/kernel/trunk/ |
Tested basic non-cached slab allocation. |
|
756 |
6851 d 21 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 |
6852 d 20 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. |
|
730 |
6862 d 3 h |
jermar |
/kernel/trunk/ |
Finalize ASID management for sparc64 and mips32 by making use of FIFO queue of ASIDs. |
|
727 |
6863 d 22 h |
jermar |
/kernel/trunk/ |
New ASID management subsystem (initial work, more is required).
Some TLB invalidation changes. |
|
704 |
6870 d 4 h |
jermar |
/kernel/trunk/ |
Make various mips32 tlb manipulation functions preserve EntryHi register.
Cleanup and more precise comments for previous commit. |
|
703 |
6870 d 8 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(). |
|
687 |
6875 d 4 h |
jermar |
/kernel/trunk/ |
Memory management work.
Pass address space identifier to functions in page_operations to support single global page hash table. |
|
618 |
6900 d 22 h |
jermar |
/kernel/trunk/arch/mips32/src/mm/ |
Unify mips32 and sparc64 tlb_invalidate_all() semantics: do not invalidate locked/wired TLB entries. |
|
612 |
6902 d 1 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. |
|
599 |
6903 d 6 h |
jermar |
/kernel/trunk/arch/mips32/ |
Fixes for mips32 invalidation functions. |
|
598 |
6903 d 7 h |
jermar |
/kernel/trunk/arch/mips32/src/mm/ |
TLB invalidation functions for mips32. Not deployed yet. Not tested. |
|
594 |
6904 d 1 h |
jermar |
/kernel/trunk/ |
ptlb command (currently usable on mips32 only). |
|
569 |
6905 d 22 h |
jermar |
/kernel/trunk/ |
sparc64 work.
Implement functions for reading IMMU and DMMU TLBs. |
|
534 |
6910 d 1 h |
jermar |
/ |
Rename HelenOS/SPARTAN to HelenOS/kernel again. |
|
532 |
6910 d 1 h |
jermar |
/ |
Revert renaming of HelenOS/SPARTAN to HelenOS/kernel because of important pending patch. |
|
501 |
6922 d 5 h |
jermar |
/ |
Rename HelenOS/SPARTAN to HelenOS/kernel. |
|
492 |
6922 d 22 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. |
|