原文地址https://blog.csdn.net/qq_39545674/article/details/82597106

一、SCI 简介
SCI(Serial Communication Interface)意为"串行通信接口",是相对于并行通信的,是串行通信技术的一种总称,最早由 Motorola 公司提出的。它是一种通用异步通信接口 UART,与 MCS‐51 的异步通信功能基本相同。(以上内容来自百度)

二、28379D 的 SCI 模块简介
2.1 模块功能
基本就是 UART,数据格式可编程。28398D 的 SCI 和其他 28 系列的产品基本一样,有两个增强功能。一个是发送和接收缓冲,FIFO。如果启用了发送 FIFO,就可以将要发送的字节先储存在发送 FIFO 里,待发送 FIFO 里的字节数达到设置的上限后,再一起发送出去。如果启用了接收 FIFO,就可以将接收的字节先存在接收 FIFO 里,待接收 FIFO 里的字节数达到设置的上限后,再产生中断来处理接收的数据。另一个是波特率自动检测功能,这个一般不用。

2.2 28379D 的 SCI 模块引脚
28379D 有 4 个 SCI,即 SCIA,SCIB,SCIC,SCID。每个 SCI 的发送引脚和接收引脚都有很多个,如下表:

发送Tx 接收Rx
SCIA GPIO8/29/36/42/48/65/84/135 GPIO9/28/35/43/49/64/85/136
SCIB GPIO9/10/14/18/22/54/70/86/137 GPIO11/15/19/23/55/71/87/138
SCIC GPIO12/38/56/63/72/89/106/140 GPIO13/39/57/62/73/90/107/139
SCID GPIO47/76/93/104/142 GPIO46/77/94/105/141

三、SCI 配置步骤
3.1 配置 GPIO
配置相应的 GPIO 为 SCIx 的复用引脚。

3.2 配置 SCI 的数据格式
配置发送和接收的数据格式,一般是:1 位停止位,无奇偶校验,无回环,空闲线模式(两个对象之间通讯,如果是三个及以上,得用地址线模式),8 位数据位。

3.3 配置波特率
配置波特率,不多说。

3.4 配置 FIFO
首先得使能 FIFO,然后根据需要,进行配置。比如使能接收 FIFO 中断,设置 FIFO 的级数,基本的就这些。还可以配置波特率自检的一些设置,不过一般不用。

3.5 使能 SCI
复位一些标志,比如 SCICTL1 寄存器的 SWRESET,必须被置 1,等等。

3.6 配置 PIE
首先使能 PIE,然后修改 PIE 向量表,然后使能对应的 PIE,以及 CPU 中断。

四、代码示例
示例使用了 SCIB,引脚使用 GPIO18 为 Tx,GPIO19 为 Rx。
4.1 配置 GPIO

EALLOW;
GpioCtrlRegs.GPAPUD.bit.GPIO18=0;//开启上拉电阻
GpioCtrlRegs.GPAPUD.bit.GPIO19=0;//开启上拉电阻
GpioCtrlRegs.GPADIR.bit.GPIO19=0;
GpioCtrlRegs.GPADIR.bit.GPIO18=1;
GpioCtrlRegs.GPAGMUX2.bit.GPIO18=0;
GpioCtrlRegs.GPAGMUX2.bit.GPIO19=0;
GpioCtrlRegs.GPAMUX2.bit.GPIO18=2;//复用为 SCIB 的输出
GpioCtrlRegs.GPAMUX2.bit.GPIO19=2;//复用为 SCIB 的输入
EDIS;

4.2 配置数据格式

ScibRegs.SCICCR.all = 0x0007;//1 位停止位,无奇偶校验,无回环测试,空闲线模式,8 位数据位

4.3 配置波特率

ScibRegs.SCIHBAUD.bit.BAUD=0x0000;//波特率 115200
ScibRegs.SCILBAUD.bit.BAUD=0x0036;//波特率 115200

4.4 配置 FIFO

ScibRegs.SCIFFTX.bit.SCIFFENA=1;//使能 FIFO
ScibRegs.SCIFFRX.bit.RXFFIENA = 1;//使能 FIFO 接收中断
ScibRegs.SCIFFRX.bit.RXFFIL=1;//FIFO 接收字节 1
ScibRegs.SCIFFCT.all = 0x0;

4.5 重新使能 SCI

ScibRegs.SCICTL1.all =0x0023; // Relinquish SCI from Reset 重启sci

4.6 配置 PIE

PieCtrlRegs.PIECTRL.bit.ENPIE = 1;//使能 PIE
EALLOW;
PieVectTable.SCIB_RX_INT=&ScibInterrupt;//修改中断向量表
EDIS;
PieCtrlRegs.PIEIER9.bit.INTx3 = 1;//使能 PIE 中断
IER |= M_INT9;//使能 CPU 中断

4.7 接收中断函数 ScibInterrupt 如下:

interrupt void ScibInterrupt(void)
{
int i=0,data;
for(i=0;i<ScibLegnth;i++)
{
data=ScibRegs.SCIRXBUF.bit.SAR;//接收的数据
}
ScibRegs.SCIFFRX.bit.RXFFINTCLR=1; // 清接收中断标志
PieCtrlRegs.PIEACK.all|=PIEACK_GROUP9;// 清接收中断标志
}

4.8 发射函数

int ScibSend(int data)
{
while (ScibRegs.SCIFFTX.bit.TXFFST != 0) {}
ScibRegs.SCITXBUF.bit.TXDT=0x06;
return 0;
}
5、注意

1、请检查自己工程的配置,系统时钟是否是200M,如果不是,则波特率不对,具体的配置方式请参百度

