ADI Blackfin DSP处理器-BF533的开发详解19:LAN的网口设计

news/2024/5/4 15:49:47/文章来源:https://blog.csdn.net/ADI_OP/article/details/128255017

硬件准备

ADSP-EDU-BF533:BF533开发板
AD-HP530ICE:ADI DSP仿真器

软件准备

Visual DSP++软件

硬件链接

在这里插入图片描述

功能介绍

BF533说实话用来做LAN的应用有些许勉强,因为他自己不带网口,要做的话,需要在总线上挂,那么真实来讲,我何不直接用一个自带网口的DSP呢?比如BF537?BF548?BF609?因为我在做BF533的项目的时候,其他的DSP都还没有推出,ADI没有什么带网口的DSP,所以强行用533+一个DM9000来实现的,当下如果让我再去做这个方案的设计,芯片选型会有更多的选择。

20年前那会,我们真的是没条件也得创造条件。。。

这个程序只是打通了底层的硬件链路,并没有去写怎么移植TCP/IP协议的,后面有时间我再单独开一章,好好说一说怎么在嵌入式DSP上去移植TCP/IP协议。

ADSP-EDU-BF533开发板上的网卡模块采用 DM9000EP 实现, DM9000EP 为 DAVICOM 公司生产的网络芯片,它集成了网卡的 MAC 和 PHY,支持 10M/100M 速度。支持 16Bit/32Bit 总线访问带宽。

ADSP-BF533 通过 EBIU 总线采用 16Bit 总线方式与 DM9000EP 连接,其映射地址为 ADSP-BF53x 的 BANK2地址,其映射寄存器如下:

DM9000_PPTR 寄存器(写唯一):
DM9000_PPTRT 寄存器地址:0x20200000
DM9000_PPTR 寄存器是 DM9000EP 的指令寄存器,用于为 DM9000EP 写入指令。
DM9000_PDATA 寄存器(读写):
DM9000_PDATA 寄存器地址:0x20200020
DM9000_PDATA 寄存器是 DM9000EP 的数据寄存器,通过该寄存器读取和发送数据包。

硬件连接示意图

在这里插入图片描述

代码实现功能

代码实现了通过网络接口发送数据包的功能,没有包含任何网络协议。通过网线与计算机连接,使用计算机上的抓包工具,抓取数据包可以查看数据包的数据内容。

调试步骤

  1. 将仿真器(ICE)与 ADSP-EDU-BF53x 开发板和计算机连接好。
  2. 先给 ADSP-EDU-BF53x 开发板上电,再为仿真器(ICE)上电。
  3. 将交叉网线连接于计算机网口和开发板网口。
  4. 运行 VisualDSP++ 5.0 软件,选择合适的 BF533 的 session 将仿真器与软件连接。
  5. 加载 VisualDSP++ 5.0 工程文件 BF53x_LAN.dpj,编译并全速运行。
  6. 运行抓包软件 Commview.exe,通过软件抓取网卡发送的数据包。

通过抓包软件 Commview.exe 的 Pack 窗口可以看到抓取的数据包的数据信息。

在这里插入图片描述

计算机端打印的网卡信息

在这里插入图片描述

使用 COMMVIEW 软件抓取的数据包信息。

程序源码

#include <cdefbf533.h>
#include “dm9000e.h”

#define CONFIG_DRIVER_DM9000
#define CONFIG_COMMANDS 1
#define CFG_CMD_NET 1
#ifdef CONFIG_DRIVER_DM9000
#if (CONFIG_COMMANDS & CFG_CMD_NET)
#define PKTALIGN 32
#define PKTSIZE_ALIGN 1536
#define CFG_HZ 1000

#define DM9000_VID_L 0x28
#define DM9000_VID_H 0x29
#define DM9000_PID_L 0x2A
#define DM9000_PID_H 0x2B
#define DM9000_ID 0x90000A46
#define DM9000_int32_MII 0x00
#define DM9000_10MHD 0x1
#define DM9000_10MFD 0x2
#define DM9000_100MHD 0x3
#define DM9000_100MFD 0x4
#define LOOP_MAC 0x1
#define LOOP_PHY100M 0x2

