Commit 104480ed authored by Sergey Lyubka's avatar Sergey Lyubka

mg_start_thread() exported

parent c1ab21ec
...@@ -255,8 +255,6 @@ typedef int socklen_t; ...@@ -255,8 +255,6 @@ typedef int socklen_t;
#define MSG_NOSIGNAL 0 #define MSG_NOSIGNAL 0
#endif #endif
typedef void * (*mg_thread_func_t)(void *);
static const char *http_500_error = "Internal Server Error"; static const char *http_500_error = "Internal Server Error";
// Snatched from OpenSSL includes. I put the prototypes here to be independent // Snatched from OpenSSL includes. I put the prototypes here to be independent
...@@ -1155,7 +1153,7 @@ static struct dirent *readdir(DIR *dir) { ...@@ -1155,7 +1153,7 @@ static struct dirent *readdir(DIR *dir) {
#define set_close_on_exec(fd) // No FD_CLOEXEC on Windows #define set_close_on_exec(fd) // No FD_CLOEXEC on Windows
static int start_thread(struct mg_context *ctx, mg_thread_func_t f, void *p) { int mg_start_thread(mg_thread_func_t f, void *p) {
return _beginthread((void (__cdecl *)(void *)) f, 0, p) == -1L ? -1 : 0; return _beginthread((void (__cdecl *)(void *)) f, 0, p) == -1L ? -1 : 0;
} }
...@@ -1264,22 +1262,16 @@ static void set_close_on_exec(int fd) { ...@@ -1264,22 +1262,16 @@ static void set_close_on_exec(int fd) {
(void) fcntl(fd, F_SETFD, FD_CLOEXEC); (void) fcntl(fd, F_SETFD, FD_CLOEXEC);
} }
static int start_thread(struct mg_context *ctx, mg_thread_func_t func, int mg_start_thread(mg_thread_func_t func, void *param) {
void *param) {
pthread_t thread_id; pthread_t thread_id;
pthread_attr_t attr; pthread_attr_t attr;
int retval;
(void) pthread_attr_init(&attr); (void) pthread_attr_init(&attr);
(void) pthread_attr_setdetachstate(&attr, PTHREAD_CREATE_DETACHED); (void) pthread_attr_setdetachstate(&attr, PTHREAD_CREATE_DETACHED);
// TODO(lsm): figure out why mongoose dies on Linux if next line is enabled // TODO(lsm): figure out why mongoose dies on Linux if next line is enabled
// (void) pthread_attr_setstacksize(&attr, sizeof(struct mg_connection) * 5); // (void) pthread_attr_setstacksize(&attr, sizeof(struct mg_connection) * 5);
if ((retval = pthread_create(&thread_id, &attr, func, param)) != 0) { return pthread_create(&thread_id, &attr, func, param);
cry(fc(ctx), "%s: %s", __func__, strerror(retval));
}
return retval;
} }
#ifndef NO_CGI #ifndef NO_CGI
...@@ -4333,11 +4325,11 @@ struct mg_context *mg_start(mg_callback_t user_callback, void *user_data, ...@@ -4333,11 +4325,11 @@ struct mg_context *mg_start(mg_callback_t user_callback, void *user_data,
(void) pthread_cond_init(&ctx->sq_full, NULL); (void) pthread_cond_init(&ctx->sq_full, NULL);
// Start master (listening) thread // Start master (listening) thread
start_thread(ctx, (mg_thread_func_t) master_thread, ctx); mg_start_thread((mg_thread_func_t) master_thread, ctx);
// Start worker threads // Start worker threads
for (i = 0; i < atoi(ctx->config[NUM_THREADS]); i++) { for (i = 0; i < atoi(ctx->config[NUM_THREADS]); i++) {
if (start_thread(ctx, (mg_thread_func_t) worker_thread, ctx) != 0) { if (mg_start_thread((mg_thread_func_t) worker_thread, ctx) != 0) {
cry(fc(ctx), "Cannot start worker thread: %d", ERRNO); cry(fc(ctx), "Cannot start worker thread: %d", ERRNO);
} else { } else {
ctx->num_threads++; ctx->num_threads++;
......
...@@ -238,6 +238,12 @@ FILE *mg_fetch(struct mg_context *ctx, const char *url, const char *path, ...@@ -238,6 +238,12 @@ FILE *mg_fetch(struct mg_context *ctx, const char *url, const char *path,
struct mg_request_info *request_info); struct mg_request_info *request_info);
// Convenience function -- create detached thread.
// Return: 0 on success, non-0 on error.
typedef void * (*mg_thread_func_t)(void *);
int mg_start_thread(mg_thread_func_t f, void *p);
// Return Mongoose version. // Return Mongoose version.
const char *mg_version(void); const char *mg_version(void);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment