Commit c99e905c authored by Chris Mason's avatar Chris Mason

Btrfs: Fix sparse endian warnings in struct-funcs.c

The btrfs macros to access individual struct members on disk were
sending the same variable to functions that expected different types
of endianness.  This fix explicitly creates a variable of the correct
type instead of abusing a single variable for mixed purposes.
Signed-off-by: default avatarChris Mason <chris.mason@oracle.com>
parent 2a7108ad
...@@ -36,9 +36,14 @@ ...@@ -36,9 +36,14 @@
* The extent buffer api is used to do all the kmapping and page * The extent buffer api is used to do all the kmapping and page
* spanning work required to get extent buffers in highmem and have * spanning work required to get extent buffers in highmem and have
* a metadata blocksize different from the page size. * a metadata blocksize different from the page size.
*
* The macro starts with a simple function prototype declaration so that
* sparse won't complain about it being static.
*/ */
#define BTRFS_SETGET_FUNCS(name, type, member, bits) \ #define BTRFS_SETGET_FUNCS(name, type, member, bits) \
u##bits btrfs_##name(struct extent_buffer *eb, type *s); \
void btrfs_set_##name(struct extent_buffer *eb, type *s, u##bits val); \
u##bits btrfs_##name(struct extent_buffer *eb, \ u##bits btrfs_##name(struct extent_buffer *eb, \
type *s) \ type *s) \
{ \ { \
...@@ -59,14 +64,15 @@ u##bits btrfs_##name(struct extent_buffer *eb, \ ...@@ -59,14 +64,15 @@ u##bits btrfs_##name(struct extent_buffer *eb, \
int unmap_on_exit = (eb->map_token == NULL); \ int unmap_on_exit = (eb->map_token == NULL); \
unsigned long map_start; \ unsigned long map_start; \
unsigned long map_len; \ unsigned long map_len; \
__le##bits res; \ u##bits res; \
err = map_extent_buffer(eb, offset, \ err = map_extent_buffer(eb, offset, \
sizeof(((type *)0)->member), \ sizeof(((type *)0)->member), \
&map_token, &kaddr, \ &map_token, &kaddr, \
&map_start, &map_len, KM_USER1); \ &map_start, &map_len, KM_USER1); \
if (err) { \ if (err) { \
read_eb_member(eb, s, type, member, &res); \ __le##bits leres; \
return le##bits##_to_cpu(res); \ read_eb_member(eb, s, type, member, &leres); \
return le##bits##_to_cpu(leres); \
} \ } \
p = (type *)(kaddr + part_offset - map_start); \ p = (type *)(kaddr + part_offset - map_start); \
res = le##bits##_to_cpu(p->member); \ res = le##bits##_to_cpu(p->member); \
...@@ -101,8 +107,9 @@ void btrfs_set_##name(struct extent_buffer *eb, \ ...@@ -101,8 +107,9 @@ void btrfs_set_##name(struct extent_buffer *eb, \
&map_token, &kaddr, \ &map_token, &kaddr, \
&map_start, &map_len, KM_USER1); \ &map_start, &map_len, KM_USER1); \
if (err) { \ if (err) { \
val = cpu_to_le##bits(val); \ __le##bits val2; \
write_eb_member(eb, s, type, member, &val); \ val2 = cpu_to_le##bits(val); \
write_eb_member(eb, s, type, member, &val2); \
return; \ return; \
} \ } \
p = (type *)(kaddr + part_offset - map_start); \ p = (type *)(kaddr + part_offset - map_start); \
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment