[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <CAHp75VdnCtCrKoMSMUfqpVruG0hJjY99wntUaqfk2C3qTccSzA@mail.gmail.com>
Date: Tue, 2 May 2017 11:02:44 +0300
From: Andy Shevchenko <andy.shevchenko@...il.com>
To: Jan Kiszka <jan.kiszka@...mens.com>
Cc: Giuseppe Cavallaro <peppe.cavallaro@...com>,
Alexandre Torgue <alexandre.torgue@...com>,
David Miller <davem@...emloft.net>,
netdev <netdev@...r.kernel.org>,
Linux Kernel Mailing List <linux-kernel@...r.kernel.org>,
Sascha Weisenberger <sascha.weisenberger@...mens.com>
Subject: Re: [PATCH v2] stmmac: Add support for SIMATIC IOT2000 platform
On Tue, May 2, 2017 at 10:58 AM, Jan Kiszka <jan.kiszka@...mens.com> wrote:
> The IOT2000 is industrial controller platform, derived from the Intel
> Galileo Gen2 board. The variant IOT2020 comes with one LAN port, the
> IOT2040 has two of them. They can be told apart based on the board asset
> tag in the DMI table.
>
> Based on patch by Sascha Weisenberger.
>
> Signed-off-by: Jan Kiszka <jan.kiszka@...mens.com>
> Signed-off-by: Sascha Weisenberger <sascha.weisenberger@...mens.com>
Reviewed-by: Andy Shevchenko <andy.shevchenko@...il.com>
> ---
>
> Changes in v2:
> - reformatted match conditions [Andy]
>
> drivers/net/ethernet/stmicro/stmmac/stmmac_pci.c | 26 +++++++++++++++++++++++-
> 1 file changed, 25 insertions(+), 1 deletion(-)
>
> diff --git a/drivers/net/ethernet/stmicro/stmmac/stmmac_pci.c b/drivers/net/ethernet/stmicro/stmmac/stmmac_pci.c
> index 5c9e462276b9..11d2229e536b 100644
> --- a/drivers/net/ethernet/stmicro/stmmac/stmmac_pci.c
> +++ b/drivers/net/ethernet/stmicro/stmmac/stmmac_pci.c
> @@ -32,6 +32,7 @@
> */
> struct stmmac_pci_dmi_data {
> const char *name;
> + const char *asset_tag;
> unsigned int func;
> int phy_addr;
> };
> @@ -46,6 +47,7 @@ struct stmmac_pci_info {
> static int stmmac_pci_find_phy_addr(struct stmmac_pci_info *info)
> {
> const char *name = dmi_get_system_info(DMI_BOARD_NAME);
> + const char *asset_tag = dmi_get_system_info(DMI_BOARD_ASSET_TAG);
> unsigned int func = PCI_FUNC(info->pdev->devfn);
> struct stmmac_pci_dmi_data *dmi;
>
> @@ -57,8 +59,12 @@ static int stmmac_pci_find_phy_addr(struct stmmac_pci_info *info)
> return 1;
>
> for (dmi = info->dmi; dmi->name && *dmi->name; dmi++) {
> - if (!strcmp(dmi->name, name) && dmi->func == func)
> + if (!strcmp(dmi->name, name) && dmi->func == func) {
> + /* If asset tag is provided, match on it as well. */
> + if (dmi->asset_tag && strcmp(dmi->asset_tag, asset_tag))
> + continue;
> return dmi->phy_addr;
> + }
> }
>
> return -ENODEV;
> @@ -142,6 +148,24 @@ static struct stmmac_pci_dmi_data quark_pci_dmi_data[] = {
> .func = 6,
> .phy_addr = 1,
> },
> + {
> + .name = "SIMATIC IOT2000",
> + .asset_tag = "6ES7647-0AA00-0YA2",
> + .func = 6,
> + .phy_addr = 1,
> + },
> + {
> + .name = "SIMATIC IOT2000",
> + .asset_tag = "6ES7647-0AA00-1YA2",
> + .func = 6,
> + .phy_addr = 1,
> + },
> + {
> + .name = "SIMATIC IOT2000",
> + .asset_tag = "6ES7647-0AA00-1YA2",
> + .func = 7,
> + .phy_addr = 1,
> + },
> {}
> };
>
--
With Best Regards,
Andy Shevchenko
Powered by blists - more mailing lists