系统时钟和UART的设置

发布时间:2023-09-25  

系统时钟:

      在开发版上,不同的器件运行在不同的时钟频率上,如CPU可能运行在400Mhz的频率上、SDRAM、DM9000等内存存储运行在100Mhz~133MHz上、

串口i2c等运行在50Mhz上,而在开发板上只有一个12Mhz的晶振,则我们需要设置两个部分

1、提高时钟频率12Mhz提高到400Mhz,有运用到PLL

2、对400Mhz时钟分频,分为400Mhz、100Mhz~133Mhz、50Mhz。

如图所示:

开发板上分布

怎么设置?

相关设置代码

#define S3C2410_MPLL_200MHZ     ((0x5c<<12)|(0x04<<4)|(0x00))

#define S3C2440_MPLL_200MHZ     ((0x5c<<12)|(0x01<<4)|(0x02))

/*

 * 对于MPLLCON寄存器,[19:12]为MDIV,[9:4]为PDIV,[1:0]为SDIV

 * 有如下计算公式:

 *  S3C2410: MPLL(FCLK) = (m * Fin)/(p * 2^s)

 *  S3C2440: MPLL(FCLK) = (2 * m * Fin)/(p * 2^s)

 *  其中: m = MDIV + 8, p = PDIV + 2, s = SDIV

 * 对于本开发板,Fin = 12MHz

 * 设置CLKDIVN,令分频比为:FCLK:HCLK:PCLK=1:2:4,

 * FCLK=200MHz,HCLK=100MHz,PCLK=50MHz

 */

void clock_init(void)

{

    // LOCKTIME = 0x00ffffff;   // 使用默认值即可

    CLKDIVN  = 0x03;            // FCLK:HCLK:PCLK=1:2:4, HDIVN=1,PDIVN=1


    /* 如果HDIVN非0,CPU的总线模式应该从“fast bus mode”变为“asynchronous bus mode” */

__asm__(

    "mrc    p15, 0, r1, c1, c0, 0n"        /* 读出控制寄存器 */ 

    "orr    r1, r1, #0xc0000000n"          /* 设置为“asynchronous bus mode” */

    "mcr    p15, 0, r1, c1, c0, 0n"        /* 写入控制寄存器 */

    );


    /* 判断是S3C2410还是S3C2440 */

    if ((GSTATUS1 == 0x32410000) || (GSTATUS1 == 0x32410002))

    {

        MPLLCON = S3C2410_MPLL_200MHZ;  /* 现在,FCLK=200MHz,HCLK=100MHz,PCLK=50MHz */

    }

    else

    {

        MPLLCON = S3C2440_MPLL_200MHZ;  /* 现在,FCLK=200MHz,HCLK=100MHz,PCLK=50MHz */

    }       

}


-------------------------------------------------------------------------------------------------------------------------------------------------


串口的使用


PC:如何用串口?


1、选中串口号


2、设置波特率、停止位、数据位、关闭流控等


3、打开串口


4、收发数据


我们需要做的:


1、初始化串口


2、设置引脚,把引脚设置为接受发送引脚


3、设置相关寄存器,对流控、时钟源、波特率等设置


设置串口相关代码


#include "s3c24xx.h"

#include "serial.h"


#define TXD0READY   (1<<2)

#define RXD0READY   (1)


#define PCLK            50000000    // init.c中的clock_init函数设置PCLK为50MHz

#define UART_CLK        PCLK        //  UART0的时钟源设为PCLK

#define UART_BAUD_RATE  115200      // 波特率

#define UART_BRD        ((UART_CLK  / (UART_BAUD_RATE * 16)) - 1)


/*

 * 初始化UART0

 * 115200,8N1,无流控

 */

void uart0_init(void)

{

    GPHCON  |= 0xa0;    // GPH2,GPH3用作TXD0,RXD0

    GPHUP   = 0x0c;     // GPH2,GPH3内部上拉


    ULCON0  = 0x03;     // 8N1(8个数据位,无较验,1个停止位)

    UCON0   = 0x05;     // 查询方式,UART时钟源为PCLK

    UFCON0  = 0x00;     // 不使用FIFO

    UMCON0  = 0x00;     // 不使用流控

    UBRDIV0 = UART_BRD; // 波特率为115200

}


/*

 * 发送一个字符

 */

void putc(unsigned char c)

{

    /* 等待,直到发送缓冲区中的数据已经全部发送出去 */

    while (!(UTRSTAT0 & TXD0READY));

    

    /* 向UTXH0寄存器中写入数据,UART即自动将它发送出去 */

    UTXH0 = c;

}


/*

 * 接收字符

 */

unsigned char getc(void)

{

    /* 等待,直到接收缓冲区中的有数据 */

    while (!(UTRSTAT0 & RXD0READY));

    

    /* 直接读取URXH0寄存器,即可获得接收到的数据 */

    return URXH0;

}


