linux系统调用之sys_unlink(基于linux0.11)

sys_unlink是删除硬链接的系统调用,引用数为0时底层的文件会被删除sys_unlink是删除硬链接的系统调用,引用数为0时底层的文件会被删除

// 删除硬链接
int sys_unlink(const char * name)
{
    const char * basename;
    int namelen;
    struct m_inode * dir, * inode;
    struct buffer_head * bh;
    struct dir_entry * de;
    // 找出路径的最后一级目录的inode和路径中的文件名
    if (!(dir = dir_namei(name,&namelen,&basename)))
        return -ENOENT;
    // 传进来的路径是一个目录
    if (!namelen) {
        iput(dir);
        return -ENOENT;
    }
    // 权限
    if (!permission(dir,MAY_WRITE)) {
        iput(dir);
        return -EPERM;
    }
    // 找到路径对应文件的目录项
    bh = find_entry(&dir,basename,namelen,&de);
    // 不存在
    if (!bh) {
        iput(dir);
        return -ENOENT;
    }
    // 读取目录项对应的inode节点
    if (!(inode = iget(dir->i_dev, de->inode))) {
        iput(dir);
        brelse(bh);
        return -ENOENT;
    }
    // 权限
    if ((dir->i_mode & S_ISVTX) && !suser() &&
        current->euid != inode->i_uid &&
        current->euid != dir->i_uid) {
        iput(dir);
        iput(inode);
        brelse(bh);
        return -EPERM;
    }
    // 硬链接不能是目录
    if (S_ISDIR(inode->i_mode)) {
        iput(inode);
        iput(dir);
        brelse(bh);
        return -EPERM;
    }
    // 没进程引用该inode
    if (!inode->i_nlinks) {
        printk("Deleting nonexistent file (%04x:%d), %d\n",
            inode->i_dev,inode->i_num,inode->i_nlinks);
        inode->i_nlinks=1;
    }
    // 解除了引用,inode置为0
    de->inode = 0;
    // 需要回写硬盘
    bh->b_dirt = 1;
    brelse(bh);
    // 引用数减一,在iput中会删除引用数为0的文件
    inode->i_nlinks--;
    inode->i_dirt = 1;
    inode->i_ctime = CURRENT_TIME;
    iput(inode);
    iput(dir);
    return 0;
}

原文发布于微信公众号 - 编程杂技(theanarkh)

原文发表时间:2019-05-05

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

扫码关注云+社区

领取腾讯云代金券