Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
L
linux-davinci-2.6.23
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-2.6.23
Commits
8caf8915
Commit
8caf8915
authored
Oct 28, 2005
by
Linus Torvalds
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'for-linus' of
git://git.kernel.org/pub/scm/linux/kernel/git/shaggy/jfs-2.6
parents
f12baeab
7038f1cb
Changes
6
Show whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
38 additions
and
19 deletions
+38
-19
fs/jfs/jfs_dmap.c
fs/jfs/jfs_dmap.c
+14
-6
fs/jfs/jfs_imap.c
fs/jfs/jfs_imap.c
+8
-2
fs/jfs/jfs_metapage.c
fs/jfs/jfs_metapage.c
+6
-0
fs/jfs/jfs_txnmgr.c
fs/jfs/jfs_txnmgr.c
+0
-2
fs/jfs/jfs_xtree.c
fs/jfs/jfs_xtree.c
+9
-9
fs/jfs/super.c
fs/jfs/super.c
+1
-0
No files found.
fs/jfs/jfs_dmap.c
View file @
8caf8915
...
@@ -74,7 +74,7 @@
...
@@ -74,7 +74,7 @@
static
void
dbAllocBits
(
struct
bmap
*
bmp
,
struct
dmap
*
dp
,
s64
blkno
,
static
void
dbAllocBits
(
struct
bmap
*
bmp
,
struct
dmap
*
dp
,
s64
blkno
,
int
nblocks
);
int
nblocks
);
static
void
dbSplit
(
dmtree_t
*
tp
,
int
leafno
,
int
splitsz
,
int
newval
);
static
void
dbSplit
(
dmtree_t
*
tp
,
int
leafno
,
int
splitsz
,
int
newval
);
static
void
dbBackSplit
(
dmtree_t
*
tp
,
int
leafno
);
static
int
dbBackSplit
(
dmtree_t
*
tp
,
int
leafno
);
static
int
dbJoin
(
dmtree_t
*
tp
,
int
leafno
,
int
newval
);
static
int
dbJoin
(
dmtree_t
*
tp
,
int
leafno
,
int
newval
);
static
void
dbAdjTree
(
dmtree_t
*
tp
,
int
leafno
,
int
newval
);
static
void
dbAdjTree
(
dmtree_t
*
tp
,
int
leafno
,
int
newval
);
static
int
dbAdjCtl
(
struct
bmap
*
bmp
,
s64
blkno
,
int
newval
,
int
alloc
,
static
int
dbAdjCtl
(
struct
bmap
*
bmp
,
s64
blkno
,
int
newval
,
int
alloc
,
...
@@ -305,7 +305,6 @@ int dbSync(struct inode *ipbmap)
...
@@ -305,7 +305,6 @@ int dbSync(struct inode *ipbmap)
filemap_fdatawrite
(
ipbmap
->
i_mapping
);
filemap_fdatawrite
(
ipbmap
->
i_mapping
);
filemap_fdatawait
(
ipbmap
->
i_mapping
);
filemap_fdatawait
(
ipbmap
->
i_mapping
);
ipbmap
->
i_state
|=
I_DIRTY
;
diWriteSpecial
(
ipbmap
,
0
);
diWriteSpecial
(
ipbmap
,
0
);
return
(
0
);
return
(
0
);
...
@@ -2467,7 +2466,9 @@ dbAdjCtl(struct bmap * bmp, s64 blkno, int newval, int alloc, int level)
...
@@ -2467,7 +2466,9 @@ dbAdjCtl(struct bmap * bmp, s64 blkno, int newval, int alloc, int level)
* that it is at the front of a binary buddy system.
* that it is at the front of a binary buddy system.
*/
*/
if
(
oldval
==
NOFREE
)
{
if
(
oldval
==
NOFREE
)
{
dbBackSplit
((
dmtree_t
*
)
dcp
,
leafno
);
rc
=
dbBackSplit
((
dmtree_t
*
)
dcp
,
leafno
);
if
(
rc
)
return
rc
;
oldval
=
dcp
->
stree
[
ti
];
oldval
=
dcp
->
stree
[
ti
];
}
}
dbSplit
((
dmtree_t
*
)
dcp
,
leafno
,
dcp
->
budmin
,
newval
);
dbSplit
((
dmtree_t
*
)
dcp
,
leafno
,
dcp
->
budmin
,
newval
);
...
@@ -2627,7 +2628,7 @@ static void dbSplit(dmtree_t * tp, int leafno, int splitsz, int newval)
...
@@ -2627,7 +2628,7 @@ static void dbSplit(dmtree_t * tp, int leafno, int splitsz, int newval)
*
*
* serialization: IREAD_LOCK(ipbmap) or IWRITE_LOCK(ipbmap) held on entry/exit;
* serialization: IREAD_LOCK(ipbmap) or IWRITE_LOCK(ipbmap) held on entry/exit;
*/
*/
static
void
dbBackSplit
(
dmtree_t
*
tp
,
int
leafno
)
static
int
dbBackSplit
(
dmtree_t
*
tp
,
int
leafno
)
{
{
int
budsz
,
bud
,
w
,
bsz
,
size
;
int
budsz
,
bud
,
w
,
bsz
,
size
;
int
cursz
;
int
cursz
;
...
@@ -2662,7 +2663,10 @@ static void dbBackSplit(dmtree_t * tp, int leafno)
...
@@ -2662,7 +2663,10 @@ static void dbBackSplit(dmtree_t * tp, int leafno)
*/
*/
for
(
w
=
leafno
,
bsz
=
budsz
;;
bsz
<<=
1
,
for
(
w
=
leafno
,
bsz
=
budsz
;;
bsz
<<=
1
,
w
=
(
w
<
bud
)
?
w
:
bud
)
{
w
=
(
w
<
bud
)
?
w
:
bud
)
{
assert
(
bsz
<
le32_to_cpu
(
tp
->
dmt_nleafs
));
if
(
bsz
>=
le32_to_cpu
(
tp
->
dmt_nleafs
))
{
jfs_err
(
"JFS: block map error in dbBackSplit"
);
return
-
EIO
;
}
/* determine the buddy.
/* determine the buddy.
*/
*/
...
@@ -2681,7 +2685,11 @@ static void dbBackSplit(dmtree_t * tp, int leafno)
...
@@ -2681,7 +2685,11 @@ static void dbBackSplit(dmtree_t * tp, int leafno)
}
}
}
}
assert
(
leaf
[
leafno
]
==
size
);
if
(
leaf
[
leafno
]
!=
size
)
{
jfs_err
(
"JFS: wrong leaf value in dbBackSplit"
);
return
-
EIO
;
}
return
0
;
}
}
...
...
fs/jfs/jfs_imap.c
View file @
8caf8915
...
@@ -56,6 +56,12 @@
...
@@ -56,6 +56,12 @@
#include "jfs_superblock.h"
#include "jfs_superblock.h"
#include "jfs_debug.h"
#include "jfs_debug.h"
/*
* __mark_inode_dirty expects inodes to be hashed. Since we don't want
* special inodes in the fileset inode space, we hash them to a dummy head
*/
static
HLIST_HEAD
(
aggregate_hash
);
/*
/*
* imap locks
* imap locks
*/
*/
...
@@ -491,6 +497,8 @@ struct inode *diReadSpecial(struct super_block *sb, ino_t inum, int secondary)
...
@@ -491,6 +497,8 @@ struct inode *diReadSpecial(struct super_block *sb, ino_t inum, int secondary)
/* release the page */
/* release the page */
release_metapage
(
mp
);
release_metapage
(
mp
);
hlist_add_head
(
&
ip
->
i_hash
,
&
aggregate_hash
);
return
(
ip
);
return
(
ip
);
}
}
...
@@ -514,8 +522,6 @@ void diWriteSpecial(struct inode *ip, int secondary)
...
@@ -514,8 +522,6 @@ void diWriteSpecial(struct inode *ip, int secondary)
ino_t
inum
=
ip
->
i_ino
;
ino_t
inum
=
ip
->
i_ino
;
struct
metapage
*
mp
;
struct
metapage
*
mp
;
ip
->
i_state
&=
~
I_DIRTY
;
if
(
secondary
)
if
(
secondary
)
address
=
addressPXD
(
&
sbi
->
ait2
)
>>
sbi
->
l2nbperpage
;
address
=
addressPXD
(
&
sbi
->
ait2
)
>>
sbi
->
l2nbperpage
;
else
else
...
...
fs/jfs/jfs_metapage.c
View file @
8caf8915
...
@@ -395,6 +395,12 @@ static int metapage_writepage(struct page *page, struct writeback_control *wbc)
...
@@ -395,6 +395,12 @@ static int metapage_writepage(struct page *page, struct writeback_control *wbc)
if
(
mp
->
nohomeok
&&
!
test_bit
(
META_forcewrite
,
&
mp
->
flag
))
{
if
(
mp
->
nohomeok
&&
!
test_bit
(
META_forcewrite
,
&
mp
->
flag
))
{
redirty
=
1
;
redirty
=
1
;
/*
* Make sure this page isn't blocked indefinitely.
* If the journal isn't undergoing I/O, push it
*/
if
(
mp
->
log
&&
!
(
mp
->
log
->
cflag
&
logGC_PAGEOUT
))
jfs_flush_journal
(
mp
->
log
,
0
);
continue
;
continue
;
}
}
...
...
fs/jfs/jfs_txnmgr.c
View file @
8caf8915
...
@@ -2396,7 +2396,6 @@ static void txUpdateMap(struct tblock * tblk)
...
@@ -2396,7 +2396,6 @@ static void txUpdateMap(struct tblock * tblk)
*/
*/
if
(
tblk
->
xflag
&
COMMIT_CREATE
)
{
if
(
tblk
->
xflag
&
COMMIT_CREATE
)
{
diUpdatePMap
(
ipimap
,
tblk
->
ino
,
FALSE
,
tblk
);
diUpdatePMap
(
ipimap
,
tblk
->
ino
,
FALSE
,
tblk
);
ipimap
->
i_state
|=
I_DIRTY
;
/* update persistent block allocation map
/* update persistent block allocation map
* for the allocation of inode extent;
* for the allocation of inode extent;
*/
*/
...
@@ -2407,7 +2406,6 @@ static void txUpdateMap(struct tblock * tblk)
...
@@ -2407,7 +2406,6 @@ static void txUpdateMap(struct tblock * tblk)
}
else
if
(
tblk
->
xflag
&
COMMIT_DELETE
)
{
}
else
if
(
tblk
->
xflag
&
COMMIT_DELETE
)
{
ip
=
tblk
->
u
.
ip
;
ip
=
tblk
->
u
.
ip
;
diUpdatePMap
(
ipimap
,
ip
->
i_ino
,
TRUE
,
tblk
);
diUpdatePMap
(
ipimap
,
ip
->
i_ino
,
TRUE
,
tblk
);
ipimap
->
i_state
|=
I_DIRTY
;
iput
(
ip
);
iput
(
ip
);
}
}
}
}
...
...
fs/jfs/jfs_xtree.c
View file @
8caf8915
...
@@ -3516,16 +3516,10 @@ s64 xtTruncate(tid_t tid, struct inode *ip, s64 newsize, int flag)
...
@@ -3516,16 +3516,10 @@ s64 xtTruncate(tid_t tid, struct inode *ip, s64 newsize, int flag)
/* process entries backward from last index */
/* process entries backward from last index */
index
=
le16_to_cpu
(
p
->
header
.
nextindex
)
-
1
;
index
=
le16_to_cpu
(
p
->
header
.
nextindex
)
-
1
;
if
(
p
->
header
.
flag
&
BT_INTERNAL
)
goto
getChild
;
/*
* leaf page
*/
/* Since this is the rightmost
leaf, and we may have already freed
/* Since this is the rightmost
page at this level, and we may have
* a
page that was formerly to the right, let's make sure that th
e
* a
lready freed a page that was formerly to the right, let's mak
e
* next pointer is zero.
*
sure that the
next pointer is zero.
*/
*/
if
(
p
->
header
.
next
)
{
if
(
p
->
header
.
next
)
{
if
(
log
)
if
(
log
)
...
@@ -3539,6 +3533,12 @@ s64 xtTruncate(tid_t tid, struct inode *ip, s64 newsize, int flag)
...
@@ -3539,6 +3533,12 @@ s64 xtTruncate(tid_t tid, struct inode *ip, s64 newsize, int flag)
p
->
header
.
next
=
0
;
p
->
header
.
next
=
0
;
}
}
if
(
p
->
header
.
flag
&
BT_INTERNAL
)
goto
getChild
;
/*
* leaf page
*/
freed
=
0
;
freed
=
0
;
/* does region covered by leaf page precede Teof ? */
/* does region covered by leaf page precede Teof ? */
...
...
fs/jfs/super.c
View file @
8caf8915
...
@@ -442,6 +442,7 @@ static int jfs_fill_super(struct super_block *sb, void *data, int silent)
...
@@ -442,6 +442,7 @@ static int jfs_fill_super(struct super_block *sb, void *data, int silent)
inode
->
i_nlink
=
1
;
inode
->
i_nlink
=
1
;
inode
->
i_size
=
sb
->
s_bdev
->
bd_inode
->
i_size
;
inode
->
i_size
=
sb
->
s_bdev
->
bd_inode
->
i_size
;
inode
->
i_mapping
->
a_ops
=
&
jfs_metapage_aops
;
inode
->
i_mapping
->
a_ops
=
&
jfs_metapage_aops
;
insert_inode_hash
(
inode
);
mapping_set_gfp_mask
(
inode
->
i_mapping
,
GFP_NOFS
);
mapping_set_gfp_mask
(
inode
->
i_mapping
,
GFP_NOFS
);
sbi
->
direct_inode
=
inode
;
sbi
->
direct_inode
=
inode
;
...
...
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