aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorHugh Dickins <hugh@veritas.com>2005-12-02 10:59:59 -0500
committerJames Bottomley <jejb@titanic.(none)>2005-12-02 11:24:14 -0500
commit032c09d76cdb448484859cc84dac4bba8f5f8f14 (patch)
treed6dded3df8c7240a17554b25ece04c9c766e21af
parent6bc733e9f71c937f3c64159bf1e569321726a44c (diff)
[SCSI] sg and st unmap_user_pages allow PageReserved
2.6.15-rc1 made sg's st_unmap_user_pages and st's sgl_unmap_user_pages BUG on a PageReserved page. But that's wrong: they could be unmapping the ZERO_PAGE, which is marked PG_reserved; and perhaps others (while get_user_pages is still permitted on VM_PFNMAP areas - that may change). More change is needed here: sg claims to dirty even pages written from, and st claims not to dirty even pages read into; and SetPageDirty is not adequate for this nowadays. Fixes to those follow in a later patch: for the moment just fix the 2.6.15 regression. Signed-off-by: Hugh Dickins <hugh@veritas.com> Acked-by: Nick Piggin <npiggin@suse.de> Signed-off-by: James Bottomley <James.Bottomley@SteelEye.com>
-rw-r--r--drivers/scsi/sg.c2
-rw-r--r--drivers/scsi/st.c2
2 files changed, 0 insertions, 4 deletions
diff --git a/drivers/scsi/sg.c b/drivers/scsi/sg.c
index 72ec59456e69..6de7ff9faf2d 100644
--- a/drivers/scsi/sg.c
+++ b/drivers/scsi/sg.c
@@ -1878,8 +1878,6 @@ st_unmap_user_pages(struct scatterlist *sgl, const unsigned int nr_pages,
1878 for (i=0; i < nr_pages; i++) { 1878 for (i=0; i < nr_pages; i++) {
1879 struct page *page = sgl[i].page; 1879 struct page *page = sgl[i].page;
1880 1880
1881 /* XXX: just for debug. Remove when PageReserved is removed */
1882 BUG_ON(PageReserved(page));
1883 if (dirtied) 1881 if (dirtied)
1884 SetPageDirty(page); 1882 SetPageDirty(page);
1885 /* unlock_page(page); */ 1883 /* unlock_page(page); */
diff --git a/drivers/scsi/st.c b/drivers/scsi/st.c
index b1056d290ae2..7ac6ea141fff 100644
--- a/drivers/scsi/st.c
+++ b/drivers/scsi/st.c
@@ -4525,8 +4525,6 @@ static int sgl_unmap_user_pages(struct scatterlist *sgl, const unsigned int nr_p
4525 for (i=0; i < nr_pages; i++) { 4525 for (i=0; i < nr_pages; i++) {
4526 struct page *page = sgl[i].page; 4526 struct page *page = sgl[i].page;
4527 4527
4528 /* XXX: just for debug. Remove when PageReserved is removed */
4529 BUG_ON(PageReserved(page));
4530 if (dirtied) 4528 if (dirtied)
4531 SetPageDirty(page); 4529 SetPageDirty(page);
4532 /* FIXME: cache flush missing for rw==READ 4530 /* FIXME: cache flush missing for rw==READ