Rev |
Age |
Author |
Path |
Log message |
Diff |
Changes |
3955 |
5650 d 21 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 |
5650 d 22 h |
jermar |
/trunk/kernel/arch/mips32/include/ |
Add missing PIO functions for mips32. |
|
/trunk/kernel/arch/mips32/include/asm.h
|
3952 |
5650 d 22 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 |
5650 d 23 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 |
5650 d 23 h |
jermar |
/trunk/kernel/generic/src/ddi/ |
Fix UP builds. |
|
/trunk/kernel/generic/src/ddi/irq.c
|
3949 |
5650 d 23 h |
jermar |
/trunk/kernel/arch/arm32/include/ |
PIO functions for arm32. |
|
/trunk/kernel/arch/arm32/include/asm.h
|
3948 |
5651 d 0 h |
jermar |
/trunk/kernel/arch/amd64/ |
Unbreak amd64. |
|
/trunk/kernel/arch/amd64/include/asm.h /trunk/kernel/arch/amd64/src/amd64.c
|
3947 |
5651 d 1 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 |
5651 d 1 h |
jermar |
/trunk/kernel/arch/ia32/include/ |
Fix ia32's pio_{read,write}_32(). |
|
/trunk/kernel/arch/ia32/include/asm.h
|
3941 |
5651 d 21 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 |
5652 d 1 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 |
5652 d 2 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 |
5652 d 2 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 |
5652 d 18 h |
jermar |
/trunk/kernel/arch/sparc64/src/drivers/ |
Fix sparc64 build. |
|
/trunk/kernel/arch/sparc64/src/drivers/kbd.c
|
3934 |
5652 d 18 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 |
5652 d 20 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 |
5652 d 20 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 |
5652 d 20 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 |
5652 d 20 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 |
5652 d 22 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 |
5652 d 23 h |
jermar |
/trunk/kernel/genarch/ |
Nuke i8042_poll(). |
|
/trunk/kernel/genarch/include/kbd/i8042.h /trunk/kernel/genarch/src/kbd/i8042.c
|
3922 |
5654 d 19 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 |
5654 d 20 h |
decky |
/trunk/kernel/generic/include/ |
add min3 and max3 macros |
|
/trunk/kernel/generic/include/macros.h
|
3919 |
5654 d 20 h |
decky |
/trunk/kernel/generic/include/ |
cstyle |
|
/trunk/kernel/generic/include/config.h
|
3918 |
5654 d 20 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 |
5654 d 20 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 |
5655 d 4 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 |
5655 d 17 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 |
5655 d 23 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 |
5656 d 8 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 |
5656 d 19 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 |
5657 d 3 h |
jermar |
/trunk/kernel/arch/ia32/include/ |
Fix ia32 build for Pentium 3 systems. |
|
/trunk/kernel/arch/ia32/include/barrier.h
|
3902 |
5657 d 3 h |
jermar |
/trunk/kernel/ |
Introduce a more platform-neutral name for programmed I/O.
The new API looks like pio_read_n() or pio_write_n(), where n is 8, 16 or 32.
The old API (i.e. inb(), inw(), inl(), outb() outw(), outl()) may have made
some people think that the interface is only to be used with the separate I/O
space. That's not the case. This API is to be implemented on all platforms
so that we can finally have really generic kernel device drivers. |
|
/trunk/kernel/arch/amd64/include/asm.h /trunk/kernel/arch/arm32/include/asm.h /trunk/kernel/arch/ia32/include/asm.h /trunk/kernel/arch/ia32/include/drivers/i8042.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/asm.h /trunk/kernel/arch/ia64/include/drivers/i8042.h /trunk/kernel/arch/ia64/src/ia64.c /trunk/kernel/arch/mips32/include/asm.h /trunk/kernel/arch/ppc32/include/asm.h /trunk/kernel/arch/sparc64/include/asm.h /trunk/kernel/genarch/include/kbd/ns16550.h /trunk/kernel/genarch/src/drivers/ega/ega.c /trunk/kernel/generic/src/ipc/irq.c
|
3900 |
5657 d 4 h |
jermar |
/trunk/ |
Get rid of CONFIG_NS16550_INTERRUPT_DRIVEN and CONFIG_I8042_INTERRUPT_DRIVEN. |
|
/trunk/HelenOS.config /trunk/kernel/arch/ia64/src/ia64.c /trunk/kernel/arch/sparc64/src/console.c /trunk/kernel/arch/sparc64/src/sparc64.c /trunk/kernel/genarch/src/kbd/ns16550.c
|
3896 |
5657 d 18 h |
svoboda |
/trunk/ |
More elegant way of invoking the loader - as a 'cloneable' service. Task names functionality lost for the time being. |
|
/trunk/kernel/generic/include/proc/program.h /trunk/kernel/generic/src/proc/program.c /trunk/uspace/lib/libc/generic/loader.c /trunk/uspace/lib/libc/generic/task.c /trunk/uspace/lib/libc/include/ipc/services.h /trunk/uspace/lib/libc/include/loader/loader.h /trunk/uspace/srv/loader/main.c /trunk/uspace/srv/ns/ns.c
|
3892 |
5657 d 21 h |
jermar |
/trunk/ |
Get rid of CONFIG_DEBUG_AS_WATCHPOINT. |
|
/trunk/HelenOS.config /trunk/kernel/arch/amd64/src/debugger.c /trunk/kernel/arch/amd64/src/proc/scheduler.c /trunk/kernel/arch/ia32/src/proc/scheduler.c
|
3891 |
5657 d 22 h |
jermar |
/trunk/ |
Get rid of CONFIG_SIMICS_FIX. |
|
/trunk/HelenOS.config /trunk/kernel/arch/ia32/src/mm/frame.c
|
3890 |
5657 d 22 h |
jermar |
/trunk/ |
Get rid of CONFIG_DEBUG_ALLREGS. |
|
/trunk/HelenOS.config /trunk/kernel/arch/amd64/include/interrupt.h /trunk/kernel/arch/amd64/src/asm_utils.S /trunk/kernel/arch/amd64/src/interrupt.c /trunk/kernel/arch/ia32/include/interrupt.h /trunk/kernel/arch/ia32/src/asm.S /trunk/kernel/arch/ia32/src/interrupt.c /trunk/kernel/arch/mips32/include/context_offset.h /trunk/kernel/arch/mips32/include/exception.h /trunk/kernel/arch/mips32/src/start.S
|
3889 |
5658 d 3 h |
svoboda |
/trunk/kernel/arch/ia32/include/drivers/ |
Make ia32/amd64 compile again. This is mostly a hack, but a more drastic cleanup is needed to do it the right way. |
|
/trunk/kernel/arch/ia32/include/drivers/kbd.h
|
3884 |
5659 d 22 h |
decky |
/trunk/ |
centralize configuration data
use a header file for passing most of the configuration directives |
|
/trunk/HelenOS.config /trunk/Makefile /trunk/kernel/Makefile /trunk/version
|