Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 4741c9fd authored by Andrew Morton's avatar Andrew Morton Committed by Linus Torvalds
Browse files

[PATCH] set_page_dirty() return value fixes



We need set_page_dirty() to return true if it actually transitioned the page
from a clean to dirty state.  This wasn't right in a couple of places.  Do a
kernel-wide audit, fix things up.

This leaves open the possibility of returning a negative errno from
set_page_dirty() sometime in the future.  But we don't do that at present.

Signed-off-by: default avatarAndrew Morton <akpm@osdl.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@osdl.org>
parent fa5a734e
Loading
Loading
Loading
Loading
+1 −1
Original line number Diff line number Diff line
@@ -2944,7 +2944,7 @@ static int cryptocop_ioctl_process(struct inode *inode, struct file *filp, unsig
		int spdl_err;
		/* Mark output pages dirty. */
		spdl_err = set_page_dirty_lock(outpages[i]);
		DEBUG(if (spdl_err)printk("cryptocop_ioctl_process: set_page_dirty_lock returned %d\n", spdl_err));
		DEBUG(if (spdl_err < 0)printk("cryptocop_ioctl_process: set_page_dirty_lock returned %d\n", spdl_err));
	}
	for (i = 0; i < nooutpages; i++){
		put_page(outpages[i]);
+2 −1
Original line number Diff line number Diff line
@@ -186,7 +186,8 @@ static int ramdisk_writepages(struct address_space *mapping,
 */
static int ramdisk_set_page_dirty(struct page *page)
{
	SetPageDirty(page);
	if (!TestSetPageDirty(page))
		return 1;
	return 0;
}

+1 −1
Original line number Diff line number Diff line
@@ -865,8 +865,8 @@ int __set_page_dirty_buffers(struct page *page)
		}
		write_unlock_irq(&mapping->tree_lock);
		__mark_inode_dirty(mapping->host, I_DIRTY_PAGES);
		return 1;
	}
	
	return 0;
}
EXPORT_SYMBOL(__set_page_dirty_buffers);
+1 −1
Original line number Diff line number Diff line
@@ -350,7 +350,7 @@ struct address_space_operations {
	/* Write back some dirty pages from this mapping. */
	int (*writepages)(struct address_space *, struct writeback_control *);

	/* Set a page dirty */
	/* Set a page dirty.  Return true if this dirtied it */
	int (*set_page_dirty)(struct page *page);

	int (*readpages)(struct file *filp, struct address_space *mapping,
+6 −5
Original line number Diff line number Diff line
@@ -628,8 +628,6 @@ EXPORT_SYMBOL(write_one_page);
 */
int __set_page_dirty_nobuffers(struct page *page)
{
	int ret = 0;

	if (!TestSetPageDirty(page)) {
		struct address_space *mapping = page_mapping(page);
		struct address_space *mapping2;
@@ -651,8 +649,9 @@ int __set_page_dirty_nobuffers(struct page *page)
							I_DIRTY_PAGES);
			}
		}
		return 1;
	}
	return ret;
	return 0;
}
EXPORT_SYMBOL(__set_page_dirty_nobuffers);

@@ -682,8 +681,10 @@ int fastcall set_page_dirty(struct page *page)
			return (*spd)(page);
		return __set_page_dirty_buffers(page);
	}
	if (!PageDirty(page))
		SetPageDirty(page);
	if (!PageDirty(page)) {
		if (!TestSetPageDirty(page))
			return 1;
	}
	return 0;
}
EXPORT_SYMBOL(set_page_dirty);