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
3963 5611 d 15 h jermar /trunk/kernel/ The kernel i8042 driver should be instance-neutral.  
/trunk/kernel/arch/amd64/src/amd64.c
/trunk/kernel/arch/ia32/src/ia32.c
/trunk/kernel/arch/ia64/src/ia64.c
/trunk/kernel/genarch/include/kbd/i8042.h
/trunk/kernel/genarch/src/kbd/i8042.c
3962 5611 d 15 h jermar /trunk/kernel/arch/ia64/src/ski/ Make ia64 for ski build again.
Need to implement kernel notifications independent of IRQ notifications.
 
/trunk/kernel/arch/ia64/src/ski/ski.c
3961 5611 d 15 h jermar /trunk/ Unbreak sparc64.
Due to the lack of userspace bus drivers for the z8530 and ns16550,
we are currently handling exactly one interrupt from these devices
in userspace.
 
/trunk/kernel/arch/sparc64/include/drivers/z8530.h
/trunk/kernel/arch/sparc64/src/console.c
/trunk/kernel/arch/sparc64/src/drivers/kbd.c
/trunk/kernel/arch/sparc64/src/drivers/sgcn.c
/trunk/kernel/genarch/include/kbd/z8530.h
/trunk/kernel/genarch/src/kbd/z8530.c
/trunk/uspace/srv/kbd/port/z8530.c
3960 5612 d 9 h jermar /trunk/kernel/genarch/include/kbd/ Remove extern declarations.  
/trunk/kernel/genarch/include/kbd/i8042.h
/trunk/kernel/genarch/include/kbd/ns16550.h
3959 5612 d 9 h jermar /trunk/kernel/genarch/src/kbd/ Remove unneeded stuff from kernel's ns16550 driver.  
/trunk/kernel/genarch/src/kbd/ns16550.c
3958 5612 d 9 h jermar /trunk/kernel/genarch/src/kbd/ Do not include the IPC stuff in the i8042 kernel driver.  
/trunk/kernel/genarch/src/kbd/i8042.c
3957 5612 d 10 h jermar /trunk/kernel/arch/ppc32/ Unbreak ppc32 candidate.  
/trunk/kernel/arch/ppc32/include/drivers/cuda.h
/trunk/kernel/arch/ppc32/src/drivers/cuda.c
/trunk/kernel/arch/ppc32/src/ppc32.c
3956 5612 d 10 h jermar /trunk/kernel/arch/ppc32/include/ Add missing PIO functions to ppc32.  
/trunk/kernel/arch/ppc32/include/asm.h
3955 5612 d 10 h jermar /trunk/ Unbreak mips32 candidate.  
/trunk/kernel/arch/mips32/src/drivers/msim.c
/trunk/kernel/arch/mips32/src/drivers/serial.c
/trunk/uspace/srv/kbd/port/msim.c
3953 5612 d 10 h jermar /trunk/kernel/arch/mips32/include/ Add missing PIO functions for mips32.  
/trunk/kernel/arch/mips32/include/asm.h
3952 5612 d 10 h jermar /trunk/kernel/arch/arm32/ Remove unnecessary stuff from arm32.  
/trunk/kernel/arch/arm32/include/machine.h
/trunk/kernel/arch/arm32/src/console.c
/trunk/kernel/arch/arm32/src/drivers/gxemul.c
3951 5612 d 11 h jermar /trunk/ Unreak arm32 (as far as breakage introduced by 3947 goes) and
adapt the uspace GXemul kbd IRQ driver to use the new pseudo code.
 
/trunk/kernel/arch/arm32/src/drivers/gxemul.c
/trunk/uspace/srv/kbd/port/gxemul.c
3950 5612 d 11 h jermar /trunk/kernel/generic/src/ddi/ Fix UP builds.  
/trunk/kernel/generic/src/ddi/irq.c
3949 5612 d 11 h jermar /trunk/kernel/arch/arm32/include/ PIO functions for arm32.  
/trunk/kernel/arch/arm32/include/asm.h
3948 5612 d 13 h jermar /trunk/kernel/arch/amd64/ Unbreak amd64.  
/trunk/kernel/arch/amd64/include/asm.h
/trunk/kernel/arch/amd64/src/amd64.c
3947 5612 d 13 h jermar /trunk/ This is the evil commit. In particular, it does:

