Rev |
Age |
Author |
Path |
Log message |
Diff |
2440 |
6367 d 3 h |
jermar |
/trunk/kernel/generic/ |
Fix the problem with sys_thread_create() by splitting the create and attach functionality of
thread_create(). Now it is possible to specify a flag that will cause thread_create() to only allocate and
initialize the thread structure. A call to thread_attach() will make the thread visible to the system.
This arrangement makes it easier to undo creation of a thread in case of a failure in sys_thread_create(). |
|
2436 |
6368 d 4 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 |
6410 d 5 h |
jermar |
/trunk/kernel/generic/ |
Document and assert proper usage of THREAD_FLAG_WIRED.
Original patch by Jan Hudecek. |
|
2229 |
6419 d 10 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 |
6421 d 4 h |
decky |
/trunk/ |
make thread ID 64 bit (task ID is 64 bit already)
cleanup thread syscalls |
|
2187 |
6422 d 11 h |
decky |
/trunk/kernel/generic/ |
add syscall for getting current thread ID |
|
2183 |
6423 d 8 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 |
6482 d 9 h |
decky |
/trunk/kernel/generic/src/ |
explicit typecast, fix signed/unsigned comparison |
|
2109 |
6483 d 12 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 |
6490 d 11 h |
decky |
/trunk/ |
huge type system cleanup
remove cyclical type dependencies across multiple header files
many minor coding style fixes |
|
2087 |
6491 d 7 h |
jermar |
/trunk/kernel/ |
Indentaion and formatting changes even Martin will like :-) |
|
2071 |
6501 d 4 h |
jermar |
/trunk/ |
(c) versus (C) |
|
2067 |
6511 d 10 h |
jermar |
/trunk/kernel/ |
More formatting changes. |
|
2050 |
6530 d 14 h |
decky |
/trunk/kernel/ |
benchmarking with statistics (initial) |
|
2042 |
6535 d 7 h |
decky |
/trunk/kernel/ |
introduce uncounted threads, whose accounting doesn't affect accumulated task accounting
run tests in kconsole thread again |
|
2039 |
6535 d 12 h |
decky |
/trunk/kernel/generic/ |
accumulate task accounting, run tests as separate kernel task |
|
2032 |
6536 d 10 h |
decky |
/trunk/kernel/generic/src/proc/ |
proper initialization of last_cycle |
|
2030 |
6536 d 12 h |
decky |
/trunk/kernel/ |
thread CPU cycles accounting |
|
1854 |
6642 d 13 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 |
6666 d 8 h |
decky |
/trunk/kernel/generic/ |
finish security context isolation |
|
1820 |
6674 d 1 h |
decky |
/trunk/kernel/generic/ |
initial security context support |
|
1787 |
6691 d 6 h |
decky |
/ |
move kernel/trunk, uspace/trunk and boot/trunk to trunk/kernel, trunk/uspace and trunk/boot |
|
1780 |
6698 d 7 h |
jermar |
/kernel/trunk/ |
Replace old __u?? types with respective C99 variants (e.g. uint32_t, int64_t, uintptr_t etc.). |
|
1766 |
6706 d 14 h |
palkovsky |
/kernel/trunk/ |
Changed frame_alloc call, cleaned a lot of stuff, fixed some not-perfectly-correct error handling. |
|
1760 |
6709 d 8 h |
palkovsky |
/kernel/trunk/ |
Changed interface of frame_alloc/free to use address of frame instead of the pfn.
This makes it impossible to use >4GB of memory on 32-bit machines, but who cares... |
|
1757 |
6712 d 12 h |
jermar |
/kernel/trunk/ |
Cleanup of comments. |
|
1735 |
6714 d 13 h |
decky |
/kernel/trunk/ |
make kernel prints case consistent |
|
1702 |
6719 d 10 h |
cejka |
/kernel/trunk/ |
Kernel doxygen comments updated. |
|
1687 |
6722 d 11 h |
jermar |
/kernel/trunk/generic/src/proc/ |
Fix double thread_join() in ktaskgc.
In thread_create(), lock TASK with interrupts disabled again.
thread_join_timeout() can use ordinary waitq_sleep_timeout(). |
|
1680 |
6723 d 0 h |
jermar |
/kernel/trunk/generic/src/proc/ |
Add interrupts_restore() to thread_join_timeout(). Note that this is not necessary, because
waitq_sleep_finish() does the job for thread_join_timeout(). However, the code looks more
correct in the form with interrupts_restore(). |
|
1661 |
6724 d 15 h |
jermar |
/kernel/trunk/generic/ |
Collect Undead threads while waiting to join uinit.
Rename ktaskkill to ktaskgc. |
|
1636 |
6726 d 0 h |
jermar |
/kernel/trunk/ |
Move comment.
Do TLB shootdown also when allocating new ASID. |
|
1595 |
6726 d 17 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. |
|
1589 |
6727 d 6 h |
jermar |
/kernel/trunk/generic/src/ |
Improve comments regarding liveliness of threads and tasks. |
|
1585 |
6727 d 10 h |
jermar |
/kernel/trunk/generic/ |
Kill task when its main thread exits. |
|
1581 |
6727 d 16 h |
jermar |
/kernel/trunk/generic/src/ |
Detach kmp thread after joining it.
Extend assertion in thread_destroy() to not panic when threads are destroyed in their Unded state. |
|
1579 |
6728 d 2 h |
jermar |
/kernel/trunk/generic/ |
Framework for task_kill().
Some pieces (e.g. implementation of ktask_cleanup() kernel thread and
task_destroy() function) are missing.
Changed locking order for task lock, threads_lock and thread lock from
threads_lock, thread lock, task lock to task lock, threads_lock, thread lock. |
|
1571 |
6728 d 7 h |
jermar |
/kernel/trunk/generic/ |
thread_join_timeout() and thread_detach() implementation.
Needs more thorough testing. |
|
1502 |
6730 d 12 h |
jermar |
/kernel/trunk/ |
Replace nonblocking argument of waitq_sleep_timeout with flags that specify mode of operation.
Now a flag can be used to specify interruptible sleep.
Modify waitq_interrupt_sleep() to only interrupt threads that used this flag.
O |
|
1458 |
6733 d 2 h |
palkovsky |
/kernel/trunk/ |
Added console support to gxemul.
Wider information in thread list. |
|