blob: 4f069f58da13481436e26e07e5ee8f326c940b0a [file] [log] [blame]
developer8d16ac22021-05-26 15:32:12 +08001/* SPDX-License-Identifier: GPL-2.0 OR BSD-3-Clause */
2/*
3 * Copyright (C) 2020 MediaTek Inc. All Rights Reserved.
4 *
5 * Definitions for NAND Mapped-block Management (NMBM)
6 *
7 * Author: Weijie Gao <weijie.gao@mediatek.com>
8 */
9
10#ifndef _NMBM_H_
11#define _NMBM_H_
12
13#include <nmbm/nmbm-os.h>
14
15enum nmbm_log_category {
16 NMBM_LOG_DEBUG,
17 NMBM_LOG_INFO,
18 NMBM_LOG_WARN,
19 NMBM_LOG_ERR,
20 NMBM_LOG_EMERG,
21
22 __NMBM_LOG_MAX
23};
24
25enum nmbm_oob_mode {
26 NMBM_MODE_PLACE_OOB,
27 NMBM_MODE_AUTO_OOB,
28 NMBM_MODE_RAW,
29
30 __NMBM_MODE_MAX
31};
32
33struct nmbm_lower_device {
34 uint32_t max_ratio;
35 uint32_t max_reserved_blocks;
36 int flags;
37
38 uint64_t size;
39 uint32_t erasesize;
40 uint32_t writesize;
41 uint32_t oobsize;
42 uint32_t oobavail;
43
44 void *arg;
45 int (*reset_chip)(void *arg);
46
47 /*
48 * read_page:
49 * return 0 if succeeds
50 * return positive number for ecc error
51 * return negative number for other errors
52 */
53 int (*read_page)(void *arg, uint64_t addr, void *buf, void *oob, enum nmbm_oob_mode mode);
54 int (*write_page)(void *arg, uint64_t addr, const void *buf, const void *oob, enum nmbm_oob_mode mode);
55 int (*erase_block)(void *arg, uint64_t addr);
56
57 int (*is_bad_block)(void *arg, uint64_t addr);
58 int (*mark_bad_block)(void *arg, uint64_t addr);
59
60 /* OS-dependent logging function */
61 void (*logprint)(void *arg, enum nmbm_log_category level, const char *fmt, va_list ap);
62};
63
64struct nmbm_instance;
65
66/* Create NMBM if management area not found, or not complete */
67#define NMBM_F_CREATE 0x01
developer28a313b2021-06-16 17:23:34 +080068#define NMBM_F_EMPTY_PAGE_ECC_OK 0x02
developer8d16ac22021-05-26 15:32:12 +080069
70size_t nmbm_calc_structure_size(struct nmbm_lower_device *nld);
71int nmbm_attach(struct nmbm_lower_device *nld, struct nmbm_instance *ni);
72int nmbm_detach(struct nmbm_instance *ni);
73
74enum nmbm_log_category nmbm_set_log_level(struct nmbm_instance *ni,
75 enum nmbm_log_category level);
76
77int nmbm_erase_block_range(struct nmbm_instance *ni, uint64_t addr,
78 uint64_t size, uint64_t *failed_addr);
79int nmbm_read_single_page(struct nmbm_instance *ni, uint64_t addr, void *data,
80 void *oob, enum nmbm_oob_mode mode);
81int nmbm_read_range(struct nmbm_instance *ni, uint64_t addr, size_t size,
82 void *data, enum nmbm_oob_mode mode, size_t *retlen);
83int nmbm_write_single_page(struct nmbm_instance *ni, uint64_t addr,
84 const void *data, const void *oob,
85 enum nmbm_oob_mode mode);
86int nmbm_write_range(struct nmbm_instance *ni, uint64_t addr, size_t size,
87 const void *data, enum nmbm_oob_mode mode,
88 size_t *retlen);
89
90int nmbm_check_bad_block(struct nmbm_instance *ni, uint64_t addr);
91int nmbm_mark_bad_block(struct nmbm_instance *ni, uint64_t addr);
92
93uint64_t nmbm_get_avail_size(struct nmbm_instance *ni);
94
95int nmbm_get_lower_device(struct nmbm_instance *ni, struct nmbm_lower_device *nld);
96
97#endif /* _NMBM_H_ */