File: test_pthread_dlopen_many.c

package info (click to toggle)
emscripten 3.1.69%2Bdfsg-3
  • links: PTS, VCS
  • area: main
  • in suites: trixie
  • size: 121,860 kB
  • sloc: ansic: 636,110; cpp: 425,974; javascript: 78,401; python: 58,404; sh: 49,154; pascal: 5,237; makefile: 3,366; asm: 2,415; lisp: 1,869
file content (74 lines) | stat: -rw-r--r-- 1,898 bytes parent folder | download | duplicates (2)
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
72
73
74
#include <assert.h>
#include <dlfcn.h>
#include <pthread.h>
#include <stdio.h>

#ifndef NUM_THREADS
#define NUM_THREADS 2
#endif

typedef int* (*sidey_data_type)();
typedef int (*func_t)();
typedef func_t (*sidey_func_type)();

pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER;

_Atomic int thread_count = 0;
_Atomic int dso_count = 0;
void jslib_func();

void* thread_main(void* arg) {
  int num = (intptr_t)arg;
  printf("thread_main %d %p\n", num, pthread_self());
  thread_count++;

  void* func_addr = dlsym(RTLD_DEFAULT, "jslib_func");
  assert(func_addr);
  printf("jslib_func via dlsym: %p\n", func_addr);

  // busy wait until all threads are running
  while (thread_count != NUM_THREADS) {}

  char filename[255];
  sprintf(filename, "liblib%d.so", num);
  printf("loading %s\n", filename);
  void* handle = dlopen(filename, RTLD_NOW|RTLD_GLOBAL);
  printf("done loading %s (total=%d)\n", filename, ++dso_count);
  if (!handle) {
    printf("dlerror: %s\n", dlerror());
  }
  assert(handle);

  sidey_data_type p_side_data_address;
  sidey_func_type p_side_func_address;
  p_side_data_address = dlsym(handle, "side_data_address");
  printf("p_side_data_address=%p\n", p_side_data_address);
  p_side_func_address = dlsym(handle, "side_func_address");
  printf("p_side_func_address=%p\n", p_side_func_address);

  printf("done thread_main %d\n", num);
  return NULL;
}

int main() {
  printf("in main: %p\n", pthread_self());
  jslib_func();

  pthread_mutex_lock(&mutex);

  // start a bunch of threads while holding the lock
  pthread_t threads[NUM_THREADS];
  for (int i = 0; i < NUM_THREADS; i++) {
    pthread_create(&threads[i], NULL, thread_main, (void*)(intptr_t)i);
  }

  // busy wait until all threads are running
  while (thread_count != NUM_THREADS) {}

  for (int i = 0; i < NUM_THREADS; i++) {
    pthread_join(threads[i], NULL);
  }

  printf("main done\n");
  return 0;
}