cregit-Linux how code gets into the kernel

Release 4.7 drivers/ata/pata_hpt3x3.c

Directory: drivers/ata
/*
 *      pata_hpt3x3             -       HPT3x3 driver
 *      (c) Copyright 2005-2006 Red Hat
 *
 *      Was pata_hpt34x but the naming was confusing as it supported the
 *      343 and 363 so it has been renamed.
 *
 *      Based on:
 *      linux/drivers/ide/pci/hpt34x.c          Version 0.40    Sept 10, 2002
 *      Copyright (C) 1998-2000 Andre Hedrick <andre@linux-ide.org>
 *
 *      May be copied or modified under the terms of the GNU General Public
 *      License
 */

#include <linux/kernel.h>
#include <linux/module.h>
#include <linux/pci.h>
#include <linux/blkdev.h>
#include <linux/delay.h>
#include <scsi/scsi_host.h>
#include <linux/libata.h>


#define DRV_NAME	"pata_hpt3x3"

#define DRV_VERSION	"0.6.1"

/**
 *      hpt3x3_set_piomode              -       PIO setup
 *      @ap: ATA interface
 *      @adev: device on the interface
 *
 *      Set our PIO requirements. This is fairly simple on the HPT3x3 as
 *      all we have to do is clear the MWDMA and UDMA bits then load the
 *      mode number.
 */


static void hpt3x3_set_piomode(struct ata_port *ap, struct ata_device *adev) { struct pci_dev *pdev = to_pci_dev(ap->host->dev); u32 r1, r2; int dn = 2 * ap->port_no + adev->devno; pci_read_config_dword(pdev, 0x44, &r1); pci_read_config_dword(pdev, 0x48, &r2); /* Load the PIO timing number */ r1 &= ~(7 << (3 * dn)); r1 |= (adev->pio_mode - XFER_PIO_0) << (3 * dn); r2 &= ~(0x11 << dn); /* Clear MWDMA and UDMA bits */ pci_write_config_dword(pdev, 0x44, r1); pci_write_config_dword(pdev, 0x48, r2); }

Contributors

PersonTokensPropCommitsCommitProp
jeff garzikjeff garzik126100.00%1100.00%
Total126100.00%1100.00%

#if defined(CONFIG_PATA_HPT3X3_DMA) /** * hpt3x3_set_dmamode - DMA timing setup * @ap: ATA interface * @adev: Device being configured * * Set up the channel for MWDMA or UDMA modes. Much the same as with * PIO, load the mode number and then set MWDMA or UDMA flag. * * 0x44 : bit 0-2 master mode, 3-5 slave mode, etc * 0x48 : bit 4/0 DMA/UDMA bit 5/1 for slave etc */
static void hpt3x3_set_dmamode(struct ata_port *ap, struct ata_device *adev) { struct pci_dev *pdev = to_pci_dev(ap->host->dev); u32 r1, r2; int dn = 2 * ap->port_no + adev->devno; int mode_num = adev->dma_mode & 0x0F; pci_read_config_dword(pdev, 0x44, &r1); pci_read_config_dword(pdev, 0x48, &r2); /* Load the timing number */ r1 &= ~(7 << (3 * dn)); r1 |= (mode_num << (3 * dn)); r2 &= ~(0x11 << dn); /* Clear MWDMA and UDMA bits */ if (adev->dma_mode >= XFER_UDMA_0) r2 |= (0x01 << dn); /* Ultra mode */ else r2 |= (0x10 << dn); /* MWDMA */ pci_write_config_dword(pdev, 0x44, r1); pci_write_config_dword(pdev, 0x48, r2); }

Contributors

PersonTokensPropCommitsCommitProp
jeff garzikjeff garzik15296.20%133.33%
alan coxalan cox63.80%266.67%
Total158100.00%3100.00%

/** * hpt3x3_freeze - DMA workaround * @ap: port to freeze * * When freezing an HPT3x3 we must stop any pending DMA before * writing to the control register or the chip will hang */
static void hpt3x3_freeze(struct ata_port *ap) { void __iomem *mmio = ap->ioaddr.bmdma_addr; iowrite8(ioread8(mmio + ATA_DMA_CMD) & ~ ATA_DMA_START, mmio + ATA_DMA_CMD); ata_sff_dma_pause(ap); ata_sff_freeze(ap); }

