Subversion Repositories HelenOS-historic

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
1676 6556 d 2 h jermar /kernel/trunk/generic/src/proc/ Forgotten interrupts_restore().  
1661 6557 d 7 h jermar /kernel/trunk/generic/ Collect Undead threads while waiting to join uinit.
Rename ktaskkill to ktaskgc.
 
1636 6558 d 15 h jermar /kernel/trunk/ Move comment.

Do TLB shootdown also when allocating new ASID.
 
1600 6559 d 7 h jermar /kernel/trunk/generic/src/proc/ Prevent task killing of kernel by returning EPERM on such a request.  
1597 6559 d 7 h palkovsky /kernel/trunk/ Added possibility to interrupt task at exit from interrupt routine.  
1589 6559 d 21 h jermar /kernel/trunk/generic/src/ Improve comments regarding liveliness of threads and tasks.  
1588 6559 d 22 h jermar /kernel/trunk/generic/src/ In task_kill(), remove the task from the tasks_btree before proceeding.
Thus, when the kernel finds the task in the tasks_btree and locks it before
releasing tasks_lock, it is guaranteed that the task will not be destroyed
until the lock is held. If the kernel needs to unlock the task, do some operation
and lock it again, it should increase its refcount before doing so. In that case,
when releasing the lock, it must decrement the refcount and if it reaches
zero, it must call task_destroy().
 
1587 6559 d 22 h jermar /kernel/trunk/ task_destroy() implementation, fixes in as_destroy() and task_kill().
This is the first version of HelenOS that would perform complete cleanup leading from thread to destruction of address space.
 
1585 6560 d 2 h jermar /kernel/trunk/generic/ Kill task when its main thread exits.  
1583 6560 d 5 h jermar /kernel/trunk/generic/ Make ktaskclnp call ipc_cleanup and futex_cleanup.  
1580 6560 d 8 h jermar /kernel/trunk/generic/src/ Update for task_kill().  
1579 6560 d 18 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.
 
1573 6560 d 23 h palkovsky /kernel/trunk/generic/ Renamed some things in IPC to be consistent.
Added ipc reporting to kconsole.
 
1468 6564 d 23 h jermar /kernel/trunk/ Function for destroying address space for which there is no other reference in the kernel.  
1460 6565 d 3 h jermar /kernel/trunk/generic/ Reference counting for futexes.  
1424 6568 d 22 h jermar /kernel/trunk/ Move the sharing functionality to address space area backends.
Add backend for continuous regions of physical memory.
Sharing for these areas works automagically now.
 
1409 6572 d 17 h jermar /kernel/trunk/generic/ Some shared memory stuff (not completed).
Support for address space area backends.
Add ELF and anonymous memory backends.
 
1358 6579 d 23 h jermar /kernel/trunk/generic/ Cleanup after removal of as_area_accept and as_area_send.  
1288 6591 d 4 h jermar /kernel/trunk/ Complete implementation of copy_from_uspace() and copy_to_uspace()
for amd64 and ia32. Other architectures still compile and run,
but need to implement their own assembly-only memcpy(), memcpy_from_uspace(),
memcpy_to_uspace() and their failover parts. For these architectures
only dummy implementations are provided.
 
1248 6598 d 23 h jermar /kernel/trunk/ Add some @file doxygen comments and improve already existing comments.  
1239 6599 d 22 h jermar /kernel/trunk/generic/ Prevent race in as_area_send() by allowing the address space area to be
created with AS_AREA_ATTR_PARTIAL attribute.
 
1235 6600 d 4 h jermar /kernel/trunk/generic/ Implementation of SYS_AS_AREA_ACCEPT and SYS_AS_AREA_SEND syscalls.
Note that these replace previously declared SYS_AS_AREA_SHARE_APPROVE
and SYS_AS_AREA_SHARE_PERFORM.
 
1229 6602 d 3 h jermar /kernel/trunk/ Remove the outdated TODO file.
Improve doxygen comments here and there.
 
1227 6603 d 0 h jermar /kernel/trunk/ Reorganize syscall names to better correspond to kernel architecture.
Add dummy placeholders for SYS_AS_AREA_SHARE_APPROVE and
SYS_AS_AREA_SHARE_PERFORM syscalls.
 
1196 6610 d 3 h cejka /kernel/trunk/ Printf ported back from uspace to kernel.
Printf calls changed to match new conventions.
 
1185 6613 d 1 h jermar /kernel/trunk/ Add task_create_arch() for all architectures.  
1178 6613 d 23 h jermar /kernel/trunk/ Add task_find_by_id().
Add kernel support for SYS_MAP_PHYSMEM.
 
1177 6614 d 3 h jermar /kernel/trunk/generic/ Modify B+tree node key width to be 64-bit wide on all platforms.  
1176 6614 d 4 h jermar /kernel/trunk/generic/ Kernel support for SYS_GET_TASK_ID syscall.  
1174 6614 d 5 h jermar /kernel/trunk/ Start capabilities support.  
1170 6614 d 23 h vana /kernel/trunk/ Stack size definition macro definition fix  
1168 6616 d 21 h vana /kernel/trunk/ Thread RSE support completion (kernel)  
1159 6617 d 0 h jermar /kernel/trunk/generic/ Replace list of all tasks with B+tree of all tasks.  
1115 6634 d 4 h jermar /kernel/trunk/generic/src/proc/ Fix kcpulb() to change state of the migrated thread to Entering so that thread_ready() won't panic() on violated assertion.
Make print out of threads and tasks more dense again.
 
1086 6638 d 17 h palkovsky /kernel/trunk/generic/ Untested better IPC functions.
* There is some bug in MIPS, unpredicatbly sometimes the thread gets mapped
different frame for stack.
 
1078 6639 d 22 h jermar /kernel/trunk/ Improved uspace threads.
ia64 needs fixing.
 
1066 6640 d 14 h jermar /kernel/trunk/ Support for user space threads.  
1062 6640 d 17 h jermar /kernel/trunk/ It is now possible to associate symbolic names with both threads and tasks.
More verbose kconsole threads, tasks and scheduler commands.
 
1060 6640 d 19 h palkovsky /kernel/trunk/ Added task_print.
Fixed ipc to support connect_me_to.
 
1048 6641 d 1 h jermar /kernel/trunk/generic/ Restore interrupts when failing in as_remap().
Add check_area_conflicts() that checks whether address area overlaps with other areas.
Refuse to create writeable executable address space areas.
Rename as_area_t::size to as_area_t::pages.