Implement sys_open() with sys_openat() (XCC)
[akaros.git] / kern / include / ros / fs.h
1 #ifndef _ROS_INC_STAT_H
2 #define _ROS_INC_STAT_H
3
4 #include <sys/types.h>
5 #include <ros/limits.h>
6 #include <ros/time.h>
7
8 /* This will change once we have a decent readdir / getdents syscall, and
9  * send the strlen along with the d_name.  The sizes need rechecked too, since
10  * they are probably wrong. */
11 struct kdirent {
12         __ino64_t                                       d_ino;          /* inode number */
13         __off64_t                                       d_off;          /* offset to the next dirent */
14         unsigned short                          d_reclen;       /* length of this record */
15         unsigned char                           d_type;
16         char                                            d_name[MAX_FILENAME_SZ + 1];    /* filename */
17 } __attribute__((aligned(8)));
18
19 /* These stat sizes should match the types in stat.h and types.h and the sizes
20  * in typesizes in glibc (which we modified slightly).  While glibc has it's own
21  * stat, we have this here so that the kernel is exporting the interface it
22  * expects.  We #def stat for our own internal use at the end. */
23 struct kstat {
24         __dev_t                                         st_dev;         /* Device.  */
25         __ino64_t                                       st_ino;         /* File serial number.  */
26         __mode_t                                        st_mode;        /* File mode.  */
27         __nlink_t                                       st_nlink;       /* Link count.  */
28         __uid_t                                         st_uid;         /* User ID of the file's owner. */
29         __gid_t                                         st_gid;         /* Group ID of the file's group.*/
30         __dev_t                                         st_rdev;        /* Device number, if device.  */
31         __off64_t                                       st_size;        /* Size of file, in bytes.  */
32         __blksize_t                                     st_blksize;     /* Optimal block size for I/O.  */
33         __blkcnt64_t                            st_blocks;      /* Number 512-byte blocks allocd. */
34         struct timespec                         st_atim;        /* Time of last access.  */
35         struct timespec                         st_mtim;        /* Time of last modification.  */
36         struct timespec                         st_ctim;        /* Time of last status change.  */
37 };
38
39 /* File access modes for open and fcntl. */
40 #define O_READ                  0x01            /* Open for reading */
41 #define O_WRITE                 0x02            /* Open for writing */
42 #define O_EXEC                  0x04            /* Open for exec */
43 #define O_RDONLY                O_READ          /* Open read-only */
44 #define O_WRONLY                O_WRITE         /* Open write-only */
45 #define O_RDWR                  (O_READ | O_WRITE)              /* Open read/write */
46 #define O_ACCMODE               0x07
47
48 /* Bits OR'd into the second argument to open */
49 #define O_CREAT                 00000100        /* not fcntl */
50 #define O_CREATE                O_CREAT         /* fucking saving space with the 'E'? */
51 #define O_EXCL                  00000200        /* not fcntl */
52 #define O_NOCTTY                00000400        /* not fcntl */
53 #define O_TRUNC                 00001000        /* not fcntl */
54 #define O_APPEND                00002000
55 #define O_NONBLOCK              00004000
56 #define O_SYNC                  00010000
57 #define O_FSYNC                 O_SYNC
58 #define O_ASYNC                 00020000
59 #define O_DIRECT                00040000        /* Direct disk access. */
60 #define O_PATH                  00100000        /* Path only, no I/O */
61 #define O_DIRECTORY             00200000        /* Must be a directory. */
62 #define O_NOFOLLOW              00400000        /* Do not follow links. */
63 #define O_NOATIME               01000000        /* Do not set atime. */
64 #define O_CLOEXEC               02000000        /* Set close_on_exec. */
65 #define O_REMCLO                04000000        /* Remove on close (unsupported). */
66
67 /* Keep this value in sync with glibc (io/fcntl.h) */
68 #define AT_FDCWD        -100
69
70 #define F_DUPFD         0       /* Duplicate file descriptor */
71 #define F_GETFD         1       /* Get file descriptor flags */
72 #define F_SETFD         2       /* Set file descriptor flags */
73 #define F_GETFL         3       /* Get file status flags */
74 #define F_SETFL         4       /* Set file status flags */
75 #define F_SYNC          101     /* fsync() */
76 #define F_ADVISE        102     /* posix_fadvise{,64}() */
77 /* For F_[GET|SET]FD */
78 #define FD_CLOEXEC      1
79 /* Advise to `posix_fadvise'.  */
80 #define POSIX_FADV_NORMAL               0       /* No further special treatment */
81 #define POSIX_FADV_RANDOM               1       /* Expect random page references */
82 #define POSIX_FADV_SEQUENTIAL   2       /* Expect sequential page references */
83 #define POSIX_FADV_WILLNEED             3       /* Will need these pages */
84 #define POSIX_FADV_DONTNEED             4       /* Don't need these pages */
85 #define POSIX_FADV_NOREUSE              5       /* Data will be accessed once */
86
87 /* TODO: have userpsace use our stuff from bits/stats.h */
88 #ifdef ROS_KERNEL
89 #define stat kstat
90 #define dirent kdirent 
91
92 /* File creation modes (access controls) */
93 #define S_IRWXU 00700   /* user (file owner) has read, write and execute perms */
94 #define S_IRUSR 00400   /* user has read permission */
95 #define S_IWUSR 00200   /* user has write permission */
96 #define S_IXUSR 00100   /* user has execute permission */
97 #define S_IRWXG 00070   /* group has read, write and execute permission */
98 #define S_IRGRP 00040   /* group has read permission */
99 #define S_IWGRP 00020   /* group has write permission */
100 #define S_IXGRP 00010   /* group has execute permission */
101 #define S_IRWXO 00007   /* others have read, write and execute permission */
102 #define S_IROTH 00004   /* others have read permission */
103 #define S_IWOTH 00002   /* others have write permission */
104 #define S_IXOTH 00001   /* others have execute permission */
105 #define S_PMASK 00777   /* mask for all perms */
106
107 /* File type is encoded in the file mode */
108 #define __S_IFMT        0170000 /* These bits determine file type */
109 /* File types */
110 #define __S_IFDIR       0040000 /* Directory */
111 #define __S_IFCHR       0020000 /* Character device */
112 #define __S_IFBLK       0060000 /* Block device */
113 #define __S_IFREG       0100000 /* Regular file */
114 #define __S_IFIFO       0010000 /* FIFO */
115 #define __S_IFLNK       0120000 /* Symbolic link */
116 #define __S_IFSOCK      0140000 /* Socket */
117 /* Protection bits */
118 #define __S_ISUID       04000   /* Set user ID on execution */
119 #define __S_ISGID       02000   /* Set group ID on execution */
120 #define __S_ISVTX       01000   /* Save swapped text after use (sticky) */
121 #define __S_IREAD       0400    /* Read by owner */
122 #define __S_IWRITE      0200    /* Write by owner */
123 #define __S_IEXEC       0100    /* Execute by owner */
124 /* Test macros for file types.  */
125 #define __S_ISTYPE(mode, mask)  (((mode) & __S_IFMT) == (mask))
126 #define S_ISDIR(mode)   __S_ISTYPE((mode), __S_IFDIR)
127 #define S_ISCHR(mode)   __S_ISTYPE((mode), __S_IFCHR)
128 #define S_ISBLK(mode)   __S_ISTYPE((mode), __S_IFBLK)
129 #define S_ISREG(mode)   __S_ISTYPE((mode), __S_IFREG)
130 #define S_ISFIFO(mode)  __S_ISTYPE((mode), __S_IFIFO)
131 #define S_ISLNK(mode)   __S_ISTYPE((mode), __S_IFLNK)
132
133 #endif /* ROS_KERNEL */
134
135 #endif /* _ROS_INC_STAT_H */