mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-11-04 05:50:17 +00:00 
			
		
		
		
	sunxi: Fix clock_twi_onoff for sun8i-a83
clock_sun8i_a83.c did not contain a clock_twi_onoff implementation at all, this is fixed by moving the clock_sun6i.c implementation, which is correct for the a83 too, to a shared location. Signed-off-by: Hans de Goede <hdegoede@redhat.com> Acked-by: Ian Campbell <ijc@hellion.org.uk>
This commit is contained in:
		
							parent
							
								
									730d2f3a41
								
							
						
					
					
						commit
						a93b0fe3fd
					
				@ -12,6 +12,7 @@
 | 
			
		||||
#include <asm/io.h>
 | 
			
		||||
#include <asm/arch/clock.h>
 | 
			
		||||
#include <asm/arch/gpio.h>
 | 
			
		||||
#include <asm/arch/prcm.h>
 | 
			
		||||
#include <asm/arch/sys_proto.h>
 | 
			
		||||
 | 
			
		||||
__weak void clock_init_sec(void)
 | 
			
		||||
@ -28,3 +29,37 @@ int clock_init(void)
 | 
			
		||||
 | 
			
		||||
	return 0;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/* These functions are shared between various SoCs so put them here. */
 | 
			
		||||
#if defined CONFIG_SUNXI_GEN_SUN6I && !defined CONFIG_MACH_SUN9I
 | 
			
		||||
int clock_twi_onoff(int port, int state)
 | 
			
		||||
{
 | 
			
		||||
	struct sunxi_ccm_reg *const ccm =
 | 
			
		||||
		(struct sunxi_ccm_reg *)SUNXI_CCM_BASE;
 | 
			
		||||
 | 
			
		||||
	if (port == 5) {
 | 
			
		||||
		if (state)
 | 
			
		||||
			prcm_apb0_enable(
 | 
			
		||||
				PRCM_APB0_GATE_PIO | PRCM_APB0_GATE_I2C);
 | 
			
		||||
		else
 | 
			
		||||
			prcm_apb0_disable(
 | 
			
		||||
				PRCM_APB0_GATE_PIO | PRCM_APB0_GATE_I2C);
 | 
			
		||||
		return 0;
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	/* set the apb clock gate and reset for twi */
 | 
			
		||||
	if (state) {
 | 
			
		||||
		setbits_le32(&ccm->apb2_gate,
 | 
			
		||||
			     CLK_GATE_OPEN << (APB2_GATE_TWI_SHIFT + port));
 | 
			
		||||
		setbits_le32(&ccm->apb2_reset_cfg,
 | 
			
		||||
			     1 << (APB2_RESET_TWI_SHIFT + port));
 | 
			
		||||
	} else {
 | 
			
		||||
		clrbits_le32(&ccm->apb2_reset_cfg,
 | 
			
		||||
			     1 << (APB2_RESET_TWI_SHIFT + port));
 | 
			
		||||
		clrbits_le32(&ccm->apb2_gate,
 | 
			
		||||
			     CLK_GATE_OPEN << (APB2_GATE_TWI_SHIFT + port));
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	return 0;
 | 
			
		||||
}
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
@ -85,37 +85,6 @@ void clock_init_uart(void)
 | 
			
		||||
#endif
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
int clock_twi_onoff(int port, int state)
 | 
			
		||||
{
 | 
			
		||||
	struct sunxi_ccm_reg *const ccm =
 | 
			
		||||
		(struct sunxi_ccm_reg *)SUNXI_CCM_BASE;
 | 
			
		||||
 | 
			
		||||
	if (port == 5) {
 | 
			
		||||
		if (state)
 | 
			
		||||
			prcm_apb0_enable(
 | 
			
		||||
				PRCM_APB0_GATE_PIO | PRCM_APB0_GATE_I2C);
 | 
			
		||||
		else
 | 
			
		||||
			prcm_apb0_disable(
 | 
			
		||||
				PRCM_APB0_GATE_PIO | PRCM_APB0_GATE_I2C);
 | 
			
		||||
		return 0;
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	/* set the apb clock gate and reset for twi */
 | 
			
		||||
	if (state) {
 | 
			
		||||
		setbits_le32(&ccm->apb2_gate,
 | 
			
		||||
			     CLK_GATE_OPEN << (APB2_GATE_TWI_SHIFT+port));
 | 
			
		||||
		setbits_le32(&ccm->apb2_reset_cfg,
 | 
			
		||||
			     1 << (APB2_RESET_TWI_SHIFT + port));
 | 
			
		||||
	} else {
 | 
			
		||||
		clrbits_le32(&ccm->apb2_reset_cfg,
 | 
			
		||||
			     1 << (APB2_RESET_TWI_SHIFT + port));
 | 
			
		||||
		clrbits_le32(&ccm->apb2_gate,
 | 
			
		||||
			     CLK_GATE_OPEN << (APB2_GATE_TWI_SHIFT+port));
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	return 0;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#ifdef CONFIG_SPL_BUILD
 | 
			
		||||
void clock_set_pll1(unsigned int clk)
 | 
			
		||||
{
 | 
			
		||||
 | 
			
		||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user