From: Kevin Hilman <khilman@ti.com>
To: "Hiremath, Vaibhav" <hvaibhav@ti.com>
Cc: "linux-omap@vger.kernel.org" <linux-omap@vger.kernel.org>,
"Varadarajan, Charulatha" <charu@ti.com>,
"linux-arm-kernel@lists.infradead.org"
<linux-arm-kernel@lists.infradead.org>
Subject: Re: [PATCH-V2] OMAP3EVM:FIX: Reset the smsc911x ethernet controller in board_init
Date: Thu, 27 Jan 2011 11:58:33 -0800 [thread overview]
Message-ID: <874o8um846.fsf@ti.com> (raw)
In-Reply-To: <19F8576C6E063C45BE387C64729E739404BD7BE3F4@dbde02.ent.ti.com> (Vaibhav Hiremath's message of "Tue, 25 Jan 2011 20:58:44 +0530")
"Hiremath, Vaibhav" <hvaibhav@ti.com> writes:
>> -----Original Message-----
>> From: Hiremath, Vaibhav
>> Sent: Tuesday, January 25, 2011 8:53 PM
>> To: linux-omap@vger.kernel.org
>> Cc: Hiremath, Vaibhav; Varadarajan, Charulatha
>> Subject: [PATCH-V2] OMAP3EVM:FIX: Reset the smsc911x ethernet controller
>> in board_init
>>
>> With addition of hwmod support to gpio, the ethernet controller
>> goes undetected for OMAP35xEVM. So explicitly assert the reset signal to
>> ethernet controller smsc911x -
>>
>> - GPIO7 (>=RevG version of EVM's)
>> - GPIO64 (<=RevD version of EVM's)
>>
>> This patch is based on intial version from Charulatha V, reference
>> to original discussion -
>> http://www.mail-archive.com/linux-omap@vger.kernel.org/msg35784.html
>> Signed-off-by: Vaibhav Hiremath <hvaibhav@ti.com>
>> Signed-off-by: Charulatha V <charu@ti.com>
>> Tested-by: Kevin Hilman <khilman@ti.com>
>> ---
>> Since Kevin reported that this patch doesn't get applied cleanly,
>> so I am reposting it again after making sure that it gets applied cleanly.
>>
> [Hiremath, Vaibhav] Oops, missed linux-arm-kernel list, adding here.
>
> Not sure whether I need to repost keeping linux-arm-kernel?
Yes, please repost.
Kevin
>
>> arch/arm/mach-omap2/board-omap3evm.c | 39
>> +++++++++++++++++++++++++++++++++-
>> 1 files changed, 38 insertions(+), 1 deletions(-)
>>
>> diff --git a/arch/arm/mach-omap2/board-omap3evm.c b/arch/arm/mach-
>> omap2/board-omap3evm.c
>> index 323c380..97e0f65 100644
>> --- a/arch/arm/mach-omap2/board-omap3evm.c
>> +++ b/arch/arm/mach-omap2/board-omap3evm.c
>> @@ -58,6 +58,13 @@
>> #define OMAP3EVM_ETHR_ID_REV 0x50
>> #define OMAP3EVM_ETHR_GPIO_IRQ 176
>> #define OMAP3EVM_SMSC911X_CS 5
>> +/*
>> + * Eth Reset signal
>> + * 64 = Generation 1 (<=RevD)
>> + * 7 = Generation 2 (>=RevE)
>> + */
>> +#define OMAP3EVM_GEN1_ETHR_GPIO_RST 64
>> +#define OMAP3EVM_GEN2_ETHR_GPIO_RST 7
>>
>> static u8 omap3_evm_version;
>>
>> @@ -124,10 +131,15 @@ static struct platform_device
>> omap3evm_smsc911x_device = {
>>
>> static inline void __init omap3evm_init_smsc911x(void)
>> {
>> - int eth_cs;
>> + int eth_cs, eth_rst;
>> struct clk *l3ck;
>> unsigned int rate;
>>
>> + if (get_omap3_evm_rev() == OMAP3EVM_BOARD_GEN_1)
>> + eth_rst = OMAP3EVM_GEN1_ETHR_GPIO_RST;
>> + else
>> + eth_rst = OMAP3EVM_GEN2_ETHR_GPIO_RST;
>> +
>> eth_cs = OMAP3EVM_SMSC911X_CS;
>>
>> l3ck = clk_get(NULL, "l3_ck");
>> @@ -136,6 +148,27 @@ static inline void __init
>> omap3evm_init_smsc911x(void)
>> else
>> rate = clk_get_rate(l3ck);
>>
>> + /* Configure ethernet controller reset gpio */
>> + if (cpu_is_omap3430()) {
>> + if (gpio_request(eth_rst, "SMSC911x gpio") < 0) {
>> + pr_err(KERN_ERR "Failed to request %d for smsc911x\n",
>> + eth_rst);
>> + return;
>> + }
>> +
>> + if (gpio_direction_output(eth_rst, 1) < 0) {
>> + pr_err(KERN_ERR "Failed to set direction of %d for" \
>> + " smsc911x\n", eth_rst);
>> + return;
>> + }
>> + /* reset pulse to ethernet controller*/
>> + usleep_range(150, 220);
>> + gpio_set_value(eth_rst, 0);
>> + usleep_range(150, 220);
>> + gpio_set_value(eth_rst, 1);
>> + usleep_range(1, 2);
>> + }
>> +
>> if (gpio_request(OMAP3EVM_ETHR_GPIO_IRQ, "SMSC911x irq") < 0) {
>> printk(KERN_ERR "Failed to request GPIO%d for smsc911x IRQ\n",
>> OMAP3EVM_ETHR_GPIO_IRQ);
>> @@ -658,6 +691,10 @@ static struct omap_board_mux board_mux[] __initdata =
>> {
>> OMAP_PIN_OFF_WAKEUPENABLE),
>> OMAP3_MUX(MCSPI1_CS1, OMAP_MUX_MODE4 | OMAP_PIN_INPUT_PULLUP |
>> OMAP_PIN_OFF_INPUT_PULLUP |
>> OMAP_PIN_OFF_OUTPUT_LOW),
>> + OMAP3_MUX(SYS_BOOT5, OMAP_MUX_MODE4 | OMAP_PIN_INPUT_PULLUP |
>> + OMAP_PIN_OFF_NONE),
>> + OMAP3_MUX(GPMC_WAIT2, OMAP_MUX_MODE4 | OMAP_PIN_INPUT_PULLUP |
>> + OMAP_PIN_OFF_NONE),
>> { .reg_offset = OMAP_MUX_TERMINATOR },
>> };
>> #endif
>> --
>> 1.6.2.4
>
> --
> To unsubscribe from this list: send the line "unsubscribe linux-omap" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at http://vger.kernel.org/majordomo-info.html
WARNING: multiple messages have this Message-ID (diff)
From: khilman@ti.com (Kevin Hilman)
To: linux-arm-kernel@lists.infradead.org
Subject: [PATCH-V2] OMAP3EVM:FIX: Reset the smsc911x ethernet controller in board_init
Date: Thu, 27 Jan 2011 11:58:33 -0800 [thread overview]
Message-ID: <874o8um846.fsf@ti.com> (raw)
In-Reply-To: <19F8576C6E063C45BE387C64729E739404BD7BE3F4@dbde02.ent.ti.com> (Vaibhav Hiremath's message of "Tue, 25 Jan 2011 20:58:44 +0530")
"Hiremath, Vaibhav" <hvaibhav@ti.com> writes:
>> -----Original Message-----
>> From: Hiremath, Vaibhav
>> Sent: Tuesday, January 25, 2011 8:53 PM
>> To: linux-omap at vger.kernel.org
>> Cc: Hiremath, Vaibhav; Varadarajan, Charulatha
>> Subject: [PATCH-V2] OMAP3EVM:FIX: Reset the smsc911x ethernet controller
>> in board_init
>>
>> With addition of hwmod support to gpio, the ethernet controller
>> goes undetected for OMAP35xEVM. So explicitly assert the reset signal to
>> ethernet controller smsc911x -
>>
>> - GPIO7 (>=RevG version of EVM's)
>> - GPIO64 (<=RevD version of EVM's)
>>
>> This patch is based on intial version from Charulatha V, reference
>> to original discussion -
>> http://www.mail-archive.com/linux-omap at vger.kernel.org/msg35784.html
>> Signed-off-by: Vaibhav Hiremath <hvaibhav@ti.com>
>> Signed-off-by: Charulatha V <charu@ti.com>
>> Tested-by: Kevin Hilman <khilman@ti.com>
>> ---
>> Since Kevin reported that this patch doesn't get applied cleanly,
>> so I am reposting it again after making sure that it gets applied cleanly.
>>
> [Hiremath, Vaibhav] Oops, missed linux-arm-kernel list, adding here.
>
> Not sure whether I need to repost keeping linux-arm-kernel?
Yes, please repost.
Kevin
>
>> arch/arm/mach-omap2/board-omap3evm.c | 39
>> +++++++++++++++++++++++++++++++++-
>> 1 files changed, 38 insertions(+), 1 deletions(-)
>>
>> diff --git a/arch/arm/mach-omap2/board-omap3evm.c b/arch/arm/mach-
>> omap2/board-omap3evm.c
>> index 323c380..97e0f65 100644
>> --- a/arch/arm/mach-omap2/board-omap3evm.c
>> +++ b/arch/arm/mach-omap2/board-omap3evm.c
>> @@ -58,6 +58,13 @@
>> #define OMAP3EVM_ETHR_ID_REV 0x50
>> #define OMAP3EVM_ETHR_GPIO_IRQ 176
>> #define OMAP3EVM_SMSC911X_CS 5
>> +/*
>> + * Eth Reset signal
>> + * 64 = Generation 1 (<=RevD)
>> + * 7 = Generation 2 (>=RevE)
>> + */
>> +#define OMAP3EVM_GEN1_ETHR_GPIO_RST 64
>> +#define OMAP3EVM_GEN2_ETHR_GPIO_RST 7
>>
>> static u8 omap3_evm_version;
>>
>> @@ -124,10 +131,15 @@ static struct platform_device
>> omap3evm_smsc911x_device = {
>>
>> static inline void __init omap3evm_init_smsc911x(void)
>> {
>> - int eth_cs;
>> + int eth_cs, eth_rst;
>> struct clk *l3ck;
>> unsigned int rate;
>>
>> + if (get_omap3_evm_rev() == OMAP3EVM_BOARD_GEN_1)
>> + eth_rst = OMAP3EVM_GEN1_ETHR_GPIO_RST;
>> + else
>> + eth_rst = OMAP3EVM_GEN2_ETHR_GPIO_RST;
>> +
>> eth_cs = OMAP3EVM_SMSC911X_CS;
>>
>> l3ck = clk_get(NULL, "l3_ck");
>> @@ -136,6 +148,27 @@ static inline void __init
>> omap3evm_init_smsc911x(void)
>> else
>> rate = clk_get_rate(l3ck);
>>
>> + /* Configure ethernet controller reset gpio */
>> + if (cpu_is_omap3430()) {
>> + if (gpio_request(eth_rst, "SMSC911x gpio") < 0) {
>> + pr_err(KERN_ERR "Failed to request %d for smsc911x\n",
>> + eth_rst);
>> + return;
>> + }
>> +
>> + if (gpio_direction_output(eth_rst, 1) < 0) {
>> + pr_err(KERN_ERR "Failed to set direction of %d for" \
>> + " smsc911x\n", eth_rst);
>> + return;
>> + }
>> + /* reset pulse to ethernet controller*/
>> + usleep_range(150, 220);
>> + gpio_set_value(eth_rst, 0);
>> + usleep_range(150, 220);
>> + gpio_set_value(eth_rst, 1);
>> + usleep_range(1, 2);
>> + }
>> +
>> if (gpio_request(OMAP3EVM_ETHR_GPIO_IRQ, "SMSC911x irq") < 0) {
>> printk(KERN_ERR "Failed to request GPIO%d for smsc911x IRQ\n",
>> OMAP3EVM_ETHR_GPIO_IRQ);
>> @@ -658,6 +691,10 @@ static struct omap_board_mux board_mux[] __initdata =
>> {
>> OMAP_PIN_OFF_WAKEUPENABLE),
>> OMAP3_MUX(MCSPI1_CS1, OMAP_MUX_MODE4 | OMAP_PIN_INPUT_PULLUP |
>> OMAP_PIN_OFF_INPUT_PULLUP |
>> OMAP_PIN_OFF_OUTPUT_LOW),
>> + OMAP3_MUX(SYS_BOOT5, OMAP_MUX_MODE4 | OMAP_PIN_INPUT_PULLUP |
>> + OMAP_PIN_OFF_NONE),
>> + OMAP3_MUX(GPMC_WAIT2, OMAP_MUX_MODE4 | OMAP_PIN_INPUT_PULLUP |
>> + OMAP_PIN_OFF_NONE),
>> { .reg_offset = OMAP_MUX_TERMINATOR },
>> };
>> #endif
>> --
>> 1.6.2.4
>
> --
> To unsubscribe from this list: send the line "unsubscribe linux-omap" in
> the body of a message to majordomo at vger.kernel.org
> More majordomo info at http://vger.kernel.org/majordomo-info.html
next prev parent reply other threads:[~2011-01-27 19:58 UTC|newest]
Thread overview: 12+ messages / expand[flat|nested] mbox.gz Atom feed top
2011-01-25 15:22 [PATCH-V2] OMAP3EVM:FIX: Reset the smsc911x ethernet controller in board_init Vaibhav Hiremath
2011-01-25 15:28 ` Hiremath, Vaibhav
2011-01-25 15:28 ` Hiremath, Vaibhav
2011-01-25 16:09 ` Will Deacon
2011-01-25 16:09 ` Will Deacon
2011-01-27 19:58 ` Kevin Hilman [this message]
2011-01-27 19:58 ` Kevin Hilman
2011-01-27 20:08 ` Kevin Hilman
2011-01-27 20:08 ` Kevin Hilman
2011-01-29 12:11 ` Hiremath, Vaibhav
2011-01-29 12:11 ` Hiremath, Vaibhav
-- strict thread matches above, loose matches on Subject: below --
2011-01-24 19:25 Vaibhav Hiremath
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=874o8um846.fsf@ti.com \
--to=khilman@ti.com \
--cc=charu@ti.com \
--cc=hvaibhav@ti.com \
--cc=linux-arm-kernel@lists.infradead.org \
--cc=linux-omap@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.