Mercurial > hg > Members > innparusu > xv6-rpi
changeset 31:96a5833d0d82
fix
author | mir3636 |
---|---|
date | Fri, 18 Jan 2019 18:20:02 +0900 |
parents | 6a7ab1d7001c |
children | 96af12a50fdb |
files | src/console.c src/defs.h src/file.c src/file.h src/fs.c src/proc.h src/syscall.c |
diffstat | 7 files changed, 77 insertions(+), 34 deletions(-) [+] |
line wrap: on
line diff
--- a/src/console.c Fri Jan 18 11:50:48 2019 +0900 +++ b/src/console.c Fri Jan 18 18:20:02 2019 +0900 @@ -12,6 +12,9 @@ #include "mmu.h" #include "proc.h" +__code cbc_consoleread1 (__code(*)(int)); +__code cbc_consoleread2 (__code(*)(int)); + static void consputc (int); static int panicked = 0; @@ -230,6 +233,30 @@ release(&input.lock); } +__code cbc_consoleread2 (__code(*next)(int ret)) +{ + int n = proc->cbc_arg.cbc_console_arg.n; + int target = proc->cbc_arg.cbc_console_arg.target; + char* dst = proc->cbc_arg.cbc_console_arg.dst; + struct inode *ip = proc->cbc_arg.cbc_console_arg.ip; + struct file *f = proc->cbc_arg.cbc_console_arg.f; + proc->cbc_arg.cbc_console_arg.n = n; + proc->cbc_arg.cbc_console_arg.target = target; + proc->cbc_arg.cbc_console_arg.dst = dst; + proc->cbc_arg.cbc_console_arg.ip = ip; + proc->cbc_arg.cbc_console_arg.f = f; + proc->cbc_arg.cbc_console_arg.next = next; + if (input.r == input.w) { + if (proc->killed) { + release(&input.lock); + ilock(ip); + goto next(-1); + } + goto cbc_sleep(&input.r, &input.lock, cbc_consoleread2); + } + goto cbc_consoleread1(0); +} + __code cbc_consoleread1 (__code(*next)(int ret)) { int cont = 1; @@ -237,41 +264,51 @@ int target = proc->cbc_arg.cbc_console_arg.target; char* dst = proc->cbc_arg.cbc_console_arg.dst; struct inode *ip = proc->cbc_arg.cbc_console_arg.ip; + struct file *f = proc->cbc_arg.cbc_console_arg.f; int c = input.buf[input.r++ % INPUT_BUF]; - if (c == C('D')) { // EOF - if (n < target) { - // Save ^D for next time, to make sure - // caller gets a 0-byte result. - input.r--; - } - cont = 0; - } + if (c == C('D')) { // EOF + if (n < target) { + // Save ^D for next time, to make sure + // caller gets a 0-byte result. + input.r--; + } + cont = 0; + } - *dst++ = c; - --n; + *dst++ = c; + --n; - if (c == '\n') { - cont = 0; - } - + if (c == '\n') { + cont = 0; + } - if (cont){ + if (n > 0) { proc->cbc_arg.cbc_console_arg.n = n; + proc->cbc_arg.cbc_console_arg.target = target; proc->cbc_arg.cbc_console_arg.dst = dst; proc->cbc_arg.cbc_console_arg.ip = ip; - proc->cbc_arg.cbc_console_arg.next = next; - goto cbc_sleep(&input.r, &input.lock, cbc_consoleread1); + proc->cbc_arg.cbc_console_arg.f = f; + proc->cbc_arg.cbc_console_arg.next = next; + goto cbc_sleep(&input.r, &input.lock, cbc_consoleread2); } release(&input.lock); ilock(ip); - goto next(target - n); + int r = target - n; + + if (r > 0) + f->off += r; + iunlock(f->ip); + + //goto next(target - n); + + goto cbc_ret(r); } -__code cbc_consoleread (struct inode *ip, char *dst, int n, __code(*next)(int ret)) +__code cbc_consoleread (struct inode *ip, char *dst, int n, struct file *f, __code(*next)(int ret)) { uint target; @@ -280,21 +317,23 @@ target = n; acquire(&input.lock); - while (n > 0) { - while (input.r == input.w) { + if (n > 0) { + proc->cbc_arg.cbc_console_arg.n = n; + proc->cbc_arg.cbc_console_arg.target = target; + proc->cbc_arg.cbc_console_arg.dst = dst; + proc->cbc_arg.cbc_console_arg.ip = ip; + proc->cbc_arg.cbc_console_arg.f = f; + proc->cbc_arg.cbc_console_arg.next = next; + if (input.r == input.w) { if (proc->killed) { release(&input.lock); ilock(ip); goto next(-1); } - proc->cbc_arg.cbc_console_arg.n = n; - proc->cbc_arg.cbc_console_arg.target = target; - proc->cbc_arg.cbc_console_arg.dst = dst; - proc->cbc_arg.cbc_console_arg.ip = ip; - proc->cbc_arg.cbc_console_arg.next = next; - goto cbc_sleep(&input.r, &input.lock, cbc_consoleread1); + goto cbc_sleep(&input.r, &input.lock, cbc_consoleread2); } + goto cbc_consoleread1(0); } }
--- a/src/defs.h Fri Jan 18 11:50:48 2019 +0900 +++ b/src/defs.h Fri Jan 18 18:20:02 2019 +0900 @@ -90,7 +90,7 @@ int namecmp(const char*, const char*); struct inode* namei(char*); struct inode* nameiparent(char*, char*); -__code cbc_readi (struct inode*, char*, uint, uint, __code (*)(int)); +__code cbc_readi (struct inode*, char*, uint, uint, struct file*, __code (*)(int)); int readi(struct inode*, char*, uint, uint); void stati(struct inode*, struct stat*); int writei(struct inode*, char*, uint, uint); @@ -165,6 +165,7 @@ int argstr(int, char**); int fetchint(uint, int*); int fetchstr(uint, char**); +__code cbc_ret(int); void syscall(void); // timer.c
--- a/src/file.c Fri Jan 18 11:50:48 2019 +0900 +++ b/src/file.c Fri Jan 18 18:20:02 2019 +0900 @@ -124,7 +124,7 @@ if (f->type == FD_INODE) { ilock(f->ip); - goto cbc_readi(f->ip, addr, f->off, n, next); + goto cbc_readi(f->ip, addr, f->off, n, f, next); } goto cbc_panic("fileread");
--- a/src/file.h Fri Jan 18 11:50:48 2019 +0900 +++ b/src/file.h Fri Jan 18 18:20:02 2019 +0900 @@ -34,7 +34,7 @@ }; struct cbc_devsw { - __code (*read) (struct inode*, char*, int, __code (*)(int)); + __code (*read) (struct inode*, char*, int, struct file*, __code (*)(int)); //__code (*write)(struct inode*, char*, int, __code (*)(int)); };
--- a/src/fs.c Fri Jan 18 11:50:48 2019 +0900 +++ b/src/fs.c Fri Jan 18 18:20:02 2019 +0900 @@ -453,7 +453,7 @@ st->size = ip->size; } -__code cbc_readi (struct inode *ip, char *dst, uint off, uint n, __code (*next)(int ret)) +__code cbc_readi (struct inode *ip, char *dst, uint off, uint n, struct file *f, __code (*next)(int ret)) { uint tot, m; struct buf *bp; @@ -463,7 +463,7 @@ goto next(-1); } - goto cbc_devsw[ip->major].read(ip, dst, n, next); + goto cbc_devsw[ip->major].read(ip, dst, n, f, next); } if (off > ip->size || off + n < off) {
--- a/src/proc.h Fri Jan 18 11:50:48 2019 +0900 +++ b/src/proc.h Fri Jan 18 18:20:02 2019 +0900 @@ -74,6 +74,7 @@ int target; char* dst; struct inode *ip; + struct file *f; __code (*next)(int ret); } cbc_console_arg; } cbc_arg;
--- a/src/syscall.c Fri Jan 18 11:50:48 2019 +0900 +++ b/src/syscall.c Fri Jan 18 18:20:02 2019 +0900 @@ -146,7 +146,7 @@ }; __code cbc_trap_return(){ - goto trap_swi(); + return; } __code cbc_ret(int ret){ @@ -161,9 +161,11 @@ num = proc->tf->r0; + if (num == 5) + num = 22; //cprintf ("syscall(%d) from %s(%d)\n", num, proc->name, proc->pid); - if((num > 0) && (num > NELEM(syscalls)) && cbccodes[num]) { + if((num >= NELEM(syscalls)) && (num <= NELEM(cbccodes)) && cbccodes[num]) { goto (cbccodes[num])(cbc_ret); }