HelenOS-historic
HelenOS
HelenOS-doc
Català-Valencià – Catalan
中文 – Chinese (Simplified)
中文 – Chinese (Traditional)
Česky – Czech
Dansk – Danish
Nederlands – Dutch
English – English
Suomi – Finnish
Français – French
Deutsch – German
עברית – Hebrew
हिंदी – Hindi
Magyar – Hungarian
Bahasa Indonesia – Indonesian
Italiano – Italian
日本語 – Japanese
한국어 – Korean
Македонски – Macedonian
मराठी – Marathi
Norsk – Norwegian
Polski – Polish
Português – Portuguese
Português – Portuguese (Brazil)
Русский – Russian
Slovenčina – Slovak
Slovenščina – Slovenian
Español – Spanish
Svenska – Swedish
Türkçe – Turkish
Українська – Ukrainian
Oëzbekcha – Uzbek
Subversion Repositories
HelenOS-historic
(root)
/
SPARTAN
/
trunk
/
arch
/
ia32
/
src
@ 185
– Rev 0
Rev
Show changed files
|
Details
|
Compare with Previous
|
Blame
|
RSS feed
Filtering Options
From rev
To rev
Max revs
Search history for
Show All
Clear current filter
Rev
Age
Author
Path
Log message
Diff
185
6897 d 22 h
decky
/SPARTAN/trunk/arch/
OpenFirmware support
184
6898 d 0 h
jermar
/SPARTAN/trunk/
Add lib/the.c.
Add and deploy the_initialize() and the_copy().
Make IA-32's before_thread_runs() use SP_DELTA macro.
182
6898 d 1 h
cejka
/SPARTAN/trunk/
Test for printf added.
177
6898 d 22 h
jermar
/SPARTAN/trunk/
Add some comments to IA-32 src/boot/boot.S and src/smp.S.
Make the boot stack start on page boundary.
This is required by get_stack_base().
Define 'THE' macro.
Implement preemption_disable() and preemption_enable().
Add memory barrier macros.
IA-32 macros need support for older processors.
Non IA-32 macros are dummy.
Reduction of many #include paths.
176
6899 d 13 h
jermar
/SPARTAN/trunk/arch/ia32/src/boot/
Initialize the stack prior to using it.
174
6902 d 13 h
jermar
/SPARTAN/trunk/
Small changes.
Coding style fix in main.c.
Make 'cli' be the first instruction in boot.S again.
170
6906 d 11 h
jermar
/SPARTAN/trunk/
Add comment to scheduler.c explaining the reason behind saving CPU priority of preempted thread.
Remove two unnecessary cpu_priority_high() calls.
168
6907 d 12 h
jermar
/SPARTAN/trunk/
Add type cast to __address in vm_create().
This seems to fix the problem with userspace.
Looks like KA2PA() returned wrong address when applied on pte_t *.
Uncomment panic() in gp_fault().
Get rid of cli and sti in userspace code.
167
6908 d 21 h
jermar
/SPARTAN/trunk/
Switch over to per vm_t page tables. (breaks ia32 userspace)
Define dummy memcopy() for amd64 and ppc to satisfy compiler.
Get rid of problematic #include <arch/mm/page.h> in mm/page.h.
Indentation fixes and small changes here and there.
149
6932 d 14 h
jermar
/SPARTAN/trunk/
Fix IA-32's get_memory_size() to return size of memory in bytes instead of in kilobytes.
Some cosmetics in memory map detection.
The IA-32 kernel is functional again.
146
6937 d 19 h
cejka
/SPARTAN/trunk/
Memory size detection for ia32 completed.
144
6937 d 20 h
vana
/SPARTAN/trunk/
Coding style fix
143
6937 d 20 h
vana
/SPARTAN/trunk/
Disable alignment check
142
6937 d 21 h
vana
/SPARTAN/trunk/arch/ia32/src/
Typing error fixed
141
6937 d 21 h
vana
/SPARTAN/trunk/
Clear IOPL on start of system on all CPUs and clear NT before all irets.
139
6938 d 17 h
cejka
/SPARTAN/trunk/arch/ia32/
Added e801 method for obtaining memory size, improved e820 method for memory map.
137
6938 d 19 h
vana
/SPARTAN/trunk/arch/ia32/src/
Comments
136
6938 d 19 h
vana
/SPARTAN/trunk/
Error word support debuging and testing passed with #NM & #GP exceptions.
132
6938 d 22 h
vana
/SPARTAN/trunk/arch/ia32/
Added support for error-word generating exceptions in return routine.
131
6938 d 22 h
jermar
/SPARTAN/trunk/arch/ia32/src/
Initialize kmp_completion_wq during configuration via ACPI MADT.
Move some generic SMP configuration code from mps.c to smp.c.
129
6939 d 19 h
jermar
/SPARTAN/trunk/arch/ia32/
Implement ACPI MADT operations for interface used by kmp.
128
6940 d 21 h
jermar
/SPARTAN/trunk/arch/ia32/
Create IA-32 interface for bringing SMP up.
This interface hides differences between ACPI MADT and MPS configuration tables.
Provide MPS implementation thereof.
127
6940 d 22 h
jermar
/SPARTAN/trunk/arch/
Copyright owner of arch/mips/src/mm/asid.c is Martin Decky.
ACPI code now understands L_APIC and IO_APIC entries in MADT.
125
6943 d 12 h
jermar
/SPARTAN/trunk/
Huge indentation fix.
120
6958 d 10 h
jermar
/SPARTAN/trunk/
Generic 4-level page tables interface & implementation (review & test).
Implement more architecture dependant macros on IA-32.
Provide fake implementation on IA-64 and MIPS.
Convert map_page_to_frame() to use the new interface.
Move adjusted map_page_to_frame() from IA-32's arch/mm/page.c to the generic mm/page.c.
117
6974 d 18 h
jermar
/SPARTAN/trunk/
Do panic() on page_fault().
Good for long testing in SMP mode as silent "extinctions" of a CPU are no longer supported.
Tiny changes here and there.
116
6978 d 18 h
jermar
/SPARTAN/trunk/
Add map_structure() to automate mapping of memory structures that can span multiple pages and/or cross page boundaries.
Change ACPI map_sdt() to use map_structure().
Small changes in MPS code.
The extra frame allocation for accessing frame 0 is unnecessary as it is possible to access frame 0 from kernel address space.
Zero TSS descriptor in the newly prepared GDT.
115
6979 d 10 h
jermar
/SPARTAN/trunk/
Implement several assembler functions in gcc's __asm__ notation instead of in .s or .S file.
Gain both better speed and size.
113
6982 d 9 h
jermar
/SPARTAN/trunk/
SMP recovery patch #2 (SMP is no longer broken !!!).
Fix missing KA2PA() operation in ap.S which was causing page faults during AP early initialization.
Fix bug in map_page_to_frame(): 'root' was interpretted as kernel address while read_dba() returns physical address.
Make references to page directory and page tables use kernel addresses instead of physical addresses.
Massive frame allocation code cleanup.
Basically revert to what we had had before implementation of userspace.
Usual cosmetics.
112
6982 d 13 h
jermar
/SPARTAN/trunk/
Define two placeholder functions for atomic_inc and atomic_dec on IA-64.
Add Ondrej Palkovsky to doc/AUTHORS.
Tweaks in IA-32 low level code to bring SMP back to life. (SMP still broken)
111
6982 d 14 h
palkovsky
/SPARTAN/trunk/
Code cleanup in scheduler.c thread.c - removed unnecessary spinlock.
atomic_inc, atomic_dec moved to arch/atomic.h instead of arch/smp/atomic.h,
advisable to use even in non-smp mode.
Fixed atomic_inc, atomic_dec in mips architecture.
110
6983 d 19 h
jermar
/SPARTAN/trunk/
SMP recovery patch #1. (SMP still broken)
Move ap_boot() to K_TEXT_START_2 section.
Change ap_boot() to cope with mapping of kernel address space.
Change some addresses in mps.c from kernel to physical.
MIPS.
Move msim dprinter device to 0xB0000000.
This address is from kseg1 (unmapped, uncached) segment.
109
6985 d 14 h
jermar
/SPARTAN/trunk/
Discard 'copy' parameter of map_page_to_frame().
Introduce 'root' parameter of map_page_to_frame().
If 'root' is zero, page directory address is read from CPU.
Otherwise 'root' is used as page directory address.
Add missing word to new doxygen-style comments in scheduler.c.
106
6985 d 21 h
jermar
/SPARTAN/trunk/
IA-32 fixes.
Use kernel addresses instead of physical addresses in map_page_to_frame().
Physical addresses are supposed to only be exported to mm hardware.
Because of this fix, userspace is functional again.
Remap EGA videoram to (0x80000000 + videoram) and change the ega driver to work with the new address.
Minor cosmetics through out the code.
Changes in linker scripts.
105
6986 d 10 h
jermar
/SPARTAN/trunk/
Big changes in IA-32 address space map.
Now the kernel is mapped above 0x80000000. Finally!
Userspace address space starts at 0x00000000.
Changes in many places.
This improvement temporarily breaks SMP and most likely also other stuff.
Supported size of memory is now only 4M as it is the biggest size that can be mapped at once on IA-32.
Changes in linker script.
Changes required because of the above.
Do not patch hardcoded_* variables but assign to them instead.
Cosmetic changes here and there.
103
6988 d 15 h
jermar
/SPARTAN/trunk/
Just cleanup.
101
6992 d 17 h
cejka
/SPARTAN/trunk/arch/ia32/src/boot/
Small bug in e820 memmap function repaired.
99
6994 d 1 h
jermar
/SPARTAN/trunk/
Replace "THREAD->cpu" with "CPU" in scheduler().
Add trailing '\n' to memmap.h
Fix some translations.
Relpace one Czech sentence with its English translation.
98
6994 d 18 h
cejka
/SPARTAN/trunk/arch/ia32/
first version of e820 memmap
95
6996 d 0 h
cejka
/SPARTAN/trunk/arch/ia32/
Started memory map support.