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
nexedi
linux
Commits
89291a9d
Commit
89291a9d
authored
May 25, 2006
by
David Woodhouse
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[JFFS2] Fix 64-bit size_t problems in XATTR code.
Signed-off-by:
David Woodhouse
<
dwmw2@infradead.org
>
parent
c5b553cc
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
15 additions
and
15 deletions
+15
-15
fs/jffs2/scan.c
fs/jffs2/scan.c
+1
-1
fs/jffs2/xattr.c
fs/jffs2/xattr.c
+14
-14
No files found.
fs/jffs2/scan.c
View file @
89291a9d
...
@@ -379,7 +379,7 @@ static int jffs2_scan_xref_node(struct jffs2_sb_info *c, struct jffs2_eraseblock
...
@@ -379,7 +379,7 @@ static int jffs2_scan_xref_node(struct jffs2_sb_info *c, struct jffs2_eraseblock
}
}
if
(
PAD
(
sizeof
(
struct
jffs2_raw_xref
))
!=
je32_to_cpu
(
rr
->
totlen
))
{
if
(
PAD
(
sizeof
(
struct
jffs2_raw_xref
))
!=
je32_to_cpu
(
rr
->
totlen
))
{
JFFS2_WARNING
(
"node length mismatch at %#08x, read=%u, calc=%
u
\n
"
,
JFFS2_WARNING
(
"node length mismatch at %#08x, read=%u, calc=%
zd
\n
"
,
ofs
,
je32_to_cpu
(
rr
->
totlen
),
ofs
,
je32_to_cpu
(
rr
->
totlen
),
PAD
(
sizeof
(
struct
jffs2_raw_xref
)));
PAD
(
sizeof
(
struct
jffs2_raw_xref
)));
if
((
err
=
jffs2_scan_dirty_space
(
c
,
jeb
,
je32_to_cpu
(
rr
->
totlen
))))
if
((
err
=
jffs2_scan_dirty_space
(
c
,
jeb
,
je32_to_cpu
(
rr
->
totlen
))))
...
...
fs/jffs2/xattr.c
View file @
89291a9d
...
@@ -111,7 +111,7 @@ static void delete_xattr_datum_node(struct jffs2_sb_info *c, struct jffs2_xattr_
...
@@ -111,7 +111,7 @@ static void delete_xattr_datum_node(struct jffs2_sb_info *c, struct jffs2_xattr_
{
{
/* must be called under down_write(xattr_sem) */
/* must be called under down_write(xattr_sem) */
struct
jffs2_raw_xattr
rx
;
struct
jffs2_raw_xattr
rx
;
uint32
_t
length
;
size
_t
length
;
int
rc
;
int
rc
;
if
(
!
xd
->
node
)
{
if
(
!
xd
->
node
)
{
...
@@ -124,14 +124,14 @@ static void delete_xattr_datum_node(struct jffs2_sb_info *c, struct jffs2_xattr_
...
@@ -124,14 +124,14 @@ static void delete_xattr_datum_node(struct jffs2_sb_info *c, struct jffs2_xattr_
sizeof
(
struct
jffs2_unknown_node
),
sizeof
(
struct
jffs2_unknown_node
),
&
length
,
(
char
*
)
&
rx
);
&
length
,
(
char
*
)
&
rx
);
if
(
rc
||
length
!=
sizeof
(
struct
jffs2_unknown_node
))
{
if
(
rc
||
length
!=
sizeof
(
struct
jffs2_unknown_node
))
{
JFFS2_ERROR
(
"jffs2_flash_read()=%d, req=%
u, read=%
u at %#08x
\n
"
,
JFFS2_ERROR
(
"jffs2_flash_read()=%d, req=%
zu, read=%z
u at %#08x
\n
"
,
rc
,
sizeof
(
struct
jffs2_unknown_node
),
rc
,
sizeof
(
struct
jffs2_unknown_node
),
length
,
ref_offset
(
xd
->
node
));
length
,
ref_offset
(
xd
->
node
));
}
}
rc
=
jffs2_flash_write
(
c
,
ref_offset
(
xd
->
node
),
sizeof
(
rx
),
rc
=
jffs2_flash_write
(
c
,
ref_offset
(
xd
->
node
),
sizeof
(
rx
),
&
length
,
(
char
*
)
&
rx
);
&
length
,
(
char
*
)
&
rx
);
if
(
rc
||
length
!=
sizeof
(
struct
jffs2_raw_xattr
))
{
if
(
rc
||
length
!=
sizeof
(
struct
jffs2_raw_xattr
))
{
JFFS2_ERROR
(
"jffs2_flash_write()=%d, req=%
u, wrote=%
u ar %#08x
\n
"
,
JFFS2_ERROR
(
"jffs2_flash_write()=%d, req=%
zu, wrote=%z
u ar %#08x
\n
"
,
rc
,
sizeof
(
rx
),
length
,
ref_offset
(
xd
->
node
));
rc
,
sizeof
(
rx
),
length
,
ref_offset
(
xd
->
node
));
}
}
}
}
...
@@ -169,7 +169,7 @@ static int do_verify_xattr_datum(struct jffs2_sb_info *c, struct jffs2_xattr_dat
...
@@ -169,7 +169,7 @@ static int do_verify_xattr_datum(struct jffs2_sb_info *c, struct jffs2_xattr_dat
rc
=
jffs2_flash_read
(
c
,
ref_offset
(
xd
->
node
),
sizeof
(
rx
),
&
readlen
,
(
char
*
)
&
rx
);
rc
=
jffs2_flash_read
(
c
,
ref_offset
(
xd
->
node
),
sizeof
(
rx
),
&
readlen
,
(
char
*
)
&
rx
);
if
(
rc
||
readlen
!=
sizeof
(
rx
))
{
if
(
rc
||
readlen
!=
sizeof
(
rx
))
{
JFFS2_WARNING
(
"jffs2_flash_read()=%d, req=%
u, read=%
u at %#08x
\n
"
,
JFFS2_WARNING
(
"jffs2_flash_read()=%d, req=%
zu, read=%z
u at %#08x
\n
"
,
rc
,
sizeof
(
rx
),
readlen
,
ref_offset
(
xd
->
node
));
rc
,
sizeof
(
rx
),
readlen
,
ref_offset
(
xd
->
node
));
return
rc
?
rc
:
-
EIO
;
return
rc
?
rc
:
-
EIO
;
}
}
...
@@ -240,7 +240,7 @@ static int do_load_xattr_datum(struct jffs2_sb_info *c, struct jffs2_xattr_datum
...
@@ -240,7 +240,7 @@ static int do_load_xattr_datum(struct jffs2_sb_info *c, struct jffs2_xattr_datum
length
,
&
readlen
,
data
);
length
,
&
readlen
,
data
);
if
(
ret
||
length
!=
readlen
)
{
if
(
ret
||
length
!=
readlen
)
{
JFFS2_WARNING
(
"jffs2_flash_read() returned %d, request=%d, readlen=%
d
, at %#08x
\n
"
,
JFFS2_WARNING
(
"jffs2_flash_read() returned %d, request=%d, readlen=%
zu
, at %#08x
\n
"
,
ret
,
length
,
readlen
,
ref_offset
(
xd
->
node
));
ret
,
length
,
readlen
,
ref_offset
(
xd
->
node
));
kfree
(
data
);
kfree
(
data
);
return
ret
?
ret
:
-
EIO
;
return
ret
?
ret
:
-
EIO
;
...
@@ -307,7 +307,7 @@ static int save_xattr_datum(struct jffs2_sb_info *c, struct jffs2_xattr_datum *x
...
@@ -307,7 +307,7 @@ static int save_xattr_datum(struct jffs2_sb_info *c, struct jffs2_xattr_datum *x
struct
jffs2_raw_node_ref
*
raw
;
struct
jffs2_raw_node_ref
*
raw
;
struct
jffs2_raw_xattr
rx
;
struct
jffs2_raw_xattr
rx
;
struct
kvec
vecs
[
2
];
struct
kvec
vecs
[
2
];
uint32
_t
length
;
size
_t
length
;
int
rc
,
totlen
;
int
rc
,
totlen
;
uint32_t
phys_ofs
=
write_ofs
(
c
);
uint32_t
phys_ofs
=
write_ofs
(
c
);
...
@@ -335,7 +335,7 @@ static int save_xattr_datum(struct jffs2_sb_info *c, struct jffs2_xattr_datum *x
...
@@ -335,7 +335,7 @@ static int save_xattr_datum(struct jffs2_sb_info *c, struct jffs2_xattr_datum *x
rc
=
jffs2_flash_writev
(
c
,
vecs
,
2
,
phys_ofs
,
&
length
,
0
);
rc
=
jffs2_flash_writev
(
c
,
vecs
,
2
,
phys_ofs
,
&
length
,
0
);
if
(
rc
||
totlen
!=
length
)
{
if
(
rc
||
totlen
!=
length
)
{
JFFS2_WARNING
(
"jffs2_flash_writev()=%d, req=%u, wrote=%u, at %#08x
\n
"
,
JFFS2_WARNING
(
"jffs2_flash_writev()=%d, req=%u, wrote=%
z
u, at %#08x
\n
"
,
rc
,
totlen
,
length
,
phys_ofs
);
rc
,
totlen
,
length
,
phys_ofs
);
rc
=
rc
?
rc
:
-
EIO
;
rc
=
rc
?
rc
:
-
EIO
;
if
(
length
)
if
(
length
)
...
@@ -459,7 +459,7 @@ static int verify_xattr_ref(struct jffs2_sb_info *c, struct jffs2_xattr_ref *ref
...
@@ -459,7 +459,7 @@ static int verify_xattr_ref(struct jffs2_sb_info *c, struct jffs2_xattr_ref *ref
rc
=
jffs2_flash_read
(
c
,
ref_offset
(
ref
->
node
),
sizeof
(
rr
),
&
readlen
,
(
char
*
)
&
rr
);
rc
=
jffs2_flash_read
(
c
,
ref_offset
(
ref
->
node
),
sizeof
(
rr
),
&
readlen
,
(
char
*
)
&
rr
);
if
(
rc
||
sizeof
(
rr
)
!=
readlen
)
{
if
(
rc
||
sizeof
(
rr
)
!=
readlen
)
{
JFFS2_WARNING
(
"jffs2_flash_read()=%d, req=%
u, read=%
u, at %#08x
\n
"
,
JFFS2_WARNING
(
"jffs2_flash_read()=%d, req=%
zu, read=%z
u, at %#08x
\n
"
,
rc
,
sizeof
(
rr
),
readlen
,
ref_offset
(
ref
->
node
));
rc
,
sizeof
(
rr
),
readlen
,
ref_offset
(
ref
->
node
));
return
rc
?
rc
:
-
EIO
;
return
rc
?
rc
:
-
EIO
;
}
}
...
@@ -475,7 +475,7 @@ static int verify_xattr_ref(struct jffs2_sb_info *c, struct jffs2_xattr_ref *ref
...
@@ -475,7 +475,7 @@ static int verify_xattr_ref(struct jffs2_sb_info *c, struct jffs2_xattr_ref *ref
||
je16_to_cpu
(
rr
.
nodetype
)
!=
JFFS2_NODETYPE_XREF
||
je16_to_cpu
(
rr
.
nodetype
)
!=
JFFS2_NODETYPE_XREF
||
je32_to_cpu
(
rr
.
totlen
)
!=
PAD
(
sizeof
(
rr
)))
{
||
je32_to_cpu
(
rr
.
totlen
)
!=
PAD
(
sizeof
(
rr
)))
{
JFFS2_ERROR
(
"inconsistent xref at %#08x, magic=%#04x/%#04x, "
JFFS2_ERROR
(
"inconsistent xref at %#08x, magic=%#04x/%#04x, "
"nodetype=%#04x/%#04x, totlen=%u/%u
\n
"
,
"nodetype=%#04x/%#04x, totlen=%u/%
z
u
\n
"
,
ref_offset
(
ref
->
node
),
je16_to_cpu
(
rr
.
magic
),
JFFS2_MAGIC_BITMASK
,
ref_offset
(
ref
->
node
),
je16_to_cpu
(
rr
.
magic
),
JFFS2_MAGIC_BITMASK
,
je16_to_cpu
(
rr
.
nodetype
),
JFFS2_NODETYPE_XREF
,
je16_to_cpu
(
rr
.
nodetype
),
JFFS2_NODETYPE_XREF
,
je32_to_cpu
(
rr
.
totlen
),
PAD
(
sizeof
(
rr
)));
je32_to_cpu
(
rr
.
totlen
),
PAD
(
sizeof
(
rr
)));
...
@@ -502,7 +502,7 @@ static int verify_xattr_ref(struct jffs2_sb_info *c, struct jffs2_xattr_ref *ref
...
@@ -502,7 +502,7 @@ static int verify_xattr_ref(struct jffs2_sb_info *c, struct jffs2_xattr_ref *ref
static
void
delete_xattr_ref_node
(
struct
jffs2_sb_info
*
c
,
struct
jffs2_xattr_ref
*
ref
)
static
void
delete_xattr_ref_node
(
struct
jffs2_sb_info
*
c
,
struct
jffs2_xattr_ref
*
ref
)
{
{
struct
jffs2_raw_xref
rr
;
struct
jffs2_raw_xref
rr
;
uint32
_t
length
;
size
_t
length
;
int
rc
;
int
rc
;
if
(
jffs2_sum_active
())
{
if
(
jffs2_sum_active
())
{
...
@@ -511,14 +511,14 @@ static void delete_xattr_ref_node(struct jffs2_sb_info *c, struct jffs2_xattr_re
...
@@ -511,14 +511,14 @@ static void delete_xattr_ref_node(struct jffs2_sb_info *c, struct jffs2_xattr_re
sizeof
(
struct
jffs2_unknown_node
),
sizeof
(
struct
jffs2_unknown_node
),
&
length
,
(
char
*
)
&
rr
);
&
length
,
(
char
*
)
&
rr
);
if
(
rc
||
length
!=
sizeof
(
struct
jffs2_unknown_node
))
{
if
(
rc
||
length
!=
sizeof
(
struct
jffs2_unknown_node
))
{
JFFS2_ERROR
(
"jffs2_flash_read()=%d, req=%
u, read=%
u at %#08x
\n
"
,
JFFS2_ERROR
(
"jffs2_flash_read()=%d, req=%
zu, read=%z
u at %#08x
\n
"
,
rc
,
sizeof
(
struct
jffs2_unknown_node
),
rc
,
sizeof
(
struct
jffs2_unknown_node
),
length
,
ref_offset
(
ref
->
node
));
length
,
ref_offset
(
ref
->
node
));
}
}
rc
=
jffs2_flash_write
(
c
,
ref_offset
(
ref
->
node
),
sizeof
(
rr
),
rc
=
jffs2_flash_write
(
c
,
ref_offset
(
ref
->
node
),
sizeof
(
rr
),
&
length
,
(
char
*
)
&
rr
);
&
length
,
(
char
*
)
&
rr
);
if
(
rc
||
length
!=
sizeof
(
struct
jffs2_raw_xref
))
{
if
(
rc
||
length
!=
sizeof
(
struct
jffs2_raw_xref
))
{
JFFS2_ERROR
(
"jffs2_flash_write()=%d, req=%
u, wrote=%
u at %#08x
\n
"
,
JFFS2_ERROR
(
"jffs2_flash_write()=%d, req=%
zu, wrote=%z
u at %#08x
\n
"
,
rc
,
sizeof
(
rr
),
length
,
ref_offset
(
ref
->
node
));
rc
,
sizeof
(
rr
),
length
,
ref_offset
(
ref
->
node
));
}
}
}
}
...
@@ -549,7 +549,7 @@ static int save_xattr_ref(struct jffs2_sb_info *c, struct jffs2_xattr_ref *ref)
...
@@ -549,7 +549,7 @@ static int save_xattr_ref(struct jffs2_sb_info *c, struct jffs2_xattr_ref *ref)
/* must be called under down_write(xattr_sem) */
/* must be called under down_write(xattr_sem) */
struct
jffs2_raw_node_ref
*
raw
;
struct
jffs2_raw_node_ref
*
raw
;
struct
jffs2_raw_xref
rr
;
struct
jffs2_raw_xref
rr
;
uint32
_t
length
;
size
_t
length
;
uint32_t
phys_ofs
=
write_ofs
(
c
);
uint32_t
phys_ofs
=
write_ofs
(
c
);
int
ret
;
int
ret
;
...
@@ -564,7 +564,7 @@ static int save_xattr_ref(struct jffs2_sb_info *c, struct jffs2_xattr_ref *ref)
...
@@ -564,7 +564,7 @@ static int save_xattr_ref(struct jffs2_sb_info *c, struct jffs2_xattr_ref *ref)
ret
=
jffs2_flash_write
(
c
,
phys_ofs
,
sizeof
(
rr
),
&
length
,
(
char
*
)
&
rr
);
ret
=
jffs2_flash_write
(
c
,
phys_ofs
,
sizeof
(
rr
),
&
length
,
(
char
*
)
&
rr
);
if
(
ret
||
sizeof
(
rr
)
!=
length
)
{
if
(
ret
||
sizeof
(
rr
)
!=
length
)
{
JFFS2_WARNING
(
"jffs2_flash_write() returned %d, request=%
u, retlen=%
u, at %#08x
\n
"
,
JFFS2_WARNING
(
"jffs2_flash_write() returned %d, request=%
zu, retlen=%z
u, at %#08x
\n
"
,
ret
,
sizeof
(
rr
),
length
,
phys_ofs
);
ret
,
sizeof
(
rr
),
length
,
phys_ofs
);
ret
=
ret
?
ret
:
-
EIO
;
ret
=
ret
?
ret
:
-
EIO
;
if
(
length
)
if
(
length
)
...
...
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