forked from emscripten-core/emscripten
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathexceptions.cpp
More file actions
71 lines (61 loc) · 1.62 KB
/
exceptions.cpp
File metadata and controls
71 lines (61 loc) · 1.62 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
// Copyright 2019 The Emscripten Authors. All rights reserved.
// Emscripten is available under two separate licenses, the MIT license and the
// University of Illinois/NCSA Open Source License. Both these licenses can be
// found in the LICENSE file.
#include <stdio.h>
#include <stdlib.h>
#include <pthread.h>
#include <assert.h>
#include <emscripten.h>
#include <atomic>
#define NUM_THREADS 2
#define TOTAL 1000
#define THREAD_ADDS 750
#define MAIN_ADDS 5
static std::atomic<int> sum;
static std::atomic<int> total;
void *ThreadMain(void *arg) {
for (int i = 0; i < TOTAL; i++) {
try {
// Throw two different types, to make sure we check throwing and landing
// pad behavior.
if (i & 3) {
throw 3.14159f;
}
throw i;
} catch (int x) {
total += x;
} catch (float f) {
// wait for a change, so we see interleaved processing.
int last = ++sum;
while (sum.load() == last) {}
}
}
pthread_exit((void*)TOTAL);
}
pthread_t thread[NUM_THREADS];
void CreateThread(int i)
{
int rc = pthread_create(&thread[i], nullptr, ThreadMain, (void*)(intptr_t)i);
assert(rc == 0);
}
void loop() {
static int main_adds = 0;
int worker_adds = sum++ - main_adds++;
printf("main iter %d : %d\n", main_adds, worker_adds);
if (worker_adds == NUM_THREADS * THREAD_ADDS &&
main_adds >= MAIN_ADDS) {
printf("done: %d.\n", total.load());
emscripten_cancel_main_loop();
exit(0);
}
}
int main() {
// Create initial threads.
for(int i = 0; i < NUM_THREADS; ++i) {
printf("make\n");
CreateThread(i);
}
emscripten_set_main_loop(loop, 0, 0);
return 0;
}