xref: /linux/drivers/ata/sata_sx4.c (revision 67feaba413ec68daf4124e9870878899b4ed9a0e)
1 // SPDX-License-Identifier: GPL-2.0-or-later
2 /*
3  *  sata_sx4.c - Promise SATA
4  *
5  *  Maintained by:  Tejun Heo <tj@kernel.org>
6  *  		    Please ALWAYS copy linux-ide@vger.kernel.org
7  *		    on emails.
8  *
9  *  Copyright 2003-2004 Red Hat, Inc.
10  *
11  *  libata documentation is available via 'make {ps|pdf}docs',
12  *  as Documentation/driver-api/libata.rst
13  *
14  *  Hardware documentation available under NDA.
15  */
16 
17 /*
18 	Theory of operation
19 	-------------------
20 
21 	The SX4 (PDC20621) chip features a single Host DMA (HDMA) copy
22 	engine, DIMM memory, and four ATA engines (one per SATA port).
23 	Data is copied to/from DIMM memory by the HDMA engine, before
24 	handing off to one (or more) of the ATA engines.  The ATA
25 	engines operate solely on DIMM memory.
26 
27 	The SX4 behaves like a PATA chip, with no SATA controls or
28 	knowledge whatsoever, leading to the presumption that
29 	PATA<->SATA bridges exist on SX4 boards, external to the
30 	PDC20621 chip itself.
31 
32 	The chip is quite capable, supporting an XOR engine and linked
33 	hardware commands (permits a string to transactions to be
34 	submitted and waited-on as a single unit), and an optional
35 	microprocessor.
36 
37 	The limiting factor is largely software.  This Linux driver was
38 	written to multiplex the single HDMA engine to copy disk
39 	transactions into a fixed DIMM memory space, from where an ATA
40 	engine takes over.  As a result, each WRITE looks like this:
41 
42 		submit HDMA packet to hardware
43 		hardware copies data from system memory to DIMM
44 		hardware raises interrupt
45 
46 		submit ATA packet to hardware
47 		hardware executes ATA WRITE command, w/ data in DIMM
48 		hardware raises interrupt
49 
50 	and each READ looks like this:
51 
52 		submit ATA packet to hardware
53 		hardware executes ATA READ command, w/ data in DIMM
54 		hardware raises interrupt
55 
56 		submit HDMA packet to hardware
57 		hardware copies data from DIMM to system memory
58 		hardware raises interrupt
59 
60 	This is a very slow, lock-step way of doing things that can
61 	certainly be improved by motivated kernel hackers.
62 
63  */
64 
65 #include <linux/kernel.h>
66 #include <linux/module.h>
67 #include <linux/pci.h>
68 #include <linux/slab.h>
69 #include <linux/blkdev.h>
70 #include <linux/delay.h>
71 #include <linux/interrupt.h>
72 #include <linux/device.h>
73 #include <scsi/scsi_host.h>
74 #include <scsi/scsi_cmnd.h>
75 #include <linux/libata.h>
76 #include "sata_promise.h"
77 
78 #define DRV_NAME	"sata_sx4"
79 #define DRV_VERSION	"0.12"
80 
81 static int dimm_test;
82 module_param(dimm_test, int, 0644);
83 MODULE_PARM_DESC(dimm_test, "Enable DIMM test during startup (1 = enabled)");
84 
85 enum {
86 	PDC_MMIO_BAR		= 3,
87 	PDC_DIMM_BAR		= 4,
88 
89 	PDC_PRD_TBL		= 0x44,	/* Direct command DMA table addr */
90 
91 	PDC_PKT_SUBMIT		= 0x40, /* Command packet pointer addr */
92 	PDC_HDMA_PKT_SUBMIT	= 0x100, /* Host DMA packet pointer addr */
93 	PDC_INT_SEQMASK		= 0x40,	/* Mask of asserted SEQ INTs */
94 	PDC_HDMA_CTLSTAT	= 0x12C, /* Host DMA control / status */
95 
96 	PDC_CTLSTAT		= 0x60,	/* IDEn control / status */
97 
98 	PDC_20621_SEQCTL	= 0x400,
99 	PDC_20621_SEQMASK	= 0x480,
100 	PDC_20621_GENERAL_CTL	= 0x484,
101 	PDC_20621_PAGE_SIZE	= (32 * 1024),
102 
103 	/* chosen, not constant, values; we design our own DIMM mem map */
104 	PDC_20621_DIMM_WINDOW	= 0x0C,	/* page# for 32K DIMM window */
105 	PDC_20621_DIMM_BASE	= 0x00200000,
106 	PDC_20621_DIMM_DATA	= (64 * 1024),
107 	PDC_DIMM_DATA_STEP	= (256 * 1024),
108 	PDC_DIMM_WINDOW_STEP	= (8 * 1024),
109 	PDC_DIMM_HOST_PRD	= (6 * 1024),
110 	PDC_DIMM_HOST_PKT	= (128 * 0),
111 	PDC_DIMM_HPKT_PRD	= (128 * 1),
112 	PDC_DIMM_ATA_PKT	= (128 * 2),
113 	PDC_DIMM_APKT_PRD	= (128 * 3),
114 	PDC_DIMM_HEADER_SZ	= PDC_DIMM_APKT_PRD + 128,
115 	PDC_PAGE_WINDOW		= 0x40,
116 	PDC_PAGE_DATA		= PDC_PAGE_WINDOW +
117 				  (PDC_20621_DIMM_DATA / PDC_20621_PAGE_SIZE),
118 	PDC_PAGE_SET		= PDC_DIMM_DATA_STEP / PDC_20621_PAGE_SIZE,
119 
120 	PDC_CHIP0_OFS		= 0xC0000, /* offset of chip #0 */
121 
122 	PDC_20621_ERR_MASK	= (1<<19) | (1<<20) | (1<<21) | (1<<22) |
123 				  (1<<23),
124 
125 	board_20621		= 0,	/* FastTrak S150 SX4 */
126 
127 	PDC_MASK_INT		= (1 << 10), /* HDMA/ATA mask int */
128 	PDC_RESET		= (1 << 11), /* HDMA/ATA reset */
129 	PDC_DMA_ENABLE		= (1 << 7),  /* DMA start/stop */
130 
131 	PDC_MAX_HDMA		= 32,
132 	PDC_HDMA_Q_MASK		= (PDC_MAX_HDMA - 1),
133 
134 	PDC_DIMM0_SPD_DEV_ADDRESS	= 0x50,
135 	PDC_DIMM1_SPD_DEV_ADDRESS	= 0x51,
136 	PDC_I2C_CONTROL			= 0x48,
137 	PDC_I2C_ADDR_DATA		= 0x4C,
138 	PDC_DIMM0_CONTROL		= 0x80,
139 	PDC_DIMM1_CONTROL		= 0x84,
140 	PDC_SDRAM_CONTROL		= 0x88,
141 	PDC_I2C_WRITE			= 0,		/* master -> slave */
142 	PDC_I2C_READ			= (1 << 6),	/* master <- slave */
143 	PDC_I2C_START			= (1 << 7),	/* start I2C proto */
144 	PDC_I2C_MASK_INT		= (1 << 5),	/* mask I2C interrupt */
145 	PDC_I2C_COMPLETE		= (1 << 16),	/* I2C normal compl. */
146 	PDC_I2C_NO_ACK			= (1 << 20),	/* slave no-ack addr */
147 	PDC_DIMM_SPD_SUBADDRESS_START	= 0x00,
148 	PDC_DIMM_SPD_SUBADDRESS_END	= 0x7F,
149 	PDC_DIMM_SPD_ROW_NUM		= 3,
150 	PDC_DIMM_SPD_COLUMN_NUM		= 4,
151 	PDC_DIMM_SPD_MODULE_ROW		= 5,
152 	PDC_DIMM_SPD_TYPE		= 11,
153 	PDC_DIMM_SPD_FRESH_RATE		= 12,
154 	PDC_DIMM_SPD_BANK_NUM		= 17,
155 	PDC_DIMM_SPD_CAS_LATENCY	= 18,
156 	PDC_DIMM_SPD_ATTRIBUTE		= 21,
157 	PDC_DIMM_SPD_ROW_PRE_CHARGE	= 27,
158 	PDC_DIMM_SPD_ROW_ACTIVE_DELAY	= 28,
159 	PDC_DIMM_SPD_RAS_CAS_DELAY	= 29,
160 	PDC_DIMM_SPD_ACTIVE_PRECHARGE	= 30,
161 	PDC_DIMM_SPD_SYSTEM_FREQ	= 126,
162 	PDC_CTL_STATUS			= 0x08,
163 	PDC_DIMM_WINDOW_CTLR		= 0x0C,
164 	PDC_TIME_CONTROL		= 0x3C,
165 	PDC_TIME_PERIOD			= 0x40,
166 	PDC_TIME_COUNTER		= 0x44,
167 	PDC_GENERAL_CTLR		= 0x484,
168 	PCI_PLL_INIT			= 0x8A531824,
169 	PCI_X_TCOUNT			= 0xEE1E5CFF,
170 
171 	/* PDC_TIME_CONTROL bits */
172 	PDC_TIMER_BUZZER		= (1 << 10),
173 	PDC_TIMER_MODE_PERIODIC		= 0,		/* bits 9:8 == 00 */
174 	PDC_TIMER_MODE_ONCE		= (1 << 8),	/* bits 9:8 == 01 */
175 	PDC_TIMER_ENABLE		= (1 << 7),
176 	PDC_TIMER_MASK_INT		= (1 << 5),
177 	PDC_TIMER_SEQ_MASK		= 0x1f,		/* SEQ ID for timer */
178 	PDC_TIMER_DEFAULT		= PDC_TIMER_MODE_ONCE |
179 					  PDC_TIMER_ENABLE |
180 					  PDC_TIMER_MASK_INT,
181 };
182 
183 #define ECC_ERASE_BUF_SZ (128 * 1024)
184 
185 struct pdc_port_priv {
186 	u8			dimm_buf[(ATA_PRD_SZ * ATA_MAX_PRD) + 512];
187 	u8			*pkt;
188 	dma_addr_t		pkt_dma;
189 };
190 
191 struct pdc_host_priv {
192 	unsigned int		doing_hdma;
193 	unsigned int		hdma_prod;
194 	unsigned int		hdma_cons;
195 	struct {
196 		struct ata_queued_cmd *qc;
197 		unsigned int	seq;
198 		unsigned long	pkt_ofs;
199 	} hdma[32];
200 };
201 
202 
203 static int pdc_sata_init_one(struct pci_dev *pdev, const struct pci_device_id *ent);
204 static void pdc_error_handler(struct ata_port *ap);
205 static void pdc_freeze(struct ata_port *ap);
206 static void pdc_thaw(struct ata_port *ap);
207 static int pdc_port_start(struct ata_port *ap);
208 static enum ata_completion_errors pdc20621_qc_prep(struct ata_queued_cmd *qc);
209 static void pdc_tf_load_mmio(struct ata_port *ap, const struct ata_taskfile *tf);
210 static void pdc_exec_command_mmio(struct ata_port *ap, const struct ata_taskfile *tf);
211 static unsigned int pdc20621_dimm_init(struct ata_host *host);
212 static int pdc20621_detect_dimm(struct ata_host *host);
213 static unsigned int pdc20621_i2c_read(struct ata_host *host,
214 				      u32 device, u32 subaddr, u32 *pdata);
215 static int pdc20621_prog_dimm0(struct ata_host *host);
216 static unsigned int pdc20621_prog_dimm_global(struct ata_host *host);
217 static void pdc20621_get_from_dimm(struct ata_host *host,
218 				   void *psource, u32 offset, u32 size);
219 static void pdc20621_put_to_dimm(struct ata_host *host,
220 				 void *psource, u32 offset, u32 size);
221 static void pdc20621_irq_clear(struct ata_port *ap);
222 static unsigned int pdc20621_qc_issue(struct ata_queued_cmd *qc);
223 static int pdc_softreset(struct ata_link *link, unsigned int *class,
224 			 unsigned long deadline);
225 static void pdc_post_internal_cmd(struct ata_queued_cmd *qc);
226 static int pdc_check_atapi_dma(struct ata_queued_cmd *qc);
227 
228 
229 static struct scsi_host_template pdc_sata_sht = {
230 	ATA_BASE_SHT(DRV_NAME),
231 	.sg_tablesize		= LIBATA_MAX_PRD,
232 	.dma_boundary		= ATA_DMA_BOUNDARY,
233 };
234 
235 /* TODO: inherit from base port_ops after converting to new EH */
236 static struct ata_port_operations pdc_20621_ops = {
237 	.inherits		= &ata_sff_port_ops,
238 
239 	.check_atapi_dma	= pdc_check_atapi_dma,
240 	.qc_prep		= pdc20621_qc_prep,
241 	.qc_issue		= pdc20621_qc_issue,
242 
243 	.freeze			= pdc_freeze,
244 	.thaw			= pdc_thaw,
245 	.softreset		= pdc_softreset,
246 	.error_handler		= pdc_error_handler,
247 	.lost_interrupt		= ATA_OP_NULL,
248 	.post_internal_cmd	= pdc_post_internal_cmd,
249 
250 	.port_start		= pdc_port_start,
251 
252 	.sff_tf_load		= pdc_tf_load_mmio,
253 	.sff_exec_command	= pdc_exec_command_mmio,
254 	.sff_irq_clear		= pdc20621_irq_clear,
255 };
256 
257 static const struct ata_port_info pdc_port_info[] = {
258 	/* board_20621 */
259 	{
260 		.flags		= ATA_FLAG_SATA | ATA_FLAG_NO_ATAPI |
261 				  ATA_FLAG_PIO_POLLING,
262 		.pio_mask	= ATA_PIO4,
263 		.mwdma_mask	= ATA_MWDMA2,
264 		.udma_mask	= ATA_UDMA6,
265 		.port_ops	= &pdc_20621_ops,
266 	},
267 
268 };
269 
270 static const struct pci_device_id pdc_sata_pci_tbl[] = {
271 	{ PCI_VDEVICE(PROMISE, 0x6622), board_20621 },
272 
273 	{ }	/* terminate list */
274 };
275 
276 static struct pci_driver pdc_sata_pci_driver = {
277 	.name			= DRV_NAME,
278 	.id_table		= pdc_sata_pci_tbl,
279 	.probe			= pdc_sata_init_one,
280 	.remove			= ata_pci_remove_one,
281 };
282 
283 
284 static int pdc_port_start(struct ata_port *ap)
285 {
286 	struct device *dev = ap->host->dev;
287 	struct pdc_port_priv *pp;
288 
289 	pp = devm_kzalloc(dev, sizeof(*pp), GFP_KERNEL);
290 	if (!pp)
291 		return -ENOMEM;
292 
293 	pp->pkt = dmam_alloc_coherent(dev, 128, &pp->pkt_dma, GFP_KERNEL);
294 	if (!pp->pkt)
295 		return -ENOMEM;
296 
297 	ap->private_data = pp;
298 
299 	return 0;
300 }
301 
302 static inline void pdc20621_ata_sg(u8 *buf, unsigned int portno,
303 				   unsigned int total_len)
304 {
305 	u32 addr;
306 	unsigned int dw = PDC_DIMM_APKT_PRD >> 2;
307 	__le32 *buf32 = (__le32 *) buf;
308 
309 	/* output ATA packet S/G table */
310 	addr = PDC_20621_DIMM_BASE + PDC_20621_DIMM_DATA +
311 	       (PDC_DIMM_DATA_STEP * portno);
312 
313 	buf32[dw] = cpu_to_le32(addr);
314 	buf32[dw + 1] = cpu_to_le32(total_len | ATA_PRD_EOT);
315 }
316 
317 static inline void pdc20621_host_sg(u8 *buf, unsigned int portno,
318 				    unsigned int total_len)
319 {
320 	u32 addr;
321 	unsigned int dw = PDC_DIMM_HPKT_PRD >> 2;
322 	__le32 *buf32 = (__le32 *) buf;
323 
324 	/* output Host DMA packet S/G table */
325 	addr = PDC_20621_DIMM_BASE + PDC_20621_DIMM_DATA +
326 	       (PDC_DIMM_DATA_STEP * portno);
327 
328 	buf32[dw] = cpu_to_le32(addr);
329 	buf32[dw + 1] = cpu_to_le32(total_len | ATA_PRD_EOT);
330 }
331 
332 static inline unsigned int pdc20621_ata_pkt(struct ata_taskfile *tf,
333 					    unsigned int devno, u8 *buf,
334 					    unsigned int portno)
335 {
336 	unsigned int i, dw;
337 	__le32 *buf32 = (__le32 *) buf;
338 	u8 dev_reg;
339 
340 	unsigned int dimm_sg = PDC_20621_DIMM_BASE +
341 			       (PDC_DIMM_WINDOW_STEP * portno) +
342 			       PDC_DIMM_APKT_PRD;
343 
344 	i = PDC_DIMM_ATA_PKT;
345 
346 	/*
347 	 * Set up ATA packet
348 	 */
349 	if ((tf->protocol == ATA_PROT_DMA) && (!(tf->flags & ATA_TFLAG_WRITE)))
350 		buf[i++] = PDC_PKT_READ;
351 	else if (tf->protocol == ATA_PROT_NODATA)
352 		buf[i++] = PDC_PKT_NODATA;
353 	else
354 		buf[i++] = 0;
355 	buf[i++] = 0;			/* reserved */
356 	buf[i++] = portno + 1;		/* seq. id */
357 	buf[i++] = 0xff;		/* delay seq. id */
358 
359 	/* dimm dma S/G, and next-pkt */
360 	dw = i >> 2;
361 	if (tf->protocol == ATA_PROT_NODATA)
362 		buf32[dw] = 0;
363 	else
364 		buf32[dw] = cpu_to_le32(dimm_sg);
365 	buf32[dw + 1] = 0;
366 	i += 8;
367 
368 	if (devno == 0)
369 		dev_reg = ATA_DEVICE_OBS;
370 	else
371 		dev_reg = ATA_DEVICE_OBS | ATA_DEV1;
372 
373 	/* select device */
374 	buf[i++] = (1 << 5) | PDC_PKT_CLEAR_BSY | ATA_REG_DEVICE;
375 	buf[i++] = dev_reg;
376 
377 	/* device control register */
378 	buf[i++] = (1 << 5) | PDC_REG_DEVCTL;
379 	buf[i++] = tf->ctl;
380 
381 	return i;
382 }
383 
384 static inline void pdc20621_host_pkt(struct ata_taskfile *tf, u8 *buf,
385 				     unsigned int portno)
386 {
387 	unsigned int dw;
388 	u32 tmp;
389 	__le32 *buf32 = (__le32 *) buf;
390 
391 	unsigned int host_sg = PDC_20621_DIMM_BASE +
392 			       (PDC_DIMM_WINDOW_STEP * portno) +
393 			       PDC_DIMM_HOST_PRD;
394 	unsigned int dimm_sg = PDC_20621_DIMM_BASE +
395 			       (PDC_DIMM_WINDOW_STEP * portno) +
396 			       PDC_DIMM_HPKT_PRD;
397 
398 	dw = PDC_DIMM_HOST_PKT >> 2;
399 
400 	/*
401 	 * Set up Host DMA packet
402 	 */
403 	if ((tf->protocol == ATA_PROT_DMA) && (!(tf->flags & ATA_TFLAG_WRITE)))
404 		tmp = PDC_PKT_READ;
405 	else
406 		tmp = 0;
407 	tmp |= ((portno + 1 + 4) << 16);	/* seq. id */
408 	tmp |= (0xff << 24);			/* delay seq. id */
409 	buf32[dw + 0] = cpu_to_le32(tmp);
410 	buf32[dw + 1] = cpu_to_le32(host_sg);
411 	buf32[dw + 2] = cpu_to_le32(dimm_sg);
412 	buf32[dw + 3] = 0;
413 }
414 
415 static void pdc20621_dma_prep(struct ata_queued_cmd *qc)
416 {
417 	struct scatterlist *sg;
418 	struct ata_port *ap = qc->ap;
419 	struct pdc_port_priv *pp = ap->private_data;
420 	void __iomem *mmio = ap->host->iomap[PDC_MMIO_BAR];
421 	void __iomem *dimm_mmio = ap->host->iomap[PDC_DIMM_BAR];
422 	unsigned int portno = ap->port_no;
423 	unsigned int i, si, idx, total_len = 0, sgt_len;
424 	__le32 *buf = (__le32 *) &pp->dimm_buf[PDC_DIMM_HEADER_SZ];
425 
426 	WARN_ON(!(qc->flags & ATA_QCFLAG_DMAMAP));
427 
428 	/* hard-code chip #0 */
429 	mmio += PDC_CHIP0_OFS;
430 
431 	/*
432 	 * Build S/G table
433 	 */
434 	idx = 0;
435 	for_each_sg(qc->sg, sg, qc->n_elem, si) {
436 		buf[idx++] = cpu_to_le32(sg_dma_address(sg));
437 		buf[idx++] = cpu_to_le32(sg_dma_len(sg));
438 		total_len += sg_dma_len(sg);
439 	}
440 	buf[idx - 1] |= cpu_to_le32(ATA_PRD_EOT);
441 	sgt_len = idx * 4;
442 
443 	/*
444 	 * Build ATA, host DMA packets
445 	 */
446 	pdc20621_host_sg(&pp->dimm_buf[0], portno, total_len);
447 	pdc20621_host_pkt(&qc->tf, &pp->dimm_buf[0], portno);
448 
449 	pdc20621_ata_sg(&pp->dimm_buf[0], portno, total_len);
450 	i = pdc20621_ata_pkt(&qc->tf, qc->dev->devno, &pp->dimm_buf[0], portno);
451 
452 	if (qc->tf.flags & ATA_TFLAG_LBA48)
453 		i = pdc_prep_lba48(&qc->tf, &pp->dimm_buf[0], i);
454 	else
455 		i = pdc_prep_lba28(&qc->tf, &pp->dimm_buf[0], i);
456 
457 	pdc_pkt_footer(&qc->tf, &pp->dimm_buf[0], i);
458 
459 	/* copy three S/G tables and two packets to DIMM MMIO window */
460 	memcpy_toio(dimm_mmio + (portno * PDC_DIMM_WINDOW_STEP),
461 		    &pp->dimm_buf, PDC_DIMM_HEADER_SZ);
462 	memcpy_toio(dimm_mmio + (portno * PDC_DIMM_WINDOW_STEP) +
463 		    PDC_DIMM_HOST_PRD,
464 		    &pp->dimm_buf[PDC_DIMM_HEADER_SZ], sgt_len);
465 
466 	/* force host FIFO dump */
467 	writel(0x00000001, mmio + PDC_20621_GENERAL_CTL);
468 
469 	readl(dimm_mmio);	/* MMIO PCI posting flush */
470 
471 	ata_port_dbg(ap, "ata pkt buf ofs %u, prd size %u, mmio copied\n",
472 		     i, sgt_len);
473 }
474 
475 static void pdc20621_nodata_prep(struct ata_queued_cmd *qc)
476 {
477 	struct ata_port *ap = qc->ap;
478 	struct pdc_port_priv *pp = ap->private_data;
479 	void __iomem *mmio = ap->host->iomap[PDC_MMIO_BAR];
480 	void __iomem *dimm_mmio = ap->host->iomap[PDC_DIMM_BAR];
481 	unsigned int portno = ap->port_no;
482 	unsigned int i;
483 
484 	/* hard-code chip #0 */
485 	mmio += PDC_CHIP0_OFS;
486 
487 	i = pdc20621_ata_pkt(&qc->tf, qc->dev->devno, &pp->dimm_buf[0], portno);
488 
489 	if (qc->tf.flags & ATA_TFLAG_LBA48)
490 		i = pdc_prep_lba48(&qc->tf, &pp->dimm_buf[0], i);
491 	else
492 		i = pdc_prep_lba28(&qc->tf, &pp->dimm_buf[0], i);
493 
494 	pdc_pkt_footer(&qc->tf, &pp->dimm_buf[0], i);
495 
496 	/* copy three S/G tables and two packets to DIMM MMIO window */
497 	memcpy_toio(dimm_mmio + (portno * PDC_DIMM_WINDOW_STEP),
498 		    &pp->dimm_buf, PDC_DIMM_HEADER_SZ);
499 
500 	/* force host FIFO dump */
501 	writel(0x00000001, mmio + PDC_20621_GENERAL_CTL);
502 
503 	readl(dimm_mmio);	/* MMIO PCI posting flush */
504 
505 	ata_port_dbg(ap, "ata pkt buf ofs %u, mmio copied\n", i);
506 }
507 
508 static enum ata_completion_errors pdc20621_qc_prep(struct ata_queued_cmd *qc)
509 {
510 	switch (qc->tf.protocol) {
511 	case ATA_PROT_DMA:
512 		pdc20621_dma_prep(qc);
513 		break;
514 	case ATA_PROT_NODATA:
515 		pdc20621_nodata_prep(qc);
516 		break;
517 	default:
518 		break;
519 	}
520 
521 	return AC_ERR_OK;
522 }
523 
524 static void __pdc20621_push_hdma(struct ata_queued_cmd *qc,
525 				 unsigned int seq,
526 				 u32 pkt_ofs)
527 {
528 	struct ata_port *ap = qc->ap;
529 	struct ata_host *host = ap->host;
530 	void __iomem *mmio = host->iomap[PDC_MMIO_BAR];
531 
532 	/* hard-code chip #0 */
533 	mmio += PDC_CHIP0_OFS;
534 
535 	writel(0x00000001, mmio + PDC_20621_SEQCTL + (seq * 4));
536 	readl(mmio + PDC_20621_SEQCTL + (seq * 4));	/* flush */
537 
538 	writel(pkt_ofs, mmio + PDC_HDMA_PKT_SUBMIT);
539 	readl(mmio + PDC_HDMA_PKT_SUBMIT);	/* flush */
540 }
541 
542 static void pdc20621_push_hdma(struct ata_queued_cmd *qc,
543 				unsigned int seq,
544 				u32 pkt_ofs)
545 {
546 	struct ata_port *ap = qc->ap;
547 	struct pdc_host_priv *pp = ap->host->private_data;
548 	unsigned int idx = pp->hdma_prod & PDC_HDMA_Q_MASK;
549 
550 	if (!pp->doing_hdma) {
551 		__pdc20621_push_hdma(qc, seq, pkt_ofs);
552 		pp->doing_hdma = 1;
553 		return;
554 	}
555 
556 	pp->hdma[idx].qc = qc;
557 	pp->hdma[idx].seq = seq;
558 	pp->hdma[idx].pkt_ofs = pkt_ofs;
559 	pp->hdma_prod++;
560 }
561 
562 static void pdc20621_pop_hdma(struct ata_queued_cmd *qc)
563 {
564 	struct ata_port *ap = qc->ap;
565 	struct pdc_host_priv *pp = ap->host->private_data;
566 	unsigned int idx = pp->hdma_cons & PDC_HDMA_Q_MASK;
567 
568 	/* if nothing on queue, we're done */
569 	if (pp->hdma_prod == pp->hdma_cons) {
570 		pp->doing_hdma = 0;
571 		return;
572 	}
573 
574 	__pdc20621_push_hdma(pp->hdma[idx].qc, pp->hdma[idx].seq,
575 			     pp->hdma[idx].pkt_ofs);
576 	pp->hdma_cons++;
577 }
578 
579 static void pdc20621_dump_hdma(struct ata_queued_cmd *qc)
580 {
581 	struct ata_port *ap = qc->ap;
582 	unsigned int port_no = ap->port_no;
583 	void __iomem *dimm_mmio = ap->host->iomap[PDC_DIMM_BAR];
584 
585 	dimm_mmio += (port_no * PDC_DIMM_WINDOW_STEP);
586 	dimm_mmio += PDC_DIMM_HOST_PKT;
587 
588 	ata_port_dbg(ap, "HDMA 0x%08X 0x%08X 0x%08X 0x%08X\n",
589 		     readl(dimm_mmio), readl(dimm_mmio + 4),
590 		     readl(dimm_mmio + 8), readl(dimm_mmio + 12));
591 }
592 
593 static void pdc20621_packet_start(struct ata_queued_cmd *qc)
594 {
595 	struct ata_port *ap = qc->ap;
596 	struct ata_host *host = ap->host;
597 	unsigned int port_no = ap->port_no;
598 	void __iomem *mmio = host->iomap[PDC_MMIO_BAR];
599 	unsigned int rw = (qc->tf.flags & ATA_TFLAG_WRITE);
600 	u8 seq = (u8) (port_no + 1);
601 	unsigned int port_ofs;
602 
603 	/* hard-code chip #0 */
604 	mmio += PDC_CHIP0_OFS;
605 
606 	wmb();			/* flush PRD, pkt writes */
607 
608 	port_ofs = PDC_20621_DIMM_BASE + (PDC_DIMM_WINDOW_STEP * port_no);
609 
610 	/* if writing, we (1) DMA to DIMM, then (2) do ATA command */
611 	if (rw && qc->tf.protocol == ATA_PROT_DMA) {
612 		seq += 4;
613 
614 		pdc20621_dump_hdma(qc);
615 		pdc20621_push_hdma(qc, seq, port_ofs + PDC_DIMM_HOST_PKT);
616 		ata_port_dbg(ap, "queued ofs 0x%x (%u), seq %u\n",
617 			port_ofs + PDC_DIMM_HOST_PKT,
618 			port_ofs + PDC_DIMM_HOST_PKT,
619 			seq);
620 	} else {
621 		writel(0x00000001, mmio + PDC_20621_SEQCTL + (seq * 4));
622 		readl(mmio + PDC_20621_SEQCTL + (seq * 4));	/* flush */
623 
624 		writel(port_ofs + PDC_DIMM_ATA_PKT,
625 		       ap->ioaddr.cmd_addr + PDC_PKT_SUBMIT);
626 		readl(ap->ioaddr.cmd_addr + PDC_PKT_SUBMIT);
627 		ata_port_dbg(ap, "submitted ofs 0x%x (%u), seq %u\n",
628 			port_ofs + PDC_DIMM_ATA_PKT,
629 			port_ofs + PDC_DIMM_ATA_PKT,
630 			seq);
631 	}
632 }
633 
634 static unsigned int pdc20621_qc_issue(struct ata_queued_cmd *qc)
635 {
636 	switch (qc->tf.protocol) {
637 	case ATA_PROT_NODATA:
638 		if (qc->tf.flags & ATA_TFLAG_POLLING)
639 			break;
640 		fallthrough;
641 	case ATA_PROT_DMA:
642 		pdc20621_packet_start(qc);
643 		return 0;
644 
645 	case ATAPI_PROT_DMA:
646 		BUG();
647 		break;
648 
649 	default:
650 		break;
651 	}
652 
653 	return ata_sff_qc_issue(qc);
654 }
655 
656 static inline unsigned int pdc20621_host_intr(struct ata_port *ap,
657 					  struct ata_queued_cmd *qc,
658 					  unsigned int doing_hdma,
659 					  void __iomem *mmio)
660 {
661 	unsigned int port_no = ap->port_no;
662 	unsigned int port_ofs =
663 		PDC_20621_DIMM_BASE + (PDC_DIMM_WINDOW_STEP * port_no);
664 	u8 status;
665 	unsigned int handled = 0;
666 
667 	if ((qc->tf.protocol == ATA_PROT_DMA) &&	/* read */
668 	    (!(qc->tf.flags & ATA_TFLAG_WRITE))) {
669 
670 		/* step two - DMA from DIMM to host */
671 		if (doing_hdma) {
672 			ata_port_dbg(ap, "read hdma, 0x%x 0x%x\n",
673 				readl(mmio + 0x104), readl(mmio + PDC_HDMA_CTLSTAT));
674 			/* get drive status; clear intr; complete txn */
675 			qc->err_mask |= ac_err_mask(ata_wait_idle(ap));
676 			ata_qc_complete(qc);
677 			pdc20621_pop_hdma(qc);
678 		}
679 
680 		/* step one - exec ATA command */
681 		else {
682 			u8 seq = (u8) (port_no + 1 + 4);
683 			ata_port_dbg(ap, "read ata, 0x%x 0x%x\n",
684 				readl(mmio + 0x104), readl(mmio + PDC_HDMA_CTLSTAT));
685 
686 			/* submit hdma pkt */
687 			pdc20621_dump_hdma(qc);
688 			pdc20621_push_hdma(qc, seq,
689 					   port_ofs + PDC_DIMM_HOST_PKT);
690 		}
691 		handled = 1;
692 
693 	} else if (qc->tf.protocol == ATA_PROT_DMA) {	/* write */
694 
695 		/* step one - DMA from host to DIMM */
696 		if (doing_hdma) {
697 			u8 seq = (u8) (port_no + 1);
698 			ata_port_dbg(ap, "write hdma, 0x%x 0x%x\n",
699 				readl(mmio + 0x104), readl(mmio + PDC_HDMA_CTLSTAT));
700 
701 			/* submit ata pkt */
702 			writel(0x00000001, mmio + PDC_20621_SEQCTL + (seq * 4));
703 			readl(mmio + PDC_20621_SEQCTL + (seq * 4));
704 			writel(port_ofs + PDC_DIMM_ATA_PKT,
705 			       ap->ioaddr.cmd_addr + PDC_PKT_SUBMIT);
706 			readl(ap->ioaddr.cmd_addr + PDC_PKT_SUBMIT);
707 		}
708 
709 		/* step two - execute ATA command */
710 		else {
711 			ata_port_dbg(ap, "write ata, 0x%x 0x%x\n",
712 				readl(mmio + 0x104), readl(mmio + PDC_HDMA_CTLSTAT));
713 			/* get drive status; clear intr; complete txn */
714 			qc->err_mask |= ac_err_mask(ata_wait_idle(ap));
715 			ata_qc_complete(qc);
716 			pdc20621_pop_hdma(qc);
717 		}
718 		handled = 1;
719 
720 	/* command completion, but no data xfer */
721 	} else if (qc->tf.protocol == ATA_PROT_NODATA) {
722 
723 		status = ata_sff_busy_wait(ap, ATA_BUSY | ATA_DRQ, 1000);
724 		ata_port_dbg(ap, "BUS_NODATA (drv_stat 0x%X)\n", status);
725 		qc->err_mask |= ac_err_mask(status);
726 		ata_qc_complete(qc);
727 		handled = 1;
728 
729 	} else {
730 		ap->stats.idle_irq++;
731 	}
732 
733 	return handled;
734 }
735 
736 static void pdc20621_irq_clear(struct ata_port *ap)
737 {
738 	ioread8(ap->ioaddr.status_addr);
739 }
740 
741 static irqreturn_t pdc20621_interrupt(int irq, void *dev_instance)
742 {
743 	struct ata_host *host = dev_instance;
744 	struct ata_port *ap;
745 	u32 mask = 0;
746 	unsigned int i, tmp, port_no;
747 	unsigned int handled = 0;
748 	void __iomem *mmio_base;
749 
750 	if (!host || !host->iomap[PDC_MMIO_BAR])
751 		return IRQ_NONE;
752 
753 	mmio_base = host->iomap[PDC_MMIO_BAR];
754 
755 	/* reading should also clear interrupts */
756 	mmio_base += PDC_CHIP0_OFS;
757 	mask = readl(mmio_base + PDC_20621_SEQMASK);
758 
759 	if (mask == 0xffffffff)
760 		return IRQ_NONE;
761 
762 	mask &= 0xffff;		/* only 16 tags possible */
763 	if (!mask)
764 		return IRQ_NONE;
765 
766 	spin_lock(&host->lock);
767 
768 	for (i = 1; i < 9; i++) {
769 		port_no = i - 1;
770 		if (port_no > 3)
771 			port_no -= 4;
772 		if (port_no >= host->n_ports)
773 			ap = NULL;
774 		else
775 			ap = host->ports[port_no];
776 		tmp = mask & (1 << i);
777 		if (ap)
778 			ata_port_dbg(ap, "seq %u, tmp %x\n", i, tmp);
779 		if (tmp && ap) {
780 			struct ata_queued_cmd *qc;
781 
782 			qc = ata_qc_from_tag(ap, ap->link.active_tag);
783 			if (qc && (!(qc->tf.flags & ATA_TFLAG_POLLING)))
784 				handled += pdc20621_host_intr(ap, qc, (i > 4),
785 							      mmio_base);
786 		}
787 	}
788 
789 	spin_unlock(&host->lock);
790 
791 	return IRQ_RETVAL(handled);
792 }
793 
794 static void pdc_freeze(struct ata_port *ap)
795 {
796 	void __iomem *mmio = ap->ioaddr.cmd_addr;
797 	u32 tmp;
798 
799 	/* FIXME: if all 4 ATA engines are stopped, also stop HDMA engine */
800 
801 	tmp = readl(mmio + PDC_CTLSTAT);
802 	tmp |= PDC_MASK_INT;
803 	tmp &= ~PDC_DMA_ENABLE;
804 	writel(tmp, mmio + PDC_CTLSTAT);
805 	readl(mmio + PDC_CTLSTAT); /* flush */
806 }
807 
808 static void pdc_thaw(struct ata_port *ap)
809 {
810 	void __iomem *mmio = ap->ioaddr.cmd_addr;
811 	u32 tmp;
812 
813 	/* FIXME: start HDMA engine, if zero ATA engines running */
814 
815 	/* clear IRQ */
816 	ioread8(ap->ioaddr.status_addr);
817 
818 	/* turn IRQ back on */
819 	tmp = readl(mmio + PDC_CTLSTAT);
820 	tmp &= ~PDC_MASK_INT;
821 	writel(tmp, mmio + PDC_CTLSTAT);
822 	readl(mmio + PDC_CTLSTAT); /* flush */
823 }
824 
825 static void pdc_reset_port(struct ata_port *ap)
826 {
827 	void __iomem *mmio = ap->ioaddr.cmd_addr + PDC_CTLSTAT;
828 	unsigned int i;
829 	u32 tmp;
830 
831 	/* FIXME: handle HDMA copy engine */
832 
833 	for (i = 11; i > 0; i--) {
834 		tmp = readl(mmio);
835 		if (tmp & PDC_RESET)
836 			break;
837 
838 		udelay(100);
839 
840 		tmp |= PDC_RESET;
841 		writel(tmp, mmio);
842 	}
843 
844 	tmp &= ~PDC_RESET;
845 	writel(tmp, mmio);
846 	readl(mmio);	/* flush */
847 }
848 
849 static int pdc_softreset(struct ata_link *link, unsigned int *class,
850 			 unsigned long deadline)
851 {
852 	pdc_reset_port(link->ap);
853 	return ata_sff_softreset(link, class, deadline);
854 }
855 
856 static void pdc_error_handler(struct ata_port *ap)
857 {
858 	if (!(ap->pflags & ATA_PFLAG_FROZEN))
859 		pdc_reset_port(ap);
860 
861 	ata_sff_error_handler(ap);
862 }
863 
864 static void pdc_post_internal_cmd(struct ata_queued_cmd *qc)
865 {
866 	struct ata_port *ap = qc->ap;
867 
868 	/* make DMA engine forget about the failed command */
869 	if (qc->flags & ATA_QCFLAG_FAILED)
870 		pdc_reset_port(ap);
871 }
872 
873 static int pdc_check_atapi_dma(struct ata_queued_cmd *qc)
874 {
875 	u8 *scsicmd = qc->scsicmd->cmnd;
876 	int pio = 1; /* atapi dma off by default */
877 
878 	/* Whitelist commands that may use DMA. */
879 	switch (scsicmd[0]) {
880 	case WRITE_12:
881 	case WRITE_10:
882 	case WRITE_6:
883 	case READ_12:
884 	case READ_10:
885 	case READ_6:
886 	case 0xad: /* READ_DVD_STRUCTURE */
887 	case 0xbe: /* READ_CD */
888 		pio = 0;
889 	}
890 	/* -45150 (FFFF4FA2) to -1 (FFFFFFFF) shall use PIO mode */
891 	if (scsicmd[0] == WRITE_10) {
892 		unsigned int lba =
893 			(scsicmd[2] << 24) |
894 			(scsicmd[3] << 16) |
895 			(scsicmd[4] << 8) |
896 			scsicmd[5];
897 		if (lba >= 0xFFFF4FA2)
898 			pio = 1;
899 	}
900 	return pio;
901 }
902 
903 static void pdc_tf_load_mmio(struct ata_port *ap, const struct ata_taskfile *tf)
904 {
905 	WARN_ON(tf->protocol == ATA_PROT_DMA ||
906 		tf->protocol == ATAPI_PROT_DMA);
907 	ata_sff_tf_load(ap, tf);
908 }
909 
910 
911 static void pdc_exec_command_mmio(struct ata_port *ap, const struct ata_taskfile *tf)
912 {
913 	WARN_ON(tf->protocol == ATA_PROT_DMA ||
914 		tf->protocol == ATAPI_PROT_DMA);
915 	ata_sff_exec_command(ap, tf);
916 }
917 
918 
919 static void pdc_sata_setup_port(struct ata_ioports *port, void __iomem *base)
920 {
921 	port->cmd_addr		= base;
922 	port->data_addr		= base;
923 	port->feature_addr	=
924 	port->error_addr	= base + 0x4;
925 	port->nsect_addr	= base + 0x8;
926 	port->lbal_addr		= base + 0xc;
927 	port->lbam_addr		= base + 0x10;
928 	port->lbah_addr		= base + 0x14;
929 	port->device_addr	= base + 0x18;
930 	port->command_addr	=
931 	port->status_addr	= base + 0x1c;
932 	port->altstatus_addr	=
933 	port->ctl_addr		= base + 0x38;
934 }
935 
936 
937 static void pdc20621_get_from_dimm(struct ata_host *host, void *psource,
938 				   u32 offset, u32 size)
939 {
940 	u32 window_size;
941 	u16 idx;
942 	u8 page_mask;
943 	long dist;
944 	void __iomem *mmio = host->iomap[PDC_MMIO_BAR];
945 	void __iomem *dimm_mmio = host->iomap[PDC_DIMM_BAR];
946 
947 	/* hard-code chip #0 */
948 	mmio += PDC_CHIP0_OFS;
949 
950 	page_mask = 0x00;
951 	window_size = 0x2000 * 4; /* 32K byte uchar size */
952 	idx = (u16) (offset / window_size);
953 
954 	writel(0x01, mmio + PDC_GENERAL_CTLR);
955 	readl(mmio + PDC_GENERAL_CTLR);
956 	writel(((idx) << page_mask), mmio + PDC_DIMM_WINDOW_CTLR);
957 	readl(mmio + PDC_DIMM_WINDOW_CTLR);
958 
959 	offset -= (idx * window_size);
960 	idx++;
961 	dist = ((long) (window_size - (offset + size))) >= 0 ? size :
962 		(long) (window_size - offset);
963 	memcpy_fromio(psource, dimm_mmio + offset / 4, dist);
964 
965 	psource += dist;
966 	size -= dist;
967 	for (; (long) size >= (long) window_size ;) {
968 		writel(0x01, mmio + PDC_GENERAL_CTLR);
969 		readl(mmio + PDC_GENERAL_CTLR);
970 		writel(((idx) << page_mask), mmio + PDC_DIMM_WINDOW_CTLR);
971 		readl(mmio + PDC_DIMM_WINDOW_CTLR);
972 		memcpy_fromio(psource, dimm_mmio, window_size / 4);
973 		psource += window_size;
974 		size -= window_size;
975 		idx++;
976 	}
977 
978 	if (size) {
979 		writel(0x01, mmio + PDC_GENERAL_CTLR);
980 		readl(mmio + PDC_GENERAL_CTLR);
981 		writel(((idx) << page_mask), mmio + PDC_DIMM_WINDOW_CTLR);
982 		readl(mmio + PDC_DIMM_WINDOW_CTLR);
983 		memcpy_fromio(psource, dimm_mmio, size / 4);
984 	}
985 }
986 
987 
988 static void pdc20621_put_to_dimm(struct ata_host *host, void *psource,
989 				 u32 offset, u32 size)
990 {
991 	u32 window_size;
992 	u16 idx;
993 	u8 page_mask;
994 	long dist;
995 	void __iomem *mmio = host->iomap[PDC_MMIO_BAR];
996 	void __iomem *dimm_mmio = host->iomap[PDC_DIMM_BAR];
997 
998 	/* hard-code chip #0 */
999 	mmio += PDC_CHIP0_OFS;
1000 
1001 	page_mask = 0x00;
1002 	window_size = 0x2000 * 4;       /* 32K byte uchar size */
1003 	idx = (u16) (offset / window_size);
1004 
1005 	writel(((idx) << page_mask), mmio + PDC_DIMM_WINDOW_CTLR);
1006 	readl(mmio + PDC_DIMM_WINDOW_CTLR);
1007 	offset -= (idx * window_size);
1008 	idx++;
1009 	dist = ((long)(s32)(window_size - (offset + size))) >= 0 ? size :
1010 		(long) (window_size - offset);
1011 	memcpy_toio(dimm_mmio + offset / 4, psource, dist);
1012 	writel(0x01, mmio + PDC_GENERAL_CTLR);
1013 	readl(mmio + PDC_GENERAL_CTLR);
1014 
1015 	psource += dist;
1016 	size -= dist;
1017 	for (; (long) size >= (long) window_size ;) {
1018 		writel(((idx) << page_mask), mmio + PDC_DIMM_WINDOW_CTLR);
1019 		readl(mmio + PDC_DIMM_WINDOW_CTLR);
1020 		memcpy_toio(dimm_mmio, psource, window_size / 4);
1021 		writel(0x01, mmio + PDC_GENERAL_CTLR);
1022 		readl(mmio + PDC_GENERAL_CTLR);
1023 		psource += window_size;
1024 		size -= window_size;
1025 		idx++;
1026 	}
1027 
1028 	if (size) {
1029 		writel(((idx) << page_mask), mmio + PDC_DIMM_WINDOW_CTLR);
1030 		readl(mmio + PDC_DIMM_WINDOW_CTLR);
1031 		memcpy_toio(dimm_mmio, psource, size / 4);
1032 		writel(0x01, mmio + PDC_GENERAL_CTLR);
1033 		readl(mmio + PDC_GENERAL_CTLR);
1034 	}
1035 }
1036 
1037 
1038 static unsigned int pdc20621_i2c_read(struct ata_host *host, u32 device,
1039 				      u32 subaddr, u32 *pdata)
1040 {
1041 	void __iomem *mmio = host->iomap[PDC_MMIO_BAR];
1042 	u32 i2creg  = 0;
1043 	u32 status;
1044 	u32 count = 0;
1045 
1046 	/* hard-code chip #0 */
1047 	mmio += PDC_CHIP0_OFS;
1048 
1049 	i2creg |= device << 24;
1050 	i2creg |= subaddr << 16;
1051 
1052 	/* Set the device and subaddress */
1053 	writel(i2creg, mmio + PDC_I2C_ADDR_DATA);
1054 	readl(mmio + PDC_I2C_ADDR_DATA);
1055 
1056 	/* Write Control to perform read operation, mask int */
1057 	writel(PDC_I2C_READ | PDC_I2C_START | PDC_I2C_MASK_INT,
1058 	       mmio + PDC_I2C_CONTROL);
1059 
1060 	for (count = 0; count <= 1000; count ++) {
1061 		status = readl(mmio + PDC_I2C_CONTROL);
1062 		if (status & PDC_I2C_COMPLETE) {
1063 			status = readl(mmio + PDC_I2C_ADDR_DATA);
1064 			break;
1065 		} else if (count == 1000)
1066 			return 0;
1067 	}
1068 
1069 	*pdata = (status >> 8) & 0x000000ff;
1070 	return 1;
1071 }
1072 
1073 
1074 static int pdc20621_detect_dimm(struct ata_host *host)
1075 {
1076 	u32 data = 0;
1077 	if (pdc20621_i2c_read(host, PDC_DIMM0_SPD_DEV_ADDRESS,
1078 			     PDC_DIMM_SPD_SYSTEM_FREQ, &data)) {
1079 		if (data == 100)
1080 			return 100;
1081 	} else
1082 		return 0;
1083 
1084 	if (pdc20621_i2c_read(host, PDC_DIMM0_SPD_DEV_ADDRESS, 9, &data)) {
1085 		if (data <= 0x75)
1086 			return 133;
1087 	} else
1088 		return 0;
1089 
1090 	return 0;
1091 }
1092 
1093 
1094 static int pdc20621_prog_dimm0(struct ata_host *host)
1095 {
1096 	u32 spd0[50];
1097 	u32 data = 0;
1098 	int size, i;
1099 	u8 bdimmsize;
1100 	void __iomem *mmio = host->iomap[PDC_MMIO_BAR];
1101 	static const struct {
1102 		unsigned int reg;
1103 		unsigned int ofs;
1104 	} pdc_i2c_read_data [] = {
1105 		{ PDC_DIMM_SPD_TYPE, 11 },
1106 		{ PDC_DIMM_SPD_FRESH_RATE, 12 },
1107 		{ PDC_DIMM_SPD_COLUMN_NUM, 4 },
1108 		{ PDC_DIMM_SPD_ATTRIBUTE, 21 },
1109 		{ PDC_DIMM_SPD_ROW_NUM, 3 },
1110 		{ PDC_DIMM_SPD_BANK_NUM, 17 },
1111 		{ PDC_DIMM_SPD_MODULE_ROW, 5 },
1112 		{ PDC_DIMM_SPD_ROW_PRE_CHARGE, 27 },
1113 		{ PDC_DIMM_SPD_ROW_ACTIVE_DELAY, 28 },
1114 		{ PDC_DIMM_SPD_RAS_CAS_DELAY, 29 },
1115 		{ PDC_DIMM_SPD_ACTIVE_PRECHARGE, 30 },
1116 		{ PDC_DIMM_SPD_CAS_LATENCY, 18 },
1117 	};
1118 
1119 	/* hard-code chip #0 */
1120 	mmio += PDC_CHIP0_OFS;
1121 
1122 	for (i = 0; i < ARRAY_SIZE(pdc_i2c_read_data); i++)
1123 		pdc20621_i2c_read(host, PDC_DIMM0_SPD_DEV_ADDRESS,
1124 				  pdc_i2c_read_data[i].reg,
1125 				  &spd0[pdc_i2c_read_data[i].ofs]);
1126 
1127 	data |= (spd0[4] - 8) | ((spd0[21] != 0) << 3) | ((spd0[3]-11) << 4);
1128 	data |= ((spd0[17] / 4) << 6) | ((spd0[5] / 2) << 7) |
1129 		((((spd0[27] + 9) / 10) - 1) << 8) ;
1130 	data |= (((((spd0[29] > spd0[28])
1131 		    ? spd0[29] : spd0[28]) + 9) / 10) - 1) << 10;
1132 	data |= ((spd0[30] - spd0[29] + 9) / 10 - 2) << 12;
1133 
1134 	if (spd0[18] & 0x08)
1135 		data |= ((0x03) << 14);
1136 	else if (spd0[18] & 0x04)
1137 		data |= ((0x02) << 14);
1138 	else if (spd0[18] & 0x01)
1139 		data |= ((0x01) << 14);
1140 	else
1141 		data |= (0 << 14);
1142 
1143 	/*
1144 	   Calculate the size of bDIMMSize (power of 2) and
1145 	   merge the DIMM size by program start/end address.
1146 	*/
1147 
1148 	bdimmsize = spd0[4] + (spd0[5] / 2) + spd0[3] + (spd0[17] / 2) + 3;
1149 	size = (1 << bdimmsize) >> 20;	/* size = xxx(MB) */
1150 	data |= (((size / 16) - 1) << 16);
1151 	data |= (0 << 23);
1152 	data |= 8;
1153 	writel(data, mmio + PDC_DIMM0_CONTROL);
1154 	readl(mmio + PDC_DIMM0_CONTROL);
1155 	return size;
1156 }
1157 
1158 
1159 static unsigned int pdc20621_prog_dimm_global(struct ata_host *host)
1160 {
1161 	u32 data, spd0;
1162 	int error, i;
1163 	void __iomem *mmio = host->iomap[PDC_MMIO_BAR];
1164 
1165 	/* hard-code chip #0 */
1166 	mmio += PDC_CHIP0_OFS;
1167 
1168 	/*
1169 	  Set To Default : DIMM Module Global Control Register (0x022259F1)
1170 	  DIMM Arbitration Disable (bit 20)
1171 	  DIMM Data/Control Output Driving Selection (bit12 - bit15)
1172 	  Refresh Enable (bit 17)
1173 	*/
1174 
1175 	data = 0x022259F1;
1176 	writel(data, mmio + PDC_SDRAM_CONTROL);
1177 	readl(mmio + PDC_SDRAM_CONTROL);
1178 
1179 	/* Turn on for ECC */
1180 	if (!pdc20621_i2c_read(host, PDC_DIMM0_SPD_DEV_ADDRESS,
1181 			       PDC_DIMM_SPD_TYPE, &spd0)) {
1182 		dev_err(host->dev,
1183 			"Failed in i2c read: device=%#x, subaddr=%#x\n",
1184 			PDC_DIMM0_SPD_DEV_ADDRESS, PDC_DIMM_SPD_TYPE);
1185 		return 1;
1186 	}
1187 	if (spd0 == 0x02) {
1188 		data |= (0x01 << 16);
1189 		writel(data, mmio + PDC_SDRAM_CONTROL);
1190 		readl(mmio + PDC_SDRAM_CONTROL);
1191 		dev_err(host->dev, "Local DIMM ECC Enabled\n");
1192 	}
1193 
1194 	/* DIMM Initialization Select/Enable (bit 18/19) */
1195 	data &= (~(1<<18));
1196 	data |= (1<<19);
1197 	writel(data, mmio + PDC_SDRAM_CONTROL);
1198 
1199 	error = 1;
1200 	for (i = 1; i <= 10; i++) {   /* polling ~5 secs */
1201 		data = readl(mmio + PDC_SDRAM_CONTROL);
1202 		if (!(data & (1<<19))) {
1203 			error = 0;
1204 			break;
1205 		}
1206 		msleep(i*100);
1207 	}
1208 	return error;
1209 }
1210 
1211 
1212 static unsigned int pdc20621_dimm_init(struct ata_host *host)
1213 {
1214 	int speed, size, length;
1215 	u32 addr, spd0, pci_status;
1216 	u32 time_period = 0;
1217 	u32 tcount = 0;
1218 	u32 ticks = 0;
1219 	u32 clock = 0;
1220 	u32 fparam = 0;
1221 	void __iomem *mmio = host->iomap[PDC_MMIO_BAR];
1222 
1223 	/* hard-code chip #0 */
1224 	mmio += PDC_CHIP0_OFS;
1225 
1226 	/* Initialize PLL based upon PCI Bus Frequency */
1227 
1228 	/* Initialize Time Period Register */
1229 	writel(0xffffffff, mmio + PDC_TIME_PERIOD);
1230 	time_period = readl(mmio + PDC_TIME_PERIOD);
1231 	dev_dbg(host->dev, "Time Period Register (0x40): 0x%x\n", time_period);
1232 
1233 	/* Enable timer */
1234 	writel(PDC_TIMER_DEFAULT, mmio + PDC_TIME_CONTROL);
1235 	readl(mmio + PDC_TIME_CONTROL);
1236 
1237 	/* Wait 3 seconds */
1238 	msleep(3000);
1239 
1240 	/*
1241 	   When timer is enabled, counter is decreased every internal
1242 	   clock cycle.
1243 	*/
1244 
1245 	tcount = readl(mmio + PDC_TIME_COUNTER);
1246 	dev_dbg(host->dev, "Time Counter Register (0x44): 0x%x\n", tcount);
1247 
1248 	/*
1249 	   If SX4 is on PCI-X bus, after 3 seconds, the timer counter
1250 	   register should be >= (0xffffffff - 3x10^8).
1251 	*/
1252 	if (tcount >= PCI_X_TCOUNT) {
1253 		ticks = (time_period - tcount);
1254 		dev_dbg(host->dev, "Num counters 0x%x (%d)\n", ticks, ticks);
1255 
1256 		clock = (ticks / 300000);
1257 		dev_dbg(host->dev, "10 * Internal clk = 0x%x (%d)\n",
1258 			clock, clock);
1259 
1260 		clock = (clock * 33);
1261 		dev_dbg(host->dev, "10 * Internal clk * 33 = 0x%x (%d)\n",
1262 			clock, clock);
1263 
1264 		/* PLL F Param (bit 22:16) */
1265 		fparam = (1400000 / clock) - 2;
1266 		dev_dbg(host->dev, "PLL F Param: 0x%x (%d)\n", fparam, fparam);
1267 
1268 		/* OD param = 0x2 (bit 31:30), R param = 0x5 (bit 29:25) */
1269 		pci_status = (0x8a001824 | (fparam << 16));
1270 	} else
1271 		pci_status = PCI_PLL_INIT;
1272 
1273 	/* Initialize PLL. */
1274 	dev_dbg(host->dev, "pci_status: 0x%x\n", pci_status);
1275 	writel(pci_status, mmio + PDC_CTL_STATUS);
1276 	readl(mmio + PDC_CTL_STATUS);
1277 
1278 	/*
1279 	   Read SPD of DIMM by I2C interface,
1280 	   and program the DIMM Module Controller.
1281 	*/
1282 	if (!(speed = pdc20621_detect_dimm(host))) {
1283 		dev_err(host->dev, "Detect Local DIMM Fail\n");
1284 		return 1;	/* DIMM error */
1285 	}
1286 	dev_dbg(host->dev, "Local DIMM Speed = %d\n", speed);
1287 
1288 	/* Programming DIMM0 Module Control Register (index_CID0:80h) */
1289 	size = pdc20621_prog_dimm0(host);
1290 	dev_dbg(host->dev, "Local DIMM Size = %dMB\n", size);
1291 
1292 	/* Programming DIMM Module Global Control Register (index_CID0:88h) */
1293 	if (pdc20621_prog_dimm_global(host)) {
1294 		dev_err(host->dev,
1295 			"Programming DIMM Module Global Control Register Fail\n");
1296 		return 1;
1297 	}
1298 
1299 	if (dimm_test) {
1300 		u8 test_parttern1[40] =
1301 			{0x55,0xAA,'P','r','o','m','i','s','e',' ',
1302 			'N','o','t',' ','Y','e','t',' ',
1303 			'D','e','f','i','n','e','d',' ',
1304 			'1','.','1','0',
1305 			'9','8','0','3','1','6','1','2',0,0};
1306 		u8 test_parttern2[40] = {0};
1307 
1308 		pdc20621_put_to_dimm(host, test_parttern2, 0x10040, 40);
1309 		pdc20621_put_to_dimm(host, test_parttern2, 0x40, 40);
1310 
1311 		pdc20621_put_to_dimm(host, test_parttern1, 0x10040, 40);
1312 		pdc20621_get_from_dimm(host, test_parttern2, 0x40, 40);
1313 		dev_info(host->dev, "DIMM test pattern 1: %x, %x, %s\n", test_parttern2[0],
1314 		       test_parttern2[1], &(test_parttern2[2]));
1315 		pdc20621_get_from_dimm(host, test_parttern2, 0x10040,
1316 				       40);
1317 		dev_info(host->dev, "DIMM test pattern 2: %x, %x, %s\n",
1318 			 test_parttern2[0],
1319 			 test_parttern2[1], &(test_parttern2[2]));
1320 
1321 		pdc20621_put_to_dimm(host, test_parttern1, 0x40, 40);
1322 		pdc20621_get_from_dimm(host, test_parttern2, 0x40, 40);
1323 		dev_info(host->dev, "DIMM test pattern 3: %x, %x, %s\n",
1324 			 test_parttern2[0],
1325 			 test_parttern2[1], &(test_parttern2[2]));
1326 	}
1327 
1328 	/* ECC initiliazation. */
1329 
1330 	if (!pdc20621_i2c_read(host, PDC_DIMM0_SPD_DEV_ADDRESS,
1331 			       PDC_DIMM_SPD_TYPE, &spd0)) {
1332 		dev_err(host->dev,
1333 			"Failed in i2c read: device=%#x, subaddr=%#x\n",
1334 		       PDC_DIMM0_SPD_DEV_ADDRESS, PDC_DIMM_SPD_TYPE);
1335 		return 1;
1336 	}
1337 	if (spd0 == 0x02) {
1338 		void *buf;
1339 		dev_dbg(host->dev, "Start ECC initialization\n");
1340 		addr = 0;
1341 		length = size * 1024 * 1024;
1342 		buf = kzalloc(ECC_ERASE_BUF_SZ, GFP_KERNEL);
1343 		if (!buf)
1344 			return 1;
1345 		while (addr < length) {
1346 			pdc20621_put_to_dimm(host, buf, addr,
1347 					     ECC_ERASE_BUF_SZ);
1348 			addr += ECC_ERASE_BUF_SZ;
1349 		}
1350 		kfree(buf);
1351 		dev_dbg(host->dev, "Finish ECC initialization\n");
1352 	}
1353 	return 0;
1354 }
1355 
1356 
1357 static void pdc_20621_init(struct ata_host *host)
1358 {
1359 	u32 tmp;
1360 	void __iomem *mmio = host->iomap[PDC_MMIO_BAR];
1361 
1362 	/* hard-code chip #0 */
1363 	mmio += PDC_CHIP0_OFS;
1364 
1365 	/*
1366 	 * Select page 0x40 for our 32k DIMM window
1367 	 */
1368 	tmp = readl(mmio + PDC_20621_DIMM_WINDOW) & 0xffff0000;
1369 	tmp |= PDC_PAGE_WINDOW;	/* page 40h; arbitrarily selected */
1370 	writel(tmp, mmio + PDC_20621_DIMM_WINDOW);
1371 
1372 	/*
1373 	 * Reset Host DMA
1374 	 */
1375 	tmp = readl(mmio + PDC_HDMA_CTLSTAT);
1376 	tmp |= PDC_RESET;
1377 	writel(tmp, mmio + PDC_HDMA_CTLSTAT);
1378 	readl(mmio + PDC_HDMA_CTLSTAT);		/* flush */
1379 
1380 	udelay(10);
1381 
1382 	tmp = readl(mmio + PDC_HDMA_CTLSTAT);
1383 	tmp &= ~PDC_RESET;
1384 	writel(tmp, mmio + PDC_HDMA_CTLSTAT);
1385 	readl(mmio + PDC_HDMA_CTLSTAT);		/* flush */
1386 }
1387 
1388 static int pdc_sata_init_one(struct pci_dev *pdev,
1389 			     const struct pci_device_id *ent)
1390 {
1391 	const struct ata_port_info *ppi[] =
1392 		{ &pdc_port_info[ent->driver_data], NULL };
1393 	struct ata_host *host;
1394 	struct pdc_host_priv *hpriv;
1395 	int i, rc;
1396 
1397 	ata_print_version_once(&pdev->dev, DRV_VERSION);
1398 
1399 	/* allocate host */
1400 	host = ata_host_alloc_pinfo(&pdev->dev, ppi, 4);
1401 	hpriv = devm_kzalloc(&pdev->dev, sizeof(*hpriv), GFP_KERNEL);
1402 	if (!host || !hpriv)
1403 		return -ENOMEM;
1404 
1405 	host->private_data = hpriv;
1406 
1407 	/* acquire resources and fill host */
1408 	rc = pcim_enable_device(pdev);
1409 	if (rc)
1410 		return rc;
1411 
1412 	rc = pcim_iomap_regions(pdev, (1 << PDC_MMIO_BAR) | (1 << PDC_DIMM_BAR),
1413 				DRV_NAME);
1414 	if (rc == -EBUSY)
1415 		pcim_pin_device(pdev);
1416 	if (rc)
1417 		return rc;
1418 	host->iomap = pcim_iomap_table(pdev);
1419 
1420 	for (i = 0; i < 4; i++) {
1421 		struct ata_port *ap = host->ports[i];
1422 		void __iomem *base = host->iomap[PDC_MMIO_BAR] + PDC_CHIP0_OFS;
1423 		unsigned int offset = 0x200 + i * 0x80;
1424 
1425 		pdc_sata_setup_port(&ap->ioaddr, base + offset);
1426 
1427 		ata_port_pbar_desc(ap, PDC_MMIO_BAR, -1, "mmio");
1428 		ata_port_pbar_desc(ap, PDC_DIMM_BAR, -1, "dimm");
1429 		ata_port_pbar_desc(ap, PDC_MMIO_BAR, offset, "port");
1430 	}
1431 
1432 	/* configure and activate */
1433 	rc = dma_set_mask_and_coherent(&pdev->dev, ATA_DMA_MASK);
1434 	if (rc)
1435 		return rc;
1436 
1437 	if (pdc20621_dimm_init(host))
1438 		return -ENOMEM;
1439 	pdc_20621_init(host);
1440 
1441 	pci_set_master(pdev);
1442 	return ata_host_activate(host, pdev->irq, pdc20621_interrupt,
1443 				 IRQF_SHARED, &pdc_sata_sht);
1444 }
1445 
1446 module_pci_driver(pdc_sata_pci_driver);
1447 
1448 MODULE_AUTHOR("Jeff Garzik");
1449 MODULE_DESCRIPTION("Promise SATA low-level driver");
1450 MODULE_LICENSE("GPL");
1451 MODULE_DEVICE_TABLE(pci, pdc_sata_pci_tbl);
1452 MODULE_VERSION(DRV_VERSION);
1453