MTD XIP related issue
Avik Sil
savik at zilog.com
Mon Nov 17 04:26:02 EST 2008
Thanks a lot. It's working fine now.
-Avik
-----Original Message-----
From: linux-mtd-bounces at lists.infradead.org
[mailto:linux-mtd-bounces at lists.infradead.org] On Behalf Of Paulius
Zaleckas
Sent: Friday, November 14, 2008 6:13 PM
To: Avik Sil
Cc: Nicolas Pitre; linux-mtd at lists.infradead.org
Subject: Re: MTD XIP related issue
Avik Sil wrote:
> While porting Linux kernel 2.6.26 on an ARM922T based custom board for
> XIP kernel, I came across the following bug report during boot-up:
Had the same problem. See my comments on your config file
[...]
> My kernel configuration is:
[...]
> #
>
> # RAM/ROM/Flash chip drivers
>
> #
>
> CONFIG_MTD_CFI=y
>
> # CONFIG_MTD_JEDECPROBE is not set
>
> CONFIG_MTD_GEN_PROBE=y
>
> # CONFIG_MTD_CFI_ADV_OPTIONS is not set
>
> CONFIG_MTD_MAP_BANK_WIDTH_1=y
>
> CONFIG_MTD_MAP_BANK_WIDTH_2=y
>
> CONFIG_MTD_MAP_BANK_WIDTH_4=y
Select only the supported BANK_WIDTH.
The problem is that if multiple bank widths are selected, then in code
which is placed
in RAM for XIP to work appears reference to __udivsi3(if I remember
correctly) and
this function is on FLASH and FLASH at that moment is inaccessible.
Sometimes it works because this function is already cached by CPU.
Nicolas: I think there should be some way to work around this... If not
maybe we should
add compile #error if multiple bank widths and XIP are selected...
> # CONFIG_MTD_MAP_BANK_WIDTH_8 is not set
>
> # CONFIG_MTD_MAP_BANK_WIDTH_16 is not set
>
> # CONFIG_MTD_MAP_BANK_WIDTH_32 is not set
>
> CONFIG_MTD_CFI_I1=y
>
> CONFIG_MTD_CFI_I2=y
Don't remember, but this may have the same effect also.
> # CONFIG_MTD_CFI_I4 is not set
>
> # CONFIG_MTD_CFI_I8 is not set
>
> # CONFIG_MTD_CFI_INTELEXT is not set
>
> CONFIG_MTD_CFI_AMDSTD=y
>
> # CONFIG_MTD_CFI_STAA is not set
>
> CONFIG_MTD_CFI_UTIL=y
>
> # CONFIG_MTD_RAM is not set
>
> # CONFIG_MTD_ROM is not set
>
> # CONFIG_MTD_ABSENT is not set
>
> CONFIG_MTD_XIP=y
______________________________________________________
Linux MTD discussion mailing list
http://lists.infradead.org/mailman/listinfo/linux-mtd/
More information about the linux-mtd
mailing list