0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

【中科昊芯Start_DSC28027勇士开发板试用体验】SCI(UART)通讯

开发板试用精选 来源:开发板试用 作者:电子发烧友论坛 2022-11-21 11:14 次阅读
本文来源电子发烧友社区,作者:xiaopeng, 帖子地址:https://bbs.elecfans.com/jishu_2287977_1_1.html

中科昊芯DSC2802x系列DSP拥有一个SCI(UART)模块,可以用来作为调试口或者与其它模块进行通讯。

poYBAGKweKCAEEarAABJIOiQaAw743.jpg


其基本功能如下:
poYBAGKweSyAEr-MAADpQzRtbTY649.jpg


注意,这个sci模块数据位是可配置为1~8bit,并非我们常见的8~9bit数据位。
还具有增强功能:
pYYBAGKwedeAJvy7AAAUQ9XheyQ869.jpg

也就是说硬件可以自动检测波特率,功能还是很强大的。

波特率计算公式:
poYBAGKweseAcfKiAACymDWu5ME019.jpg


代码实操:
新建两个文件,sci.c和sci.h
poYBAGKwe2OAMjW_AACEqWzwnyM468.jpg


与sci相关的代码全部放在sci.c文件里面,sci.h用于sci相关的函数的声明。

1、sci模块硬件初始化:


  1. /******************************************************************
  2. *函数名:Scia_Config(uint32 baud)
  3. *参 数: baud,串口波特率
  4. *返回值:无
  5. *作 用: SCIA 初始化配置
  6. ******************************************************************/
  7. void Scia_Config(uint32 baud)
  8. {
  9. uint32 div = 0;
  10. uint32 divsel = 0;
  11. uint32 lospcp = 0;
  12. uint32 lspclk = 0;
  13. uint16 brr = 0;
  14. //获取系统时钟的倍频、分频和低速外部时钟的值
  15. div = SysCtrlRegs.PLLCR.bit.DIV;
  16. divsel = SysCtrlRegs.PLLSTS.bit.DIVSEL;
  17. lospcp = SysCtrlRegs.LOSPCP.bit.LSPCLK;
  18. if (lospcp != 0)
  19. {
  20. lospcp = lospcp * 2;
  21. }
  22. else
  23. {
  24. lospcp = 1;
  25. }
  26. /*分频值设置
  27. divsel为 0时,系统时钟4分频
  28. divsel为 1时,系统时钟4分频
  29. divsel为 2时,系统时钟2分频
  30. divsel为 3时,系统时钟1分频*/
  31. switch (divsel)
  32. {
  33. case 0:
  34. case 1:
  35. lspclk = 12000000 * div / 4 / lospcp;
  36. break;
  37. case 2:
  38. lspclk = 12000000 * div / 2 / lospcp;
  39. break;
  40. case 3:
  41. lspclk = 12000000 * div / 1 / lospcp;
  42. break;
  43. }
  44. brr = lspclk / (baud * 8) - 1;
  45. /*SCI 停止位设置 0:一个停止位 1:两个停止位*/
  46. SciaRegs.SCICCR.bit.STOPBITS = 0;
  47. /*SCI 奇偶校验位 0:奇偶校验 1:偶偶校验*/
  48. SciaRegs.SCICCR.bit.PARITY = 0;
  49. /*SCI 奇偶校验使能 0:关闭 1:启用*/
  50. SciaRegs.SCICCR.bit.PARITYENA = 0;
  51. /*SCI 字符长度 0:1个字长1:2个字长 ... 7:8个字长*/
  52. SciaRegs.SCICCR.bit.SCICHAR = 7;
  53. /*使能SCI的发送机和接收机*/
  54. SciaRegs.SCICTL1.bit.TXENA = 1;
  55. SciaRegs.SCICTL1.bit.RXENA = 1;
  56. /*SCI 16位波特率选择寄存器 高8位*/
  57. SciaRegs.SCIHBAUD = (uint8) ((brr >> 8) & 0xff);
  58. /*SCI 16位波特率选择寄存器 低8位*/
  59. SciaRegs.SCILBAUD = (uint8) (brr & 0xff);
  60. /*SCI 发送中断使能*/
  61. SciaRegs.SCICTL2.bit.TXINTENA = 1;
  62. /*SCI 接收中断使能*/
  63. SciaRegs.SCICTL2.bit.RXBKINTENA = 1;
  64. /*SCI 指定发送和接收中断处理函数,该寄存器受EALLOW保护*/
  65. EALLOW;
  66. PieVectTable.SCIRXINTA = &sciaRxIsr;
  67. PieVectTable.SCITXINTA = &sciaTxIsr;
  68. EDIS;
  69. /*PIE Group 9, SCIRXINTA*/
  70. PieCtrlRegs.PIEIER9.bit.INTx1 = 1;
  71. /*PIE Group 9, SCITXINTA*/
  72. PieCtrlRegs.PIEIER9.bit.INTx2 = 1;
  73. IER_ENABLE(M_INT9);
  74. /*SCI 软件复位,重新启动SCI*/
  75. SciaRegs.SCICTL1.bit.SWRESET = 1;
  76. }
