diff options
| author | Peng Tao <bergwolf@gmail.com> | 2011-09-22 21:50:12 -0400 |
|---|---|---|
| committer | Trond Myklebust <Trond.Myklebust@netapp.com> | 2011-10-18 12:08:13 -0400 |
| commit | 1b0ae068779874f54b55aac3a2a992bcf3f2c3c4 (patch) | |
| tree | 2cfc6f406312ca02704fedb9675a02a5ec2993bf | |
| parent | 760383f1ee4d14b0e0bdf0cddee648d9b8633429 (diff) | |
pnfs: make _set_lo_fail generic
file layout and block layout both use it to set mark layout io failure
bit. So make it generic.
Signed-off-by: Peng Tao <peng_tao@emc.com>
Signed-off-by: Jim Rees <rees@umich.edu>
Cc: stable@kernel.org [3.0]
Signed-off-by: Trond Myklebust <Trond.Myklebust@netapp.com>
| -rw-r--r-- | fs/nfs/blocklayout/blocklayout.c | 17 | ||||
| -rw-r--r-- | fs/nfs/nfs4filelayout.c | 19 | ||||
| -rw-r--r-- | fs/nfs/pnfs.c | 12 | ||||
| -rw-r--r-- | fs/nfs/pnfs.h | 1 |
4 files changed, 19 insertions, 30 deletions
diff --git a/fs/nfs/blocklayout/blocklayout.c b/fs/nfs/blocklayout/blocklayout.c index dee6cae80fea..2167ba2afdbb 100644 --- a/fs/nfs/blocklayout/blocklayout.c +++ b/fs/nfs/blocklayout/blocklayout.c | |||
| @@ -176,17 +176,6 @@ retry: | |||
| 176 | return bio; | 176 | return bio; |
| 177 | } | 177 | } |
| 178 | 178 | ||
| 179 | static void bl_set_lo_fail(struct pnfs_layout_segment *lseg) | ||
| 180 | { | ||
| 181 | if (lseg->pls_range.iomode == IOMODE_RW) { | ||
| 182 | dprintk("%s Setting layout IOMODE_RW fail bit\n", __func__); | ||
| 183 | set_bit(lo_fail_bit(IOMODE_RW), &lseg->pls_layout->plh_flags); | ||
| 184 | } else { | ||
| 185 | dprintk("%s Setting layout IOMODE_READ fail bit\n", __func__); | ||
| 186 | set_bit(lo_fail_bit(IOMODE_READ), &lseg->pls_layout->plh_flags); | ||
| 187 | } | ||
| 188 | } | ||
| 189 | |||
| 190 | /* This is basically copied from mpage_end_io_read */ | 179 | /* This is basically copied from mpage_end_io_read */ |
| 191 | static void bl_end_io_read(struct bio *bio, int err) | 180 | static void bl_end_io_read(struct bio *bio, int err) |
| 192 | { | 181 | { |
| @@ -206,7 +195,7 @@ static void bl_end_io_read(struct bio *bio, int err) | |||
| 206 | if (!uptodate) { | 195 | if (!uptodate) { |
| 207 | if (!rdata->pnfs_error) | 196 | if (!rdata->pnfs_error) |
| 208 | rdata->pnfs_error = -EIO; | 197 | rdata->pnfs_error = -EIO; |
| 209 | bl_set_lo_fail(rdata->lseg); | 198 | pnfs_set_lo_fail(rdata->lseg); |
| 210 | } | 199 | } |
| 211 | bio_put(bio); | 200 | bio_put(bio); |
| 212 | put_parallel(par); | 201 | put_parallel(par); |
| @@ -370,7 +359,7 @@ static void bl_end_io_write_zero(struct bio *bio, int err) | |||
| 370 | if (!uptodate) { | 359 | if (!uptodate) { |
| 371 | if (!wdata->pnfs_error) | 360 | if (!wdata->pnfs_error) |
| 372 | wdata->pnfs_error = -EIO; | 361 | wdata->pnfs_error = -EIO; |
| 373 | bl_set_lo_fail(wdata->lseg); | 362 | pnfs_set_lo_fail(wdata->lseg); |
| 374 | } | 363 | } |
| 375 | bio_put(bio); | 364 | bio_put(bio); |
| 376 | put_parallel(par); | 365 | put_parallel(par); |
| @@ -386,7 +375,7 @@ static void bl_end_io_write(struct bio *bio, int err) | |||
| 386 | if (!uptodate) { | 375 | if (!uptodate) { |
| 387 | if (!wdata->pnfs_error) | 376 | if (!wdata->pnfs_error) |
| 388 | wdata->pnfs_error = -EIO; | 377 | wdata->pnfs_error = -EIO; |
| 389 | bl_set_lo_fail(wdata->lseg); | 378 | pnfs_set_lo_fail(wdata->lseg); |
| 390 | } | 379 | } |
| 391 | bio_put(bio); | 380 | bio_put(bio); |
| 392 | put_parallel(par); | 381 | put_parallel(par); |
diff --git a/fs/nfs/nfs4filelayout.c b/fs/nfs/nfs4filelayout.c index e8915d4840ad..4c78c62639e6 100644 --- a/fs/nfs/nfs4filelayout.c +++ b/fs/nfs/nfs4filelayout.c | |||
| @@ -77,19 +77,6 @@ filelayout_get_dserver_offset(struct pnfs_layout_segment *lseg, loff_t offset) | |||
| 77 | BUG(); | 77 | BUG(); |
| 78 | } | 78 | } |
| 79 | 79 | ||
| 80 | /* For data server errors we don't recover from */ | ||
| 81 | static void | ||
| 82 | filelayout_set_lo_fail(struct pnfs_layout_segment *lseg) | ||
| 83 | { | ||
| 84 | if (lseg->pls_range.iomode == IOMODE_RW) { | ||
| 85 | dprintk("%s Setting layout IOMODE_RW fail bit\n", __func__); | ||
| 86 | set_bit(lo_fail_bit(IOMODE_RW), &lseg->pls_layout->plh_flags); | ||
| 87 | } else { | ||
| 88 | dprintk("%s Setting layout IOMODE_READ fail bit\n", __func__); | ||
| 89 | set_bit(lo_fail_bit(IOMODE_READ), &lseg->pls_layout->plh_flags); | ||
| 90 | } | ||
| 91 | } | ||
| 92 | |||
| 93 | static int filelayout_async_handle_error(struct rpc_task *task, | 80 | static int filelayout_async_handle_error(struct rpc_task *task, |
| 94 | struct nfs4_state *state, | 81 | struct nfs4_state *state, |
| 95 | struct nfs_client *clp, | 82 | struct nfs_client *clp, |
| @@ -145,7 +132,7 @@ static int filelayout_read_done_cb(struct rpc_task *task, | |||
| 145 | dprintk("%s calling restart ds_clp %p ds_clp->cl_session %p\n", | 132 | dprintk("%s calling restart ds_clp %p ds_clp->cl_session %p\n", |
| 146 | __func__, data->ds_clp, data->ds_clp->cl_session); | 133 | __func__, data->ds_clp, data->ds_clp->cl_session); |
| 147 | if (reset) { | 134 | if (reset) { |
| 148 | filelayout_set_lo_fail(data->lseg); | 135 | pnfs_set_lo_fail(data->lseg); |
| 149 | nfs4_reset_read(task, data); | 136 | nfs4_reset_read(task, data); |
| 150 | clp = NFS_SERVER(data->inode)->nfs_client; | 137 | clp = NFS_SERVER(data->inode)->nfs_client; |
| 151 | } | 138 | } |
| @@ -221,7 +208,7 @@ static int filelayout_write_done_cb(struct rpc_task *task, | |||
| 221 | dprintk("%s calling restart ds_clp %p ds_clp->cl_session %p\n", | 208 | dprintk("%s calling restart ds_clp %p ds_clp->cl_session %p\n", |
| 222 | __func__, data->ds_clp, data->ds_clp->cl_session); | 209 | __func__, data->ds_clp, data->ds_clp->cl_session); |
| 223 | if (reset) { | 210 | if (reset) { |
| 224 | filelayout_set_lo_fail(data->lseg); | 211 | pnfs_set_lo_fail(data->lseg); |
| 225 | nfs4_reset_write(task, data); | 212 | nfs4_reset_write(task, data); |
| 226 | clp = NFS_SERVER(data->inode)->nfs_client; | 213 | clp = NFS_SERVER(data->inode)->nfs_client; |
| 227 | } else | 214 | } else |
| @@ -256,7 +243,7 @@ static int filelayout_commit_done_cb(struct rpc_task *task, | |||
| 256 | __func__, data->ds_clp, data->ds_clp->cl_session); | 243 | __func__, data->ds_clp, data->ds_clp->cl_session); |
| 257 | if (reset) { | 244 | if (reset) { |
| 258 | prepare_to_resend_writes(data); | 245 | prepare_to_resend_writes(data); |
| 259 | filelayout_set_lo_fail(data->lseg); | 246 | pnfs_set_lo_fail(data->lseg); |
| 260 | } else | 247 | } else |
| 261 | nfs_restart_rpc(task, data->ds_clp); | 248 | nfs_restart_rpc(task, data->ds_clp); |
| 262 | return -EAGAIN; | 249 | return -EAGAIN; |
diff --git a/fs/nfs/pnfs.c b/fs/nfs/pnfs.c index e550e8836c37..6b19fffa812a 100644 --- a/fs/nfs/pnfs.c +++ b/fs/nfs/pnfs.c | |||
| @@ -1381,6 +1381,18 @@ static void pnfs_list_write_lseg(struct inode *inode, struct list_head *listp) | |||
| 1381 | } | 1381 | } |
| 1382 | } | 1382 | } |
| 1383 | 1383 | ||
| 1384 | void pnfs_set_lo_fail(struct pnfs_layout_segment *lseg) | ||
| 1385 | { | ||
| 1386 | if (lseg->pls_range.iomode == IOMODE_RW) { | ||
| 1387 | dprintk("%s Setting layout IOMODE_RW fail bit\n", __func__); | ||
| 1388 | set_bit(lo_fail_bit(IOMODE_RW), &lseg->pls_layout->plh_flags); | ||
| 1389 | } else { | ||
| 1390 | dprintk("%s Setting layout IOMODE_READ fail bit\n", __func__); | ||
| 1391 | set_bit(lo_fail_bit(IOMODE_READ), &lseg->pls_layout->plh_flags); | ||
| 1392 | } | ||
| 1393 | } | ||
| 1394 | EXPORT_SYMBOL_GPL(pnfs_set_lo_fail); | ||
| 1395 | |||
| 1384 | void | 1396 | void |
| 1385 | pnfs_set_layoutcommit(struct nfs_write_data *wdata) | 1397 | pnfs_set_layoutcommit(struct nfs_write_data *wdata) |
| 1386 | { | 1398 | { |
diff --git a/fs/nfs/pnfs.h b/fs/nfs/pnfs.h index 01cbfd54f3cb..94e760eb543a 100644 --- a/fs/nfs/pnfs.h +++ b/fs/nfs/pnfs.h | |||
| @@ -178,6 +178,7 @@ int pnfs_generic_pg_readpages(struct nfs_pageio_descriptor *desc); | |||
| 178 | void pnfs_generic_pg_init_write(struct nfs_pageio_descriptor *, struct nfs_page *); | 178 | void pnfs_generic_pg_init_write(struct nfs_pageio_descriptor *, struct nfs_page *); |
| 179 | int pnfs_generic_pg_writepages(struct nfs_pageio_descriptor *desc); | 179 | int pnfs_generic_pg_writepages(struct nfs_pageio_descriptor *desc); |
| 180 | bool pnfs_generic_pg_test(struct nfs_pageio_descriptor *pgio, struct nfs_page *prev, struct nfs_page *req); | 180 | bool pnfs_generic_pg_test(struct nfs_pageio_descriptor *pgio, struct nfs_page *prev, struct nfs_page *req); |
| 181 | void pnfs_set_lo_fail(struct pnfs_layout_segment *lseg); | ||
| 181 | int pnfs_layout_process(struct nfs4_layoutget *lgp); | 182 | int pnfs_layout_process(struct nfs4_layoutget *lgp); |
| 182 | void pnfs_free_lseg_list(struct list_head *tmp_list); | 183 | void pnfs_free_lseg_list(struct list_head *tmp_list); |
| 183 | void pnfs_destroy_layout(struct nfs_inode *); | 184 | void pnfs_destroy_layout(struct nfs_inode *); |
