1 // SPDX-License-Identifier: GPL-2.0-or-later 2 /* 3 * drivers/ata/sata_dwc_460ex.c 4 * 5 * Synopsys DesignWare Cores (DWC) SATA host driver 6 * 7 * Author: Mark Miesfeld <mmiesfeld@amcc.com> 8 * 9 * Ported from 2.6.19.2 to 2.6.25/26 by Stefan Roese <sr@denx.de> 10 * Copyright 2008 DENX Software Engineering 11 * 12 * Based on versions provided by AMCC and Synopsys which are: 13 * Copyright 2006 Applied Micro Circuits Corporation 14 * COPYRIGHT (C) 2005 SYNOPSYS, INC. ALL RIGHTS RESERVED 15 */ 16 17 #include <linux/kernel.h> 18 #include <linux/module.h> 19 #include <linux/device.h> 20 #include <linux/dmaengine.h> 21 #include <linux/of.h> 22 #include <linux/of_irq.h> 23 #include <linux/platform_device.h> 24 #include <linux/phy/phy.h> 25 #include <linux/libata.h> 26 #include <linux/slab.h> 27 #include <trace/events/libata.h> 28 29 #include "libata.h" 30 31 #include <scsi/scsi_host.h> 32 #include <scsi/scsi_cmnd.h> 33 34 /* These two are defined in "libata.h" */ 35 #undef DRV_NAME 36 #undef DRV_VERSION 37 38 #define DRV_NAME "sata-dwc" 39 #define DRV_VERSION "1.3" 40 41 #define sata_dwc_writel(a, v) writel_relaxed(v, a) 42 #define sata_dwc_readl(a) readl_relaxed(a) 43 44 #define AHB_DMA_BRST_DFLT 64 /* 16 data items burst length */ 45 46 enum { 47 SATA_DWC_MAX_PORTS = 1, 48 49 SATA_DWC_SCR_OFFSET = 0x24, 50 SATA_DWC_REG_OFFSET = 0x64, 51 }; 52 53 /* DWC SATA Registers */ 54 struct sata_dwc_regs { 55 u32 fptagr; /* 1st party DMA tag */ 56 u32 fpbor; /* 1st party DMA buffer offset */ 57 u32 fptcr; /* 1st party DMA Xfr count */ 58 u32 dmacr; /* DMA Control */ 59 u32 dbtsr; /* DMA Burst Transac size */ 60 u32 intpr; /* Interrupt Pending */ 61 u32 intmr; /* Interrupt Mask */ 62 u32 errmr; /* Error Mask */ 63 u32 llcr; /* Link Layer Control */ 64 u32 phycr; /* PHY Control */ 65 u32 physr; /* PHY Status */ 66 u32 rxbistpd; /* Recvd BIST pattern def register */ 67 u32 rxbistpd1; /* Recvd BIST data dword1 */ 68 u32 rxbistpd2; /* Recvd BIST pattern data dword2 */ 69 u32 txbistpd; /* Trans BIST pattern def register */ 70 u32 txbistpd1; /* Trans BIST data dword1 */ 71 u32 txbistpd2; /* Trans BIST data dword2 */ 72 u32 bistcr; /* BIST Control Register */ 73 u32 bistfctr; /* BIST FIS Count Register */ 74 u32 bistsr; /* BIST Status Register */ 75 u32 bistdecr; /* BIST Dword Error count register */ 76 u32 res[15]; /* Reserved locations */ 77 u32 testr; /* Test Register */ 78 u32 versionr; /* Version Register */ 79 u32 idr; /* ID Register */ 80 u32 unimpl[192]; /* Unimplemented */ 81 u32 dmadr[256]; /* FIFO Locations in DMA Mode */ 82 }; 83 84 enum { 85 SCR_SCONTROL_DET_ENABLE = 0x00000001, 86 SCR_SSTATUS_DET_PRESENT = 0x00000001, 87 SCR_SERROR_DIAG_X = 0x04000000, 88 /* DWC SATA Register Operations */ 89 SATA_DWC_TXFIFO_DEPTH = 0x01FF, 90 SATA_DWC_RXFIFO_DEPTH = 0x01FF, 91 SATA_DWC_DMACR_TMOD_TXCHEN = 0x00000004, 92 SATA_DWC_DMACR_TXCHEN = (0x00000001 | SATA_DWC_DMACR_TMOD_TXCHEN), 93 SATA_DWC_DMACR_RXCHEN = (0x00000002 | SATA_DWC_DMACR_TMOD_TXCHEN), 94 SATA_DWC_DMACR_TXRXCH_CLEAR = SATA_DWC_DMACR_TMOD_TXCHEN, 95 SATA_DWC_INTPR_DMAT = 0x00000001, 96 SATA_DWC_INTPR_NEWFP = 0x00000002, 97 SATA_DWC_INTPR_PMABRT = 0x00000004, 98 SATA_DWC_INTPR_ERR = 0x00000008, 99 SATA_DWC_INTPR_NEWBIST = 0x00000010, 100 SATA_DWC_INTPR_IPF = 0x10000000, 101 SATA_DWC_INTMR_DMATM = 0x00000001, 102 SATA_DWC_INTMR_NEWFPM = 0x00000002, 103 SATA_DWC_INTMR_PMABRTM = 0x00000004, 104 SATA_DWC_INTMR_ERRM = 0x00000008, 105 SATA_DWC_INTMR_NEWBISTM = 0x00000010, 106 SATA_DWC_LLCR_SCRAMEN = 0x00000001, 107 SATA_DWC_LLCR_DESCRAMEN = 0x00000002, 108 SATA_DWC_LLCR_RPDEN = 0x00000004, 109 /* This is all error bits, zero's are reserved fields. */ 110 SATA_DWC_SERROR_ERR_BITS = 0x0FFF0F03 111 }; 112 113 #define SATA_DWC_SCR0_SPD_GET(v) (((v) >> 4) & 0x0000000F) 114 #define SATA_DWC_DMACR_TX_CLEAR(v) (((v) & ~SATA_DWC_DMACR_TXCHEN) |\ 115 SATA_DWC_DMACR_TMOD_TXCHEN) 116 #define SATA_DWC_DMACR_RX_CLEAR(v) (((v) & ~SATA_DWC_DMACR_RXCHEN) |\ 117 SATA_DWC_DMACR_TMOD_TXCHEN) 118 #define SATA_DWC_DBTSR_MWR(size) (((size)/4) & SATA_DWC_TXFIFO_DEPTH) 119 #define SATA_DWC_DBTSR_MRD(size) ((((size)/4) & SATA_DWC_RXFIFO_DEPTH)\ 120 << 16) 121 struct sata_dwc_device { 122 struct device *dev; /* generic device struct */ 123 struct ata_probe_ent *pe; /* ptr to probe-ent */ 124 struct ata_host *host; 125 struct sata_dwc_regs __iomem *sata_dwc_regs; /* DW SATA specific */ 126 u32 sactive_issued; 127 u32 sactive_queued; 128 struct phy *phy; 129 phys_addr_t dmadr; 130 #ifdef CONFIG_SATA_DWC_OLD_DMA 131 struct dw_dma_chip *dma; 132 #endif 133 }; 134 135 /* 136 * Allow one extra special slot for commands and DMA management 137 * to account for libata internal commands. 138 */ 139 #define SATA_DWC_QCMD_MAX (ATA_MAX_QUEUE + 1) 140 141 struct sata_dwc_device_port { 142 struct sata_dwc_device *hsdev; 143 int cmd_issued[SATA_DWC_QCMD_MAX]; 144 int dma_pending[SATA_DWC_QCMD_MAX]; 145 146 /* DMA info */ 147 struct dma_chan *chan; 148 struct dma_async_tx_descriptor *desc[SATA_DWC_QCMD_MAX]; 149 u32 dma_interrupt_count; 150 }; 151 152 /* 153 * Commonly used DWC SATA driver macros 154 */ 155 #define HSDEV_FROM_HOST(host) ((struct sata_dwc_device *)(host)->private_data) 156 #define HSDEV_FROM_AP(ap) ((struct sata_dwc_device *)(ap)->host->private_data) 157 #define HSDEVP_FROM_AP(ap) ((struct sata_dwc_device_port *)(ap)->private_data) 158 #define HSDEV_FROM_QC(qc) ((struct sata_dwc_device *)(qc)->ap->host->private_data) 159 #define HSDEV_FROM_HSDEVP(p) ((struct sata_dwc_device *)(p)->hsdev) 160 161 enum { 162 SATA_DWC_CMD_ISSUED_NOT = 0, 163 SATA_DWC_CMD_ISSUED_PEND = 1, 164 SATA_DWC_CMD_ISSUED_EXEC = 2, 165 SATA_DWC_CMD_ISSUED_NODATA = 3, 166 167 SATA_DWC_DMA_PENDING_NONE = 0, 168 SATA_DWC_DMA_PENDING_TX = 1, 169 SATA_DWC_DMA_PENDING_RX = 2, 170 }; 171 172 /* 173 * Prototypes 174 */ 175 static void sata_dwc_bmdma_start_by_tag(struct ata_queued_cmd *qc, u8 tag); 176 static int sata_dwc_qc_complete(struct ata_port *ap, struct ata_queued_cmd *qc); 177 static void sata_dwc_dma_xfer_complete(struct ata_port *ap); 178 static void sata_dwc_clear_dmacr(struct sata_dwc_device_port *hsdevp, u8 tag); 179 180 #ifdef CONFIG_SATA_DWC_OLD_DMA 181 182 #include <linux/platform_data/dma-dw.h> 183 #include <linux/dma/dw.h> 184 185 static struct dw_dma_slave sata_dwc_dma_dws = { 186 .src_id = 0, 187 .dst_id = 0, 188 .m_master = 1, 189 .p_master = 0, 190 }; 191 192 static bool sata_dwc_dma_filter(struct dma_chan *chan, void *param) 193 { 194 struct dw_dma_slave *dws = &sata_dwc_dma_dws; 195 196 if (dws->dma_dev != chan->device->dev) 197 return false; 198 199 chan->private = dws; 200 return true; 201 } 202 203 static int sata_dwc_dma_get_channel_old(struct sata_dwc_device_port *hsdevp) 204 { 205 struct sata_dwc_device *hsdev = hsdevp->hsdev; 206 struct dw_dma_slave *dws = &sata_dwc_dma_dws; 207 struct device *dev = hsdev->dev; 208 dma_cap_mask_t mask; 209 210 dws->dma_dev = dev; 211 212 dma_cap_zero(mask); 213 dma_cap_set(DMA_SLAVE, mask); 214 215 /* Acquire DMA channel */ 216 hsdevp->chan = dma_request_channel(mask, sata_dwc_dma_filter, hsdevp); 217 if (!hsdevp->chan) { 218 dev_err(dev, "%s: dma channel unavailable\n", __func__); 219 return -EAGAIN; 220 } 221 222 return 0; 223 } 224 225 static int sata_dwc_dma_init_old(struct platform_device *pdev, 226 struct sata_dwc_device *hsdev) 227 { 228 struct device *dev = &pdev->dev; 229 struct device_node *np = dev->of_node; 230 231 hsdev->dma = devm_kzalloc(dev, sizeof(*hsdev->dma), GFP_KERNEL); 232 if (!hsdev->dma) 233 return -ENOMEM; 234 235 hsdev->dma->dev = dev; 236 hsdev->dma->id = pdev->id; 237 238 /* Get SATA DMA interrupt number */ 239 hsdev->dma->irq = irq_of_parse_and_map(np, 1); 240 if (!hsdev->dma->irq) { 241 dev_err(dev, "no SATA DMA irq\n"); 242 return -ENODEV; 243 } 244 245 /* Get physical SATA DMA register base address */ 246 hsdev->dma->regs = devm_platform_ioremap_resource(pdev, 1); 247 if (IS_ERR(hsdev->dma->regs)) 248 return PTR_ERR(hsdev->dma->regs); 249 250 /* Initialize AHB DMAC */ 251 return dw_dma_probe(hsdev->dma); 252 } 253 254 static void sata_dwc_dma_exit_old(struct sata_dwc_device *hsdev) 255 { 256 if (!hsdev->dma) 257 return; 258 259 dw_dma_remove(hsdev->dma); 260 } 261 262 #endif 263 264 static const char *get_prot_descript(u8 protocol) 265 { 266 switch (protocol) { 267 case ATA_PROT_NODATA: 268 return "ATA no data"; 269 case ATA_PROT_PIO: 270 return "ATA PIO"; 271 case ATA_PROT_DMA: 272 return "ATA DMA"; 273 case ATA_PROT_NCQ: 274 return "ATA NCQ"; 275 case ATA_PROT_NCQ_NODATA: 276 return "ATA NCQ no data"; 277 case ATAPI_PROT_NODATA: 278 return "ATAPI no data"; 279 case ATAPI_PROT_PIO: 280 return "ATAPI PIO"; 281 case ATAPI_PROT_DMA: 282 return "ATAPI DMA"; 283 default: 284 return "unknown"; 285 } 286 } 287 288 static void dma_dwc_xfer_done(void *hsdev_instance) 289 { 290 unsigned long flags; 291 struct sata_dwc_device *hsdev = hsdev_instance; 292 struct ata_host *host = (struct ata_host *)hsdev->host; 293 struct ata_port *ap; 294 struct sata_dwc_device_port *hsdevp; 295 u8 tag = 0; 296 unsigned int port = 0; 297 298 spin_lock_irqsave(&host->lock, flags); 299 ap = host->ports[port]; 300 hsdevp = HSDEVP_FROM_AP(ap); 301 tag = ap->link.active_tag; 302 303 /* 304 * Each DMA command produces 2 interrupts. Only 305 * complete the command after both interrupts have been 306 * seen. (See sata_dwc_isr()) 307 */ 308 hsdevp->dma_interrupt_count++; 309 sata_dwc_clear_dmacr(hsdevp, tag); 310 311 if (hsdevp->dma_pending[tag] == SATA_DWC_DMA_PENDING_NONE) { 312 dev_err(ap->dev, "DMA not pending tag=0x%02x pending=%d\n", 313 tag, hsdevp->dma_pending[tag]); 314 } 315 316 if ((hsdevp->dma_interrupt_count % 2) == 0) 317 sata_dwc_dma_xfer_complete(ap); 318 319 spin_unlock_irqrestore(&host->lock, flags); 320 } 321 322 static struct dma_async_tx_descriptor *dma_dwc_xfer_setup(struct ata_queued_cmd *qc) 323 { 324 struct ata_port *ap = qc->ap; 325 struct sata_dwc_device_port *hsdevp = HSDEVP_FROM_AP(ap); 326 struct sata_dwc_device *hsdev = HSDEV_FROM_AP(ap); 327 struct dma_slave_config sconf; 328 struct dma_async_tx_descriptor *desc; 329 330 if (qc->dma_dir == DMA_DEV_TO_MEM) { 331 sconf.src_addr = hsdev->dmadr; 332 sconf.device_fc = false; 333 } else { /* DMA_MEM_TO_DEV */ 334 sconf.dst_addr = hsdev->dmadr; 335 sconf.device_fc = false; 336 } 337 338 sconf.direction = qc->dma_dir; 339 sconf.src_maxburst = AHB_DMA_BRST_DFLT / 4; /* in items */ 340 sconf.dst_maxburst = AHB_DMA_BRST_DFLT / 4; /* in items */ 341 sconf.src_addr_width = DMA_SLAVE_BUSWIDTH_4_BYTES; 342 sconf.dst_addr_width = DMA_SLAVE_BUSWIDTH_4_BYTES; 343 344 dmaengine_slave_config(hsdevp->chan, &sconf); 345 346 /* Convert SG list to linked list of items (LLIs) for AHB DMA */ 347 desc = dmaengine_prep_slave_sg(hsdevp->chan, qc->sg, qc->n_elem, 348 qc->dma_dir, 349 DMA_PREP_INTERRUPT | DMA_CTRL_ACK); 350 351 if (!desc) 352 return NULL; 353 354 desc->callback = dma_dwc_xfer_done; 355 desc->callback_param = hsdev; 356 357 dev_dbg(hsdev->dev, "%s sg: 0x%p, count: %d addr: %pa\n", __func__, 358 qc->sg, qc->n_elem, &hsdev->dmadr); 359 360 return desc; 361 } 362 363 static int sata_dwc_scr_read(struct ata_link *link, unsigned int scr, u32 *val) 364 { 365 if (scr > SCR_NOTIFICATION) { 366 dev_err(link->ap->dev, "%s: Incorrect SCR offset 0x%02x\n", 367 __func__, scr); 368 return -EINVAL; 369 } 370 371 *val = sata_dwc_readl(link->ap->ioaddr.scr_addr + (scr * 4)); 372 dev_dbg(link->ap->dev, "%s: id=%d reg=%d val=0x%08x\n", __func__, 373 link->ap->print_id, scr, *val); 374 375 return 0; 376 } 377 378 static int sata_dwc_scr_write(struct ata_link *link, unsigned int scr, u32 val) 379 { 380 dev_dbg(link->ap->dev, "%s: id=%d reg=%d val=0x%08x\n", __func__, 381 link->ap->print_id, scr, val); 382 if (scr > SCR_NOTIFICATION) { 383 dev_err(link->ap->dev, "%s: Incorrect SCR offset 0x%02x\n", 384 __func__, scr); 385 return -EINVAL; 386 } 387 sata_dwc_writel(link->ap->ioaddr.scr_addr + (scr * 4), val); 388 389 return 0; 390 } 391 392 static void clear_serror(struct ata_port *ap) 393 { 394 u32 val; 395 sata_dwc_scr_read(&ap->link, SCR_ERROR, &val); 396 sata_dwc_scr_write(&ap->link, SCR_ERROR, val); 397 } 398 399 static void clear_interrupt_bit(struct sata_dwc_device *hsdev, u32 bit) 400 { 401 sata_dwc_writel(&hsdev->sata_dwc_regs->intpr, 402 sata_dwc_readl(&hsdev->sata_dwc_regs->intpr)); 403 } 404 405 static u32 qcmd_tag_to_mask(u8 tag) 406 { 407 return 0x00000001 << (tag & 0x1f); 408 } 409 410 /* See ahci.c */ 411 static void sata_dwc_error_intr(struct ata_port *ap, 412 struct sata_dwc_device *hsdev, uint intpr) 413 { 414 struct sata_dwc_device_port *hsdevp = HSDEVP_FROM_AP(ap); 415 struct ata_eh_info *ehi = &ap->link.eh_info; 416 unsigned int err_mask = 0, action = 0; 417 struct ata_queued_cmd *qc; 418 u32 serror; 419 u8 status, tag; 420 421 ata_ehi_clear_desc(ehi); 422 423 sata_dwc_scr_read(&ap->link, SCR_ERROR, &serror); 424 status = ap->ops->sff_check_status(ap); 425 426 tag = ap->link.active_tag; 427 428 dev_err(ap->dev, 429 "%s SCR_ERROR=0x%08x intpr=0x%08x status=0x%08x dma_intp=%d pending=%d issued=%d", 430 __func__, serror, intpr, status, hsdevp->dma_interrupt_count, 431 hsdevp->dma_pending[tag], hsdevp->cmd_issued[tag]); 432 433 /* Clear error register and interrupt bit */ 434 clear_serror(ap); 435 clear_interrupt_bit(hsdev, SATA_DWC_INTPR_ERR); 436 437 /* This is the only error happening now. TODO check for exact error */ 438 439 err_mask |= AC_ERR_HOST_BUS; 440 action |= ATA_EH_RESET; 441 442 /* Pass this on to EH */ 443 ehi->serror |= serror; 444 ehi->action |= action; 445 446 qc = ata_qc_from_tag(ap, tag); 447 if (qc) 448 qc->err_mask |= err_mask; 449 else 450 ehi->err_mask |= err_mask; 451 452 ata_port_abort(ap); 453 } 454 455 /* 456 * Function : sata_dwc_isr 457 * arguments : irq, void *dev_instance, struct pt_regs *regs 458 * Return value : irqreturn_t - status of IRQ 459 * This Interrupt handler called via port ops registered function. 460 * .irq_handler = sata_dwc_isr 461 */ 462 static irqreturn_t sata_dwc_isr(int irq, void *dev_instance) 463 { 464 struct ata_host *host = (struct ata_host *)dev_instance; 465 struct sata_dwc_device *hsdev = HSDEV_FROM_HOST(host); 466 struct ata_port *ap; 467 struct ata_queued_cmd *qc; 468 unsigned long flags; 469 u8 status, tag; 470 int handled, port = 0; 471 uint intpr, sactive, sactive2, tag_mask; 472 struct sata_dwc_device_port *hsdevp; 473 hsdev->sactive_issued = 0; 474 475 spin_lock_irqsave(&host->lock, flags); 476 477 /* Read the interrupt register */ 478 intpr = sata_dwc_readl(&hsdev->sata_dwc_regs->intpr); 479 480 ap = host->ports[port]; 481 hsdevp = HSDEVP_FROM_AP(ap); 482 483 dev_dbg(ap->dev, "%s intpr=0x%08x active_tag=%d\n", __func__, intpr, 484 ap->link.active_tag); 485 486 /* Check for error interrupt */ 487 if (intpr & SATA_DWC_INTPR_ERR) { 488 sata_dwc_error_intr(ap, hsdev, intpr); 489 handled = 1; 490 goto DONE; 491 } 492 493 /* Check for DMA SETUP FIS (FP DMA) interrupt */ 494 if (intpr & SATA_DWC_INTPR_NEWFP) { 495 clear_interrupt_bit(hsdev, SATA_DWC_INTPR_NEWFP); 496 497 tag = (u8)(sata_dwc_readl(&hsdev->sata_dwc_regs->fptagr)); 498 dev_dbg(ap->dev, "%s: NEWFP tag=%d\n", __func__, tag); 499 if (hsdevp->cmd_issued[tag] != SATA_DWC_CMD_ISSUED_PEND) 500 dev_warn(ap->dev, "CMD tag=%d not pending?\n", tag); 501 502 hsdev->sactive_issued |= qcmd_tag_to_mask(tag); 503 504 qc = ata_qc_from_tag(ap, tag); 505 if (unlikely(!qc)) { 506 dev_err(ap->dev, "failed to get qc"); 507 handled = 1; 508 goto DONE; 509 } 510 /* 511 * Start FP DMA for NCQ command. At this point the tag is the 512 * active tag. It is the tag that matches the command about to 513 * be completed. 514 */ 515 trace_ata_bmdma_start(ap, &qc->tf, tag); 516 qc->ap->link.active_tag = tag; 517 sata_dwc_bmdma_start_by_tag(qc, tag); 518 519 handled = 1; 520 goto DONE; 521 } 522 sata_dwc_scr_read(&ap->link, SCR_ACTIVE, &sactive); 523 tag_mask = (hsdev->sactive_issued | sactive) ^ sactive; 524 525 /* If no sactive issued and tag_mask is zero then this is not NCQ */ 526 if (hsdev->sactive_issued == 0 && tag_mask == 0) { 527 if (ap->link.active_tag == ATA_TAG_POISON) 528 tag = 0; 529 else 530 tag = ap->link.active_tag; 531 qc = ata_qc_from_tag(ap, tag); 532 533 /* DEV interrupt w/ no active qc? */ 534 if (unlikely(!qc || (qc->tf.flags & ATA_TFLAG_POLLING))) { 535 dev_err(ap->dev, 536 "%s interrupt with no active qc qc=%p\n", 537 __func__, qc); 538 ap->ops->sff_check_status(ap); 539 handled = 1; 540 goto DONE; 541 } 542 status = ap->ops->sff_check_status(ap); 543 544 qc->ap->link.active_tag = tag; 545 hsdevp->cmd_issued[tag] = SATA_DWC_CMD_ISSUED_NOT; 546 547 if (status & ATA_ERR) { 548 dev_dbg(ap->dev, "interrupt ATA_ERR (0x%x)\n", status); 549 sata_dwc_qc_complete(ap, qc); 550 handled = 1; 551 goto DONE; 552 } 553 554 dev_dbg(ap->dev, "%s non-NCQ cmd interrupt, protocol: %s\n", 555 __func__, get_prot_descript(qc->tf.protocol)); 556 DRVSTILLBUSY: 557 if (ata_is_dma(qc->tf.protocol)) { 558 /* 559 * Each DMA transaction produces 2 interrupts. The DMAC 560 * transfer complete interrupt and the SATA controller 561 * operation done interrupt. The command should be 562 * completed only after both interrupts are seen. 563 */ 564 hsdevp->dma_interrupt_count++; 565 if (hsdevp->dma_pending[tag] == \ 566 SATA_DWC_DMA_PENDING_NONE) { 567 dev_err(ap->dev, 568 "%s: DMA not pending intpr=0x%08x status=0x%08x pending=%d\n", 569 __func__, intpr, status, 570 hsdevp->dma_pending[tag]); 571 } 572 573 if ((hsdevp->dma_interrupt_count % 2) == 0) 574 sata_dwc_dma_xfer_complete(ap); 575 } else if (ata_is_pio(qc->tf.protocol)) { 576 ata_sff_hsm_move(ap, qc, status, 0); 577 handled = 1; 578 goto DONE; 579 } else { 580 if (unlikely(sata_dwc_qc_complete(ap, qc))) 581 goto DRVSTILLBUSY; 582 } 583 584 handled = 1; 585 goto DONE; 586 } 587 588 /* 589 * This is a NCQ command. At this point we need to figure out for which 590 * tags we have gotten a completion interrupt. One interrupt may serve 591 * as completion for more than one operation when commands are queued 592 * (NCQ). We need to process each completed command. 593 */ 594 595 /* process completed commands */ 596 sata_dwc_scr_read(&ap->link, SCR_ACTIVE, &sactive); 597 tag_mask = (hsdev->sactive_issued | sactive) ^ sactive; 598 599 if (sactive != 0 || hsdev->sactive_issued > 1 || tag_mask > 1) { 600 dev_dbg(ap->dev, 601 "%s NCQ:sactive=0x%08x sactive_issued=0x%08x tag_mask=0x%08x\n", 602 __func__, sactive, hsdev->sactive_issued, tag_mask); 603 } 604 605 if ((tag_mask | hsdev->sactive_issued) != hsdev->sactive_issued) { 606 dev_warn(ap->dev, 607 "Bad tag mask? sactive=0x%08x sactive_issued=0x%08x tag_mask=0x%08x\n", 608 sactive, hsdev->sactive_issued, tag_mask); 609 } 610 611 /* read just to clear ... not bad if currently still busy */ 612 status = ap->ops->sff_check_status(ap); 613 dev_dbg(ap->dev, "%s ATA status register=0x%x\n", __func__, status); 614 615 tag = 0; 616 while (tag_mask) { 617 while (!(tag_mask & 0x00000001)) { 618 tag++; 619 tag_mask <<= 1; 620 } 621 622 tag_mask &= (~0x00000001); 623 qc = ata_qc_from_tag(ap, tag); 624 if (unlikely(!qc)) { 625 dev_err(ap->dev, "failed to get qc"); 626 handled = 1; 627 goto DONE; 628 } 629 630 /* To be picked up by completion functions */ 631 qc->ap->link.active_tag = tag; 632 hsdevp->cmd_issued[tag] = SATA_DWC_CMD_ISSUED_NOT; 633 634 /* Let libata/scsi layers handle error */ 635 if (status & ATA_ERR) { 636 dev_dbg(ap->dev, "%s ATA_ERR (0x%x)\n", __func__, 637 status); 638 sata_dwc_qc_complete(ap, qc); 639 handled = 1; 640 goto DONE; 641 } 642 643 /* Process completed command */ 644 dev_dbg(ap->dev, "%s NCQ command, protocol: %s\n", __func__, 645 get_prot_descript(qc->tf.protocol)); 646 if (ata_is_dma(qc->tf.protocol)) { 647 hsdevp->dma_interrupt_count++; 648 if (hsdevp->dma_pending[tag] == \ 649 SATA_DWC_DMA_PENDING_NONE) 650 dev_warn(ap->dev, "%s: DMA not pending?\n", 651 __func__); 652 if ((hsdevp->dma_interrupt_count % 2) == 0) 653 sata_dwc_dma_xfer_complete(ap); 654 } else { 655 if (unlikely(sata_dwc_qc_complete(ap, qc))) 656 goto STILLBUSY; 657 } 658 continue; 659 660 STILLBUSY: 661 ap->stats.idle_irq++; 662 dev_warn(ap->dev, "STILL BUSY IRQ ata%d: irq trap\n", 663 ap->print_id); 664 } /* while tag_mask */ 665 666 /* 667 * Check to see if any commands completed while we were processing our 668 * initial set of completed commands (read status clears interrupts, 669 * so we might miss a completed command interrupt if one came in while 670 * we were processing --we read status as part of processing a completed 671 * command). 672 */ 673 sata_dwc_scr_read(&ap->link, SCR_ACTIVE, &sactive2); 674 if (sactive2 != sactive) { 675 dev_dbg(ap->dev, 676 "More completed - sactive=0x%x sactive2=0x%x\n", 677 sactive, sactive2); 678 } 679 handled = 1; 680 681 DONE: 682 spin_unlock_irqrestore(&host->lock, flags); 683 return IRQ_RETVAL(handled); 684 } 685 686 static void sata_dwc_clear_dmacr(struct sata_dwc_device_port *hsdevp, u8 tag) 687 { 688 struct sata_dwc_device *hsdev = HSDEV_FROM_HSDEVP(hsdevp); 689 u32 dmacr = sata_dwc_readl(&hsdev->sata_dwc_regs->dmacr); 690 691 if (hsdevp->dma_pending[tag] == SATA_DWC_DMA_PENDING_RX) { 692 dmacr = SATA_DWC_DMACR_RX_CLEAR(dmacr); 693 sata_dwc_writel(&hsdev->sata_dwc_regs->dmacr, dmacr); 694 } else if (hsdevp->dma_pending[tag] == SATA_DWC_DMA_PENDING_TX) { 695 dmacr = SATA_DWC_DMACR_TX_CLEAR(dmacr); 696 sata_dwc_writel(&hsdev->sata_dwc_regs->dmacr, dmacr); 697 } else { 698 /* 699 * This should not happen, it indicates the driver is out of 700 * sync. If it does happen, clear dmacr anyway. 701 */ 702 dev_err(hsdev->dev, 703 "%s DMA protocol RX and TX DMA not pending tag=0x%02x pending=%d dmacr: 0x%08x\n", 704 __func__, tag, hsdevp->dma_pending[tag], dmacr); 705 sata_dwc_writel(&hsdev->sata_dwc_regs->dmacr, 706 SATA_DWC_DMACR_TXRXCH_CLEAR); 707 } 708 } 709 710 static void sata_dwc_dma_xfer_complete(struct ata_port *ap) 711 { 712 struct ata_queued_cmd *qc; 713 struct sata_dwc_device_port *hsdevp = HSDEVP_FROM_AP(ap); 714 struct sata_dwc_device *hsdev = HSDEV_FROM_AP(ap); 715 u8 tag = 0; 716 717 tag = ap->link.active_tag; 718 qc = ata_qc_from_tag(ap, tag); 719 if (!qc) { 720 dev_err(ap->dev, "failed to get qc"); 721 return; 722 } 723 724 if (ata_is_dma(qc->tf.protocol)) { 725 if (hsdevp->dma_pending[tag] == SATA_DWC_DMA_PENDING_NONE) { 726 dev_err(ap->dev, 727 "%s DMA protocol RX and TX DMA not pending dmacr: 0x%08x\n", 728 __func__, 729 sata_dwc_readl(&hsdev->sata_dwc_regs->dmacr)); 730 } 731 732 hsdevp->dma_pending[tag] = SATA_DWC_DMA_PENDING_NONE; 733 sata_dwc_qc_complete(ap, qc); 734 ap->link.active_tag = ATA_TAG_POISON; 735 } else { 736 sata_dwc_qc_complete(ap, qc); 737 } 738 } 739 740 static int sata_dwc_qc_complete(struct ata_port *ap, struct ata_queued_cmd *qc) 741 { 742 u8 status = 0; 743 u32 mask = 0x0; 744 u8 tag = qc->hw_tag; 745 struct sata_dwc_device *hsdev = HSDEV_FROM_AP(ap); 746 struct sata_dwc_device_port *hsdevp = HSDEVP_FROM_AP(ap); 747 hsdev->sactive_queued = 0; 748 749 if (hsdevp->dma_pending[tag] == SATA_DWC_DMA_PENDING_TX) 750 dev_err(ap->dev, "TX DMA PENDING\n"); 751 else if (hsdevp->dma_pending[tag] == SATA_DWC_DMA_PENDING_RX) 752 dev_err(ap->dev, "RX DMA PENDING\n"); 753 dev_dbg(ap->dev, 754 "QC complete cmd=0x%02x status=0x%02x ata%u: protocol=%d\n", 755 qc->tf.command, status, ap->print_id, qc->tf.protocol); 756 757 /* clear active bit */ 758 mask = (~(qcmd_tag_to_mask(tag))); 759 hsdev->sactive_queued = hsdev->sactive_queued & mask; 760 hsdev->sactive_issued = hsdev->sactive_issued & mask; 761 ata_qc_complete(qc); 762 return 0; 763 } 764 765 static void sata_dwc_enable_interrupts(struct sata_dwc_device *hsdev) 766 { 767 /* Enable selective interrupts by setting the interrupt maskregister*/ 768 sata_dwc_writel(&hsdev->sata_dwc_regs->intmr, 769 SATA_DWC_INTMR_ERRM | 770 SATA_DWC_INTMR_NEWFPM | 771 SATA_DWC_INTMR_PMABRTM | 772 SATA_DWC_INTMR_DMATM); 773 /* 774 * Unmask the error bits that should trigger an error interrupt by 775 * setting the error mask register. 776 */ 777 sata_dwc_writel(&hsdev->sata_dwc_regs->errmr, SATA_DWC_SERROR_ERR_BITS); 778 779 dev_dbg(hsdev->dev, "%s: INTMR = 0x%08x, ERRMR = 0x%08x\n", 780 __func__, sata_dwc_readl(&hsdev->sata_dwc_regs->intmr), 781 sata_dwc_readl(&hsdev->sata_dwc_regs->errmr)); 782 } 783 784 static void sata_dwc_setup_port(struct ata_ioports *port, void __iomem *base) 785 { 786 port->cmd_addr = base + 0x00; 787 port->data_addr = base + 0x00; 788 789 port->error_addr = base + 0x04; 790 port->feature_addr = base + 0x04; 791 792 port->nsect_addr = base + 0x08; 793 794 port->lbal_addr = base + 0x0c; 795 port->lbam_addr = base + 0x10; 796 port->lbah_addr = base + 0x14; 797 798 port->device_addr = base + 0x18; 799 port->command_addr = base + 0x1c; 800 port->status_addr = base + 0x1c; 801 802 port->altstatus_addr = base + 0x20; 803 port->ctl_addr = base + 0x20; 804 } 805 806 static int sata_dwc_dma_get_channel(struct sata_dwc_device_port *hsdevp) 807 { 808 struct sata_dwc_device *hsdev = hsdevp->hsdev; 809 struct device *dev = hsdev->dev; 810 811 #ifdef CONFIG_SATA_DWC_OLD_DMA 812 if (!of_property_present(dev->of_node, "dmas")) 813 return sata_dwc_dma_get_channel_old(hsdevp); 814 #endif 815 816 hsdevp->chan = dma_request_chan(dev, "sata-dma"); 817 if (IS_ERR(hsdevp->chan)) { 818 dev_err(dev, "failed to allocate dma channel: %ld\n", 819 PTR_ERR(hsdevp->chan)); 820 return PTR_ERR(hsdevp->chan); 821 } 822 823 return 0; 824 } 825 826 /* 827 * Function : sata_dwc_port_start 828 * arguments : struct ata_ioports *port 829 * Return value : returns 0 if success, error code otherwise 830 * This function allocates the scatter gather LLI table for AHB DMA 831 */ 832 static int sata_dwc_port_start(struct ata_port *ap) 833 { 834 int err = 0; 835 struct sata_dwc_device *hsdev; 836 struct sata_dwc_device_port *hsdevp = NULL; 837 struct device *pdev; 838 int i; 839 840 hsdev = HSDEV_FROM_AP(ap); 841 842 dev_dbg(ap->dev, "%s: port_no=%d\n", __func__, ap->port_no); 843 844 hsdev->host = ap->host; 845 pdev = ap->host->dev; 846 if (!pdev) { 847 dev_err(ap->dev, "%s: no ap->host->dev\n", __func__); 848 err = -ENODEV; 849 goto CLEANUP; 850 } 851 852 /* Allocate Port Struct */ 853 hsdevp = kzalloc(sizeof(*hsdevp), GFP_KERNEL); 854 if (!hsdevp) { 855 err = -ENOMEM; 856 goto CLEANUP; 857 } 858 hsdevp->hsdev = hsdev; 859 860 err = sata_dwc_dma_get_channel(hsdevp); 861 if (err) 862 goto CLEANUP_ALLOC; 863 864 err = phy_power_on(hsdev->phy); 865 if (err) 866 goto CLEANUP_ALLOC; 867 868 for (i = 0; i < SATA_DWC_QCMD_MAX; i++) 869 hsdevp->cmd_issued[i] = SATA_DWC_CMD_ISSUED_NOT; 870 871 ap->bmdma_prd = NULL; /* set these so libata doesn't use them */ 872 ap->bmdma_prd_dma = 0; 873 874 if (ap->port_no == 0) { 875 dev_dbg(ap->dev, "%s: clearing TXCHEN, RXCHEN in DMAC\n", 876 __func__); 877 sata_dwc_writel(&hsdev->sata_dwc_regs->dmacr, 878 SATA_DWC_DMACR_TXRXCH_CLEAR); 879 880 dev_dbg(ap->dev, "%s: setting burst size in DBTSR\n", 881 __func__); 882 sata_dwc_writel(&hsdev->sata_dwc_regs->dbtsr, 883 (SATA_DWC_DBTSR_MWR(AHB_DMA_BRST_DFLT) | 884 SATA_DWC_DBTSR_MRD(AHB_DMA_BRST_DFLT))); 885 } 886 887 /* Clear any error bits before libata starts issuing commands */ 888 clear_serror(ap); 889 ap->private_data = hsdevp; 890 dev_dbg(ap->dev, "%s: done\n", __func__); 891 return 0; 892 893 CLEANUP_ALLOC: 894 kfree(hsdevp); 895 CLEANUP: 896 dev_dbg(ap->dev, "%s: fail. ap->id = %d\n", __func__, ap->print_id); 897 return err; 898 } 899 900 static void sata_dwc_port_stop(struct ata_port *ap) 901 { 902 struct sata_dwc_device_port *hsdevp = HSDEVP_FROM_AP(ap); 903 struct sata_dwc_device *hsdev = HSDEV_FROM_AP(ap); 904 905 dev_dbg(ap->dev, "%s: ap->id = %d\n", __func__, ap->print_id); 906 907 dmaengine_terminate_sync(hsdevp->chan); 908 dma_release_channel(hsdevp->chan); 909 phy_power_off(hsdev->phy); 910 911 kfree(hsdevp); 912 ap->private_data = NULL; 913 } 914 915 /* 916 * Function : sata_dwc_exec_command_by_tag 917 * arguments : ata_port *ap, ata_taskfile *tf, u8 tag, u32 cmd_issued 918 * Return value : None 919 * This function keeps track of individual command tag ids and calls 920 * ata_exec_command in libata 921 */ 922 static void sata_dwc_exec_command_by_tag(struct ata_port *ap, 923 struct ata_taskfile *tf, 924 u8 tag, u32 cmd_issued) 925 { 926 struct sata_dwc_device_port *hsdevp = HSDEVP_FROM_AP(ap); 927 928 hsdevp->cmd_issued[tag] = cmd_issued; 929 930 /* 931 * Clear SError before executing a new command. 932 * sata_dwc_scr_write and read can not be used here. Clearing the PM 933 * managed SError register for the disk needs to be done before the 934 * task file is loaded. 935 */ 936 clear_serror(ap); 937 ata_sff_exec_command(ap, tf); 938 } 939 940 static void sata_dwc_bmdma_setup_by_tag(struct ata_queued_cmd *qc, u8 tag) 941 { 942 sata_dwc_exec_command_by_tag(qc->ap, &qc->tf, tag, 943 SATA_DWC_CMD_ISSUED_PEND); 944 } 945 946 static void sata_dwc_bmdma_setup(struct ata_queued_cmd *qc) 947 { 948 u8 tag = qc->hw_tag; 949 950 if (!ata_is_ncq(qc->tf.protocol)) 951 tag = 0; 952 953 sata_dwc_bmdma_setup_by_tag(qc, tag); 954 } 955 956 static void sata_dwc_bmdma_start_by_tag(struct ata_queued_cmd *qc, u8 tag) 957 { 958 int start_dma; 959 u32 reg; 960 struct sata_dwc_device *hsdev = HSDEV_FROM_QC(qc); 961 struct ata_port *ap = qc->ap; 962 struct sata_dwc_device_port *hsdevp = HSDEVP_FROM_AP(ap); 963 struct dma_async_tx_descriptor *desc = hsdevp->desc[tag]; 964 int dir = qc->dma_dir; 965 966 if (hsdevp->cmd_issued[tag] != SATA_DWC_CMD_ISSUED_NOT) { 967 start_dma = 1; 968 if (dir == DMA_TO_DEVICE) 969 hsdevp->dma_pending[tag] = SATA_DWC_DMA_PENDING_TX; 970 else 971 hsdevp->dma_pending[tag] = SATA_DWC_DMA_PENDING_RX; 972 } else { 973 dev_err(ap->dev, 974 "%s: Command not pending cmd_issued=%d (tag=%d) DMA NOT started\n", 975 __func__, hsdevp->cmd_issued[tag], tag); 976 start_dma = 0; 977 } 978 979 if (start_dma) { 980 sata_dwc_scr_read(&ap->link, SCR_ERROR, ®); 981 if (reg & SATA_DWC_SERROR_ERR_BITS) { 982 dev_err(ap->dev, "%s: ****** SError=0x%08x ******\n", 983 __func__, reg); 984 } 985 986 if (dir == DMA_TO_DEVICE) 987 sata_dwc_writel(&hsdev->sata_dwc_regs->dmacr, 988 SATA_DWC_DMACR_TXCHEN); 989 else 990 sata_dwc_writel(&hsdev->sata_dwc_regs->dmacr, 991 SATA_DWC_DMACR_RXCHEN); 992 993 /* Enable AHB DMA transfer on the specified channel */ 994 dmaengine_submit(desc); 995 dma_async_issue_pending(hsdevp->chan); 996 } 997 } 998 999 static void sata_dwc_bmdma_start(struct ata_queued_cmd *qc) 1000 { 1001 u8 tag = qc->hw_tag; 1002 1003 if (!ata_is_ncq(qc->tf.protocol)) 1004 tag = 0; 1005 1006 sata_dwc_bmdma_start_by_tag(qc, tag); 1007 } 1008 1009 static unsigned int sata_dwc_qc_issue(struct ata_queued_cmd *qc) 1010 { 1011 u32 sactive; 1012 u8 tag = qc->hw_tag; 1013 struct ata_port *ap = qc->ap; 1014 struct sata_dwc_device_port *hsdevp = HSDEVP_FROM_AP(ap); 1015 1016 if (!ata_is_ncq(qc->tf.protocol)) 1017 tag = 0; 1018 1019 if (ata_is_dma(qc->tf.protocol)) { 1020 hsdevp->desc[tag] = dma_dwc_xfer_setup(qc); 1021 if (!hsdevp->desc[tag]) 1022 return AC_ERR_SYSTEM; 1023 } else { 1024 hsdevp->desc[tag] = NULL; 1025 } 1026 1027 if (ata_is_ncq(qc->tf.protocol)) { 1028 sata_dwc_scr_read(&ap->link, SCR_ACTIVE, &sactive); 1029 sactive |= (0x00000001 << tag); 1030 sata_dwc_scr_write(&ap->link, SCR_ACTIVE, sactive); 1031 1032 trace_ata_tf_load(ap, &qc->tf); 1033 ap->ops->sff_tf_load(ap, &qc->tf); 1034 trace_ata_exec_command(ap, &qc->tf, tag); 1035 sata_dwc_exec_command_by_tag(ap, &qc->tf, tag, 1036 SATA_DWC_CMD_ISSUED_PEND); 1037 } else { 1038 return ata_bmdma_qc_issue(qc); 1039 } 1040 return 0; 1041 } 1042 1043 static void sata_dwc_error_handler(struct ata_port *ap) 1044 { 1045 ata_sff_error_handler(ap); 1046 } 1047 1048 static int sata_dwc_hardreset(struct ata_link *link, unsigned int *class, 1049 unsigned long deadline) 1050 { 1051 struct sata_dwc_device *hsdev = HSDEV_FROM_AP(link->ap); 1052 int ret; 1053 1054 ret = sata_sff_hardreset(link, class, deadline); 1055 1056 sata_dwc_enable_interrupts(hsdev); 1057 1058 /* Reconfigure the DMA control register */ 1059 sata_dwc_writel(&hsdev->sata_dwc_regs->dmacr, 1060 SATA_DWC_DMACR_TXRXCH_CLEAR); 1061 1062 /* Reconfigure the DMA Burst Transaction Size register */ 1063 sata_dwc_writel(&hsdev->sata_dwc_regs->dbtsr, 1064 SATA_DWC_DBTSR_MWR(AHB_DMA_BRST_DFLT) | 1065 SATA_DWC_DBTSR_MRD(AHB_DMA_BRST_DFLT)); 1066 1067 return ret; 1068 } 1069 1070 static void sata_dwc_dev_select(struct ata_port *ap, unsigned int device) 1071 { 1072 /* SATA DWC is master only */ 1073 } 1074 1075 /* 1076 * scsi mid-layer and libata interface structures 1077 */ 1078 static const struct scsi_host_template sata_dwc_sht = { 1079 ATA_NCQ_SHT(DRV_NAME), 1080 /* 1081 * test-only: Currently this driver doesn't handle NCQ 1082 * correctly. We enable NCQ but set the queue depth to a 1083 * max of 1. This will get fixed in in a future release. 1084 */ 1085 .sg_tablesize = LIBATA_MAX_PRD, 1086 /* .can_queue = ATA_MAX_QUEUE, */ 1087 /* 1088 * Make sure a LLI block is not created that will span 8K max FIS 1089 * boundary. If the block spans such a FIS boundary, there is a chance 1090 * that a DMA burst will cross that boundary -- this results in an 1091 * error in the host controller. 1092 */ 1093 .dma_boundary = 0x1fff /* ATA_DMA_BOUNDARY */, 1094 }; 1095 1096 static struct ata_port_operations sata_dwc_ops = { 1097 .inherits = &ata_sff_port_ops, 1098 1099 .error_handler = sata_dwc_error_handler, 1100 .hardreset = sata_dwc_hardreset, 1101 1102 .qc_issue = sata_dwc_qc_issue, 1103 1104 .scr_read = sata_dwc_scr_read, 1105 .scr_write = sata_dwc_scr_write, 1106 1107 .port_start = sata_dwc_port_start, 1108 .port_stop = sata_dwc_port_stop, 1109 1110 .sff_dev_select = sata_dwc_dev_select, 1111 1112 .bmdma_setup = sata_dwc_bmdma_setup, 1113 .bmdma_start = sata_dwc_bmdma_start, 1114 }; 1115 1116 static const struct ata_port_info sata_dwc_port_info[] = { 1117 { 1118 .flags = ATA_FLAG_SATA | ATA_FLAG_NCQ, 1119 .pio_mask = ATA_PIO4, 1120 .udma_mask = ATA_UDMA6, 1121 .port_ops = &sata_dwc_ops, 1122 }, 1123 }; 1124 1125 static int sata_dwc_probe(struct platform_device *ofdev) 1126 { 1127 struct device *dev = &ofdev->dev; 1128 struct device_node *np = dev->of_node; 1129 struct sata_dwc_device *hsdev; 1130 u32 idr, versionr; 1131 char *ver = (char *)&versionr; 1132 void __iomem *base; 1133 int err = 0; 1134 int irq; 1135 struct ata_host *host; 1136 struct ata_port_info pi = sata_dwc_port_info[0]; 1137 const struct ata_port_info *ppi[] = { &pi, NULL }; 1138 struct resource *res; 1139 1140 /* Allocate DWC SATA device */ 1141 host = ata_host_alloc_pinfo(dev, ppi, SATA_DWC_MAX_PORTS); 1142 hsdev = devm_kzalloc(dev, sizeof(*hsdev), GFP_KERNEL); 1143 if (!host || !hsdev) 1144 return -ENOMEM; 1145 1146 host->private_data = hsdev; 1147 1148 /* Ioremap SATA registers */ 1149 base = devm_platform_get_and_ioremap_resource(ofdev, 0, &res); 1150 if (IS_ERR(base)) 1151 return PTR_ERR(base); 1152 dev_dbg(dev, "ioremap done for SATA register address\n"); 1153 1154 /* Synopsys DWC SATA specific Registers */ 1155 hsdev->sata_dwc_regs = base + SATA_DWC_REG_OFFSET; 1156 hsdev->dmadr = res->start + SATA_DWC_REG_OFFSET + offsetof(struct sata_dwc_regs, dmadr); 1157 1158 /* Setup port */ 1159 host->ports[0]->ioaddr.cmd_addr = base; 1160 host->ports[0]->ioaddr.scr_addr = base + SATA_DWC_SCR_OFFSET; 1161 sata_dwc_setup_port(&host->ports[0]->ioaddr, base); 1162 1163 /* Read the ID and Version Registers */ 1164 idr = sata_dwc_readl(&hsdev->sata_dwc_regs->idr); 1165 versionr = sata_dwc_readl(&hsdev->sata_dwc_regs->versionr); 1166 dev_notice(dev, "id %d, controller version %c.%c%c\n", idr, ver[0], ver[1], ver[2]); 1167 1168 /* Save dev for later use in dev_xxx() routines */ 1169 hsdev->dev = dev; 1170 1171 /* Enable SATA Interrupts */ 1172 sata_dwc_enable_interrupts(hsdev); 1173 1174 /* Get SATA interrupt number */ 1175 irq = irq_of_parse_and_map(np, 0); 1176 if (!irq) { 1177 dev_err(dev, "no SATA DMA irq\n"); 1178 return -ENODEV; 1179 } 1180 1181 #ifdef CONFIG_SATA_DWC_OLD_DMA 1182 if (!of_property_present(np, "dmas")) { 1183 err = sata_dwc_dma_init_old(ofdev, hsdev); 1184 if (err) 1185 return err; 1186 } 1187 #endif 1188 1189 hsdev->phy = devm_phy_optional_get(dev, "sata-phy"); 1190 if (IS_ERR(hsdev->phy)) 1191 return PTR_ERR(hsdev->phy); 1192 1193 err = phy_init(hsdev->phy); 1194 if (err) 1195 goto error_out; 1196 1197 /* 1198 * Now, register with libATA core, this will also initiate the 1199 * device discovery process, invoking our port_start() handler & 1200 * error_handler() to execute a dummy Softreset EH session 1201 */ 1202 err = ata_host_activate(host, irq, sata_dwc_isr, 0, &sata_dwc_sht); 1203 if (err) 1204 dev_err(dev, "failed to activate host"); 1205 1206 return 0; 1207 1208 error_out: 1209 phy_exit(hsdev->phy); 1210 return err; 1211 } 1212 1213 static void sata_dwc_remove(struct platform_device *ofdev) 1214 { 1215 struct device *dev = &ofdev->dev; 1216 struct ata_host *host = dev_get_drvdata(dev); 1217 struct sata_dwc_device *hsdev = host->private_data; 1218 1219 ata_host_detach(host); 1220 1221 phy_exit(hsdev->phy); 1222 1223 #ifdef CONFIG_SATA_DWC_OLD_DMA 1224 /* Free SATA DMA resources */ 1225 sata_dwc_dma_exit_old(hsdev); 1226 #endif 1227 1228 dev_dbg(dev, "done\n"); 1229 } 1230 1231 static const struct of_device_id sata_dwc_match[] = { 1232 { .compatible = "amcc,sata-460ex", }, 1233 {} 1234 }; 1235 MODULE_DEVICE_TABLE(of, sata_dwc_match); 1236 1237 static struct platform_driver sata_dwc_driver = { 1238 .driver = { 1239 .name = DRV_NAME, 1240 .of_match_table = sata_dwc_match, 1241 }, 1242 .probe = sata_dwc_probe, 1243 .remove = sata_dwc_remove, 1244 }; 1245 1246 module_platform_driver(sata_dwc_driver); 1247 1248 MODULE_LICENSE("GPL"); 1249 MODULE_AUTHOR("Mark Miesfeld <mmiesfeld@amcc.com>"); 1250 MODULE_DESCRIPTION("DesignWare Cores SATA controller low level driver"); 1251 MODULE_VERSION(DRV_VERSION); 1252