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

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

3天内不再提示

单片机系统板的实现及应用分析

电子设计 ? 来源:电子技术应用 ? 作者:赵力强,赵小冬, ? 2021-05-21 10:52 ? 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

作者:赵力强,赵小冬,李璟

在因特网上TCP/IP协议每时每刻保证了数据的准确传输。在数据采集领域,如何利用TCP/IP协议在网络中进行数据传输成为一个炙手可热的话题。在本系统中,利用TCP/IP协议中的UDP(用户数据报协议)、IP(网络报文协议)、ARP(地址解析协议)及简单的应用层协议成功地实现了单片机的网络互连,既提高了数据传输的速度,又保证了数据传输的正确性,同时也扩展了数据传输的有效半径。

1 TCP/IP协议简介

TCP/IP协议是一套把因特网上的各种系统互连起来的协议组,保证因特网上数据的准确快速传输。参考开放系统互连(OSI)模型,TCP/IP通常采用一种简化的四层模型,分别为:应用层、传输层、网络层、链路层。

(1)应用层

网络应用层要有一个定义清晰的会话过程?如通常所说的Http、Ftp、Telnet等。在本系统中,单片机系统传递来自Ethernet和数据终端的数据,应用层只对大的数据报作打包拆报处理。

(2)传输层

传输层让网络程序通过明确定义的通道及某些特性获取数据,如定义网络连接的端口号等?实现该层协议的传输控制协议TCP和用户数据报协议UDP。在本系统中使用UDP数据报协议。

(3)网络层

网络层让信息可以发送到相邻的TCP/IP网络上的任一主机上,IP协议就是该层中传送数据的机制。同时为建立网络间的互连,应提供ARP地址解析协议,实现从IP地址到数据链路物理地址的映像。

(4)链路层

由控制同一物理网络上的不同机器间数据传送的底层协议组成?实现这一层协议的协议并不属于TCP/IP协议组。在本系统中这部分功能由单片机控制网卡芯片CS8900实现。

2 硬件框图

如图1所示,系统提供RJ45接口连接Ethernet网络,并且提供一个串口给用户使用。系统板可以将从Ethernet上过来的IP数据报解包后送给串口,也可将从串口过来的数据封装为IP包送到局域网中。外部RAM使用61C1024(128KB),从而为数据处理提供了很大的缓存; 使用E2PROM--X25045,既可以作为看门狗使用?也可以将IP地址、网卡物理地址和其他参数保存在里面。

CS8900芯片是Cirrus Logic公司生产的一种局域网处理芯片,它的封装是100-pin TQFP,内部集成了在片RAM、10BASE-T收发滤波器,并且提供8位和16位两种接口,本文只介绍它的8位模式。

ME103是一种脉冲变压器,在CS8900的前端对网络信号进行脉冲波形变换。

3 工作原理

3.1 CS8900的工作原理

CS8900与单片机按照8位方式连接,网卡芯片复位后默认工作方式为I/O连接,基址是300H,下面对它的几个主要工作寄存器进行介绍(寄存器后括号内的数字为寄存器地址相对基址300H的偏移量)。

·LINECTL(0112H)

LINECTL决定CS8900的基本配置和物理接口。在本系统中,设置初始值为00d3H,选择物理接口为10BASE-T,并使能设备的发送和接收控制位。

·RXCTL(0104H)

RXCTL控制CS8900接收特定数据报。设置RXTCL的初始值为0d05H,接收网络上的广播或者目标地址同本地物理地址相同的正确数据报。

·RXCFG(0102H)

RXCFG控制CS8900接收到特定数据报后会引发接收中断。RXCFG可设置为0103H,这样当收到一个正确的数据报后,CS8900会产生一个接收中断。

·BUSCT(0116H)

BUSCT可控制芯片的I/O接口的一些操作。设置初始值为8017H,打开CS8900的中断总控制位。

·ISQ(0120H)

ISQ是网卡芯片的中断状态寄存器,内部映射接收中断状态寄存器和发送中断状态寄存器的内容。

·PORT0(0000H)

发送和接收数据时,CPU通过PORT0传递数据。

·TXCMD(0004H)

发送控制寄存器,如果写入数据00C0H,那么网卡芯片在全部数据写入后开始发送数据。

·TXLENG(0006H)

发送数据长度寄存器,发送数据时,首先写入发送数据长度,然后将数据通过PORT0写入芯片。

以上为几个最主要的工作寄存器(为16位),CS8900支持8位模式,当读或写16位数据时,低位字节对应偶地址,高位字节对应奇地址。例如,向TXCMD中写入00C0H,则可将00h写入305H,将C0H写入304H。

系统工作时,应首先对网卡芯片进行初始化,即写寄存器LINECTL、RXCTL、RCCFG、BUSCT。发数据时,写控制寄存器TXCMD,并将发送数据长度写入TXLENG,然后将数据依次写入PORT0口,如将第一个字节写入300H,第二个字节写入301H,第三个字节写入300H,依此类推。网卡芯片将数据组织为链路层类型并添加填充位和CRC校验送到网络。同样,单片机查询ISO的数据,当有数据来到后,读取接收到的数据帧。读数据时,单片机依次读地址300H,301H,300H,301H...。

3.2 单片机工作流程

如图2所示,单片机首先初始化网络设备。网卡的IP地址和物理地址存在X25045中,单片机复位后首先调取这些数据以初始化网络。

单片机主要完成数据的解包打包。当有数据从RJ45过来,单片机对数据报进行分析,如果是ARP(物理地址解析)数据包,则程序转入ARP处理程序(因为在网络上正是ARP协议将IP地址和物理地址相映射)。如果是IP数据包且传输层使用UDP协议,端口正确,则认为数据报正确,数据解包后,将数据部分通过串口输出。反之,如果单片机从串口收到数据,则将数据按照UDP协议格式打包,送入CS8900,由CS8900将数据输出到局域网中。

