blob: 9fa10bcca5f52ac918056293b3c09651bb91de75 [file] [log] [blame]
Dima Zavine12b4112009-01-23 16:36:23 -08001/*
2 * Copyright (c) 2008, Google Inc.
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 * * Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer.
10 * * Redistributions in binary form must reproduce the above copyright
11 * notice, this list of conditions and the following disclaimer in
12 * the documentation and/or other materials provided with the
13 * distribution.
14 *
15 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
16 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
17 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
18 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
19 * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
20 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
21 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
22 * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
23 * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
24 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
25 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26 * SUCH DAMAGE.
27 */
28
29
30#ifndef __DEV_FLASH_H
31#define __DEV_FLASH_H
32
33#include <lib/ptable.h>
34
Deepa Dinamanie4573be2012-08-03 16:32:29 -070035enum nand_ecc_width
36{
37 NAND_WITH_4_BIT_ECC,
38 NAND_WITH_8_BIT_ECC,
39};
Shashank Mittaldcc2e352009-11-19 19:11:16 -080040
Dima Zavinfbde0ac2009-03-02 16:39:18 -080041struct flash_info {
Shashank Mittal83d16d02009-11-18 16:54:42 -080042 unsigned id;
43 unsigned type;
Dima Zavinfbde0ac2009-03-02 16:39:18 -080044 unsigned vendor;
45 unsigned device;
46 unsigned page_size;
47 unsigned block_size;
48 unsigned spare_size;
49 unsigned num_blocks;
Deepa Dinamanie4573be2012-08-03 16:32:29 -070050 enum nand_ecc_width ecc_width;
51 unsigned num_pages_per_blk;
52 unsigned num_pages_per_blk_mask;
53 unsigned widebus;
54 unsigned density;
55 unsigned cw_size;
56 unsigned cws_per_page;
57 unsigned bad_blk_loc;
58 unsigned blksize;
59 unsigned dev_cfg;
Dima Zavinfbde0ac2009-03-02 16:39:18 -080060};
61
Dima Zavine5f64352009-03-02 16:04:20 -080062void flash_init(void);
Dima Zavine12b4112009-01-23 16:36:23 -080063struct ptable *flash_get_ptable(void);
Dima Zavine5f64352009-03-02 16:04:20 -080064void flash_set_ptable(struct ptable *ptable);
Dima Zavinfbde0ac2009-03-02 16:39:18 -080065struct flash_info *flash_get_info(void);
Dima Zavine12b4112009-01-23 16:36:23 -080066
67/* flash operations */
68int flash_erase(struct ptentry *ptn);
69int flash_read_ext(struct ptentry *ptn, unsigned extra_per_page,
70 unsigned offset, void *data, unsigned bytes);
71int flash_write(struct ptentry *ptn, unsigned extra_per_page, const void *data,
72 unsigned bytes);
73
74static inline int flash_read(struct ptentry *ptn, unsigned offset, void *data,
75 unsigned bytes)
76{
77 return flash_read_ext(ptn, 0, offset, data, bytes);
78}
Shashank Mittaldcc2e352009-11-19 19:11:16 -080079unsigned flash_page_size(void);
Channagoud Kadabi404a7062011-03-21 19:27:50 +053080int flash_ecc_bch_enabled(void);
Dima Zavine12b4112009-01-23 16:36:23 -080081
82
83#endif /* __DEV_FLASH_H */