Lines Matching full:ni
28 struct ntfs_inode *ni = ntfs_i(inode); in ntfs_read_mft() local
54 err = mi_init(&ni->mi, sbi, ino); in ntfs_read_mft()
58 if (!sbi->mft.ni && ino == MFT_REC_MFT && !sb->s_root) { in ntfs_read_mft()
61 sbi->mft.ni = ni; in ntfs_read_mft()
62 init_rwsem(&ni->file.run_lock); in ntfs_read_mft()
64 if (!run_add_entry(&ni->file.run, 0, t64, t32, true)) { in ntfs_read_mft()
70 err = mi_read(&ni->mi, ino == MFT_REC_MFT); in ntfs_read_mft()
75 rec = ni->mi.mrec; in ntfs_read_mft()
118 * while( (attr = ni_enum_attr_ex(ni, attr, &le, NULL) )) in ntfs_read_mft()
123 attr = ni_enum_attr_ex(ni, attr, &le, NULL); in ntfs_read_mft()
132 run = &ni->file.run; in ntfs_read_mft()
170 nt2kernel(std5->cr_time, &ni->i_crtime); in ntfs_read_mft()
177 ni->std_fa = std5->fa; in ntfs_read_mft()
181 ni->std_security_id = std5->security_id; in ntfs_read_mft()
188 err = ntfs_load_attr_list(ni, attr); in ntfs_read_mft()
234 ni->std_fa |= FILE_ATTRIBUTE_SPARSE_FILE; in ntfs_read_mft()
236 ni->std_fa &= ~FILE_ATTRIBUTE_SPARSE_FILE; in ntfs_read_mft()
239 ni->std_fa |= FILE_ATTRIBUTE_COMPRESSED; in ntfs_read_mft()
241 ni->std_fa &= ~FILE_ATTRIBUTE_COMPRESSED; in ntfs_read_mft()
244 ni->std_fa |= FILE_ATTRIBUTE_ENCRYPTED; in ntfs_read_mft()
246 ni->std_fa &= ~FILE_ATTRIBUTE_ENCRYPTED; in ntfs_read_mft()
249 ni->i_valid = inode->i_size = rsize; in ntfs_read_mft()
256 ni->ni_flags |= NI_FLAG_RESIDENT; in ntfs_read_mft()
262 ni->i_valid = le64_to_cpu(attr->nres.valid_size); in ntfs_read_mft()
268 &ni->file.run; in ntfs_read_mft()
289 ni->ni_flags |= NI_FLAG_DIR; in ntfs_read_mft()
291 err = indx_init(&ni->dir, sbi, attr, INDEX_MUTEX_I30); in ntfs_read_mft()
306 ni->i_valid = le64_to_cpu(attr->nres.valid_size); in ntfs_read_mft()
309 run = &ni->dir.alloc_run; in ntfs_read_mft()
327 run = &ni->dir.bitmap_run; in ntfs_read_mft()
336 rp_fa = ni_parse_reparse(ni, attr, &rp); in ntfs_read_mft()
347 ni->i_valid = inode->i_size; in ntfs_read_mft()
350 if (ni->ni_flags & NI_FLAG_DIR) { in ntfs_read_mft()
351 indx_clear(&ni->dir); in ntfs_read_mft()
352 memset(&ni->dir, 0, sizeof(ni->dir)); in ntfs_read_mft()
353 ni->ni_flags &= ~NI_FLAG_DIR; in ntfs_read_mft()
355 run_close(&ni->file.run); in ntfs_read_mft()
360 run = &ni->file.run; in ntfs_read_mft()
376 ni->ni_flags |= NI_FLAG_EA; in ntfs_read_mft()
429 ni->mi.dirty = true; in ntfs_read_mft()
435 ni->std_fa |= FILE_ATTRIBUTE_DIRECTORY; in ntfs_read_mft()
444 ni->i_valid = 0; in ntfs_read_mft()
446 ni->std_fa &= ~FILE_ATTRIBUTE_DIRECTORY; in ntfs_read_mft()
451 ni->std_fa &= ~FILE_ATTRIBUTE_DIRECTORY; in ntfs_read_mft()
454 inode->i_mapping->a_ops = is_compressed(ni) ? &ntfs_aops_cmpr : in ntfs_read_mft()
457 init_rwsem(&ni->file.run_lock); in ntfs_read_mft()
480 if (!(ni->ni_flags & NI_FLAG_EA)) { in ntfs_read_mft()
486 sbi->mft.ni = NULL; in ntfs_read_mft()
494 sbi->mft.ni = NULL; in ntfs_read_mft()
558 struct ntfs_inode *ni = ntfs_i(inode); in ntfs_get_block_vbo() local
572 if (is_resident(ni)) { in ntfs_get_block_vbo()
573 ni_lock(ni); in ntfs_get_block_vbo()
574 err = attr_data_read_resident(ni, &folio->page); in ntfs_get_block_vbo()
575 ni_unlock(ni); in ntfs_get_block_vbo()
587 err = attr_data_get_block(ni, vcn, 1, &lcn, &len, create ? &new : NULL, in ntfs_get_block_vbo()
615 valid = ni->i_valid; in ntfs_get_block_vbo()
618 /* ntfs_direct_IO will update ni->i_valid. */ in ntfs_get_block_vbo()
630 ni->i_valid = vbo + bytes; in ntfs_get_block_vbo()
704 struct ntfs_inode *ni = ntfs_i(inode); in ntfs_read_folio() local
706 if (is_resident(ni)) { in ntfs_read_folio()
707 ni_lock(ni); in ntfs_read_folio()
708 err = attr_data_read_resident(ni, page); in ntfs_read_folio()
709 ni_unlock(ni); in ntfs_read_folio()
716 if (is_compressed(ni)) { in ntfs_read_folio()
717 ni_lock(ni); in ntfs_read_folio()
718 err = ni_readpage_cmpr(ni, page); in ntfs_read_folio()
719 ni_unlock(ni); in ntfs_read_folio()
731 struct ntfs_inode *ni = ntfs_i(inode); in ntfs_readahead() local
735 if (is_resident(ni)) { in ntfs_readahead()
740 if (is_compressed(ni)) { in ntfs_readahead()
745 valid = ni->i_valid; in ntfs_readahead()
776 struct ntfs_inode *ni = ntfs_i(inode); in ntfs_direct_IO() local
784 if (is_resident(ni)) { in ntfs_direct_IO()
801 valid = ni->i_valid; in ntfs_direct_IO()
804 ni->i_valid = end; in ntfs_direct_IO()
821 struct ntfs_inode *ni = ntfs_i(inode); in ntfs_set_size() local
825 if (is_sparsed(ni) || is_compressed(ni)) { in ntfs_set_size()
835 ni_lock(ni); in ntfs_set_size()
836 down_write(&ni->file.run_lock); in ntfs_set_size()
838 err = attr_set_size(ni, ATTR_DATA, NULL, 0, &ni->file.run, new_size, in ntfs_set_size()
839 &ni->i_valid, true, NULL); in ntfs_set_size()
841 up_write(&ni->file.run_lock); in ntfs_set_size()
842 ni_unlock(ni); in ntfs_set_size()
855 struct ntfs_inode *ni = ntfs_i(inode); in ntfs_resident_writepage() local
861 ni_lock(ni); in ntfs_resident_writepage()
862 ret = attr_data_write_resident(ni, &folio->page); in ntfs_resident_writepage()
863 ni_unlock(ni); in ntfs_resident_writepage()
897 struct ntfs_inode *ni = ntfs_i(inode); in ntfs_write_begin() local
903 if (is_resident(ni)) { in ntfs_write_begin()
912 ni_lock(ni); in ntfs_write_begin()
913 err = attr_data_read_resident(ni, page); in ntfs_write_begin()
914 ni_unlock(ni); in ntfs_write_begin()
941 struct ntfs_inode *ni = ntfs_i(inode); in ntfs_write_end() local
942 u64 valid = ni->i_valid; in ntfs_write_end()
946 if (is_resident(ni)) { in ntfs_write_end()
947 ni_lock(ni); in ntfs_write_end()
948 err = attr_data_write_resident(ni, page); in ntfs_write_end()
949 ni_unlock(ni); in ntfs_write_end()
974 if (!(ni->std_fa & FILE_ATTRIBUTE_ARCHIVE)) { in ntfs_write_end()
976 ni->std_fa |= FILE_ATTRIBUTE_ARCHIVE; in ntfs_write_end()
980 if (valid != ni->i_valid) { in ntfs_write_end()
981 /* ni->i_valid is changed in ntfs_get_block_vbo. */ in ntfs_write_end()
1223 struct ntfs_inode *ni = NULL; in ntfs_create_inode() local
1331 ni = ntfs_new_inode(sbi, ino, S_ISDIR(mode) ? RECORD_FLAG_DIR : 0); in ntfs_create_inode()
1332 if (IS_ERR(ni)) { in ntfs_create_inode()
1333 err = PTR_ERR(ni); in ntfs_create_inode()
1334 ni = NULL; in ntfs_create_inode()
1337 inode = &ni->vfs_inode; in ntfs_create_inode()
1341 ni->i_crtime = current_time(inode); in ntfs_create_inode()
1343 rec = ni->mi.mrec; in ntfs_create_inode()
1371 ni->std_security_id = security_id; in ntfs_create_inode()
1382 kernel2nt(&ni->i_crtime); in ntfs_create_inode()
1384 std5->fa = ni->std_fa = fa; in ntfs_create_inode()
1393 mi_get_ref(&ni->mi, &new_de->ref); in ntfs_create_inode()
1516 ni->ni_flags |= NI_FLAG_RESIDENT; in ntfs_create_inode()
1520 ni->ni_flags |= NI_FLAG_DIR; in ntfs_create_inode()
1521 err = indx_init(&ni->dir, sbi, attr, INDEX_MUTEX_I30); in ntfs_create_inode()
1564 err = attr_allocate_clusters(sbi, &ni->file.run, 0, 0, in ntfs_create_inode()
1570 err = run_pack(&ni->file.run, 0, clst, in ntfs_create_inode()
1583 err = ntfs_sb_write_run(sbi, &ni->file.run, 0, rp, in ntfs_create_inode()
1625 inode->i_mapping->a_ops = is_compressed(ni) ? &ntfs_aops_cmpr : in ntfs_create_inode()
1627 init_rwsem(&ni->file.run_lock); in ntfs_create_inode()
1656 attr = ni_find_attr(ni, NULL, NULL, ATTR_NAME, NULL, 0, NULL, NULL); in ntfs_create_inode()
1666 ni->ni_flags &= ~NI_FLAG_UPDATE_PARENT; in ntfs_create_inode()
1681 inode_set_ctime_to_ts(inode, ni->i_crtime); in ntfs_create_inode()
1682 dir->i_mtime = inode_set_ctime_to_ts(dir, ni->i_crtime); in ntfs_create_inode()
1696 run_deallocate(sbi, &ni->file.run, false); in ntfs_create_inode()
1701 ni->mi.dirty = false; in ntfs_create_inode()
1725 struct ntfs_inode *ni = ntfs_i(inode); in ntfs_link_inode() local
1742 err = ni_add_name(ntfs_i(d_inode(dentry->d_parent)), ni, de); in ntfs_link_inode()
1759 struct ntfs_inode *ni = ntfs_i(inode); in ntfs_unlink_inode() local
1764 if (ntfs_is_meta_file(sbi, ni->mi.rno)) in ntfs_unlink_inode()
1772 ni_lock(ni); in ntfs_unlink_inode()
1784 err = ni_remove_name(dir_ni, ni, de, &de2, &undo_remove); in ntfs_unlink_inode()
1793 } else if (!ni_remove_name_undo(dir_ni, ni, de, de2, undo_remove)) { in ntfs_unlink_inode()
1803 ni_unlock(ni); in ntfs_unlink_inode()
1918 struct ntfs_inode *ni = ntfs_i(inode); in ntfs_readlink_hlp() local
1934 attr = ni_find_attr(ni, NULL, NULL, ATTR_REPARSE, NULL, 0, NULL, NULL); in ntfs_readlink_hlp()
1959 err = ntfs_read_run_nb(sbi, &ni->file.run, 0, rp, size, NULL); in ntfs_readlink_hlp()