Subversion Repositories HelenOS

Rev

Go to most recent revision | Show changed files | Directory listing | RSS feed

Filtering Options

Rev Age Author Path Log message Diff
2465 6185 d 13 h jermar /trunk/ Merge arm32 into trunk.  
2441 6193 d 7 h decky /trunk/kernel/ fix ICC compilation  
2321 6214 d 13 h decky /trunk/ keep mouse state in i8042_grab, unify keyboard and mouse IRQ handler
(this fixes ticket #12)
 
2222 6246 d 7 h decky /trunk/kernel/ map kernel pages explicitly as writable (this solves compatibility issues with Intel Core 2)
make VESA framebuffer initialization more robust
 
2170 6254 d 6 h jermar /trunk/kernel/ Simplify synchronization in as_switch().
The function was oversynchronized, which
was causing deadlocks on the address
space mutex.

Now, address spaces can only be switched
when the asidlock is held. This also protects
stealing of ASIDs. No other synchronization
is necessary.
 
2141 6258 d 5 h jermar /trunk/ The Ultimate Solution To Illegal Virtual Aliases.
It is better to avoid them completely than to fight them.
Switch the sparc64 port to 16K pages. The TLBs and TSBs
continue to operate with 8K pages only. Page tables and
other generic parts operate with 16K pages.

Because the MMU doesn't support 16K directly, each 16K
page is emulated by a pair of 8K pages. With 16K pages,
illegal aliases cannot be created in 16K D-cache.
 
2125 6302 d 8 h decky /trunk/ experimental support for Objective C
(disabled by default)
 
2106 6310 d 15 h jermar /trunk/kernel/ Merge as_t structure into one and leave the differring parts in as_genarch_t.

Indentation and formatting changes in header files.
 
2102 6315 d 9 h decky /trunk/kernel/genarch/src/fb/ signed/unsigned comparison, explicit typecast  
2101 6315 d 9 h decky /trunk/kernel/ fix signed/unsigned comparison and integer overflow  
2100 6315 d 10 h decky /trunk/kernel/ signed/unsigned comparison, explicit typecast  
2089 6316 d 15 h decky /trunk/ huge type system cleanup
remove cyclical type dependencies across multiple header files
many minor coding style fixes
 
2086 6318 d 11 h jermar /trunk/kernel/genarch/src/fb/ Don't write to frame buffer memory, which is past the resolution.
This fixes Ticket #17

Coding style a formatting changes in the frame buffer code.
 
2071 6327 d 8 h jermar /trunk/ (c) versus (C)  
2054 6355 d 6 h jermar /trunk/kernel/ Fix important comment in kernel/arch/sparc64/src/proc/scheduler.c.

Improve framebuffer code.

Formatting and indentation fixes.
 
2015 6366 d 8 h jermar /trunk/ Rework support for virtually indexed cache.
Instead of repeatedly flushing the data cache, which was a huge overkill, refuse to create an illegal address alias
in the kernel (again) and allocate appropriate page color in userspace instead. Extend the detection also to
SYS_PHYSMEM_MAP syscall.

Add support for tracking physical memory areas mappable by SYS_PHYSMEM_MAP.

Lots of coding style changes.
 
2007 6374 d 6 h jermar /trunk/kernel/ Introduce page colors. So far, only sparc64 uses correct page color bits. Other architectures have a dummy define
specifying zero bits for a page color.

There is a new check of page color in as_area_share(). Because of lack of support for this in the userspace, the
check has been #ifef'ed out.
 
1994 6383 d 14 h decky /trunk/ Add BGR 0888 visual for Ultra 60  
1993 6383 d 16 h decky /trunk/ make framebuffer code more generic  
1991 6384 d 9 h jermar /trunk/kernel/genarch/src/fb/ The prefered switch statement indentation is the one replaced by the previous commit :-)  
1990 6384 d 12 h decky /trunk/kernel/genarch/src/fb/ framebuffer cleanup  
1981 6387 d 16 h jermar /trunk/kernel/ Indentation, formatting and minor changes.  
1974 6398 d 9 h jermar /trunk/kernel/genarch/src/ofw/ Rewrite OFW device tree traversal algorithms to iterate over the list of peers rather than recurse on each
peer node. This saves us from big troubles with stack overflows.
 
1972 6400 d 14 h jermar /trunk/ Modify selected function to consume less stack space.

Avoid flushw instruction in the sparc64 loader.
 
1957 6409 d 16 h decky /trunk/kernel/ ia32: mouse support, mouse regrab is still broken  
1956 6409 d 17 h decky /trunk/kernel/ ia32: adopt new IRQ interface, mouse not tested yet  
1944 6417 d 11 h jermar /trunk/kernel/ Add mutual exclusion to keyboard grab and release
functions on sparc64, ppc32, mips32 and ia64.
 
1932 6419 d 8 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.
 
1931 6419 d 9 h jermar /trunk/ Add support for IPC notifications even for polled ns16550 based keyboard.  
1925 6420 d 7 h jermar /trunk/kernel/genarch/src/kbd/ Support for grabbing and releasing z8530 keyboard for sparc64.
We might later add some locking.
 
1923 6420 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.
 
1921 6422 d 9 h jermar /trunk/kernel/ Changes in ns16550 and z8530 drivers.
Add some stuff for IRQ notifications to irq_t.
 
1920 6422 d 17 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.
 
1919 6423 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.
 
1912 6429 d 17 h jermar /trunk/kernel/ Separate mapping of EBUS interrupts into two parts: EBUS and PCI.  
1911 6430 d 6 h jermar /trunk/kernel/ Add support for interrupt mapping in the Sabre PCI controller.
Add support for PCI and EBUS interrupt mapping via the OpenFirmware device tree.
Unfortunatelly, the code is not capable enough to earn single ns16550 interrupt.
I suspect something needs to be enabled in the EBUS registers.
 
1910 6433 d 5 h jermar /trunk/kernel/ Rename INO to INR, for the sake of consistency with manuals.  
1909 6434 d 7 h jermar /trunk/ Extend the OFW device tree node with a void pointer. The boot loader is
supposed to reset all pointers in all nodes. The kernel uses the pointer
to recognize that a particular device has already been visited and initialized.

Read interrupt mapping from the OFW device tree for FHC devices (z8530) and
EBUS devices (ns16550). In case of FHC devices, remove hardwired values from
the code and use only values read from the tree. FHC initialization is started
when a FHC device wants to map its interrupt. In case of EBUS devices, map
the interrupt to INO. Interrupt enabling in the interrupt controller for that
specific interrupt is not implemented yet.
 
1908 6436 d 17 h jermar /trunk/kernel/genarch/ Add function to find OFW tree node by handle.  
1899 6440 d 15 h jermar /trunk/ sparc64 work:
- Loader now starts all processors.
- Kernel halts all but the bootstrup processor for now.
- Read clock-frequency from the respective processor node in the device tree