2015-01-26 08:51:42 +01:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2015 Eistec AB
|
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser General
|
|
|
|
* Public License v2.1. See the file LICENSE in the top level directory for more
|
|
|
|
* details.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2015-11-19 17:13:33 +01:00
|
|
|
* @defgroup drivers_nvram Non-volatile RAM
|
2017-02-07 11:16:38 +01:00
|
|
|
* @ingroup drivers_storage
|
2015-01-26 08:51:42 +01:00
|
|
|
* @brief Non-volatile RAM interface
|
|
|
|
*
|
|
|
|
* This API is designed around non-volatile memories which do not need blockwise
|
|
|
|
* erase, such as ferro-electric RAM (FRAM) or magneto-resistive RAM (MRAM).
|
|
|
|
*
|
|
|
|
* This interface is not suitable for flash memories.
|
|
|
|
*
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
*
|
|
|
|
* @brief Generic non-volatile RAM driver interface
|
2015-09-20 13:47:39 +02:00
|
|
|
* @author Joakim Nohlgård <joakim.nohlgard@eistec.se>
|
2015-01-26 08:51:42 +01:00
|
|
|
*/
|
|
|
|
|
2017-05-23 18:19:52 +02:00
|
|
|
#ifndef NVRAM_H
|
|
|
|
#define NVRAM_H
|
2015-01-26 08:51:42 +01:00
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
#include <stddef.h>
|
|
|
|
|
2016-07-12 07:58:42 +02:00
|
|
|
#if MODULE_VFS
|
|
|
|
#include "vfs.h"
|
|
|
|
#endif
|
|
|
|
|
2015-01-26 08:51:42 +01:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/* Forward declaration in order to declare function pointers which take this
|
|
|
|
* type as a parameter within the struct. */
|
|
|
|
struct nvram;
|
|
|
|
|
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @brief Device descriptor for generic NVRAM devices.
|
2015-01-26 08:51:42 +01:00
|
|
|
*/
|
|
|
|
typedef struct nvram {
|
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @brief Pointer to device-specific read function
|
2015-01-26 08:51:42 +01:00
|
|
|
*
|
|
|
|
* Copy data from system memory to NVRAM.
|
|
|
|
*
|
|
|
|
* @param[in] dev Pointer to NVRAM device descriptor
|
|
|
|
* @param[out] dst Pointer to the first byte in the system memory address space
|
|
|
|
* @param[in] src Starting address in the NVRAM device address space
|
|
|
|
* @param[in] len Number of bytes to copy
|
|
|
|
*
|
|
|
|
* @return Number of bytes read on success
|
|
|
|
* @return <0 on errors
|
|
|
|
*/
|
|
|
|
int (*read)(struct nvram *dev, uint8_t *dst, uint32_t src, size_t size);
|
|
|
|
|
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @brief Pointer to device-specific write function
|
2015-01-26 08:51:42 +01:00
|
|
|
*
|
|
|
|
* Copy data from NVRAM to system memory.
|
|
|
|
*
|
|
|
|
* @param[in] dev Pointer to NVRAM device descriptor
|
|
|
|
* @param[in] src Pointer to the first byte in the system memory address space
|
|
|
|
* @param[in] dst Starting address in the NVRAM device address space
|
|
|
|
* @param[in] len Number of bytes to copy
|
|
|
|
*
|
|
|
|
* @return Number of bytes written on success
|
|
|
|
* @return <0 on errors
|
|
|
|
*/
|
2016-07-12 07:47:20 +02:00
|
|
|
int (*write)(struct nvram *dev, const uint8_t *src, uint32_t dst, size_t size);
|
2015-01-26 08:51:42 +01:00
|
|
|
|
2017-08-29 18:00:46 +02:00
|
|
|
/** @brief Device capacity */
|
2015-01-26 08:51:42 +01:00
|
|
|
size_t size;
|
|
|
|
|
2017-08-29 18:00:46 +02:00
|
|
|
/** @brief Device-specific parameters, if any. */
|
2015-01-26 08:51:42 +01:00
|
|
|
void *extra;
|
|
|
|
} nvram_t;
|
|
|
|
|
2016-07-12 07:58:42 +02:00
|
|
|
#if MODULE_VFS
|
|
|
|
extern const vfs_file_ops_t nvram_vfs_ops;
|
|
|
|
#endif
|
|
|
|
|
2015-01-26 08:51:42 +01:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2017-05-23 18:19:52 +02:00
|
|
|
#endif /* NVRAM_H */
|
2015-01-26 08:51:42 +01:00
|
|
|
/** @} */
|