1 diff -u -N -r linux.orig/fs/nfs/inode.c linux.nfs/fs/nfs/inode.c
2 --- linux.orig/fs/nfs/inode.c Tue Feb 13 19:14:28 2001
3 +++ linux.nfs/fs/nfs/inode.c Fri Mar 9 10:58:47 2001
8 +/* This kludge (of Lance's) converts 16bit DUNIX device numbers
9 + * into 8-bit Linux ones.
12 +do_that_magic(u32 rdev)
14 + if (((rdev & 0xffff0000) != 0) &&
15 + ((rdev & 0x0ff000ff) == rdev)) {
17 + tmp = ((rdev & 0x0ff00000) >> 12) | (rdev & 0xff) ;
18 + //printk("doing that magic!! %08x -> %08x\n", rdev, tmp) ;
25 * Fill in inode information from the fattr.
28 } else if (S_ISLNK(inode->i_mode))
29 inode->i_op = &nfs_symlink_inode_operations;
31 - init_special_inode(inode, inode->i_mode, fattr->rdev);
32 + init_special_inode(inode, inode->i_mode, do_that_magic(fattr->rdev));
33 memcpy(&inode->u.nfs_i.fh, fh, sizeof(inode->u.nfs_i.fh));
35 nfs_refresh_inode(inode, fattr);
39 if (S_ISCHR(inode->i_mode) || S_ISBLK(inode->i_mode))
40 - inode->i_rdev = to_kdev_t(fattr->rdev);
41 + inode->i_rdev = to_kdev_t(do_that_magic(fattr->rdev));
43 /* Update attrtimeo value */
44 if (!invalid && time_after(jiffies, NFS_ATTRTIMEO_UPDATE(inode)+NFS_ATTRTIMEO(inode))) {
45 diff -u -N -r linux.orig/fs/nfs/mount_clnt.c linux.nfs/fs/nfs/mount_clnt.c
46 --- linux.orig/fs/nfs/mount_clnt.c Thu Apr 13 10:54:19 2000
47 +++ linux.nfs/fs/nfs/mount_clnt.c Fri Mar 9 10:58:47 2001
50 clnt = rpc_create_client(xprt, hostname,
51 &mnt_program, version,
57 diff -u -N -r linux.orig/fs/nfs/proc.c linux.nfs/fs/nfs/proc.c
58 --- linux.orig/fs/nfs/proc.c Fri Feb 9 14:29:44 2001
59 +++ linux.nfs/fs/nfs/proc.c Mon Apr 30 16:54:48 2001
64 +/* convert Linux major/minor number into Tru64 major/minor */
65 +#define linux2tru64(rdev) \
66 + (MAJOR((rdev))<<20 | MINOR((rdev)))
69 * In NFSv2, mknod is grafted onto the create call.
72 sattr->ia_valid &= ~ATTR_SIZE;
73 } else if (S_ISCHR(mode) || S_ISBLK(mode)) {
74 sattr->ia_valid |= ATTR_SIZE;
75 - sattr->ia_size = rdev; /* get out your barf bag */
76 + sattr->ia_size = linux2tru64(rdev); /* get out your barf bag */