linux-ide.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Sergei Shtylyov <sshtylyov@mvista.com>
To: Joerg Dorchain <joerg@dorchain.net>
Cc: linux-ide@vger.kernel.org
Subject: Re: [Patch] Enable AHCI on certain ich chipsets
Date: Fri, 11 Feb 2011 15:27:04 +0300	[thread overview]
Message-ID: <4D552B18.8030808@ru.mvista.com> (raw)
In-Reply-To: <20110210192321.GB5778@Redstar.dorchain.net>

Hello.

On 10-02-2011 22:23, Joerg Dorchain wrote:

> On Wed, Feb 09, 2011 at 03:56:32PM +0300, Sergei Shtylyov wrote:
> [Several formal corrections]

> Should be addressed by this try.

>>> The patch to ahci.c is required for suspend/resume.

>>     Need a better description than thatl, I think...

> Well, then it is a bit longer story.

> During resume from suspend to ram, the kernel pci layer restores
> the registers for the SATA controller once, then says okay, and
> sets dev->state_saved = false. However, since the restore goes
> from highest address (the BARs [base address registers]) to
> lowest register, some of the higher registers are set as RO
> because according to the lower registers controller is in PIIX
> mode.  This patch introduces a workaround for
> this problem, hacking around the PCI API by setting pdev->state_saved = true
> before we do the restore.

> Admittingly, more testing would be welcome.

> Signed-Off-By: joerg Dorchain<joerg@dorchain.net>

    This only describes drivers/ata/ahci.c change. And looks like it should be 
in a patch of its own...

> --- linux/drivers/pci/quirks.c.orig	2011-02-04 18:29:03.000000000 +0100
> +++ linux/drivers/pci/quirks.c	2011-02-09 14:40:15.000000000 +0100
> @@ -2684,6 +2684,76 @@
[...]
> +static void ich789_force_ahci_mode(struct pci_dev *pdev)
> +{
> +        u8 amrval;
> +        u8 sclkgc;
> +        const int ich89_address_map_reg = 0x90;
> +        const int ich89_sata_clock_gen_config_reg = 0x9c;

    You indent with spaces instead of tab here.

> +
> +	if (!ich_force_ahci_mode)
> +		return;
> +
> +        /* ICH8 datasheet section 12.1.33 */
> +        if (!pci_bus_read_config_byte(pdev->bus, PCI_DEVFN(PCI_SLOT(pdev->devfn), 2),
> +        	ich89_address_map_reg, &amrval))

    You again indent with spaces...

> +	{

    I've clearly said that { should be on the same line as the end of *if* 
statement.

> +                if (amrval & (BIT(6) | BIT(7))) {
> +                        dev_printk(KERN_DEBUG, &pdev->dev,
> +                                        "ICH7/8/9 SATA controller not in IDE mode.  Not modifying.\n");
> +                        return;
> +                }
> +                if (amrval & (BIT(0) | BIT(1)))
> +                        dev_printk(KERN_DEBUG, &pdev->dev,
> +                                        "ICH7/8/9 in SATA/PATA combined mode.  Untested.\n");
> +                /* AHCI mode */
> +                amrval |= BIT(6);
> +                amrval &= ~BIT(7);
> +                pci_bus_read_config_byte(pdev->bus, PCI_DEVFN(PCI_SLOT(pdev->devfn), 2),
> +                                ich89_sata_clock_gen_config_reg, &sclkgc);
> +                dev_printk(KERN_DEBUG, &pdev->dev, "sclkgc is %#0x\n", sclkgc);
> +                pci_bus_write_config_byte(pdev->bus, PCI_DEVFN(PCI_SLOT(pdev->devfn), 2),
> +                                ich89_address_map_reg, amrval);
> +                ich_ahci_mode_forced = true;
> +                dev_printk(KERN_DEBUG, &pdev->dev, "Forced ICH7/8/9 mode PIIX->AHCI\n");

    Again indented with spaces...

> +        }
> +

    Empty line not needed...

> +}

> --- linux/drivers/ata/ahci.c.orig	2011-02-04 18:13:33.000000000 +0100
> +++ linux/drivers/ata/ahci.c	2011-02-09 14:30:06.000000000 +0100
> @@ -640,6 +640,9 @@
>   	struct ata_host *host = dev_get_drvdata(&pdev->dev);
>   	int rc;
>
> +	/* override check to see if PCI config space is already
> +	 * restored in pci_restore_state */

    The preferred style for the multi-line comments is this:

/*
  * bla
  * bla
  */

WBR, Sergei

  reply	other threads:[~2011-02-11 12:28 UTC|newest]

Thread overview: 9+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2011-02-09 11:59 [Patch] Enable AHCI on certain ich chipsets Joerg Dorchain
2011-02-09 12:56 ` Sergei Shtylyov
2011-02-10 19:23   ` Joerg Dorchain
2011-02-11 12:27     ` Sergei Shtylyov [this message]
2011-02-11 17:36       ` Joerg Dorchain
2011-02-11 20:50         ` Sergei Shtylyov
2011-02-12  6:27           ` Joerg Dorchain
2011-02-12 12:09             ` Bartlomiej Zolnierkiewicz
2011-02-14  7:41               ` Joerg Dorchain

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=4D552B18.8030808@ru.mvista.com \
    --to=sshtylyov@mvista.com \
    --cc=joerg@dorchain.net \
    --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).