]> CyberLeo.Net >> Repos - FreeBSD/releng/10.2.git/blob - sys/dev/nand/nandsim_chip.h
- Copy stable/10@285827 to releng/10.2 in preparation for 10.2-RC1
[FreeBSD/releng/10.2.git] / sys / dev / nand / nandsim_chip.h
1 /*-
2  * Copyright (C) 2009-2012 Semihalf
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  * 1. Redistributions of source code must retain the above copyright
9  *    notice, this list of conditions and the following disclaimer.
10  * 2. Redistributions in binary form must reproduce the above copyright
11  *    notice, this list of conditions and the following disclaimer in the
12  *    documentation and/or other materials provided with the distribution.
13  *
14  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
15  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
16  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
17  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
18  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
19  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
20  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
21  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
22  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
23  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
24  * SUCH DAMAGE.
25  *
26  * $FreeBSD$
27  */
28
29 #ifndef _NANDSIM_CHIP_H
30 #define _NANDSIM_CHIP_H
31
32 #include <sys/malloc.h>
33 #include <sys/callout.h>
34 #include <dev/nand/nand.h>
35 #include <dev/nand/nandsim.h>
36 #include <dev/nand/nandsim_swap.h>
37
38 MALLOC_DECLARE(M_NANDSIM);
39
40 #define MAX_CS_NUM      4
41 struct nandsim_chip;
42
43 typedef void nandsim_evh_t(struct nandsim_chip *chip, uint32_t ev, void *data);
44
45 enum addr_type {
46         ADDR_NONE,
47         ADDR_ID,
48         ADDR_ROW,
49         ADDR_ROWCOL
50 };
51
52 struct nandsim_softc {
53         struct nand_softc       nand_dev;
54         device_t                dev;
55
56         struct nandsim_chip     *chips[MAX_CS_NUM];
57         struct nandsim_chip     *active_chip;
58
59         uint8_t                 address_cycle;
60         enum addr_type          address_type;
61         int                     log_idx;
62         char                    *log_buff;
63         struct alq              *alq;
64 };
65
66 struct nandsim_ev {
67         STAILQ_ENTRY(nandsim_ev)        links;
68         struct nandsim_chip             *chip;
69         uint8_t         type;
70         void            *data;
71 };
72
73 struct nandsim_data {
74         uint8_t         *data_ptr;
75         uint32_t        index;
76         uint32_t        size;
77 };
78
79 struct nandsim_block_state {
80         int32_t         wear_lev;
81         uint8_t         is_bad;
82 };
83
84 #define NANDSIM_CHIP_ACTIVE     0x1
85 #define NANDSIM_CHIP_FROZEN     0x2
86 #define NANDSIM_CHIP_GET_STATUS 0x4
87
88 struct nandsim_chip {
89         struct nandsim_softc    *sc;
90         struct thread           *nandsim_td;
91
92         STAILQ_HEAD(, nandsim_ev) nandsim_events;
93         nandsim_evh_t           *ev_handler;
94         struct mtx              ns_lock;
95         struct callout          ns_callout;
96
97         struct chip_geom        cg;
98         struct nand_id          id;
99         struct onfi_params      params;
100         struct nandsim_data     data;
101         struct nandsim_block_state *blk_state;
102
103         struct chip_swap        *swap;
104
105         uint32_t        error_ratio;
106         uint32_t        wear_level;
107         uint32_t        sm_state;
108         uint32_t        sm_addr_cycle;
109
110         uint32_t        erase_delay;
111         uint32_t        prog_delay;
112         uint32_t        read_delay;
113         struct timeval  delay_tv;
114
115         uint8_t         flags;
116         uint8_t         chip_status;
117         uint8_t         ctrl_num;
118         uint8_t         chip_num;
119 };
120
121 struct sim_ctrl_conf {
122         uint8_t         num;
123         uint8_t         num_cs;
124         uint8_t         ecc;
125         uint8_t         running;
126         uint8_t         created;
127         device_t        sim_ctrl_dev;
128         struct sim_chip *chips[MAX_CTRL_CS];
129         uint16_t        ecc_layout[MAX_ECC_BYTES];
130         char            filename[FILENAME_SIZE];
131 };
132
133 #define NANDSIM_STATE_IDLE              0x0
134 #define NANDSIM_STATE_WAIT_ADDR_BYTE    0x1
135 #define NANDSIM_STATE_WAIT_CMD          0x2
136 #define NANDSIM_STATE_TIMEOUT           0x3
137 #define NANDSIM_STATE_WAIT_ADDR_ROW     0x4
138 #define NANDSIM_STATE_WAIT_ADDR_COL     0x5
139
140 #define NANDSIM_EV_START        0x1
141 #define NANDSIM_EV_CMD          0x2
142 #define NANDSIM_EV_ADDR         0x3
143 #define NANDSIM_EV_TIMEOUT      0x4
144 #define NANDSIM_EV_EXIT         0xff
145
146 struct nandsim_chip *nandsim_chip_init(struct nandsim_softc *,
147     uint8_t, struct sim_chip *);
148 void nandsim_chip_destroy(struct nandsim_chip *);
149 void nandsim_chip_freeze(struct nandsim_chip *);
150 void nandsim_chip_timeout(struct nandsim_chip *);
151 int nandsim_chip_check_bad_block(struct nandsim_chip *, int);
152
153 uint8_t nandchip_get_status(struct nandsim_chip *);
154
155 void destroy_event(struct nandsim_ev *);
156 int send_event(struct nandsim_ev *);
157 struct nandsim_ev *create_event(struct nandsim_chip *, uint8_t, uint8_t);
158
159 #endif /*  _NANDSIM_CHIP_H */