- introduces more powerful pseudo code for userspace IRQ top-half handlers
- changes the internals of IRQ dispatching
- simplifies the kernel's i8042 driver
- adapts the uspace i8042 driver to make use of the new pseudocode
- breaks all other architectures except ia32
- breaks almost all existing drivers
- breaks switching between uspace and kernel drivers
 
/trunk/kernel/arch/ia32/src/ia32.c
/trunk/kernel/genarch/src/kbd/i8042.c
/trunk/kernel/generic/include/ddi/irq.h
/trunk/kernel/generic/include/ipc/irq.h
/trunk/kernel/generic/src/ddi/irq.c
/trunk/kernel/generic/src/ipc/irq.c
/trunk/uspace/srv/kbd/port/i8042.c
3946 5612 d 14 h jermar /trunk/kernel/arch/ia32/include/ Fix ia32's pio_{read,write}_32().  
/trunk/kernel/arch/ia32/include/asm.h
3941 5613 d 10 h jermar /trunk/kernel/ Let IRQ claim methods take irq_t * instead of the instance argument.  
/trunk/kernel/arch/arm32/src/drivers/gxemul.c
/trunk/kernel/arch/ia32/src/drivers/i8254.c
/trunk/kernel/arch/ia32/src/smp/apic.c
/trunk/kernel/arch/ia64/src/drivers/it.c
/trunk/kernel/arch/ia64/src/ski/ski.c
/trunk/kernel/arch/mips32/src/drivers/msim.c
/trunk/kernel/arch/mips32/src/drivers/serial.c
/trunk/kernel/arch/mips32/src/interrupt.c
/trunk/kernel/arch/ppc32/src/drivers/cuda.c
/trunk/kernel/arch/sparc64/src/drivers/sgcn.c
/trunk/kernel/genarch/include/kbd/ns16550.h
/trunk/kernel/genarch/include/kbd/z8530.h
/trunk/kernel/genarch/src/kbd/i8042.c
/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/console/console.c
/trunk/kernel/generic/src/console/kconsole.c
3940 5613 d 13 h decky /trunk/kernel/ make hw_area API more generic
this allows mapping of EGA VRAM on ia32/amd64
 
/trunk/kernel/arch/amd64/include/mm/tlb.h
/trunk/kernel/arch/amd64/src/mm/page.c
/trunk/kernel/arch/arm32/include/mm/tlb.h
/trunk/kernel/arch/arm32/src/mm/page.c
/trunk/kernel/arch/arm32/src/mm/tlb.c
/trunk/kernel/arch/ia32/include/mm/tlb.h
/trunk/kernel/arch/ia32/src/mm/page.c
/trunk/kernel/arch/ia32/src/mm/tlb.c
/trunk/kernel/arch/ia64/include/mm/tlb.h
/trunk/kernel/arch/ia64/src/mm/page.c
/trunk/kernel/arch/ia64/src/mm/tlb.c
/trunk/kernel/arch/mips32/src/mm/page.c
/trunk/kernel/arch/ppc32/src/mm/page.c
/trunk/kernel/arch/sparc64/src/mm/page.c
/trunk/kernel/genarch/include/drivers/ega/ega.h
/trunk/kernel/genarch/include/drivers/legacy/ia32/io.h
/trunk/kernel/genarch/src/drivers/ega/ega.c
/trunk/kernel/generic/include/mm/page.h
/trunk/kernel/generic/src/ddi/ddi.c
3938 5613 d 14 h jermar /trunk/kernel/genarch/ Embed the ns16550 irq structure into the ns16550 instance structure.  
/trunk/kernel/genarch/include/kbd/ns16550.h
/trunk/kernel/genarch/src/kbd/ns16550.c
3936 5613 d 15 h decky /trunk/ dash is not a safe character for C preprocessor, use underscore instead  
/trunk/HelenOS.config
/trunk/kernel/arch/ia32/Makefile.inc
3935 5614 d 7 h jermar /trunk/kernel/arch/sparc64/src/drivers/ Fix sparc64 build.  
/trunk/kernel/arch/sparc64/src/drivers/kbd.c
3934 5614 d 7 h jermar /trunk/kernel/ Improve the ns16550 driver.

