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

TOMOYO Linux Cross Reference
Linux/fs/xfs/xfs_hooks.h

Version: ~ [ linux-6.11.5 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.58 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.114 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.169 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.228 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.284 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.322 ] ~ [ 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-or-later
  2 /*
  3  * Copyright (c) 2022-2024 Oracle.  All Rights Reserved.
  4  * Author: Darrick J. Wong <djwong@kernel.org>
  5  */
  6 #ifndef XFS_HOOKS_H_
  7 #define XFS_HOOKS_H_
  8 
  9 #ifdef CONFIG_XFS_LIVE_HOOKS
 10 struct xfs_hooks {
 11         struct blocking_notifier_head   head;
 12 };
 13 
 14 /*
 15  * If jump labels are enabled in Kconfig, the static key uses nop sleds and
 16  * code patching to eliminate the overhead of taking the rwsem in
 17  * blocking_notifier_call_chain when there are no hooks configured.  If not,
 18  * the static key per-call overhead is an atomic read.  Most arches that can
 19  * handle XFS also support jump labels.
 20  *
 21  * Note: Patching the kernel code requires taking the cpu hotplug lock.  Other
 22  * parts of the kernel allocate memory with that lock held, which means that
 23  * XFS callers cannot hold any locks that might be used by memory reclaim or
 24  * writeback when calling the static_branch_{inc,dec} functions.
 25  */
 26 # define DEFINE_STATIC_XFS_HOOK_SWITCH(name) \
 27         static DEFINE_STATIC_KEY_FALSE(name)
 28 # define xfs_hooks_switch_on(name)      static_branch_inc(name)
 29 # define xfs_hooks_switch_off(name)     static_branch_dec(name)
 30 # define xfs_hooks_switched_on(name)    static_branch_unlikely(name)
 31 
 32 struct xfs_hook {
 33         /* This must come at the start of the structure. */
 34         struct notifier_block           nb;
 35 };
 36 
 37 typedef int (*xfs_hook_fn_t)(struct xfs_hook *hook, unsigned long action,
 38                 void *data);
 39 
 40 void xfs_hooks_init(struct xfs_hooks *chain);
 41 int xfs_hooks_add(struct xfs_hooks *chain, struct xfs_hook *hook);
 42 void xfs_hooks_del(struct xfs_hooks *chain, struct xfs_hook *hook);
 43 int xfs_hooks_call(struct xfs_hooks *chain, unsigned long action,
 44                 void *priv);
 45 
 46 static inline void xfs_hook_setup(struct xfs_hook *hook, notifier_fn_t fn)
 47 {
 48         hook->nb.notifier_call = fn;
 49         hook->nb.priority = 0;
 50 }
 51 
 52 #else
 53 
 54 struct xfs_hooks { /* empty */ };
 55 
 56 # define DEFINE_STATIC_XFS_HOOK_SWITCH(name)
 57 # define xfs_hooks_switch_on(name)              ((void)0)
 58 # define xfs_hooks_switch_off(name)             ((void)0)
 59 # define xfs_hooks_switched_on(name)            (false)
 60 
 61 # define xfs_hooks_init(chain)                  ((void)0)
 62 # define xfs_hooks_call(chain, val, priv)       (NOTIFY_DONE)
 63 #endif
 64 
 65 #endif /* XFS_HOOKS_H_ */
 66 

~ [ 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