Blame view

kernel/user-return-notifier.c 1.35 KB
457c89965   Thomas Gleixner   treewide: Add SPD...
1
  // SPDX-License-Identifier: GPL-2.0-only
7c68af6e3   Avi Kivity   core, x86: Add us...
2
3
4
5
  
  #include <linux/user-return-notifier.h>
  #include <linux/percpu.h>
  #include <linux/sched.h>
9984de1a5   Paul Gortmaker   kernel: Map most ...
6
  #include <linux/export.h>
7c68af6e3   Avi Kivity   core, x86: Add us...
7
8
  
  static DEFINE_PER_CPU(struct hlist_head, return_notifier_list);
7c68af6e3   Avi Kivity   core, x86: Add us...
9
10
11
12
13
14
15
16
  /*
   * Request a notification when the current cpu returns to userspace.  Must be
   * called in atomic context.  The notifier will also be called in atomic
   * context.
   */
  void user_return_notifier_register(struct user_return_notifier *urn)
  {
  	set_tsk_thread_flag(current, TIF_USER_RETURN_NOTIFY);
4a32fea9d   Christoph Lameter   scheduler: Replac...
17
  	hlist_add_head(&urn->link, this_cpu_ptr(&return_notifier_list));
7c68af6e3   Avi Kivity   core, x86: Add us...
18
19
20
21
22
  }
  EXPORT_SYMBOL_GPL(user_return_notifier_register);
  
  /*
   * Removes a registered user return notifier.  Must be called from atomic
25985edce   Lucas De Marchi   Fix common misspe...
23
   * context, and from the same cpu registration occurred in.
7c68af6e3   Avi Kivity   core, x86: Add us...
24
25
26
27
   */
  void user_return_notifier_unregister(struct user_return_notifier *urn)
  {
  	hlist_del(&urn->link);
4a32fea9d   Christoph Lameter   scheduler: Replac...
28
  	if (hlist_empty(this_cpu_ptr(&return_notifier_list)))
7c68af6e3   Avi Kivity   core, x86: Add us...
29
30
31
32
33
34
35
36
  		clear_tsk_thread_flag(current, TIF_USER_RETURN_NOTIFY);
  }
  EXPORT_SYMBOL_GPL(user_return_notifier_unregister);
  
  /* Calls registered user return notifiers */
  void fire_user_return_notifiers(void)
  {
  	struct user_return_notifier *urn;
b67bfe0d4   Sasha Levin   hlist: drop the n...
37
  	struct hlist_node *tmp2;
7c68af6e3   Avi Kivity   core, x86: Add us...
38
39
40
  	struct hlist_head *head;
  
  	head = &get_cpu_var(return_notifier_list);
b67bfe0d4   Sasha Levin   hlist: drop the n...
41
  	hlist_for_each_entry_safe(urn, tmp2, head, link)
7c68af6e3   Avi Kivity   core, x86: Add us...
42
  		urn->on_user_return(urn);
3c912b6ed   Stephen Rothwell   x86: Fix user ret...
43
  	put_cpu_var(return_notifier_list);
7c68af6e3   Avi Kivity   core, x86: Add us...
44
  }