/* ChibiOS - Copyright (C) 2006,2007,2008,2009,2010,2011,2012,2013,2014, 2015,2016,2017,2018,2019,2020,2021 Giovanni Di Sirio. This file is part of ChibiOS. ChibiOS is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation version 3 of the License. ChibiOS 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. You should have received a copy of the GNU General Public License along with this program. If not, see . */ /** * @file vfs/include/vfsnodes.h * @brief VFS nodes header file. * * @addtogroup VFS_NODES * @{ */ #ifndef VFSNODES_H #define VFSNODES_H /*===========================================================================*/ /* Module constants. */ /*===========================================================================*/ /** * @name Node attributes. * @{ */ #define VFS_NODE_ATTR_READONLY 1U #define VFS_NODE_ATTR_RESERVED2 2U #define VFS_NODE_ATTR_SYSTEM 4U #define VFS_NODE_ATTR_RESERVED8 8U #define VFS_NODE_ATTR_ISDIR 16U /** @} */ /*===========================================================================*/ /* Module pre-compile time settings. */ /*===========================================================================*/ /*===========================================================================*/ /* Derived constants and error checks. */ /*===========================================================================*/ /*===========================================================================*/ /* Module data structures and types. */ /*===========================================================================*/ /* Forward declaration because nodes holds references to drivers.*/ typedef struct vfs_driver vfs_driver_t; /** * @brief Type of a file offset. */ typedef uint32_t vfs_fileoffset_t; /** * @brief Type of a node attributes. */ typedef uint32_t vfs_nodeattr_t; /** * @brief Type of a node information structure. * @todo Add attributes, permissions etc. */ typedef struct vfs_node_info { /** * @brief Size of the node. */ vfs_nodeattr_t attr; /** * @brief Size of the node. */ vfs_fileoffset_t size; /** * @brief Name of the node. */ char name[VFS_CFG_MAX_NAMELEN + 1]; } vfs_node_info_t; /** * @brief @p vfs_node_t specific methods. */ #define __vfs_node_methods \ /* Instance offset, used for multiple inheritance, normally zero. It represents the offset between the current object and the container object*/ \ size_t instance_offset; \ /* Node release, the object is disposed when the counter reaches zero.*/ \ void (*release)(void *instance); /** * @brief @p vfs_node_t specific data. */ #define __vfs_node_data \ /* Number of references to this node.*/ \ unsigned references_counter; \ /* Driver handling this node.*/ \ vfs_driver_t *driver; /** * @brief @p vfs_node_t virtual methods table. */ struct vfs_node_vmt { __vfs_node_methods }; /** * @brief Type of a structure representing a generic VFS node. */ typedef struct vfs_node { /** * @brief Virtual Methods Table. */ const struct vfs_node_vmt *vmt; __vfs_node_data } vfs_node_t; /** * @brief @p vfs_directory_node_t specific methods. */ #define __vfs_directory_node_methods \ __vfs_node_methods /** * @brief @p vfs_directory_node_t specific data. */ #define __vfs_directory_node_data \ __vfs_node_data /** * @brief @p vfs_directory_node_t virtual methods table. */ struct vfs_directory_node_vmt { __vfs_directory_node_methods }; /** * @brief Type of a structure representing a directory VFS node. */ typedef struct vfs_directory_node { /** * @brief Virtual Methods Table. */ const struct vfs_directory_node_vmt *vmt; __vfs_directory_node_data } vfs_directory_node_t; /** * @brief @p vfs_file_node_t specific methods. */ #define __vfs_file_node_methods \ __vfs_node_methods \ bool (*first)(vfs_node_info_t *nif); \ bool (*next)(vfs_node_info_t *nif); /** * @brief @p vfs_file_node_t specific data. */ #define __vfs_file_node_data \ __vfs_node_data /** * @brief @p vfs_file_node_t virtual methods table. */ struct vfs_file_node_vmt { __vfs_file_node_methods }; /** * @brief Type of a structure representing a file VFS node. */ typedef struct vfs_file_node { /** * @brief Virtual Methods Table. */ const struct vfs_directory_node_vmt *vmt; __vfs_file_node_data } vfs_file_node_t; /*===========================================================================*/ /* Module macros. */ /*===========================================================================*/ /*===========================================================================*/ /* External declarations. */ /*===========================================================================*/ #ifdef __cplusplus extern "C" { #endif #ifdef __cplusplus } #endif #endif /* VFSNODES_H */ /** @} */