nfssvc.c 27 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072
  1. // SPDX-License-Identifier: GPL-2.0
  2. /*
  3. * Central processing for nfsd.
  4. *
  5. * Authors: Olaf Kirch (okir@monad.swb.de)
  6. *
  7. * Copyright (C) 1995, 1996, 1997 Olaf Kirch <okir@monad.swb.de>
  8. */
  9. #include <linux/sched/signal.h>
  10. #include <linux/freezer.h>
  11. #include <linux/module.h>
  12. #include <linux/fs_struct.h>
  13. #include <linux/swap.h>
  14. #include <linux/siphash.h>
  15. #include <linux/sunrpc/stats.h>
  16. #include <linux/sunrpc/svcsock.h>
  17. #include <linux/sunrpc/svc_xprt.h>
  18. #include <linux/lockd/bind.h>
  19. #include <linux/nfsacl.h>
  20. #include <linux/nfslocalio.h>
  21. #include <linux/seq_file.h>
  22. #include <linux/inetdevice.h>
  23. #include <net/addrconf.h>
  24. #include <net/ipv6.h>
  25. #include <net/net_namespace.h>
  26. #include "nfsd.h"
  27. #include "cache.h"
  28. #include "vfs.h"
  29. #include "netns.h"
  30. #include "filecache.h"
  31. #include "trace.h"
  32. #define NFSDDBG_FACILITY NFSDDBG_SVC
  33. atomic_t nfsd_th_cnt = ATOMIC_INIT(0);
  34. static int nfsd(void *vrqstp);
  35. #if defined(CONFIG_NFSD_V2_ACL) || defined(CONFIG_NFSD_V3_ACL)
  36. static int nfsd_acl_rpcbind_set(struct net *,
  37. const struct svc_program *,
  38. u32, int,
  39. unsigned short,
  40. unsigned short);
  41. static __be32 nfsd_acl_init_request(struct svc_rqst *,
  42. const struct svc_program *,
  43. struct svc_process_info *);
  44. #endif
  45. static int nfsd_rpcbind_set(struct net *,
  46. const struct svc_program *,
  47. u32, int,
  48. unsigned short,
  49. unsigned short);
  50. static __be32 nfsd_init_request(struct svc_rqst *,
  51. const struct svc_program *,
  52. struct svc_process_info *);
  53. /*
  54. * nfsd_mutex protects nn->nfsd_serv -- both the pointer itself and some members
  55. * of the svc_serv struct such as ->sv_temp_socks and ->sv_permsocks.
  56. *
  57. * Finally, the nfsd_mutex also protects some of the global variables that are
  58. * accessed when nfsd starts and that are settable via the write_* routines in
  59. * nfsctl.c. In particular:
  60. *
  61. * user_recovery_dirname
  62. * user_lease_time
  63. * nfsd_versions
  64. */
  65. DEFINE_MUTEX(nfsd_mutex);
  66. #if IS_ENABLED(CONFIG_NFS_LOCALIO)
  67. static const struct svc_version *localio_versions[] = {
  68. [1] = &localio_version1,
  69. };
  70. #define NFSD_LOCALIO_NRVERS ARRAY_SIZE(localio_versions)
  71. #endif /* CONFIG_NFS_LOCALIO */
  72. #if defined(CONFIG_NFSD_V2_ACL) || defined(CONFIG_NFSD_V3_ACL)
  73. static const struct svc_version *nfsd_acl_version[] = {
  74. # if defined(CONFIG_NFSD_V2_ACL)
  75. [2] = &nfsd_acl_version2,
  76. # endif
  77. # if defined(CONFIG_NFSD_V3_ACL)
  78. [3] = &nfsd_acl_version3,
  79. # endif
  80. };
  81. #define NFSD_ACL_MINVERS 2
  82. #define NFSD_ACL_NRVERS ARRAY_SIZE(nfsd_acl_version)
  83. #endif /* defined(CONFIG_NFSD_V2_ACL) || defined(CONFIG_NFSD_V3_ACL) */
  84. static const struct svc_version *nfsd_version[NFSD_MAXVERS+1] = {
  85. #if defined(CONFIG_NFSD_V2)
  86. [2] = &nfsd_version2,
  87. #endif
  88. [3] = &nfsd_version3,
  89. #if defined(CONFIG_NFSD_V4)
  90. [4] = &nfsd_version4,
  91. #endif
  92. };
  93. struct svc_program nfsd_programs[] = {
  94. {
  95. .pg_prog = NFS_PROGRAM, /* program number */
  96. .pg_nvers = NFSD_MAXVERS+1, /* nr of entries in nfsd_version */
  97. .pg_vers = nfsd_version, /* version table */
  98. .pg_name = "nfsd", /* program name */
  99. .pg_class = "nfsd", /* authentication class */
  100. .pg_authenticate = svc_set_client, /* export authentication */
  101. .pg_init_request = nfsd_init_request,
  102. .pg_rpcbind_set = nfsd_rpcbind_set,
  103. },
  104. #if defined(CONFIG_NFSD_V2_ACL) || defined(CONFIG_NFSD_V3_ACL)
  105. {
  106. .pg_prog = NFS_ACL_PROGRAM,
  107. .pg_nvers = NFSD_ACL_NRVERS,
  108. .pg_vers = nfsd_acl_version,
  109. .pg_name = "nfsacl",
  110. .pg_class = "nfsd",
  111. .pg_authenticate = svc_set_client,
  112. .pg_init_request = nfsd_acl_init_request,
  113. .pg_rpcbind_set = nfsd_acl_rpcbind_set,
  114. },
  115. #endif /* defined(CONFIG_NFSD_V2_ACL) || defined(CONFIG_NFSD_V3_ACL) */
  116. #if IS_ENABLED(CONFIG_NFS_LOCALIO)
  117. {
  118. .pg_prog = NFS_LOCALIO_PROGRAM,
  119. .pg_nvers = NFSD_LOCALIO_NRVERS,
  120. .pg_vers = localio_versions,
  121. .pg_name = "nfslocalio",
  122. .pg_class = "nfsd",
  123. .pg_authenticate = svc_set_client,
  124. .pg_init_request = svc_generic_init_request,
  125. .pg_rpcbind_set = svc_generic_rpcbind_set,
  126. }
  127. #endif /* CONFIG_NFS_LOCALIO */
  128. };
  129. bool nfsd_support_version(int vers)
  130. {
  131. if (vers >= NFSD_MINVERS && vers <= NFSD_MAXVERS)
  132. return nfsd_version[vers] != NULL;
  133. return false;
  134. }
  135. int nfsd_vers(struct nfsd_net *nn, int vers, enum vers_op change)
  136. {
  137. if (vers < NFSD_MINVERS || vers > NFSD_MAXVERS)
  138. return 0;
  139. switch(change) {
  140. case NFSD_SET:
  141. nn->nfsd_versions[vers] = nfsd_support_version(vers);
  142. break;
  143. case NFSD_CLEAR:
  144. nn->nfsd_versions[vers] = false;
  145. break;
  146. case NFSD_TEST:
  147. return nn->nfsd_versions[vers];
  148. case NFSD_AVAIL:
  149. return nfsd_support_version(vers);
  150. }
  151. return 0;
  152. }
  153. static void
  154. nfsd_adjust_nfsd_versions4(struct nfsd_net *nn)
  155. {
  156. unsigned i;
  157. for (i = 0; i <= NFSD_SUPPORTED_MINOR_VERSION; i++) {
  158. if (nn->nfsd4_minorversions[i])
  159. return;
  160. }
  161. nfsd_vers(nn, 4, NFSD_CLEAR);
  162. }
  163. int nfsd_minorversion(struct nfsd_net *nn, u32 minorversion, enum vers_op change)
  164. {
  165. if (minorversion > NFSD_SUPPORTED_MINOR_VERSION &&
  166. change != NFSD_AVAIL)
  167. return -1;
  168. switch(change) {
  169. case NFSD_SET:
  170. nfsd_vers(nn, 4, NFSD_SET);
  171. nn->nfsd4_minorversions[minorversion] =
  172. nfsd_vers(nn, 4, NFSD_TEST);
  173. break;
  174. case NFSD_CLEAR:
  175. nn->nfsd4_minorversions[minorversion] = false;
  176. nfsd_adjust_nfsd_versions4(nn);
  177. break;
  178. case NFSD_TEST:
  179. return nn->nfsd4_minorversions[minorversion];
  180. case NFSD_AVAIL:
  181. return minorversion <= NFSD_SUPPORTED_MINOR_VERSION &&
  182. nfsd_vers(nn, 4, NFSD_AVAIL);
  183. }
  184. return 0;
  185. }
  186. bool nfsd_net_try_get(struct net *net) __must_hold(rcu)
  187. {
  188. struct nfsd_net *nn = net_generic(net, nfsd_net_id);
  189. return (nn && percpu_ref_tryget_live(&nn->nfsd_net_ref));
  190. }
  191. void nfsd_net_put(struct net *net) __must_hold(rcu)
  192. {
  193. struct nfsd_net *nn = net_generic(net, nfsd_net_id);
  194. percpu_ref_put(&nn->nfsd_net_ref);
  195. }
  196. static void nfsd_net_done(struct percpu_ref *ref)
  197. {
  198. struct nfsd_net *nn = container_of(ref, struct nfsd_net, nfsd_net_ref);
  199. complete(&nn->nfsd_net_confirm_done);
  200. }
  201. static void nfsd_net_free(struct percpu_ref *ref)
  202. {
  203. struct nfsd_net *nn = container_of(ref, struct nfsd_net, nfsd_net_ref);
  204. complete(&nn->nfsd_net_free_done);
  205. }
  206. /*
  207. * Maximum number of nfsd processes
  208. */
  209. #define NFSD_MAXSERVS 8192
  210. int nfsd_nrthreads(struct net *net)
  211. {
  212. int i, rv = 0;
  213. struct nfsd_net *nn = net_generic(net, nfsd_net_id);
  214. mutex_lock(&nfsd_mutex);
  215. if (nn->nfsd_serv)
  216. for (i = 0; i < nn->nfsd_serv->sv_nrpools; ++i)
  217. rv += nn->nfsd_serv->sv_pools[i].sp_nrthrmax;
  218. mutex_unlock(&nfsd_mutex);
  219. return rv;
  220. }
  221. static int nfsd_users = 0;
  222. static int nfsd_startup_generic(void)
  223. {
  224. int ret;
  225. if (nfsd_users++)
  226. return 0;
  227. ret = nfsd_file_cache_init();
  228. if (ret)
  229. goto dec_users;
  230. ret = nfs4_state_start();
  231. if (ret)
  232. goto out_file_cache;
  233. return 0;
  234. out_file_cache:
  235. nfsd_file_cache_shutdown();
  236. dec_users:
  237. nfsd_users--;
  238. return ret;
  239. }
  240. static void nfsd_shutdown_generic(void)
  241. {
  242. if (--nfsd_users)
  243. return;
  244. nfs4_state_shutdown();
  245. nfsd_file_cache_shutdown();
  246. }
  247. static bool nfsd_needs_lockd(struct nfsd_net *nn)
  248. {
  249. return nfsd_vers(nn, 2, NFSD_TEST) || nfsd_vers(nn, 3, NFSD_TEST);
  250. }
  251. /**
  252. * nfsd_copy_write_verifier - Atomically copy a write verifier
  253. * @verf: buffer in which to receive the verifier cookie
  254. * @nn: NFS net namespace
  255. *
  256. * This function provides a wait-free mechanism for copying the
  257. * namespace's write verifier without tearing it.
  258. */
  259. void nfsd_copy_write_verifier(__be32 verf[2], struct nfsd_net *nn)
  260. {
  261. unsigned int seq;
  262. do {
  263. seq = read_seqbegin(&nn->writeverf_lock);
  264. memcpy(verf, nn->writeverf, sizeof(nn->writeverf));
  265. } while (read_seqretry(&nn->writeverf_lock, seq));
  266. }
  267. static void nfsd_reset_write_verifier_locked(struct nfsd_net *nn)
  268. {
  269. struct timespec64 now;
  270. u64 verf;
  271. /*
  272. * Because the time value is hashed, y2038 time_t overflow
  273. * is irrelevant in this usage.
  274. */
  275. ktime_get_raw_ts64(&now);
  276. verf = siphash_2u64(now.tv_sec, now.tv_nsec, &nn->siphash_key);
  277. memcpy(nn->writeverf, &verf, sizeof(nn->writeverf));
  278. }
  279. /**
  280. * nfsd_reset_write_verifier - Generate a new write verifier
  281. * @nn: NFS net namespace
  282. *
  283. * This function updates the ->writeverf field of @nn. This field
  284. * contains an opaque cookie that, according to Section 18.32.3 of
  285. * RFC 8881, "the client can use to determine whether a server has
  286. * changed instance state (e.g., server restart) between a call to
  287. * WRITE and a subsequent call to either WRITE or COMMIT. This
  288. * cookie MUST be unchanged during a single instance of the NFSv4.1
  289. * server and MUST be unique between instances of the NFSv4.1
  290. * server."
  291. */
  292. void nfsd_reset_write_verifier(struct nfsd_net *nn)
  293. {
  294. write_seqlock(&nn->writeverf_lock);
  295. nfsd_reset_write_verifier_locked(nn);
  296. write_sequnlock(&nn->writeverf_lock);
  297. }
  298. /*
  299. * Crank up a set of per-namespace resources for a new NFSD instance,
  300. * including lockd, a duplicate reply cache, an open file cache
  301. * instance, and a cache of NFSv4 state objects.
  302. */
  303. static int nfsd_startup_net(struct net *net, const struct cred *cred)
  304. {
  305. struct nfsd_net *nn = net_generic(net, nfsd_net_id);
  306. int ret;
  307. if (nn->nfsd_net_up)
  308. return 0;
  309. ret = nfsd_startup_generic();
  310. if (ret)
  311. return ret;
  312. if (list_empty(&nn->nfsd_serv->sv_permsocks)) {
  313. pr_warn("NFSD: Failed to start, no listeners configured.\n");
  314. ret = -EIO;
  315. goto out_socks;
  316. }
  317. if (nfsd_needs_lockd(nn) && !nn->lockd_up) {
  318. ret = lockd_up(net, cred);
  319. if (ret)
  320. goto out_socks;
  321. nn->lockd_up = true;
  322. }
  323. ret = nfsd_file_cache_start_net(net);
  324. if (ret)
  325. goto out_lockd;
  326. ret = nfsd_reply_cache_init(nn);
  327. if (ret)
  328. goto out_filecache;
  329. #ifdef CONFIG_NFSD_V4_2_INTER_SSC
  330. nfsd4_ssc_init_umount_work(nn);
  331. #endif
  332. ret = nfs4_state_start_net(net);
  333. if (ret)
  334. goto out_reply_cache;
  335. nn->nfsd_net_up = true;
  336. return 0;
  337. out_reply_cache:
  338. nfsd_reply_cache_shutdown(nn);
  339. out_filecache:
  340. nfsd_file_cache_shutdown_net(net);
  341. out_lockd:
  342. if (nn->lockd_up) {
  343. lockd_down(net);
  344. nn->lockd_up = false;
  345. }
  346. out_socks:
  347. nfsd_shutdown_generic();
  348. return ret;
  349. }
  350. static void nfsd_shutdown_net(struct net *net)
  351. {
  352. struct nfsd_net *nn = net_generic(net, nfsd_net_id);
  353. if (nn->nfsd_net_up) {
  354. percpu_ref_kill_and_confirm(&nn->nfsd_net_ref, nfsd_net_done);
  355. wait_for_completion(&nn->nfsd_net_confirm_done);
  356. nfsd_export_flush(net);
  357. nfs4_state_shutdown_net(net);
  358. nfsd_reply_cache_shutdown(nn);
  359. nfsd_file_cache_shutdown_net(net);
  360. if (nn->lockd_up) {
  361. lockd_down(net);
  362. nn->lockd_up = false;
  363. }
  364. wait_for_completion(&nn->nfsd_net_free_done);
  365. }
  366. percpu_ref_exit(&nn->nfsd_net_ref);
  367. if (nn->nfsd_net_up)
  368. nfsd_shutdown_generic();
  369. nn->nfsd_net_up = false;
  370. }
  371. static DEFINE_SPINLOCK(nfsd_notifier_lock);
  372. static int nfsd_inetaddr_event(struct notifier_block *this, unsigned long event,
  373. void *ptr)
  374. {
  375. struct in_ifaddr *ifa = (struct in_ifaddr *)ptr;
  376. struct net_device *dev = ifa->ifa_dev->dev;
  377. struct net *net = dev_net(dev);
  378. struct nfsd_net *nn = net_generic(net, nfsd_net_id);
  379. struct sockaddr_in sin;
  380. if (event != NETDEV_DOWN || !nn->nfsd_serv)
  381. goto out;
  382. spin_lock(&nfsd_notifier_lock);
  383. if (nn->nfsd_serv) {
  384. dprintk("nfsd_inetaddr_event: removed %pI4\n", &ifa->ifa_local);
  385. sin.sin_family = AF_INET;
  386. sin.sin_addr.s_addr = ifa->ifa_local;
  387. svc_age_temp_xprts_now(nn->nfsd_serv, (struct sockaddr *)&sin);
  388. }
  389. spin_unlock(&nfsd_notifier_lock);
  390. out:
  391. return NOTIFY_DONE;
  392. }
  393. static struct notifier_block nfsd_inetaddr_notifier = {
  394. .notifier_call = nfsd_inetaddr_event,
  395. };
  396. #if IS_ENABLED(CONFIG_IPV6)
  397. static int nfsd_inet6addr_event(struct notifier_block *this,
  398. unsigned long event, void *ptr)
  399. {
  400. struct inet6_ifaddr *ifa = (struct inet6_ifaddr *)ptr;
  401. struct net_device *dev = ifa->idev->dev;
  402. struct net *net = dev_net(dev);
  403. struct nfsd_net *nn = net_generic(net, nfsd_net_id);
  404. struct sockaddr_in6 sin6;
  405. if (event != NETDEV_DOWN || !nn->nfsd_serv)
  406. goto out;
  407. spin_lock(&nfsd_notifier_lock);
  408. if (nn->nfsd_serv) {
  409. dprintk("nfsd_inet6addr_event: removed %pI6\n", &ifa->addr);
  410. sin6.sin6_family = AF_INET6;
  411. sin6.sin6_addr = ifa->addr;
  412. if (ipv6_addr_type(&sin6.sin6_addr) & IPV6_ADDR_LINKLOCAL)
  413. sin6.sin6_scope_id = ifa->idev->dev->ifindex;
  414. svc_age_temp_xprts_now(nn->nfsd_serv, (struct sockaddr *)&sin6);
  415. }
  416. spin_unlock(&nfsd_notifier_lock);
  417. out:
  418. return NOTIFY_DONE;
  419. }
  420. static struct notifier_block nfsd_inet6addr_notifier = {
  421. .notifier_call = nfsd_inet6addr_event,
  422. };
  423. #endif
  424. /* Only used under nfsd_mutex, so this atomic may be overkill: */
  425. static atomic_t nfsd_notifier_refcount = ATOMIC_INIT(0);
  426. /**
  427. * nfsd_destroy_serv - tear down NFSD's svc_serv for a namespace
  428. * @net: network namespace the NFS service is associated with
  429. */
  430. void nfsd_destroy_serv(struct net *net)
  431. {
  432. struct nfsd_net *nn = net_generic(net, nfsd_net_id);
  433. struct svc_serv *serv = nn->nfsd_serv;
  434. lockdep_assert_held(&nfsd_mutex);
  435. spin_lock(&nfsd_notifier_lock);
  436. nn->nfsd_serv = NULL;
  437. spin_unlock(&nfsd_notifier_lock);
  438. /* check if the notifier still has clients */
  439. if (atomic_dec_return(&nfsd_notifier_refcount) == 0) {
  440. unregister_inetaddr_notifier(&nfsd_inetaddr_notifier);
  441. #if IS_ENABLED(CONFIG_IPV6)
  442. unregister_inet6addr_notifier(&nfsd_inet6addr_notifier);
  443. #endif
  444. }
  445. /*
  446. * write_ports can create the server without actually starting
  447. * any threads. If we get shut down before any threads are
  448. * started, then nfsd_destroy_serv will be run before any of this
  449. * other initialization has been done except the rpcb information.
  450. */
  451. svc_xprt_destroy_all(serv, net, true);
  452. nfsd_shutdown_net(net);
  453. svc_destroy(&serv);
  454. }
  455. void nfsd_reset_versions(struct nfsd_net *nn)
  456. {
  457. int i;
  458. for (i = 0; i <= NFSD_MAXVERS; i++)
  459. if (nfsd_vers(nn, i, NFSD_TEST))
  460. return;
  461. for (i = 0; i <= NFSD_MAXVERS; i++)
  462. if (i != 4)
  463. nfsd_vers(nn, i, NFSD_SET);
  464. else {
  465. int minor = 0;
  466. while (nfsd_minorversion(nn, minor, NFSD_SET) >= 0)
  467. minor++;
  468. }
  469. }
  470. static int nfsd_get_default_max_blksize(void)
  471. {
  472. struct sysinfo i;
  473. unsigned long long target;
  474. unsigned long ret;
  475. si_meminfo(&i);
  476. target = (i.totalram - i.totalhigh) << PAGE_SHIFT;
  477. /*
  478. * Aim for 1/4096 of memory per thread This gives 1MB on 4Gig
  479. * machines, but only uses 32K on 128M machines. Bottom out at
  480. * 8K on 32M and smaller. Of course, this is only a default.
  481. */
  482. target >>= 12;
  483. ret = NFSSVC_DEFBLKSIZE;
  484. while (ret > target && ret >= 8*1024*2)
  485. ret /= 2;
  486. return ret;
  487. }
  488. void nfsd_shutdown_threads(struct net *net)
  489. {
  490. struct nfsd_net *nn = net_generic(net, nfsd_net_id);
  491. struct svc_serv *serv;
  492. mutex_lock(&nfsd_mutex);
  493. serv = nn->nfsd_serv;
  494. if (serv == NULL) {
  495. mutex_unlock(&nfsd_mutex);
  496. return;
  497. }
  498. /* Kill outstanding nfsd threads */
  499. svc_set_num_threads(serv, 0, 0);
  500. nfsd_destroy_serv(net);
  501. mutex_unlock(&nfsd_mutex);
  502. }
  503. struct svc_rqst *nfsd_current_rqst(void)
  504. {
  505. if (kthread_func(current) == nfsd)
  506. return kthread_data(current);
  507. return NULL;
  508. }
  509. int nfsd_create_serv(struct net *net)
  510. {
  511. int error;
  512. struct nfsd_net *nn = net_generic(net, nfsd_net_id);
  513. struct svc_serv *serv;
  514. WARN_ON(!mutex_is_locked(&nfsd_mutex));
  515. if (nn->nfsd_serv)
  516. return 0;
  517. error = percpu_ref_init(&nn->nfsd_net_ref, nfsd_net_free,
  518. 0, GFP_KERNEL);
  519. if (error)
  520. return error;
  521. init_completion(&nn->nfsd_net_free_done);
  522. init_completion(&nn->nfsd_net_confirm_done);
  523. if (nfsd_max_blksize == 0)
  524. nfsd_max_blksize = nfsd_get_default_max_blksize();
  525. nfsd_reset_versions(nn);
  526. serv = svc_create_pooled(nfsd_programs, ARRAY_SIZE(nfsd_programs),
  527. &nn->nfsd_svcstats,
  528. nfsd_max_blksize, nfsd);
  529. if (serv == NULL) {
  530. percpu_ref_exit(&nn->nfsd_net_ref);
  531. return -ENOMEM;
  532. }
  533. error = svc_bind(serv, net);
  534. if (error < 0) {
  535. svc_destroy(&serv);
  536. percpu_ref_exit(&nn->nfsd_net_ref);
  537. return error;
  538. }
  539. spin_lock(&nfsd_notifier_lock);
  540. nn->nfsd_serv = serv;
  541. spin_unlock(&nfsd_notifier_lock);
  542. /* check if the notifier is already set */
  543. if (atomic_inc_return(&nfsd_notifier_refcount) == 1) {
  544. register_inetaddr_notifier(&nfsd_inetaddr_notifier);
  545. #if IS_ENABLED(CONFIG_IPV6)
  546. register_inet6addr_notifier(&nfsd_inet6addr_notifier);
  547. #endif
  548. }
  549. nfsd_reset_write_verifier(nn);
  550. return 0;
  551. }
  552. int nfsd_nrpools(struct net *net)
  553. {
  554. struct nfsd_net *nn = net_generic(net, nfsd_net_id);
  555. if (nn->nfsd_serv == NULL)
  556. return 0;
  557. else
  558. return nn->nfsd_serv->sv_nrpools;
  559. }
  560. int nfsd_get_nrthreads(int n, int *nthreads, struct net *net)
  561. {
  562. struct nfsd_net *nn = net_generic(net, nfsd_net_id);
  563. struct svc_serv *serv = nn->nfsd_serv;
  564. int i;
  565. if (serv)
  566. for (i = 0; i < serv->sv_nrpools && i < n; i++)
  567. nthreads[i] = serv->sv_pools[i].sp_nrthrmax;
  568. return 0;
  569. }
  570. /**
  571. * nfsd_set_nrthreads - set the number of running threads in the net's service
  572. * @n: number of array members in @nthreads
  573. * @nthreads: array of thread counts for each pool
  574. * @net: network namespace to operate within
  575. *
  576. * This function alters the number of running threads for the given network
  577. * namespace in each pool. If passed an array longer then the number of pools
  578. * the extra pool settings are ignored. If passed an array shorter than the
  579. * number of pools, the missing values are interpreted as 0's.
  580. *
  581. * Returns 0 on success or a negative errno on error.
  582. */
  583. int nfsd_set_nrthreads(int n, int *nthreads, struct net *net)
  584. {
  585. int i = 0;
  586. int tot = 0;
  587. int err = 0;
  588. struct nfsd_net *nn = net_generic(net, nfsd_net_id);
  589. lockdep_assert_held(&nfsd_mutex);
  590. if (nn->nfsd_serv == NULL || n <= 0)
  591. return 0;
  592. /* Special case: When n == 1, distribute threads equally among pools. */
  593. if (n == 1)
  594. return svc_set_num_threads(nn->nfsd_serv, nn->min_threads, nthreads[0]);
  595. if (n > nn->nfsd_serv->sv_nrpools)
  596. n = nn->nfsd_serv->sv_nrpools;
  597. /* enforce a global maximum number of threads */
  598. tot = 0;
  599. for (i = 0; i < n; i++) {
  600. nthreads[i] = min(nthreads[i], NFSD_MAXSERVS);
  601. tot += nthreads[i];
  602. }
  603. if (tot > NFSD_MAXSERVS) {
  604. /* total too large: scale down requested numbers */
  605. for (i = 0; i < n && tot > 0; i++) {
  606. int new = nthreads[i] * NFSD_MAXSERVS / tot;
  607. tot -= (nthreads[i] - new);
  608. nthreads[i] = new;
  609. }
  610. for (i = 0; i < n && tot > 0; i++) {
  611. nthreads[i]--;
  612. tot--;
  613. }
  614. }
  615. /* apply the new numbers */
  616. for (i = 0; i < n; i++) {
  617. err = svc_set_pool_threads(nn->nfsd_serv,
  618. &nn->nfsd_serv->sv_pools[i],
  619. nn->min_threads, nthreads[i]);
  620. if (err)
  621. goto out;
  622. }
  623. /* Anything undefined in array is considered to be 0 */
  624. for (i = n; i < nn->nfsd_serv->sv_nrpools; ++i) {
  625. err = svc_set_pool_threads(nn->nfsd_serv,
  626. &nn->nfsd_serv->sv_pools[i],
  627. 0, 0);
  628. if (err)
  629. goto out;
  630. }
  631. out:
  632. return err;
  633. }
  634. /**
  635. * nfsd_svc: start up or shut down the nfsd server
  636. * @n: number of array members in @nthreads
  637. * @nthreads: array of thread counts for each pool
  638. * @net: network namespace to operate within
  639. * @cred: credentials to use for xprt creation
  640. * @scope: server scope value (defaults to nodename)
  641. *
  642. * Adjust the number of threads in each pool and return the new
  643. * total number of threads in the service.
  644. */
  645. int
  646. nfsd_svc(int n, int *nthreads, struct net *net, const struct cred *cred, const char *scope)
  647. {
  648. int error;
  649. struct nfsd_net *nn = net_generic(net, nfsd_net_id);
  650. struct svc_serv *serv;
  651. lockdep_assert_held(&nfsd_mutex);
  652. dprintk("nfsd: creating service\n");
  653. strscpy(nn->nfsd_name, scope ? scope : utsname()->nodename,
  654. sizeof(nn->nfsd_name));
  655. error = nfsd_create_serv(net);
  656. if (error)
  657. goto out;
  658. serv = nn->nfsd_serv;
  659. error = nfsd_startup_net(net, cred);
  660. if (error)
  661. goto out_put;
  662. error = nfsd_set_nrthreads(n, nthreads, net);
  663. if (error)
  664. goto out_put;
  665. error = serv->sv_nrthreads;
  666. out_put:
  667. if (serv->sv_nrthreads == 0)
  668. nfsd_destroy_serv(net);
  669. out:
  670. return error;
  671. }
  672. #if defined(CONFIG_NFSD_V2_ACL) || defined(CONFIG_NFSD_V3_ACL)
  673. static bool
  674. nfsd_support_acl_version(int vers)
  675. {
  676. if (vers >= NFSD_ACL_MINVERS && vers < NFSD_ACL_NRVERS)
  677. return nfsd_acl_version[vers] != NULL;
  678. return false;
  679. }
  680. static int
  681. nfsd_acl_rpcbind_set(struct net *net, const struct svc_program *progp,
  682. u32 version, int family, unsigned short proto,
  683. unsigned short port)
  684. {
  685. if (!nfsd_support_acl_version(version) ||
  686. !nfsd_vers(net_generic(net, nfsd_net_id), version, NFSD_TEST))
  687. return 0;
  688. return svc_generic_rpcbind_set(net, progp, version, family,
  689. proto, port);
  690. }
  691. static __be32
  692. nfsd_acl_init_request(struct svc_rqst *rqstp,
  693. const struct svc_program *progp,
  694. struct svc_process_info *ret)
  695. {
  696. struct nfsd_net *nn = net_generic(SVC_NET(rqstp), nfsd_net_id);
  697. int i;
  698. if (likely(nfsd_support_acl_version(rqstp->rq_vers) &&
  699. nfsd_vers(nn, rqstp->rq_vers, NFSD_TEST)))
  700. return svc_generic_init_request(rqstp, progp, ret);
  701. ret->mismatch.lovers = NFSD_ACL_NRVERS;
  702. for (i = NFSD_ACL_MINVERS; i < NFSD_ACL_NRVERS; i++) {
  703. if (nfsd_support_acl_version(rqstp->rq_vers) &&
  704. nfsd_vers(nn, i, NFSD_TEST)) {
  705. ret->mismatch.lovers = i;
  706. break;
  707. }
  708. }
  709. if (ret->mismatch.lovers == NFSD_ACL_NRVERS)
  710. return rpc_prog_unavail;
  711. ret->mismatch.hivers = NFSD_ACL_MINVERS;
  712. for (i = NFSD_ACL_NRVERS - 1; i >= NFSD_ACL_MINVERS; i--) {
  713. if (nfsd_support_acl_version(rqstp->rq_vers) &&
  714. nfsd_vers(nn, i, NFSD_TEST)) {
  715. ret->mismatch.hivers = i;
  716. break;
  717. }
  718. }
  719. return rpc_prog_mismatch;
  720. }
  721. #endif
  722. static int
  723. nfsd_rpcbind_set(struct net *net, const struct svc_program *progp,
  724. u32 version, int family, unsigned short proto,
  725. unsigned short port)
  726. {
  727. if (!nfsd_vers(net_generic(net, nfsd_net_id), version, NFSD_TEST))
  728. return 0;
  729. return svc_generic_rpcbind_set(net, progp, version, family,
  730. proto, port);
  731. }
  732. static __be32
  733. nfsd_init_request(struct svc_rqst *rqstp,
  734. const struct svc_program *progp,
  735. struct svc_process_info *ret)
  736. {
  737. struct nfsd_net *nn = net_generic(SVC_NET(rqstp), nfsd_net_id);
  738. int i;
  739. if (likely(nfsd_vers(nn, rqstp->rq_vers, NFSD_TEST)))
  740. return svc_generic_init_request(rqstp, progp, ret);
  741. ret->mismatch.lovers = NFSD_MAXVERS + 1;
  742. for (i = NFSD_MINVERS; i <= NFSD_MAXVERS; i++) {
  743. if (nfsd_vers(nn, i, NFSD_TEST)) {
  744. ret->mismatch.lovers = i;
  745. break;
  746. }
  747. }
  748. if (ret->mismatch.lovers > NFSD_MAXVERS)
  749. return rpc_prog_unavail;
  750. ret->mismatch.hivers = NFSD_MINVERS;
  751. for (i = NFSD_MAXVERS; i >= NFSD_MINVERS; i--) {
  752. if (nfsd_vers(nn, i, NFSD_TEST)) {
  753. ret->mismatch.hivers = i;
  754. break;
  755. }
  756. }
  757. return rpc_prog_mismatch;
  758. }
  759. /*
  760. * This is the NFS server kernel thread
  761. */
  762. static int
  763. nfsd(void *vrqstp)
  764. {
  765. struct svc_rqst *rqstp = (struct svc_rqst *) vrqstp;
  766. struct svc_pool *pool = rqstp->rq_pool;
  767. struct svc_xprt *perm_sock = list_entry(rqstp->rq_server->sv_permsocks.next, typeof(struct svc_xprt), xpt_list);
  768. struct net *net = perm_sock->xpt_net;
  769. struct nfsd_net *nn = net_generic(net, nfsd_net_id);
  770. bool have_mutex = false;
  771. /* At this point, the thread shares current->fs
  772. * with the init process. We need to create files with the
  773. * umask as defined by the client instead of init's umask.
  774. */
  775. svc_thread_init_status(rqstp, unshare_fs_struct());
  776. current->fs->umask = 0;
  777. atomic_inc(&nfsd_th_cnt);
  778. set_freezable();
  779. /*
  780. * The main request loop
  781. */
  782. while (!svc_thread_should_stop(rqstp)) {
  783. switch (svc_recv(rqstp, 5 * HZ)) {
  784. case -ETIMEDOUT:
  785. /* No work arrived within the timeout window */
  786. if (mutex_trylock(&nfsd_mutex)) {
  787. if (pool->sp_nrthreads > pool->sp_nrthrmin) {
  788. trace_nfsd_dynthread_kill(net, pool);
  789. set_bit(RQ_VICTIM, &rqstp->rq_flags);
  790. have_mutex = true;
  791. } else {
  792. mutex_unlock(&nfsd_mutex);
  793. }
  794. } else {
  795. trace_nfsd_dynthread_trylock_fail(net, pool);
  796. }
  797. break;
  798. case -EBUSY:
  799. /* No idle threads; consider spawning another */
  800. if (pool->sp_nrthreads < pool->sp_nrthrmax) {
  801. if (mutex_trylock(&nfsd_mutex)) {
  802. if (pool->sp_nrthreads < pool->sp_nrthrmax) {
  803. int ret;
  804. trace_nfsd_dynthread_start(net, pool);
  805. ret = svc_new_thread(rqstp->rq_server, pool);
  806. if (ret)
  807. pr_notice_ratelimited("%s: unable to spawn new thread: %d\n",
  808. __func__, ret);
  809. }
  810. mutex_unlock(&nfsd_mutex);
  811. } else {
  812. trace_nfsd_dynthread_trylock_fail(net, pool);
  813. }
  814. }
  815. clear_bit(SP_TASK_STARTING, &pool->sp_flags);
  816. break;
  817. default:
  818. break;
  819. }
  820. nfsd_file_net_dispose(nn);
  821. }
  822. atomic_dec(&nfsd_th_cnt);
  823. /* Release the thread */
  824. svc_exit_thread(rqstp);
  825. if (have_mutex)
  826. mutex_unlock(&nfsd_mutex);
  827. return 0;
  828. }
  829. /**
  830. * nfsd_dispatch - Process an NFS or NFSACL or LOCALIO Request
  831. * @rqstp: incoming request
  832. *
  833. * This RPC dispatcher integrates the NFS server's duplicate reply cache.
  834. *
  835. * Return values:
  836. * %0: Processing complete; do not send a Reply
  837. * %1: Processing complete; send Reply in rqstp->rq_res
  838. */
  839. int nfsd_dispatch(struct svc_rqst *rqstp)
  840. {
  841. const struct svc_procedure *proc = rqstp->rq_procinfo;
  842. __be32 *statp = rqstp->rq_accept_statp;
  843. struct nfsd_cacherep *rp;
  844. unsigned int start, len;
  845. __be32 *nfs_reply;
  846. /*
  847. * Give the xdr decoder a chance to change this if it wants
  848. * (necessary in the NFSv4.0 compound case)
  849. */
  850. rqstp->rq_cachetype = proc->pc_cachetype;
  851. /*
  852. * ->pc_decode advances the argument stream past the NFS
  853. * Call header, so grab the header's starting location and
  854. * size now for the call to nfsd_cache_lookup().
  855. */
  856. start = xdr_stream_pos(&rqstp->rq_arg_stream);
  857. len = xdr_stream_remaining(&rqstp->rq_arg_stream);
  858. if (!proc->pc_decode(rqstp, &rqstp->rq_arg_stream))
  859. goto out_decode_err;
  860. /*
  861. * Release rq_status_counter setting it to an odd value after the rpc
  862. * request has been properly parsed. rq_status_counter is used to
  863. * notify the consumers if the rqstp fields are stable
  864. * (rq_status_counter is odd) or not meaningful (rq_status_counter
  865. * is even).
  866. */
  867. smp_store_release(&rqstp->rq_status_counter, rqstp->rq_status_counter | 1);
  868. rp = NULL;
  869. switch (nfsd_cache_lookup(rqstp, start, len, &rp)) {
  870. case RC_DOIT:
  871. break;
  872. case RC_REPLY:
  873. goto out_cached_reply;
  874. case RC_DROPIT:
  875. goto out_dropit;
  876. }
  877. nfs_reply = xdr_inline_decode(&rqstp->rq_res_stream, 0);
  878. *statp = proc->pc_func(rqstp);
  879. if (test_bit(RQ_DROPME, &rqstp->rq_flags))
  880. goto out_update_drop;
  881. if (!proc->pc_encode(rqstp, &rqstp->rq_res_stream))
  882. goto out_encode_err;
  883. /*
  884. * Release rq_status_counter setting it to an even value after the rpc
  885. * request has been properly processed.
  886. */
  887. smp_store_release(&rqstp->rq_status_counter, rqstp->rq_status_counter + 1);
  888. nfsd_cache_update(rqstp, rp, rqstp->rq_cachetype, nfs_reply);
  889. out_cached_reply:
  890. return 1;
  891. out_decode_err:
  892. trace_nfsd_garbage_args_err(rqstp);
  893. *statp = rpc_garbage_args;
  894. return 1;
  895. out_update_drop:
  896. nfsd_cache_update(rqstp, rp, RC_NOCACHE, NULL);
  897. out_dropit:
  898. return 0;
  899. out_encode_err:
  900. trace_nfsd_cant_encode_err(rqstp);
  901. nfsd_cache_update(rqstp, rp, RC_NOCACHE, NULL);
  902. *statp = rpc_system_err;
  903. return 1;
  904. }
  905. /**
  906. * nfssvc_decode_voidarg - Decode void arguments
  907. * @rqstp: Server RPC transaction context
  908. * @xdr: XDR stream positioned at arguments to decode
  909. *
  910. * Return values:
  911. * %false: Arguments were not valid
  912. * %true: Decoding was successful
  913. */
  914. bool nfssvc_decode_voidarg(struct svc_rqst *rqstp, struct xdr_stream *xdr)
  915. {
  916. return true;
  917. }
  918. /**
  919. * nfssvc_encode_voidres - Encode void results
  920. * @rqstp: Server RPC transaction context
  921. * @xdr: XDR stream into which to encode results
  922. *
  923. * Return values:
  924. * %false: Local error while encoding
  925. * %true: Encoding was successful
  926. */
  927. bool nfssvc_encode_voidres(struct svc_rqst *rqstp, struct xdr_stream *xdr)
  928. {
  929. return true;
  930. }