@@ -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,56 @@ 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 = NULL ;
113
+ uint32 i = 0 , total_elem_count = 0 ;
114
+ if (!(args = wasm_runtime_malloc (sizeof (AtomicWaitAddressArgs )))) {
115
+ LOG_ERROR ("failed to create atomic wait address args node" );
116
+ return ;
117
+ }
118
+
119
+ os_mutex_lock (& shared_memory_list_lock );
120
+
121
+ /* count number of addresses in wait_map */
122
+ bh_hash_map_traverse (wait_map , wait_map_address_count_callback ,
123
+ (void * )& total_elem_count );
124
+
125
+ /* allocate memory */
126
+ uint32 total_size = sizeof (void * ) * total_elem_count ;
127
+ void * temp_addr [total_size ];
128
+ memset (temp_addr , 0 , sizeof (temp_addr ));
129
+
130
+ args -> addr = temp_addr ;
131
+
132
+ /* set values in list of addresses */
133
+ bh_hash_map_traverse (wait_map , create_list_of_waiter_addresses , args );
134
+ os_mutex_unlock (& shared_memory_list_lock );
135
+
136
+ /* notify */
137
+ for (i = 0 ; i < args -> index ; i ++ ) {
138
+ wasm_runtime_atomic_notify (module_inst , args -> addr [i ], UINT32_MAX );
139
+ }
140
+
141
+ /* free memory allocated to args data */
142
+ wasm_runtime_free (args );
143
+ }
144
+
90
145
WASMSharedMemNode *
91
146
wasm_module_get_shared_memory (WASMModuleCommon * module )
92
147
{
0 commit comments