27 lines
827 B
C
27 lines
827 B
C
|
#ifndef _FS_CEPH_MSGPOOL
|
||
|
#define _FS_CEPH_MSGPOOL
|
||
|
|
||
|
#include "messenger.h"
|
||
|
|
||
|
/*
|
||
|
* we use memory pools for preallocating messages we may receive, to
|
||
|
* avoid unexpected OOM conditions.
|
||
|
*/
|
||
|
struct ceph_msgpool {
|
||
|
spinlock_t lock;
|
||
|
int front_len; /* preallocated payload size */
|
||
|
struct list_head msgs; /* msgs in the pool; each has 1 ref */
|
||
|
int num, min; /* cur, min # msgs in the pool */
|
||
|
bool blocking;
|
||
|
wait_queue_head_t wait;
|
||
|
};
|
||
|
|
||
|
extern int ceph_msgpool_init(struct ceph_msgpool *pool,
|
||
|
int front_len, int size, bool blocking);
|
||
|
extern void ceph_msgpool_destroy(struct ceph_msgpool *pool);
|
||
|
extern int ceph_msgpool_resv(struct ceph_msgpool *, int delta);
|
||
|
extern struct ceph_msg *ceph_msgpool_get(struct ceph_msgpool *);
|
||
|
extern void ceph_msgpool_put(struct ceph_msgpool *, struct ceph_msg *);
|
||
|
|
||
|
#endif
|