diff options
| author | Jiri Slaby <jirislaby@gmail.com> | 2009-08-22 20:24:49 +0200 | 
|---|---|---|
| committer | Greg Kroah-Hartman <gregkh@suse.de> | 2009-09-23 06:46:37 -0700 | 
| commit | 2912282c06f219cf1634a624653c445329b37acf (patch) | |
| tree | 43e2550ad8f4c1ec75dbdfe407c802f2148db67c /drivers/usb/core/usb.c | |
| parent | a448c9d8c58ff7d3f8cc2a8f835065460099b22d (diff) | |
| download | olio-linux-3.10-2912282c06f219cf1634a624653c445329b37acf.tar.xz olio-linux-3.10-2912282c06f219cf1634a624653c445329b37acf.zip  | |
USB: make usb_buffer_map_sg consistent with doc
usb_buffer_map_sg should return negative on error according to
its documentation. But dma_map_sg returns 0 on error. Take this
into account and return -ENOMEM in such situation.
While at it, return -EINVAL instead of -1 when wrong input is
passed in.
If this wasn't done, usb_sg_* operations used after usb_sg_init
which returned 0 may cause oopses/deadlocks since we don't init
structures/entries, esp. completion and status entry.
Signed-off-by: Jiri Slaby <jirislaby@gmail.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Diffstat (limited to 'drivers/usb/core/usb.c')
| -rw-r--r-- | drivers/usb/core/usb.c | 4 | 
1 files changed, 2 insertions, 2 deletions
diff --git a/drivers/usb/core/usb.c b/drivers/usb/core/usb.c index 43ee943d757..30dd2636f26 100644 --- a/drivers/usb/core/usb.c +++ b/drivers/usb/core/usb.c @@ -914,11 +914,11 @@ int usb_buffer_map_sg(const struct usb_device *dev, int is_in,  			|| !(bus = dev->bus)  			|| !(controller = bus->controller)  			|| !controller->dma_mask) -		return -1; +		return -EINVAL;  	/* FIXME generic api broken like pci, can't report errors */  	return dma_map_sg(controller, sg, nents, -			is_in ? DMA_FROM_DEVICE : DMA_TO_DEVICE); +			is_in ? DMA_FROM_DEVICE : DMA_TO_DEVICE) ? : -ENOMEM;  }  EXPORT_SYMBOL_GPL(usb_buffer_map_sg);  |