Contributors

PersonTokensPropCommitsCommitProp
alan coxalan cox4897.96%150.00%
jeff garzikjeff garzik12.04%150.00%
Total49100.00%2100.00%

/** * hpt3x3_bmdma_setup - DMA workaround * @qc: Queued command * * When issuing BMDMA we must clean up the error/active bits in * software on this device */
static void hpt3x3_bmdma_setup(struct ata_queued_cmd *qc) { struct ata_port *ap = qc->ap; u8 r = ioread8(ap->ioaddr.bmdma_addr + ATA_DMA_STATUS); r |= ATA_DMA_INTR | ATA_DMA_ERR; iowrite8(r, ap->ioaddr.bmdma_addr + ATA_DMA_STATUS); return ata_bmdma_setup(qc); }

Contributors

PersonTokensPropCommitsCommitProp
alan coxalan cox59100.00%1100.00%
Total59100.00%1100.00%

/** * hpt3x3_atapi_dma - ATAPI DMA check * @qc: Queued command * * Just say no - we don't do ATAPI DMA */
static int hpt3x3_atapi_dma(struct ata_queued_cmd *qc) { return 1; }

Contributors

PersonTokensPropCommitsCommitProp
alan coxalan cox14100.00%1100.00%
Total14100.00%1100.00%

#endif /* CONFIG_PATA_HPT3X3_DMA */ static struct scsi_host_template hpt3x3_sht = { ATA_BMDMA_SHT(DRV_NAME), }; static struct ata_port_operations hpt3x3_port_ops = { .inherits = &ata_bmdma_port_ops, .cable_detect = ata_cable_40wire, .set_piomode = hpt3x3_set_piomode, #if defined(CONFIG_PATA_HPT3X3_DMA) .set_dmamode = hpt3x3_set_dmamode, .bmdma_setup = hpt3x3_bmdma_setup, .check_atapi_dma= hpt3x3_atapi_dma, .freeze = hpt3x3_freeze, #endif }; /** * hpt3x3_init_chipset - chip setup * @dev: PCI device * * Perform the setup required at boot and on resume. */
static void hpt3x3_init_chipset(struct pci_dev *dev) { u16 cmd; /* Initialize the board */ pci_write_config_word(dev, 0x80, 0x00); /* Check if it is a 343 or a 363. 363 has COMMAND_MEMORY set */ pci_read_config_word(dev, PCI_COMMAND, &cmd); if (cmd & PCI_COMMAND_MEMORY) pci_write_config_byte(dev, PCI_LATENCY_TIMER, 0xF0); else pci_write_config_byte(dev, PCI_LATENCY_TIMER, 0x20); }

Contributors

PersonTokensPropCommitsCommitProp
alan coxalan cox60100.00%1100.00%
Total60100.00%1100.00%

