Chris <[EMAIL PROTECTED]> writes:
> I have discovered a rather interesting bug with this combination,
> and was wondering if anyone could point me in the right direction
> to help me track it down.
>
> The problem is that linux binaries which call getdirents on an afs
> directory do not report the last directory entry:
>
> /afs/whatever% /bin/ls -f
> 1 2 3 4
> /afs/whatever% /compat/linux/bin/ls
> 1 2 3
The patch below for arla fixes the problem.
> I believe that this might also be what is causing linux-netscape
> to wedge the machine (with home directories on afs), although I'm
> not positive.
>
> Any ideas where to start the search for the offending code?
The problem is that linux_getdents uses a little too small buffer, arla
uses (before the patch) a directory-blocksize of 1024 bytes. This make
every entry that have its end past a 512 bytes offset disapper when running
under linux-emulation.
Love
Index: bsd-subr.c
===================================================================
RCS file: /afs/stacken.kth.se/src/SourceRepository/arla/arlad/bsd-subr.c,v
retrieving revision 1.55
retrieving revision 1.55.2.1
diff -u -w -u -w -r1.55 -r1.55.2.1
--- arlad/bsd-subr.c 2000/10/14 19:58:04 1.55
+++ arlad/bsd-subr.c 2001/01/29 02:02:17 1.55.2.1
@@ -44,7 +44,7 @@
#ifdef __linux__
#include <xfs/xfs_dirent.h>
#else
-#define XFS_DIRENT_BLOCKSIZE 1024
+#define XFS_DIRENT_BLOCKSIZE 512
#define xfs_dirent dirent
#endif
To Unsubscribe: send mail to [EMAIL PROTECTED]
with "unsubscribe freebsd-hackers" in the body of the message