summaryrefslogtreecommitdiff
path: root/man/open.2
blob: 3cc18b33b7d0d712be2a4554be270e9090b9953e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
.Dd June 15, 2024
.Dt OPEN 2
.Os Camellia
.Sh NAME
.Nm open
.Nd open a file
.Sh SYNOPSIS
.In camellia/flags.h
.In camellia/syscalls.h
.In camellia/types.h
.Ft long
.Fo _sys_open
.Fa "const char *path"
.Fa "long len"
.Fa "int flags"
.Fc
.Sh DESCRIPTION
.Nm
tries to open the file located at
.Fa path ,
which is a string of length
.Fa len ,
potentially returning a new handle.
The call will be handled by the most recent mount that contains the given path,
according to the definition in
.Xr path 7 .
The path must be absolute.
.Pp
.Fa flags
is a bitmask that must include
.Sy exactly one
of
.Dv OPEN_READ ,
.Dv OPEN_WRITE ,
.Dv OPEN_RW ,
or
.Dv OPEN_EXEC .
Files opened with
.Dv OPEN_READ
and
.Dv OPEN_EXEC
are read-only, and files opened with
.Dv OPEN_WRITE
are write-only.
.Dv OPEN_EXEC
only succeeds if the executable bit is set on a file.
.Pp
.Dv OPEN_READ
is also meant to prevent
.Dq major side-effects ,
the exact meaning of which depend on the context.
For example,
since
.Xr net 7
allows connecting to any host just by opening a file,
trying to open them as read-only returns
.Er EACCES .
This allows tools such as
.Xr whitelist 1
to reliably make an entire filesystem read-only just by
controlling the values of
.Fa flags
passed to the underlying filesystems.
.Pp
.Fa flags
also accepts the following additional flags:
.Bl -tag -width OPEN_CREATE
.It Dv OPEN_CREATE
Try to create a new file if one isn't present at the given path.
Requires
.Dv OPEN_WRITE
or
.Dv OPEN_RW .
.El
.Sh RETURN VALUES
If successful,
.Nm
returns a non-negative handle to the opened file.
Otherwise, it returns a negated error value \(em
the possible errors will depend on the filesystem.
.Sh SEE ALSO
.Xr fs_wait 2 ,
.Xr mount 2 ,
.Xr path 7
.Sh BUGS
No current filesystem checks the execute bit.
.Pp
The
.Dq no side-effects
aspect of
.Dv OPEN_READ
means that you can't
.Dl cat /net/connect/0.0.0.0/192.0.2.1/tcp/17
as
.Xr cat 1
will try to open the file as read-only and fail.
I'm not yet sure if that's a feature or a bug.
.Pp
The permission flags should probably just be renamed to the POSIX ones.
.Sh RATIONALE
.Nm
is the
.Dq narrow waist
through which all the interactions with paths are done.
For example,
.Xr remove 2
only accepts a handle returned by
.Nm ,
instead of the full path \(em
the same will even apply for the future move call.
This means that all the path handling logic is concentrated in a single place.
In particular, simple filesystem overlays such as
.Xr whitelist 2
only need to implement support for
.Nm ,
instead of needing separate logic for all calls that operate on paths.