/* SPDX-License-Identifier: GPL-2.0 */ /* * Copyright (C) 2021. Huawei Technologies Co., Ltd. All rights reserved. * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License version 2 and * only version 2 as published by the Free Software Foundation. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. */ #ifndef EUFS_ALLOC_INTERFACE_H #define EUFS_ALLOC_INTERFACE_H #include "nvalloc.h" #include "pbatch.h" static __always_inline void *nvzalloc(struct super_block *sb, size_t size, u8 tag, bool nonblocking) { void *r = nvmalloc(sb, size, tag, nonblocking); if (r) memset(r, 0, size); return r; } static __always_inline void * nv_zalloc_file_data_nonblocking(struct super_block *sb) { return nvzalloc(sb, PAGE_SIZE, EUFS_PAGE_FILE_DATA, true); } struct eufs_inode; struct nv_name_ext; struct nv_dict_entry; static __always_inline struct eufs_inode * eufs_malloc_pinode(struct super_block *sb) { /* mirrored inodes: the head inode and the tail inode */ return nvmalloc(sb, EUFS_INODE_SIZE * 2, EUFS_LINE4_INODE, false); } static __always_inline struct nv_dict_entry * eufs_malloc_dentry(struct super_block *sb) { return nvmalloc(sb, CACHELINE_SIZE, EUFS_LINE_DENTRY, false); } static __always_inline struct nv_name_ext * eufs_malloc_name_ext(struct super_block *sb) { return nvmalloc(sb, CACHELINE_SIZE, EUFS_LINE_NAME_EXT, false); } static __always_inline void *eufs_malloc_file_data(struct super_block *sb) { return nvmalloc(sb, PAGE_SIZE, EUFS_PAGE_FILE_DATA, false); } static __always_inline void *eufs_zalloc_file_data(struct super_block *sb) { return nvzalloc(sb, PAGE_SIZE, EUFS_PAGE_FILE_DATA, false); } static __always_inline void *eufs_zmlloc_file_index(struct super_block *sb) { return nvmalloc(sb, PAGE_SIZE, EUFS_PAGE_FILE_INDEX, false); } static __always_inline void *eufs_zalloc_symlink(struct super_block *sb) { return nvzalloc(sb, PAGE_SIZE, EUFS_PAGE_SYMLINK, false); } static __always_inline void *eufs_zalloc_htable(struct super_block *sb) { return nvzalloc(sb, PAGE_SIZE, EUFS_PAGE_HTABLE, false); } static __always_inline void *eufs_malloc_inode_ext(struct super_block *sb) { return nvmalloc(sb, PAGE_SIZE, EUFS_PAGE_INODE_EXT, false); } static __always_inline void nv_zfree(struct super_block *sb, void *p) { if (p == NULL_ADDR_PTR) return; nvfree(sb, p, false); } static __always_inline void nv_free(struct super_block *sb, void *p) { if (p != NULL_ADDR_PTR) nv_zfree(sb, p); } static __always_inline void nv_free_rest(struct super_block *sb, void *p) { if (p != NULL_ADDR_PTR) nvfree(sb, p, true); } static __always_inline void *zalloc(ssize_t size) { return kzalloc(size, GFP_KERNEL); } static __always_inline void zfree(void *p) { kfree(p); } #endif /* EUFS_ALLOC_INTERFACE_H */