Author | Tokens | Token Proportion | Commits | Commit Proportion |
---|---|---|---|---|
Milosz Tanski | 503 | 73.43% | 4 | 44.44% |
Yan Zheng | 104 | 15.18% | 2 | 22.22% |
Li Wang | 66 | 9.64% | 1 | 11.11% |
David Howells | 10 | 1.46% | 1 | 11.11% |
Thomas Gleixner | 2 | 0.29% | 1 | 11.11% |
Total | 685 | 9 |
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176
/* 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 #ifdef CONFIG_CEPH_FSCACHE extern struct fscache_netfs ceph_cache_netfs; int ceph_fscache_register(void); void ceph_fscache_unregister(void); 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_file_set_cookie(struct inode *inode, struct file *filp); void ceph_fscache_revalidate_cookie(struct ceph_inode_info *ci); int ceph_readpage_from_fscache(struct inode *inode, struct page *page); int ceph_readpages_from_fscache(struct inode *inode, struct address_space *mapping, struct list_head *pages, unsigned *nr_pages); void ceph_readpage_to_fscache(struct inode *inode, struct page *page); void ceph_invalidate_fscache_page(struct inode* inode, struct page *page); static inline void ceph_fscache_inode_init(struct ceph_inode_info *ci) { ci->fscache = NULL; ci->i_fscache_gen = 0; } static inline void ceph_fscache_invalidate(struct inode *inode) { fscache_invalidate(ceph_inode(inode)->fscache); } static inline void ceph_fscache_uncache_page(struct inode *inode, struct page *page) { struct ceph_inode_info *ci = ceph_inode(inode); return fscache_uncache_page(ci->fscache, page); } static inline int ceph_release_fscache_page(struct page *page, gfp_t gfp) { struct inode* inode = page->mapping->host; struct ceph_inode_info *ci = ceph_inode(inode); return fscache_maybe_release_page(ci->fscache, page, gfp); } static inline void ceph_fscache_readpage_cancel(struct inode *inode, struct page *page) { struct ceph_inode_info *ci = ceph_inode(inode); if (fscache_cookie_valid(ci->fscache) && PageFsCache(page)) __fscache_uncache_page(ci->fscache, page); } static inline void ceph_fscache_readpages_cancel(struct inode *inode, struct list_head *pages) { struct ceph_inode_info *ci = ceph_inode(inode); return fscache_readpages_cancel(ci->fscache, pages); } static inline void ceph_disable_fscache_readpage(struct ceph_inode_info *ci) { ci->i_fscache_gen = ci->i_rdcache_gen - 1; } #else static inline int ceph_fscache_register(void) { return 0; } static inline void ceph_fscache_unregister(void) { } 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_inode_init(struct ceph_inode_info *ci) { } 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_file_set_cookie(struct inode *inode, struct file *filp) { } static inline void ceph_fscache_revalidate_cookie(struct ceph_inode_info *ci) { } static inline void ceph_fscache_uncache_page(struct inode *inode, struct page *pages) { } static inline int ceph_readpage_from_fscache(struct inode* inode, struct page *page) { return -ENOBUFS; } static inline int ceph_readpages_from_fscache(struct inode *inode, struct address_space *mapping, struct list_head *pages, unsigned *nr_pages) { return -ENOBUFS; } static inline void ceph_readpage_to_fscache(struct inode *inode, struct page *page) { } static inline void ceph_fscache_invalidate(struct inode *inode) { } static inline void ceph_invalidate_fscache_page(struct inode *inode, struct page *page) { } static inline int ceph_release_fscache_page(struct page *page, gfp_t gfp) { return 1; } static inline void ceph_fscache_readpage_cancel(struct inode *inode, struct page *page) { } static inline void ceph_fscache_readpages_cancel(struct inode *inode, struct list_head *pages) { } static inline void ceph_disable_fscache_readpage(struct ceph_inode_info *ci) { } #endif #endif
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with Cregit http://github.com/cregit/cregit
Version 2.0-RC1