[dahdi-commits] tzafrir: linux/trunk r9626 - /linux/trunk/drivers/dahdi/dahdi-base.c
SVN commits to the DAHDI project
dahdi-commits at lists.digium.com
Mon Jan 10 15:42:54 CST 2011
Author: tzafrir
Date: Mon Jan 10 15:42:49 2011
New Revision: 9626
URL: http://svnview.digium.com/svn/dahdi?view=rev&rev=9626
Log:
cleaner error handling in dahdi_register
* Better error handling in dahdi_register.
* Fail registration if fails creating proc entry for span.
Signed-off-by: Tzafrir Cohen <tzafrir.cohen at xorcom.com>
Acked-by: Shaun Ruffell <sruffell at digium.com>
Modified:
linux/trunk/drivers/dahdi/dahdi-base.c
Modified: linux/trunk/drivers/dahdi/dahdi-base.c
URL: http://svnview.digium.com/svn/dahdi/linux/trunk/drivers/dahdi/dahdi-base.c?view=diff&rev=9626&r1=9625&r2=9626
==============================================================================
--- linux/trunk/drivers/dahdi/dahdi-base.c (original)
+++ linux/trunk/drivers/dahdi/dahdi-base.c Mon Jan 10 15:42:49 2011
@@ -6481,6 +6481,8 @@
NULL, chan_name);
if (IS_ERR(dummy)) {
res = PTR_ERR(dummy);
+ chan_err(chan, "Failed creating sysfs device: %d\n",
+ res);
goto cleanup;
}
@@ -6606,10 +6608,17 @@
span->proc_entry = create_proc_read_entry(tempfile, 0444,
root_proc_entry, dahdi_proc_read,
(int *) (long) span->spanno);
+ if (!span->proc_entry) {
+ res = -EFAULT;
+ span_err(span, "Error creating procfs entry\n");
+ goto cleanup;
+ }
}
#endif
res = span_sysfs_create(span);
+ if (res)
+ goto cleanup;
if (debug & DEBUG_MAIN) {
module_printk(KERN_NOTICE, "Registered Span %d ('%s') with "
@@ -6626,6 +6635,23 @@
__dahdi_find_master_span();
return 0;
+
+cleanup:
+#ifdef CONFIG_PROC_FS
+ if (span->proc_entry) {
+ char tempfile[17];
+
+ snprintf(tempfile, sizeof(tempfile), "dahdi/%d", span->spanno);
+ remove_proc_entry(tempfile, NULL);
+ span->proc_entry = NULL;
+ }
+#endif
+ for (x = 0; x < span->channels; x++) {
+ struct dahdi_chan *chan = span->chans[x];
+ if (test_bit(DAHDI_FLAGBIT_REGISTERED, &chan->flags))
+ dahdi_chan_unreg(chan);
+ }
+ return res;
}
/**
More information about the dahdi-commits
mailing list