
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.
73 lines
1.8 KiB
C
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
|