/* ----> 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 | |