• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /* AFS File Server client stubs
2  *
3  * Copyright (C) 2002, 2007 Red Hat, Inc. All Rights Reserved.
4  * Written by David Howells (dhowells@redhat.com)
5  *
6  * This program is free software; you can redistribute it and/or
7  * modify it under the terms of the GNU General Public License
8  * as published by the Free Software Foundation; either version
9  * 2 of the License, or (at your option) any later version.
10  */
11 
12 #include <linux/init.h>
13 #include <linux/sched.h>
14 #include <linux/circ_buf.h>
15 #include "internal.h"
16 #include "afs_fs.h"
17 
18 /*
19  * decode an AFSFid block
20  */
xdr_decode_AFSFid(const __be32 ** _bp,struct afs_fid * fid)21 static void xdr_decode_AFSFid(const __be32 **_bp, struct afs_fid *fid)
22 {
23 	const __be32 *bp = *_bp;
24 
25 	fid->vid		= ntohl(*bp++);
26 	fid->vnode		= ntohl(*bp++);
27 	fid->unique		= ntohl(*bp++);
28 	*_bp = bp;
29 }
30 
31 /*
32  * decode an AFSFetchStatus block
33  */
xdr_decode_AFSFetchStatus(const __be32 ** _bp,struct afs_file_status * status,struct afs_vnode * vnode,afs_dataversion_t * store_version)34 static void xdr_decode_AFSFetchStatus(const __be32 **_bp,
35 				      struct afs_file_status *status,
36 				      struct afs_vnode *vnode,
37 				      afs_dataversion_t *store_version)
38 {
39 	afs_dataversion_t expected_version;
40 	const __be32 *bp = *_bp;
41 	umode_t mode;
42 	u64 data_version, size;
43 	u32 changed = 0; /* becomes non-zero if ctime-type changes seen */
44 
45 #define EXTRACT(DST)				\
46 	do {					\
47 		u32 x = ntohl(*bp++);		\
48 		changed |= DST - x;		\
49 		DST = x;			\
50 	} while (0)
51 
52 	status->if_version = ntohl(*bp++);
53 	EXTRACT(status->type);
54 	EXTRACT(status->nlink);
55 	size = ntohl(*bp++);
56 	data_version = ntohl(*bp++);
57 	EXTRACT(status->author);
58 	EXTRACT(status->owner);
59 	EXTRACT(status->caller_access); /* call ticket dependent */
60 	EXTRACT(status->anon_access);
61 	EXTRACT(status->mode);
62 	EXTRACT(status->parent.vnode);
63 	EXTRACT(status->parent.unique);
64 	bp++; /* seg size */
65 	status->mtime_client = ntohl(*bp++);
66 	status->mtime_server = ntohl(*bp++);
67 	EXTRACT(status->group);
68 	bp++; /* sync counter */
69 	data_version |= (u64) ntohl(*bp++) << 32;
70 	EXTRACT(status->lock_count);
71 	size |= (u64) ntohl(*bp++) << 32;
72 	bp++; /* spare 4 */
73 	*_bp = bp;
74 
75 	if (size != status->size) {
76 		status->size = size;
77 		changed |= true;
78 	}
79 	status->mode &= S_IALLUGO;
80 
81 	_debug("vnode time %lx, %lx",
82 	       status->mtime_client, status->mtime_server);
83 
84 	if (vnode) {
85 		status->parent.vid = vnode->fid.vid;
86 		if (changed && !test_bit(AFS_VNODE_UNSET, &vnode->flags)) {
87 			_debug("vnode changed");
88 			i_size_write(&vnode->vfs_inode, size);
89 			vnode->vfs_inode.i_uid = status->owner;
90 			vnode->vfs_inode.i_gid = status->group;
91 			vnode->vfs_inode.i_version = vnode->fid.unique;
92 			vnode->vfs_inode.i_nlink = status->nlink;
93 
94 			mode = vnode->vfs_inode.i_mode;
95 			mode &= ~S_IALLUGO;
96 			mode |= status->mode;
97 			barrier();
98 			vnode->vfs_inode.i_mode = mode;
99 		}
100 
101 		vnode->vfs_inode.i_ctime.tv_sec	= status->mtime_server;
102 		vnode->vfs_inode.i_mtime	= vnode->vfs_inode.i_ctime;
103 		vnode->vfs_inode.i_atime	= vnode->vfs_inode.i_ctime;
104 	}
105 
106 	expected_version = status->data_version;
107 	if (store_version)
108 		expected_version = *store_version;
109 
110 	if (expected_version != data_version) {
111 		status->data_version = data_version;
112 		if (vnode && !test_bit(AFS_VNODE_UNSET, &vnode->flags)) {
113 			_debug("vnode modified %llx on {%x:%u}",
114 			       (unsigned long long) data_version,
115 			       vnode->fid.vid, vnode->fid.vnode);
116 			set_bit(AFS_VNODE_MODIFIED, &vnode->flags);
117 			set_bit(AFS_VNODE_ZAP_DATA, &vnode->flags);
118 		}
119 	} else if (store_version) {
120 		status->data_version = data_version;
121 	}
122 }
123 
124 /*
125  * decode an AFSCallBack block
126  */
xdr_decode_AFSCallBack(const __be32 ** _bp,struct afs_vnode * vnode)127 static void xdr_decode_AFSCallBack(const __be32 **_bp, struct afs_vnode *vnode)
128 {
129 	const __be32 *bp = *_bp;
130 
131 	vnode->cb_version	= ntohl(*bp++);
132 	vnode->cb_expiry	= ntohl(*bp++);
133 	vnode->cb_type		= ntohl(*bp++);
134 	vnode->cb_expires	= vnode->cb_expiry + get_seconds();
135 	*_bp = bp;
136 }
137 
xdr_decode_AFSCallBack_raw(const __be32 ** _bp,struct afs_callback * cb)138 static void xdr_decode_AFSCallBack_raw(const __be32 **_bp,
139 				       struct afs_callback *cb)
140 {
141 	const __be32 *bp = *_bp;
142 
143 	cb->version	= ntohl(*bp++);
144 	cb->expiry	= ntohl(*bp++);
145 	cb->type	= ntohl(*bp++);
146 	*_bp = bp;
147 }
148 
149 /*
150  * decode an AFSVolSync block
151  */
xdr_decode_AFSVolSync(const __be32 ** _bp,struct afs_volsync * volsync)152 static void xdr_decode_AFSVolSync(const __be32 **_bp,
153 				  struct afs_volsync *volsync)
154 {
155 	const __be32 *bp = *_bp;
156 
157 	volsync->creation = ntohl(*bp++);
158 	bp++; /* spare2 */
159 	bp++; /* spare3 */
160 	bp++; /* spare4 */
161 	bp++; /* spare5 */
162 	bp++; /* spare6 */
163 	*_bp = bp;
164 }
165 
166 /*
167  * encode the requested attributes into an AFSStoreStatus block
168  */
xdr_encode_AFS_StoreStatus(__be32 ** _bp,struct iattr * attr)169 static void xdr_encode_AFS_StoreStatus(__be32 **_bp, struct iattr *attr)
170 {
171 	__be32 *bp = *_bp;
172 	u32 mask = 0, mtime = 0, owner = 0, group = 0, mode = 0;
173 
174 	mask = 0;
175 	if (attr->ia_valid & ATTR_MTIME) {
176 		mask |= AFS_SET_MTIME;
177 		mtime = attr->ia_mtime.tv_sec;
178 	}
179 
180 	if (attr->ia_valid & ATTR_UID) {
181 		mask |= AFS_SET_OWNER;
182 		owner = attr->ia_uid;
183 	}
184 
185 	if (attr->ia_valid & ATTR_GID) {
186 		mask |= AFS_SET_GROUP;
187 		group = attr->ia_gid;
188 	}
189 
190 	if (attr->ia_valid & ATTR_MODE) {
191 		mask |= AFS_SET_MODE;
192 		mode = attr->ia_mode & S_IALLUGO;
193 	}
194 
195 	*bp++ = htonl(mask);
196 	*bp++ = htonl(mtime);
197 	*bp++ = htonl(owner);
198 	*bp++ = htonl(group);
199 	*bp++ = htonl(mode);
200 	*bp++ = 0;		/* segment size */
201 	*_bp = bp;
202 }
203 
204 /*
205  * decode an AFSFetchVolumeStatus block
206  */
xdr_decode_AFSFetchVolumeStatus(const __be32 ** _bp,struct afs_volume_status * vs)207 static void xdr_decode_AFSFetchVolumeStatus(const __be32 **_bp,
208 					    struct afs_volume_status *vs)
209 {
210 	const __be32 *bp = *_bp;
211 
212 	vs->vid			= ntohl(*bp++);
213 	vs->parent_id		= ntohl(*bp++);
214 	vs->online		= ntohl(*bp++);
215 	vs->in_service		= ntohl(*bp++);
216 	vs->blessed		= ntohl(*bp++);
217 	vs->needs_salvage	= ntohl(*bp++);
218 	vs->type		= ntohl(*bp++);
219 	vs->min_quota		= ntohl(*bp++);
220 	vs->max_quota		= ntohl(*bp++);
221 	vs->blocks_in_use	= ntohl(*bp++);
222 	vs->part_blocks_avail	= ntohl(*bp++);
223 	vs->part_max_blocks	= ntohl(*bp++);
224 	*_bp = bp;
225 }
226 
227 /*
228  * deliver reply data to an FS.FetchStatus
229  */
afs_deliver_fs_fetch_status(struct afs_call * call,struct sk_buff * skb,bool last)230 static int afs_deliver_fs_fetch_status(struct afs_call *call,
231 				       struct sk_buff *skb, bool last)
232 {
233 	struct afs_vnode *vnode = call->reply;
234 	const __be32 *bp;
235 
236 	_enter(",,%u", last);
237 
238 	afs_transfer_reply(call, skb);
239 	if (!last)
240 		return 0;
241 
242 	if (call->reply_size != call->reply_max)
243 		return -EBADMSG;
244 
245 	/* unmarshall the reply once we've received all of it */
246 	bp = call->buffer;
247 	xdr_decode_AFSFetchStatus(&bp, &vnode->status, vnode, NULL);
248 	xdr_decode_AFSCallBack(&bp, vnode);
249 	if (call->reply2)
250 		xdr_decode_AFSVolSync(&bp, call->reply2);
251 
252 	_leave(" = 0 [done]");
253 	return 0;
254 }
255 
256 /*
257  * FS.FetchStatus operation type
258  */
259 static const struct afs_call_type afs_RXFSFetchStatus = {
260 	.name		= "FS.FetchStatus",
261 	.deliver	= afs_deliver_fs_fetch_status,
262 	.abort_to_error	= afs_abort_to_error,
263 	.destructor	= afs_flat_call_destructor,
264 };
265 
266 /*
267  * fetch the status information for a file
268  */
afs_fs_fetch_file_status(struct afs_server * server,struct key * key,struct afs_vnode * vnode,struct afs_volsync * volsync,const struct afs_wait_mode * wait_mode)269 int afs_fs_fetch_file_status(struct afs_server *server,
270 			     struct key *key,
271 			     struct afs_vnode *vnode,
272 			     struct afs_volsync *volsync,
273 			     const struct afs_wait_mode *wait_mode)
274 {
275 	struct afs_call *call;
276 	__be32 *bp;
277 
278 	_enter(",%x,{%x:%u},,",
279 	       key_serial(key), vnode->fid.vid, vnode->fid.vnode);
280 
281 	call = afs_alloc_flat_call(&afs_RXFSFetchStatus, 16, (21 + 3 + 6) * 4);
282 	if (!call)
283 		return -ENOMEM;
284 
285 	call->key = key;
286 	call->reply = vnode;
287 	call->reply2 = volsync;
288 	call->service_id = FS_SERVICE;
289 	call->port = htons(AFS_FS_PORT);
290 
291 	/* marshall the parameters */
292 	bp = call->request;
293 	bp[0] = htonl(FSFETCHSTATUS);
294 	bp[1] = htonl(vnode->fid.vid);
295 	bp[2] = htonl(vnode->fid.vnode);
296 	bp[3] = htonl(vnode->fid.unique);
297 
298 	return afs_make_call(&server->addr, call, GFP_NOFS, wait_mode);
299 }
300 
301 /*
302  * deliver reply data to an FS.FetchData
303  */
afs_deliver_fs_fetch_data(struct afs_call * call,struct sk_buff * skb,bool last)304 static int afs_deliver_fs_fetch_data(struct afs_call *call,
305 				     struct sk_buff *skb, bool last)
306 {
307 	struct afs_vnode *vnode = call->reply;
308 	const __be32 *bp;
309 	struct page *page;
310 	void *buffer;
311 	int ret;
312 
313 	_enter("{%u},{%u},%d", call->unmarshall, skb->len, last);
314 
315 	switch (call->unmarshall) {
316 	case 0:
317 		call->offset = 0;
318 		call->unmarshall++;
319 		if (call->operation_ID != FSFETCHDATA64) {
320 			call->unmarshall++;
321 			goto no_msw;
322 		}
323 
324 		/* extract the upper part of the returned data length of an
325 		 * FSFETCHDATA64 op (which should always be 0 using this
326 		 * client) */
327 	case 1:
328 		_debug("extract data length (MSW)");
329 		ret = afs_extract_data(call, skb, last, &call->tmp, 4);
330 		switch (ret) {
331 		case 0:		break;
332 		case -EAGAIN:	return 0;
333 		default:	return ret;
334 		}
335 
336 		call->count = ntohl(call->tmp);
337 		_debug("DATA length MSW: %u", call->count);
338 		if (call->count > 0)
339 			return -EBADMSG;
340 		call->offset = 0;
341 		call->unmarshall++;
342 
343 	no_msw:
344 		/* extract the returned data length */
345 	case 2:
346 		_debug("extract data length");
347 		ret = afs_extract_data(call, skb, last, &call->tmp, 4);
348 		switch (ret) {
349 		case 0:		break;
350 		case -EAGAIN:	return 0;
351 		default:	return ret;
352 		}
353 
354 		call->count = ntohl(call->tmp);
355 		_debug("DATA length: %u", call->count);
356 		if (call->count > PAGE_SIZE)
357 			return -EBADMSG;
358 		call->offset = 0;
359 		call->unmarshall++;
360 
361 		/* extract the returned data */
362 	case 3:
363 		_debug("extract data");
364 		if (call->count > 0) {
365 			page = call->reply3;
366 			buffer = kmap_atomic(page, KM_USER0);
367 			ret = afs_extract_data(call, skb, last, buffer,
368 					       call->count);
369 			kunmap_atomic(buffer, KM_USER0);
370 			switch (ret) {
371 			case 0:		break;
372 			case -EAGAIN:	return 0;
373 			default:	return ret;
374 			}
375 		}
376 
377 		call->offset = 0;
378 		call->unmarshall++;
379 
380 		/* extract the metadata */
381 	case 4:
382 		ret = afs_extract_data(call, skb, last, call->buffer,
383 				       (21 + 3 + 6) * 4);
384 		switch (ret) {
385 		case 0:		break;
386 		case -EAGAIN:	return 0;
387 		default:	return ret;
388 		}
389 
390 		bp = call->buffer;
391 		xdr_decode_AFSFetchStatus(&bp, &vnode->status, vnode, NULL);
392 		xdr_decode_AFSCallBack(&bp, vnode);
393 		if (call->reply2)
394 			xdr_decode_AFSVolSync(&bp, call->reply2);
395 
396 		call->offset = 0;
397 		call->unmarshall++;
398 
399 	case 5:
400 		_debug("trailer");
401 		if (skb->len != 0)
402 			return -EBADMSG;
403 		break;
404 	}
405 
406 	if (!last)
407 		return 0;
408 
409 	if (call->count < PAGE_SIZE) {
410 		_debug("clear");
411 		page = call->reply3;
412 		buffer = kmap_atomic(page, KM_USER0);
413 		memset(buffer + call->count, 0, PAGE_SIZE - call->count);
414 		kunmap_atomic(buffer, KM_USER0);
415 	}
416 
417 	_leave(" = 0 [done]");
418 	return 0;
419 }
420 
421 /*
422  * FS.FetchData operation type
423  */
424 static const struct afs_call_type afs_RXFSFetchData = {
425 	.name		= "FS.FetchData",
426 	.deliver	= afs_deliver_fs_fetch_data,
427 	.abort_to_error	= afs_abort_to_error,
428 	.destructor	= afs_flat_call_destructor,
429 };
430 
431 static const struct afs_call_type afs_RXFSFetchData64 = {
432 	.name		= "FS.FetchData64",
433 	.deliver	= afs_deliver_fs_fetch_data,
434 	.abort_to_error	= afs_abort_to_error,
435 	.destructor	= afs_flat_call_destructor,
436 };
437 
438 /*
439  * fetch data from a very large file
440  */
afs_fs_fetch_data64(struct afs_server * server,struct key * key,struct afs_vnode * vnode,off_t offset,size_t length,struct page * buffer,const struct afs_wait_mode * wait_mode)441 static int afs_fs_fetch_data64(struct afs_server *server,
442 			       struct key *key,
443 			       struct afs_vnode *vnode,
444 			       off_t offset, size_t length,
445 			       struct page *buffer,
446 			       const struct afs_wait_mode *wait_mode)
447 {
448 	struct afs_call *call;
449 	__be32 *bp;
450 
451 	_enter("");
452 
453 	ASSERTCMP(length, <, ULONG_MAX);
454 
455 	call = afs_alloc_flat_call(&afs_RXFSFetchData64, 32, (21 + 3 + 6) * 4);
456 	if (!call)
457 		return -ENOMEM;
458 
459 	call->key = key;
460 	call->reply = vnode;
461 	call->reply2 = NULL; /* volsync */
462 	call->reply3 = buffer;
463 	call->service_id = FS_SERVICE;
464 	call->port = htons(AFS_FS_PORT);
465 	call->operation_ID = FSFETCHDATA64;
466 
467 	/* marshall the parameters */
468 	bp = call->request;
469 	bp[0] = htonl(FSFETCHDATA64);
470 	bp[1] = htonl(vnode->fid.vid);
471 	bp[2] = htonl(vnode->fid.vnode);
472 	bp[3] = htonl(vnode->fid.unique);
473 	bp[4] = htonl(upper_32_bits(offset));
474 	bp[5] = htonl((u32) offset);
475 	bp[6] = 0;
476 	bp[7] = htonl((u32) length);
477 
478 	return afs_make_call(&server->addr, call, GFP_NOFS, wait_mode);
479 }
480 
481 /*
482  * fetch data from a file
483  */
afs_fs_fetch_data(struct afs_server * server,struct key * key,struct afs_vnode * vnode,off_t offset,size_t length,struct page * buffer,const struct afs_wait_mode * wait_mode)484 int afs_fs_fetch_data(struct afs_server *server,
485 		      struct key *key,
486 		      struct afs_vnode *vnode,
487 		      off_t offset, size_t length,
488 		      struct page *buffer,
489 		      const struct afs_wait_mode *wait_mode)
490 {
491 	struct afs_call *call;
492 	__be32 *bp;
493 
494 	if (upper_32_bits(offset) || upper_32_bits(offset + length))
495 		return afs_fs_fetch_data64(server, key, vnode, offset, length,
496 					   buffer, wait_mode);
497 
498 	_enter("");
499 
500 	call = afs_alloc_flat_call(&afs_RXFSFetchData, 24, (21 + 3 + 6) * 4);
501 	if (!call)
502 		return -ENOMEM;
503 
504 	call->key = key;
505 	call->reply = vnode;
506 	call->reply2 = NULL; /* volsync */
507 	call->reply3 = buffer;
508 	call->service_id = FS_SERVICE;
509 	call->port = htons(AFS_FS_PORT);
510 	call->operation_ID = FSFETCHDATA;
511 
512 	/* marshall the parameters */
513 	bp = call->request;
514 	bp[0] = htonl(FSFETCHDATA);
515 	bp[1] = htonl(vnode->fid.vid);
516 	bp[2] = htonl(vnode->fid.vnode);
517 	bp[3] = htonl(vnode->fid.unique);
518 	bp[4] = htonl(offset);
519 	bp[5] = htonl(length);
520 
521 	return afs_make_call(&server->addr, call, GFP_NOFS, wait_mode);
522 }
523 
524 /*
525  * deliver reply data to an FS.GiveUpCallBacks
526  */
afs_deliver_fs_give_up_callbacks(struct afs_call * call,struct sk_buff * skb,bool last)527 static int afs_deliver_fs_give_up_callbacks(struct afs_call *call,
528 					    struct sk_buff *skb, bool last)
529 {
530 	_enter(",{%u},%d", skb->len, last);
531 
532 	if (skb->len > 0)
533 		return -EBADMSG; /* shouldn't be any reply data */
534 	return 0;
535 }
536 
537 /*
538  * FS.GiveUpCallBacks operation type
539  */
540 static const struct afs_call_type afs_RXFSGiveUpCallBacks = {
541 	.name		= "FS.GiveUpCallBacks",
542 	.deliver	= afs_deliver_fs_give_up_callbacks,
543 	.abort_to_error	= afs_abort_to_error,
544 	.destructor	= afs_flat_call_destructor,
545 };
546 
547 /*
548  * give up a set of callbacks
549  * - the callbacks are held in the server->cb_break ring
550  */
afs_fs_give_up_callbacks(struct afs_server * server,const struct afs_wait_mode * wait_mode)551 int afs_fs_give_up_callbacks(struct afs_server *server,
552 			     const struct afs_wait_mode *wait_mode)
553 {
554 	struct afs_call *call;
555 	size_t ncallbacks;
556 	__be32 *bp, *tp;
557 	int loop;
558 
559 	ncallbacks = CIRC_CNT(server->cb_break_head, server->cb_break_tail,
560 			      ARRAY_SIZE(server->cb_break));
561 
562 	_enter("{%zu},", ncallbacks);
563 
564 	if (ncallbacks == 0)
565 		return 0;
566 	if (ncallbacks > AFSCBMAX)
567 		ncallbacks = AFSCBMAX;
568 
569 	_debug("break %zu callbacks", ncallbacks);
570 
571 	call = afs_alloc_flat_call(&afs_RXFSGiveUpCallBacks,
572 				   12 + ncallbacks * 6 * 4, 0);
573 	if (!call)
574 		return -ENOMEM;
575 
576 	call->service_id = FS_SERVICE;
577 	call->port = htons(AFS_FS_PORT);
578 
579 	/* marshall the parameters */
580 	bp = call->request;
581 	tp = bp + 2 + ncallbacks * 3;
582 	*bp++ = htonl(FSGIVEUPCALLBACKS);
583 	*bp++ = htonl(ncallbacks);
584 	*tp++ = htonl(ncallbacks);
585 
586 	atomic_sub(ncallbacks, &server->cb_break_n);
587 	for (loop = ncallbacks; loop > 0; loop--) {
588 		struct afs_callback *cb =
589 			&server->cb_break[server->cb_break_tail];
590 
591 		*bp++ = htonl(cb->fid.vid);
592 		*bp++ = htonl(cb->fid.vnode);
593 		*bp++ = htonl(cb->fid.unique);
594 		*tp++ = htonl(cb->version);
595 		*tp++ = htonl(cb->expiry);
596 		*tp++ = htonl(cb->type);
597 		smp_mb();
598 		server->cb_break_tail =
599 			(server->cb_break_tail + 1) &
600 			(ARRAY_SIZE(server->cb_break) - 1);
601 	}
602 
603 	ASSERT(ncallbacks > 0);
604 	wake_up_nr(&server->cb_break_waitq, ncallbacks);
605 
606 	return afs_make_call(&server->addr, call, GFP_NOFS, wait_mode);
607 }
608 
609 /*
610  * deliver reply data to an FS.CreateFile or an FS.MakeDir
611  */
afs_deliver_fs_create_vnode(struct afs_call * call,struct sk_buff * skb,bool last)612 static int afs_deliver_fs_create_vnode(struct afs_call *call,
613 				       struct sk_buff *skb, bool last)
614 {
615 	struct afs_vnode *vnode = call->reply;
616 	const __be32 *bp;
617 
618 	_enter("{%u},{%u},%d", call->unmarshall, skb->len, last);
619 
620 	afs_transfer_reply(call, skb);
621 	if (!last)
622 		return 0;
623 
624 	if (call->reply_size != call->reply_max)
625 		return -EBADMSG;
626 
627 	/* unmarshall the reply once we've received all of it */
628 	bp = call->buffer;
629 	xdr_decode_AFSFid(&bp, call->reply2);
630 	xdr_decode_AFSFetchStatus(&bp, call->reply3, NULL, NULL);
631 	xdr_decode_AFSFetchStatus(&bp, &vnode->status, vnode, NULL);
632 	xdr_decode_AFSCallBack_raw(&bp, call->reply4);
633 	/* xdr_decode_AFSVolSync(&bp, call->replyX); */
634 
635 	_leave(" = 0 [done]");
636 	return 0;
637 }
638 
639 /*
640  * FS.CreateFile and FS.MakeDir operation type
641  */
642 static const struct afs_call_type afs_RXFSCreateXXXX = {
643 	.name		= "FS.CreateXXXX",
644 	.deliver	= afs_deliver_fs_create_vnode,
645 	.abort_to_error	= afs_abort_to_error,
646 	.destructor	= afs_flat_call_destructor,
647 };
648 
649 /*
650  * create a file or make a directory
651  */
afs_fs_create(struct afs_server * server,struct key * key,struct afs_vnode * vnode,const char * name,umode_t mode,struct afs_fid * newfid,struct afs_file_status * newstatus,struct afs_callback * newcb,const struct afs_wait_mode * wait_mode)652 int afs_fs_create(struct afs_server *server,
653 		  struct key *key,
654 		  struct afs_vnode *vnode,
655 		  const char *name,
656 		  umode_t mode,
657 		  struct afs_fid *newfid,
658 		  struct afs_file_status *newstatus,
659 		  struct afs_callback *newcb,
660 		  const struct afs_wait_mode *wait_mode)
661 {
662 	struct afs_call *call;
663 	size_t namesz, reqsz, padsz;
664 	__be32 *bp;
665 
666 	_enter("");
667 
668 	namesz = strlen(name);
669 	padsz = (4 - (namesz & 3)) & 3;
670 	reqsz = (5 * 4) + namesz + padsz + (6 * 4);
671 
672 	call = afs_alloc_flat_call(&afs_RXFSCreateXXXX, reqsz,
673 				   (3 + 21 + 21 + 3 + 6) * 4);
674 	if (!call)
675 		return -ENOMEM;
676 
677 	call->key = key;
678 	call->reply = vnode;
679 	call->reply2 = newfid;
680 	call->reply3 = newstatus;
681 	call->reply4 = newcb;
682 	call->service_id = FS_SERVICE;
683 	call->port = htons(AFS_FS_PORT);
684 
685 	/* marshall the parameters */
686 	bp = call->request;
687 	*bp++ = htonl(S_ISDIR(mode) ? FSMAKEDIR : FSCREATEFILE);
688 	*bp++ = htonl(vnode->fid.vid);
689 	*bp++ = htonl(vnode->fid.vnode);
690 	*bp++ = htonl(vnode->fid.unique);
691 	*bp++ = htonl(namesz);
692 	memcpy(bp, name, namesz);
693 	bp = (void *) bp + namesz;
694 	if (padsz > 0) {
695 		memset(bp, 0, padsz);
696 		bp = (void *) bp + padsz;
697 	}
698 	*bp++ = htonl(AFS_SET_MODE);
699 	*bp++ = 0; /* mtime */
700 	*bp++ = 0; /* owner */
701 	*bp++ = 0; /* group */
702 	*bp++ = htonl(mode & S_IALLUGO); /* unix mode */
703 	*bp++ = 0; /* segment size */
704 
705 	return afs_make_call(&server->addr, call, GFP_NOFS, wait_mode);
706 }
707 
708 /*
709  * deliver reply data to an FS.RemoveFile or FS.RemoveDir
710  */
afs_deliver_fs_remove(struct afs_call * call,struct sk_buff * skb,bool last)711 static int afs_deliver_fs_remove(struct afs_call *call,
712 				 struct sk_buff *skb, bool last)
713 {
714 	struct afs_vnode *vnode = call->reply;
715 	const __be32 *bp;
716 
717 	_enter("{%u},{%u},%d", call->unmarshall, skb->len, last);
718 
719 	afs_transfer_reply(call, skb);
720 	if (!last)
721 		return 0;
722 
723 	if (call->reply_size != call->reply_max)
724 		return -EBADMSG;
725 
726 	/* unmarshall the reply once we've received all of it */
727 	bp = call->buffer;
728 	xdr_decode_AFSFetchStatus(&bp, &vnode->status, vnode, NULL);
729 	/* xdr_decode_AFSVolSync(&bp, call->replyX); */
730 
731 	_leave(" = 0 [done]");
732 	return 0;
733 }
734 
735 /*
736  * FS.RemoveDir/FS.RemoveFile operation type
737  */
738 static const struct afs_call_type afs_RXFSRemoveXXXX = {
739 	.name		= "FS.RemoveXXXX",
740 	.deliver	= afs_deliver_fs_remove,
741 	.abort_to_error	= afs_abort_to_error,
742 	.destructor	= afs_flat_call_destructor,
743 };
744 
745 /*
746  * remove a file or directory
747  */
afs_fs_remove(struct afs_server * server,struct key * key,struct afs_vnode * vnode,const char * name,bool isdir,const struct afs_wait_mode * wait_mode)748 int afs_fs_remove(struct afs_server *server,
749 		  struct key *key,
750 		  struct afs_vnode *vnode,
751 		  const char *name,
752 		  bool isdir,
753 		  const struct afs_wait_mode *wait_mode)
754 {
755 	struct afs_call *call;
756 	size_t namesz, reqsz, padsz;
757 	__be32 *bp;
758 
759 	_enter("");
760 
761 	namesz = strlen(name);
762 	padsz = (4 - (namesz & 3)) & 3;
763 	reqsz = (5 * 4) + namesz + padsz;
764 
765 	call = afs_alloc_flat_call(&afs_RXFSRemoveXXXX, reqsz, (21 + 6) * 4);
766 	if (!call)
767 		return -ENOMEM;
768 
769 	call->key = key;
770 	call->reply = vnode;
771 	call->service_id = FS_SERVICE;
772 	call->port = htons(AFS_FS_PORT);
773 
774 	/* marshall the parameters */
775 	bp = call->request;
776 	*bp++ = htonl(isdir ? FSREMOVEDIR : FSREMOVEFILE);
777 	*bp++ = htonl(vnode->fid.vid);
778 	*bp++ = htonl(vnode->fid.vnode);
779 	*bp++ = htonl(vnode->fid.unique);
780 	*bp++ = htonl(namesz);
781 	memcpy(bp, name, namesz);
782 	bp = (void *) bp + namesz;
783 	if (padsz > 0) {
784 		memset(bp, 0, padsz);
785 		bp = (void *) bp + padsz;
786 	}
787 
788 	return afs_make_call(&server->addr, call, GFP_NOFS, wait_mode);
789 }
790 
791 /*
792  * deliver reply data to an FS.Link
793  */
afs_deliver_fs_link(struct afs_call * call,struct sk_buff * skb,bool last)794 static int afs_deliver_fs_link(struct afs_call *call,
795 			       struct sk_buff *skb, bool last)
796 {
797 	struct afs_vnode *dvnode = call->reply, *vnode = call->reply2;
798 	const __be32 *bp;
799 
800 	_enter("{%u},{%u},%d", call->unmarshall, skb->len, last);
801 
802 	afs_transfer_reply(call, skb);
803 	if (!last)
804 		return 0;
805 
806 	if (call->reply_size != call->reply_max)
807 		return -EBADMSG;
808 
809 	/* unmarshall the reply once we've received all of it */
810 	bp = call->buffer;
811 	xdr_decode_AFSFetchStatus(&bp, &vnode->status, vnode, NULL);
812 	xdr_decode_AFSFetchStatus(&bp, &dvnode->status, dvnode, NULL);
813 	/* xdr_decode_AFSVolSync(&bp, call->replyX); */
814 
815 	_leave(" = 0 [done]");
816 	return 0;
817 }
818 
819 /*
820  * FS.Link operation type
821  */
822 static const struct afs_call_type afs_RXFSLink = {
823 	.name		= "FS.Link",
824 	.deliver	= afs_deliver_fs_link,
825 	.abort_to_error	= afs_abort_to_error,
826 	.destructor	= afs_flat_call_destructor,
827 };
828 
829 /*
830  * make a hard link
831  */
afs_fs_link(struct afs_server * server,struct key * key,struct afs_vnode * dvnode,struct afs_vnode * vnode,const char * name,const struct afs_wait_mode * wait_mode)832 int afs_fs_link(struct afs_server *server,
833 		struct key *key,
834 		struct afs_vnode *dvnode,
835 		struct afs_vnode *vnode,
836 		const char *name,
837 		const struct afs_wait_mode *wait_mode)
838 {
839 	struct afs_call *call;
840 	size_t namesz, reqsz, padsz;
841 	__be32 *bp;
842 
843 	_enter("");
844 
845 	namesz = strlen(name);
846 	padsz = (4 - (namesz & 3)) & 3;
847 	reqsz = (5 * 4) + namesz + padsz + (3 * 4);
848 
849 	call = afs_alloc_flat_call(&afs_RXFSLink, reqsz, (21 + 21 + 6) * 4);
850 	if (!call)
851 		return -ENOMEM;
852 
853 	call->key = key;
854 	call->reply = dvnode;
855 	call->reply2 = vnode;
856 	call->service_id = FS_SERVICE;
857 	call->port = htons(AFS_FS_PORT);
858 
859 	/* marshall the parameters */
860 	bp = call->request;
861 	*bp++ = htonl(FSLINK);
862 	*bp++ = htonl(dvnode->fid.vid);
863 	*bp++ = htonl(dvnode->fid.vnode);
864 	*bp++ = htonl(dvnode->fid.unique);
865 	*bp++ = htonl(namesz);
866 	memcpy(bp, name, namesz);
867 	bp = (void *) bp + namesz;
868 	if (padsz > 0) {
869 		memset(bp, 0, padsz);
870 		bp = (void *) bp + padsz;
871 	}
872 	*bp++ = htonl(vnode->fid.vid);
873 	*bp++ = htonl(vnode->fid.vnode);
874 	*bp++ = htonl(vnode->fid.unique);
875 
876 	return afs_make_call(&server->addr, call, GFP_NOFS, wait_mode);
877 }
878 
879 /*
880  * deliver reply data to an FS.Symlink
881  */
afs_deliver_fs_symlink(struct afs_call * call,struct sk_buff * skb,bool last)882 static int afs_deliver_fs_symlink(struct afs_call *call,
883 				  struct sk_buff *skb, bool last)
884 {
885 	struct afs_vnode *vnode = call->reply;
886 	const __be32 *bp;
887 
888 	_enter("{%u},{%u},%d", call->unmarshall, skb->len, last);
889 
890 	afs_transfer_reply(call, skb);
891 	if (!last)
892 		return 0;
893 
894 	if (call->reply_size != call->reply_max)
895 		return -EBADMSG;
896 
897 	/* unmarshall the reply once we've received all of it */
898 	bp = call->buffer;
899 	xdr_decode_AFSFid(&bp, call->reply2);
900 	xdr_decode_AFSFetchStatus(&bp, call->reply3, NULL, NULL);
901 	xdr_decode_AFSFetchStatus(&bp, &vnode->status, vnode, NULL);
902 	/* xdr_decode_AFSVolSync(&bp, call->replyX); */
903 
904 	_leave(" = 0 [done]");
905 	return 0;
906 }
907 
908 /*
909  * FS.Symlink operation type
910  */
911 static const struct afs_call_type afs_RXFSSymlink = {
912 	.name		= "FS.Symlink",
913 	.deliver	= afs_deliver_fs_symlink,
914 	.abort_to_error	= afs_abort_to_error,
915 	.destructor	= afs_flat_call_destructor,
916 };
917 
918 /*
919  * create a symbolic link
920  */
afs_fs_symlink(struct afs_server * server,struct key * key,struct afs_vnode * vnode,const char * name,const char * contents,struct afs_fid * newfid,struct afs_file_status * newstatus,const struct afs_wait_mode * wait_mode)921 int afs_fs_symlink(struct afs_server *server,
922 		   struct key *key,
923 		   struct afs_vnode *vnode,
924 		   const char *name,
925 		   const char *contents,
926 		   struct afs_fid *newfid,
927 		   struct afs_file_status *newstatus,
928 		   const struct afs_wait_mode *wait_mode)
929 {
930 	struct afs_call *call;
931 	size_t namesz, reqsz, padsz, c_namesz, c_padsz;
932 	__be32 *bp;
933 
934 	_enter("");
935 
936 	namesz = strlen(name);
937 	padsz = (4 - (namesz & 3)) & 3;
938 
939 	c_namesz = strlen(contents);
940 	c_padsz = (4 - (c_namesz & 3)) & 3;
941 
942 	reqsz = (6 * 4) + namesz + padsz + c_namesz + c_padsz + (6 * 4);
943 
944 	call = afs_alloc_flat_call(&afs_RXFSSymlink, reqsz,
945 				   (3 + 21 + 21 + 6) * 4);
946 	if (!call)
947 		return -ENOMEM;
948 
949 	call->key = key;
950 	call->reply = vnode;
951 	call->reply2 = newfid;
952 	call->reply3 = newstatus;
953 	call->service_id = FS_SERVICE;
954 	call->port = htons(AFS_FS_PORT);
955 
956 	/* marshall the parameters */
957 	bp = call->request;
958 	*bp++ = htonl(FSSYMLINK);
959 	*bp++ = htonl(vnode->fid.vid);
960 	*bp++ = htonl(vnode->fid.vnode);
961 	*bp++ = htonl(vnode->fid.unique);
962 	*bp++ = htonl(namesz);
963 	memcpy(bp, name, namesz);
964 	bp = (void *) bp + namesz;
965 	if (padsz > 0) {
966 		memset(bp, 0, padsz);
967 		bp = (void *) bp + padsz;
968 	}
969 	*bp++ = htonl(c_namesz);
970 	memcpy(bp, contents, c_namesz);
971 	bp = (void *) bp + c_namesz;
972 	if (c_padsz > 0) {
973 		memset(bp, 0, c_padsz);
974 		bp = (void *) bp + c_padsz;
975 	}
976 	*bp++ = htonl(AFS_SET_MODE);
977 	*bp++ = 0; /* mtime */
978 	*bp++ = 0; /* owner */
979 	*bp++ = 0; /* group */
980 	*bp++ = htonl(S_IRWXUGO); /* unix mode */
981 	*bp++ = 0; /* segment size */
982 
983 	return afs_make_call(&server->addr, call, GFP_NOFS, wait_mode);
984 }
985 
986 /*
987  * deliver reply data to an FS.Rename
988  */
afs_deliver_fs_rename(struct afs_call * call,struct sk_buff * skb,bool last)989 static int afs_deliver_fs_rename(struct afs_call *call,
990 				  struct sk_buff *skb, bool last)
991 {
992 	struct afs_vnode *orig_dvnode = call->reply, *new_dvnode = call->reply2;
993 	const __be32 *bp;
994 
995 	_enter("{%u},{%u},%d", call->unmarshall, skb->len, last);
996 
997 	afs_transfer_reply(call, skb);
998 	if (!last)
999 		return 0;
1000 
1001 	if (call->reply_size != call->reply_max)
1002 		return -EBADMSG;
1003 
1004 	/* unmarshall the reply once we've received all of it */
1005 	bp = call->buffer;
1006 	xdr_decode_AFSFetchStatus(&bp, &orig_dvnode->status, orig_dvnode, NULL);
1007 	if (new_dvnode != orig_dvnode)
1008 		xdr_decode_AFSFetchStatus(&bp, &new_dvnode->status, new_dvnode,
1009 					  NULL);
1010 	/* xdr_decode_AFSVolSync(&bp, call->replyX); */
1011 
1012 	_leave(" = 0 [done]");
1013 	return 0;
1014 }
1015 
1016 /*
1017  * FS.Rename operation type
1018  */
1019 static const struct afs_call_type afs_RXFSRename = {
1020 	.name		= "FS.Rename",
1021 	.deliver	= afs_deliver_fs_rename,
1022 	.abort_to_error	= afs_abort_to_error,
1023 	.destructor	= afs_flat_call_destructor,
1024 };
1025 
1026 /*
1027  * create a symbolic link
1028  */
afs_fs_rename(struct afs_server * server,struct key * key,struct afs_vnode * orig_dvnode,const char * orig_name,struct afs_vnode * new_dvnode,const char * new_name,const struct afs_wait_mode * wait_mode)1029 int afs_fs_rename(struct afs_server *server,
1030 		  struct key *key,
1031 		  struct afs_vnode *orig_dvnode,
1032 		  const char *orig_name,
1033 		  struct afs_vnode *new_dvnode,
1034 		  const char *new_name,
1035 		  const struct afs_wait_mode *wait_mode)
1036 {
1037 	struct afs_call *call;
1038 	size_t reqsz, o_namesz, o_padsz, n_namesz, n_padsz;
1039 	__be32 *bp;
1040 
1041 	_enter("");
1042 
1043 	o_namesz = strlen(orig_name);
1044 	o_padsz = (4 - (o_namesz & 3)) & 3;
1045 
1046 	n_namesz = strlen(new_name);
1047 	n_padsz = (4 - (n_namesz & 3)) & 3;
1048 
1049 	reqsz = (4 * 4) +
1050 		4 + o_namesz + o_padsz +
1051 		(3 * 4) +
1052 		4 + n_namesz + n_padsz;
1053 
1054 	call = afs_alloc_flat_call(&afs_RXFSRename, reqsz, (21 + 21 + 6) * 4);
1055 	if (!call)
1056 		return -ENOMEM;
1057 
1058 	call->key = key;
1059 	call->reply = orig_dvnode;
1060 	call->reply2 = new_dvnode;
1061 	call->service_id = FS_SERVICE;
1062 	call->port = htons(AFS_FS_PORT);
1063 
1064 	/* marshall the parameters */
1065 	bp = call->request;
1066 	*bp++ = htonl(FSRENAME);
1067 	*bp++ = htonl(orig_dvnode->fid.vid);
1068 	*bp++ = htonl(orig_dvnode->fid.vnode);
1069 	*bp++ = htonl(orig_dvnode->fid.unique);
1070 	*bp++ = htonl(o_namesz);
1071 	memcpy(bp, orig_name, o_namesz);
1072 	bp = (void *) bp + o_namesz;
1073 	if (o_padsz > 0) {
1074 		memset(bp, 0, o_padsz);
1075 		bp = (void *) bp + o_padsz;
1076 	}
1077 
1078 	*bp++ = htonl(new_dvnode->fid.vid);
1079 	*bp++ = htonl(new_dvnode->fid.vnode);
1080 	*bp++ = htonl(new_dvnode->fid.unique);
1081 	*bp++ = htonl(n_namesz);
1082 	memcpy(bp, new_name, n_namesz);
1083 	bp = (void *) bp + n_namesz;
1084 	if (n_padsz > 0) {
1085 		memset(bp, 0, n_padsz);
1086 		bp = (void *) bp + n_padsz;
1087 	}
1088 
1089 	return afs_make_call(&server->addr, call, GFP_NOFS, wait_mode);
1090 }
1091 
1092 /*
1093  * deliver reply data to an FS.StoreData
1094  */
afs_deliver_fs_store_data(struct afs_call * call,struct sk_buff * skb,bool last)1095 static int afs_deliver_fs_store_data(struct afs_call *call,
1096 				     struct sk_buff *skb, bool last)
1097 {
1098 	struct afs_vnode *vnode = call->reply;
1099 	const __be32 *bp;
1100 
1101 	_enter(",,%u", last);
1102 
1103 	afs_transfer_reply(call, skb);
1104 	if (!last) {
1105 		_leave(" = 0 [more]");
1106 		return 0;
1107 	}
1108 
1109 	if (call->reply_size != call->reply_max) {
1110 		_leave(" = -EBADMSG [%u != %u]",
1111 		       call->reply_size, call->reply_max);
1112 		return -EBADMSG;
1113 	}
1114 
1115 	/* unmarshall the reply once we've received all of it */
1116 	bp = call->buffer;
1117 	xdr_decode_AFSFetchStatus(&bp, &vnode->status, vnode,
1118 				  &call->store_version);
1119 	/* xdr_decode_AFSVolSync(&bp, call->replyX); */
1120 
1121 	afs_pages_written_back(vnode, call);
1122 
1123 	_leave(" = 0 [done]");
1124 	return 0;
1125 }
1126 
1127 /*
1128  * FS.StoreData operation type
1129  */
1130 static const struct afs_call_type afs_RXFSStoreData = {
1131 	.name		= "FS.StoreData",
1132 	.deliver	= afs_deliver_fs_store_data,
1133 	.abort_to_error	= afs_abort_to_error,
1134 	.destructor	= afs_flat_call_destructor,
1135 };
1136 
1137 static const struct afs_call_type afs_RXFSStoreData64 = {
1138 	.name		= "FS.StoreData64",
1139 	.deliver	= afs_deliver_fs_store_data,
1140 	.abort_to_error	= afs_abort_to_error,
1141 	.destructor	= afs_flat_call_destructor,
1142 };
1143 
1144 /*
1145  * store a set of pages to a very large file
1146  */
afs_fs_store_data64(struct afs_server * server,struct afs_writeback * wb,pgoff_t first,pgoff_t last,unsigned offset,unsigned to,loff_t size,loff_t pos,loff_t i_size,const struct afs_wait_mode * wait_mode)1147 static int afs_fs_store_data64(struct afs_server *server,
1148 			       struct afs_writeback *wb,
1149 			       pgoff_t first, pgoff_t last,
1150 			       unsigned offset, unsigned to,
1151 			       loff_t size, loff_t pos, loff_t i_size,
1152 			       const struct afs_wait_mode *wait_mode)
1153 {
1154 	struct afs_vnode *vnode = wb->vnode;
1155 	struct afs_call *call;
1156 	__be32 *bp;
1157 
1158 	_enter(",%x,{%x:%u},,",
1159 	       key_serial(wb->key), vnode->fid.vid, vnode->fid.vnode);
1160 
1161 	call = afs_alloc_flat_call(&afs_RXFSStoreData64,
1162 				   (4 + 6 + 3 * 2) * 4,
1163 				   (21 + 6) * 4);
1164 	if (!call)
1165 		return -ENOMEM;
1166 
1167 	call->wb = wb;
1168 	call->key = wb->key;
1169 	call->reply = vnode;
1170 	call->service_id = FS_SERVICE;
1171 	call->port = htons(AFS_FS_PORT);
1172 	call->mapping = vnode->vfs_inode.i_mapping;
1173 	call->first = first;
1174 	call->last = last;
1175 	call->first_offset = offset;
1176 	call->last_to = to;
1177 	call->send_pages = true;
1178 	call->store_version = vnode->status.data_version + 1;
1179 
1180 	/* marshall the parameters */
1181 	bp = call->request;
1182 	*bp++ = htonl(FSSTOREDATA64);
1183 	*bp++ = htonl(vnode->fid.vid);
1184 	*bp++ = htonl(vnode->fid.vnode);
1185 	*bp++ = htonl(vnode->fid.unique);
1186 
1187 	*bp++ = 0; /* mask */
1188 	*bp++ = 0; /* mtime */
1189 	*bp++ = 0; /* owner */
1190 	*bp++ = 0; /* group */
1191 	*bp++ = 0; /* unix mode */
1192 	*bp++ = 0; /* segment size */
1193 
1194 	*bp++ = htonl(pos >> 32);
1195 	*bp++ = htonl((u32) pos);
1196 	*bp++ = htonl(size >> 32);
1197 	*bp++ = htonl((u32) size);
1198 	*bp++ = htonl(i_size >> 32);
1199 	*bp++ = htonl((u32) i_size);
1200 
1201 	return afs_make_call(&server->addr, call, GFP_NOFS, wait_mode);
1202 }
1203 
1204 /*
1205  * store a set of pages
1206  */
afs_fs_store_data(struct afs_server * server,struct afs_writeback * wb,pgoff_t first,pgoff_t last,unsigned offset,unsigned to,const struct afs_wait_mode * wait_mode)1207 int afs_fs_store_data(struct afs_server *server, struct afs_writeback *wb,
1208 		      pgoff_t first, pgoff_t last,
1209 		      unsigned offset, unsigned to,
1210 		      const struct afs_wait_mode *wait_mode)
1211 {
1212 	struct afs_vnode *vnode = wb->vnode;
1213 	struct afs_call *call;
1214 	loff_t size, pos, i_size;
1215 	__be32 *bp;
1216 
1217 	_enter(",%x,{%x:%u},,",
1218 	       key_serial(wb->key), vnode->fid.vid, vnode->fid.vnode);
1219 
1220 	size = to - offset;
1221 	if (first != last)
1222 		size += (loff_t)(last - first) << PAGE_SHIFT;
1223 	pos = (loff_t)first << PAGE_SHIFT;
1224 	pos += offset;
1225 
1226 	i_size = i_size_read(&vnode->vfs_inode);
1227 	if (pos + size > i_size)
1228 		i_size = size + pos;
1229 
1230 	_debug("size %llx, at %llx, i_size %llx",
1231 	       (unsigned long long) size, (unsigned long long) pos,
1232 	       (unsigned long long) i_size);
1233 
1234 	if (pos >> 32 || i_size >> 32 || size >> 32 || (pos + size) >> 32)
1235 		return afs_fs_store_data64(server, wb, first, last, offset, to,
1236 					   size, pos, i_size, wait_mode);
1237 
1238 	call = afs_alloc_flat_call(&afs_RXFSStoreData,
1239 				   (4 + 6 + 3) * 4,
1240 				   (21 + 6) * 4);
1241 	if (!call)
1242 		return -ENOMEM;
1243 
1244 	call->wb = wb;
1245 	call->key = wb->key;
1246 	call->reply = vnode;
1247 	call->service_id = FS_SERVICE;
1248 	call->port = htons(AFS_FS_PORT);
1249 	call->mapping = vnode->vfs_inode.i_mapping;
1250 	call->first = first;
1251 	call->last = last;
1252 	call->first_offset = offset;
1253 	call->last_to = to;
1254 	call->send_pages = true;
1255 	call->store_version = vnode->status.data_version + 1;
1256 
1257 	/* marshall the parameters */
1258 	bp = call->request;
1259 	*bp++ = htonl(FSSTOREDATA);
1260 	*bp++ = htonl(vnode->fid.vid);
1261 	*bp++ = htonl(vnode->fid.vnode);
1262 	*bp++ = htonl(vnode->fid.unique);
1263 
1264 	*bp++ = 0; /* mask */
1265 	*bp++ = 0; /* mtime */
1266 	*bp++ = 0; /* owner */
1267 	*bp++ = 0; /* group */
1268 	*bp++ = 0; /* unix mode */
1269 	*bp++ = 0; /* segment size */
1270 
1271 	*bp++ = htonl(pos);
1272 	*bp++ = htonl(size);
1273 	*bp++ = htonl(i_size);
1274 
1275 	return afs_make_call(&server->addr, call, GFP_NOFS, wait_mode);
1276 }
1277 
1278 /*
1279  * deliver reply data to an FS.StoreStatus
1280  */
afs_deliver_fs_store_status(struct afs_call * call,struct sk_buff * skb,bool last)1281 static int afs_deliver_fs_store_status(struct afs_call *call,
1282 				       struct sk_buff *skb, bool last)
1283 {
1284 	afs_dataversion_t *store_version;
1285 	struct afs_vnode *vnode = call->reply;
1286 	const __be32 *bp;
1287 
1288 	_enter(",,%u", last);
1289 
1290 	afs_transfer_reply(call, skb);
1291 	if (!last) {
1292 		_leave(" = 0 [more]");
1293 		return 0;
1294 	}
1295 
1296 	if (call->reply_size != call->reply_max) {
1297 		_leave(" = -EBADMSG [%u != %u]",
1298 		       call->reply_size, call->reply_max);
1299 		return -EBADMSG;
1300 	}
1301 
1302 	/* unmarshall the reply once we've received all of it */
1303 	store_version = NULL;
1304 	if (call->operation_ID == FSSTOREDATA)
1305 		store_version = &call->store_version;
1306 
1307 	bp = call->buffer;
1308 	xdr_decode_AFSFetchStatus(&bp, &vnode->status, vnode, store_version);
1309 	/* xdr_decode_AFSVolSync(&bp, call->replyX); */
1310 
1311 	_leave(" = 0 [done]");
1312 	return 0;
1313 }
1314 
1315 /*
1316  * FS.StoreStatus operation type
1317  */
1318 static const struct afs_call_type afs_RXFSStoreStatus = {
1319 	.name		= "FS.StoreStatus",
1320 	.deliver	= afs_deliver_fs_store_status,
1321 	.abort_to_error	= afs_abort_to_error,
1322 	.destructor	= afs_flat_call_destructor,
1323 };
1324 
1325 static const struct afs_call_type afs_RXFSStoreData_as_Status = {
1326 	.name		= "FS.StoreData",
1327 	.deliver	= afs_deliver_fs_store_status,
1328 	.abort_to_error	= afs_abort_to_error,
1329 	.destructor	= afs_flat_call_destructor,
1330 };
1331 
1332 static const struct afs_call_type afs_RXFSStoreData64_as_Status = {
1333 	.name		= "FS.StoreData64",
1334 	.deliver	= afs_deliver_fs_store_status,
1335 	.abort_to_error	= afs_abort_to_error,
1336 	.destructor	= afs_flat_call_destructor,
1337 };
1338 
1339 /*
1340  * set the attributes on a very large file, using FS.StoreData rather than
1341  * FS.StoreStatus so as to alter the file size also
1342  */
afs_fs_setattr_size64(struct afs_server * server,struct key * key,struct afs_vnode * vnode,struct iattr * attr,const struct afs_wait_mode * wait_mode)1343 static int afs_fs_setattr_size64(struct afs_server *server, struct key *key,
1344 				 struct afs_vnode *vnode, struct iattr *attr,
1345 				 const struct afs_wait_mode *wait_mode)
1346 {
1347 	struct afs_call *call;
1348 	__be32 *bp;
1349 
1350 	_enter(",%x,{%x:%u},,",
1351 	       key_serial(key), vnode->fid.vid, vnode->fid.vnode);
1352 
1353 	ASSERT(attr->ia_valid & ATTR_SIZE);
1354 
1355 	call = afs_alloc_flat_call(&afs_RXFSStoreData64_as_Status,
1356 				   (4 + 6 + 3 * 2) * 4,
1357 				   (21 + 6) * 4);
1358 	if (!call)
1359 		return -ENOMEM;
1360 
1361 	call->key = key;
1362 	call->reply = vnode;
1363 	call->service_id = FS_SERVICE;
1364 	call->port = htons(AFS_FS_PORT);
1365 	call->store_version = vnode->status.data_version + 1;
1366 	call->operation_ID = FSSTOREDATA;
1367 
1368 	/* marshall the parameters */
1369 	bp = call->request;
1370 	*bp++ = htonl(FSSTOREDATA64);
1371 	*bp++ = htonl(vnode->fid.vid);
1372 	*bp++ = htonl(vnode->fid.vnode);
1373 	*bp++ = htonl(vnode->fid.unique);
1374 
1375 	xdr_encode_AFS_StoreStatus(&bp, attr);
1376 
1377 	*bp++ = 0;				/* position of start of write */
1378 	*bp++ = 0;
1379 	*bp++ = 0;				/* size of write */
1380 	*bp++ = 0;
1381 	*bp++ = htonl(attr->ia_size >> 32);	/* new file length */
1382 	*bp++ = htonl((u32) attr->ia_size);
1383 
1384 	return afs_make_call(&server->addr, call, GFP_NOFS, wait_mode);
1385 }
1386 
1387 /*
1388  * set the attributes on a file, using FS.StoreData rather than FS.StoreStatus
1389  * so as to alter the file size also
1390  */
afs_fs_setattr_size(struct afs_server * server,struct key * key,struct afs_vnode * vnode,struct iattr * attr,const struct afs_wait_mode * wait_mode)1391 static int afs_fs_setattr_size(struct afs_server *server, struct key *key,
1392 			       struct afs_vnode *vnode, struct iattr *attr,
1393 			       const struct afs_wait_mode *wait_mode)
1394 {
1395 	struct afs_call *call;
1396 	__be32 *bp;
1397 
1398 	_enter(",%x,{%x:%u},,",
1399 	       key_serial(key), vnode->fid.vid, vnode->fid.vnode);
1400 
1401 	ASSERT(attr->ia_valid & ATTR_SIZE);
1402 	if (attr->ia_size >> 32)
1403 		return afs_fs_setattr_size64(server, key, vnode, attr,
1404 					     wait_mode);
1405 
1406 	call = afs_alloc_flat_call(&afs_RXFSStoreData_as_Status,
1407 				   (4 + 6 + 3) * 4,
1408 				   (21 + 6) * 4);
1409 	if (!call)
1410 		return -ENOMEM;
1411 
1412 	call->key = key;
1413 	call->reply = vnode;
1414 	call->service_id = FS_SERVICE;
1415 	call->port = htons(AFS_FS_PORT);
1416 	call->store_version = vnode->status.data_version + 1;
1417 	call->operation_ID = FSSTOREDATA;
1418 
1419 	/* marshall the parameters */
1420 	bp = call->request;
1421 	*bp++ = htonl(FSSTOREDATA);
1422 	*bp++ = htonl(vnode->fid.vid);
1423 	*bp++ = htonl(vnode->fid.vnode);
1424 	*bp++ = htonl(vnode->fid.unique);
1425 
1426 	xdr_encode_AFS_StoreStatus(&bp, attr);
1427 
1428 	*bp++ = 0;				/* position of start of write */
1429 	*bp++ = 0;				/* size of write */
1430 	*bp++ = htonl(attr->ia_size);		/* new file length */
1431 
1432 	return afs_make_call(&server->addr, call, GFP_NOFS, wait_mode);
1433 }
1434 
1435 /*
1436  * set the attributes on a file, using FS.StoreData if there's a change in file
1437  * size, and FS.StoreStatus otherwise
1438  */
afs_fs_setattr(struct afs_server * server,struct key * key,struct afs_vnode * vnode,struct iattr * attr,const struct afs_wait_mode * wait_mode)1439 int afs_fs_setattr(struct afs_server *server, struct key *key,
1440 		   struct afs_vnode *vnode, struct iattr *attr,
1441 		   const struct afs_wait_mode *wait_mode)
1442 {
1443 	struct afs_call *call;
1444 	__be32 *bp;
1445 
1446 	if (attr->ia_valid & ATTR_SIZE)
1447 		return afs_fs_setattr_size(server, key, vnode, attr,
1448 					   wait_mode);
1449 
1450 	_enter(",%x,{%x:%u},,",
1451 	       key_serial(key), vnode->fid.vid, vnode->fid.vnode);
1452 
1453 	call = afs_alloc_flat_call(&afs_RXFSStoreStatus,
1454 				   (4 + 6) * 4,
1455 				   (21 + 6) * 4);
1456 	if (!call)
1457 		return -ENOMEM;
1458 
1459 	call->key = key;
1460 	call->reply = vnode;
1461 	call->service_id = FS_SERVICE;
1462 	call->port = htons(AFS_FS_PORT);
1463 	call->operation_ID = FSSTORESTATUS;
1464 
1465 	/* marshall the parameters */
1466 	bp = call->request;
1467 	*bp++ = htonl(FSSTORESTATUS);
1468 	*bp++ = htonl(vnode->fid.vid);
1469 	*bp++ = htonl(vnode->fid.vnode);
1470 	*bp++ = htonl(vnode->fid.unique);
1471 
1472 	xdr_encode_AFS_StoreStatus(&bp, attr);
1473 
1474 	return afs_make_call(&server->addr, call, GFP_NOFS, wait_mode);
1475 }
1476 
1477 /*
1478  * deliver reply data to an FS.GetVolumeStatus
1479  */
afs_deliver_fs_get_volume_status(struct afs_call * call,struct sk_buff * skb,bool last)1480 static int afs_deliver_fs_get_volume_status(struct afs_call *call,
1481 					    struct sk_buff *skb, bool last)
1482 {
1483 	const __be32 *bp;
1484 	char *p;
1485 	int ret;
1486 
1487 	_enter("{%u},{%u},%d", call->unmarshall, skb->len, last);
1488 
1489 	switch (call->unmarshall) {
1490 	case 0:
1491 		call->offset = 0;
1492 		call->unmarshall++;
1493 
1494 		/* extract the returned status record */
1495 	case 1:
1496 		_debug("extract status");
1497 		ret = afs_extract_data(call, skb, last, call->buffer,
1498 				       12 * 4);
1499 		switch (ret) {
1500 		case 0:		break;
1501 		case -EAGAIN:	return 0;
1502 		default:	return ret;
1503 		}
1504 
1505 		bp = call->buffer;
1506 		xdr_decode_AFSFetchVolumeStatus(&bp, call->reply2);
1507 		call->offset = 0;
1508 		call->unmarshall++;
1509 
1510 		/* extract the volume name length */
1511 	case 2:
1512 		ret = afs_extract_data(call, skb, last, &call->tmp, 4);
1513 		switch (ret) {
1514 		case 0:		break;
1515 		case -EAGAIN:	return 0;
1516 		default:	return ret;
1517 		}
1518 
1519 		call->count = ntohl(call->tmp);
1520 		_debug("volname length: %u", call->count);
1521 		if (call->count >= AFSNAMEMAX)
1522 			return -EBADMSG;
1523 		call->offset = 0;
1524 		call->unmarshall++;
1525 
1526 		/* extract the volume name */
1527 	case 3:
1528 		_debug("extract volname");
1529 		if (call->count > 0) {
1530 			ret = afs_extract_data(call, skb, last, call->reply3,
1531 					       call->count);
1532 			switch (ret) {
1533 			case 0:		break;
1534 			case -EAGAIN:	return 0;
1535 			default:	return ret;
1536 			}
1537 		}
1538 
1539 		p = call->reply3;
1540 		p[call->count] = 0;
1541 		_debug("volname '%s'", p);
1542 
1543 		call->offset = 0;
1544 		call->unmarshall++;
1545 
1546 		/* extract the volume name padding */
1547 		if ((call->count & 3) == 0) {
1548 			call->unmarshall++;
1549 			goto no_volname_padding;
1550 		}
1551 		call->count = 4 - (call->count & 3);
1552 
1553 	case 4:
1554 		ret = afs_extract_data(call, skb, last, call->buffer,
1555 				       call->count);
1556 		switch (ret) {
1557 		case 0:		break;
1558 		case -EAGAIN:	return 0;
1559 		default:	return ret;
1560 		}
1561 
1562 		call->offset = 0;
1563 		call->unmarshall++;
1564 	no_volname_padding:
1565 
1566 		/* extract the offline message length */
1567 	case 5:
1568 		ret = afs_extract_data(call, skb, last, &call->tmp, 4);
1569 		switch (ret) {
1570 		case 0:		break;
1571 		case -EAGAIN:	return 0;
1572 		default:	return ret;
1573 		}
1574 
1575 		call->count = ntohl(call->tmp);
1576 		_debug("offline msg length: %u", call->count);
1577 		if (call->count >= AFSNAMEMAX)
1578 			return -EBADMSG;
1579 		call->offset = 0;
1580 		call->unmarshall++;
1581 
1582 		/* extract the offline message */
1583 	case 6:
1584 		_debug("extract offline");
1585 		if (call->count > 0) {
1586 			ret = afs_extract_data(call, skb, last, call->reply3,
1587 					       call->count);
1588 			switch (ret) {
1589 			case 0:		break;
1590 			case -EAGAIN:	return 0;
1591 			default:	return ret;
1592 			}
1593 		}
1594 
1595 		p = call->reply3;
1596 		p[call->count] = 0;
1597 		_debug("offline '%s'", p);
1598 
1599 		call->offset = 0;
1600 		call->unmarshall++;
1601 
1602 		/* extract the offline message padding */
1603 		if ((call->count & 3) == 0) {
1604 			call->unmarshall++;
1605 			goto no_offline_padding;
1606 		}
1607 		call->count = 4 - (call->count & 3);
1608 
1609 	case 7:
1610 		ret = afs_extract_data(call, skb, last, call->buffer,
1611 				       call->count);
1612 		switch (ret) {
1613 		case 0:		break;
1614 		case -EAGAIN:	return 0;
1615 		default:	return ret;
1616 		}
1617 
1618 		call->offset = 0;
1619 		call->unmarshall++;
1620 	no_offline_padding:
1621 
1622 		/* extract the message of the day length */
1623 	case 8:
1624 		ret = afs_extract_data(call, skb, last, &call->tmp, 4);
1625 		switch (ret) {
1626 		case 0:		break;
1627 		case -EAGAIN:	return 0;
1628 		default:	return ret;
1629 		}
1630 
1631 		call->count = ntohl(call->tmp);
1632 		_debug("motd length: %u", call->count);
1633 		if (call->count >= AFSNAMEMAX)
1634 			return -EBADMSG;
1635 		call->offset = 0;
1636 		call->unmarshall++;
1637 
1638 		/* extract the message of the day */
1639 	case 9:
1640 		_debug("extract motd");
1641 		if (call->count > 0) {
1642 			ret = afs_extract_data(call, skb, last, call->reply3,
1643 					       call->count);
1644 			switch (ret) {
1645 			case 0:		break;
1646 			case -EAGAIN:	return 0;
1647 			default:	return ret;
1648 			}
1649 		}
1650 
1651 		p = call->reply3;
1652 		p[call->count] = 0;
1653 		_debug("motd '%s'", p);
1654 
1655 		call->offset = 0;
1656 		call->unmarshall++;
1657 
1658 		/* extract the message of the day padding */
1659 		if ((call->count & 3) == 0) {
1660 			call->unmarshall++;
1661 			goto no_motd_padding;
1662 		}
1663 		call->count = 4 - (call->count & 3);
1664 
1665 	case 10:
1666 		ret = afs_extract_data(call, skb, last, call->buffer,
1667 				       call->count);
1668 		switch (ret) {
1669 		case 0:		break;
1670 		case -EAGAIN:	return 0;
1671 		default:	return ret;
1672 		}
1673 
1674 		call->offset = 0;
1675 		call->unmarshall++;
1676 	no_motd_padding:
1677 
1678 	case 11:
1679 		_debug("trailer %d", skb->len);
1680 		if (skb->len != 0)
1681 			return -EBADMSG;
1682 		break;
1683 	}
1684 
1685 	if (!last)
1686 		return 0;
1687 
1688 	_leave(" = 0 [done]");
1689 	return 0;
1690 }
1691 
1692 /*
1693  * destroy an FS.GetVolumeStatus call
1694  */
afs_get_volume_status_call_destructor(struct afs_call * call)1695 static void afs_get_volume_status_call_destructor(struct afs_call *call)
1696 {
1697 	kfree(call->reply3);
1698 	call->reply3 = NULL;
1699 	afs_flat_call_destructor(call);
1700 }
1701 
1702 /*
1703  * FS.GetVolumeStatus operation type
1704  */
1705 static const struct afs_call_type afs_RXFSGetVolumeStatus = {
1706 	.name		= "FS.GetVolumeStatus",
1707 	.deliver	= afs_deliver_fs_get_volume_status,
1708 	.abort_to_error	= afs_abort_to_error,
1709 	.destructor	= afs_get_volume_status_call_destructor,
1710 };
1711 
1712 /*
1713  * fetch the status of a volume
1714  */
afs_fs_get_volume_status(struct afs_server * server,struct key * key,struct afs_vnode * vnode,struct afs_volume_status * vs,const struct afs_wait_mode * wait_mode)1715 int afs_fs_get_volume_status(struct afs_server *server,
1716 			     struct key *key,
1717 			     struct afs_vnode *vnode,
1718 			     struct afs_volume_status *vs,
1719 			     const struct afs_wait_mode *wait_mode)
1720 {
1721 	struct afs_call *call;
1722 	__be32 *bp;
1723 	void *tmpbuf;
1724 
1725 	_enter("");
1726 
1727 	tmpbuf = kmalloc(AFSOPAQUEMAX, GFP_KERNEL);
1728 	if (!tmpbuf)
1729 		return -ENOMEM;
1730 
1731 	call = afs_alloc_flat_call(&afs_RXFSGetVolumeStatus, 2 * 4, 12 * 4);
1732 	if (!call) {
1733 		kfree(tmpbuf);
1734 		return -ENOMEM;
1735 	}
1736 
1737 	call->key = key;
1738 	call->reply = vnode;
1739 	call->reply2 = vs;
1740 	call->reply3 = tmpbuf;
1741 	call->service_id = FS_SERVICE;
1742 	call->port = htons(AFS_FS_PORT);
1743 
1744 	/* marshall the parameters */
1745 	bp = call->request;
1746 	bp[0] = htonl(FSGETVOLUMESTATUS);
1747 	bp[1] = htonl(vnode->fid.vid);
1748 
1749 	return afs_make_call(&server->addr, call, GFP_NOFS, wait_mode);
1750 }
1751 
1752 /*
1753  * deliver reply data to an FS.SetLock, FS.ExtendLock or FS.ReleaseLock
1754  */
afs_deliver_fs_xxxx_lock(struct afs_call * call,struct sk_buff * skb,bool last)1755 static int afs_deliver_fs_xxxx_lock(struct afs_call *call,
1756 				    struct sk_buff *skb, bool last)
1757 {
1758 	const __be32 *bp;
1759 
1760 	_enter("{%u},{%u},%d", call->unmarshall, skb->len, last);
1761 
1762 	afs_transfer_reply(call, skb);
1763 	if (!last)
1764 		return 0;
1765 
1766 	if (call->reply_size != call->reply_max)
1767 		return -EBADMSG;
1768 
1769 	/* unmarshall the reply once we've received all of it */
1770 	bp = call->buffer;
1771 	/* xdr_decode_AFSVolSync(&bp, call->replyX); */
1772 
1773 	_leave(" = 0 [done]");
1774 	return 0;
1775 }
1776 
1777 /*
1778  * FS.SetLock operation type
1779  */
1780 static const struct afs_call_type afs_RXFSSetLock = {
1781 	.name		= "FS.SetLock",
1782 	.deliver	= afs_deliver_fs_xxxx_lock,
1783 	.abort_to_error	= afs_abort_to_error,
1784 	.destructor	= afs_flat_call_destructor,
1785 };
1786 
1787 /*
1788  * FS.ExtendLock operation type
1789  */
1790 static const struct afs_call_type afs_RXFSExtendLock = {
1791 	.name		= "FS.ExtendLock",
1792 	.deliver	= afs_deliver_fs_xxxx_lock,
1793 	.abort_to_error	= afs_abort_to_error,
1794 	.destructor	= afs_flat_call_destructor,
1795 };
1796 
1797 /*
1798  * FS.ReleaseLock operation type
1799  */
1800 static const struct afs_call_type afs_RXFSReleaseLock = {
1801 	.name		= "FS.ReleaseLock",
1802 	.deliver	= afs_deliver_fs_xxxx_lock,
1803 	.abort_to_error	= afs_abort_to_error,
1804 	.destructor	= afs_flat_call_destructor,
1805 };
1806 
1807 /*
1808  * get a lock on a file
1809  */
afs_fs_set_lock(struct afs_server * server,struct key * key,struct afs_vnode * vnode,afs_lock_type_t type,const struct afs_wait_mode * wait_mode)1810 int afs_fs_set_lock(struct afs_server *server,
1811 		    struct key *key,
1812 		    struct afs_vnode *vnode,
1813 		    afs_lock_type_t type,
1814 		    const struct afs_wait_mode *wait_mode)
1815 {
1816 	struct afs_call *call;
1817 	__be32 *bp;
1818 
1819 	_enter("");
1820 
1821 	call = afs_alloc_flat_call(&afs_RXFSSetLock, 5 * 4, 6 * 4);
1822 	if (!call)
1823 		return -ENOMEM;
1824 
1825 	call->key = key;
1826 	call->reply = vnode;
1827 	call->service_id = FS_SERVICE;
1828 	call->port = htons(AFS_FS_PORT);
1829 
1830 	/* marshall the parameters */
1831 	bp = call->request;
1832 	*bp++ = htonl(FSSETLOCK);
1833 	*bp++ = htonl(vnode->fid.vid);
1834 	*bp++ = htonl(vnode->fid.vnode);
1835 	*bp++ = htonl(vnode->fid.unique);
1836 	*bp++ = htonl(type);
1837 
1838 	return afs_make_call(&server->addr, call, GFP_NOFS, wait_mode);
1839 }
1840 
1841 /*
1842  * extend a lock on a file
1843  */
afs_fs_extend_lock(struct afs_server * server,struct key * key,struct afs_vnode * vnode,const struct afs_wait_mode * wait_mode)1844 int afs_fs_extend_lock(struct afs_server *server,
1845 		       struct key *key,
1846 		       struct afs_vnode *vnode,
1847 		       const struct afs_wait_mode *wait_mode)
1848 {
1849 	struct afs_call *call;
1850 	__be32 *bp;
1851 
1852 	_enter("");
1853 
1854 	call = afs_alloc_flat_call(&afs_RXFSExtendLock, 4 * 4, 6 * 4);
1855 	if (!call)
1856 		return -ENOMEM;
1857 
1858 	call->key = key;
1859 	call->reply = vnode;
1860 	call->service_id = FS_SERVICE;
1861 	call->port = htons(AFS_FS_PORT);
1862 
1863 	/* marshall the parameters */
1864 	bp = call->request;
1865 	*bp++ = htonl(FSEXTENDLOCK);
1866 	*bp++ = htonl(vnode->fid.vid);
1867 	*bp++ = htonl(vnode->fid.vnode);
1868 	*bp++ = htonl(vnode->fid.unique);
1869 
1870 	return afs_make_call(&server->addr, call, GFP_NOFS, wait_mode);
1871 }
1872 
1873 /*
1874  * release a lock on a file
1875  */
afs_fs_release_lock(struct afs_server * server,struct key * key,struct afs_vnode * vnode,const struct afs_wait_mode * wait_mode)1876 int afs_fs_release_lock(struct afs_server *server,
1877 			struct key *key,
1878 			struct afs_vnode *vnode,
1879 			const struct afs_wait_mode *wait_mode)
1880 {
1881 	struct afs_call *call;
1882 	__be32 *bp;
1883 
1884 	_enter("");
1885 
1886 	call = afs_alloc_flat_call(&afs_RXFSReleaseLock, 4 * 4, 6 * 4);
1887 	if (!call)
1888 		return -ENOMEM;
1889 
1890 	call->key = key;
1891 	call->reply = vnode;
1892 	call->service_id = FS_SERVICE;
1893 	call->port = htons(AFS_FS_PORT);
1894 
1895 	/* marshall the parameters */
1896 	bp = call->request;
1897 	*bp++ = htonl(FSRELEASELOCK);
1898 	*bp++ = htonl(vnode->fid.vid);
1899 	*bp++ = htonl(vnode->fid.vnode);
1900 	*bp++ = htonl(vnode->fid.unique);
1901 
1902 	return afs_make_call(&server->addr, call, GFP_NOFS, wait_mode);
1903 }
1904