@@ -30,6 +30,11 @@ typedef struct AtomicWaitNode {
3030 korp_cond wait_cond ;
3131} AtomicWaitNode ;
3232
33+ typedef struct AtomicWaitAddressArgs {
34+ uint32 index ;
35+ void * * addr ;
36+ } AtomicWaitAddressArgs ;
37+
3338/* Atomic wait map */
3439static HashMap * wait_map ;
3540
@@ -87,6 +92,48 @@ search_module(WASMModuleCommon *module)
8792 return NULL ;
8893}
8994
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+
90137WASMSharedMemNode *
91138wasm_module_get_shared_memory (WASMModuleCommon * module )
92139{
0 commit comments