| /* SPDX-License-Identifier: LGPL-2.1 */ | 
 | /* | 
 |  *   CIFS filesystem cache interface definitions | 
 |  * | 
 |  *   Copyright (c) 2010 Novell, Inc. | 
 |  *   Authors(s): Suresh Jayaraman (sjayaraman@suse.de> | 
 |  * | 
 |  */ | 
 | #ifndef _CIFS_FSCACHE_H | 
 | #define _CIFS_FSCACHE_H | 
 |  | 
 | #include <linux/fscache.h> | 
 |  | 
 | #include "cifsglob.h" | 
 |  | 
 | #ifdef CONFIG_CIFS_FSCACHE | 
 |  | 
 | /* | 
 |  * Auxiliary data attached to CIFS superblock within the cache | 
 |  */ | 
 | struct cifs_fscache_super_auxdata { | 
 | 	u64	resource_id;		/* unique server resource id */ | 
 | 	__le64	vol_create_time; | 
 | 	u32	vol_serial_number; | 
 | } __packed; | 
 |  | 
 | /* | 
 |  * Auxiliary data attached to CIFS inode within the cache | 
 |  */ | 
 | struct cifs_fscache_inode_auxdata { | 
 | 	u64 last_write_time_sec; | 
 | 	u64 last_change_time_sec; | 
 | 	u32 last_write_time_nsec; | 
 | 	u32 last_change_time_nsec; | 
 | 	u64 eof; | 
 | }; | 
 |  | 
 | /* | 
 |  * cache.c | 
 |  */ | 
 | extern struct fscache_netfs cifs_fscache_netfs; | 
 | extern const struct fscache_cookie_def cifs_fscache_server_index_def; | 
 | extern const struct fscache_cookie_def cifs_fscache_super_index_def; | 
 | extern const struct fscache_cookie_def cifs_fscache_inode_object_def; | 
 |  | 
 | extern int cifs_fscache_register(void); | 
 | extern void cifs_fscache_unregister(void); | 
 |  | 
 | /* | 
 |  * fscache.c | 
 |  */ | 
 | extern void cifs_fscache_get_client_cookie(struct TCP_Server_Info *); | 
 | extern void cifs_fscache_release_client_cookie(struct TCP_Server_Info *); | 
 | extern void cifs_fscache_get_super_cookie(struct cifs_tcon *); | 
 | extern void cifs_fscache_release_super_cookie(struct cifs_tcon *); | 
 |  | 
 | extern void cifs_fscache_release_inode_cookie(struct inode *); | 
 | extern void cifs_fscache_update_inode_cookie(struct inode *inode); | 
 | extern void cifs_fscache_set_inode_cookie(struct inode *, struct file *); | 
 | extern void cifs_fscache_reset_inode_cookie(struct inode *); | 
 |  | 
 | extern void __cifs_fscache_invalidate_page(struct page *, struct inode *); | 
 | extern void __cifs_fscache_wait_on_page_write(struct inode *inode, struct page *page); | 
 | extern void __cifs_fscache_uncache_page(struct inode *inode, struct page *page); | 
 | extern int cifs_fscache_release_page(struct page *page, gfp_t gfp); | 
 | extern int __cifs_readpage_from_fscache(struct inode *, struct page *); | 
 | extern int __cifs_readpages_from_fscache(struct inode *, | 
 | 					 struct address_space *, | 
 | 					 struct list_head *, | 
 | 					 unsigned *); | 
 | extern void __cifs_fscache_readpages_cancel(struct inode *, struct list_head *); | 
 |  | 
 | extern void __cifs_readpage_to_fscache(struct inode *, struct page *); | 
 |  | 
 | static inline void cifs_fscache_invalidate_page(struct page *page, | 
 | 					       struct inode *inode) | 
 | { | 
 | 	if (PageFsCache(page)) | 
 | 		__cifs_fscache_invalidate_page(page, inode); | 
 | } | 
 |  | 
 | static inline void cifs_fscache_wait_on_page_write(struct inode *inode, | 
 | 						   struct page *page) | 
 | { | 
 | 	if (PageFsCache(page)) | 
 | 		__cifs_fscache_wait_on_page_write(inode, page); | 
 | } | 
 |  | 
 | static inline void cifs_fscache_uncache_page(struct inode *inode, | 
 | 						   struct page *page) | 
 | { | 
 | 	if (PageFsCache(page)) | 
 | 		__cifs_fscache_uncache_page(inode, page); | 
 | } | 
 |  | 
 | static inline int cifs_readpage_from_fscache(struct inode *inode, | 
 | 					     struct page *page) | 
 | { | 
 | 	if (CIFS_I(inode)->fscache) | 
 | 		return __cifs_readpage_from_fscache(inode, page); | 
 |  | 
 | 	return -ENOBUFS; | 
 | } | 
 |  | 
 | static inline int cifs_readpages_from_fscache(struct inode *inode, | 
 | 					      struct address_space *mapping, | 
 | 					      struct list_head *pages, | 
 | 					      unsigned *nr_pages) | 
 | { | 
 | 	if (CIFS_I(inode)->fscache) | 
 | 		return __cifs_readpages_from_fscache(inode, mapping, pages, | 
 | 						     nr_pages); | 
 | 	return -ENOBUFS; | 
 | } | 
 |  | 
 | static inline void cifs_readpage_to_fscache(struct inode *inode, | 
 | 					    struct page *page) | 
 | { | 
 | 	if (PageFsCache(page)) | 
 | 		__cifs_readpage_to_fscache(inode, page); | 
 | } | 
 |  | 
 | static inline void cifs_fscache_readpages_cancel(struct inode *inode, | 
 | 						 struct list_head *pages) | 
 | { | 
 | 	if (CIFS_I(inode)->fscache) | 
 | 		return __cifs_fscache_readpages_cancel(inode, pages); | 
 | } | 
 |  | 
 | #else /* CONFIG_CIFS_FSCACHE */ | 
 | static inline int cifs_fscache_register(void) { return 0; } | 
 | static inline void cifs_fscache_unregister(void) {} | 
 |  | 
 | static inline void | 
 | cifs_fscache_get_client_cookie(struct TCP_Server_Info *server) {} | 
 | static inline void | 
 | cifs_fscache_release_client_cookie(struct TCP_Server_Info *server) {} | 
 | static inline void cifs_fscache_get_super_cookie(struct cifs_tcon *tcon) {} | 
 | static inline void | 
 | cifs_fscache_release_super_cookie(struct cifs_tcon *tcon) {} | 
 |  | 
 | static inline void cifs_fscache_release_inode_cookie(struct inode *inode) {} | 
 | static inline void cifs_fscache_update_inode_cookie(struct inode *inode) {} | 
 | static inline void cifs_fscache_set_inode_cookie(struct inode *inode, | 
 | 						 struct file *filp) {} | 
 | static inline void cifs_fscache_reset_inode_cookie(struct inode *inode) {} | 
 | static inline int cifs_fscache_release_page(struct page *page, gfp_t gfp) | 
 | { | 
 | 	return 1; /* May release page */ | 
 | } | 
 |  | 
 | static inline void cifs_fscache_invalidate_page(struct page *page, | 
 | 			struct inode *inode) {} | 
 | static inline void cifs_fscache_wait_on_page_write(struct inode *inode, | 
 | 						   struct page *page) {} | 
 | static inline void cifs_fscache_uncache_page(struct inode *inode, | 
 | 						   struct page *page) {} | 
 |  | 
 | static inline int | 
 | cifs_readpage_from_fscache(struct inode *inode, struct page *page) | 
 | { | 
 | 	return -ENOBUFS; | 
 | } | 
 |  | 
 | static inline int cifs_readpages_from_fscache(struct inode *inode, | 
 | 					      struct address_space *mapping, | 
 | 					      struct list_head *pages, | 
 | 					      unsigned *nr_pages) | 
 | { | 
 | 	return -ENOBUFS; | 
 | } | 
 |  | 
 | static inline void cifs_readpage_to_fscache(struct inode *inode, | 
 | 			struct page *page) {} | 
 |  | 
 | static inline void cifs_fscache_readpages_cancel(struct inode *inode, | 
 | 						 struct list_head *pages) | 
 | { | 
 | } | 
 |  | 
 | #endif /* CONFIG_CIFS_FSCACHE */ | 
 |  | 
 | #endif /* _CIFS_FSCACHE_H */ |