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
4030 5595 d 8 h svoboda /trunk/ Init-task names for ppc32.  
4021 5596 d 10 h jermar /trunk/kernel/ There is no need to define ioport{8,16,32}_t types for each architecture separately.  
3973 5600 d 19 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 5606 d 9 h jermar /trunk/kernel/arch/ppc32/ Unbreak ppc32 candidate.  
3956 5606 d 9 h jermar /trunk/kernel/arch/ppc32/include/ Add missing PIO functions to ppc32.  
3929 5608 d 8 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 5610 d 8 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 5611 d 12 h decky /trunk/ overhaul pareas: use one single physical area for the physical address space not belonging to physical memory  
3902 5612 d 15 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 5615 d 10 h decky /trunk/kernel/arch/ simplify configuration
introduce arch_construct_function and inb/outb (sometimes empty) on all platforms
various code cleanup
 
3878 5615 d 10 h decky /trunk/kernel/arch/ introduce fncptr_t and ioport_t on all platforms  
3857 5625 d 12 h decky /trunk/ very experimental TLB refill for ppc32  
3856 5625 d 14 h decky /trunk/ ppc32: strict coherency, compatible TLB flush  
3837 5627 d 17 h decky /trunk/kernel/arch/ppc32/ use pseudorandom generator to avoid even the longest path of livelock collisions  
3833 5628 d 13 h decky /trunk/ avoid nasty race condition during page fault handling  
3830 5629 d 12 h decky /trunk/kernel/arch/ppc32/ ppc32: add support for cache disable page access control  
3829 5629 d 13 h decky /trunk/ use macio optionally  
3406 5766 d 19 h svoboda /trunk/kernel/arch/ppc32/include/ Merge changeset 3114 from tracing into trunk. (implementation of istate_from_uspace() for ppc32)  
3233 5815 d 15 h decky /trunk/ remove dummy page coloring facility, which is currenty not used  
3143 5858 d 14 h svoboda /trunk/kernel/ Implement smc_coherence[_block]() for ppc32  
3134 5858 d 20 h jermar /trunk/kernel/arch/ Add smc_coherence_block().  
3133 5859 d 10 h jermar /trunk/kernel/arch/ Add smc_coherence() macro to all architectures.
So far, only amd64, ia32, ia64 and sparc64 are implemented.
 
3104 5866 d 23 h svoboda /trunk/kernel/ Declare arguments for memstr.h operations as pointers instead of uintptr_t.  
3071 5869 d 15 h decky /trunk/kernel/ reflect changes in generic code
proper formatting directives
coding style
 
3070 5869 d 15 h decky /trunk/kernel/arch/ introduce portable formatting directives
remove common types
 
2861 5917 d 10 h cejka /trunk/ Used common macro for context saving on ppc64.  
2797 5930 d 10 h jermar /trunk/kernel/ Each architecture should only announce its endianity.
The conversion macros should be defined only once.
 
2794 5931 d 10 h jermar /trunk/kernel/ Add macros for byte swapping of uint16_t's.  
2781 5949 d 17 h cejka /trunk/ Unified context saving/restoring macros in ppc32.  
2725 5987 d 16 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 5988 d 14 h decky /trunk/kernel/arch/ remove memory_print_map(), as it duplicates functionality of physmem_print()  
2721 5988 d 16 h decky /trunk/kernel/ convert e820list to a generic physmem command  
2467 6225 d 13 h jermar /trunk/ Improve comments for arch-specific implementations of hierarchical
4-level page tables. Improve formatting.
 
2465 6230 d 15 h jermar /trunk/ Merge arm32 into trunk.  
2216 6292 d 10 h decky /trunk/ make thread ID 64 bit (task ID is 64 bit already)
cleanup thread syscalls
 
2089 6361 d 17 h decky /trunk/ huge type system cleanup
remove cyclical type dependencies across multiple header files
many minor coding style fixes
 
2083 6367 d 17 h decky /trunk/kernel/ typedef elimination  
2079 6368 d 11 h decky /trunk/kernel/ remove some typedefs in favor of anonymous structures  
2071 6372 d 10 h jermar /trunk/ (c) versus (C)  
2057 6399 d 21 h jermar /trunk/kernel/arch/ Fix all remaining mistmatches in width of byte swapping functions for ia64,
ppc32, ppc64, amd64, mips32 and ia32.