Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 294055
b: refs/heads/master
c: 419fd24
h: refs/heads/master
i:
  294053: d6119d7
  294051: b621c4c
  294047: 3b8cde2
v: v3
  • Loading branch information
Sergei Shtylyov authored and Jeff Garzik committed Mar 13, 2012
1 parent fc54e06 commit e5735ec
Show file tree
Hide file tree
Showing 2 changed files with 16 additions and 17 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 8a686bc984454c1eba6788d0d97dec72ad87f052
refs/heads/master: 419fd2461354f7675ef298fa26ffceff4d0b2168
31 changes: 15 additions & 16 deletions trunk/drivers/ata/pata_cmd64x.c
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,7 @@
#include <linux/libata.h>

#define DRV_NAME "pata_cmd64x"
#define DRV_VERSION "0.2.16"
#define DRV_VERSION "0.2.17"

/*
* CMD64x specific registers definition.
Expand Down Expand Up @@ -230,41 +230,39 @@ static void cmd64x_set_dmamode(struct ata_port *ap, struct ata_device *adev)
}

/**
* cmd64x_bmdma_stop - DMA stop callback
* @qc: Command in progress
* cmd64x_sff_irq_clear - clear IDE interrupt
* @ap: ATA interface
*
* DMA has completed.
* Clear IDE interrupt in CFR/ARTTIM23 and DMA status registers.
*/

static void cmd64x_bmdma_stop(struct ata_queued_cmd *qc)
static void cmd64x_sff_irq_clear(struct ata_port *ap)
{
struct ata_port *ap = qc->ap;
struct pci_dev *pdev = to_pci_dev(ap->host->dev);
int irq_reg = ap->port_no ? ARTTIM23 : CFR;
u8 irq_stat;

ata_bmdma_stop(qc);
ata_bmdma_irq_clear(ap);

/* Reading the register should be enough to clear the interrupt */
pci_read_config_byte(pdev, irq_reg, &irq_stat);
}

/**
* cmd648_bmdma_stop - DMA stop callback
* @qc: Command in progress
* cmd648_sff_irq_clear - clear IDE interrupt
* @ap: ATA interface
*
* DMA has completed.
* Clear IDE interrupt in MRDMODE and DMA status registers.
*/

static void cmd648_bmdma_stop(struct ata_queued_cmd *qc)
static void cmd648_sff_irq_clear(struct ata_port *ap)
{
struct ata_port *ap = qc->ap;
struct pci_dev *pdev = to_pci_dev(ap->host->dev);
unsigned long base = pci_resource_start(pdev, 4);
int irq_mask = ap->port_no ? MRDMODE_INTR_CH1 : MRDMODE_INTR_CH0;
u8 mrdmode;

ata_bmdma_stop(qc);
ata_bmdma_irq_clear(ap);

/* Clear this port's interrupt bit (leaving the other port alone) */
mrdmode = inb(base + 1);
Expand Down Expand Up @@ -296,25 +294,26 @@ static const struct ata_port_operations cmd64x_base_ops = {

static struct ata_port_operations cmd64x_port_ops = {
.inherits = &cmd64x_base_ops,
.bmdma_stop = cmd64x_bmdma_stop,
.sff_irq_clear = cmd64x_sff_irq_clear,
.cable_detect = ata_cable_40wire,
};

static struct ata_port_operations cmd646r1_port_ops = {
.inherits = &cmd64x_base_ops,
.sff_irq_clear = cmd64x_sff_irq_clear,
.bmdma_stop = cmd646r1_bmdma_stop,
.cable_detect = ata_cable_40wire,
};

static struct ata_port_operations cmd646r3_port_ops = {
.inherits = &cmd64x_base_ops,
.bmdma_stop = cmd648_bmdma_stop,
.sff_irq_clear = cmd648_sff_irq_clear,
.cable_detect = ata_cable_40wire,
};

static struct ata_port_operations cmd648_port_ops = {
.inherits = &cmd64x_base_ops,
.bmdma_stop = cmd648_bmdma_stop,
.sff_irq_clear = cmd648_sff_irq_clear,
.cable_detect = cmd648_cable_detect,
};

Expand Down

0 comments on commit e5735ec

Please sign in to comment.