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
2436 6436 d 3 h jermar /trunk/ Fix two memory leaks.

In kernel, kernel_uarg structure needs to be deallocated when a thread
with userspace context is destroyed.

In userspace, the return value of the SYS_THREAD_CREATE must be checked
for error conditions and in case of error, uarg and stack must be freed
up.
 
2268 6478 d 3 h jermar /trunk/kernel/generic/ Document and assert proper usage of THREAD_FLAG_WIRED.
Original patch by Jan Hudecek.
 
2229 6487 d 9 h jermar /trunk/ Revert some of the changes introduced in revision 2209.
I think it is not correct to remove serialization of pseudo threads in printf_core.c.
With thread-level futex serialization, several pseudo threads running in one thread could easily deadlock
the task.

Add a dedicated futex serialization to thread1.c test only.
 
2216 6489 d 2 h decky /trunk/ make thread ID 64 bit (task ID is 64 bit already)
cleanup thread syscalls
 
2187 6490 d 10 h decky /trunk/kernel/generic/ add syscall for getting current thread ID  
2183 6491 d 6 h jermar /trunk/kernel/generic/ Continue to de-oversynchronize the kernel.
- replace as->refcount with an atomic counter; accesses to this
reference counter are not to be done when the as->lock mutex is held;
this gets us rid of mutex_lock_active();

Remove the possibility of a deadlock between TLB shootdown and asidlock.
- get rid of mutex_lock_active() on as->lock
- when locking the asidlock spinlock, always do it conditionally and with
preemption disabled; in the unsuccessful case, enable interrupts and try again
- there should be no deadlock between TLB shootdown and the as->lock mutexes
- PLEASE REVIEW !!!

Add DEADLOCK_PROBE's to places where we have spinlock_trylock() loops.
 
2118 6550 d 7 h decky /trunk/kernel/generic/src/ explicit typecast, fix signed/unsigned comparison  
2109 6551 d 11 h jermar /trunk/kernel/generic/ Revert thread_interrupt_sleep() to waitq_interrupt_sleep().
I'd prefer that this, IMO, waitq related stuff stays together.
 
2089 6558 d 9 h decky /trunk/ huge type system cleanup
remove cyclical type dependencies across multiple header files
many minor coding style fixes
 
2087 6559 d 5 h jermar /trunk/kernel/ Indentaion and formatting changes even Martin will like :-)  
2071 6569 d 2 h jermar /trunk/ (c) versus (C)  
2067 6579 d 8 h jermar /trunk/kernel/ More formatting changes.  
2050 6598 d 12 h decky /trunk/kernel/ benchmarking with statistics (initial)  
2042 6603 d 6 h decky /trunk/kernel/ introduce uncounted threads, whose accounting doesn't affect accumulated task accounting
run tests in kconsole thread again
 
2039 6603 d 10 h decky /trunk/kernel/generic/ accumulate task accounting, run tests as separate kernel task  
2032 6604 d 9 h decky /trunk/kernel/generic/src/proc/ proper initialization of last_cycle  
2030 6604 d 10 h decky /trunk/kernel/ thread CPU cycles accounting  
1854 6710 d 11 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.
 
1839 6734 d 6 h decky /trunk/kernel/generic/ finish security context isolation  
1820 6741 d 23 h decky /trunk/kernel/generic/ initial security context support  

Show All