On Fri, Aug 15, 2003 at 06:44:14PM +1000, Peter Jeremy wrote:
+> >But there are two problems:
+> >1. Device major numbers.
+> 
+> I don't see this as a problem - you do the name to major/minor mapping
+> on the remote system.  All that goes across the network is the device
+> name (filename in /dev).  This is the same way that NFS works.  The
+> device major number is just an easy way for the kernel to map a device
+> name onto the device-specific functions to access the physical
+> hardware - this only needs to occur on the server.

Hmm, I was thinking about something like this:

        # devaccess 192.168.0.2 host1
        # ls -l /dev/host1
        <list of devices that was exported on host1>

And 'devaccess' command will call some kernel mechanism to create new
devices, but all those devices are defined in this way:

        [...]
        .d_open =       std_open,
        .d_close =      std_close,
        .d_ioctl =      std_ioctl,
        .d_maj =        ??
        [...]

And std_open()/std_close()/std_ioctl() are functions that only pass
requests to userland daemon, which forwards them to remote host and back.

+> >2. Handle network errors.
+> 
+> I think the easiest way is just to pass them back to the application.
+> This does mean that an application would get unexpected network-related
+> errors, but there's no obvious alternative.

Or translate all of them to EIO.

-- 
Pawel Jakub Dawidek                       [EMAIL PROTECTED]
UNIX Systems Programmer/Administrator     http://garage.freebsd.pl
Am I Evil? Yes, I Am!                     http://cerber.sourceforge.net

Attachment: pgp00000.pgp
Description: PGP signature

Reply via email to