All of lore.kernel.org
 help / color / mirror / Atom feed
From: Bin Meng <bmeng.cn@gmail.com>
To: u-boot@lists.denx.de
Subject: [U-Boot] [PATCH 7/7] dm: x86: spi: Convert ICH SPI driver to driver model PCI API
Date: Tue, 8 Dec 2015 21:24:36 +0800	[thread overview]
Message-ID: <CAEUhbmWXH+5C4wjPnT8=dQqfX=XwcMa0Vpy3x5NH5Wpk-aT2Sg@mail.gmail.com> (raw)
In-Reply-To: <1448943086-1079-8-git-send-email-sjg@chromium.org>

Hi Simon,

On Tue, Dec 1, 2015 at 12:11 PM, Simon Glass <sjg@chromium.org> wrote:
> At present this SPI driver works by searching the PCI buses for its
> peripheral. It also uses the legacy PCI API.
>
> In addition the driver has code to determine the type of Intel PCH that is
> used (version 7 or version 9). Now that we have proper PCH drivers we can
> use those to obtain the information we need.
>
> While the device tree has a node for the SPI peripheral it is not in the
> right place. It should be on the PCI bus as a sub-peripheral of the LPC
> device.
>
> Update the device tree files to show the SPI controller within the PCH, so
> that PCI access works as expected.
>
> Signed-off-by: Simon Glass <sjg@chromium.org>
> ---
>
>  arch/x86/cpu/irq.c                  |   7 +-
>  arch/x86/cpu/ivybridge/bd82x6x.c    |  11 +++
>  arch/x86/dts/bayleybay.dts          | 160 +++++++++++++++++++-----------------
>  arch/x86/dts/broadwell_som-6896.dts |  23 ++++--
>  arch/x86/dts/chromebook_link.dts    |   3 +-
>  arch/x86/dts/chromebox_panther.dts  |  33 ++++----
>  arch/x86/dts/crownbay.dts           | 150 +++++++++++++++++----------------
>  arch/x86/dts/galileo.dts            |  98 +++++++++++-----------
>  arch/x86/dts/minnowmax.dts          | 158 ++++++++++++++++++-----------------
>  arch/x86/dts/qemu-x86_i440fx.dts    |  26 +++---
>  arch/x86/dts/qemu-x86_q35.dts       |  38 +++++----
>  drivers/spi/ich.c                   | 115 ++++++--------------------
>  12 files changed, 409 insertions(+), 413 deletions(-)
>
> diff --git a/arch/x86/cpu/irq.c b/arch/x86/cpu/irq.c
> index 35b29f6..205405b 100644
> --- a/arch/x86/cpu/irq.c
> +++ b/arch/x86/cpu/irq.c
> @@ -97,6 +97,7 @@ static int create_pirq_routing_table(void)
>         struct irq_routing_table *rt;
>         struct irq_info *slot, *slot_base;
>         int irq_entries = 0;
> +       int parent;
>         int i;
>         int ret;
>
> @@ -106,7 +107,11 @@ static int create_pirq_routing_table(void)
>                 return -EINVAL;
>         }
>
> -       ret = fdtdec_get_pci_addr(blob, node, FDT_PCI_SPACE_CONFIG,
> +       /* TODO(sjg at chromium.org): Drop this when PIRQ is a driver */
> +       parent = fdt_parent_offset(blob, node);
> +       if (parent < 0)
> +               return -EINVAL;
> +       ret = fdtdec_get_pci_addr(blob, parent, FDT_PCI_SPACE_CONFIG,
>                                   "reg", &addr);
>         if (ret)
>                 return ret;
> diff --git a/arch/x86/cpu/ivybridge/bd82x6x.c b/arch/x86/cpu/ivybridge/bd82x6x.c
> index 434dfd6..abd59da 100644
> --- a/arch/x86/cpu/ivybridge/bd82x6x.c
> +++ b/arch/x86/cpu/ivybridge/bd82x6x.c
> @@ -9,6 +9,7 @@
>  #include <errno.h>
>  #include <fdtdec.h>
>  #include <malloc.h>
> +#include <pch.h>
>  #include <asm/lapic.h>
>  #include <asm/pci.h>
>  #include <asm/arch/bd82x6x.h>
> @@ -116,6 +117,15 @@ int bd82x6x_init(void)

Should this bd82x6x_init() be moved to init op of the pch driver?

>         return 0;
>  }
>
> +static int bd82x6x_pch_get_version(struct udevice *dev)
> +{
> +       return 9;
> +}
> +
> +static const struct pch_ops bd82x6x_pch_ops = {
> +       .get_version    = bd82x6x_pch_get_version,
> +};
> +
>  static const struct udevice_id bd82x6x_ids[] = {
>         { .compatible = "intel,bd82x6x" },
>         { }
> @@ -126,4 +136,5 @@ U_BOOT_DRIVER(bd82x6x_drv) = {
>         .id             = UCLASS_PCH,
>         .of_match       = bd82x6x_ids,
>         .probe          = bd82x6x_probe,
> +       .ops            = &bd82x6x_pch_ops,
>  };
> diff --git a/arch/x86/dts/bayleybay.dts b/arch/x86/dts/bayleybay.dts
> index d3380de..87d809b 100644
> --- a/arch/x86/dts/bayleybay.dts
> +++ b/arch/x86/dts/bayleybay.dts
> @@ -65,23 +65,6 @@
>                 };
>         };
>
> -       spi {
> -               #address-cells = <1>;
> -               #size-cells = <0>;
> -               compatible = "intel,ich-spi";
> -               spi-flash at 0 {
> -                       #address-cells = <1>;
> -                       #size-cells = <1>;
> -                       reg = <0>;
> -                       compatible = "winbond,w25q64dw", "spi-flash";
> -                       memory-map = <0xff800000 0x00800000>;
> -                       rw-mrc-cache {
> -                               label = "rw-mrc-cache";
> -                               reg = <0x006e0000 0x00010000>;
> -                       };
> -               };
> -       };
> -
>         gpioa {
>                 compatible = "intel,ich6-gpio";
>                 u-boot,dm-pre-reloc;
> @@ -133,66 +116,91 @@
>                           0x42000000 0x0 0xc0000000 0xc0000000 0 0x20000000
>                           0x01000000 0x0 0x2000 0x2000 0 0xe000>;
>
> -               irq-router at 1f,0 {
> +               pch at 1f,0 {
>                         reg = <0x0000f800 0 0 0 0>;
> -                       compatible = "intel,irq-router";
> -                       intel,pirq-config = "ibase";
> -                       intel,ibase-offset = <0x50>;
> -                       intel,pirq-link = <8 8>;
> -                       intel,pirq-mask = <0xdee0>;
> -                       intel,pirq-routing = <
> -                               /* BayTrail PCI devices */
> -                               PCI_BDF(0, 2, 0) INTA PIRQA
> -                               PCI_BDF(0, 3, 0) INTA PIRQA
> -                               PCI_BDF(0, 16, 0) INTA PIRQA
> -                               PCI_BDF(0, 17, 0) INTA PIRQA
> -                               PCI_BDF(0, 18, 0) INTA PIRQA
> -                               PCI_BDF(0, 19, 0) INTA PIRQA
> -                               PCI_BDF(0, 20, 0) INTA PIRQA
> -                               PCI_BDF(0, 21, 0) INTA PIRQA
> -                               PCI_BDF(0, 22, 0) INTA PIRQA
> -                               PCI_BDF(0, 23, 0) INTA PIRQA
> -                               PCI_BDF(0, 24, 0) INTA PIRQA
> -                               PCI_BDF(0, 24, 1) INTC PIRQC
> -                               PCI_BDF(0, 24, 2) INTD PIRQD
> -                               PCI_BDF(0, 24, 3) INTB PIRQB
> -                               PCI_BDF(0, 24, 4) INTA PIRQA
> -                               PCI_BDF(0, 24, 5) INTC PIRQC
> -                               PCI_BDF(0, 24, 6) INTD PIRQD
> -                               PCI_BDF(0, 24, 7) INTB PIRQB
> -                               PCI_BDF(0, 26, 0) INTA PIRQA
> -                               PCI_BDF(0, 27, 0) INTA PIRQA
> -                               PCI_BDF(0, 28, 0) INTA PIRQA
> -                               PCI_BDF(0, 28, 1) INTB PIRQB
> -                               PCI_BDF(0, 28, 2) INTC PIRQC
> -                               PCI_BDF(0, 28, 3) INTD PIRQD
> -                               PCI_BDF(0, 29, 0) INTA PIRQA
> -                               PCI_BDF(0, 30, 0) INTA PIRQA
> -                               PCI_BDF(0, 30, 1) INTD PIRQD
> -                               PCI_BDF(0, 30, 2) INTB PIRQB
> -                               PCI_BDF(0, 30, 3) INTC PIRQC
> -                               PCI_BDF(0, 30, 4) INTD PIRQD
> -                               PCI_BDF(0, 30, 5) INTB PIRQB
> -                               PCI_BDF(0, 31, 3) INTB PIRQB
> -
> -                               /* PCIe root ports downstream interrupts */
> -                               PCI_BDF(1, 0, 0) INTA PIRQA
> -                               PCI_BDF(1, 0, 0) INTB PIRQB
> -                               PCI_BDF(1, 0, 0) INTC PIRQC
> -                               PCI_BDF(1, 0, 0) INTD PIRQD
> -                               PCI_BDF(2, 0, 0) INTA PIRQB
> -                               PCI_BDF(2, 0, 0) INTB PIRQC
> -                               PCI_BDF(2, 0, 0) INTC PIRQD
> -                               PCI_BDF(2, 0, 0) INTD PIRQA
> -                               PCI_BDF(3, 0, 0) INTA PIRQC
> -                               PCI_BDF(3, 0, 0) INTB PIRQD
> -                               PCI_BDF(3, 0, 0) INTC PIRQA
> -                               PCI_BDF(3, 0, 0) INTD PIRQB
> -                               PCI_BDF(4, 0, 0) INTA PIRQD
> -                               PCI_BDF(4, 0, 0) INTB PIRQA
> -                               PCI_BDF(4, 0, 0) INTC PIRQB
> -                               PCI_BDF(4, 0, 0) INTD PIRQC
> -                       >;
> +                       compatible = "intel,pch7";
> +
> +                       irq-router {
> +                               compatible = "intel,irq-router";
> +                               intel,pirq-config = "ibase";
> +                               intel,ibase-offset = <0x50>;
> +                               intel,pirq-link = <8 8>;
> +                               intel,pirq-mask = <0xdee0>;
> +                               intel,pirq-routing = <
> +                                       /* BayTrail PCI devices */
> +                                       PCI_BDF(0, 2, 0) INTA PIRQA
> +                                       PCI_BDF(0, 3, 0) INTA PIRQA
> +                                       PCI_BDF(0, 16, 0) INTA PIRQA
> +                                       PCI_BDF(0, 17, 0) INTA PIRQA
> +                                       PCI_BDF(0, 18, 0) INTA PIRQA
> +                                       PCI_BDF(0, 19, 0) INTA PIRQA
> +                                       PCI_BDF(0, 20, 0) INTA PIRQA
> +                                       PCI_BDF(0, 21, 0) INTA PIRQA
> +                                       PCI_BDF(0, 22, 0) INTA PIRQA
> +                                       PCI_BDF(0, 23, 0) INTA PIRQA
> +                                       PCI_BDF(0, 24, 0) INTA PIRQA
> +                                       PCI_BDF(0, 24, 1) INTC PIRQC
> +                                       PCI_BDF(0, 24, 2) INTD PIRQD
> +                                       PCI_BDF(0, 24, 3) INTB PIRQB
> +                                       PCI_BDF(0, 24, 4) INTA PIRQA
> +                                       PCI_BDF(0, 24, 5) INTC PIRQC
> +                                       PCI_BDF(0, 24, 6) INTD PIRQD
> +                                       PCI_BDF(0, 24, 7) INTB PIRQB
> +                                       PCI_BDF(0, 26, 0) INTA PIRQA
> +                                       PCI_BDF(0, 27, 0) INTA PIRQA
> +                                       PCI_BDF(0, 28, 0) INTA PIRQA
> +                                       PCI_BDF(0, 28, 1) INTB PIRQB
> +                                       PCI_BDF(0, 28, 2) INTC PIRQC
> +                                       PCI_BDF(0, 28, 3) INTD PIRQD
> +                                       PCI_BDF(0, 29, 0) INTA PIRQA
> +                                       PCI_BDF(0, 30, 0) INTA PIRQA
> +                                       PCI_BDF(0, 30, 1) INTD PIRQD
> +                                       PCI_BDF(0, 30, 2) INTB PIRQB
> +                                       PCI_BDF(0, 30, 3) INTC PIRQC
> +                                       PCI_BDF(0, 30, 4) INTD PIRQD
> +                                       PCI_BDF(0, 30, 5) INTB PIRQB
> +                                       PCI_BDF(0, 31, 3) INTB PIRQB
> +
> +                                       /*
> +                                        * PCIe root ports downstream
> +                                        * interrupts
> +                                        */
> +                                       PCI_BDF(1, 0, 0) INTA PIRQA
> +                                       PCI_BDF(1, 0, 0) INTB PIRQB
> +                                       PCI_BDF(1, 0, 0) INTC PIRQC
> +                                       PCI_BDF(1, 0, 0) INTD PIRQD
> +                                       PCI_BDF(2, 0, 0) INTA PIRQB
> +                                       PCI_BDF(2, 0, 0) INTB PIRQC
> +                                       PCI_BDF(2, 0, 0) INTC PIRQD
> +                                       PCI_BDF(2, 0, 0) INTD PIRQA
> +                                       PCI_BDF(3, 0, 0) INTA PIRQC
> +                                       PCI_BDF(3, 0, 0) INTB PIRQD
> +                                       PCI_BDF(3, 0, 0) INTC PIRQA
> +                                       PCI_BDF(3, 0, 0) INTD PIRQB
> +                                       PCI_BDF(4, 0, 0) INTA PIRQD
> +                                       PCI_BDF(4, 0, 0) INTB PIRQA
> +                                       PCI_BDF(4, 0, 0) INTC PIRQB
> +                                       PCI_BDF(4, 0, 0) INTD PIRQC
> +                               >;
> +                       };
> +
> +                       spi {
> +                               #address-cells = <1>;
> +                               #size-cells = <0>;
> +                               compatible = "intel,ich-spi";
> +                               spi-flash at 0 {
> +                                       #address-cells = <1>;
> +                                       #size-cells = <1>;
> +                                       reg = <0>;
> +                                       compatible = "winbond,w25q64dw",
> +                                               "spi-flash";
> +                                       memory-map = <0xff800000 0x00800000>;
> +                                       rw-mrc-cache {
> +                                               label = "rw-mrc-cache";
> +                                               reg = <0x006e0000 0x00010000>;
> +                                       };
> +                               };
> +                       };
>                 };
>         };
>
> diff --git a/arch/x86/dts/broadwell_som-6896.dts b/arch/x86/dts/broadwell_som-6896.dts
> index 194f0eb..57a2943 100644
> --- a/arch/x86/dts/broadwell_som-6896.dts
> +++ b/arch/x86/dts/broadwell_som-6896.dts
> @@ -29,16 +29,21 @@
>                 ranges = <0x02000000 0x0 0xe0000000 0xe0000000 0 0x10000000
>                         0x42000000 0x0 0xd0000000 0xd0000000 0 0x10000000
>                         0x01000000 0x0 0x2000 0x2000 0 0xe000>;
> -       };
>
> -       spi {
> -               #address-cells = <1>;
> -               #size-cells = <0>;
> -               compatible = "intel,ich-spi";
> -               spi-flash at 0 {
> -                       reg = <0>;
> -                       compatible = "winbond,w25q128", "spi-flash";
> -                       memory-map = <0xff000000 0x01000000>;
> +               pch at 1f,0 {
> +                       reg = <0x0000f800 0 0 0 0>;
> +                       compatible = "intel,pch9";
> +                       spi {
> +                               #address-cells = <1>;
> +                               #size-cells = <0>;
> +                               compatible = "intel,ich-spi";
> +                               spi-flash at 0 {
> +                                       reg = <0>;
> +                                       compatible = "winbond,w25q128", "spi-flash";
> +                                       memory-map = <0xff000000 0x01000000>;
> +                               };
> +                       };
>                 };
>         };
> +
>  };
> diff --git a/arch/x86/dts/chromebook_link.dts b/arch/x86/dts/chromebook_link.dts
> index c4469a9..4d158da 100644
> --- a/arch/x86/dts/chromebook_link.dts
> +++ b/arch/x86/dts/chromebook_link.dts
> @@ -186,7 +186,7 @@
>                         intel,pch-backlight = <0x04000000>;
>                 };
>
> -               pch {
> +               pch at 1f,0 {
>                         reg = <0x0000f800 0 0 0 0>;
>                         compatible = "intel,bd82x6x", "intel,pch";
>                         u-boot,dm-pre-reloc;
> @@ -200,6 +200,7 @@
>                                                 1 0 0 0 0 0 0 0>;
>                         /* Enable EC SMI source */
>                         intel,alt-gp-smi-enable = <0x0100>;
> +
>                         spi {
>                                 #address-cells = <1>;
>                                 #size-cells = <0>;
> diff --git a/arch/x86/dts/chromebox_panther.dts b/arch/x86/dts/chromebox_panther.dts
> index 4e2b517..bc0c7bb 100644
> --- a/arch/x86/dts/chromebox_panther.dts
> +++ b/arch/x86/dts/chromebox_panther.dts
> @@ -51,21 +51,26 @@
>                 ranges = <0x02000000 0x0 0xe0000000 0xe0000000 0 0x10000000
>                         0x42000000 0x0 0xd0000000 0xd0000000 0 0x10000000
>                         0x01000000 0x0 0x1000 0x1000 0 0xf000>;
> -       };
>
> -       spi {
> -               #address-cells = <1>;
> -               #size-cells = <0>;
> -               compatible = "intel,ich-spi";
> -               spi-flash at 0 {
> -                       #size-cells = <1>;
> -                       #address-cells = <1>;
> -                       reg = <0>;
> -                       compatible = "winbond,w25q64", "spi-flash";
> -                       memory-map = <0xff800000 0x00800000>;
> -                       rw-mrc-cache {
> -                               label = "rw-mrc-cache";
> -                               reg = <0x003e0000 0x00010000>;
> +               pch at 1f,0 {
> +                       reg = <0x0000f800 0 0 0 0>;
> +                       compatible = "intel,pch9";
> +                       spi {
> +                               #address-cells = <1>;
> +                               #size-cells = <0>;
> +                               compatible = "intel,ich-spi";
> +                               spi-flash at 0 {
> +                                       #size-cells = <1>;
> +                                       #address-cells = <1>;
> +                                       reg = <0>;
> +                                       compatible = "winbond,w25q64",
> +                                               "spi-flash";
> +                                       memory-map = <0xff800000 0x00800000>;
> +                                       rw-mrc-cache {
> +                                               label = "rw-mrc-cache";
> +                                               reg = <0x003e0000 0x00010000>;
> +                                       };
> +                               };
>                         };
>                 };
>         };
> diff --git a/arch/x86/dts/crownbay.dts b/arch/x86/dts/crownbay.dts
> index e17ce71..7039332 100644
> --- a/arch/x86/dts/crownbay.dts
> +++ b/arch/x86/dts/crownbay.dts
> @@ -72,17 +72,6 @@
>                 stdout-path = "/serial";
>         };
>
> -       spi {
> -               #address-cells = <1>;
> -               #size-cells = <0>;
> -               compatible = "intel,ich-spi";
> -               spi-flash at 0 {
> -                       reg = <0>;
> -                       compatible = "sst,25vf016b", "spi-flash";
> -                       memory-map = <0xffe00000 0x00200000>;
> -               };
> -       };
> -
>         microcode {
>                 update at 0 {
>  #include "microcode/m0220661105_cv.dtsi"
> @@ -105,6 +94,18 @@
>                         u-boot,dm-pre-reloc;
>                         reg = <0x0000b800 0x0 0x0 0x0 0x0>;
>
> +                       spi {
> +                               #address-cells = <1>;
> +                               #size-cells = <0>;
> +                               compatible = "intel,ich-spi";
> +                               spi-flash at 0 {
> +                                       reg = <0>;
> +                                       compatible = "sst,25vf016b",
> +                                               "spi-flash";
> +                                       memory-map = <0xffe00000 0x00200000>;
> +                               };
> +                       };
> +
>                         topcliff at 0,0 {
>                                 #address-cells = <3>;
>                                 #size-cells = <2>;
> @@ -170,68 +171,73 @@
>                         };
>                 };
>
> -               irq-router at 1f,0 {
> +               pch at 1f,0 {
>                         reg = <0x0000f800 0 0 0 0>;
> -                       compatible = "intel,irq-router";
> -                       intel,pirq-config = "pci";
> -                       intel,pirq-link = <0x60 8>;
> -                       intel,pirq-mask = <0xcee0>;
> -                       intel,pirq-routing = <
> -                               /* TunnelCreek PCI devices */
> -                               PCI_BDF(0, 2, 0) INTA PIRQE
> -                               PCI_BDF(0, 3, 0) INTA PIRQF
> -                               PCI_BDF(0, 23, 0) INTA PIRQA
> -                               PCI_BDF(0, 23, 0) INTB PIRQB
> -                               PCI_BDF(0, 23, 0) INTC PIRQC
> -                               PCI_BDF(0, 23, 0) INTD PIRQD
> -                               PCI_BDF(0, 24, 0) INTA PIRQB
> -                               PCI_BDF(0, 24, 0) INTB PIRQC
> -                               PCI_BDF(0, 24, 0) INTC PIRQD
> -                               PCI_BDF(0, 24, 0) INTD PIRQA
> -                               PCI_BDF(0, 25, 0) INTA PIRQC
> -                               PCI_BDF(0, 25, 0) INTB PIRQD
> -                               PCI_BDF(0, 25, 0) INTC PIRQA
> -                               PCI_BDF(0, 25, 0) INTD PIRQB
> -                               PCI_BDF(0, 26, 0) INTA PIRQD
> -                               PCI_BDF(0, 26, 0) INTB PIRQA
> -                               PCI_BDF(0, 26, 0) INTC PIRQB
> -                               PCI_BDF(0, 26, 0) INTD PIRQC
> -                               PCI_BDF(0, 27, 0) INTA PIRQG
> -                               /*
> -                                * Topcliff PCI devices
> -                                *
> -                                * Note on the Crown Bay board, Topcliff chipset
> -                                * is connected to TunnelCreek PCIe port 0, so
> -                                * its bus number is 1 for its PCIe port and 2
> -                                * for its PCI devices per U-Boot current PCI
> -                                * bus enumeration algorithm.
> -                                */
> -                               PCI_BDF(1, 0, 0) INTA PIRQA
> -                               PCI_BDF(2, 0, 1) INTA PIRQA
> -                               PCI_BDF(2, 0, 2) INTA PIRQA
> -                               PCI_BDF(2, 2, 0) INTB PIRQD
> -                               PCI_BDF(2, 2, 1) INTB PIRQD
> -                               PCI_BDF(2, 2, 2) INTB PIRQD
> -                               PCI_BDF(2, 2, 3) INTB PIRQD
> -                               PCI_BDF(2, 2, 4) INTB PIRQD
> -                               PCI_BDF(2, 4, 0) INTC PIRQC
> -                               PCI_BDF(2, 4, 1) INTC PIRQC
> -                               PCI_BDF(2, 6, 0) INTD PIRQB
> -                               PCI_BDF(2, 8, 0) INTA PIRQA
> -                               PCI_BDF(2, 8, 1) INTA PIRQA
> -                               PCI_BDF(2, 8, 2) INTA PIRQA
> -                               PCI_BDF(2, 8, 3) INTA PIRQA
> -                               PCI_BDF(2, 10, 0) INTB PIRQD
> -                               PCI_BDF(2, 10, 1) INTB PIRQD
> -                               PCI_BDF(2, 10, 2) INTB PIRQD
> -                               PCI_BDF(2, 10, 3) INTB PIRQD
> -                               PCI_BDF(2, 10, 4) INTB PIRQD
> -                               PCI_BDF(2, 12, 0) INTC PIRQC
> -                               PCI_BDF(2, 12, 1) INTC PIRQC
> -                               PCI_BDF(2, 12, 2) INTC PIRQC
> -                               PCI_BDF(2, 12, 3) INTC PIRQC
> -                               PCI_BDF(2, 12, 4) INTC PIRQC
> -                       >;
> +                       compatible = "intel,pch7";
> +
> +                       irq-router {
> +                               compatible = "intel,irq-router";
> +                               intel,pirq-config = "pci";
> +                               intel,pirq-link = <0x60 8>;
> +                               intel,pirq-mask = <0xcee0>;
> +                               intel,pirq-routing = <
> +                                       /* TunnelCreek PCI devices */
> +                                       PCI_BDF(0, 2, 0) INTA PIRQE
> +                                       PCI_BDF(0, 3, 0) INTA PIRQF
> +                                       PCI_BDF(0, 23, 0) INTA PIRQA
> +                                       PCI_BDF(0, 23, 0) INTB PIRQB
> +                                       PCI_BDF(0, 23, 0) INTC PIRQC
> +                                       PCI_BDF(0, 23, 0) INTD PIRQD
> +                                       PCI_BDF(0, 24, 0) INTA PIRQB
> +                                       PCI_BDF(0, 24, 0) INTB PIRQC
> +                                       PCI_BDF(0, 24, 0) INTC PIRQD
> +                                       PCI_BDF(0, 24, 0) INTD PIRQA
> +                                       PCI_BDF(0, 25, 0) INTA PIRQC
> +                                       PCI_BDF(0, 25, 0) INTB PIRQD
> +                                       PCI_BDF(0, 25, 0) INTC PIRQA
> +                                       PCI_BDF(0, 25, 0) INTD PIRQB
> +                                       PCI_BDF(0, 26, 0) INTA PIRQD
> +                                       PCI_BDF(0, 26, 0) INTB PIRQA
> +                                       PCI_BDF(0, 26, 0) INTC PIRQB
> +                                       PCI_BDF(0, 26, 0) INTD PIRQC
> +                                       PCI_BDF(0, 27, 0) INTA PIRQG
> +                                       /*
> +                                       * Topcliff PCI devices
> +                                       *
> +                                       * Note on the Crown Bay board, Topcliff
> +                                       * chipset is connected to TunnelCreek
> +                                       * PCIe port 0, so its bus number is 1
> +                                       * for its PCIe port and 2 for its PCI
> +                                       * devices per U-Boot current PCI bus
> +                                       * enumeration algorithm.
> +                                       */
> +                                       PCI_BDF(1, 0, 0) INTA PIRQA
> +                                       PCI_BDF(2, 0, 1) INTA PIRQA
> +                                       PCI_BDF(2, 0, 2) INTA PIRQA
> +                                       PCI_BDF(2, 2, 0) INTB PIRQD
> +                                       PCI_BDF(2, 2, 1) INTB PIRQD
> +                                       PCI_BDF(2, 2, 2) INTB PIRQD
> +                                       PCI_BDF(2, 2, 3) INTB PIRQD
> +                                       PCI_BDF(2, 2, 4) INTB PIRQD
> +                                       PCI_BDF(2, 4, 0) INTC PIRQC
> +                                       PCI_BDF(2, 4, 1) INTC PIRQC
> +                                       PCI_BDF(2, 6, 0) INTD PIRQB
> +                                       PCI_BDF(2, 8, 0) INTA PIRQA
> +                                       PCI_BDF(2, 8, 1) INTA PIRQA
> +                                       PCI_BDF(2, 8, 2) INTA PIRQA
> +                                       PCI_BDF(2, 8, 3) INTA PIRQA
> +                                       PCI_BDF(2, 10, 0) INTB PIRQD
> +                                       PCI_BDF(2, 10, 1) INTB PIRQD
> +                                       PCI_BDF(2, 10, 2) INTB PIRQD
> +                                       PCI_BDF(2, 10, 3) INTB PIRQD
> +                                       PCI_BDF(2, 10, 4) INTB PIRQD
> +                                       PCI_BDF(2, 12, 0) INTC PIRQC
> +                                       PCI_BDF(2, 12, 1) INTC PIRQC
> +                                       PCI_BDF(2, 12, 2) INTC PIRQC
> +                                       PCI_BDF(2, 12, 3) INTC PIRQC
> +                                       PCI_BDF(2, 12, 4) INTC PIRQC
> +                               >;
> +                       };
>                 };
>         };
>
> diff --git a/arch/x86/dts/galileo.dts b/arch/x86/dts/galileo.dts
> index 2342de7..3ee9a33 100644
> --- a/arch/x86/dts/galileo.dts
> +++ b/arch/x86/dts/galileo.dts
> @@ -79,37 +79,58 @@
>                         current-speed = <115200>;
>                 };
>
> -               irq-router at 1f,0 {
> +               pch at 1f,0 {
>                         reg = <0x0000f800 0 0 0 0>;
> -                       compatible = "intel,irq-router";
> -                       intel,pirq-config = "pci";
> -                       intel,pirq-link = <0x60 8>;
> -                       intel,pirq-mask = <0xdef8>;
> -                       intel,pirq-routing = <
> -                               PCI_BDF(0, 20, 0) INTA PIRQE
> -                               PCI_BDF(0, 20, 1) INTB PIRQF
> -                               PCI_BDF(0, 20, 2) INTC PIRQG
> -                               PCI_BDF(0, 20, 3) INTD PIRQH
> -                               PCI_BDF(0, 20, 4) INTA PIRQE
> -                               PCI_BDF(0, 20, 5) INTB PIRQF
> -                               PCI_BDF(0, 20, 6) INTC PIRQG
> -                               PCI_BDF(0, 20, 7) INTD PIRQH
> -                               PCI_BDF(0, 21, 0) INTA PIRQE
> -                               PCI_BDF(0, 21, 1) INTB PIRQF
> -                               PCI_BDF(0, 21, 2) INTC PIRQG
> -                               PCI_BDF(0, 23, 0) INTA PIRQA
> -                               PCI_BDF(0, 23, 1) INTB PIRQB
> -
> -                               /* PCIe root ports downstream interrupts */
> -                               PCI_BDF(1, 0, 0) INTA PIRQA
> -                               PCI_BDF(1, 0, 0) INTB PIRQB
> -                               PCI_BDF(1, 0, 0) INTC PIRQC
> -                               PCI_BDF(1, 0, 0) INTD PIRQD
> -                               PCI_BDF(2, 0, 0) INTA PIRQB
> -                               PCI_BDF(2, 0, 0) INTB PIRQC
> -                               PCI_BDF(2, 0, 0) INTC PIRQD
> -                               PCI_BDF(2, 0, 0) INTD PIRQA
> -                       >;
> +
> +                       irq-router {
> +                               compatible = "intel,irq-router";
> +                               intel,pirq-config = "pci";
> +                               intel,pirq-link = <0x60 8>;
> +                               intel,pirq-mask = <0xdef8>;
> +                               intel,pirq-routing = <
> +                                       PCI_BDF(0, 20, 0) INTA PIRQE
> +                                       PCI_BDF(0, 20, 1) INTB PIRQF
> +                                       PCI_BDF(0, 20, 2) INTC PIRQG
> +                                       PCI_BDF(0, 20, 3) INTD PIRQH
> +                                       PCI_BDF(0, 20, 4) INTA PIRQE
> +                                       PCI_BDF(0, 20, 5) INTB PIRQF
> +                                       PCI_BDF(0, 20, 6) INTC PIRQG
> +                                       PCI_BDF(0, 20, 7) INTD PIRQH
> +                                       PCI_BDF(0, 21, 0) INTA PIRQE
> +                                       PCI_BDF(0, 21, 1) INTB PIRQF
> +                                       PCI_BDF(0, 21, 2) INTC PIRQG
> +                                       PCI_BDF(0, 23, 0) INTA PIRQA
> +                                       PCI_BDF(0, 23, 1) INTB PIRQB
> +
> +                                       /* PCIe root ports downstream interrupts */
> +                                       PCI_BDF(1, 0, 0) INTA PIRQA
> +                                       PCI_BDF(1, 0, 0) INTB PIRQB
> +                                       PCI_BDF(1, 0, 0) INTC PIRQC
> +                                       PCI_BDF(1, 0, 0) INTD PIRQD
> +                                       PCI_BDF(2, 0, 0) INTA PIRQB
> +                                       PCI_BDF(2, 0, 0) INTB PIRQC
> +                                       PCI_BDF(2, 0, 0) INTC PIRQD
> +                                       PCI_BDF(2, 0, 0) INTD PIRQA
> +                               >;
> +                       };
> +
> +                       spi {
> +                               #address-cells = <1>;
> +                               #size-cells = <0>;
> +                               compatible = "intel,ich-spi";
> +                               spi-flash at 0 {
> +                                       #size-cells = <1>;
> +                                       #address-cells = <1>;
> +                                       reg = <0>;
> +                                       compatible = "winbond,w25q64",
> +                                               "spi-flash";
> +                                       memory-map = <0xff800000 0x00800000>;
> +                                       rw-mrc-cache {
> +                                               label = "rw-mrc-cache";
> +                                               reg = <0x00010000 0x00010000>;
> +                                       };
> +                               };
> +                       };
>                 };
>         };
>
> @@ -127,21 +148,4 @@
>                 bank-name = "B";
>         };
>
> -       spi {
> -               #address-cells = <1>;
> -               #size-cells = <0>;
> -               compatible = "intel,ich-spi";
> -               spi-flash at 0 {
> -                       #size-cells = <1>;
> -                       #address-cells = <1>;
> -                       reg = <0>;
> -                       compatible = "winbond,w25q64", "spi-flash";
> -                       memory-map = <0xff800000 0x00800000>;
> -                       rw-mrc-cache {
> -                               label = "rw-mrc-cache";
> -                               reg = <0x00010000 0x00010000>;
> -                       };
> -               };
> -       };
> -
>  };
> diff --git a/arch/x86/dts/minnowmax.dts b/arch/x86/dts/minnowmax.dts
> index bbfd6d4..e7ef7c9 100644
> --- a/arch/x86/dts/minnowmax.dts
> +++ b/arch/x86/dts/minnowmax.dts
> @@ -150,66 +150,91 @@
>                           0x42000000 0x0 0xc0000000 0xc0000000 0 0x20000000
>                           0x01000000 0x0 0x2000 0x2000 0 0xe000>;
>
> -               irq-router at 1f,0 {
> +               pch at 1f,0 {
>                         reg = <0x0000f800 0 0 0 0>;
> -                       compatible = "intel,irq-router";
> -                       intel,pirq-config = "ibase";
> -                       intel,ibase-offset = <0x50>;
> -                       intel,pirq-link = <8 8>;
> -                       intel,pirq-mask = <0xdee0>;
> -                       intel,pirq-routing = <
> -                               /* BayTrail PCI devices */
> -                               PCI_BDF(0, 2, 0) INTA PIRQA
> -                               PCI_BDF(0, 3, 0) INTA PIRQA
> -                               PCI_BDF(0, 16, 0) INTA PIRQA
> -                               PCI_BDF(0, 17, 0) INTA PIRQA
> -                               PCI_BDF(0, 18, 0) INTA PIRQA
> -                               PCI_BDF(0, 19, 0) INTA PIRQA
> -                               PCI_BDF(0, 20, 0) INTA PIRQA
> -                               PCI_BDF(0, 21, 0) INTA PIRQA
> -                               PCI_BDF(0, 22, 0) INTA PIRQA
> -                               PCI_BDF(0, 23, 0) INTA PIRQA
> -                               PCI_BDF(0, 24, 0) INTA PIRQA
> -                               PCI_BDF(0, 24, 1) INTC PIRQC
> -                               PCI_BDF(0, 24, 2) INTD PIRQD
> -                               PCI_BDF(0, 24, 3) INTB PIRQB
> -                               PCI_BDF(0, 24, 4) INTA PIRQA
> -                               PCI_BDF(0, 24, 5) INTC PIRQC
> -                               PCI_BDF(0, 24, 6) INTD PIRQD
> -                               PCI_BDF(0, 24, 7) INTB PIRQB
> -                               PCI_BDF(0, 26, 0) INTA PIRQA
> -                               PCI_BDF(0, 27, 0) INTA PIRQA
> -                               PCI_BDF(0, 28, 0) INTA PIRQA
> -                               PCI_BDF(0, 28, 1) INTB PIRQB
> -                               PCI_BDF(0, 28, 2) INTC PIRQC
> -                               PCI_BDF(0, 28, 3) INTD PIRQD
> -                               PCI_BDF(0, 29, 0) INTA PIRQA
> -                               PCI_BDF(0, 30, 0) INTA PIRQA
> -                               PCI_BDF(0, 30, 1) INTD PIRQD
> -                               PCI_BDF(0, 30, 2) INTB PIRQB
> -                               PCI_BDF(0, 30, 3) INTC PIRQC
> -                               PCI_BDF(0, 30, 4) INTD PIRQD
> -                               PCI_BDF(0, 30, 5) INTB PIRQB
> -                               PCI_BDF(0, 31, 3) INTB PIRQB
> +                       compatible = "pci8086,0f1c", "intel,pch9";
>
> -                               /* PCIe root ports downstream interrupts */
> -                               PCI_BDF(1, 0, 0) INTA PIRQA
> -                               PCI_BDF(1, 0, 0) INTB PIRQB
> -                               PCI_BDF(1, 0, 0) INTC PIRQC
> -                               PCI_BDF(1, 0, 0) INTD PIRQD
> -                               PCI_BDF(2, 0, 0) INTA PIRQB
> -                               PCI_BDF(2, 0, 0) INTB PIRQC
> -                               PCI_BDF(2, 0, 0) INTC PIRQD
> -                               PCI_BDF(2, 0, 0) INTD PIRQA
> -                               PCI_BDF(3, 0, 0) INTA PIRQC
> -                               PCI_BDF(3, 0, 0) INTB PIRQD
> -                               PCI_BDF(3, 0, 0) INTC PIRQA
> -                               PCI_BDF(3, 0, 0) INTD PIRQB
> -                               PCI_BDF(4, 0, 0) INTA PIRQD
> -                               PCI_BDF(4, 0, 0) INTB PIRQA
> -                               PCI_BDF(4, 0, 0) INTC PIRQB
> -                               PCI_BDF(4, 0, 0) INTD PIRQC
> -                       >;
> +                       irq-router {
> +                               compatible = "intel,irq-router";
> +                               intel,pirq-config = "ibase";
> +                               intel,ibase-offset = <0x50>;
> +                               intel,pirq-link = <8 8>;
> +                               intel,pirq-mask = <0xdee0>;
> +                               intel,pirq-routing = <
> +                                       /* BayTrail PCI devices */
> +                                       PCI_BDF(0, 2, 0) INTA PIRQA
> +                                       PCI_BDF(0, 3, 0) INTA PIRQA
> +                                       PCI_BDF(0, 16, 0) INTA PIRQA
> +                                       PCI_BDF(0, 17, 0) INTA PIRQA
> +                                       PCI_BDF(0, 18, 0) INTA PIRQA
> +                                       PCI_BDF(0, 19, 0) INTA PIRQA
> +                                       PCI_BDF(0, 20, 0) INTA PIRQA
> +                                       PCI_BDF(0, 21, 0) INTA PIRQA
> +                                       PCI_BDF(0, 22, 0) INTA PIRQA
> +                                       PCI_BDF(0, 23, 0) INTA PIRQA
> +                                       PCI_BDF(0, 24, 0) INTA PIRQA
> +                                       PCI_BDF(0, 24, 1) INTC PIRQC
> +                                       PCI_BDF(0, 24, 2) INTD PIRQD
> +                                       PCI_BDF(0, 24, 3) INTB PIRQB
> +                                       PCI_BDF(0, 24, 4) INTA PIRQA
> +                                       PCI_BDF(0, 24, 5) INTC PIRQC
> +                                       PCI_BDF(0, 24, 6) INTD PIRQD
> +                                       PCI_BDF(0, 24, 7) INTB PIRQB
> +                                       PCI_BDF(0, 26, 0) INTA PIRQA
> +                                       PCI_BDF(0, 27, 0) INTA PIRQA
> +                                       PCI_BDF(0, 28, 0) INTA PIRQA
> +                                       PCI_BDF(0, 28, 1) INTB PIRQB
> +                                       PCI_BDF(0, 28, 2) INTC PIRQC
> +                                       PCI_BDF(0, 28, 3) INTD PIRQD
> +                                       PCI_BDF(0, 29, 0) INTA PIRQA
> +                                       PCI_BDF(0, 30, 0) INTA PIRQA
> +                                       PCI_BDF(0, 30, 1) INTD PIRQD
> +                                       PCI_BDF(0, 30, 2) INTB PIRQB
> +                                       PCI_BDF(0, 30, 3) INTC PIRQC
> +                                       PCI_BDF(0, 30, 4) INTD PIRQD
> +                                       PCI_BDF(0, 30, 5) INTB PIRQB
> +                                       PCI_BDF(0, 31, 3) INTB PIRQB
> +
> +                                       /*
> +                                        * PCIe root ports downstream
> +                                        * interrupts
> +                                        */
> +                                       PCI_BDF(1, 0, 0) INTA PIRQA
> +                                       PCI_BDF(1, 0, 0) INTB PIRQB
> +                                       PCI_BDF(1, 0, 0) INTC PIRQC
> +                                       PCI_BDF(1, 0, 0) INTD PIRQD
> +                                       PCI_BDF(2, 0, 0) INTA PIRQB
> +                                       PCI_BDF(2, 0, 0) INTB PIRQC
> +                                       PCI_BDF(2, 0, 0) INTC PIRQD
> +                                       PCI_BDF(2, 0, 0) INTD PIRQA
> +                                       PCI_BDF(3, 0, 0) INTA PIRQC
> +                                       PCI_BDF(3, 0, 0) INTB PIRQD
> +                                       PCI_BDF(3, 0, 0) INTC PIRQA
> +                                       PCI_BDF(3, 0, 0) INTD PIRQB
> +                                       PCI_BDF(4, 0, 0) INTA PIRQD
> +                                       PCI_BDF(4, 0, 0) INTB PIRQA
> +                                       PCI_BDF(4, 0, 0) INTC PIRQB
> +                                       PCI_BDF(4, 0, 0) INTD PIRQC
> +                               >;
> +                       };
> +
> +                       spi {
> +                               #address-cells = <1>;
> +                               #size-cells = <0>;
> +                               compatible = "intel,ich-spi";
> +                               spi-flash at 0 {
> +                                       #address-cells = <1>;
> +                                       #size-cells = <1>;
> +                                       reg = <0>;
> +                                       compatible = "stmicro,n25q064a",
> +                                               "spi-flash";
> +                                       memory-map = <0xff800000 0x00800000>;
> +                                       rw-mrc-cache {
> +                                               label = "rw-mrc-cache";
> +                                               reg = <0x006f0000 0x00010000>;
> +                                       };
> +                               };
> +                       };
>                 };
>         };
>
> @@ -269,23 +294,6 @@
>                 };
>         };
>
> -       spi {
> -               #address-cells = <1>;
> -               #size-cells = <0>;
> -               compatible = "intel,ich-spi";
> -               spi-flash at 0 {
> -                       #address-cells = <1>;
> -                       #size-cells = <1>;
> -                       reg = <0>;
> -                       compatible = "stmicro,n25q064a", "spi-flash";
> -                       memory-map = <0xff800000 0x00800000>;
> -                       rw-mrc-cache {
> -                               label = "rw-mrc-cache";
> -                               reg = <0x006f0000 0x00010000>;
> -                       };
> -               };
> -       };
> -
>         microcode {
>                 update at 0 {
>  #include "microcode/m0130673322.dtsi"
> diff --git a/arch/x86/dts/qemu-x86_i440fx.dts b/arch/x86/dts/qemu-x86_i440fx.dts
> index 8a06229..a16875f 100644
> --- a/arch/x86/dts/qemu-x86_i440fx.dts
> +++ b/arch/x86/dts/qemu-x86_i440fx.dts
> @@ -58,18 +58,22 @@
>                         0x42000000 0x0 0xd0000000 0xd0000000 0 0x10000000
>                         0x01000000 0x0 0x2000 0x2000 0 0xe000>;
>
> -               irq-router at 1,0 {
> +               pch at 1,0 {
>                         reg = <0x00000800 0 0 0 0>;
> -                       compatible = "intel,irq-router";
> -                       intel,pirq-config = "pci";
> -                       intel,pirq-link = <0x60 4>;
> -                       intel,pirq-mask = <0x0e40>;
> -                       intel,pirq-routing = <
> -                               /* PIIX UHCI */
> -                               PCI_BDF(0, 1, 2) INTD PIRQD
> -                               /* e1000 NIC */
> -                               PCI_BDF(0, 3, 0) INTA PIRQC
> -                       >;
> +                       compatible = "intel,pch7";
> +
> +                       irq-router {
> +                               compatible = "intel,irq-router";
> +                               intel,pirq-config = "pci";
> +                               intel,pirq-link = <0x60 4>;
> +                               intel,pirq-mask = <0x0e40>;
> +                               intel,pirq-routing = <
> +                                       /* PIIX UHCI */
> +                                       PCI_BDF(0, 1, 2) INTD PIRQD
> +                                       /* e1000 NIC */
> +                                       PCI_BDF(0, 3, 0) INTA PIRQC
> +                               >;
> +                       };
>                 };
>         };
>
> diff --git a/arch/x86/dts/qemu-x86_q35.dts b/arch/x86/dts/qemu-x86_q35.dts
> index 0b685c8..c00a4a8 100644
> --- a/arch/x86/dts/qemu-x86_q35.dts
> +++ b/arch/x86/dts/qemu-x86_q35.dts
> @@ -69,24 +69,28 @@
>                         0x42000000 0x0 0xd0000000 0xd0000000 0 0x10000000
>                         0x01000000 0x0 0x2000 0x2000 0 0xe000>;
>
> -               irq-router at 1f,0 {
> +               pch at 1f,0 {
>                         reg = <0x0000f800 0 0 0 0>;
> -                       compatible = "intel,irq-router";
> -                       intel,pirq-config = "pci";
> -                       intel,pirq-link = <0x60 8>;
> -                       intel,pirq-mask = <0x0e40>;
> -                       intel,pirq-routing = <
> -                               /* e1000 NIC */
> -                               PCI_BDF(0, 2, 0) INTA PIRQG
> -                               /* ICH9 UHCI */
> -                               PCI_BDF(0, 29, 0) INTA PIRQA
> -                               PCI_BDF(0, 29, 1) INTB PIRQB
> -                               PCI_BDF(0, 29, 2) INTC PIRQC
> -                               /* ICH9 EHCI */
> -                               PCI_BDF(0, 29, 7) INTD PIRQD
> -                               /* ICH9 SATA */
> -                               PCI_BDF(0, 31, 2) INTA PIRQA
> -                       >;
> +                       compatible = "intel,pch7";
> +
> +                       irq-router {
> +                               compatible = "intel,irq-router";
> +                               intel,pirq-config = "pci";
> +                               intel,pirq-link = <0x60 8>;
> +                               intel,pirq-mask = <0x0e40>;
> +                               intel,pirq-routing = <
> +                                       /* e1000 NIC */
> +                                       PCI_BDF(0, 2, 0) INTA PIRQG
> +                                       /* ICH9 UHCI */
> +                                       PCI_BDF(0, 29, 0) INTA PIRQA
> +                                       PCI_BDF(0, 29, 1) INTB PIRQB
> +                                       PCI_BDF(0, 29, 2) INTC PIRQC
> +                                       /* ICH9 EHCI */
> +                                       PCI_BDF(0, 29, 7) INTD PIRQD
> +                                       /* ICH9 SATA */
> +                                       PCI_BDF(0, 31, 2) INTA PIRQA
> +                               >;
> +                       };
>                 };
>         };
>
> diff --git a/drivers/spi/ich.c b/drivers/spi/ich.c
> index f85af9c..ecb68b4 100644
> --- a/drivers/spi/ich.c
> +++ b/drivers/spi/ich.c
> @@ -10,9 +10,10 @@
>  #include <dm.h>
>  #include <errno.h>
>  #include <malloc.h>
> -#include <spi.h>
> +#include <pch.h>
>  #include <pci.h>
>  #include <pci_ids.h>
> +#include <spi.h>
>  #include <asm/io.h>
>
>  #include "ich.h"
> @@ -21,9 +22,7 @@
>  #define SPI_OPCODE_FAST_READ 0x0b
>
>  struct ich_spi_platdata {
> -       pci_dev_t dev;          /* PCI device number */
>         int ich_version;        /* Controller version, 7 or 9 */
> -       bool use_sbase;         /* Use SBASE instead of RCB */
>  };
>
>  struct ich_spi_priv {
> @@ -116,40 +115,16 @@ static void ich_set_bbar(struct ich_spi_priv *ctlr, uint32_t minaddr)
>         ich_writel(ctlr, ichspi_bbar, ctlr->bbar);
>  }
>
> -/*
> - * Check if this device ID matches one of supported Intel PCH devices.
> - *
> - * Return the ICH version if there is a match, or zero otherwise.
> - */
> -static int get_ich_version(uint16_t device_id)
> -{
> -       if (device_id == PCI_DEVICE_ID_INTEL_TGP_LPC ||
> -           device_id == PCI_DEVICE_ID_INTEL_ITC_LPC ||
> -           device_id == PCI_DEVICE_ID_INTEL_QRK_ILB)
> -               return 7;
> -
> -       if ((device_id >= PCI_DEVICE_ID_INTEL_COUGARPOINT_LPC_MIN &&
> -            device_id <= PCI_DEVICE_ID_INTEL_COUGARPOINT_LPC_MAX) ||
> -           (device_id >= PCI_DEVICE_ID_INTEL_PANTHERPOINT_LPC_MIN &&
> -            device_id <= PCI_DEVICE_ID_INTEL_PANTHERPOINT_LPC_MAX) ||
> -           device_id == PCI_DEVICE_ID_INTEL_VALLEYVIEW_LPC ||
> -           device_id == PCI_DEVICE_ID_INTEL_LYNXPOINT_LPC ||
> -           device_id == PCI_DEVICE_ID_INTEL_WILDCATPOINT_LPC)
> -               return 9;
> -
> -       return 0;
> -}
> -
>  /* @return 1 if the SPI flash supports the 33MHz speed */
> -static int ich9_can_do_33mhz(pci_dev_t dev)
> +static int ich9_can_do_33mhz(struct udevice *dev)
>  {
>         u32 fdod, speed;
>
>         /* Observe SPI Descriptor Component Section 0 */
> -       pci_write_config_dword(dev, 0xb0, 0x1000);
> +       dm_pci_write_config32(dev->parent, 0xb0, 0x1000);
>
>         /* Extract the Write/Erase SPI Frequency from descriptor */
> -       pci_read_config_dword(dev, 0xb4, &fdod);
> +       dm_pci_read_config32(dev->parent, 0xb4, &fdod);
>
>         /* Bits 23:21 have the fast read clock frequency, 0=20MHz, 1=33MHz */
>         speed = (fdod >> 21) & 7;
> @@ -157,54 +132,23 @@ static int ich9_can_do_33mhz(pci_dev_t dev)
>         return speed == 1;
>  }
>
> -static int ich_find_spi_controller(struct ich_spi_platdata *ich)
> -{
> -       int last_bus = pci_last_busno();
> -       int bus;
> -
> -       if (last_bus == -1) {
> -               debug("No PCI busses?\n");
> -               return -ENODEV;
> -       }
> -
> -       for (bus = 0; bus <= last_bus; bus++) {
> -               uint16_t vendor_id, device_id;
> -               uint32_t ids;
> -               pci_dev_t dev;
> -
> -               dev = PCI_BDF(bus, 31, 0);
> -               pci_read_config_dword(dev, 0, &ids);
> -               vendor_id = ids;
> -               device_id = ids >> 16;
> -
> -               if (vendor_id == PCI_VENDOR_ID_INTEL) {
> -                       ich->dev = dev;
> -                       ich->ich_version = get_ich_version(device_id);
> -                       if (device_id == PCI_DEVICE_ID_INTEL_VALLEYVIEW_LPC)
> -                               ich->use_sbase = true;
> -                       return ich->ich_version == 0 ? -ENODEV : 0;
> -               }
> -       }
> -
> -       debug("ICH SPI: No ICH found.\n");
> -       return -ENODEV;
> -}
> -
> -static int ich_init_controller(struct ich_spi_platdata *plat,
> +static int ich_init_controller(struct udevice *dev,
> +                              struct ich_spi_platdata *plat,
>                                struct ich_spi_priv *ctlr)
>  {
>         uint8_t *rcrb; /* Root Complex Register Block */
>         uint32_t rcba; /* Root Complex Base Address */
> -       uint32_t sbase_addr;
> +       ulong sbase_addr;
>         uint8_t *sbase;
>
> -       pci_read_config_dword(plat->dev, 0xf0, &rcba);
> +       dm_pci_read_config32(dev->parent, 0xf0, &rcba);
>         /* Bits 31-14 are the base address, 13-1 are reserved, 0 is enable. */
>         rcrb = (uint8_t *)(rcba & 0xffffc000);

Can we move this RCRB case into pch driver's get_sbase() implementation?

>
>         /* SBASE is similar */
> -       pci_read_config_dword(plat->dev, 0x54, &sbase_addr);
> -       sbase = (uint8_t *)(sbase_addr & 0xfffffe00);
> +       pch_get_sbase(dev->parent, &sbase_addr);
> +       sbase = (void *)sbase_addr;
> +       debug("%s: rcrb=%p, sbase=%p\n", __func__, rcrb, sbase);
>
>         if (plat->ich_version == 7) {
>                 struct ich7_spi_regs *ich7_spi;
> @@ -225,7 +169,7 @@ static int ich_init_controller(struct ich_spi_platdata *plat,
>         } else if (plat->ich_version == 9) {
>                 struct ich9_spi_regs *ich9_spi;
>
> -               if (plat->use_sbase)

And use a property to the pch node, something like has-sbase;

In the pch9 driver, we can do something like this:

If (has-sbase)
    read value from sbase register;
else
    read value from RCBA register;

This way, we hide details of where SPI base register is from the SPI
controller driver. After all, where to map the SPI base is PCH's
responsibility.

> +               if (sbase)
>                         ich9_spi = (struct ich9_spi_regs *)sbase;
>                 else
>                         ich9_spi = (struct ich9_spi_regs *)(rcrb + 0x3800);
> @@ -252,7 +196,7 @@ static int ich_init_controller(struct ich_spi_platdata *plat,
>
>         /* Work out the maximum speed we can support */
>         ctlr->max_speed = 20000000;
> -       if (plat->ich_version == 9 && ich9_can_do_33mhz(plat->dev))
> +       if (plat->ich_version == 9 && ich9_can_do_33mhz(dev))
>                 ctlr->max_speed = 33000000;
>         debug("ICH SPI: Version %d detected at %p, speed %ld\n",
>               plat->ich_version, ctlr->base, ctlr->max_speed);
> @@ -676,30 +620,34 @@ int spi_write_protect_region(struct udevice *dev, uint32_t lower_limit,
>         return 0;
>  }
>
> -static int ich_spi_probe(struct udevice *bus)
> +static int ich_spi_probe(struct udevice *dev)
>  {
> -       struct ich_spi_platdata *plat = dev_get_platdata(bus);
> -       struct ich_spi_priv *priv = dev_get_priv(bus);
> +       struct ich_spi_platdata *plat = dev_get_platdata(dev);
> +       struct ich_spi_priv *priv = dev_get_priv(dev);
>         uint8_t bios_cntl;
> +       ulong sbase_addr;
>         int ret;
>
> -       ret = ich_init_controller(plat, priv);
> +       /* Check the ICH version */
> +       plat->ich_version = pch_get_version(dev->parent);
> +
> +       ret = ich_init_controller(dev, plat, priv);
>         if (ret)
>                 return ret;
>         /*
>          * Disable the BIOS write protect so write commands are allowed.  On
>          * v9, deassert SMM BIOS Write Protect Disable.
>          */
> -       if (plat->use_sbase) {
> +       if (!pch_get_sbase(dev->parent, &sbase_addr)) {
>                 bios_cntl = ich_readb(priv, priv->bcr);
>                 bios_cntl &= ~BIT(5);   /* clear Enable InSMM_STS (EISS) */
>                 bios_cntl |= 1;         /* Write Protect Disable (WPD) */
>                 ich_writeb(priv, bios_cntl, priv->bcr);
>         } else {
> -               pci_read_config_byte(plat->dev, 0xdc, &bios_cntl);
> +               dm_pci_read_config8(dev->parent, 0xdc, &bios_cntl);
>                 if (plat->ich_version == 9)
>                         bios_cntl &= ~BIT(5);
> -               pci_write_config_byte(plat->dev, 0xdc, bios_cntl | 0x1);
> +               dm_pci_write_config8(dev->parent, 0xdc, bios_cntl | 0x1);
>         }
>
>         priv->cur_speed = priv->max_speed;
> @@ -707,18 +655,6 @@ static int ich_spi_probe(struct udevice *bus)
>         return 0;
>  }
>
> -static int ich_spi_ofdata_to_platdata(struct udevice *bus)
> -{
> -       struct ich_spi_platdata *plat = dev_get_platdata(bus);
> -       int ret;
> -
> -       ret = ich_find_spi_controller(plat);
> -       if (ret)
> -               return ret;
> -
> -       return 0;
> -}
> -
>  static int ich_spi_set_speed(struct udevice *bus, uint speed)
>  {
>         struct ich_spi_priv *priv = dev_get_priv(bus);
> @@ -779,7 +715,6 @@ U_BOOT_DRIVER(ich_spi) = {
>         .id     = UCLASS_SPI,
>         .of_match = ich_spi_ids,
>         .ops    = &ich_spi_ops,
> -       .ofdata_to_platdata = ich_spi_ofdata_to_platdata,
>         .platdata_auto_alloc_size = sizeof(struct ich_spi_platdata),
>         .priv_auto_alloc_size = sizeof(struct ich_spi_priv),
>         .child_pre_probe = ich_spi_child_pre_probe,
> --

Regards,
Bin

  parent reply	other threads:[~2015-12-08 13:24 UTC|newest]

Thread overview: 22+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2015-12-01  4:11 [U-Boot] [PATCH 0/7] dm: x86: Convert ICH driver fully to driver model PCI API Simon Glass
2015-12-01  4:11 ` [U-Boot] [PATCH 1/7] dm: pci: Move pci_bus_to_hose() to compatibility Simon Glass
2015-12-08 13:22   ` Bin Meng
2015-12-01  4:11 ` [U-Boot] [PATCH 2/7] dm: pci: Add a function to write a BAR Simon Glass
2015-12-08 13:23   ` Bin Meng
2015-12-19  2:51     ` Simon Glass
2015-12-01  4:11 ` [U-Boot] [PATCH 3/7] dm: pci: Avoid using pci_bus_to_hose() in the uclass Simon Glass
2015-12-08 13:23   ` Bin Meng
2015-12-01  4:11 ` [U-Boot] [PATCH 4/7] dm: Expand the uclass for Peripheral Controller Hubs (PCH) Simon Glass
2015-12-08 13:23   ` Bin Meng
2015-12-08 13:45     ` Bin Meng
2015-12-17  4:09     ` Simon Glass
2015-12-17 10:09       ` Bin Meng
2015-12-18  2:46         ` Simon Glass
2015-12-01  4:11 ` [U-Boot] [PATCH 5/7] dm: x86: Add a driver for Intel PCH7 Simon Glass
2015-12-08 13:23   ` Bin Meng
2015-12-01  4:11 ` [U-Boot] [PATCH 6/7] dm: x86: Add a driver for Intel PCH9 Simon Glass
2015-12-08 13:23   ` Bin Meng
2015-12-01  4:11 ` [U-Boot] [PATCH 7/7] dm: x86: spi: Convert ICH SPI driver to driver model PCI API Simon Glass
2015-12-03 11:47   ` Jagan Teki
2015-12-08 13:24   ` Bin Meng [this message]
2015-12-17  4:10     ` Simon Glass

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='CAEUhbmWXH+5C4wjPnT8=dQqfX=XwcMa0Vpy3x5NH5Wpk-aT2Sg@mail.gmail.com' \
    --to=bmeng.cn@gmail.com \
    --cc=u-boot@lists.denx.de \
    /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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.