All of lore.kernel.org
 help / color / mirror / Atom feed
* [Ocfs2-devel] [PATCH 1/1] ocfs2: add dlm context printing in dlm debug
@ 2008-01-08 21:38 wengang wang
  2008-01-08 21:47 ` wengang wang
                   ` (2 more replies)
  0 siblings, 3 replies; 5+ messages in thread
From: wengang wang @ 2008-01-08 21:38 UTC (permalink / raw)
  To: ocfs2-devel

add dlm context printing support in dlm debugging

- echo 'd' >/proc/fs/ocfs2_dlm/debug prints all dlm contexts.
- echo 'D UUID' >/proc/fs/ocfs2_dlm/debug prints the context of the specified dlm

Signed-off-by: wengang wang <wen.gang.wang@oracle.com>
Singed-off-by: Tao Ma <tao.ma@oracle.com>
---
dlmdebug.c |  104 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
1 file changed, 104 insertions(+)

--- ./fs/ocfs2/dlm/dlmdebug.c.orig	2008-01-09 06:39:18.000000000 -0500
+++ ./fs/ocfs2/dlm/dlmdebug.c	2008-01-10 03:17:13.000000000 -0500
@@ -61,6 +61,10 @@
 static int dlm_proc_stats(char *page, char **start, off_t off,
 			  int count, int *eof, void *data);
 
+static void __dlm_print_one_dlm_ctxt(struct dlm_ctxt *dlm);
+static int dlm_dump_one_dlm_ctxt(const char __user *buf, unsigned int count);
+static int dlm_dump_all_dlm_ctxts(const char __user *buf, unsigned int count);
+
 typedef int (dlm_debug_func_t)(const char __user *data, unsigned int len);
 
 struct dlm_debug_funcs
@@ -75,6 +79,8 @@
 	{ 'm', dlm_dump_all_mles },
 	{ 'p', dlm_dump_all_purge_lists  },
 	{ 'M', dlm_trigger_migration },
+	{ 'd', dlm_dump_all_dlm_ctxts },
+	{ 'D', dlm_dump_one_dlm_ctxt },
 };
 static int dlm_debug_map_sz = (sizeof(dlm_debug_map) /
 			       sizeof(struct dlm_debug_funcs));
@@ -210,7 +216,105 @@
 	spin_unlock(&dlm_domain_lock);
 	return len;
 }
