ufs: move non-layout parts of ufs_fs.h to fs/ufs/
authorChristoph Hellwig <hch@lst.de>
Wed, 17 Oct 2007 06:26:51 +0000 (23:26 -0700)
committerLinus Torvalds <torvalds@woody.linux-foundation.org>
Wed, 17 Oct 2007 15:42:51 +0000 (08:42 -0700)
Move prototypes and in-core structures to fs/ufs/ similar to what most
other filesystems already do.

I made little modifications: move also ufs debug macros and
mount options constants into fs/ufs/ufs.h, this stuff
also private for ufs.

Signed-off-by: Christoph Hellwig <hch@lst.de>
Signed-off-by: Evgeniy Dushistov <dushistov@mail.ru>
Cc: Al Viro <viro@zeniv.linux.org.uk>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
15 files changed:
fs/ufs/balloc.c
fs/ufs/cylinder.c
fs/ufs/dir.c
fs/ufs/file.c
fs/ufs/ialloc.c
fs/ufs/inode.c
fs/ufs/namei.c
fs/ufs/super.c
fs/ufs/symlink.c
fs/ufs/truncate.c
fs/ufs/ufs.h [new file with mode: 0644]
fs/ufs/util.c
include/linux/ufs_fs.h
include/linux/ufs_fs_i.h [deleted file]
include/linux/ufs_fs_sb.h [deleted file]

index 841ac25fd95042f86d134330a13dafd8521521dd..f63a09ce8683b8fbb43eb088e4b7466ce40caec0 100644 (file)
@@ -19,6 +19,7 @@
 #include <linux/bitops.h>
 #include <asm/byteorder.h>
 
+#include "ufs.h"
 #include "swab.h"
 #include "util.h"
 
index 09c39e5e638631a784faed8106835dbe7e49ff47..2a815665644f30b0d3efb4d632004cada1ddc57f 100644 (file)
@@ -17,6 +17,7 @@
 
 #include <asm/byteorder.h>
 
+#include "ufs.h"
 #include "swab.h"
 #include "util.h"
 
index 2410ec6002db55807945b126fa880a096036dc36..30f8c2bb0c3e7a4c4aa29e86ae2ffdfc3cd9e00c 100644 (file)
@@ -21,6 +21,7 @@
 #include <linux/ufs_fs.h>
 #include <linux/swap.h>
 
+#include "ufs.h"
 #include "swab.h"
 #include "util.h"
 
index 6705d74c6d2d9b836dcdd3d3be1d40b65b3bf8e1..a46c97bf023fb25462606b228ed5372a67d79fd4 100644 (file)
@@ -27,6 +27,9 @@
 #include <linux/ufs_fs.h>
 #include <linux/buffer_head.h> /* for sync_mapping_buffers() */
 
