mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-10-25 01:58:13 +01:00 
			
		
		
		
	Signed-off-by: Wolfgang Denk <wd@denx.de> [trini: Fixup common/cmd_io.c] Signed-off-by: Tom Rini <trini@ti.com>
		
			
				
	
	
		
			88 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			88 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * (C) Copyright 2008
 | |
|  * Martha J Marx, Silicon Turnkey Express, mmarx@silicontkx.com
 | |
|  * mpc512x I/O pin/pad initialization for the ADS5121 board
 | |
|  * SPDX-License-Identifier:	GPL-2.0+
 | |
|  */
 | |
| 
 | |
| #include <common.h>
 | |
| #include <linux/types.h>
 | |
| #include <asm/io.h>
 | |
| 
 | |
| void iopin_initialize(iopin_t *ioregs_init, int len)
 | |
| {
 | |
| 	short i, j, p;
 | |
| 	u32 *reg;
 | |
| 	immap_t *im = (immap_t *)CONFIG_SYS_IMMR;
 | |
| 
 | |
| 	reg = (u32 *)&(im->io_ctrl);
 | |
| 
 | |
| 	if (sizeof(ioregs_init) == 0)
 | |
| 		return;
 | |
| 
 | |
| 	for (i = 0; i < len; i++) {
 | |
| 		for (p = 0, j = ioregs_init[i].p_offset / sizeof(u_long);
 | |
| 			p < ioregs_init[i].nr_pins; p++, j++) {
 | |
| 			if (ioregs_init[i].bit_or)
 | |
| 				setbits_be32(reg + j, ioregs_init[i].val);
 | |
| 			else
 | |
| 				out_be32 (reg + j, ioregs_init[i].val);
 | |
| 		}
 | |
| 	}
 | |
| 	return;
 | |
| }
 | |
| 
 | |
| void iopin_initialize_bits(iopin_t *ioregs_init, int len)
 | |
| {
 | |
| 	short i, j, p;
 | |
| 	u32 *reg, mask;
 | |
| 	immap_t *im = (immap_t *)CONFIG_SYS_IMMR;
 | |
| 
 | |
| 	reg = (u32 *)&(im->io_ctrl);
 | |
| 
 | |
| 	/* iterate over table entries */
 | |
| 	for (i = 0; i < len; i++) {
 | |
| 		/* iterate over pins within a table entry */
 | |
| 		for (p = 0, j = ioregs_init[i].p_offset / sizeof(u_long);
 | |
| 			p < ioregs_init[i].nr_pins; p++, j++) {
 | |
| 			if (ioregs_init[i].bit_or & IO_PIN_OVER_EACH) {
 | |
| 				/* replace all settings at once */
 | |
| 				out_be32(reg + j, ioregs_init[i].val);
 | |
| 			} else {
 | |
| 				/*
 | |
| 				 * only replace individual parts, but
 | |
| 				 * REPLACE them instead of just ORing
 | |
| 				 * them in and "inheriting" previously
 | |
| 				 * set bits which we don't want
 | |
| 				 */
 | |
| 				mask = 0;
 | |
| 				if (ioregs_init[i].bit_or & IO_PIN_OVER_FMUX)
 | |
| 					mask |= IO_PIN_FMUX(3);
 | |
| 
 | |
| 				if (ioregs_init[i].bit_or & IO_PIN_OVER_HOLD)
 | |
| 					mask |= IO_PIN_HOLD(3);
 | |
| 
 | |
| 				if (ioregs_init[i].bit_or & IO_PIN_OVER_PULL)
 | |
| 					mask |= IO_PIN_PUD(1) | IO_PIN_PUE(1);
 | |
| 
 | |
| 				if (ioregs_init[i].bit_or & IO_PIN_OVER_STRIG)
 | |
| 					mask |= IO_PIN_ST(1);
 | |
| 
 | |
| 				if (ioregs_init[i].bit_or & IO_PIN_OVER_DRVSTR)
 | |
| 					mask |= IO_PIN_DS(3);
 | |
| 				/*
 | |
| 				 * DON'T do the "mask, then insert"
 | |
| 				 * in place on the register, it may
 | |
| 				 * break access to external hardware
 | |
| 				 * (like boot ROMs) when configuring
 | |
| 				 * LPB related pins, while the code to
 | |
| 				 * configure the pin is read from this
 | |
| 				 * very address region
 | |
| 				 */
 | |
| 				clrsetbits_be32(reg + j, mask,
 | |
| 						ioregs_init[i].val & mask);
 | |
| 			}
 | |
| 		}
 | |
| 	}
 | |
| }
 |