linux-mm.kvack.org archive mirror
 help / color / mirror / Atom feed
From: Seth Jennings <sjenning@linux.vnet.ibm.com>
To: Ben Teissier <ben.teissier@gmail.com>
Cc: linux-mm@kvack.org
Subject: Re: misunderstanding of the virtual memory
Date: Thu, 9 May 2013 11:57:17 -0500	[thread overview]
Message-ID: <20130509165717.GA9548@medulla> (raw)
In-Reply-To: <518BB3B1.8010207@gmail.com>

On Thu, May 09, 2013 at 10:33:21AM -0400, Ben Teissier wrote:
> 
> Hi,
> 
> I'm Benjamin and I'm studying the kernel. I write you this email
> because I've a trouble with the mmu and the virtual memory. I try to
> understand how a program (user land) can write something into the stack
> (push ebp, for example), indeed, the program works with virtual address
> (between 0x00000 and 0x8... if my memory is good) but at the hardware
> side the address is not the same (that's why mmu was created, if I'm right).

Yes, this is the purpose of pages tables; to map virtual addresses to real
memory addresses (more precisely virtual memory _pages_ to real memory pages).

> 
> My problem is the following : how the data is wrote on the physical
> memory. When I try a strace (kernel 2.6.32 on a simple program) I have
> no hint on the transfer of data. Moreover, according to the wikipedia
> web page on syscall (
> https://en.wikipedia.org/wiki/System_call#The_library_as_an_intermediary
> ), a call is not managed by the kernel. So, how the transfer between
> virtual memory and physical memory is possible ?

That is because writing to a memory location in userspace isn't an operation
that requires a syscall or any kind of kernel intervention at all.  It is an
assembly store instruction executed directly on the CPU by the program.  The
only time the kernel is involved in a store operation is if the virtual address
translation doesn't exist in the TLB (or is write-protected, etc..), in which
case the hardware generates a fault so the kernel take the required action to
populate the TLB with the translation.

Hope this answers your question.

Seth

--
To unsubscribe, send a message with 'unsubscribe linux-mm' in
the body to majordomo@kvack.org.  For more info on Linux MM,
see: http://www.linux-mm.org/ .
Don't email: <a href=mailto:"dont@kvack.org"> email@kvack.org </a>

  reply	other threads:[~2013-05-09 16:57 UTC|newest]

Thread overview: 3+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
     [not found] <518BB132.5050802@gmail.com>
2013-05-09 14:33 ` misunderstanding of the virtual memory Ben Teissier
2013-05-09 16:57   ` Seth Jennings [this message]
2013-05-10 15:57     ` Benjamin Teissier

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20130509165717.GA9548@medulla \
    --to=sjenning@linux.vnet.ibm.com \
    --cc=ben.teissier@gmail.com \
    --cc=linux-mm@kvack.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).