OpenCores
URL https://opencores.org/ocsvn/or1k_old/or1k_old/trunk

Subversion Repositories or1k_old

[/] [or1k_old/] [trunk/] [rc203soc/] [sw/] [uClinux/] [fs/] [proc/] [inode.c] - Diff between revs 1765 and 1782

Only display areas with differences | Details | Blame | View Log

Rev 1765 Rev 1782
/*
/*
 *  linux/fs/proc/inode.c
 *  linux/fs/proc/inode.c
 *
 *
 *  Copyright (C) 1991, 1992  Linus Torvalds
 *  Copyright (C) 1991, 1992  Linus Torvalds
 */
 */
 
 
/*
/*
 * uClinux revisions for NO_MM
 * uClinux revisions for NO_MM
 * Copyright (C) 1998  Kenneth Albanowski <kjahds@kjahds.com>,
 * Copyright (C) 1998  Kenneth Albanowski <kjahds@kjahds.com>,
 *                     The Silver Hammer Group, Ltd.
 *                     The Silver Hammer Group, Ltd.
 */
 */
 
 
#include <linux/sched.h>
#include <linux/sched.h>
#include <linux/proc_fs.h>
#include <linux/proc_fs.h>
#include <linux/kernel.h>
#include <linux/kernel.h>
#include <linux/mm.h>
#include <linux/mm.h>
#include <linux/string.h>
#include <linux/string.h>
#include <linux/stat.h>
#include <linux/stat.h>
#include <linux/locks.h>
#include <linux/locks.h>
#include <linux/limits.h>
#include <linux/limits.h>
 
 
#include <asm/system.h>
#include <asm/system.h>
#include <asm/segment.h>
#include <asm/segment.h>
 
 
static void proc_put_inode(struct inode *inode)
static void proc_put_inode(struct inode *inode)
{
{
        if (inode->i_nlink)
        if (inode->i_nlink)
                return;
                return;
        inode->i_size = 0;
        inode->i_size = 0;
}
}
 
 
static void proc_put_super(struct super_block *sb)
static void proc_put_super(struct super_block *sb)
{
{
        lock_super(sb);
        lock_super(sb);
        sb->s_dev = 0;
        sb->s_dev = 0;
        unlock_super(sb);
        unlock_super(sb);
}
}
 
 
static struct super_operations proc_sops = {
static struct super_operations proc_sops = {
        proc_read_inode,
        proc_read_inode,
        NULL,
        NULL,
        proc_write_inode,
        proc_write_inode,
        proc_put_inode,
        proc_put_inode,
        proc_put_super,
        proc_put_super,
        NULL,
        NULL,
        proc_statfs,
        proc_statfs,
        NULL
        NULL
};
};
 
 
 
 
static int parse_options(char *options,uid_t *uid,gid_t *gid)
static int parse_options(char *options,uid_t *uid,gid_t *gid)
{
{
        char *this_char,*value;
        char *this_char,*value;
 
 
        *uid = current->uid;
        *uid = current->uid;
        *gid = current->gid;
        *gid = current->gid;
        if (!options) return 1;
        if (!options) return 1;
        for (this_char = strtok(options,","); this_char; this_char = strtok(NULL,",")) {
        for (this_char = strtok(options,","); this_char; this_char = strtok(NULL,",")) {
                if ((value = strchr(this_char,'=')) != NULL)
                if ((value = strchr(this_char,'=')) != NULL)
                        *value++ = 0;
                        *value++ = 0;
                if (!strcmp(this_char,"uid")) {
                if (!strcmp(this_char,"uid")) {
                        if (!value || !*value)
                        if (!value || !*value)
                                return 0;
                                return 0;
                        *uid = simple_strtoul(value,&value,0);
                        *uid = simple_strtoul(value,&value,0);
                        if (*value)
                        if (*value)
                                return 0;
                                return 0;
                }
                }
                else if (!strcmp(this_char,"gid")) {
                else if (!strcmp(this_char,"gid")) {
                        if (!value || !*value)
                        if (!value || !*value)
                                return 0;
                                return 0;
                        *gid = simple_strtoul(value,&value,0);
                        *gid = simple_strtoul(value,&value,0);
                        if (*value)
                        if (*value)
                                return 0;
                                return 0;
                }
                }
                else return 1;
                else return 1;
        }
        }
        return 1;
        return 1;
}
}
 
 
struct inode * proc_get_inode(struct super_block * s, int ino, struct proc_dir_entry * de)
struct inode * proc_get_inode(struct super_block * s, int ino, struct proc_dir_entry * de)
{
{
        struct inode * inode = iget(s, ino);
        struct inode * inode = iget(s, ino);
        if (inode && inode->i_sb == s) {
        if (inode && inode->i_sb == s) {
                inode->u.generic_ip = (void *) de;
                inode->u.generic_ip = (void *) de;
                if (de) {
                if (de) {
                        if (de->mode) {
                        if (de->mode) {
                                inode->i_mode = de->mode;
                                inode->i_mode = de->mode;
                                inode->i_uid = de->uid;
                                inode->i_uid = de->uid;
                                inode->i_gid = de->gid;
                                inode->i_gid = de->gid;
                        }
                        }
                        if (de->size)
                        if (de->size)
                                inode->i_size = de->size;
                                inode->i_size = de->size;
                        if (de->ops)
                        if (de->ops)
                                inode->i_op = de->ops;
                                inode->i_op = de->ops;
                        if (de->nlink)
                        if (de->nlink)
                                inode->i_nlink = de->nlink;
                                inode->i_nlink = de->nlink;
                        if (de->fill_inode)
                        if (de->fill_inode)
                                de->fill_inode(inode);
                                de->fill_inode(inode);
                }
                }
        }
        }
        return inode;
        return inode;
}
}
 
 
struct super_block *proc_read_super(struct super_block *s,void *data,
struct super_block *proc_read_super(struct super_block *s,void *data,
                                    int silent)
                                    int silent)
{
{
        proc_root_init();
        proc_root_init();
        lock_super(s);
        lock_super(s);
        s->s_blocksize = 1024;
        s->s_blocksize = 1024;
        s->s_blocksize_bits = 10;
        s->s_blocksize_bits = 10;
        s->s_magic = PROC_SUPER_MAGIC;
        s->s_magic = PROC_SUPER_MAGIC;
        s->s_op = &proc_sops;
        s->s_op = &proc_sops;
        unlock_super(s);
        unlock_super(s);
        if (!(s->s_mounted = proc_get_inode(s, PROC_ROOT_INO, &proc_root))) {
        if (!(s->s_mounted = proc_get_inode(s, PROC_ROOT_INO, &proc_root))) {
                s->s_dev = 0;
                s->s_dev = 0;
                printk("get root inode failed\n");
                printk("get root inode failed\n");
                return NULL;
                return NULL;
        }
        }
        parse_options(data, &s->s_mounted->i_uid, &s->s_mounted->i_gid);
        parse_options(data, &s->s_mounted->i_uid, &s->s_mounted->i_gid);
        return s;
        return s;
}
}
 
 
void proc_statfs(struct super_block *sb, struct statfs *buf, int bufsiz)
void proc_statfs(struct super_block *sb, struct statfs *buf, int bufsiz)
{
{
        struct statfs tmp;
        struct statfs tmp;
 
 
        tmp.f_type = PROC_SUPER_MAGIC;
        tmp.f_type = PROC_SUPER_MAGIC;
        tmp.f_bsize = PAGE_SIZE/sizeof(long);
        tmp.f_bsize = PAGE_SIZE/sizeof(long);
        tmp.f_blocks = 0;
        tmp.f_blocks = 0;
        tmp.f_bfree = 0;
        tmp.f_bfree = 0;
        tmp.f_bavail = 0;
        tmp.f_bavail = 0;
        tmp.f_files = 0;
        tmp.f_files = 0;
        tmp.f_ffree = 0;
        tmp.f_ffree = 0;
        tmp.f_namelen = NAME_MAX;
        tmp.f_namelen = NAME_MAX;
        memcpy_tofs(buf, &tmp, bufsiz);
        memcpy_tofs(buf, &tmp, bufsiz);
}
}
 
 
void proc_read_inode(struct inode * inode)
void proc_read_inode(struct inode * inode)
{
{
        unsigned long ino, pid;
        unsigned long ino, pid;
        struct task_struct * p;
        struct task_struct * p;
        int i;
        int i;
 
 
        inode->i_op = NULL;
        inode->i_op = NULL;
        inode->i_mode = 0;
        inode->i_mode = 0;
        inode->i_uid = 0;
        inode->i_uid = 0;
        inode->i_gid = 0;
        inode->i_gid = 0;
        inode->i_nlink = 1;
        inode->i_nlink = 1;
        inode->i_size = 0;
        inode->i_size = 0;
        inode->i_mtime = inode->i_atime = inode->i_ctime = CURRENT_TIME;
        inode->i_mtime = inode->i_atime = inode->i_ctime = CURRENT_TIME;
        inode->i_blocks = 0;
        inode->i_blocks = 0;
        inode->i_blksize = 1024;
        inode->i_blksize = 1024;
        ino = inode->i_ino;
        ino = inode->i_ino;
        pid = ino >> 16;
        pid = ino >> 16;
        p = task[0];
        p = task[0];
        for (i = 0; i < NR_TASKS ; i++)
        for (i = 0; i < NR_TASKS ; i++)
                if ((p = task[i]) && (p->pid == pid))
                if ((p = task[i]) && (p->pid == pid))
                        break;
                        break;
        if (!p || i >= NR_TASKS)
        if (!p || i >= NR_TASKS)
                return;
                return;
        if (ino == PROC_ROOT_INO) {
        if (ino == PROC_ROOT_INO) {
                inode->i_mode = S_IFDIR | S_IRUGO | S_IXUGO;
                inode->i_mode = S_IFDIR | S_IRUGO | S_IXUGO;
                inode->i_nlink = 2;
                inode->i_nlink = 2;
                for (i = 1 ; i < NR_TASKS ; i++)
                for (i = 1 ; i < NR_TASKS ; i++)
                        if (task[i])
                        if (task[i])
                                inode->i_nlink++;
                                inode->i_nlink++;
                return;
                return;
        }
        }
 
 
        if (!pid) {
        if (!pid) {
                switch (ino) {
                switch (ino) {
                        case PROC_KMSG:
                        case PROC_KMSG:
                                inode->i_mode = S_IFREG | S_IRUSR;
                                inode->i_mode = S_IFREG | S_IRUSR;
                                inode->i_op = &proc_kmsg_inode_operations;
                                inode->i_op = &proc_kmsg_inode_operations;
                                break;
                                break;
                        case PROC_NET:
                        case PROC_NET:
                                inode->i_nlink = 2;
                                inode->i_nlink = 2;
                                break;
                                break;
                        case PROC_SCSI:
                        case PROC_SCSI:
                                inode->i_mode = S_IFDIR | S_IRUGO | S_IXUGO;
                                inode->i_mode = S_IFDIR | S_IRUGO | S_IXUGO;
                                inode->i_nlink = 2;
                                inode->i_nlink = 2;
                                inode->i_op = &proc_scsi_inode_operations;
                                inode->i_op = &proc_scsi_inode_operations;
                                break;
                                break;
                        case PROC_KCORE:
                        case PROC_KCORE:
                                inode->i_mode = S_IFREG | S_IRUSR;
                                inode->i_mode = S_IFREG | S_IRUSR;
                                inode->i_op = &proc_kcore_inode_operations;
                                inode->i_op = &proc_kcore_inode_operations;
                                inode->i_size = (MAP_NR(high_memory) << PAGE_SHIFT) + PAGE_SIZE;
                                inode->i_size = (MAP_NR(high_memory) << PAGE_SHIFT) + PAGE_SIZE;
                                break;
                                break;
                        case PROC_PROFILE:
                        case PROC_PROFILE:
                                inode->i_mode = S_IFREG | S_IRUGO | S_IWUSR;
                                inode->i_mode = S_IFREG | S_IRUGO | S_IWUSR;
                                inode->i_op = &proc_profile_inode_operations;
                                inode->i_op = &proc_profile_inode_operations;
                                inode->i_size = (1+prof_len) * sizeof(unsigned long);
                                inode->i_size = (1+prof_len) * sizeof(unsigned long);
                                break;
                                break;
                        default:
                        default:
                                inode->i_mode = S_IFREG | S_IRUGO;
                                inode->i_mode = S_IFREG | S_IRUGO;
                                inode->i_op = &proc_array_inode_operations;
                                inode->i_op = &proc_array_inode_operations;
                                break;
                                break;
                }
                }
                return;
                return;
        }
        }
        ino &= 0x0000ffff;
        ino &= 0x0000ffff;
        if (ino == PROC_PID_INO || p->dumpable) {
        if (ino == PROC_PID_INO || p->dumpable) {
                inode->i_uid = p->euid;
                inode->i_uid = p->euid;
                inode->i_gid = p->egid;
                inode->i_gid = p->egid;
        }
        }
        switch (ino) {
        switch (ino) {
                case PROC_PID_INO:
                case PROC_PID_INO:
                        inode->i_nlink = 4;
                        inode->i_nlink = 4;
                        return;
                        return;
                case PROC_PID_MEM:
                case PROC_PID_MEM:
                        inode->i_op = &proc_mem_inode_operations;
                        inode->i_op = &proc_mem_inode_operations;
                        inode->i_mode = S_IFREG | S_IRUSR | S_IWUSR;
                        inode->i_mode = S_IFREG | S_IRUSR | S_IWUSR;
                        return;
                        return;
                case PROC_PID_CWD:
                case PROC_PID_CWD:
                case PROC_PID_ROOT:
                case PROC_PID_ROOT:
                case PROC_PID_EXE:
                case PROC_PID_EXE:
                        inode->i_op = &proc_link_inode_operations;
                        inode->i_op = &proc_link_inode_operations;
                        inode->i_size = 64;
                        inode->i_size = 64;
                        inode->i_mode = S_IFLNK | S_IRWXU;
                        inode->i_mode = S_IFLNK | S_IRWXU;
                        return;
                        return;
                case PROC_PID_FD:
                case PROC_PID_FD:
                        inode->i_mode = S_IFDIR | S_IRUSR | S_IXUSR;
                        inode->i_mode = S_IFDIR | S_IRUSR | S_IXUSR;
                        inode->i_op = &proc_fd_inode_operations;
                        inode->i_op = &proc_fd_inode_operations;
                        inode->i_nlink = 2;
                        inode->i_nlink = 2;
                        return;
                        return;
                case PROC_PID_ENVIRON:
                case PROC_PID_ENVIRON:
                        inode->i_mode = S_IFREG | S_IRUSR;
                        inode->i_mode = S_IFREG | S_IRUSR;
                        inode->i_op = &proc_array_inode_operations;
                        inode->i_op = &proc_array_inode_operations;
                        return;
                        return;
                case PROC_PID_CMDLINE:
                case PROC_PID_CMDLINE:
                case PROC_PID_STATUS:
                case PROC_PID_STATUS:
                case PROC_PID_STAT:
                case PROC_PID_STAT:
#ifndef NO_MM
#ifndef NO_MM
                case PROC_PID_STATM:
                case PROC_PID_STATM:
#endif /* !NO_MM */
#endif /* !NO_MM */
                        inode->i_mode = S_IFREG | S_IRUGO;
                        inode->i_mode = S_IFREG | S_IRUGO;
                        inode->i_op = &proc_array_inode_operations;
                        inode->i_op = &proc_array_inode_operations;
                        return;
                        return;
#ifndef NO_MM
#ifndef NO_MM
                case PROC_PID_MAPS:
                case PROC_PID_MAPS:
                        inode->i_mode = S_IFIFO | S_IRUGO;
                        inode->i_mode = S_IFIFO | S_IRUGO;
                        inode->i_op = &proc_arraylong_inode_operations;
                        inode->i_op = &proc_arraylong_inode_operations;
                        return;
                        return;
#endif /* !NO_MM */
#endif /* !NO_MM */
        }
        }
        switch (ino >> 8) {
        switch (ino >> 8) {
                case PROC_PID_FD_DIR:
                case PROC_PID_FD_DIR:
                        ino &= 0xff;
                        ino &= 0xff;
                        if (ino >= NR_OPEN || !p->files || !p->files->fd[ino])
                        if (ino >= NR_OPEN || !p->files || !p->files->fd[ino])
                                return;
                                return;
                        inode->i_op = &proc_link_inode_operations;
                        inode->i_op = &proc_link_inode_operations;
                        inode->i_size = 64;
                        inode->i_size = 64;
                        inode->i_mode = S_IFLNK;
                        inode->i_mode = S_IFLNK;
                        if (p->files->fd[ino]->f_mode & 1)
                        if (p->files->fd[ino]->f_mode & 1)
                                inode->i_mode |= S_IRUSR | S_IXUSR;
                                inode->i_mode |= S_IRUSR | S_IXUSR;
                        if (p->files->fd[ino]->f_mode & 2)
                        if (p->files->fd[ino]->f_mode & 2)
                                inode->i_mode |= S_IWUSR | S_IXUSR;
                                inode->i_mode |= S_IWUSR | S_IXUSR;
                        return;
                        return;
        }
        }
        return;
        return;
}
}
 
 
void proc_write_inode(struct inode * inode)
void proc_write_inode(struct inode * inode)
{
{
        inode->i_dirt=0;
        inode->i_dirt=0;
}
}
 
 

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.