mtd.h
Go to the documentation of this file.
1 /*
2  * Copyright (C) 2016 OTA keys S.A.
3  *
4  * This file is subject to the terms and conditions of the GNU Lesser
5  * General Public License v2.1. See the file LICENSE in the top level
6  * directory for more details.
7  */
8 
9 #pragma once
10 
75 #include <stdbool.h>
76 #include <stddef.h>
77 #include <stdint.h>
78 
79 #include "xfa.h"
80 
81 #ifdef __cplusplus
82 extern "C" {
83 #endif
84 
91 };
92 
103 typedef struct mtd_desc mtd_desc_t;
104 
111 typedef struct {
113  uint32_t sector_count;
114  uint32_t pages_per_sector;
115  uint32_t page_size;
116  uint32_t write_size;
117 #if defined(MODULE_MTD_WRITE_PAGE) || DOXYGEN
118  void *work_area;
119 #endif
120 } mtd_dev_t;
121 
135 #if !DOXYGEN
137 #else
139 #endif
140 
165 #define MTD_XFA_ADD(dev, idx) \
166  XFA_CONST(mtd_dev_t, mtd_dev_xfa, idx) *mtd ## idx = (mtd_dev_t *)&(dev)
167 
171 #define MTD_NUMOF XFA_LEN(mtd_dev_t *, mtd_dev_xfa)
172 
178 #define MTD_DRIVER_FLAG_DIRECT_WRITE (1 << 0)
179 
191 #define MTD_DRIVER_FLAG_CLEARING_OVERWRITE (1 << 1)
192 
203 struct mtd_desc {
212  int (*init)(mtd_dev_t *dev);
213 
227  int (*read)(mtd_dev_t *dev,
228  void *buff,
229  uint32_t addr,
230  uint32_t size);
231 
247  int (*read_page)(mtd_dev_t *dev,
248  void *buff,
249  uint32_t page,
250  uint32_t offset,
251  uint32_t size);
252 
268  int (*write_page)(mtd_dev_t *dev,
269  const void *buff,
270  uint32_t page,
271  uint32_t offset,
272  uint32_t size);
273 
286  int (*erase)(mtd_dev_t *dev,
287  uint32_t addr,
288  uint32_t size);
289 
301  int (*erase_sector)(mtd_dev_t *dev,
302  uint32_t sector,
303  uint32_t count);
304 
314  int (*power)(mtd_dev_t *dev, enum mtd_power_state power);
315 
319  uint8_t flags;
320 };
321 
332 int mtd_init(mtd_dev_t *mtd);
333 
351 int mtd_read(mtd_dev_t *mtd, void *dest, uint32_t addr, uint32_t count);
352 
372 int mtd_read_page(mtd_dev_t *mtd, void *dest, uint32_t page, uint32_t offset, uint32_t size);
373 
396 int mtd_write(mtd_dev_t *mtd, const void *src, uint32_t addr, uint32_t count);
397 
422 int mtd_write_page_raw(mtd_dev_t *mtd, const void *src, uint32_t page,
423  uint32_t offset, uint32_t size);
424 
452 int mtd_write_page(mtd_dev_t *mtd, const void *src, uint32_t page,
453  uint32_t offset, uint32_t size);
454 
471 int mtd_erase(mtd_dev_t *mtd, uint32_t addr, uint32_t count);
472 
487 int mtd_erase_sector(mtd_dev_t *mtd, uint32_t sector, uint32_t num);
488 
510 int mtd_write_sector(mtd_dev_t *mtd, const void *src, uint32_t sector, uint32_t num);
511 
524 int mtd_power(mtd_dev_t *mtd, enum mtd_power_state power);
525 
534 static inline mtd_dev_t *mtd_dev_get(unsigned idx)
535 {
536  assert(MTD_NUMOF != 0);
537  assert(idx < MTD_NUMOF);
538 
539  return mtd_dev_xfa[idx];
540 }
541 
542 #ifdef __cplusplus
543 }
544 #endif
545 
#define assert(cond)
abort the program if assertion is false
Definition: assert.h:135
static mtd_dev_t * mtd_dev_get(unsigned idx)
Get an MTD device by index.
Definition: mtd.h:534
mtd_dev_t *const mtd_dev_xfa[]
MTD device array as XFA.
Definition: mtd.h:138
mtd_power_state
MTD power states.
Definition: mtd.h:88
int mtd_write_sector(mtd_dev_t *mtd, const void *src, uint32_t sector, uint32_t num)
Write data to a MTD device with whole sector writes.
int mtd_write(mtd_dev_t *mtd, const void *src, uint32_t addr, uint32_t count)
Write data to a MTD device.
int mtd_init(mtd_dev_t *mtd)
mtd_init Initialize a MTD device
int mtd_write_page_raw(mtd_dev_t *mtd, const void *src, uint32_t page, uint32_t offset, uint32_t size)
Write data to a MTD device with pagewise addressing.
int mtd_read(mtd_dev_t *mtd, void *dest, uint32_t addr, uint32_t count)
Read data from a MTD device.
int mtd_read_page(mtd_dev_t *mtd, void *dest, uint32_t page, uint32_t offset, uint32_t size)
Read data from a MTD device with pagewise addressing.
int mtd_erase(mtd_dev_t *mtd, uint32_t addr, uint32_t count)
Erase sectors of a MTD device.
int mtd_write_page(mtd_dev_t *mtd, const void *src, uint32_t page, uint32_t offset, uint32_t size)
Write data to a MTD device with pagewise addressing.
#define MTD_NUMOF
Number of MTDs defined in the MTD device array in XFA.
Definition: mtd.h:171
int mtd_power(mtd_dev_t *mtd, enum mtd_power_state power)
Set power mode on a MTD device.
int mtd_erase_sector(mtd_dev_t *mtd, uint32_t sector, uint32_t num)
Erase sectors of a MTD device.
@ MTD_POWER_DOWN
Power down.
Definition: mtd.h:90
@ MTD_POWER_UP
Power up.
Definition: mtd.h:89
MTD driver interface.
Definition: mtd.h:203
int(* read)(mtd_dev_t *dev, void *buff, uint32_t addr, uint32_t size)
Read from the Memory Technology Device (MTD)
Definition: mtd.h:227
int(* read_page)(mtd_dev_t *dev, void *buff, uint32_t page, uint32_t offset, uint32_t size)
Read from the Memory Technology Device (MTD) using pagewise addressing.
Definition: mtd.h:247
int(* erase)(mtd_dev_t *dev, uint32_t addr, uint32_t size)
Erase sector(s) over the Memory Technology Device (MTD)
Definition: mtd.h:286
int(* erase_sector)(mtd_dev_t *dev, uint32_t sector, uint32_t count)
Erase sector(s) of the Memory Technology Device (MTD)
Definition: mtd.h:301
int(* power)(mtd_dev_t *dev, enum mtd_power_state power)
Control power of Memory Technology Device (MTD)
Definition: mtd.h:314
int(* write_page)(mtd_dev_t *dev, const void *buff, uint32_t page, uint32_t offset, uint32_t size)
Write to the Memory Technology Device (MTD) using pagewise addressing.
Definition: mtd.h:268
uint8_t flags
Properties of the MTD driver.
Definition: mtd.h:319
int(* init)(mtd_dev_t *dev)
Initialize Memory Technology Device (MTD)
Definition: mtd.h:212
MTD device descriptor.
Definition: mtd.h:111
uint32_t write_size
Minimum size and alignment of writes to the device.
Definition: mtd.h:116
uint32_t pages_per_sector
Number of pages per sector in the MTD.
Definition: mtd.h:114
uint32_t sector_count
Number of sector in the MTD.
Definition: mtd.h:113
const mtd_desc_t * driver
MTD driver.
Definition: mtd.h:112
void * work_area
sector-sized buffer (only present when mtd_write_page is enabled)
Definition: mtd.h:118
uint32_t page_size
Size of the pages in the MTD.
Definition: mtd.h:115
Cross File Arrays.
#define XFA_USE_CONST(type, name)
Declare an external read-only cross-file array.
Definition: xfa.h:113