unsigned short NetRxPackets[PKTSIZE_ALIGN+PKTALIGN];
unsigned char env_enetaddr[6];

#define DM9000_PPTR *(volatile unsigned short *)(0x20200000)
#define DM9000_PDATA *(volatile unsigned short *)(0x20200020)

/****************************************************************************

  • 名称 : GetDM9000ID

  • 功能 : 读取DM9000E ID并打印

  • 入口参数 :无

  • 出口参数 :id_val ID值
    ****************************************************************************/
    unsigned int GetDM9000ID(void)
    {
    unsigned int id_val;

    id_val = ior(DM9000_PID_H);
    printf(“DM9000E ID is %x”,id_val);
    id_val = ior(DM9000_PID_L);
    printf(“%x”,id_val);
    id_val = ior(DM9000_VID_H);
    printf(“%x”,id_val);
    id_val = ior(DM9000_VID_L);
    printf(" %x\n\r",id_val);
    return id_val;
    }
    /****************************************************************************

  • 名称 : iow

  • 功能 : 将值写入指定的寄存器

  • 入口参数 :reg,value

  • 出口参数 :无
    /
    static void iow(int reg, unsigned char value)
    {
    DM9000_PPTR = reg;
    asm(“ssync;”);
    asm(“ssync;”);
    asm(“ssync;”);
    DM9000_PDATA = value & 0xff;
    asm(“ssync;”);
    asm(“ssync;”);
    asm(“ssync;”);
    }
    /

  • 名称 : ior

  • 功能 : 送入要读取的寄存器地址返回当前寄存器值

  • 入口参数 :reg

  • 出口参数 :DM9000_PDATA & 0xff
    /
    static unsigned char ior(int reg)
    {
    DM9000_PPTR = reg;
    asm(“ssync;”);
    asm(“ssync;”);
    asm(“ssync;”);
    return DM9000_PDATA & 0xff;
    }
    /

  • 名称 : eth_reset

  • 功能 : 复位,初始化dm9000E并打印相关设置

  • 入口参数 :无

  • 出口参数 :无
    ****************************************************************************/
    void eth_reset (void)
    {
    int IoMode;
    unsigned char tmp;

    iow(0, 1); // 复位
    delay(50); // delay 100us
    IoMode = ior(0xfe) >> 6; //读取io模式
    if(!IoMode)
    printf(“DM9000 work in 16 bus width\r\n”);
    else if(IoMode == 2)
    printf(“DM9000 work in 8 bus width\r\n”);
    else if(IoMode == 1)
    printf(“DM9000 work in 32 bus width\r\n”);
    else
    printf(“DM9000 work in wrong bus width, error\r\n”);
    iow(0x1e, 0x01);
    iow(0x1f, 0x00); // 使能 PHY
    iow(0xff, 0x80);
    iow(0x01, 0xc); // 清除 TX 状态
    iow(0x5, 0x33); // 使能 RX
    ior(0x6);
    iow(0x2, 1); // 使能TX
    delay(100);
    IoMode = ior(0x01);
    if(IoMode & 0x40)
    printf(“Link on ethernet at:%d Mbps\r\n”, (IoMode & 0x80) ? 10:100);

}
/****************************************************************************

  • 名称 : eth_rx

  • 功能 : 读取网络传输数据

  • 入口参数 :addr

  • 出口参数 :rxlen
    ****************************************************************************/
    int eth_rx (unsigned short *addr)
    {
    int i;
    unsigned short rxlen;
    unsigned short status;
    unsigned char RxRead;
    unsigned char *tmp;

    RxRead = ior(0xf0);
    RxRead = (DM9000_PDATA) & 0xff;
    RxRead = (DM9000_PDATA) & 0xff;
    if (RxRead != 1)
    return 0;
    status = ior(0xf2);//获得状态
    rxlen = DM9000_PDATA; //获得长度
    asm(“ssync;”);
    if (rxlen > PKTSIZE_ALIGN + PKTALIGN)
    printf (“packet too big! %d %d\r\n”, rxlen, PKTSIZE_ALIGN + PKTALIGN);
    for ( i =0; i<rxlen/2;i++)
    addr[i] = DM9000_PDATA;
    asm(“ssync;”);
    return rxlen;
    }

