| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117 |
- /* SPDX-License-Identifier: GPL-2.0-only */
- /*
- * Ceph cache definitions.
- *
- * Copyright (C) 2013 by Adfin Solutions, Inc. All Rights Reserved.
- * Written by Milosz Tanski (milosz@adfin.com)
- */
- #ifndef _CEPH_CACHE_H
- #define _CEPH_CACHE_H
- #include <linux/netfs.h>
- #ifdef CONFIG_CEPH_FSCACHE
- #include <linux/fscache.h>
- int ceph_fscache_register_fs(struct ceph_fs_client* fsc, struct fs_context *fc);
- void ceph_fscache_unregister_fs(struct ceph_fs_client* fsc);
- void ceph_fscache_register_inode_cookie(struct inode *inode);
- void ceph_fscache_unregister_inode_cookie(struct ceph_inode_info* ci);
- void ceph_fscache_use_cookie(struct inode *inode, bool will_modify);
- void ceph_fscache_unuse_cookie(struct inode *inode, bool update);
- void ceph_fscache_update(struct inode *inode);
- void ceph_fscache_invalidate(struct inode *inode, bool dio_write);
- static inline struct fscache_cookie *ceph_fscache_cookie(struct ceph_inode_info *ci)
- {
- return netfs_i_cookie(&ci->netfs);
- }
- static inline void ceph_fscache_resize(struct inode *inode, loff_t to)
- {
- struct ceph_inode_info *ci = ceph_inode(inode);
- struct fscache_cookie *cookie = ceph_fscache_cookie(ci);
- if (cookie) {
- ceph_fscache_use_cookie(inode, true);
- fscache_resize_cookie(cookie, to);
- ceph_fscache_unuse_cookie(inode, true);
- }
- }
- static inline int ceph_fscache_unpin_writeback(struct inode *inode,
- struct writeback_control *wbc)
- {
- return netfs_unpin_writeback(inode, wbc);
- }
- #define ceph_fscache_dirty_folio netfs_dirty_folio
- static inline bool ceph_is_cache_enabled(struct inode *inode)
- {
- return fscache_cookie_enabled(ceph_fscache_cookie(ceph_inode(inode)));
- }
- #else /* CONFIG_CEPH_FSCACHE */
- static inline int ceph_fscache_register_fs(struct ceph_fs_client* fsc,
- struct fs_context *fc)
- {
- return 0;
- }
- static inline void ceph_fscache_unregister_fs(struct ceph_fs_client* fsc)
- {
- }
- static inline void ceph_fscache_register_inode_cookie(struct inode *inode)
- {
- }
- static inline void ceph_fscache_unregister_inode_cookie(struct ceph_inode_info* ci)
- {
- }
- static inline void ceph_fscache_use_cookie(struct inode *inode, bool will_modify)
- {
- }
- static inline void ceph_fscache_unuse_cookie(struct inode *inode, bool update)
- {
- }
- static inline void ceph_fscache_update(struct inode *inode)
- {
- }
- static inline void ceph_fscache_invalidate(struct inode *inode, bool dio_write)
- {
- }
- static inline struct fscache_cookie *ceph_fscache_cookie(struct ceph_inode_info *ci)
- {
- return NULL;
- }
- static inline void ceph_fscache_resize(struct inode *inode, loff_t to)
- {
- }
- static inline int ceph_fscache_unpin_writeback(struct inode *inode,
- struct writeback_control *wbc)
- {
- return 0;
- }
- #define ceph_fscache_dirty_folio filemap_dirty_folio
- static inline bool ceph_is_cache_enabled(struct inode *inode)
- {
- return false;
- }
- #endif /* CONFIG_CEPH_FSCACHE */
- #endif
|