Subversion Repositories HelenOS

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
3569 5722 d 0 h svoboda /branches/dynload/ Merge latest trunk changes into dynload.  
3448 5773 d 1 h svoboda /branches/dynload/ Merge latest trunk changes into dynload  
3403 5777 d 0 h svoboda /branches/dynload/ Merge latest trunk changes into dynload  
3203 5846 d 23 h svoboda /branches/dynload/ Move stuff related to running programs to a separate source file proc/program.c  
3197 5851 d 20 h svoboda /branches/dynload/ Merge latest changes from trunk to dynload  
3191 5852 d 21 h svoboda /branches/dynload/ Merge latest trunk changes into dynload  
3153 5866 d 21 h svoboda /branches/dynload/ Merge latest trunk changes into dynload  
3149 5866 d 22 h svoboda /branches/dynload/ Merge trunk changes up to r3071 into dynload (broken)  
3107 5877 d 2 h svoboda /branches/dynload/ Merge trunk changes up to r3044 into dynload  
3001 5888 d 20 h svoboda /branches/dynload/kernel/generic/ Kernel support for running programs from userspace.  
2927 5899 d 1 h decky /branches/dynload/ added dynload branch  
2746 5976 d 18 h decky /trunk/kernel/ start merging tasklets (more or less a rewrite)  
2745 5976 d 23 h decky /trunk/ code cleanup (mostly signed/unsigned)
allow extra compiler warnings
 
2725 5997 d 21 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)
 
2701 6009 d 23 h jermar /trunk/kernel/ Fix cstyle and (c) to 2008.  
2447 6247 d 19 h jermar /trunk/kernel/generic/src/main/ Split accidently joined lines.  
2446 6247 d 19 h jermar /trunk/kernel/generic/ More efficient and simpler task termination.

Based on the assumption, that after its creation, only the task itself can create more threads for itself,
the last thread with userspace context to execute thread_exit() will perform futex and IPC cleanup. When
the task has no threads, it is destroyed. Both the cleanup and destruction is controlled by reference
counting.

As for userspace threads, even though there could be a global garbage collector for joining threads, it is
much simpler if the uinit thread detaches itself before switching to userspace.

task_kill() is now an idempotent operation. It just instructs the threads within a task to exit.

Change in the name of a thread state: Undead -> JoinMe.
 
2445 6247 d 21 h decky /trunk/ initial merge of branches/fs
(not finished, huge cleanup is needed)
 
2227 6301 d 5 h decky /trunk/kernel/ start shutdown infrastructure  
2223 6301 d 11 h decky /trunk/kernel/generic/src/ add mcall0 command (calling a function on each CPU)  
2118 6363 d 20 h decky /trunk/kernel/generic/src/ explicit typecast, fix signed/unsigned comparison  
2089 6371 d 22 h decky /trunk/ huge type system cleanup
remove cyclical type dependencies across multiple header files
many minor coding style fixes
 
2087 6372 d 17 h jermar /trunk/kernel/ Indentaion and formatting changes even Martin will like :-)  
2071 6382 d 14 h jermar /trunk/ (c) versus (C)  
2070 6382 d 22 h jermar /trunk/ Rather big indentation and formatting changes.
More inteligent long line wrapping.
 
2066 6394 d 19 h jermar /trunk/kernel/generic/src/main/ Formatting changes.
Bump year in kernel copyright.
 
2048 6414 d 16 h jermar /trunk/ Formatting and indentation changes.  
2042 6416 d 18 h decky /trunk/kernel/ introduce uncounted threads, whose accounting doesn't affect accumulated task accounting
run tests in kconsole thread again
 
2039 6416 d 22 h decky /trunk/kernel/generic/ accumulate task accounting, run tests as separate kernel task  
2019 6419 d 16 h decky /trunk/kernel/ prepare for new test infrastructure  
2015 6421 d 15 h jermar /trunk/ Rework support for virtually indexed cache.
Instead of repeatedly flushing the data cache, which was a huge overkill, refuse to create an illegal address alias
in the kernel (again) and allocate appropriate page color in userspace instead. Extend the detection also to
SYS_PHYSMEM_MAP syscall.

Add support for tracking physical memory areas mappable by SYS_PHYSMEM_MAP.

Lots of coding style changes.
 
2005 6430 d 19 h decky /trunk/ update rd  
2002 6430 d 21 h decky /trunk/kernel/generic/ rd work  
2000 6433 d 0 h decky /trunk/kernel/ move files to more proper locations  
1999 6433 d 0 h decky /trunk/ start RAM disk support  
1901 6495 d 20 h jermar /trunk/kernel/ Make SMP related parts of main.c more generic.
Move initialization of local APIC to architecture specific code.
Add arch_post_cpu_init() to support the above.
 
1894 6502 d 12 h jermar /trunk/ Add balloc() (a.k.a boot allocator):
- balloc() only needs to know how to allocate memory.
- Memory allocated via balloc() is supposed to be passed to kernel and never freed by boot itself.
- make kernel aware of boot allocations

More work on OFW device tree:
- use balloc() to efficiently and safely allocate memory for the canonical copy of the device tree

sparc64 boot:
- pass OFW device tree root node pointer to kernel
 
1855 6523 d 19 h jermar /trunk/kernel/ sparc64 work.

Fix bug introduced in revision 1852. When fixing CWP,
the input registers of the current window (i.e. output
registers of the window belonging to the interrupted
context) must be preserved. Preserve those registers
in memory. Sure there exist more efficient ways how to
copy the inputs.

Simplify before_thread_runs_arch(), resp. after_thread_ran_arch(),
and make them install, resp. uninstall, DTLB locked mapping for
eventual userspace window buffer.
 
1854 6524 d 0 h jermar /trunk/kernel/ Define architecture-specific thread sub-constructors and sub-destructors on all architectures.
Define the THREAD_FLAG_USPACE which means that the thread runs in user space.
The forementioned changes allow for allocating of user window buffer on sparc64
threads that execute in userspace.

A lot of formatting and indentation fixes.
 
1833 6551 d 10 h decky /trunk/kernel/ more sophisticated initial stack handling