Linux Audio

Check our new training course

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