Newer
Older
arm-trusted-firmware / include / drivers / io / io_mtd.h
@Lionel Debieve Lionel Debieve on 20 Jan 2020 1 KB Add raw NAND framework
/*
 * Copyright (c) 2019, ARM Limited and Contributors. All rights reserved.
 *
 * SPDX-License-Identifier: BSD-3-Clause
 */

#ifndef IO_MTD_H
#define IO_MTD_H

#include <stdint.h>
#include <stdio.h>

#include <drivers/io/io_storage.h>

/* MTD devices ops */
typedef struct io_mtd_ops {
	/*
	 * Initialize MTD framework and retrieve device information.
	 *
	 * @size:  [out] MTD device size in bytes.
	 * @erase_size: [out] MTD erase size in bytes.
	 * Return 0 on success, a negative error code otherwise.
	 */
	int (*init)(unsigned long long *size, unsigned int *erase_size);

	/*
	 * Execute a read memory operation.
	 *
	 * @offset: Offset in bytes to start read operation.
	 * @buffer: [out] Buffer to store read data.
	 * @length: Required length to be read in bytes.
	 * @out_length: [out] Length read in bytes.
	 * Return 0 on success, a negative error code otherwise.
	 */
	int (*read)(unsigned int offset, uintptr_t buffer, size_t length,
		    size_t *out_length);

	/*
	 * Execute a write memory operation.
	 *
	 * @offset: Offset in bytes to start write operation.
	 * @buffer: Buffer to be written in device.
	 * @length: Required length to be written in bytes.
	 * Return 0 on success, a negative error code otherwise.
	 */
	int (*write)(unsigned int offset, uintptr_t buffer, size_t length);
} io_mtd_ops_t;

typedef struct io_mtd_dev_spec {
	unsigned long long device_size;
	unsigned int erase_size;
	io_mtd_ops_t ops;
} io_mtd_dev_spec_t;

struct io_dev_connector;

int register_io_dev_mtd(const struct io_dev_connector **dev_con);

#endif /* IO_MTD_H */