[U-Boot] [PATCH 12/18] arm: mx6: add support for Compulab cm-fx6 CoM

Marek Vasut marex at denx.de
Mon Aug 4 17:12:27 CEST 2014


On Monday, August 04, 2014 at 04:41:03 PM, Nikita Kiryanov wrote:
> On 03/08/14 17:09, Marek Vasut wrote:
> > On Sunday, August 03, 2014 at 09:34:42 AM, Nikita Kiryanov wrote:
> >> Add initial support for Compulab CM-FX6 CoM.
> >> Support includes MMC, SPI flash, and SPL with dynamic DRAM detection.
> >> 
> >> Cc: Igor Grinberg <grinberg at compulab.co.il>
> >> Cc: Stefano Babic <sbabic at denx.de>
> >> Cc: Tom Rini <trini at ti.com>
> >> Signed-off-by: Nikita Kiryanov <nikita at compulab.co.il>
> >> ---
> >> 
> >>   arch/arm/cpu/armv7/mx6/ddr.c       |   1 -
> >>   board/compulab/cm_fx6/Makefile     |  12 ++
> >>   board/compulab/cm_fx6/cm_fx6.c     | 108 ++++++++++
> >>   board/compulab/cm_fx6/common.c     |  83 ++++++++
> >>   board/compulab/cm_fx6/common.h     |  36 ++++
> >>   board/compulab/cm_fx6/imximage.cfg |   8 +
> >>   board/compulab/cm_fx6/spl.c        | 400
> >> 
> >> +++++++++++++++++++++++++++++++++++++ boards.cfg                        
> >> |
> >> 
> >>    2 +
> >>   
> >>   include/configs/cm_fx6.h           | 227 +++++++++++++++++++++
> >>   9 files changed, 876 insertions(+), 1 deletion(-)
> >>   create mode 100644 board/compulab/cm_fx6/Makefile
> >>   create mode 100644 board/compulab/cm_fx6/cm_fx6.c
> >>   create mode 100644 board/compulab/cm_fx6/common.c
> >>   create mode 100644 board/compulab/cm_fx6/common.h
> >>   create mode 100644 board/compulab/cm_fx6/imximage.cfg
> >>   create mode 100644 board/compulab/cm_fx6/spl.c
> >>   create mode 100644 include/configs/cm_fx6.h
> >> 
> >> diff --git a/arch/arm/cpu/armv7/mx6/ddr.c b/arch/arm/cpu/armv7/mx6/ddr.c
> >> index d3891dc..219263a 100644
> >> --- a/arch/arm/cpu/armv7/mx6/ddr.c
> >> +++ b/arch/arm/cpu/armv7/mx6/ddr.c
> >> @@ -4,7 +4,6 @@
> >> 
> >>    *
> >>    * SPDX-License-Identifier:     GPL-2.0+
> >>    */
> >> 
> >> -
> >> 
> >>   #include <common.h>
> >>   #include <linux/types.h>
> >>   #include <asm/arch/mx6-ddr.h>
> > 
> > Drop this piece ;-)
> 
> Yep...
> 
> > [...]
> > 
> >> +++ b/board/compulab/cm_fx6/cm_fx6.c
> > 
> > [...]
> > 
> >> +static ulong bank1_size;
> >> +static ulong bank2_size;
> >> +
> >> +#define MMDC1_MDCTL 0x21B0000
> >> +static int probe_mmdc_config(void)
> >> +{
> >> +	u32 val = readl(0x21B0000);
> >> +	switch (val) {
> >> +	case 0x83180000: /* DDR_16BIT_256MB */
> >> +		gd->ram_size	= 0x10000000;
> >> +		bank1_size	= 0x10000000;
> >> +		bank2_size	= 0;
> >> +		break;
> >> +	case 0x83190000: /* DDR_32BIT_512MB */
> >> +		gd->ram_size	= 0x20000000;
> >> +		bank1_size	= 0x20000000;
> >> +		bank2_size	= 0;
> >> +		break;
> > 
> > imx_ddr_size() won't cut it here ?
> 
> It doesn't handle 4GB correctly (returns 0). I suppose
> I can make a patch which caps the return value of
> imx_ddr_size() for MX6 socs to 3840MB.
> What do you think?

That you should check the U-Boot ML, since that's what I did yesterday ;-) But 
still, this is rather sad practice -- instead of fixing a bug in code which you 
do know about, you implement such a workaround :-(


More information about the U-Boot mailing list