unsigned char txCmd;
/****************************************************************************

  • 名称 : eth_send

  • 功能 : 向网络发送数据包

  • 入口参数 :packet,length

  • 出口参数 :0
    ****************************************************************************/
    void eth_send (volatile void *packet, int length)
    {
    int i;
    volatile unsigned short *addr;
    int tmo;
    unsigned char TxStatus;
    int length1 = length>>1;
    int IoMode;

    TxStatus = ior(0x01);
    TxStatus = TxStatus & 0xc;

    DM9000_PPTR = 0xf8;
    for(i=0;i<2;i++) //延时匹配时序。
    asm(“ssync;”);

    for (addr = packet; length1 > 0; length1 --)
    {
    DM9000_PDATA = *addr++;
    for(i=0;i<3;i++) //延时匹配84nS延时时序。
    asm(“ssync;”);

    }
    iow(0xfd, (length >> 8) & 0xff); //set transmit leng
    iow(0xfc, length & 0xff);
    /* start transmit */
    iow(0x02, txCmd|0x1);

    return 0;
    }

/****************************************************************************

  • 名称 : phy_read

  • 功能 : 读取DM9000E物理寄存器

  • 入口参数 :reg

  • 出口参数 :( ior( 0xe) << 8 ) | ior( 0xd)
    /
    static unsigned short phy_read(int reg)
    {
    iow( 0xc, DM9000_PHY | reg);
    iow( 0xb, 0xc);
    delay(100);
    iow(0xb, 0x0);
    return ( ior( 0xe) << 8 ) | ior( 0xd);
    }
    /

  • 名称 : phy_write

  • 功能 : 写DM9000E物理寄存器

  • 入口参数 :reg,value

  • 出口参数 :无
    /
    static void phy_write( int reg, unsigned short value)
    {
    iow( 0xc, DM9000_PHY | reg);
    iow( 0xd, (value & 0xff));
    iow(0xe, ( (value >> 8) & 0xff));
    iow(0xb, 0xa);
    delay(100);
    iow(0xb, 0x0);
    }
    /

  • 名称 : set_PHY_mode

  • 功能 : 设置网卡工作模式 10M:100M

  • 入口参数 :op_mode

  • 出口参数 :无
    ****************************************************************************/
    static void set_PHY_mode(op_mode)
    {
    int phy_reg4,phy_reg0;
    switch(op_mode)
    {
    case DM9000_10MHD:
    phy_reg4 = 0x21;
    asm(“ssync;”);
    phy_reg0 = 0x0000;
    asm(“ssync;”);
    break;
    case DM9000_10MFD:
    phy_reg4 = 0x41;
    asm(“ssync;”);
    phy_reg0 = 0x1100;
    asm(“ssync;”);
    break;
    case DM9000_100MHD:
    phy_reg4 = 0x81;
    asm(“ssync;”);
    phy_reg0 = 0x2000;
    asm(“ssync;”);
    break;
    case DM9000_100MFD:
    phy_reg4 = 0x101;
    asm(“ssync;”);
    phy_reg0 = 0x3100;
    asm(“ssync;”);
    break;
    } // end of switch
    phy_write( 0, phy_reg0);

    phy_write( 4, 0x0400|phy_reg4);
    }
    /****************************************************************************

  • 名称 : loopback

  • 功能 : 网卡环路测试,设置网卡工作于何种环路测试模式

  • 入口参数 :mode

  • 出口参数 :无
    ****************************************************************************/
    void loopback(int mode)
    {
    switch(mode)
    {
    case LOOP_MAC:
    iow(DM9000_NCR, 0x02);
    phy_write( 0, 0x40);
    break;
    case LOOP_PHY100M:
    iow(DM9000_NCR, 0x04);
    phy_write( 0, 0x40);
    break;
    }
    }

#endif
#endif

unsigned short pack[1024];
unsigned short packLen=0;

