~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/include/asm-generic/mmu_context.h

Version: ~ [ linux-6.11-rc3 ] ~ [ linux-6.10.4 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.45 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.104 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.164 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.223 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.281 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.319 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.9 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

  1 /* SPDX-License-Identifier: GPL-2.0 */
  2 #ifndef __ASM_GENERIC_MMU_CONTEXT_H
  3 #define __ASM_GENERIC_MMU_CONTEXT_H
  4 
  5 /*
  6  * Generic hooks to implement no-op functionality.
  7  */
  8 
  9 struct task_struct;
 10 struct mm_struct;
 11 
 12 /*
 13  * enter_lazy_tlb - Called when "tsk" is about to enter lazy TLB mode.
 14  *
 15  * @mm:  the currently active mm context which is becoming lazy
 16  * @tsk: task which is entering lazy tlb
 17  *
 18  * tsk->mm will be NULL
 19  */
 20 #ifndef enter_lazy_tlb
 21 static inline void enter_lazy_tlb(struct mm_struct *mm,
 22                         struct task_struct *tsk)
 23 {
 24 }
 25 #endif
 26 
 27 /**
 28  * init_new_context - Initialize context of a new mm_struct.
 29  * @tsk: task struct for the mm
 30  * @mm:  the new mm struct
 31  * @return: 0 on success, -errno on failure
 32  */
 33 #ifndef init_new_context
 34 static inline int init_new_context(struct task_struct *tsk,
 35                         struct mm_struct *mm)
 36 {
 37         return 0;
 38 }
 39 #endif
 40 
 41 /**
 42  * destroy_context - Undo init_new_context when the mm is going away
 43  * @mm: old mm struct
 44  */
 45 #ifndef destroy_context
 46 static inline void destroy_context(struct mm_struct *mm)
 47 {
 48 }
 49 #endif
 50 
 51 /**
 52  * activate_mm - called after exec switches the current task to a new mm, to switch to it
 53  * @prev_mm: previous mm of this task
 54  * @next_mm: new mm
 55  */
 56 #ifndef activate_mm
 57 static inline void activate_mm(struct mm_struct *prev_mm,
 58                                struct mm_struct *next_mm)
 59 {
 60         switch_mm(prev_mm, next_mm, current);
 61 }
 62 #endif
 63 
 64 /**
 65  * dectivate_mm - called when an mm is released after exit or exec switches away from it
 66  * @tsk: the task
 67  * @mm:  the old mm
 68  */
 69 #ifndef deactivate_mm
 70 static inline void deactivate_mm(struct task_struct *tsk,
 71                         struct mm_struct *mm)
 72 {
 73 }
 74 #endif
 75 
 76 #endif /* __ASM_GENERIC_MMU_CONTEXT_H */
 77 

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php