Fork and Page Sharing
When a fork
system call is issued, a copy of all the pages corresponding to the parent process is created, loaded into a separate memory location by the OS for the child process. But this is not needed in certain cases. Consider the case when a child executes an "exec
" system call (which is used to execute any executable file from within a C program) or exits very soon after the fork
. When the child is needed just to execute a command for the parent process, there is no need for copying the parent process' pages, since exec replaces the address space of the process which invoked it with the command to be executed.
In such cases, a technique called copy-on-write (COW) is used. With this technique, when a fork occurs, the parent process's pages are not copied for the child process. Instead, the pages are shared between the child and the parent process. Whenever a process (parent or child) modifies a page, a separate copy of that particular page alone is made for that process (parent or child) which performed the modification. This process will then use the newly copied page rather than the shared one in all future references. The other process (the one which did not modify the shared page) continues to use the original copy of the page (which is now no longer shared). This technique is called copy-on-write since the page is copied when some process writes to it.
Read more about this topic: Fork (operating System)
Famous quotes containing the words fork and, fork, page and/or sharing:
“Eye of newt and toe of frog,
Wool of bat and tongue of dog,
Adders fork and blind-worms sting,
Lizards leg and owlets wing,
For a charm of powerful trouble,
Like a hell-broth boil and bubble.”
—William Shakespeare (15641616)
“Wherever a man separates from the multitude, and goes his own way in this mood, there indeed is a fork in the road, though ordinary travelers may see only a gap in the paling. His solitary path across lots will turn out the higher way of the two.”
—Henry David Thoreau (18171862)
“He crafted his writing and loved listening to those tiny explosions when the active brutality of verbs in revolution raced into sweet established nouns to send marching across the page a newly commissioned army of words-on-maneuvers, all decorated in loops, frets, and arrowlike flourishes.”
—Alexander Theroux (b. 1940)
“Eventually we will learn that the loss of indivisible love is another of our necessary losses, that loving extends beyond the mother-child pair, that most of the love we receive in this world is love we will have to shareand that sharing begins at home, with our sibling rivals.”
—Judith Viorst (20th century)