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(); 等等;