[PATCH 2/3] ARM: i.mx53: Parse Reset GPIO pin in FEC driver from Devicetree
Sascha Hauer
s.hauer at pengutronix.de
Wed Nov 13 05:35:10 EST 2013
On Tue, Nov 12, 2013 at 11:46:35PM +0100, Rostislav Lisovy wrote:
> Signed-off-by: Rostislav Lisovy <lisovy at gmail.com>
>
> diff --git a/drivers/net/fec_imx.c b/drivers/net/fec_imx.c
> index 2f31352..9855e8c 100644
> --- a/drivers/net/fec_imx.c
> +++ b/drivers/net/fec_imx.c
> @@ -27,6 +27,8 @@
> #include <linux/clk.h>
> #include <linux/err.h>
> #include <of_net.h>
> +#include <of_gpio.h>
> +#include <gpio.h>
>
> #include <asm/mmu.h>
>
> @@ -643,6 +645,7 @@ static int fec_probe(struct device_d *dev)
> void *base;
> int ret;
> enum fec_type type;
> + int phy_reset;
>
> ret = dev_get_drvdata(dev, (unsigned long *)&type);
> if (ret)
> @@ -671,6 +674,36 @@ static int fec_probe(struct device_d *dev)
>
> fec->regs = dev_request_mem_region(dev, 0);
>
> + if (IS_ENABLED(CONFIG_OFDEVICE)) {
This check shouldn't be needed. of_get_named_gpio() epxands to a static
inline function returning -ENOSYS if we are compiling without devicetree
support.
> + phy_reset = of_get_named_gpio(dev->device_node, "phy-reset-gpios", 0);
> + if (phy_reset < 0) {
Use gpio_is_valid(phy_reset) directly here...
> + pr_info("%s: 'phy-reset-gpios' not used. Skipping hardware PHY reset.\n", __func__);
> + } else {
> + if (!gpio_is_valid(phy_reset)) {
...and drop this check.
> + pr_err("%s: 'phy-reset' gpio is not valid:\n",
> + __func__);
Driver messages should be done with dev_* functions, but in this case
most of the messages should be dropped as they all add to the binary
size of the image. Even without messages barebox will print an error
message if probing of a device fails. This message is a good enough hint
for the developer to find out where the problem is.
Sascha
--
Pengutronix e.K. | |
Industrial Linux Solutions | http://www.pengutronix.de/ |
Peiner Str. 6-8, 31137 Hildesheim, Germany | Phone: +49-5121-206917-0 |
Amtsgericht Hildesheim, HRA 2686 | Fax: +49-5121-206917-5555 |
More information about the barebox
mailing list