[Cluster-devel] Re: [PATCH 2/2] dlm: interface for purge
Steven Whitehouse
swhiteho at redhat.com
Mon Apr 2 14:17:55 UTC 2007
Hi,
Now pushed to the -nmw git tree. Thanks,
Steve.
On Fri, 2007-03-30 at 15:06 -0500, David Teigland wrote:
> Add code to accept purge commands from userland.
>
> Signed-off-by: David Teigland <teigland at redhat.com>
>
> Index: linux-2.6.21-rc5-quilt/fs/dlm/lock.h
> ===================================================================
> --- linux-2.6.21-rc5-quilt.orig/fs/dlm/lock.h 2007-03-30 13:33:53.000000000 -0500
> +++ linux-2.6.21-rc5-quilt/fs/dlm/lock.h 2007-03-30 14:40:02.000000000 -0500
> @@ -41,6 +41,8 @@
> uint32_t flags, uint32_t lkid, char *lvb_in);
> int dlm_user_cancel(struct dlm_ls *ls, struct dlm_user_args *ua_tmp,
> 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);
>
> static inline int is_master(struct dlm_rsb *r)
> Index: linux-2.6.21-rc5-quilt/fs/dlm/user.c
> ===================================================================
> --- linux-2.6.21-rc5-quilt.orig/fs/dlm/user.c 2007-03-30 13:33:53.000000000 -0500
> +++ linux-2.6.21-rc5-quilt/fs/dlm/user.c 2007-03-30 14:46:10.000000000 -0500
> @@ -56,6 +56,7 @@
> union {
> struct dlm_lock_params32 lock;
> struct dlm_lspace_params lspace;
> + struct dlm_purge_params purge;
> } i;
> };
>
> @@ -92,6 +93,9 @@
> kb->i.lspace.flags = kb32->i.lspace.flags;
> kb->i.lspace.minor = kb32->i.lspace.minor;
> 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 {
> kb->i.lock.mode = kb32->i.lock.mode;
> kb->i.lock.namelen = kb32->i.lock.namelen;
> @@ -297,6 +301,22 @@
> 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)
> {
> dlm_lockspace_t *lockspace;
> @@ -508,6 +528,14 @@
> error = device_remove_lockspace(&kbuf->i.lspace);
> 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:
> log_print("Unknown command passed to DLM device : %d\n",
> kbuf->cmd);
> Index: linux-2.6.21-rc5-quilt/include/linux/dlm_device.h
> ===================================================================
> --- linux-2.6.21-rc5-quilt.orig/include/linux/dlm_device.h 2007-03-30 13:33:53.000000000 -0500
> +++ linux-2.6.21-rc5-quilt/include/linux/dlm_device.h 2007-03-30 14:40:02.000000000 -0500
> @@ -19,7 +19,7 @@
>
> /* Version of the device interface */
> #define DLM_DEVICE_VERSION_MAJOR 5
> -#define DLM_DEVICE_VERSION_MINOR 0
> +#define DLM_DEVICE_VERSION_MINOR 1
> #define DLM_DEVICE_VERSION_PATCH 0
>
> /* struct passed to the lock write */
> @@ -44,6 +44,11 @@
> char name[0];
> };
>
> +struct dlm_purge_params {
> + __u32 nodeid;
> + __u32 pid;
> +};
> +
> struct dlm_write_request {
> __u32 version[3];
> __u8 cmd;
> @@ -53,6 +58,7 @@
> union {
> struct dlm_lock_params lock;
> struct dlm_lspace_params lspace;
> + struct dlm_purge_params purge;
> } i;
> };
>
> @@ -76,6 +82,7 @@
> #define DLM_USER_QUERY 3
> #define DLM_USER_CREATE_LOCKSPACE 4
> #define DLM_USER_REMOVE_LOCKSPACE 5
> +#define DLM_USER_PURGE 6
>
> /* Arbitrary length restriction */
> #define MAX_LS_NAME_LEN 64
More information about the Cluster-devel
mailing list