X-Git-Url: https://git.kernel.dk/?p=fio.git;a=blobdiff_plain;f=mutex.h;h=4f3486df7a3b01163515cd548678445d7e40b924;hp=6fdf7c6dabceaa456d17f66040be3894c61556c8;hb=7a16102ef84e3db14b6802a06f7f99e2e55af85d;hpb=521da527743088a9bd2ab882f8b64799d49d5848 diff --git a/mutex.h b/mutex.h index 6fdf7c6d..4f3486df 100644 --- a/mutex.h +++ b/mutex.h @@ -3,11 +3,20 @@ #include +#define FIO_MUTEX_MAGIC 0x4d555445U +#define FIO_RWLOCK_MAGIC 0x52574c4fU + struct fio_mutex { pthread_mutex_t lock; pthread_cond_t cond; int value; int waiters; + int magic; +}; + +struct fio_rwlock { + pthread_rwlock_t lock; + int magic; }; enum { @@ -17,22 +26,14 @@ enum { extern struct fio_mutex *fio_mutex_init(int); extern void fio_mutex_remove(struct fio_mutex *); +extern void fio_mutex_up(struct fio_mutex *); extern void fio_mutex_down(struct fio_mutex *); extern int fio_mutex_down_timeout(struct fio_mutex *, unsigned int); -extern void fio_mutex_down_read(struct fio_mutex *); -extern void fio_mutex_down_write(struct fio_mutex *); -extern void fio_mutex_up(struct fio_mutex *); -extern void fio_mutex_up_read(struct fio_mutex *); -extern void fio_mutex_up_write(struct fio_mutex *); - -static inline struct fio_mutex *fio_mutex_rw_init(void) -{ - return fio_mutex_init(0); -} - -static inline int fio_mutex_getval(struct fio_mutex *mutex) -{ - return mutex->value; -} + +extern void fio_rwlock_read(struct fio_rwlock *); +extern void fio_rwlock_write(struct fio_rwlock *); +extern void fio_rwlock_unlock(struct fio_rwlock *); +extern struct fio_rwlock *fio_rwlock_init(void); +extern void fio_rwlock_remove(struct fio_rwlock *); #endif