Subversion Repositories HelenOS-historic

Rev

Go to most recent revision | Hide changed files | Details | Compare with Previous | Blame | RSS feed

Filtering Options

Rev Age Author Path Log message Diff Changes
1460 6732 d 13 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 6735 d 2 h palkovsky /kernel/trunk/generic/include/ Added error code for timeouts.  
/kernel/trunk/generic/include/errno.h
1438 6735 d 3 h palkovsky /kernel/trunk/generic/ Correct realtime clock communication.  
/kernel/trunk/generic/include/print.h
/kernel/trunk/generic/src/time/clock.c
1434 6735 d 7 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 6735 d 14 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 6735 d 15 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 6736 d 2 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 6736 d 5 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 6736 d 7 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 6736 d 12 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 6738 d 4 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 6738 d 15 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 6738 d 16 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 6739 d 3 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 6739 d 8 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 6740 d 2 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 6742 d 10 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 6743 d 4 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 6743 d 6 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 6744 d 13 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

Show All