HI3520D在内核中复用UART2,UART3管脚

HI3520D在内核中复用UART2,UART3管脚

linux-3.0.y/arch/arm/mach-hi3520d/core.c文件中合适的位置假如

#define 	GK_HW_WEG(gkval,gkaddr) 	writel(gkval,gkaddr)

#define		GK_IOCFG_BASE_ADDR		0x200F0000					/*	IO口复用寄存器地址空间映射	*/
#define		GK_GPIO0_BASE_ADDR		0x20150000					/*	GPIO0的地址空间映射	*/
#define		GK_GPIO1_BASE_ADDR		0x20160000					/*	GPIO1的地址空间映射	*/
#define		GK_GPIO2_BASE_ADDR		0x20170000					/*	GPIO2的地址空间映射	*/
#define		GK_GPIO3_BASE_ADDR		0x20180000					/*	GPIO3的地址空间映射	*/
#define		GK_GPIO4_BASE_ADDR		0x20190000					/*	GPIO4的地址空间映射	*/
#define		GK_GPIO5_BASE_ADDR		0x201A0000					/*	GPIO5的地址空间映射	*/
#define	 	GK_GPIO6_BASE_ADDR		0x201B0000					/*	GPIO6的地址空间映射	*/
#define		GK_GPIO7_BASE_ADDR		0x201C0000					/*	GPIO7的地址空间映射	*/
#define		GK_GPIO8_BASE_ADDR		0x201D0000					/*	GPIO7的地址空间映射	*/

#define		GK_REG_UART1RXD_OFFSET		IO_ADDRESS(GK_IOCFG_BASE_ADDR + 0x050)		/*	UART1_RXD偏移寄存器	*/
#define		GK_REG_UART1TXD_OFFSET		IO_ADDRESS(GK_IOCFG_BASE_ADDR + 0x058)		/*	UART1_TXD偏移寄存器	*/
#define		GK_REG_UART2RXD_OFFSET		IO_ADDRESS(GK_IOCFG_BASE_ADDR + 0x05C)		/*	UART2_RXD偏移寄存器	*/
#define		GK_REG_UART2TXD_OFFSET		IO_ADDRESS(GK_IOCFG_BASE_ADDR + 0x060)		/*	UART2_TXD偏移寄存器	*/
#define		GK_REG_UART3RXD_OFFSET		IO_ADDRESS(GK_IOCFG_BASE_ADDR + 0x0BC)		/*	UART3_RXD偏移寄存器	*/
#define		GK_REG_UART3TXD_OFFSET		IO_ADDRESS(GK_IOCFG_BASE_ADDR + 0x0B8)		/*	UART3_TXD偏移寄存器	*/

#define 	gk_cfg_uart_pin()({\
			GK_HW_WEG(0x01,GK_REG_UART1RXD_OFFSET);\
			GK_HW_WEG(0x01,GK_REG_UART1TXD_OFFSET);\
			GK_HW_WEG(0x01,GK_REG_UART2RXD_OFFSET);\
			GK_HW_WEG(0x01,GK_REG_UART2TXD_OFFSET);\
			GK_HW_WEG(0x01,GK_REG_UART3RXD_OFFSET);\
			GK_HW_WEG(0x01,GK_REG_UART3TXD_OFFSET);\
			})


在  uart_clk_init 函数最后加入初始化


static void  uart_clk_init(unsigned long clk)
{
	uart_clk.rate = clk;

	lookups[0].dev_id = "uart:0";
	lookups[0].clk = &uart_clk;

	lookups[1].dev_id = "uart:1";
	lookups[1].clk = &uart_clk;
	
	lookups[2].dev_id = "uart:2";
	lookups[2].clk = &uart_clk;

	lookups[3].dev_id = "uart:3";
	lookups[3].clk = &uart_clk;
	
	gk_cfg_uart_pin();
}




评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值