|
@@ -58,29 +58,48 @@ IOThread *mon_iothread;
|
|
|
/* Bottom half to dispatch the requests received from I/O thread */
|
|
|
QEMUBH *qmp_dispatcher_bh;
|
|
|
|
|
|
-/* Protects mon_list, monitor_qapi_event_state, monitor_destroyed. */
|
|
|
+/*
|
|
|
+ * Protects mon_list, monitor_qapi_event_state, coroutine_mon,
|
|
|
+ * monitor_destroyed.
|
|
|
+ */
|
|
|
QemuMutex monitor_lock;
|
|
|
static GHashTable *monitor_qapi_event_state;
|
|
|
+static GHashTable *coroutine_mon; /* Maps Coroutine* to Monitor* */
|
|
|
|
|
|
MonitorList mon_list;
|
|
|
int mon_refcount;
|
|
|
static bool monitor_destroyed;
|
|
|
|
|
|
-static __thread Monitor *cur_monitor;
|
|
|
-
|
|
|
Monitor *monitor_cur(void)
|
|
|
{
|
|
|
- return cur_monitor;
|
|
|
+ Monitor *mon;
|
|
|
+
|
|
|
+ qemu_mutex_lock(&monitor_lock);
|
|
|
+ mon = g_hash_table_lookup(coroutine_mon, qemu_coroutine_self());
|
|
|
+ qemu_mutex_unlock(&monitor_lock);
|
|
|
+
|
|
|
+ return mon;
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
* Sets a new current monitor and returns the old one.
|
|
|
+ *
|
|
|
+ * If a non-NULL monitor is set for a coroutine, another call
|
|
|
+ * resetting it to NULL is required before the coroutine terminates,
|
|
|
+ * otherwise a stale entry would remain in the hash table.
|
|
|
*/
|
|
|
-Monitor *monitor_set_cur(Monitor *mon)
|
|
|
+Monitor *monitor_set_cur(Coroutine *co, Monitor *mon)
|
|
|
{
|
|
|
- Monitor *old_monitor = cur_monitor;
|
|
|
+ Monitor *old_monitor = monitor_cur();
|
|
|
+
|
|
|
+ qemu_mutex_lock(&monitor_lock);
|
|
|
+ if (mon) {
|
|
|
+ g_hash_table_replace(coroutine_mon, co, mon);
|
|
|
+ } else {
|
|
|
+ g_hash_table_remove(coroutine_mon, co);
|
|
|
+ }
|
|
|
+ qemu_mutex_unlock(&monitor_lock);
|
|
|
|
|
|
- cur_monitor = mon;
|
|
|
return old_monitor;
|
|
|
}
|
|
|
|
|
@@ -623,6 +642,7 @@ void monitor_init_globals_core(void)
|
|
|
{
|
|
|
monitor_qapi_event_init();
|
|
|
qemu_mutex_init(&monitor_lock);
|
|
|
+ coroutine_mon = g_hash_table_new(NULL, NULL);
|
|
|
|
|
|
/*
|
|
|
* The dispatcher BH must run in the main loop thread, since we
|