void main()
{
int i;

Set_PLL(16,4);	
Init_EBIU();
Init_SDRAM(); 
GetDM9000ID();		
set_PHY_mode(DM9000_100MHD);
eth_reset();
delay(100);   
for(i=0;i<1024;i++)pack[i] = i;
while(1)
{  for(i=0;i<1000000;i++){packLen = 512; 	eth_send(pack,packLen);} 	eth_rx(NetRxPackets);      	    	  	
}

}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.luyixian.cn/news_show_233460.aspx

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Stm32旧版库函数1——adxl335 模拟输出量 usart2

主函数&#xff1a; /******************************************************************************* // // 使用单片机STM32F103C8T6 // 晶振&#xff1a;8.00M // 编译环境 Keil uVision4 // 在3.3V的供电环境下&#xff0c;就能运行 // 波特率 19200 串口2 PA2(Tx) P…

Kotlin 基础学习笔记第八章——高阶函数:Lambda作为形参和返回值

一、声明高阶函数 高阶函数定义&#xff1a;高阶函数就是以另一个函数作为参数或者返回值的函数。 在kotlin中&#xff0c;函数可以用lambda或者函数引用来表示。因此&#xff0c;任何以lambda或者函数引用作为参数的函数&#xff0c;或者返回值为lamda或函数应用的函数&#x…

[附源码]计算机毕业设计健身房预约平台Springboot程序

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

【MySQL基础】数据库操作语言DML相关操作有那些?

目录 一、什么是DML 二、数据插入insert 三、数据的修改update 四、数据的删除delete 五、delete和truncate有什么不同&#xff1f; 六、DML操作知识构图 七、DML操作练习 &#x1f49f; 创作不易&#xff0c;不妨点赞&#x1f49a;评论❤️收藏&#x1f499;一下 一、什…

OPT(奥普特)工控机新品上市,产品矩阵再扩大

近日&#xff0c;OPT&#xff08;奥普特&#xff09;发布工控机新品&#xff0c;进一步扩展产品矩阵&#xff0c;为制造业数字化转型提供更为全面的机器视觉产品和服务。 OPT&#xff08;奥普特&#xff09;上市的工控机共有两大系列&#xff0c;分别是3U桌面式和4U上架式的设…

【代码审计-.NET】基于.NET框架开发的基本特征

目录 一、.NET基本架构 1、基本构成 2、可支持语言 3、封装 4、文件 5、指向解析 6、安全认证 二、工具 1、ILSpyi 2、dnSpy 3、Reflector &#xff08;网上找的一张图谱&#xff09; 本博客只面向讲安全相关内容 一、.NET基本架构 1、基本构成 可支持语言&#xf…

PyTorch中学习率调度器可视化介绍

神经网络有许多影响模型性能的超参数。一个最基本的超参数是学习率(LR)&#xff0c;它决定了在训练步骤之间模型权重的变化程度。在最简单的情况下&#xff0c;LR值是0到1之间的固定值。 选择正确的LR值是具有挑战性。一方面较大的学习率有助于算法快速收敛&#xff0c;但它也…

[论文阅读] 颜色迁移-梯度保护颜色迁移

[论文阅读] 颜色迁移-梯度保护颜色迁移 文章: [Gradient-Preserving Color Transfer], [代码未公开] 本文目的: 如题所示为梯度保护的颜色迁移方法. 1-算法原理 人类的视觉系统对局部强度差异比强度本身更敏感, 因而, 保持颜色梯度是场景保真度的必要条件, 因而作者认为: 一…

如何批量查询谷歌PR权重是多少?谷歌PR权重怎么批量查询

权重是就是网站在搜索引擎心目中的位置&#xff0c;如果一个网站在搜索引擎心目中的位置高的话&#xff0c;当然容易获得较好的排名&#xff0c;今天不是来跟大家聊如何提升网站权重的&#xff0c;而是教大家如何去看一个网站的权重&#xff0c;做网站的朋友都要知道要做关键词…

数据库面试题1-数据库基本概念、常用SQL语言

题1&#xff1a;什么是数据库 数据库&#xff08;Database&#xff09; 是保存有组织的数据的容器&#xff08;通常是一个文件或一组文件&#xff09;&#xff0c;是通过 数据库管理系统&#xff08;DataBase- Management System&#xff0c;DBMS&#xff09; 创建和操纵的容器…

