mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-15 13:15:57 +00:00
14bb211d32
As we no longer release the lock before potentially raising BLACKLISTED in rbd_reregister_watch(), the "either locked or blacklisted" assert in rbd_queue_workfn() needs to go: we can be both locked and blacklisted at that point now. Signed-off-by: Ilya Dryomov <idryomov@gmail.com> Reviewed-by: Jason Dillaman <dillaman@redhat.com>
55 lines
1.6 KiB
C
55 lines
1.6 KiB
C
#ifndef _LINUX_CEPH_CLS_LOCK_CLIENT_H
|
|
#define _LINUX_CEPH_CLS_LOCK_CLIENT_H
|
|
|
|
#include <linux/ceph/osd_client.h>
|
|
|
|
enum ceph_cls_lock_type {
|
|
CEPH_CLS_LOCK_NONE = 0,
|
|
CEPH_CLS_LOCK_EXCLUSIVE = 1,
|
|
CEPH_CLS_LOCK_SHARED = 2,
|
|
};
|
|
|
|
struct ceph_locker_id {
|
|
struct ceph_entity_name name; /* locker's client name */
|
|
char *cookie; /* locker's cookie */
|
|
};
|
|
|
|
struct ceph_locker_info {
|
|
struct ceph_entity_addr addr; /* locker's address */
|
|
};
|
|
|
|
struct ceph_locker {
|
|
struct ceph_locker_id id;
|
|
struct ceph_locker_info info;
|
|
};
|
|
|
|
int ceph_cls_lock(struct ceph_osd_client *osdc,
|
|
struct ceph_object_id *oid,
|
|
struct ceph_object_locator *oloc,
|
|
char *lock_name, u8 type, char *cookie,
|
|
char *tag, char *desc, u8 flags);
|
|
int ceph_cls_unlock(struct ceph_osd_client *osdc,
|
|
struct ceph_object_id *oid,
|
|
struct ceph_object_locator *oloc,
|
|
char *lock_name, char *cookie);
|
|
int ceph_cls_break_lock(struct ceph_osd_client *osdc,
|
|
struct ceph_object_id *oid,
|
|
struct ceph_object_locator *oloc,
|
|
char *lock_name, char *cookie,
|
|
struct ceph_entity_name *locker);
|
|
int ceph_cls_set_cookie(struct ceph_osd_client *osdc,
|
|
struct ceph_object_id *oid,
|
|
struct ceph_object_locator *oloc,
|
|
char *lock_name, u8 type, char *old_cookie,
|
|
char *tag, char *new_cookie);
|
|
|
|
void ceph_free_lockers(struct ceph_locker *lockers, u32 num_lockers);
|
|
|
|
int ceph_cls_lock_info(struct ceph_osd_client *osdc,
|
|
struct ceph_object_id *oid,
|
|
struct ceph_object_locator *oloc,
|
|
char *lock_name, u8 *type, char **tag,
|
|
struct ceph_locker **lockers, u32 *num_lockers);
|
|
|
|
#endif
|