File: test_large_pthread_allocation.cpp

package info (click to toggle)
emscripten 2.0.12~dfsg-2
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 108,440 kB
  • sloc: ansic: 510,324; cpp: 384,763; javascript: 84,341; python: 51,362; sh: 50,019; pascal: 4,159; makefile: 3,409; asm: 2,150; lisp: 1,869; ruby: 488; cs: 142
file content (69 lines) | stat: -rw-r--r-- 1,665 bytes parent folder | download
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
// 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 <pthread.h>
#include <sys/types.h>
#include <stdio.h>
#include <stdlib.h>
#include <assert.h>
#include <unistd.h>
#include <errno.h>
#include <emscripten.h>
#include <emscripten/threading.h>
#include <vector>

pthread_t threads[50];

static void *thread_start(void *arg)
{
  // This thread quits immediately...
  pthread_exit((void*)0);
}

void CreateThread(int idx) {
  int rc = pthread_create(&threads[idx], NULL, thread_start, (void*)idx);
  assert(rc == 0);
}

void JoinThread(int idx) {
  int rc = pthread_join(threads[idx], nullptr);
  assert(rc == 0);
}

int main()
{
  if (!emscripten_has_threading_support())
  {
#ifdef REPORT_RESULT
    REPORT_RESULT(0);
#endif
    printf("Skipped: Threading is not supported.\n");
    return 0;
  }

  // This test should be run with a prewarmed pool of size 50. They should be fully allocated.
  assert(EM_ASM_INT(return PThread.unusedWorkers.length) == 50);

  double total = 0;
  for (int i = 0; i < 10; ++i) {
    double t1 = emscripten_get_now();
    for (int j = 0; j < 50; ++j) {
      CreateThread(j);
    }
    double t2 = emscripten_get_now();
    printf("Took %f ms to allocate 50 threads.\n", t2 - t1);
    total += (t2 - t1);
    // Join all the threads to clear the queue..
    for (int j = 0; j < 50; ++j) {
      JoinThread(j);
    }
  }

  printf("Final average %f ms.\n", total / 10.0);

#ifdef REPORT_RESULT
  REPORT_RESULT(0);
#endif
}