1 /* 2 * pNFS functions to call and manage layout drivers. 3 * 4 * Copyright (c) 2002 [year of first publication] 5 * The Regents of the University of Michigan 6 * All Rights Reserved 7 * 8 * Dean Hildebrand <dhildebz@umich.edu> 9 * 10 * Permission is granted to use, copy, create derivative works, and 11 * redistribute this software and such derivative works for any purpose, 12 * so long as the name of the University of Michigan is not used in 13 * any advertising or publicity pertaining to the use or distribution 14 * of this software without specific, written prior authorization. If 15 * the above copyright notice or any other identification of the 16 * University of Michigan is included in any copy of any portion of 17 * this software, then the disclaimer below must also be included. 18 * 19 * This software is provided as is, without representation or warranty 20 * of any kind either express or implied, including without limitation 21 * the implied warranties of merchantability, fitness for a particular 22 * purpose, or noninfringement. The Regents of the University of 23 * Michigan shall not be liable for any damages, including special, 24 * indirect, incidental, or consequential damages, with respect to any 25 * claim arising out of or in connection with the use of the software, 26 * even if it has been or is hereafter advised of the possibility of 27 * such damages. 28 */ 29 30 #include <linux/nfs_fs.h> 31 #include <linux/nfs_page.h> 32 #include <linux/module.h> 33 #include "internal.h" 34 #include "pnfs.h" 35 #include "iostat.h" 36 #include "nfs4trace.h" 37 38 #define NFSDBG_FACILITY NFSDBG_PNFS 39 #define PNFS_LAYOUTGET_RETRY_TIMEOUT (120*HZ) 40 41 /* Locking: 42 * 43 * pnfs_spinlock: 44 * protects pnfs_modules_tbl. 45 */ 46 static DEFINE_SPINLOCK(pnfs_spinlock); 47 48 /* 49 * pnfs_modules_tbl holds all pnfs modules 50 */ 51 static LIST_HEAD(pnfs_modules_tbl); 52 53 /* Return the registered pnfs layout driver module matching given id */ 54 static struct pnfs_layoutdriver_type * 55 find_pnfs_driver_locked(u32 id) 56 { 57 struct pnfs_layoutdriver_type *local; 58 59 list_for_each_entry(local, &pnfs_modules_tbl, pnfs_tblid) 60 if (local->id == id) 61 goto out; 62 local = NULL; 63 out: 64 dprintk("%s: Searching for id %u, found %p\n", __func__, id, local); 65 return local; 66 } 67 68 static struct pnfs_layoutdriver_type * 69 find_pnfs_driver(u32 id) 70 { 71 struct pnfs_layoutdriver_type *local; 72 73 spin_lock(&pnfs_spinlock); 74 local = find_pnfs_driver_locked(id); 75 if (local != NULL && !try_module_get(local->owner)) { 76 dprintk("%s: Could not grab reference on module\n", __func__); 77 local = NULL; 78 } 79 spin_unlock(&pnfs_spinlock); 80 return local; 81 } 82 83 void 84 unset_pnfs_layoutdriver(struct nfs_server *nfss) 85 { 86 if (nfss->pnfs_curr_ld) { 87 if (nfss->pnfs_curr_ld->clear_layoutdriver) 88 nfss->pnfs_curr_ld->clear_layoutdriver(nfss); 89 /* Decrement the MDS count. Purge the deviceid cache if zero */ 90 if (atomic_dec_and_test(&nfss->nfs_client->cl_mds_count)) 91 nfs4_deviceid_purge_client(nfss->nfs_client); 92 module_put(nfss->pnfs_curr_ld->owner); 93 } 94 nfss->pnfs_curr_ld = NULL; 95 } 96 97 /* 98 * Try to set the server's pnfs module to the pnfs layout type specified by id. 99 * Currently only one pNFS layout driver per filesystem is supported. 100 * 101 * @id layout type. Zero (illegal layout type) indicates pNFS not in use. 102 */ 103 void 104 set_pnfs_layoutdriver(struct nfs_server *server, const struct nfs_fh *mntfh, 105 u32 id) 106 { 107 struct pnfs_layoutdriver_type *ld_type = NULL; 108 109 if (id == 0) 110 goto out_no_driver; 111 if (!(server->nfs_client->cl_exchange_flags & 112 (EXCHGID4_FLAG_USE_NON_PNFS | EXCHGID4_FLAG_USE_PNFS_MDS))) { 113 printk(KERN_ERR "NFS: %s: id %u cl_exchange_flags 0x%x\n", 114 __func__, id, server->nfs_client->cl_exchange_flags); 115 goto out_no_driver; 116 } 117 ld_type = find_pnfs_driver(id); 118 if (!ld_type) { 119 request_module("%s-%u", LAYOUT_NFSV4_1_MODULE_PREFIX, id); 120 ld_type = find_pnfs_driver(id); 121 if (!ld_type) { 122 dprintk("%s: No pNFS module found for %u.\n", 123 __func__, id); 124 goto out_no_driver; 125 } 126 } 127 server->pnfs_curr_ld = ld_type; 128 if (ld_type->set_layoutdriver 129 && ld_type->set_layoutdriver(server, mntfh)) { 130 printk(KERN_ERR "NFS: %s: Error initializing pNFS layout " 131 "driver %u.\n", __func__, id); 132 module_put(ld_type->owner); 133 goto out_no_driver; 134 } 135 /* Bump the MDS count */ 136 atomic_inc(&server->nfs_client->cl_mds_count); 137 138 dprintk("%s: pNFS module for %u set\n", __func__, id); 139 return; 140 141 out_no_driver: 142 dprintk("%s: Using NFSv4 I/O\n", __func__); 143 server->pnfs_curr_ld = NULL; 144 } 145 146 int 147 pnfs_register_layoutdriver(struct pnfs_layoutdriver_type *ld_type) 148 { 149 int status = -EINVAL; 150 struct pnfs_layoutdriver_type *tmp; 151 152 if (ld_type->id == 0) { 153 printk(KERN_ERR "NFS: %s id 0 is reserved\n", __func__); 154 return status; 155 } 156 if (!ld_type->alloc_lseg || !ld_type->free_lseg) { 157 printk(KERN_ERR "NFS: %s Layout driver must provide " 158 "alloc_lseg and free_lseg.\n", __func__); 159 return status; 160 } 161 162 spin_lock(&pnfs_spinlock); 163 tmp = find_pnfs_driver_locked(ld_type->id); 164 if (!tmp) { 165 list_add(&ld_type->pnfs_tblid, &pnfs_modules_tbl); 166 status = 0; 167 dprintk("%s Registering id:%u name:%s\n", __func__, ld_type->id, 168 ld_type->name); 169 } else { 170 printk(KERN_ERR "NFS: %s Module with id %d already loaded!\n", 171 __func__, ld_type->id); 172 } 173 spin_unlock(&pnfs_spinlock); 174 175 return status; 176 } 177 EXPORT_SYMBOL_GPL(pnfs_register_layoutdriver); 178 179 void 180 pnfs_unregister_layoutdriver(struct pnfs_layoutdriver_type *ld_type) 181 { 182 dprintk("%s Deregistering id:%u\n", __func__, ld_type->id); 183 spin_lock(&pnfs_spinlock); 184 list_del(&ld_type->pnfs_tblid); 185 spin_unlock(&pnfs_spinlock); 186 } 187 EXPORT_SYMBOL_GPL(pnfs_unregister_layoutdriver); 188 189 /* 190 * pNFS client layout cache 191 */ 192 193 /* Need to hold i_lock if caller does not already hold reference */ 194 void 195 pnfs_get_layout_hdr(struct pnfs_layout_hdr *lo) 196 { 197 atomic_inc(&lo->plh_refcount); 198 } 199 200 static struct pnfs_layout_hdr * 201 pnfs_alloc_layout_hdr(struct inode *ino, gfp_t gfp_flags) 202 { 203 struct pnfs_layoutdriver_type *ld = NFS_SERVER(ino)->pnfs_curr_ld; 204 return ld->alloc_layout_hdr(ino, gfp_flags); 205 } 206 207 static void 208 pnfs_free_layout_hdr(struct pnfs_layout_hdr *lo) 209 { 210 struct nfs_server *server = NFS_SERVER(lo->plh_inode); 211 struct pnfs_layoutdriver_type *ld = server->pnfs_curr_ld; 212 213 if (!list_empty(&lo->plh_layouts)) { 214 struct nfs_client *clp = server->nfs_client; 215 216 spin_lock(&clp->cl_lock); 217 list_del_init(&lo->plh_layouts); 218 spin_unlock(&clp->cl_lock); 219 } 220 put_rpccred(lo->plh_lc_cred); 221 return ld->free_layout_hdr(lo); 222 } 223 224 static void 225 pnfs_detach_layout_hdr(struct pnfs_layout_hdr *lo) 226 { 227 struct nfs_inode *nfsi = NFS_I(lo->plh_inode); 228 dprintk("%s: freeing layout cache %p\n", __func__, lo); 229 nfsi->layout = NULL; 230 /* Reset MDS Threshold I/O counters */ 231 nfsi->write_io = 0; 232 nfsi->read_io = 0; 233 } 234 235 void 236 pnfs_put_layout_hdr(struct pnfs_layout_hdr *lo) 237 { 238 struct inode *inode = lo->plh_inode; 239 240 if (atomic_dec_and_lock(&lo->plh_refcount, &inode->i_lock)) { 241 pnfs_detach_layout_hdr(lo); 242 spin_unlock(&inode->i_lock); 243 pnfs_free_layout_hdr(lo); 244 } 245 } 246 247 static int 248 pnfs_iomode_to_fail_bit(u32 iomode) 249 { 250 return iomode == IOMODE_RW ? 251 NFS_LAYOUT_RW_FAILED : NFS_LAYOUT_RO_FAILED; 252 } 253 254 static void 255 pnfs_layout_set_fail_bit(struct pnfs_layout_hdr *lo, int fail_bit) 256 { 257 lo->plh_retry_timestamp = jiffies; 258 if (!test_and_set_bit(fail_bit, &lo->plh_flags)) 259 atomic_inc(&lo->plh_refcount); 260 } 261 262 static void 263 pnfs_layout_clear_fail_bit(struct pnfs_layout_hdr *lo, int fail_bit) 264 { 265 if (test_and_clear_bit(fail_bit, &lo->plh_flags)) 266 atomic_dec(&lo->plh_refcount); 267 } 268 269 static void 270 pnfs_layout_io_set_failed(struct pnfs_layout_hdr *lo, u32 iomode) 271 { 272 struct inode *inode = lo->plh_inode; 273 struct pnfs_layout_range range = { 274 .iomode = iomode, 275 .offset = 0, 276 .length = NFS4_MAX_UINT64, 277 }; 278 LIST_HEAD(head); 279 280 spin_lock(&inode->i_lock); 281 pnfs_layout_set_fail_bit(lo, pnfs_iomode_to_fail_bit(iomode)); 282 pnfs_mark_matching_lsegs_invalid(lo, &head, &range); 283 spin_unlock(&inode->i_lock); 284 pnfs_free_lseg_list(&head); 285 dprintk("%s Setting layout IOMODE_%s fail bit\n", __func__, 286 iomode == IOMODE_RW ? "RW" : "READ"); 287 } 288 289 static bool 290 pnfs_layout_io_test_failed(struct pnfs_layout_hdr *lo, u32 iomode) 291 { 292 unsigned long start, end; 293 int fail_bit = pnfs_iomode_to_fail_bit(iomode); 294 295 if (test_bit(fail_bit, &lo->plh_flags) == 0) 296 return false; 297 end = jiffies; 298 start = end - PNFS_LAYOUTGET_RETRY_TIMEOUT; 299 if (!time_in_range(lo->plh_retry_timestamp, start, end)) { 300 /* It is time to retry the failed layoutgets */ 301 pnfs_layout_clear_fail_bit(lo, fail_bit); 302 return false; 303 } 304 return true; 305 } 306 307 static void 308 init_lseg(struct pnfs_layout_hdr *lo, struct pnfs_layout_segment *lseg) 309 { 310 INIT_LIST_HEAD(&lseg->pls_list); 311 INIT_LIST_HEAD(&lseg->pls_lc_list); 312 atomic_set(&lseg->pls_refcount, 1); 313 smp_mb(); 314 set_bit(NFS_LSEG_VALID, &lseg->pls_flags); 315 lseg->pls_layout = lo; 316 } 317 318 static void pnfs_free_lseg(struct pnfs_layout_segment *lseg) 319 { 320 struct inode *ino = lseg->pls_layout->plh_inode; 321 322 NFS_SERVER(ino)->pnfs_curr_ld->free_lseg(lseg); 323 } 324 325 static void 326 pnfs_layout_remove_lseg(struct pnfs_layout_hdr *lo, 327 struct pnfs_layout_segment *lseg) 328 { 329 struct inode *inode = lo->plh_inode; 330 331 WARN_ON(test_bit(NFS_LSEG_VALID, &lseg->pls_flags)); 332 list_del_init(&lseg->pls_list); 333 /* Matched by pnfs_get_layout_hdr in pnfs_layout_insert_lseg */ 334 atomic_dec(&lo->plh_refcount); 335 if (list_empty(&lo->plh_segs)) 336 clear_bit(NFS_LAYOUT_BULK_RECALL, &lo->plh_flags); 337 rpc_wake_up(&NFS_SERVER(inode)->roc_rpcwaitq); 338 } 339 340 void 341 pnfs_put_lseg(struct pnfs_layout_segment *lseg) 342 { 343 struct pnfs_layout_hdr *lo; 344 struct inode *inode; 345 346 if (!lseg) 347 return; 348 349 dprintk("%s: lseg %p ref %d valid %d\n", __func__, lseg, 350 atomic_read(&lseg->pls_refcount), 351 test_bit(NFS_LSEG_VALID, &lseg->pls_flags)); 352 lo = lseg->pls_layout; 353 inode = lo->plh_inode; 354 if (atomic_dec_and_lock(&lseg->pls_refcount, &inode->i_lock)) { 355 pnfs_get_layout_hdr(lo); 356 pnfs_layout_remove_lseg(lo, lseg); 357 spin_unlock(&inode->i_lock); 358 pnfs_free_lseg(lseg); 359 pnfs_put_layout_hdr(lo); 360 } 361 } 362 EXPORT_SYMBOL_GPL(pnfs_put_lseg); 363 364 static u64 365 end_offset(u64 start, u64 len) 366 { 367 u64 end; 368 369 end = start + len; 370 return end >= start ? end : NFS4_MAX_UINT64; 371 } 372 373 /* 374 * is l2 fully contained in l1? 375 * start1 end1 376 * [----------------------------------) 377 * start2 end2 378 * [----------------) 379 */ 380 static bool 381 pnfs_lseg_range_contained(const struct pnfs_layout_range *l1, 382 const struct pnfs_layout_range *l2) 383 { 384 u64 start1 = l1->offset; 385 u64 end1 = end_offset(start1, l1->length); 386 u64 start2 = l2->offset; 387 u64 end2 = end_offset(start2, l2->length); 388 389 return (start1 <= start2) && (end1 >= end2); 390 } 391 392 /* 393 * is l1 and l2 intersecting? 394 * start1 end1 395 * [----------------------------------) 396 * start2 end2 397 * [----------------) 398 */ 399 static bool 400 pnfs_lseg_range_intersecting(const struct pnfs_layout_range *l1, 401 const struct pnfs_layout_range *l2) 402 { 403 u64 start1 = l1->offset; 404 u64 end1 = end_offset(start1, l1->length); 405 u64 start2 = l2->offset; 406 u64 end2 = end_offset(start2, l2->length); 407 408 return (end1 == NFS4_MAX_UINT64 || end1 > start2) && 409 (end2 == NFS4_MAX_UINT64 || end2 > start1); 410 } 411 412 static bool 413 should_free_lseg(const struct pnfs_layout_range *lseg_range, 414 const struct pnfs_layout_range *recall_range) 415 { 416 return (recall_range->iomode == IOMODE_ANY || 417 lseg_range->iomode == recall_range->iomode) && 418 pnfs_lseg_range_intersecting(lseg_range, recall_range); 419 } 420 421 static bool pnfs_lseg_dec_and_remove_zero(struct pnfs_layout_segment *lseg, 422 struct list_head *tmp_list) 423 { 424 if (!atomic_dec_and_test(&lseg->pls_refcount)) 425 return false; 426 pnfs_layout_remove_lseg(lseg->pls_layout, lseg); 427 list_add(&lseg->pls_list, tmp_list); 428 return true; 429 } 430 431 /* Returns 1 if lseg is removed from list, 0 otherwise */ 432 static int mark_lseg_invalid(struct pnfs_layout_segment *lseg, 433 struct list_head *tmp_list) 434 { 435 int rv = 0; 436 437 if (test_and_clear_bit(NFS_LSEG_VALID, &lseg->pls_flags)) { 438 /* Remove the reference keeping the lseg in the 439 * list. It will now be removed when all 440 * outstanding io is finished. 441 */ 442 dprintk("%s: lseg %p ref %d\n", __func__, lseg, 443 atomic_read(&lseg->pls_refcount)); 444 if (pnfs_lseg_dec_and_remove_zero(lseg, tmp_list)) 445 rv = 1; 446 } 447 return rv; 448 } 449 450 /* Returns count of number of matching invalid lsegs remaining in list 451 * after call. 452 */ 453 int 454 pnfs_mark_matching_lsegs_invalid(struct pnfs_layout_hdr *lo, 455 struct list_head *tmp_list, 456 struct pnfs_layout_range *recall_range) 457 { 458 struct pnfs_layout_segment *lseg, *next; 459 int invalid = 0, removed = 0; 460 461 dprintk("%s:Begin lo %p\n", __func__, lo); 462 463 if (list_empty(&lo->plh_segs)) 464 return 0; 465 list_for_each_entry_safe(lseg, next, &lo->plh_segs, pls_list) 466 if (!recall_range || 467 should_free_lseg(&lseg->pls_range, recall_range)) { 468 dprintk("%s: freeing lseg %p iomode %d " 469 "offset %llu length %llu\n", __func__, 470 lseg, lseg->pls_range.iomode, lseg->pls_range.offset, 471 lseg->pls_range.length); 472 invalid++; 473 removed += mark_lseg_invalid(lseg, tmp_list); 474 } 475 dprintk("%s:Return %i\n", __func__, invalid - removed); 476 return invalid - removed; 477 } 478 479 /* note free_me must contain lsegs from a single layout_hdr */ 480 void 481 pnfs_free_lseg_list(struct list_head *free_me) 482 { 483 struct pnfs_layout_segment *lseg, *tmp; 484 485 if (list_empty(free_me)) 486 return; 487 488 list_for_each_entry_safe(lseg, tmp, free_me, pls_list) { 489 list_del(&lseg->pls_list); 490 pnfs_free_lseg(lseg); 491 } 492 } 493 494 void 495 pnfs_destroy_layout(struct nfs_inode *nfsi) 496 { 497 struct pnfs_layout_hdr *lo; 498 LIST_HEAD(tmp_list); 499 500 spin_lock(&nfsi->vfs_inode.i_lock); 501 lo = nfsi->layout; 502 if (lo) { 503 lo->plh_block_lgets++; /* permanently block new LAYOUTGETs */ 504 pnfs_mark_matching_lsegs_invalid(lo, &tmp_list, NULL); 505 pnfs_get_layout_hdr(lo); 506 pnfs_layout_clear_fail_bit(lo, NFS_LAYOUT_RO_FAILED); 507 pnfs_layout_clear_fail_bit(lo, NFS_LAYOUT_RW_FAILED); 508 spin_unlock(&nfsi->vfs_inode.i_lock); 509 pnfs_free_lseg_list(&tmp_list); 510 pnfs_put_layout_hdr(lo); 511 } else 512 spin_unlock(&nfsi->vfs_inode.i_lock); 513 } 514 EXPORT_SYMBOL_GPL(pnfs_destroy_layout); 515 516 static bool 517 pnfs_layout_add_bulk_destroy_list(struct inode *inode, 518 struct list_head *layout_list) 519 { 520 struct pnfs_layout_hdr *lo; 521 bool ret = false; 522 523 spin_lock(&inode->i_lock); 524 lo = NFS_I(inode)->layout; 525 if (lo != NULL && list_empty(&lo->plh_bulk_destroy)) { 526 pnfs_get_layout_hdr(lo); 527 list_add(&lo->plh_bulk_destroy, layout_list); 528 ret = true; 529 } 530 spin_unlock(&inode->i_lock); 531 return ret; 532 } 533 534 /* Caller must hold rcu_read_lock and clp->cl_lock */ 535 static int 536 pnfs_layout_bulk_destroy_byserver_locked(struct nfs_client *clp, 537 struct nfs_server *server, 538 struct list_head *layout_list) 539 { 540 struct pnfs_layout_hdr *lo, *next; 541 struct inode *inode; 542 543 list_for_each_entry_safe(lo, next, &server->layouts, plh_layouts) { 544 inode = igrab(lo->plh_inode); 545 if (inode == NULL) 546 continue; 547 list_del_init(&lo->plh_layouts); 548 if (pnfs_layout_add_bulk_destroy_list(inode, layout_list)) 549 continue; 550 rcu_read_unlock(); 551 spin_unlock(&clp->cl_lock); 552 iput(inode); 553 spin_lock(&clp->cl_lock); 554 rcu_read_lock(); 555 return -EAGAIN; 556 } 557 return 0; 558 } 559 560 static int 561 pnfs_layout_free_bulk_destroy_list(struct list_head *layout_list, 562 bool is_bulk_recall) 563 { 564 struct pnfs_layout_hdr *lo; 565 struct inode *inode; 566 struct pnfs_layout_range range = { 567 .iomode = IOMODE_ANY, 568 .offset = 0, 569 .length = NFS4_MAX_UINT64, 570 }; 571 LIST_HEAD(lseg_list); 572 int ret = 0; 573 574 while (!list_empty(layout_list)) { 575 lo = list_entry(layout_list->next, struct pnfs_layout_hdr, 576 plh_bulk_destroy); 577 dprintk("%s freeing layout for inode %lu\n", __func__, 578 lo->plh_inode->i_ino); 579 inode = lo->plh_inode; 580 spin_lock(&inode->i_lock); 581 list_del_init(&lo->plh_bulk_destroy); 582 lo->plh_block_lgets++; /* permanently block new LAYOUTGETs */ 583 if (is_bulk_recall) 584 set_bit(NFS_LAYOUT_BULK_RECALL, &lo->plh_flags); 585 if (pnfs_mark_matching_lsegs_invalid(lo, &lseg_list, &range)) 586 ret = -EAGAIN; 587 spin_unlock(&inode->i_lock); 588 pnfs_free_lseg_list(&lseg_list); 589 pnfs_put_layout_hdr(lo); 590 iput(inode); 591 } 592 return ret; 593 } 594 595 int 596 pnfs_destroy_layouts_byfsid(struct nfs_client *clp, 597 struct nfs_fsid *fsid, 598 bool is_recall) 599 { 600 struct nfs_server *server; 601 LIST_HEAD(layout_list); 602 603 spin_lock(&clp->cl_lock); 604 rcu_read_lock(); 605 restart: 606 list_for_each_entry_rcu(server, &clp->cl_superblocks, client_link) { 607 if (memcmp(&server->fsid, fsid, sizeof(*fsid)) != 0) 608 continue; 609 if (pnfs_layout_bulk_destroy_byserver_locked(clp, 610 server, 611 &layout_list) != 0) 612 goto restart; 613 } 614 rcu_read_unlock(); 615 spin_unlock(&clp->cl_lock); 616 617 if (list_empty(&layout_list)) 618 return 0; 619 return pnfs_layout_free_bulk_destroy_list(&layout_list, is_recall); 620 } 621 622 int 623 pnfs_destroy_layouts_byclid(struct nfs_client *clp, 624 bool is_recall) 625 { 626 struct nfs_server *server; 627 LIST_HEAD(layout_list); 628 629 spin_lock(&clp->cl_lock); 630 rcu_read_lock(); 631 restart: 632 list_for_each_entry_rcu(server, &clp->cl_superblocks, client_link) { 633 if (pnfs_layout_bulk_destroy_byserver_locked(clp, 634 server, 635 &layout_list) != 0) 636 goto restart; 637 } 638 rcu_read_unlock(); 639 spin_unlock(&clp->cl_lock); 640 641 if (list_empty(&layout_list)) 642 return 0; 643 return pnfs_layout_free_bulk_destroy_list(&layout_list, is_recall); 644 } 645 646 /* 647 * Called by the state manger to remove all layouts established under an 648 * expired lease. 649 */ 650 void 651 pnfs_destroy_all_layouts(struct nfs_client *clp) 652 { 653 nfs4_deviceid_mark_client_invalid(clp); 654 nfs4_deviceid_purge_client(clp); 655 656 pnfs_destroy_layouts_byclid(clp, false); 657 } 658 659 /* 660 * Compare 2 layout stateid sequence ids, to see which is newer, 661 * taking into account wraparound issues. 662 */ 663 static bool pnfs_seqid_is_newer(u32 s1, u32 s2) 664 { 665 return (s32)(s1 - s2) > 0; 666 } 667 668 static void 669 pnfs_verify_layout_stateid(struct pnfs_layout_hdr *lo, 670 const nfs4_stateid *new, 671 struct list_head *free_me_list) 672 { 673 if (nfs4_stateid_match_other(&lo->plh_stateid, new)) 674 return; 675 /* Layout is new! Kill existing layout segments */ 676 pnfs_mark_matching_lsegs_invalid(lo, free_me_list, NULL); 677 } 678 679 /* update lo->plh_stateid with new if is more recent */ 680 void 681 pnfs_set_layout_stateid(struct pnfs_layout_hdr *lo, const nfs4_stateid *new, 682 bool update_barrier) 683 { 684 u32 oldseq, newseq, new_barrier; 685 int empty = list_empty(&lo->plh_segs); 686 687 oldseq = be32_to_cpu(lo->plh_stateid.seqid); 688 newseq = be32_to_cpu(new->seqid); 689 if (empty || pnfs_seqid_is_newer(newseq, oldseq)) { 690 nfs4_stateid_copy(&lo->plh_stateid, new); 691 if (update_barrier) { 692 new_barrier = be32_to_cpu(new->seqid); 693 } else { 694 /* Because of wraparound, we want to keep the barrier 695 * "close" to the current seqids. 696 */ 697 new_barrier = newseq - atomic_read(&lo->plh_outstanding); 698 } 699 if (empty || pnfs_seqid_is_newer(new_barrier, lo->plh_barrier)) 700 lo->plh_barrier = new_barrier; 701 } 702 } 703 704 static bool 705 pnfs_layout_stateid_blocked(const struct pnfs_layout_hdr *lo, 706 const nfs4_stateid *stateid) 707 { 708 u32 seqid = be32_to_cpu(stateid->seqid); 709 710 return !pnfs_seqid_is_newer(seqid, lo->plh_barrier); 711 } 712 713 /* lget is set to 1 if called from inside send_layoutget call chain */ 714 static bool 715 pnfs_layoutgets_blocked(const struct pnfs_layout_hdr *lo, int lget) 716 { 717 return lo->plh_block_lgets || 718 test_bit(NFS_LAYOUT_BULK_RECALL, &lo->plh_flags) || 719 (list_empty(&lo->plh_segs) && 720 (atomic_read(&lo->plh_outstanding) > lget)); 721 } 722 723 int 724 pnfs_choose_layoutget_stateid(nfs4_stateid *dst, struct pnfs_layout_hdr *lo, 725 struct nfs4_state *open_state) 726 { 727 int status = 0; 728 729 dprintk("--> %s\n", __func__); 730 spin_lock(&lo->plh_inode->i_lock); 731 if (pnfs_layoutgets_blocked(lo, 1)) { 732 status = -EAGAIN; 733 } else if (!nfs4_valid_open_stateid(open_state)) { 734 status = -EBADF; 735 } else if (list_empty(&lo->plh_segs)) { 736 int seq; 737 738 do { 739 seq = read_seqbegin(&open_state->seqlock); 740 nfs4_stateid_copy(dst, &open_state->stateid); 741 } while (read_seqretry(&open_state->seqlock, seq)); 742 } else 743 nfs4_stateid_copy(dst, &lo->plh_stateid); 744 spin_unlock(&lo->plh_inode->i_lock); 745 dprintk("<-- %s\n", __func__); 746 return status; 747 } 748 749 /* 750 * Get layout from server. 751 * for now, assume that whole file layouts are requested. 752 * arg->offset: 0 753 * arg->length: all ones 754 */ 755 static struct pnfs_layout_segment * 756 send_layoutget(struct pnfs_layout_hdr *lo, 757 struct nfs_open_context *ctx, 758 struct pnfs_layout_range *range, 759 gfp_t gfp_flags) 760 { 761 struct inode *ino = lo->plh_inode; 762 struct nfs_server *server = NFS_SERVER(ino); 763 struct nfs4_layoutget *lgp; 764 struct pnfs_layout_segment *lseg; 765 766 dprintk("--> %s\n", __func__); 767 768 lgp = kzalloc(sizeof(*lgp), gfp_flags); 769 if (lgp == NULL) 770 return NULL; 771 772 lgp->args.minlength = PAGE_CACHE_SIZE; 773 if (lgp->args.minlength > range->length) 774 lgp->args.minlength = range->length; 775 lgp->args.maxcount = PNFS_LAYOUT_MAXSIZE; 776 lgp->args.range = *range; 777 lgp->args.type = server->pnfs_curr_ld->id; 778 lgp->args.inode = ino; 779 lgp->args.ctx = get_nfs_open_context(ctx); 780 lgp->gfp_flags = gfp_flags; 781 lgp->cred = lo->plh_lc_cred; 782 783 /* Synchronously retrieve layout information from server and 784 * store in lseg. 785 */ 786 lseg = nfs4_proc_layoutget(lgp, gfp_flags); 787 if (IS_ERR(lseg)) { 788 switch (PTR_ERR(lseg)) { 789 case -ENOMEM: 790 case -ERESTARTSYS: 791 break; 792 default: 793 /* remember that LAYOUTGET failed and suspend trying */ 794 pnfs_layout_io_set_failed(lo, range->iomode); 795 } 796 return NULL; 797 } 798 799 return lseg; 800 } 801 802 static void pnfs_clear_layoutcommit(struct inode *inode, 803 struct list_head *head) 804 { 805 struct nfs_inode *nfsi = NFS_I(inode); 806 struct pnfs_layout_segment *lseg, *tmp; 807 808 if (!test_and_clear_bit(NFS_INO_LAYOUTCOMMIT, &nfsi->flags)) 809 return; 810 list_for_each_entry_safe(lseg, tmp, &nfsi->layout->plh_segs, pls_list) { 811 if (!test_and_clear_bit(NFS_LSEG_LAYOUTCOMMIT, &lseg->pls_flags)) 812 continue; 813 pnfs_lseg_dec_and_remove_zero(lseg, head); 814 } 815 } 816 817 /* 818 * Initiates a LAYOUTRETURN(FILE), and removes the pnfs_layout_hdr 819 * when the layout segment list is empty. 820 * 821 * Note that a pnfs_layout_hdr can exist with an empty layout segment 822 * list when LAYOUTGET has failed, or when LAYOUTGET succeeded, but the 823 * deviceid is marked invalid. 824 */ 825 int 826 _pnfs_return_layout(struct inode *ino) 827 { 828 struct pnfs_layout_hdr *lo = NULL; 829 struct nfs_inode *nfsi = NFS_I(ino); 830 LIST_HEAD(tmp_list); 831 struct nfs4_layoutreturn *lrp; 832 nfs4_stateid stateid; 833 int status = 0, empty; 834 835 dprintk("NFS: %s for inode %lu\n", __func__, ino->i_ino); 836 837 spin_lock(&ino->i_lock); 838 lo = nfsi->layout; 839 if (!lo) { 840 spin_unlock(&ino->i_lock); 841 dprintk("NFS: %s no layout to return\n", __func__); 842 goto out; 843 } 844 stateid = nfsi->layout->plh_stateid; 845 /* Reference matched in nfs4_layoutreturn_release */ 846 pnfs_get_layout_hdr(lo); 847 empty = list_empty(&lo->plh_segs); 848 pnfs_clear_layoutcommit(ino, &tmp_list); 849 pnfs_mark_matching_lsegs_invalid(lo, &tmp_list, NULL); 850 /* Don't send a LAYOUTRETURN if list was initially empty */ 851 if (empty) { 852 spin_unlock(&ino->i_lock); 853 pnfs_put_layout_hdr(lo); 854 dprintk("NFS: %s no layout segments to return\n", __func__); 855 goto out; 856 } 857 lo->plh_block_lgets++; 858 spin_unlock(&ino->i_lock); 859 pnfs_free_lseg_list(&tmp_list); 860 861 lrp = kzalloc(sizeof(*lrp), GFP_KERNEL); 862 if (unlikely(lrp == NULL)) { 863 status = -ENOMEM; 864 spin_lock(&ino->i_lock); 865 lo->plh_block_lgets--; 866 spin_unlock(&ino->i_lock); 867 pnfs_put_layout_hdr(lo); 868 goto out; 869 } 870 871 lrp->args.stateid = stateid; 872 lrp->args.layout_type = NFS_SERVER(ino)->pnfs_curr_ld->id; 873 lrp->args.inode = ino; 874 lrp->args.layout = lo; 875 lrp->clp = NFS_SERVER(ino)->nfs_client; 876 lrp->cred = lo->plh_lc_cred; 877 878 status = nfs4_proc_layoutreturn(lrp); 879 out: 880 dprintk("<-- %s status: %d\n", __func__, status); 881 return status; 882 } 883 EXPORT_SYMBOL_GPL(_pnfs_return_layout); 884 885 int 886 pnfs_commit_and_return_layout(struct inode *inode) 887 { 888 struct pnfs_layout_hdr *lo; 889 int ret; 890 891 spin_lock(&inode->i_lock); 892 lo = NFS_I(inode)->layout; 893 if (lo == NULL) { 894 spin_unlock(&inode->i_lock); 895 return 0; 896 } 897 pnfs_get_layout_hdr(lo); 898 /* Block new layoutgets and read/write to ds */ 899 lo->plh_block_lgets++; 900 spin_unlock(&inode->i_lock); 901 filemap_fdatawait(inode->i_mapping); 902 ret = pnfs_layoutcommit_inode(inode, true); 903 if (ret == 0) 904 ret = _pnfs_return_layout(inode); 905 spin_lock(&inode->i_lock); 906 lo->plh_block_lgets--; 907 spin_unlock(&inode->i_lock); 908 pnfs_put_layout_hdr(lo); 909 return ret; 910 } 911 912 bool pnfs_roc(struct inode *ino) 913 { 914 struct pnfs_layout_hdr *lo; 915 struct pnfs_layout_segment *lseg, *tmp; 916 LIST_HEAD(tmp_list); 917 bool found = false; 918 919 spin_lock(&ino->i_lock); 920 lo = NFS_I(ino)->layout; 921 if (!lo || !test_and_clear_bit(NFS_LAYOUT_ROC, &lo->plh_flags) || 922 test_bit(NFS_LAYOUT_BULK_RECALL, &lo->plh_flags)) 923 goto out_nolayout; 924 list_for_each_entry_safe(lseg, tmp, &lo->plh_segs, pls_list) 925 if (test_bit(NFS_LSEG_ROC, &lseg->pls_flags)) { 926 mark_lseg_invalid(lseg, &tmp_list); 927 found = true; 928 } 929 if (!found) 930 goto out_nolayout; 931 lo->plh_block_lgets++; 932 pnfs_get_layout_hdr(lo); /* matched in pnfs_roc_release */ 933 spin_unlock(&ino->i_lock); 934 pnfs_free_lseg_list(&tmp_list); 935 return true; 936 937 out_nolayout: 938 spin_unlock(&ino->i_lock); 939 return false; 940 } 941 942 void pnfs_roc_release(struct inode *ino) 943 { 944 struct pnfs_layout_hdr *lo; 945 946 spin_lock(&ino->i_lock); 947 lo = NFS_I(ino)->layout; 948 lo->plh_block_lgets--; 949 if (atomic_dec_and_test(&lo->plh_refcount)) { 950 pnfs_detach_layout_hdr(lo); 951 spin_unlock(&ino->i_lock); 952 pnfs_free_layout_hdr(lo); 953 } else 954 spin_unlock(&ino->i_lock); 955 } 956 957 void pnfs_roc_set_barrier(struct inode *ino, u32 barrier) 958 { 959 struct pnfs_layout_hdr *lo; 960 961 spin_lock(&ino->i_lock); 962 lo = NFS_I(ino)->layout; 963 if (pnfs_seqid_is_newer(barrier, lo->plh_barrier)) 964 lo->plh_barrier = barrier; 965 spin_unlock(&ino->i_lock); 966 } 967 968 bool pnfs_roc_drain(struct inode *ino, u32 *barrier, struct rpc_task *task) 969 { 970 struct nfs_inode *nfsi = NFS_I(ino); 971 struct pnfs_layout_hdr *lo; 972 struct pnfs_layout_segment *lseg; 973 u32 current_seqid; 974 bool found = false; 975 976 spin_lock(&ino->i_lock); 977 list_for_each_entry(lseg, &nfsi->layout->plh_segs, pls_list) 978 if (test_bit(NFS_LSEG_ROC, &lseg->pls_flags)) { 979 rpc_sleep_on(&NFS_SERVER(ino)->roc_rpcwaitq, task, NULL); 980 found = true; 981 goto out; 982 } 983 lo = nfsi->layout; 984 current_seqid = be32_to_cpu(lo->plh_stateid.seqid); 985 986 /* Since close does not return a layout stateid for use as 987 * a barrier, we choose the worst-case barrier. 988 */ 989 *barrier = current_seqid + atomic_read(&lo->plh_outstanding); 990 out: 991 spin_unlock(&ino->i_lock); 992 return found; 993 } 994 995 /* 996 * Compare two layout segments for sorting into layout cache. 997 * We want to preferentially return RW over RO layouts, so ensure those 998 * are seen first. 999 */ 1000 static s64 1001 pnfs_lseg_range_cmp(const struct pnfs_layout_range *l1, 1002 const struct pnfs_layout_range *l2) 1003 { 1004 s64 d; 1005 1006 /* high offset > low offset */ 1007 d = l1->offset - l2->offset; 1008 if (d) 1009 return d; 1010 1011 /* short length > long length */ 1012 d = l2->length - l1->length; 1013 if (d) 1014 return d; 1015 1016 /* read > read/write */ 1017 return (int)(l1->iomode == IOMODE_READ) - (int)(l2->iomode == IOMODE_READ); 1018 } 1019 1020 static void 1021 pnfs_layout_insert_lseg(struct pnfs_layout_hdr *lo, 1022 struct pnfs_layout_segment *lseg) 1023 { 1024 struct pnfs_layout_segment *lp; 1025 1026 dprintk("%s:Begin\n", __func__); 1027 1028 list_for_each_entry(lp, &lo->plh_segs, pls_list) { 1029 if (pnfs_lseg_range_cmp(&lseg->pls_range, &lp->pls_range) > 0) 1030 continue; 1031 list_add_tail(&lseg->pls_list, &lp->pls_list); 1032 dprintk("%s: inserted lseg %p " 1033 "iomode %d offset %llu length %llu before " 1034 "lp %p iomode %d offset %llu length %llu\n", 1035 __func__, lseg, lseg->pls_range.iomode, 1036 lseg->pls_range.offset, lseg->pls_range.length, 1037 lp, lp->pls_range.iomode, lp->pls_range.offset, 1038 lp->pls_range.length); 1039 goto out; 1040 } 1041 list_add_tail(&lseg->pls_list, &lo->plh_segs); 1042 dprintk("%s: inserted lseg %p " 1043 "iomode %d offset %llu length %llu at tail\n", 1044 __func__, lseg, lseg->pls_range.iomode, 1045 lseg->pls_range.offset, lseg->pls_range.length); 1046 out: 1047 pnfs_get_layout_hdr(lo); 1048 1049 dprintk("%s:Return\n", __func__); 1050 } 1051 1052 static struct pnfs_layout_hdr * 1053 alloc_init_layout_hdr(struct inode *ino, 1054 struct nfs_open_context *ctx, 1055 gfp_t gfp_flags) 1056 { 1057 struct pnfs_layout_hdr *lo; 1058 1059 lo = pnfs_alloc_layout_hdr(ino, gfp_flags); 1060 if (!lo) 1061 return NULL; 1062 atomic_set(&lo->plh_refcount, 1); 1063 INIT_LIST_HEAD(&lo->plh_layouts); 1064 INIT_LIST_HEAD(&lo->plh_segs); 1065 INIT_LIST_HEAD(&lo->plh_bulk_destroy); 1066 lo->plh_inode = ino; 1067 lo->plh_lc_cred = get_rpccred(ctx->cred); 1068 return lo; 1069 } 1070 1071 static struct pnfs_layout_hdr * 1072 pnfs_find_alloc_layout(struct inode *ino, 1073 struct nfs_open_context *ctx, 1074 gfp_t gfp_flags) 1075 { 1076 struct nfs_inode *nfsi = NFS_I(ino); 1077 struct pnfs_layout_hdr *new = NULL; 1078 1079 dprintk("%s Begin ino=%p layout=%p\n", __func__, ino, nfsi->layout); 1080 1081 if (nfsi->layout != NULL) 1082 goto out_existing; 1083 spin_unlock(&ino->i_lock); 1084 new = alloc_init_layout_hdr(ino, ctx, gfp_flags); 1085 spin_lock(&ino->i_lock); 1086 1087 if (likely(nfsi->layout == NULL)) { /* Won the race? */ 1088 nfsi->layout = new; 1089 return new; 1090 } else if (new != NULL) 1091 pnfs_free_layout_hdr(new); 1092 out_existing: 1093 pnfs_get_layout_hdr(nfsi->layout); 1094 return nfsi->layout; 1095 } 1096 1097 /* 1098 * iomode matching rules: 1099 * iomode lseg match 1100 * ----- ----- ----- 1101 * ANY READ true 1102 * ANY RW true 1103 * RW READ false 1104 * RW RW true 1105 * READ READ true 1106 * READ RW true 1107 */ 1108 static bool 1109 pnfs_lseg_range_match(const struct pnfs_layout_range *ls_range, 1110 const struct pnfs_layout_range *range) 1111 { 1112 struct pnfs_layout_range range1; 1113 1114 if ((range->iomode == IOMODE_RW && 1115 ls_range->iomode != IOMODE_RW) || 1116 !pnfs_lseg_range_intersecting(ls_range, range)) 1117 return 0; 1118 1119 /* range1 covers only the first byte in the range */ 1120 range1 = *range; 1121 range1.length = 1; 1122 return pnfs_lseg_range_contained(ls_range, &range1); 1123 } 1124 1125 /* 1126 * lookup range in layout 1127 */ 1128 static struct pnfs_layout_segment * 1129 pnfs_find_lseg(struct pnfs_layout_hdr *lo, 1130 struct pnfs_layout_range *range) 1131 { 1132 struct pnfs_layout_segment *lseg, *ret = NULL; 1133 1134 dprintk("%s:Begin\n", __func__); 1135 1136 list_for_each_entry(lseg, &lo->plh_segs, pls_list) { 1137 if (test_bit(NFS_LSEG_VALID, &lseg->pls_flags) && 1138 pnfs_lseg_range_match(&lseg->pls_range, range)) { 1139 ret = pnfs_get_lseg(lseg); 1140 break; 1141 } 1142 if (lseg->pls_range.offset > range->offset) 1143 break; 1144 } 1145 1146 dprintk("%s:Return lseg %p ref %d\n", 1147 __func__, ret, ret ? atomic_read(&ret->pls_refcount) : 0); 1148 return ret; 1149 } 1150 1151 /* 1152 * Use mdsthreshold hints set at each OPEN to determine if I/O should go 1153 * to the MDS or over pNFS 1154 * 1155 * The nfs_inode read_io and write_io fields are cumulative counters reset 1156 * when there are no layout segments. Note that in pnfs_update_layout iomode 1157 * is set to IOMODE_READ for a READ request, and set to IOMODE_RW for a 1158 * WRITE request. 1159 * 1160 * A return of true means use MDS I/O. 1161 * 1162 * From rfc 5661: 1163 * If a file's size is smaller than the file size threshold, data accesses 1164 * SHOULD be sent to the metadata server. If an I/O request has a length that 1165 * is below the I/O size threshold, the I/O SHOULD be sent to the metadata 1166 * server. If both file size and I/O size are provided, the client SHOULD 1167 * reach or exceed both thresholds before sending its read or write 1168 * requests to the data server. 1169 */ 1170 static bool pnfs_within_mdsthreshold(struct nfs_open_context *ctx, 1171 struct inode *ino, int iomode) 1172 { 1173 struct nfs4_threshold *t = ctx->mdsthreshold; 1174 struct nfs_inode *nfsi = NFS_I(ino); 1175 loff_t fsize = i_size_read(ino); 1176 bool size = false, size_set = false, io = false, io_set = false, ret = false; 1177 1178 if (t == NULL) 1179 return ret; 1180 1181 dprintk("%s bm=0x%x rd_sz=%llu wr_sz=%llu rd_io=%llu wr_io=%llu\n", 1182 __func__, t->bm, t->rd_sz, t->wr_sz, t->rd_io_sz, t->wr_io_sz); 1183 1184 switch (iomode) { 1185 case IOMODE_READ: 1186 if (t->bm & THRESHOLD_RD) { 1187 dprintk("%s fsize %llu\n", __func__, fsize); 1188 size_set = true; 1189 if (fsize < t->rd_sz) 1190 size = true; 1191 } 1192 if (t->bm & THRESHOLD_RD_IO) { 1193 dprintk("%s nfsi->read_io %llu\n", __func__, 1194 nfsi->read_io); 1195 io_set = true; 1196 if (nfsi->read_io < t->rd_io_sz) 1197 io = true; 1198 } 1199 break; 1200 case IOMODE_RW: 1201 if (t->bm & THRESHOLD_WR) { 1202 dprintk("%s fsize %llu\n", __func__, fsize); 1203 size_set = true; 1204 if (fsize < t->wr_sz) 1205 size = true; 1206 } 1207 if (t->bm & THRESHOLD_WR_IO) { 1208 dprintk("%s nfsi->write_io %llu\n", __func__, 1209 nfsi->write_io); 1210 io_set = true; 1211 if (nfsi->write_io < t->wr_io_sz) 1212 io = true; 1213 } 1214 break; 1215 } 1216 if (size_set && io_set) { 1217 if (size && io) 1218 ret = true; 1219 } else if (size || io) 1220 ret = true; 1221 1222 dprintk("<-- %s size %d io %d ret %d\n", __func__, size, io, ret); 1223 return ret; 1224 } 1225 1226 /* 1227 * Layout segment is retreived from the server if not cached. 1228 * The appropriate layout segment is referenced and returned to the caller. 1229 */ 1230 struct pnfs_layout_segment * 1231 pnfs_update_layout(struct inode *ino, 1232 struct nfs_open_context *ctx, 1233 loff_t pos, 1234 u64 count, 1235 enum pnfs_iomode iomode, 1236 gfp_t gfp_flags) 1237 { 1238 struct pnfs_layout_range arg = { 1239 .iomode = iomode, 1240 .offset = pos, 1241 .length = count, 1242 }; 1243 unsigned pg_offset; 1244 struct nfs_server *server = NFS_SERVER(ino); 1245 struct nfs_client *clp = server->nfs_client; 1246 struct pnfs_layout_hdr *lo; 1247 struct pnfs_layout_segment *lseg = NULL; 1248 bool first; 1249 1250 if (!pnfs_enabled_sb(NFS_SERVER(ino))) 1251 goto out; 1252 1253 if (pnfs_within_mdsthreshold(ctx, ino, iomode)) 1254 goto out; 1255 1256 spin_lock(&ino->i_lock); 1257 lo = pnfs_find_alloc_layout(ino, ctx, gfp_flags); 1258 if (lo == NULL) { 1259 spin_unlock(&ino->i_lock); 1260 goto out; 1261 } 1262 1263 /* Do we even need to bother with this? */ 1264 if (test_bit(NFS_LAYOUT_BULK_RECALL, &lo->plh_flags)) { 1265 dprintk("%s matches recall, use MDS\n", __func__); 1266 goto out_unlock; 1267 } 1268 1269 /* if LAYOUTGET already failed once we don't try again */ 1270 if (pnfs_layout_io_test_failed(lo, iomode)) 1271 goto out_unlock; 1272 1273 /* Check to see if the layout for the given range already exists */ 1274 lseg = pnfs_find_lseg(lo, &arg); 1275 if (lseg) 1276 goto out_unlock; 1277 1278 if (pnfs_layoutgets_blocked(lo, 0)) 1279 goto out_unlock; 1280 atomic_inc(&lo->plh_outstanding); 1281 1282 first = list_empty(&lo->plh_layouts) ? true : false; 1283 spin_unlock(&ino->i_lock); 1284 1285 if (first) { 1286 /* The lo must be on the clp list if there is any 1287 * chance of a CB_LAYOUTRECALL(FILE) coming in. 1288 */ 1289 spin_lock(&clp->cl_lock); 1290 list_add_tail(&lo->plh_layouts, &server->layouts); 1291 spin_unlock(&clp->cl_lock); 1292 } 1293 1294 pg_offset = arg.offset & ~PAGE_CACHE_MASK; 1295 if (pg_offset) { 1296 arg.offset -= pg_offset; 1297 arg.length += pg_offset; 1298 } 1299 if (arg.length != NFS4_MAX_UINT64) 1300 arg.length = PAGE_CACHE_ALIGN(arg.length); 1301 1302 lseg = send_layoutget(lo, ctx, &arg, gfp_flags); 1303 atomic_dec(&lo->plh_outstanding); 1304 out_put_layout_hdr: 1305 pnfs_put_layout_hdr(lo); 1306 out: 1307 dprintk("%s: inode %s/%llu pNFS layout segment %s for " 1308 "(%s, offset: %llu, length: %llu)\n", 1309 __func__, ino->i_sb->s_id, 1310 (unsigned long long)NFS_FILEID(ino), 1311 lseg == NULL ? "not found" : "found", 1312 iomode==IOMODE_RW ? "read/write" : "read-only", 1313 (unsigned long long)pos, 1314 (unsigned long long)count); 1315 return lseg; 1316 out_unlock: 1317 spin_unlock(&ino->i_lock); 1318 goto out_put_layout_hdr; 1319 } 1320 EXPORT_SYMBOL_GPL(pnfs_update_layout); 1321 1322 struct pnfs_layout_segment * 1323 pnfs_layout_process(struct nfs4_layoutget *lgp) 1324 { 1325 struct pnfs_layout_hdr *lo = NFS_I(lgp->args.inode)->layout; 1326 struct nfs4_layoutget_res *res = &lgp->res; 1327 struct pnfs_layout_segment *lseg; 1328 struct inode *ino = lo->plh_inode; 1329 LIST_HEAD(free_me); 1330 int status = 0; 1331 1332 /* Inject layout blob into I/O device driver */ 1333 lseg = NFS_SERVER(ino)->pnfs_curr_ld->alloc_lseg(lo, res, lgp->gfp_flags); 1334 if (!lseg || IS_ERR(lseg)) { 1335 if (!lseg) 1336 status = -ENOMEM; 1337 else 1338 status = PTR_ERR(lseg); 1339 dprintk("%s: Could not allocate layout: error %d\n", 1340 __func__, status); 1341 goto out; 1342 } 1343 1344 spin_lock(&ino->i_lock); 1345 if (test_bit(NFS_LAYOUT_BULK_RECALL, &lo->plh_flags)) { 1346 dprintk("%s forget reply due to recall\n", __func__); 1347 goto out_forget_reply; 1348 } 1349 1350 if (pnfs_layoutgets_blocked(lo, 1) || 1351 pnfs_layout_stateid_blocked(lo, &res->stateid)) { 1352 dprintk("%s forget reply due to state\n", __func__); 1353 goto out_forget_reply; 1354 } 1355 1356 /* Check that the new stateid matches the old stateid */ 1357 pnfs_verify_layout_stateid(lo, &res->stateid, &free_me); 1358 /* Done processing layoutget. Set the layout stateid */ 1359 pnfs_set_layout_stateid(lo, &res->stateid, false); 1360 1361 init_lseg(lo, lseg); 1362 lseg->pls_range = res->range; 1363 pnfs_get_lseg(lseg); 1364 pnfs_layout_insert_lseg(lo, lseg); 1365 1366 if (res->return_on_close) { 1367 set_bit(NFS_LSEG_ROC, &lseg->pls_flags); 1368 set_bit(NFS_LAYOUT_ROC, &lo->plh_flags); 1369 } 1370 1371 spin_unlock(&ino->i_lock); 1372 pnfs_free_lseg_list(&free_me); 1373 return lseg; 1374 out: 1375 return ERR_PTR(status); 1376 1377 out_forget_reply: 1378 spin_unlock(&ino->i_lock); 1379 lseg->pls_layout = lo; 1380 NFS_SERVER(ino)->pnfs_curr_ld->free_lseg(lseg); 1381 goto out; 1382 } 1383 1384 void 1385 pnfs_generic_pg_init_read(struct nfs_pageio_descriptor *pgio, struct nfs_page *req) 1386 { 1387 u64 rd_size = req->wb_bytes; 1388 1389 WARN_ON_ONCE(pgio->pg_lseg != NULL); 1390 1391 if (req->wb_offset != req->wb_pgbase) { 1392 nfs_pageio_reset_read_mds(pgio); 1393 return; 1394 } 1395 1396 if (pgio->pg_dreq == NULL) 1397 rd_size = i_size_read(pgio->pg_inode) - req_offset(req); 1398 else 1399 rd_size = nfs_dreq_bytes_left(pgio->pg_dreq); 1400 1401 pgio->pg_lseg = pnfs_update_layout(pgio->pg_inode, 1402 req->wb_context, 1403 req_offset(req), 1404 rd_size, 1405 IOMODE_READ, 1406 GFP_KERNEL); 1407 /* If no lseg, fall back to read through mds */ 1408 if (pgio->pg_lseg == NULL) 1409 nfs_pageio_reset_read_mds(pgio); 1410 1411 } 1412 EXPORT_SYMBOL_GPL(pnfs_generic_pg_init_read); 1413 1414 void 1415 pnfs_generic_pg_init_write(struct nfs_pageio_descriptor *pgio, 1416 struct nfs_page *req, u64 wb_size) 1417 { 1418 WARN_ON_ONCE(pgio->pg_lseg != NULL); 1419 1420 if (req->wb_offset != req->wb_pgbase) { 1421 nfs_pageio_reset_write_mds(pgio); 1422 return; 1423 } 1424 1425 pgio->pg_lseg = pnfs_update_layout(pgio->pg_inode, 1426 req->wb_context, 1427 req_offset(req), 1428 wb_size, 1429 IOMODE_RW, 1430 GFP_NOFS); 1431 /* If no lseg, fall back to write through mds */ 1432 if (pgio->pg_lseg == NULL) 1433 nfs_pageio_reset_write_mds(pgio); 1434 } 1435 EXPORT_SYMBOL_GPL(pnfs_generic_pg_init_write); 1436 1437 void 1438 pnfs_pageio_init_read(struct nfs_pageio_descriptor *pgio, struct inode *inode, 1439 const struct nfs_pgio_completion_ops *compl_ops) 1440 { 1441 struct nfs_server *server = NFS_SERVER(inode); 1442 struct pnfs_layoutdriver_type *ld = server->pnfs_curr_ld; 1443 1444 if (ld == NULL) 1445 nfs_pageio_init_read(pgio, inode, compl_ops); 1446 else 1447 nfs_pageio_init(pgio, inode, ld->pg_read_ops, compl_ops, server->rsize, 0); 1448 } 1449 1450 void 1451 pnfs_pageio_init_write(struct nfs_pageio_descriptor *pgio, struct inode *inode, 1452 int ioflags, 1453 const struct nfs_pgio_completion_ops *compl_ops) 1454 { 1455 struct nfs_server *server = NFS_SERVER(inode); 1456 struct pnfs_layoutdriver_type *ld = server->pnfs_curr_ld; 1457 1458 if (ld == NULL) 1459 nfs_pageio_init_write(pgio, inode, ioflags, compl_ops); 1460 else 1461 nfs_pageio_init(pgio, inode, ld->pg_write_ops, compl_ops, server->wsize, ioflags); 1462 } 1463 1464 bool 1465 pnfs_generic_pg_test(struct nfs_pageio_descriptor *pgio, struct nfs_page *prev, 1466 struct nfs_page *req) 1467 { 1468 if (pgio->pg_lseg == NULL) 1469 return nfs_generic_pg_test(pgio, prev, req); 1470 1471 /* 1472 * Test if a nfs_page is fully contained in the pnfs_layout_range. 1473 * Note that this test makes several assumptions: 1474 * - that the previous nfs_page in the struct nfs_pageio_descriptor 1475 * is known to lie within the range. 1476 * - that the nfs_page being tested is known to be contiguous with the 1477 * previous nfs_page. 1478 * - Layout ranges are page aligned, so we only have to test the 1479 * start offset of the request. 1480 * 1481 * Please also note that 'end_offset' is actually the offset of the 1482 * first byte that lies outside the pnfs_layout_range. FIXME? 1483 * 1484 */ 1485 return req_offset(req) < end_offset(pgio->pg_lseg->pls_range.offset, 1486 pgio->pg_lseg->pls_range.length); 1487 } 1488 EXPORT_SYMBOL_GPL(pnfs_generic_pg_test); 1489 1490 int pnfs_write_done_resend_to_mds(struct inode *inode, 1491 struct list_head *head, 1492 const struct nfs_pgio_completion_ops *compl_ops, 1493 struct nfs_direct_req *dreq) 1494 { 1495 struct nfs_pageio_descriptor pgio; 1496 LIST_HEAD(failed); 1497 1498 /* Resend all requests through the MDS */ 1499 nfs_pageio_init_write(&pgio, inode, FLUSH_STABLE, compl_ops); 1500 pgio.pg_dreq = dreq; 1501 while (!list_empty(head)) { 1502 struct nfs_page *req = nfs_list_entry(head->next); 1503 1504 nfs_list_remove_request(req); 1505 if (!nfs_pageio_add_request(&pgio, req)) 1506 nfs_list_add_request(req, &failed); 1507 } 1508 nfs_pageio_complete(&pgio); 1509 1510 if (!list_empty(&failed)) { 1511 /* For some reason our attempt to resend pages. Mark the 1512 * overall send request as having failed, and let 1513 * nfs_writeback_release_full deal with the error. 1514 */ 1515 list_move(&failed, head); 1516 return -EIO; 1517 } 1518 return 0; 1519 } 1520 EXPORT_SYMBOL_GPL(pnfs_write_done_resend_to_mds); 1521 1522 static void pnfs_ld_handle_write_error(struct nfs_write_data *data) 1523 { 1524 struct nfs_pgio_header *hdr = data->header; 1525 1526 dprintk("pnfs write error = %d\n", hdr->pnfs_error); 1527 if (NFS_SERVER(hdr->inode)->pnfs_curr_ld->flags & 1528 PNFS_LAYOUTRET_ON_ERROR) { 1529 pnfs_return_layout(hdr->inode); 1530 } 1531 if (!test_and_set_bit(NFS_IOHDR_REDO, &hdr->flags)) 1532 data->task.tk_status = pnfs_write_done_resend_to_mds(hdr->inode, 1533 &hdr->pages, 1534 hdr->completion_ops, 1535 hdr->dreq); 1536 } 1537 1538 /* 1539 * Called by non rpc-based layout drivers 1540 */ 1541 void pnfs_ld_write_done(struct nfs_write_data *data) 1542 { 1543 struct nfs_pgio_header *hdr = data->header; 1544 1545 trace_nfs4_pnfs_write(data, hdr->pnfs_error); 1546 if (!hdr->pnfs_error) { 1547 pnfs_set_layoutcommit(data); 1548 hdr->mds_ops->rpc_call_done(&data->task, data); 1549 } else 1550 pnfs_ld_handle_write_error(data); 1551 hdr->mds_ops->rpc_release(data); 1552 } 1553 EXPORT_SYMBOL_GPL(pnfs_ld_write_done); 1554 1555 static void 1556 pnfs_write_through_mds(struct nfs_pageio_descriptor *desc, 1557 struct nfs_write_data *data) 1558 { 1559 struct nfs_pgio_header *hdr = data->header; 1560 1561 if (!test_and_set_bit(NFS_IOHDR_REDO, &hdr->flags)) { 1562 list_splice_tail_init(&hdr->pages, &desc->pg_list); 1563 nfs_pageio_reset_write_mds(desc); 1564 desc->pg_recoalesce = 1; 1565 } 1566 nfs_writedata_release(data); 1567 } 1568 1569 static enum pnfs_try_status 1570 pnfs_try_to_write_data(struct nfs_write_data *wdata, 1571 const struct rpc_call_ops *call_ops, 1572 struct pnfs_layout_segment *lseg, 1573 int how) 1574 { 1575 struct nfs_pgio_header *hdr = wdata->header; 1576 struct inode *inode = hdr->inode; 1577 enum pnfs_try_status trypnfs; 1578 struct nfs_server *nfss = NFS_SERVER(inode); 1579 1580 hdr->mds_ops = call_ops; 1581 1582 dprintk("%s: Writing ino:%lu %u@%llu (how %d)\n", __func__, 1583 inode->i_ino, wdata->args.count, wdata->args.offset, how); 1584 trypnfs = nfss->pnfs_curr_ld->write_pagelist(wdata, how); 1585 if (trypnfs != PNFS_NOT_ATTEMPTED) 1586 nfs_inc_stats(inode, NFSIOS_PNFS_WRITE); 1587 dprintk("%s End (trypnfs:%d)\n", __func__, trypnfs); 1588 return trypnfs; 1589 } 1590 1591 static void 1592 pnfs_do_multiple_writes(struct nfs_pageio_descriptor *desc, struct list_head *head, int how) 1593 { 1594 struct nfs_write_data *data; 1595 const struct rpc_call_ops *call_ops = desc->pg_rpc_callops; 1596 struct pnfs_layout_segment *lseg = desc->pg_lseg; 1597 1598 desc->pg_lseg = NULL; 1599 while (!list_empty(head)) { 1600 enum pnfs_try_status trypnfs; 1601 1602 data = list_first_entry(head, struct nfs_write_data, list); 1603 list_del_init(&data->list); 1604 1605 trypnfs = pnfs_try_to_write_data(data, call_ops, lseg, how); 1606 if (trypnfs == PNFS_NOT_ATTEMPTED) 1607 pnfs_write_through_mds(desc, data); 1608 } 1609 pnfs_put_lseg(lseg); 1610 } 1611 1612 static void pnfs_writehdr_free(struct nfs_pgio_header *hdr) 1613 { 1614 pnfs_put_lseg(hdr->lseg); 1615 nfs_writehdr_free(hdr); 1616 } 1617 EXPORT_SYMBOL_GPL(pnfs_writehdr_free); 1618 1619 int 1620 pnfs_generic_pg_writepages(struct nfs_pageio_descriptor *desc) 1621 { 1622 struct nfs_write_header *whdr; 1623 struct nfs_pgio_header *hdr; 1624 int ret; 1625 1626 whdr = nfs_writehdr_alloc(); 1627 if (!whdr) { 1628 desc->pg_completion_ops->error_cleanup(&desc->pg_list); 1629 pnfs_put_lseg(desc->pg_lseg); 1630 desc->pg_lseg = NULL; 1631 return -ENOMEM; 1632 } 1633 hdr = &whdr->header; 1634 nfs_pgheader_init(desc, hdr, pnfs_writehdr_free); 1635 hdr->lseg = pnfs_get_lseg(desc->pg_lseg); 1636 atomic_inc(&hdr->refcnt); 1637 ret = nfs_generic_flush(desc, hdr); 1638 if (ret != 0) { 1639 pnfs_put_lseg(desc->pg_lseg); 1640 desc->pg_lseg = NULL; 1641 } else 1642 pnfs_do_multiple_writes(desc, &hdr->rpc_list, desc->pg_ioflags); 1643 if (atomic_dec_and_test(&hdr->refcnt)) 1644 hdr->completion_ops->completion(hdr); 1645 return ret; 1646 } 1647 EXPORT_SYMBOL_GPL(pnfs_generic_pg_writepages); 1648 1649 int pnfs_read_done_resend_to_mds(struct inode *inode, 1650 struct list_head *head, 1651 const struct nfs_pgio_completion_ops *compl_ops, 1652 struct nfs_direct_req *dreq) 1653 { 1654 struct nfs_pageio_descriptor pgio; 1655 LIST_HEAD(failed); 1656 1657 /* Resend all requests through the MDS */ 1658 nfs_pageio_init_read(&pgio, inode, compl_ops); 1659 pgio.pg_dreq = dreq; 1660 while (!list_empty(head)) { 1661 struct nfs_page *req = nfs_list_entry(head->next); 1662 1663 nfs_list_remove_request(req); 1664 if (!nfs_pageio_add_request(&pgio, req)) 1665 nfs_list_add_request(req, &failed); 1666 } 1667 nfs_pageio_complete(&pgio); 1668 1669 if (!list_empty(&failed)) { 1670 list_move(&failed, head); 1671 return -EIO; 1672 } 1673 return 0; 1674 } 1675 EXPORT_SYMBOL_GPL(pnfs_read_done_resend_to_mds); 1676 1677 static void pnfs_ld_handle_read_error(struct nfs_read_data *data) 1678 { 1679 struct nfs_pgio_header *hdr = data->header; 1680 1681 dprintk("pnfs read error = %d\n", hdr->pnfs_error); 1682 if (NFS_SERVER(hdr->inode)->pnfs_curr_ld->flags & 1683 PNFS_LAYOUTRET_ON_ERROR) { 1684 pnfs_return_layout(hdr->inode); 1685 } 1686 if (!test_and_set_bit(NFS_IOHDR_REDO, &hdr->flags)) 1687 data->task.tk_status = pnfs_read_done_resend_to_mds(hdr->inode, 1688 &hdr->pages, 1689 hdr->completion_ops, 1690 hdr->dreq); 1691 } 1692 1693 /* 1694 * Called by non rpc-based layout drivers 1695 */ 1696 void pnfs_ld_read_done(struct nfs_read_data *data) 1697 { 1698 struct nfs_pgio_header *hdr = data->header; 1699 1700 trace_nfs4_pnfs_read(data, hdr->pnfs_error); 1701 if (likely(!hdr->pnfs_error)) { 1702 __nfs4_read_done_cb(data); 1703 hdr->mds_ops->rpc_call_done(&data->task, data); 1704 } else 1705 pnfs_ld_handle_read_error(data); 1706 hdr->mds_ops->rpc_release(data); 1707 } 1708 EXPORT_SYMBOL_GPL(pnfs_ld_read_done); 1709 1710 static void 1711 pnfs_read_through_mds(struct nfs_pageio_descriptor *desc, 1712 struct nfs_read_data *data) 1713 { 1714 struct nfs_pgio_header *hdr = data->header; 1715 1716 if (!test_and_set_bit(NFS_IOHDR_REDO, &hdr->flags)) { 1717 list_splice_tail_init(&hdr->pages, &desc->pg_list); 1718 nfs_pageio_reset_read_mds(desc); 1719 desc->pg_recoalesce = 1; 1720 } 1721 nfs_readdata_release(data); 1722 } 1723 1724 /* 1725 * Call the appropriate parallel I/O subsystem read function. 1726 */ 1727 static enum pnfs_try_status 1728 pnfs_try_to_read_data(struct nfs_read_data *rdata, 1729 const struct rpc_call_ops *call_ops, 1730 struct pnfs_layout_segment *lseg) 1731 { 1732 struct nfs_pgio_header *hdr = rdata->header; 1733 struct inode *inode = hdr->inode; 1734 struct nfs_server *nfss = NFS_SERVER(inode); 1735 enum pnfs_try_status trypnfs; 1736 1737 hdr->mds_ops = call_ops; 1738 1739 dprintk("%s: Reading ino:%lu %u@%llu\n", 1740 __func__, inode->i_ino, rdata->args.count, rdata->args.offset); 1741 1742 trypnfs = nfss->pnfs_curr_ld->read_pagelist(rdata); 1743 if (trypnfs != PNFS_NOT_ATTEMPTED) 1744 nfs_inc_stats(inode, NFSIOS_PNFS_READ); 1745 dprintk("%s End (trypnfs:%d)\n", __func__, trypnfs); 1746 return trypnfs; 1747 } 1748 1749 static void 1750 pnfs_do_multiple_reads(struct nfs_pageio_descriptor *desc, struct list_head *head) 1751 { 1752 struct nfs_read_data *data; 1753 const struct rpc_call_ops *call_ops = desc->pg_rpc_callops; 1754 struct pnfs_layout_segment *lseg = desc->pg_lseg; 1755 1756 desc->pg_lseg = NULL; 1757 while (!list_empty(head)) { 1758 enum pnfs_try_status trypnfs; 1759 1760 data = list_first_entry(head, struct nfs_read_data, list); 1761 list_del_init(&data->list); 1762 1763 trypnfs = pnfs_try_to_read_data(data, call_ops, lseg); 1764 if (trypnfs == PNFS_NOT_ATTEMPTED) 1765 pnfs_read_through_mds(desc, data); 1766 } 1767 pnfs_put_lseg(lseg); 1768 } 1769 1770 static void pnfs_readhdr_free(struct nfs_pgio_header *hdr) 1771 { 1772 pnfs_put_lseg(hdr->lseg); 1773 nfs_readhdr_free(hdr); 1774 } 1775 EXPORT_SYMBOL_GPL(pnfs_readhdr_free); 1776 1777 int 1778 pnfs_generic_pg_readpages(struct nfs_pageio_descriptor *desc) 1779 { 1780 struct nfs_read_header *rhdr; 1781 struct nfs_pgio_header *hdr; 1782 int ret; 1783 1784 rhdr = nfs_readhdr_alloc(); 1785 if (!rhdr) { 1786 desc->pg_completion_ops->error_cleanup(&desc->pg_list); 1787 ret = -ENOMEM; 1788 pnfs_put_lseg(desc->pg_lseg); 1789 desc->pg_lseg = NULL; 1790 return ret; 1791 } 1792 hdr = &rhdr->header; 1793 nfs_pgheader_init(desc, hdr, pnfs_readhdr_free); 1794 hdr->lseg = pnfs_get_lseg(desc->pg_lseg); 1795 atomic_inc(&hdr->refcnt); 1796 ret = nfs_generic_pagein(desc, hdr); 1797 if (ret != 0) { 1798 pnfs_put_lseg(desc->pg_lseg); 1799 desc->pg_lseg = NULL; 1800 } else 1801 pnfs_do_multiple_reads(desc, &hdr->rpc_list); 1802 if (atomic_dec_and_test(&hdr->refcnt)) 1803 hdr->completion_ops->completion(hdr); 1804 return ret; 1805 } 1806 EXPORT_SYMBOL_GPL(pnfs_generic_pg_readpages); 1807 1808 static void pnfs_clear_layoutcommitting(struct inode *inode) 1809 { 1810 unsigned long *bitlock = &NFS_I(inode)->flags; 1811 1812 clear_bit_unlock(NFS_INO_LAYOUTCOMMITTING, bitlock); 1813 smp_mb__after_clear_bit(); 1814 wake_up_bit(bitlock, NFS_INO_LAYOUTCOMMITTING); 1815 } 1816 1817 /* 1818 * There can be multiple RW segments. 1819 */ 1820 static void pnfs_list_write_lseg(struct inode *inode, struct list_head *listp) 1821 { 1822 struct pnfs_layout_segment *lseg; 1823 1824 list_for_each_entry(lseg, &NFS_I(inode)->layout->plh_segs, pls_list) { 1825 if (lseg->pls_range.iomode == IOMODE_RW && 1826 test_and_clear_bit(NFS_LSEG_LAYOUTCOMMIT, &lseg->pls_flags)) 1827 list_add(&lseg->pls_lc_list, listp); 1828 } 1829 } 1830 1831 static void pnfs_list_write_lseg_done(struct inode *inode, struct list_head *listp) 1832 { 1833 struct pnfs_layout_segment *lseg, *tmp; 1834 1835 /* Matched by references in pnfs_set_layoutcommit */ 1836 list_for_each_entry_safe(lseg, tmp, listp, pls_lc_list) { 1837 list_del_init(&lseg->pls_lc_list); 1838 pnfs_put_lseg(lseg); 1839 } 1840 1841 pnfs_clear_layoutcommitting(inode); 1842 } 1843 1844 void pnfs_set_lo_fail(struct pnfs_layout_segment *lseg) 1845 { 1846 pnfs_layout_io_set_failed(lseg->pls_layout, lseg->pls_range.iomode); 1847 } 1848 EXPORT_SYMBOL_GPL(pnfs_set_lo_fail); 1849 1850 void 1851 pnfs_set_layoutcommit(struct nfs_write_data *wdata) 1852 { 1853 struct nfs_pgio_header *hdr = wdata->header; 1854 struct inode *inode = hdr->inode; 1855 struct nfs_inode *nfsi = NFS_I(inode); 1856 loff_t end_pos = wdata->mds_offset + wdata->res.count; 1857 bool mark_as_dirty = false; 1858 1859 spin_lock(&inode->i_lock); 1860 if (!test_and_set_bit(NFS_INO_LAYOUTCOMMIT, &nfsi->flags)) { 1861 mark_as_dirty = true; 1862 dprintk("%s: Set layoutcommit for inode %lu ", 1863 __func__, inode->i_ino); 1864 } 1865 if (!test_and_set_bit(NFS_LSEG_LAYOUTCOMMIT, &hdr->lseg->pls_flags)) { 1866 /* references matched in nfs4_layoutcommit_release */ 1867 pnfs_get_lseg(hdr->lseg); 1868 } 1869 if (end_pos > nfsi->layout->plh_lwb) 1870 nfsi->layout->plh_lwb = end_pos; 1871 spin_unlock(&inode->i_lock); 1872 dprintk("%s: lseg %p end_pos %llu\n", 1873 __func__, hdr->lseg, nfsi->layout->plh_lwb); 1874 1875 /* if pnfs_layoutcommit_inode() runs between inode locks, the next one 1876 * will be a noop because NFS_INO_LAYOUTCOMMIT will not be set */ 1877 if (mark_as_dirty) 1878 mark_inode_dirty_sync(inode); 1879 } 1880 EXPORT_SYMBOL_GPL(pnfs_set_layoutcommit); 1881 1882 void pnfs_cleanup_layoutcommit(struct nfs4_layoutcommit_data *data) 1883 { 1884 struct nfs_server *nfss = NFS_SERVER(data->args.inode); 1885 1886 if (nfss->pnfs_curr_ld->cleanup_layoutcommit) 1887 nfss->pnfs_curr_ld->cleanup_layoutcommit(data); 1888 pnfs_list_write_lseg_done(data->args.inode, &data->lseg_list); 1889 } 1890 1891 /* 1892 * For the LAYOUT4_NFSV4_1_FILES layout type, NFS_DATA_SYNC WRITEs and 1893 * NFS_UNSTABLE WRITEs with a COMMIT to data servers must store enough 1894 * data to disk to allow the server to recover the data if it crashes. 1895 * LAYOUTCOMMIT is only needed when the NFL4_UFLG_COMMIT_THRU_MDS flag 1896 * is off, and a COMMIT is sent to a data server, or 1897 * if WRITEs to a data server return NFS_DATA_SYNC. 1898 */ 1899 int 1900 pnfs_layoutcommit_inode(struct inode *inode, bool sync) 1901 { 1902 struct nfs4_layoutcommit_data *data; 1903 struct nfs_inode *nfsi = NFS_I(inode); 1904 loff_t end_pos; 1905 int status; 1906 1907 if (!pnfs_layoutcommit_outstanding(inode)) 1908 return 0; 1909 1910 dprintk("--> %s inode %lu\n", __func__, inode->i_ino); 1911 1912 status = -EAGAIN; 1913 if (test_and_set_bit(NFS_INO_LAYOUTCOMMITTING, &nfsi->flags)) { 1914 if (!sync) 1915 goto out; 1916 status = wait_on_bit_lock(&nfsi->flags, 1917 NFS_INO_LAYOUTCOMMITTING, 1918 nfs_wait_bit_killable, 1919 TASK_KILLABLE); 1920 if (status) 1921 goto out; 1922 } 1923 1924 status = -ENOMEM; 1925 /* Note kzalloc ensures data->res.seq_res.sr_slot == NULL */ 1926 data = kzalloc(sizeof(*data), GFP_NOFS); 1927 if (!data) 1928 goto clear_layoutcommitting; 1929 1930 status = 0; 1931 spin_lock(&inode->i_lock); 1932 if (!test_and_clear_bit(NFS_INO_LAYOUTCOMMIT, &nfsi->flags)) 1933 goto out_unlock; 1934 1935 INIT_LIST_HEAD(&data->lseg_list); 1936 pnfs_list_write_lseg(inode, &data->lseg_list); 1937 1938 end_pos = nfsi->layout->plh_lwb; 1939 nfsi->layout->plh_lwb = 0; 1940 1941 nfs4_stateid_copy(&data->args.stateid, &nfsi->layout->plh_stateid); 1942 spin_unlock(&inode->i_lock); 1943 1944 data->args.inode = inode; 1945 data->cred = get_rpccred(nfsi->layout->plh_lc_cred); 1946 nfs_fattr_init(&data->fattr); 1947 data->args.bitmask = NFS_SERVER(inode)->cache_consistency_bitmask; 1948 data->res.fattr = &data->fattr; 1949 data->args.lastbytewritten = end_pos - 1; 1950 data->res.server = NFS_SERVER(inode); 1951 1952 status = nfs4_proc_layoutcommit(data, sync); 1953 out: 1954 if (status) 1955 mark_inode_dirty_sync(inode); 1956 dprintk("<-- %s status %d\n", __func__, status); 1957 return status; 1958 out_unlock: 1959 spin_unlock(&inode->i_lock); 1960 kfree(data); 1961 clear_layoutcommitting: 1962 pnfs_clear_layoutcommitting(inode); 1963 goto out; 1964 } 1965 1966 struct nfs4_threshold *pnfs_mdsthreshold_alloc(void) 1967 { 1968 struct nfs4_threshold *thp; 1969 1970 thp = kzalloc(sizeof(*thp), GFP_NOFS); 1971 if (!thp) { 1972 dprintk("%s mdsthreshold allocation failed\n", __func__); 1973 return NULL; 1974 } 1975 return thp; 1976 } 1977