Subversion Repositories HelenOS

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
1984 6440 d 8 h jermar /trunk/kernel/arch/sparc64/ sparc64 work:
- untested support for Psycho PCI controller
 
/trunk/kernel/arch/sparc64/include/drivers/pci.h
/trunk/kernel/arch/sparc64/src/drivers/pci.c
1983 6441 d 12 h jermar /trunk/kernel/arch/sparc64/src/mm/ sparc64 work:
- fix computation of the frame allocator configuration frame
- mark the first physical frame unavailable, no matter what is its address

Because of that, we can now boot past the frame_arch_init() on the Ultra 60 now.
 
/trunk/kernel/arch/sparc64/src/mm/frame.c
1982 6441 d 15 h jermar /trunk/ Modify the sparc64 startup code to not cause MMU traps before it takes over the TLB and
the trap table. Fix several PA2KA and KA2PA omittions or errors. Fix configuration to pass
the DEFS variable along.
 
/trunk/boot/arch/sparc64/Makefile.inc
/trunk/boot/arch/sparc64/loader/Makefile
/trunk/boot/boot.config
/trunk/kernel/arch/sparc64/src/mm/page.c
/trunk/kernel/arch/sparc64/src/sparc64.c
/trunk/kernel/arch/sparc64/src/start.S
1980 6441 d 16 h jermar /trunk/kernel/arch/mips32/include/mm/ mips32 mm has not been under construction for while now  
/trunk/kernel/arch/mips32/include/mm/page.h
1978 6442 d 8 h jermar /trunk/ sparc64 code to support physical memory that starts on non-zero addresses.
Still needs to be tested on systems with such setup.
 
/trunk/boot/arch/sparc64/loader/asm.S
/trunk/boot/arch/sparc64/loader/asm.h
/trunk/boot/arch/sparc64/loader/main.c
/trunk/boot/arch/sparc64/loader/main.h
/trunk/boot/arch/sparc64/loader/ofwarch.c
/trunk/boot/arch/sparc64/loader/ofwarch.h
/trunk/kernel/arch/sparc64/include/boot/boot.h
/trunk/kernel/arch/sparc64/include/mm/page.h
/trunk/kernel/arch/sparc64/include/trap/mmu.h
/trunk/kernel/arch/sparc64/src/start.S
1977 6443 d 4 h jermar /trunk/ Fix bad indentation in ofw.c

sparc64 work:
o Fix copyright in main.c
o Move code from unused parts of the trap table.
 
/trunk/boot/arch/sparc64/loader/main.c
/trunk/boot/genarch/ofw.c
/trunk/kernel/arch/sparc64/src/trap/trap_table.S
1976 6448 d 13 h jermar /trunk/kernel/arch/sparc64/ sparc64 context does not have to include the CLEANWIN register.  
/trunk/kernel/arch/sparc64/include/context.h
/trunk/kernel/arch/sparc64/include/context_offset.h
/trunk/kernel/arch/sparc64/src/context.S
1975 6452 d 6 h jermar /trunk/kernel/arch/sparc64/src/ Typo.  
/trunk/kernel/arch/sparc64/src/start.S
1970 6461 d 15 h decky /trunk/kernel/arch/ia32/src/smp/ use new IRQ scheme in l_apic_timer_interrupt()  
/trunk/kernel/arch/ia32/src/smp/apic.c
1960 6463 d 7 h jermar /trunk/kernel/arch/sparc64/src/mm/ Fix the following bug:

Ticket #3 data_access_exception after killing task on sparc64
 
