diff options
Diffstat (limited to 'drivers/mfd/rtsx_pcr.c')
| -rw-r--r-- | drivers/mfd/rtsx_pcr.c | 27 | 
1 files changed, 23 insertions, 4 deletions
diff --git a/drivers/mfd/rtsx_pcr.c b/drivers/mfd/rtsx_pcr.c index 7a7b0bda461..9fc57009e22 100644 --- a/drivers/mfd/rtsx_pcr.c +++ b/drivers/mfd/rtsx_pcr.c @@ -630,7 +630,10 @@ int rtsx_pci_switch_clock(struct rtsx_pcr *pcr, unsigned int card_clock,  	if (clk == pcr->cur_clock)  		return 0; -	N = (u8)(clk - 2); +	if (pcr->ops->conv_clk_and_div_n) +		N = (u8)pcr->ops->conv_clk_and_div_n(clk, CLK_TO_DIV_N); +	else +		N = (u8)(clk - 2);  	if ((clk <= 2) || (N > max_N))  		return -EINVAL; @@ -641,7 +644,14 @@ int rtsx_pci_switch_clock(struct rtsx_pcr *pcr, unsigned int card_clock,  	/* Make sure that the SSC clock div_n is equal or greater than min_N */  	div = CLK_DIV_1;  	while ((N < min_N) && (div < max_div)) { -		N = (N + 2) * 2 - 2; +		if (pcr->ops->conv_clk_and_div_n) { +			int dbl_clk = pcr->ops->conv_clk_and_div_n(N, +					DIV_N_TO_CLK) * 2; +			N = (u8)pcr->ops->conv_clk_and_div_n(dbl_clk, +					CLK_TO_DIV_N); +		} else { +			N = (N + 2) * 2 - 2; +		}  		div++;  	}  	dev_dbg(&(pcr->pci->dev), "N = %d, div = %d\n", N, div); @@ -703,6 +713,15 @@ int rtsx_pci_card_power_off(struct rtsx_pcr *pcr, int card)  }  EXPORT_SYMBOL_GPL(rtsx_pci_card_power_off); +int rtsx_pci_switch_output_voltage(struct rtsx_pcr *pcr, u8 voltage) +{ +	if (pcr->ops->switch_output_voltage) +		return pcr->ops->switch_output_voltage(pcr, voltage); + +	return 0; +} +EXPORT_SYMBOL_GPL(rtsx_pci_switch_output_voltage); +  unsigned int rtsx_pci_card_exist(struct rtsx_pcr *pcr)  {  	unsigned int val; @@ -767,10 +786,10 @@ static void rtsx_pci_card_detect(struct work_struct *work)  	spin_unlock_irqrestore(&pcr->lock, flags); -	if (card_detect & SD_EXIST) +	if ((card_detect & SD_EXIST) && pcr->slots[RTSX_SD_CARD].card_event)  		pcr->slots[RTSX_SD_CARD].card_event(  				pcr->slots[RTSX_SD_CARD].p_dev); -	if (card_detect & MS_EXIST) +	if ((card_detect & MS_EXIST) && pcr->slots[RTSX_MS_CARD].card_event)  		pcr->slots[RTSX_MS_CARD].card_event(  				pcr->slots[RTSX_MS_CARD].p_dev);  }  |