[U-Boot] [PATCH] fsl_upm: Add MxMR/MDR synchronization

Scott Wood scottwood at freescale.com
Fri Dec 3 01:32:44 CET 2010


On Thu, 2 Dec 2010 18:19:08 -0600
Kumar Gala <galak at kernel.crashing.org> wrote:

> [Adding Scott W. - would like his ack on this]

Acked-by: Scott Wood <scottwood at freescale.com>

> 
> - k
> 
> On Dec 2, 2010, at 11:43 AM, Peter Tyser wrote:
> 
> > From: John Schmoller <jschmoller at xes-inc.com>
> > 
> > According to Freescale reference manuals (eg section "13.4.4.2
> > Programming the UPMs" of the P4080 Reference Manual):
> > 
> > "Since the result of any update to the MxMR/MDR register must be in
> > effect before the dummy read or write to the UPM region, a write to
> > MxMR/MDR should be followed immediately by a read of MxMR/MDR."
> > 
> > The UPM on a custom P4080-based board did not work without performing
> > a read of MxMR/MDR after a write.
> > 
> > Signed-off-by: John Schmoller <jschmoller at xes-inc.com>
> > Signed-off-by: Peter Tyser <ptyser at xes-inc.com>
> > ---
> > drivers/mtd/nand/fsl_upm.c |    2 ++
> > 1 files changed, 2 insertions(+), 0 deletions(-)
> > 
> > diff --git a/drivers/mtd/nand/fsl_upm.c b/drivers/mtd/nand/fsl_upm.c
> > index b76c673..be00555 100644
> > --- a/drivers/mtd/nand/fsl_upm.c
> > +++ b/drivers/mtd/nand/fsl_upm.c
> > @@ -21,6 +21,7 @@
> > static void fsl_upm_start_pattern(struct fsl_upm *upm, u32 pat_offset)
> > {
> > 	clrsetbits_be32(upm->mxmr, MxMR_MAD_MSK, MxMR_OP_RUNP | pat_offset);
> > +	(void)in_be32(upm->mxmr);
> > }
> > 
> > static void fsl_upm_end_pattern(struct fsl_upm *upm)
> > @@ -35,6 +36,7 @@ static void fsl_upm_run_pattern(struct fsl_upm *upm, int width,
> > 				void __iomem *io_addr, u32 mar)
> > {
> > 	out_be32(upm->mar, mar);
> > +	(void)in_be32(upm->mar);
> > 	switch (width) {
> > 	case 8:
> > 		out_8(io_addr, 0x0);
> > -- 
> > 1.7.0.4
> 
> _______________________________________________
> U-Boot mailing list
> U-Boot at lists.denx.de
> http://lists.denx.de/mailman/listinfo/u-boot
> 




More information about the U-Boot mailing list