/trunk/kernel/arch/sparc64/src/mm/tsb.c
1959 6463 d 14 h decky /trunk/kernel/arch/ia32xen/src/ ia32xen: adopt new IRQ interface  
/trunk/kernel/arch/ia32xen/src/ia32xen.c
/trunk/kernel/arch/ia32xen/src/interrupt.c
/trunk/kernel/arch/ia32xen/src/mm/page.c
/trunk/kernel/arch/ia32xen/src/pm.c
1958 6463 d 14 h decky /trunk/kernel/arch/amd64/ amd64: adopt new IRQ interface  
/trunk/kernel/arch/amd64/include/interrupt.h
/trunk/kernel/arch/amd64/include/mm/page.h
/trunk/kernel/arch/amd64/src/amd64.c
/trunk/kernel/arch/amd64/src/interrupt.c
/trunk/kernel/arch/amd64/src/mm/page.c
/trunk/kernel/arch/amd64/src/pm.c
1957 6463 d 15 h decky /trunk/kernel/ ia32: mouse support, mouse regrab is still broken  
/trunk/kernel/arch/ia32/include/interrupt.h
/trunk/kernel/arch/ia32/src/ia32.c
/trunk/kernel/genarch/include/kbd/i8042.h
/trunk/kernel/genarch/src/kbd/i8042.c
1956 6463 d 17 h decky /trunk/kernel/ ia32: adopt new IRQ interface, mouse not tested yet  
/trunk/kernel/arch/ia32/include/interrupt.h
/trunk/kernel/arch/ia32/src/drivers/i8254.c
/trunk/kernel/arch/ia32/src/ia32.c
/trunk/kernel/arch/ia32/src/interrupt.c
/trunk/kernel/arch/ia32/src/mm/page.c
/trunk/kernel/arch/ia32/src/pm.c
/trunk/kernel/genarch/include/kbd/i8042.h
/trunk/kernel/genarch/src/kbd/i8042.c
1955 6463 d 19 h decky /trunk/kernel/arch/mips32/ timer_fnc -> virtual_timer_fnc  
/trunk/kernel/arch/mips32/include/interrupt.h
/trunk/kernel/arch/mips32/src/drivers/arc.c
/trunk/kernel/arch/mips32/src/drivers/serial.c
/trunk/kernel/arch/mips32/src/interrupt.c
1954 6464 d 6 h jermar /trunk/ Minor changes. Some coding style fixes and also a type (tee vs. tree).
One AS -> as change.
 
/trunk/kernel/arch/sparc64/include/mm/tsb.h
/trunk/kernel/arch/sparc64/include/trap/mmu.h
/trunk/kernel/arch/sparc64/src/start.S
/trunk/kernel/generic/src/mm/as.c
/trunk/kernel/generic/src/mm/backend_anon.c
/trunk/uspace/fb/fb.c
1953 6468 d 9 h jermar /trunk/kernel/ Finish renaming xen32 to ia32xen.  
/trunk/kernel/arch/ia32xen/src/ia32xen.c
/trunk/kernel/arch/ia32xen/src/xen32.c
/trunk/kernel/arch/ia32xen/xen32
/trunk/kernel/Makefile
/trunk/kernel/arch/ia32xen/Makefile.inc
/trunk/kernel/arch/ia32xen/_link.ld.in
1952 6468 d 9 h jermar /trunk/ Rename xen32 to ia32xen.
The name seems to be more logical as Xen supports more host architectures.
 
/trunk/boot/arch/ia32xen
/trunk/kernel/arch/ia32xen
/trunk/kernel/arch/ia32xen/xen32
/trunk/boot/arch/xen32
/trunk/kernel/arch/ia32xen/xen32/Makefile.inc
/trunk/kernel/arch/ia32xen/xen32/_link.ld.in
/trunk/kernel/arch/ia32xen/xen32/include
/trunk/kernel/arch/ia32xen/xen32/src
/trunk/kernel/arch/xen32
/trunk/HelenOS.config
/trunk/Makefile
/trunk/boot/arch/ia32xen/grub/menu.debug.lst
/trunk/boot/arch/ia32xen/grub/menu.lst
/trunk/boot/boot.config
/trunk/kernel/arch/ia32xen/include/asm.h
/trunk/kernel/arch/ia32xen/include/boot/boot.h
/trunk/kernel/arch/ia32xen/include/drivers/xconsole.h
/trunk/kernel/arch/ia32xen/include/hypercall.h
/trunk/kernel/arch/ia32xen/include/mm/as.h
/trunk/kernel/arch/ia32xen/include/mm/asid.h
/trunk/kernel/arch/ia32xen/include/mm/frame.h
/trunk/kernel/arch/ia32xen/include/mm/memory_init.h
/trunk/kernel/arch/ia32xen/include/mm/page.h
/trunk/kernel/arch/ia32xen/include/mm/tlb.h
/trunk/kernel/arch/ia32xen/include/pm.h
/trunk/kernel/arch/ia32xen/include/types.h
/trunk/kernel/arch/ia32xen/src/drivers/xconsole.c
/trunk/kernel/arch/ia32xen/src/interrupt.c
/trunk/kernel/arch/ia32xen/src/mm/as.c
/trunk/kernel/arch/ia32xen/src/mm/frame.c
/trunk/kernel/arch/ia32xen/src/mm/memory_init.c
/trunk/kernel/arch/ia32xen/src/mm/page.c
/trunk/kernel/arch/ia32xen/src/mm/tlb.c
/trunk/kernel/arch/ia32xen/src/pm.c
/trunk/kernel/arch/ia32xen/src/proc/scheduler.c
/trunk/kernel/arch/ia32xen/src/proc/task.c
/trunk/kernel/arch/ia32xen/src/proc/thread.c
/trunk/kernel/arch/ia32xen/src/smp/apic.c
/trunk/kernel/arch/ia32xen/src/smp/ipi.c
/trunk/kernel/arch/ia32xen/src/smp/mps.c
/trunk/kernel/arch/ia32xen/src/smp/smp.c
/trunk/kernel/arch/ia32xen/src/userspace.c
/trunk/kernel/arch/ia32xen/src/xen32.c
/trunk/kernel/kernel.config
1949 6468 d 15 h jermar /trunk/kernel/arch/ Remove notes about automatically generated context_offset.h
and replace it with a proper copyright notice.
 