/** * hpt3x3_init_one - Initialise an HPT343/363 * @pdev: PCI device * @id: Entry in match table * * Perform basic initialisation. We set the device up so we access all * ports via BAR4. This is necessary to work around errata. */
static int hpt3x3_init_one(struct pci_dev *pdev, const struct pci_device_id *id) { static const struct ata_port_info info = { .flags = ATA_FLAG_SLAVE_POSS, .pio_mask = ATA_PIO4, #if defined(CONFIG_PATA_HPT3X3_DMA) /* Further debug needed */ .mwdma_mask = ATA_MWDMA2, .udma_mask = ATA_UDMA2, #endif .port_ops = &hpt3x3_port_ops }; /* Register offsets of taskfiles in BAR4 area */ static const u8 offset_cmd[2] = { 0x20, 0x28 }; static const u8 offset_ctl[2] = { 0x36, 0x3E }; const struct ata_port_info *ppi[] = { &info, NULL }; struct ata_host *host; int i, rc; void __iomem *base; hpt3x3_init_chipset(pdev); ata_print_version_once(&pdev->dev, DRV_VERSION); host = ata_host_alloc_pinfo(&pdev->dev, ppi, 2); if (!host) return -ENOMEM; /* acquire resources and fill host */ rc = pcim_enable_device(pdev); if (rc) return rc; /* Everything is relative to BAR4 if we set up this way */ rc = pcim_iomap_regions(pdev, 1 << 4, DRV_NAME); if (rc == -EBUSY) pcim_pin_device(pdev); if (rc) return rc; host->iomap = pcim_iomap_table(pdev); rc = dma_set_mask(&pdev->dev, ATA_DMA_MASK); if (rc) return rc; rc = dma_set_coherent_mask(&pdev->dev, ATA_DMA_MASK); if (rc) return rc; base = host->iomap[4]; /* Bus mastering base */ for (i = 0; i < host->n_ports; i++) { struct ata_port *ap = host->ports[i]; struct ata_ioports *ioaddr = &ap->ioaddr; ioaddr->cmd_addr = base + offset_cmd[i]; ioaddr->altstatus_addr = ioaddr->ctl_addr = base + offset_ctl[i]; ioaddr->scr_addr = NULL; ata_sff_std_ports(ioaddr); ioaddr->bmdma_addr = base + 8 * i; ata_port_pbar_desc(ap, 4, -1, "ioport"); ata_port_pbar_desc(ap, 4, offset_cmd[i], "cmd"); } pci_set_master(pdev); return ata_host_activate(host, pdev->irq, ata_bmdma_interrupt, IRQF_SHARED, &hpt3x3_sht); }

Contributors

PersonTokensPropCommitsCommitProp
alan coxalan cox27669.87%220.00%
jeff garzikjeff garzik6315.95%110.00%
tejun heotejun heo4411.14%440.00%
quentin lambertquentin lambert82.03%110.00%
erik inge bolsoerik inge bolso30.76%110.00%
joe perchesjoe perches10.25%110.00%
Total395100.00%10100.00%

#ifdef CONFIG_PM_SLEEP
static int hpt3x3_reinit_one(struct pci_dev *dev) { struct ata_host *host = pci_get_drvdata(dev); int rc; rc = ata_pci_device_do_resume(dev); if (rc) return rc; hpt3x3_init_chipset(dev); ata_host_resume(host); return 0; }

Contributors

PersonTokensPropCommitsCommitProp
bartlomiej zolnierkiewiczbartlomiej zolnierkiewicz3058.82%125.00%
jeff garzikjeff garzik1121.57%125.00%
alan coxalan cox917.65%125.00%
jingoo hanjingoo han11.96%125.00%
Total51100.00%4100.00%

#endif static const struct pci_device_id hpt3x3[] = { { PCI_VDEVICE(TTI, PCI_DEVICE_ID_TTI_HPT343), }, { }, }; static struct pci_driver hpt3x3_pci_driver = { .name = DRV_NAME, .id_table = hpt3x3, .probe = hpt3x3_init_one, .remove = ata_pci_remove_one, #ifdef CONFIG_PM_SLEEP .suspend = ata_pci_device_suspend, .resume = hpt3x3_reinit_one, #endif }; module_pci_driver(hpt3x3_pci_driver); MODULE_AUTHOR("Alan Cox"); MODULE_DESCRIPTION("low-level driver for the Highpoint HPT343/363"); MODULE_LICENSE("GPL"); MODULE_DEVICE_TABLE(pci, hpt3x3); MODULE_VERSION(DRV_VERSION);

Overall Contributors

PersonTokensPropCommitsCommitProp
alan coxalan cox50645.10%313.04%
jeff garzikjeff garzik49944.47%417.39%
tejun heotejun heo706.24%834.78%
bartlomiej zolnierkiewiczbartlomiej zolnierkiewicz322.85%28.70%
quentin lambertquentin lambert80.71%14.35%
erik inge bolsoerik inge bolso30.27%14.35%
jingoo hanjingoo han10.09%14.35%
joe perchesjoe perches10.09%14.35%
daniel mackdaniel mack10.09%14.35%
axel linaxel lin10.09%14.35%
Total1122100.00%23100.00%
Directory: drivers/ata
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
{% endraw %}