Adjust the content map when we shorten a backing object. In this case, only the unused tail of the content map after shortening gets zeroed, while the size of the content map itself is not changed. Also the corresponding range in the backing content map file is not changed. Besides, the content map and the corresponding range in the backing content map file are not touched when we expand a backing object. They will be lazily expanded at runtime later. Signed-off-by: Jingbo Xu <jefflexu@xxxxxxxxxxxxxxxxx> --- fs/cachefiles/content-map.c | 23 +++++++++++++++++++++++ fs/cachefiles/interface.c | 1 + fs/cachefiles/internal.h | 2 ++ 3 files changed, 26 insertions(+) diff --git a/fs/cachefiles/content-map.c b/fs/cachefiles/content-map.c index b73a109844ca..360c59b06670 100644 --- a/fs/cachefiles/content-map.c +++ b/fs/cachefiles/content-map.c @@ -271,3 +271,26 @@ void cachefiles_invalidate_content_map(struct cachefiles_object *object) } write_unlock_bh(&object->content_map_lock); } + +/* + * Adjust the content map when we shorten a backing object. + */ +void cachefiles_shorten_content_map(struct cachefiles_object *object, + loff_t new_size) +{ + if (object->content_info != CACHEFILES_CONTENT_MAP) + return; + + read_lock_bh(&object->content_map_lock); + /* + * Nothing needs to be done when content map has not been allocated yet. + */ + if (!object->content_map_size) + goto out; + + if (cachefiles_map_size(new_size) <= object->content_map_size) + cachefiles_zero_content_map(object->content_map, + object->content_map_size, new_size); +out: + read_unlock_bh(&object->content_map_lock); +} diff --git a/fs/cachefiles/interface.c b/fs/cachefiles/interface.c index f87b9a665d85..76f70a9ebe50 100644 --- a/fs/cachefiles/interface.c +++ b/fs/cachefiles/interface.c @@ -290,6 +290,7 @@ static void cachefiles_resize_cookie(struct netfs_cache_resources *cres, cachefiles_begin_secure(cache, &saved_cred); cachefiles_shorten_object(object, file, new_size); cachefiles_end_secure(cache, saved_cred); + cachefiles_shorten_content_map(object, new_size); object->cookie->object_size = new_size; return; } diff --git a/fs/cachefiles/internal.h b/fs/cachefiles/internal.h index c674c4e42529..7747f99f00c1 100644 --- a/fs/cachefiles/internal.h +++ b/fs/cachefiles/internal.h @@ -188,6 +188,8 @@ extern loff_t cachefiles_find_next_granule(struct cachefiles_object *object, extern loff_t cachefiles_find_next_hole(struct cachefiles_object *object, loff_t start); extern void cachefiles_invalidate_content_map(struct cachefiles_object *object); +extern void cachefiles_shorten_content_map(struct cachefiles_object *object, + loff_t new_size); /* * daemon.c -- 2.27.0 -- Linux-cachefs mailing list Linux-cachefs@xxxxxxxxxx https://listman.redhat.com/mailman/listinfo/linux-cachefs