2017-11-23 20:42:14 +01:00
|
|
|
/**
|
2017-11-24 17:48:47 +01:00
|
|
|
* @file lv_fs.h
|
2018-06-19 09:49:58 +02:00
|
|
|
*
|
2017-11-23 20:42:14 +01:00
|
|
|
*/
|
|
|
|
|
2017-11-24 17:48:47 +01:00
|
|
|
#ifndef LV_FS_H
|
|
|
|
#define LV_FS_H
|
2017-11-23 20:42:14 +01:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/*********************
|
|
|
|
* INCLUDES
|
|
|
|
*********************/
|
2018-09-13 15:09:05 +03:00
|
|
|
#ifdef LV_CONF_INCLUDE_SIMPLE
|
|
|
|
#include "lv_conf.h"
|
|
|
|
#else
|
|
|
|
#include "../../lv_conf.h"
|
|
|
|
#endif
|
|
|
|
|
2018-09-14 12:40:30 +03:00
|
|
|
#if USE_LV_FILESYSTEM
|
|
|
|
|
2017-11-23 20:42:14 +01:00
|
|
|
#include <stdint.h>
|
|
|
|
#include <stdbool.h>
|
|
|
|
#include "lv_mem.h"
|
|
|
|
|
|
|
|
/*********************
|
|
|
|
* DEFINES
|
|
|
|
*********************/
|
2017-11-26 11:38:28 +01:00
|
|
|
#define LV_FS_MAX_FN_LENGTH 64
|
2017-11-23 20:42:14 +01:00
|
|
|
|
|
|
|
/**********************
|
|
|
|
* TYPEDEFS
|
|
|
|
**********************/
|
2018-09-18 13:59:40 +02:00
|
|
|
enum
|
2017-11-23 20:42:14 +01:00
|
|
|
{
|
2017-12-03 22:32:09 +01:00
|
|
|
LV_FS_RES_OK = 0,
|
|
|
|
LV_FS_RES_HW_ERR, /*Low level hardware error*/
|
|
|
|
LV_FS_RES_FS_ERR, /*Error in the file system structure */
|
|
|
|
LV_FS_RES_NOT_EX, /*Driver, file or directory is not exists*/
|
|
|
|
LV_FS_RES_FULL, /*Disk full*/
|
|
|
|
LV_FS_RES_LOCKED, /*The file is already opened*/
|
|
|
|
LV_FS_RES_DENIED, /*Access denied. Check 'fs_open' modes and write protect*/
|
|
|
|
LV_FS_RES_BUSY, /*The file system now can't handle it, try later*/
|
|
|
|
LV_FS_RES_TOUT, /*Process time outed*/
|
|
|
|
LV_FS_RES_NOT_IMP, /*Requested function is not implemented*/
|
|
|
|
LV_FS_RES_OUT_OF_MEM, /*Not enough memory for an internal operation*/
|
|
|
|
LV_FS_RES_INV_PARAM, /*Invalid parameter among arguments*/
|
|
|
|
LV_FS_RES_UNKNOWN, /*Other unknown error*/
|
2018-09-18 13:59:40 +02:00
|
|
|
};
|
|
|
|
typedef uint8_t lv_fs_res_t;
|
2017-11-23 20:42:14 +01:00
|
|
|
|
2017-12-03 22:32:09 +01:00
|
|
|
struct __lv_fs_drv_t;
|
2018-06-19 09:49:58 +02:00
|
|
|
|
2017-11-23 20:42:14 +01:00
|
|
|
typedef struct
|
|
|
|
{
|
|
|
|
void * file_d;
|
2017-12-03 22:32:09 +01:00
|
|
|
struct __lv_fs_drv_t* drv;
|
2018-06-19 09:49:58 +02:00
|
|
|
} lv_fs_file_t;
|
2017-11-23 20:42:14 +01:00
|
|
|
|
|
|
|
|
|
|
|
typedef struct
|
|
|
|
{
|
2017-12-03 22:32:09 +01:00
|
|
|
void * dir_d;
|
|
|
|
struct __lv_fs_drv_t * drv;
|
2018-06-19 09:49:58 +02:00
|
|
|
} lv_fs_dir_t;
|
2017-11-23 20:42:14 +01:00
|
|
|
|
2018-09-18 13:59:40 +02:00
|
|
|
enum
|
2017-11-23 20:42:14 +01:00
|
|
|
{
|
2017-12-03 22:32:09 +01:00
|
|
|
LV_FS_MODE_WR = 0x01,
|
|
|
|
LV_FS_MODE_RD = 0x02,
|
2018-09-18 13:59:40 +02:00
|
|
|
};
|
|
|
|
typedef uint8_t lv_fs_mode_t;
|
2017-11-23 20:42:14 +01:00
|
|
|
|
2017-12-03 22:32:09 +01:00
|
|
|
typedef struct __lv_fs_drv_t
|
2017-11-23 20:42:14 +01:00
|
|
|
{
|
|
|
|
char letter;
|
|
|
|
uint16_t file_size;
|
|
|
|
uint16_t rddir_size;
|
|
|
|
bool (*ready) (void);
|
2018-06-19 09:49:58 +02:00
|
|
|
|
2017-11-24 17:48:47 +01:00
|
|
|
lv_fs_res_t (*open) (void * file_p, const char * path, lv_fs_mode_t mode);
|
|
|
|
lv_fs_res_t (*close) (void * file_p);
|
|
|
|
lv_fs_res_t (*remove) (const char * fn);
|
|
|
|
lv_fs_res_t (*read) (void * file_p, void * buf, uint32_t btr, uint32_t * br);
|
|
|
|
lv_fs_res_t (*write) (void * file_p, const void * buf, uint32_t btw, uint32_t * bw);
|
|
|
|
lv_fs_res_t (*seek) (void * file_p, uint32_t pos);
|
|
|
|
lv_fs_res_t (*tell) (void * file_p, uint32_t * pos_p);
|
|
|
|
lv_fs_res_t (*trunc) (void * file_p);
|
|
|
|
lv_fs_res_t (*size) (void * file_p, uint32_t * size_p);
|
2018-09-20 21:58:10 +02:00
|
|
|
lv_fs_res_t (*rename) (const char * oldname, const char * newname);
|
2019-02-25 15:34:35 +01:00
|
|
|
lv_fs_res_t (*free_space) (uint32_t * total_p, uint32_t * free_p);
|
2018-06-19 09:49:58 +02:00
|
|
|
|
2017-12-03 22:32:09 +01:00
|
|
|
lv_fs_res_t (*dir_open) (void * rddir_p, const char * path);
|
|
|
|
lv_fs_res_t (*dir_read) (void * rddir_p, char * fn);
|
|
|
|
lv_fs_res_t (*dir_close) (void * rddir_p);
|
2018-06-19 09:49:58 +02:00
|
|
|
} lv_fs_drv_t;
|
2017-11-23 20:42:14 +01:00
|
|
|
|
|
|
|
/**********************
|
|
|
|
* GLOBAL PROTOTYPES
|
|
|
|
**********************/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Initialize the File system interface
|
|
|
|
*/
|
2017-11-24 17:48:47 +01:00
|
|
|
void lv_fs_init(void);
|
2017-11-23 20:42:14 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Add a new drive
|
2017-11-24 17:48:47 +01:00
|
|
|
* @param drv_p pointer to an lv_fs_drv_t structure which is inited with the
|
2017-12-03 22:32:09 +01:00
|
|
|
* corresponding function pointers. The data will be copied so the variable can be local.
|
2017-11-23 20:42:14 +01:00
|
|
|
*/
|
2017-11-24 17:48:47 +01:00
|
|
|
void lv_fs_add_drv(lv_fs_drv_t * drv_p);
|
2017-11-23 20:42:14 +01:00
|
|
|
|
2019-01-31 13:24:02 +01:00
|
|
|
/**
|
|
|
|
* Test if a drive is rady or not. If the `ready` function was not initialized `true` will be returned.
|
|
|
|
* @param letter letter of the drive
|
|
|
|
* @return true: drive is ready; false: drive is not ready
|
|
|
|
*/
|
|
|
|
bool lv_fs_is_ready(char letter);
|
|
|
|
|
2017-11-23 20:42:14 +01:00
|
|
|
/**
|
|
|
|
* Open a file
|
2017-11-24 17:48:47 +01:00
|
|
|
* @param file_p pointer to a lv_fs_file_t variable
|
2017-11-23 20:42:14 +01:00
|
|
|
* @param path path to the file beginning with the driver letter (e.g. S:/folder/file.txt)
|
|
|
|
* @param mode read: FS_MODE_RD, write: FS_MODE_WR, both: FS_MODE_RD | FS_MODE_WR
|
2017-12-03 22:32:09 +01:00
|
|
|
* @return LV_FS_RES_OK or any error from lv_fs_res_t enum
|
2017-11-23 20:42:14 +01:00
|
|
|
*/
|
2017-11-24 17:48:47 +01:00
|
|
|
lv_fs_res_t lv_fs_open (lv_fs_file_t * file_p, const char * path, lv_fs_mode_t mode);
|
2017-11-23 20:42:14 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Close an already opened file
|
2017-11-24 17:48:47 +01:00
|
|
|
* @param file_p pointer to a lv_fs_file_t variable
|
2017-12-03 22:32:09 +01:00
|
|
|
* @return LV_FS_RES_OK or any error from lv_fs_res_t enum
|
2017-11-23 20:42:14 +01:00
|
|
|
*/
|
2017-11-24 17:48:47 +01:00
|
|
|
lv_fs_res_t lv_fs_close (lv_fs_file_t * file_p);
|
2017-11-23 20:42:14 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Delete a file
|
|
|
|
* @param path path of the file to delete
|
2017-12-03 22:32:09 +01:00
|
|
|
* @return LV_FS_RES_OK or any error from lv_fs_res_t enum
|
2017-11-23 20:42:14 +01:00
|
|
|
*/
|
2017-11-24 17:48:47 +01:00
|
|
|
lv_fs_res_t lv_fs_remove (const char * path);
|
2017-11-23 20:42:14 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Read from a file
|
2017-11-24 17:48:47 +01:00
|
|
|
* @param file_p pointer to a lv_fs_file_t variable
|
2017-11-23 20:42:14 +01:00
|
|
|
* @param buf pointer to a buffer where the read bytes are stored
|
|
|
|
* @param btr Bytes To Read
|
|
|
|
* @param br the number of real read bytes (Bytes Read). NULL if unused.
|
2017-12-03 22:32:09 +01:00
|
|
|
* @return LV_FS_RES_OK or any error from lv_fs_res_t enum
|
2017-11-23 20:42:14 +01:00
|
|
|
*/
|
2017-11-24 17:48:47 +01:00
|
|
|
lv_fs_res_t lv_fs_read (lv_fs_file_t * file_p, void * buf, uint32_t btr, uint32_t * br);
|
2017-11-23 20:42:14 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Write into a file
|
2017-11-24 17:48:47 +01:00
|
|
|
* @param file_p pointer to a lv_fs_file_t variable
|
2017-11-23 20:42:14 +01:00
|
|
|
* @param buf pointer to a buffer with the bytes to write
|
|
|
|
* @param btr Bytes To Write
|
|
|
|
* @param br the number of real written bytes (Bytes Written). NULL if unused.
|
2017-12-03 22:32:09 +01:00
|
|
|
* @return LV_FS_RES_OK or any error from lv_fs_res_t enum
|
2017-11-23 20:42:14 +01:00
|
|
|
*/
|
2017-11-24 17:48:47 +01:00
|
|
|
lv_fs_res_t lv_fs_write (lv_fs_file_t * file_p, const void * buf, uint32_t btw, uint32_t * bw);
|
2017-11-23 20:42:14 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the position of the 'cursor' (read write pointer) in a file
|
2017-11-24 17:48:47 +01:00
|
|
|
* @param file_p pointer to a lv_fs_file_t variable
|
2017-11-23 20:42:14 +01:00
|
|
|
* @param pos the new position expressed in bytes index (0: start of file)
|
2017-12-03 22:32:09 +01:00
|
|
|
* @return LV_FS_RES_OK or any error from lv_fs_res_t enum
|
2017-11-23 20:42:14 +01:00
|
|
|
*/
|
2017-11-24 17:48:47 +01:00
|
|
|
lv_fs_res_t lv_fs_seek (lv_fs_file_t * file_p, uint32_t pos);
|
2017-11-23 20:42:14 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Give the position of the read write pointer
|
2017-11-24 17:48:47 +01:00
|
|
|
* @param file_p pointer to a lv_fs_file_t variable
|
2017-11-23 20:42:14 +01:00
|
|
|
* @param pos_p pointer to store the position of the read write pointer
|
2017-12-03 22:32:09 +01:00
|
|
|
* @return LV_FS_RES_OK or any error from 'fs_res_t'
|
2017-11-23 20:42:14 +01:00
|
|
|
*/
|
2017-11-24 17:48:47 +01:00
|
|
|
lv_fs_res_t lv_fs_tell (lv_fs_file_t * file_p, uint32_t * pos);
|
2017-11-23 20:42:14 +01:00
|
|
|
|
2018-09-20 21:58:10 +02:00
|
|
|
/**
|
|
|
|
* Truncate the file size to the current position of the read write pointer
|
|
|
|
* @param file_p pointer to an 'ufs_file_t' variable. (opened with lv_fs_open )
|
|
|
|
* @return LV_FS_RES_OK: no error, the file is read
|
|
|
|
* any error from lv_fs_res_t enum
|
|
|
|
*/
|
|
|
|
lv_fs_res_t lv_fs_trunc (lv_fs_file_t * file_p);
|
|
|
|
|
2017-11-23 20:42:14 +01:00
|
|
|
/**
|
|
|
|
* Give the size of a file bytes
|
2017-11-24 17:48:47 +01:00
|
|
|
* @param file_p pointer to a lv_fs_file_t variable
|
2017-11-23 20:42:14 +01:00
|
|
|
* @param size pointer to a variable to store the size
|
2017-12-03 22:32:09 +01:00
|
|
|
* @return LV_FS_RES_OK or any error from lv_fs_res_t enum
|
2017-11-23 20:42:14 +01:00
|
|
|
*/
|
2017-11-24 17:48:47 +01:00
|
|
|
lv_fs_res_t lv_fs_size (lv_fs_file_t * file_p, uint32_t * size);
|
2017-11-23 20:42:14 +01:00
|
|
|
|
2018-09-20 21:58:10 +02:00
|
|
|
/**
|
|
|
|
* Rename a file
|
|
|
|
* @param oldname path to the file
|
|
|
|
* @param newname path with the new name
|
|
|
|
* @return LV_FS_RES_OK or any error from 'fs_res_t'
|
|
|
|
*/
|
|
|
|
lv_fs_res_t lv_fs_rename (const char * oldname, const char * newname);
|
|
|
|
|
2017-11-23 20:42:14 +01:00
|
|
|
/**
|
2017-12-03 22:32:09 +01:00
|
|
|
* Initialize a 'fs_dir_t' variable for directory reading
|
2017-11-23 20:42:14 +01:00
|
|
|
* @param rddir_p pointer to a 'fs_read_dir_t' variable
|
|
|
|
* @param path path to a directory
|
2017-12-03 22:32:09 +01:00
|
|
|
* @return LV_FS_RES_OK or any error from lv_fs_res_t enum
|
2017-11-23 20:42:14 +01:00
|
|
|
*/
|
2017-12-03 22:32:09 +01:00
|
|
|
lv_fs_res_t lv_fs_dir_open(lv_fs_dir_t * rddir_p, const char * path);
|
2017-11-23 20:42:14 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Read the next filename form a directory.
|
|
|
|
* The name of the directories will begin with '/'
|
2017-12-03 22:32:09 +01:00
|
|
|
* @param rddir_p pointer to an initialized 'fs_rdir_t' variable
|
2017-11-23 20:42:14 +01:00
|
|
|
* @param fn pointer to a buffer to store the filename
|
2017-12-03 22:32:09 +01:00
|
|
|
* @return LV_FS_RES_OK or any error from lv_fs_res_t enum
|
2017-11-23 20:42:14 +01:00
|
|
|
*/
|
2017-12-03 22:32:09 +01:00
|
|
|
lv_fs_res_t lv_fs_dir_read (lv_fs_dir_t * rddir_p, char * fn);
|
2017-11-23 20:42:14 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Close the directory reading
|
2017-12-03 22:32:09 +01:00
|
|
|
* @param rddir_p pointer to an initialized 'fs_dir_t' variable
|
|
|
|
* @return LV_FS_RES_OK or any error from lv_fs_res_t enum
|
2017-11-23 20:42:14 +01:00
|
|
|
*/
|
2017-12-03 22:32:09 +01:00
|
|
|
lv_fs_res_t lv_fs_dir_close (lv_fs_dir_t * rddir_p);
|
2017-11-23 20:42:14 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the free and total size of a driver in kB
|
|
|
|
* @param letter the driver letter
|
|
|
|
* @param total_p pointer to store the total size [kB]
|
|
|
|
* @param free_p pointer to store the free size [kB]
|
2017-12-03 22:32:09 +01:00
|
|
|
* @return LV_FS_RES_OK or any error from lv_fs_res_t enum
|
2017-11-23 20:42:14 +01:00
|
|
|
*/
|
2019-02-25 15:34:35 +01:00
|
|
|
lv_fs_res_t lv_fs_free_space (char letter, uint32_t * total_p, uint32_t * free_p);
|
2017-11-23 20:42:14 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Fill a buffer with the letters of existing drivers
|
|
|
|
* @param buf buffer to store the letters ('\0' added after the last letter)
|
|
|
|
* @return the buffer
|
|
|
|
*/
|
2017-11-24 17:48:47 +01:00
|
|
|
char * lv_fs_get_letters(char * buf);
|
2017-11-23 20:42:14 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Return with the extension of the filename
|
|
|
|
* @param fn string with a filename
|
|
|
|
* @return pointer to the beginning extension or empty string if no extension
|
|
|
|
*/
|
2017-11-24 17:48:47 +01:00
|
|
|
const char * lv_fs_get_ext(const char * fn);
|
2017-11-23 20:42:14 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Step up one level
|
|
|
|
* @param path pointer to a file name
|
|
|
|
* @return the truncated file name
|
|
|
|
*/
|
2017-11-24 17:48:47 +01:00
|
|
|
char * lv_fs_up(char * path);
|
2017-11-23 20:42:14 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the last element of a path (e.g. U:/folder/file -> file)
|
|
|
|
* @param buf buffer to store the letters ('\0' added after the last letter)
|
|
|
|
* @return pointer to the beginning of the last element in the path
|
|
|
|
*/
|
2017-11-24 17:48:47 +01:00
|
|
|
const char * lv_fs_get_last(const char * path);
|
2017-11-23 20:42:14 +01:00
|
|
|
|
|
|
|
/**********************
|
|
|
|
* MACROS
|
|
|
|
**********************/
|
|
|
|
|
2017-12-07 19:22:23 +01:00
|
|
|
#endif /*USE_LV_FILESYSTEM*/
|
|
|
|
|
2017-11-23 20:42:14 +01:00
|
|
|
#ifdef __cplusplus
|
|
|
|
} /* extern "C" */
|
|
|
|
#endif
|
|
|
|
|
2017-12-07 19:22:23 +01:00
|
|
|
#endif /*LV_FS_H*/
|