Changeset b5e68c8 in mainline for uspace/srv/fs/fat/fat_fat.c
- Timestamp:
- 2011-05-12T16:49:44Z (14 years ago)
- Branches:
- lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
- Children:
- f36787d7
- Parents:
- e80329d6 (diff), 750636a (diff)
Note: this is a merge changeset, the changes displayed below correspond to the merge itself.
Use the(diff)
links above to see all the changes relative to each parent. - File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
uspace/srv/fs/fat/fat_fat.c
re80329d6 rb5e68c8 47 47 #include <assert.h> 48 48 #include <fibril_synch.h> 49 #include <malloc.h> 49 50 #include <mem.h> 50 51 … … 70 71 * 71 72 * @param bs Buffer holding the boot sector for the file. 72 * @param dev _handle Device handle of the device with the file.73 * @param devmap_handle Device handle of the device with the file. 73 74 * @param firstc First cluster to start the walk with. 74 75 * @param lastc If non-NULL, output argument hodling the last cluster … … 81 82 */ 82 83 int 83 fat_cluster_walk(fat_bs_t *bs, dev _handle_t dev_handle, fat_cluster_t firstc,84 fat_cluster_walk(fat_bs_t *bs, devmap_handle_t devmap_handle, fat_cluster_t firstc, 84 85 fat_cluster_t *lastc, uint16_t *numc, uint16_t max_clusters) 85 86 { … … 108 109 fidx = clst % (BPS(bs) / sizeof(fat_cluster_t)); 109 110 /* read FAT1 */ 110 rc = block_get(&b, dev _handle, RSCNT(bs) + fsec,111 rc = block_get(&b, devmap_handle, RSCNT(bs) + fsec, 111 112 BLOCK_FLAGS_NONE); 112 113 if (rc != EOK) … … 159 160 * when fortunately we have the last cluster number cached. 160 161 */ 161 return block_get(block, nodep->idx->dev _handle,162 return block_get(block, nodep->idx->devmap_handle, 162 163 CLBN2PBN(bs, nodep->lastc_cached_value, bn), flags); 163 164 } … … 173 174 174 175 fall_through: 175 rc = _fat_block_get(block, bs, nodep->idx->dev _handle, firstc,176 rc = _fat_block_get(block, bs, nodep->idx->devmap_handle, firstc, 176 177 &currc, relbn, flags); 177 178 if (rc != EOK) … … 192 193 * @param block Pointer to a block pointer for storing result. 193 194 * @param bs Buffer holding the boot sector of the file system. 194 * @param dev _handle Device handle of the file system.195 * @param devmap_handle Device handle of the file system. 195 196 * @param fcl First cluster used by the file. Can be zero if the file 196 197 * is empty. … … 204 205 */ 205 206 int 206 _fat_block_get(block_t **block, fat_bs_t *bs, dev _handle_t dev_handle,207 _fat_block_get(block_t **block, fat_bs_t *bs, devmap_handle_t devmap_handle, 207 208 fat_cluster_t fcl, fat_cluster_t *clp, aoff64_t bn, int flags) 208 209 { … … 221 222 /* root directory special case */ 222 223 assert(bn < RDS(bs)); 223 rc = block_get(block, dev _handle,224 rc = block_get(block, devmap_handle, 224 225 RSCNT(bs) + FATCNT(bs) * SF(bs) + bn, flags); 225 226 return rc; … … 227 228 228 229 max_clusters = bn / SPC(bs); 229 rc = fat_cluster_walk(bs, dev _handle, fcl, &c, &clusters, max_clusters);230 rc = fat_cluster_walk(bs, devmap_handle, fcl, &c, &clusters, max_clusters); 230 231 if (rc != EOK) 231 232 return rc; 232 233 assert(clusters == max_clusters); 233 234 234 rc = block_get(block, dev _handle, CLBN2PBN(bs, c, bn), flags);235 rc = block_get(block, devmap_handle, CLBN2PBN(bs, c, bn), flags); 235 236 236 237 if (clp) … … 280 281 /* zero out the initial part of the new cluster chain */ 281 282 for (o = boundary; o < pos; o += BPS(bs)) { 282 rc = _fat_block_get(&b, bs, nodep->idx->dev _handle, mcl,283 rc = _fat_block_get(&b, bs, nodep->idx->devmap_handle, mcl, 283 284 NULL, (o - boundary) / BPS(bs), BLOCK_FLAGS_NOREAD); 284 285 if (rc != EOK) … … 297 298 * 298 299 * @param bs Buffer holding the boot sector for the file system. 299 * @param dev _handle Device handle for the file system.300 * @param devmap_handle Device handle for the file system. 300 301 * @param clst Cluster which to get. 301 302 * @param value Output argument holding the value of the cluster. … … 304 305 */ 305 306 int 306 fat_get_cluster(fat_bs_t *bs, dev _handle_t dev_handle, unsigned fatno,307 fat_get_cluster(fat_bs_t *bs, devmap_handle_t devmap_handle, unsigned fatno, 307 308 fat_cluster_t clst, fat_cluster_t *value) 308 309 { … … 311 312 int rc; 312 313 313 rc = block_get(&b, dev _handle, RSCNT(bs) + SF(bs) * fatno +314 rc = block_get(&b, devmap_handle, RSCNT(bs) + SF(bs) * fatno + 314 315 (clst * sizeof(fat_cluster_t)) / BPS(bs), BLOCK_FLAGS_NONE); 315 316 if (rc != EOK) … … 326 327 * 327 328 * @param bs Buffer holding the boot sector for the file system. 328 * @param dev _handle Device handle for the file system.329 * @param devmap_handle Device handle for the file system. 329 330 * @param fatno Number of the FAT instance where to make the change. 330 331 * @param clst Cluster which is to be set. … … 334 335 */ 335 336 int 336 fat_set_cluster(fat_bs_t *bs, dev _handle_t dev_handle, unsigned fatno,337 fat_set_cluster(fat_bs_t *bs, devmap_handle_t devmap_handle, unsigned fatno, 337 338 fat_cluster_t clst, fat_cluster_t value) 338 339 { … … 342 343 343 344 assert(fatno < FATCNT(bs)); 344 rc = block_get(&b, dev _handle, RSCNT(bs) + SF(bs) * fatno +345 rc = block_get(&b, devmap_handle, RSCNT(bs) + SF(bs) * fatno + 345 346 (clst * sizeof(fat_cluster_t)) / BPS(bs), BLOCK_FLAGS_NONE); 346 347 if (rc != EOK) … … 357 358 * 358 359 * @param bs Buffer holding the boot sector of the file system. 359 * @param dev _handle Device handle of the file system.360 * @param devmap_handle Device handle of the file system. 360 361 * @param lifo Chain of allocated clusters. 361 362 * @param nclsts Number of clusters in the lifo chain. … … 363 364 * @return EOK on success or a negative error code. 364 365 */ 365 int fat_alloc_shadow_clusters(fat_bs_t *bs, dev _handle_t dev_handle,366 int fat_alloc_shadow_clusters(fat_bs_t *bs, devmap_handle_t devmap_handle, 366 367 fat_cluster_t *lifo, unsigned nclsts) 367 368 { … … 372 373 for (fatno = FAT1 + 1; fatno < bs->fatcnt; fatno++) { 373 374 for (c = 0; c < nclsts; c++) { 374 rc = fat_set_cluster(bs, dev _handle, fatno, lifo[c],375 rc = fat_set_cluster(bs, devmap_handle, fatno, lifo[c], 375 376 c == 0 ? FAT_CLST_LAST1 : lifo[c - 1]); 376 377 if (rc != EOK) … … 390 391 * 391 392 * @param bs Buffer holding the boot sector of the file system. 392 * @param dev _handle Device handle of the file system.393 * @param devmap_handle Device handle of the file system. 393 394 * @param nclsts Number of clusters to allocate. 394 395 * @param mcl Output parameter where the first cluster in the chain … … 400 401 */ 401 402 int 402 fat_alloc_clusters(fat_bs_t *bs, dev _handle_t dev_handle, unsigned nclsts,403 fat_alloc_clusters(fat_bs_t *bs, devmap_handle_t devmap_handle, unsigned nclsts, 403 404 fat_cluster_t *mcl, fat_cluster_t *lcl) 404 405 { … … 418 419 fibril_mutex_lock(&fat_alloc_lock); 419 420 for (b = 0, cl = 0; b < SF(bs); b++) { 420 rc = block_get(&blk, dev _handle, RSCNT(bs) + b,421 rc = block_get(&blk, devmap_handle, RSCNT(bs) + b, 421 422 BLOCK_FLAGS_NONE); 422 423 if (rc != EOK) … … 457 458 /* update the shadow copies of FAT */ 458 459 rc = fat_alloc_shadow_clusters(bs, 459 dev _handle, lifo, nclsts);460 devmap_handle, lifo, nclsts); 460 461 if (rc != EOK) 461 462 goto error; … … 484 485 */ 485 486 while (found--) { 486 rc = fat_set_cluster(bs, dev _handle, FAT1, lifo[found],487 rc = fat_set_cluster(bs, devmap_handle, FAT1, lifo[found], 487 488 FAT_CLST_RES0); 488 489 if (rc != EOK) { … … 499 500 * 500 501 * @param bs Buffer hodling the boot sector of the file system. 501 * @param dev _handle Device handle of the file system.502 * @param devmap_handle Device handle of the file system. 502 503 * @param firstc First cluster in the chain which is to be freed. 503 504 * … … 505 506 */ 506 507 int 507 fat_free_clusters(fat_bs_t *bs, dev _handle_t dev_handle, fat_cluster_t firstc)508 fat_free_clusters(fat_bs_t *bs, devmap_handle_t devmap_handle, fat_cluster_t firstc) 508 509 { 509 510 unsigned fatno; … … 514 515 while (firstc < FAT_CLST_LAST1) { 515 516 assert(firstc >= FAT_CLST_FIRST && firstc < FAT_CLST_BAD); 516 rc = fat_get_cluster(bs, dev _handle, FAT1, firstc, &nextc);517 rc = fat_get_cluster(bs, devmap_handle, FAT1, firstc, &nextc); 517 518 if (rc != EOK) 518 519 return rc; 519 520 for (fatno = FAT1; fatno < bs->fatcnt; fatno++) { 520 rc = fat_set_cluster(bs, dev _handle, fatno, firstc,521 rc = fat_set_cluster(bs, devmap_handle, fatno, firstc, 521 522 FAT_CLST_RES0); 522 523 if (rc != EOK) … … 543 544 fat_cluster_t lcl) 544 545 { 545 dev _handle_t dev_handle = nodep->idx->dev_handle;546 devmap_handle_t devmap_handle = nodep->idx->devmap_handle; 546 547 fat_cluster_t lastc; 547 548 uint8_t fatno; … … 557 558 nodep->lastc_cached_valid = false; 558 559 } else { 559 rc = fat_cluster_walk(bs, dev _handle, nodep->firstc,560 rc = fat_cluster_walk(bs, devmap_handle, nodep->firstc, 560 561 &lastc, NULL, (uint16_t) -1); 561 562 if (rc != EOK) … … 564 565 565 566 for (fatno = FAT1; fatno < bs->fatcnt; fatno++) { 566 rc = fat_set_cluster(bs, nodep->idx->dev _handle, fatno,567 rc = fat_set_cluster(bs, nodep->idx->devmap_handle, fatno, 567 568 lastc, mcl); 568 569 if (rc != EOK) … … 590 591 { 591 592 int rc; 592 dev _handle_t dev_handle = nodep->idx->dev_handle;593 devmap_handle_t devmap_handle = nodep->idx->devmap_handle; 593 594 594 595 /* … … 601 602 if (lcl == FAT_CLST_RES0) { 602 603 /* The node will have zero size and no clusters allocated. */ 603 rc = fat_free_clusters(bs, dev _handle, nodep->firstc);604 rc = fat_free_clusters(bs, devmap_handle, nodep->firstc); 604 605 if (rc != EOK) 605 606 return rc; … … 610 611 unsigned fatno; 611 612 612 rc = fat_get_cluster(bs, dev _handle, FAT1, lcl, &nextc);613 rc = fat_get_cluster(bs, devmap_handle, FAT1, lcl, &nextc); 613 614 if (rc != EOK) 614 615 return rc; … … 616 617 /* Terminate the cluster chain in all copies of FAT. */ 617 618 for (fatno = FAT1; fatno < bs->fatcnt; fatno++) { 618 rc = fat_set_cluster(bs, dev _handle, fatno, lcl,619 rc = fat_set_cluster(bs, devmap_handle, fatno, lcl, 619 620 FAT_CLST_LAST1); 620 621 if (rc != EOK) … … 623 624 624 625 /* Free all following clusters. */ 625 rc = fat_free_clusters(bs, dev _handle, nextc);626 rc = fat_free_clusters(bs, devmap_handle, nextc); 626 627 if (rc != EOK) 627 628 return rc; … … 638 639 639 640 int 640 fat_zero_cluster(struct fat_bs *bs, dev _handle_t dev_handle, fat_cluster_t c)641 fat_zero_cluster(struct fat_bs *bs, devmap_handle_t devmap_handle, fat_cluster_t c) 641 642 { 642 643 int i; … … 645 646 646 647 for (i = 0; i < SPC(bs); i++) { 647 rc = _fat_block_get(&b, bs, dev _handle, c, NULL, i,648 rc = _fat_block_get(&b, bs, devmap_handle, c, NULL, i, 648 649 BLOCK_FLAGS_NOREAD); 649 650 if (rc != EOK) … … 665 666 * does not contain a fat file system. 666 667 */ 667 int fat_sanity_check(fat_bs_t *bs, dev _handle_t dev_handle)668 int fat_sanity_check(fat_bs_t *bs, devmap_handle_t devmap_handle) 668 669 { 669 670 fat_cluster_t e0, e1; … … 706 707 707 708 for (fat_no = 0; fat_no < bs->fatcnt; fat_no++) { 708 rc = fat_get_cluster(bs, dev _handle, fat_no, 0, &e0);709 rc = fat_get_cluster(bs, devmap_handle, fat_no, 0, &e0); 709 710 if (rc != EOK) 710 711 return EIO; 711 712 712 rc = fat_get_cluster(bs, dev _handle, fat_no, 1, &e1);713 rc = fat_get_cluster(bs, devmap_handle, fat_no, 1, &e1); 713 714 if (rc != EOK) 714 715 return EIO;
Note:
See TracChangeset
for help on using the changeset viewer.