summaryrefslogtreecommitdiffstats
path: root/xlators/cluster/afr/src/afr.h
diff options
context:
space:
mode:
Diffstat (limited to 'xlators/cluster/afr/src/afr.h')
-rw-r--r--xlators/cluster/afr/src/afr.h17
1 files changed, 17 insertions, 0 deletions
diff --git a/xlators/cluster/afr/src/afr.h b/xlators/cluster/afr/src/afr.h
index 93f4ba3dddc..9bfb5812d8a 100644
--- a/xlators/cluster/afr/src/afr.h
+++ b/xlators/cluster/afr/src/afr.h
@@ -347,6 +347,11 @@ typedef struct {
int readdir_subvol;
} afr_fd_ctx_t;
+typedef enum {
+ AFR_FOP_LOCK_PARALLEL,
+ AFR_FOP_LOCK_SERIAL,
+ AFR_FOP_LOCK_QUORUM_FAILED,
+} afr_fop_lock_state_t;
typedef struct _afr_local {
glusterfs_fop_t op;
@@ -664,11 +669,19 @@ typedef struct _afr_local {
struct {
char *volume;
int32_t cmd;
+ int32_t in_cmd;
+ struct gf_flock in_flock;
struct gf_flock flock;
+ void *xdata;
} inodelk;
struct {
+ char *volume;
+ char *basename;
+ entrylk_cmd in_cmd;
entrylk_cmd cmd;
+ entrylk_type type;
+ void *xdata;
} entrylk;
struct {
@@ -791,6 +804,7 @@ typedef struct _afr_local {
gf_boolean_t need_full_crawl;
gf_boolean_t compound;
+ afr_fop_lock_state_t fop_lock_state;
} afr_local_t;
@@ -1180,6 +1194,9 @@ int
afr_set_in_flight_sb_status (xlator_t *this, afr_local_t *local,
inode_t *inode);
+int32_t
+afr_quorum_errno (afr_private_t *priv);
+
gf_boolean_t
afr_is_consistent_io_possible (afr_local_t *local, afr_private_t *priv,
int32_t *op_errno);