summaryrefslogtreecommitdiffstats
path: root/include/linux/pagemap.h
diff options
context:
space:
mode:
authorMatthew Wilcox <matthew@wil.cx>2007-12-06 11:18:49 -0500
committerMatthew Wilcox <willy@linux.intel.com>2007-12-06 17:35:41 -0500
commit2687a3569e40b1302f96698bcd6329aeb0ce3dd2 (patch)
tree7bb5e1ffd807ef94b145f6829bf4326a98b8fd99 /include/linux/pagemap.h
parentf776d12dd16da1b0cd55a1240002c1b31f315d5d (diff)
downloadlinux-2687a3569e40b1302f96698bcd6329aeb0ce3dd2.tar.gz
linux-2687a3569e40b1302f96698bcd6329aeb0ce3dd2.tar.bz2
linux-2687a3569e40b1302f96698bcd6329aeb0ce3dd2.zip
Add lock_page_killable
This routine is like lock_page, but can be interrupted by a fatal signal Signed-off-by: Matthew Wilcox <willy@linux.intel.com>
Diffstat (limited to 'include/linux/pagemap.h')
-rw-r--r--include/linux/pagemap.h14
1 files changed, 14 insertions, 0 deletions
diff --git a/include/linux/pagemap.h b/include/linux/pagemap.h
index db8a410ae9e1..4b62a105622b 100644
--- a/include/linux/pagemap.h
+++ b/include/linux/pagemap.h
@@ -157,6 +157,7 @@ static inline pgoff_t linear_page_index(struct vm_area_struct *vma,
}
extern void FASTCALL(__lock_page(struct page *page));
+extern int FASTCALL(__lock_page_killable(struct page *page));
extern void FASTCALL(__lock_page_nosync(struct page *page));
extern void FASTCALL(unlock_page(struct page *page));
@@ -171,6 +172,19 @@ static inline void lock_page(struct page *page)
}
/*
+ * lock_page_killable is like lock_page but can be interrupted by fatal
+ * signals. It returns 0 if it locked the page and -EINTR if it was
+ * killed while waiting.
+ */
+static inline int lock_page_killable(struct page *page)
+{
+ might_sleep();
+ if (TestSetPageLocked(page))
+ return __lock_page_killable(page);
+ return 0;
+}
+
+/*
* lock_page_nosync should only be used if we can't pin the page's inode.
* Doesn't play quite so well with block device plugging.
*/