File: mt.h

package info (click to toggle)
schism 2%3A20250313-2
  • links: PTS, VCS
  • area: main
  • in suites: trixie
  • size: 4,948 kB
  • sloc: ansic: 77,328; makefile: 545; objc: 365; python: 321; perl: 75; sh: 41; xml: 10
file content (71 lines) | stat: -rw-r--r-- 2,464 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
/*
 * Schism Tracker - a cross-platform Impulse Tracker clone
 * copyright (c) 2003-2005 Storlek <storlek@rigelseven.com>
 * copyright (c) 2005-2008 Mrs. Brisby <mrs.brisby@nimh.org>
 * copyright (c) 2009 Storlek & Mrs. Brisby
 * copyright (c) 2010-2012 Storlek
 * URL: http://schismtracker.org/
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 */

/* "mt" stands for "multithreading" ;)
 *
 * this was heavily "inspired" by the SDL 2 threading API, which has remained
 * largely unchanged in SDL 3. if you don't know what a certain function does
 * or even what a type is for (like the condition variables) see SDL's API
 * docs for how all this stuff goes together. */

#ifndef SCHISM_MT_H_
#define SCHISM_MT_H_

#include "headers.h"

typedef uint64_t mt_thread_id_t;

/* private to each backend */
typedef struct mt_thread mt_thread_t;
typedef struct mt_mutex mt_mutex_t;
typedef struct mt_cond mt_cond_t;

typedef int (*schism_thread_function_t)(void *userdata);

enum {
	MT_THREAD_PRIORITY_LOW = 0,
	MT_THREAD_PRIORITY_NORMAL,
	MT_THREAD_PRIORITY_HIGH,
	MT_THREAD_PRIORITY_TIME_CRITICAL,
};

mt_thread_t *mt_thread_create(schism_thread_function_t func, const char *name, void *userdata);
void mt_thread_wait(mt_thread_t *thread, int *status);
void mt_thread_set_priority(int priority);
mt_thread_id_t mt_thread_id(void);

mt_mutex_t *mt_mutex_create(void);
void mt_mutex_delete(mt_mutex_t *mutex);
void mt_mutex_lock(mt_mutex_t *mutex);
void mt_mutex_unlock(mt_mutex_t *mutex);

mt_cond_t *mt_cond_create(void);
void mt_cond_delete(mt_cond_t *cond);
void mt_cond_signal(mt_cond_t *cond);
void mt_cond_wait(mt_cond_t *cond, mt_mutex_t *mutex);
void mt_cond_wait_timeout(mt_cond_t *cond, mt_mutex_t *mutex, uint32_t timeout);

int mt_init(void);
void mt_quit(void);

#endif /* SCHISM_MT_H_ */