cmservice.c 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617
  1. // SPDX-License-Identifier: GPL-2.0-or-later
  2. /* AFS Cache Manager Service
  3. *
  4. * Copyright (C) 2002 Red Hat, Inc. All Rights Reserved.
  5. * Written by David Howells (dhowells@redhat.com)
  6. */
  7. #include <linux/module.h>
  8. #include <linux/init.h>
  9. #include <linux/slab.h>
  10. #include <linux/sched.h>
  11. #include <linux/ip.h>
  12. #include "internal.h"
  13. #include "afs_cm.h"
  14. #include "protocol_yfs.h"
  15. #define RXRPC_TRACE_ONLY_DEFINE_ENUMS
  16. #include <trace/events/rxrpc.h>
  17. static int afs_deliver_cb_init_call_back_state(struct afs_call *);
  18. static int afs_deliver_cb_init_call_back_state3(struct afs_call *);
  19. static int afs_deliver_cb_probe(struct afs_call *);
  20. static int afs_deliver_cb_callback(struct afs_call *);
  21. static int afs_deliver_cb_probe_uuid(struct afs_call *);
  22. static int afs_deliver_cb_tell_me_about_yourself(struct afs_call *);
  23. static void afs_cm_destructor(struct afs_call *);
  24. static void SRXAFSCB_CallBack(struct work_struct *);
  25. static void SRXAFSCB_InitCallBackState(struct work_struct *);
  26. static void SRXAFSCB_Probe(struct work_struct *);
  27. static void SRXAFSCB_ProbeUuid(struct work_struct *);
  28. static void SRXAFSCB_TellMeAboutYourself(struct work_struct *);
  29. static int afs_deliver_yfs_cb_callback(struct afs_call *);
  30. /*
  31. * CB.CallBack operation type
  32. */
  33. static const struct afs_call_type afs_SRXCBCallBack = {
  34. .name = "CB.CallBack",
  35. .deliver = afs_deliver_cb_callback,
  36. .destructor = afs_cm_destructor,
  37. .work = SRXAFSCB_CallBack,
  38. };
  39. /*
  40. * CB.InitCallBackState operation type
  41. */
  42. static const struct afs_call_type afs_SRXCBInitCallBackState = {
  43. .name = "CB.InitCallBackState",
  44. .deliver = afs_deliver_cb_init_call_back_state,
  45. .destructor = afs_cm_destructor,
  46. .work = SRXAFSCB_InitCallBackState,
  47. };
  48. /*
  49. * CB.InitCallBackState3 operation type
  50. */
  51. static const struct afs_call_type afs_SRXCBInitCallBackState3 = {
  52. .name = "CB.InitCallBackState3",
  53. .deliver = afs_deliver_cb_init_call_back_state3,
  54. .destructor = afs_cm_destructor,
  55. .work = SRXAFSCB_InitCallBackState,
  56. };
  57. /*
  58. * CB.Probe operation type
  59. */
  60. static const struct afs_call_type afs_SRXCBProbe = {
  61. .name = "CB.Probe",
  62. .deliver = afs_deliver_cb_probe,
  63. .destructor = afs_cm_destructor,
  64. .work = SRXAFSCB_Probe,
  65. };
  66. /*
  67. * CB.ProbeUuid operation type
  68. */
  69. static const struct afs_call_type afs_SRXCBProbeUuid = {
  70. .name = "CB.ProbeUuid",
  71. .deliver = afs_deliver_cb_probe_uuid,
  72. .destructor = afs_cm_destructor,
  73. .work = SRXAFSCB_ProbeUuid,
  74. };
  75. /*
  76. * CB.TellMeAboutYourself operation type
  77. */
  78. static const struct afs_call_type afs_SRXCBTellMeAboutYourself = {
  79. .name = "CB.TellMeAboutYourself",
  80. .deliver = afs_deliver_cb_tell_me_about_yourself,
  81. .destructor = afs_cm_destructor,
  82. .work = SRXAFSCB_TellMeAboutYourself,
  83. };
  84. /*
  85. * YFS CB.CallBack operation type
  86. */
  87. static const struct afs_call_type afs_SRXYFSCB_CallBack = {
  88. .name = "YFSCB.CallBack",
  89. .deliver = afs_deliver_yfs_cb_callback,
  90. .destructor = afs_cm_destructor,
  91. .work = SRXAFSCB_CallBack,
  92. };
  93. /*
  94. * route an incoming cache manager call
  95. * - return T if supported, F if not
  96. */
  97. bool afs_cm_incoming_call(struct afs_call *call)
  98. {
  99. _enter("{%u, CB.OP %u}", call->service_id, call->operation_ID);
  100. switch (call->operation_ID) {
  101. case CBCallBack:
  102. call->type = &afs_SRXCBCallBack;
  103. return true;
  104. case CBInitCallBackState:
  105. call->type = &afs_SRXCBInitCallBackState;
  106. return true;
  107. case CBInitCallBackState3:
  108. call->type = &afs_SRXCBInitCallBackState3;
  109. return true;
  110. case CBProbe:
  111. call->type = &afs_SRXCBProbe;
  112. return true;
  113. case CBProbeUuid:
  114. call->type = &afs_SRXCBProbeUuid;
  115. return true;
  116. case CBTellMeAboutYourself:
  117. call->type = &afs_SRXCBTellMeAboutYourself;
  118. return true;
  119. case YFSCBCallBack:
  120. if (call->service_id != YFS_CM_SERVICE)
  121. return false;
  122. call->type = &afs_SRXYFSCB_CallBack;
  123. return true;
  124. default:
  125. return false;
  126. }
  127. }
  128. /*
  129. * Clean up a cache manager call.
  130. */
  131. static void afs_cm_destructor(struct afs_call *call)
  132. {
  133. kfree(call->buffer);
  134. call->buffer = NULL;
  135. }
  136. /*
  137. * Abort a service call from within an action function.
  138. */
  139. static void afs_abort_service_call(struct afs_call *call, u32 abort_code, int error,
  140. enum rxrpc_abort_reason why)
  141. {
  142. rxrpc_kernel_abort_call(call->net->socket, call->rxcall,
  143. abort_code, error, why);
  144. afs_set_call_complete(call, error, 0);
  145. }
  146. /*
  147. * The server supplied a list of callbacks that it wanted to break.
  148. */
  149. static void SRXAFSCB_CallBack(struct work_struct *work)
  150. {
  151. struct afs_call *call = container_of(work, struct afs_call, work);
  152. _enter("");
  153. /* We need to break the callbacks before sending the reply as the
  154. * server holds up change visibility till it receives our reply so as
  155. * to maintain cache coherency.
  156. */
  157. if (call->server) {
  158. trace_afs_server(call->server->debug_id,
  159. refcount_read(&call->server->ref),
  160. atomic_read(&call->server->active),
  161. afs_server_trace_callback);
  162. afs_break_callbacks(call->server, call->count, call->request);
  163. }
  164. afs_send_empty_reply(call);
  165. afs_put_call(call);
  166. _leave("");
  167. }
  168. /*
  169. * deliver request data to a CB.CallBack call
  170. */
  171. static int afs_deliver_cb_callback(struct afs_call *call)
  172. {
  173. struct afs_callback_break *cb;
  174. __be32 *bp;
  175. int ret, loop;
  176. _enter("{%u}", call->unmarshall);
  177. switch (call->unmarshall) {
  178. case 0:
  179. afs_extract_to_tmp(call);
  180. call->unmarshall++;
  181. /* extract the FID array and its count in two steps */
  182. fallthrough;
  183. case 1:
  184. _debug("extract FID count");
  185. ret = afs_extract_data(call, true);
  186. if (ret < 0)
  187. return ret;
  188. call->count = ntohl(call->tmp);
  189. _debug("FID count: %u", call->count);
  190. if (call->count > AFSCBMAX)
  191. return afs_protocol_error(call, afs_eproto_cb_fid_count);
  192. call->buffer = kmalloc(array3_size(call->count, 3, 4),
  193. GFP_KERNEL);
  194. if (!call->buffer)
  195. return -ENOMEM;
  196. afs_extract_to_buf(call, call->count * 3 * 4);
  197. call->unmarshall++;
  198. fallthrough;
  199. case 2:
  200. _debug("extract FID array");
  201. ret = afs_extract_data(call, true);
  202. if (ret < 0)
  203. return ret;
  204. _debug("unmarshall FID array");
  205. call->request = kzalloc_objs(struct afs_callback_break,
  206. call->count);
  207. if (!call->request)
  208. return -ENOMEM;
  209. cb = call->request;
  210. bp = call->buffer;
  211. for (loop = call->count; loop > 0; loop--, cb++) {
  212. cb->fid.vid = ntohl(*bp++);
  213. cb->fid.vnode = ntohl(*bp++);
  214. cb->fid.unique = ntohl(*bp++);
  215. }
  216. afs_extract_to_tmp(call);
  217. call->unmarshall++;
  218. /* extract the callback array and its count in two steps */
  219. fallthrough;
  220. case 3:
  221. _debug("extract CB count");
  222. ret = afs_extract_data(call, true);
  223. if (ret < 0)
  224. return ret;
  225. call->count2 = ntohl(call->tmp);
  226. _debug("CB count: %u", call->count2);
  227. if (call->count2 != call->count && call->count2 != 0)
  228. return afs_protocol_error(call, afs_eproto_cb_count);
  229. call->iter = &call->def_iter;
  230. iov_iter_discard(&call->def_iter, ITER_DEST, call->count2 * 3 * 4);
  231. call->unmarshall++;
  232. fallthrough;
  233. case 4:
  234. _debug("extract discard %zu/%u",
  235. iov_iter_count(call->iter), call->count2 * 3 * 4);
  236. ret = afs_extract_data(call, false);
  237. if (ret < 0)
  238. return ret;
  239. call->unmarshall++;
  240. fallthrough;
  241. case 5:
  242. break;
  243. }
  244. if (!afs_check_call_state(call, AFS_CALL_SV_REPLYING))
  245. return afs_io_error(call, afs_io_error_cm_reply);
  246. return 0;
  247. }
  248. /*
  249. * allow the fileserver to request callback state (re-)initialisation
  250. */
  251. static void SRXAFSCB_InitCallBackState(struct work_struct *work)
  252. {
  253. struct afs_call *call = container_of(work, struct afs_call, work);
  254. _enter("{%p}", call->server);
  255. if (call->server)
  256. afs_init_callback_state(call->server);
  257. afs_send_empty_reply(call);
  258. afs_put_call(call);
  259. _leave("");
  260. }
  261. /*
  262. * deliver request data to a CB.InitCallBackState call
  263. */
  264. static int afs_deliver_cb_init_call_back_state(struct afs_call *call)
  265. {
  266. _enter("");
  267. afs_extract_discard(call, 0);
  268. return afs_extract_data(call, false);
  269. }
  270. /*
  271. * deliver request data to a CB.InitCallBackState3 call
  272. */
  273. static int afs_deliver_cb_init_call_back_state3(struct afs_call *call)
  274. {
  275. struct afs_uuid *r;
  276. unsigned loop;
  277. __be32 *b;
  278. int ret;
  279. _enter("{%u}", call->unmarshall);
  280. switch (call->unmarshall) {
  281. case 0:
  282. call->buffer = kmalloc_array(11, sizeof(__be32), GFP_KERNEL);
  283. if (!call->buffer)
  284. return -ENOMEM;
  285. afs_extract_to_buf(call, 11 * sizeof(__be32));
  286. call->unmarshall++;
  287. fallthrough;
  288. case 1:
  289. _debug("extract UUID");
  290. ret = afs_extract_data(call, false);
  291. switch (ret) {
  292. case 0: break;
  293. case -EAGAIN: return 0;
  294. default: return ret;
  295. }
  296. _debug("unmarshall UUID");
  297. call->request = kmalloc_obj(struct afs_uuid);
  298. if (!call->request)
  299. return -ENOMEM;
  300. b = call->buffer;
  301. r = call->request;
  302. r->time_low = b[0];
  303. r->time_mid = htons(ntohl(b[1]));
  304. r->time_hi_and_version = htons(ntohl(b[2]));
  305. r->clock_seq_hi_and_reserved = ntohl(b[3]);
  306. r->clock_seq_low = ntohl(b[4]);
  307. for (loop = 0; loop < 6; loop++)
  308. r->node[loop] = ntohl(b[loop + 5]);
  309. call->unmarshall++;
  310. fallthrough;
  311. case 2:
  312. break;
  313. }
  314. if (!afs_check_call_state(call, AFS_CALL_SV_REPLYING))
  315. return afs_io_error(call, afs_io_error_cm_reply);
  316. if (memcmp(call->request, &call->server->_uuid, sizeof(call->server->_uuid)) != 0) {
  317. pr_notice("Callback UUID does not match fileserver UUID\n");
  318. trace_afs_cm_no_server_u(call, call->request);
  319. return 0;
  320. }
  321. return 0;
  322. }
  323. /*
  324. * allow the fileserver to see if the cache manager is still alive
  325. */
  326. static void SRXAFSCB_Probe(struct work_struct *work)
  327. {
  328. struct afs_call *call = container_of(work, struct afs_call, work);
  329. _enter("");
  330. afs_send_empty_reply(call);
  331. afs_put_call(call);
  332. _leave("");
  333. }
  334. /*
  335. * deliver request data to a CB.Probe call
  336. */
  337. static int afs_deliver_cb_probe(struct afs_call *call)
  338. {
  339. int ret;
  340. _enter("");
  341. afs_extract_discard(call, 0);
  342. ret = afs_extract_data(call, false);
  343. if (ret < 0)
  344. return ret;
  345. if (!afs_check_call_state(call, AFS_CALL_SV_REPLYING))
  346. return afs_io_error(call, afs_io_error_cm_reply);
  347. return 0;
  348. }
  349. /*
  350. * Allow the fileserver to quickly find out if the cache manager has been
  351. * rebooted.
  352. */
  353. static void SRXAFSCB_ProbeUuid(struct work_struct *work)
  354. {
  355. struct afs_call *call = container_of(work, struct afs_call, work);
  356. struct afs_uuid *r = call->request;
  357. _enter("");
  358. if (memcmp(r, &call->net->uuid, sizeof(call->net->uuid)) == 0)
  359. afs_send_empty_reply(call);
  360. else
  361. afs_abort_service_call(call, 1, 1, afs_abort_probeuuid_negative);
  362. afs_put_call(call);
  363. _leave("");
  364. }
  365. /*
  366. * deliver request data to a CB.ProbeUuid call
  367. */
  368. static int afs_deliver_cb_probe_uuid(struct afs_call *call)
  369. {
  370. struct afs_uuid *r;
  371. unsigned loop;
  372. __be32 *b;
  373. int ret;
  374. _enter("{%u}", call->unmarshall);
  375. switch (call->unmarshall) {
  376. case 0:
  377. call->buffer = kmalloc_array(11, sizeof(__be32), GFP_KERNEL);
  378. if (!call->buffer)
  379. return -ENOMEM;
  380. afs_extract_to_buf(call, 11 * sizeof(__be32));
  381. call->unmarshall++;
  382. fallthrough;
  383. case 1:
  384. _debug("extract UUID");
  385. ret = afs_extract_data(call, false);
  386. switch (ret) {
  387. case 0: break;
  388. case -EAGAIN: return 0;
  389. default: return ret;
  390. }
  391. _debug("unmarshall UUID");
  392. call->request = kmalloc_obj(struct afs_uuid);
  393. if (!call->request)
  394. return -ENOMEM;
  395. b = call->buffer;
  396. r = call->request;
  397. r->time_low = b[0];
  398. r->time_mid = htons(ntohl(b[1]));
  399. r->time_hi_and_version = htons(ntohl(b[2]));
  400. r->clock_seq_hi_and_reserved = ntohl(b[3]);
  401. r->clock_seq_low = ntohl(b[4]);
  402. for (loop = 0; loop < 6; loop++)
  403. r->node[loop] = ntohl(b[loop + 5]);
  404. call->unmarshall++;
  405. fallthrough;
  406. case 2:
  407. break;
  408. }
  409. if (!afs_check_call_state(call, AFS_CALL_SV_REPLYING))
  410. return afs_io_error(call, afs_io_error_cm_reply);
  411. return 0;
  412. }
  413. /*
  414. * allow the fileserver to ask about the cache manager's capabilities
  415. */
  416. static void SRXAFSCB_TellMeAboutYourself(struct work_struct *work)
  417. {
  418. struct afs_call *call = container_of(work, struct afs_call, work);
  419. int loop;
  420. struct {
  421. struct /* InterfaceAddr */ {
  422. __be32 nifs;
  423. __be32 uuid[11];
  424. __be32 ifaddr[32];
  425. __be32 netmask[32];
  426. __be32 mtu[32];
  427. } ia;
  428. struct /* Capabilities */ {
  429. __be32 capcount;
  430. __be32 caps[1];
  431. } cap;
  432. } reply;
  433. _enter("");
  434. memset(&reply, 0, sizeof(reply));
  435. reply.ia.uuid[0] = call->net->uuid.time_low;
  436. reply.ia.uuid[1] = htonl(ntohs(call->net->uuid.time_mid));
  437. reply.ia.uuid[2] = htonl(ntohs(call->net->uuid.time_hi_and_version));
  438. reply.ia.uuid[3] = htonl((s8) call->net->uuid.clock_seq_hi_and_reserved);
  439. reply.ia.uuid[4] = htonl((s8) call->net->uuid.clock_seq_low);
  440. for (loop = 0; loop < 6; loop++)
  441. reply.ia.uuid[loop + 5] = htonl((s8) call->net->uuid.node[loop]);
  442. reply.cap.capcount = htonl(1);
  443. reply.cap.caps[0] = htonl(AFS_CAP_ERROR_TRANSLATION);
  444. afs_send_simple_reply(call, &reply, sizeof(reply));
  445. afs_put_call(call);
  446. _leave("");
  447. }
  448. /*
  449. * deliver request data to a CB.TellMeAboutYourself call
  450. */
  451. static int afs_deliver_cb_tell_me_about_yourself(struct afs_call *call)
  452. {
  453. int ret;
  454. _enter("");
  455. afs_extract_discard(call, 0);
  456. ret = afs_extract_data(call, false);
  457. if (ret < 0)
  458. return ret;
  459. if (!afs_check_call_state(call, AFS_CALL_SV_REPLYING))
  460. return afs_io_error(call, afs_io_error_cm_reply);
  461. return 0;
  462. }
  463. /*
  464. * deliver request data to a YFS CB.CallBack call
  465. */
  466. static int afs_deliver_yfs_cb_callback(struct afs_call *call)
  467. {
  468. struct afs_callback_break *cb;
  469. struct yfs_xdr_YFSFid *bp;
  470. size_t size;
  471. int ret, loop;
  472. _enter("{%u}", call->unmarshall);
  473. switch (call->unmarshall) {
  474. case 0:
  475. afs_extract_to_tmp(call);
  476. call->unmarshall++;
  477. /* extract the FID array and its count in two steps */
  478. fallthrough;
  479. case 1:
  480. _debug("extract FID count");
  481. ret = afs_extract_data(call, true);
  482. if (ret < 0)
  483. return ret;
  484. call->count = ntohl(call->tmp);
  485. _debug("FID count: %u", call->count);
  486. if (call->count > YFSCBMAX)
  487. return afs_protocol_error(call, afs_eproto_cb_fid_count);
  488. size = array_size(call->count, sizeof(struct yfs_xdr_YFSFid));
  489. call->buffer = kmalloc(size, GFP_KERNEL);
  490. if (!call->buffer)
  491. return -ENOMEM;
  492. afs_extract_to_buf(call, size);
  493. call->unmarshall++;
  494. fallthrough;
  495. case 2:
  496. _debug("extract FID array");
  497. ret = afs_extract_data(call, false);
  498. if (ret < 0)
  499. return ret;
  500. _debug("unmarshall FID array");
  501. call->request = kzalloc_objs(struct afs_callback_break,
  502. call->count);
  503. if (!call->request)
  504. return -ENOMEM;
  505. cb = call->request;
  506. bp = call->buffer;
  507. for (loop = call->count; loop > 0; loop--, cb++) {
  508. cb->fid.vid = xdr_to_u64(bp->volume);
  509. cb->fid.vnode = xdr_to_u64(bp->vnode.lo);
  510. cb->fid.vnode_hi = ntohl(bp->vnode.hi);
  511. cb->fid.unique = ntohl(bp->vnode.unique);
  512. bp++;
  513. }
  514. afs_extract_to_tmp(call);
  515. call->unmarshall++;
  516. fallthrough;
  517. case 3:
  518. break;
  519. }
  520. if (!afs_check_call_state(call, AFS_CALL_SV_REPLYING))
  521. return afs_io_error(call, afs_io_error_cm_reply);
  522. return 0;
  523. }