summaryrefslogtreecommitdiff
path: root/lib/ext2fs
diff options
context:
space:
mode:
authorTheodore Ts'o <tytso@mit.edu>2011-09-14 13:13:07 -0400
committerTheodore Ts'o <tytso@mit.edu>2011-09-14 13:47:35 -0400
commit897fbaac7dfb2afe1eb67a76f3b003a8eca19199 (patch)
tree66d152bef24e1e202136a03f8c511ba208f5b7d0 /lib/ext2fs
parent9f6ba888f027ba4daf57ac61a11a6dce98e42347 (diff)
downloade2fsprogs-897fbaac7dfb2afe1eb67a76f3b003a8eca19199.tar.gz
libext2fs: add new test: tst_inode_size
This test makes sure the size of the ext2_inode is what we expect Signed-off-by: "Theodore Ts'o" <tytso@mit.edu>
Diffstat (limited to 'lib/ext2fs')
-rw-r--r--lib/ext2fs/Makefile.in8
-rw-r--r--lib/ext2fs/tst_inode_size.c80
2 files changed, 87 insertions, 1 deletions
diff --git a/lib/ext2fs/Makefile.in b/lib/ext2fs/Makefile.in
index f6338f07..e374c1c2 100644
--- a/lib/ext2fs/Makefile.in
+++ b/lib/ext2fs/Makefile.in
@@ -262,6 +262,12 @@ tst_super_size: tst_super_size.o
$(E) " LD $@"
$(Q) $(CC) -o tst_super_size tst_super_size.o
+tst_inode_size.o: $(srcdir)/tst_inode_size.c $(srcdir)/ext2_fs.h
+
+tst_inode_size: tst_inode_size.o
+ $(E) " LD $@"
+ $(Q) $(CC) -o tst_inode_size tst_inode_size.o
+
ext2_tdbtool: tdbtool.o
$(E) " LD $@"
$(Q) $(CC) -o ext2_tdbtool tdbtool.o tdb.o
@@ -339,7 +345,7 @@ mkjournal: mkjournal.c $(STATIC_LIBEXT2FS) $(DEPLIBCOM_ERR)
$(E) " LD $@"
$(Q) $(CC) -o mkjournal $(srcdir)/mkjournal.c -DDEBUG $(STATIC_LIBEXT2FS) $(LIBCOM_ERR) $(ALL_CFLAGS)
-check:: tst_bitops tst_badblocks tst_iscan tst_types tst_icount tst_super_size tst_types tst_csum
+check:: tst_bitops tst_badblocks tst_iscan tst_types tst_icount tst_super_size tst_types tst_inode_size tst_csum
LD_LIBRARY_PATH=$(LIB) DYLD_LIBRARY_PATH=$(LIB) ./tst_bitops
LD_LIBRARY_PATH=$(LIB) DYLD_LIBRARY_PATH=$(LIB) ./tst_badblocks
LD_LIBRARY_PATH=$(LIB) DYLD_LIBRARY_PATH=$(LIB) ./tst_iscan
diff --git a/lib/ext2fs/tst_inode_size.c b/lib/ext2fs/tst_inode_size.c
new file mode 100644
index 00000000..962f1cd3
--- /dev/null
+++ b/lib/ext2fs/tst_inode_size.c
@@ -0,0 +1,80 @@
+/*
+ * This testing program makes sure the ext2_inode structure is 1024 bytes long
+ *
+ * Copyright (C) 2007 by Theodore Ts'o.
+ *
+ * %Begin-Header%
+ * This file may be redistributed under the terms of the GNU Library
+ * General Public License, version 2.
+ * %End-Header%
+ */
+
+#include <stdio.h>
+#include <unistd.h>
+#include <stdlib.h>
+
+#include "ext2_fs.h"
+
+struct ext2_inode inode;
+
+int verbose = 0;
+
+#define offsetof(type, member) __builtin_offsetof (type, member)
+#define check_field(x) cur_offset = do_field(#x, sizeof(inode.x), \
+ offsetof(struct ext2_inode, x), \
+ cur_offset)
+
+static int do_field(const char *field, size_t size, int offset, int cur_offset)
+{
+ if (offset != cur_offset) {
+ printf("Warning! Unexpected offset at %s\n", field);
+ exit(1);
+ }
+ printf("%8d %-30s %3u\n", offset, field, (unsigned) size);
+ return offset + size;
+}
+
+void check_structure_fields()
+{
+#if (__GNUC__ >= 4)
+ int cur_offset = 0;
+
+ printf("%8s %-30s %3s\n", "offset", "field", "size");
+ check_field(i_mode);
+ check_field(i_uid);
+ check_field(i_size);
+ check_field(i_atime);
+ check_field(i_ctime);
+ check_field(i_mtime);
+ check_field(i_dtime);
+ check_field(i_gid);
+ check_field(i_links_count);
+ check_field(i_blocks);
+ check_field(i_flags);
+ check_field(osd1.linux1.l_i_version);
+ check_field(i_block);
+ check_field(i_generation);
+ check_field(i_file_acl);
+ check_field(i_size_high);
+ check_field(i_faddr);
+ check_field(osd2.linux2.l_i_blocks_hi);
+ check_field(osd2.linux2.l_i_file_acl_high);
+ check_field(osd2.linux2.l_i_uid_high);
+ check_field(osd2.linux2.l_i_gid_high);
+ check_field(osd2.linux2.l_i_reserved2);
+ printf("Ending offset is %d\n\n", cur_offset);
+#endif
+}
+
+
+int main(int argc, char **argv)
+{
+ int l = sizeof(struct ext2_inode);
+
+ check_structure_fields();
+ printf("Size of struct ext2_inode is %d\n", l);
+ if (l != 256) {
+ exit(1);
+ }
+ exit(0);
+}