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 6197 d 5 h jermar /trunk/ Merge arm32 into trunk.  
2441 6204 d 22 h decky /trunk/kernel/ fix ICC compilation  
2321 6226 d 5 h decky /trunk/ keep mouse state in i8042_grab, unify keyboard and mouse IRQ handler
(this fixes ticket #12)
 
2222 6257 d 23 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 6265 d 22 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 6269 d 20 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 6314 d 0 h decky /trunk/ experimental support for Objective C
(disabled by default)
 
2106 6322 d 7 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 6327 d 0 h decky /trunk/kernel/genarch/src/fb/ signed/unsigned comparison, explicit typecast  
2101 6327 d 1 h decky /trunk/kernel/ fix signed/unsigned comparison and integer overflow  
2100 6327 d 1 h decky /trunk/kernel/ signed/unsigned comparison, explicit typecast  
2093 6327 d 3 h decky /trunk/kernel/ spinlock extern declaration macro  
2089 6328 d 7 h decky /trunk/ huge type system cleanup
remove cyclical type dependencies across multiple header files
many minor coding style fixes
 
2086 6330 d 3 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.
 
2085 6334 d 5 h decky /trunk/kernel/ typedef elimination  
2071 6338 d 23 h jermar /trunk/ (c) versus (C)  
2054 6366 d 22 h jermar /trunk/kernel/ Fix important comment in kernel/arch/sparc64/src/proc/scheduler.c.

Improve framebuffer code.

Formatting and indentation fixes.
 
2015 6378 d 0 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 6385 d 22 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 6395 d 6 h decky /trunk/ Add BGR 0888 visual for Ultra 60  
1993 6395 d 7 h decky /trunk/ make framebuffer code more generic  
1991 6396 d 1 h jermar /trunk/kernel/genarch/src/fb/ The prefered switch statement indentation is the one replaced by the previous commit :-)  
1990 6396 d 4 h decky /trunk/kernel/genarch/src/fb/ framebuffer cleanup  
1981 6399 d 7 h jermar /trunk/kernel/ Indentation, formatting and minor changes.  
1974 6410 d 1 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 6412 d 6 h jermar /trunk/ Modify selected function to consume less stack space.

Avoid flushw instruction in the sparc64 loader.
 
1957 6421 d 8 h decky /trunk/kernel/ ia32: mouse support, mouse regrab is still broken  
1956 6421 d 9 h decky /trunk/kernel/ ia32: adopt new IRQ interface, mouse not tested yet  
1944 6429 d 2 h jermar /trunk/kernel/ Add mutual exclusion to keyboard grab and release
functions on sparc64, ppc32, mips32 and ia64.
 
1932 6430 d 23 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 6431 d 1 h jermar /trunk/ Add support for IPC notifications even for polled ns16550 based keyboard.  
1925 6431 d 22 h jermar /trunk/kernel/genarch/src/kbd/ Support for grabbing and releasing z8530 keyboard for sparc64.
We might later add some locking.
 
1923 6431 d 23 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 6434 d 0 h jermar /trunk/kernel/ Changes in ns16550 and z8530 drivers.
Add some stuff for IRQ notifications to irq_t.
 
1920 6434 d 8 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 6434 d 23 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 6441 d 9 h jermar /trunk/kernel/ Separate mapping of EBUS interrupts into two parts: EBUS and PCI.  
1911 6441 d 21 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 6444 d 21 h jermar /trunk/kernel/ Rename INO to INR, for the sake of consistency with manuals.  
1909 6445 d 23 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.