Commit 9ac77ec6 authored by Eli Billauer's avatar Eli Billauer Committed by Greg Kroah-Hartman

staging: xillybus: Improved error handling

xilly_scan_idt() now returns an error status code, rather than being a void
function and hint the status through an entry in a data structure.
Suggested-by: default avatarDan Carpenter <dan.carpenter@oracle.com>
Signed-off-by: default avatarEli Billauer <eli.billauer@gmail.com>
Reviewed-by: default avatarDan Carpenter <dan.carpenter@oracle.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 31ca128d
...@@ -568,8 +568,8 @@ static int xilly_setupchannels(struct xilly_endpoint *ep, ...@@ -568,8 +568,8 @@ static int xilly_setupchannels(struct xilly_endpoint *ep,
return 0; return 0;
} }
static void xilly_scan_idt(struct xilly_endpoint *endpoint, static int xilly_scan_idt(struct xilly_endpoint *endpoint,
struct xilly_idt_handle *idt_handle) struct xilly_idt_handle *idt_handle)
{ {
int count = 0; int count = 0;
unsigned char *idt = endpoint->channels[1]->wr_buffers[0]->addr; unsigned char *idt = endpoint->channels[1]->wr_buffers[0]->addr;
...@@ -593,23 +593,22 @@ static void xilly_scan_idt(struct xilly_endpoint *endpoint, ...@@ -593,23 +593,22 @@ static void xilly_scan_idt(struct xilly_endpoint *endpoint,
if (scan > end_of_idt) { if (scan > end_of_idt) {
dev_err(endpoint->dev, dev_err(endpoint->dev,
"IDT device name list overflow. Aborting.\n"); "IDT device name list overflow. Aborting.\n");
idt_handle->chandesc = NULL; return -ENODEV;
return;
} }
idt_handle->chandesc = scan; idt_handle->chandesc = scan;
len = endpoint->idtlen - (3 + ((int) (scan - idt))); len = endpoint->idtlen - (3 + ((int) (scan - idt)));
if (len & 0x03) { if (len & 0x03) {
idt_handle->chandesc = NULL;
dev_err(endpoint->dev, dev_err(endpoint->dev,
"Corrupt IDT device name list. Aborting.\n"); "Corrupt IDT device name list. Aborting.\n");
return -ENODEV;
} }
idt_handle->entries = len >> 2; idt_handle->entries = len >> 2;
endpoint->num_channels = count; endpoint->num_channels = count;
return 0;
} }
static int xilly_obtain_idt(struct xilly_endpoint *endpoint) static int xilly_obtain_idt(struct xilly_endpoint *endpoint)
...@@ -2041,12 +2040,9 @@ int xillybus_endpoint_discovery(struct xilly_endpoint *endpoint) ...@@ -2041,12 +2040,9 @@ int xillybus_endpoint_discovery(struct xilly_endpoint *endpoint)
if (rc) if (rc)
goto failed_idt; goto failed_idt;
xilly_scan_idt(endpoint, &idt_handle); rc = xilly_scan_idt(endpoint, &idt_handle);
if (rc)
if (!idt_handle.chandesc) {
rc = -ENODEV;
goto failed_idt; goto failed_idt;
}
devres_close_group(dev, bootstrap_resources); devres_close_group(dev, bootstrap_resources);
......
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