omap4 hsmmc: Update ocr mask for MMC2 for regulator to use
On OMAP4, MMC2 controller has eMMC which draws power from VAUX regulator on TWL. Though the eMMC supports dual voltage[1.8v/3v] as per ocr register, its VCC is fixed at 3V for operation. With this once the mmc core selects the minimum voltage[1.8] supported based on the ocr value read from OCR register, eMMC will not get detected. Thus the platform data for MMC2 is updated with ocr mask and same will be communicated to core which will set the regulator to always operate at 3V when ever turned ON. Cc: Tony Lindgren <tony@atomide.com> Cc: Andrew Morton <akpm@linux-foundation.org> Cc: Madhusudhan Chikkature <madhu.cr@ti.com> Cc: Adrian Hunter <adrian.hunter@nokia.com> Signed-off-by: Kishore Kadiyala <kishore.kadiyala@ti.com> Signed-off-by: Tony Lindgren <tony@atomide.com>
This commit is contained in:
		
					parent
					
						
							
								91a0b089f8
							
						
					
				
			
			
				commit
				
					
						64be97822b
					
				
			
		
					 2 changed files with 13 additions and 0 deletions
				
			
		|  | @ -242,6 +242,7 @@ static struct omap2_hsmmc_info mmc[] = { | ||||||
| 		.gpio_cd	= -EINVAL, | 		.gpio_cd	= -EINVAL, | ||||||
| 		.gpio_wp	= -EINVAL, | 		.gpio_wp	= -EINVAL, | ||||||
| 		.nonremovable   = true, | 		.nonremovable   = true, | ||||||
|  | 		.ocr_mask	= MMC_VDD_29_30, | ||||||
| 	}, | 	}, | ||||||
| 	{}	/* Terminator */ | 	{}	/* Terminator */ | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | @ -364,6 +364,7 @@ static int omap_hsmmc_reg_get(struct omap_hsmmc_host *host) | ||||||
| { | { | ||||||
| 	struct regulator *reg; | 	struct regulator *reg; | ||||||
| 	int ret = 0; | 	int ret = 0; | ||||||
|  | 	int ocr_value = 0; | ||||||
| 
 | 
 | ||||||
| 	switch (host->id) { | 	switch (host->id) { | ||||||
| 	case OMAP_MMC1_DEVID: | 	case OMAP_MMC1_DEVID: | ||||||
|  | @ -396,6 +397,17 @@ static int omap_hsmmc_reg_get(struct omap_hsmmc_host *host) | ||||||
| 		} | 		} | ||||||
| 	} else { | 	} else { | ||||||
| 		host->vcc = reg; | 		host->vcc = reg; | ||||||
|  | 		ocr_value = mmc_regulator_get_ocrmask(reg); | ||||||
|  | 		if (!mmc_slot(host).ocr_mask) { | ||||||
|  | 			mmc_slot(host).ocr_mask = ocr_value; | ||||||
|  | 		} else { | ||||||
|  | 			if (!(mmc_slot(host).ocr_mask & ocr_value)) { | ||||||
|  | 				pr_err("MMC%d ocrmask %x is not supported\n", | ||||||
|  | 					host->id, mmc_slot(host).ocr_mask); | ||||||
|  | 				mmc_slot(host).ocr_mask = 0; | ||||||
|  | 				return -EINVAL; | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
| 		mmc_slot(host).ocr_mask = mmc_regulator_get_ocrmask(reg); | 		mmc_slot(host).ocr_mask = mmc_regulator_get_ocrmask(reg); | ||||||
| 
 | 
 | ||||||
| 		/* Allow an aux regulator */ | 		/* Allow an aux regulator */ | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 kishore kadiyala
				kishore kadiyala