复制代码


2、中断方式的数据发送


  1. /******************************************************************
  2. *函数名:Scia_Send(uint8 data)
  3. *参 数: data,准备发送的字节
  4. *返回值:无
  5. *作 用: SCIA 发送一个字节
  6. ******************************************************************/
  7. void Scia_Send(uint8 data)
  8. {
  9. while (SciaRegs.SCICTL2.bit.TXRDY == 0)
  10. {
  11. }
  12. SciaRegs.SCITXBUF = data;
  13. }
复制代码


3、字符串的发送


  1. /******************************************************************
  2. *函数名:Scia_Print(char *str)
  3. *参 数: *str,要发送的字符串
  4. *返回值:无
  5. *作 用: SCIA 发送一个字符串
  6. ******************************************************************/
  7. void Scia_Print(char *str)
  8. {
  9. while (*str != '')
  10. {
  11. while (SciaRegs.SCICTL2.bit.TXRDY == 0)
  12. {
  13. }
  14. SciaRegs.SCITXBUF = *str++;
  15. }
  16. }
复制代码


4、发送与接收中断函数


  1. /******************************************************************
  2. *函数名:sciaTxIsr(void)
  3. *参 数: 无
  4. *返回值:无
  5. *作 用: SCIA中断发送处理
  6. ******************************************************************/
  7. INTERRUPT void sciaTxIsr(void)
  8. {
  9. /*清除中断标志位*/
  10. while (SciaRegs.SCICTL2.bit.TXRDY == 0)
  11. {
  12. }
  13. PieCtrlRegs.PIEACK.all = PIEACK_GROUP9;
  14. }
  15. /******************************************************************
  16. *函数名:sciaRxIsr(void)
  17. *参 数: 无
  18. *返回值:无
  19. *作 用: SCIA中断接收处理
  20. ******************************************************************/
  21. INTERRUPT void sciaRxIsr(void)
  22. {
  23. if (SciaRegs.SCICTL2.bit.TXRDY == 1)
  24. {
  25. Scia_Send(SciaRegs.SCIRXBUF.bit.RXDT);
  26. PieCtrlRegs.PIEACK.all = PIEACK_GROUP9;
  27. }
  28. }
复制代码


