Blame view
mm/mmu_context.c
1.36 KB
3d2d827f5 mm: move use_mm/u... |
1 2 3 4 5 6 7 |
/* Copyright (C) 2009 Red Hat, Inc. * * See ../COPYING for licensing terms. */ #include <linux/mm.h> #include <linux/mmu_context.h> |
b95f1b31b mm: Map most file... |
8 |
#include <linux/export.h> |
3d2d827f5 mm: move use_mm/u... |
9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 |
#include <linux/sched.h> #include <asm/mmu_context.h> /* * use_mm * Makes the calling kernel thread take on the specified * mm context. * Called by the retry thread execute retries within the * iocb issuer's mm context, so that copy_from/to_user * operations work seamlessly for aio. * (Note: this routine is intended to be called only * from a kernel thread context) */ void use_mm(struct mm_struct *mm) { struct mm_struct *active_mm; struct task_struct *tsk = current; task_lock(tsk); active_mm = tsk->active_mm; |
f68e14805 mm: reduce atomic... |
30 31 32 33 |
if (active_mm != mm) { atomic_inc(&mm->mm_count); tsk->active_mm = mm; } |
3d2d827f5 mm: move use_mm/u... |
34 |
tsk->mm = mm; |
3d2d827f5 mm: move use_mm/u... |
35 36 |
switch_mm(active_mm, mm, tsk); task_unlock(tsk); |
f68e14805 mm: reduce atomic... |
37 38 |
if (active_mm != mm) mmdrop(active_mm); |
3d2d827f5 mm: move use_mm/u... |
39 |
} |
5da779c34 mm: export use_mm... |
40 |
EXPORT_SYMBOL_GPL(use_mm); |
3d2d827f5 mm: move use_mm/u... |
41 42 43 44 45 46 47 48 49 50 51 52 53 54 |
/* * unuse_mm * Reverses the effect of use_mm, i.e. releases the * specified mm context which was earlier taken on * by the calling kernel thread * (Note: this routine is intended to be called only * from a kernel thread context) */ void unuse_mm(struct mm_struct *mm) { struct task_struct *tsk = current; task_lock(tsk); |
298359c5b exit: fix oops in... |
55 |
sync_mm_rss(tsk, mm); |
3d2d827f5 mm: move use_mm/u... |
56 57 58 59 60 |
tsk->mm = NULL; /* active_mm is still 'mm' */ enter_lazy_tlb(mm, tsk); task_unlock(tsk); } |
5da779c34 mm: export use_mm... |
61 |
EXPORT_SYMBOL_GPL(unuse_mm); |