io.c 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762
  1. // SPDX-License-Identifier: GPL-2.0-or-later
  2. /* kiocb-using read/write
  3. *
  4. * Copyright (C) 2021 Red Hat, Inc. All Rights Reserved.
  5. * Written by David Howells (dhowells@redhat.com)
  6. */
  7. #include <linux/mount.h>
  8. #include <linux/slab.h>
  9. #include <linux/file.h>
  10. #include <linux/uio.h>
  11. #include <linux/bio.h>
  12. #include <linux/falloc.h>
  13. #include <linux/sched/mm.h>
  14. #include <trace/events/fscache.h>
  15. #include <trace/events/netfs.h>
  16. #include "internal.h"
  17. struct cachefiles_kiocb {
  18. struct kiocb iocb;
  19. refcount_t ki_refcnt;
  20. loff_t start;
  21. union {
  22. size_t skipped;
  23. size_t len;
  24. };
  25. struct cachefiles_object *object;
  26. netfs_io_terminated_t term_func;
  27. void *term_func_priv;
  28. bool was_async;
  29. unsigned int inval_counter; /* Copy of cookie->inval_counter */
  30. u64 b_writing;
  31. };
  32. static inline void cachefiles_put_kiocb(struct cachefiles_kiocb *ki)
  33. {
  34. if (refcount_dec_and_test(&ki->ki_refcnt)) {
  35. cachefiles_put_object(ki->object, cachefiles_obj_put_ioreq);
  36. fput(ki->iocb.ki_filp);
  37. kfree(ki);
  38. }
  39. }
  40. /*
  41. * Handle completion of a read from the cache.
  42. */
  43. static void cachefiles_read_complete(struct kiocb *iocb, long ret)
  44. {
  45. struct cachefiles_kiocb *ki = container_of(iocb, struct cachefiles_kiocb, iocb);
  46. struct inode *inode = file_inode(ki->iocb.ki_filp);
  47. _enter("%ld", ret);
  48. if (ret < 0)
  49. trace_cachefiles_io_error(ki->object, inode, ret,
  50. cachefiles_trace_read_error);
  51. if (ki->term_func) {
  52. if (ret >= 0) {
  53. if (ki->object->cookie->inval_counter == ki->inval_counter)
  54. ki->skipped += ret;
  55. else
  56. ret = -ESTALE;
  57. }
  58. ki->term_func(ki->term_func_priv, ret);
  59. }
  60. cachefiles_put_kiocb(ki);
  61. }
  62. /*
  63. * Initiate a read from the cache.
  64. */
  65. static int cachefiles_read(struct netfs_cache_resources *cres,
  66. loff_t start_pos,
  67. struct iov_iter *iter,
  68. enum netfs_read_from_hole read_hole,
  69. netfs_io_terminated_t term_func,
  70. void *term_func_priv)
  71. {
  72. struct cachefiles_object *object;
  73. struct cachefiles_kiocb *ki;
  74. struct file *file;
  75. unsigned int old_nofs;
  76. ssize_t ret = -ENOBUFS;
  77. size_t len = iov_iter_count(iter), skipped = 0;
  78. if (!fscache_wait_for_operation(cres, FSCACHE_WANT_READ))
  79. goto presubmission_error;
  80. fscache_count_read();
  81. object = cachefiles_cres_object(cres);
  82. file = cachefiles_cres_file(cres);
  83. _enter("%pD,%li,%llx,%zx/%llx",
  84. file, file_inode(file)->i_ino, start_pos, len,
  85. i_size_read(file_inode(file)));
  86. /* If the caller asked us to seek for data before doing the read, then
  87. * we should do that now. If we find a gap, we fill it with zeros.
  88. */
  89. if (read_hole != NETFS_READ_HOLE_IGNORE) {
  90. loff_t off = start_pos, off2;
  91. off2 = cachefiles_inject_read_error();
  92. if (off2 == 0)
  93. off2 = vfs_llseek(file, off, SEEK_DATA);
  94. if (off2 < 0 && off2 >= (loff_t)-MAX_ERRNO && off2 != -ENXIO) {
  95. skipped = 0;
  96. ret = off2;
  97. goto presubmission_error;
  98. }
  99. if (off2 == -ENXIO || off2 >= start_pos + len) {
  100. /* The region is beyond the EOF or there's no more data
  101. * in the region, so clear the rest of the buffer and
  102. * return success.
  103. */
  104. ret = -ENODATA;
  105. if (read_hole == NETFS_READ_HOLE_FAIL)
  106. goto presubmission_error;
  107. iov_iter_zero(len, iter);
  108. skipped = len;
  109. ret = 0;
  110. goto presubmission_error;
  111. }
  112. skipped = off2 - off;
  113. iov_iter_zero(skipped, iter);
  114. }
  115. ret = -ENOMEM;
  116. ki = kzalloc_obj(struct cachefiles_kiocb);
  117. if (!ki)
  118. goto presubmission_error;
  119. refcount_set(&ki->ki_refcnt, 2);
  120. ki->iocb.ki_filp = file;
  121. ki->iocb.ki_pos = start_pos + skipped;
  122. ki->iocb.ki_flags = IOCB_DIRECT;
  123. ki->iocb.ki_ioprio = get_current_ioprio();
  124. ki->skipped = skipped;
  125. ki->object = object;
  126. ki->inval_counter = cres->inval_counter;
  127. ki->term_func = term_func;
  128. ki->term_func_priv = term_func_priv;
  129. ki->was_async = true;
  130. if (ki->term_func)
  131. ki->iocb.ki_complete = cachefiles_read_complete;
  132. get_file(ki->iocb.ki_filp);
  133. cachefiles_grab_object(object, cachefiles_obj_get_ioreq);
  134. trace_cachefiles_read(object, file_inode(file), ki->iocb.ki_pos, len - skipped);
  135. old_nofs = memalloc_nofs_save();
  136. ret = cachefiles_inject_read_error();
  137. if (ret == 0)
  138. ret = vfs_iocb_iter_read(file, &ki->iocb, iter);
  139. memalloc_nofs_restore(old_nofs);
  140. switch (ret) {
  141. case -EIOCBQUEUED:
  142. goto in_progress;
  143. case -ERESTARTSYS:
  144. case -ERESTARTNOINTR:
  145. case -ERESTARTNOHAND:
  146. case -ERESTART_RESTARTBLOCK:
  147. /* There's no easy way to restart the syscall since other AIO's
  148. * may be already running. Just fail this IO with EINTR.
  149. */
  150. ret = -EINTR;
  151. fallthrough;
  152. default:
  153. ki->was_async = false;
  154. cachefiles_read_complete(&ki->iocb, ret);
  155. if (ret > 0)
  156. ret = 0;
  157. break;
  158. }
  159. in_progress:
  160. cachefiles_put_kiocb(ki);
  161. _leave(" = %zd", ret);
  162. return ret;
  163. presubmission_error:
  164. if (term_func)
  165. term_func(term_func_priv, ret < 0 ? ret : skipped);
  166. return ret;
  167. }
  168. /*
  169. * Query the occupancy of the cache in a region, returning where the next chunk
  170. * of data starts and how long it is.
  171. */
  172. static int cachefiles_query_occupancy(struct netfs_cache_resources *cres,
  173. loff_t start, size_t len, size_t granularity,
  174. loff_t *_data_start, size_t *_data_len)
  175. {
  176. struct cachefiles_object *object;
  177. struct file *file;
  178. loff_t off, off2;
  179. *_data_start = -1;
  180. *_data_len = 0;
  181. if (!fscache_wait_for_operation(cres, FSCACHE_WANT_READ))
  182. return -ENOBUFS;
  183. object = cachefiles_cres_object(cres);
  184. file = cachefiles_cres_file(cres);
  185. granularity = max_t(size_t, object->volume->cache->bsize, granularity);
  186. _enter("%pD,%li,%llx,%zx/%llx",
  187. file, file_inode(file)->i_ino, start, len,
  188. i_size_read(file_inode(file)));
  189. off = cachefiles_inject_read_error();
  190. if (off == 0)
  191. off = vfs_llseek(file, start, SEEK_DATA);
  192. if (off == -ENXIO)
  193. return -ENODATA; /* Beyond EOF */
  194. if (off < 0 && off >= (loff_t)-MAX_ERRNO)
  195. return -ENOBUFS; /* Error. */
  196. if (round_up(off, granularity) >= start + len)
  197. return -ENODATA; /* No data in range */
  198. off2 = cachefiles_inject_read_error();
  199. if (off2 == 0)
  200. off2 = vfs_llseek(file, off, SEEK_HOLE);
  201. if (off2 == -ENXIO)
  202. return -ENODATA; /* Beyond EOF */
  203. if (off2 < 0 && off2 >= (loff_t)-MAX_ERRNO)
  204. return -ENOBUFS; /* Error. */
  205. /* Round away partial blocks */
  206. off = round_up(off, granularity);
  207. off2 = round_down(off2, granularity);
  208. if (off2 <= off)
  209. return -ENODATA;
  210. *_data_start = off;
  211. if (off2 > start + len)
  212. *_data_len = len;
  213. else
  214. *_data_len = off2 - off;
  215. return 0;
  216. }
  217. /*
  218. * Handle completion of a write to the cache.
  219. */
  220. static void cachefiles_write_complete(struct kiocb *iocb, long ret)
  221. {
  222. struct cachefiles_kiocb *ki = container_of(iocb, struct cachefiles_kiocb, iocb);
  223. struct cachefiles_object *object = ki->object;
  224. struct inode *inode = file_inode(ki->iocb.ki_filp);
  225. _enter("%ld", ret);
  226. if (ki->was_async)
  227. kiocb_end_write(iocb);
  228. if (ret < 0)
  229. trace_cachefiles_io_error(object, inode, ret,
  230. cachefiles_trace_write_error);
  231. atomic_long_sub(ki->b_writing, &object->volume->cache->b_writing);
  232. set_bit(FSCACHE_COOKIE_HAVE_DATA, &object->cookie->flags);
  233. if (ki->term_func)
  234. ki->term_func(ki->term_func_priv, ret);
  235. cachefiles_put_kiocb(ki);
  236. }
  237. /*
  238. * Initiate a write to the cache.
  239. */
  240. int __cachefiles_write(struct cachefiles_object *object,
  241. struct file *file,
  242. loff_t start_pos,
  243. struct iov_iter *iter,
  244. netfs_io_terminated_t term_func,
  245. void *term_func_priv)
  246. {
  247. struct cachefiles_cache *cache;
  248. struct cachefiles_kiocb *ki;
  249. unsigned int old_nofs;
  250. ssize_t ret;
  251. size_t len = iov_iter_count(iter);
  252. fscache_count_write();
  253. cache = object->volume->cache;
  254. _enter("%pD,%li,%llx,%zx/%llx",
  255. file, file_inode(file)->i_ino, start_pos, len,
  256. i_size_read(file_inode(file)));
  257. ki = kzalloc_obj(struct cachefiles_kiocb);
  258. if (!ki) {
  259. if (term_func)
  260. term_func(term_func_priv, -ENOMEM);
  261. return -ENOMEM;
  262. }
  263. refcount_set(&ki->ki_refcnt, 2);
  264. ki->iocb.ki_filp = file;
  265. ki->iocb.ki_pos = start_pos;
  266. ki->iocb.ki_flags = IOCB_DIRECT | IOCB_WRITE;
  267. ki->iocb.ki_ioprio = get_current_ioprio();
  268. ki->object = object;
  269. ki->start = start_pos;
  270. ki->len = len;
  271. ki->term_func = term_func;
  272. ki->term_func_priv = term_func_priv;
  273. ki->was_async = true;
  274. ki->b_writing = (len + (1 << cache->bshift) - 1) >> cache->bshift;
  275. if (ki->term_func)
  276. ki->iocb.ki_complete = cachefiles_write_complete;
  277. atomic_long_add(ki->b_writing, &cache->b_writing);
  278. get_file(ki->iocb.ki_filp);
  279. cachefiles_grab_object(object, cachefiles_obj_get_ioreq);
  280. trace_cachefiles_write(object, file_inode(file), ki->iocb.ki_pos, len);
  281. old_nofs = memalloc_nofs_save();
  282. ret = cachefiles_inject_write_error();
  283. if (ret == 0)
  284. ret = vfs_iocb_iter_write(file, &ki->iocb, iter);
  285. memalloc_nofs_restore(old_nofs);
  286. switch (ret) {
  287. case -EIOCBQUEUED:
  288. goto in_progress;
  289. case -ERESTARTSYS:
  290. case -ERESTARTNOINTR:
  291. case -ERESTARTNOHAND:
  292. case -ERESTART_RESTARTBLOCK:
  293. /* There's no easy way to restart the syscall since other AIO's
  294. * may be already running. Just fail this IO with EINTR.
  295. */
  296. ret = -EINTR;
  297. fallthrough;
  298. default:
  299. ki->was_async = false;
  300. cachefiles_write_complete(&ki->iocb, ret);
  301. break;
  302. }
  303. in_progress:
  304. cachefiles_put_kiocb(ki);
  305. _leave(" = %zd", ret);
  306. return ret;
  307. }
  308. static int cachefiles_write(struct netfs_cache_resources *cres,
  309. loff_t start_pos,
  310. struct iov_iter *iter,
  311. netfs_io_terminated_t term_func,
  312. void *term_func_priv)
  313. {
  314. if (!fscache_wait_for_operation(cres, FSCACHE_WANT_WRITE)) {
  315. if (term_func)
  316. term_func(term_func_priv, -ENOBUFS);
  317. trace_netfs_sreq(term_func_priv, netfs_sreq_trace_cache_nowrite);
  318. return -ENOBUFS;
  319. }
  320. return __cachefiles_write(cachefiles_cres_object(cres),
  321. cachefiles_cres_file(cres),
  322. start_pos, iter,
  323. term_func, term_func_priv);
  324. }
  325. static inline enum netfs_io_source
  326. cachefiles_do_prepare_read(struct netfs_cache_resources *cres,
  327. loff_t start, size_t *_len, loff_t i_size,
  328. unsigned long *_flags, ino_t netfs_ino)
  329. {
  330. enum cachefiles_prepare_read_trace why;
  331. struct cachefiles_object *object = NULL;
  332. struct cachefiles_cache *cache;
  333. struct fscache_cookie *cookie = fscache_cres_cookie(cres);
  334. const struct cred *saved_cred;
  335. struct file *file = cachefiles_cres_file(cres);
  336. enum netfs_io_source ret = NETFS_DOWNLOAD_FROM_SERVER;
  337. size_t len = *_len;
  338. loff_t off, to;
  339. ino_t ino = file ? file_inode(file)->i_ino : 0;
  340. int rc;
  341. _enter("%zx @%llx/%llx", len, start, i_size);
  342. if (start >= i_size) {
  343. ret = NETFS_FILL_WITH_ZEROES;
  344. why = cachefiles_trace_read_after_eof;
  345. goto out_no_object;
  346. }
  347. if (test_bit(FSCACHE_COOKIE_NO_DATA_TO_READ, &cookie->flags)) {
  348. __set_bit(NETFS_SREQ_COPY_TO_CACHE, _flags);
  349. why = cachefiles_trace_read_no_data;
  350. if (!test_bit(NETFS_SREQ_ONDEMAND, _flags))
  351. goto out_no_object;
  352. }
  353. /* The object and the file may be being created in the background. */
  354. if (!file) {
  355. why = cachefiles_trace_read_no_file;
  356. if (!fscache_wait_for_operation(cres, FSCACHE_WANT_READ))
  357. goto out_no_object;
  358. file = cachefiles_cres_file(cres);
  359. if (!file)
  360. goto out_no_object;
  361. ino = file_inode(file)->i_ino;
  362. }
  363. object = cachefiles_cres_object(cres);
  364. cache = object->volume->cache;
  365. cachefiles_begin_secure(cache, &saved_cred);
  366. retry:
  367. off = cachefiles_inject_read_error();
  368. if (off == 0)
  369. off = vfs_llseek(file, start, SEEK_DATA);
  370. if (off < 0 && off >= (loff_t)-MAX_ERRNO) {
  371. if (off == (loff_t)-ENXIO) {
  372. why = cachefiles_trace_read_seek_nxio;
  373. goto download_and_store;
  374. }
  375. trace_cachefiles_io_error(object, file_inode(file), off,
  376. cachefiles_trace_seek_error);
  377. why = cachefiles_trace_read_seek_error;
  378. goto out;
  379. }
  380. if (off >= start + len) {
  381. why = cachefiles_trace_read_found_hole;
  382. goto download_and_store;
  383. }
  384. if (off > start) {
  385. off = round_up(off, cache->bsize);
  386. len = off - start;
  387. *_len = len;
  388. why = cachefiles_trace_read_found_part;
  389. goto download_and_store;
  390. }
  391. to = cachefiles_inject_read_error();
  392. if (to == 0)
  393. to = vfs_llseek(file, start, SEEK_HOLE);
  394. if (to < 0 && to >= (loff_t)-MAX_ERRNO) {
  395. trace_cachefiles_io_error(object, file_inode(file), to,
  396. cachefiles_trace_seek_error);
  397. why = cachefiles_trace_read_seek_error;
  398. goto out;
  399. }
  400. if (to < start + len) {
  401. if (start + len >= i_size)
  402. to = round_up(to, cache->bsize);
  403. else
  404. to = round_down(to, cache->bsize);
  405. len = to - start;
  406. *_len = len;
  407. }
  408. why = cachefiles_trace_read_have_data;
  409. ret = NETFS_READ_FROM_CACHE;
  410. goto out;
  411. download_and_store:
  412. __set_bit(NETFS_SREQ_COPY_TO_CACHE, _flags);
  413. if (test_bit(NETFS_SREQ_ONDEMAND, _flags)) {
  414. rc = cachefiles_ondemand_read(object, start, len);
  415. if (!rc) {
  416. __clear_bit(NETFS_SREQ_ONDEMAND, _flags);
  417. goto retry;
  418. }
  419. ret = NETFS_INVALID_READ;
  420. }
  421. out:
  422. cachefiles_end_secure(cache, saved_cred);
  423. out_no_object:
  424. trace_cachefiles_prep_read(object, start, len, *_flags, ret, why, ino, netfs_ino);
  425. return ret;
  426. }
  427. /*
  428. * Prepare a read operation, shortening it to a cached/uncached
  429. * boundary as appropriate.
  430. */
  431. static enum netfs_io_source cachefiles_prepare_read(struct netfs_io_subrequest *subreq,
  432. unsigned long long i_size)
  433. {
  434. return cachefiles_do_prepare_read(&subreq->rreq->cache_resources,
  435. subreq->start, &subreq->len, i_size,
  436. &subreq->flags, subreq->rreq->inode->i_ino);
  437. }
  438. /*
  439. * Prepare an on-demand read operation, shortening it to a cached/uncached
  440. * boundary as appropriate.
  441. */
  442. static enum netfs_io_source
  443. cachefiles_prepare_ondemand_read(struct netfs_cache_resources *cres,
  444. loff_t start, size_t *_len, loff_t i_size,
  445. unsigned long *_flags, ino_t ino)
  446. {
  447. return cachefiles_do_prepare_read(cres, start, _len, i_size, _flags, ino);
  448. }
  449. /*
  450. * Prepare for a write to occur.
  451. */
  452. int __cachefiles_prepare_write(struct cachefiles_object *object,
  453. struct file *file,
  454. loff_t *_start, size_t *_len, size_t upper_len,
  455. bool no_space_allocated_yet)
  456. {
  457. struct cachefiles_cache *cache = object->volume->cache;
  458. loff_t start = *_start, pos;
  459. size_t len = *_len;
  460. int ret;
  461. /* Round to DIO size */
  462. start = round_down(*_start, PAGE_SIZE);
  463. if (start != *_start || *_len > upper_len) {
  464. /* Probably asked to cache a streaming write written into the
  465. * pagecache when the cookie was temporarily out of service to
  466. * culling.
  467. */
  468. fscache_count_dio_misfit();
  469. return -ENOBUFS;
  470. }
  471. *_len = round_up(len, PAGE_SIZE);
  472. /* We need to work out whether there's sufficient disk space to perform
  473. * the write - but we can skip that check if we have space already
  474. * allocated.
  475. */
  476. if (no_space_allocated_yet)
  477. goto check_space;
  478. pos = cachefiles_inject_read_error();
  479. if (pos == 0)
  480. pos = vfs_llseek(file, start, SEEK_DATA);
  481. if (pos < 0 && pos >= (loff_t)-MAX_ERRNO) {
  482. if (pos == -ENXIO)
  483. goto check_space; /* Unallocated tail */
  484. trace_cachefiles_io_error(object, file_inode(file), pos,
  485. cachefiles_trace_seek_error);
  486. return pos;
  487. }
  488. if ((u64)pos >= (u64)start + *_len)
  489. goto check_space; /* Unallocated region */
  490. /* We have a block that's at least partially filled - if we're low on
  491. * space, we need to see if it's fully allocated. If it's not, we may
  492. * want to cull it.
  493. */
  494. if (cachefiles_has_space(cache, 0, *_len / PAGE_SIZE,
  495. cachefiles_has_space_check) == 0)
  496. return 0; /* Enough space to simply overwrite the whole block */
  497. pos = cachefiles_inject_read_error();
  498. if (pos == 0)
  499. pos = vfs_llseek(file, start, SEEK_HOLE);
  500. if (pos < 0 && pos >= (loff_t)-MAX_ERRNO) {
  501. trace_cachefiles_io_error(object, file_inode(file), pos,
  502. cachefiles_trace_seek_error);
  503. return pos;
  504. }
  505. if ((u64)pos >= (u64)start + *_len)
  506. return 0; /* Fully allocated */
  507. /* Partially allocated, but insufficient space: cull. */
  508. fscache_count_no_write_space();
  509. ret = cachefiles_inject_remove_error();
  510. if (ret == 0)
  511. ret = vfs_fallocate(file, FALLOC_FL_PUNCH_HOLE | FALLOC_FL_KEEP_SIZE,
  512. start, *_len);
  513. if (ret < 0) {
  514. trace_cachefiles_io_error(object, file_inode(file), ret,
  515. cachefiles_trace_fallocate_error);
  516. cachefiles_io_error_obj(object,
  517. "CacheFiles: fallocate failed (%d)\n", ret);
  518. ret = -EIO;
  519. }
  520. return ret;
  521. check_space:
  522. return cachefiles_has_space(cache, 0, *_len / PAGE_SIZE,
  523. cachefiles_has_space_for_write);
  524. }
  525. static int cachefiles_prepare_write(struct netfs_cache_resources *cres,
  526. loff_t *_start, size_t *_len, size_t upper_len,
  527. loff_t i_size, bool no_space_allocated_yet)
  528. {
  529. struct cachefiles_object *object = cachefiles_cres_object(cres);
  530. struct cachefiles_cache *cache = object->volume->cache;
  531. const struct cred *saved_cred;
  532. int ret;
  533. if (!cachefiles_cres_file(cres)) {
  534. if (!fscache_wait_for_operation(cres, FSCACHE_WANT_WRITE))
  535. return -ENOBUFS;
  536. if (!cachefiles_cres_file(cres))
  537. return -ENOBUFS;
  538. }
  539. cachefiles_begin_secure(cache, &saved_cred);
  540. ret = __cachefiles_prepare_write(object, cachefiles_cres_file(cres),
  541. _start, _len, upper_len,
  542. no_space_allocated_yet);
  543. cachefiles_end_secure(cache, saved_cred);
  544. return ret;
  545. }
  546. static void cachefiles_prepare_write_subreq(struct netfs_io_subrequest *subreq)
  547. {
  548. struct netfs_io_request *wreq = subreq->rreq;
  549. struct netfs_cache_resources *cres = &wreq->cache_resources;
  550. struct netfs_io_stream *stream = &wreq->io_streams[subreq->stream_nr];
  551. _enter("W=%x[%x] %llx", wreq->debug_id, subreq->debug_index, subreq->start);
  552. stream->sreq_max_len = MAX_RW_COUNT;
  553. stream->sreq_max_segs = BIO_MAX_VECS;
  554. if (!cachefiles_cres_file(cres)) {
  555. if (!fscache_wait_for_operation(cres, FSCACHE_WANT_WRITE))
  556. return netfs_prepare_write_failed(subreq);
  557. if (!cachefiles_cres_file(cres))
  558. return netfs_prepare_write_failed(subreq);
  559. }
  560. }
  561. static void cachefiles_issue_write(struct netfs_io_subrequest *subreq)
  562. {
  563. struct netfs_io_request *wreq = subreq->rreq;
  564. struct netfs_cache_resources *cres = &wreq->cache_resources;
  565. struct cachefiles_object *object = cachefiles_cres_object(cres);
  566. struct cachefiles_cache *cache = object->volume->cache;
  567. struct netfs_io_stream *stream = &wreq->io_streams[subreq->stream_nr];
  568. const struct cred *saved_cred;
  569. size_t off, pre, post, len = subreq->len;
  570. loff_t start = subreq->start;
  571. int ret;
  572. _enter("W=%x[%x] %llx-%llx",
  573. wreq->debug_id, subreq->debug_index, start, start + len - 1);
  574. /* We need to start on the cache granularity boundary */
  575. off = start & (CACHEFILES_DIO_BLOCK_SIZE - 1);
  576. if (off) {
  577. pre = CACHEFILES_DIO_BLOCK_SIZE - off;
  578. if (pre >= len) {
  579. fscache_count_dio_misfit();
  580. netfs_write_subrequest_terminated(subreq, len);
  581. return;
  582. }
  583. subreq->transferred += pre;
  584. start += pre;
  585. len -= pre;
  586. iov_iter_advance(&subreq->io_iter, pre);
  587. }
  588. /* We also need to end on the cache granularity boundary */
  589. if (start + len == wreq->i_size) {
  590. size_t part = len % CACHEFILES_DIO_BLOCK_SIZE;
  591. size_t need = CACHEFILES_DIO_BLOCK_SIZE - part;
  592. if (part && stream->submit_extendable_to >= need) {
  593. len += need;
  594. subreq->len += need;
  595. subreq->io_iter.count += need;
  596. }
  597. }
  598. post = len & (CACHEFILES_DIO_BLOCK_SIZE - 1);
  599. if (post) {
  600. len -= post;
  601. if (len == 0) {
  602. fscache_count_dio_misfit();
  603. netfs_write_subrequest_terminated(subreq, post);
  604. return;
  605. }
  606. iov_iter_truncate(&subreq->io_iter, len);
  607. }
  608. trace_netfs_sreq(subreq, netfs_sreq_trace_cache_prepare);
  609. cachefiles_begin_secure(cache, &saved_cred);
  610. ret = __cachefiles_prepare_write(object, cachefiles_cres_file(cres),
  611. &start, &len, len, true);
  612. cachefiles_end_secure(cache, saved_cred);
  613. if (ret < 0) {
  614. netfs_write_subrequest_terminated(subreq, ret);
  615. return;
  616. }
  617. trace_netfs_sreq(subreq, netfs_sreq_trace_cache_write);
  618. cachefiles_write(&subreq->rreq->cache_resources,
  619. subreq->start, &subreq->io_iter,
  620. netfs_write_subrequest_terminated, subreq);
  621. }
  622. /*
  623. * Clean up an operation.
  624. */
  625. static void cachefiles_end_operation(struct netfs_cache_resources *cres)
  626. {
  627. struct file *file = cachefiles_cres_file(cres);
  628. if (file)
  629. fput(file);
  630. fscache_end_cookie_access(fscache_cres_cookie(cres), fscache_access_io_end);
  631. }
  632. static const struct netfs_cache_ops cachefiles_netfs_cache_ops = {
  633. .end_operation = cachefiles_end_operation,
  634. .read = cachefiles_read,
  635. .write = cachefiles_write,
  636. .issue_write = cachefiles_issue_write,
  637. .prepare_read = cachefiles_prepare_read,
  638. .prepare_write = cachefiles_prepare_write,
  639. .prepare_write_subreq = cachefiles_prepare_write_subreq,
  640. .prepare_ondemand_read = cachefiles_prepare_ondemand_read,
  641. .query_occupancy = cachefiles_query_occupancy,
  642. };
  643. /*
  644. * Open the cache file when beginning a cache operation.
  645. */
  646. bool cachefiles_begin_operation(struct netfs_cache_resources *cres,
  647. enum fscache_want_state want_state)
  648. {
  649. struct cachefiles_object *object = cachefiles_cres_object(cres);
  650. if (!cachefiles_cres_file(cres)) {
  651. cres->ops = &cachefiles_netfs_cache_ops;
  652. if (object->file) {
  653. spin_lock(&object->lock);
  654. if (!cres->cache_priv2 && object->file)
  655. cres->cache_priv2 = get_file(object->file);
  656. spin_unlock(&object->lock);
  657. }
  658. }
  659. if (!cachefiles_cres_file(cres) && want_state != FSCACHE_WANT_PARAMS) {
  660. pr_err("failed to get cres->file\n");
  661. return false;
  662. }
  663. return true;
  664. }