Metal每日分享,波动滤镜/涂鸦滤镜效果

本案例的目的是理解如何用Metal实现图像波动效果滤镜&#xff0c;还可类似涂鸦效果&#xff0c;主要就是对纹理坐标进行正余弦偏移处理&#xff1b; Demo HarbethDemo地址 实操代码 // 波动效果 let filter C7Fluctuate.init(extent: 50, amplitude: 0.003, fluctuate: 2.5…

自动驾驶两大路线对决,渐进式玩家为何更容易得人心?

HiEV消息&#xff08;文/长海&#xff09;对自动驾驶赛道而言&#xff0c;2022年的冬天格外冷冽。寒潮袭来&#xff0c;从各家的应变方式看&#xff0c;不同路径的玩家呈现“冰火两重天”&#xff0c;进化的趋势也越来越清晰。 以Waymo为代表、持续研发L4级无人驾驶的跨越式路线…

Python实现房产数据分析与可视化 数据分析 实战

Python库的选择 话说&#xff0c;工欲善其事&#xff0c;必先利其器&#xff0c;虽然我们已经选择Python来完成剩余的工作&#xff0c;但是我们需要考虑具体选择使用Pytho的哪些利器来帮助我们更快更好地完成剩余的工作。 我们可以看一下&#xff0c;在这个任务中&#xff0c…

UIAutomator测试框架介绍

uiautomator简介 UiAutomator是Google提供的用来做安卓自动化测试的一个Java库&#xff0c;基于Accessibility服务。功能很强&#xff0c;可以对第三方App进行测试&#xff0c;获取屏幕上任意一个APP的任意一个控件属性&#xff0c;并对其进行任意操作&#xff0c;但有两个缺点…

【Docker学习教程系列】8-如何将本地的Docker镜像发布到私服?

通过前面的学习&#xff0c;我们已经知道&#xff0c;怎么将本地自己制作的镜像发布到阿里云远程镜像仓库中去。但是在实际工作开发中&#xff0c;一般&#xff0c;我们都是将公司的镜像发布到公司自己搭建的私服镜像仓库中&#xff0c;那么一个私服的镜像仓库怎么搭建&#xf…

【云原生】Kubernetes(k8s)Istio Gateway 介绍与实战操作

文章目录一、概述二、Istio 架构三、通过 istioctl 部署 Istio1&#xff09;安装istioctl 工具2&#xff09;通过istioctl安装istio3&#xff09;检查四、Istio Gateway五、Istio VirtualService 虚拟服务六、示例演示&#xff08;bookinfo&#xff09;1&#xff09;安装bookin…

笔试强训(四十一)

目录一、选择题二、编程题2.1 Emacs计算器2.1.1 题目2.1.1 题解一、选择题 &#xff08;1&#xff09;某主机的IP地址为180.80.77.55&#xff0c;子网掩码为255.255.252.0.若该主机向其所在子网发送广播分组&#xff0c;则目的地址可以是&#xff08;D&#xff09; A.180.80.7…

制作移动端整页滚动动画

制作移动端整页滚动动画 需要用到 rem7.5.js(rem适配) pageSlider.js(控制动画的js文件) 基于zepto&#xff0c;引入zepto.js文件 animate.css(动画样式) base.css(公共样式) 下面看一下页面结构 <div class"section sec1"style"background-image:url(./ima…

ASP.NET微信快速开发框架源码【源码分享】

ASP.NET微信快速开发框架源码 微信公众平台快速开发框架源码 需要源码学习&#xff0c;查看文末卡片获取&#xff0c;或私信我。 框架主要技术&#xff1a; ASP.NET MVC5、ASP.NET Identity、Bootstrap、KnockoutJs、Entity Framework等。 主要特色&#xff1a; 1、快速迭代开…

​创新不是公司的救命良药

阅读本文大概需要1.06 分钟。之前问说当整个大环境都差的时候&#xff0c;公司还有项目可做就不错了&#xff0c;不要觉得只能赚点小钱就看不上&#xff0c;现在已经从伸手抓钱&#xff0c;变成弯腰捡钱的时代了。 开始赚的钱是不多&#xff0c;但能验证方向&#xff0c;先把跑…