int sys_read(unsigned int fd,char * buf,int count) { struct file * file; struct m_inode * inode; if (fd>=NR_OPEN || count<0 || !(file=current->filp[fd])) return -EINVAL; if (!count) return 0; verify_area(buf,count); inode = file->f_inode; if (inode->i_pipe) return (file->f_mode&1)?read_pipe(inode,buf,count):-EIO; if (S_ISCHR(inode->i_mode)) return rw_char(READ,inode->i_zone[0],buf,count,&file->f_pos); if (S_ISBLK(inode->i_mode)) return block_read(inode->i_zone[0],&file->f_pos,buf,count); if (S_ISDIR(inode->i_mode) || S_ISREG(inode->i_mode)) { if (count+file->f_pos > inode->i_size) count = inode->i_size - file->f_pos; if (count<=0) return 0; return file_read(inode,file,buf,count); } if(S_ISPROC(inode->i_mode)) return proc_read(inode, buf, count, &file->f_pos); printk("(Read)inode->i_mode=%06o\n\r",inode->i_mode); return -EINVAL; }
int sys_write (unsigned int fd, char *buf, int count) { struct file *file; struct m_inode *inode; // 如果文件句柄值大于程序最多打开文件数NR_OPEN,或者需要写入的字节计数小于0,或者该句柄 // 的文件结构指针为空,则返回出错码并退出。 if (fd >= NR_OPEN || count < 0 || !(file = current->filp[fd])) return -EINVAL; // 若需读取的字节数count 等于0,则返回0,退出 if (!count) return 0; // 取文件对应的i 节点。若是管道文件,并且是写管道文件模式,则进行写管道操作,若成功则返回 // 写入的字节数,否则返回出错码,退出。 inode = file->f_inode; if (inode->i_pipe) return (file->f_mode & 2) ? write_pipe (inode, buf, count) : -EIO; // 如果是字符型文件,则进行写字符设备操作,返回写入的字符数,退出。 if (S_ISCHR (inode->i_mode)) return rw_char (WRITE, inode->i_zone[0], buf, count, &file->f_pos); // 如果是块设备文件,则进行块设备写操作,并返回写入的字节数,退出。 if (S_ISBLK (inode->i_mode)) return block_write (inode->i_zone[0], &file->f_pos, buf, count); // 若是常规文件,则执行文件写操作,并返回写入的字节数,退出。 if (S_ISREG (inode->i_mode)) return file_write (inode, file, buf, count); // 否则,显示对应节点的文件模式,返回出错码,退出。 printk ("(Write)inode->i_mode=%06o\n\r", inode->i_mode); return -EINVAL; }
int sys_write(unsigned int fd,char * buf,int count) { struct file * file; struct m_inode * inode; if (fd>=NR_OPEN || count <0 || !(file=current->filp[fd])) return -EINVAL; if (!count) return 0; inode=file->f_inode; if (inode->i_pipe) return (file->f_mode&2)?write_pipe(inode,buf,count):-EIO; if (S_ISCHR(inode->i_mode)) return rw_char(WRITE,inode->i_zone[0],buf,count,&file->f_pos); if (S_ISBLK(inode->i_mode)) return block_write(inode->i_zone[0],&file->f_pos,buf,count); if (S_ISREG(inode->i_mode)) return file_write(inode,file,buf,count); printk("(Write)inode->i_mode=%06o\n\r",inode->i_mode); return -EINVAL; }
//// 读文件系统调用函数。 // 参数fd 是文件句柄,buf 是缓冲区,count 是欲读字节数。 int sys_read (unsigned int fd, char *buf, int count) { struct file *file; struct m_inode *inode; // 如果文件句柄值大于程序最多打开文件数NR_OPEN,或者需要读取的字节计数值小于0,或者该句柄 // 的文件结构指针为空,则返回出错码并退出。 if (fd >= NR_OPEN || count < 0 || !(file = current->filp[fd])) return -EINVAL; // 若需读取的字节数count 等于0,则返回0,退出 if (!count) return 0; // 验证存放数据的缓冲区内存限制。 verify_area (buf, count); // 取文件对应的i 节点。若是管道文件,并且是读管道文件模式,则进行读管道操作,若成功则返回 // 读取的字节数,否则返回出错码,退出。 inode = file->f_inode; if (inode->i_pipe) return (file->f_mode & 1) ? read_pipe (inode, buf, count) : -EIO; // 如果是字符型文件,则进行读字符设备操作,返回读取的字符数。 if (S_ISCHR (inode->i_mode)) return rw_char (READ, inode->i_zone[0], buf, count, &file->f_pos); // 如果是块设备文件,则执行块设备读操作,并返回读取的字节数。 if (S_ISBLK (inode->i_mode)) return block_read (inode->i_zone[0], &file->f_pos, buf, count); // 如果是目录文件或者是常规文件,则首先验证读取数count 的有效性并进行调整(若读取字节数加上 // 文件当前读写指针值大于文件大小,则重新设置读取字节数为文件长度-当前读写指针值,若读取数 // 等于0,则返回0 退出),然后执行文件读操作,返回读取的字节数并退出。 if (S_ISDIR (inode->i_mode) || S_ISREG (inode->i_mode)) { if (count + file->f_pos > inode->i_size) count = inode->i_size - file->f_pos; if (count <= 0) return 0; return file_read (inode, file, buf, count); } // 否则打印节点文件属性,并返回出错码退出。 printk ("(Read)inode->i_mode=%06o\n\r", inode->i_mode); return -EINVAL; }