Linux Audio

Check our new training course

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