- The driver support multiple instances.
- It still remembers the last registered IRQ in a global structure (cannot be
easily fixed now)
- Was converted to use PIO directly
 
/trunk/kernel/arch/ia64/src/ia64.c
/trunk/kernel/arch/ia64/src/smp/smp.c
/trunk/kernel/genarch/include/drivers/legacy/ia32/io.h
/trunk/kernel/genarch/include/kbd/i8042.h
/trunk/kernel/genarch/include/kbd/ns16550.h
/trunk/kernel/genarch/src/kbd/i8042.c
/trunk/kernel/genarch/src/kbd/ns16550.c
3932 5614 d 8 h jermar /trunk/kernel/ Kill arch/drivers/ega.h. Provide one-stop shopping
place for architectures with ia32 legacy I/O space.
 
/trunk/kernel/genarch/include/drivers/legacy
/trunk/kernel/genarch/include/drivers/legacy/ia32
/trunk/kernel/genarch/include/drivers/legacy/ia32/io.h
/trunk/kernel/arch/ia32/include/drivers/ega.h
/trunk/kernel/arch/ia64/include/drivers/ega.h
/trunk/kernel/arch/amd64/src/amd64.c
/trunk/kernel/arch/ia32/src/ia32.c
/trunk/kernel/arch/ia64/src/ia64.c
/trunk/kernel/genarch/src/kbd/i8042.c
3931 5614 d 9 h jermar /trunk/kernel/genarch/ Improve the i8042 kernel driver (phase I).

- Convert the code to be instance-aware
- Still using hardcoded initialization from legacy IO address
- Use elegant i8042 register map for PIO
 
/trunk/kernel/genarch/include/kbd/i8042.h
/trunk/kernel/genarch/src/kbd/i8042.c
3930 5614 d 9 h jermar /trunk/kernel/ Adapt most of the kernel to ioport8_t, ioport16_t and ioport32_t types.  
/trunk/kernel/arch/ia32/include/drivers/ega.h
/trunk/kernel/arch/ia32/include/drivers/i8259.h
/trunk/kernel/arch/ia32/src/drivers/i8254.c
/trunk/kernel/arch/ia32/src/drivers/i8259.c
/trunk/kernel/arch/ia32/src/smp/smp.c
/trunk/kernel/arch/ia64/include/drivers/ega.h
/trunk/kernel/genarch/include/drivers/ega/ega.h
/trunk/kernel/genarch/src/drivers/ega/ega.c
/trunk/kernel/generic/src/ipc/irq.c
3929 5614 d 9 h jermar /trunk/kernel/arch/ Introduce ioport8_t, ioport16_t and ioport32_t. These types are to be used with
pio_read_n() and pio_write_n() functions. This breaks everything.
 
/trunk/kernel/arch/amd64/include/asm.h
/trunk/kernel/arch/amd64/include/types.h
/trunk/kernel/arch/arm32/include/asm.h
/trunk/kernel/arch/arm32/include/types.h
/trunk/kernel/arch/ia32/include/asm.h
/trunk/kernel/arch/ia32/include/types.h
/trunk/kernel/arch/ia64/include/asm.h
/trunk/kernel/arch/ia64/include/types.h
/trunk/kernel/arch/mips32/include/asm.h
/trunk/kernel/arch/mips32/include/types.h
/trunk/kernel/arch/ppc32/include/asm.h
/trunk/kernel/arch/ppc32/include/types.h
/trunk/kernel/arch/sparc64/include/asm.h
/trunk/kernel/arch/sparc64/include/types.h
3928 5614 d 11 h jermar /trunk/kernel/ Kill arch/drivers/i8042.h.  
/trunk/kernel/arch/ia32/include/drivers/i8042.h
/trunk/kernel/arch/ia64/include/drivers/i8042.h
/trunk/kernel/genarch/src/kbd/i8042.c
3927 5614 d 11 h jermar /trunk/kernel/genarch/ Nuke i8042_poll().  
/trunk/kernel/genarch/include/kbd/i8042.h
/trunk/kernel/genarch/src/kbd/i8042.c
3922 5616 d 8 h decky /trunk/ make arch_pre_main optional, don't force any specific prototype
simplify boot process
mips32: detect number of configured CPUs in msim
 
