diff options
Diffstat (limited to 'include/linux')
| -rw-r--r-- | include/linux/mm.h | 2 | ||||
| -rw-r--r-- | include/linux/pagemap.h | 13 |
2 files changed, 15 insertions, 0 deletions
diff --git a/include/linux/mm.h b/include/linux/mm.h index 2862009f9573..3bf46655b50a 100644 --- a/include/linux/mm.h +++ b/include/linux/mm.h | |||
| @@ -144,6 +144,7 @@ extern pgprot_t protection_map[16]; | |||
| 144 | #define FAULT_FLAG_WRITE 0x01 /* Fault was a write access */ | 144 | #define FAULT_FLAG_WRITE 0x01 /* Fault was a write access */ |
| 145 | #define FAULT_FLAG_NONLINEAR 0x02 /* Fault was via a nonlinear mapping */ | 145 | #define FAULT_FLAG_NONLINEAR 0x02 /* Fault was via a nonlinear mapping */ |
| 146 | #define FAULT_FLAG_MKWRITE 0x04 /* Fault was mkwrite of existing pte */ | 146 | #define FAULT_FLAG_MKWRITE 0x04 /* Fault was mkwrite of existing pte */ |
| 147 | #define FAULT_FLAG_ALLOW_RETRY 0x08 /* Retry fault if blocking */ | ||
| 147 | 148 | ||
| 148 | /* | 149 | /* |
| 149 | * This interface is used by x86 PAT code to identify a pfn mapping that is | 150 | * This interface is used by x86 PAT code to identify a pfn mapping that is |
| @@ -723,6 +724,7 @@ static inline int page_mapped(struct page *page) | |||
| 723 | 724 | ||
| 724 | #define VM_FAULT_NOPAGE 0x0100 /* ->fault installed the pte, not return page */ | 725 | #define VM_FAULT_NOPAGE 0x0100 /* ->fault installed the pte, not return page */ |
| 725 | #define VM_FAULT_LOCKED 0x0200 /* ->fault locked the returned page */ | 726 | #define VM_FAULT_LOCKED 0x0200 /* ->fault locked the returned page */ |
| 727 | #define VM_FAULT_RETRY 0x0400 /* ->fault blocked, must retry */ | ||
| 726 | 728 | ||
| 727 | #define VM_FAULT_HWPOISON_LARGE_MASK 0xf000 /* encodes hpage index for large hwpoison */ | 729 | #define VM_FAULT_HWPOISON_LARGE_MASK 0xf000 /* encodes hpage index for large hwpoison */ |
| 728 | 730 | ||
diff --git a/include/linux/pagemap.h b/include/linux/pagemap.h index e12cdc6d79ee..2d1ffe3cf1ee 100644 --- a/include/linux/pagemap.h +++ b/include/linux/pagemap.h | |||
| @@ -299,6 +299,8 @@ static inline pgoff_t linear_page_index(struct vm_area_struct *vma, | |||
| 299 | extern void __lock_page(struct page *page); | 299 | extern void __lock_page(struct page *page); |
| 300 | extern int __lock_page_killable(struct page *page); | 300 | extern int __lock_page_killable(struct page *page); |
| 301 | extern void __lock_page_nosync(struct page *page); | 301 | extern void __lock_page_nosync(struct page *page); |
| 302 | extern int __lock_page_or_retry(struct page *page, struct mm_struct *mm, | ||
| 303 | unsigned int flags); | ||
| 302 | extern void unlock_page(struct page *page); | 304 | extern void unlock_page(struct page *page); |
| 303 | 305 | ||
| 304 | static inline void __set_page_locked(struct page *page) | 306 | static inline void __set_page_locked(struct page *page) |
| @@ -351,6 +353,17 @@ static inline void lock_page_nosync(struct page *page) | |||
| 351 | } | 353 | } |
| 352 | 354 | ||
| 353 | /* | 355 | /* |
| 356 | * lock_page_or_retry - Lock the page, unless this would block and the | ||
| 357 | * caller indicated that it can handle a retry. | ||
| 358 | */ | ||
| 359 | static inline int lock_page_or_retry(struct page *page, struct mm_struct *mm, | ||
| 360 | unsigned int flags) | ||
| 361 | { | ||
| 362 | might_sleep(); | ||
| 363 | return trylock_page(page) || __lock_page_or_retry(page, mm, flags); | ||
| 364 | } | ||
| 365 | |||
| 366 | /* | ||
| 354 | * This is exported only for wait_on_page_locked/wait_on_page_writeback. | 367 | * This is exported only for wait_on_page_locked/wait_on_page_writeback. |
| 355 | * Never use this directly! | 368 | * Never use this directly! |
| 356 | */ | 369 | */ |
