<aname="l3"></a>Paging is practically not used. 64-bit mode requires paging, however, so it is identity-mapped -- virtual identical to
<aname="l4"></a>physical. All tasks on all cores use the same page table map, just as though all addresses are physical addresses. 2Meg or
<aname="l5"></a>1Gig page table entries are used. Nothing swaps to disk.
<aname="l6"></a>
<aname="l7"></a>In ZealOS, the lowest 2Gig of memory is called the </span><spanclass=cF2>code heap</span><spanclass=cF0>. ZealOS's compiler always uses 32-bit signed relative JMP & CALL
<aname="l8"></a>insts because 64-bit CALLs take two insts. With signed +/- 32-bit values, code can only call a function within 2Gig distance.
<aname="l9"></a>Therefore, ZealOS keeps all code in the lowest 2Gig memory addresses including what would normally be called "the kernel". Two
<aname="l10"></a>Gig is plenty for code, don't worry.
<aname="l12"></a>You can create new, independent heaps using </span><ahref="https://www.tomawezome.github.io/ZealOS/Kernel/Memory/HeapCtrl.html#l1"><spanclass=cF4>HeapCtrlInit</span></a><spanclass=cF0>(). Then, use the </span><ahref="https://www.tomawezome.github.io/ZealOS/Kernel/KernelA.html#l3527"><spanclass=cF4>CHeapCtrl</span></a><spanclass=cF0> as the 2nd arg to </span><ahref="https://www.tomawezome.github.io/ZealOS/Kernel/Memory/MAllocFree.html#l391"><spanclass=cF4>MAlloc</span></a><spanclass=cF0>(). See </span><ahref="https://www.tomawezome.github.io/ZealOS/System/Utils/HeapLog.html#l83"><spanclass=cF4>HeapLog</span></a><spanclass=cF0>()
<aname="l15"></a>Memory alloced by a task will be freed when the task is killed. The </span><ahref="https://www.tomawezome.github.io/ZealOS/Doc/Glossary.html#l154"><spanclass=cF4>System Task</span></a><spanclass=cF0> is a task that never dies. His memory is like
<aname="l16"></a>kernel memory in other operating systems. See </span><ahref="https://www.tomawezome.github.io/ZealOS/Kernel/Memory/MAllocFree.html#l408"><spanclass=cF4>ZCAlloc</span></a><spanclass=cF0>(), </span><ahref="https://www.tomawezome.github.io/ZealOS/Kernel/Memory/MAllocFree.html#l394"><spanclass=cF4>ZMAlloc</span></a><spanclass=cF0>(), </span><ahref="https://www.tomawezome.github.io/ZealOS/Kernel/Memory/MAllocFree.html#l427"><spanclass=cF4>ZMAllocIdent</span></a><spanclass=cF0>() and </span><ahref="https://www.tomawezome.github.io/ZealOS/Kernel/Memory/MAllocFree.html#l503"><spanclass=cF4>ZStrNew</span></a><spanclass=cF0>().
<aname="l19"></a>lowest 4Gig addresses have an alias to access hardware located toward the top of mapped space, </span><spanclass=cF2>0x0140000000</span><spanclass=cF0>. See </span><spanclass=cF4>
<aname="l25"></a>See </span><ahref="https://www.tomawezome.github.io/ZealOS/System/Utils/MemRep.html#l219"><spanclass=cF4>MemRep</span></a><spanclass=cF0>() and </span><ahref="https://www.tomawezome.github.io/ZealOS/Demo/MemDemo.html#l1"><spanclass=cF4>::/Demo/MemDemo.CC</span></a><spanclass=cF0>.
<aname="l31"></a> Kernel module, placed here by the boot-loader, </span><ahref="https://www.tomawezome.github.io/ZealOS/Kernel/KernelA.html#l4439"><spanclass=cF4>BOOT_RAM_BASE</span></a><spanclass=cF0>.
<aname="l34"></a> Boot block relocated here before loading the Kernel module, </span><ahref="https://www.tomawezome.github.io/ZealOS/System/Boot/BootDVD.html#l1"><spanclass=cF4>BootDVD</span></a><spanclass=cF0>&</span><ahref="https://www.tomawezome.github.io/ZealOS/System/Boot/BootHD.html#l1"><spanclass=cF4>BootHD</span></a><spanclass=cF0>.
<aname="l38"></a></span><spanclass=cF2> 0x00000A0000- 0x00000BFFFF</span><spanclass=cF0> VGA graphics mem with alias at </span><ahref="https://www.tomawezome.github.io/ZealOS/Kernel/KGlobals.html#l30"><spanclass=cF4>text</span></a><spanclass=cF0>.vga_alias.
<aname="l39"></a></span><spanclass=cF2> 0x0000100000- 0x0000101FFF</span><spanclass=cF0></span><ahref="https://www.tomawezome.github.io/ZealOS/Kernel/KernelA.html#l4082"><spanclass=cF4>CSysFixedArea</span></a><spanclass=cF0> for misc.
<aname="l44"></a> 0xF0000000. PCI devices are supported, so </span><ahref="https://www.tomawezome.github.io/ZealOS/Kernel/Memory/MemPhysical.html#l64"><spanclass=cF4>Mem32DevAlloc</span></a><spanclass=cF0>() flaws could become an issue.
<aname="l54"></a> 64-bit devices are alloced with </span><ahref="https://www.tomawezome.github.io/ZealOS/Kernel/Memory/MemPhysical.html#l122"><spanclass=cF4>Mem64DevAlloc</span></a><spanclass=cF0>() counting backward.
<aname="l59"></a>contiguous requests. You can </span><ahref="https://www.tomawezome.github.io/ZealOS/Kernel/Memory/MAllocFree.html#l391"><spanclass=cF4>MAlloc</span></a><spanclass=cF0>() an 8Gig chunk on a 12Gig machine. You can </span><ahref="https://www.tomawezome.github.io/ZealOS/Kernel/Memory/MAllocFree.html#l391"><spanclass=cF4>MAlloc</span></a><spanclass=cF0>() a 32Gig chunk on a 64Gig machine.
<aname="l62"></a>the code heap is 1/4 of the total. See </span><ahref="https://www.tomawezome.github.io/ZealOS/Kernel/Memory/BlkPool.html#l31"><spanclass=cF4>BlkPoolsInit</span></a><spanclass=cF0>().
<aname="l67"></a>In 2003, Terry Davis wanted to make a no-paging ring-0-only 64-bit operating system for super speed with simplicity and full
<aname="l68"></a>access. With paging, every memory request requires 5 accesses -- it must access the address itself, 4K, 2Meg, 1Gig, and 512Gig
<aname="l69"></a>page tables, but the CPU's translation look-aside buffer mostly removes the penalty for using paging. So, he did not want to
<aname="l70"></a>use paging, but long mode requires it. He did the next best thing -- he identity-mapped everything and achieved the simplicity
<aname="l71"></a>he was after with subtle performance boosts, not wasting time changing address maps. We look forward to the day Intel makes an
<aname="l72"></a>optimized no-paging long mode.
<aname="l73"></a>
<aname="l74"></a>Terry needed VGA A0000-BFFFF memory to be write-through and 0xE0000000-0xFFFFFFFF to be uncached for various devices. All
<aname="l75"></a>64-bit computers allow stopping address translation at 2Meg page size, not using 4K. He wanted to use 2Meg for everything
<aname="l76"></a>because it's faster, with one less level of page tables. He had to make A0000-BFFFF write-through, though, so he could not use
<aname="l77"></a>2Meg size on the lowest page. He did the lowest 2Meg area as 4K pages. He also unmapped the first 4K to cause a fault when
<aname="l78"></a>dereferencing NULL.
<aname="l79"></a>
<aname="l80"></a>In 2016, Terry came-up with an alternate idea. He double mapped the lowest memory with an alias that was uncached. Accessing
<aname="l81"></a>the lowest 2Meg area directly was cached but the alias he created up at the top of address space was uncached. See </span><spanclass=cF4>
<aname="l82"></a></span><ahref="https://www.tomawezome.github.io/ZealOS/Kernel/Memory/MemPhysical.html#l157"><spanclass=cF4>UncachedAliasAlloc</span></a><spanclass=cF0>(). Unfortunately, he could no longer boast of the simplicity of identity mapping everything. Since many of
<aname="l84"></a>numbers of A0000-BFFFF, but must access the relocated alias location. See </span><ahref="https://www.tomawezome.github.io/ZealOS/Kernel/KMain.html#l116"><spanclass=cF4>text.vga_alias</span></a><spanclass=cF0>. We also no longer cause a fault
<aname="l87"></a>Then, Terry switched to 1Gig page sizes. For the lowest 4Gig, he set-up an alias up at the top of address space. See </span><spanclass=cF4>
<aname="l88"></a></span><ahref="https://www.tomawezome.github.io/ZealOS/Kernel/Memory/MemPhysical.html#l157"><spanclass=cF4>UncachedAliasAlloc</span></a><spanclass=cF0>(). Not all computers support 1Gig page tables, however, so he also supported 2Meg.
<aname="l92"></a>all of the first 4Gig can be accessed without caching at the </span><ahref="https://www.tomawezome.github.io/ZealOS/Kernel/MultiProc.html#l147"><spanclass=cF4>dev.uncached_alias</span></a><spanclass=cF0>.