/trunk/kernel/arch/arm32/include/boot.h
/trunk/kernel/arch/mips32/include/boot.h
/trunk/boot/arch/arm32/loader/asm.h
/trunk/boot/arch/arm32/loader/boot.S
/trunk/boot/arch/arm32/loader/main.c
/trunk/boot/arch/arm32/loader/main.h
/trunk/boot/arch/mips32/loader/asm.h
/trunk/boot/arch/mips32/loader/boot.S
/trunk/boot/arch/mips32/loader/main.c
/trunk/boot/arch/mips32/loader/main.h
/trunk/kernel/arch/arm32/include/arch.h
/trunk/kernel/arch/arm32/include/asm/boot.h
/trunk/kernel/arch/arm32/src/arm32.c
/trunk/kernel/arch/arm32/src/start.S
/trunk/kernel/arch/ia64/include/arch.h
/trunk/kernel/arch/mips32/include/arch.h
/trunk/kernel/arch/mips32/include/asm/boot.h
/trunk/kernel/arch/mips32/src/mips32.c
/trunk/kernel/arch/mips32/src/smp/smp.c
/trunk/kernel/arch/mips32/src/start.S
/trunk/kernel/arch/ppc32/include/arch.h
/trunk/kernel/arch/ppc32/include/boot/boot.h
/trunk/kernel/arch/ppc32/src/boot/boot.S
/trunk/kernel/arch/ppc32/src/ppc32.c
/trunk/kernel/arch/sparc64/include/arch.h
/trunk/kernel/generic/include/arch.h
3920 5616 d 8 h decky /trunk/kernel/generic/include/ add min3 and max3 macros  
/trunk/kernel/generic/include/macros.h
3919 5616 d 8 h decky /trunk/kernel/generic/include/ cstyle  
/trunk/kernel/generic/include/config.h
3918 5616 d 8 h decky /trunk/kernel/ avoid ugly ifdefs in fpu1 test  
/trunk/kernel/test/fpu/fpu1_ia64.c
/trunk/kernel/test/fpu/fpu1_x86.c
/trunk/kernel/test/fpu/fpu1.c
/trunk/kernel/Makefile
3917 5616 d 9 h decky /trunk/ remove non-standard define  
/trunk/HelenOS.config
/trunk/kernel/arch/arm32/Makefile.inc
/trunk/kernel/arch/arm32/_link.ld.in
/trunk/kernel/arch/arm32/include/machine.h
3913 5616 d 17 h decky /trunk/ mips32: basic SMP support  
/trunk/kernel/arch/mips32/include/smp/dorder.h
/trunk/kernel/arch/mips32/src/smp/dorder.c
/trunk/kernel/arch/mips32/src/smp/smp.c
/trunk/kernel/arch/mips32/include/smp/order.h
/trunk/kernel/arch/mips32/src/dummy.S
/trunk/kernel/arch/mips32/src/smp/order.c
/trunk/HelenOS.config
/trunk/kernel/arch/mips32/Makefile.inc
/trunk/kernel/arch/mips32/_link.ld.in
/trunk/kernel/arch/mips32/include/asm.h
/trunk/kernel/arch/mips32/include/atomic.h
/trunk/kernel/arch/mips32/include/cpu.h
/trunk/kernel/arch/mips32/include/interrupt.h
/trunk/kernel/arch/mips32/src/asm.S
/trunk/kernel/arch/mips32/src/debugger.c
/trunk/kernel/arch/mips32/src/interrupt.c
/trunk/kernel/arch/mips32/src/mips32.c
/trunk/kernel/arch/mips32/src/mm/tlb.c
/trunk/kernel/generic/src/mm/as.c
3910 5617 d 6 h decky /trunk/kernel/arch/mips32/ eliminate non-standard -D$(MACHINE)  
/trunk/kernel/arch/mips32/Makefile.inc
/trunk/kernel/arch/mips32/_link.ld.in
/trunk/kernel/arch/mips32/src/mips32.c
/trunk/kernel/arch/mips32/src/mm/frame.c
3908 5617 d 12 h decky /trunk/ overhaul pareas: use one single physical area for the physical address space not belonging to physical memory  
/trunk/kernel/arch/amd64/include/mm/frame.h
/trunk/kernel/arch/amd64/src/mm/page.c
/trunk/kernel/arch/arm32/include/mm/frame.h
/trunk/kernel/arch/arm32/src/mm/frame.c
/trunk/kernel/arch/arm32/src/mm/page.c
/trunk/kernel/arch/ia32/include/mm/frame.h
/trunk/kernel/arch/ia32/src/mm/frame.c
/trunk/kernel/arch/ia32/src/mm/page.c
/trunk/kernel/arch/ia64/include/mm/frame.h
/trunk/kernel/arch/ia64/src/mm/frame.c
/trunk/kernel/arch/ia64/src/mm/page.c
/trunk/kernel/arch/mips32/include/mm/frame.h
/trunk/kernel/arch/mips32/src/drivers/msim.c
/trunk/kernel/arch/mips32/src/mm/frame.c
/trunk/kernel/arch/mips32/src/mm/page.c
/trunk/kernel/arch/ppc32/include/mm/frame.h
/trunk/kernel/arch/ppc32/src/mm/frame.c
/trunk/kernel/arch/ppc32/src/mm/page.c
/trunk/kernel/arch/sparc64/include/mm/frame.h
/trunk/kernel/arch/sparc64/src/drivers/sgcn.c
/trunk/kernel/arch/sparc64/src/mm/frame.c
/trunk/kernel/arch/sparc64/src/mm/page.c
/trunk/kernel/genarch/src/drivers/ega/ega.c
/trunk/kernel/genarch/src/fb/fb.c
/trunk/kernel/generic/include/ddi/ddi.h
/trunk/kernel/generic/include/mm/page.h
/trunk/kernel/generic/src/adt/avl.c
/trunk/kernel/generic/src/console/cmd.c
/trunk/kernel/generic/src/console/console.c
/trunk/kernel/generic/src/ddi/ddi.c
/trunk/kernel/generic/src/lib/rd.c
/trunk/kernel/generic/src/proc/task.c
/trunk/kernel/generic/src/time/clock.c
/trunk/uspace/srv/fb/ega.c
/trunk/uspace/srv/fb/fb.c
/trunk/uspace/srv/fb/msim.c
/trunk/uspace/srv/fb/sgcn.c
/trunk/uspace/srv/kbd/arch/sparc64/src/sgcn.c
/trunk/uspace/srv/ns/ns.c
/trunk/uspace/srv/rd/rd.c
3907 5617 d 20 h decky /trunk/kernel/ remove forgotten #ifdef arch  
/trunk/kernel/test/debug/mips1_skip.c
/trunk/kernel/test/mm/purge1_skip.c
/trunk/kernel/Makefile
/trunk/kernel/genarch/include/kbd/ns16550.h
/trunk/kernel/test/debug/mips1.c
/trunk/kernel/test/debug/mips1.def
/trunk/kernel/test/mm/purge1.c
/trunk/kernel/test/mm/purge1.def
3906 5618 d 8 h jermar /trunk/kernel/ IRQ handlers are using one superfluous argument and an unused elipsis.
On the other hand, IRQ claim functions would need to be passed the instance
argument.
 
/trunk/kernel/arch/amd64/src/interrupt.c
/trunk/kernel/arch/arm32/src/drivers/gxemul.c
/trunk/kernel/arch/ia32/src/drivers/i8254.c
/trunk/kernel/arch/ia32/src/interrupt.c
/trunk/kernel/arch/ia32/src/smp/apic.c
/trunk/kernel/arch/ia64/src/drivers/it.c
/trunk/kernel/arch/ia64/src/interrupt.c
/trunk/kernel/arch/ia64/src/ski/ski.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/ppc32/src/drivers/cuda.c
/trunk/kernel/arch/ppc32/src/interrupt.c
/trunk/kernel/arch/sparc64/include/cpu_family.h
/trunk/kernel/arch/sparc64/include/cpu_node.h
/trunk/kernel/arch/sparc64/src/drivers/sgcn.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/i8042.c
/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/console/console.c
/trunk/kernel/generic/src/console/kconsole.c
/trunk/kernel/generic/src/ddi/irq.c
3903 5618 d 15 h jermar /trunk/kernel/arch/ia32/include/ Fix ia32 build for Pentium 3 systems.  
/trunk/kernel/arch/ia32/include/barrier.h