mirror of
				https://github.com/FreeRTOS/FreeRTOS-Kernel.git
				synced 2025-10-22 04:37:49 -04:00 
			
		
		
		
	* Use new version of CI-CD Actions, checkout@v3 instead of checkout@v2 on all jobs * Use cSpell spell check, and use ubuntu-20.04 for formatting check * Add in bot formatting action * Update freertos_demo.yml and freertos_plus_demo.yml files to increase github log readability * Add in a Qemu demo onto the workflows.
		
			
				
	
	
		
			119 lines
		
	
	
	
		
			4.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			119 lines
		
	
	
	
		
			4.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*             ----> DO NOT REMOVE THE FOLLOWING NOTICE <----
 | |
|  *
 | |
|  *                 Copyright (c) 2014-2015 Datalight, Inc.
 | |
|  *                     All Rights Reserved Worldwide.
 | |
|  *
 | |
|  *  This program 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; use version 2 of the License.
 | |
|  *
 | |
|  *  This program is distributed in the hope that it will be useful,
 | |
|  *  but "AS-IS," 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, write to the Free Software Foundation, Inc.,
 | |
|  *  51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
 | |
|  */
 | |
| 
 | |
| /*  Businesses and individuals that for commercial or other reasons cannot
 | |
|  *  comply with the terms of the GPLv2 license may obtain a commercial license
 | |
|  *  before incorporating Reliance Edge into proprietary software for
 | |
|  *  distribution in any form.  Visit http://www.datalight.com/reliance-edge for
 | |
|  *  more information.
 | |
|  */
 | |
| 
 | |
| /** @file
 | |
|  *  @brief Interface for the Reliance Edge FSE API.
 | |
|  *
 | |
|  *  The FSE (File Systems Essentials) API is a minimalist file system API
 | |
|  *  intended for simple use cases with a fixed number of statically-defined
 | |
|  *  files.  It does not support creating or deleting files dynamically.  Files
 | |
|  *  are referenced by a fixed file number, rather than by name; there are no
 | |
|  *  file names and no directories.  There are also no file handles: files are
 | |
|  *  not opened or closed, and file offsets are given explicitly.
 | |
|  *
 | |
|  *  If the FSE API is too limited to meet the needs of your application,
 | |
|  *  consider using the more feature-rich POSIX-like file system API instead.
 | |
|  */
 | |
| #ifndef REDFSE_H
 | |
|     #define REDFSE_H
 | |
| 
 | |
| /*  This header is intended for application use; some applications are written
 | |
|  *  in C++.
 | |
|  */
 | |
|     #ifdef __cplusplus
 | |
|     extern "C" {
 | |
|     #endif
 | |
| 
 | |
|     #include <redconf.h>
 | |
| 
 | |
|     #if REDCONF_API_FSE == 1
 | |
| 
 | |
|         #include <redtypes.h>
 | |
|         #include "redapimacs.h"
 | |
|         #include "rederrno.h"
 | |
| 
 | |
| 
 | |
| /** @brief First valid file number.
 | |
|  *
 | |
|  *  This macro can be used to statically define file numbers for given files,
 | |
|  *  as in the below example:
 | |
|  *
 | |
|  *  ~~~{.c}
 | |
|  #define LOG_FILE        (RED_FILENUM_FIRST_VALID)
 | |
|  #define DATABASE_FILE   (RED_FILENUM_FIRST_VALID + 1U)
 | |
|  #define ICON1_FILE      (RED_FILENUM_FIRST_VALID + 2U)
 | |
|  #define ICON2_FILE      (RED_FILENUM_FIRST_VALID + 3U)
 | |
|  *  ~~~
 | |
|  */
 | |
|         #define RED_FILENUM_FIRST_VALID    ( 2U )
 | |
| 
 | |
| 
 | |
|         REDSTATUS RedFseInit( void );
 | |
|         REDSTATUS RedFseUninit( void );
 | |
|         REDSTATUS RedFseMount( uint8_t bVolNum );
 | |
|         REDSTATUS RedFseUnmount( uint8_t bVolNum );
 | |
|         #if ( REDCONF_READ_ONLY == 0 ) && ( REDCONF_API_FSE_FORMAT == 1 )
 | |
|             REDSTATUS RedFseFormat( uint8_t bVolNum );
 | |
|         #endif
 | |
|         int32_t RedFseRead( uint8_t bVolNum,
 | |
|                             uint32_t ulFileNum,
 | |
|                             uint64_t ullFileOffset,
 | |
|                             uint32_t ulLength,
 | |
|                             void * pBuffer );
 | |
|         #if REDCONF_READ_ONLY == 0
 | |
|             int32_t RedFseWrite( uint8_t bVolNum,
 | |
|                                  uint32_t ulFileNum,
 | |
|                                  uint64_t ullFileOffset,
 | |
|                                  uint32_t ulLength,
 | |
|                                  const void * pBuffer );
 | |
|         #endif
 | |
|         #if ( REDCONF_READ_ONLY == 0 ) && ( REDCONF_API_FSE_TRUNCATE == 1 )
 | |
|             REDSTATUS RedFseTruncate( uint8_t bVolNum,
 | |
|                                       uint32_t ulFileNum,
 | |
|                                       uint64_t ullNewFileSize );
 | |
|         #endif
 | |
|         int64_t RedFseSizeGet( uint8_t bVolNum,
 | |
|                                uint32_t ulFileNum );
 | |
|         #if ( REDCONF_READ_ONLY == 0 ) && ( REDCONF_API_FSE_TRANSMASKSET == 1 )
 | |
|             REDSTATUS RedFseTransMaskSet( uint8_t bVolNum,
 | |
|                                           uint32_t ulEventMask );
 | |
|         #endif
 | |
|         #if REDCONF_API_FSE_TRANSMASKGET == 1
 | |
|             REDSTATUS RedFseTransMaskGet( uint8_t bVolNum,
 | |
|                                           uint32_t * pulEventMask );
 | |
|         #endif
 | |
|         #if REDCONF_READ_ONLY == 0
 | |
|             REDSTATUS RedFseTransact( uint8_t bVolNum );
 | |
|         #endif
 | |
| 
 | |
|     #endif /* REDCONF_API_FSE == 1 */
 | |
| 
 | |
| 
 | |
|     #ifdef __cplusplus
 | |
| }
 | |
|     #endif
 | |
| 
 | |
| #endif /* ifndef REDFSE_H */
 |