Rev |
Age |
Author |
Path |
Log message |
Diff |
Changes |
1587 |
6695 d 3 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. |
|
/kernel/trunk/arch/amd64/src/proc/task.c /kernel/trunk/arch/ia32/src/proc/task.c /kernel/trunk/arch/ia64/include/proc/task.h /kernel/trunk/arch/mips32/include/proc/task.h /kernel/trunk/arch/ppc32/include/proc/task.h /kernel/trunk/arch/ppc64/include/proc/task.h /kernel/trunk/arch/sparc64/include/proc/task.h /kernel/trunk/generic/include/proc/task.h /kernel/trunk/generic/src/mm/as.c /kernel/trunk/generic/src/proc/task.c
|
1585 |
6695 d 6 h |
jermar |
/kernel/trunk/generic/ |
Kill task when its main thread exits. |
|
/kernel/trunk/generic/include/proc/task.h /kernel/trunk/generic/src/proc/task.c /kernel/trunk/generic/src/proc/thread.c
|
1583 |
6695 d 10 h |
jermar |
/kernel/trunk/generic/ |
Make ktaskclnp call ipc_cleanup and futex_cleanup. |
|
/kernel/trunk/generic/include/proc/task.h /kernel/trunk/generic/include/synch/futex.h /kernel/trunk/generic/src/proc/task.c /kernel/trunk/generic/src/synch/futex.c
|
1582 |
6695 d 10 h |
palkovsky |
/kernel/trunk/generic/ |
Modified ipc_cleanup. |
|
/kernel/trunk/generic/include/ipc/ipc.h /kernel/trunk/generic/src/console/cmd.c /kernel/trunk/generic/src/ipc/ipc.c
|
1579 |
6695 d 23 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. |
|
/kernel/trunk/generic/include/proc/task.h /kernel/trunk/generic/include/proc/thread.h /kernel/trunk/generic/src/proc/task.c /kernel/trunk/generic/src/proc/thread.c /kernel/trunk/generic/src/synch/waitq.c /kernel/trunk/generic/src/syscall/syscall.c
|
1576 |
6696 d 1 h |
jermar |
/kernel/trunk/ |
Make use of thread_join_timeout() and thread_detach() in kernel.
Improved comments in slab.h. |
|
/kernel/trunk/arch/ia32/include/smp/mps.h /kernel/trunk/arch/ia32/src/smp/mps.c /kernel/trunk/arch/ia32/src/smp/smp.c /kernel/trunk/generic/include/mm/slab.h /kernel/trunk/generic/include/proc/thread.h /kernel/trunk/generic/src/main/kinit.c /kernel/trunk/generic/src/proc/scheduler.c
|
1573 |
6696 d 3 h |
palkovsky |
/kernel/trunk/generic/ |
Renamed some things in IPC to be consistent.
Added ipc reporting to kconsole. |
|
/kernel/trunk/generic/include/ipc/ipc.h /kernel/trunk/generic/src/console/cmd.c /kernel/trunk/generic/src/ipc/ipc.c /kernel/trunk/generic/src/ipc/ipcrsc.c /kernel/trunk/generic/src/ipc/irq.c /kernel/trunk/generic/src/ipc/sysipc.c /kernel/trunk/generic/src/proc/task.c
|
1571 |
6696 d 3 h |
jermar |
/kernel/trunk/generic/ |
thread_join_timeout() and thread_detach() implementation.
Needs more thorough testing. |
|
/kernel/trunk/generic/include/proc/thread.h /kernel/trunk/generic/src/proc/scheduler.c /kernel/trunk/generic/src/proc/thread.c
|
1568 |
6696 d 5 h |
palkovsky |
/kernel/trunk/generic/ |
Slightly remodelled ipc hangups to facilitate correct cleanup.
Doc updates for frame allocator. |
|
/kernel/trunk/generic/include/ipc/ipc.h /kernel/trunk/generic/include/proc/task.h /kernel/trunk/generic/src/ipc/ipc.c /kernel/trunk/generic/src/ipc/ipcrsc.c /kernel/trunk/generic/src/ipc/sysipc.c /kernel/trunk/generic/src/mm/frame.c
|
1544 |
6697 d 6 h |
palkovsky |
/kernel/trunk/generic/ |
Slightly better behaviour with caching on memory sharing. |
|
/kernel/trunk/generic/include/errno.h /kernel/trunk/generic/src/mm/as.c
|
1507 |
6698 d 7 h |
vana |
/kernel/trunk/ |
IA64 uspace keyboard kernel part |
|
/kernel/trunk/arch/ia64/include/arch.h /kernel/trunk/arch/ia64/include/interrupt.h /kernel/trunk/arch/ia64/include/ski/ski.h /kernel/trunk/arch/ia64/src/ia64.c /kernel/trunk/arch/ia64/src/interrupt.c /kernel/trunk/arch/ia64/src/ski/ski.c /kernel/trunk/generic/include/ipc/irq.h /kernel/trunk/generic/src/ipc/irq.c
|
1502 |
6698 d 8 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 |
|
/kernel/trunk/arch/ia32/src/smp/smp.c /kernel/trunk/generic/include/ipc/ipc.h /kernel/trunk/generic/include/proc/thread.h /kernel/trunk/generic/include/synch/condvar.h /kernel/trunk/generic/include/synch/futex.h /kernel/trunk/generic/include/synch/mutex.h /kernel/trunk/generic/include/synch/rwlock.h /kernel/trunk/generic/include/synch/semaphore.h /kernel/trunk/generic/include/synch/synch.h /kernel/trunk/generic/include/synch/waitq.h /kernel/trunk/generic/src/ipc/ipc.c /kernel/trunk/generic/src/ipc/sysipc.c /kernel/trunk/generic/src/proc/thread.c /kernel/trunk/generic/src/synch/condvar.c /kernel/trunk/generic/src/synch/futex.c /kernel/trunk/generic/src/synch/mutex.c /kernel/trunk/generic/src/synch/rwlock.c /kernel/trunk/generic/src/synch/semaphore.c /kernel/trunk/generic/src/synch/waitq.c
|
1494 |
6698 d 20 h |
palkovsky |
/kernel/trunk/generic/ |
Removes unnecessary parameter for map_physmem syscall. |
|
/kernel/trunk/generic/include/ddi/ddi.h /kernel/trunk/generic/src/ddi/ddi.c
|
1484 |
6699 d 6 h |
palkovsky |
/kernel/trunk/generic/include/ |
Added EINVAL error code. |
|
/kernel/trunk/generic/include/errno.h
|
1474 |
6699 d 22 h |
palkovsky |
/kernel/trunk/ |
Added syscall that lets kernel regain access to keyboard. |
|
/kernel/trunk/arch/amd64/src/amd64.c /kernel/trunk/arch/ia32/src/ia32.c /kernel/trunk/arch/ia64/src/ia64.c /kernel/trunk/arch/mips32/include/drivers/msim.h /kernel/trunk/arch/mips32/src/console.c /kernel/trunk/arch/mips32/src/drivers/msim.c /kernel/trunk/arch/mips32/src/mips32.c /kernel/trunk/arch/ppc32/src/ppc32.c /kernel/trunk/arch/ppc64/src/ppc64.c /kernel/trunk/arch/sparc64/src/sparc64.c /kernel/trunk/genarch/include/i8042/i8042.h /kernel/trunk/genarch/src/i8042/i8042.c /kernel/trunk/generic/include/console/console.h /kernel/trunk/generic/include/syscall/syscall.h /kernel/trunk/generic/src/console/cmd.c /kernel/trunk/generic/src/syscall/syscall.c
|
1468 |
6700 d 4 h |
jermar |
/kernel/trunk/ |
Function for destroying address space for which there is no other reference in the kernel. |
|
/kernel/trunk/arch/ia32/include/mm/asid.h /kernel/trunk/genarch/src/mm/as_ht.c /kernel/trunk/genarch/src/mm/as_pt.c /kernel/trunk/generic/include/mm/as.h /kernel/trunk/generic/include/mm/page.h /kernel/trunk/generic/include/proc/task.h /kernel/trunk/generic/src/mm/as.c /kernel/trunk/generic/src/proc/task.c
|
1461 |
6700 d 6 h |
palkovsky |
/kernel/trunk/generic/ |
Slightly changed semantics of AS_AREA_SEND/RECV. |
|
/kernel/trunk/generic/include/ipc/ipc.h /kernel/trunk/generic/src/ipc/sysipc.c /kernel/trunk/generic/src/mm/as.c
|
1460 |
6700 d 8 h |
jermar |
/kernel/trunk/generic/ |
Reference counting for futexes. |
|
/kernel/trunk/generic/include/proc/task.h /kernel/trunk/generic/include/synch/futex.h /kernel/trunk/generic/src/proc/task.c /kernel/trunk/generic/src/synch/futex.c
|
1440 |
6702 d 21 h |
palkovsky |
/kernel/trunk/generic/include/ |
Added error code for timeouts. |
|
/kernel/trunk/generic/include/errno.h
|
1438 |
6702 d 22 h |
palkovsky |
/kernel/trunk/generic/ |
Correct realtime clock communication. |
|
/kernel/trunk/generic/include/print.h /kernel/trunk/generic/src/time/clock.c
|
1434 |
6703 d 2 h |
palkovsky |
/kernel/trunk/ |
Added 'realtime' clock interface.
Added some asm macros as memory barriers.
Added drift computing for mips platform. |
|
/kernel/trunk/arch/ia32/include/barrier.h /kernel/trunk/arch/mips32/include/barrier.h /kernel/trunk/arch/mips32/include/cp0.h /kernel/trunk/arch/mips32/src/interrupt.c /kernel/trunk/arch/mips32/src/mips32.c /kernel/trunk/generic/include/time/clock.h /kernel/trunk/generic/src/ipc/sysipc.c /kernel/trunk/generic/src/main/main.c /kernel/trunk/generic/src/mm/as.c /kernel/trunk/generic/src/time/clock.c
|
1431 |
6703 d 9 h |
jermar |
/kernel/trunk/generic/ |
Add missed_clock_ticks to CPU structure so that clock() can detect missed timer interrupts.
Architectures are required to support this in order to make time keeping accurate. |
|
/kernel/trunk/generic/include/cpu.h /kernel/trunk/generic/src/time/clock.c
|
1429 |
6703 d 11 h |
jermar |
/kernel/trunk/generic/ |
Make ddi_physmem_map() accept address space area flags instead of writable switch.
Thus even these types of address space areas can turn caching on, if it is desired. |
|
/kernel/trunk/generic/include/ddi/ddi_arg.h /kernel/trunk/generic/src/ddi/ddi.c
|
1428 |
6703 d 22 h |
palkovsky |
/kernel/trunk/generic/ |
Added 256K slab, so that AMD can boot (until ELF loader is fixed).
Added AS_AREA_RECV so that the caller can receive AS_AREA. |
|
/kernel/trunk/generic/include/ipc/ipc.h /kernel/trunk/generic/include/mm/as.h /kernel/trunk/generic/include/mm/slab.h /kernel/trunk/generic/src/ipc/sysipc.c /kernel/trunk/generic/src/mm/as.c /kernel/trunk/generic/src/mm/slab.c
|
1425 |
6704 d 1 h |
jermar |
/kernel/trunk/generic/ |
Make address space backend data a union. |
|
/kernel/trunk/generic/include/elf.h /kernel/trunk/generic/include/mm/as.h /kernel/trunk/generic/src/ddi/ddi.c /kernel/trunk/generic/src/lib/elf.c /kernel/trunk/generic/src/mm/backend_anon.c /kernel/trunk/generic/src/mm/backend_elf.c /kernel/trunk/generic/src/mm/backend_phys.c
|
1424 |
6704 d 3 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. |
|
/kernel/trunk/generic/src/mm/backend_anon.c /kernel/trunk/generic/src/mm/backend_elf.c /kernel/trunk/generic/src/mm/backend_phys.c
/kernel/trunk/Makefile /kernel/trunk/genarch/src/mm/page_ht.c /kernel/trunk/generic/include/mm/as.h /kernel/trunk/generic/src/ddi/ddi.c /kernel/trunk/generic/src/lib/elf.c /kernel/trunk/generic/src/mm/as.c /kernel/trunk/generic/src/proc/task.c
|
1423 |
6704 d 7 h |
jermar |
/kernel/trunk/ |
Update page fault handlers to distinguish between different access modes that had caused the page fault. |
|
/kernel/trunk/arch/amd64/include/mm/page.h /kernel/trunk/arch/ia32/include/mm/page.h /kernel/trunk/arch/mips32/include/mm/page.h /kernel/trunk/arch/ppc32/include/mm/page.h /kernel/trunk/arch/ppc64/include/mm/page.h /kernel/trunk/genarch/include/mm/page_ht.h /kernel/trunk/genarch/include/mm/page_pt.h /kernel/trunk/generic/include/mm/as.h /kernel/trunk/generic/src/lib/elf.c /kernel/trunk/generic/src/mm/as.c
|
1417 |
6705 d 23 h |
jermar |
/kernel/trunk/generic/ |
Modify as_area_share() to accept destination area flags bitmask from the sender
(i.e. the sender can limit access mode to the shared area for the recipient).
Modify IPC_M_AS_AREA_SEND code to support this. Arguments for sender: arg1=as_area,
arg2=size, arg3=flags_mask.
The mechanism seems to work, but the page fault handlers need to be altered to
distinguish between faults under different access modes. |
|
/kernel/trunk/generic/include/mm/as.h /kernel/trunk/generic/src/ipc/sysipc.c /kernel/trunk/generic/src/mm/as.c
|
1416 |
6706 d 11 h |
jermar |
/kernel/trunk/generic/ |
Make implementation of condition variables compliant with their definition.
Signal operation must become a no-op if there is no thread in the wait operation.
Remove condvar_trywait() which has no meaning after this change. |
|
/kernel/trunk/generic/include/synch/condvar.h /kernel/trunk/generic/src/synch/condvar.c
|
1415 |
6706 d 12 h |
jermar |
/kernel/trunk/generic/ |
Some renaming to prevent confusion.
as_lock -> inactive_as_with_asid_lock
as_t::refcount -> as_t::cpu_refcount |
|
/kernel/trunk/generic/include/mm/as.h /kernel/trunk/generic/src/mm/as.c
|
1413 |
6706 d 23 h |
jermar |
/kernel/trunk/generic/ |
Reimplement memory sharing. Currently, only
anonymous address space areas can be shared. |
|
/kernel/trunk/generic/include/mm/as.h /kernel/trunk/generic/src/ipc/sysipc.c /kernel/trunk/generic/src/mm/as.c
|
1411 |
6707 d 4 h |
jermar |
/kernel/trunk/ |
Modify the hierarchy of page fault handlers to pass access mode that caused the fault.
Architectures are required to pass either PF_ACCESS_READ, PF_ACCESS_WRITE or PF_ACCESS_EXEC
to as_page_fault(), depending on the cause of the fault. |
|
/kernel/trunk/arch/amd64/include/mm/page.h /kernel/trunk/arch/amd64/src/mm/page.c /kernel/trunk/arch/ia32/include/interrupt.h /kernel/trunk/arch/ia32/include/mm/page.h /kernel/trunk/arch/ia32/src/interrupt.c /kernel/trunk/arch/ia32/src/mm/page.c /kernel/trunk/arch/ia64/src/mm/tlb.c /kernel/trunk/arch/mips32/src/mm/tlb.c /kernel/trunk/arch/ppc32/src/mm/page.c /kernel/trunk/arch/ppc64/src/mm/page.c /kernel/trunk/generic/include/mm/as.h /kernel/trunk/generic/include/mm/page.h /kernel/trunk/generic/src/lib/elf.c /kernel/trunk/generic/src/mm/as.c
|
1409 |
6707 d 21 h |
jermar |
/kernel/trunk/generic/ |
Some shared memory stuff (not completed).
Support for address space area backends.
Add ELF and anonymous memory backends. |
|
/kernel/trunk/generic/include/mm/as.h /kernel/trunk/generic/src/ddi/ddi.c /kernel/trunk/generic/src/lib/elf.c /kernel/trunk/generic/src/mm/as.c /kernel/trunk/generic/src/proc/task.c
|
1387 |
6710 d 5 h |
jermar |
/kernel/trunk/generic/ |
Add used_space_insert() and used_space_remove().
These are the alpha versions of functions that
will help to map used and unused portions of address
space areas. Currently unused, but many as_area operations
will be more efficient when the used space B+tree map
is used. |
|
/kernel/trunk/generic/include/mm/as.h /kernel/trunk/generic/src/mm/as.c
|
1382 |
6710 d 23 h |
decky |
/kernel/trunk/ |
make hardware memory mapping more generic |
|
/kernel/trunk/genarch/src/fb/fb_map.c
/kernel/trunk/arch/amd64/src/mm/page.c /kernel/trunk/arch/ia32/src/mm/page.c /kernel/trunk/arch/sparc64/Makefile.inc /kernel/trunk/arch/sparc64/src/console.c /kernel/trunk/arch/sparc64/src/mm/page.c /kernel/trunk/genarch/Makefile.inc /kernel/trunk/genarch/include/fb/fb.h /kernel/trunk/genarch/src/fb/fb.c /kernel/trunk/generic/include/mm/page.h
|
1380 |
6711 d 1 h |
jermar |
/kernel/trunk/ |
Turn address space lock, address space area lock and
page_ht_lock into mutexes. |
|
/kernel/trunk/genarch/include/mm/page_ht.h /kernel/trunk/genarch/src/mm/as_ht.c /kernel/trunk/genarch/src/mm/as_pt.c /kernel/trunk/genarch/src/mm/asid.c /kernel/trunk/genarch/src/mm/page_ht.c /kernel/trunk/generic/include/mm/as.h /kernel/trunk/generic/include/synch/mutex.h /kernel/trunk/generic/include/typedefs.h /kernel/trunk/generic/src/mm/as.c /kernel/trunk/generic/src/proc/scheduler.c
|
1375 |
6712 d 9 h |
jermar |
/kernel/trunk/generic/ |
Fix race in condition variables. |
|
/kernel/trunk/generic/include/synch/waitq.h /kernel/trunk/generic/src/synch/condvar.c /kernel/trunk/generic/src/synch/waitq.c
|
1364 |
6714 d 7 h |
jermar |
/kernel/trunk/generic/ |
Modify ipc_wait_for_call() to support all of blocking, non-blocking and timeout operation. |
|
/kernel/trunk/generic/include/ipc/ipc.h /kernel/trunk/generic/include/ipc/sysipc.h /kernel/trunk/generic/src/ipc/ipc.c /kernel/trunk/generic/src/ipc/sysipc.c
|
1359 |
6715 d 3 h |
jermar |
/kernel/trunk/generic/ |
Rename IPC_M_AS_SEND to IPC_M_AS_AREA_SEND. |
|
/kernel/trunk/generic/include/ipc/ipc.h /kernel/trunk/generic/src/ipc/sysipc.c
|
1358 |
6715 d 4 h |
jermar |
/kernel/trunk/generic/ |
Cleanup after removal of as_area_accept and as_area_send. |
|
/kernel/trunk/generic/include/mm/as_arg.h
/kernel/trunk/generic/include/mm/as.h /kernel/trunk/generic/include/proc/task.h /kernel/trunk/generic/src/mm/as.c /kernel/trunk/generic/src/proc/task.c
|