diff options
author | Corey Minyard <cminyard@mvista.com> | 2019-04-24 08:32:02 -0500 |
---|---|---|
committer | Corey Minyard <cminyard@mvista.com> | 2019-04-24 09:02:53 -0500 |
commit | d73236383eb1cd4b7b65c33a09f0ed45f6781f40 (patch) | |
tree | 65d4c68c22e5b2222cea8029c5e9b9fd3bde2997 /drivers/char/ipmi/ipmi_plat_data.c | |
parent | b779ceadf548b2fc13ce6694d9a480d6a4330b35 (diff) | |
download | linux-d73236383eb1cd4b7b65c33a09f0ed45f6781f40.tar.gz linux-d73236383eb1cd4b7b65c33a09f0ed45f6781f40.tar.bz2 linux-d73236383eb1cd4b7b65c33a09f0ed45f6781f40.zip |
ipmi: Add the i2c-addr property for SSIF interfaces
This is required for SSIF to work.
There was no way to know if the interface being added was SI
or SSIF from the platform data, but that was required so the
i2c-addr is only added for SSIF interfaces. So add a field
for that.
Also rework the logic a bit so that ipmi-type is not set
for SSIF interfaces, as it is not necessary for that.
Fixes: 3cd83bac481d ("ipmi: Consolidate the adding of platform devices")
Reported-by: Kamlakant Patel <kamlakantp@marvell.com>
Signed-off-by: Corey Minyard <cminyard@mvista.com>
Cc: stable@vger.kernel.org # 5.1
Diffstat (limited to 'drivers/char/ipmi/ipmi_plat_data.c')
-rw-r--r-- | drivers/char/ipmi/ipmi_plat_data.c | 27 |
1 files changed, 15 insertions, 12 deletions
diff --git a/drivers/char/ipmi/ipmi_plat_data.c b/drivers/char/ipmi/ipmi_plat_data.c index 8f0ca2a848eb..28471ff2a3a3 100644 --- a/drivers/char/ipmi/ipmi_plat_data.c +++ b/drivers/char/ipmi/ipmi_plat_data.c @@ -12,7 +12,7 @@ struct platform_device *ipmi_platform_add(const char *name, unsigned int inst, struct ipmi_plat_data *p) { struct platform_device *pdev; - unsigned int num_r = 1, size, pidx = 0; + unsigned int num_r = 1, size = 0, pidx = 0; struct resource r[4]; struct property_entry pr[6]; u32 flags; @@ -21,19 +21,22 @@ struct platform_device *ipmi_platform_add(const char *name, unsigned int inst, memset(pr, 0, sizeof(pr)); memset(r, 0, sizeof(r)); - if (p->type == SI_BT) - size = 3; - else if (p->type == SI_TYPE_INVALID) - size = 0; - else - size = 2; + if (p->iftype == IPMI_PLAT_IF_SI) { + if (p->type == SI_BT) + size = 3; + else if (p->type != SI_TYPE_INVALID) + size = 2; + + if (p->regsize == 0) + p->regsize = DEFAULT_REGSIZE; + if (p->regspacing == 0) + p->regspacing = p->regsize; - if (p->regsize == 0) - p->regsize = DEFAULT_REGSIZE; - if (p->regspacing == 0) - p->regspacing = p->regsize; + pr[pidx++] = PROPERTY_ENTRY_U8("ipmi-type", p->type); + } else if (p->iftype == IPMI_PLAT_IF_SSIF) { + pr[pidx++] = PROPERTY_ENTRY_U16("i2c-addr", p->addr); + } - pr[pidx++] = PROPERTY_ENTRY_U8("ipmi-type", p->type); if (p->slave_addr) pr[pidx++] = PROPERTY_ENTRY_U8("slave-addr", p->slave_addr); pr[pidx++] = PROPERTY_ENTRY_U8("addr-source", p->addr_source); |