5、主函数
在上一篇GPIO发布的基础上增加sci功能,实现数据的收发,同时,led和按键功能也正常工作。


  1. int main(void)
  2. {
  3. uint16_t cnt = 0;
  4. /*初始化系统控制:PLL,WatchDog,使能外设时钟*/
  5. InitSysCtrl();
  6. /*初始化内存控制寄存器,使能内存流水线模式*/
  7. InitFlash();
  8. /*初始化串口通信的GPIO口*/
  9. /*GPIO28: SCIRXDA*/
  10. /*GPIO29: SCITXDA*/
  11. InitSciGpio();
  12. /*关闭中断*/
  13. DINT;
  14. /*将PIE控制寄存器初始化为默认状态,该状态禁止所有PIE中断并清除所有标志*/
  15. InitPieCtrl();
  16. /*禁止CPU中断并清除所有中断标志*/
  17. IER = 0x0000;
  18. IFR = 0x0000;
  19. /*初始化PIE向量表,为PIE向量表中的所有中断向量配置对应向量的入口地址*/
  20. InitPieVectTable();
  21. /*SCI寄存器配置*/
  22. Scia_Config(9600);
  23. /*使能外部中断和CPU中断*/
  24. EINT;
  25. /*初始化KEY、LED*/
  26. InitKEY();
  27. InitLED();
  28. /*通过SCI发送字符串*/
  29. Scia_Print("Hello haawking!rn");
  30. while(1)
  31. {
  32. /*按键按下*/
  33. if(GpioDataRegs.GPADAT.bit.GPIO12 == 0)
  34. {
  35. /*D400亮*/
  36. GpioDataRegs.GPACLEAR.bit.GPIO7 = 1;
  37. }
  38. else
  39. {
  40. /*松开按键D400灭*/
  41. GpioDataRegs.GPASET.bit.GPIO7 = 1;
  42. }
  43. if(cnt == 500)
  44. {
  45. cnt = 0;
  46. /*D401一直闪烁*/
  47. GpioDataRegs.GPATOGGLE.bit.GPIO6 = 1;
  48. }
  49. else
  50. {
  51. cnt++;
  52. DELAY_US(1000);
  53. }
  54. }
  55. return 0;
  56. }
复制代码


测试

poYBAGKwfUiAdZZhAABQ8zCgFcs967.jpg


测试成功

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 中科昊芯
    +关注

    关注

    5

    文章

    79

    浏览量

    5129
  • 开发板试用
    +关注

    关注

    3

    文章

    300

    浏览量

    2028
