提交 f77a9a78 编写于 作者: S Sunil Mushran 提交者: Mark Fasheh

ocfs2/dlm: Clean up struct dlm_lock_name

For master mle, the name it stored in the attached lockres in struct qstr.
For block and migration mle, the name is stored inline in struct dlm_lock_name.
This patch attempts to make struct dlm_lock_name look like a struct qstr. While
we could use struct qstr, we don't because we want to avoid having to malloc
and free the lockname string as the mle's lifetime is fairly short.
Signed-off-by: NSunil Mushran <sunil.mushran@oracle.com>
Signed-off-by: NMark Fasheh <mfasheh@suse.com>
上级 1c084577
...@@ -56,8 +56,8 @@ enum dlm_mle_type { ...@@ -56,8 +56,8 @@ enum dlm_mle_type {
}; };
struct dlm_lock_name { struct dlm_lock_name {
u8 len; unsigned int len;
u8 name[DLM_LOCKID_NAME_MAX]; unsigned char name[DLM_LOCKID_NAME_MAX];
}; };
struct dlm_master_list_entry { struct dlm_master_list_entry {
...@@ -79,8 +79,8 @@ struct dlm_master_list_entry { ...@@ -79,8 +79,8 @@ struct dlm_master_list_entry {
struct o2hb_callback_func mle_hb_up; struct o2hb_callback_func mle_hb_up;
struct o2hb_callback_func mle_hb_down; struct o2hb_callback_func mle_hb_down;
union { union {
struct dlm_lock_resource *res; struct dlm_lock_resource *mleres;
struct dlm_lock_name name; struct dlm_lock_name mlename;
} u; } u;
}; };
......
...@@ -288,15 +288,15 @@ static int dump_mle(struct dlm_master_list_entry *mle, char *buf, int len) ...@@ -288,15 +288,15 @@ static int dump_mle(struct dlm_master_list_entry *mle, char *buf, int len)
{ {
int out = 0; int out = 0;
unsigned int namelen; unsigned int namelen;
const char *name; unsigned char *name;
char *mle_type; char *mle_type;
if (mle->type != DLM_MLE_MASTER) { if (mle->type != DLM_MLE_MASTER) {
namelen = mle->u.name.len; name = mle->u.mlename.name;
name = mle->u.name.name; namelen = mle->u.mlename.len;
} else { } else {
namelen = mle->u.res->lockname.len; name = (unsigned char *)mle->u.mleres->lockname.name;
name = mle->u.res->lockname.name; namelen = mle->u.mleres->lockname.len;
} }
if (mle->type == DLM_MLE_BLOCK) if (mle->type == DLM_MLE_BLOCK)
......
...@@ -68,27 +68,38 @@ static int dlm_do_assert_master(struct dlm_ctxt *dlm, ...@@ -68,27 +68,38 @@ static int dlm_do_assert_master(struct dlm_ctxt *dlm,
void *nodemap, u32 flags); void *nodemap, u32 flags);
static void dlm_deref_lockres_worker(struct dlm_work_item *item, void *data); static void dlm_deref_lockres_worker(struct dlm_work_item *item, void *data);
static inline void __dlm_mle_name(struct dlm_master_list_entry *mle,
unsigned char **name, unsigned int *namelen)
{
BUG_ON(mle->type != DLM_MLE_BLOCK &&
mle->type != DLM_MLE_MASTER &&
mle->type != DLM_MLE_MIGRATION);
if (mle->type != DLM_MLE_MASTER) {
*name = mle->u.mlename.name;
*namelen = mle->u.mlename.len;
} else {
*name = (unsigned char *)mle->u.mleres->lockname.name;
*namelen = mle->u.mleres->lockname.len;
}
}
static inline int dlm_mle_equal(struct dlm_ctxt *dlm, static inline int dlm_mle_equal(struct dlm_ctxt *dlm,
struct dlm_master_list_entry *mle, struct dlm_master_list_entry *mle,
const char *name, const char *name,
unsigned int namelen) unsigned int namelen)
{ {
struct dlm_lock_resource *res; unsigned char *mlename;
unsigned int mlelen;
if (dlm != mle->dlm) if (dlm != mle->dlm)
return 0; return 0;
if (mle->type == DLM_MLE_BLOCK || __dlm_mle_name(mle, &mlename, &mlelen);
mle->type == DLM_MLE_MIGRATION) {
if (namelen != mle->u.name.len || if (namelen != mlelen || memcmp(name, mlename, namelen) != 0)
memcmp(name, mle->u.name.name, namelen)!=0) return 0;
return 0;
} else {
res = mle->u.res;
if (namelen != res->lockname.len ||
memcmp(res->lockname.name, name, namelen) != 0)
return 0;
}
return 1; return 1;
} }
...@@ -295,17 +306,17 @@ static void dlm_init_mle(struct dlm_master_list_entry *mle, ...@@ -295,17 +306,17 @@ static void dlm_init_mle(struct dlm_master_list_entry *mle,
mle->new_master = O2NM_MAX_NODES; mle->new_master = O2NM_MAX_NODES;
mle->inuse = 0; mle->inuse = 0;
BUG_ON(mle->type != DLM_MLE_BLOCK &&
mle->type != DLM_MLE_MASTER &&
mle->type != DLM_MLE_MIGRATION);
if (mle->type == DLM_MLE_MASTER) { if (mle->type == DLM_MLE_MASTER) {
BUG_ON(!res); BUG_ON(!res);
mle->u.res = res; mle->u.mleres = res;
} else if (mle->type == DLM_MLE_BLOCK) { } else {
BUG_ON(!name);
memcpy(mle->u.name.name, name, namelen);
mle->u.name.len = namelen;
} else /* DLM_MLE_MIGRATION */ {
BUG_ON(!name); BUG_ON(!name);
memcpy(mle->u.name.name, name, namelen); memcpy(mle->u.mlename.name, name, namelen);
mle->u.name.len = namelen; mle->u.mlename.len = namelen;
} }
/* copy off the node_map and register hb callbacks on our copy */ /* copy off the node_map and register hb callbacks on our copy */
...@@ -425,11 +436,11 @@ static void dlm_mle_release(struct kref *kref) ...@@ -425,11 +436,11 @@ static void dlm_mle_release(struct kref *kref)
if (mle->type != DLM_MLE_MASTER) { if (mle->type != DLM_MLE_MASTER) {
mlog(0, "calling mle_release for %.*s, type %d\n", mlog(0, "calling mle_release for %.*s, type %d\n",
mle->u.name.len, mle->u.name.name, mle->type); mle->u.mlename.len, mle->u.mlename.name, mle->type);
} else { } else {
mlog(0, "calling mle_release for %.*s, type %d\n", mlog(0, "calling mle_release for %.*s, type %d\n",
mle->u.res->lockname.len, mle->u.mleres->lockname.len,
mle->u.res->lockname.name, mle->type); mle->u.mleres->lockname.name, mle->type);
} }
assert_spin_locked(&dlm->spinlock); assert_spin_locked(&dlm->spinlock);
assert_spin_locked(&dlm->master_lock); assert_spin_locked(&dlm->master_lock);
...@@ -1284,7 +1295,7 @@ static int dlm_restart_lock_mastery(struct dlm_ctxt *dlm, ...@@ -1284,7 +1295,7 @@ static int dlm_restart_lock_mastery(struct dlm_ctxt *dlm,
res->lockname.len, res->lockname.len,
res->lockname.name); res->lockname.name);
mle->type = DLM_MLE_MASTER; mle->type = DLM_MLE_MASTER;
mle->u.res = res; mle->u.mleres = res;
} }
} }
} }
...@@ -1323,20 +1334,18 @@ static int dlm_do_master_request(struct dlm_lock_resource *res, ...@@ -1323,20 +1334,18 @@ static int dlm_do_master_request(struct dlm_lock_resource *res,
struct dlm_ctxt *dlm = mle->dlm; struct dlm_ctxt *dlm = mle->dlm;
struct dlm_master_request request; struct dlm_master_request request;
int ret, response=0, resend; int ret, response=0, resend;
unsigned char *mlename;
unsigned int mlenamelen;
memset(&request, 0, sizeof(request)); memset(&request, 0, sizeof(request));
request.node_idx = dlm->node_num; request.node_idx = dlm->node_num;
BUG_ON(mle->type == DLM_MLE_MIGRATION); BUG_ON(mle->type == DLM_MLE_MIGRATION);
if (mle->type != DLM_MLE_MASTER) { __dlm_mle_name(mle, &mlename, &mlenamelen);
request.namelen = mle->u.name.len;
memcpy(request.name, mle->u.name.name, request.namelen); request.namelen = (u8)mlenamelen;
} else { memcpy(request.name, mlename, request.namelen);
request.namelen = mle->u.res->lockname.len;
memcpy(request.name, mle->u.res->lockname.name,
request.namelen);
}
again: again:
ret = o2net_send_message(DLM_MASTER_REQUEST_MSG, dlm->key, &request, ret = o2net_send_message(DLM_MASTER_REQUEST_MSG, dlm->key, &request,
...@@ -3286,9 +3295,9 @@ void dlm_clean_master_list(struct dlm_ctxt *dlm, u8 dead_node) ...@@ -3286,9 +3295,9 @@ void dlm_clean_master_list(struct dlm_ctxt *dlm, u8 dead_node)
mle->master, mle->new_master); mle->master, mle->new_master);
/* if there is a lockres associated with this /* if there is a lockres associated with this
* mle, find it and set its owner to UNKNOWN */ * mle, find it and set its owner to UNKNOWN */
hash = dlm_lockid_hash(mle->u.name.name, mle->u.name.len); hash = dlm_lockid_hash(mle->u.mlename.name, mle->u.mlename.len);
res = __dlm_lookup_lockres(dlm, mle->u.name.name, res = __dlm_lookup_lockres(dlm, mle->u.mlename.name,
mle->u.name.len, hash); mle->u.mlename.len, hash);
if (res) { if (res) {
/* unfortunately if we hit this rare case, our /* unfortunately if we hit this rare case, our
* lock ordering is messed. we need to drop * lock ordering is messed. we need to drop
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册