Rev |
Age |
Author |
Path |
Log message |
Diff |
1895 |
6531 d 20 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 |
6532 d 17 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 |
6532 d 21 h |
jermar |
/trunk/boot/ |
Add prototype implementation for creating canonical copy of OpenFirmware device tree. |
|
1892 |
6533 d 6 h |
jermar |
/trunk/kernel/arch/sparc64/src/mm/ |
Small improvement in initialization of sparc64's TBSs. |
|
1891 |
6533 d 18 h |
jermar |
/trunk/kernel/ |
sparc64 work:
- Experimental support for TSB (Translation Storage Buffer). |
|
1890 |
6534 d 4 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 |
6534 d 20 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 |
6537 d 23 h |
jermar |
/trunk/ |
C99 compliant header guards (hopefully) everywhere in the kernel.
Formatting and indentation changes.
Small improvements in sparc64. |
|
1887 |
6538 d 3 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 |
6538 d 3 h |
jermar |
/trunk/uspace/fb/ |
Mapping framebuffer as cacheable was identified to cause the sparc64 port not work on Sun Ultra 5. |
|
1885 |
6538 d 7 h |
jermar |
/trunk/kernel/arch/sparc64/include/ |
On sparc64, get_stack_base() must use the unbiased %sp (i.e. %sp + 2047). |
|
1884 |
6539 d 2 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 |
6539 d 2 h |
jermar |
/trunk/kernel/arch/sparc64/ |
More sparc64 FPU trap handlers. |
|
1882 |
6539 d 3 h |
jermar |
/trunk/kernel/ |
Support for sparc64 FPU context. |
|
1881 |
6540 d 3 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 |
6541 d 19 h |
jermar |
/trunk/ |
Small improvements here and there. |
|
1879 |
6543 d 4 h |
jermar |
/trunk/kernel/arch/sparc64/src/ |
Revert last change.
The register window save area is automatically allocated by the SAVE instruction. |
|
1878 |
6543 d 5 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 |
6543 d 7 h |
jermar |
/trunk/kernel/ |
Coding style fixes.
Remove unneeded sparc64 dummy functions. |
|
1876 |
6543 d 7 h |
jermar |
/trunk/kernel/arch/sparc64/src/trap/ |
Fixes for sparc64's preemptible_handler().
Resynchronize CWP with that of TL=0. |
|
1875 |
6544 d 20 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 |
6544 d 20 h |
jermar |
/trunk/uspace/kbd/ |
Cleanup and reorganize the kbd service a bit. |
|
1873 |
6544 d 20 h |
jermar |
/trunk/uspace/kbd/ |
sparc64 support for the kbd userspace service. |
|
1872 |
6545 d 18 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 |
6546 d 7 h |
jermar |
/trunk/ |
Replace FB_BIG_ENDIAN with FB_INVERT_ENDIAN.
Omit tests for architecture endianness in deciding framebuffer endianness. |
|
1870 |
6546 d 19 h |
jermar |
/trunk/kernel/ |
Handle more sparc64 traps and improve handling of already handled traps. |
|
1869 |
6546 d 23 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 |
6547 d 1 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 |
6547 d 20 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 |
6547 d 20 h |
jermar |
/trunk/uspace/ |
Indentation and formatting facelift for libc.
Libc headers now have C99 compliant guards. |
|
1865 |
6547 d 21 h |
jermar |
/trunk/kernel/ |
sparc64 kernel fixes |
|
1864 |
6548 d 17 h |
jermar |
/trunk/ |
sparc64 update.
- Prototype userspace layer implementation that
at least relates to sparc64 and compiles cleanly.
- Fixes for kernel's preemptible_handler and code
related to running userspace.
- Enable userspace. Several dozen instructions
are now run in userspace! We are pretty near
the userspace milestone for sparc64. |
|
1863 |
6550 d 19 h |
jermar |
/trunk/ |
Allow architectures to decide between inlined and not inlined version of syscall wrapper.
Implement inlined syscall wrapper for sparc64. |
|
1862 |
6550 d 23 h |
jermar |
/trunk/kernel/ |
sparc64 work.
Kernel syscall support.
Modify the preemptive_handler for the use by syscalls. |
|
1861 |
6551 d 3 h |
jermar |
/trunk/kernel/arch/sparc64/ |
Convert sparc64 traps using SIMPLE_HANDLER to using PREEMPTIBLE_HANDLER. |
|
1860 |
6551 d 21 h |
jermar |
/trunk/kernel/ |
A lot of untested sparc64 stuff:
- Write ASID to hardware when a thread is about to run in userspace.
- Add userspace() and switch_to_userspace() functions.
- Handle special cases when the userspace spill/fill handler causes MMU trap.
- Resolve some TODOs in the existing sparc64 code.
- sparc64 has now C99 compliant header guards.
- Formatting and indentation fixes. |
|
1859 |
6552 d 4 h |
jermar |
/trunk/kernel/arch/sparc64/ |
sparc64 work.
- Convert interrupt_vector trap handler and some mm related trap handlers to
use preemptibe_handler(), which is essential for traps coming from userspace.
- Add fast_data_access_protection() handler. |
|
1858 |
6552 d 5 h |
jermar |
/trunk/kernel/arch/sparc64/src/trap/ |
sparc64 work.
Handle situation when there are more valid windows than NWINDOW - 2 during
the return to userspace in preemtpible_handler(). |
|
1857 |
6553 d 0 h |
jermar |
/trunk/kernel/arch/sparc64/ |
sparc64 work.
More bits needed to reach the userspace milestone were added.
The preemptible_handler(), still a prototype, now contains all functionality it needs.
Some sanitation was added to functions expecting page-aligned pointers to
userspace window buffer. |
|
1856 |
6553 d 5 h |
jermar |
/trunk/kernel/ |
sparc64 work.
- Modify before_thread_runs_arch() to store addresses of the kernel stack and
userspace window buffer, resp., to registers %g6 and %g7, resp, in the
alternate and interrupt global sets.
- Modify after_thread_ran_arch() to sample %g7 from the alternate globals.
- Implement trap handler for spilling register windows into userspace window buffer.
- Implement assembly language functions to access %g6 and %g7 registers in the alternate sets.
- Initialize the trap table so that there are now also spill_1_normal, spill_2_normal,
spill_0_other and fill_1_normal handlers. These handlers are used in different situations
and for different purposes. |
|