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 5616 d 3 h rimsky /branches/sparc/ The sparc branch synchronized with trunk at revision 3722 (trunk@3722).  
3665 5639 d 16 h rimsky /branches/sparc/ Merged latest trunk changes into the sparc brach.  
3664 5639 d 16 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 5649 d 16 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 5654 d 16 h rimsky /branches/sparc/ Merged latest trunk changes into sparc branch.  
3582 5660 d 5 h rimsky /branches/sparc/ Made changes making HelenOS run on US-IV CPUs. Minor refactoring of the SGCN driver.  
3343 5744 d 22 h decky /branches/sparc/ add sparc branch  
3240 5764 d 5 h decky / move unfinished ObjC support to a separate branch  
3071 5822 d 0 h decky /trunk/kernel/ reflect changes in generic code
proper formatting directives
coding style
 
2510 6093 d 19 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 6177 d 21 h jermar /trunk/ Improve comments for arch-specific implementations of hierarchical
4-level page tables. Improve formatting.
 
2465 6183 d 0 h jermar /trunk/ Merge arm32 into trunk.  
2125 6299 d 19 h decky /trunk/ experimental support for Objective C
(disabled by default)
 
2106 6308 d 2 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 6312 d 22 h decky /trunk/kernel/ spinlock extern declaration macro  
2089 6314 d 2 h decky /trunk/ huge type system cleanup
remove cyclical type dependencies across multiple header files
many minor coding style fixes
 
2085 6320 d 0 h decky /trunk/kernel/ typedef elimination  
2071 6324 d 19 h jermar /trunk/ (c) versus (C)  
1994 6381 d 1 h decky /trunk/ Add BGR 0888 visual for Ultra 60  
1993 6381 d 3 h decky /trunk/ make framebuffer code more generic  
1957 6407 d 3 h decky /trunk/kernel/ ia32: mouse support, mouse regrab is still broken  
1956 6407 d 4 h decky /trunk/kernel/ ia32: adopt new IRQ interface, mouse not tested yet  
1921 6419 d 20 h jermar /trunk/kernel/ Changes in ns16550 and z8530 drivers.
Add some stuff for IRQ notifications to irq_t.
 
1920 6420 d 4 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 6420 d 18 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 6427 d 4 h jermar /trunk/kernel/ Separate mapping of EBUS interrupts into two parts: EBUS and PCI.  
1910 6430 d 16 h jermar /trunk/kernel/ Rename INO to INR, for the sake of consistency with manuals.  
1909 6431 d 18 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 6434 d 4 h jermar /trunk/kernel/genarch/ Add function to find OFW tree node by handle.  
1907 6434 d 5 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 6438 d 2 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 6438 d 18 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 6441 d 2 h jermar /trunk/ Convert sparc64 framebuffer code to configure from the OpenFirmware device tree memory representation.  
1896 6441 d 17 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 6443 d 19 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 6444 d 16 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 6449 d 22 h jermar /trunk/ C99 compliant header guards (hopefully) everywhere in the kernel.
Formatting and indentation changes.
Small improvements in sparc64.
 
1875 6456 d 19 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 6474 d 2 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 6478 d 4 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.