diff options
| author | Stefan Monnier | 2017-10-06 09:50:54 -0400 |
|---|---|---|
| committer | Stefan Monnier | 2017-10-06 09:50:54 -0400 |
| commit | 11f9cb522fed9aa6552f6315340ca7352661a1e8 (patch) | |
| tree | 39facc48471c67b321c045e47d70ef030adbea44 /src/thread.c | |
| parent | 92045f4546b9708dc9f69954799d211c1f56ff1e (diff) | |
| parent | 9655937da4a339300c624addd97674c038a01bc9 (diff) | |
| download | emacs-11f9cb522fed9aa6552f6315340ca7352661a1e8.tar.gz emacs-11f9cb522fed9aa6552f6315340ca7352661a1e8.zip | |
Merge emacs-26
Diffstat (limited to 'src/thread.c')
| -rw-r--r-- | src/thread.c | 16 |
1 files changed, 11 insertions, 5 deletions
diff --git a/src/thread.c b/src/thread.c index 42d7791ad0f..d075bdb3a13 100644 --- a/src/thread.c +++ b/src/thread.c | |||
| @@ -101,14 +101,20 @@ acquire_global_lock (struct thread_state *self) | |||
| 101 | post_acquire_global_lock (self); | 101 | post_acquire_global_lock (self); |
| 102 | } | 102 | } |
| 103 | 103 | ||
| 104 | /* This is called from keyboard.c when it detects that SIGINT | 104 | /* This is called from keyboard.c when it detects that SIGINT was |
| 105 | interrupted thread_select before the current thread could acquire | 105 | delivered to the main thread and interrupted thread_select before |
| 106 | the lock. We must acquire the lock to prevent a thread from | 106 | the main thread could acquire the lock. We must acquire the lock |
| 107 | running without holding the global lock, and to avoid repeated | 107 | to prevent a thread from running without holding the global lock, |
| 108 | calls to sys_mutex_unlock, which invokes undefined behavior. */ | 108 | and to avoid repeated calls to sys_mutex_unlock, which invokes |
| 109 | undefined behavior. */ | ||
| 109 | void | 110 | void |
| 110 | maybe_reacquire_global_lock (void) | 111 | maybe_reacquire_global_lock (void) |
| 111 | { | 112 | { |
| 113 | /* SIGINT handler is always run on the main thread, see | ||
| 114 | deliver_process_signal, so reflect that in our thread-tracking | ||
| 115 | variables. */ | ||
| 116 | current_thread = &main_thread; | ||
| 117 | |||
| 112 | if (current_thread->not_holding_lock) | 118 | if (current_thread->not_holding_lock) |
| 113 | { | 119 | { |
| 114 | struct thread_state *self = current_thread; | 120 | struct thread_state *self = current_thread; |