| /* 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->vfs_inode); | 
 | } | 
 |  | 
 | 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 void ceph_fscache_unpin_writeback(struct inode *inode, | 
 | 						struct writeback_control *wbc) | 
 | { | 
 | 	fscache_unpin_writeback(wbc, ceph_fscache_cookie(ceph_inode(inode))); | 
 | } | 
 |  | 
 | static inline int ceph_fscache_dirty_folio(struct address_space *mapping, | 
 | 		struct folio *folio) | 
 | { | 
 | 	struct ceph_inode_info *ci = ceph_inode(mapping->host); | 
 |  | 
 | 	return fscache_dirty_folio(mapping, folio, ceph_fscache_cookie(ci)); | 
 | } | 
 |  | 
 | static inline int ceph_begin_cache_operation(struct netfs_io_request *rreq) | 
 | { | 
 | 	struct fscache_cookie *cookie = ceph_fscache_cookie(ceph_inode(rreq->inode)); | 
 |  | 
 | 	return fscache_begin_read_operation(&rreq->cache_resources, cookie); | 
 | } | 
 |  | 
 | static inline bool ceph_is_cache_enabled(struct inode *inode) | 
 | { | 
 | 	return fscache_cookie_enabled(ceph_fscache_cookie(ceph_inode(inode))); | 
 | } | 
 |  | 
 | static inline void ceph_fscache_note_page_release(struct inode *inode) | 
 | { | 
 | 	struct ceph_inode_info *ci = ceph_inode(inode); | 
 |  | 
 | 	fscache_note_page_release(ceph_fscache_cookie(ci)); | 
 | } | 
 | #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 void ceph_fscache_unpin_writeback(struct inode *inode, | 
 | 						struct writeback_control *wbc) | 
 | { | 
 | } | 
 |  | 
 | static inline int ceph_fscache_dirty_folio(struct address_space *mapping, | 
 | 		struct folio *folio) | 
 | { | 
 | 	return filemap_dirty_folio(mapping, folio); | 
 | } | 
 |  | 
 | static inline bool ceph_is_cache_enabled(struct inode *inode) | 
 | { | 
 | 	return false; | 
 | } | 
 |  | 
 | static inline int ceph_begin_cache_operation(struct netfs_io_request *rreq) | 
 | { | 
 | 	return -ENOBUFS; | 
 | } | 
 |  | 
 | static inline void ceph_fscache_note_page_release(struct inode *inode) | 
 | { | 
 | } | 
 | #endif /* CONFIG_CEPH_FSCACHE */ | 
 |  | 
 | #endif |