@@ -30,6 +30,11 @@ typedef struct AtomicWaitNode {
30
30
korp_cond wait_cond ;
31
31
} AtomicWaitNode ;
32
32
33
+ typedef struct AtomicWaitAddressArgs {
34
+ uint32 index ;
35
+ void * * addr ;
36
+ } AtomicWaitAddressArgs ;
37
+
33
38
/* Atomic wait map */
34
39
static HashMap * wait_map ;
35
40
@@ -87,6 +92,48 @@ search_module(WASMModuleCommon *module)
87
92
return NULL ;
88
93
}
89
94
95
+ static void
96
+ wait_map_address_count_callback (void * key , void * value ,
97
+ void * p_total_elem_count )
98
+ {
99
+ * (uint32 * )p_total_elem_count = * (uint32 * )p_total_elem_count + 1 ;
100
+ }
101
+
102
+ static void
103
+ create_list_of_waiter_addresses (void * key , void * value , void * user_data )
104
+ {
105
+ AtomicWaitAddressArgs * data = (AtomicWaitAddressArgs * )user_data ;
106
+ data -> addr [data -> index ++ ] = key ;
107
+ }
108
+
109
+ void
110
+ notify_stale_threads_on_exception (WASMModuleInstanceCommon * module_inst )
111
+ {
112
+ AtomicWaitAddressArgs args = { 0 };
113
+ uint32 i = 0 , total_elem_count = 0 ;
114
+
115
+ os_mutex_lock (& shared_memory_list_lock );
116
+
117
+ /* count number of addresses in wait_map */
118
+ bh_hash_map_traverse (wait_map , wait_map_address_count_callback ,
119
+ (void * )& total_elem_count );
120
+
121
+ /* allocate memory */
122
+ args .addr = wasm_runtime_malloc (sizeof (void * ) * total_elem_count );
123
+
124
+ /* set values in list of addresses */
125
+ bh_hash_map_traverse (wait_map , create_list_of_waiter_addresses , & args );
126
+ os_mutex_unlock (& shared_memory_list_lock );
127
+
128
+ /* notify */
129
+ for (i = 0 ; i < args .index ; i ++ ) {
130
+ wasm_runtime_atomic_notify (module_inst , args .addr [i ], UINT32_MAX );
131
+ }
132
+
133
+ /* free memory allocated to args data */
134
+ wasm_runtime_free (args .addr );
135
+ }
136
+
90
137
WASMSharedMemNode *
91
138
wasm_module_get_shared_memory (WASMModuleCommon * module )
92
139
{
0 commit comments