diff options
| author | kaashoek <kaashoek> | 2006-08-14 03:00:13 +0000 | 
|---|---|---|
| committer | kaashoek <kaashoek> | 2006-08-14 03:00:13 +0000 | 
| commit | d15f0d1033a7da6448966d9626ec2776781e4188 (patch) | |
| tree | 21760376e140e637d48cb3a246b76f62650a454e | |
| parent | e4bcd2a3a919ef040d2a577a1025f286c3b57168 (diff) | |
| download | xv6-labs-d15f0d1033a7da6448966d9626ec2776781e4188.tar.gz xv6-labs-d15f0d1033a7da6448966d9626ec2776781e4188.tar.bz2 xv6-labs-d15f0d1033a7da6448966d9626ec2776781e4188.zip | |
start on mkdir
stat
| -rw-r--r-- | ls.c | 18 | ||||
| -rw-r--r-- | syscall.c | 28 | ||||
| -rw-r--r-- | syscall.h | 1 | ||||
| -rw-r--r-- | ulib.c | 16 | ||||
| -rw-r--r-- | user.h | 3 | ||||
| -rw-r--r-- | userfs.c | 13 | ||||
| -rw-r--r-- | usys.S | 1 | 
7 files changed, 73 insertions, 7 deletions
| @@ -4,7 +4,7 @@  #include "fs.h"  char buf[512]; -struct stat stat; +struct stat st;  struct dirent dirent;  int @@ -23,20 +23,26 @@ main(int argc, char *argv[])      printf(2, "ls: cannot open .\n");      exit();    } -  if (fstat(fd, &stat) < 0) { +  if (fstat(fd, &st) < 0) {      printf(2, "ls: cannot open .\n");      exit();    } -  if (stat.st_type != T_DIR) { +  if (st.st_type != T_DIR) {      printf(2, "ls: . is not a dir\n");    } -  for(off = 0; off < stat.st_size; off += sizeof(struct dirent)) { +  cprintf("size %d\n", st.st_size); +  for(off = 0; off < st.st_size; off += sizeof(struct dirent)) {      if (read(fd, &dirent, sizeof(struct dirent)) != sizeof(struct dirent)) {        printf(2, "ls: read error\n");        exit();      } -    if (dirent.inum != 0) -      printf(1, "%s\n", dirent.name); +    if (dirent.inum != 0) { + +      if (stat (dirent.name, &st) < 0)  +	printf(2, "stat: failed\n"); + +      printf(1, "%s t %d\n", dirent.name, st.st_type); +    }    }    close(fd); @@ -290,6 +290,31 @@ sys_mknod(void)  }  int +sys_mkdir(void) +{ +  struct proc *cp = curproc[cpu()]; +  struct inode *nip; +  uint arg0; +  int l; + +  if(fetcharg(0, &arg0) < 0)  +    return -1; + +  if((l = checkstring(arg0)) < 0) +    return -1; + +  if(l >= DIRSIZ) +    return -1; + +  nip = mknod (cp->mem + arg0, T_DIR, 0, 0); + +  // XXX put . and .. in + +  iput(nip); +  return (nip == 0) ? -1 : 0; +} + +int  sys_unlink(void)  {    struct proc *cp = curproc[cpu()]; @@ -561,6 +586,9 @@ syscall(void)    case SYS_link:      ret = sys_link();      break; +  case SYS_mkdir: +    ret = sys_mkdir(); +    break;    default:      cprintf("unknown sys call %d\n", num);      // XXX fault @@ -13,4 +13,5 @@  #define SYS_unlink 16  #define SYS_fstat 17  #define SYS_link 18 +#define SYS_mkdir 19 @@ -1,3 +1,6 @@ +#include "types.h" +#include "stat.h" +#include "fcntl.h"  #include "user.h"  int @@ -54,3 +57,16 @@ gets(char *buf, int max)    buf[i] = '\0';    return buf;  } + +int +stat(char *n, struct stat *st) +{ +  int fd = open(n, O_RDONLY); +  int r; + +  if (fd < 0) return -1; + +  r = fstat(fd, st); +  close(fd); +  return r; +} @@ -14,9 +14,10 @@ int exec(char *, char **);  int open(char *, int);  int mknod (char*,short,short,short);  int unlink (char*); -struct stat;  int fstat (int fd, struct stat *stat);  int link(char *, char *); +int mkdir(char *); +int stat(char *, struct stat *stat);  int puts(char*);  char* strcpy(char*, char*); @@ -65,7 +65,13 @@ main(void)      printf(stdout, "read failed\n");    }    close(fd); + +  printf(stdout, "unlink doesnotexist\n"); +    unlink("doesnotexist"); + +  printf(stdout, "many creates, followed by unlink\n"); +    name[0] = 'a';    name[2] = '\0';    for (i = 0; i < 52; i++) { @@ -80,6 +86,13 @@ main(void)      unlink(name);    } +  printf(stdout, "mkdir\n"); + +  if (mkdir("dir0") < 0)  +    printf(stdout, "mkdir failed\n"); + +  //  unlink("dir0"); +    //exec("echo", echo_args);    printf(stdout, "about to do exec\n");    exec("cat", cat_args); @@ -23,3 +23,4 @@ STUB(mknod)  STUB(unlink)  STUB(fstat)  STUB(link) +STUB(mkdir) | 
