u-boot 第二阶段 硬件初始化之设置系统时钟

U-boot  第二阶段硬件初始化 设置系统时钟  函数:board_init (void) --------->>board/开发板/开发板.c 

<span style="font-size:18px;">{
S3C24X0_CLOCK_POWER * const clk_power = S3C24X0_GetBase_CLOCK_POWER();
...
}
</span>


其中S3C24X0_CLOCK_POWER为结构体  定义于include\s3c2410.h  中

<span style="font-size:18px;"><span style="font-size:14px;">typedef struct {
    S3C24X0_REG32   LOCKTIME; //锁定时间计数寄存器
    S3C24X0_REG32   MPLLCON; //MPLL配置寄存器
    S3C24X0_REG32   UPLLCON;
    S3C24X0_REG32   CLKCON;
    S3C24X0_REG32   CLKSLOW;
    S3C24X0_REG32   CLKDIVN;
    S3C24X0_REG32   CAMDIVN;    // for s3c2440, by www.embedsky.net
    
} S3C24X0_CLOCK_POWER;
</span>


 

函数S3C24X0_GetBase_CLOCK_POWER()  定义于include\s3c2410.h中
static inline S3C24X0_CLOCK_POWER * const S3C24X0_GetBase_CLOCK_POWER(void){ return (S3C24X0_CLOCK_POWER * const)S3C24X0_CLOCK_POWER_BASE;}

 

其中S3C24X0_CLOCK_POWER_BASE为时钟寄存器的首地址,定义于include\s3c2410.

#define S3C24X0_CLOCK_POWER_BASE 0x4C000000
最后通过操作指向结构体的指针来操作相应的寄存器。

<span style="font-size:18px;">clk_power->MPLLCON = ((M_MDIV << 12) + (M_PDIV << 4) + M_SDIV);</span></span>

相同原理的还包括:对GPIO寄存器的操作

S3C24X0_GPIO 结构体  以及相应的S3C24X0_GetBase_GPIO();  等等;

 

 

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值