Blame view

kernel/user-return-notifier.c 1.32 KB
7c68af6e3   Avi Kivity   core, x86: Add us...
1
2
3
4
  
  #include <linux/user-return-notifier.h>
  #include <linux/percpu.h>
  #include <linux/sched.h>
9984de1a5   Paul Gortmaker   kernel: Map most ...
5
  #include <linux/export.h>
7c68af6e3   Avi Kivity   core, x86: Add us...
6
7
  
  static DEFINE_PER_CPU(struct hlist_head, return_notifier_list);
7c68af6e3   Avi Kivity   core, x86: Add us...
8
9
10
11
12
13
14
15
  /*
   * 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);
1786bf009   Avi Kivity   core: Clean up us...
16
  	hlist_add_head(&urn->link, &__get_cpu_var(return_notifier_list));
7c68af6e3   Avi Kivity   core, x86: Add us...
17
18
19
20
21
  }
  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...
22
   * context, and from the same cpu registration occurred in.
7c68af6e3   Avi Kivity   core, x86: Add us...
23
24
25
26
   */
  void user_return_notifier_unregister(struct user_return_notifier *urn)
  {
  	hlist_del(&urn->link);
1786bf009   Avi Kivity   core: Clean up us...
27
  	if (hlist_empty(&__get_cpu_var(return_notifier_list)))
7c68af6e3   Avi Kivity   core, x86: Add us...
28
29
30
31
32
33
34
35
36
37
38
39
40
41
  		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;
  	struct hlist_node *tmp1, *tmp2;
  	struct hlist_head *head;
  
  	head = &get_cpu_var(return_notifier_list);
  	hlist_for_each_entry_safe(urn, tmp1, tmp2, head, link)
  		urn->on_user_return(urn);
3c912b6ed   Stephen Rothwell   x86: Fix user ret...
42
  	put_cpu_var(return_notifier_list);
7c68af6e3   Avi Kivity   core, x86: Add us...
43
  }