+#include "ufs.h"
+
+
 static int ufs_sync_file(struct file *file, struct dentry *dentry, int datasync)
 {
        struct inode *inode = dentry->d_inode;
index c28a8b6f2feb65695dca3be4cd7d954871425d8f..7e260bc0d94f66719f40a71bebdfea19fb09c859 100644 (file)
@@ -34,6 +34,7 @@
 #include <linux/bitops.h>
 #include <asm/byteorder.h>
 
+#include "ufs.h"
 #include "swab.h"
 #include "util.h"
 
index d84d4b0f4779416573cf82a06730a2593628fa62..4320782761ae875c54fc9f6a04592a3990ecfdc3 100644 (file)
@@ -38,6 +38,7 @@
 #include <linux/smp_lock.h>
 #include <linux/buffer_head.h>
 
+#include "ufs.h"
 #include "swab.h"
 #include "util.h"
 
index a059ccd064eaa317f257ac1ac73ec3a28ba9867e..d8bfbee2fe2ba9e9ced1bcc66dbfdebb4b9ced7c 100644 (file)
@@ -31,7 +31,7 @@
 #include <linux/fs.h>
 #include <linux/ufs_fs.h>
 #include <linux/smp_lock.h>
-#include "swab.h"      /* will go away - see comment in mknod() */
+#include "ufs.h"
 #include "util.h"
 
 static inline int ufs_add_nondir(struct dentry *dentry, struct inode *inode)
@@ -110,7 +110,6 @@ static int ufs_mknod (struct inode * dir, struct dentry *dentry, int mode, dev_t
        err = PTR_ERR(inode);
        if (!IS_ERR(inode)) {
                init_special_inode(inode, mode, rdev);
-               /* NOTE: that'll go when we get wide dev_t */
                ufs_set_inode_dev(inode->i_sb, UFS_I(inode), rdev);
                mark_inode_dirty(inode);
                lock_kernel();
index 21987d29994d4b7b2e11076ca3aa4722657ac90d..4d72933661b72caa4491c8abfe1e30ec91bfce86 100644 (file)
@@ -91,6 +91,7 @@
 #include <linux/mount.h>
 #include <linux/seq_file.h>
 
+#include "ufs.h"
 #include "swab.h"
 #include "util.h"
 
index d8549f807e8003ef06abc6c79a34799829b7d204..43ac10e75a4aae8234a20cf301b55aaa7ad661e2 100644 (file)
@@ -28,6 +28,8 @@
 #include <linux/fs.h>
 #include <linux/namei.h>
 #include <linux/ufs_fs.h>
+#include "ufs.h"
+
 
 static void *ufs_follow_link(struct dentry *dentry, struct nameidata *nd)
 {
index 79c54c85fb58e8cd937da6fa1e8b46505e26908b..311ded34c2b2b1027dc17e3f8b7d4f9682ba7412 100644 (file)
@@ -46,6 +46,7 @@
 #include <linux/blkdev.h>
 #include <linux/sched.h>
 
+#include "ufs.h"
 #include "swab.h"
 #include "util.h"
 
diff --git a/fs/ufs/ufs.h b/fs/ufs/ufs.h
new file mode 100644 (file)
index 0000000..7faa4cd
--- /dev/null
@@ -0,0 +1,157 @@
+#ifndef _UFS_UFS_H
+#define _UFS_UFS_H 1
+
+#define UFS_MAX_GROUP_LOADED 8
+#define UFS_CGNO_EMPTY ((unsigned)-1)
+
+struct ufs_sb_private_info;
+struct ufs_cg_private_info;
+struct ufs_csum;
+
+struct ufs_sb_info {
+       struct ufs_sb_private_info * s_uspi;
+       struct ufs_csum * s_csp;
+       unsigned s_bytesex;
+       unsigned s_flags;
+       struct buffer_head ** s_ucg;
+       struct ufs_cg_private_info * s_ucpi[UFS_MAX_GROUP_LOADED];
+       unsigned s_cgno[UFS_MAX_GROUP_LOADED];
+       unsigned short s_cg_loaded;
+       unsigned s_mount_opt;
+};
+
+struct ufs_inode_info {
+       union {
+               __fs32  i_data[15];
+               __u8    i_symlink[4*15];
+               __fs64  u2_i_data[15];
+       } i_u1;
+       __u32   i_flags;
+       __u32   i_shadow;
+       __u32   i_unused1;
+       __u32   i_unused2;
+       __u32   i_oeftflag;
+       __u16   i_osync;
+       __u64   i_lastfrag;
+       __u32   i_dir_start_lookup;
+       struct inode vfs_inode;
+};
+
+/* mount options */
+#define UFS_MOUNT_ONERROR              0x0000000F
+#define UFS_MOUNT_ONERROR_PANIC                0x00000001
+#define UFS_MOUNT_ONERROR_LOCK         0x00000002
+#define UFS_MOUNT_ONERROR_UMOUNT       0x00000004
+#define UFS_MOUNT_ONERROR_REPAIR       0x00000008
+
+#define UFS_MOUNT_UFSTYPE              0x0000FFF0
+#define UFS_MOUNT_UFSTYPE_OLD          0x00000010
+#define UFS_MOUNT_UFSTYPE_44BSD                0x00000020
+#define UFS_MOUNT_UFSTYPE_SUN          0x00000040
+#define UFS_MOUNT_UFSTYPE_NEXTSTEP     0x00000080
+#define UFS_MOUNT_UFSTYPE_NEXTSTEP_CD  0x00000100
+#define UFS_MOUNT_UFSTYPE_OPENSTEP     0x00000200
+#define UFS_MOUNT_UFSTYPE_SUNx86       0x00000400
+#define UFS_MOUNT_UFSTYPE_HP           0x00000800
+#define UFS_MOUNT_UFSTYPE_UFS2         0x00001000
+#define UFS_MOUNT_UFSTYPE_SUNOS                0x00002000
+
+#define ufs_clear_opt(o,opt)   o &= ~UFS_MOUNT_##opt
+#define ufs_set_opt(o,opt)     o |= UFS_MOUNT_##opt
+#define ufs_test_opt(o,opt)    ((o) & UFS_MOUNT_##opt)
+
+/*
+ * Debug code
+ */
+#ifdef CONFIG_UFS_DEBUG
+#      define UFSD(f, a...)    {                                       \
+               printk ("UFSD (%s, %d): %s:",                           \
+                       __FILE__, __LINE__, __FUNCTION__);              \
+               printk (f, ## a);                                       \
+       }
+#else
+#      define UFSD(f, a...)    /**/
+#endif
+
+/* balloc.c */
+extern void ufs_free_fragments (struct inode *, u64, unsigned);
+extern void ufs_free_blocks (struct inode *, u64, unsigned);
+extern u64 ufs_new_fragments(struct inode *, void *, u64, u64,
+                            unsigned, int *, struct page *);
+
+/* cylinder.c */
+extern struct ufs_cg_private_info * ufs_load_cylinder (struct super_block *, unsigned);
+extern void ufs_put_cylinder (struct super_block *, unsigned);
+
+/* dir.c */
+extern const struct inode_operations ufs_dir_inode_operations;
+extern int ufs_add_link (struct dentry *, struct inode *);
+extern ino_t ufs_inode_by_name(struct inode *, struct dentry *);
+extern int ufs_make_empty(struct inode *, struct inode *);
+extern struct ufs_dir_entry *ufs_find_entry(struct inode *, struct dentry *, struct page **);
+extern int ufs_delete_entry(struct inode *, struct ufs_dir_entry *, struct page *);
+extern int ufs_empty_dir (struct inode *);
+extern struct ufs_dir_entry *ufs_dotdot(struct inode *, struct page **);
+extern void ufs_set_link(struct inode *dir, struct ufs_dir_entry *de,
+                        struct page *page, struct inode *inode);
+
+/* file.c */
+extern const struct inode_operations ufs_file_inode_operations;
+extern const struct file_operations ufs_file_operations;
+
+extern const struct address_space_operations ufs_aops;
+
+/* ialloc.c */
+extern void ufs_free_inode (struct inode *inode);
+extern struct inode * ufs_new_inode (struct inode *, int);
+
+/* inode.c */
+extern void ufs_read_inode (struct inode *);
+extern void ufs_put_inode (struct inode *);
+extern int ufs_write_inode (struct inode *, int);
+extern int ufs_sync_inode (struct inode *);
+extern void ufs_delete_inode (struct inode *);
+extern struct buffer_head * ufs_bread (struct inode *, unsigned, int, int *);
+extern int ufs_getfrag_block (struct inode *inode, sector_t fragment, struct buffer_head *bh_result, int create);
+
+/* namei.c */
+extern const struct file_operations ufs_dir_operations;
+
+/* super.c */
+extern void ufs_warning (struct super_block *, const char *, const char *, ...) __attribute__ ((format (printf, 3, 4)));
+extern void ufs_error (struct super_block *, const char *, const char *, ...) __attribute__ ((format (printf, 3, 4)));
+extern void ufs_panic (struct super_block *, const char *, const char *, ...) __attribute__ ((format (printf, 3, 4)));
+
+/* symlink.c */
+extern const struct inode_operations ufs_fast_symlink_inode_operations;
+
+/* truncate.c */
+extern int ufs_truncate (struct inode *, loff_t);
+
+static inline struct ufs_sb_info *UFS_SB(struct super_block *sb)
+{
+       return sb->s_fs_info;
+}
+
+static inline struct ufs_inode_info *UFS_I(struct inode *inode)
+{
+       return container_of(inode, struct ufs_inode_info, vfs_inode);
+}
+
+/*
+ * Give cylinder group number for a file system block.
+ * Give cylinder group block number for a file system block.
+ */
+/* #define     ufs_dtog(d)     ((d) / uspi->s_fpg) */
+static inline u64 ufs_dtog(struct ufs_sb_private_info * uspi, u64 b)
+{
+       do_div(b, uspi->s_fpg);
+       return b;
+}
+/* #define     ufs_dtogd(d)    ((d) % uspi->s_fpg) */
+static inline u32 ufs_dtogd(struct ufs_sb_private_info * uspi, u64 b)
+{
+       return do_div(b, uspi->s_fpg);
+}
+
+#endif /* _UFS_UFS_H */
index 84357f1ff0ec8915b4839d45f01fc33566c99a70..410084dae3891be9c0c4d3de4c42dc6ccf50218e 100644 (file)
@@ -11,6 +11,7 @@
 #include <linux/ufs_fs.h>
 #include <linux/buffer_head.h>
 
+#include "ufs.h"
 #include "swab.h"
 #include "util.h"
 
index 52730d2c9ad9c8432763d284a31249fb6dfdfd80..10b854d3561fd982a42d976eddbdad8aa6a538fa 100644 (file)
@@ -46,11 +46,6 @@ typedef __u32 __bitwise __fs32;
 typedef __u16 __bitwise __fs16;
 #endif
 
-#ifdef __KERNEL__
-#include <linux/ufs_fs_i.h>
-#include <linux/ufs_fs_sb.h>
-#endif
-
 #define UFS_BBLOCK 0
 #define UFS_BBSIZE 8192
 #define UFS_SBLOCK 8192
@@ -188,29 +183,6 @@ typedef __u16 __bitwise __fs16;
 #define UFS_42INODEFMT -1
 #define UFS_44INODEFMT 2
 
-/* mount options */
-#define UFS_MOUNT_ONERROR              0x0000000F
-#define UFS_MOUNT_ONERROR_PANIC                0x00000001
-#define UFS_MOUNT_ONERROR_LOCK         0x00000002
-#define UFS_MOUNT_ONERROR_UMOUNT       0x00000004
-#define UFS_MOUNT_ONERROR_REPAIR       0x00000008
-
-#define UFS_MOUNT_UFSTYPE              0x0000FFF0
-#define UFS_MOUNT_UFSTYPE_OLD          0x00000010
-#define UFS_MOUNT_UFSTYPE_44BSD                0x00000020
-#define UFS_MOUNT_UFSTYPE_SUN          0x00000040
-#define UFS_MOUNT_UFSTYPE_NEXTSTEP     0x00000080
-#define UFS_MOUNT_UFSTYPE_NEXTSTEP_CD  0x00000100
-#define UFS_MOUNT_UFSTYPE_OPENSTEP     0x00000200
-#define UFS_MOUNT_UFSTYPE_SUNx86       0x00000400
-#define UFS_MOUNT_UFSTYPE_HP           0x00000800
-#define UFS_MOUNT_UFSTYPE_UFS2         0x00001000
-#define UFS_MOUNT_UFSTYPE_SUNOS                0x00002000
-
-#define ufs_clear_opt(o,opt)   o &= ~UFS_MOUNT_##opt
-#define ufs_set_opt(o,opt)     o |= UFS_MOUNT_##opt
-#define ufs_test_opt(o,opt)    ((o) & UFS_MOUNT_##opt)
-
 /*
  * MINFREE gives the minimum acceptable percentage of file system
  * blocks which may be free. If the freelist drops below this level
@@ -225,19 +197,6 @@ typedef __u16 __bitwise __fs16;
  */
 #define UFS_MINFREE         5
 #define UFS_DEFAULTOPT      UFS_OPTTIME
-
-/*
- * Debug code
- */
-#ifdef CONFIG_UFS_DEBUG
-#      define UFSD(f, a...)    {                                       \
-               printk ("UFSD (%s, %d): %s:",                           \
-                       __FILE__, __LINE__, __FUNCTION__);              \
-               printk (f, ## a);                                       \
-       }
-#else
-#      define UFSD(f, a...)    /**/
-#endif
             
 /*
  * Turn file system block numbers into disk block addresses.
@@ -991,89 +950,4 @@ struct ufs_super_block_third {
        __u8    fs_space[1];
 };
 
-#ifdef __KERNEL__
-
-/* balloc.c */
-extern void ufs_free_fragments (struct inode *, u64, unsigned);
-extern void ufs_free_blocks (struct inode *, u64, unsigned);
-extern u64 ufs_new_fragments(struct inode *, void *, u64, u64,
-                            unsigned, int *, struct page *);
-
-/* cylinder.c */
-extern struct ufs_cg_private_info * ufs_load_cylinder (struct super_block *, unsigned);
-extern void ufs_put_cylinder (struct super_block *, unsigned);
-
-/* dir.c */
-extern const struct inode_operations ufs_dir_inode_operations;
-extern int ufs_add_link (struct dentry *, struct inode *);
-extern ino_t ufs_inode_by_name(struct inode *, struct dentry *);
-extern int ufs_make_empty(struct inode *, struct inode *);
-extern struct ufs_dir_entry *ufs_find_entry(struct inode *, struct dentry *, struct page **);
-extern int ufs_delete_entry(struct inode *, struct ufs_dir_entry *, struct page *);
-extern int ufs_empty_dir (struct inode *);
-extern struct ufs_dir_entry *ufs_dotdot(struct inode *, struct page **);
-extern void ufs_set_link(struct inode *dir, struct ufs_dir_entry *de,
-                        struct page *page, struct inode *inode);
-
-/* file.c */
-extern const struct inode_operations ufs_file_inode_operations;
-extern const struct file_operations ufs_file_operations;
-
-extern const struct address_space_operations ufs_aops;
-
-/* ialloc.c */
-extern void ufs_free_inode (struct inode *inode);
-extern struct inode * ufs_new_inode (struct inode *, int);
-
-/* inode.c */
-extern void ufs_read_inode (struct inode *);
-extern void ufs_put_inode (struct inode *);
-extern int ufs_write_inode (struct inode *, int);
-extern int ufs_sync_inode (struct inode *);
-extern void ufs_delete_inode (struct inode *);
-extern struct buffer_head * ufs_bread (struct inode *, unsigned, int, int *);
-extern int ufs_getfrag_block (struct inode *inode, sector_t fragment, struct buffer_head *bh_result, int create);
-
-/* namei.c */
-extern const struct file_operations ufs_dir_operations;
-        
-/* super.c */
-extern void ufs_warning (struct super_block *, const char *, const char *, ...) __attribute__ ((format (printf, 3, 4)));
-extern void ufs_error (struct super_block *, const char *, const char *, ...) __attribute__ ((format (printf, 3, 4)));
-extern void ufs_panic (struct super_block *, const char *, const char *, ...) __attribute__ ((format (printf, 3, 4)));
-
-/* symlink.c */
-extern const struct inode_operations ufs_fast_symlink_inode_operations;
-
-/* truncate.c */
-extern int ufs_truncate (struct inode *, loff_t);
-
-static inline struct ufs_sb_info *UFS_SB(struct super_block *sb)
-{
-       return sb->s_fs_info;
-}
-
-static inline struct ufs_inode_info *UFS_I(struct inode *inode)
-{
-       return container_of(inode, struct ufs_inode_info, vfs_inode);
-}
-
-/*
- * Give cylinder group number for a file system block.
- * Give cylinder group block number for a file system block.
- */
-/* #define     ufs_dtog(d)     ((d) / uspi->s_fpg) */
-static inline u64 ufs_dtog(struct ufs_sb_private_info * uspi, u64 b)
-{
-       do_div(b, uspi->s_fpg);
-       return b;
-}
-/* #define     ufs_dtogd(d)    ((d) % uspi->s_fpg) */
-static inline u32 ufs_dtogd(struct ufs_sb_private_info * uspi, u64 b)
-{
-       return do_div(b, uspi->s_fpg);
-}
-
-#endif /* __KERNEL__ */
-
 #endif /* __LINUX_UFS_FS_H */
diff --git a/include/linux/ufs_fs_i.h b/include/linux/ufs_fs_i.h
deleted file mode 100644 (file)
index 6496caa..0000000
+++ /dev/null
@@ -1,33 +0,0 @@
-/*
- *  linux/include/linux/ufs_fs_i.h
- *
- * Copyright (C) 1996
- * Adrian Rodriguez (adrian@franklins-tower.rutgers.edu)
- * Laboratory for Computer Science Research Computing Facility
- * Rutgers, The State University of New Jersey
- *
- * NeXTstep support added on February 5th 1998 by
- * Niels Kristian Bech Jensen <nkbj@image.dk>.
- */
-
-#ifndef _LINUX_UFS_FS_I_H
-#define _LINUX_UFS_FS_I_H
-
-struct ufs_inode_info {
-       union {
-               __fs32  i_data[15];
-               __u8    i_symlink[4*15];
-               __fs64  u2_i_data[15];
-       } i_u1;
-       __u32   i_flags;
-       __u32   i_shadow;
-       __u32   i_unused1;
-       __u32   i_unused2;
-       __u32   i_oeftflag;
-       __u16   i_osync;
-       __u64   i_lastfrag;
-       __u32   i_dir_start_lookup;
-       struct inode vfs_inode;
-};
-
-#endif /* _LINUX_UFS_FS_I_H */
diff --git a/include/linux/ufs_fs_sb.h b/include/linux/ufs_fs_sb.h
deleted file mode 100644 (file)
index e114c93..0000000
+++ /dev/null
@@ -1,37 +0,0 @@
-/* 
- *  linux/include/linux/ufs_fs_sb.h
- *
- * Copyright (C) 1996
- * Adrian Rodriguez (adrian@franklins-tower.rutgers.edu)
- * Laboratory for Computer Science Research Computing Facility
- * Rutgers, The State University of New Jersey
- *
- * $Id: ufs_fs_sb.h,v 1.8 1998/05/06 12:04:40 jj Exp $
- *
- * Write support by Daniel Pirkl <daniel.pirkl@email.cz>
- */
-
-#ifndef __LINUX_UFS_FS_SB_H
-#define __LINUX_UFS_FS_SB_H
-
-
-#define UFS_MAX_GROUP_LOADED 8
-#define UFS_CGNO_EMPTY ((unsigned)-1)
-
-struct ufs_sb_private_info;
-struct ufs_cg_private_info;
-struct ufs_csum;
-
-struct ufs_sb_info {
-       struct ufs_sb_private_info * s_uspi;    
-       struct ufs_csum * s_csp;
-       unsigned s_bytesex;
-       unsigned s_flags;
-       struct buffer_head ** s_ucg;
-       struct ufs_cg_private_info * s_ucpi[UFS_MAX_GROUP_LOADED]; 
-       unsigned s_cgno[UFS_MAX_GROUP_LOADED];
-       unsigned short s_cg_loaded;
-       unsigned s_mount_opt;
-};
-
-#endif