manpagez: man pages & more
man mknod(2)
Home | html | info | man
mknod(2)                    BSD System Calls Manual                   mknod(2)


NAME

     mknod -- make a special file node


SYNOPSIS

     #include <sys/stat.h>

     int
     mknod(const char *path, mode_t mode, dev_t dev);


DESCRIPTION

     The device special file path is created with the major and minor device
     numbers extracted from mode.  The access permissions of path are con-
     strained by the umask(2) of the parent process.

     If mode indicates a block or character special file, dev is a configura-
     tion-dependent specification of a character or block I/O device and the
     superblock of the device.  If mode does not indicate a block special or
     character special device, dev is ignored.

     Mknod() requires super-user privileges.


RETURN VALUES

     Upon successful completion, a value of 0 is returned.  Otherwise, a value
     of -1 is returned and errno is set to indicate the error.


ERRORS

     Mknod() will fail and the file will be not created if:

     [EACCES]           Search permission is denied for a component of the
                        path prefix.

     [EACCES]           Write permission is denied for the parent directory.

     [EDQUOT]           The directory in which the entry for the new node is
                        being placed cannot be extended; the user's quota of
                        disk blocks on the file system containing the direc-
                        tory has been exhausted.

     [EDQUOT]           The user's quota of inodes for the file system on
                        which the node is being created has been exhausted.

     [EEXIST]           The named file exists.

     [EFAULT]           Path points outside the process's allocated address
                        space.

     [EINVAL]           One or more of the arguments is invalid.

     [EIO]              An I/O error occurs while making the directory entry
                        or allocating the inode.

     [ELOOP]            Too many symbolic links were encountered in translat-
                        ing the pathname.  This is taken to be indicative of a
                        looping symbolic link.

     [ENAMETOOLONG]     A component of a pathname exceeds {NAME_MAX} charac-
                        ters or an entire path name exceeds {PATH_MAX} charac-
                        ters.

     [ENOENT]           A component of the path prefix does not exist or path
                        is an empty string.

     [ENOSPC]           The directory in which the entry for the new node is
                        being placed cannot be extended, because there is no
                        space left on the file system containing the direc-
                        tory.

     [ENOSPC]           There are no free inodes on the file system on which
                        the node is being created.

     [ENOTDIR]          A component of the path prefix is not a directory.

     [EPERM]            The process's effective user ID is not super-user.

     [EROFS]            The created node would reside on a read-only file sys-
                        tem.


LEGACY SYNOPSIS

     #include <unistd.h>

     The include file has changed.


SEE ALSO

     chmod(2), stat(2), umask(2), compat(5)


HISTORY

     A mknod() function call appeared in Version 6 AT&T UNIX.

4th Berkeley Distribution        June 4, 1993        4th Berkeley Distribution

Mac OS X 10.9.1 - Generated Mon Jan 6 08:54:53 CST 2014
© manpagez.com 2000-2024
Individual documents may contain additional copyright information.