* fhandler.cc (fhandler_base::fstat): Move dev and ino calculation into caller.

* syscalls.cc (stat_worker): Calculate dev and ino calculation here, if zero.
* fhandler_proc.cc (fhandler_proc::fhandler_proc): Minor reorg for debugging.
* fhandler_process.cc (fhandler_process::exists): Return 0 on nonexistence.
(fhandler_process::fstat): Simplify pid logic.
* fhandler_tape.cc (fhandler_dev_tape::fstat): Minor reformatting.
This commit is contained in:
Christopher Faylor 2002-06-02 03:13:22 +00:00
parent 415f62a72c
commit e065a187ab
6 changed files with 37 additions and 28 deletions

View File

@ -1,3 +1,16 @@
2002-06-01 Christopher Faylor <cgf@redhat.com>
* fhandler.cc (fhandler_base::fstat): Move dev and ino calculation into
caller.
* syscalls.cc (stat_worker): Calculate dev and ino calculation here, if
zero.
* fhandler_proc.cc (fhandler_proc::fhandler_proc): Minor reorg for
debugging.
* fhandler_process.cc (fhandler_process::exists): Return 0 on
nonexistence.
(fhandler_process::fstat): Simplify pid logic.
* fhandler_tape.cc (fhandler_dev_tape::fstat): Minor reformatting.
2002-06-01 Christopher Faylor <cgf@redhat.com> 2002-06-01 Christopher Faylor <cgf@redhat.com>
* path.cc (chdir): Don't allow cd'ing to a non-directory virtual path. * path.cc (chdir): Don't allow cd'ing to a non-directory virtual path.

View File

@ -839,8 +839,6 @@ fhandler_base::fstat (struct __stat64 *buf, path_conv *)
buf->st_mode |= get_device () == FH_FLOPPY ? S_IFBLK : S_IFCHR; buf->st_mode |= get_device () == FH_FLOPPY ? S_IFBLK : S_IFCHR;
buf->st_nlink = 1; buf->st_nlink = 1;
buf->st_blksize = S_BLKSIZE; buf->st_blksize = S_BLKSIZE;
buf->st_dev = buf->st_rdev = FHDEVN (get_device ()) << 8 | (get_unit () & 0xff);
buf->st_ino = get_namehash ();
buf->st_atime = buf->st_mtime = buf->st_ctime = time (NULL) - 1; buf->st_atime = buf->st_mtime = buf->st_ctime = time (NULL) - 1;
return 0; return 0;
} }

View File

@ -161,8 +161,9 @@ fhandler_proc::fhandler_proc (DWORD devtype):
int int
fhandler_proc::fstat (struct __stat64 *buf, path_conv *pc) fhandler_proc::fstat (struct __stat64 *buf, path_conv *pc)
{ {
debug_printf ("fstat (%s)", get_name ());
const char *path = get_name (); const char *path = get_name ();
debug_printf ("fstat (%s)", path);
path += proc_len; path += proc_len;
(void) fhandler_base::fstat (buf, pc); (void) fhandler_base::fstat (buf, pc);

View File

@ -87,7 +87,7 @@ fhandler_process::exists ()
for (int i = 0; process_listing[i]; i++) for (int i = 0; process_listing[i]; i++)
if (pathmatch (path + 1, process_listing[i])) if (pathmatch (path + 1, process_listing[i]))
return -1; return -1;
return 1; return 0;
} }
fhandler_process::fhandler_process (): fhandler_process::fhandler_process ():
@ -104,20 +104,13 @@ fhandler_process::fstat (struct __stat64 *buf, path_conv *pc)
path += proc_len + 1; path += proc_len + 1;
int pid = atoi (path); int pid = atoi (path);
winpids pids; winpids pids;
_pinfo *p; pinfo p (pid);
for (unsigned i = 0; i < pids.npids; i++) if (!p)
{ {
p = pids[i];
if (!proc_exists (p))
continue;
if (p->pid == pid)
goto found;
}
set_errno(ENOENT); set_errno(ENOENT);
return -1; return -1;
found: }
buf->st_mode &= ~_IFMT & NO_W; buf->st_mode &= ~_IFMT & NO_W;
switch (file_type) switch (file_type)

View File

@ -155,11 +155,9 @@ fhandler_dev_tape::fstat (struct __stat64 *buf, path_conv *pc)
{ {
struct mtget get; struct mtget get;
if (! ioctl (MTIOCGET, &get)) if (!ioctl (MTIOCGET, &get))
{
buf->st_blocks = get.mt_capacity / buf->st_blksize; buf->st_blocks = get.mt_capacity / buf->st_blksize;
} }
}
return ret; return ret;
} }

View File

@ -1073,18 +1073,17 @@ stat_worker (const char *name, struct __stat64 *buf, int nofollow,
path_conv real_path; path_conv real_path;
fhandler_base *fh = NULL; fhandler_base *fh = NULL;
if (!pc)
pc = &real_path;
MALLOC_CHECK;
if (check_null_invalid_struct_errno (buf)) if (check_null_invalid_struct_errno (buf))
goto done; goto done;
if (!pc)
pc = &real_path;
fh = cygheap->fdtab.build_fhandler_from_name (-1, name, NULL, *pc, fh = cygheap->fdtab.build_fhandler_from_name (-1, name, NULL, *pc,
(nofollow ? (nofollow ? PC_SYM_NOFOLLOW
PC_SYM_NOFOLLOW
: PC_SYM_FOLLOW) : PC_SYM_FOLLOW)
| PC_FULL, stat_suffixes); | PC_FULL, stat_suffixes);
if (pc->error) if (pc->error)
{ {
debug_printf ("got %d error from build_fhandler_from_name", pc->error); debug_printf ("got %d error from build_fhandler_from_name", pc->error);
@ -1094,8 +1093,15 @@ stat_worker (const char *name, struct __stat64 *buf, int nofollow,
{ {
debug_printf ("(%s, %p, %d, %p), file_attributes %d", name, buf, nofollow, debug_printf ("(%s, %p, %d, %p), file_attributes %d", name, buf, nofollow,
pc, (DWORD) real_path); pc, (DWORD) real_path);
memset (buf, 0, sizeof (struct __stat64)); memset (buf, 0, sizeof (*buf));
res = fh->fstat (buf, pc); res = fh->fstat (buf, pc);
if (!res)
{
if (!buf->st_ino)
buf->st_ino = hash_path_name (0, fh->get_win32_name ());
if (!buf->st_dev)
buf->st_dev = FHDEVN (fh->get_device ()) << 8 | (fh->get_unit () & 0xff);
}
} }
done: done: