[PATCH] drivers/nor: allow overriding of AMD_ADDR_* in board-configs
Sascha Hauer
s.hauer at pengutronix.de
Thu Jun 17 04:54:04 EDT 2010
On Thu, Jun 17, 2010 at 05:22:45AM +0200, Wolfram Sang wrote:
> Because there are a number of flash-makers who did it wrong.
>
> Signed-off-by: Wolfram Sang <w.sang at pengutronix.de>
> ---
> drivers/nor/cfi_flash.h | 13 ++++++++++---
> 1 files changed, 10 insertions(+), 3 deletions(-)
>
> diff --git a/drivers/nor/cfi_flash.h b/drivers/nor/cfi_flash.h
> index a8fa879..a278772 100644
> --- a/drivers/nor/cfi_flash.h
> +++ b/drivers/nor/cfi_flash.h
> @@ -109,9 +109,16 @@ extern struct cfi_cmd_set cfi_cmd_set_amd;
> #define AMD_STATUS_TOGGLE 0x40
> #define AMD_STATUS_ERROR 0x20
>
> -#define AMD_ADDR_ERASE_START ((info->portwidth == FLASH_CFI_8BIT) ? 0xAAA : 0x555)
> -#define AMD_ADDR_START ((info->portwidth == FLASH_CFI_8BIT) ? 0xAAA : 0x555)
> -#define AMD_ADDR_ACK ((info->portwidth == FLASH_CFI_8BIT) ? 0x555 : 0x2AA)
> +/* AMD_ADDR_* can be overridden in board-specific config.h files */
> +#ifndef AMD_ADDR_ERASE_START
> +# define AMD_ADDR_ERASE_START ((info->portwidth == FLASH_CFI_8BIT) ? 0xAAA : 0x555)
> +#endif
> +#ifndef AMD_ADDR_START
> +# define AMD_ADDR_START ((info->portwidth == FLASH_CFI_8BIT) ? 0xAAA : 0x555)
> +#endif
> +#ifndef AMD_ADDR_ACK
> +# define AMD_ADDR_ACK ((info->portwidth == FLASH_CFI_8BIT) ? 0x555 : 0x2AA)
> +#endif
Uh, Having arbitrary board specific defines is exactly what I wanted to
get rid of while rewriting U-Boot. Sorry, this is not acceptable.
There are some ways to do this: You could add a runtime detection if
possible, maybe combined with a kconfig option if it influences image
size too badly. Or you could add the information to platform_data.
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