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
3742 5627 d 6 h rimsky /branches/sparc/ The sparc branch synchronized with trunk at revision 3722 (trunk@3722).  
3665 5650 d 19 h rimsky /branches/sparc/ Merged latest trunk changes into the sparc brach.  
3664 5650 d 20 h rimsky /branches/sparc/ Added some SunBlade 1500 stuff (part of it is just temporary - e.g. the new visual). Some small fixes and enhancements.  
3618 5660 d 20 h rimsky /branches/sparc/ Support for framebuffers, where the first pixel is mapped to a different address than the OBP 'reg' property claims. Cleanup, comments, C-style.  
3593 5665 d 20 h rimsky /branches/sparc/ Merged latest trunk changes into sparc branch.  
3582 5671 d 9 h rimsky /branches/sparc/ Made changes making HelenOS run on US-IV CPUs. Minor refactoring of the SGCN driver.  
3343 5756 d 2 h decky /branches/sparc/ add sparc branch  
3240 5775 d 8 h decky / move unfinished ObjC support to a separate branch  
3071 5833 d 4 h decky /trunk/kernel/ reflect changes in generic code
proper formatting directives
coding style
 
2510 6104 d 22 h jermar /trunk/kernel/ Experimental support for the cgsix framebuffer, which is found on old Ultra 1
worksations, and the SBUS bus and devices. Not tested.
 
2467 6189 d 1 h jermar /trunk/ Improve comments for arch-specific implementations of hierarchical
4-level page tables. Improve formatting.
 
2465 6194 d 3 h jermar /trunk/ Merge arm32 into trunk.  
2125 6310 d 22 h decky /trunk/ experimental support for Objective C
(disabled by default)
 
2106 6319 d 5 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.
 
2093 6324 d 1 h decky /trunk/kernel/ spinlock extern declaration macro  
2089 6325 d 5 h decky /trunk/ huge type system cleanup
remove cyclical type dependencies across multiple header files
many minor coding style fixes
 
2085 6331 d 4 h decky /trunk/kernel/ typedef elimination  
2071 6335 d 22 h jermar /trunk/ (c) versus (C)  
1994 6392 d 5 h decky /trunk/ Add BGR 0888 visual for Ultra 60  
1993 6392 d 6 h decky /trunk/ make framebuffer code more generic  
1957 6418 d 6 h decky /trunk/kernel/ ia32: mouse support, mouse regrab is still broken  
1956 6418 d 7 h decky /trunk/kernel/ ia32: adopt new IRQ interface, mouse not tested yet  
1921 6430 d 23 h jermar /trunk/kernel/ Changes in ns16550 and z8530 drivers.
Add some stuff for IRQ notifications to irq_t.
 
1920 6431 d 7 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 6431 d 22 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 6438 d 7 h jermar /trunk/kernel/ Separate mapping of EBUS interrupts into two parts: EBUS and PCI.  
1910 6441 d 20 h jermar /trunk/kernel/ Rename INO to INR, for the sake of consistency with manuals.  
1909 6442 d 21 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 6445 d 8 h jermar /trunk/kernel/genarch/ Add function to find OFW tree node by handle.  
1907 6445 d 8 h jermar /trunk/ Add node handle to in-memory ofw tree node.
This is essential for interrupt mapping on sparc64
and perhaps on other platforms that have OpenFirmware.
 
1899 6449 d 6 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
 
1898 6449 d 22 h jermar /trunk/kernel/ Support for FFB (Creator 3D) framebuffer detection on sparc64.
(Not tested as the Ultra 60, which I have for testing, and which
only has this type of framebuffer doesn't boot for some unknown reason.)
 
1897 6452 d 5 h jermar /trunk/ Convert sparc64 framebuffer code to configure from the OpenFirmware device tree memory representation.  
1896 6452 d 21 h jermar /trunk/ Convert sparc64 to detect keyboard and determine
its physical address by walking the memory representation
of the OpenFirmware device tree.

Add bus-specific functions that know how to apply the
"ranges" property to one component of the "reg" property.
Buses supported so far include FHC, EBUS and PCI.
 
1895 6454 d 22 h jermar /trunk/ More ofw_tree work and fixes.
Add ofw_tree_lookup().
Every ofw_tree_node now also contains a disambigued name which is essential for tree lookups.
 
1894 6455 d 20 h jermar /trunk/ Add balloc() (a.k.a boot allocator):
- balloc() only needs to know how to allocate memory.
- Memory allocated via balloc() is supposed to be passed to kernel and never freed by boot itself.
- make kernel aware of boot allocations

More work on OFW device tree:
- use balloc() to efficiently and safely allocate memory for the canonical copy of the device tree

sparc64 boot:
- pass OFW device tree root node pointer to kernel
 
1888 6461 d 1 h jermar /trunk/ C99 compliant header guards (hopefully) everywhere in the kernel.
Formatting and indentation changes.
Small improvements in sparc64.
 
1875 6467 d 23 h jermar /trunk/ sparc64 work.
- Changes to enable userspace keyboard drivers.
- Fix z8530 initialization (i.e. clear any pending Tx interrupts).
- Experimental support for framebuffers with inverted colors.
 
1851 6485 d 5 h jermar /trunk/kernel/ sparc64 work.
Define the istate structure.
Move the identity-mapping handler to assembly.
Make the preemptible handler more general so that TL=1 MMU exceptions can make use of it.

Little bit of formatting and indentation.
 
1849 6489 d 7 h jermar /trunk/kernel/ sparc64 work.
interrupt_vector trap experimental handling.
Minimal reverse-engineered FireHose Controller driver (documentation needed!).
Keyboard on Sun Enterprise is now interrupt driven. Keyboard on Sun Ultra
is still polled.