[U-Boot] board/freescale/mx6slevk: Add support for SPI NOR on the Freescale MCIMX6SLEVK Board
Fabio Estevam
festevam at gmail.com
Fri Apr 11 13:28:32 CEST 2014
On Thu, Apr 10, 2014 at 12:20 PM, Fabio Estevam <festevam at gmail.com> wrote:
> On Thu, Apr 10, 2014 at 12:05 PM, Sam Catch <dsblue.spam at gmail.com> wrote:
>> I hope this email is now in the right format.
>>
>> Hi All,
>>
>> I am trying to add support for the SPI NOR device on the Freescale
>> MCIMX6SLEVK Board. I have created a patch that should enable support but
>> the u-boot probe command still does not find the device. The process fails
>> during the ECSPI transfer.
>>
>> I have tried the following patch to the latest git master of u-boot:
>>
>> http://pastebin.com/hamK7Ybb
>>
>> U-Boot Output:
>>
>> => sf probe
>> SF: Unsupported flash IDs: manuf 00, jedec 0000, ext_jedec 0000
>> Failed to initialize SPI flash at 0:27392
>>
>> Does anyone have any insight as to why the Probe may be failing? I modeled
>> the changes on the mx6sabresd board.
>
> I see the same error here. I measured with a scope and the chip select
> signal behaves very differently compared to the mx6qsabresd board.
>
> When I do 'sf probe' on a mx6qsabresd the chip select line stays low
> for 10us and then stays high.
>
> On mx6slevk the chip select line stays low for 0.5us, then it goes
> high, goes low for 2us and they stays high.
>
> So there is something very wrong with the timings on mx6sl, but I
> haven't had a chance to debug this yet.
I have fixed the problem: just apply this one on top of the previous
patch I sent you:
--- a/arch/arm/include/asm/arch-mx6/mx6sl_pins.h
+++ b/arch/arm/include/asm/arch-mx6/mx6sl_pins.h
@@ -13,7 +13,7 @@ enum {
MX6_PAD_ECSPI1_MISO__ECSPI_MISO =
IOMUX_PAD(0x0358, 0x0068, 0, 0x0684, 0, 0),
MX6_PAD_ECSPI1_MOSI__ECSPI_MOSI =
IOMUX_PAD(0x035C, 0x006C, 0, 0x0688, 0, 0),
MX6_PAD_ECSPI1_SCLK__ECSPI_SCLK =
IOMUX_PAD(0x0360, 0x0070, 0, 0x067C, 0, 0),
- MX6_PAD_ECSPI1_SS0__GPIO4_IO11 =
IOMUX_PAD(0x0364, 0x0074, 0, 0x0000, 5, 0),
+ MX6_PAD_ECSPI1_SS0__GPIO4_IO11 =
IOMUX_PAD(0x0364, 0x0074, 5, 0x0000, 0, 0),
MX6_PAD_SD2_CLK__USDHC2_CLK =
IOMUX_PAD(0x055C, 0x0254, 0, 0x0000, 0, 0),
MX6_PAD_SD2_CMD__USDHC2_CMD =
IOMUX_PAD(0x0560, 0x0258, 0, 0x0000, 0, 0),
MX6_PAD_SD2_DAT0__USDHC2_DAT0
Then it will work fine:
=> sf probe
SF: Detected M25P32 with page size 256 Bytes, erase size 64 KiB, total 4 MiB
I will submit a formal patch soon.
Regards,
Fabio Estevam
More information about the U-Boot
mailing list