patch-2.1.90 linux/fs/coda/super.c
Next file: linux/fs/coda/upcall.c
Previous file: linux/fs/coda/psdev.c
Back to the patch index
Back to the overall index
- Lines: 371
- Date:
Wed Dec 31 16:00:00 1969
- Orig file:
v2.1.89/linux/fs/coda/super.c
- Orig date:
Tue Mar 10 10:03:33 1998
diff -u --recursive --new-file v2.1.89/linux/fs/coda/super.c linux/fs/coda/super.c
@@ -1,370 +0,0 @@
-/*
- * Super block/filesystem wide operations
- *
- * Copryright (C) 1996 Peter J. Braam <braam@maths.ox.ac.uk> and
- * Michael Callahan <callahan@maths.ox.ac.uk>
- *
- * Rewritten for Linux 2.1.?? Peter Braam <braam@cs.cmu.edu>
- * Copyright (C) Carnegie Mellon University
- */
-
-#define __NO_VERSION__
-#include <linux/module.h>
-#include <linux/kernel.h>
-#include <linux/mm.h>
-#include <linux/string.h>
-#include <linux/stat.h>
-#include <linux/errno.h>
-#include <linux/locks.h>
-#include <linux/unistd.h>
-
-#include <asm/system.h>
-#include <asm/uaccess.h>
-
-#include <linux/fs.h>
-#include <linux/stat.h>
-#include <linux/errno.h>
-#include <linux/locks.h>
-#include <linux/string.h>
-#include <asm/uaccess.h>
-#include <linux/vmalloc.h>
-#include <asm/segment.h>
-
-#include <linux/coda.h>
-#include <linux/coda_linux.h>
-#include <linux/coda_psdev.h>
-#include <linux/coda_fs_i.h>
-#include <linux/coda_cache.h>
-
-
-/* VFS super_block ops */
-static struct super_block *coda_read_super(struct super_block *, void *, int);
-static void coda_read_inode(struct inode *);
-static int coda_notify_change(struct dentry *dentry, struct iattr *attr);
-static void coda_put_inode(struct inode *);
-static void coda_delete_inode(struct inode *);
-static void coda_put_super(struct super_block *);
-static int coda_statfs(struct super_block *sb, struct statfs *buf,
- int bufsiz);
-
-/* helper functions */
-static inline struct vcomm *coda_psinode2vcomm(struct inode *inode);
-static int coda_get_psdev(void *, struct inode **);
-static struct coda_sb_info *coda_psinode2sbi(struct inode *inode);
-
-/* exported operations */
-struct super_operations coda_super_operations =
-{
- coda_read_inode, /* read_inode */
- NULL, /* write_inode */
- coda_put_inode, /* put_inode */
- coda_delete_inode, /* delete_inode */
- coda_notify_change, /* notify_change */
- coda_put_super, /* put_super */
- NULL, /* write_super */
- coda_statfs, /* statfs */
- NULL /* remount_fs */
-};
-
-/*
- * globals
- */
-struct coda_sb_info coda_super_info[MAX_CODADEVS];
-
-
-static struct super_block * coda_read_super(struct super_block *sb,
- void *data, int silent)
-{
- struct inode *psdev = 0, *root = 0;
- struct coda_sb_info *sbi = NULL;
- struct vcomm *vc = NULL;
- ViceFid fid;
- kdev_t dev = sb->s_dev;
- int error;
- char str[50];
-
- ENTRY;
- MOD_INC_USE_COUNT;
- if (coda_get_psdev(data, &psdev))
- goto error;
-
- vc = coda_psinode2vcomm(psdev);
- if ( !vc )
- goto error;
- vc->vc_sb = sb;
- vc->vc_inuse = 1;
-
- sbi = coda_psinode2sbi(psdev);
- if ( !sbi )
- goto error;
- sbi->sbi_psdev = psdev;
- sbi->sbi_vcomm = vc;
- INIT_LIST_HEAD(&(sbi->sbi_cchead));
- INIT_LIST_HEAD(&(sbi->sbi_volroothead));
-
- lock_super(sb);
- sb->u.generic_sbp = sbi;
- sb->s_blocksize = 1024; /* XXXXX what do we put here?? */
- sb->s_blocksize_bits = 10;
- sb->s_magic = CODA_SUPER_MAGIC;
- sb->s_dev = dev;
- sb->s_op = &coda_super_operations;
-
- /* get root fid from Venus: this needs the root inode */
- error = venus_rootfid(sb, &fid);
- if ( error ) {
- printk("coda_read_super: coda_get_rootfid failed with %d\n",
- error);
- sb->s_dev = 0;
- unlock_super(sb);
- goto error;
- }
- printk("coda_read_super: rootfid is %s\n", coda_f2s(&fid));
-
- /* make root inode */
- error = coda_cnode_make(&root, &fid, sb);
- if ( error || !root ) {
- printk("Failure of coda_cnode_make for root: error %d\n", error);
- sb->s_dev = 0;
- unlock_super(sb);
- goto error;
- }
-
- printk("coda_read_super: rootinode is %ld dev %d\n",
- root->i_ino, root->i_dev);
- sbi->sbi_root = root;
- sb->s_root = d_alloc_root(root, NULL);
- unlock_super(sb);
- EXIT;
- return sb;
-
-error:
-EXIT;
- MOD_DEC_USE_COUNT;
- if (sbi) {
- sbi->sbi_vcomm = NULL;
- sbi->sbi_root = NULL;
- }
- if ( vc ) {
- vc->vc_sb = NULL;
- vc->vc_inuse = 0;
- }
- if (root) {
- iput(root);
- }
- sb->s_dev = 0;
- return NULL;
-}
-
-static void coda_put_super(struct super_block *sb)
-{
- struct coda_sb_info *sb_info;
-
- ENTRY;
-
- lock_super(sb);
-
- sb->s_dev = 0;
- coda_cache_clear_all(sb);
- sb_info = coda_sbp(sb);
- sb_info->sbi_vcomm->vc_inuse = 0;
- sb_info->sbi_vcomm->vc_sb = NULL;
- printk("Coda: Bye bye.\n");
- memset(sb_info, 0, sizeof(* sb_info));
-
- unlock_super(sb);
- MOD_DEC_USE_COUNT;
- EXIT;
-}
-
-/* all filling in of inodes postponed until lookup */
-static void coda_read_inode(struct inode *inode)
-{
- struct coda_inode_info *cnp;
- ENTRY;
- cnp = ITOC(inode);
- cnp->c_magic = 0;
- return;
-}
-
-static void coda_put_inode(struct inode *in)
-{
- ENTRY;
-
- CDEBUG(D_INODE,"ino: %ld, count %d\n", in->i_ino, in->i_count);
-
- if ( in->i_count == 1 )
- in->i_nlink = 0;
-
-}
-
-static void coda_delete_inode(struct inode *inode)
-{
- struct coda_inode_info *cnp;
- struct inode *open_inode;
-
- ENTRY;
- CDEBUG(D_SUPER, " inode->ino: %ld, count: %d\n",
- inode->i_ino, inode->i_count);
-
- cnp = ITOC(inode);
- if ( inode->i_ino == CTL_INO || cnp->c_magic != CODA_CNODE_MAGIC ) {
- clear_inode(inode);
- return;
- }
-
-
- if ( coda_fid_is_volroot(&cnp->c_fid) )
- list_del(&cnp->c_volrootlist);
-
- open_inode = cnp->c_ovp;
- if ( open_inode ) {
- CDEBUG(D_SUPER, "DELINO cached file: ino %ld count %d.\n",
- open_inode->i_ino, open_inode->i_count);
- cnp->c_ovp = NULL;
- iput(open_inode);
- }
-
- coda_cache_clear_cnp(cnp);
-
- inode->u.generic_ip = NULL;
- clear_inode(inode);
- EXIT;
-}
-
-static int coda_notify_change(struct dentry *de, struct iattr *iattr)
-{
- struct inode *inode = de->d_inode;
- struct coda_inode_info *cnp;
- struct coda_vattr vattr;
- int error;
-
- ENTRY;
- memset(&vattr, 0, sizeof(vattr));
- cnp = ITOC(inode);
- CHECK_CNODE(cnp);
-
- coda_iattr_to_vattr(iattr, &vattr);
- vattr.va_type = C_VNON; /* cannot set type */
- CDEBUG(D_SUPER, "vattr.va_mode %o\n", vattr.va_mode);
-
- error = venus_setattr(inode->i_sb, &cnp->c_fid, &vattr);
-
- if ( !error ) {
- coda_vattr_to_iattr(inode, &vattr);
- coda_cache_clear_cnp(cnp);
- }
- CDEBUG(D_SUPER, "inode.i_mode %o, error %d\n",
- inode->i_mode, error);
-
- EXIT;
- return error;
-}
-
-/* we need _something_ for this routine. Let's mimic AFS */
-static int coda_statfs(struct super_block *sb, struct statfs *buf,
- int bufsiz)
-{
- struct statfs tmp;
-
- tmp.f_type = CODA_SUPER_MAGIC;
- tmp.f_bsize = 1024;
- tmp.f_blocks = 9000000;
- tmp.f_bfree = 9000000;
- tmp.f_bavail = 9000000 ;
- tmp.f_files = 9000000;
- tmp.f_ffree = 9000000;
- tmp.f_namelen = 0;
- copy_to_user(buf, &tmp, bufsiz);
- return 0;
-}
-
-
-/* init_coda: used by filesystems.c to register coda */
-
-struct file_system_type coda_fs_type = {
- "coda", 0, coda_read_super, NULL
-};
-
-int init_coda_fs(void)
-{
- return register_filesystem(&coda_fs_type);
-}
-
-/* MODULE stuff is in psdev.c */
-
-/* helpers */
-static inline struct vcomm *coda_psinode2vcomm(struct inode *inode)
-{
-
- unsigned int minor = MINOR(inode->i_rdev);
- CDEBUG(D_PSDEV,"minor %d\n", minor);
- if ( minor < MAX_CODADEVS )
- return &(psdev_vcomm[minor]);
- else
- return NULL;
-}
-
-static struct coda_sb_info *coda_psinode2sbi(struct inode *inode)
-{
- unsigned int minor = MINOR(inode->i_rdev);
-
- CDEBUG(D_PSDEV,"minor %d\n", minor);
- if ( (minor >= 0) && (minor < MAX_CODADEVS))
- return &(coda_super_info[minor]);
- else
- return NULL;
-}
-
-/* name lookup for psdev passed in by mount */
-static int coda_get_psdev(void *data, struct inode **res_dev)
-{
- char **psdev_path;
- struct inode *psdev = 0;
- struct dentry *ent=NULL;
-
-
- if ( ! data ) {
- printk("coda_get_psdev: no data!\n");
- return 1;
- }
-
- psdev_path = data;
- ent = namei((char *) *psdev_path);
- if (IS_ERR(ent)) {
- printk("namei error %ld for %d\n", PTR_ERR(ent),
- (int) psdev_path);
- return 1;
- }
- psdev = ent->d_inode;
-
- if (!S_ISCHR(psdev->i_mode)) {
- printk("not a character device\n");
- return 1;
- }
- CDEBUG(D_PSDEV,"major %d, minor %d, count %d\n",
- MAJOR(psdev->i_rdev),
- MINOR(psdev->i_rdev), psdev->i_count);
-
- if (MAJOR(psdev->i_rdev) != CODA_PSDEV_MAJOR) {
- printk("device %d not a Coda PSDEV device\n",
- MAJOR(psdev->i_rdev));
- return 1;
- }
-
- if (MINOR(psdev->i_rdev) >= MAX_CODADEVS) {
- printk("minor %d not an allocated Coda PSDEV\n",
- psdev->i_rdev);
- return 1;
- }
-
- if (psdev->i_count < 1) {
- printk("coda device minor %d not open (i_count = %d)\n",
- MINOR(psdev->i_rdev), psdev->i_count);
- return 1;
- }
-
- *res_dev = psdev;
- EXIT;
- return 0;
-}
FUNET's LINUX-ADM group, linux-adm@nic.funet.fi
TCL-scripts by Sam Shen, slshen@lbl.gov