diff options
author | Jiri Slaby <jirislaby@gmail.com> | 2009-08-22 14:24:49 -0400 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@suse.de> | 2009-09-23 09:46:37 -0400 |
commit | 2912282c06f219cf1634a624653c445329b37acf (patch) | |
tree | 43e2550ad8f4c1ec75dbdfe407c802f2148db67c /drivers/usb | |
parent | a448c9d8c58ff7d3f8cc2a8f835065460099b22d (diff) |
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')
-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 43ee943d757a..30dd2636f262 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, | |||
914 | || !(bus = dev->bus) | 914 | || !(bus = dev->bus) |
915 | || !(controller = bus->controller) | 915 | || !(controller = bus->controller) |
916 | || !controller->dma_mask) | 916 | || !controller->dma_mask) |
917 | return -1; | 917 | return -EINVAL; |
918 | 918 | ||
919 | /* FIXME generic api broken like pci, can't report errors */ | 919 | /* FIXME generic api broken like pci, can't report errors */ |
920 | return dma_map_sg(controller, sg, nents, | 920 | return dma_map_sg(controller, sg, nents, |
921 | is_in ? DMA_FROM_DEVICE : DMA_TO_DEVICE); | 921 | is_in ? DMA_FROM_DEVICE : DMA_TO_DEVICE) ? : -ENOMEM; |
922 | } | 922 | } |
923 | EXPORT_SYMBOL_GPL(usb_buffer_map_sg); | 923 | EXPORT_SYMBOL_GPL(usb_buffer_map_sg); |
924 | 924 | ||