diff options
Diffstat (limited to 'drivers/scsi/sg.c')
| -rw-r--r-- | drivers/scsi/sg.c | 17 |
1 files changed, 10 insertions, 7 deletions
diff --git a/drivers/scsi/sg.c b/drivers/scsi/sg.c index 861e51375d70..d86d5c26061d 100644 --- a/drivers/scsi/sg.c +++ b/drivers/scsi/sg.c | |||
| @@ -49,6 +49,7 @@ static int sg_version_num = 30533; /* 2 digits for each component */ | |||
| 49 | #include <linux/seq_file.h> | 49 | #include <linux/seq_file.h> |
| 50 | #include <linux/blkdev.h> | 50 | #include <linux/blkdev.h> |
| 51 | #include <linux/delay.h> | 51 | #include <linux/delay.h> |
| 52 | #include <linux/scatterlist.h> | ||
| 52 | 53 | ||
| 53 | #include "scsi.h" | 54 | #include "scsi.h" |
| 54 | #include <scsi/scsi_dbg.h> | 55 | #include <scsi/scsi_dbg.h> |
| @@ -1886,13 +1887,17 @@ st_unmap_user_pages(struct scatterlist *sgl, const unsigned int nr_pages, | |||
| 1886 | int i; | 1887 | int i; |
| 1887 | 1888 | ||
| 1888 | for (i=0; i < nr_pages; i++) { | 1889 | for (i=0; i < nr_pages; i++) { |
| 1889 | if (dirtied && !PageReserved(sgl[i].page)) | 1890 | struct page *page = sgl[i].page; |
| 1890 | SetPageDirty(sgl[i].page); | 1891 | |
| 1891 | /* unlock_page(sgl[i].page); */ | 1892 | /* XXX: just for debug. Remove when PageReserved is removed */ |
| 1893 | BUG_ON(PageReserved(page)); | ||
| 1894 | if (dirtied) | ||
| 1895 | SetPageDirty(page); | ||
| 1896 | /* unlock_page(page); */ | ||
| 1892 | /* FIXME: cache flush missing for rw==READ | 1897 | /* FIXME: cache flush missing for rw==READ |
| 1893 | * FIXME: call the correct reference counting function | 1898 | * FIXME: call the correct reference counting function |
| 1894 | */ | 1899 | */ |
| 1895 | page_cache_release(sgl[i].page); | 1900 | page_cache_release(page); |
| 1896 | } | 1901 | } |
| 1897 | 1902 | ||
| 1898 | return 0; | 1903 | return 0; |
| @@ -1992,9 +1997,7 @@ sg_build_indirect(Sg_scatter_hold * schp, Sg_fd * sfp, int buff_size) | |||
| 1992 | if (!p) | 1997 | if (!p) |
| 1993 | break; | 1998 | break; |
| 1994 | } | 1999 | } |
| 1995 | sclp->page = virt_to_page(p); | 2000 | sg_set_buf(sclp, p, ret_sz); |
| 1996 | sclp->offset = offset_in_page(p); | ||
| 1997 | sclp->length = ret_sz; | ||
| 1998 | 2001 | ||
| 1999 | SCSI_LOG_TIMEOUT(5, printk("sg_build_build: k=%d, a=0x%p, len=%d\n", | 2002 | SCSI_LOG_TIMEOUT(5, printk("sg_build_build: k=%d, a=0x%p, len=%d\n", |
| 2000 | k, sg_scatg2virt(sclp), ret_sz)); | 2003 | k, sg_scatg2virt(sclp), ret_sz)); |
