]> git.meshlink.io Git - meshlink/commitdiff
Explicitly set the stack size for the MeshLink thread.
authorGuus Sliepen <guus@meshlink.io>
Thu, 21 May 2020 12:48:02 +0000 (14:48 +0200)
committerGuus Sliepen <guus@meshlink.io>
Thu, 21 May 2020 12:48:02 +0000 (14:48 +0200)
Different libcs have different default sizes for newly created threads. In
particular, Musl defaults to 80 kB, which is too small for MeshLink. We now
request 1 MB, which should be more than enough to handle the deepest call
stacks.

src/meshlink.c

index e50be188b32ef9b19b96c2961766da4ef2d60bc4..22f5220d4beebe6c19d6612d45923602e0e78061 100644 (file)
@@ -1659,7 +1659,12 @@ bool meshlink_start(meshlink_handle_t *mesh) {
 
        event_loop_start(&mesh->loop);
 
-       if(pthread_create(&mesh->thread, NULL, meshlink_main_loop, mesh) != 0) {
+       // Ensure we have a decent amount of stack space. Musl's default of 80 kB is too small.
+       pthread_attr_t attr;
+       pthread_attr_init(&attr);
+       pthread_attr_setstacksize(&attr, 1024 * 1024);
+
+       if(pthread_create(&mesh->thread, &attr, meshlink_main_loop, mesh) != 0) {
                logger(mesh, MESHLINK_DEBUG, "Could not start thread: %s\n", strerror(errno));
                memset(&mesh->thread, 0, sizeof(mesh)->thread);
                meshlink_errno = MESHLINK_EINTERNAL;