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
3973 5639 d 3 h decky /trunk/kernel/ kernel memory management revisited (phase 2): map physical memory according to zones
- ia32: register reserved and ACPI zones
- pareas are now used only for mapping of present physical memory (hw_area() is gone)
- firmware zones and physical addresses outside any zones are allowed to be mapped generally
- fix nasty antient bug in zones_insert_zone()
 
3957 5644 d 17 h jermar /trunk/kernel/arch/ppc32/ Unbreak ppc32 candidate.  
3956 5644 d 17 h jermar /trunk/kernel/arch/ppc32/include/ Add missing PIO functions to ppc32.  
3929 5646 d 16 h jermar /trunk/kernel/arch/ Introduce ioport8_t, ioport16_t and ioport32_t. These types are to be used with
pio_read_n() and pio_write_n() functions. This breaks everything.
 
3922 5648 d 16 h decky /trunk/ make arch_pre_main optional, don't force any specific prototype
simplify boot process
mips32: detect number of configured CPUs in msim
 
3908 5649 d 20 h decky /trunk/ overhaul pareas: use one single physical area for the physical address space not belonging to physical memory  
3902 5650 d 23 h jermar /trunk/kernel/ Introduce a more platform-neutral name for programmed I/O.

The new API looks like pio_read_n() or pio_write_n(), where n is 8, 16 or 32.
The old API (i.e. inb(), inw(), inl(), outb() outw(), outl()) may have made
some people think that the interface is only to be used with the separate I/O
space. That's not the case. This API is to be implemented on all platforms
so that we can finally have really generic kernel device drivers.
 
3880 5653 d 18 h decky /trunk/kernel/arch/ simplify configuration
introduce arch_construct_function and inb/outb (sometimes empty) on all platforms
various code cleanup
 
3878 5653 d 18 h decky /trunk/kernel/arch/ introduce fncptr_t and ioport_t on all platforms  
3857 5663 d 20 h decky /trunk/ very experimental TLB refill for ppc32  
3856 5663 d 22 h decky /trunk/ ppc32: strict coherency, compatible TLB flush  
3837 5666 d 1 h decky /trunk/kernel/arch/ppc32/ use pseudorandom generator to avoid even the longest path of livelock collisions  
3833 5666 d 21 h decky /trunk/ avoid nasty race condition during page fault handling  
3830 5667 d 20 h decky /trunk/kernel/arch/ppc32/ ppc32: add support for cache disable page access control  
3829 5667 d 21 h decky /trunk/ use macio optionally  
3406 5805 d 3 h svoboda /trunk/kernel/arch/ppc32/include/ Merge changeset 3114 from tracing into trunk. (implementation of istate_from_uspace() for ppc32)  
3233 5853 d 23 h decky /trunk/ remove dummy page coloring facility, which is currenty not used  
3143 5896 d 22 h svoboda /trunk/kernel/ Implement smc_coherence[_block]() for ppc32  
3134 5897 d 4 h jermar /trunk/kernel/arch/ Add smc_coherence_block().  
3133 5897 d 18 h jermar /trunk/kernel/arch/ Add smc_coherence() macro to all architectures.
So far, only amd64, ia32, ia64 and sparc64 are implemented.
 
3104 5905 d 7 h svoboda /trunk/kernel/ Declare arguments for memstr.h operations as pointers instead of uintptr_t.  
3071 5907 d 23 h decky /trunk/kernel/ reflect changes in generic code
proper formatting directives
coding style
 
3070 5907 d 23 h decky /trunk/kernel/arch/ introduce portable formatting directives
remove common types
 
2861 5955 d 19 h cejka /trunk/ Used common macro for context saving on ppc64.  
2797 5968 d 18 h jermar /trunk/kernel/ Each architecture should only announce its endianity.
The conversion macros should be defined only once.
 
2794 5969 d 18 h jermar /trunk/kernel/ Add macros for byte swapping of uint16_t's.  
2781 5988 d 1 h cejka /trunk/ Unified context saving/restoring macros in ppc32.  
2725 6026 d 0 h decky /trunk/kernel/ remove config.memory_size, get_memory_size() and memory_init.{c|d}
the amount of available memory can be calculated from the sizes of the zones
add FRAMES2SIZE, SIZE2KB and SIZE2MB functions/macros (code readability)
 
2723 6026 d 22 h decky /trunk/kernel/arch/ remove memory_print_map(), as it duplicates functionality of physmem_print()  
2721 6027 d 0 h decky /trunk/kernel/ convert e820list to a generic physmem command  
2467 6263 d 21 h jermar /trunk/ Improve comments for arch-specific implementations of hierarchical
4-level page tables. Improve formatting.
 
2465 6268 d 23 h jermar /trunk/ Merge arm32 into trunk.  
2216 6330 d 18 h decky /trunk/ make thread ID 64 bit (task ID is 64 bit already)
cleanup thread syscalls
 
2089 6400 d 1 h decky /trunk/ huge type system cleanup
remove cyclical type dependencies across multiple header files
many minor coding style fixes
 
2083 6406 d 1 h decky /trunk/kernel/ typedef elimination  
2079 6406 d 20 h decky /trunk/kernel/ remove some typedefs in favor of anonymous structures  
2071 6410 d 18 h jermar /trunk/ (c) versus (C)  
2057 6438 d 5 h jermar /trunk/kernel/arch/ Fix all remaining mistmatches in width of byte swapping functions for ia64,
ppc32, ppc64, amd64, mips32 and ia32.
 
2033 6446 d 0 h decky /trunk/kernel/arch/ppc32/include/ get_cycle() for PPC32  
2023 6447 d 19 h decky /trunk/kernel/arch/ add dummy cycle.h