How a 64-bit process virtual address space is divided in Linux? The Next CEO of Stack OverflowLinux Kernel logical address space organisationhow is page size determined in virtual address space?Physical Address Extension - how do virtual addresses work?How can two identical virtual addresses point to different physical addresses?How does the CPU knows which physical address is mapped to which virtual address?how to get virtual address generated by a processHow can the Linux kernel address from 8 MB to 1 GB of virtual memory in x86 systemsDoes the isolation between virtual memory address spaces of different processes not apply to privileged process and to swap?Do the virtual address spaces of all the processes have the same content in their “Kernel” parts?Disabling virtual address space randomization for a linux kernel module

Create custom note boxes

Mathematica command that allows it to read my intentions

Calculate the Mean mean of two numbers

Calculating discount not working

What difference does it make matching a word with/without a trailing whitespace?

A hang glider, sudden unexpected lift to 25,000 feet altitude, what could do this?

What did the word "leisure" mean in late 18th Century usage?

Which acid/base does a strong base/acid react when added to a buffer solution?

Why do we say “un seul M” and not “une seule M” even though M is a “consonne”?

Early programmable calculators with RS-232

How should I connect my cat5 cable to connectors having an orange-green line?

Car headlights in a world without electricity

What day is it again?

How badly should I try to prevent a user from XSSing themselves?

Can Sri Krishna be called 'a person'?

Why does freezing point matter when picking cooler ice packs?

Is it OK to decorate a log book cover?

Can you teleport closer to a creature you are Frightened of?

Compensation for working overtime on Saturdays

Is it possible to create a QR code using text?

Gauss' Posthumous Publications?

How to compactly explain secondary and tertiary characters without resorting to stereotypes?

How to implement Comparable so it is consistent with identity-equality

Would a grinding machine be a simple and workable propulsion system for an interplanetary spacecraft?



How a 64-bit process virtual address space is divided in Linux?



The Next CEO of Stack OverflowLinux Kernel logical address space organisationhow is page size determined in virtual address space?Physical Address Extension - how do virtual addresses work?How can two identical virtual addresses point to different physical addresses?How does the CPU knows which physical address is mapped to which virtual address?how to get virtual address generated by a processHow can the Linux kernel address from 8 MB to 1 GB of virtual memory in x86 systemsDoes the isolation between virtual memory address spaces of different processes not apply to privileged process and to swap?Do the virtual address spaces of all the processes have the same content in their “Kernel” parts?Disabling virtual address space randomization for a linux kernel module










6















The following image shows how a 32-bit process virtual address space is divided:



enter image description here



But how a 64-bit process virtual address space is divided?










