Rev |
Age |
Author |
Path |
Log message |
Diff |
1904 |
6578 d 19 h |
jermar |
/trunk/kernel/ |
IPI/cross-call support for sparc64.
SMP on sparc64 is now fully supported. |
|
1903 |
6579 d 14 h |
jermar |
/trunk/ |
SMP stuff for sparc64.
Almost complete except for IPIs.
The absence of IPI support deadlocks
the kernel when more CPUs are configured. |
|
1902 |
6580 d 18 h |
jermar |
/trunk/kernel/arch/sparc64/include/ |
Implement spinlock and test_and_set for sparc64. |
|
1901 |
6580 d 19 h |
jermar |
/trunk/kernel/ |
Make SMP related parts of main.c more generic.
Move initialization of local APIC to architecture specific code.
Add arch_post_cpu_init() to support the above. |
|
1900 |
6580 d 21 h |
jermar |
/trunk/kernel/arch/sparc64/src/ |
Block the secondary processors after they setup kernel mapping in ITLB and DTLB and
switch to kernel trap table. |
|
1899 |
6580 d 21 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 |
6581 d 14 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 |
6583 d 21 h |
jermar |
/trunk/ |
Convert sparc64 framebuffer code to configure from the OpenFirmware device tree memory representation. |
|
1896 |
6584 d 13 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 |
6586 d 14 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 |
6587 d 12 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 |
|
1893 |
6587 d 15 h |
jermar |
/trunk/boot/ |
Add prototype implementation for creating canonical copy of OpenFirmware device tree. |
|
1892 |
6588 d 0 h |
jermar |
/trunk/kernel/arch/sparc64/src/mm/ |
Small improvement in initialization of sparc64's TBSs. |
|
1891 |
6588 d 12 h |
jermar |
/trunk/kernel/ |
sparc64 work:
- Experimental support for TSB (Translation Storage Buffer). |
|
1890 |
6588 d 23 h |
jermar |
/trunk/ |
- Create a dedicated slab cache for as_t objects and switch from malloc/free to slab_alloc/slab_free for
them.
- Slightly fix and improve both the kernel and userspace atomic_add() on sparc64.
- More TSB work on the sparc64 front. |
|
1889 |
6589 d 14 h |
jermar |
/trunk/kernel/ |
Fix bug in mm/as.c:
- as_area_destroy() should not work with AS but as
sparc64 work:
- start implementing TSB support |
|
1888 |
6592 d 17 h |
jermar |
/trunk/ |
C99 compliant header guards (hopefully) everywhere in the kernel.
Formatting and indentation changes.
Small improvements in sparc64. |
|
1887 |
6592 d 21 h |
jermar |
/trunk/kernel/arch/sparc64/ |
When creating TLB mapping for the sparc64 kernel, enable CV (cacheable virtually) bit.
Also install locked mappings only in context 0. |
|
1886 |
6592 d 21 h |
jermar |
/trunk/uspace/fb/ |
Mapping framebuffer as cacheable was identified to cause the sparc64 port not work on Sun Ultra 5. |
|
1885 |
6593 d 2 h |
jermar |
/trunk/kernel/arch/sparc64/include/ |
On sparc64, get_stack_base() must use the unbiased %sp (i.e. %sp + 2047). |
|
1884 |
6593 d 20 h |
jermar |
/trunk/kernel/arch/sparc64/src/ |
Unfortunatelly, the sparc64's FPRS register is writable by non-privileged software
so we cannot save only half of the FPU context depending on FPRS dirty bits.
Instead, we must save the entire FPU register file. |
|
1883 |
6593 d 20 h |
jermar |
/trunk/kernel/arch/sparc64/ |
More sparc64 FPU trap handlers. |
|
1882 |
6593 d 21 h |
jermar |
/trunk/kernel/ |
Support for sparc64 FPU context. |
|
1881 |
6594 d 21 h |
jermar |
/trunk/ |
sparc64 work:
- find a CPU node and read its clock_frequency attribute
- implement asm_delay_loop()
- set TICK_COMPARE register according to processor frequency
- small improvements at random places
OpenFirmware work:
- two new functions for walking the device tree
Generic boot loader work:
- added basic string functions
Usual pile of indentation and formatting fixes. |
|
1880 |
6596 d 13 h |
jermar |
/trunk/ |
Small improvements here and there. |
|
1879 |
6597 d 22 h |
jermar |
/trunk/kernel/arch/sparc64/src/ |
Revert last change.
The register window save area is automatically allocated by the SAVE instruction. |
|
1878 |
6598 d 0 h |
jermar |
/trunk/kernel/arch/sparc64/src/ |
Even the first kernel register window after the switch from userspace stack needs
proper register window save area [sparc64]. |
|
1877 |
6598 d 1 h |
jermar |
/trunk/kernel/ |
Coding style fixes.
Remove unneeded sparc64 dummy functions. |
|
1876 |
6598 d 1 h |
jermar |
/trunk/kernel/arch/sparc64/src/trap/ |
Fixes for sparc64's preemptible_handler().
Resynchronize CWP with that of TL=0. |
|
1875 |
6599 d 14 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. |
|
1874 |
6599 d 15 h |
jermar |
/trunk/uspace/kbd/ |
Cleanup and reorganize the kbd service a bit. |
|
1873 |
6599 d 15 h |
jermar |
/trunk/uspace/kbd/ |
sparc64 support for the kbd userspace service. |
|
1872 |
6600 d 13 h |
jermar |
/trunk/uspace/libc/generic/io/ |
read() and write() now check if the virtual function they want to
call exists. Thus, these calls will not kill the whole task
if called for instance from a driver task but gracefully fail. |
|
1871 |
6601 d 1 h |
jermar |
/trunk/ |
Replace FB_BIG_ENDIAN with FB_INVERT_ENDIAN.
Omit tests for architecture endianness in deciding framebuffer endianness. |
|
1870 |
6601 d 13 h |
jermar |
/trunk/kernel/ |
Handle more sparc64 traps and improve handling of already handled traps. |
|
1869 |
6601 d 18 h |
jermar |
/trunk/ |
Pass "fb.bpp-align" property to userspace so that our fb task works properly even on
framebuffers used in some Sun hardware. |
|
1868 |
6601 d 20 h |
jermar |
/trunk/ |
sparc64 work.
- the syscall wrapper needs to use the "memory"
clobber specifier to prevent over-optimization.
- on sparc64, the user address space spans the whole
64-bit space and therefore the macro
USER_ADDRESS_SPACE_SIZE_ARCH, as it was defined,
overflows to 0
- stop using USER_ADDRESS_SPACE_SIZE_ARCH and define
MAX_HEAP_SIZE instead
- in our situation when kernel and user address spaces
are separate, the G (global) bit cannot be used
(there is no point in it anymore)
- add the DEBUG() macro to stdio.h; DEBUG() uses
SYS_IO and is a good debugging tool for getting
early userspace to work |
|
1867 |
6602 d 14 h |
jermar |
/trunk/uspace/ |
Prototype for mmap() should be in mman.h.
Anyway, is there any common sense behind naming of mman.h and mman.c? |
|
1866 |
6602 d 14 h |
jermar |
/trunk/uspace/ |
Indentation and formatting facelift for libc.
Libc headers now have C99 compliant guards. |
|
1865 |
6602 d 15 h |
jermar |
/trunk/kernel/ |
sparc64 kernel fixes |
|