/* * Copyright (c) 2013-2019, Huawei Technologies Co., Ltd. All rights reserved. * Copyright (c) 2020, Huawei Device Co., Ltd. All rights reserved. * * Redistribution and use in source and binary forms, with or without modification, * are permitted provided that the following conditions are met: * * 1. Redistributions of source code must retain the above copyright notice, this list of * conditions and the following disclaimer. * * 2. Redistributions in binary form must reproduce the above copyright notice, this list * of conditions and the following disclaimer in the documentation and/or other materials * provided with the distribution. * * 3. Neither the name of the copyright holder nor the names of its contributors may be used * to endorse or promote products derived from this software without specific prior written * permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ /** * @defgroup filesystem FileSystem * @defgroup mtd_partition Multi Partition * @ingroup filesystem */ #ifndef _MTD_PARTITION_H #define _MTD_PARTITION_H #include "sys/types.h" #include "los_mux.h" #include "mtd_list.h" #ifdef __cplusplus #if __cplusplus extern "C" { #endif /* __cplusplus */ #endif /* __cplusplus */ #define SPIBLK_NAME "/dev/spinorblk" #define SPICHR_NAME "/dev/spinorchr" #define NANDBLK_NAME "/dev/nandblk" #define NANDCHR_NAME "/dev/nandchr" typedef struct mtd_node { UINT32 start_block; UINT32 end_block; UINT32 patitionnum; CHAR *blockdriver_name; CHAR *chardriver_name; CHAR *mountpoint_name; VOID *mtd_info; /* Driver used by a partition */ LOS_DL_LIST node_info; LosMux lock; UINT32 user_num; } mtd_partition; typedef struct par_param { mtd_partition *partition_head; struct MtdDev *flash_mtd; const struct block_operations *flash_ops; const struct file_operations_vfs *char_ops; CHAR *blockname; CHAR *charname; UINT32 block_size; } partition_param; #define CONFIG_MTD_PATTITION_NUM 20 #define ALIGN_ASSIGN(len, startAddr, startBlk, endBlk, blkSize) do { \ (len) = (((len) + ((blkSize) - 1)) & ~((blkSize) - 1)); \ (startAddr) = ((startAddr) & ~((blkSize) - 1)); \ (startBlk) = (startAddr) / (blkSize); \ (endBlk) = (len) / (blkSize) + ((startBlk) - 1); \ } while (0) #define PAR_ASSIGNMENT(node, len, startAddr, num, mtd, blkSize) do { \ (node)->start_block = (startAddr) / (blkSize); \ (node)->end_block = (len) / (blkSize) + ((node)->start_block - 1); \ (node)->patitionnum = (num); \ (node)->mtd_info = (mtd); \ (node)->mountpoint_name = NULL; \ } while (0) mtd_partition *GetSpinorPartitionHead(VOID); /** * @ingroup mtd_partition * @brief Add a partition. * * @par Description: * * @attention * * * @param type [IN] Storage medium type, support "nand" and "spinor" currently. * @param startAddr [IN] Starting address of a partition. * @param length [IN] Partition size. * @param partitionNum [IN] Partition number, less than the value defined by CONFIG_MTD_PATTITION_NUM. * * @retval #-ENODEV The driver is not found. * @retval #-EINVAL Invalid parameter. * @retval #-ENOMEM Insufficient memory. * @retval #ENOERR The partition is successfully created. * * @par Dependency: * * @see delete_mtd_partition */ extern INT32 add_mtd_partition(const CHAR *type, UINT32 startAddr, UINT32 length, UINT32 partitionNum); /** * @ingroup mtd_partition * @brief Delete a partition. * * @par Description: * * @attention * * * @param partitionNum [IN] Partition number, less than the value defined by CONFIG_MTD_PATTITION_NUM. * @param type [IN] Storage medium type, support "nand" and "spinor" currently. * * @retval #-EINVAL Invalid parameter. * @retval #ENOERR The partition is successfully deleted. * * @par Dependency: * * @see add_mtd_partition */ extern INT32 delete_mtd_partition(UINT32 partitionNum, const CHAR *type); #ifdef __cplusplus #if __cplusplus } #endif /* __cplusplus */ #endif /* __cplusplus */ #endif /* _MTD_PARTITION_H */