return err;
}
-static inline void ufs_put_page(struct page *page)
-{
- kunmap(page);
- put_page(page);
-}
-
ino_t ufs_inode_by_name(struct inode *dir, const struct qstr *qstr)
{
ino_t res = 0;
de = ufs_find_entry(dir, qstr, &folio);
if (de) {
res = fs32_to_cpu(dir->i_sb, de->d_ino);
- ufs_put_page(&folio->page);
+ folio_release_kmap(folio, de);
}
return res;
}
ufs_set_de_type(dir->i_sb, de, inode->i_mode);
ufs_commit_chunk(folio, pos, len);
- ufs_put_page(&folio->page);
+ folio_release_kmap(folio, de);
if (update_times)
inode_set_mtime_to_ts(dir, inode_set_ctime_current(dir));
mark_inode_dirty(dir);
if (IS_ERR(folio))
return ERR_CAST(folio);
- kaddr = kmap(&folio->page);
+ kaddr = kmap_local_folio(folio, 0);
if (unlikely(!folio_test_checked(folio))) {
if (!ufs_check_folio(folio, kaddr))
goto fail;
return kaddr;
fail:
- ufs_put_page(&folio->page);
+ folio_release_kmap(folio, kaddr);
return ERR_PTR(-EIO);
}
goto found;
de = ufs_next_entry(sb, de);
}
- ufs_put_page(&(*foliop)->page);
+ folio_release_kmap(*foliop, kaddr);
}
if (++n >= npages)
n = 0;
de = (struct ufs_dir_entry *) ((char *) de + rec_len);
}
folio_unlock(folio);
- ufs_put_page(&folio->page);
+ folio_release_kmap(folio, kaddr);
}
BUG();
return -EINVAL;
err = ufs_handle_dirsync(dir);
/* OFFSET_CACHE */
out_put:
- ufs_put_page(&folio->page);
+ folio_release_kmap(folio, de);
return err;
out_unlock:
folio_unlock(folio);
ufs_get_de_namlen(sb, de),
fs32_to_cpu(sb, de->d_ino),
d_type)) {
- ufs_put_page(&folio->page);
+ folio_release_kmap(folio, de);
return 0;
}
}
ctx->pos += fs16_to_cpu(sb, de->d_reclen);
}
- ufs_put_page(&folio->page);
+ folio_release_kmap(folio, kaddr);
}
return 0;
}
mark_inode_dirty(inode);
err = ufs_handle_dirsync(inode);
out:
- ufs_put_page(&folio->page);
+ folio_release_kmap(folio, kaddr);
UFSD("EXIT\n");
return err;
}
}
de = ufs_next_entry(sb, de);
}
- ufs_put_page(&folio->page);
+ folio_release_kmap(folio, kaddr);
}
return 1;
not_empty:
- ufs_put_page(&folio->page);
+ folio_release_kmap(folio, kaddr);
return 0;
}
if (dir_de) {
if (old_dir != new_dir)
ufs_set_link(old_inode, dir_de, dir_folio, new_dir, 0);
- else {
- kunmap(&dir_folio->page);
- folio_put(dir_folio);
- }
+ else
+ folio_release_kmap(dir_folio, new_dir);
inode_dec_link_count(old_dir);
}
return 0;
out_dir:
- if (dir_de) {
- kunmap(&dir_folio->page);
- folio_put(dir_folio);
- }
+ if (dir_de)
+ folio_release_kmap(dir_folio, dir_de);
out_old:
- kunmap(&old_folio->page);
- folio_put(old_folio);
+ folio_release_kmap(old_folio, old_de);
out:
return err;
}