diff options
Diffstat (limited to 'mm/filemap.c')
| -rw-r--r-- | mm/filemap.c | 15 |
1 files changed, 8 insertions, 7 deletions
diff --git a/mm/filemap.c b/mm/filemap.c index 876bc595d0f8..494ff20b6cfa 100644 --- a/mm/filemap.c +++ b/mm/filemap.c | |||
| @@ -1100,8 +1100,9 @@ page_ok: | |||
| 1100 | 1100 | ||
| 1101 | page_not_up_to_date: | 1101 | page_not_up_to_date: |
| 1102 | /* Get exclusive access to the page ... */ | 1102 | /* Get exclusive access to the page ... */ |
| 1103 | if (lock_page_killable(page)) | 1103 | error = lock_page_killable(page); |
| 1104 | goto readpage_eio; | 1104 | if (unlikely(error)) |
| 1105 | goto readpage_error; | ||
| 1105 | 1106 | ||
| 1106 | page_not_up_to_date_locked: | 1107 | page_not_up_to_date_locked: |
| 1107 | /* Did it get truncated before we got the lock? */ | 1108 | /* Did it get truncated before we got the lock? */ |
| @@ -1130,8 +1131,9 @@ readpage: | |||
| 1130 | } | 1131 | } |
| 1131 | 1132 | ||
| 1132 | if (!PageUptodate(page)) { | 1133 | if (!PageUptodate(page)) { |
| 1133 | if (lock_page_killable(page)) | 1134 | error = lock_page_killable(page); |
| 1134 | goto readpage_eio; | 1135 | if (unlikely(error)) |
| 1136 | goto readpage_error; | ||
| 1135 | if (!PageUptodate(page)) { | 1137 | if (!PageUptodate(page)) { |
| 1136 | if (page->mapping == NULL) { | 1138 | if (page->mapping == NULL) { |
| 1137 | /* | 1139 | /* |
| @@ -1143,15 +1145,14 @@ readpage: | |||
| 1143 | } | 1145 | } |
| 1144 | unlock_page(page); | 1146 | unlock_page(page); |
| 1145 | shrink_readahead_size_eio(filp, ra); | 1147 | shrink_readahead_size_eio(filp, ra); |
| 1146 | goto readpage_eio; | 1148 | error = -EIO; |
| 1149 | goto readpage_error; | ||
| 1147 | } | 1150 | } |
| 1148 | unlock_page(page); | 1151 | unlock_page(page); |
| 1149 | } | 1152 | } |
| 1150 | 1153 | ||
| 1151 | goto page_ok; | 1154 | goto page_ok; |
| 1152 | 1155 | ||
| 1153 | readpage_eio: | ||
| 1154 | error = -EIO; | ||
| 1155 | readpage_error: | 1156 | readpage_error: |
| 1156 | /* UHHUH! A synchronous read error occurred. Report it */ | 1157 | /* UHHUH! A synchronous read error occurred. Report it */ |
| 1157 | desc->error = error; | 1158 | desc->error = error; |