/trunk/kernel/arch/amd64/include/context_offset.h
/trunk/kernel/arch/mips32/include/context_offset.h
/trunk/kernel/arch/ppc32/include/context_offset.h
/trunk/kernel/arch/ppc64/include/context_offset.h
/trunk/kernel/arch/sparc64/include/context_offset.h
1948 6468 d 17 h jermar /trunk/kernel/ Remove broken, outdated and unused gencontext.c utilities.  
/trunk/kernel/tools/amd64/gencontext.c
/trunk/kernel/tools/mips32/gencontext.c
/trunk/kernel/tools/ppc32/gencontext.c
/trunk/kernel/tools/ppc64/gencontext.c
/trunk/kernel/tools/sparc64/gencontext.c
/trunk/kernel/arch/amd64/include/context.h
/trunk/kernel/arch/mips32/include/context.h
/trunk/kernel/arch/mips32/include/context_offset.h
/trunk/kernel/arch/mips32/include/exception.h
/trunk/kernel/arch/ppc32/include/context.h
/trunk/kernel/arch/ppc32/include/exception.h
/trunk/kernel/arch/ppc64/include/context.h
/trunk/kernel/arch/ppc64/include/exception.h
/trunk/kernel/arch/sparc64/include/context.h
1946 6471 d 5 h jermar /trunk/kernel/arch/sparc64/ sparc64 work.
- Improve panic screen on data_access_exception
by dumping contents of DSFSR and DSFAR.
- Change the FHC enable interrupt code to only
set the IMAP_V bit.
 
/trunk/kernel/arch/sparc64/include/mm/tlb.h
/trunk/kernel/arch/sparc64/src/drivers/fhc.c
/trunk/kernel/arch/sparc64/src/drivers/pci.c
/trunk/kernel/arch/sparc64/src/mm/tlb.c
/trunk/kernel/arch/sparc64/src/trap/exception.c
1945 6471 d 10 h jermar /trunk/kernel/arch/ia64/ ia64 work.
Move keyboard polling to a dedicated kernel thread.
Console initialization and console related sysinfo setup
can be now done in a single function.
 
/trunk/kernel/arch/ia64/include/ski/ski.h
/trunk/kernel/arch/ia64/src/drivers/it.c
/trunk/kernel/arch/ia64/src/ia64.c
/trunk/kernel/arch/ia64/src/ski/ski.c
1944 6471 d 10 h jermar /trunk/kernel/ Add mutual exclusion to keyboard grab and release
functions on sparc64, ppc32, mips32 and ia64.
 
