Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
linux
Commits
fabb5681
Commit
fabb5681
authored
Jun 07, 2007
by
Chris Mason
Committed by
David Woodhouse
Jun 07, 2007
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Btrfs: d_type optimization
Signed-off-by:
Chris Mason
<
chris.mason@oracle.com
>
parent
fbdc762b
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
68 additions
and
9 deletions
+68
-9
fs/btrfs/ctree.h
fs/btrfs/ctree.h
+10
-0
fs/btrfs/extent-tree.c
fs/btrfs/extent-tree.c
+1
-0
fs/btrfs/super.c
fs/btrfs/super.c
+57
-9
No files found.
fs/btrfs/ctree.h
View file @
fabb5681
...
@@ -34,6 +34,16 @@ extern struct kmem_cache *btrfs_path_cachep;
...
@@ -34,6 +34,16 @@ extern struct kmem_cache *btrfs_path_cachep;
#define BTRFS_CRC32_SIZE 4
#define BTRFS_CRC32_SIZE 4
#define BTRFS_EMPTY_DIR_SIZE 6
#define BTRFS_EMPTY_DIR_SIZE 6
#define BTRFS_FT_UNKNOWN 0
#define BTRFS_FT_REG_FILE 1
#define BTRFS_FT_DIR 2
#define BTRFS_FT_CHRDEV 3
#define BTRFS_FT_BLKDEV 4
#define BTRFS_FT_FIFO 5
#define BTRFS_FT_SOCK 6
#define BTRFS_FT_SYMLINK 7
#define BTRFS_FT_MAX 8
/*
/*
* the key defines the order in the tree, and so it also defines (optimal)
* the key defines the order in the tree, and so it also defines (optimal)
* block layout. objectid corresonds to the inode number. The flags
* block layout. objectid corresonds to the inode number. The flags
...
...
fs/btrfs/extent-tree.c
View file @
fabb5681
...
@@ -1264,6 +1264,7 @@ int btrfs_alloc_extent(struct btrfs_trans_handle *trans,
...
@@ -1264,6 +1264,7 @@ int btrfs_alloc_extent(struct btrfs_trans_handle *trans,
}
}
ret
=
update_block_group
(
trans
,
root
,
ins
->
objectid
,
ins
->
offset
,
1
,
0
,
ret
=
update_block_group
(
trans
,
root
,
ins
->
objectid
,
ins
->
offset
,
1
,
0
,
data
);
data
);
BUG_ON
(
ret
);
return
0
;
return
0
;
}
}
...
...
fs/btrfs/super.c
View file @
fabb5681
...
@@ -43,6 +43,18 @@ static int drop_extents(struct btrfs_trans_handle *trans,
...
@@ -43,6 +43,18 @@ static int drop_extents(struct btrfs_trans_handle *trans,
static
int
btrfs_get_block
(
struct
inode
*
inode
,
sector_t
iblock
,
static
int
btrfs_get_block
(
struct
inode
*
inode
,
sector_t
iblock
,
struct
buffer_head
*
result
,
int
create
);
struct
buffer_head
*
result
,
int
create
);
#define S_SHIFT 12
static
unsigned
char
btrfs_type_by_mode
[
S_IFMT
>>
S_SHIFT
]
=
{
[
S_IFREG
>>
S_SHIFT
]
=
BTRFS_FT_REG_FILE
,
[
S_IFDIR
>>
S_SHIFT
]
=
BTRFS_FT_DIR
,
[
S_IFCHR
>>
S_SHIFT
]
=
BTRFS_FT_CHRDEV
,
[
S_IFBLK
>>
S_SHIFT
]
=
BTRFS_FT_BLKDEV
,
[
S_IFIFO
>>
S_SHIFT
]
=
BTRFS_FT_FIFO
,
[
S_IFSOCK
>>
S_SHIFT
]
=
BTRFS_FT_SOCK
,
[
S_IFLNK
>>
S_SHIFT
]
=
BTRFS_FT_SYMLINK
,
};
static
void
btrfs_read_locked_inode
(
struct
inode
*
inode
)
static
void
btrfs_read_locked_inode
(
struct
inode
*
inode
)
{
{
struct
btrfs_path
*
path
;
struct
btrfs_path
*
path
;
...
@@ -785,6 +797,9 @@ static void reada_leaves(struct btrfs_root *root, struct btrfs_path *path,
...
@@ -785,6 +797,9 @@ static void reada_leaves(struct btrfs_root *root, struct btrfs_path *path,
break
;
break
;
}
}
}
}
static
unsigned
char
btrfs_filetype_table
[]
=
{
DT_UNKNOWN
,
DT_REG
,
DT_DIR
,
DT_CHR
,
DT_BLK
,
DT_FIFO
,
DT_SOCK
,
DT_LNK
};
static
int
btrfs_readdir
(
struct
file
*
filp
,
void
*
dirent
,
filldir_t
filldir
)
static
int
btrfs_readdir
(
struct
file
*
filp
,
void
*
dirent
,
filldir_t
filldir
)
{
{
...
@@ -799,7 +814,7 @@ static int btrfs_readdir(struct file *filp, void *dirent, filldir_t filldir)
...
@@ -799,7 +814,7 @@ static int btrfs_readdir(struct file *filp, void *dirent, filldir_t filldir)
struct
btrfs_leaf
*
leaf
;
struct
btrfs_leaf
*
leaf
;
int
slot
;
int
slot
;
int
advance
;
int
advance
;
unsigned
char
d_type
=
DT_UNKNOWN
;
unsigned
char
d_type
;
int
over
=
0
;
int
over
=
0
;
u32
di_cur
;
u32
di_cur
;
u32
di_total
;
u32
di_total
;
...
@@ -853,6 +868,7 @@ static int btrfs_readdir(struct file *filp, void *dirent, filldir_t filldir)
...
@@ -853,6 +868,7 @@ static int btrfs_readdir(struct file *filp, void *dirent, filldir_t filldir)
di_cur
=
0
;
di_cur
=
0
;
di_total
=
btrfs_item_size
(
leaf
->
items
+
slot
);
di_total
=
btrfs_item_size
(
leaf
->
items
+
slot
);
while
(
di_cur
<
di_total
)
{
while
(
di_cur
<
di_total
)
{
d_type
=
btrfs_filetype_table
[
btrfs_dir_type
(
di
)];
over
=
filldir
(
dirent
,
(
const
char
*
)(
di
+
1
),
over
=
filldir
(
dirent
,
(
const
char
*
)(
di
+
1
),
btrfs_dir_name_len
(
di
),
btrfs_dir_name_len
(
di
),
btrfs_disk_key_offset
(
&
item
->
key
),
btrfs_disk_key_offset
(
&
item
->
key
),
...
@@ -1012,6 +1028,11 @@ static struct inode *btrfs_new_inode(struct btrfs_trans_handle *trans,
...
@@ -1012,6 +1028,11 @@ static struct inode *btrfs_new_inode(struct btrfs_trans_handle *trans,
return
inode
;
return
inode
;
}
}
static
inline
u8
btrfs_inode_type
(
struct
inode
*
inode
)
{
return
btrfs_type_by_mode
[(
inode
->
i_mode
&
S_IFMT
)
>>
S_SHIFT
];
}
static
int
btrfs_add_link
(
struct
btrfs_trans_handle
*
trans
,
static
int
btrfs_add_link
(
struct
btrfs_trans_handle
*
trans
,
struct
dentry
*
dentry
,
struct
inode
*
inode
)
struct
dentry
*
dentry
,
struct
inode
*
inode
)
{
{
...
@@ -1026,7 +1047,7 @@ static int btrfs_add_link(struct btrfs_trans_handle *trans,
...
@@ -1026,7 +1047,7 @@ 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
,
0
);
&
key
,
btrfs_inode_type
(
inode
)
);
if
(
ret
==
0
)
{
if
(
ret
==
0
)
{
dentry
->
d_parent
->
d_inode
->
i_size
+=
dentry
->
d_name
.
len
*
2
;
dentry
->
d_parent
->
d_inode
->
i_size
+=
dentry
->
d_name
.
len
*
2
;
ret
=
btrfs_update_inode
(
trans
,
root
,
ret
=
btrfs_update_inode
(
trans
,
root
,
...
@@ -1150,12 +1171,12 @@ static int btrfs_make_empty_dir(struct btrfs_trans_handle *trans,
...
@@ -1150,12 +1171,12 @@ static int btrfs_make_empty_dir(struct btrfs_trans_handle *trans,
btrfs_set_key_type
(
&
key
,
BTRFS_INODE_ITEM_KEY
);
btrfs_set_key_type
(
&
key
,
BTRFS_INODE_ITEM_KEY
);
ret
=
btrfs_insert_dir_item
(
trans
,
root
,
buf
,
1
,
objectid
,
ret
=
btrfs_insert_dir_item
(
trans
,
root
,
buf
,
1
,
objectid
,
&
key
,
1
);
&
key
,
BTRFS_FT_DIR
);
if
(
ret
)
if
(
ret
)
goto
error
;
goto
error
;
key
.
objectid
=
dirid
;
key
.
objectid
=
dirid
;
ret
=
btrfs_insert_dir_item
(
trans
,
root
,
buf
,
2
,
objectid
,
ret
=
btrfs_insert_dir_item
(
trans
,
root
,
buf
,
2
,
objectid
,
&
key
,
1
);
&
key
,
BTRFS_FT_DIR
);
if
(
ret
)
if
(
ret
)
goto
error
;
goto
error
;
error:
error:
...
@@ -1265,6 +1286,10 @@ printk("btrfs sync_fs\n");
...
@@ -1265,6 +1286,10 @@ printk("btrfs sync_fs\n");
return
0
;
return
0
;
}
}
#define BTRFS_GET_BLOCK_NO_CREATE 0
#define BTRFS_GET_BLOCK_CREATE 1
#define BTRFS_GET_BLOCK_NO_DIRECT 2
static
int
btrfs_get_block_lock
(
struct
inode
*
inode
,
sector_t
iblock
,
static
int
btrfs_get_block_lock
(
struct
inode
*
inode
,
sector_t
iblock
,
struct
buffer_head
*
result
,
int
create
)
struct
buffer_head
*
result
,
int
create
)
{
{
...
@@ -1286,7 +1311,7 @@ static int btrfs_get_block_lock(struct inode *inode, sector_t iblock,
...
@@ -1286,7 +1311,7 @@ static int btrfs_get_block_lock(struct inode *inode, sector_t iblock,
path
=
btrfs_alloc_path
();
path
=
btrfs_alloc_path
();
BUG_ON
(
!
path
);
BUG_ON
(
!
path
);
btrfs_init_path
(
path
);
btrfs_init_path
(
path
);
if
(
create
)
{
if
(
create
&
BTRFS_GET_BLOCK_CREATE
)
{
WARN_ON
(
1
);
WARN_ON
(
1
);
/* this almost but not quite works */
/* this almost but not quite works */
trans
=
btrfs_start_transaction
(
root
,
1
);
trans
=
btrfs_start_transaction
(
root
,
1
);
...
@@ -1349,6 +1374,11 @@ static int btrfs_get_block_lock(struct inode *inode, sector_t iblock,
...
@@ -1349,6 +1374,11 @@ static int btrfs_get_block_lock(struct inode *inode, sector_t iblock,
char
*
ptr
;
char
*
ptr
;
char
*
map
;
char
*
map
;
u32
size
;
u32
size
;
if
(
create
&
BTRFS_GET_BLOCK_NO_DIRECT
)
{
err
=
-
EINVAL
;
goto
out
;
}
size
=
btrfs_file_extent_inline_len
(
leaf
->
items
+
size
=
btrfs_file_extent_inline_len
(
leaf
->
items
+
path
->
slots
[
0
]);
path
->
slots
[
0
]);
extent_end
=
(
extent_start
+
size
)
>>
inode
->
i_blkbits
;
extent_end
=
(
extent_start
+
size
)
>>
inode
->
i_blkbits
;
...
@@ -1367,7 +1397,7 @@ static int btrfs_get_block_lock(struct inode *inode, sector_t iblock,
...
@@ -1367,7 +1397,7 @@ static int btrfs_get_block_lock(struct inode *inode, sector_t iblock,
btrfs_map_bh_to_logical
(
root
,
result
,
0
);
btrfs_map_bh_to_logical
(
root
,
result
,
0
);
}
}
not_found:
not_found:
if
(
create
)
{
if
(
create
&
BTRFS_GET_BLOCK_CREATE
)
{
struct
btrfs_key
ins
;
struct
btrfs_key
ins
;
ret
=
btrfs_alloc_extent
(
trans
,
root
,
inode
->
i_ino
,
ret
=
btrfs_alloc_extent
(
trans
,
root
,
inode
->
i_ino
,
1
,
alloc_hint
,
(
u64
)
-
1
,
1
,
alloc_hint
,
(
u64
)
-
1
,
...
@@ -1399,6 +1429,21 @@ static int btrfs_get_block(struct inode *inode, sector_t iblock,
...
@@ -1399,6 +1429,21 @@ static int btrfs_get_block(struct inode *inode, sector_t iblock,
return
err
;
return
err
;
}
}
static
int
btrfs_get_block_bmap
(
struct
inode
*
inode
,
sector_t
iblock
,
struct
buffer_head
*
result
,
int
create
)
{
struct
btrfs_root
*
root
=
BTRFS_I
(
inode
)
->
root
;
mutex_lock
(
&
root
->
fs_info
->
fs_mutex
);
btrfs_get_block_lock
(
inode
,
iblock
,
result
,
BTRFS_GET_BLOCK_NO_DIRECT
);
mutex_unlock
(
&
root
->
fs_info
->
fs_mutex
);
return
0
;
}
static
sector_t
btrfs_bmap
(
struct
address_space
*
as
,
sector_t
block
)
{
return
generic_block_bmap
(
as
,
block
,
btrfs_get_block_bmap
);
}
static
int
btrfs_prepare_write
(
struct
file
*
file
,
struct
page
*
page
,
static
int
btrfs_prepare_write
(
struct
file
*
file
,
struct
page
*
page
,
unsigned
from
,
unsigned
to
)
unsigned
from
,
unsigned
to
)
{
{
...
@@ -2428,7 +2473,8 @@ static int create_subvol(struct btrfs_root *root, char *name, int namelen)
...
@@ -2428,7 +2473,8 @@ static int create_subvol(struct btrfs_root *root, char *name, int namelen)
key
.
offset
=
(
u64
)
-
1
;
key
.
offset
=
(
u64
)
-
1
;
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
,
0
);
name
,
namelen
,
dir
->
i_ino
,
&
key
,
BTRFS_FT_DIR
);
BUG_ON
(
ret
);
BUG_ON
(
ret
);
ret
=
btrfs_commit_transaction
(
trans
,
root
);
ret
=
btrfs_commit_transaction
(
trans
,
root
);
...
@@ -2505,7 +2551,7 @@ static int create_snapshot(struct btrfs_root *root, char *name, int namelen)
...
@@ -2505,7 +2551,7 @@ static int create_snapshot(struct btrfs_root *root, char *name, int namelen)
ret
=
btrfs_insert_dir_item
(
trans
,
root
->
fs_info
->
tree_root
,
ret
=
btrfs_insert_dir_item
(
trans
,
root
->
fs_info
->
tree_root
,
name
,
namelen
,
name
,
namelen
,
root
->
fs_info
->
sb
->
s_root
->
d_inode
->
i_ino
,
root
->
fs_info
->
sb
->
s_root
->
d_inode
->
i_ino
,
&
key
,
0
);
&
key
,
BTRFS_FT_DIR
);
BUG_ON
(
ret
);
BUG_ON
(
ret
);
...
@@ -2833,7 +2879,8 @@ static int btrfs_rename(struct inode * old_dir, struct dentry *old_dentry,
...
@@ -2833,7 +2879,8 @@ static int btrfs_rename(struct inode * old_dir, struct dentry *old_dentry,
btrfs_release_path
(
root
,
path
);
btrfs_release_path
(
root
,
path
);
ret
=
btrfs_insert_dir_item
(
trans
,
root
,
".."
,
2
,
ret
=
btrfs_insert_dir_item
(
trans
,
root
,
".."
,
2
,
old_inode
->
i_ino
,
location
,
0
);
old_inode
->
i_ino
,
location
,
BTRFS_FT_DIR
);
if
(
ret
)
if
(
ret
)
goto
out_fail
;
goto
out_fail
;
}
}
...
@@ -3003,6 +3050,7 @@ static struct address_space_operations btrfs_aops = {
...
@@ -3003,6 +3050,7 @@ static struct address_space_operations btrfs_aops = {
.
sync_page
=
block_sync_page
,
.
sync_page
=
block_sync_page
,
.
prepare_write
=
btrfs_prepare_write
,
.
prepare_write
=
btrfs_prepare_write
,
.
commit_write
=
btrfs_commit_write
,
.
commit_write
=
btrfs_commit_write
,
.
bmap
=
btrfs_bmap
,
};
};
static
struct
address_space_operations
btrfs_symlink_aops
=
{
static
struct
address_space_operations
btrfs_symlink_aops
=
{
...
...
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