parent
39c5e0af88
commit
dccab72215
@ -0,0 +1,96 @@
|
|||||||
|
#include <errno.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <sys/stat.h>
|
||||||
|
#include <a.out.h>
|
||||||
|
|
||||||
|
#include <linux/fs.h>
|
||||||
|
#include <linux/sched.h>
|
||||||
|
#include <linux/kernel.h>
|
||||||
|
#include <linux/mm.h>
|
||||||
|
#include <asm/segment.h>
|
||||||
|
|
||||||
|
struct linux_dirent {
|
||||||
|
long d_ino;
|
||||||
|
off_t d_off;
|
||||||
|
unsigned short d_reclen;
|
||||||
|
char d_name[14];
|
||||||
|
};
|
||||||
|
|
||||||
|
int sys_getdents(unsigned int fd, struct linux_dirent *d, unsigned int count)
|
||||||
|
{
|
||||||
|
struct file *f;
|
||||||
|
struct m_inode * m;
|
||||||
|
struct buffer_head * b;
|
||||||
|
struct dir_entry * dir;
|
||||||
|
int i,j,k,res;
|
||||||
|
struct linux_dirent usrd;
|
||||||
|
i=0;
|
||||||
|
res=0;
|
||||||
|
f=current->filp[fd];
|
||||||
|
m=f->f_inode;
|
||||||
|
b=bread(m->i_dev,m->i_zone[0]);
|
||||||
|
dir=(struct dir_entry*)b->b_data;
|
||||||
|
while(dir[i].inode>0)
|
||||||
|
{
|
||||||
|
if(res+sizeof(struct linux_dirent)>count)
|
||||||
|
break;
|
||||||
|
usrd.d_ino=dir[i].inode;
|
||||||
|
usrd.d_off=0;
|
||||||
|
usrd.d_reclen=sizeof(struct linux_dirent);
|
||||||
|
for(j=0;j<14;j++)
|
||||||
|
usrd.d_name[j]=dir[i].name[j];
|
||||||
|
for(k=0;k<sizeof(struct linux_dirent);k++)
|
||||||
|
{
|
||||||
|
put_fs_byte(((char*)(&usrd))[k],(char*)d+res);
|
||||||
|
res++;
|
||||||
|
}
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
|
char *sys_getcwd(char* buf,size_t size)
|
||||||
|
{
|
||||||
|
char *path[14];
|
||||||
|
int i,j,k,l,dev,inum;
|
||||||
|
struct m_inode *inode;
|
||||||
|
struct buffer_head *b;
|
||||||
|
struct dir_entry *d;
|
||||||
|
dev=current->root->i_dev;
|
||||||
|
inode=current->pwd;
|
||||||
|
inum=inode->i_num;
|
||||||
|
b=bread(dev,inode->i_zone[0]);
|
||||||
|
d=(struct dir_entry*) b->b_data;
|
||||||
|
i=0;
|
||||||
|
l=0;
|
||||||
|
while(inum!=1)
|
||||||
|
{
|
||||||
|
inode=iget(dev, d[1].inode);
|
||||||
|
b=bread(dev,inode->i_zone[0]);
|
||||||
|
d=(struct dir_entry*) b->b_data;
|
||||||
|
j=0;
|
||||||
|
while(d[j].inode!=inum) j++;
|
||||||
|
inum=inode->i_num;
|
||||||
|
path[i]=d[j].name;
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
while(i>0)
|
||||||
|
{
|
||||||
|
i--;
|
||||||
|
put_fs_byte('/',buf+l);
|
||||||
|
l++;
|
||||||
|
k=0;
|
||||||
|
while(path[i][k]!='\0')
|
||||||
|
{
|
||||||
|
put_fs_byte(path[i][k],buf+l);
|
||||||
|
l++;
|
||||||
|
if(l>=size) break;
|
||||||
|
k++;
|
||||||
|
}
|
||||||
|
if(l>=size) break;
|
||||||
|
}
|
||||||
|
return buf;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in new issue