/*

 * 判断一个字符是否数字

 */

int isDigit(unsigned char c)

{

    if (c >= '0' && c <= '9')

        return 1;

    else

        return 0;       

}


/*

 * 判断一个字符是否英文字母

 */

int isLetter(unsigned char c)

{

    if (c >= 'a' && c <= 'z')

        return 1;

    else if (c >= 'A' && c <= 'Z')

        return 1;       

    else

        return 0;

}


文章来源于:电子工程世界    原文链接
本站所有转载文章系出于传递更多信息之目的,且明确注明来源,不希望被转载的媒体或个人可与我们联系,我们将立即进行删除处理。

相关文章

    对语音文件进行转换了。   7.耐心等待语音转换结束后,我们就可以将转换后的文件保存到电脑上进行使用了。   手机语音识别怎么设置   苹果手机的语音识别设置步骤如下:   1.进入手机设置”界面,点击......
    副屏主要是针对老的翻盖机而言的,合上盖有个小屏幕用于显示时间以及来电提示等信息副屏怎么设置。主屏就是打开翻盖的那个大显示屏,作为主要的人机界面。副屏相对主屏而言。要是没有副屏也就没有主屏。 OLED,即有......
    当日都是溢价200-500元。 iPhone 14的产品竞争力过差、并且外观和设计毫无新意,使得iPhone 14全球爆冷,国产手机翻身的机会来了么?首先,iPhone虽然难逃跌价,但在iOS和苹果......
    iPhone 自带软件功能大揭秘; 导读 很多消费者包括果粉在内,使用苹果手机的时候,使用的只是它极少数的一部分功能,而对于苹果手机......
    原理图可以得知PC4为SW1按键。 同时配置为上拉,默认状态下电平为高电平状态。 LED配置 查看原理图可以得知PB5为蓝色LED。 配置PB5为输出IO。 设置工程信息 工程文件设置 通过手机翻......
    iPhone 6突发自燃!苹果:不知道咋回事;说起苹果手机,相信许多市民都不觉得意外,从苹果手机4系列到苹果7系列,可以说,在中国拥有了相当比重的手机使用者,然而就是在今年以来,却陆续曝出了苹果6......
    点对于本系统这样需要长时间连续运行的系统来说尤为重要。下图为运动控制的简单原理示意图: 1.2 系统概述 本系统利用NI Motion 控制模块对伺服电机运动进行速度控制,按照用户设置的参数驱动相应的拨片、拨杆控制手机翻盖的开合。整个......
    苹果手表AppleWatch2不敢说Siri?因不如Ticwatch2;2016苹果秋季新品发布会上,苹果公司发布了“史上最好的苹果手机”iPhone7和苹果手表Apple Watch2代。此次......
    监视器进入休眠状态怎么办 监视器的屏幕刷新频率怎么设置;  监视器进入休眠状态怎么办   如果您的监视器进入了休眠状态(常见于长时间无操作时),您可以尝试以下方法解决问题:   1. 检查连接:确保......
    400Mhz、100Mhz~133Mhz、50Mhz。 如图所示: 开发板上分布 怎么设置? 相关设置代码 #define S3C2410_MPLL_200MHZ     ((0x5c<......

我们与500+贴片厂合作,完美满足客户的定制需求。为品牌提供定制化的推广方案、专属产品特色页,多渠道推广,SEM/SEO精准营销以及与公众号的联合推广...详细>>

利用葫芦芯平台的卓越技术服务和新产品推广能力,原厂代理能轻松打入消费物联网(IOT)、信息与通信(ICT)、汽车及新能源汽车、工业自动化及工业物联网、装备及功率电子...详细>>

充分利用其强大的电子元器件采购流量,创新性地为这些物料提供了一个全新的窗口。我们的高效数字营销技术,不仅可以助你轻松识别与连接到需求方,更能够极大地提高“闲置物料”的处理能力,通过葫芦芯平台...详细>>

我们的目标很明确:构建一个全方位的半导体产业生态系统。成为一家全球领先的半导体互联网生态公司。目前,我们已成功打造了智能汽车、智能家居、大健康医疗、机器人和材料等五大生态领域。更为重要的是...详细>>

我们深知加工与定制类服务商的价值和重要性,因此,我们倾力为您提供最顶尖的营销资源。在我们的平台上,您可以直接接触到100万的研发工程师和采购工程师,以及10万的活跃客户群体...详细>>

凭借我们强大的专业流量和尖端的互联网数字营销技术,我们承诺为原厂提供免费的产品资料推广服务。无论是最新的资讯、技术动态还是创新产品,都可以通过我们的平台迅速传达给目标客户...详细>>

我们不止于将线索转化为潜在客户。葫芦芯平台致力于形成业务闭环,从引流、宣传到最终销售,全程跟进,确保每一个potential lead都得到妥善处理,从而大幅提高转化率。不仅如此...详细>>