/trunk/kernel/arch/ia64/src/ski/ski.c
/trunk/kernel/arch/mips32/src/drivers/msim.c
/trunk/kernel/arch/ppc32/src/drivers/cuda.c
/trunk/kernel/arch/ppc32/src/drivers/pic.c
/trunk/kernel/genarch/src/kbd/ns16550.c
/trunk/kernel/genarch/src/kbd/z8530.c
1943 6471 d 19 h decky /trunk/kernel/arch/xen32/src/ xen32: fix compilation  
/trunk/kernel/arch/xen32/src/interrupt.c
1942 6472 d 7 h jermar /trunk/ Convert ia64 to the new IRQ and notification scheme.  
/trunk/kernel/arch/ia64/include/drivers/it.h
/trunk/kernel/arch/ia64/include/interrupt.h
/trunk/kernel/arch/ia64/include/ski/ski.h
/trunk/kernel/arch/ia64/src/drivers/it.c
/trunk/kernel/arch/ia64/src/ia64.c
/trunk/kernel/arch/ia64/src/interrupt.c
/trunk/kernel/arch/ia64/src/ski/ski.c
/trunk/kernel/arch/sparc64/include/interrupt.h
/trunk/uspace/kbd/arch/ia64/src/kbd.c
1940 6472 d 11 h decky /trunk/kernel/arch/amd64/ amd64: fix compilation, keyboard not checked yet  
/trunk/kernel/arch/amd64/include/interrupt.h
/trunk/kernel/arch/amd64/src/interrupt.c
1939 6472 d 11 h decky /trunk/ ia32: fix compilation, keyboard not checked yet  
/trunk/kernel/arch/ia32/include/interrupt.h
/trunk/kernel/arch/ia32/src/interrupt.c
/trunk/uspace/kbd/arch/ia32/include/kbd.h
/trunk/uspace/kbd/arch/ia32/src/kbd.c
1937 6472 d 18 h decky /trunk/kernel/arch/ remove orphaned functions  
/trunk/kernel/arch/amd64/src/interrupt.c
/trunk/kernel/arch/ia32/src/interrupt.c
/trunk/kernel/arch/ia64/src/interrupt.c
/trunk/kernel/arch/xen32/src/interrupt.c
1936 6472 d 18 h decky /trunk/kernel/arch/mips32/ mips32: update for new IRQ subsystem  
/trunk/kernel/arch/mips32/include/console.h
/trunk/kernel/arch/mips32/include/drivers/msim.h
/trunk/kernel/arch/mips32/include/drivers/serial.h
/trunk/kernel/arch/mips32/include/interrupt.h
/trunk/kernel/arch/mips32/src/console.c
/trunk/kernel/arch/mips32/src/drivers/arc.c
/trunk/kernel/arch/mips32/src/drivers/msim.c
/trunk/kernel/arch/mips32/src/drivers/serial.c
/trunk/kernel/arch/mips32/src/exception.c
/trunk/kernel/arch/mips32/src/interrupt.c
/trunk/kernel/arch/mips32/src/mips32.c
1934 6472 d 19 h decky /trunk/kernel/arch/ppc32/src/drivers/ remove grab (not needed)  
/trunk/kernel/arch/ppc32/src/drivers/cuda.c
1932 6473 d 7 h jermar /trunk/kernel/ Do not copy notification config out of the IRQ structure.
Add the notify member, that toggles notifications on and off instead.
This is good for preventing other tasks from registering the notification
while the notification config is stored outside the IRQ structure.
It should also help to implement the cleanup code.
 
/trunk/kernel/arch/ppc32/src/drivers/cuda.c
/trunk/kernel/genarch/src/kbd/ns16550.c
/trunk/kernel/genarch/src/kbd/z8530.c
/trunk/kernel/generic/include/ipc/irq.h
/trunk/kernel/generic/src/ipc/irq.c
1931 6473 d 9 h jermar /trunk/ Add support for IPC notifications even for polled ns16550 based keyboard.  
/trunk/kernel/arch/sparc64/src/console.c
/trunk/kernel/genarch/src/kbd/ns16550.c
/trunk/kernel/genarch/src/kbd/z8530.c
/trunk/uspace/kbd/arch/sparc64/src/kbd.c
1930 6473 d 12 h decky /trunk/kernel/arch/ppc64/ ppc64: make it compile again  
/trunk/kernel/arch/ppc64/include/drivers
/trunk/kernel/arch/ppc64/include/drivers/pic.h
/trunk/kernel/arch/ppc64/src/drivers
/trunk/kernel/arch/ppc64/src/drivers/pic.c
/trunk/kernel/arch/ppc64/Makefile.inc
/trunk/kernel/arch/ppc64/include/interrupt.h
/trunk/kernel/arch/ppc64/src/interrupt.c
1928 6473 d 13 h decky /trunk/ ppc32: update for new IRQ subsystem (there is still a bug left)  
/trunk/kernel/arch/ppc32/include/drivers/cuda.h
/trunk/kernel/arch/ppc32/include/interrupt.h
/trunk/kernel/arch/ppc32/src/drivers/cuda.c
/trunk/kernel/arch/ppc32/src/drivers/pic.c
/trunk/kernel/arch/ppc32/src/interrupt.c
/trunk/kernel/arch/ppc32/src/ppc32.c
/trunk/uspace/kbd/arch/ppc32/src/kbd.c
1926 6473 d 18 h decky /trunk/kernel/ cleanup for new IRQ subsystem  
/trunk/kernel/arch/ppc32/src/interrupt.c
/trunk/kernel/generic/src/ddi/device.c
1923 6474 d 7 h jermar /trunk/ Replace the old IRQ dispatcher and IPC notifier with new implementation.
Note that all architectures except for sparc64 are now broken
and don't even compile.
 
