2  *  sata_nv.c - NVIDIA nForce SATA
 
   4  *  Copyright 2004 NVIDIA Corp.  All rights reserved.
 
   5  *  Copyright 2004 Andrew Chew
 
   8  *  This program is free software; you can redistribute it and/or modify
 
   9  *  it under the terms of the GNU General Public License as published by
 
  10  *  the Free Software Foundation; either version 2, or (at your option)
 
  13  *  This program is distributed in the hope that it will be useful,
 
  14  *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 
  15  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
  16  *  GNU General Public License for more details.
 
  18  *  You should have received a copy of the GNU General Public License
 
  19  *  along with this program; see the file COPYING.  If not, write to
 
  20  *  the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
 
  23  *  libata documentation is available via 'make {ps|pdf}docs',
 
  24  *  as Documentation/DocBook/libata.*
 
  26  *  No hardware documentation available outside of NVIDIA.
 
  27  *  This driver programs the NVIDIA SATA controller in a similar
 
  28  *  fashion as with other PCI IDE BMDMA controllers, with a few
 
  29  *  NV-specific details such as register offsets, SATA phy location,
 
  32  *  CK804/MCP04 controllers support an alternate programming interface
 
  33  *  similar to the ADMA specification (with some modifications).
 
  34  *  This allows the use of NCQ. Non-DMA-mapped ATA commands are still
 
  35  *  sent through the legacy interface.
 
  39 #include <linux/kernel.h>
 
  40 #include <linux/module.h>
 
  41 #include <linux/pci.h>
 
  42 #include <linux/init.h>
 
  43 #include <linux/blkdev.h>
 
  44 #include <linux/delay.h>
 
  45 #include <linux/interrupt.h>
 
  46 #include <linux/device.h>
 
  47 #include <scsi/scsi_host.h>
 
  48 #include <scsi/scsi_device.h>
 
  49 #include <linux/libata.h>
 
  51 #define DRV_NAME                        "sata_nv"
 
  52 #define DRV_VERSION                     "3.2"
 
  54 #define NV_ADMA_DMA_BOUNDARY            0xffffffffUL
 
  61         NV_PORT0_SCR_REG_OFFSET         = 0x00,
 
  62         NV_PORT1_SCR_REG_OFFSET         = 0x40,
 
  64         /* INT_STATUS/ENABLE */
 
  67         NV_INT_STATUS_CK804             = 0x440,
 
  68         NV_INT_ENABLE_CK804             = 0x441,
 
  70         /* INT_STATUS/ENABLE bits */
 
  74         NV_INT_REMOVED                  = 0x08,
 
  76         NV_INT_PORT_SHIFT               = 4,    /* each port occupies 4 bits */
 
  79         NV_INT_MASK                     = NV_INT_DEV |
 
  80                                           NV_INT_ADDED | NV_INT_REMOVED,
 
  84         NV_INT_CONFIG_METHD             = 0x01, // 0 = INT, 1 = SMI
 
  86         // For PCI config register 20
 
  87         NV_MCP_SATA_CFG_20              = 0x50,
 
  88         NV_MCP_SATA_CFG_20_SATA_SPACE_EN = 0x04,
 
  89         NV_MCP_SATA_CFG_20_PORT0_EN     = (1 << 17),
 
  90         NV_MCP_SATA_CFG_20_PORT1_EN     = (1 << 16),
 
  91         NV_MCP_SATA_CFG_20_PORT0_PWB_EN = (1 << 14),
 
  92         NV_MCP_SATA_CFG_20_PORT1_PWB_EN = (1 << 12),
 
  94         NV_ADMA_MAX_CPBS                = 32,
 
  97         NV_ADMA_SGTBL_LEN               = (1024 - NV_ADMA_CPB_SZ) /
 
  99         NV_ADMA_SGTBL_TOTAL_LEN         = NV_ADMA_SGTBL_LEN + 5,
 
 100         NV_ADMA_SGTBL_SZ                = NV_ADMA_SGTBL_LEN * NV_ADMA_APRD_SZ,
 
 101         NV_ADMA_PORT_PRIV_DMA_SZ        = NV_ADMA_MAX_CPBS *
 
 102                                            (NV_ADMA_CPB_SZ + NV_ADMA_SGTBL_SZ),
 
 104         /* BAR5 offset to ADMA general registers */
 
 106         NV_ADMA_GEN_CTL                 = 0x00,
 
 107         NV_ADMA_NOTIFIER_CLEAR          = 0x30,
 
 109         /* BAR5 offset to ADMA ports */
 
 110         NV_ADMA_PORT                    = 0x480,
 
 112         /* size of ADMA port register space  */
 
 113         NV_ADMA_PORT_SIZE               = 0x100,
 
 115         /* ADMA port registers */
 
 117         NV_ADMA_CPB_COUNT               = 0x42,
 
 118         NV_ADMA_NEXT_CPB_IDX            = 0x43,
 
 120         NV_ADMA_CPB_BASE_LOW            = 0x48,
 
 121         NV_ADMA_CPB_BASE_HIGH           = 0x4C,
 
 122         NV_ADMA_APPEND                  = 0x50,
 
 123         NV_ADMA_NOTIFIER                = 0x68,
 
 124         NV_ADMA_NOTIFIER_ERROR          = 0x6C,
 
 126         /* NV_ADMA_CTL register bits */
 
 127         NV_ADMA_CTL_HOTPLUG_IEN         = (1 << 0),
 
 128         NV_ADMA_CTL_CHANNEL_RESET       = (1 << 5),
 
 129         NV_ADMA_CTL_GO                  = (1 << 7),
 
 130         NV_ADMA_CTL_AIEN                = (1 << 8),
 
 131         NV_ADMA_CTL_READ_NON_COHERENT   = (1 << 11),
 
 132         NV_ADMA_CTL_WRITE_NON_COHERENT  = (1 << 12),
 
 134         /* CPB response flag bits */
 
 135         NV_CPB_RESP_DONE                = (1 << 0),
 
 136         NV_CPB_RESP_ATA_ERR             = (1 << 3),
 
 137         NV_CPB_RESP_CMD_ERR             = (1 << 4),
 
 138         NV_CPB_RESP_CPB_ERR             = (1 << 7),
 
 140         /* CPB control flag bits */
 
 141         NV_CPB_CTL_CPB_VALID            = (1 << 0),
 
 142         NV_CPB_CTL_QUEUE                = (1 << 1),
 
 143         NV_CPB_CTL_APRD_VALID           = (1 << 2),
 
 144         NV_CPB_CTL_IEN                  = (1 << 3),
 
 145         NV_CPB_CTL_FPDMA                = (1 << 4),
 
 148         NV_APRD_WRITE                   = (1 << 1),
 
 149         NV_APRD_END                     = (1 << 2),
 
 150         NV_APRD_CONT                    = (1 << 3),
 
 152         /* NV_ADMA_STAT flags */
 
 153         NV_ADMA_STAT_TIMEOUT            = (1 << 0),
 
 154         NV_ADMA_STAT_HOTUNPLUG          = (1 << 1),
 
 155         NV_ADMA_STAT_HOTPLUG            = (1 << 2),
 
 156         NV_ADMA_STAT_CPBERR             = (1 << 4),
 
 157         NV_ADMA_STAT_SERROR             = (1 << 5),
 
 158         NV_ADMA_STAT_CMD_COMPLETE       = (1 << 6),
 
 159         NV_ADMA_STAT_IDLE               = (1 << 8),
 
 160         NV_ADMA_STAT_LEGACY             = (1 << 9),
 
 161         NV_ADMA_STAT_STOPPED            = (1 << 10),
 
 162         NV_ADMA_STAT_DONE               = (1 << 12),
 
 163         NV_ADMA_STAT_ERR                = NV_ADMA_STAT_CPBERR |
 
 164                                           NV_ADMA_STAT_TIMEOUT,
 
 167         NV_ADMA_PORT_REGISTER_MODE      = (1 << 0),
 
 168         NV_ADMA_ATAPI_SETUP_COMPLETE    = (1 << 1),
 
 172 /* ADMA Physical Region Descriptor - one SG segment */
 
 181 enum nv_adma_regbits {
 
 182         CMDEND  = (1 << 15),            /* end of command list */
 
 183         WNB     = (1 << 14),            /* wait-not-BSY */
 
 184         IGN     = (1 << 13),            /* ignore this entry */
 
 185         CS1n    = (1 << (4 + 8)),       /* std. PATA signals follow... */
 
 186         DA2     = (1 << (2 + 8)),
 
 187         DA1     = (1 << (1 + 8)),
 
 188         DA0     = (1 << (0 + 8)),
 
 191 /* ADMA Command Parameter Block
 
 192    The first 5 SG segments are stored inside the Command Parameter Block itself.
 
 193    If there are more than 5 segments the remainder are stored in a separate
 
 194    memory area indicated by next_aprd. */
 
 196         u8                      resp_flags;    /* 0 */
 
 197         u8                      reserved1;     /* 1 */
 
 198         u8                      ctl_flags;     /* 2 */
 
 199         /* len is length of taskfile in 64 bit words */
 
 202         u8                      next_cpb_idx;  /* 5 */
 
 203         __le16                  reserved2;     /* 6-7 */
 
 204         __le16                  tf[12];        /* 8-31 */
 
 205         struct nv_adma_prd      aprd[5];       /* 32-111 */
 
 206         __le64                  next_aprd;     /* 112-119 */
 
 207         __le64                  reserved3;     /* 120-127 */
 
 211 struct nv_adma_port_priv {
 
 212         struct nv_adma_cpb      *cpb;
 
 214         struct nv_adma_prd      *aprd;
 
 219 #define NV_ADMA_CHECK_INTR(GCTL, PORT) ((GCTL) & ( 1 << (19 + (12 * (PORT)))))
 
 221 static int nv_init_one (struct pci_dev *pdev, const struct pci_device_id *ent);
 
 222 static void nv_ck804_host_stop(struct ata_host *host);
 
 223 static irqreturn_t nv_generic_interrupt(int irq, void *dev_instance);
 
 224 static irqreturn_t nv_nf2_interrupt(int irq, void *dev_instance);
 
 225 static irqreturn_t nv_ck804_interrupt(int irq, void *dev_instance);
 
 226 static u32 nv_scr_read (struct ata_port *ap, unsigned int sc_reg);
 
 227 static void nv_scr_write (struct ata_port *ap, unsigned int sc_reg, u32 val);
 
 229 static void nv_nf2_freeze(struct ata_port *ap);
 
 230 static void nv_nf2_thaw(struct ata_port *ap);
 
 231 static void nv_ck804_freeze(struct ata_port *ap);
 
 232 static void nv_ck804_thaw(struct ata_port *ap);
 
 233 static void nv_error_handler(struct ata_port *ap);
 
 234 static int nv_adma_slave_config(struct scsi_device *sdev);
 
 235 static int nv_adma_check_atapi_dma(struct ata_queued_cmd *qc);
 
 236 static void nv_adma_qc_prep(struct ata_queued_cmd *qc);
 
 237 static unsigned int nv_adma_qc_issue(struct ata_queued_cmd *qc);
 
 238 static irqreturn_t nv_adma_interrupt(int irq, void *dev_instance);
 
 239 static void nv_adma_irq_clear(struct ata_port *ap);
 
 240 static int nv_adma_port_start(struct ata_port *ap);
 
 241 static void nv_adma_port_stop(struct ata_port *ap);
 
 242 static void nv_adma_error_handler(struct ata_port *ap);
 
 243 static void nv_adma_host_stop(struct ata_host *host);
 
 244 static void nv_adma_bmdma_setup(struct ata_queued_cmd *qc);
 
 245 static void nv_adma_bmdma_start(struct ata_queued_cmd *qc);
 
 246 static void nv_adma_bmdma_stop(struct ata_queued_cmd *qc);
 
 247 static u8 nv_adma_bmdma_status(struct ata_port *ap);
 
 253         NFORCE3 = NFORCE2,      /* NF2 == NF3 as far as sata_nv is concerned */
 
 258 static const struct pci_device_id nv_pci_tbl[] = {
 
 259         { PCI_VDEVICE(NVIDIA, PCI_DEVICE_ID_NVIDIA_NFORCE2S_SATA), NFORCE2 },
 
 260         { PCI_VDEVICE(NVIDIA, PCI_DEVICE_ID_NVIDIA_NFORCE3S_SATA), NFORCE3 },
 
 261         { PCI_VDEVICE(NVIDIA, PCI_DEVICE_ID_NVIDIA_NFORCE3S_SATA2), NFORCE3 },
 
 262         { PCI_VDEVICE(NVIDIA, PCI_DEVICE_ID_NVIDIA_NFORCE_CK804_SATA), CK804 },
 
 263         { PCI_VDEVICE(NVIDIA, PCI_DEVICE_ID_NVIDIA_NFORCE_CK804_SATA2), CK804 },
 
 264         { PCI_VDEVICE(NVIDIA, PCI_DEVICE_ID_NVIDIA_NFORCE_MCP04_SATA), CK804 },
 
 265         { PCI_VDEVICE(NVIDIA, PCI_DEVICE_ID_NVIDIA_NFORCE_MCP04_SATA2), CK804 },
 
 266         { PCI_VDEVICE(NVIDIA, PCI_DEVICE_ID_NVIDIA_NFORCE_MCP51_SATA), GENERIC },
 
 267         { PCI_VDEVICE(NVIDIA, PCI_DEVICE_ID_NVIDIA_NFORCE_MCP51_SATA2), GENERIC },
 
 268         { PCI_VDEVICE(NVIDIA, PCI_DEVICE_ID_NVIDIA_NFORCE_MCP55_SATA), GENERIC },
 
 269         { PCI_VDEVICE(NVIDIA, PCI_DEVICE_ID_NVIDIA_NFORCE_MCP55_SATA2), GENERIC },
 
 270         { PCI_VDEVICE(NVIDIA, PCI_DEVICE_ID_NVIDIA_NFORCE_MCP61_SATA), GENERIC },
 
 271         { PCI_VDEVICE(NVIDIA, PCI_DEVICE_ID_NVIDIA_NFORCE_MCP61_SATA2), GENERIC },
 
 272         { PCI_VDEVICE(NVIDIA, PCI_DEVICE_ID_NVIDIA_NFORCE_MCP61_SATA3), GENERIC },
 
 273         { PCI_VENDOR_ID_NVIDIA, PCI_ANY_ID,
 
 274                 PCI_ANY_ID, PCI_ANY_ID,
 
 275                 PCI_CLASS_STORAGE_IDE<<8, 0xffff00, GENERIC },
 
 276         { PCI_VENDOR_ID_NVIDIA, PCI_ANY_ID,
 
 277                 PCI_ANY_ID, PCI_ANY_ID,
 
 278                 PCI_CLASS_STORAGE_RAID<<8, 0xffff00, GENERIC },
 
 280         { } /* terminate list */
 
 283 static struct pci_driver nv_pci_driver = {
 
 285         .id_table               = nv_pci_tbl,
 
 286         .probe                  = nv_init_one,
 
 287         .remove                 = ata_pci_remove_one,
 
 290 static struct scsi_host_template nv_sht = {
 
 291         .module                 = THIS_MODULE,
 
 293         .ioctl                  = ata_scsi_ioctl,
 
 294         .queuecommand           = ata_scsi_queuecmd,
 
 295         .can_queue              = ATA_DEF_QUEUE,
 
 296         .this_id                = ATA_SHT_THIS_ID,
 
 297         .sg_tablesize           = LIBATA_MAX_PRD,
 
 298         .cmd_per_lun            = ATA_SHT_CMD_PER_LUN,
 
 299         .emulated               = ATA_SHT_EMULATED,
 
 300         .use_clustering         = ATA_SHT_USE_CLUSTERING,
 
 301         .proc_name              = DRV_NAME,
 
 302         .dma_boundary           = ATA_DMA_BOUNDARY,
 
 303         .slave_configure        = ata_scsi_slave_config,
 
 304         .slave_destroy          = ata_scsi_slave_destroy,
 
 305         .bios_param             = ata_std_bios_param,
 
 308 static struct scsi_host_template nv_adma_sht = {
 
 309         .module                 = THIS_MODULE,
 
 311         .ioctl                  = ata_scsi_ioctl,
 
 312         .queuecommand           = ata_scsi_queuecmd,
 
 313         .can_queue              = NV_ADMA_MAX_CPBS,
 
 314         .this_id                = ATA_SHT_THIS_ID,
 
 315         .sg_tablesize           = NV_ADMA_SGTBL_TOTAL_LEN,
 
 316         .cmd_per_lun            = ATA_SHT_CMD_PER_LUN,
 
 317         .emulated               = ATA_SHT_EMULATED,
 
 318         .use_clustering         = ATA_SHT_USE_CLUSTERING,
 
 319         .proc_name              = DRV_NAME,
 
 320         .dma_boundary           = NV_ADMA_DMA_BOUNDARY,
 
 321         .slave_configure        = nv_adma_slave_config,
 
 322         .slave_destroy          = ata_scsi_slave_destroy,
 
 323         .bios_param             = ata_std_bios_param,
 
 326 static const struct ata_port_operations nv_generic_ops = {
 
 327         .port_disable           = ata_port_disable,
 
 328         .tf_load                = ata_tf_load,
 
 329         .tf_read                = ata_tf_read,
 
 330         .exec_command           = ata_exec_command,
 
 331         .check_status           = ata_check_status,
 
 332         .dev_select             = ata_std_dev_select,
 
 333         .bmdma_setup            = ata_bmdma_setup,
 
 334         .bmdma_start            = ata_bmdma_start,
 
 335         .bmdma_stop             = ata_bmdma_stop,
 
 336         .bmdma_status           = ata_bmdma_status,
 
 337         .qc_prep                = ata_qc_prep,
 
 338         .qc_issue               = ata_qc_issue_prot,
 
 339         .freeze                 = ata_bmdma_freeze,
 
 340         .thaw                   = ata_bmdma_thaw,
 
 341         .error_handler          = nv_error_handler,
 
 342         .post_internal_cmd      = ata_bmdma_post_internal_cmd,
 
 343         .data_xfer              = ata_pio_data_xfer,
 
 344         .irq_handler            = nv_generic_interrupt,
 
 345         .irq_clear              = ata_bmdma_irq_clear,
 
 346         .scr_read               = nv_scr_read,
 
 347         .scr_write              = nv_scr_write,
 
 348         .port_start             = ata_port_start,
 
 349         .port_stop              = ata_port_stop,
 
 350         .host_stop              = ata_pci_host_stop,
 
 353 static const struct ata_port_operations nv_nf2_ops = {
 
 354         .port_disable           = ata_port_disable,
 
 355         .tf_load                = ata_tf_load,
 
 356         .tf_read                = ata_tf_read,
 
 357         .exec_command           = ata_exec_command,
 
 358         .check_status           = ata_check_status,
 
 359         .dev_select             = ata_std_dev_select,
 
 360         .bmdma_setup            = ata_bmdma_setup,
 
 361         .bmdma_start            = ata_bmdma_start,
 
 362         .bmdma_stop             = ata_bmdma_stop,
 
 363         .bmdma_status           = ata_bmdma_status,
 
 364         .qc_prep                = ata_qc_prep,
 
 365         .qc_issue               = ata_qc_issue_prot,
 
 366         .freeze                 = nv_nf2_freeze,
 
 368         .error_handler          = nv_error_handler,
 
 369         .post_internal_cmd      = ata_bmdma_post_internal_cmd,
 
 370         .data_xfer              = ata_pio_data_xfer,
 
 371         .irq_handler            = nv_nf2_interrupt,
 
 372         .irq_clear              = ata_bmdma_irq_clear,
 
 373         .scr_read               = nv_scr_read,
 
 374         .scr_write              = nv_scr_write,
 
 375         .port_start             = ata_port_start,
 
 376         .port_stop              = ata_port_stop,
 
 377         .host_stop              = ata_pci_host_stop,
 
 380 static const struct ata_port_operations nv_ck804_ops = {
 
 381         .port_disable           = ata_port_disable,
 
 382         .tf_load                = ata_tf_load,
 
 383         .tf_read                = ata_tf_read,
 
 384         .exec_command           = ata_exec_command,
 
 385         .check_status           = ata_check_status,
 
 386         .dev_select             = ata_std_dev_select,
 
 387         .bmdma_setup            = ata_bmdma_setup,
 
 388         .bmdma_start            = ata_bmdma_start,
 
 389         .bmdma_stop             = ata_bmdma_stop,
 
 390         .bmdma_status           = ata_bmdma_status,
 
 391         .qc_prep                = ata_qc_prep,
 
 392         .qc_issue               = ata_qc_issue_prot,
 
 393         .freeze                 = nv_ck804_freeze,
 
 394         .thaw                   = nv_ck804_thaw,
 
 395         .error_handler          = nv_error_handler,
 
 396         .post_internal_cmd      = ata_bmdma_post_internal_cmd,
 
 397         .data_xfer              = ata_pio_data_xfer,
 
 398         .irq_handler            = nv_ck804_interrupt,
 
 399         .irq_clear              = ata_bmdma_irq_clear,
 
 400         .scr_read               = nv_scr_read,
 
 401         .scr_write              = nv_scr_write,
 
 402         .port_start             = ata_port_start,
 
 403         .port_stop              = ata_port_stop,
 
 404         .host_stop              = nv_ck804_host_stop,
 
 407 static const struct ata_port_operations nv_adma_ops = {
 
 408         .port_disable           = ata_port_disable,
 
 409         .tf_load                = ata_tf_load,
 
 410         .tf_read                = ata_tf_read,
 
 411         .check_atapi_dma        = nv_adma_check_atapi_dma,
 
 412         .exec_command           = ata_exec_command,
 
 413         .check_status           = ata_check_status,
 
 414         .dev_select             = ata_std_dev_select,
 
 415         .bmdma_setup            = nv_adma_bmdma_setup,
 
 416         .bmdma_start            = nv_adma_bmdma_start,
 
 417         .bmdma_stop             = nv_adma_bmdma_stop,
 
 418         .bmdma_status           = nv_adma_bmdma_status,
 
 419         .qc_prep                = nv_adma_qc_prep,
 
 420         .qc_issue               = nv_adma_qc_issue,
 
 421         .freeze                 = nv_ck804_freeze,
 
 422         .thaw                   = nv_ck804_thaw,
 
 423         .error_handler          = nv_adma_error_handler,
 
 424         .post_internal_cmd      = nv_adma_bmdma_stop,
 
 425         .data_xfer              = ata_mmio_data_xfer,
 
 426         .irq_handler            = nv_adma_interrupt,
 
 427         .irq_clear              = nv_adma_irq_clear,
 
 428         .scr_read               = nv_scr_read,
 
 429         .scr_write              = nv_scr_write,
 
 430         .port_start             = nv_adma_port_start,
 
 431         .port_stop              = nv_adma_port_stop,
 
 432         .host_stop              = nv_adma_host_stop,
 
 435 static struct ata_port_info nv_port_info[] = {
 
 439                 .flags          = ATA_FLAG_SATA | ATA_FLAG_NO_LEGACY |
 
 440                                   ATA_FLAG_HRST_TO_RESUME,
 
 441                 .pio_mask       = NV_PIO_MASK,
 
 442                 .mwdma_mask     = NV_MWDMA_MASK,
 
 443                 .udma_mask      = NV_UDMA_MASK,
 
 444                 .port_ops       = &nv_generic_ops,
 
 449                 .flags          = ATA_FLAG_SATA | ATA_FLAG_NO_LEGACY |
 
 450                                   ATA_FLAG_HRST_TO_RESUME,
 
 451                 .pio_mask       = NV_PIO_MASK,
 
 452                 .mwdma_mask     = NV_MWDMA_MASK,
 
 453                 .udma_mask      = NV_UDMA_MASK,
 
 454                 .port_ops       = &nv_nf2_ops,
 
 459                 .flags          = ATA_FLAG_SATA | ATA_FLAG_NO_LEGACY |
 
 460                                   ATA_FLAG_HRST_TO_RESUME,
 
 461                 .pio_mask       = NV_PIO_MASK,
 
 462                 .mwdma_mask     = NV_MWDMA_MASK,
 
 463                 .udma_mask      = NV_UDMA_MASK,
 
 464                 .port_ops       = &nv_ck804_ops,
 
 469                 .flags          = ATA_FLAG_SATA | ATA_FLAG_NO_LEGACY |
 
 470                                   ATA_FLAG_MMIO | ATA_FLAG_NCQ,
 
 471                 .pio_mask       = NV_PIO_MASK,
 
 472                 .mwdma_mask     = NV_MWDMA_MASK,
 
 473                 .udma_mask      = NV_UDMA_MASK,
 
 474                 .port_ops       = &nv_adma_ops,
 
 478 MODULE_AUTHOR("NVIDIA");
 
 479 MODULE_DESCRIPTION("low-level driver for NVIDIA nForce SATA controller");
 
 480 MODULE_LICENSE("GPL");
 
 481 MODULE_DEVICE_TABLE(pci, nv_pci_tbl);
 
 482 MODULE_VERSION(DRV_VERSION);
 
 484 static int adma_enabled = 1;
 
 486 static inline void __iomem *__nv_adma_ctl_block(void __iomem *mmio,
 
 487                                                 unsigned int port_no)
 
 489         mmio += NV_ADMA_PORT + port_no * NV_ADMA_PORT_SIZE;
 
 493 static inline void __iomem *nv_adma_ctl_block(struct ata_port *ap)
 
 495         return __nv_adma_ctl_block(ap->host->mmio_base, ap->port_no);
 
 498 static inline void __iomem *nv_adma_gen_block(struct ata_port *ap)
 
 500         return (ap->host->mmio_base + NV_ADMA_GEN);
 
 503 static inline void __iomem *nv_adma_notifier_clear_block(struct ata_port *ap)
 
 505         return (nv_adma_gen_block(ap) + NV_ADMA_NOTIFIER_CLEAR + (4 * ap->port_no));
 
 508 static void nv_adma_register_mode(struct ata_port *ap)
 
 510         void __iomem *mmio = nv_adma_ctl_block(ap);
 
 511         struct nv_adma_port_priv *pp = ap->private_data;
 
 514         if (pp->flags & NV_ADMA_PORT_REGISTER_MODE)
 
 517         tmp = readw(mmio + NV_ADMA_CTL);
 
 518         writew(tmp & ~NV_ADMA_CTL_GO, mmio + NV_ADMA_CTL);
 
 520         pp->flags |= NV_ADMA_PORT_REGISTER_MODE;
 
 523 static void nv_adma_mode(struct ata_port *ap)
 
 525         void __iomem *mmio = nv_adma_ctl_block(ap);
 
 526         struct nv_adma_port_priv *pp = ap->private_data;
 
 529         if (!(pp->flags & NV_ADMA_PORT_REGISTER_MODE))
 
 532         WARN_ON(pp->flags & NV_ADMA_ATAPI_SETUP_COMPLETE);
 
 534         tmp = readw(mmio + NV_ADMA_CTL);
 
 535         writew(tmp | NV_ADMA_CTL_GO, mmio + NV_ADMA_CTL);
 
 537         pp->flags &= ~NV_ADMA_PORT_REGISTER_MODE;
 
 540 static int nv_adma_slave_config(struct scsi_device *sdev)
 
 542         struct ata_port *ap = ata_shost_to_port(sdev->host);
 
 543         struct nv_adma_port_priv *pp = ap->private_data;
 
 544         struct pci_dev *pdev = to_pci_dev(ap->host->dev);
 
 546         unsigned long segment_boundary;
 
 547         unsigned short sg_tablesize;
 
 550         u32 current_reg, new_reg, config_mask;
 
 552         rc = ata_scsi_slave_config(sdev);
 
 554         if (sdev->id >= ATA_MAX_DEVICES || sdev->channel || sdev->lun)
 
 555                 /* Not a proper libata device, ignore */
 
 558         if (ap->device[sdev->id].class == ATA_DEV_ATAPI) {
 
 560                  * NVIDIA reports that ADMA mode does not support ATAPI commands.
 
 561                  * Therefore ATAPI commands are sent through the legacy interface.
 
 562                  * However, the legacy interface only supports 32-bit DMA.
 
 563                  * Restrict DMA parameters as required by the legacy interface
 
 564                  * when an ATAPI device is connected.
 
 566                 bounce_limit = ATA_DMA_MASK;
 
 567                 segment_boundary = ATA_DMA_BOUNDARY;
 
 568                 /* Subtract 1 since an extra entry may be needed for padding, see
 
 570                 sg_tablesize = LIBATA_MAX_PRD - 1;
 
 572                 /* Since the legacy DMA engine is in use, we need to disable ADMA
 
 575                 nv_adma_register_mode(ap);
 
 578                 bounce_limit = *ap->dev->dma_mask;
 
 579                 segment_boundary = NV_ADMA_DMA_BOUNDARY;
 
 580                 sg_tablesize = NV_ADMA_SGTBL_TOTAL_LEN;
 
 584         pci_read_config_dword(pdev, NV_MCP_SATA_CFG_20, ¤t_reg);
 
 587                 config_mask = NV_MCP_SATA_CFG_20_PORT1_EN |
 
 588                               NV_MCP_SATA_CFG_20_PORT1_PWB_EN;
 
 590                 config_mask = NV_MCP_SATA_CFG_20_PORT0_EN |
 
 591                               NV_MCP_SATA_CFG_20_PORT0_PWB_EN;
 
 594                 new_reg = current_reg | config_mask;
 
 595                 pp->flags &= ~NV_ADMA_ATAPI_SETUP_COMPLETE;
 
 598                 new_reg = current_reg & ~config_mask;
 
 599                 pp->flags |= NV_ADMA_ATAPI_SETUP_COMPLETE;
 
 602         if(current_reg != new_reg)
 
 603                 pci_write_config_dword(pdev, NV_MCP_SATA_CFG_20, new_reg);
 
 605         blk_queue_bounce_limit(sdev->request_queue, bounce_limit);
 
 606         blk_queue_segment_boundary(sdev->request_queue, segment_boundary);
 
 607         blk_queue_max_hw_segments(sdev->request_queue, sg_tablesize);
 
 608         ata_port_printk(ap, KERN_INFO,
 
 609                 "bounce limit 0x%llX, segment boundary 0x%lX, hw segs %hu\n",
 
 610                 (unsigned long long)bounce_limit, segment_boundary, sg_tablesize);
 
 614 static int nv_adma_check_atapi_dma(struct ata_queued_cmd *qc)
 
 616         struct nv_adma_port_priv *pp = qc->ap->private_data;
 
 617         return !(pp->flags & NV_ADMA_ATAPI_SETUP_COMPLETE);
 
 620 static unsigned int nv_adma_tf_to_cpb(struct ata_taskfile *tf, __le16 *cpb)
 
 622         unsigned int idx = 0;
 
 624         cpb[idx++] = cpu_to_le16((ATA_REG_DEVICE << 8) | tf->device | WNB);
 
 626         if ((tf->flags & ATA_TFLAG_LBA48) == 0) {
 
 627                 cpb[idx++] = cpu_to_le16(IGN);
 
 628                 cpb[idx++] = cpu_to_le16(IGN);
 
 629                 cpb[idx++] = cpu_to_le16(IGN);
 
 630                 cpb[idx++] = cpu_to_le16(IGN);
 
 631                 cpb[idx++] = cpu_to_le16(IGN);
 
 634                 cpb[idx++] = cpu_to_le16((ATA_REG_ERR   << 8) | tf->hob_feature);
 
 635                 cpb[idx++] = cpu_to_le16((ATA_REG_NSECT << 8) | tf->hob_nsect);
 
 636                 cpb[idx++] = cpu_to_le16((ATA_REG_LBAL  << 8) | tf->hob_lbal);
 
 637                 cpb[idx++] = cpu_to_le16((ATA_REG_LBAM  << 8) | tf->hob_lbam);
 
 638                 cpb[idx++] = cpu_to_le16((ATA_REG_LBAH  << 8) | tf->hob_lbah);
 
 640         cpb[idx++] = cpu_to_le16((ATA_REG_ERR    << 8) | tf->feature);
 
 641         cpb[idx++] = cpu_to_le16((ATA_REG_NSECT  << 8) | tf->nsect);
 
 642         cpb[idx++] = cpu_to_le16((ATA_REG_LBAL   << 8) | tf->lbal);
 
 643         cpb[idx++] = cpu_to_le16((ATA_REG_LBAM   << 8) | tf->lbam);
 
 644         cpb[idx++] = cpu_to_le16((ATA_REG_LBAH   << 8) | tf->lbah);
 
 646         cpb[idx++] = cpu_to_le16((ATA_REG_CMD    << 8) | tf->command | CMDEND);
 
 651 static void nv_adma_check_cpb(struct ata_port *ap, int cpb_num, int force_err)
 
 653         struct nv_adma_port_priv *pp = ap->private_data;
 
 654         int complete = 0, have_err = 0;
 
 655         u8 flags = pp->cpb[cpb_num].resp_flags;
 
 657         VPRINTK("CPB %d, flags=0x%x\n", cpb_num, flags);
 
 659         if (flags & NV_CPB_RESP_DONE) {
 
 660                 VPRINTK("CPB flags done, flags=0x%x\n", flags);
 
 663         if (flags & NV_CPB_RESP_ATA_ERR) {
 
 664                 ata_port_printk(ap, KERN_ERR, "CPB flags ATA err, flags=0x%x\n", flags);
 
 668         if (flags & NV_CPB_RESP_CMD_ERR) {
 
 669                 ata_port_printk(ap, KERN_ERR, "CPB flags CMD err, flags=0x%x\n", flags);
 
 673         if (flags & NV_CPB_RESP_CPB_ERR) {
 
 674                 ata_port_printk(ap, KERN_ERR, "CPB flags CPB err, flags=0x%x\n", flags);
 
 678         if(complete || force_err)
 
 680                 struct ata_queued_cmd *qc = ata_qc_from_tag(ap, cpb_num);
 
 683                         /* Only use the ATA port status for non-NCQ commands.
 
 684                            For NCQ commands the current status may have nothing to do with
 
 685                            the command just completed. */
 
 686                         if(qc->tf.protocol != ATA_PROT_NCQ)
 
 687                                 ata_status = readb(nv_adma_ctl_block(ap) + (ATA_REG_STATUS * 4));
 
 689                         if(have_err || force_err)
 
 690                                 ata_status |= ATA_ERR;
 
 692                         qc->err_mask |= ac_err_mask(ata_status);
 
 693                         DPRINTK("Completing qc from tag %d with err_mask %u\n",cpb_num,
 
 700 static int nv_host_intr(struct ata_port *ap, u8 irq_stat)
 
 702         struct ata_queued_cmd *qc = ata_qc_from_tag(ap, ap->active_tag);
 
 704         /* freeze if hotplugged */
 
 705         if (unlikely(irq_stat & (NV_INT_ADDED | NV_INT_REMOVED))) {
 
 710         /* bail out if not our interrupt */
 
 711         if (!(irq_stat & NV_INT_DEV))
 
 714         /* DEV interrupt w/ no active qc? */
 
 715         if (unlikely(!qc || (qc->tf.flags & ATA_TFLAG_POLLING))) {
 
 716                 ata_check_status(ap);
 
 720         /* handle interrupt */
 
 721         return ata_host_intr(ap, qc);
 
 724 static irqreturn_t nv_adma_interrupt(int irq, void *dev_instance)
 
 726         struct ata_host *host = dev_instance;
 
 728         u32 notifier_clears[2];
 
 730         spin_lock(&host->lock);
 
 732         for (i = 0; i < host->n_ports; i++) {
 
 733                 struct ata_port *ap = host->ports[i];
 
 734                 notifier_clears[i] = 0;
 
 736                 if (ap && !(ap->flags & ATA_FLAG_DISABLED)) {
 
 737                         struct nv_adma_port_priv *pp = ap->private_data;
 
 738                         void __iomem *mmio = nv_adma_ctl_block(ap);
 
 741                         int have_global_err = 0;
 
 742                         u32 notifier, notifier_error;
 
 744                         /* if in ATA register mode, use standard ata interrupt handler */
 
 745                         if (pp->flags & NV_ADMA_PORT_REGISTER_MODE) {
 
 746                                 u8 irq_stat = readb(host->mmio_base + NV_INT_STATUS_CK804)
 
 747                                         >> (NV_INT_PORT_SHIFT * i);
 
 748                                 if(ata_tag_valid(ap->active_tag))
 
 749                                         /** NV_INT_DEV indication seems unreliable at times
 
 750                                             at least in ADMA mode. Force it on always when a
 
 751                                             command is active, to prevent losing interrupts. */
 
 752                                         irq_stat |= NV_INT_DEV;
 
 753                                 handled += nv_host_intr(ap, irq_stat);
 
 757                         notifier = readl(mmio + NV_ADMA_NOTIFIER);
 
 758                         notifier_error = readl(mmio + NV_ADMA_NOTIFIER_ERROR);
 
 759                         notifier_clears[i] = notifier | notifier_error;
 
 761                         gen_ctl = readl(nv_adma_gen_block(ap) + NV_ADMA_GEN_CTL);
 
 763                         if( !NV_ADMA_CHECK_INTR(gen_ctl, ap->port_no) && !notifier &&
 
 768                         status = readw(mmio + NV_ADMA_STAT);
 
 770                         /* Clear status. Ensure the controller sees the clearing before we start
 
 771                            looking at any of the CPB statuses, so that any CPB completions after
 
 772                            this point in the handler will raise another interrupt. */
 
 773                         writew(status, mmio + NV_ADMA_STAT);
 
 774                         readw(mmio + NV_ADMA_STAT); /* flush posted write */
 
 777                         /* freeze if hotplugged */
 
 778                         if (unlikely(status & (NV_ADMA_STAT_HOTPLUG | NV_ADMA_STAT_HOTUNPLUG))) {
 
 779                                 ata_port_printk(ap, KERN_NOTICE, "Hotplug event, freezing\n");
 
 785                         if (status & NV_ADMA_STAT_TIMEOUT) {
 
 786                                 ata_port_printk(ap, KERN_ERR, "timeout, stat=0x%x\n", status);
 
 789                         if (status & NV_ADMA_STAT_CPBERR) {
 
 790                                 ata_port_printk(ap, KERN_ERR, "CPB error, stat=0x%x\n", status);
 
 793                         if ((status & NV_ADMA_STAT_DONE) || have_global_err) {
 
 794                                 /** Check CPBs for completed commands */
 
 796                                 if(ata_tag_valid(ap->active_tag))
 
 797                                         /* Non-NCQ command */
 
 798                                         nv_adma_check_cpb(ap, ap->active_tag, have_global_err ||
 
 799                                                 (notifier_error & (1 << ap->active_tag)));
 
 802                                         u32 active = ap->sactive;
 
 803                                         while( (pos = ffs(active)) ) {
 
 805                                                 nv_adma_check_cpb(ap, pos, have_global_err ||
 
 806                                                         (notifier_error & (1 << pos)) );
 
 807                                                 active &= ~(1 << pos );
 
 812                         handled++; /* irq handled if we got here */
 
 816         if(notifier_clears[0] || notifier_clears[1]) {
 
 817                 /* Note: Both notifier clear registers must be written
 
 818                    if either is set, even if one is zero, according to NVIDIA. */
 
 819                 writel(notifier_clears[0], 
 
 820                         nv_adma_notifier_clear_block(host->ports[0]));
 
 821                 writel(notifier_clears[1], 
 
 822                         nv_adma_notifier_clear_block(host->ports[1]));
 
 825         spin_unlock(&host->lock);
 
 827         return IRQ_RETVAL(handled);
 
 830 static void nv_adma_irq_clear(struct ata_port *ap)
 
 832         void __iomem *mmio = nv_adma_ctl_block(ap);
 
 833         u16 status = readw(mmio + NV_ADMA_STAT);
 
 834         u32 notifier = readl(mmio + NV_ADMA_NOTIFIER);
 
 835         u32 notifier_error = readl(mmio + NV_ADMA_NOTIFIER_ERROR);
 
 836         unsigned long dma_stat_addr = ap->ioaddr.bmdma_addr + ATA_DMA_STATUS;
 
 838         /* clear ADMA status */
 
 839         writew(status, mmio + NV_ADMA_STAT);
 
 840         writel(notifier | notifier_error,
 
 841                nv_adma_notifier_clear_block(ap));
 
 843         /** clear legacy status */
 
 844         outb(inb(dma_stat_addr), dma_stat_addr);
 
 847 static void nv_adma_bmdma_setup(struct ata_queued_cmd *qc)
 
 849         struct ata_port *ap = qc->ap;
 
 850         unsigned int rw = (qc->tf.flags & ATA_TFLAG_WRITE);
 
 851         struct nv_adma_port_priv *pp = ap->private_data;
 
 854         if(!(pp->flags & NV_ADMA_PORT_REGISTER_MODE)) {
 
 859         /* load PRD table addr. */
 
 860         outl(ap->prd_dma, ap->ioaddr.bmdma_addr + ATA_DMA_TABLE_OFS);
 
 862         /* specify data direction, triple-check start bit is clear */
 
 863         dmactl = inb(ap->ioaddr.bmdma_addr + ATA_DMA_CMD);
 
 864         dmactl &= ~(ATA_DMA_WR | ATA_DMA_START);
 
 866                 dmactl |= ATA_DMA_WR;
 
 868         outb(dmactl, ap->ioaddr.bmdma_addr + ATA_DMA_CMD);
 
 870         /* issue r/w command */
 
 871         ata_exec_command(ap, &qc->tf);
 
 874 static void nv_adma_bmdma_start(struct ata_queued_cmd *qc)
 
 876         struct ata_port *ap = qc->ap;
 
 877         struct nv_adma_port_priv *pp = ap->private_data;
 
 880         if(!(pp->flags & NV_ADMA_PORT_REGISTER_MODE)) {
 
 885         /* start host DMA transaction */
 
 886         dmactl = inb(ap->ioaddr.bmdma_addr + ATA_DMA_CMD);
 
 887         outb(dmactl | ATA_DMA_START,
 
 888              ap->ioaddr.bmdma_addr + ATA_DMA_CMD);
 
 891 static void nv_adma_bmdma_stop(struct ata_queued_cmd *qc)
 
 893         struct ata_port *ap = qc->ap;
 
 894         struct nv_adma_port_priv *pp = ap->private_data;
 
 896         if(!(pp->flags & NV_ADMA_PORT_REGISTER_MODE))
 
 899         /* clear start/stop bit */
 
 900         outb(inb(ap->ioaddr.bmdma_addr + ATA_DMA_CMD) & ~ATA_DMA_START,
 
 901                 ap->ioaddr.bmdma_addr + ATA_DMA_CMD);
 
 903         /* one-PIO-cycle guaranteed wait, per spec, for HDMA1:0 transition */
 
 904         ata_altstatus(ap);        /* dummy read */
 
 907 static u8 nv_adma_bmdma_status(struct ata_port *ap)
 
 909         struct nv_adma_port_priv *pp = ap->private_data;
 
 911         WARN_ON(!(pp->flags & NV_ADMA_PORT_REGISTER_MODE));
 
 913         return inb(ap->ioaddr.bmdma_addr + ATA_DMA_STATUS);
 
 916 static int nv_adma_port_start(struct ata_port *ap)
 
 918         struct device *dev = ap->host->dev;
 
 919         struct nv_adma_port_priv *pp;
 
 923         void __iomem *mmio = nv_adma_ctl_block(ap);
 
 928         rc = ata_port_start(ap);
 
 932         pp = kzalloc(sizeof(*pp), GFP_KERNEL);
 
 938         mem = dma_alloc_coherent(dev, NV_ADMA_PORT_PRIV_DMA_SZ,
 
 939                                  &mem_dma, GFP_KERNEL);
 
 945         memset(mem, 0, NV_ADMA_PORT_PRIV_DMA_SZ);
 
 948          * First item in chunk of DMA memory:
 
 949          * 128-byte command parameter block (CPB)
 
 950          * one for each command tag
 
 953         pp->cpb_dma = mem_dma;
 
 955         writel(mem_dma & 0xFFFFFFFF,    mmio + NV_ADMA_CPB_BASE_LOW);
 
 956         writel((mem_dma >> 16 ) >> 16,  mmio + NV_ADMA_CPB_BASE_HIGH);
 
 958         mem     += NV_ADMA_MAX_CPBS * NV_ADMA_CPB_SZ;
 
 959         mem_dma += NV_ADMA_MAX_CPBS * NV_ADMA_CPB_SZ;
 
 962          * Second item: block of ADMA_SGTBL_LEN s/g entries
 
 965         pp->aprd_dma = mem_dma;
 
 967         ap->private_data = pp;
 
 969         /* clear any outstanding interrupt conditions */
 
 970         writew(0xffff, mmio + NV_ADMA_STAT);
 
 972         /* initialize port variables */
 
 973         pp->flags = NV_ADMA_PORT_REGISTER_MODE;
 
 975         /* clear CPB fetch count */
 
 976         writew(0, mmio + NV_ADMA_CPB_COUNT);
 
 978         /* clear GO for register mode */
 
 979         tmp = readw(mmio + NV_ADMA_CTL);
 
 980         writew(tmp & ~NV_ADMA_CTL_GO, mmio + NV_ADMA_CTL);
 
 982         tmp = readw(mmio + NV_ADMA_CTL);
 
 983         writew(tmp | NV_ADMA_CTL_CHANNEL_RESET, mmio + NV_ADMA_CTL);
 
 984         readl( mmio + NV_ADMA_CTL );    /* flush posted write */
 
 986         writew(tmp & ~NV_ADMA_CTL_CHANNEL_RESET, mmio + NV_ADMA_CTL);
 
 987         readl( mmio + NV_ADMA_CTL );    /* flush posted write */
 
 998 static void nv_adma_port_stop(struct ata_port *ap)
 
1000         struct device *dev = ap->host->dev;
 
1001         struct nv_adma_port_priv *pp = ap->private_data;
 
1002         void __iomem *mmio = nv_adma_ctl_block(ap);
 
1006         writew(0, mmio + NV_ADMA_CTL);
 
1008         ap->private_data = NULL;
 
1009         dma_free_coherent(dev, NV_ADMA_PORT_PRIV_DMA_SZ, pp->cpb, pp->cpb_dma);
 
1015 static void nv_adma_setup_port(struct ata_probe_ent *probe_ent, unsigned int port)
 
1017         void __iomem *mmio = probe_ent->mmio_base;
 
1018         struct ata_ioports *ioport = &probe_ent->port[port];
 
1022         mmio += NV_ADMA_PORT + port * NV_ADMA_PORT_SIZE;
 
1024         ioport->cmd_addr        = (unsigned long) mmio;
 
1025         ioport->data_addr       = (unsigned long) mmio + (ATA_REG_DATA * 4);
 
1026         ioport->error_addr      =
 
1027         ioport->feature_addr    = (unsigned long) mmio + (ATA_REG_ERR * 4);
 
1028         ioport->nsect_addr      = (unsigned long) mmio + (ATA_REG_NSECT * 4);
 
1029         ioport->lbal_addr       = (unsigned long) mmio + (ATA_REG_LBAL * 4);
 
1030         ioport->lbam_addr       = (unsigned long) mmio + (ATA_REG_LBAM * 4);
 
1031         ioport->lbah_addr       = (unsigned long) mmio + (ATA_REG_LBAH * 4);
 
1032         ioport->device_addr     = (unsigned long) mmio + (ATA_REG_DEVICE * 4);
 
1033         ioport->status_addr     =
 
1034         ioport->command_addr    = (unsigned long) mmio + (ATA_REG_STATUS * 4);
 
1035         ioport->altstatus_addr  =
 
1036         ioport->ctl_addr        = (unsigned long) mmio + 0x20;
 
1039 static int nv_adma_host_init(struct ata_probe_ent *probe_ent)
 
1041         struct pci_dev *pdev = to_pci_dev(probe_ent->dev);
 
1047         /* enable ADMA on the ports */
 
1048         pci_read_config_dword(pdev, NV_MCP_SATA_CFG_20, &tmp32);
 
1049         tmp32 |= NV_MCP_SATA_CFG_20_PORT0_EN |
 
1050                  NV_MCP_SATA_CFG_20_PORT0_PWB_EN |
 
1051                  NV_MCP_SATA_CFG_20_PORT1_EN |
 
1052                  NV_MCP_SATA_CFG_20_PORT1_PWB_EN;
 
1054         pci_write_config_dword(pdev, NV_MCP_SATA_CFG_20, tmp32);
 
1056         for (i = 0; i < probe_ent->n_ports; i++)
 
1057                 nv_adma_setup_port(probe_ent, i);
 
1059         for (i = 0; i < probe_ent->n_ports; i++) {
 
1060                 void __iomem *mmio = __nv_adma_ctl_block(probe_ent->mmio_base, i);
 
1063                 /* enable interrupt, clear reset if not already clear */
 
1064                 tmp = readw(mmio + NV_ADMA_CTL);
 
1065                 writew(tmp | NV_ADMA_CTL_AIEN, mmio + NV_ADMA_CTL);
 
1071 static void nv_adma_fill_aprd(struct ata_queued_cmd *qc,
 
1072                               struct scatterlist *sg,
 
1074                               struct nv_adma_prd *aprd)
 
1078         memset(aprd, 0, sizeof(struct nv_adma_prd));
 
1081         if (qc->tf.flags & ATA_TFLAG_WRITE)
 
1082                 flags |= NV_APRD_WRITE;
 
1083         if (idx == qc->n_elem - 1)
 
1084                 flags |= NV_APRD_END;
 
1086                 flags |= NV_APRD_CONT;
 
1088         aprd->addr  = cpu_to_le64(((u64)sg_dma_address(sg)));
 
1089         aprd->len   = cpu_to_le32(((u32)sg_dma_len(sg))); /* len in bytes */
 
1090         aprd->flags = flags;
 
1093 static void nv_adma_fill_sg(struct ata_queued_cmd *qc, struct nv_adma_cpb *cpb)
 
1095         struct nv_adma_port_priv *pp = qc->ap->private_data;
 
1097         struct nv_adma_prd *aprd;
 
1098         struct scatterlist *sg;
 
1104         ata_for_each_sg(sg, qc) {
 
1105                 aprd = (idx < 5) ? &cpb->aprd[idx] : &pp->aprd[NV_ADMA_SGTBL_LEN * qc->tag + (idx-5)];
 
1106                 nv_adma_fill_aprd(qc, sg, idx, aprd);
 
1110                 cpb->next_aprd = cpu_to_le64(((u64)(pp->aprd_dma + NV_ADMA_SGTBL_SZ * qc->tag)));
 
1113 static void nv_adma_qc_prep(struct ata_queued_cmd *qc)
 
1115         struct nv_adma_port_priv *pp = qc->ap->private_data;
 
1116         struct nv_adma_cpb *cpb = &pp->cpb[qc->tag];
 
1117         u8 ctl_flags = NV_CPB_CTL_CPB_VALID |
 
1118                        NV_CPB_CTL_APRD_VALID |
 
1121         VPRINTK("qc->flags = 0x%lx\n", qc->flags);
 
1123         if (!(qc->flags & ATA_QCFLAG_DMAMAP) ||
 
1124              (pp->flags & NV_ADMA_ATAPI_SETUP_COMPLETE)) {
 
1125                 nv_adma_register_mode(qc->ap);
 
1130         memset(cpb, 0, sizeof(struct nv_adma_cpb));
 
1134         cpb->next_cpb_idx       = 0;
 
1136         /* turn on NCQ flags for NCQ commands */
 
1137         if (qc->tf.protocol == ATA_PROT_NCQ)
 
1138                 ctl_flags |= NV_CPB_CTL_QUEUE | NV_CPB_CTL_FPDMA;
 
1140         nv_adma_tf_to_cpb(&qc->tf, cpb->tf);
 
1142         nv_adma_fill_sg(qc, cpb);
 
1144         /* Be paranoid and don't let the device see NV_CPB_CTL_CPB_VALID until we are
 
1145            finished filling in all of the contents */
 
1147         cpb->ctl_flags = ctl_flags;
 
1150 static unsigned int nv_adma_qc_issue(struct ata_queued_cmd *qc)
 
1152         struct nv_adma_port_priv *pp = qc->ap->private_data;
 
1153         void __iomem *mmio = nv_adma_ctl_block(qc->ap);
 
1157         if (!(qc->flags & ATA_QCFLAG_DMAMAP) ||
 
1158              (pp->flags & NV_ADMA_ATAPI_SETUP_COMPLETE)) {
 
1159                 /* use ATA register mode */
 
1160                 VPRINTK("no dmamap or ATAPI, using ATA register mode: 0x%lx\n", qc->flags);
 
1161                 nv_adma_register_mode(qc->ap);
 
1162                 return ata_qc_issue_prot(qc);
 
1164                 nv_adma_mode(qc->ap);
 
1166         /* write append register, command tag in lower 8 bits
 
1167            and (number of cpbs to append -1) in top 8 bits */
 
1169         writew(qc->tag, mmio + NV_ADMA_APPEND);
 
1171         DPRINTK("Issued tag %u\n",qc->tag);
 
1176 static irqreturn_t nv_generic_interrupt(int irq, void *dev_instance)
 
1178         struct ata_host *host = dev_instance;
 
1180         unsigned int handled = 0;
 
1181         unsigned long flags;
 
1183         spin_lock_irqsave(&host->lock, flags);
 
1185         for (i = 0; i < host->n_ports; i++) {
 
1186                 struct ata_port *ap;
 
1188                 ap = host->ports[i];
 
1190                     !(ap->flags & ATA_FLAG_DISABLED)) {
 
1191                         struct ata_queued_cmd *qc;
 
1193                         qc = ata_qc_from_tag(ap, ap->active_tag);
 
1194                         if (qc && (!(qc->tf.flags & ATA_TFLAG_POLLING)))
 
1195                                 handled += ata_host_intr(ap, qc);
 
1197                                 // No request pending?  Clear interrupt status
 
1198                                 // anyway, in case there's one pending.
 
1199                                 ap->ops->check_status(ap);
 
1204         spin_unlock_irqrestore(&host->lock, flags);
 
1206         return IRQ_RETVAL(handled);
 
1209 static irqreturn_t nv_do_interrupt(struct ata_host *host, u8 irq_stat)
 
1213         for (i = 0; i < host->n_ports; i++) {
 
1214                 struct ata_port *ap = host->ports[i];
 
1216                 if (ap && !(ap->flags & ATA_FLAG_DISABLED))
 
1217                         handled += nv_host_intr(ap, irq_stat);
 
1219                 irq_stat >>= NV_INT_PORT_SHIFT;
 
1222         return IRQ_RETVAL(handled);
 
1225 static irqreturn_t nv_nf2_interrupt(int irq, void *dev_instance)
 
1227         struct ata_host *host = dev_instance;
 
1231         spin_lock(&host->lock);
 
1232         irq_stat = inb(host->ports[0]->ioaddr.scr_addr + NV_INT_STATUS);
 
1233         ret = nv_do_interrupt(host, irq_stat);
 
1234         spin_unlock(&host->lock);
 
1239 static irqreturn_t nv_ck804_interrupt(int irq, void *dev_instance)
 
1241         struct ata_host *host = dev_instance;
 
1245         spin_lock(&host->lock);
 
1246         irq_stat = readb(host->mmio_base + NV_INT_STATUS_CK804);
 
1247         ret = nv_do_interrupt(host, irq_stat);
 
1248         spin_unlock(&host->lock);
 
1253 static u32 nv_scr_read (struct ata_port *ap, unsigned int sc_reg)
 
1255         if (sc_reg > SCR_CONTROL)
 
1258         return ioread32((void __iomem *)ap->ioaddr.scr_addr + (sc_reg * 4));
 
1261 static void nv_scr_write (struct ata_port *ap, unsigned int sc_reg, u32 val)
 
1263         if (sc_reg > SCR_CONTROL)
 
1266         iowrite32(val, (void __iomem *)ap->ioaddr.scr_addr + (sc_reg * 4));
 
1269 static void nv_nf2_freeze(struct ata_port *ap)
 
1271         unsigned long scr_addr = ap->host->ports[0]->ioaddr.scr_addr;
 
1272         int shift = ap->port_no * NV_INT_PORT_SHIFT;
 
1275         mask = inb(scr_addr + NV_INT_ENABLE);
 
1276         mask &= ~(NV_INT_ALL << shift);
 
1277         outb(mask, scr_addr + NV_INT_ENABLE);
 
1280 static void nv_nf2_thaw(struct ata_port *ap)
 
1282         unsigned long scr_addr = ap->host->ports[0]->ioaddr.scr_addr;
 
1283         int shift = ap->port_no * NV_INT_PORT_SHIFT;
 
1286         outb(NV_INT_ALL << shift, scr_addr + NV_INT_STATUS);
 
1288         mask = inb(scr_addr + NV_INT_ENABLE);
 
1289         mask |= (NV_INT_MASK << shift);
 
1290         outb(mask, scr_addr + NV_INT_ENABLE);
 
1293 static void nv_ck804_freeze(struct ata_port *ap)
 
1295         void __iomem *mmio_base = ap->host->mmio_base;
 
1296         int shift = ap->port_no * NV_INT_PORT_SHIFT;
 
1299         mask = readb(mmio_base + NV_INT_ENABLE_CK804);
 
1300         mask &= ~(NV_INT_ALL << shift);
 
1301         writeb(mask, mmio_base + NV_INT_ENABLE_CK804);
 
1304 static void nv_ck804_thaw(struct ata_port *ap)
 
1306         void __iomem *mmio_base = ap->host->mmio_base;
 
1307         int shift = ap->port_no * NV_INT_PORT_SHIFT;
 
1310         writeb(NV_INT_ALL << shift, mmio_base + NV_INT_STATUS_CK804);
 
1312         mask = readb(mmio_base + NV_INT_ENABLE_CK804);
 
1313         mask |= (NV_INT_MASK << shift);
 
1314         writeb(mask, mmio_base + NV_INT_ENABLE_CK804);
 
1317 static int nv_hardreset(struct ata_port *ap, unsigned int *class)
 
1321         /* SATA hardreset fails to retrieve proper device signature on
 
1322          * some controllers.  Don't classify on hardreset.  For more
 
1323          * info, see http://bugme.osdl.org/show_bug.cgi?id=3352
 
1325         return sata_std_hardreset(ap, &dummy);
 
1328 static void nv_error_handler(struct ata_port *ap)
 
1330         ata_bmdma_drive_eh(ap, ata_std_prereset, ata_std_softreset,
 
1331                            nv_hardreset, ata_std_postreset);
 
1334 static void nv_adma_error_handler(struct ata_port *ap)
 
1336         struct nv_adma_port_priv *pp = ap->private_data;
 
1337         if(!(pp->flags & NV_ADMA_PORT_REGISTER_MODE)) {
 
1338                 void __iomem *mmio = nv_adma_ctl_block(ap);
 
1342                 u32 notifier = readl(mmio + NV_ADMA_NOTIFIER);
 
1343                 u32 notifier_error = readl(mmio + NV_ADMA_NOTIFIER_ERROR);
 
1344                 u32 gen_ctl = readl(nv_adma_gen_block(ap) + NV_ADMA_GEN_CTL);
 
1345                 u32 status = readw(mmio + NV_ADMA_STAT);
 
1347                 ata_port_printk(ap, KERN_ERR, "EH in ADMA mode, notifier 0x%X "
 
1348                         "notifier_error 0x%X gen_ctl 0x%X status 0x%X\n",
 
1349                         notifier, notifier_error, gen_ctl, status);
 
1351                 for( i=0;i<NV_ADMA_MAX_CPBS;i++) {
 
1352                         struct nv_adma_cpb *cpb = &pp->cpb[i];
 
1353                         if( cpb->ctl_flags || cpb->resp_flags )
 
1354                                 ata_port_printk(ap, KERN_ERR,
 
1355                                         "CPB %d: ctl_flags 0x%x, resp_flags 0x%x\n",
 
1356                                         i, cpb->ctl_flags, cpb->resp_flags);
 
1359                 /* Push us back into port register mode for error handling. */
 
1360                 nv_adma_register_mode(ap);
 
1362                 ata_port_printk(ap, KERN_ERR, "Resetting port\n");
 
1364                 /* Mark all of the CPBs as invalid to prevent them from being executed */
 
1365                 for( i=0;i<NV_ADMA_MAX_CPBS;i++)
 
1366                         pp->cpb[i].ctl_flags &= ~NV_CPB_CTL_CPB_VALID;
 
1368                 /* clear CPB fetch count */
 
1369                 writew(0, mmio + NV_ADMA_CPB_COUNT);
 
1372                 tmp = readw(mmio + NV_ADMA_CTL);
 
1373                 writew(tmp | NV_ADMA_CTL_CHANNEL_RESET, mmio + NV_ADMA_CTL);
 
1374                 readl( mmio + NV_ADMA_CTL );    /* flush posted write */
 
1376                 writew(tmp & ~NV_ADMA_CTL_CHANNEL_RESET, mmio + NV_ADMA_CTL);
 
1377                 readl( mmio + NV_ADMA_CTL );    /* flush posted write */
 
1380         ata_bmdma_drive_eh(ap, ata_std_prereset, ata_std_softreset,
 
1381                            nv_hardreset, ata_std_postreset);
 
1384 static int nv_init_one (struct pci_dev *pdev, const struct pci_device_id *ent)
 
1386         static int printed_version = 0;
 
1387         struct ata_port_info *ppi[2];
 
1388         struct ata_probe_ent *probe_ent;
 
1389         int pci_dev_busy = 0;
 
1393         unsigned long type = ent->driver_data;
 
1396         // Make sure this is a SATA controller by counting the number of bars
 
1397         // (NVIDIA SATA controllers will always have six bars).  Otherwise,
 
1398         // it's an IDE controller and we ignore it.
 
1399         for (bar=0; bar<6; bar++)
 
1400                 if (pci_resource_start(pdev, bar) == 0)
 
1403         if (    !printed_version++)
 
1404                 dev_printk(KERN_DEBUG, &pdev->dev, "version " DRV_VERSION "\n");
 
1406         rc = pci_enable_device(pdev);
 
1410         rc = pci_request_regions(pdev, DRV_NAME);
 
1413                 goto err_out_disable;
 
1416         if(type >= CK804 && adma_enabled) {
 
1417                 dev_printk(KERN_NOTICE, &pdev->dev, "Using ADMA mode\n");
 
1419                 if(!pci_set_dma_mask(pdev, DMA_64BIT_MASK) &&
 
1420                    !pci_set_consistent_dma_mask(pdev, DMA_64BIT_MASK))
 
1425                 rc = pci_set_dma_mask(pdev, ATA_DMA_MASK);
 
1427                         goto err_out_regions;
 
1428                 rc = pci_set_consistent_dma_mask(pdev, ATA_DMA_MASK);
 
1430                         goto err_out_regions;
 
1435         ppi[0] = ppi[1] = &nv_port_info[type];
 
1436         probe_ent = ata_pci_init_native_mode(pdev, ppi, ATA_PORT_PRIMARY | ATA_PORT_SECONDARY);
 
1438                 goto err_out_regions;
 
1440         probe_ent->mmio_base = pci_iomap(pdev, 5, 0);
 
1441         if (!probe_ent->mmio_base) {
 
1443                 goto err_out_free_ent;
 
1446         base = (unsigned long)probe_ent->mmio_base;
 
1448         probe_ent->port[0].scr_addr = base + NV_PORT0_SCR_REG_OFFSET;
 
1449         probe_ent->port[1].scr_addr = base + NV_PORT1_SCR_REG_OFFSET;
 
1451         /* enable SATA space for CK804 */
 
1452         if (type >= CK804) {
 
1455                 pci_read_config_byte(pdev, NV_MCP_SATA_CFG_20, ®val);
 
1456                 regval |= NV_MCP_SATA_CFG_20_SATA_SPACE_EN;
 
1457                 pci_write_config_byte(pdev, NV_MCP_SATA_CFG_20, regval);
 
1460         pci_set_master(pdev);
 
1463                 rc = nv_adma_host_init(probe_ent);
 
1465                         goto err_out_iounmap;
 
1468         rc = ata_device_add(probe_ent);
 
1470                 goto err_out_iounmap;
 
1477         pci_iounmap(pdev, probe_ent->mmio_base);
 
1481         pci_release_regions(pdev);
 
1484                 pci_disable_device(pdev);
 
1489 static void nv_ck804_host_stop(struct ata_host *host)
 
1491         struct pci_dev *pdev = to_pci_dev(host->dev);
 
1494         /* disable SATA space for CK804 */
 
1495         pci_read_config_byte(pdev, NV_MCP_SATA_CFG_20, ®val);
 
1496         regval &= ~NV_MCP_SATA_CFG_20_SATA_SPACE_EN;
 
1497         pci_write_config_byte(pdev, NV_MCP_SATA_CFG_20, regval);
 
1499         ata_pci_host_stop(host);
 
1502 static void nv_adma_host_stop(struct ata_host *host)
 
1504         struct pci_dev *pdev = to_pci_dev(host->dev);
 
1508         for (i = 0; i < host->n_ports; i++) {
 
1509                 void __iomem *mmio = __nv_adma_ctl_block(host->mmio_base, i);
 
1512                 /* disable interrupt */
 
1513                 tmp = readw(mmio + NV_ADMA_CTL);
 
1514                 writew(tmp & ~NV_ADMA_CTL_AIEN, mmio + NV_ADMA_CTL);
 
1517         /* disable ADMA on the ports */
 
1518         pci_read_config_dword(pdev, NV_MCP_SATA_CFG_20, &tmp32);
 
1519         tmp32 &= ~(NV_MCP_SATA_CFG_20_PORT0_EN |
 
1520                    NV_MCP_SATA_CFG_20_PORT0_PWB_EN |
 
1521                    NV_MCP_SATA_CFG_20_PORT1_EN |
 
1522                    NV_MCP_SATA_CFG_20_PORT1_PWB_EN);
 
1524         pci_write_config_dword(pdev, NV_MCP_SATA_CFG_20, tmp32);
 
1526         nv_ck804_host_stop(host);
 
1529 static int __init nv_init(void)
 
1531         return pci_register_driver(&nv_pci_driver);
 
1534 static void __exit nv_exit(void)
 
1536         pci_unregister_driver(&nv_pci_driver);
 
1539 module_init(nv_init);
 
1540 module_exit(nv_exit);
 
1541 module_param_named(adma, adma_enabled, bool, 0444);
 
1542 MODULE_PARM_DESC(adma, "Enable use of ADMA (Default: true)");