2019-05-28 09:57:16 -07:00
/* SPDX-License-Identifier: GPL-2.0-only */
2013-08-21 17:29:54 -04:00
/*
* 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
2020-06-01 10:10:21 -04:00
# include <linux/netfs.h>
2013-08-21 17:29:54 -04:00
# ifdef CONFIG_CEPH_FSCACHE
2021-12-07 08:44:50 -05:00
# include <linux/fscache.h>
2013-08-21 17:29:54 -04:00
2019-03-25 16:38:32 +00:00
int ceph_fscache_register_fs ( struct ceph_fs_client * fsc , struct fs_context * fc ) ;
2013-08-21 17:29:54 -04:00
void ceph_fscache_unregister_fs ( struct ceph_fs_client * fsc ) ;
2016-05-18 15:25:03 +08:00
void ceph_fscache_register_inode_cookie ( struct inode * inode ) ;
2013-08-21 17:29:54 -04:00
void ceph_fscache_unregister_inode_cookie ( struct ceph_inode_info * ci ) ;
2021-12-07 08:44:50 -05:00
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 ) ;
2013-08-21 17:29:54 -04:00
2016-05-18 20:31:55 +08:00
static inline void ceph_fscache_inode_init ( struct ceph_inode_info * ci )
{
ci - > fscache = NULL ;
}
2013-08-21 17:29:54 -04:00
2020-06-01 10:10:21 -04:00
static inline struct fscache_cookie * ceph_fscache_cookie ( struct ceph_inode_info * ci )
{
return ci - > fscache ;
}
2021-12-07 08:44:50 -05:00
static inline void ceph_fscache_resize ( struct inode * inode , loff_t to )
2013-08-21 17:29:54 -04:00
{
2021-12-07 08:44:50 -05:00
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 ) ;
}
2013-08-21 17:29:54 -04:00
}
2021-12-07 08:44:50 -05:00
static inline void ceph_fscache_unpin_writeback ( struct inode * inode ,
struct writeback_control * wbc )
2020-06-01 10:10:21 -04:00
{
2021-12-07 08:44:50 -05:00
fscache_unpin_writeback ( wbc , ceph_fscache_cookie ( ceph_inode ( inode ) ) ) ;
}
static inline int ceph_fscache_set_page_dirty ( struct page * page )
{
struct inode * inode = page - > mapping - > host ;
struct ceph_inode_info * ci = ceph_inode ( inode ) ;
2020-06-01 10:10:21 -04:00
2021-12-07 08:44:50 -05:00
return fscache_set_page_dirty ( page , ceph_fscache_cookie ( ci ) ) ;
2020-06-01 10:10:21 -04:00
}
static inline int ceph_begin_cache_operation ( struct netfs_read_request * rreq )
{
struct fscache_cookie * cookie = ceph_fscache_cookie ( ceph_inode ( rreq - > inode ) ) ;
2021-12-07 08:44:50 -05:00
return fscache_begin_read_operation ( & rreq - > cache_resources , cookie ) ;
2020-06-01 10:10:21 -04:00
}
2013-08-21 17:29:54 -04:00
2021-12-07 08:44:50 -05:00
static inline bool ceph_is_cache_enabled ( struct inode * inode )
2013-08-21 17:29:54 -04:00
{
2021-12-07 08:44:50 -05:00
return fscache_cookie_enabled ( ceph_fscache_cookie ( ceph_inode ( inode ) ) ) ;
2013-08-21 17:29:54 -04:00
}
2021-12-07 08:44:50 -05:00
static inline void ceph_fscache_note_page_release ( struct inode * inode )
2013-08-21 17:29:54 -04:00
{
2021-12-07 08:44:50 -05:00
struct ceph_inode_info * ci = ceph_inode ( inode ) ;
2013-08-21 17:29:54 -04:00
2021-12-07 08:44:50 -05:00
fscache_note_page_release ( ceph_fscache_cookie ( ci ) ) ;
}
# else /* CONFIG_CEPH_FSCACHE */
2019-03-25 16:38:32 +00:00
static inline int ceph_fscache_register_fs ( struct ceph_fs_client * fsc ,
struct fs_context * fc )
2013-08-21 17:29:54 -04:00
{
return 0 ;
}
static inline void ceph_fscache_unregister_fs ( struct ceph_fs_client * fsc )
{
}
static inline void ceph_fscache_inode_init ( struct ceph_inode_info * ci )
{
}
2021-12-07 08:44:50 -05:00
static inline void ceph_fscache_register_inode_cookie ( struct inode * inode )
2020-06-01 10:10:21 -04:00
{
}
2021-12-07 08:44:50 -05:00
static inline void ceph_fscache_unregister_inode_cookie ( struct ceph_inode_info * ci )
2016-05-18 15:25:03 +08:00
{
}
2021-12-07 08:44:50 -05:00
static inline void ceph_fscache_use_cookie ( struct inode * inode , bool will_modify )
2016-05-18 15:25:03 +08:00
{
}
2021-12-07 08:44:50 -05:00
static inline void ceph_fscache_unuse_cookie ( struct inode * inode , bool update )
2013-08-21 17:29:54 -04:00
{
}
2021-12-07 08:44:50 -05:00
static inline void ceph_fscache_update ( struct inode * inode )
2013-08-21 17:29:54 -04:00
{
}
2021-12-07 08:44:50 -05:00
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_set_page_dirty ( struct page * page )
{
return __set_page_dirty_nobuffers ( page ) ;
}
2020-06-01 10:10:21 -04:00
static inline bool ceph_is_cache_enabled ( struct inode * inode )
{
return false ;
}
static inline int ceph_begin_cache_operation ( struct netfs_read_request * rreq )
{
return - ENOBUFS ;
}
2013-08-21 17:29:54 -04:00
2021-12-07 08:44:50 -05:00
static inline void ceph_fscache_note_page_release ( struct inode * inode )
{
}
# endif /* CONFIG_CEPH_FSCACHE */
# endif