/trunk/kernel/arch/sparc64/src/trap/interrupt.c
/trunk/kernel/genarch/src/kbd/z8530.c
/trunk/kernel/generic/include/ddi/irq.h
/trunk/kernel/generic/include/ipc/ipc.h
/trunk/kernel/generic/include/ipc/irq.h
/trunk/kernel/generic/include/ipc/sysipc.h
/trunk/kernel/generic/include/typedefs.h
/trunk/kernel/generic/src/console/cmd.c
/trunk/kernel/generic/src/console/klog.c
/trunk/kernel/generic/src/ddi/irq.c
/trunk/kernel/generic/src/ipc/ipc.c
/trunk/kernel/generic/src/ipc/irq.c
/trunk/kernel/generic/src/ipc/sysipc.c
/trunk/uspace/kbd/arch/sparc64/src/kbd.c
/trunk/uspace/klog/klog.c
/trunk/uspace/libc/generic/async.c
/trunk/uspace/libc/generic/ipc.c
/trunk/uspace/libc/include/ipc/ipc.h
1922 6475 d 15 h jermar /trunk/kernel/ More IRQ stuff.
Modify the IRQ hash table functions to support lookup based on inr and devno.
Add method member to irq_t.
 
/trunk/kernel/arch/sparc64/src/trap/interrupt.c
/trunk/kernel/generic/include/ddi/irq.h
/trunk/kernel/generic/src/ddi/irq.c
1921 6476 d 8 h jermar /trunk/kernel/ Changes in ns16550 and z8530 drivers.
Add some stuff for IRQ notifications to irq_t.
 
/trunk/kernel/arch/sparc64/include/drivers/kbd.h
/trunk/kernel/arch/sparc64/include/drivers/ns16550.h
/trunk/kernel/arch/sparc64/include/drivers/z8530.h
/trunk/kernel/arch/sparc64/src/drivers/kbd.c
/trunk/kernel/genarch/include/kbd/ns16550.h
/trunk/kernel/genarch/include/kbd/z8530.h
/trunk/kernel/genarch/src/kbd/ns16550.c
/trunk/kernel/genarch/src/kbd/z8530.c
/trunk/kernel/generic/include/ddi/irq.h
/trunk/kernel/generic/src/ddi/irq.c
1920 6476 d 16 h jermar /trunk/kernel/ Move the new IRQ redirector to ddi/.
Add function for assigning unique device numbers.
Change sparc64/drivers/kbd.c to assign devno to keyboard.
 
/trunk/kernel/generic/include/ddi/device.h
/trunk/kernel/generic/include/ddi/irq.h
/trunk/kernel/generic/src/ddi/device.c
/trunk/kernel/generic/src/ddi/irq.c
/trunk/kernel/generic/include/irq.h
/trunk/kernel/generic/src/interrupt/irq.c
/trunk/kernel/Makefile
/trunk/kernel/arch/sparc64/src/drivers/kbd.c
/trunk/kernel/arch/sparc64/src/sparc64.c
/trunk/kernel/arch/sparc64/src/trap/interrupt.c
/trunk/kernel/genarch/include/kbd/ns16550.h
/trunk/kernel/genarch/include/kbd/z8530.h
/trunk/kernel/genarch/src/kbd/ns16550.c
/trunk/kernel/genarch/src/kbd/z8530.c
/trunk/kernel/generic/include/typedefs.h
1919 6477 d 7 h jermar /trunk/kernel/ Prototypical implementation of new IRQ redirector in sparc64.
The new code can support shared IRQs in kernel (and multiple IRQs per device).
Userspace support is yet to be written.
The only architecture that uses this code is actually sparc64 only.
 
/trunk/kernel/generic/include/irq.h
/trunk/kernel/generic/src/interrupt/irq.c
/trunk/kernel/Makefile
/trunk/kernel/arch/sparc64/src/drivers/kbd.c
/trunk/kernel/arch/sparc64/src/sparc64.c
/trunk/kernel/arch/sparc64/src/trap/interrupt.c
/trunk/kernel/genarch/include/kbd/ns16550.h
/trunk/kernel/genarch/include/kbd/z8530.h
/trunk/kernel/genarch/src/kbd/ns16550.c
/trunk/kernel/genarch/src/kbd/z8530.c
/trunk/kernel/generic/include/ipc/irq.h