Lines Matching refs:inode
44 static int squashfs_new_inode(struct super_block *sb, struct inode *inode, in squashfs_new_inode() argument
59 i_uid_write(inode, i_uid); in squashfs_new_inode()
60 i_gid_write(inode, i_gid); in squashfs_new_inode()
61 inode->i_ino = le32_to_cpu(sqsh_ino->inode_number); in squashfs_new_inode()
62 inode->i_mtime.tv_sec = le32_to_cpu(sqsh_ino->mtime); in squashfs_new_inode()
63 inode->i_atime.tv_sec = inode->i_mtime.tv_sec; in squashfs_new_inode()
64 inode->i_ctime.tv_sec = inode->i_mtime.tv_sec; in squashfs_new_inode()
65 inode->i_mode = le16_to_cpu(sqsh_ino->mode); in squashfs_new_inode()
66 inode->i_size = 0; in squashfs_new_inode()
72 struct inode *squashfs_iget(struct super_block *sb, long long ino, in squashfs_iget()
75 struct inode *inode = iget_locked(sb, ino_number); in squashfs_iget() local
80 if (!inode) in squashfs_iget()
82 if (!(inode->i_state & I_NEW)) in squashfs_iget()
83 return inode; in squashfs_iget()
85 err = squashfs_read_inode(inode, ino); in squashfs_iget()
87 iget_failed(inode); in squashfs_iget()
91 unlock_new_inode(inode); in squashfs_iget()
92 return inode; in squashfs_iget()
100 int squashfs_read_inode(struct inode *inode, long long ino) in squashfs_read_inode() argument
102 struct super_block *sb = inode->i_sb; in squashfs_read_inode()
120 err = squashfs_new_inode(sb, inode, sqshb_ino); in squashfs_read_inode()
154 set_nlink(inode, 1); in squashfs_read_inode()
155 inode->i_size = le32_to_cpu(sqsh_ino->file_size); in squashfs_read_inode()
156 inode->i_fop = &generic_ro_fops; in squashfs_read_inode()
157 inode->i_mode |= S_IFREG; in squashfs_read_inode()
158 inode->i_blocks = ((inode->i_size - 1) >> 9) + 1; in squashfs_read_inode()
159 squashfs_i(inode)->fragment_block = frag_blk; in squashfs_read_inode()
160 squashfs_i(inode)->fragment_size = frag_size; in squashfs_read_inode()
161 squashfs_i(inode)->fragment_offset = frag_offset; in squashfs_read_inode()
162 squashfs_i(inode)->start = le32_to_cpu(sqsh_ino->start_block); in squashfs_read_inode()
163 squashfs_i(inode)->block_list_start = block; in squashfs_read_inode()
164 squashfs_i(inode)->offset = offset; in squashfs_read_inode()
165 inode->i_data.a_ops = &squashfs_aops; in squashfs_read_inode()
169 offset, squashfs_i(inode)->start, block, offset); in squashfs_read_inode()
198 set_nlink(inode, le32_to_cpu(sqsh_ino->nlink)); in squashfs_read_inode()
199 inode->i_size = le64_to_cpu(sqsh_ino->file_size); in squashfs_read_inode()
200 inode->i_op = &squashfs_inode_ops; in squashfs_read_inode()
201 inode->i_fop = &generic_ro_fops; in squashfs_read_inode()
202 inode->i_mode |= S_IFREG; in squashfs_read_inode()
203 inode->i_blocks = (inode->i_size - in squashfs_read_inode()
206 squashfs_i(inode)->fragment_block = frag_blk; in squashfs_read_inode()
207 squashfs_i(inode)->fragment_size = frag_size; in squashfs_read_inode()
208 squashfs_i(inode)->fragment_offset = frag_offset; in squashfs_read_inode()
209 squashfs_i(inode)->start = le64_to_cpu(sqsh_ino->start_block); in squashfs_read_inode()
210 squashfs_i(inode)->block_list_start = block; in squashfs_read_inode()
211 squashfs_i(inode)->offset = offset; in squashfs_read_inode()
212 inode->i_data.a_ops = &squashfs_aops; in squashfs_read_inode()
216 offset, squashfs_i(inode)->start, block, offset); in squashfs_read_inode()
227 set_nlink(inode, le32_to_cpu(sqsh_ino->nlink)); in squashfs_read_inode()
228 inode->i_size = le16_to_cpu(sqsh_ino->file_size); in squashfs_read_inode()
229 inode->i_op = &squashfs_dir_inode_ops; in squashfs_read_inode()
230 inode->i_fop = &squashfs_dir_ops; in squashfs_read_inode()
231 inode->i_mode |= S_IFDIR; in squashfs_read_inode()
232 squashfs_i(inode)->start = le32_to_cpu(sqsh_ino->start_block); in squashfs_read_inode()
233 squashfs_i(inode)->offset = le16_to_cpu(sqsh_ino->offset); in squashfs_read_inode()
234 squashfs_i(inode)->dir_idx_cnt = 0; in squashfs_read_inode()
235 squashfs_i(inode)->parent = le32_to_cpu(sqsh_ino->parent_inode); in squashfs_read_inode()
239 squashfs_i(inode)->start, in squashfs_read_inode()
252 set_nlink(inode, le32_to_cpu(sqsh_ino->nlink)); in squashfs_read_inode()
253 inode->i_size = le32_to_cpu(sqsh_ino->file_size); in squashfs_read_inode()
254 inode->i_op = &squashfs_dir_inode_ops; in squashfs_read_inode()
255 inode->i_fop = &squashfs_dir_ops; in squashfs_read_inode()
256 inode->i_mode |= S_IFDIR; in squashfs_read_inode()
257 squashfs_i(inode)->start = le32_to_cpu(sqsh_ino->start_block); in squashfs_read_inode()
258 squashfs_i(inode)->offset = le16_to_cpu(sqsh_ino->offset); in squashfs_read_inode()
259 squashfs_i(inode)->dir_idx_start = block; in squashfs_read_inode()
260 squashfs_i(inode)->dir_idx_offset = offset; in squashfs_read_inode()
261 squashfs_i(inode)->dir_idx_cnt = le16_to_cpu(sqsh_ino->i_count); in squashfs_read_inode()
262 squashfs_i(inode)->parent = le32_to_cpu(sqsh_ino->parent_inode); in squashfs_read_inode()
266 squashfs_i(inode)->start, in squashfs_read_inode()
279 set_nlink(inode, le32_to_cpu(sqsh_ino->nlink)); in squashfs_read_inode()
280 inode->i_size = le32_to_cpu(sqsh_ino->symlink_size); in squashfs_read_inode()
281 inode->i_op = &squashfs_symlink_inode_ops; in squashfs_read_inode()
282 inode_nohighmem(inode); in squashfs_read_inode()
283 inode->i_data.a_ops = &squashfs_symlink_aops; in squashfs_read_inode()
284 inode->i_mode |= S_IFLNK; in squashfs_read_inode()
285 squashfs_i(inode)->start = block; in squashfs_read_inode()
286 squashfs_i(inode)->offset = offset; in squashfs_read_inode()
292 &offset, inode->i_size); in squashfs_read_inode()
318 inode->i_mode |= S_IFCHR; in squashfs_read_inode()
320 inode->i_mode |= S_IFBLK; in squashfs_read_inode()
321 set_nlink(inode, le32_to_cpu(sqsh_ino->nlink)); in squashfs_read_inode()
323 init_special_inode(inode, inode->i_mode, new_decode_dev(rdev)); in squashfs_read_inode()
340 inode->i_mode |= S_IFCHR; in squashfs_read_inode()
342 inode->i_mode |= S_IFBLK; in squashfs_read_inode()
344 inode->i_op = &squashfs_inode_ops; in squashfs_read_inode()
345 set_nlink(inode, le32_to_cpu(sqsh_ino->nlink)); in squashfs_read_inode()
347 init_special_inode(inode, inode->i_mode, new_decode_dev(rdev)); in squashfs_read_inode()
363 inode->i_mode |= S_IFIFO; in squashfs_read_inode()
365 inode->i_mode |= S_IFSOCK; in squashfs_read_inode()
366 set_nlink(inode, le32_to_cpu(sqsh_ino->nlink)); in squashfs_read_inode()
367 init_special_inode(inode, inode->i_mode, 0); in squashfs_read_inode()
380 inode->i_mode |= S_IFIFO; in squashfs_read_inode()
382 inode->i_mode |= S_IFSOCK; in squashfs_read_inode()
384 inode->i_op = &squashfs_inode_ops; in squashfs_read_inode()
385 set_nlink(inode, le32_to_cpu(sqsh_ino->nlink)); in squashfs_read_inode()
386 init_special_inode(inode, inode->i_mode, 0); in squashfs_read_inode()
396 &squashfs_i(inode)->xattr_count, in squashfs_read_inode()
397 &squashfs_i(inode)->xattr_size, in squashfs_read_inode()
398 &squashfs_i(inode)->xattr); in squashfs_read_inode()
401 inode->i_blocks += ((squashfs_i(inode)->xattr_size - 1) >> 9) in squashfs_read_inode()
404 squashfs_i(inode)->xattr_count = 0; in squashfs_read_inode()