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
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