1
0
mirror of https://github.com/corundum/corundum.git synced 2025-01-16 08:12:53 +08:00
corundum/utils/flash.h

69 lines
1.9 KiB
C
Raw Permalink Normal View History

// SPDX-License-Identifier: BSD-2-Clause-Views
2020-10-04 00:56:06 -07:00
/*
* Copyright (c) 2020-2023 The Regents of the University of California
*/
2020-10-04 00:56:06 -07:00
#ifndef FLASH_H
#define FLASH_H
#include <stdint.h>
#include <unistd.h>
#define FLASH_ERASE_REGIONS 2
struct flash_driver;
struct flash_ops;
struct flash_erase_region_info {
size_t block_count;
size_t block_size;
size_t region_start;
size_t region_end;
};
struct flash_device {
const struct flash_driver *driver;
const struct flash_ops *ops;
volatile uint8_t *ctrl_reg;
volatile uint8_t *addr_reg;
volatile uint8_t *data_reg;
size_t size;
int data_width;
size_t write_buffer_size;
size_t erase_block_size;
int protocol;
int bulk_protocol;
int read_dummy_cycles;
int erase_region_count;
struct flash_erase_region_info erase_region[FLASH_ERASE_REGIONS];
};
struct flash_ops {
void (*init)(struct flash_device *fdev);
int (*sector_erase)(struct flash_device *fdev, size_t addr);
2022-03-03 22:45:38 -08:00
int (*buffered_program)(struct flash_device *fdev, size_t addr, size_t len, const void *src);
2020-10-04 00:56:06 -07:00
};
struct flash_driver {
int (*init)(struct flash_device *fdev);
void (*release)(struct flash_device *fdev);
2022-03-03 22:45:38 -08:00
int (*read)(struct flash_device *fdev, size_t addr, size_t len, void *dest);
int (*write)(struct flash_device *fdev, size_t addr, size_t len, const void *src);
2020-10-04 00:56:06 -07:00
int (*erase)(struct flash_device *fdev, size_t addr, size_t len);
};
struct flash_device *flash_open_spi(int data_width, volatile uint8_t *ctrl_reg);
struct flash_device *flash_open_bpi(int data_width, volatile uint8_t *ctrl_reg, volatile uint8_t *addr_reg, volatile uint8_t *data_reg);
void flash_release(struct flash_device *fdev);
2022-03-03 22:45:38 -08:00
int flash_read(struct flash_device *fdev, size_t addr, size_t len, void *dest);
int flash_write(struct flash_device *fdev, size_t addr, size_t len, const void *src);
2020-10-04 00:56:06 -07:00
int flash_erase(struct flash_device *fdev, size_t addr, size_t len);
#endif /* FLASH_H */