Commit 72c2be77 authored by David Teigland's avatar David Teigland Committed by Steven Whitehouse

[DLM] interface for purge (2/2)

Add code to accept purge commands from userland.
Signed-off-by: default avatarDavid Teigland <teigland@redhat.com>
Signed-off-by: default avatarSteven Whitehouse <swhiteho@redhat.com>
parent 8499137d
...@@ -41,6 +41,8 @@ int dlm_user_unlock(struct dlm_ls *ls, struct dlm_user_args *ua_tmp, ...@@ -41,6 +41,8 @@ int dlm_user_unlock(struct dlm_ls *ls, struct dlm_user_args *ua_tmp,
uint32_t flags, uint32_t lkid, char *lvb_in); uint32_t flags, uint32_t lkid, char *lvb_in);
int dlm_user_cancel(struct dlm_ls *ls, struct dlm_user_args *ua_tmp, int dlm_user_cancel(struct dlm_ls *ls, struct dlm_user_args *ua_tmp,
uint32_t flags, uint32_t lkid); uint32_t flags, uint32_t lkid);
int dlm_user_purge(struct dlm_ls *ls, struct dlm_user_proc *proc,
int nodeid, int pid);
void dlm_clear_proc_locks(struct dlm_ls *ls, struct dlm_user_proc *proc); void dlm_clear_proc_locks(struct dlm_ls *ls, struct dlm_user_proc *proc);
static inline int is_master(struct dlm_rsb *r) static inline int is_master(struct dlm_rsb *r)
......
...@@ -56,6 +56,7 @@ struct dlm_write_request32 { ...@@ -56,6 +56,7 @@ struct dlm_write_request32 {
union { union {
struct dlm_lock_params32 lock; struct dlm_lock_params32 lock;
struct dlm_lspace_params lspace; struct dlm_lspace_params lspace;
struct dlm_purge_params purge;
} i; } i;
}; };
...@@ -92,6 +93,9 @@ static void compat_input(struct dlm_write_request *kb, ...@@ -92,6 +93,9 @@ static void compat_input(struct dlm_write_request *kb,
kb->i.lspace.flags = kb32->i.lspace.flags; kb->i.lspace.flags = kb32->i.lspace.flags;
kb->i.lspace.minor = kb32->i.lspace.minor; kb->i.lspace.minor = kb32->i.lspace.minor;
strcpy(kb->i.lspace.name, kb32->i.lspace.name); strcpy(kb->i.lspace.name, kb32->i.lspace.name);
} else if (kb->cmd == DLM_USER_PURGE) {
kb->i.purge.nodeid = kb32->i.purge.nodeid;
kb->i.purge.pid = kb32->i.purge.pid;
} else { } else {
kb->i.lock.mode = kb32->i.lock.mode; kb->i.lock.mode = kb32->i.lock.mode;
kb->i.lock.namelen = kb32->i.lock.namelen; kb->i.lock.namelen = kb32->i.lock.namelen;
...@@ -320,6 +324,22 @@ fail: ...@@ -320,6 +324,22 @@ fail:
return error; return error;
} }
static int device_user_purge(struct dlm_user_proc *proc,
struct dlm_purge_params *params)
{
struct dlm_ls *ls;
int error;
ls = dlm_find_lockspace_local(proc->lockspace);
if (!ls)
return -ENOENT;
error = dlm_user_purge(ls, proc, params->nodeid, params->pid);
dlm_put_lockspace(ls);
return error;
}
static int device_create_lockspace(struct dlm_lspace_params *params) static int device_create_lockspace(struct dlm_lspace_params *params)
{ {
dlm_lockspace_t *lockspace; dlm_lockspace_t *lockspace;
...@@ -522,6 +542,14 @@ static ssize_t device_write(struct file *file, const char __user *buf, ...@@ -522,6 +542,14 @@ static ssize_t device_write(struct file *file, const char __user *buf,
error = device_remove_lockspace(&kbuf->i.lspace); error = device_remove_lockspace(&kbuf->i.lspace);
break; break;
case DLM_USER_PURGE:
if (!proc) {
log_print("no locking on control device");
goto out_sig;
}
error = device_user_purge(proc, &kbuf->i.purge);
break;
default: default:
log_print("Unknown command passed to DLM device : %d\n", log_print("Unknown command passed to DLM device : %d\n",
kbuf->cmd); kbuf->cmd);
......
...@@ -19,7 +19,7 @@ ...@@ -19,7 +19,7 @@
/* Version of the device interface */ /* Version of the device interface */
#define DLM_DEVICE_VERSION_MAJOR 5 #define DLM_DEVICE_VERSION_MAJOR 5
#define DLM_DEVICE_VERSION_MINOR 0 #define DLM_DEVICE_VERSION_MINOR 1
#define DLM_DEVICE_VERSION_PATCH 0 #define DLM_DEVICE_VERSION_PATCH 0
/* struct passed to the lock write */ /* struct passed to the lock write */
...@@ -44,6 +44,11 @@ struct dlm_lspace_params { ...@@ -44,6 +44,11 @@ struct dlm_lspace_params {
char name[0]; char name[0];
}; };
struct dlm_purge_params {
__u32 nodeid;
__u32 pid;
};
struct dlm_write_request { struct dlm_write_request {
__u32 version[3]; __u32 version[3];
__u8 cmd; __u8 cmd;
...@@ -53,6 +58,7 @@ struct dlm_write_request { ...@@ -53,6 +58,7 @@ struct dlm_write_request {
union { union {
struct dlm_lock_params lock; struct dlm_lock_params lock;
struct dlm_lspace_params lspace; struct dlm_lspace_params lspace;
struct dlm_purge_params purge;
} i; } i;
}; };
...@@ -76,6 +82,7 @@ struct dlm_lock_result { ...@@ -76,6 +82,7 @@ struct dlm_lock_result {
#define DLM_USER_QUERY 3 #define DLM_USER_QUERY 3
#define DLM_USER_CREATE_LOCKSPACE 4 #define DLM_USER_CREATE_LOCKSPACE 4
#define DLM_USER_REMOVE_LOCKSPACE 5 #define DLM_USER_REMOVE_LOCKSPACE 5
#define DLM_USER_PURGE 6
/* Arbitrary length restriction */ /* Arbitrary length restriction */
#define MAX_LS_NAME_LEN 64 #define MAX_LS_NAME_LEN 64
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment