[PATCH 14/15] ARM: mxs: Add initial mx28evk support
Uwe Kleine-König
u.kleine-koenig at pengutronix.de
Tue Nov 30 15:06:29 EST 2010
On Fri, Nov 26, 2010 at 02:49:13PM +0800, Shawn Guo wrote:
> Add initial mx28evk support with duart and fec0.
>
> Signed-off-by: Shawn Guo <shawn.guo at freescale.com>
> ---
> arch/arm/mach-mxs/mach-mx28evk.c | 108 ++++++++++++++++++++++++++++++++++++++
> 1 files changed, 108 insertions(+), 0 deletions(-)
> create mode 100644 arch/arm/mach-mxs/mach-mx28evk.c
>
> diff --git a/arch/arm/mach-mxs/mach-mx28evk.c b/arch/arm/mach-mxs/mach-mx28evk.c
> new file mode 100644
> index 0000000..901e6b1
> --- /dev/null
> +++ b/arch/arm/mach-mxs/mach-mx28evk.c
> @@ -0,0 +1,108 @@
> +/*
> + * Copyright 2010 Freescale Semiconductor, Inc. All Rights Reserved.
> + *
> + * This program is free software; you can redistribute it and/or modify
> + * it under the terms of the GNU General Public License as published by
> + * the Free Software Foundation; either version 2 of the License, or
> + * (at your option) any later version.
> + *
> + * This program is distributed in the hope that it will be useful,
> + * but WITHOUT ANY WARRANTY; without even the implied warranty of
> + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
> + * GNU General Public License for more details.
> + */
> +
> +#include <linux/delay.h>
> +#include <linux/platform_device.h>
> +#include <linux/gpio.h>
> +#include <linux/irq.h>
> +
> +#include <asm/mach-types.h>
> +#include <asm/mach/arch.h>
> +#include <asm/mach/time.h>
> +
> +#include <mach/hardware.h>
> +#include <mach/common.h>
> +#include <mach/iomux-mx28.h>
> +
> +#include "devices-mx28.h"
> +
> +#define MX28EVK_FEC_PHY_POWER MXS_GPIO_NR(2, 15)
> +#define MX28EVK_FEC_PHY_RESET MXS_GPIO_NR(4, 13)
> +
> +static iomux_cfg_t mx28evk_pads[] = {
> + /* duart */
> + MX28_PAD_PWM0__DUART_RX,
> + MX28_PAD_PWM1__DUART_TX,
> +
> + /* fec0 */
> + MX28_PAD_ENET0_MDC__ENET0_MDC,
> + MX28_PAD_ENET0_MDIO__ENET0_MDIO,
> + MX28_PAD_ENET0_RX_EN__ENET0_RX_EN,
> + MX28_PAD_ENET0_RXD0__ENET0_RXD0,
> + MX28_PAD_ENET0_RXD1__ENET0_RXD1,
> + MX28_PAD_ENET0_TX_EN__ENET0_TX_EN,
> + MX28_PAD_ENET0_TXD0__ENET0_TXD0,
> + MX28_PAD_ENET0_TXD1__ENET0_TXD1,
> + MX28_PAD_ENET_CLK__ENET_CLK,
> + /* phy power line */
> + MX28_PAD_SSP1_DATA3__GPIO_2_15,
> + /* phy reset line */
> + MX28_PAD_ENET0_RX_CLK__GPIO_4_13,
> +};
> +
> +/* fec */
> +static inline void mx28evk_fec_reset(void)
If the function is inlined everything is OK. If not it should live in
.init.text. I suggest to remove the inline to give the compiler the
freedom to inline it or not and mark it with __init.
> +{
> + int ret;
> +
> + /* Power up fec phy */
> + ret = gpio_request(MX28EVK_FEC_PHY_POWER, "fec-phy-power");
> + if (ret) {
> + pr_err("Failed to request GPIO_FEC_PHY_POWER: %d\n", ret);
> + return;
> + }
> + gpio_direction_output(MX28EVK_FEC_PHY_POWER, 0);
technically gpio_direction_output can fail. Not sure this matters much
here though.
> +
> + /* Reset fec phy */
> + ret = gpio_request(MX28EVK_FEC_PHY_RESET, "fec-phy-reset");
> + if (ret) {
> + pr_err("Failed to request GPIO_FEC_PHY_RESET: %d\n", ret);
You can save a few bytes here by using the same format string as above.
Obviously you need to pass "POWER" and "RESET" as parameter for that.
Is it worth the effort? Up to you to decide.
> + return;
> + }
> + gpio_direction_output(MX28EVK_FEC_PHY_RESET, 0);
> + mdelay(1);
> + gpio_set_value(MX28EVK_FEC_PHY_RESET, 1);
> +}
> +
> +static const struct fec_platform_data mx28_fec_pdata __initconst = {
> + .phy = PHY_INTERFACE_MODE_RMII,
> +};
> +
> +static void __init mx28evk_init(void)
> +{
> + mxs_iomux_setup_multiple_pads(mx28evk_pads, ARRAY_SIZE(mx28evk_pads));
> +
> + mx28_add_duart();
> +
> + mx28evk_fec_reset();
> + mx28_add_fec0(&mx28_fec_pdata);
> +}
> +
> +static void __init mx28evk_timer_init(void)
> +{
> + mx28_clocks_init();
> +}
> +
> +static struct sys_timer mx28evk_timer = {
> + .init = mx28evk_timer_init,
> +};
> +
> +MACHINE_START(MX28EVK, "Freescale MX28 EVK")
> + /* Maintainer: Freescale Semiconductor, Inc. */
> + .boot_params = PHYS_OFFSET + 0x100,
> + .map_io = mx28_map_io,
> + .init_irq = mx28_init_irq,
> + .init_machine = mx28evk_init,
> + .timer = &mx28evk_timer,
> +MACHINE_END
> --
> 1.7.1
>
>
>
--
Pengutronix e.K. | Uwe Kleine-König |
Industrial Linux Solutions | http://www.pengutronix.de/ |
More information about the linux-arm-kernel
mailing list