📄 pipe.c
字号:
#include <signal.h>
#include <linux/sched.h>
#include <linux/mm.h> /* for get_free_page */
#include <asm/segment.h>
int read_pipe(struct m_inode * inode, char * buf, int count)
{
char * b=buf;
while (PIPE_EMPTY(*inode)) { //如果此管道inode为空
wake_up(&inode->i_wait); //唤醒等待用此管道的进程(写进程)
if (inode->i_count != 2) /* are there any writers left? */
return 0;
sleep_on(&inode->i_wait); //让该进程睡眠在此管道上
}
while (count>0 && !(PIPE_EMPTY(*inode))) { //如果管道不为空
count --;
put_fs_byte(((char *)inode->i_size)[PIPE_TAIL(*inode)],b++); //从管道尾开始读数据到buf
INC_PIPE( PIPE_TAIL(*inode) );
}
wake_up(&inode->i_wait); //唤醒写进程
return b-buf;
}
int write_pipe(struct m_inode * inode, char * buf, int count)
{
char * b=buf;
wake_up(&inode->i_wait);
if (inode->i_count != 2) { /* no readers */
current->signal |= (1<<(SIGPIPE-1));
return -1;
}
while (count-->0) {
while (PIPE_FULL(*inode)) { //管道是否是满的
wake_up(&inode->i_wait); //唤醒读进程
if (inode->i_count != 2) {
current->signal |= (1<<(SIGPIPE-1));
return b-buf;
}
sleep_on(&inode->i_wait); //写进程睡眠
}
((char *)inode->i_size)[PIPE_HEAD(*inode)] = get_fs_byte(b++); //向管道实际写数据
INC_PIPE( PIPE_HEAD(*inode) );
wake_up(&inode->i_wait); //唤醒读进程
}
wake_up(&inode->i_wait); //唤醒读进程
return b-buf;
}
int sys_pipe(unsigned long * fildes) //建立一个管道
{
struct m_inode * inode;
struct file * f[2];
int fd[2];
int i,j;
j=0;
for(i=0;j<2 && i<NR_FILE;i++)
if (!file_table[i].f_count) //在文件表中找一个未用的文件项
(f[j++]=i+file_table)->f_count++; //在文件表中登记两个文件结构
if (j==1)
f[0]->f_count=0;
if (j<2)
return -1;
j=0;
for(i=0;j<2 && i<NR_OPEN;i++) //在当前进程的文件列表中找两个未被占用的filp,来登记两个文件结构
if (!current->filp[i]) {
current->filp[ fd[j]=i ] = f[j];
j++;
}
if (j==1)
current->filp[fd[0]]=NULL;
if (j<2) {
f[0]->f_count=f[1]->f_count=0;
return -1;
}
if (!(inode=get_pipe_inode())) { //建立一个管道inode
current->filp[fd[0]] =
current->filp[fd[1]] = NULL;
f[0]->f_count = f[1]->f_count = 0;
return -1;
}
f[0]->f_inode = f[1]->f_inode = inode; //把这个inode附给两个文件
f[0]->f_pos = f[1]->f_pos = 0;
f[0]->f_mode = 1; /* read */
f[1]->f_mode = 2; /* write */
put_fs_long(fd[0],0+fildes);
put_fs_long(fd[1],1+fildes);
return 0;
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -