diff options
Diffstat (limited to 'include/linux/pagemap.h')
| -rw-r--r-- | include/linux/pagemap.h | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/include/linux/pagemap.h b/include/linux/pagemap.h index 0a2f5d27f60e..64f950925151 100644 --- a/include/linux/pagemap.h +++ b/include/linux/pagemap.h | |||
| @@ -130,14 +130,29 @@ static inline pgoff_t linear_page_index(struct vm_area_struct *vma, | |||
| 130 | } | 130 | } |
| 131 | 131 | ||
| 132 | extern void FASTCALL(__lock_page(struct page *page)); | 132 | extern void FASTCALL(__lock_page(struct page *page)); |
| 133 | extern void FASTCALL(__lock_page_nosync(struct page *page)); | ||
| 133 | extern void FASTCALL(unlock_page(struct page *page)); | 134 | extern void FASTCALL(unlock_page(struct page *page)); |
| 134 | 135 | ||
| 136 | /* | ||
| 137 | * lock_page may only be called if we have the page's inode pinned. | ||
| 138 | */ | ||
| 135 | static inline void lock_page(struct page *page) | 139 | static inline void lock_page(struct page *page) |
| 136 | { | 140 | { |
| 137 | might_sleep(); | 141 | might_sleep(); |
| 138 | if (TestSetPageLocked(page)) | 142 | if (TestSetPageLocked(page)) |
| 139 | __lock_page(page); | 143 | __lock_page(page); |
| 140 | } | 144 | } |
| 145 | |||
| 146 | /* | ||
| 147 | * lock_page_nosync should only be used if we can't pin the page's inode. | ||
| 148 | * Doesn't play quite so well with block device plugging. | ||
| 149 | */ | ||
| 150 | static inline void lock_page_nosync(struct page *page) | ||
| 151 | { | ||
| 152 | might_sleep(); | ||
| 153 | if (TestSetPageLocked(page)) | ||
| 154 | __lock_page_nosync(page); | ||
| 155 | } | ||
| 141 | 156 | ||
| 142 | /* | 157 | /* |
| 143 | * This is exported only for wait_on_page_locked/wait_on_page_writeback. | 158 | * This is exported only for wait_on_page_locked/wait_on_page_writeback. |
