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

Kumar Gala galak at kernel.crashing.org
Fri Dec 3 01:19:08 CET 2010


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

- 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



More information about the U-Boot mailing list