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
ea8c2819
Commit
ea8c2819
authored
Aug 04, 2008
by
Chris Mason
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Btrfs: Maintain a list of inodes that are delalloc and a way to wait on them
Signed-off-by:
Chris Mason
<
chris.mason@oracle.com
>
parent
d7a029a8
Changes
7
Show whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
60 additions
and
13 deletions
+60
-13
fs/btrfs/btrfs_inode.h
fs/btrfs/btrfs_inode.h
+2
-0
fs/btrfs/ctree.h
fs/btrfs/ctree.h
+4
-0
fs/btrfs/disk-io.c
fs/btrfs/disk-io.c
+1
-0
fs/btrfs/extent-tree.c
fs/btrfs/extent-tree.c
+9
-3
fs/btrfs/file.c
fs/btrfs/file.c
+1
-2
fs/btrfs/inode.c
fs/btrfs/inode.c
+41
-6
fs/btrfs/ioctl.c
fs/btrfs/ioctl.c
+2
-2
No files found.
fs/btrfs/btrfs_inode.h
View file @
ea8c2819
...
@@ -42,6 +42,8 @@ struct btrfs_inode {
...
@@ -42,6 +42,8 @@ struct btrfs_inode {
/* for keeping track of orphaned inodes */
/* for keeping track of orphaned inodes */
struct
list_head
i_orphan
;
struct
list_head
i_orphan
;
struct
list_head
delalloc_inodes
;
/*
/*
* transid of the trans_handle that last modified this inode
* transid of the trans_handle that last modified this inode
*/
*/
...
...
fs/btrfs/ctree.h
View file @
ea8c2819
...
@@ -551,6 +551,7 @@ struct btrfs_fs_info {
...
@@ -551,6 +551,7 @@ struct btrfs_fs_info {
*/
*/
spinlock_t
ordered_extent_lock
;
spinlock_t
ordered_extent_lock
;
struct
list_head
ordered_extents
;
struct
list_head
ordered_extents
;
struct
list_head
delalloc_inodes
;
/*
/*
* there is a pool of worker threads for checksumming during writes
* there is a pool of worker threads for checksumming during writes
...
@@ -637,6 +638,7 @@ struct btrfs_root {
...
@@ -637,6 +638,7 @@ struct btrfs_root {
struct
kobject
root_kobj
;
struct
kobject
root_kobj
;
struct
completion
kobj_unregister
;
struct
completion
kobj_unregister
;
struct
mutex
objectid_mutex
;
struct
mutex
objectid_mutex
;
u64
objectid
;
u64
objectid
;
u64
last_trans
;
u64
last_trans
;
...
@@ -1651,6 +1653,8 @@ int btrfs_csum_truncate(struct btrfs_trans_handle *trans,
...
@@ -1651,6 +1653,8 @@ int btrfs_csum_truncate(struct btrfs_trans_handle *trans,
#define PageChecked PageFsMisc
#define PageChecked PageFsMisc
#endif
#endif
int
btrfs_start_delalloc_inodes
(
struct
btrfs_root
*
root
);
int
btrfs_set_extent_delalloc
(
struct
inode
*
inode
,
u64
start
,
u64
end
);
int
btrfs_writepages
(
struct
address_space
*
mapping
,
int
btrfs_writepages
(
struct
address_space
*
mapping
,
struct
writeback_control
*
wbc
);
struct
writeback_control
*
wbc
);
int
btrfs_create_subvol_root
(
struct
btrfs_root
*
new_root
,
int
btrfs_create_subvol_root
(
struct
btrfs_root
*
new_root
,
...
...
fs/btrfs/disk-io.c
View file @
ea8c2819
...
@@ -1234,6 +1234,7 @@ struct btrfs_root *open_ctree(struct super_block *sb,
...
@@ -1234,6 +1234,7 @@ struct btrfs_root *open_ctree(struct super_block *sb,
INIT_LIST_HEAD
(
&
fs_info
->
trans_list
);
INIT_LIST_HEAD
(
&
fs_info
->
trans_list
);
INIT_LIST_HEAD
(
&
fs_info
->
dead_roots
);
INIT_LIST_HEAD
(
&
fs_info
->
dead_roots
);
INIT_LIST_HEAD
(
&
fs_info
->
hashers
);
INIT_LIST_HEAD
(
&
fs_info
->
hashers
);
INIT_LIST_HEAD
(
&
fs_info
->
delalloc_inodes
);
spin_lock_init
(
&
fs_info
->
hash_lock
);
spin_lock_init
(
&
fs_info
->
hash_lock
);
spin_lock_init
(
&
fs_info
->
delalloc_lock
);
spin_lock_init
(
&
fs_info
->
delalloc_lock
);
spin_lock_init
(
&
fs_info
->
new_trans_lock
);
spin_lock_init
(
&
fs_info
->
new_trans_lock
);
...
...
fs/btrfs/extent-tree.c
View file @
ea8c2819
...
@@ -1230,7 +1230,6 @@ static int update_space_info(struct btrfs_fs_info *info, u64 flags,
...
@@ -1230,7 +1230,6 @@ static int update_space_info(struct btrfs_fs_info *info, u64 flags,
found
->
total_bytes
+=
total_bytes
;
found
->
total_bytes
+=
total_bytes
;
found
->
bytes_used
+=
bytes_used
;
found
->
bytes_used
+=
bytes_used
;
found
->
full
=
0
;
found
->
full
=
0
;
WARN_ON
(
found
->
total_bytes
<
found
->
bytes_used
);
*
space_info
=
found
;
*
space_info
=
found
;
return
0
;
return
0
;
}
}
...
@@ -2841,8 +2840,7 @@ again:
...
@@ -2841,8 +2840,7 @@ again:
*/
*/
clear_page_dirty_for_io
(
page
);
clear_page_dirty_for_io
(
page
);
set_extent_delalloc
(
io_tree
,
page_start
,
btrfs_set_extent_delalloc
(
inode
,
page_start
,
page_end
);
page_end
,
GFP_NOFS
);
set_page_dirty
(
page
);
set_page_dirty
(
page
);
unlock_extent
(
io_tree
,
page_start
,
page_end
,
GFP_NOFS
);
unlock_extent
(
io_tree
,
page_start
,
page_end
,
GFP_NOFS
);
...
@@ -3319,6 +3317,13 @@ again:
...
@@ -3319,6 +3317,13 @@ again:
key
.
type
=
0
;
key
.
type
=
0
;
cur_byte
=
key
.
objectid
;
cur_byte
=
key
.
objectid
;
mutex_unlock
(
&
root
->
fs_info
->
alloc_mutex
);
btrfs_start_delalloc_inodes
(
root
);
btrfs_wait_ordered_extents
(
tree_root
);
mutex_lock
(
&
root
->
fs_info
->
alloc_mutex
);
ret
=
btrfs_search_slot
(
NULL
,
root
,
&
key
,
path
,
0
,
0
);
ret
=
btrfs_search_slot
(
NULL
,
root
,
&
key
,
path
,
0
,
0
);
if
(
ret
<
0
)
if
(
ret
<
0
)
goto
out
;
goto
out
;
...
@@ -3401,6 +3406,7 @@ next:
...
@@ -3401,6 +3406,7 @@ next:
btrfs_clean_old_snapshots
(
tree_root
);
btrfs_clean_old_snapshots
(
tree_root
);
btrfs_start_delalloc_inodes
(
root
);
btrfs_wait_ordered_extents
(
tree_root
);
btrfs_wait_ordered_extents
(
tree_root
);
trans
=
btrfs_start_transaction
(
tree_root
,
1
);
trans
=
btrfs_start_transaction
(
tree_root
,
1
);
...
...
fs/btrfs/file.c
View file @
ea8c2819
...
@@ -312,8 +312,7 @@ static int noinline dirty_and_release_pages(struct btrfs_trans_handle *trans,
...
@@ -312,8 +312,7 @@ static int noinline dirty_and_release_pages(struct btrfs_trans_handle *trans,
* to reset the delalloc bit on things that already have
* to reset the delalloc bit on things that already have
* extents reserved.
* extents reserved.
*/
*/
set_extent_delalloc
(
io_tree
,
start_pos
,
btrfs_set_extent_delalloc
(
inode
,
start_pos
,
end_of_last_block
);
end_of_last_block
,
GFP_NOFS
);
for
(
i
=
0
;
i
<
num_pages
;
i
++
)
{
for
(
i
=
0
;
i
<
num_pages
;
i
++
)
{
struct
page
*
p
=
pages
[
i
];
struct
page
*
p
=
pages
[
i
];
SetPageUptodate
(
p
);
SetPageUptodate
(
p
);
...
...
fs/btrfs/inode.c
View file @
ea8c2819
...
@@ -303,6 +303,10 @@ int btrfs_set_bit_hook(struct inode *inode, u64 start, u64 end,
...
@@ -303,6 +303,10 @@ int btrfs_set_bit_hook(struct inode *inode, u64 start, u64 end,
spin_lock_irqsave
(
&
root
->
fs_info
->
delalloc_lock
,
flags
);
spin_lock_irqsave
(
&
root
->
fs_info
->
delalloc_lock
,
flags
);
BTRFS_I
(
inode
)
->
delalloc_bytes
+=
end
-
start
+
1
;
BTRFS_I
(
inode
)
->
delalloc_bytes
+=
end
-
start
+
1
;
root
->
fs_info
->
delalloc_bytes
+=
end
-
start
+
1
;
root
->
fs_info
->
delalloc_bytes
+=
end
-
start
+
1
;
if
(
list_empty
(
&
BTRFS_I
(
inode
)
->
delalloc_inodes
))
{
list_add_tail
(
&
BTRFS_I
(
inode
)
->
delalloc_inodes
,
&
root
->
fs_info
->
delalloc_inodes
);
}
spin_unlock_irqrestore
(
&
root
->
fs_info
->
delalloc_lock
,
flags
);
spin_unlock_irqrestore
(
&
root
->
fs_info
->
delalloc_lock
,
flags
);
}
}
return
0
;
return
0
;
...
@@ -325,6 +329,10 @@ int btrfs_clear_bit_hook(struct inode *inode, u64 start, u64 end,
...
@@ -325,6 +329,10 @@ int btrfs_clear_bit_hook(struct inode *inode, u64 start, u64 end,
root
->
fs_info
->
delalloc_bytes
-=
end
-
start
+
1
;
root
->
fs_info
->
delalloc_bytes
-=
end
-
start
+
1
;
BTRFS_I
(
inode
)
->
delalloc_bytes
-=
end
-
start
+
1
;
BTRFS_I
(
inode
)
->
delalloc_bytes
-=
end
-
start
+
1
;
}
}
if
(
BTRFS_I
(
inode
)
->
delalloc_bytes
==
0
&&
!
list_empty
(
&
BTRFS_I
(
inode
)
->
delalloc_inodes
))
{
list_del_init
(
&
BTRFS_I
(
inode
)
->
delalloc_inodes
);
}
spin_unlock_irqrestore
(
&
root
->
fs_info
->
delalloc_lock
,
flags
);
spin_unlock_irqrestore
(
&
root
->
fs_info
->
delalloc_lock
,
flags
);
}
}
return
0
;
return
0
;
...
@@ -408,6 +416,12 @@ static noinline int add_pending_csums(struct btrfs_trans_handle *trans,
...
@@ -408,6 +416,12 @@ static noinline int add_pending_csums(struct btrfs_trans_handle *trans,
return
0
;
return
0
;
}
}
int
btrfs_set_extent_delalloc
(
struct
inode
*
inode
,
u64
start
,
u64
end
)
{
return
set_extent_delalloc
(
&
BTRFS_I
(
inode
)
->
io_tree
,
start
,
end
,
GFP_NOFS
);
}
struct
btrfs_writepage_fixup
{
struct
btrfs_writepage_fixup
{
struct
page
*
page
;
struct
page
*
page
;
struct
btrfs_work
work
;
struct
btrfs_work
work
;
...
@@ -453,8 +467,7 @@ again:
...
@@ -453,8 +467,7 @@ again:
goto
again
;
goto
again
;
}
}
set_extent_delalloc
(
&
BTRFS_I
(
inode
)
->
io_tree
,
page_start
,
page_end
,
btrfs_set_extent_delalloc
(
inode
,
page_start
,
page_end
);
GFP_NOFS
);
ClearPageChecked
(
page
);
ClearPageChecked
(
page
);
out:
out:
unlock_extent
(
&
BTRFS_I
(
inode
)
->
io_tree
,
page_start
,
page_end
,
GFP_NOFS
);
unlock_extent
(
&
BTRFS_I
(
inode
)
->
io_tree
,
page_start
,
page_end
,
GFP_NOFS
);
...
@@ -1530,8 +1543,7 @@ again:
...
@@ -1530,8 +1543,7 @@ again:
goto
again
;
goto
again
;
}
}
set_extent_delalloc
(
&
BTRFS_I
(
inode
)
->
io_tree
,
page_start
,
btrfs_set_extent_delalloc
(
inode
,
page_start
,
page_end
);
page_end
,
GFP_NOFS
);
ret
=
0
;
ret
=
0
;
if
(
offset
!=
PAGE_CACHE_SIZE
)
{
if
(
offset
!=
PAGE_CACHE_SIZE
)
{
kaddr
=
kmap
(
page
);
kaddr
=
kmap
(
page
);
...
@@ -1766,6 +1778,7 @@ static int btrfs_init_locked_inode(struct inode *inode, void *p)
...
@@ -1766,6 +1778,7 @@ static int btrfs_init_locked_inode(struct inode *inode, void *p)
inode
->
i_mapping
,
GFP_NOFS
);
inode
->
i_mapping
,
GFP_NOFS
);
extent_io_tree_init
(
&
BTRFS_I
(
inode
)
->
io_failure_tree
,
extent_io_tree_init
(
&
BTRFS_I
(
inode
)
->
io_failure_tree
,
inode
->
i_mapping
,
GFP_NOFS
);
inode
->
i_mapping
,
GFP_NOFS
);
INIT_LIST_HEAD
(
&
BTRFS_I
(
inode
)
->
delalloc_inodes
);
btrfs_ordered_inode_tree_init
(
&
BTRFS_I
(
inode
)
->
ordered_tree
);
btrfs_ordered_inode_tree_init
(
&
BTRFS_I
(
inode
)
->
ordered_tree
);
mutex_init
(
&
BTRFS_I
(
inode
)
->
csum_mutex
);
mutex_init
(
&
BTRFS_I
(
inode
)
->
csum_mutex
);
mutex_init
(
&
BTRFS_I
(
inode
)
->
extent_mutex
);
mutex_init
(
&
BTRFS_I
(
inode
)
->
extent_mutex
);
...
@@ -2158,6 +2171,7 @@ static struct inode *btrfs_new_inode(struct btrfs_trans_handle *trans,
...
@@ -2158,6 +2171,7 @@ static struct inode *btrfs_new_inode(struct btrfs_trans_handle *trans,
extent_io_tree_init
(
&
BTRFS_I
(
inode
)
->
io_failure_tree
,
extent_io_tree_init
(
&
BTRFS_I
(
inode
)
->
io_failure_tree
,
inode
->
i_mapping
,
GFP_NOFS
);
inode
->
i_mapping
,
GFP_NOFS
);
btrfs_ordered_inode_tree_init
(
&
BTRFS_I
(
inode
)
->
ordered_tree
);
btrfs_ordered_inode_tree_init
(
&
BTRFS_I
(
inode
)
->
ordered_tree
);
INIT_LIST_HEAD
(
&
BTRFS_I
(
inode
)
->
delalloc_inodes
);
mutex_init
(
&
BTRFS_I
(
inode
)
->
csum_mutex
);
mutex_init
(
&
BTRFS_I
(
inode
)
->
csum_mutex
);
mutex_init
(
&
BTRFS_I
(
inode
)
->
extent_mutex
);
mutex_init
(
&
BTRFS_I
(
inode
)
->
extent_mutex
);
BTRFS_I
(
inode
)
->
delalloc_bytes
=
0
;
BTRFS_I
(
inode
)
->
delalloc_bytes
=
0
;
...
@@ -2400,6 +2414,7 @@ static int btrfs_create(struct inode *dir, struct dentry *dentry,
...
@@ -2400,6 +2414,7 @@ static int btrfs_create(struct inode *dir, struct dentry *dentry,
inode
->
i_mapping
,
GFP_NOFS
);
inode
->
i_mapping
,
GFP_NOFS
);
extent_io_tree_init
(
&
BTRFS_I
(
inode
)
->
io_failure_tree
,
extent_io_tree_init
(
&
BTRFS_I
(
inode
)
->
io_failure_tree
,
inode
->
i_mapping
,
GFP_NOFS
);
inode
->
i_mapping
,
GFP_NOFS
);
INIT_LIST_HEAD
(
&
BTRFS_I
(
inode
)
->
delalloc_inodes
);
mutex_init
(
&
BTRFS_I
(
inode
)
->
csum_mutex
);
mutex_init
(
&
BTRFS_I
(
inode
)
->
csum_mutex
);
mutex_init
(
&
BTRFS_I
(
inode
)
->
extent_mutex
);
mutex_init
(
&
BTRFS_I
(
inode
)
->
extent_mutex
);
BTRFS_I
(
inode
)
->
delalloc_bytes
=
0
;
BTRFS_I
(
inode
)
->
delalloc_bytes
=
0
;
...
@@ -3049,8 +3064,7 @@ again:
...
@@ -3049,8 +3064,7 @@ again:
goto
again
;
goto
again
;
}
}
set_extent_delalloc
(
&
BTRFS_I
(
inode
)
->
io_tree
,
page_start
,
btrfs_set_extent_delalloc
(
inode
,
page_start
,
page_end
);
page_end
,
GFP_NOFS
);
ret
=
0
;
ret
=
0
;
/* page is wholly or partially inside EOF */
/* page is wholly or partially inside EOF */
...
@@ -3373,6 +3387,26 @@ out_unlock:
...
@@ -3373,6 +3387,26 @@ out_unlock:
return
ret
;
return
ret
;
}
}
int
btrfs_start_delalloc_inodes
(
struct
btrfs_root
*
root
)
{
struct
list_head
*
head
=
&
root
->
fs_info
->
delalloc_inodes
;
struct
btrfs_inode
*
binode
;
unsigned
long
flags
;
spin_lock_irqsave
(
&
root
->
fs_info
->
delalloc_lock
,
flags
);
while
(
!
list_empty
(
head
))
{
binode
=
list_entry
(
head
->
next
,
struct
btrfs_inode
,
delalloc_inodes
);
atomic_inc
(
&
binode
->
vfs_inode
.
i_count
);
spin_unlock_irqrestore
(
&
root
->
fs_info
->
delalloc_lock
,
flags
);
filemap_write_and_wait
(
binode
->
vfs_inode
.
i_mapping
);
iput
(
&
binode
->
vfs_inode
);
spin_lock_irqsave
(
&
root
->
fs_info
->
delalloc_lock
,
flags
);
}
spin_unlock_irqrestore
(
&
root
->
fs_info
->
delalloc_lock
,
flags
);
return
0
;
}
static
int
btrfs_symlink
(
struct
inode
*
dir
,
struct
dentry
*
dentry
,
static
int
btrfs_symlink
(
struct
inode
*
dir
,
struct
dentry
*
dentry
,
const
char
*
symname
)
const
char
*
symname
)
{
{
...
@@ -3436,6 +3470,7 @@ static int btrfs_symlink(struct inode *dir, struct dentry *dentry,
...
@@ -3436,6 +3470,7 @@ static int btrfs_symlink(struct inode *dir, struct dentry *dentry,
inode
->
i_mapping
,
GFP_NOFS
);
inode
->
i_mapping
,
GFP_NOFS
);
extent_io_tree_init
(
&
BTRFS_I
(
inode
)
->
io_failure_tree
,
extent_io_tree_init
(
&
BTRFS_I
(
inode
)
->
io_failure_tree
,
inode
->
i_mapping
,
GFP_NOFS
);
inode
->
i_mapping
,
GFP_NOFS
);
INIT_LIST_HEAD
(
&
BTRFS_I
(
inode
)
->
delalloc_inodes
);
mutex_init
(
&
BTRFS_I
(
inode
)
->
csum_mutex
);
mutex_init
(
&
BTRFS_I
(
inode
)
->
csum_mutex
);
mutex_init
(
&
BTRFS_I
(
inode
)
->
extent_mutex
);
mutex_init
(
&
BTRFS_I
(
inode
)
->
extent_mutex
);
BTRFS_I
(
inode
)
->
delalloc_bytes
=
0
;
BTRFS_I
(
inode
)
->
delalloc_bytes
=
0
;
...
...
fs/btrfs/ioctl.c
View file @
ea8c2819
...
@@ -274,8 +274,7 @@ again:
...
@@ -274,8 +274,7 @@ again:
*/
*/
clear_page_dirty_for_io
(
page
);
clear_page_dirty_for_io
(
page
);
set_extent_delalloc
(
io_tree
,
page_start
,
btrfs_set_extent_delalloc
(
inode
,
page_start
,
page_end
);
page_end
,
GFP_NOFS
);
unlock_extent
(
io_tree
,
page_start
,
page_end
,
GFP_NOFS
);
unlock_extent
(
io_tree
,
page_start
,
page_end
,
GFP_NOFS
);
set_page_dirty
(
page
);
set_page_dirty
(
page
);
...
@@ -784,6 +783,7 @@ long btrfs_ioctl(struct file *file, unsigned int
...
@@ -784,6 +783,7 @@ long btrfs_ioctl(struct file *file, unsigned int
case
BTRFS_IOC_TRANS_END
:
case
BTRFS_IOC_TRANS_END
:
return
btrfs_ioctl_trans_end
(
file
);
return
btrfs_ioctl_trans_end
(
file
);
case
BTRFS_IOC_SYNC
:
case
BTRFS_IOC_SYNC
:
btrfs_start_delalloc_inodes
(
root
);
btrfs_sync_fs
(
file
->
f_dentry
->
d_sb
,
1
);
btrfs_sync_fs
(
file
->
f_dentry
->
d_sb
,
1
);
return
0
;
return
0
;
}
}
...
...
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