diff options
author | Hans Verkuil <hverkuil@xs4all.nl> | 2007-08-19 16:56:41 -0400 |
---|---|---|
committer | Mauro Carvalho Chehab <mchehab@infradead.org> | 2007-10-09 21:05:48 -0400 |
commit | 8beb058f1ecde7bc0554d18ce1baa18b5dfb02d3 (patch) | |
tree | 0ac375d2d009baca2d39ffae97734d04b167872d /drivers/media/video/ivtv/ivtv-udma.c | |
parent | 25e3f8f40ecf61b87a4b6476ea6d00cb5b74628c (diff) |
V4L/DVB (6060): ivtv: fix IVTV_IOC_DMA_FRAME bug introduced by highmem bugfix
The return value of ivtv_udma_fill_sg_list() was changed by the
highmem bugfix, but that return value was still used in ivtv-yuv.c.
Revert to the old return value, but in addition return -1 in case of
a memory allocation error.
Signed-off-by: Hans Verkuil <hverkuil@xs4all.nl>
Signed-off-by: Mauro Carvalho Chehab <mchehab@infradead.org>
Diffstat (limited to 'drivers/media/video/ivtv/ivtv-udma.c')
-rw-r--r-- | drivers/media/video/ivtv/ivtv-udma.c | 12 |
1 files changed, 7 insertions, 5 deletions
diff --git a/drivers/media/video/ivtv/ivtv-udma.c b/drivers/media/video/ivtv/ivtv-udma.c index 5592abbe14e6..7e503adacea0 100644 --- a/drivers/media/video/ivtv/ivtv-udma.c +++ b/drivers/media/video/ivtv/ivtv-udma.c | |||
@@ -40,6 +40,9 @@ int ivtv_udma_fill_sg_list (struct ivtv_user_dma *dma, struct ivtv_dma_page_info | |||
40 | int i, offset; | 40 | int i, offset; |
41 | unsigned long flags; | 41 | unsigned long flags; |
42 | 42 | ||
43 | if (map_offset < 0) | ||
44 | return map_offset; | ||
45 | |||
43 | offset = dma_page->offset; | 46 | offset = dma_page->offset; |
44 | 47 | ||
45 | /* Fill SG Array with new values */ | 48 | /* Fill SG Array with new values */ |
@@ -55,7 +58,7 @@ int ivtv_udma_fill_sg_list (struct ivtv_user_dma *dma, struct ivtv_dma_page_info | |||
55 | if (dma->bouncemap[map_offset] == NULL) | 58 | if (dma->bouncemap[map_offset] == NULL) |
56 | dma->bouncemap[map_offset] = alloc_page(GFP_KERNEL); | 59 | dma->bouncemap[map_offset] = alloc_page(GFP_KERNEL); |
57 | if (dma->bouncemap[map_offset] == NULL) | 60 | if (dma->bouncemap[map_offset] == NULL) |
58 | return -ENOMEM; | 61 | return -1; |
59 | local_irq_save(flags); | 62 | local_irq_save(flags); |
60 | src = kmap_atomic(dma->map[map_offset], KM_BOUNCE_READ) + offset; | 63 | src = kmap_atomic(dma->map[map_offset], KM_BOUNCE_READ) + offset; |
61 | memcpy(page_address(dma->bouncemap[map_offset]) + offset, src, len); | 64 | memcpy(page_address(dma->bouncemap[map_offset]) + offset, src, len); |
@@ -69,7 +72,7 @@ int ivtv_udma_fill_sg_list (struct ivtv_user_dma *dma, struct ivtv_dma_page_info | |||
69 | offset = 0; | 72 | offset = 0; |
70 | map_offset++; | 73 | map_offset++; |
71 | } | 74 | } |
72 | return 0; | 75 | return map_offset; |
73 | } | 76 | } |
74 | 77 | ||
75 | void ivtv_udma_fill_sg_array (struct ivtv_user_dma *dma, u32 buffer_offset, u32 buffer_offset_2, u32 split) { | 78 | void ivtv_udma_fill_sg_array (struct ivtv_user_dma *dma, u32 buffer_offset, u32 buffer_offset_2, u32 split) { |
@@ -138,13 +141,12 @@ int ivtv_udma_setup(struct ivtv *itv, unsigned long ivtv_dest_addr, | |||
138 | dma->page_count = user_dma.page_count; | 141 | dma->page_count = user_dma.page_count; |
139 | 142 | ||
140 | /* Fill SG List with new values */ | 143 | /* Fill SG List with new values */ |
141 | err = ivtv_udma_fill_sg_list(dma, &user_dma, 0); | 144 | if (ivtv_udma_fill_sg_list(dma, &user_dma, 0) < 0) { |
142 | if (err) { | ||
143 | for (i = 0; i < dma->page_count; i++) { | 145 | for (i = 0; i < dma->page_count; i++) { |
144 | put_page(dma->map[i]); | 146 | put_page(dma->map[i]); |
145 | } | 147 | } |
146 | dma->page_count = 0; | 148 | dma->page_count = 0; |
147 | return err; | 149 | return -ENOMEM; |
148 | } | 150 | } |
149 | 151 | ||
150 | /* Map SG List */ | 152 | /* Map SG List */ |