可以知道,单片机主要处理协议的网络层和传输层,链路层部分由CS8900完成。因单片机将数据接收后完整不变地通过串口输出,所以将应用层交付用户来处理,用户可以根据需求对收到的数据进行处理。

在单片机的程序处理中,包含了完整的APR地址解析协议。通过在单片机中正确设置网关、子网掩码等参数,实现了通过局域网单片机与外部因特网上的终端设备的数据通信

4 应用

这种嵌入了TCP/IP协议的单片机系统板,具有成本低、硬件少、占用面积少、传输速度快、使用方便等优点。适用于现有的网络传输系统,有着广泛的应用前景,特别是数据采集、数据传输领域。目前,在屏幕板数据成像、远程数据采集系统中被使用。

责任编辑:gt

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

    关注

    162

    文章

    8154

    浏览量

    182418
  • 寄存器
    +关注

    关注

    31

    文章

    5440

    浏览量

    125001
  • 接口
    +关注

    关注

    33

    文章

    9033

    浏览量

    154020
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    ISP 型单片机实验

    ISP 型单片机实验学习单片机离不开实验,以往单片机的实验往往依赖于仿真单片机学习
    发表于 04-09 14:51 ?32次下载

    基于单片机的OLED显示系统设计与实现

    为了提高图形信息的显示速度,并得到更多的显示效果,文章基于FG_V1.2单片机开发,依据OLED12864显示屏的操作时序要求,用51单片机实现了基于0.96英寸OLED屏的显示
    发表于 12-31 09:20 ?23次下载

    基于单片机的OLED显示系统设计与实现

    基于单片机的OLED显示系统设计与实现,没有例程
    发表于 06-21 15:39 ?16次下载

    单片机的以太网络接入系统实现及网络性能分析

    单片机的以太网络接入系统实现及网络性能分析
    发表于 02-07 17:25 ?6次下载

    采用单片机系统实现的AFC跟踪系统

    采用单片机系统实现的AFC跟踪系统
    发表于 01-17 19:47 ?15次下载

    基于单片机创新实验系统的设计与应用

    基于单片机创新实验系统的设计与应用
    发表于 10-16 10:16 ?5次下载
    基于<b class='flag-5'>单片机</b>创新实验<b class='flag-5'>板</b><b class='flag-5'>系统</b>的设计与应用

    AVR单片机最小系统的基本硬件线路与分析资料免费下载

    单片机最小系统 单片机最小系统设计AVR基本硬件线路设计与分析 (ATmega16功能小板) AVR DB-CORE Ver2.3 Atme
    发表于 07-08 17:14 ?15次下载
    AVR<b class='flag-5'>单片机</b>最小<b class='flag-5'>系统</b>的基本硬件线路与<b class='flag-5'>分析</b>资料免费下载

    52单片机和AVR单片机最小系统开发板的电路原理图免费下载

    本文档的主要内容详细介绍的是52单片机和AVR单片机最小系统开发板的电路原理图免费下载。
    发表于 06-15 08:00 ?8次下载
    52<b class='flag-5'>单片机</b>和AVR<b class='flag-5'>单片机</b>最小<b class='flag-5'>系统开发板</b>的电路原理图免费下载

    多个单片机硬件系统的案例分析

      本章首先从单片机的概念入手,简单介绍了单片机实验系统的基本组成及功能,以最简单的信号灯控制应用实验让读者对单片机及其应用系统有一个感性的
    发表于 07-08 11:26 ?155次下载
    多个<b class='flag-5'>单片机</b>硬件<b class='flag-5'>系统</b>的案例<b class='flag-5'>分析</b>

    单片机对GPRS电路的开关控制实现案例

    案例描述:“灯控项目”中让单片机通过IO口控制继电器,继电器接入GPRS电路供电电源,从而实现单片机对GPRS电路的开关控制
    的头像 发表于 09-24 10:01 ?6312次阅读
    <b class='flag-5'>单片机</b>对GPRS电路<b class='flag-5'>板</b>的开关控制<b class='flag-5'>实现</b>案例

    单片机最小系统的PCB的设计

    单片机最小系统的PCB的设计方法介绍。
    发表于 05-28 14:52 ?0次下载
    <b class='flag-5'>单片机</b>最小<b class='flag-5'>系统</b>的PCB<b class='flag-5'>板</b>的设计

    单片机数据采集系统PCB制作

    单片机数据采集系统PCB制作(pic单片机论坛)-该文档为单片机数据采集系统PCB
    发表于 07-22 10:17 ?35次下载
    <b class='flag-5'>单片机</b>数据采集<b class='flag-5'>系统</b>PCB<b class='flag-5'>板</b>制作

    单片机最小系统

    单片机最小系统单片机最小系统来源单片机最小系统为什么称之为
    发表于 11-23 16:51 ?37次下载
    <b class='flag-5'>单片机</b>最小<b class='flag-5'>系统</b>

    单片机最小系统

    、复位电路,如图 2-1 所示:这张最小系统的电路图节选自我们的 KST-51 开发原理图,下面我们就照这张电路图来具体分析最小系统的三要素。电源这个很好理解,电子设备都需要供电,就
    发表于 12-29 19:36 ?69次下载
    <b class='flag-5'>单片机</b>最小<b class='flag-5'>系统</b>

    基于单片机的FFT算法分析实现

    电子发烧友网站提供《基于单片机的FFT算法分析实现.pdf》资料免费下载
    发表于 10-20 11:37 ?16次下载
    基于<b class='flag-5'>单片机</b>的FFT算法<b class='flag-5'>分析</b>与<b class='flag-5'>实现</b>