Lines Matching +full:real +full:- +full:time

6 (running tasks with ->active_mm == mm && ->mm == NULL) on kernels
13 List: linux-kernel
16 Date: 1999-07-30 21:36:24
18 Cc'd to linux-kernel, because I don't write explanations all that often,
25 > discussed on the mailing lists---I just returned from vacation and
26 > wasn't able to follow linux-kernel for a while).
30 - we have "real address spaces" and "anonymous address spaces". The
32 user-level page tables at all, so when we do a context switch into an
37 doesn't need any user mappings - all kernel threads basically fall into
38 this category, but even "real" threads can temporarily say that for
39 some amount of time they are not going to be interested in user space,
40 and that the scheduler might as well try to avoid wasting time on
41 switching the VM state around. Currently only the old-style bdflush
44 - "tsk->mm" points to the "real address space". For an anonymous process,
45 tsk->mm will be NULL, for the logical reason that an anonymous process
46 really doesn't _have_ a real address space at all.
48 - however, we obviously need to keep track of which address space we
49 "stole" for such an anonymous user. For that, we have "tsk->active_mm",
52 The rule is that for a process with a real address space (ie tsk->mm is
53 non-NULL) the active_mm obviously always has to be the same as the real
56 For a anonymous process, tsk->mm == NULL, and tsk->active_mm is the
62 "mm_users" counter that is how many "real address space users" there are,
64 users) plus one if there are any real users.
66 Usually there is at least one real user, but it could be that the real
69 lazy users. That is often a short-lived state, because once that thread
70 gets scheduled away in favour of a real thread, the "zombie" mm gets
73 Also, a new rule is that _nobody_ ever has "init_mm" as a real MM any
76 no real VM has yet been created. So code that used to check
78 if (current->mm == &init_mm)
82 if (!current->mm)
84 instead (which makes more sense anyway - the test is basically one of "do
88 Anyway, I put a pre-patch-2.3.13-1 on ftp.kernel.org just a moment ago,
91 ugliest context switch codes - unlike the other architectures where the MM
95 (From http://marc.info/?l=linux-kernel&m=93337278602211&w=2)