mirror of
https://github.com/status-im/status-go.git
synced 2025-01-17 02:02:36 +00:00
e65760ca85
This commit adds basic syncing capabilities with peers if they are both online. It updates the work done on MVDS, but I decided to create the code in status-go instead, since it's very tight to the application (similarly the code that was the inspiration for mvds, bramble, is all tight together at the database level). I reused parts of the protobufs. The flow is: 1) An OFFER message is sent periodically with a bunch of message-ids and group-ids. 2) Anyone can REQUEST some of those messages if not present in their database. 3) The peer will then send over those messages. It's disabled by default, but I am planning to add a way to set up the flags.
94 lines
1.8 KiB
C
94 lines
1.8 KiB
C
#ifndef _THREADS_H
|
|
#define _THREADS_H
|
|
|
|
#include <features.h>
|
|
#include <time.h>
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
typedef unsigned long thrd_t;
|
|
#else
|
|
typedef struct __pthread *thrd_t;
|
|
#define thread_local _Thread_local
|
|
#endif
|
|
|
|
typedef int once_flag;
|
|
typedef unsigned tss_t;
|
|
typedef int (*thrd_start_t)(void *);
|
|
typedef void (*tss_dtor_t)(void *);
|
|
|
|
#define __NEED_cnd_t
|
|
#define __NEED_mtx_t
|
|
|
|
#include <bits/alltypes.h>
|
|
|
|
#define TSS_DTOR_ITERATIONS 4
|
|
|
|
enum {
|
|
thrd_success = 0,
|
|
thrd_busy = 1,
|
|
thrd_error = 2,
|
|
thrd_nomem = 3,
|
|
thrd_timedout = 4,
|
|
};
|
|
|
|
enum {
|
|
mtx_plain = 0,
|
|
mtx_recursive = 1,
|
|
mtx_timed = 2,
|
|
};
|
|
|
|
#define ONCE_FLAG_INIT 0
|
|
|
|
int thrd_create(thrd_t *, thrd_start_t, void *);
|
|
_Noreturn void thrd_exit(int);
|
|
|
|
int thrd_detach(thrd_t);
|
|
int thrd_join(thrd_t, int *);
|
|
|
|
int thrd_sleep(const struct timespec *, struct timespec *);
|
|
void thrd_yield(void);
|
|
|
|
thrd_t thrd_current(void);
|
|
int thrd_equal(thrd_t, thrd_t);
|
|
#ifndef __cplusplus
|
|
#define thrd_equal(A, B) ((A) == (B))
|
|
#endif
|
|
|
|
void call_once(once_flag *, void (*)(void));
|
|
|
|
int mtx_init(mtx_t *, int);
|
|
void mtx_destroy(mtx_t *);
|
|
|
|
int mtx_lock(mtx_t *);
|
|
int mtx_timedlock(mtx_t *__restrict, const struct timespec *__restrict);
|
|
int mtx_trylock(mtx_t *);
|
|
int mtx_unlock(mtx_t *);
|
|
|
|
int cnd_init(cnd_t *);
|
|
void cnd_destroy(cnd_t *);
|
|
|
|
int cnd_broadcast(cnd_t *);
|
|
int cnd_signal(cnd_t *);
|
|
|
|
int cnd_timedwait(cnd_t *__restrict, mtx_t *__restrict, const struct timespec *__restrict);
|
|
int cnd_wait(cnd_t *, mtx_t *);
|
|
|
|
int tss_create(tss_t *, tss_dtor_t);
|
|
void tss_delete(tss_t);
|
|
|
|
int tss_set(tss_t, void *);
|
|
void *tss_get(tss_t);
|
|
|
|
#if _REDIR_TIME64
|
|
__REDIR(thrd_sleep, __thrd_sleep_time64);
|
|
__REDIR(mtx_timedlock, __mtx_timedlock_time64);
|
|
__REDIR(cnd_timedwait, __cnd_timedwait_time64);
|
|
#endif
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif
|