Blame view
mm/mmu_context.c
1.28 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 |
#include <linux/sched.h> #include <asm/mmu_context.h> /* * use_mm * Makes the calling kernel thread take on the specified * mm context. |
3d2d827f5 mm: move use_mm/u... |
17 18 19 20 21 22 23 24 25 26 |
* (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... |
27 28 29 30 |
if (active_mm != mm) { atomic_inc(&mm->mm_count); tsk->active_mm = mm; } |
3d2d827f5 mm: move use_mm/u... |
31 |
tsk->mm = mm; |
3d2d827f5 mm: move use_mm/u... |
32 33 |
switch_mm(active_mm, mm, tsk); task_unlock(tsk); |
a53efe5ff sched/mm: call fi... |
34 35 36 |
#ifdef finish_arch_post_lock_switch finish_arch_post_lock_switch(); #endif |
3d2d827f5 mm: move use_mm/u... |
37 |
|
f68e14805 mm: reduce atomic... |
38 39 |
if (active_mm != mm) mmdrop(active_mm); |
3d2d827f5 mm: move use_mm/u... |
40 |
} |
5da779c34 mm: export use_mm... |
41 |
EXPORT_SYMBOL_GPL(use_mm); |
3d2d827f5 mm: move use_mm/u... |
42 43 44 45 46 47 48 49 50 51 52 53 54 55 |
/* * 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); |
05af2e104 mm, counters: rem... |
56 |
sync_mm_rss(mm); |
3d2d827f5 mm: move use_mm/u... |
57 58 59 60 61 |
tsk->mm = NULL; /* active_mm is still 'mm' */ enter_lazy_tlb(mm, tsk); task_unlock(tsk); } |
5da779c34 mm: export use_mm... |
62 |
EXPORT_SYMBOL_GPL(unuse_mm); |