+static void __dlm_print_one_dlm_ctxt(struct dlm_ctxt *dlm)
+{
+	mlog(ML_NOTICE, "purge_count: %d, name: %s\n",
+		dlm->purge_count, dlm->name);
+	mlog(ML_NOTICE, "node_num: %u, key: %u\n",
+		dlm->node_num, dlm->key);
+	mlog(ML_NOTICE, "joining_node: %u, reco->new_master: %u\n",
+		dlm->joining_node, dlm->reco.new_master);
+	mlog(ML_NOTICE, "reco->dead_node: %u, reco->state: %u\n",
+		dlm->reco.dead_node, dlm->reco.state);
+	mlog(ML_NOTICE, "dlm_state: %d, num_joins: %d\n",
+		dlm->dlm_state, dlm->num_joins);
+}
+static int dlm_dump_all_dlm_ctxts(const char __user *data, unsigned int len)
+{
+	struct dlm_ctxt *dlm;
+	struct list_head *iter;
+
+	mlog(ML_NOTICE, "dumping ALL dlm contexts for node %s\n",
+		system_utsname.nodename);
+	spin_lock(&dlm_domain_lock);
+	list_for_each(iter, &dlm_domains) {
+		dlm = list_entry (iter, struct dlm_ctxt, list);
+		spin_lock(&dlm->spinlock);
+		__dlm_print_one_dlm_ctxt(dlm);
+		spin_unlock(&dlm->spinlock);
+	}
+	spin_unlock(&dlm_domain_lock);
+	return len;
+}
+static int dlm_dump_one_dlm_ctxt(const char __user *data, unsigned int len)
+{
+	struct dlm_ctxt *dlm;
+	char *buf = NULL, *tmp;
+	int ret = -EINVAL;
+
+	mlog(ML_NOTICE, "dumping one dlm context for node %s\n",
+		system_utsname.nodename);
+
+	if (len >= PAGE_SIZE-1) {
+		mlog(ML_ERROR, "user passed too much data: %d bytes\n", len);
+		goto leave;
+	}
+	if (len < 4) {
+		mlog(ML_ERROR, "user passed too little data: %d bytes\n", len);
+		goto leave;
+	}
+	buf = kmalloc(len+1, GFP_NOFS);
+	if (!buf) {
+		mlog(ML_ERROR, "could not alloc %d bytes\n", len+1);
+		ret = -ENOMEM;
+		goto leave;
+	}
+	if (strncpy_from_user(buf, data, len) < len) {
+		mlog(ML_ERROR, "failed to get all user data\n");
+		goto leave;
+	}
+	buf[len] = '\0';
+	mlog(0, "got this data from user: %s\n", buf);
+
+	tmp = buf+1;
+	if (*tmp != ' ') {
+		mlog(ML_ERROR, "bad data\n");
+		goto leave;
+	}
+	tmp ++;
+
+	while (*tmp != '\0') {
+		if (*tmp == '\n' || *tmp == '\r') {
+			*tmp = '\0';
+			break;
+		}
+		tmp ++;
+	}
 
+	spin_lock(&dlm_domain_lock);
+	dlm = __dlm_lookup_domain(buf+2);
+	spin_unlock(&dlm_domain_lock);
+	if (dlm) {
+		if (!dlm_grab(dlm)) {
+			mlog(ML_ERROR, "bad dlm!\n");
+			goto leave;
+		}
+		spin_lock(&dlm_domain_lock);
+		spin_lock(&dlm->spinlock);
+		__dlm_print_one_dlm_ctxt(dlm);
+		spin_unlock(&dlm->spinlock);
+		spin_unlock(&dlm_domain_lock);
+		dlm_put(dlm);
+	} else {
+		mlog(ML_ERROR, "no such dlm: %s(%lu)\n", buf+2, strlen(buf+2));
+		goto leave;
+	}
+	ret = len;
+leave:
+	if (buf)
+		kfree(buf);
+	return ret;
+}
 static int dlm_dump_one_lock_resource(const char __user *data,
 				       unsigned int len)
 {

^ permalink raw reply	[flat|nested] 5+ messages in thread

* [Ocfs2-devel] [PATCH 1/1] ocfs2: add dlm context printing in dlm debug
  2008-01-08 21:38 [Ocfs2-devel] [PATCH 1/1] ocfs2: add dlm context printing in dlm debug wengang wang
@ 2008-01-08 21:47 ` wengang wang
  2008-01-09 11:15 ` Mark Fasheh
  2008-01-15 10:22 ` Sunil Mushran
  2 siblings, 0 replies; 5+ messages in thread
From: wengang wang @ 2008-01-08 21:47 UTC (permalink / raw)
  To: ocfs2-devel

the patch is based on 1.2.3

thanks,
wengang.

wengang wang wrote:
> add dlm context printing support in dlm debugging
>
> - echo 'd' >/proc/fs/ocfs2_dlm/debug prints all dlm contexts.
> - echo 'D UUID' >/proc/fs/ocfs2_dlm/debug prints the context of the 
> specified dlm
>
> Signed-off-by: wengang wang <wen.gang.wang@oracle.com>
> Singed-off-by: Tao Ma <tao.ma@oracle.com>
> ---
> dlmdebug.c |  104 
> +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
> 1 file changed, 104 insertions(+)
>
> --- ./fs/ocfs2/dlm/dlmdebug.c.orig    2008-01-09 06:39:18.000000000 -0500
> +++ ./fs/ocfs2/dlm/dlmdebug.c    2008-01-10 03:17:13.000000000 -0500
> @@ -61,6 +61,10 @@
> static int dlm_proc_stats(char *page, char **start, off_t off,
>               int count, int *eof, void *data);
>
> +static void __dlm_print_one_dlm_ctxt(struct dlm_ctxt *dlm);
> +static int dlm_dump_one_dlm_ctxt(const char __user *buf, unsigned int 
> count);
> +static int dlm_dump_all_dlm_ctxts(const char __user *buf, unsigned 
> int count);
> +
> typedef int (dlm_debug_func_t)(const char __user *data, unsigned int 
> len);
>
> struct dlm_debug_funcs
> @@ -75,6 +79,8 @@
>     { 'm', dlm_dump_all_mles },
>     { 'p', dlm_dump_all_purge_lists  },
>     { 'M', dlm_trigger_migration },
> +    { 'd', dlm_dump_all_dlm_ctxts },
> +    { 'D', dlm_dump_one_dlm_ctxt },
> };
> static int dlm_debug_map_sz = (sizeof(dlm_debug_map) /
>                    sizeof(struct dlm_debug_funcs));
> @@ -210,7 +216,105 @@
>     spin_unlock(&dlm_domain_lock);
>     return len;
> }
> +static void __dlm_print_one_dlm_ctxt(struct dlm_ctxt *dlm)
> +{
> +    mlog(ML_NOTICE, "purge_count: %d, name: %s\n",
> +        dlm->purge_count, dlm->name);
> +    mlog(ML_NOTICE, "node_num: %u, key: %u\n",
> +        dlm->node_num, dlm->key);
> +    mlog(ML_NOTICE, "joining_node: %u, reco->new_master: %u\n",
> +        dlm->joining_node, dlm->reco.new_master);
> +    mlog(ML_NOTICE, "reco->dead_node: %u, reco->state: %u\n",
> +        dlm->reco.dead_node, dlm->reco.state);
> +    mlog(ML_NOTICE, "dlm_state: %d, num_joins: %d\n",
> +        dlm->dlm_state, dlm->num_joins);
> +}
> +static int dlm_dump_all_dlm_ctxts(const char __user *data, unsigned 
> int len)
> +{
> +    struct dlm_ctxt *dlm;
> +    struct list_head *iter;
> +
> +    mlog(ML_NOTICE, "dumping ALL dlm contexts for node %s\n",
> +        system_utsname.nodename);
> +    spin_lock(&dlm_domain_lock);
> +    list_for_each(iter, &dlm_domains) {
> +        dlm = list_entry (iter, struct dlm_ctxt, list);
> +        spin_lock(&dlm->spinlock);
> +        __dlm_print_one_dlm_ctxt(dlm);
> +        spin_unlock(&dlm->spinlock);
> +    }
> +    spin_unlock(&dlm_domain_lock);
> +    return len;
> +}
> +static int dlm_dump_one_dlm_ctxt(const char __user *data, unsigned 
> int len)
> +{
> +    struct dlm_ctxt *dlm;
> +    char *buf = NULL, *tmp;
> +    int ret = -EINVAL;
> +
> +    mlog(ML_NOTICE, "dumping one dlm context for node %s\n",
> +        system_utsname.nodename);
> +
> +    if (len >= PAGE_SIZE-1) {
> +        mlog(ML_ERROR, "user passed too much data: %d bytes\n", len);
> +        goto leave;
> +    }
> +    if (len < 4) {
> +        mlog(ML_ERROR, "user passed too little data: %d bytes\n", len);
> +        goto leave;
> +    }
> +    buf = kmalloc(len+1, GFP_NOFS);
> +    if (!buf) {
> +        mlog(ML_ERROR, "could not alloc %d bytes\n", len+1);
> +        ret = -ENOMEM;
> +        goto leave;
> +    }
> +    if (strncpy_from_user(buf, data, len) < len) {
> +        mlog(ML_ERROR, "failed to get all user data\n");
> +        goto leave;
> +    }
> +    buf[len] = '\0';
> +    mlog(0, "got this data from user: %s\n", buf);
> +
> +    tmp = buf+1;
> +    if (*tmp != ' ') {
> +        mlog(ML_ERROR, "bad data\n");
> +        goto leave;
> +    }
> +    tmp ++;
> +
> +    while (*tmp != '\0') {
> +        if (*tmp == '\n' || *tmp == '\r') {
> +            *tmp = '\0';
> +            break;
> +        }
> +        tmp ++;
> +    }
>
> +    spin_lock(&dlm_domain_lock);
> +    dlm = __dlm_lookup_domain(buf+2);
> +    spin_unlock(&dlm_domain_lock);
> +    if (dlm) {
> +        if (!dlm_grab(dlm)) {
> +            mlog(ML_ERROR, "bad dlm!\n");
> +            goto leave;
> +        }
> +        spin_lock(&dlm_domain_lock);
> +        spin_lock(&dlm->spinlock);
> +        __dlm_print_one_dlm_ctxt(dlm);
> +        spin_unlock(&dlm->spinlock);
> +        spin_unlock(&dlm_domain_lock);
> +        dlm_put(dlm);
> +    } else {
> +        mlog(ML_ERROR, "no such dlm: %s(%lu)\n", buf+2, strlen(buf+2));
> +        goto leave;
> +    }
> +    ret = len;
> +leave:
> +    if (buf)
> +        kfree(buf);
> +    return ret;
> +}
> static int dlm_dump_one_lock_resource(const char __user *data,
>                        unsigned int len)
> {
>
>
> _______________________________________________
> Ocfs2-devel mailing list
> Ocfs2-devel@oss.oracle.com
> http://oss.oracle.com/mailman/listinfo/ocfs2-devel

-- 
Wengang Wang
Member of Technical Staff
Oracle Asia R&D Center
Open Source Technologies Development

Tel:      +86 10 8278 6265
Mobile:   +86 13381078925

^ permalink raw reply	[flat|nested] 5+ messages in thread

* [Ocfs2-devel] [PATCH 1/1] ocfs2: add dlm context printing in dlm debug
  2008-01-08 21:38 [Ocfs2-devel] [PATCH 1/1] ocfs2: add dlm context printing in dlm debug wengang wang
  2008-01-08 21:47 ` wengang wang
@ 2008-01-09 11:15 ` Mark Fasheh
  2008-01-15 10:22 ` Sunil Mushran
  2 siblings, 0 replies; 5+ messages in thread
From: Mark Fasheh @ 2008-01-09 11:15 UTC (permalink / raw)
  To: ocfs2-devel

On Sun, Jan 06, 2008 at 01:34:40PM +0800, wengang wang wrote:
> add dlm context printing support in dlm debugging

Great, I like that you've added the ability for us to show these.


> - echo 'd' >/proc/fs/ocfs2_dlm/debug prints all dlm contexts.
> - echo 'D UUID' >/proc/fs/ocfs2_dlm/debug prints the context of the 
> specified dlm

We took out all the /proc/ code in the mainline Ocfs2 code. This patch would
be fine for 1.2 though and we can work out what to do in mainline/1.4 later.
	--Mark

--
Mark Fasheh
Principal Software Developer, Oracle
mark.fasheh@oracle.com

^ permalink raw reply	[flat|nested] 5+ messages in thread

* [Ocfs2-devel] [PATCH 1/1] ocfs2: add dlm context printing in dlm debug
  2008-01-08 21:38 [Ocfs2-devel] [PATCH 1/1] ocfs2: add dlm context printing in dlm debug wengang wang
  2008-01-08 21:47 ` wengang wang
  2008-01-09 11:15 ` Mark Fasheh
@ 2008-01-15 10:22 ` Sunil Mushran
  2008-01-15 18:05   ` wengang wang
  2 siblings, 1 reply; 5+ messages in thread
From: Sunil Mushran @ 2008-01-15 10:22 UTC (permalink / raw)
  To: ocfs2-devel

Can you rework this so that it outputs in /proc/fs/ocfs2_dlm/<domain>/ctxt.
Look at /proc/fs/ocfs2_dlm/.../stat.

As in, dmesg is very clunky for this. Make the patch against ocfs2-1.2 
svn head.

Thanks
Sunil

wengang wang wrote:
> add dlm context printing support in dlm debugging
>
> - echo 'd' >/proc/fs/ocfs2_dlm/debug prints all dlm contexts.
> - echo 'D UUID' >/proc/fs/ocfs2_dlm/debug prints the context of the 
> specified dlm
>
> Signed-off-by: wengang wang <wen.gang.wang@oracle.com>
> Singed-off-by: Tao Ma <tao.ma@oracle.com>
> ---
> dlmdebug.c |  104 
> +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
> 1 file changed, 104 insertions(+)
>
> --- ./fs/ocfs2/dlm/dlmdebug.c.orig    2008-01-09 06:39:18.000000000 -0500
> +++ ./fs/ocfs2/dlm/dlmdebug.c    2008-01-10 03:17:13.000000000 -0500
> @@ -61,6 +61,10 @@
> static int dlm_proc_stats(char *page, char **start, off_t off,
>               int count, int *eof, void *data);
>
> +static void __dlm_print_one_dlm_ctxt(struct dlm_ctxt *dlm);
> +static int dlm_dump_one_dlm_ctxt(const char __user *buf, unsigned int 
> count);
> +static int dlm_dump_all_dlm_ctxts(const char __user *buf, unsigned 
> int count);
> +
> typedef int (dlm_debug_func_t)(const char __user *data, unsigned int 
> len);
>
> struct dlm_debug_funcs
> @@ -75,6 +79,8 @@
>     { 'm', dlm_dump_all_mles },
>     { 'p', dlm_dump_all_purge_lists  },
>     { 'M', dlm_trigger_migration },
> +    { 'd', dlm_dump_all_dlm_ctxts },
> +    { 'D', dlm_dump_one_dlm_ctxt },
> };
> static int dlm_debug_map_sz = (sizeof(dlm_debug_map) /
>                    sizeof(struct dlm_debug_funcs));
> @@ -210,7 +216,105 @@
>     spin_unlock(&dlm_domain_lock);
>     return len;
> }
> +static void __dlm_print_one_dlm_ctxt(struct dlm_ctxt *dlm)
> +{
> +    mlog(ML_NOTICE, "purge_count: %d, name: %s\n",
> +        dlm->purge_count, dlm->name);
> +    mlog(ML_NOTICE, "node_num: %u, key: %u\n",
> +        dlm->node_num, dlm->key);
> +    mlog(ML_NOTICE, "joining_node: %u, reco->new_master: %u\n",
> +        dlm->joining_node, dlm->reco.new_master);
> +    mlog(ML_NOTICE, "reco->dead_node: %u, reco->state: %u\n",
> +        dlm->reco.dead_node, dlm->reco.state);
> +    mlog(ML_NOTICE, "dlm_state: %d, num_joins: %d\n",
> +        dlm->dlm_state, dlm->num_joins);
> +}
> +static int dlm_dump_all_dlm_ctxts(const char __user *data, unsigned 
> int len)
> +{
> +    struct dlm_ctxt *dlm;
> +    struct list_head *iter;
> +
> +    mlog(ML_NOTICE, "dumping ALL dlm contexts for node %s\n",
> +        system_utsname.nodename);
> +    spin_lock(&dlm_domain_lock);
> +    list_for_each(iter, &dlm_domains) {
> +        dlm = list_entry (iter, struct dlm_ctxt, list);
> +        spin_lock(&dlm->spinlock);
> +        __dlm_print_one_dlm_ctxt(dlm);
> +        spin_unlock(&dlm->spinlock);
> +    }
> +    spin_unlock(&dlm_domain_lock);
> +    return len;
> +}
> +static int dlm_dump_one_dlm_ctxt(const char __user *data, unsigned 
> int len)
> +{
> +    struct dlm_ctxt *dlm;
> +    char *buf = NULL, *tmp;
> +    int ret = -EINVAL;
> +
> +    mlog(ML_NOTICE, "dumping one dlm context for node %s\n",
> +        system_utsname.nodename);
> +
> +    if (len >= PAGE_SIZE-1) {
> +        mlog(ML_ERROR, "user passed too much data: %d bytes\n", len);
> +        goto leave;
> +    }
> +    if (len < 4) {
> +        mlog(ML_ERROR, "user passed too little data: %d bytes\n", len);
> +        goto leave;
> +    }
> +    buf = kmalloc(len+1, GFP_NOFS);
> +    if (!buf) {
> +        mlog(ML_ERROR, "could not alloc %d bytes\n", len+1);
> +        ret = -ENOMEM;
> +        goto leave;
> +    }
> +    if (strncpy_from_user(buf, data, len) < len) {
> +        mlog(ML_ERROR, "failed to get all user data\n");
> +        goto leave;
> +    }
> +    buf[len] = '\0';
> +    mlog(0, "got this data from user: %s\n", buf);
> +
> +    tmp = buf+1;
> +    if (*tmp != ' ') {
> +        mlog(ML_ERROR, "bad data\n");
> +        goto leave;
> +    }
> +    tmp ++;
> +
> +    while (*tmp != '\0') {
> +        if (*tmp == '\n' || *tmp == '\r') {
> +            *tmp = '\0';
> +            break;
> +        }
> +        tmp ++;
> +    }
>
> +    spin_lock(&dlm_domain_lock);
> +    dlm = __dlm_lookup_domain(buf+2);
> +    spin_unlock(&dlm_domain_lock);
> +    if (dlm) {
> +        if (!dlm_grab(dlm)) {
> +            mlog(ML_ERROR, "bad dlm!\n");
> +            goto leave;
> +        }
> +        spin_lock(&dlm_domain_lock);
> +        spin_lock(&dlm->spinlock);
> +        __dlm_print_one_dlm_ctxt(dlm);
> +        spin_unlock(&dlm->spinlock);
> +        spin_unlock(&dlm_domain_lock);
> +        dlm_put(dlm);
> +    } else {
> +        mlog(ML_ERROR, "no such dlm: %s(%lu)\n", buf+2, strlen(buf+2));
> +        goto leave;
> +    }
> +    ret = len;
> +leave:
> +    if (buf)
> +        kfree(buf);
> +    return ret;
> +}
> static int dlm_dump_one_lock_resource(const char __user *data,
>                        unsigned int len)
> {
>
>
> _______________________________________________
> Ocfs2-devel mailing list
> Ocfs2-devel@oss.oracle.com
> http://oss.oracle.com/mailman/listinfo/ocfs2-devel

^ permalink raw reply	[flat|nested] 5+ messages in thread

* [Ocfs2-devel] [PATCH 1/1] ocfs2: add dlm context printing in dlm debug
  2008-01-15 10:22 ` Sunil Mushran
@ 2008-01-15 18:05   ` wengang wang
  0 siblings, 0 replies; 5+ messages in thread
From: wengang wang @ 2008-01-15 18:05 UTC (permalink / raw)
  To: ocfs2-devel

sure, will do it.

thanks,
wengang.

Sunil Mushran wrote:
> Can you rework this so that it outputs in 
> /proc/fs/ocfs2_dlm/<domain>/ctxt.
> Look at /proc/fs/ocfs2_dlm/.../stat.
>
> As in, dmesg is very clunky for this. Make the patch against ocfs2-1.2 
> svn head.
>
> Thanks
> Sunil
>
> wengang wang wrote:
>> add dlm context printing support in dlm debugging
>>
>> - echo 'd' >/proc/fs/ocfs2_dlm/debug prints all dlm contexts.
>> - echo 'D UUID' >/proc/fs/ocfs2_dlm/debug prints the context of the 
>> specified dlm
>>
>> Signed-off-by: wengang wang <wen.gang.wang@oracle.com>
>> Singed-off-by: Tao Ma <tao.ma@oracle.com>
>> ---
>> dlmdebug.c |  104 
>> +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
>> 1 file changed, 104 insertions(+)
>>
>> --- ./fs/ocfs2/dlm/dlmdebug.c.orig    2008-01-09 06:39:18.000000000 
>> -0500
>> +++ ./fs/ocfs2/dlm/dlmdebug.c    2008-01-10 03:17:13.000000000 -0500
>> @@ -61,6 +61,10 @@
>> static int dlm_proc_stats(char *page, char **start, off_t off,
>>               int count, int *eof, void *data);
>>
>> +static void __dlm_print_one_dlm_ctxt(struct dlm_ctxt *dlm);
>> +static int dlm_dump_one_dlm_ctxt(const char __user *buf, unsigned 
>> int count);
>> +static int dlm_dump_all_dlm_ctxts(const char __user *buf, unsigned 
>> int count);
>> +
>> typedef int (dlm_debug_func_t)(const char __user *data, unsigned int 
>> len);
>>
>> struct dlm_debug_funcs
>> @@ -75,6 +79,8 @@
>>     { 'm', dlm_dump_all_mles },
>>     { 'p', dlm_dump_all_purge_lists  },
>>     { 'M', dlm_trigger_migration },
>> +    { 'd', dlm_dump_all_dlm_ctxts },
>> +    { 'D', dlm_dump_one_dlm_ctxt },
>> };
>> static int dlm_debug_map_sz = (sizeof(dlm_debug_map) /
>>                    sizeof(struct dlm_debug_funcs));
>> @@ -210,7 +216,105 @@
>>     spin_unlock(&dlm_domain_lock);
>>     return len;
>> }
>> +static void __dlm_print_one_dlm_ctxt(struct dlm_ctxt *dlm)
>> +{
>> +    mlog(ML_NOTICE, "purge_count: %d, name: %s\n",
>> +        dlm->purge_count, dlm->name);
>> +    mlog(ML_NOTICE, "node_num: %u, key: %u\n",
>> +        dlm->node_num, dlm->key);
>> +    mlog(ML_NOTICE, "joining_node: %u, reco->new_master: %u\n",
>> +        dlm->joining_node, dlm->reco.new_master);
>> +    mlog(ML_NOTICE, "reco->dead_node: %u, reco->state: %u\n",
>> +        dlm->reco.dead_node, dlm->reco.state);
>> +    mlog(ML_NOTICE, "dlm_state: %d, num_joins: %d\n",
>> +        dlm->dlm_state, dlm->num_joins);
>> +}
>> +static int dlm_dump_all_dlm_ctxts(const char __user *data, unsigned 
>> int len)
>> +{
>> +    struct dlm_ctxt *dlm;
>> +    struct list_head *iter;
>> +
>> +    mlog(ML_NOTICE, "dumping ALL dlm contexts for node %s\n",
>> +        system_utsname.nodename);
>> +    spin_lock(&dlm_domain_lock);
>> +    list_for_each(iter, &dlm_domains) {
>> +        dlm = list_entry (iter, struct dlm_ctxt, list);
>> +        spin_lock(&dlm->spinlock);
>> +        __dlm_print_one_dlm_ctxt(dlm);
>> +        spin_unlock(&dlm->spinlock);
>> +    }
>> +    spin_unlock(&dlm_domain_lock);
>> +    return len;
>> +}
>> +static int dlm_dump_one_dlm_ctxt(const char __user *data, unsigned 
>> int len)
>> +{
>> +    struct dlm_ctxt *dlm;
>> +    char *buf = NULL, *tmp;
>> +    int ret = -EINVAL;
>> +
>> +    mlog(ML_NOTICE, "dumping one dlm context for node %s\n",
>> +        system_utsname.nodename);
>> +
>> +    if (len >= PAGE_SIZE-1) {
>> +        mlog(ML_ERROR, "user passed too much data: %d bytes\n", len);
>> +        goto leave;
>> +    }
>> +    if (len < 4) {
>> +        mlog(ML_ERROR, "user passed too little data: %d bytes\n", len);
>> +        goto leave;
>> +    }
>> +    buf = kmalloc(len+1, GFP_NOFS);
>> +    if (!buf) {
>> +        mlog(ML_ERROR, "could not alloc %d bytes\n", len+1);
>> +        ret = -ENOMEM;
>> +        goto leave;
>> +    }
>> +    if (strncpy_from_user(buf, data, len) < len) {
>> +        mlog(ML_ERROR, "failed to get all user data\n");
>> +        goto leave;
>> +    }
>> +    buf[len] = '\0';
>> +    mlog(0, "got this data from user: %s\n", buf);
>> +
>> +    tmp = buf+1;
>> +    if (*tmp != ' ') {
>> +        mlog(ML_ERROR, "bad data\n");
>> +        goto leave;
>> +    }
>> +    tmp ++;
>> +
>> +    while (*tmp != '\0') {
>> +        if (*tmp == '\n' || *tmp == '\r') {
>> +            *tmp = '\0';
>> +            break;
>> +        }
>> +        tmp ++;
>> +    }
>>
>> +    spin_lock(&dlm_domain_lock);
>> +    dlm = __dlm_lookup_domain(buf+2);
>> +    spin_unlock(&dlm_domain_lock);
>> +    if (dlm) {
>> +        if (!dlm_grab(dlm)) {
>> +            mlog(ML_ERROR, "bad dlm!\n");
>> +            goto leave;
>> +        }
>> +        spin_lock(&dlm_domain_lock);
>> +        spin_lock(&dlm->spinlock);
>> +        __dlm_print_one_dlm_ctxt(dlm);
>> +        spin_unlock(&dlm->spinlock);
>> +        spin_unlock(&dlm_domain_lock);
>> +        dlm_put(dlm);
>> +    } else {
>> +        mlog(ML_ERROR, "no such dlm: %s(%lu)\n", buf+2, strlen(buf+2));
>> +        goto leave;
>> +    }
>> +    ret = len;
>> +leave:
>> +    if (buf)
>> +        kfree(buf);
>> +    return ret;
>> +}
>> static int dlm_dump_one_lock_resource(const char __user *data,
>>                        unsigned int len)
>> {
>>
>>
>> _______________________________________________
>> Ocfs2-devel mailing list
>> Ocfs2-devel@oss.oracle.com
>> http://oss.oracle.com/mailman/listinfo/ocfs2-devel
>

-- 
Wengang Wang
Member of Technical Staff
Oracle Asia R&D Center
Open Source Technologies Development

Tel:      +86 10 8278 6265
Mobile:   +86 13381078925

^ permalink raw reply	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2008-01-15 18:05 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2008-01-08 21:38 [Ocfs2-devel] [PATCH 1/1] ocfs2: add dlm context printing in dlm debug wengang wang
2008-01-08 21:47 ` wengang wang
2008-01-09 11:15 ` Mark Fasheh
2008-01-15 10:22 ` Sunil Mushran
2008-01-15 18:05   ` wengang wang

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.