udf: Convert udf_expand_file_adinicb() to avoid kmap_atomic()
Remove the last two remaining kmap_atomic() uses in UDF in udf_expand_file_adinicb(). The first use can be actually conveniently replaced with udf_adinicb_readpage(), the second with memcpy_to_page(). Signed-off-by: Jan Kara <jack@suse.cz>
This commit is contained in:
parent
5cfc45321a
commit
1eeceaec79
@ -336,7 +336,6 @@ const struct address_space_operations udf_aops = {
|
|||||||
int udf_expand_file_adinicb(struct inode *inode)
|
int udf_expand_file_adinicb(struct inode *inode)
|
||||||
{
|
{
|
||||||
struct page *page;
|
struct page *page;
|
||||||
char *kaddr;
|
|
||||||
struct udf_inode_info *iinfo = UDF_I(inode);
|
struct udf_inode_info *iinfo = UDF_I(inode);
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
@ -358,16 +357,8 @@ int udf_expand_file_adinicb(struct inode *inode)
|
|||||||
if (!page)
|
if (!page)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
|
||||||
if (!PageUptodate(page)) {
|
if (!PageUptodate(page))
|
||||||
kaddr = kmap_atomic(page);
|
udf_adinicb_readpage(page);
|
||||||
memset(kaddr + iinfo->i_lenAlloc, 0x00,
|
|
||||||
PAGE_SIZE - iinfo->i_lenAlloc);
|
|
||||||
memcpy(kaddr, iinfo->i_data + iinfo->i_lenEAttr,
|
|
||||||
iinfo->i_lenAlloc);
|
|
||||||
flush_dcache_page(page);
|
|
||||||
SetPageUptodate(page);
|
|
||||||
kunmap_atomic(kaddr);
|
|
||||||
}
|
|
||||||
down_write(&iinfo->i_data_sem);
|
down_write(&iinfo->i_data_sem);
|
||||||
memset(iinfo->i_data + iinfo->i_lenEAttr, 0x00,
|
memset(iinfo->i_data + iinfo->i_lenEAttr, 0x00,
|
||||||
iinfo->i_lenAlloc);
|
iinfo->i_lenAlloc);
|
||||||
@ -384,9 +375,8 @@ int udf_expand_file_adinicb(struct inode *inode)
|
|||||||
/* Restore everything back so that we don't lose data... */
|
/* Restore everything back so that we don't lose data... */
|
||||||
lock_page(page);
|
lock_page(page);
|
||||||
down_write(&iinfo->i_data_sem);
|
down_write(&iinfo->i_data_sem);
|
||||||
kaddr = kmap_atomic(page);
|
memcpy_to_page(page, 0, iinfo->i_data + iinfo->i_lenEAttr,
|
||||||
memcpy(iinfo->i_data + iinfo->i_lenEAttr, kaddr, inode->i_size);
|
inode->i_size);
|
||||||
kunmap_atomic(kaddr);
|
|
||||||
unlock_page(page);
|
unlock_page(page);
|
||||||
iinfo->i_alloc_type = ICBTAG_FLAG_AD_IN_ICB;
|
iinfo->i_alloc_type = ICBTAG_FLAG_AD_IN_ICB;
|
||||||
iinfo->i_lenAlloc = inode->i_size;
|
iinfo->i_lenAlloc = inode->i_size;
|
||||||
|
Loading…
Reference in New Issue
Block a user