提交 50f09073 编写于 作者: M Martin Blumenstingl 提交者: Linus Walleij

gpio: stp-xway: Use the of_property_read_u32 helper

This removes some redundant code but does not have any functional impact.
Signed-off-by: NMartin Blumenstingl <martin.blumenstingl@googlemail.com>
Signed-off-by: NLinus Walleij <linus.walleij@linaro.org>
上级 ffb8e44b
...@@ -200,7 +200,7 @@ static int xway_stp_hw_init(struct xway_stp *chip) ...@@ -200,7 +200,7 @@ static int xway_stp_hw_init(struct xway_stp *chip)
static int xway_stp_probe(struct platform_device *pdev) static int xway_stp_probe(struct platform_device *pdev)
{ {
struct resource *res; struct resource *res;
const __be32 *shadow, *groups, *dsl, *phy; u32 shadow, groups, dsl, phy;
struct xway_stp *chip; struct xway_stp *chip;
struct clk *clk; struct clk *clk;
int ret = 0; int ret = 0;
...@@ -223,33 +223,28 @@ static int xway_stp_probe(struct platform_device *pdev) ...@@ -223,33 +223,28 @@ static int xway_stp_probe(struct platform_device *pdev)
chip->gc.owner = THIS_MODULE; chip->gc.owner = THIS_MODULE;
/* store the shadow value if one was passed by the devicetree */ /* store the shadow value if one was passed by the devicetree */
shadow = of_get_property(pdev->dev.of_node, "lantiq,shadow", NULL); if (!of_property_read_u32(pdev->dev.of_node, "lantiq,shadow", &shadow))
if (shadow) chip->shadow = shadow;
chip->shadow = be32_to_cpu(*shadow);
/* find out which gpio groups should be enabled */ /* find out which gpio groups should be enabled */
groups = of_get_property(pdev->dev.of_node, "lantiq,groups", NULL); if (!of_property_read_u32(pdev->dev.of_node, "lantiq,groups", &groups))
if (groups) chip->groups = groups & XWAY_STP_GROUP_MASK;
chip->groups = be32_to_cpu(*groups) & XWAY_STP_GROUP_MASK;
else else
chip->groups = XWAY_STP_GROUP0; chip->groups = XWAY_STP_GROUP0;
chip->gc.ngpio = fls(chip->groups) * 8; chip->gc.ngpio = fls(chip->groups) * 8;
/* find out which gpios are controlled by the dsl core */ /* find out which gpios are controlled by the dsl core */
dsl = of_get_property(pdev->dev.of_node, "lantiq,dsl", NULL); if (!of_property_read_u32(pdev->dev.of_node, "lantiq,dsl", &dsl))
if (dsl) chip->dsl = dsl & XWAY_STP_ADSL_MASK;
chip->dsl = be32_to_cpu(*dsl) & XWAY_STP_ADSL_MASK;
/* find out which gpios are controlled by the phys */ /* find out which gpios are controlled by the phys */
if (of_machine_is_compatible("lantiq,ar9") || if (of_machine_is_compatible("lantiq,ar9") ||
of_machine_is_compatible("lantiq,gr9") || of_machine_is_compatible("lantiq,gr9") ||
of_machine_is_compatible("lantiq,vr9")) { of_machine_is_compatible("lantiq,vr9")) {
phy = of_get_property(pdev->dev.of_node, "lantiq,phy1", NULL); if (!of_property_read_u32(pdev->dev.of_node, "lantiq,phy1", &phy))
if (phy) chip->phy1 = phy & XWAY_STP_PHY_MASK;
chip->phy1 = be32_to_cpu(*phy) & XWAY_STP_PHY_MASK; if (!of_property_read_u32(pdev->dev.of_node, "lantiq,phy2", &phy))
phy = of_get_property(pdev->dev.of_node, "lantiq,phy2", NULL); chip->phy2 = phy & XWAY_STP_PHY_MASK;
if (phy)
chip->phy2 = be32_to_cpu(*phy) & XWAY_STP_PHY_MASK;
} }
/* check which edge trigger we should use, default to a falling edge */ /* check which edge trigger we should use, default to a falling edge */
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册