2、本文代码是基于硬件TMS320F28379D,如果你是使用的其他硬件,则代码一般是不能用的
---------------------
作者:一朝英雄拔剑起
来源:CSDN
原文:https://blog.csdn.net/qq_39545674/article/details/82597106
版权声明:本文为博主原创文章,转载请附上博文链接!

TMS320F28379D 使用心得之 SCI的更多相关文章

  1. 如何在两个月的时间内发表一篇EI/SCI论文-我的时间管理心得

    在松松垮垮的三年研究生时期,要说有点像样的成果,也只有我的小论文可以谈谈了.可能有些厉害的角色研究生是丰富而多彩的,而大多数的同学在研究生阶段可能同我一样,是慢悠悠的渡过的,而且可能有的还不如我,我还 ...

  2. SCI投稿过程总结、投稿状态解析、拒稿后对策及接受后期相关问答

    SCI投稿过程总结.投稿状态解析.拒稿后对策及接受后期相关问答   http://muchong.com/t-9174366-1 SCI投稿过程总结.投稿状态解析.拒稿后处理对策及接受后期相关问答综合 ...

  3. 我的MYSQL学习心得(一) 简单语法

    我的MYSQL学习心得(一) 简单语法 我的MYSQL学习心得(二) 数据类型宽度 我的MYSQL学习心得(三) 查看字段长度 我的MYSQL学习心得(四) 数据类型 我的MYSQL学习心得(五) 运 ...

  4. NoSql数据库使用半年后在设计上面的一些心得

    NoSql数据库这个概念听闻许久了,也陆续看到很多公司和产品都在使用,优缺点似乎都被分析的清清楚楚.但我心里一直存有一个疑惑,它的出现究竟是为了解决什么问题? 这个疑惑非常大,为此我看了很多分析文章, ...

  5. 我的MYSQL学习心得(二) 数据类型宽度

    我的MYSQL学习心得(二) 数据类型宽度 我的MYSQL学习心得(一) 简单语法 我的MYSQL学习心得(三) 查看字段长度 我的MYSQL学习心得(四) 数据类型 我的MYSQL学习心得(五) 运 ...

  6. 我的MYSQL学习心得(三) 查看字段长度

    我的MYSQL学习心得(三) 查看字段长度 我的MYSQL学习心得(一) 简单语法 我的MYSQL学习心得(二) 数据类型宽度 我的MYSQL学习心得(四) 数据类型 我的MYSQL学习心得(五) 运 ...

  7. 我的MYSQL学习心得(四) 数据类型

    我的MYSQL学习心得(四) 数据类型 我的MYSQL学习心得(一) 简单语法 我的MYSQL学习心得(二) 数据类型宽度 我的MYSQL学习心得(三) 查看字段长度 我的MYSQL学习心得(五) 运 ...

  8. 我的MYSQL学习心得(五) 运算符

    我的MYSQL学习心得(五) 运算符 我的MYSQL学习心得(一) 简单语法 我的MYSQL学习心得(二) 数据类型宽度 我的MYSQL学习心得(三) 查看字段长度 我的MYSQL学习心得(四) 数据 ...

  9. 我的MYSQL学习心得(六) 函数

    我的MYSQL学习心得(六) 函数 我的MYSQL学习心得(一) 简单语法 我的MYSQL学习心得(二) 数据类型宽度 我的MYSQL学习心得(三) 查看字段长度 我的MYSQL学习心得(四) 数据类 ...

随机推荐

  1. python——获取数据类型

    在python中,可使用type()和isinstance()内置函数获取数据类型 如: (1)type()的使用方法: >>> a = '230'         >> ...

  2. CERC2017 F: Faulty Factorial 简单数论题

    #include <iostream> using namespace std; #define ll long long ; ll n,p,r; ll poww(ll a,ll b){ ...

  3. Alter the structure of web pages with JavaScript

    Most of the DOM methods you've seen so far are useful for identifying elements. Both getElementById ...

  4. C语言关键词解释

    51单片机关键词 code code的作用是告诉单片机,我定义的数据要放在ROM(程序存储区)里面,写入后就不能再更改

  5. LC.exe已退出,代码为-1

    解决方法就是把Properties文件下的license.licx给删除,重新编译,这样就可以了.

  6. 解决 ld: library not found for -lPods的问题

    现在打开有pods建好的workspace文件,尝试编译,会报ld: library not found for -lPods错误,原因就是工程里面的设置项覆盖了pods中xcconfig中的设置.解 ...

  7. 跟着学!教你开发第一个Java程序

    今天我们的目标是开发人生中的第一个Java程序,虽然可能会很简单,但是这小小的一步却是跨入IT行业的一大步!下面我们来一起来仔细的了解开发的流程. 准备工作 1,作为一名准程序猿自备一台电脑那是必不可 ...

  8. 《Cracking the Coding Interview》——第3章:栈和队列——题目2

    2014-03-18 05:08 题目:实现一个栈,除了能进行push和pop之外,还能在O(1)时间内返回栈中最小的元素. 解法:用另一个“最小栈”存放最小的元素,每当有不小于当前最小值的元素进栈时 ...

  9. os--留

    os.path.abspath(path) #返回绝对路径    绝对路径和文件路径的区别,绝对路径是当前在操作文本的路径,文件路径是当前文本的文件的路径 os.path.basename(path) ...

  10. ASP.NET Core ---异常处理

    一.局部异常处理: 在Action里面catch 二.全局异常处理: 1.默认的异常处理配置: 默认配置在StartUp文件的Configure中注册错误处理,显示开发者错误页面: public vo ...