Johan Wikman e9b2a560b8 MXS-1360 Make it possible to specify thread stack size
It is now possible to specify the thread stack size to be used,
when a new thread is created. This will subsequently be used
for allowing the stack size to be specified for worker threads.
2017-08-14 15:24:16 +03:00

73 lines
1.8 KiB
C

#pragma once
/*
* Copyright (c) 2016 MariaDB Corporation Ab
*
* Use of this software is governed by the Business Source License included
* in the LICENSE.TXT file and at www.mariadb.com/bsl11.
*
* Change Date: 2020-01-01
*
* On the date above, in accordance with the Business Source License, use
* of this software will be governed by version 2 or later of the General
* Public License.
*/
/**
* @file thread.h The gateway threading interface
*
* An encapsulation of the threading used by the gateway. This is designed to
* isolate the majority of the gateway code from the pthread library, enabling
* the gateway to be ported to a different threading package with the minimum
* of changes.
*/
#include <maxscale/cdefs.h>
MXS_BEGIN_DECLS
/**
* Thread type and thread identifier function macros
*/
#include <pthread.h>
typedef pthread_t THREAD;
/**
* Obtain a handle to the calling thread
*
* @return The thread handle of the calling thread.
*/
static inline THREAD thread_self()
{
return pthread_self();
}
/**
* Start a secondary thread
*
* @param thd Pointer to the THREAD object
* @param entry The entry point to call
* @param arg The argument to pass the thread entry point
* @param stack_size The stack size of the thread. If 0, the default
* size will be used.
*
* @return The thread handle or NULL if an error occurred
*/
extern THREAD *thread_start(THREAD *thd, void (*entry)(void *), void *arg, size_t stack_size);
/**
* Wait for a running thread to complete.
*
* @param thd The thread handle
*/
extern void thread_wait(THREAD thd);
/**
* Put the calling thread to sleep for a number of milliseconds
*
* @param ms Number of milliseconds to sleep
*/
extern void thread_millisleep(int ms);
MXS_END_DECLS