Ticket #11 (new enhancement)

Opened 3 years ago

Last modified 2 months ago

Support PAE on ia32

Reported by: jermar Owned by: decky
Priority: minor Milestone: 0.5.1
Component: helenos/kernel/ia32 Version: mainline
Keywords: gsoc12 Cc:
Blocker for: Depends on: #3
See also:

Description (last modified by decky) (diff)

Add support for Physical Address Extension to our ia32 port so that more than 4G of physical memory can be addressed.

Details
On all currently supported 32-bit platforms (arm32, ia32, mips32, ppc32), HelenOS assumes 32-bit physical addresses. This allows the system to make use of 4G of physical memory in total. Some of these architectures, however, provide extensions (e.g. PAE on ia32, LPAE on arm32) that make it possible to address more physical memory by using wider physical addresses (e.g. 36-bit or 40-bit).

There are actually two goals for this project. The first is to modify HelenOS to use a dedicated type for representing physical addresses instead of the current uintptr_t or void *, because the assumption that both virtual and physical addresses have the same amount of bits will no longer hold. The second goal is to implement the actual support for PAE in the form of PAE page table format and PAE feature detection and initialization.

What Gains and Benefits will this bring?
By having the PAE support on ia32, HelenOS will be able to utilize more of the installed memory. HelenOS will also become ready to support similar features on other architectures (think LPAE on arm32).
Difficulty
Difficult
Required skills
Kernel programming skills are needed and the applicant should be strong in C and should have the ability to understand the HelenOS memory management subsystem quickly.
Documentation
Possible mentors
HelenOS Core Team, Jakub Jermar

Change History

comment:1 Changed 3 years ago by decky

  • Milestone set to 0.5.0

comment:2 Changed 3 years ago by svoboda

  • Component set to kernel/ia32

comment:3 Changed 18 months ago by jermar

  • Depends on set to #3

comment:4 Changed 16 months ago by jermar

  • Milestone changed from 0.5.0 to 0.5.1

comment:5 Changed 3 months ago by jermar

  • Keywords gsoc12 added
  • Milestone changed from 0.5.0 to 0.5.1

comment:6 Changed 3 months ago by jermar

  • Keywords gsoc12, needswork added; gsoc12 removed

comment:7 Changed 2 months ago by jermar

  • Keywords gsoc12 added; gsoc12, needswork removed
  • Description modified (diff)

comment:8 Changed 2 months ago by jermar

  • Description modified (diff)

comment:9 Changed 2 months ago by jermar

  • Description modified (diff)

comment:10 Changed 2 months ago by jermar

  • Description modified (diff)

comment:11 Changed 2 months ago by decky

  • Description modified (diff)
Note: See TracTickets for help on using tickets.