收藏 人收藏

    评论

    相关推荐

    【RA-Eco-RA2E1-48PIN-V1.0开发板试用】开箱点灯

    【RA-Eco-RA2E1-48PIN-V1.0开发板试用】开箱点灯 0. 写在前面 在此,衷心感谢电子发烧友平台和瑞萨提供的免费试用名额,让我有机会体验和评估
    发表于 10-26 22:47

    在NXP源码基础上如何适配ELF 1开发板UART功能

    UART即通用异步收发器,是一种支持全双工串行通信协议的接口。在i.MX6ULL处理器平台上,该处理器原生支持多达8路的UART接口,提供了丰富的串行通信能力。 针对ELF 1开发板,实际引出了4路
    的头像 发表于 09-29 11:49 247次阅读
    在NXP源码基础上如何适配ELF 1<b class='flag-5'>开发板</b>的<b class='flag-5'>UART</b>功能

    ElfBoard技术贴|如何在NXP源码基础上适配ELF 1开发板UART功能

    UART即通用异步收发器,是一种支持全双工串行通信协议的接口。在i.MX6ULL处理器平台上,该处理器原生支持多达8路的UART接口,提供了丰富的串行通信能力。 针对ELF 1开发板,实际引出
    的头像 发表于 09-25 13:56 2209次阅读
    ElfBoard技术贴|如何在NXP源码基础上适配ELF 1<b class='flag-5'>开发板</b>的<b class='flag-5'>UART</b>功能

    中科受邀参加中关村科技沙龙,争当科技成果转化排头兵

    近日,中科副总经理吴军宁及人力行政部经理吴丹受邀出席了中关村科技联盟举办的第二期科技沙龙活动。为中关村街道及自动化所领导详细汇报了中科
    的头像 发表于 09-25 08:00 313次阅读
    <b class='flag-5'>中科</b><b class='flag-5'>昊</b><b class='flag-5'>芯</b>受邀参加中关村科技沙龙,争当科技成果转化排头兵

    喜报!中科荣获国家级专精特新“小巨人”企业称号

    喜讯!近日,国家工业和信息化部门正式揭晓了第六批国家专精特新“小巨人”企业名单,中科凭借卓越的技术实力和创新能力,荣获了专精特新“小巨人”企业殊荣。这一荣誉不仅是对中科
    的头像 发表于 09-14 08:00 554次阅读
    喜报!<b class='flag-5'>中科</b><b class='flag-5'>昊</b><b class='flag-5'>芯</b>荣获国家级专精特新“小巨人”企业称号

    【龙芯2K0300蜂鸟试用】开箱体验

    本帖最后由 ele2022 于 2024-8-13 19:54 编辑 首先感谢电子发烧友和龙芯中科提供的试用机会。 今天开箱体验龙芯中科的一款2K0300蜂鸟开发板。龙芯2K03
    发表于 08-12 19:59

    点击参与米尔NXP i.MX 93开发板有奖试用

    米尔与NXP合作发布的新品基于NXPi.MX93应用处理器的MYD-LMX9X开发板免费试用活动来啦~~米尔提供了3块价值678元的MYD-LMX9X开发板发起试用活动您不仅可以免费体
    的头像 发表于 06-13 08:02 423次阅读
    点击参与米尔NXP i.MX 93<b class='flag-5'>开发板</b>有奖<b class='flag-5'>试用</b>

    免费!NXP i.MX 93开发板有奖试用

    米尔与NXP合作发布的新品基于NXPi.MX93应用处理器的MYD-LMX9X开发板免费试用活动来啦~~米尔提供了2块价值678
    的头像 发表于 05-23 08:01 634次阅读
    免费!NXP i.MX 93<b class='flag-5'>开发板</b>有奖<b class='flag-5'>试用</b>

    fpga开发板与linux开发板区别

    FPGA开发板与Linux开发板是两种不同的硬件开发平台,各自具有不同的特点和应用场景。在以下的文章中,我将详细介绍FPGA开发板和Linux开发板
    的头像 发表于 02-01 17:09 1993次阅读

    使用爱派Pro开发板部署人体姿态估计模型

    在经过之前对于开发板的使用,以及通过几个爱派官方给出的示例demo(mobilenet/yolov5)在开发板上的部署之后,笔者也逐渐了解了爱派这块
    的头像 发表于 01-09 09:50 1317次阅读
    使用爱<b class='flag-5'>芯</b>派Pro<b class='flag-5'>开发板</b>部署人体姿态估计模型

    利用星闪BS25开发板NL001测试官方sdk中的外设程序uart

    本文利用星闪BS25开发板NL001测试一下官方sdk中的外设程序uart,以便熟悉外设的基本操作。
    的头像 发表于 01-02 11:30 2699次阅读
    利用星闪BS25<b class='flag-5'>开发板</b>NL001测试官方sdk中的外设程序<b class='flag-5'>uart</b>

    中科完成Pre-B轮融资,用于DSP产品研发等

    作为中科院科技成果的转换企业,中科以开源指令集risc-v为基础,制造了多系列数字信号处理器产品,构建了完善的处理器产品生态系统。产品广泛应用于工业控制及电机驱动、数字电源、光伏、
    的头像 发表于 12-06 14:39 1246次阅读

    明德扬PCIE开发板系列XILINX-K7试用体验-第二篇

    本文为明德扬原创文章,转载请注明出处!作者:Vito 明德扬PCIE开发板系列XILINX-K7试用体验-第二篇 第二周的试用计划是实现常见低速协议(UART,I2C,SPI)的FPG
    的头像 发表于 11-29 15:39 3174次阅读
    明德扬PCIE<b class='flag-5'>开发板</b>系列XILINX-K7<b class='flag-5'>试用</b>体验-第二篇

    【爱派 Pro 开发板试用体验】开箱测试

    的各种纸盒包装结实很多。 打开后发现,其中包括一个开发板和电源。还有一个口袋里面有个螺母,不知道什么用途,我现在把它安装在电源的接头上了,好像也不是特别合适。 开发板上的各种接口似乎都是双份,包括
    发表于 11-20 22:09

    【爱派 Pro 开发板试用体验】开箱报告 + 资料准备

    很高兴获得了这次试用爱心派Pro开发板试用资格,之前也有接触过爱元智家的AX620开发板,是因为他们的家的AI ISP慕名而来的,之前深
    发表于 11-14 20:59