aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/usb
diff options
context:
space:
mode:
authorJiri Slaby <jirislaby@gmail.com>2009-08-22 14:24:49 -0400
committerGreg Kroah-Hartman <gregkh@suse.de>2009-09-23 09:46:37 -0400
commit2912282c06f219cf1634a624653c445329b37acf (patch)
tree43e2550ad8f4c1ec75dbdfe407c802f2148db67c /drivers/usb
parenta448c9d8c58ff7d3f8cc2a8f835065460099b22d (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.c4
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}
923EXPORT_SYMBOL_GPL(usb_buffer_map_sg); 923EXPORT_SYMBOL_GPL(usb_buffer_map_sg);
924 924