nushell/crates/nu-plugin/src/plugin
Devyn Cairns e1cfc96ee8
Fix locking soundness in PersistentPlugin (#12182)
# Description

There were two problems in `PersistentPlugin` which could cause a
deadlock:

1. There were two mutexes being used, and `get()` could potentially hold
both simultaneously if it had to spawn. This won't necessarily cause a
deadlock on its own, but it does mean that lock order is sensitive

2. `set_gc_config()` called `flush()` while still holding the lock,
meaning that the GC thread had to proceed before the lock was released.
However, waiting for the GC thread to proceed could mean waiting for the
GC thread to call `stop()`, which itself would try to lock the mutex.
So, it's not safe to wait for the GC thread while the lock is held. This
is fixed now.

I've also reverted #12177, as @IanManske reported that this was also
happening for him on Linux, and it seems to be this problem which should
not be platform-specific at all. I believe this solves it.

# User-Facing Changes
None

# Tests + Formatting
- 🟢 `toolkit fmt`
- 🟢 `toolkit clippy`
- 🟢 `toolkit test`
- 🟢 `toolkit test stdlib`

# After Submitting
2024-03-12 18:22:29 -05:00
..
interface Add environment engine calls for plugins (#12166) 2024-03-12 06:34:32 -05:00
context.rs Add environment engine calls for plugins (#12166) 2024-03-12 06:34:32 -05:00
declaration.rs Keep plugins persistently running in the background (#12064) 2024-03-09 17:10:22 -06:00
gc.rs Sync with the plugin garbage collector when setting config (#12152) 2024-03-12 10:50:13 +01:00
interface.rs Add support for engine calls from plugins (#12029) 2024-03-09 11:26:30 -06:00
mod.rs Add environment engine calls for plugins (#12166) 2024-03-12 06:34:32 -05:00
persistent.rs Fix locking soundness in PersistentPlugin (#12182) 2024-03-12 18:22:29 -05:00
source.rs Keep plugins persistently running in the background (#12064) 2024-03-09 17:10:22 -06:00