ARM Cortex-A8/A9开发板 | ARM11开发板ARM11开发套件 | ARM9开发板ARM9开发套件 | 飞思卡尔I.MX28I.MX6开发板 |
tiny210/mini210开发板 | mini6410开发板/套餐 | Tiny6410开发板无线套件 | mini2440开发板/套餐 | micro2440开发板带核心板 | 友善开发板配件 模块 | QQ2440 V3 SBC-2410X |
FL2440 OK2440-IV V4 | OK2440-III OK2440V3 | TE2440-II TE2440V2 | OK6410 S3C6410 ARM11 | FL6410/OK6410B ARM11 | TE6410 S3C6410 ARM11 | TE-9263 AT91SAM9263 | 开发板配件 模块和其他 |
Xilinx开发板/fpga开发套件 | altera开发板/fpga开发套件 | 基于FMC FPGA/DSP子卡 |
BeagleBoard原厂开发板 | PandaBoard原厂开发板 |
TI DM3730 DevKit8500D | TI系列 omap3530开发板 | ATMEL系列 开发板 | Samsung系列 开发板 | 开发板配件-仿真器 模块 | NXP LPC3250 mini3250 |
Tiny210 三星S5PV210 | Mini210/Mini210s开发板 | Tiny4412开发板Cortex-A9 | Tiny6410开发板 ARM11 | mini2440开发板 ARM9 | micro2440开发板 ARM9 | mini6410开发板 ARM11 | 友善ARM开发板配件 模块 |
keil ARM仿真器/开发工具 | STM32开发板 Cortex-M3 | NXP LPC开发板Cortex-M3 | ATMEL系列 ARM开发板 | Luminary EKK8962开发板 | Freescale i.MX31开发板 | 三星s3c2440 s3c6410开发板 |
FL2440 OK2440-IV V4 | OK6410 S3C6410 ARM11 | FL6410/OK6410B ARM11 | OK210/-A Cortex-A8 | TE2440-II TE2440V2 | TE6410 S3C6410 ARM11 | TE-9263 AT91SAM9263 | ARM开发板配件 模块等 |
Real6410开发板/套餐 | Real210开发板/Real2410 | WIFI GPS GPRS模块摄像头 |
Xilinx开发板/开发套件KIT | Altera开发板/开发套件KIT | 配套模块 |
NXP LPC开发板 ARM7 | Cortex-M3 STM32开发板 | 最小系统模块类(初学者勿选) | 开发工具 仿真器 调试器 | TFT液晶屏LCD 液晶模块 |
DM642开发板/DM642实验箱 | DM6446开发板/DSP实验箱 | DSP仿真器 液晶屏 摄像头等 |
DM3730/AM3715/AM3359 | OMAP3530AM1808AM3517 | 飞思卡尔Cortex-A9开发板 | ATMEL系列ARM开发板 | NXP LPC3250 LPC1788 | Samsung系列ARM开发板 | STM32系列F207/F407 | ARM开发板配件-仿真器 模块 |
Realv210 S5PV210开发板 | Real6410开发板 ARM11 | WIFI GPS GPRS模块摄像头 |
NXP LPC开发板 ARM7 | Cortex-M3 STM32开发板 | ARM小系统模块(初学勿选) | 开发工具 ARM仿真器 调试器 | TFT液晶屏LCD 液晶模块 |
keil ARM仿真器/开发工具 | STM32开发板 Cortex-M3 | NXP LPC开发板Cortex-M3 | ATMEL系列 ARM开发板 | Luminary EKK8962开发板 | Freescale i.MX31开发板 | 三星s3c2440 s3c6410开发板 |
Exynos4412开发板A9四核 | UT-S5PV210 S5PC100 | UT-S3C6410开发板 ARM11 | idea 6410开发板 ARM11 | UT-S3C2450开发板 ARM9 | UT-S3C2416开发板 ARM9 | UT-S3C6410核心板 工控 |
Xilinx开发板 FPGA开发套件 | altera开发板 FPGA开发套件 | FMC模块 配件 下载线 |
DM642开发板/DM642实验箱 | DM6446开发板/DSP实验箱 | DSP仿真器 液晶屏 摄像头等 |
s3c2410 ARM9 FS2410 | s3c2440开发板 ARM9 | s3c44B0开发板 ARM7 | s3c6410 2450 2443/13 | PXA270 PXA320 PXA255 | Atmel 9200 9261 9G20 | Philips NXP开发板YL-LPC | FS-EP9315开发板ARM9 | LCD液晶屏TFT真彩/触摸屏 | ARM仿真器/仿真调试工具 | ARM开发板配套ARM核心板 |
三星s3c2410 s3c44B0 | 三星s3c6410 s3c2443 | Intel PXA270 PXA320 | UP-CUP OMAP5910平台 | FPGA Xilinx altera平台 | 配件-仿真器 模块 液晶屏LCD | 龙芯开发板UP-DRAGON-I | 物联网教学科研设备 | EDA/FPGA/SOPC教学科研 |
utu2440-F-V4.5 含核心板 | utu2440-S-V4.1 单板结构 | YC2440-F-V5.1开发板 豪华型 | YC-ePC-A系列人机界面 | Mars-EDA套件CPLD FPGA | 触摸屏LCD 摄像头 WI-FI模块 |
ARM开发板/开发平台 | FPGA开发板/开发平台 | 编程器/烧写器下载器烧录 | ZLG 仿真器ARM FPGA DSP | ZLG周立功逻辑分析仪 |
DSP初学者开发套件(DSK) | DSP仿真器/仿真系统 | DSP开发板/DSP试验箱 | DaVinci系列多媒体平台 | Xilinx FPGA大学计划产品 | SEED教学实验系统 | FPGA/DSP FPGA开发板 | TI原厂开发板套件/CCS软件 |
ARM开发板 | XSCALE开发板 | ARM仿真器 | SOPC开发板 | DSP开发板 | 达芬奇系列DSP开发平台 | DSP仿真器 | DSP实验箱 | DSP专业研究平台 | ARM实验箱系列 |
广嵌实验室项目产品 | GEC2440/GEC6410开发板 |
泰克Tektronix示波器 | 普源RIGOL示波器 | USB虚拟示波器 |
UT-S5PC100 UT-S5PV210 | UT-S3C6410开发板 ARM11 | idea 6410开发板 ARM11 | UT-S3C2450开发板 ARM9 | UT-S3C2416开发板 ARM9 | UT-S3C6410核心板 工控 | 开发板模块wifi gps等 |
EMA OMAP3530开发板 | EMA OMAP 3530核心板 |
三星s3c2410 s3c44B0 | 三星s3c6410 s3c2443 | Intel PXA270 PXA320 | UP-CUP OMAP5910平台 | FPGA Xilinx Altera平台 | 配件-仿真器 模块 液晶屏LCD | 龙芯系列 UP-DRAGON-I |
utu2440-F-V4.5 含核心板 | utu2440-S-V4.1 单板结构 | YC2440-F-V5.1开发板 豪华型 | 触摸屏LCD 摄像头 WI-FI模块 | Mars-EDA套件CPLD FPGA | ePC系列工控一体机ARM9 A8 |
ARM开发板/开发平台 | FPGA开发板/开发平台 | 编程器/烧写器下载器烧录 | ZLG 仿真器ARM FPGA DSP | ZLG周立功逻辑分析仪 |
DSP初学者开发套件(DSK) | DSP仿真器 | DSP开发板 | DSP实验箱 | Xilinx FPGA大学计划产品 |
ARM开发板 | XSCALE开发板 | ARM仿真器 | SOPC开发板 | DSP开发板 | 达芬奇系列DSP开发平台 | DSP仿真器 | DSP实验箱 | DSP专业研究平台 | ARM实验箱系列 |
ARM开发板S3C6410等 | Cortex-A8/ARM11仿真器 | ADSP Blackfin开发板 | FPGA Spartan-3E开发板 |
GEC2410开发套件ARM9 | GEC2440开发套件ARM9 |
泰克 示波器 |
异步串行通讯,诸如RS232、RS485等以大略实用而众所周知。同步串行通讯以异步不可相比的高速率而应用在很多速率请求较高的通讯网络。同步通讯无需开始位和克制位,直接由同步时钟对数据采样,数据传输率等同于时钟速率。其明显特点便是两端必须共享同临时钟,发送方必须将时钟和数据同时发送,吸取方才华精确采样。同步模式分为字节同步和位同步。国际标准化构造的HDLC(高级数据链路控制)协议是应用最广泛的同步协议。
Intel8274简介
Intel8274是实现HDLC同步通讯协议的最佳接口芯片,图1是其管脚定义,有以下明显特点:
·有异步、字节同步和位同步事变模式;
·2个独立的、全双工的吸取器和发送器;
·和很多CPU接口兼容;
·4个独立的DMA通道;
·波特率可达880K;
·异步模式下,具备通用串口的全部信号;
·在位同步时,主动孕育产生并辨认HDLC的开标记和关标记、主动举行零位插入和删除、主动为发送数据孕育产生CRC校验码并主动对吸取数据举行CRC校验、和CCITT的X.25兼容。
Intel8274的零位插入是为了把标记字节 7EH和正式数据中的7EH( 0111.1110B)区退出来。在发送一方,除标记字节之外的全部发送字节,每遇到有五个连续的“1”就主动插入一个“0”,从而包管了两个标记字节之间的别的字节没有7EH。在吸取一方,吸取到标记字节之后,每遇到字节中有五个连续的“1”后的一个“0”,将这个“0”删撤除,规复字节原值。发送方和吸取方的CRC校验都不包括这个分外插入的“0”和被删除的“0”。硬件实现时很容易用锁相环电路检测出标记字节,方便地果断同步数据帧的开始和结束。
图1 Intel8274管脚定义
图2 智能通讯板布局
体系硬件布局
Intel8274不但性能良好,并且和种种CPU接口比较大略。基于该芯片的某机载雷达计划的同步通讯体系如图2所示,整个体系采取二级CPU布局,将主CPU从啰嗦的通讯办理中解放出来。主CPU和通讯CPU共享双口RAM,在此互换数据。主CPU只需将发送的同步数据帧填入发送缓冲区,由通讯CPU监控同步帧发送。当通讯CPU精确吸取到完备的数据帧时直接放入吸取缓冲区,然后通过停止关照主CPU取走即可。
硬件细化计划时应该细致:
·时钟
在图2中,Intel8274的事变时钟由3.6864MHz的时钟直接输入,而2个通道的发送时钟由8254对事变时钟举行分频后给出。如许可以由软件对8254举行设置,机动配置出种种得当的波特率。分外细致,颠末差分驱动的信号应包括发送时钟,而吸取时钟应该和吸取数据一起由外部提供。
·停止
同步通讯不克不及利用查问的要领,只能利用停止驱动。必须把Intel8274的停止恳求信号/INT(Pin28)和停止应答/INTA(Pin27)各自上拉10KW电阻,而将菊花链的停止输入/IPI(Pin29)接地。/INT未上拉时,Intel8274不克不及孕育产生有效的低电平,CPU不大概相应停止。/INTA未上拉时Intel8274大概向的数据线输出停止向量,扰乱CPU事变。而/IPI未接地时Intel8274的停止恳求有大概被克制,时偶然无,粉碎体系的稳固性。
软件计划
通讯软件重要利用TMS320的汇编语言实现,英华在于对Intel8274的停止处理惩罚上。软件初始化8274为同步模式时,应选择CCITT的CRC,而不是CRC-16。为正确简便,我们采取最通用的算法形貌语言。
同步数据帧发送算法
为了开始同步帧的发送,在全部环境下(包括DMA)都应该由CPU向8274写入第一个字符。在HDLC协议中,第一个字符便是吸取站点的节点地点,而不是开标记。开、关标记由8274主动插入。
Const // 常量定义
DONE = ... // 表现发送或吸取进程已结束
DONE; // 帧发送进程尚未结束,正在运行,
RxDone := NOT_DONE; // 帧吸取进程尚未结束
Reset Tx Intterrupt; // 复位发送停止
Reset Tx CRC; // 复位CRC产生器。
Send Addr; // 发送帧地点,引爆帧发送开始。
Reset TxUnder-Run/EOM; // 立即复位下溢停止,包管精确孕育产生CRC{以后,帧发送的实际进程由停止完成,I8274硬件接口应该在规定的最大时间内应孕育产生“下溢/帧结束”停止,不然产生错误,应复位8274 }
while not TimeOut do
begin
if TxDone = DONE then // 由停止进程设置 TxDone标记
begin
Wait CRC; // 等待CRC发送结束
Check TxResult; // 查抄发送结果是否精确。
Exit;
end;
end;
Reset 8274; // 至此,则超时退出,产生错误,复位8274。
end;
Intel8274停止相应算法
HDLC协议的同步通讯必须由停止驱动,重要是同步通讯的协讲和校验由硬件完成,软硬件必须共同得当。停止重要处理惩罚4类环境,一是利用“发送缓冲器空”停止来发送帧数据,二是用“外部状态变革”停止来果断帧发送结束,三是用“数据吸取”停止来吸取数据帧,四是用“吸取到特别条件”停止来果断帧吸取的开始和结束。在利用多个吸取帧缓冲时,停止处理惩罚要细致缓冲区切换精确。
procedure IntrruptTxRxFrame
begin
Read Interrpt Type; // 从8274读停止范例
case Interrpt Type of // 查抄停止范例
1:Tx Empty: // “发送缓冲器空”停止
if 数据未发送完 then
Send One byte // 从发送缓冲区读取、并发送1字节
else
Reset Tx Empty Interrupt; // 复位此停止,迫使孕育产生下溢停止;
2:External Status Chang // “外部状态变革”停止
if 是下溢停止 then
TxDone := DONE // 帧发送结束,结果精确
else begin
TxDone := DONE; // 帧发送结束
TxResult := FAIL; // 但结果不精确
end;
3:RxChar // “吸取到帧数据字符”
读入并存到吸取帧缓冲区;
4:RxSpecial: // "吸取到特别条件" 停止
if End of Frame then // 帧吸取结束
RxDone := DONE // 吸取进程完成,结果精确
else begin
RxDone := DONE // 吸取进程完成
RxResult := FAIL; // 但结果不精确.
Reset Error Interrupt
end;
else // 别的停止马虎失。
Ignore;
end;
Send EOI; // 发停止结束下令.
end;
结语
同步通讯技能在不绝地生长,席卷环球的Internet网便是采取同步协议X..25连接了差别范例的谋略机。同步通讯和异步通讯相对立而存在,相比较而生长。这里只是抛砖引玉,先容了我们实际事变的一点领会和做法。同步通讯将向更高速率生长,应用在更多的一样平常电子配置中。
参考文献
1 Intel: 《8274 Multi-Protocol Serial Controller》
2 TI: 《TMS320F240 DSP Controllers Refence Guide》
博航网 www.broadon.net 版权所有
京ICP备10051899号-2 京公网安备110108006479号