2021-02-08 09:51:59 +01:00
|
|
|
/*
|
|
|
|
* BIRD Coroutines
|
|
|
|
*
|
|
|
|
* (c) 2017 Martin Mares <mj@ucw.cz>
|
2021-06-19 20:50:18 +02:00
|
|
|
* (c) 2020-2021 Maria Matejka <mq@jmq.cz>
|
2021-02-08 09:51:59 +01:00
|
|
|
*
|
|
|
|
* Can be freely distributed and used under the terms of the GNU GPL.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _BIRD_CORO_H_
|
|
|
|
#define _BIRD_CORO_H_
|
|
|
|
|
|
|
|
#include "lib/resource.h"
|
|
|
|
|
|
|
|
/* A completely opaque coroutine handle. */
|
|
|
|
struct coroutine;
|
|
|
|
|
|
|
|
/* Coroutines are independent threads bound to pools.
|
|
|
|
* You request a coroutine by calling coro_run().
|
|
|
|
* It is forbidden to free a running coroutine from outside.
|
|
|
|
* The running coroutine must free itself by rfree() before returning.
|
|
|
|
*/
|
|
|
|
struct coroutine *coro_run(pool *, void (*entry)(void *), void *data);
|
|
|
|
|
2021-06-19 20:50:18 +02:00
|
|
|
/* Get self. */
|
|
|
|
extern _Thread_local struct coroutine *this_coro;
|
|
|
|
|
2021-11-12 22:58:40 +01:00
|
|
|
/* Just wait for a little while. Not intended for general use; use events if possible. */
|
|
|
|
void coro_yield(void);
|
2021-02-08 09:51:59 +01:00
|
|
|
|
|
|
|
#endif
|