share|improve this question


























    6















    The following image shows how a 32-bit process virtual address space is divided:



    enter image description here



    But how a 64-bit process virtual address space is divided?










    share|improve this question
























      6












      6








      6


      1






      The following image shows how a 32-bit process virtual address space is divided:



      enter image description here



      But how a 64-bit process virtual address space is divided?










      share|improve this question














      The following image shows how a 32-bit process virtual address space is divided:



      enter image description here



      But how a 64-bit process virtual address space is divided?







      linux






      share|improve this question













      share|improve this question











      share|improve this question




      share|improve this question










      asked 2 days ago









      ChristopherChristopher

      1512




      1512




















          1 Answer
          1






          active

          oldest

          votes


















          5














          The 64-bit x86 virtual memory map splits the address space into two: the lower section (with the top bit set to 0) is user-space, the upper section (with the top bit set to 1) is kernel-space. (Note that x86-64 defines “canonical” “lower half” and “higher half” addresses, with a number of bits effectively limited to 48 or 56; see Wikipedia for details.)



          The complete map is documented in detail in the kernel; currently it looks like



          ===========================================================================================
          Start addr | Offset | End addr | Size | VM area description
          ===========================================================================================
          | | | |
          0000000000000000 | 0 | 00007fffffffffff | 128 TB | user-space virtual memory
          __________________|____________|__________________|_________|______________________________
          | | | |
          0000800000000000 | +128 TB | ffff7fffffffffff | ~16M TB | non-canonical
          __________________|____________|__________________|_________|______________________________
          | | | |
          ffff800000000000 | -128 TB | ffffffffffffffff | 128 TB | kernel-space virtual memory
          __________________|____________|__________________|_________|______________________________


          with 48-bit virtual addresses.



          Unlike the 32-bit case, the “64-bit” memory map is a direct reflection of hardware constraints.






          share|improve this answer

























          • To clarify: this limitation is imposed by the hardware. There is currently no 64-bit processor implementation that doesn't leave a huge hole of unusable addresses in the middle of the virtual address space. The amount of physical memory the CPUs are able to address is also way below 2 to the power of 64.

            – Johan Myréen
            2 days ago











          • Thanks @Johan, I’ve tried to highlight this.

            – Stephen Kitt
            2 days ago











          Your Answer








          StackExchange.ready(function()
          var channelOptions =
          tags: "".split(" "),
          id: "106"
          ;
          initTagRenderer("".split(" "), "".split(" "), channelOptions);

          StackExchange.using("externalEditor", function()
          // Have to fire editor after snippets, if snippets enabled
          if (StackExchange.settings.snippets.snippetsEnabled)
          StackExchange.using("snippets", function()
          createEditor();
          );

          else
          createEditor();

          );

          function createEditor()
          StackExchange.prepareEditor(
          heartbeatType: 'answer',
          autoActivateHeartbeat: false,
          convertImagesToLinks: false,
          noModals: true,
          showLowRepImageUploadWarning: true,
          reputationToPostImages: null,
          bindNavPrevention: true,
          postfix: "",
          imageUploader:
          brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
          contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
          allowUrls: true
          ,
          onDemand: true,
          discardSelector: ".discard-answer"
          ,immediatelyShowMarkdownHelp:true
          );



          );













          draft saved

          draft discarded


















          StackExchange.ready(
          function ()
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f509607%2fhow-a-64-bit-process-virtual-address-space-is-divided-in-linux%23new-answer', 'question_page');

          );

          Post as a guest















          Required, but never shown

























          1 Answer
          1






          active

          oldest

          votes








          1 Answer
          1






          active

          oldest

          votes









          active

          oldest

          votes






          active

          oldest

          votes









          5














          The 64-bit x86 virtual memory map splits the address space into two: the lower section (with the top bit set to 0) is user-space, the upper section (with the top bit set to 1) is kernel-space. (Note that x86-64 defines “canonical” “lower half” and “higher half” addresses, with a number of bits effectively limited to 48 or 56; see Wikipedia for details.)



          The complete map is documented in detail in the kernel; currently it looks like



          ===========================================================================================
          Start addr | Offset | End addr | Size | VM area description
          ===========================================================================================
          | | | |
          0000000000000000 | 0 | 00007fffffffffff | 128 TB | user-space virtual memory
          __________________|____________|__________________|_________|______________________________
          | | | |
          0000800000000000 | +128 TB | ffff7fffffffffff | ~16M TB | non-canonical
          __________________|____________|__________________|_________|______________________________
          | | | |
          ffff800000000000 | -128 TB | ffffffffffffffff | 128 TB | kernel-space virtual memory
          __________________|____________|__________________|_________|______________________________


          with 48-bit virtual addresses.



          Unlike the 32-bit case, the “64-bit” memory map is a direct reflection of hardware constraints.






          share|improve this answer

























          • To clarify: this limitation is imposed by the hardware. There is currently no 64-bit processor implementation that doesn't leave a huge hole of unusable addresses in the middle of the virtual address space. The amount of physical memory the CPUs are able to address is also way below 2 to the power of 64.

            – Johan Myréen
            2 days ago











          • Thanks @Johan, I’ve tried to highlight this.

            – Stephen Kitt
            2 days ago















          5














          The 64-bit x86 virtual memory map splits the address space into two: the lower section (with the top bit set to 0) is user-space, the upper section (with the top bit set to 1) is kernel-space. (Note that x86-64 defines “canonical” “lower half” and “higher half” addresses, with a number of bits effectively limited to 48 or 56; see Wikipedia for details.)



          The complete map is documented in detail in the kernel; currently it looks like



          ===========================================================================================
          Start addr | Offset | End addr | Size | VM area description
          ===========================================================================================
          | | | |
          0000000000000000 | 0 | 00007fffffffffff | 128 TB | user-space virtual memory
          __________________|____________|__________________|_________|______________________________
          | | | |
          0000800000000000 | +128 TB | ffff7fffffffffff | ~16M TB | non-canonical
          __________________|____________|__________________|_________|______________________________
          | | | |
          ffff800000000000 | -128 TB | ffffffffffffffff | 128 TB | kernel-space virtual memory
          __________________|____________|__________________|_________|______________________________


          with 48-bit virtual addresses.



          Unlike the 32-bit case, the “64-bit” memory map is a direct reflection of hardware constraints.






          share|improve this answer

























          • To clarify: this limitation is imposed by the hardware. There is currently no 64-bit processor implementation that doesn't leave a huge hole of unusable addresses in the middle of the virtual address space. The amount of physical memory the CPUs are able to address is also way below 2 to the power of 64.

            – Johan Myréen
            2 days ago











          • Thanks @Johan, I’ve tried to highlight this.

            – Stephen Kitt
            2 days ago













          5












          5








          5







          The 64-bit x86 virtual memory map splits the address space into two: the lower section (with the top bit set to 0) is user-space, the upper section (with the top bit set to 1) is kernel-space. (Note that x86-64 defines “canonical” “lower half” and “higher half” addresses, with a number of bits effectively limited to 48 or 56; see Wikipedia for details.)



          The complete map is documented in detail in the kernel; currently it looks like



          ===========================================================================================
          Start addr | Offset | End addr | Size | VM area description
          ===========================================================================================
          | | | |
          0000000000000000 | 0 | 00007fffffffffff | 128 TB | user-space virtual memory
          __________________|____________|__________________|_________|______________________________
          | | | |
          0000800000000000 | +128 TB | ffff7fffffffffff | ~16M TB | non-canonical
          __________________|____________|__________________|_________|______________________________
          | | | |
          ffff800000000000 | -128 TB | ffffffffffffffff | 128 TB | kernel-space virtual memory
          __________________|____________|__________________|_________|______________________________


          with 48-bit virtual addresses.



          Unlike the 32-bit case, the “64-bit” memory map is a direct reflection of hardware constraints.






          share|improve this answer















          The 64-bit x86 virtual memory map splits the address space into two: the lower section (with the top bit set to 0) is user-space, the upper section (with the top bit set to 1) is kernel-space. (Note that x86-64 defines “canonical” “lower half” and “higher half” addresses, with a number of bits effectively limited to 48 or 56; see Wikipedia for details.)



          The complete map is documented in detail in the kernel; currently it looks like



          ===========================================================================================
          Start addr | Offset | End addr | Size | VM area description
          ===========================================================================================
          | | | |
          0000000000000000 | 0 | 00007fffffffffff | 128 TB | user-space virtual memory
          __________________|____________|__________________|_________|______________________________
          | | | |
          0000800000000000 | +128 TB | ffff7fffffffffff | ~16M TB | non-canonical
          __________________|____________|__________________|_________|______________________________
          | | | |
          ffff800000000000 | -128 TB | ffffffffffffffff | 128 TB | kernel-space virtual memory
          __________________|____________|__________________|_________|______________________________


          with 48-bit virtual addresses.



          Unlike the 32-bit case, the “64-bit” memory map is a direct reflection of hardware constraints.







          share|improve this answer














          share|improve this answer



          share|improve this answer








          edited 2 days ago

























          answered 2 days ago









          Stephen KittStephen Kitt

          179k24407485




          179k24407485












          • To clarify: this limitation is imposed by the hardware. There is currently no 64-bit processor implementation that doesn't leave a huge hole of unusable addresses in the middle of the virtual address space. The amount of physical memory the CPUs are able to address is also way below 2 to the power of 64.

            – Johan Myréen
            2 days ago











          • Thanks @Johan, I’ve tried to highlight this.

            – Stephen Kitt
            2 days ago

















          • To clarify: this limitation is imposed by the hardware. There is currently no 64-bit processor implementation that doesn't leave a huge hole of unusable addresses in the middle of the virtual address space. The amount of physical memory the CPUs are able to address is also way below 2 to the power of 64.

            – Johan Myréen
            2 days ago











          • Thanks @Johan, I’ve tried to highlight this.

            – Stephen Kitt
            2 days ago
















          To clarify: this limitation is imposed by the hardware. There is currently no 64-bit processor implementation that doesn't leave a huge hole of unusable addresses in the middle of the virtual address space. The amount of physical memory the CPUs are able to address is also way below 2 to the power of 64.

          – Johan Myréen
          2 days ago





          To clarify: this limitation is imposed by the hardware. There is currently no 64-bit processor implementation that doesn't leave a huge hole of unusable addresses in the middle of the virtual address space. The amount of physical memory the CPUs are able to address is also way below 2 to the power of 64.

          – Johan Myréen
          2 days ago













          Thanks @Johan, I’ve tried to highlight this.

          – Stephen Kitt
          2 days ago





          Thanks @Johan, I’ve tried to highlight this.

          – Stephen Kitt
          2 days ago

















          draft saved

          draft discarded
















































          Thanks for contributing an answer to Unix & Linux Stack Exchange!


          • Please be sure to answer the question. Provide details and share your research!

          But avoid


          • Asking for help, clarification, or responding to other answers.

          • Making statements based on opinion; back them up with references or personal experience.

          To learn more, see our tips on writing great answers.




          draft saved


          draft discarded














          StackExchange.ready(
          function ()
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f509607%2fhow-a-64-bit-process-virtual-address-space-is-divided-in-linux%23new-answer', 'question_page');

          );

          Post as a guest















          Required, but never shown





















































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown

































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown







          Popular posts from this blog

          getting Checkpoint VPN SSL Network Extender working in the command lineHow to connect to CheckPoint VPN on Ubuntu 18.04LTS?Will the Linux ( red-hat ) Open VPNC Client connect to checkpoint or nortel VPN gateways?VPN client for linux machine + support checkpoint gatewayVPN SSL Network Extender in FirefoxLinux Checkpoint SNX tool configuration issuesCheck Point - Connect under Linux - snx + OTPSNX VPN Ububuntu 18.XXUsing Checkpoint VPN SSL Network Extender CLI with certificateVPN with network manager (nm-applet) is not workingWill the Linux ( red-hat ) Open VPNC Client connect to checkpoint or nortel VPN gateways?VPN client for linux machine + support checkpoint gatewayImport VPN config files to NetworkManager from command lineTrouble connecting to VPN using network-manager, while command line worksStart a VPN connection with PPTP protocol on command linestarting a docker service daemon breaks the vpn networkCan't connect to vpn with Network-managerVPN SSL Network Extender in FirefoxUsing Checkpoint VPN SSL Network Extender CLI with certificate

          Cannot Extend partition with GParted The 2019 Stack Overflow Developer Survey Results Are In Announcing the arrival of Valued Associate #679: Cesar Manara Planned maintenance scheduled April 17/18, 2019 at 00:00UTC (8:00pm US/Eastern) 2019 Community Moderator Election ResultsCan't increase partition size with GParted?GParted doesn't recognize the unallocated space after my current partitionWhat is the best way to add unallocated space located before to Ubuntu 12.04 partition with GParted live?I can't figure out how to extend my Arch home partition into free spaceGparted Linux Mint 18.1 issueTrying to extend but swap partition is showing as Unknown in Gparted, shows proper from fdiskRearrange partitions in gparted to extend a partitionUnable to extend partition even though unallocated space is next to it using GPartedAllocate free space to root partitiongparted: how to merge unallocated space with a partition

          Marilyn Monroe Ny fiainany manokana | Jereo koa | Meny fitetezanafanitarana azy.