blob: c1be892c4d058043d609f887ae726d8e133cb23d [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
68
69size_t nmbm_calc_structure_size(struct nmbm_lower_device *nld);
70int nmbm_attach(struct nmbm_lower_device *nld, struct nmbm_instance *ni);
71int nmbm_detach(struct nmbm_instance *ni);
72
73enum nmbm_log_category nmbm_set_log_level(struct nmbm_instance *ni,
74 enum nmbm_log_category level);
75
76int nmbm_erase_block_range(struct nmbm_instance *ni, uint64_t addr,
77 uint64_t size, uint64_t *failed_addr);
78int nmbm_read_single_page(struct nmbm_instance *ni, uint64_t addr, void *data,
79 void *oob, enum nmbm_oob_mode mode);
80int nmbm_read_range(struct nmbm_instance *ni, uint64_t addr, size_t size,
81 void *data, enum nmbm_oob_mode mode, size_t *retlen);
82int nmbm_write_single_page(struct nmbm_instance *ni, uint64_t addr,
83 const void *data, const void *oob,
84 enum nmbm_oob_mode mode);
85int nmbm_write_range(struct nmbm_instance *ni, uint64_t addr, size_t size,
86 const void *data, enum nmbm_oob_mode mode,
87 size_t *retlen);
88
89int nmbm_check_bad_block(struct nmbm_instance *ni, uint64_t addr);
90int nmbm_mark_bad_block(struct nmbm_instance *ni, uint64_t addr);
91
92uint64_t nmbm_get_avail_size(struct nmbm_instance *ni);
93
94int nmbm_get_lower_device(struct nmbm_instance *ni, struct nmbm_lower_device *nld);
95
96#endif /* _NMBM_H_ */