sys_unlink是删除硬链接的系统调用,引用数为0时底层的文件会被删除sys_unlink是删除硬链接的系统调用,引用数为0时底层的文件会被删除
代码语言:javascript复制// 删除硬链接
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 (x:%d), %dn",
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;
}