Subject: Re: NFS hangs on Mac port of NetBSD 1.2
To: Scott Reynolds <scottr@plexus.com>
From: Greg Earle <earle@isolar.Tujunga.CA.US>
List: port-mac68k
Date: 10/08/1996 00:51:34
> On Mon, 7 Oct 1996, Greg Earle wrote:
> 
>> But for normal things (rlogin/telnet/ftp/etc.) it seems to work fine, 
though.
>> But NFS is another story altogether.  I use "amd" with some local AMD maps.
> 
> Can you mount things manually without trouble?  Do they continue to work?

The manual mount attempts also fail similarly.

> If not, does the -c (amd's `noconn') option apply to this situation?  

Well, that's a good question.

If I read the man page, I would say "No":

     -c      For UDP mount points, do not do a connect(2).  This must be used
             for servers that do not reply to requests from the standard NFS
             port number 2049.

I can't believe that I'd need this with a Solaris NFS server, which I know
damn well listens on port 2049.  Secondly, I have *no* problem doing NFS
mounts from the SPARCserver to the NetBSD/SPARC machine, without using
"noconn" at all.  Explain that one ...

Yet here's the interesting thing.  Here are two lines from my /etc/amd/home
map.  The first one is unchanged; meaning it pretty much has the default
options I use for the amd maps:

/defaults opts:=rw,nosuid,intr,grpid,noconn,resvport,timeo=20,retrans=8;\
remopts:=${opts},rsize=1024,wsize=1024
[...]
mdm type:=nfs;opts:=rw,nosuid,intr,grpid,resvport,timeo=20,retrans=8;\
rfs:=/export/vrhome/mdm;rhost:=server

gke type:=nfs;opts:=rw,nosuid,intr,grpid,noconn,resvport,timeo=20,retrans=8,\
wsize=8192,rsize=8192;rfs:=/export/home/gke;rhost:=server

Notice that the only difference between these two entries is the changed
default wsize/rsize (back to normal) and the addition of "noconn".

The net result:

ls of "/home/mdm" still fails, producing

  277 ??  D      0:00.14 amd -l syslog -x error,noinfo,nostats -p -a /tmp_mnt /
  276 p1  D      0:00.10 ls /home/mdm 

with, again, "netio" WCHANs.

ls of "/home/gke" *works*, however.  So either the "noconn" or the 8K w/rsize
is making it work.  I'll determine which one it is tomorrow.

However, I should note that once I've tried to look at a mount that drops into
"D" state, "amd" is no longer responsive.  Right now an attempt to look at
"/home/gke" successfully mounts, but it hangs with a "nfsrcv" WCHAN.  I also
get:

macbsd4me# ls -FC /home/gke
nfs server amd:59: not responding

To make things even whackier, I can't even manually mount the SPARCserver now:

macbsd4me# mount -v -r -t nfs -o nosuid,-P,-c coda3:/home/gke /mnt
nfs: can't access /home/gke: Permission denied

Huh?

Yet I can still manually mount/unmount my own NetBSD home directory:

macbsd4me# mount -v -r -t nfs -o nosuid,-P,-c netbsd4me:/export/home/earle /mnt
netbsd4me:/export/home/earle on /mnt type nfs (nosuid, read-only)
macbsd4me# umount -v /mnt
/export/home/earle: unmount from /mnt

> Also, if I'm not mistaken, amd uses v2 mounts exclusively.

Sounds like a bug to me, given that "mount_nfs" uses V3 mounts by default,
according to the man page ...

	- Greg