Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
L
linux-davinci
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Redmine
Redmine
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Metrics
Environments
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
linux
linux-davinci
Commits
aec7477b
Commit
aec7477b
authored
Jul 24, 2008
by
Josef Bacik
Committed by
Chris Mason
Sep 25, 2008
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Btrfs: Implement new dir index format
Signed-off-by:
Chris Mason
<
chris.mason@oracle.com
>
parent
3eaa2885
Changes
7
Show whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
155 additions
and
33 deletions
+155
-33
fs/btrfs/btrfs_inode.h
fs/btrfs/btrfs_inode.h
+15
-0
fs/btrfs/ctree.h
fs/btrfs/ctree.h
+5
-3
fs/btrfs/dir-item.c
fs/btrfs/dir-item.c
+2
-2
fs/btrfs/inode-item.c
fs/btrfs/inode-item.c
+8
-2
fs/btrfs/inode.c
fs/btrfs/inode.c
+121
-22
fs/btrfs/ioctl.c
fs/btrfs/ioctl.c
+2
-2
fs/btrfs/transaction.c
fs/btrfs/transaction.c
+2
-2
No files found.
fs/btrfs/btrfs_inode.h
View file @
aec7477b
...
@@ -43,6 +43,21 @@ struct btrfs_inode {
...
@@ -43,6 +43,21 @@ struct btrfs_inode {
u64
delalloc_bytes
;
u64
delalloc_bytes
;
u64
disk_i_size
;
u64
disk_i_size
;
u32
flags
;
u32
flags
;
/*
* if this is a directory then index_cnt is the counter for the index
* number for new files that are created
*/
u64
index_cnt
;
/*
* index holds the directory index for this inode on creation, so
* add_link can do what its supposed to. This isn't populated when the
* inode is read because there isn't really a reason to know this unless
* we are creating the directory index or deleting it, and deletion
* reads the index off of the inode reference at unlink time.
*/
u64
index
;
};
};
static
inline
struct
btrfs_inode
*
BTRFS_I
(
struct
inode
*
inode
)
static
inline
struct
btrfs_inode
*
BTRFS_I
(
struct
inode
*
inode
)
...
...
fs/btrfs/ctree.h
View file @
aec7477b
...
@@ -372,6 +372,7 @@ struct btrfs_dev_extent {
...
@@ -372,6 +372,7 @@ struct btrfs_dev_extent {
}
__attribute__
((
__packed__
));
}
__attribute__
((
__packed__
));
struct
btrfs_inode_ref
{
struct
btrfs_inode_ref
{
__le64
index
;
__le16
name_len
;
__le16
name_len
;
/* name goes here */
/* name goes here */
}
__attribute__
((
__packed__
));
}
__attribute__
((
__packed__
));
...
@@ -902,6 +903,7 @@ BTRFS_SETGET_STACK_FUNCS(block_group_flags,
...
@@ -902,6 +903,7 @@ BTRFS_SETGET_STACK_FUNCS(block_group_flags,
/* struct btrfs_inode_ref */
/* struct btrfs_inode_ref */
BTRFS_SETGET_FUNCS
(
inode_ref_name_len
,
struct
btrfs_inode_ref
,
name_len
,
16
);
BTRFS_SETGET_FUNCS
(
inode_ref_name_len
,
struct
btrfs_inode_ref
,
name_len
,
16
);
BTRFS_SETGET_FUNCS
(
inode_ref_index
,
struct
btrfs_inode_ref
,
index
,
64
);
/* struct btrfs_inode_item */
/* struct btrfs_inode_item */
BTRFS_SETGET_FUNCS
(
inode_generation
,
struct
btrfs_inode_item
,
generation
,
64
);
BTRFS_SETGET_FUNCS
(
inode_generation
,
struct
btrfs_inode_item
,
generation
,
64
);
...
@@ -1528,7 +1530,7 @@ int btrfs_find_dead_roots(struct btrfs_root *root, u64 objectid,
...
@@ -1528,7 +1530,7 @@ int btrfs_find_dead_roots(struct btrfs_root *root, u64 objectid,
/* dir-item.c */
/* dir-item.c */
int
btrfs_insert_dir_item
(
struct
btrfs_trans_handle
*
trans
,
struct
btrfs_root
int
btrfs_insert_dir_item
(
struct
btrfs_trans_handle
*
trans
,
struct
btrfs_root
*
root
,
const
char
*
name
,
int
name_len
,
u64
dir
,
*
root
,
const
char
*
name
,
int
name_len
,
u64
dir
,
struct
btrfs_key
*
location
,
u8
type
);
struct
btrfs_key
*
location
,
u8
type
,
u64
index
);
struct
btrfs_dir_item
*
btrfs_lookup_dir_item
(
struct
btrfs_trans_handle
*
trans
,
struct
btrfs_dir_item
*
btrfs_lookup_dir_item
(
struct
btrfs_trans_handle
*
trans
,
struct
btrfs_root
*
root
,
struct
btrfs_root
*
root
,
struct
btrfs_path
*
path
,
u64
dir
,
struct
btrfs_path
*
path
,
u64
dir
,
...
@@ -1566,11 +1568,11 @@ int btrfs_find_highest_inode(struct btrfs_root *fs_root, u64 *objectid);
...
@@ -1566,11 +1568,11 @@ int btrfs_find_highest_inode(struct btrfs_root *fs_root, u64 *objectid);
int
btrfs_insert_inode_ref
(
struct
btrfs_trans_handle
*
trans
,
int
btrfs_insert_inode_ref
(
struct
btrfs_trans_handle
*
trans
,
struct
btrfs_root
*
root
,
struct
btrfs_root
*
root
,
const
char
*
name
,
int
name_len
,
const
char
*
name
,
int
name_len
,
u64
inode_objectid
,
u64
ref_objectid
);
u64
inode_objectid
,
u64
ref_objectid
,
u64
index
);
int
btrfs_del_inode_ref
(
struct
btrfs_trans_handle
*
trans
,
int
btrfs_del_inode_ref
(
struct
btrfs_trans_handle
*
trans
,
struct
btrfs_root
*
root
,
struct
btrfs_root
*
root
,
const
char
*
name
,
int
name_len
,
const
char
*
name
,
int
name_len
,
u64
inode_objectid
,
u64
ref_objectid
);
u64
inode_objectid
,
u64
ref_objectid
,
u64
*
index
);
int
btrfs_insert_empty_inode
(
struct
btrfs_trans_handle
*
trans
,
int
btrfs_insert_empty_inode
(
struct
btrfs_trans_handle
*
trans
,
struct
btrfs_root
*
root
,
struct
btrfs_root
*
root
,
struct
btrfs_path
*
path
,
u64
objectid
);
struct
btrfs_path
*
path
,
u64
objectid
);
...
...
fs/btrfs/dir-item.c
View file @
aec7477b
...
@@ -110,7 +110,7 @@ int btrfs_insert_xattr_item(struct btrfs_trans_handle *trans,
...
@@ -110,7 +110,7 @@ int btrfs_insert_xattr_item(struct btrfs_trans_handle *trans,
int
btrfs_insert_dir_item
(
struct
btrfs_trans_handle
*
trans
,
struct
btrfs_root
int
btrfs_insert_dir_item
(
struct
btrfs_trans_handle
*
trans
,
struct
btrfs_root
*
root
,
const
char
*
name
,
int
name_len
,
u64
dir
,
*
root
,
const
char
*
name
,
int
name_len
,
u64
dir
,
struct
btrfs_key
*
location
,
u8
type
)
struct
btrfs_key
*
location
,
u8
type
,
u64
index
)
{
{
int
ret
=
0
;
int
ret
=
0
;
int
ret2
=
0
;
int
ret2
=
0
;
...
@@ -156,7 +156,7 @@ second_insert:
...
@@ -156,7 +156,7 @@ second_insert:
btrfs_release_path
(
root
,
path
);
btrfs_release_path
(
root
,
path
);
btrfs_set_key_type
(
&
key
,
BTRFS_DIR_INDEX_KEY
);
btrfs_set_key_type
(
&
key
,
BTRFS_DIR_INDEX_KEY
);
key
.
offset
=
location
->
objectid
;
key
.
offset
=
index
;
dir_item
=
insert_with_overflow
(
trans
,
root
,
path
,
&
key
,
data_size
,
dir_item
=
insert_with_overflow
(
trans
,
root
,
path
,
&
key
,
data_size
,
name
,
name_len
);
name
,
name_len
);
if
(
IS_ERR
(
dir_item
))
{
if
(
IS_ERR
(
dir_item
))
{
...
...
fs/btrfs/inode-item.c
View file @
aec7477b
...
@@ -52,7 +52,7 @@ int find_name_in_backref(struct btrfs_path *path, const char * name,
...
@@ -52,7 +52,7 @@ int find_name_in_backref(struct btrfs_path *path, const char * name,
int
btrfs_del_inode_ref
(
struct
btrfs_trans_handle
*
trans
,
int
btrfs_del_inode_ref
(
struct
btrfs_trans_handle
*
trans
,
struct
btrfs_root
*
root
,
struct
btrfs_root
*
root
,
const
char
*
name
,
int
name_len
,
const
char
*
name
,
int
name_len
,
u64
inode_objectid
,
u64
ref_objectid
)
u64
inode_objectid
,
u64
ref_objectid
,
u64
*
index
)
{
{
struct
btrfs_path
*
path
;
struct
btrfs_path
*
path
;
struct
btrfs_key
key
;
struct
btrfs_key
key
;
...
@@ -86,6 +86,10 @@ int btrfs_del_inode_ref(struct btrfs_trans_handle *trans,
...
@@ -86,6 +86,10 @@ int btrfs_del_inode_ref(struct btrfs_trans_handle *trans,
}
}
leaf
=
path
->
nodes
[
0
];
leaf
=
path
->
nodes
[
0
];
item_size
=
btrfs_item_size_nr
(
leaf
,
path
->
slots
[
0
]);
item_size
=
btrfs_item_size_nr
(
leaf
,
path
->
slots
[
0
]);
if
(
index
)
*
index
=
btrfs_inode_ref_index
(
leaf
,
ref
);
if
(
del_len
==
item_size
)
{
if
(
del_len
==
item_size
)
{
ret
=
btrfs_del_item
(
trans
,
root
,
path
);
ret
=
btrfs_del_item
(
trans
,
root
,
path
);
goto
out
;
goto
out
;
...
@@ -106,7 +110,7 @@ out:
...
@@ -106,7 +110,7 @@ out:
int
btrfs_insert_inode_ref
(
struct
btrfs_trans_handle
*
trans
,
int
btrfs_insert_inode_ref
(
struct
btrfs_trans_handle
*
trans
,
struct
btrfs_root
*
root
,
struct
btrfs_root
*
root
,
const
char
*
name
,
int
name_len
,
const
char
*
name
,
int
name_len
,
u64
inode_objectid
,
u64
ref_objectid
)
u64
inode_objectid
,
u64
ref_objectid
,
u64
index
)
{
{
struct
btrfs_path
*
path
;
struct
btrfs_path
*
path
;
struct
btrfs_key
key
;
struct
btrfs_key
key
;
...
@@ -138,6 +142,7 @@ int btrfs_insert_inode_ref(struct btrfs_trans_handle *trans,
...
@@ -138,6 +142,7 @@ int btrfs_insert_inode_ref(struct btrfs_trans_handle *trans,
struct
btrfs_inode_ref
);
struct
btrfs_inode_ref
);
ref
=
(
struct
btrfs_inode_ref
*
)((
unsigned
long
)
ref
+
old_size
);
ref
=
(
struct
btrfs_inode_ref
*
)((
unsigned
long
)
ref
+
old_size
);
btrfs_set_inode_ref_name_len
(
path
->
nodes
[
0
],
ref
,
name_len
);
btrfs_set_inode_ref_name_len
(
path
->
nodes
[
0
],
ref
,
name_len
);
btrfs_set_inode_ref_index
(
path
->
nodes
[
0
],
ref
,
index
);
ptr
=
(
unsigned
long
)(
ref
+
1
);
ptr
=
(
unsigned
long
)(
ref
+
1
);
ret
=
0
;
ret
=
0
;
}
else
if
(
ret
<
0
)
{
}
else
if
(
ret
<
0
)
{
...
@@ -146,6 +151,7 @@ int btrfs_insert_inode_ref(struct btrfs_trans_handle *trans,
...
@@ -146,6 +151,7 @@ int btrfs_insert_inode_ref(struct btrfs_trans_handle *trans,
ref
=
btrfs_item_ptr
(
path
->
nodes
[
0
],
path
->
slots
[
0
],
ref
=
btrfs_item_ptr
(
path
->
nodes
[
0
],
path
->
slots
[
0
],
struct
btrfs_inode_ref
);
struct
btrfs_inode_ref
);
btrfs_set_inode_ref_name_len
(
path
->
nodes
[
0
],
ref
,
name_len
);
btrfs_set_inode_ref_name_len
(
path
->
nodes
[
0
],
ref
,
name_len
);
btrfs_set_inode_ref_index
(
path
->
nodes
[
0
],
ref
,
index
);
ptr
=
(
unsigned
long
)(
ref
+
1
);
ptr
=
(
unsigned
long
)(
ref
+
1
);
}
}
write_extent_buffer
(
path
->
nodes
[
0
],
name
,
ptr
,
name_len
);
write_extent_buffer
(
path
->
nodes
[
0
],
name
,
ptr
,
name_len
);
...
...
fs/btrfs/inode.c
View file @
aec7477b
...
@@ -872,6 +872,8 @@ void btrfs_read_locked_inode(struct inode *inode)
...
@@ -872,6 +872,8 @@ void btrfs_read_locked_inode(struct inode *inode)
inode
->
i_rdev
=
0
;
inode
->
i_rdev
=
0
;
rdev
=
btrfs_inode_rdev
(
leaf
,
inode_item
);
rdev
=
btrfs_inode_rdev
(
leaf
,
inode_item
);
BTRFS_I
(
inode
)
->
index_cnt
=
(
u64
)
-
1
;
alloc_group_block
=
btrfs_inode_block_group
(
leaf
,
inode_item
);
alloc_group_block
=
btrfs_inode_block_group
(
leaf
,
inode_item
);
BTRFS_I
(
inode
)
->
block_group
=
btrfs_lookup_block_group
(
root
->
fs_info
,
BTRFS_I
(
inode
)
->
block_group
=
btrfs_lookup_block_group
(
root
->
fs_info
,
alloc_group_block
);
alloc_group_block
);
...
@@ -993,6 +995,7 @@ static int btrfs_unlink_trans(struct btrfs_trans_handle *trans,
...
@@ -993,6 +995,7 @@ static int btrfs_unlink_trans(struct btrfs_trans_handle *trans,
struct
extent_buffer
*
leaf
;
struct
extent_buffer
*
leaf
;
struct
btrfs_dir_item
*
di
;
struct
btrfs_dir_item
*
di
;
struct
btrfs_key
key
;
struct
btrfs_key
key
;
u64
index
;
path
=
btrfs_alloc_path
();
path
=
btrfs_alloc_path
();
if
(
!
path
)
{
if
(
!
path
)
{
...
@@ -1017,8 +1020,19 @@ static int btrfs_unlink_trans(struct btrfs_trans_handle *trans,
...
@@ -1017,8 +1020,19 @@ static int btrfs_unlink_trans(struct btrfs_trans_handle *trans,
goto
err
;
goto
err
;
btrfs_release_path
(
root
,
path
);
btrfs_release_path
(
root
,
path
);
ret
=
btrfs_del_inode_ref
(
trans
,
root
,
name
,
name_len
,
dentry
->
d_inode
->
i_ino
,
dentry
->
d_parent
->
d_inode
->
i_ino
,
&
index
);
if
(
ret
)
{
printk
(
"failed to delete reference to %.*s, "
"inode %lu parent %lu
\n
"
,
name_len
,
name
,
dentry
->
d_inode
->
i_ino
,
dentry
->
d_parent
->
d_inode
->
i_ino
);
goto
err
;
}
di
=
btrfs_lookup_dir_index_item
(
trans
,
root
,
path
,
dir
->
i_ino
,
di
=
btrfs_lookup_dir_index_item
(
trans
,
root
,
path
,
dir
->
i_ino
,
key
.
objectid
,
name
,
name_len
,
-
1
);
index
,
name
,
name_len
,
-
1
);
if
(
IS_ERR
(
di
))
{
if
(
IS_ERR
(
di
))
{
ret
=
PTR_ERR
(
di
);
ret
=
PTR_ERR
(
di
);
goto
err
;
goto
err
;
...
@@ -1031,15 +1045,6 @@ static int btrfs_unlink_trans(struct btrfs_trans_handle *trans,
...
@@ -1031,15 +1045,6 @@ static int btrfs_unlink_trans(struct btrfs_trans_handle *trans,
btrfs_release_path
(
root
,
path
);
btrfs_release_path
(
root
,
path
);
dentry
->
d_inode
->
i_ctime
=
dir
->
i_ctime
;
dentry
->
d_inode
->
i_ctime
=
dir
->
i_ctime
;
ret
=
btrfs_del_inode_ref
(
trans
,
root
,
name
,
name_len
,
dentry
->
d_inode
->
i_ino
,
dentry
->
d_parent
->
d_inode
->
i_ino
);
if
(
ret
)
{
printk
(
"failed to delete reference to %.*s, "
"inode %lu parent %lu
\n
"
,
name_len
,
name
,
dentry
->
d_inode
->
i_ino
,
dentry
->
d_parent
->
d_inode
->
i_ino
);
}
err:
err:
btrfs_free_path
(
path
);
btrfs_free_path
(
path
);
if
(
!
ret
)
{
if
(
!
ret
)
{
...
@@ -1625,6 +1630,7 @@ static int btrfs_init_locked_inode(struct inode *inode, void *p)
...
@@ -1625,6 +1630,7 @@ static int btrfs_init_locked_inode(struct inode *inode, void *p)
BTRFS_I
(
inode
)
->
root
=
args
->
root
;
BTRFS_I
(
inode
)
->
root
=
args
->
root
;
BTRFS_I
(
inode
)
->
delalloc_bytes
=
0
;
BTRFS_I
(
inode
)
->
delalloc_bytes
=
0
;
BTRFS_I
(
inode
)
->
disk_i_size
=
0
;
BTRFS_I
(
inode
)
->
disk_i_size
=
0
;
BTRFS_I
(
inode
)
->
index_cnt
=
(
u64
)
-
1
;
extent_map_tree_init
(
&
BTRFS_I
(
inode
)
->
extent_tree
,
GFP_NOFS
);
extent_map_tree_init
(
&
BTRFS_I
(
inode
)
->
extent_tree
,
GFP_NOFS
);
extent_io_tree_init
(
&
BTRFS_I
(
inode
)
->
io_tree
,
extent_io_tree_init
(
&
BTRFS_I
(
inode
)
->
io_tree
,
inode
->
i_mapping
,
GFP_NOFS
);
inode
->
i_mapping
,
GFP_NOFS
);
...
@@ -1901,8 +1907,77 @@ void btrfs_dirty_inode(struct inode *inode)
...
@@ -1901,8 +1907,77 @@ void btrfs_dirty_inode(struct inode *inode)
btrfs_end_transaction
(
trans
,
root
);
btrfs_end_transaction
(
trans
,
root
);
}
}
static
int
btrfs_set_inode_index_count
(
struct
inode
*
inode
)
{
struct
btrfs_root
*
root
=
BTRFS_I
(
inode
)
->
root
;
struct
btrfs_key
key
,
found_key
;
struct
btrfs_path
*
path
;
struct
extent_buffer
*
leaf
;
int
ret
;
key
.
objectid
=
inode
->
i_ino
;
btrfs_set_key_type
(
&
key
,
BTRFS_DIR_INDEX_KEY
);
key
.
offset
=
(
u64
)
-
1
;
path
=
btrfs_alloc_path
();
if
(
!
path
)
return
-
ENOMEM
;
ret
=
btrfs_search_slot
(
NULL
,
root
,
&
key
,
path
,
0
,
0
);
if
(
ret
<
0
)
goto
out
;
/* FIXME: we should be able to handle this */
if
(
ret
==
0
)
goto
out
;
ret
=
0
;
/*
* MAGIC NUMBER EXPLANATION:
* since we search a directory based on f_pos we have to start at 2
* since '.' and '..' have f_pos of 0 and 1 respectively, so everybody
* else has to start at 2
*/
if
(
path
->
slots
[
0
]
==
0
)
{
BTRFS_I
(
inode
)
->
index_cnt
=
2
;
goto
out
;
}
path
->
slots
[
0
]
--
;
leaf
=
path
->
nodes
[
0
];
btrfs_item_key_to_cpu
(
leaf
,
&
found_key
,
path
->
slots
[
0
]);
if
(
found_key
.
objectid
!=
inode
->
i_ino
||
btrfs_key_type
(
&
found_key
)
!=
BTRFS_DIR_INDEX_KEY
)
{
BTRFS_I
(
inode
)
->
index_cnt
=
2
;
goto
out
;
}
BTRFS_I
(
inode
)
->
index_cnt
=
found_key
.
offset
+
1
;
out:
btrfs_free_path
(
path
);
return
ret
;
}
static
int
btrfs_set_inode_index
(
struct
inode
*
dir
,
struct
inode
*
inode
)
{
int
ret
=
0
;
if
(
BTRFS_I
(
dir
)
->
index_cnt
==
(
u64
)
-
1
)
{
ret
=
btrfs_set_inode_index_count
(
dir
);
if
(
ret
)
return
ret
;
}
BTRFS_I
(
inode
)
->
index
=
BTRFS_I
(
dir
)
->
index_cnt
;
BTRFS_I
(
dir
)
->
index_cnt
++
;
return
ret
;
}
static
struct
inode
*
btrfs_new_inode
(
struct
btrfs_trans_handle
*
trans
,
static
struct
inode
*
btrfs_new_inode
(
struct
btrfs_trans_handle
*
trans
,
struct
btrfs_root
*
root
,
struct
btrfs_root
*
root
,
struct
inode
*
dir
,
const
char
*
name
,
int
name_len
,
const
char
*
name
,
int
name_len
,
u64
ref_objectid
,
u64
ref_objectid
,
u64
objectid
,
u64
objectid
,
...
@@ -1928,6 +2003,20 @@ static struct inode *btrfs_new_inode(struct btrfs_trans_handle *trans,
...
@@ -1928,6 +2003,20 @@ static struct inode *btrfs_new_inode(struct btrfs_trans_handle *trans,
if
(
!
inode
)
if
(
!
inode
)
return
ERR_PTR
(
-
ENOMEM
);
return
ERR_PTR
(
-
ENOMEM
);
if
(
dir
)
{
ret
=
btrfs_set_inode_index
(
dir
,
inode
);
if
(
ret
)
return
ERR_PTR
(
ret
);
}
else
{
BTRFS_I
(
inode
)
->
index
=
0
;
}
/*
* index_cnt is ignored for everything but a dir,
* btrfs_get_inode_index_count has an explanation for the magic
* number
*/
BTRFS_I
(
inode
)
->
index_cnt
=
2
;
extent_map_tree_init
(
&
BTRFS_I
(
inode
)
->
extent_tree
,
GFP_NOFS
);
extent_map_tree_init
(
&
BTRFS_I
(
inode
)
->
extent_tree
,
GFP_NOFS
);
extent_io_tree_init
(
&
BTRFS_I
(
inode
)
->
io_tree
,
extent_io_tree_init
(
&
BTRFS_I
(
inode
)
->
io_tree
,
inode
->
i_mapping
,
GFP_NOFS
);
inode
->
i_mapping
,
GFP_NOFS
);
...
@@ -1984,6 +2073,7 @@ static struct inode *btrfs_new_inode(struct btrfs_trans_handle *trans,
...
@@ -1984,6 +2073,7 @@ static struct inode *btrfs_new_inode(struct btrfs_trans_handle *trans,
ref
=
btrfs_item_ptr
(
path
->
nodes
[
0
],
path
->
slots
[
0
]
+
1
,
ref
=
btrfs_item_ptr
(
path
->
nodes
[
0
],
path
->
slots
[
0
]
+
1
,
struct
btrfs_inode_ref
);
struct
btrfs_inode_ref
);
btrfs_set_inode_ref_name_len
(
path
->
nodes
[
0
],
ref
,
name_len
);
btrfs_set_inode_ref_name_len
(
path
->
nodes
[
0
],
ref
,
name_len
);
btrfs_set_inode_ref_index
(
path
->
nodes
[
0
],
ref
,
BTRFS_I
(
inode
)
->
index
);
ptr
=
(
unsigned
long
)(
ref
+
1
);
ptr
=
(
unsigned
long
)(
ref
+
1
);
write_extent_buffer
(
path
->
nodes
[
0
],
name
,
ptr
,
name_len
);
write_extent_buffer
(
path
->
nodes
[
0
],
name
,
ptr
,
name_len
);
...
@@ -1998,6 +2088,8 @@ static struct inode *btrfs_new_inode(struct btrfs_trans_handle *trans,
...
@@ -1998,6 +2088,8 @@ static struct inode *btrfs_new_inode(struct btrfs_trans_handle *trans,
insert_inode_hash
(
inode
);
insert_inode_hash
(
inode
);
return
inode
;
return
inode
;
fail:
fail:
if
(
dir
)
BTRFS_I
(
dir
)
->
index_cnt
--
;
btrfs_free_path
(
path
);
btrfs_free_path
(
path
);
return
ERR_PTR
(
ret
);
return
ERR_PTR
(
ret
);
}
}
...
@@ -2014,7 +2106,7 @@ static int btrfs_add_link(struct btrfs_trans_handle *trans,
...
@@ -2014,7 +2106,7 @@ static int btrfs_add_link(struct btrfs_trans_handle *trans,
int
ret
;
int
ret
;
struct
btrfs_key
key
;
struct
btrfs_key
key
;
struct
btrfs_root
*
root
=
BTRFS_I
(
dentry
->
d_parent
->
d_inode
)
->
root
;
struct
btrfs_root
*
root
=
BTRFS_I
(
dentry
->
d_parent
->
d_inode
)
->
root
;
struct
inode
*
parent_inode
;
struct
inode
*
parent_inode
=
dentry
->
d_parent
->
d_inode
;
key
.
objectid
=
inode
->
i_ino
;
key
.
objectid
=
inode
->
i_ino
;
btrfs_set_key_type
(
&
key
,
BTRFS_INODE_ITEM_KEY
);
btrfs_set_key_type
(
&
key
,
BTRFS_INODE_ITEM_KEY
);
...
@@ -2023,16 +2115,17 @@ static int btrfs_add_link(struct btrfs_trans_handle *trans,
...
@@ -2023,16 +2115,17 @@ static int btrfs_add_link(struct btrfs_trans_handle *trans,
ret
=
btrfs_insert_dir_item
(
trans
,
root
,
ret
=
btrfs_insert_dir_item
(
trans
,
root
,
dentry
->
d_name
.
name
,
dentry
->
d_name
.
len
,
dentry
->
d_name
.
name
,
dentry
->
d_name
.
len
,
dentry
->
d_parent
->
d_inode
->
i_ino
,
dentry
->
d_parent
->
d_inode
->
i_ino
,
&
key
,
btrfs_inode_type
(
inode
));
&
key
,
btrfs_inode_type
(
inode
),
BTRFS_I
(
inode
)
->
index
);
if
(
ret
==
0
)
{
if
(
ret
==
0
)
{
if
(
add_backref
)
{
if
(
add_backref
)
{
ret
=
btrfs_insert_inode_ref
(
trans
,
root
,
ret
=
btrfs_insert_inode_ref
(
trans
,
root
,
dentry
->
d_name
.
name
,
dentry
->
d_name
.
name
,
dentry
->
d_name
.
len
,
dentry
->
d_name
.
len
,
inode
->
i_ino
,
inode
->
i_ino
,
dentry
->
d_parent
->
d_inode
->
i_ino
);
parent_inode
->
i_ino
,
BTRFS_I
(
inode
)
->
index
);
}
}
parent_inode
=
dentry
->
d_parent
->
d_inode
;
btrfs_i_size_write
(
parent_inode
,
parent_inode
->
i_size
+
btrfs_i_size_write
(
parent_inode
,
parent_inode
->
i_size
+
dentry
->
d_name
.
len
*
2
);
dentry
->
d_name
.
len
*
2
);
parent_inode
->
i_mtime
=
parent_inode
->
i_ctime
=
CURRENT_TIME
;
parent_inode
->
i_mtime
=
parent_inode
->
i_ctime
=
CURRENT_TIME
;
...
@@ -2083,7 +2176,7 @@ static int btrfs_mknod(struct inode *dir, struct dentry *dentry,
...
@@ -2083,7 +2176,7 @@ static int btrfs_mknod(struct inode *dir, struct dentry *dentry,
goto
out_unlock
;
goto
out_unlock
;
}
}
inode
=
btrfs_new_inode
(
trans
,
root
,
dentry
->
d_name
.
name
,
inode
=
btrfs_new_inode
(
trans
,
root
,
d
ir
,
d
entry
->
d_name
.
name
,
dentry
->
d_name
.
len
,
dentry
->
d_name
.
len
,
dentry
->
d_parent
->
d_inode
->
i_ino
,
objectid
,
dentry
->
d_parent
->
d_inode
->
i_ino
,
objectid
,
BTRFS_I
(
dir
)
->
block_group
,
mode
);
BTRFS_I
(
dir
)
->
block_group
,
mode
);
...
@@ -2138,7 +2231,7 @@ static int btrfs_create(struct inode *dir, struct dentry *dentry,
...
@@ -2138,7 +2231,7 @@ static int btrfs_create(struct inode *dir, struct dentry *dentry,
goto
out_unlock
;
goto
out_unlock
;
}
}
inode
=
btrfs_new_inode
(
trans
,
root
,
dentry
->
d_name
.
name
,
inode
=
btrfs_new_inode
(
trans
,
root
,
d
ir
,
d
entry
->
d_name
.
name
,
dentry
->
d_name
.
len
,
dentry
->
d_name
.
len
,
dentry
->
d_parent
->
d_inode
->
i_ino
,
dentry
->
d_parent
->
d_inode
->
i_ino
,
objectid
,
BTRFS_I
(
dir
)
->
block_group
,
mode
);
objectid
,
BTRFS_I
(
dir
)
->
block_group
,
mode
);
...
@@ -2203,10 +2296,15 @@ static int btrfs_link(struct dentry *old_dentry, struct inode *dir,
...
@@ -2203,10 +2296,15 @@ static int btrfs_link(struct dentry *old_dentry, struct inode *dir,
err
=
btrfs_check_free_space
(
root
,
1
,
0
);
err
=
btrfs_check_free_space
(
root
,
1
,
0
);
if
(
err
)
if
(
err
)
goto
fail
;
goto
fail
;
err
=
btrfs_set_inode_index
(
dir
,
inode
);
if
(
err
)
goto
fail
;
trans
=
btrfs_start_transaction
(
root
,
1
);
trans
=
btrfs_start_transaction
(
root
,
1
);
btrfs_set_trans_block_group
(
trans
,
dir
);
btrfs_set_trans_block_group
(
trans
,
dir
);
atomic_inc
(
&
inode
->
i_count
);
atomic_inc
(
&
inode
->
i_count
);
err
=
btrfs_add_nondir
(
trans
,
dentry
,
inode
,
1
);
err
=
btrfs_add_nondir
(
trans
,
dentry
,
inode
,
1
);
if
(
err
)
if
(
err
)
...
@@ -2258,7 +2356,7 @@ static int btrfs_mkdir(struct inode *dir, struct dentry *dentry, int mode)
...
@@ -2258,7 +2356,7 @@ static int btrfs_mkdir(struct inode *dir, struct dentry *dentry, int mode)
goto
out_unlock
;
goto
out_unlock
;
}
}
inode
=
btrfs_new_inode
(
trans
,
root
,
dentry
->
d_name
.
name
,
inode
=
btrfs_new_inode
(
trans
,
root
,
d
ir
,
d
entry
->
d_name
.
name
,
dentry
->
d_name
.
len
,
dentry
->
d_name
.
len
,
dentry
->
d_parent
->
d_inode
->
i_ino
,
objectid
,
dentry
->
d_parent
->
d_inode
->
i_ino
,
objectid
,
BTRFS_I
(
dir
)
->
block_group
,
S_IFDIR
|
mode
);
BTRFS_I
(
dir
)
->
block_group
,
S_IFDIR
|
mode
);
...
@@ -2886,9 +2984,8 @@ int btrfs_create_subvol_root(struct btrfs_root *new_root,
...
@@ -2886,9 +2984,8 @@ int btrfs_create_subvol_root(struct btrfs_root *new_root,
struct
btrfs_block_group_cache
*
block_group
)
struct
btrfs_block_group_cache
*
block_group
)
{
{
struct
inode
*
inode
;
struct
inode
*
inode
;
int
ret
;
inode
=
btrfs_new_inode
(
trans
,
new_root
,
".."
,
2
,
new_dirid
,
inode
=
btrfs_new_inode
(
trans
,
new_root
,
NULL
,
".."
,
2
,
new_dirid
,
new_dirid
,
block_group
,
S_IFDIR
|
0700
);
new_dirid
,
block_group
,
S_IFDIR
|
0700
);
if
(
IS_ERR
(
inode
))
if
(
IS_ERR
(
inode
))
return
PTR_ERR
(
inode
);
return
PTR_ERR
(
inode
);
...
@@ -2896,8 +2993,6 @@ int btrfs_create_subvol_root(struct btrfs_root *new_root,
...
@@ -2896,8 +2993,6 @@ int btrfs_create_subvol_root(struct btrfs_root *new_root,
inode
->
i_fop
=
&
btrfs_dir_file_operations
;
inode
->
i_fop
=
&
btrfs_dir_file_operations
;
new_root
->
inode
=
inode
;
new_root
->
inode
=
inode
;
ret
=
btrfs_insert_inode_ref
(
trans
,
new_root
,
".."
,
2
,
new_dirid
,
new_dirid
);
inode
->
i_nlink
=
1
;
inode
->
i_nlink
=
1
;
btrfs_i_size_write
(
inode
,
0
);
btrfs_i_size_write
(
inode
,
0
);
...
@@ -3078,6 +3173,10 @@ static int btrfs_rename(struct inode * old_dir, struct dentry *old_dentry,
...
@@ -3078,6 +3173,10 @@ static int btrfs_rename(struct inode * old_dir, struct dentry *old_dentry,
if
(
ret
)
if
(
ret
)
goto
out_fail
;
goto
out_fail
;
}
}
ret
=
btrfs_set_inode_index
(
new_dir
,
old_inode
);
if
(
ret
)
goto
out_fail
;
ret
=
btrfs_add_link
(
trans
,
new_dentry
,
old_inode
,
1
);
ret
=
btrfs_add_link
(
trans
,
new_dentry
,
old_inode
,
1
);
if
(
ret
)
if
(
ret
)
goto
out_fail
;
goto
out_fail
;
...
@@ -3123,7 +3222,7 @@ static int btrfs_symlink(struct inode *dir, struct dentry *dentry,
...
@@ -3123,7 +3222,7 @@ static int btrfs_symlink(struct inode *dir, struct dentry *dentry,
goto
out_unlock
;
goto
out_unlock
;
}
}
inode
=
btrfs_new_inode
(
trans
,
root
,
dentry
->
d_name
.
name
,
inode
=
btrfs_new_inode
(
trans
,
root
,
d
ir
,
d
entry
->
d_name
.
name
,
dentry
->
d_name
.
len
,
dentry
->
d_name
.
len
,
dentry
->
d_parent
->
d_inode
->
i_ino
,
objectid
,
dentry
->
d_parent
->
d_inode
->
i_ino
,
objectid
,
BTRFS_I
(
dir
)
->
block_group
,
S_IFLNK
|
S_IRWXUGO
);
BTRFS_I
(
dir
)
->
block_group
,
S_IFLNK
|
S_IRWXUGO
);
...
...
fs/btrfs/ioctl.c
View file @
aec7477b
...
@@ -129,13 +129,13 @@ static noinline int create_subvol(struct btrfs_root *root, char *name,
...
@@ -129,13 +129,13 @@ static noinline int create_subvol(struct btrfs_root *root, char *name,
dir
=
root
->
fs_info
->
sb
->
s_root
->
d_inode
;
dir
=
root
->
fs_info
->
sb
->
s_root
->
d_inode
;
ret
=
btrfs_insert_dir_item
(
trans
,
root
->
fs_info
->
tree_root
,
ret
=
btrfs_insert_dir_item
(
trans
,
root
->
fs_info
->
tree_root
,
name
,
namelen
,
dir
->
i_ino
,
&
key
,
name
,
namelen
,
dir
->
i_ino
,
&
key
,
BTRFS_FT_DIR
);
BTRFS_FT_DIR
,
0
);
if
(
ret
)
if
(
ret
)
goto
fail
;
goto
fail
;
ret
=
btrfs_insert_inode_ref
(
trans
,
root
->
fs_info
->
tree_root
,
ret
=
btrfs_insert_inode_ref
(
trans
,
root
->
fs_info
->
tree_root
,
name
,
namelen
,
objectid
,
name
,
namelen
,
objectid
,
root
->
fs_info
->
sb
->
s_root
->
d_inode
->
i_ino
);
root
->
fs_info
->
sb
->
s_root
->
d_inode
->
i_ino
,
0
);
if
(
ret
)
if
(
ret
)
goto
fail
;
goto
fail
;
...
...
fs/btrfs/transaction.c
View file @
aec7477b
...
@@ -577,14 +577,14 @@ static noinline int create_pending_snapshot(struct btrfs_trans_handle *trans,
...
@@ -577,14 +577,14 @@ static noinline int create_pending_snapshot(struct btrfs_trans_handle *trans,
ret
=
btrfs_insert_dir_item
(
trans
,
root
->
fs_info
->
tree_root
,
ret
=
btrfs_insert_dir_item
(
trans
,
root
->
fs_info
->
tree_root
,
pending
->
name
,
namelen
,
pending
->
name
,
namelen
,
root
->
fs_info
->
sb
->
s_root
->
d_inode
->
i_ino
,
root
->
fs_info
->
sb
->
s_root
->
d_inode
->
i_ino
,
&
key
,
BTRFS_FT_DIR
);
&
key
,
BTRFS_FT_DIR
,
0
);
if
(
ret
)
if
(
ret
)
goto
fail
;
goto
fail
;
ret
=
btrfs_insert_inode_ref
(
trans
,
root
->
fs_info
->
tree_root
,
ret
=
btrfs_insert_inode_ref
(
trans
,
root
->
fs_info
->
tree_root
,
pending
->
name
,
strlen
(
pending
->
name
),
objectid
,
pending
->
name
,
strlen
(
pending
->
name
),
objectid
,
root
->
fs_info
->
sb
->
s_root
->
d_inode
->
i_ino
);
root
->
fs_info
->
sb
->
s_root
->
d_inode
->
i_ino
,
0
);
/* Invalidate existing dcache entry for new snapshot. */
/* Invalidate existing dcache entry for new snapshot. */
btrfs_invalidate_dcache_root
(
root
,
pending
->
name
,
namelen
);
btrfs_invalidate_dcache_root
(
root
,
pending
->
name
,
namelen
);
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment