1 /* SPDX-License-Identifier: GPL-2.0-or-later */
2 /*
3 * Filename: rsxx_priv.h
4 *
5 * Authors: Joshua Morris <josh.h.morris@us.ibm.com>
6 * Philip Kelleher <pjk1939@linux.vnet.ibm.com>
7 *
8 * (C) Copyright 2013 IBM Corporation
9 */
10
11 #ifndef __RSXX_PRIV_H__
12 #define __RSXX_PRIV_H__
13
14 #include <linux/version.h>
15 #include <linux/semaphore.h>
16
17 #include <linux/fs.h>
18 #include <linux/interrupt.h>
19 #include <linux/mutex.h>
20 #include <linux/pci.h>
21 #include <linux/spinlock.h>
22 #include <linux/sysfs.h>
23 #include <linux/workqueue.h>
24 #include <linux/bio.h>
25 #include <linux/vmalloc.h>
26 #include <linux/timer.h>
27 #include <linux/ioctl.h>
28 #include <linux/delay.h>
29
30 #include "rsxx.h"
31 #include "rsxx_cfg.h"
32
33 struct proc_cmd;
34
35 #define PCI_DEVICE_ID_FS70_FLASH 0x04A9
36 #define PCI_DEVICE_ID_FS80_FLASH 0x04AA
37
38 #define RS70_PCI_REV_SUPPORTED 4
39
40 #define DRIVER_NAME "rsxx"
41 #define DRIVER_VERSION "4.0.3.2516"
42
43 /* Block size is 4096 */
44 #define RSXX_HW_BLK_SHIFT 12
45 #define RSXX_HW_BLK_SIZE (1 << RSXX_HW_BLK_SHIFT)
46 #define RSXX_HW_BLK_MASK (RSXX_HW_BLK_SIZE - 1)
47
48 #define MAX_CREG_DATA8 32
49 #define LOG_BUF_SIZE8 128
50
51 #define RSXX_MAX_OUTSTANDING_CMDS 255
52 #define RSXX_CS_IDX_MASK 0xff
53
54 #define STATUS_BUFFER_SIZE8 4096
55 #define COMMAND_BUFFER_SIZE8 4096
56
57 #define RSXX_MAX_TARGETS 8
58
59 struct dma_tracker_list;
60
61 /* DMA Command/Status Buffer structure */
62 struct rsxx_cs_buffer {
63 dma_addr_t dma_addr;
64 void *buf;
65 u32 idx;
66 };
67
68 struct rsxx_dma_stats {
69 u32 crc_errors;
70 u32 hard_errors;
71 u32 soft_errors;
72 u32 writes_issued;
73 u32 writes_failed;
74 u32 reads_issued;
75 u32 reads_failed;
76 u32 reads_retried;
77 u32 discards_issued;
78 u32 discards_failed;
79 u32 done_rescheduled;
80 u32 issue_rescheduled;
81 u32 dma_sw_err;
82 u32 dma_hw_fault;
83 u32 dma_cancelled;
84 u32 sw_q_depth; /* Number of DMAs on the SW queue. */
85 atomic_t hw_q_depth; /* Number of DMAs queued to HW. */
86 };
87
88 struct rsxx_dma_ctrl {
89 struct rsxx_cardinfo *card;
90 int id;
91 void __iomem *regmap;
92 struct rsxx_cs_buffer status;
93 struct rsxx_cs_buffer cmd;
94 u16 e_cnt;
95 spinlock_t queue_lock;
96 struct list_head queue;
97 struct workqueue_struct *issue_wq;
98 struct work_struct issue_dma_work;
99 struct workqueue_struct *done_wq;
100 struct work_struct dma_done_work;
101 struct timer_list activity_timer;
102 struct dma_tracker_list *trackers;
103 struct rsxx_dma_stats stats;
104 struct mutex work_lock;
105 };
106
107 struct rsxx_cardinfo {
108 struct pci_dev *dev;
109 unsigned int halt;
110 unsigned int eeh_state;
111
112 void __iomem *regmap;
113 spinlock_t irq_lock;
114 unsigned int isr_mask;
115 unsigned int ier_mask;
116
117 struct rsxx_card_cfg config;
118 int config_valid;
119
120 /* Embedded CPU Communication */
121 struct {
122 spinlock_t lock;
123 bool active;
124 struct creg_cmd *active_cmd;
125 struct workqueue_struct *creg_wq;
126 struct work_struct done_work;
127 struct list_head queue;
128 unsigned int q_depth;
129 /* Cache the creg status to prevent ioreads */
130 struct {
131 u32 stat;
132 u32 failed_cancel_timer;
133 u32 creg_timeout;
134 } creg_stats;
135 struct timer_list cmd_timer;
136 struct mutex reset_lock;
137 int reset;
138 } creg_ctrl;
139
140 struct {
141 char tmp[MAX_CREG_DATA8];
142 char buf[LOG_BUF_SIZE8]; /* terminated */
143 int buf_len;
144 } log;
145
146 struct workqueue_struct *event_wq;
147 struct work_struct event_work;
148 unsigned int state;
149 u64 size8;
150
151 /* Lock the device attach/detach function */
152 struct mutex dev_lock;
153
154 /* Block Device Variables */
155 bool bdev_attached;
156 int disk_id;
157 int major;
158 struct request_queue *queue;
159 struct gendisk *gendisk;
160 struct {
161 /* Used to convert a byte address to a device address. */
162 u64 lower_mask;
163 u64 upper_shift;
164 u64 upper_mask;
165 u64 target_mask;
166 u64 target_shift;
167 } _stripe;
168 unsigned int dma_fault;
169
170 int scrub_hard;
171
172 int n_targets;
173 struct rsxx_dma_ctrl *ctrl;
174
175 struct dentry *debugfs_dir;
176 };
177
178 enum rsxx_pci_regmap {
179 HWID = 0x00, /* Hardware Identification Register */
180 SCRATCH = 0x04, /* Scratch/Debug Register */
181 RESET = 0x08, /* Reset Register */
182 ISR = 0x10, /* Interrupt Status Register */
183 IER = 0x14, /* Interrupt Enable Register */
184 IPR = 0x18, /* Interrupt Poll Register */
185 CB_ADD_LO = 0x20, /* Command Host Buffer Address [31:0] */
186 CB_ADD_HI = 0x24, /* Command Host Buffer Address [63:32]*/
187 HW_CMD_IDX = 0x28, /* Hardware Processed Command Index */
188 SW_CMD_IDX = 0x2C, /* Software Processed Command Index */
189 SB_ADD_LO = 0x30, /* Status Host Buffer Address [31:0] */
190 SB_ADD_HI = 0x34, /* Status Host Buffer Address [63:32] */
191 HW_STATUS_CNT = 0x38, /* Hardware Status Counter */
192 SW_STATUS_CNT = 0x3C, /* Deprecated */
193 CREG_CMD = 0x40, /* CPU Command Register */
194 CREG_ADD = 0x44, /* CPU Address Register */
195 CREG_CNT = 0x48, /* CPU Count Register */
196 CREG_STAT = 0x4C, /* CPU Status Register */
197 CREG_DATA0 = 0x50, /* CPU Data Registers */
198 CREG_DATA1 = 0x54,
199 CREG_DATA2 = 0x58,
200 CREG_DATA3 = 0x5C,
201 CREG_DATA4 = 0x60,
202 CREG_DATA5 = 0x64,
203 CREG_DATA6 = 0x68,
204 CREG_DATA7 = 0x6c,
205 INTR_COAL = 0x70, /* Interrupt Coalescing Register */
206 HW_ERROR = 0x74, /* Card Error Register */
207 PCI_DEBUG0 = 0x78, /* PCI Debug Registers */
208 PCI_DEBUG1 = 0x7C,
209 PCI_DEBUG2 = 0x80,
210 PCI_DEBUG3 = 0x84,
211 PCI_DEBUG4 = 0x88,
212 PCI_DEBUG5 = 0x8C,
213 PCI_DEBUG6 = 0x90,
214 PCI_DEBUG7 = 0x94,
215 PCI_POWER_THROTTLE = 0x98,
216 PERF_CTRL = 0x9c,
217 PERF_TIMER_LO = 0xa0,
218 PERF_TIMER_HI = 0xa4,
219 PERF_RD512_LO = 0xa8,
220 PERF_RD512_HI = 0xac,
221 PERF_WR512_LO = 0xb0,
222 PERF_WR512_HI = 0xb4,
223 PCI_RECONFIG = 0xb8,
224 };
225
226 enum rsxx_intr {
227 CR_INTR_DMA0 = 0x00000001,
228 CR_INTR_CREG = 0x00000002,
229 CR_INTR_DMA1 = 0x00000004,
230 CR_INTR_EVENT = 0x00000008,
231 CR_INTR_DMA2 = 0x00000010,
232 CR_INTR_DMA3 = 0x00000020,
233 CR_INTR_DMA4 = 0x00000040,
234 CR_INTR_DMA5 = 0x00000080,
235 CR_INTR_DMA6 = 0x00000100,
236 CR_INTR_DMA7 = 0x00000200,
237 CR_INTR_ALL_C = 0x0000003f,
238 CR_INTR_ALL_G = 0x000003ff,
239 CR_INTR_DMA_ALL = 0x000003f5,
240 CR_INTR_ALL = 0xffffffff,
241 };
242
CR_INTR_DMA(int N)243 static inline int CR_INTR_DMA(int N)
244 {
245 static const unsigned int _CR_INTR_DMA[] = {
246 CR_INTR_DMA0, CR_INTR_DMA1, CR_INTR_DMA2, CR_INTR_DMA3,
247 CR_INTR_DMA4, CR_INTR_DMA5, CR_INTR_DMA6, CR_INTR_DMA7
248 };
249 return _CR_INTR_DMA[N];
250 }
251 enum rsxx_pci_reset {
252 DMA_QUEUE_RESET = 0x00000001,
253 };
254
255 enum rsxx_hw_fifo_flush {
256 RSXX_FLUSH_BUSY = 0x00000002,
257 RSXX_FLUSH_TIMEOUT = 0x00000004,
258 };
259
260 enum rsxx_pci_revision {
261 RSXX_DISCARD_SUPPORT = 2,
262 RSXX_EEH_SUPPORT = 3,
263 };
264
265 enum rsxx_creg_cmd {
266 CREG_CMD_TAG_MASK = 0x0000FF00,
267 CREG_OP_WRITE = 0x000000C0,
268 CREG_OP_READ = 0x000000E0,
269 };
270
271 enum rsxx_creg_addr {
272 CREG_ADD_CARD_CMD = 0x80001000,
273 CREG_ADD_CARD_STATE = 0x80001004,
274 CREG_ADD_CARD_SIZE = 0x8000100c,
275 CREG_ADD_CAPABILITIES = 0x80001050,
276 CREG_ADD_LOG = 0x80002000,
277 CREG_ADD_NUM_TARGETS = 0x80003000,
278 CREG_ADD_CRAM = 0xA0000000,
279 CREG_ADD_CONFIG = 0xB0000000,
280 };
281
282 enum rsxx_creg_card_cmd {
283 CARD_CMD_STARTUP = 1,
284 CARD_CMD_SHUTDOWN = 2,
285 CARD_CMD_LOW_LEVEL_FORMAT = 3,
286 CARD_CMD_FPGA_RECONFIG_BR = 4,
287 CARD_CMD_FPGA_RECONFIG_MAIN = 5,
288 CARD_CMD_BACKUP = 6,
289 CARD_CMD_RESET = 7,
290 CARD_CMD_deprecated = 8,
291 CARD_CMD_UNINITIALIZE = 9,
292 CARD_CMD_DSTROY_EMERGENCY = 10,
293 CARD_CMD_DSTROY_NORMAL = 11,
294 CARD_CMD_DSTROY_EXTENDED = 12,
295 CARD_CMD_DSTROY_ABORT = 13,
296 };
297
298 enum rsxx_card_state {
299 CARD_STATE_SHUTDOWN = 0x00000001,
300 CARD_STATE_STARTING = 0x00000002,
301 CARD_STATE_FORMATTING = 0x00000004,
302 CARD_STATE_UNINITIALIZED = 0x00000008,
303 CARD_STATE_GOOD = 0x00000010,
304 CARD_STATE_SHUTTING_DOWN = 0x00000020,
305 CARD_STATE_FAULT = 0x00000040,
306 CARD_STATE_RD_ONLY_FAULT = 0x00000080,
307 CARD_STATE_DSTROYING = 0x00000100,
308 };
309
310 enum rsxx_led {
311 LED_DEFAULT = 0x0,
312 LED_IDENTIFY = 0x1,
313 LED_SOAK = 0x2,
314 };
315
316 enum rsxx_creg_flash_lock {
317 CREG_FLASH_LOCK = 1,
318 CREG_FLASH_UNLOCK = 2,
319 };
320
321 enum rsxx_card_capabilities {
322 CARD_CAP_SUBPAGE_WRITES = 0x00000080,
323 };
324
325 enum rsxx_creg_stat {
326 CREG_STAT_STATUS_MASK = 0x00000003,
327 CREG_STAT_SUCCESS = 0x1,
328 CREG_STAT_ERROR = 0x2,
329 CREG_STAT_CHAR_PENDING = 0x00000004, /* Character I/O pending bit */
330 CREG_STAT_LOG_PENDING = 0x00000008, /* HW log message pending bit */
331 CREG_STAT_TAG_MASK = 0x0000ff00,
332 };
333
334 enum rsxx_dma_finish {
335 FREE_DMA = 0x0,
336 COMPLETE_DMA = 0x1,
337 };
338
CREG_DATA(int N)339 static inline unsigned int CREG_DATA(int N)
340 {
341 return CREG_DATA0 + (N << 2);
342 }
343
344 /*----------------- Convenient Log Wrappers -------------------*/
345 #define CARD_TO_DEV(__CARD) (&(__CARD)->dev->dev)
346
347 /***** config.c *****/
348 int rsxx_load_config(struct rsxx_cardinfo *card);
349
350 /***** core.c *****/
351 void rsxx_enable_ier(struct rsxx_cardinfo *card, unsigned int intr);
352 void rsxx_disable_ier(struct rsxx_cardinfo *card, unsigned int intr);
353 void rsxx_enable_ier_and_isr(struct rsxx_cardinfo *card,
354 unsigned int intr);
355 void rsxx_disable_ier_and_isr(struct rsxx_cardinfo *card,
356 unsigned int intr);
357
358 /***** dev.c *****/
359 int rsxx_attach_dev(struct rsxx_cardinfo *card);
360 void rsxx_detach_dev(struct rsxx_cardinfo *card);
361 int rsxx_setup_dev(struct rsxx_cardinfo *card);
362 void rsxx_destroy_dev(struct rsxx_cardinfo *card);
363 int rsxx_dev_init(void);
364 void rsxx_dev_cleanup(void);
365
366 /***** dma.c ****/
367 typedef void (*rsxx_dma_cb)(struct rsxx_cardinfo *card,
368 void *cb_data,
369 unsigned int status);
370 int rsxx_dma_setup(struct rsxx_cardinfo *card);
371 void rsxx_dma_destroy(struct rsxx_cardinfo *card);
372 int rsxx_dma_init(void);
373 int rsxx_cleanup_dma_queue(struct rsxx_dma_ctrl *ctrl,
374 struct list_head *q,
375 unsigned int done);
376 int rsxx_dma_cancel(struct rsxx_dma_ctrl *ctrl);
377 void rsxx_dma_cleanup(void);
378 void rsxx_dma_queue_reset(struct rsxx_cardinfo *card);
379 int rsxx_dma_configure(struct rsxx_cardinfo *card);
380 blk_status_t rsxx_dma_queue_bio(struct rsxx_cardinfo *card,
381 struct bio *bio,
382 atomic_t *n_dmas,
383 rsxx_dma_cb cb,
384 void *cb_data);
385 int rsxx_hw_buffers_init(struct pci_dev *dev, struct rsxx_dma_ctrl *ctrl);
386 int rsxx_eeh_save_issued_dmas(struct rsxx_cardinfo *card);
387 int rsxx_eeh_remap_dmas(struct rsxx_cardinfo *card);
388
389 /***** cregs.c *****/
390 int rsxx_creg_write(struct rsxx_cardinfo *card, u32 addr,
391 unsigned int size8,
392 void *data,
393 int byte_stream);
394 int rsxx_creg_read(struct rsxx_cardinfo *card,
395 u32 addr,
396 unsigned int size8,
397 void *data,
398 int byte_stream);
399 int rsxx_read_hw_log(struct rsxx_cardinfo *card);
400 int rsxx_get_card_state(struct rsxx_cardinfo *card,
401 unsigned int *state);
402 int rsxx_get_card_size8(struct rsxx_cardinfo *card, u64 *size8);
403 int rsxx_get_num_targets(struct rsxx_cardinfo *card,
404 unsigned int *n_targets);
405 int rsxx_get_card_capabilities(struct rsxx_cardinfo *card,
406 u32 *capabilities);
407 int rsxx_issue_card_cmd(struct rsxx_cardinfo *card, u32 cmd);
408 int rsxx_creg_setup(struct rsxx_cardinfo *card);
409 void rsxx_creg_destroy(struct rsxx_cardinfo *card);
410 int rsxx_creg_init(void);
411 void rsxx_creg_cleanup(void);
412 int rsxx_reg_access(struct rsxx_cardinfo *card,
413 struct rsxx_reg_access __user *ucmd,
414 int read);
415 void rsxx_eeh_save_issued_creg(struct rsxx_cardinfo *card);
416 void rsxx_kick_creg_queue(struct rsxx_cardinfo *card);
417
418
419
420 #endif /* __DRIVERS_BLOCK_RSXX_H__ */
421