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