linux-ide.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Mark Lord <liml@rtr.ca>
To: Jeff Garzik <jgarzik@pobox.com>
Cc: Tejun Heo <htejun@gmail.com>,
	IDE/ATA development list <linux-ide@vger.kernel.org>
Subject: Re: [PATCH] sata_mv rework hardreset sequence
Date: Tue, 15 Apr 2008 21:17:41 -0400	[thread overview]
Message-ID: <480553B5.30507@rtr.ca> (raw)
In-Reply-To: <47FEAF13.5050605@rtr.ca>

Mark Lord wrote:
> Jeff Garzik wrote:
>> Mark Lord wrote:
>>> Remove the now unused mv_phy_reset() code,
>>> as well as the unnecessary mv_postreset() function.
>>>
>>> Signed-off-by: Mark Lord <mlord@pobox.com>
>>
>> ACK patches 4-5
>>
>> However, I would prefer to finish merging Tejun's honkin' huge 
>> modularize patchsets, and then request that you rediff&resend sata_mv 
>> patches 4 and 5
> 
> 
> This patch replaces the earlier patches 04/05.
..

Jeff -- drop this patch for now.
I'll resubmit it as part of the upcoming PMP patches.

Thanks



> 
> * * *
> 
> Rework and simplify sata_mv's hardreset code to take advantage
> of libata improvements since it was first coded.
> 
> Also, get rid of the now unnecessary prereset, postreset, and phy_reset 
> functions.
> 
> This patch also paves the way for subsequent pmp support patches,
> which will follow once this one passes muster.
> 
> Signed-off-by: Mark Lord <mlord@pobox.com>
> 
> --- upstream/linux/drivers/ata/sata_mv.c    2008-04-10 
> 14:30:27.000000000 -0400
> +++ new/linux/drivers/ata/sata_mv.c    2008-04-10 14:31:01.000000000 -0400
> @@ -478,10 +478,8 @@
> static void mv_qc_prep(struct ata_queued_cmd *qc);
> static void mv_qc_prep_iie(struct ata_queued_cmd *qc);
> static unsigned int mv_qc_issue(struct ata_queued_cmd *qc);
> -static int mv_prereset(struct ata_link *link, unsigned long deadline);
> static int mv_hardreset(struct ata_link *link, unsigned int *class,
>             unsigned long deadline);
> -static void mv_postreset(struct ata_link *link, unsigned int *classes);
> static void mv_eh_freeze(struct ata_port *ap);
> static void mv_eh_thaw(struct ata_port *ap);
> static void mv6_dev_config(struct ata_device *dev);
> @@ -545,9 +543,7 @@
> 
>     .freeze            = mv_eh_freeze,
>     .thaw            = mv_eh_thaw,
> -    .prereset        = mv_prereset,
>     .hardreset        = mv_hardreset,
> -    .postreset        = mv_postreset,
>     .error_handler        = ata_std_error_handler, /* avoid SFF EH */
>     .post_internal_cmd    = ATA_OP_NULL,
> 
> @@ -1904,7 +1900,6 @@
>      * (but doesn't say what the problem might be).  So we first try
>      * to disable the EDMA engine before doing the ATA_RST operation.
>      */
> -    mv_stop_edma_engine(port_mmio);
>     mv_reset_channel(hpriv, mmio, port);
> 
>     ZERO(0x028);    /* command */
> @@ -2184,7 +2179,6 @@
>      * (but doesn't say what the problem might be).  So we first try
>      * to disable the EDMA engine before doing the ATA_RST operation.
>      */
> -    mv_stop_edma_engine(port_mmio);
>     mv_reset_channel(hpriv, mmio, port);
> 
>     ZERO(0x028);        /* command */
> @@ -2261,6 +2255,7 @@
> {
>     void __iomem *port_mmio = mv_port_base(mmio, port_no);
> 
> +    mv_stop_edma_engine(port_mmio);
>     writelfl(ATA_RST, port_mmio + EDMA_CMD_OFS);
> 
>     if (!IS_GEN_I(hpriv)) {
> @@ -2282,116 +2277,6 @@
>         mdelay(1);
> }
> 
> -/**
> - *      mv_phy_reset - Perform eDMA reset followed by COMRESET
> - *      @ap: ATA channel to manipulate
> - *
> - *      Part of this is taken from __sata_phy_reset and modified to
> - *      not sleep since this routine gets called from interrupt level.
> - *
> - *      LOCKING:
> - *      Inherited from caller.  This is coded to safe to call at
> - *      interrupt level, i.e. it does not sleep.
> - */
> -static void mv_phy_reset(struct ata_port *ap, unsigned int *class,
> -             unsigned long deadline)
> -{
> -    struct mv_port_priv *pp    = ap->private_data;
> -    struct mv_host_priv *hpriv = ap->host->private_data;
> -    void __iomem *port_mmio = mv_ap_base(ap);
> -    int retry = 5;
> -    u32 sstatus;
> -
> -    VPRINTK("ENTER, port %u, mmio 0x%p\n", ap->port_no, port_mmio);
> -
> -#ifdef DEBUG
> -    {
> -        u32 sstatus, serror, scontrol;
> -
> -        mv_scr_read(ap, SCR_STATUS, &sstatus);
> -        mv_scr_read(ap, SCR_ERROR, &serror);
> -        mv_scr_read(ap, SCR_CONTROL, &scontrol);
> -        DPRINTK("S-regs after ATA_RST: SStat 0x%08x SErr 0x%08x "
> -            "SCtrl 0x%08x\n", sstatus, serror, scontrol);
> -    }
> -#endif
> -
> -    /* Issue COMRESET via SControl */
> -comreset_retry:
> -    sata_scr_write_flush(&ap->link, SCR_CONTROL, 0x301);
> -    msleep(1);
> -
> -    sata_scr_write_flush(&ap->link, SCR_CONTROL, 0x300);
> -    msleep(20);
> -
> -    do {
> -        sata_scr_read(&ap->link, SCR_STATUS, &sstatus);
> -        if (((sstatus & 0x3) == 3) || ((sstatus & 0x3) == 0))
> -            break;
> -
> -        msleep(1);
> -    } while (time_before(jiffies, deadline));
> -
> -    /* work around errata */
> -    if (IS_GEN_II(hpriv) &&
> -        (sstatus != 0x0) && (sstatus != 0x113) && (sstatus != 0x123) &&
> -        (retry-- > 0))
> -        goto comreset_retry;
> -
> -#ifdef DEBUG
> -    {
> -        u32 sstatus, serror, scontrol;
> -
> -        mv_scr_read(ap, SCR_STATUS, &sstatus);
> -        mv_scr_read(ap, SCR_ERROR, &serror);
> -        mv_scr_read(ap, SCR_CONTROL, &scontrol);
> -        DPRINTK("S-regs after PHY wake: SStat 0x%08x SErr 0x%08x "
> -            "SCtrl 0x%08x\n", sstatus, serror, scontrol);
> -    }
> -#endif
> -
> -    if (ata_link_offline(&ap->link)) {
> -        *class = ATA_DEV_NONE;
> -        return;
> -    }
> -
> -    /* even after SStatus reflects that device is ready,
> -     * it seems to take a while for link to be fully
> -     * established (and thus Status no longer 0x80/0x7F),
> -     * so we poll a bit for that, here.
> -     */
> -    retry = 20;
> -    while (1) {
> -        u8 drv_stat = ata_sff_check_status(ap);
> -        if ((drv_stat != 0x80) && (drv_stat != 0x7f))
> -            break;
> -        msleep(500);
> -        if (retry-- <= 0)
> -            break;
> -        if (time_after(jiffies, deadline))
> -            break;
> -    }
> -
> -    /* FIXME: if we passed the deadline, the following
> -     * code probably produces an invalid result
> -     */
> -
> -    /* finally, read device signature from TF registers */
> -    *class = ata_sff_dev_classify(ap->link.device, 1, NULL);
> -
> -    writelfl(0, port_mmio + EDMA_ERR_IRQ_CAUSE_OFS);
> -
> -    WARN_ON(pp->pp_flags & MV_PP_FLAG_EDMA_EN);
> -
> -    VPRINTK("EXIT\n");
> -}
> -
> -static int mv_prereset(struct ata_link *link, unsigned long deadline)
> -{
> -    mv_stop_edma(link->ap);
> -    return 0;
> -}
> -
> static int mv_hardreset(struct ata_link *link, unsigned int *class,
>             unsigned long deadline)
> {
> @@ -2399,34 +2284,33 @@
>     struct mv_host_priv *hpriv = ap->host->private_data;
>     struct mv_port_priv *pp = ap->private_data;
>     void __iomem *mmio = hpriv->base;
> +    int rc, attempts = 0, extra = 0;
> +    u32 sstatus;
> +    bool online;
> 
>     mv_reset_channel(hpriv, mmio, ap->port_no);
>     pp->pp_flags &= ~MV_PP_FLAG_EDMA_EN;
> -    mv_phy_reset(ap, class, deadline);
> -
> -    return 0;
> -}
> -
> -static void mv_postreset(struct ata_link *link, unsigned int *classes)
> -{
> -    struct ata_port *ap = link->ap;
> -    u32 serr;
> 
> -    /* print link status */
> -    sata_print_link_status(link);
> +    /* Workaround for errata FEr SATA#10 (part 2) */
> +    do {
> +        const unsigned long *timing = 
> sata_ehc_deb_timing(&link->eh_context);
> 
> -    /* clear SError */
> -    sata_scr_read(link, SCR_ERROR, &serr);
> -    sata_scr_write_flush(link, SCR_ERROR, serr);
> -
> -    /* bail out if no device is present */
> -    if (classes[0] == ATA_DEV_NONE && classes[1] == ATA_DEV_NONE) {
> -        DPRINTK("EXIT, no device\n");
> -        return;
> -    }
> +        rc = sata_link_hardreset(link, timing, deadline + extra, 
> &online, NULL);
> +        if (rc) {
> +            ata_link_printk(link, KERN_ERR,
> +                    "COMRESET failed (errno=%d)\n", rc);
> +            return rc;
> +        }
> +        sata_scr_read(link, SCR_STATUS, &sstatus);
> +        if (!IS_GEN_I(hpriv) && ++attempts >= 5 && sstatus == 0x121) {
> +            /* Force 1.5gb/s link speed and try again */
> +            mv_setup_ifctl(mv_ap_base(ap), 0);
> +            if (time_after(jiffies + HZ, deadline))
> +                extra = HZ; /* only extend it once, max */
> +        }
> +    } while (sstatus != 0x0 && sstatus != 0x113 && sstatus != 0x123);
> 
> -    /* set up device control */
> -    iowrite8(ap->ctl, ap->ioaddr.ctl_addr);
> +    return online ? -EAGAIN : rc;
> }
> 
> static void mv_eh_freeze(struct ata_port *ap)


      reply	other threads:[~2008-04-16  1:17 UTC|newest]

Thread overview: 30+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2008-03-31 23:27 [PATCH 0/5] sata_mv cleanups Mark Lord
2008-03-31 23:33 ` [PATCH 1/5] sata_mv cosmetic fixes Mark Lord
2008-04-04  7:56   ` Jeff Garzik
2008-03-31 23:34 ` [PATCH 2/5] sata_mv clean up mv_stop_edma usage Mark Lord
2008-04-02  1:59   ` Tejun Heo
2008-04-02 19:33     ` Mark Lord
2008-04-02 19:42       ` Jeff Garzik
2008-04-02 19:47         ` Mark Lord
2008-04-03  0:47           ` Tejun Heo
2008-04-04  7:59   ` Jeff Garzik
2008-03-31 23:35 ` [PATCH 3/5] sata_mv fix ifctl handling Mark Lord
2008-03-31 23:35 ` [PATCH 4/5] sata_mv new mv_sata_hardreset handler Mark Lord
2008-04-02  2:31   ` Tejun Heo
2008-04-02 19:33     ` Mark Lord
2008-04-02 19:51     ` Mark Lord
2008-04-03  0:49       ` Tejun Heo
2008-04-03  2:48         ` Mark Lord
2008-04-03  3:15           ` Tejun Heo
2008-04-03 14:01             ` Mark Lord
2008-04-03 14:04               ` Mark Lord
2008-04-03 14:09                 ` Tejun Heo
2008-04-03 14:21                   ` Mark Lord
2008-04-03 14:35                     ` Tejun Heo
2008-04-03 15:05                       ` Mark Lord
2008-04-03 14:05               ` Tejun Heo
2008-03-31 23:36 ` [PATCH 5/5] sata_mv remove mv_phy_reset and mv_postreset Mark Lord
2008-04-04  8:02   ` Jeff Garzik
2008-04-04 14:25     ` Mark Lord
2008-04-11  0:21     ` [PATCH] sata_mv rework hardreset sequence Mark Lord
2008-04-16  1:17       ` Mark Lord [this message]

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=480553B5.30507@rtr.ca \
    --to=liml@rtr.ca \
    --cc=htejun@gmail.com \
    --cc=jgarzik@pobox.com \
    --cc=linux-ide@vger.kernel.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).