diff options
author | Steven Whitehouse <swhiteho@redhat.com> | 2007-06-01 09:11:58 -0400 |
---|---|---|
committer | Steven Whitehouse <swhiteho@redhat.com> | 2007-07-09 03:23:10 -0400 |
commit | bb8d8a6f54c1c84d7c74623491bab043b36a38c5 (patch) | |
tree | 76c62c505df2a1acd090f4aacc63fb9eddd3950f /include/linux/gfs2_ondisk.h | |
parent | ddf4b426aababdae4cb96326d7aeb9d119f42c50 (diff) |
[GFS2] Fix sign problem in quota/statfs and cleanup _host structures
This patch fixes some sign issues which were accidentally introduced
into the quota & statfs code during the endianess annotation process.
Also included is a general clean up which moves all of the _host
structures out of gfs2_ondisk.h (where they should not have been to
start with) and into the places where they are actually used (often only
one place). Also those _host structures which are not required any more
are removed entirely (which is the eventual plan for all of them).
The conversion routines from ondisk.c are also moved into the places
where they are actually used, which for almost every one, was just one
single place, so all those are now static functions. This also cleans up
the end of gfs2_ondisk.h which no longer needs the #ifdef __KERNEL__.
The net result is a reduction of about 100 lines of code, many functions
now marked static plus the bug fixes as mentioned above. For good
measure I ran the code through sparse after making these changes to
check that there are no warnings generated.
This fixes Red Hat bz #239686
Signed-off-by: Steven Whitehouse <swhiteho@redhat.com>
Diffstat (limited to 'include/linux/gfs2_ondisk.h')
-rw-r--r-- | include/linux/gfs2_ondisk.h | 127 |
1 files changed, 0 insertions, 127 deletions
diff --git a/include/linux/gfs2_ondisk.h b/include/linux/gfs2_ondisk.h index 01cc35946a9d..2c4e24fb0765 100644 --- a/include/linux/gfs2_ondisk.h +++ b/include/linux/gfs2_ondisk.h | |||
@@ -54,11 +54,6 @@ struct gfs2_inum { | |||
54 | __be64 no_addr; | 54 | __be64 no_addr; |
55 | }; | 55 | }; |
56 | 56 | ||
57 | struct gfs2_inum_host { | ||
58 | __u64 no_formal_ino; | ||
59 | __u64 no_addr; | ||
60 | }; | ||
61 | |||
62 | /* | 57 | /* |
63 | * Generic metadata head structure | 58 | * Generic metadata head structure |
64 | * Every inplace buffer logged in the journal must start with this. | 59 | * Every inplace buffer logged in the journal must start with this. |
@@ -87,12 +82,6 @@ struct gfs2_meta_header { | |||
87 | __be32 __pad1; /* Was incarnation number in gfs1 */ | 82 | __be32 __pad1; /* Was incarnation number in gfs1 */ |
88 | }; | 83 | }; |
89 | 84 | ||
90 | struct gfs2_meta_header_host { | ||
91 | __u32 mh_magic; | ||
92 | __u32 mh_type; | ||
93 | __u32 mh_format; | ||
94 | }; | ||
95 | |||
96 | /* | 85 | /* |
97 | * super-block structure | 86 | * super-block structure |
98 | * | 87 | * |
@@ -132,23 +121,6 @@ struct gfs2_sb { | |||
132 | /* In gfs1, quota and license dinodes followed */ | 121 | /* In gfs1, quota and license dinodes followed */ |
133 | }; | 122 | }; |
134 | 123 | ||
135 | struct gfs2_sb_host { | ||
136 | struct gfs2_meta_header_host sb_header; | ||
137 | |||
138 | __u32 sb_fs_format; | ||
139 | __u32 sb_multihost_format; | ||
140 | |||
141 | __u32 sb_bsize; | ||
142 | __u32 sb_bsize_shift; | ||
143 | |||
144 | struct gfs2_inum_host sb_master_dir; /* Was jindex dinode in gfs1 */ | ||
145 | struct gfs2_inum_host sb_root_dir; | ||
146 | |||
147 | char sb_lockproto[GFS2_LOCKNAME_LEN]; | ||
148 | char sb_locktable[GFS2_LOCKNAME_LEN]; | ||
149 | /* In gfs1, quota and license dinodes followed */ | ||
150 | }; | ||
151 | |||
152 | /* | 124 | /* |
153 | * resource index structure | 125 | * resource index structure |
154 | */ | 126 | */ |
@@ -166,14 +138,6 @@ struct gfs2_rindex { | |||
166 | __u8 ri_reserved[64]; | 138 | __u8 ri_reserved[64]; |
167 | }; | 139 | }; |
168 | 140 | ||
169 | struct gfs2_rindex_host { | ||
170 | __u64 ri_addr; /* grp block disk address */ | ||
171 | __u64 ri_data0; /* first data location */ | ||
172 | __u32 ri_length; /* length of rgrp header in fs blocks */ | ||
173 | __u32 ri_data; /* num of data blocks in rgrp */ | ||
174 | __u32 ri_bitbytes; /* number of bytes in data bitmaps */ | ||
175 | }; | ||
176 | |||
177 | /* | 141 | /* |
178 | * resource group header structure | 142 | * resource group header structure |
179 | */ | 143 | */ |
@@ -205,13 +169,6 @@ struct gfs2_rgrp { | |||
205 | __u8 rg_reserved[80]; /* Several fields from gfs1 now reserved */ | 169 | __u8 rg_reserved[80]; /* Several fields from gfs1 now reserved */ |
206 | }; | 170 | }; |
207 | 171 | ||
208 | struct gfs2_rgrp_host { | ||
209 | __u32 rg_flags; | ||
210 | __u32 rg_free; | ||
211 | __u32 rg_dinodes; | ||
212 | __u64 rg_igeneration; | ||
213 | }; | ||
214 | |||
215 | /* | 172 | /* |
216 | * quota structure | 173 | * quota structure |
217 | */ | 174 | */ |
@@ -223,12 +180,6 @@ struct gfs2_quota { | |||
223 | __u8 qu_reserved[64]; | 180 | __u8 qu_reserved[64]; |
224 | }; | 181 | }; |
225 | 182 | ||
226 | struct gfs2_quota_host { | ||
227 | __u64 qu_limit; | ||
228 | __u64 qu_warn; | ||
229 | __u64 qu_value; | ||
230 | }; | ||
231 | |||
232 | /* | 183 | /* |
233 | * dinode structure | 184 | * dinode structure |
234 | */ | 185 | */ |
@@ -312,27 +263,6 @@ struct gfs2_dinode { | |||
312 | __u8 di_reserved[56]; | 263 | __u8 di_reserved[56]; |
313 | }; | 264 | }; |
314 | 265 | ||
315 | struct gfs2_dinode_host { | ||
316 | __u64 di_size; /* number of bytes in file */ | ||
317 | __u64 di_blocks; /* number of blocks in file */ | ||
318 | |||
319 | /* This section varies from gfs1. Padding added to align with | ||
320 | * remainder of dinode | ||
321 | */ | ||
322 | __u64 di_goal_meta; /* rgrp to alloc from next */ | ||
323 | __u64 di_goal_data; /* data block goal */ | ||
324 | __u64 di_generation; /* generation number for NFS */ | ||
325 | |||
326 | __u32 di_flags; /* GFS2_DIF_... */ | ||
327 | __u16 di_height; /* height of metadata */ | ||
328 | |||
329 | /* These only apply to directories */ | ||
330 | __u16 di_depth; /* Number of bits in the table */ | ||
331 | __u32 di_entries; /* The number of entries in the directory */ | ||
332 | |||
333 | __u64 di_eattr; /* extended attribute block number */ | ||
334 | }; | ||
335 | |||
336 | /* | 266 | /* |
337 | * directory structure - many of these per directory file | 267 | * directory structure - many of these per directory file |
338 | */ | 268 | */ |
@@ -407,16 +337,6 @@ struct gfs2_log_header { | |||
407 | __be32 lh_hash; | 337 | __be32 lh_hash; |
408 | }; | 338 | }; |
409 | 339 | ||
410 | struct gfs2_log_header_host { | ||
411 | struct gfs2_meta_header_host lh_header; | ||
412 | |||
413 | __u64 lh_sequence; /* Sequence number of this transaction */ | ||
414 | __u32 lh_flags; /* GFS2_LOG_HEAD_... */ | ||
415 | __u32 lh_tail; /* Block number of log tail */ | ||
416 | __u32 lh_blkno; | ||
417 | __u32 lh_hash; | ||
418 | }; | ||
419 | |||
420 | /* | 340 | /* |
421 | * Log type descriptor | 341 | * Log type descriptor |
422 | */ | 342 | */ |
@@ -457,11 +377,6 @@ struct gfs2_inum_range { | |||
457 | __be64 ir_length; | 377 | __be64 ir_length; |
458 | }; | 378 | }; |
459 | 379 | ||
460 | struct gfs2_inum_range_host { | ||
461 | __u64 ir_start; | ||
462 | __u64 ir_length; | ||
463 | }; | ||
464 | |||
465 | /* | 380 | /* |
466 | * Statfs change | 381 | * Statfs change |
467 | * Describes an change to the pool of free and allocated | 382 | * Describes an change to the pool of free and allocated |
@@ -474,12 +389,6 @@ struct gfs2_statfs_change { | |||
474 | __be64 sc_dinodes; | 389 | __be64 sc_dinodes; |
475 | }; | 390 | }; |
476 | 391 | ||
477 | struct gfs2_statfs_change_host { | ||
478 | __u64 sc_total; | ||
479 | __u64 sc_free; | ||
480 | __u64 sc_dinodes; | ||
481 | }; | ||
482 | |||
483 | /* | 392 | /* |
484 | * Quota change | 393 | * Quota change |
485 | * Describes an allocation change for a particular | 394 | * Describes an allocation change for a particular |
@@ -494,12 +403,6 @@ struct gfs2_quota_change { | |||
494 | __be32 qc_id; | 403 | __be32 qc_id; |
495 | }; | 404 | }; |
496 | 405 | ||
497 | struct gfs2_quota_change_host { | ||
498 | __u64 qc_change; | ||
499 | __u32 qc_flags; /* GFS2_QCF_... */ | ||
500 | __u32 qc_id; | ||
501 | }; | ||
502 | |||
503 | struct gfs2_quota_lvb { | 406 | struct gfs2_quota_lvb { |
504 | __be32 qb_magic; | 407 | __be32 qb_magic; |
505 | __u32 __pad; | 408 | __u32 __pad; |
@@ -508,34 +411,4 @@ struct gfs2_quota_lvb { | |||
508 | __be64 qb_value; /* Current # blocks allocated */ | 411 | __be64 qb_value; /* Current # blocks allocated */ |
509 | }; | 412 | }; |
510 | 413 | ||
511 | #ifdef __KERNEL__ | ||
512 | /* Translation functions */ | ||
513 | struct gfs2_inode; | ||
514 | |||
515 | extern void gfs2_inum_out(const struct gfs2_inode *ip, struct gfs2_dirent *dent); | ||
516 | extern void gfs2_sb_in(struct gfs2_sb_host *sb, const void *buf); | ||
517 | extern void gfs2_rindex_in(struct gfs2_rindex_host *ri, const void *buf); | ||
518 | extern void gfs2_rindex_out(const struct gfs2_rindex_host *ri, void *buf); | ||
519 | extern void gfs2_rgrp_in(struct gfs2_rgrp_host *rg, const void *buf); | ||
520 | extern void gfs2_rgrp_out(const struct gfs2_rgrp_host *rg, void *buf); | ||
521 | extern void gfs2_quota_in(struct gfs2_quota_host *qu, const void *buf); | ||
522 | extern void gfs2_quota_out(const struct gfs2_quota_host *qu, void *buf); | ||
523 | struct gfs2_inode; | ||
524 | extern void gfs2_dinode_out(const struct gfs2_inode *ip, void *buf); | ||
525 | extern void gfs2_ea_header_in(struct gfs2_ea_header *ea, const void *buf); | ||
526 | extern void gfs2_ea_header_out(const struct gfs2_ea_header *ea, void *buf); | ||
527 | extern void gfs2_log_header_in(struct gfs2_log_header_host *lh, const void *buf); | ||
528 | extern void gfs2_inum_range_in(struct gfs2_inum_range_host *ir, const void *buf); | ||
529 | extern void gfs2_inum_range_out(const struct gfs2_inum_range_host *ir, void *buf); | ||
530 | extern void gfs2_statfs_change_in(struct gfs2_statfs_change_host *sc, const void *buf); | ||
531 | extern void gfs2_statfs_change_out(const struct gfs2_statfs_change_host *sc, void *buf); | ||
532 | extern void gfs2_quota_change_in(struct gfs2_quota_change_host *qc, const void *buf); | ||
533 | |||
534 | /* Printing functions */ | ||
535 | |||
536 | extern void gfs2_rindex_print(const struct gfs2_rindex_host *ri); | ||
537 | extern void gfs2_dinode_print(const struct gfs2_inode *ip); | ||
538 | |||
539 | #endif /* __KERNEL__ */ | ||
540 | |||
541 | #endif /* __GFS2_ONDISK_DOT_H__ */ | 414 | #endif /* __GFS2_ONDISK_DOT_H__ */ |