Blame


1 fb1a36c0 2022-01-09 op /*
2 fb1a36c0 2022-01-09 op * Copyright (c) 2021 Omar Polo <op@omarpolo.com>
3 fb1a36c0 2022-01-09 op *
4 fb1a36c0 2022-01-09 op * Permission to use, copy, modify, and distribute this software for any
5 fb1a36c0 2022-01-09 op * purpose with or without fee is hereby granted, provided that the above
6 fb1a36c0 2022-01-09 op * copyright notice and this permission notice appear in all copies.
7 fb1a36c0 2022-01-09 op *
8 fb1a36c0 2022-01-09 op * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
9 fb1a36c0 2022-01-09 op * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
10 fb1a36c0 2022-01-09 op * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
11 fb1a36c0 2022-01-09 op * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
12 fb1a36c0 2022-01-09 op * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
13 fb1a36c0 2022-01-09 op * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
14 fb1a36c0 2022-01-09 op * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
15 fb1a36c0 2022-01-09 op */
16 fb1a36c0 2022-01-09 op
17 bbcba3ed 2022-01-10 op #include "compat.h"
18 bbcba3ed 2022-01-10 op
19 fb1a36c0 2022-01-09 op #include <inttypes.h>
20 fb1a36c0 2022-01-09 op #include <string.h>
21 fb1a36c0 2022-01-09 op
22 fb1a36c0 2022-01-09 op #include "kami.h"
23 fb1a36c0 2022-01-09 op #include "log.h"
24 fb1a36c0 2022-01-09 op #include "utils.h"
25 fb1a36c0 2022-01-09 op
26 4e93fcbd 2022-01-17 op #include "9pclib.h"
27 4e93fcbd 2022-01-17 op
28 fb1a36c0 2022-01-09 op uint16_t iota_tag;
29 fb1a36c0 2022-01-09 op
30 fb1a36c0 2022-01-09 op struct evbuffer *evb;
31 fb1a36c0 2022-01-09 op
32 fb1a36c0 2022-01-09 op void
33 fb1a36c0 2022-01-09 op write_hdr(uint32_t len, uint8_t type, uint16_t tag)
34 fb1a36c0 2022-01-09 op {
35 fb1a36c0 2022-01-09 op len += HEADERSIZE;
36 fb1a36c0 2022-01-09 op
37 fb1a36c0 2022-01-09 op log_debug("enqueuing a packet; len=%"PRIu32" type=%d[%s] tag=%d",
38 fb1a36c0 2022-01-09 op len, type, pp_msg_type(type), tag);
39 fb1a36c0 2022-01-09 op
40 fb1a36c0 2022-01-09 op len = htole32(len);
41 fb1a36c0 2022-01-09 op /* type is one byte, no endiannes issues */
42 fb1a36c0 2022-01-09 op tag = htole16(tag);
43 fb1a36c0 2022-01-09 op
44 fb1a36c0 2022-01-09 op evbuffer_add(evb, &len, sizeof(len));
45 fb1a36c0 2022-01-09 op evbuffer_add(evb, &type, sizeof(type));
46 fb1a36c0 2022-01-09 op evbuffer_add(evb, &tag, sizeof(tag));
47 fb1a36c0 2022-01-09 op }
48 fb1a36c0 2022-01-09 op
49 fb1a36c0 2022-01-09 op void
50 fb1a36c0 2022-01-09 op write_hdr_auto(uint32_t len, uint8_t type)
51 fb1a36c0 2022-01-09 op {
52 fb1a36c0 2022-01-09 op if (++iota_tag == NOTAG)
53 fb1a36c0 2022-01-09 op ++iota_tag;
54 fb1a36c0 2022-01-09 op write_hdr(len, type, iota_tag);
55 fb1a36c0 2022-01-09 op }
56 fb1a36c0 2022-01-09 op
57 fb1a36c0 2022-01-09 op void
58 fb1a36c0 2022-01-09 op write_str(uint16_t len, const char *str)
59 fb1a36c0 2022-01-09 op {
60 fb1a36c0 2022-01-09 op uint16_t l = len;
61 fb1a36c0 2022-01-09 op
62 fb1a36c0 2022-01-09 op len = htole16(len);
63 fb1a36c0 2022-01-09 op evbuffer_add(evb, &len, sizeof(len));
64 fb1a36c0 2022-01-09 op evbuffer_add(evb, str, l);
65 fb1a36c0 2022-01-09 op }
66 fb1a36c0 2022-01-09 op
67 fb1a36c0 2022-01-09 op void
68 fb1a36c0 2022-01-09 op write_str_auto(const char *str)
69 fb1a36c0 2022-01-09 op {
70 4e93fcbd 2022-01-17 op if (str == NULL)
71 4e93fcbd 2022-01-17 op write_16(0);
72 4e93fcbd 2022-01-17 op else
73 4e93fcbd 2022-01-17 op write_str(strlen(str), str);
74 fb1a36c0 2022-01-09 op }
75 fb1a36c0 2022-01-09 op
76 fb1a36c0 2022-01-09 op void
77 fb1a36c0 2022-01-09 op write_buf(const void *d, uint32_t len)
78 fb1a36c0 2022-01-09 op {
79 fb1a36c0 2022-01-09 op write_32(len);
80 fb1a36c0 2022-01-09 op evbuffer_add(evb, d, len);
81 fb1a36c0 2022-01-09 op }
82 fb1a36c0 2022-01-09 op
83 fb1a36c0 2022-01-09 op void
84 fb1a36c0 2022-01-09 op write_64(uint64_t x)
85 fb1a36c0 2022-01-09 op {
86 fb1a36c0 2022-01-09 op x = htole64(x);
87 fb1a36c0 2022-01-09 op evbuffer_add(evb, &x, sizeof(x));
88 fb1a36c0 2022-01-09 op }
89 fb1a36c0 2022-01-09 op
90 fb1a36c0 2022-01-09 op void
91 fb1a36c0 2022-01-09 op write_32(uint32_t fid)
92 fb1a36c0 2022-01-09 op {
93 fb1a36c0 2022-01-09 op fid = htole32(fid);
94 fb1a36c0 2022-01-09 op evbuffer_add(evb, &fid, sizeof(fid));
95 fb1a36c0 2022-01-09 op }
96 fb1a36c0 2022-01-09 op
97 fb1a36c0 2022-01-09 op void
98 fb1a36c0 2022-01-09 op write_16(uint16_t tag)
99 fb1a36c0 2022-01-09 op {
100 fb1a36c0 2022-01-09 op tag = htole16(tag);
101 fb1a36c0 2022-01-09 op evbuffer_add(evb, &tag, sizeof(tag));
102 fb1a36c0 2022-01-09 op }
103 fb1a36c0 2022-01-09 op
104 fb1a36c0 2022-01-09 op void
105 fb1a36c0 2022-01-09 op write_8(uint8_t x)
106 fb1a36c0 2022-01-09 op {
107 fb1a36c0 2022-01-09 op evbuffer_add(evb, &x, sizeof(x));
108 fb1a36c0 2022-01-09 op }
109 fb1a36c0 2022-01-09 op
110 fb1a36c0 2022-01-09 op
111 fb1a36c0 2022-01-09 op
112 fb1a36c0 2022-01-09 op void
113 fb1a36c0 2022-01-09 op tversion(const char *v, uint32_t msize)
114 fb1a36c0 2022-01-09 op {
115 fb1a36c0 2022-01-09 op uint32_t len;
116 fb1a36c0 2022-01-09 op uint16_t sl;
117 fb1a36c0 2022-01-09 op
118 fb1a36c0 2022-01-09 op sl = strlen(v);
119 fb1a36c0 2022-01-09 op
120 fb1a36c0 2022-01-09 op /* msize[4] version[s] */
121 fb1a36c0 2022-01-09 op len = sizeof(msize) + sizeof(sl) + sl;
122 fb1a36c0 2022-01-09 op write_hdr(len, Tversion, NOTAG);
123 fb1a36c0 2022-01-09 op write_32(msize);
124 fb1a36c0 2022-01-09 op write_str(sl, v);
125 fb1a36c0 2022-01-09 op }
126 fb1a36c0 2022-01-09 op
127 fb1a36c0 2022-01-09 op void
128 fb1a36c0 2022-01-09 op tattach(uint32_t fid, uint32_t afid, const char *uname, const char *aname)
129 fb1a36c0 2022-01-09 op {
130 fb1a36c0 2022-01-09 op uint32_t len;
131 fb1a36c0 2022-01-09 op uint16_t ul, al;
132 fb1a36c0 2022-01-09 op
133 fb1a36c0 2022-01-09 op ul = strlen(uname);
134 fb1a36c0 2022-01-09 op al = strlen(aname);
135 fb1a36c0 2022-01-09 op
136 fb1a36c0 2022-01-09 op /* fid[4] afid[4] uname[s] aname[s] */
137 fb1a36c0 2022-01-09 op len = sizeof(fid) + sizeof(afid) + sizeof(ul) + ul
138 fb1a36c0 2022-01-09 op + sizeof(al) + al;
139 fb1a36c0 2022-01-09 op write_hdr_auto(len, Tattach);
140 fb1a36c0 2022-01-09 op write_fid(fid);
141 fb1a36c0 2022-01-09 op write_fid(afid);
142 fb1a36c0 2022-01-09 op write_str(ul, uname);
143 fb1a36c0 2022-01-09 op write_str(al, aname);
144 fb1a36c0 2022-01-09 op }
145 fb1a36c0 2022-01-09 op
146 fb1a36c0 2022-01-09 op void
147 fb1a36c0 2022-01-09 op tclunk(uint32_t fid)
148 fb1a36c0 2022-01-09 op {
149 fb1a36c0 2022-01-09 op uint32_t len;
150 fb1a36c0 2022-01-09 op
151 fb1a36c0 2022-01-09 op /* fid[4] */
152 fb1a36c0 2022-01-09 op len = sizeof(fid);
153 fb1a36c0 2022-01-09 op write_hdr_auto(len, Tclunk);
154 fb1a36c0 2022-01-09 op write_fid(fid);
155 fb1a36c0 2022-01-09 op }
156 fb1a36c0 2022-01-09 op
157 fb1a36c0 2022-01-09 op void
158 fb1a36c0 2022-01-09 op tflush(uint16_t oldtag)
159 fb1a36c0 2022-01-09 op {
160 fb1a36c0 2022-01-09 op uint32_t len;
161 fb1a36c0 2022-01-09 op
162 fb1a36c0 2022-01-09 op /* oldtag[2] */
163 fb1a36c0 2022-01-09 op len = sizeof(oldtag);
164 fb1a36c0 2022-01-09 op write_hdr_auto(len, Tflush);
165 fb1a36c0 2022-01-09 op write_tag(oldtag);
166 fb1a36c0 2022-01-09 op }
167 fb1a36c0 2022-01-09 op
168 fb1a36c0 2022-01-09 op void
169 fb1a36c0 2022-01-09 op twalk(uint32_t fid, uint32_t newfid, const char **wnames, size_t nwname)
170 fb1a36c0 2022-01-09 op {
171 fb1a36c0 2022-01-09 op size_t i;
172 fb1a36c0 2022-01-09 op uint32_t len;
173 fb1a36c0 2022-01-09 op
174 fb1a36c0 2022-01-09 op /* fid[4] newfid[4] nwname[2] nwname*(wname[s]) */
175 fb1a36c0 2022-01-09 op len = sizeof(fid) + sizeof(newfid) + 2;
176 fb1a36c0 2022-01-09 op for (i = 0; i < nwname; ++i)
177 fb1a36c0 2022-01-09 op len += 2 + strlen(wnames[i]);
178 fb1a36c0 2022-01-09 op
179 fb1a36c0 2022-01-09 op write_hdr_auto(len, Twalk);
180 fb1a36c0 2022-01-09 op write_fid(fid);
181 fb1a36c0 2022-01-09 op write_fid(newfid);
182 fb1a36c0 2022-01-09 op write_16(nwname);
183 fb1a36c0 2022-01-09 op for (i = 0; i < nwname; ++i)
184 fb1a36c0 2022-01-09 op write_str_auto(wnames[i]);
185 fb1a36c0 2022-01-09 op }
186 fb1a36c0 2022-01-09 op
187 fb1a36c0 2022-01-09 op void
188 fb1a36c0 2022-01-09 op topen(uint32_t fid, uint8_t mode)
189 fb1a36c0 2022-01-09 op {
190 fb1a36c0 2022-01-09 op uint32_t len;
191 fb1a36c0 2022-01-09 op
192 fb1a36c0 2022-01-09 op /* fid[4] mode[1] */
193 fb1a36c0 2022-01-09 op len = sizeof(fid) + sizeof(mode);
194 fb1a36c0 2022-01-09 op write_hdr_auto(len, Topen);
195 fb1a36c0 2022-01-09 op write_fid(fid);
196 fb1a36c0 2022-01-09 op write_8(mode);
197 fb1a36c0 2022-01-09 op }
198 fb1a36c0 2022-01-09 op
199 fb1a36c0 2022-01-09 op void
200 fb1a36c0 2022-01-09 op tcreate(uint32_t fid, const char *name, uint32_t perm, uint8_t mode)
201 fb1a36c0 2022-01-09 op {
202 fb1a36c0 2022-01-09 op uint32_t len;
203 fb1a36c0 2022-01-09 op uint16_t nl;
204 fb1a36c0 2022-01-09 op
205 fb1a36c0 2022-01-09 op /* fid[4] name[s] perm[4] mode[1] */
206 fb1a36c0 2022-01-09 op nl = strlen(name);
207 fb1a36c0 2022-01-09 op len = sizeof(fid) + sizeof(nl) + nl + sizeof(perm) + sizeof(mode);
208 fb1a36c0 2022-01-09 op write_hdr_auto(len, Tcreate);
209 fb1a36c0 2022-01-09 op write_fid(fid);
210 fb1a36c0 2022-01-09 op write_str(nl, name);
211 fb1a36c0 2022-01-09 op write_32(perm);
212 fb1a36c0 2022-01-09 op write_8(mode);
213 fb1a36c0 2022-01-09 op }
214 fb1a36c0 2022-01-09 op
215 fb1a36c0 2022-01-09 op void
216 fb1a36c0 2022-01-09 op tread(uint32_t fid, uint64_t off, uint32_t count)
217 fb1a36c0 2022-01-09 op {
218 fb1a36c0 2022-01-09 op uint32_t len;
219 fb1a36c0 2022-01-09 op
220 fb1a36c0 2022-01-09 op /* fid[4] off[8] count[4] */
221 fb1a36c0 2022-01-09 op len = sizeof(fid) + sizeof(off) + sizeof(count);
222 fb1a36c0 2022-01-09 op write_hdr_auto(len, Tread);
223 fb1a36c0 2022-01-09 op write_fid(fid);
224 fb1a36c0 2022-01-09 op write_off(off);
225 fb1a36c0 2022-01-09 op write_32(count);
226 fb1a36c0 2022-01-09 op }
227 fb1a36c0 2022-01-09 op
228 fb1a36c0 2022-01-09 op void
229 fb1a36c0 2022-01-09 op twrite(uint32_t fid, uint64_t off, const void *data, uint32_t count)
230 fb1a36c0 2022-01-09 op {
231 fb1a36c0 2022-01-09 op uint32_t len;
232 fb1a36c0 2022-01-09 op
233 fb1a36c0 2022-01-09 op /* fid[4] off[8] count[4] data[count] */
234 fb1a36c0 2022-01-09 op len = sizeof(fid) + sizeof(off) + sizeof(count) + count;
235 fb1a36c0 2022-01-09 op write_hdr_auto(len, Twrite);
236 fb1a36c0 2022-01-09 op write_fid(fid);
237 fb1a36c0 2022-01-09 op write_off(off);
238 fb1a36c0 2022-01-09 op write_buf(data, count);
239 fb1a36c0 2022-01-09 op }
240 fb1a36c0 2022-01-09 op
241 fb1a36c0 2022-01-09 op void
242 fb1a36c0 2022-01-09 op tstat(uint32_t fid)
243 fb1a36c0 2022-01-09 op {
244 fb1a36c0 2022-01-09 op /* fid[4] */
245 fb1a36c0 2022-01-09 op write_hdr_auto(sizeof(fid), Tstat);
246 4e93fcbd 2022-01-17 op write_fid(fid);
247 4e93fcbd 2022-01-17 op }
248 4e93fcbd 2022-01-17 op
249 4e93fcbd 2022-01-17 op void
250 4e93fcbd 2022-01-17 op twstat(uint32_t fid, const struct np_stat *st)
251 4e93fcbd 2022-01-17 op {
252 4e93fcbd 2022-01-17 op uint32_t len;
253 9f898869 2022-02-02 op uint16_t stlen, n;
254 4e93fcbd 2022-01-17 op
255 4e93fcbd 2022-01-17 op /* fid[4] stat[n] */
256 f55ab68b 2022-01-19 op
257 f55ab68b 2022-01-19 op stlen = NPSTATSIZ(0, 0, 0, 0);
258 4e93fcbd 2022-01-17 op if (st->name != NULL)
259 f55ab68b 2022-01-19 op stlen += strlen(st->name);
260 4e93fcbd 2022-01-17 op if (st->uid != NULL)
261 f55ab68b 2022-01-19 op stlen += strlen(st->uid);
262 f55ab68b 2022-01-19 op if (st->gid != NULL)
263 f55ab68b 2022-01-19 op stlen += strlen(st->gid);
264 4e93fcbd 2022-01-17 op if (st->muid != NULL)
265 f55ab68b 2022-01-19 op stlen += strlen(st->muid);
266 4e93fcbd 2022-01-17 op
267 9f898869 2022-02-02 op n = sizeof(stlen) + stlen;
268 9f898869 2022-02-02 op len = sizeof(fid) + sizeof(n) + n;
269 f55ab68b 2022-01-19 op
270 4e93fcbd 2022-01-17 op write_hdr_auto(len, Twstat);
271 fb1a36c0 2022-01-09 op write_fid(fid);
272 9f898869 2022-02-02 op write_16(n);
273 f55ab68b 2022-01-19 op write_16(stlen);
274 4e93fcbd 2022-01-17 op write_16(st->type);
275 4e93fcbd 2022-01-17 op write_32(st->dev);
276 4e93fcbd 2022-01-17 op
277 4e93fcbd 2022-01-17 op write_8(st->qid.type);
278 344d2bad 2022-01-22 op write_32(st->qid.vers);
279 344d2bad 2022-01-22 op write_64(st->qid.path);
280 4e93fcbd 2022-01-17 op
281 4e93fcbd 2022-01-17 op write_32(st->mode);
282 4e93fcbd 2022-01-17 op write_32(st->atime);
283 4e93fcbd 2022-01-17 op write_32(st->mtime);
284 4e93fcbd 2022-01-17 op write_64(st->length);
285 4e93fcbd 2022-01-17 op
286 4e93fcbd 2022-01-17 op write_str_auto(st->name);
287 4e93fcbd 2022-01-17 op write_str_auto(st->uid);
288 4e93fcbd 2022-01-17 op write_str_auto(st->gid);
289 4e93fcbd 2022-01-17 op write_str_auto(st->muid);
290 fb1a36c0 2022-01-09 op }
291 fb1a36c0 2022-01-09 op
292 fb1a36c0 2022-01-09 op void
293 fb1a36c0 2022-01-09 op tremove(uint32_t fid)
294 fb1a36c0 2022-01-09 op {
295 fb1a36c0 2022-01-09 op /* fid[4] */
296 fb1a36c0 2022-01-09 op write_hdr_auto(sizeof(fid), Tremove);
297 fb1a36c0 2022-01-09 op write_fid(fid);
298 fb1a36c0 2022-01-09 op }