我想基于lwIP协议中的UDP协议,用单片机做一个服务器,接受电脑的指令然后返回数据。以下是我的代码

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

*函数功能:初始化udp,选定通信端口,建立连接机制

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

void Udp_Api_init(void)

{

  err_t err;

  struct udp_pcb *UDPpcb;

/* create a new UDP PCB structure  */

  UDPpcb = udp_new();

  if (!UDPpcb)

  {  /* Error creating PCB. Out of Memory  */

    return;

  }

/* Bind this PCB to port 99  */

  err = udp_bind(UDPpcb, IP_ADDR_ANY, service_port);

  if (err != ERR_OK)

  {    /* Unable to bind to port  */

    return;

  }

//通知协议栈当99端口有连接请求时调用recv_callback_udp

  udp_recv(UDPpcb, recv_callback_udp, NULL);

}

void recv_callback_udp(void *arg,struct udp_pcb *upcb, struct pbuf *pkt_buf,

                        struct ip_addr *addr,u16_t port)

{

  struct ip_addr dAddr = *addr;

  u8 data[5]={1,2,3,4,5};

  u8 *pValiData;

  

  struct pbuf *p ;

  struct ip_addr ipaddr;

  struct udp_pcb *UDPpcb1;

pValiData=pkt_buf->payload;

if( pkt_buf != NULL )

       {

          if(*pValiData > 0x05)   //接收到的指令码大于5,返回原指令

            udp_sendto( upcb , pkt_buf , &dAddr , port ) ;

  else

  {

          p = pbuf_alloc(PBUF_RAW,sizeof(data),PBUF_RAM);  //根据将要发送的数据大小开辟pbuf

                  p->payload=(void *)data;

  

                  IP4_ADDR(&ipaddr,192,168,1,2); 

                  UDPpcb1 = udp_new(); 

                  udp_bind(UDPpcb1,IP_ADDR_ANY,service_port);  //绑定本地IP 地址     

                  udp_connect(UDPpcb1,&ipaddr,1000); 

                  udp_send(UDPpcb1,p);

      //udp_remove(upcb);

            //udp_sendto( upcb , pkt_buf , &dAddr , port ) ;

   }

     }

     pbuf_free(pkt_buf);

}

实验结果:在发送指令大于5时,单片机返回数据5;但是当指令小于5时,没有返回值,且串口显示“HardFault_Handler”

            这是为什么呢???????????

void UDPceshi_recv(void *arg,struct udp_pcb *upcb, struct pbuf *pkt_buf,

                        struct ip_addr *addr,u16_t port)

  {

  struct ip_addr dAddr = *addr;

//  u8 data[5]={1,2,3,4,5};

 u8 *pValiData;

//  

//  struct pbuf *p ;

  struct ip_addr ipaddr;

  struct udp_pcb *UDPpcb;

pValiData=pkt_buf->payload;

if( pkt_buf != NULL )

       {

        

          //if(*pValiData > 0x05)   //接收到的指令码大于5,返回原指令

   //         udp_sendto( upcb ,pValiData , &ipaddr , 70 ) ;

//  else

//  {

//          p = pbuf_alloc(PBUF_RAW,sizeof(data),PBUF_RAM);  //根据将要发送的数据大小开辟pbuf

                //  p->payload=(void *)data;

  

                 // IP4_ADDR(&ipaddr,192,168,1,125); 

                  UDPpcb= udp_new(); 

                  udp_bind(UDPpcb,IP_ADDR_ANY,60);  //绑定本地IP 地址     

                  udp_connect(UDPpcb,&ipaddr,1000); 

                //  udp_send(UDPpcb1,p);

      //udp_remove(upcb);

            udp_sendto( upcb , pkt_buf , &dAddr , port ) ;

   }

pbuf_free(pkt_buf);

//    else

//    {

//      udp_remove(upcb);

//    }

}

{

 // uint8_t i=0;

  struct ip_addr destAddr = *addr;

  if(p != NULL)                          /* 如果收到的数据不为空   */            

  {

  

    //pbuf_copy_partial(p, UDPData, p->len, 0);       

    udp_sendto(upcb,p,&destAddr,port);                    /* 将收到的数据再发送出去 */           


    pbuf_free(p);                       /* 释放缓冲区数据 */

  }

}

我用PC机周期性地通过UDP给lm3s8962发数据,lm3s8962处理完后,再通过UDP发送给PC机。

无论PC机的周期设为多大,发现lm3s8962只能收到一半pc机发送的数据。

假如我分别创建两个UDP socket,一个用于UDP数据接收,一个用于UDP数据发送。接收和发送都正常。

请问下各位大侠,这是什么原因?先谢过了。

代码如下:

void UDPNetInit(void)

{

     struct ip_addr ipaddr1;

     IP4_ADDR(&ipaddr1,192,168,0,125);

    //

    // Start listening for incoming TFTP requests.

    //

    UDPpcb = udp_new();

    udp_recv(UDPpcb, UDPDataRecv, NULL);

    udp_bind(UDPpcb,IP_ADDR_ANY,UDPPRO_PORT);   /* 绑定本地IP地址 */

    udp_connect(UDPpcb,&ipaddr1,UDPPRO_PORT); /* 连接远程主机 */

}

UDPDataRecv函数用于UDP数据接收,在另外一个地方调用udp_send()作为UDP数据发送。

udp协议的数据接收与发送的代码的更多相关文章

  1. 局域网内通过UDP协议进行传输接受数据——AsyncUdpSocket

    在相同的局域网内,可以通过Udp协议进行数据的传输和接收,Udp协议与Http协议不同,Udp更加方便快捷,省去了很多步骤,但是也有很多传输问题,在局域网内小范围传输数据时Udp还是非常能够胜任的. ...

  2. C#,COM口,接收,发送数据

    这里写一种,COM口的数据接收,发送方法. 1.COMHelper类 /// <summary>初始化串行端口</summary> private SerialPort _se ...

  3. 网络编程——基于TCP协议的Socket编程,基于UDP协议的Socket编程

    Socket编程 目前较为流行的网络编程模型是客户机/服务器通信模式 客户进程向服务器进程发出要求某种服务的请求,服务器进程响应该请求.如图所示,通常,一个服务器进程会同时为多个客户端进程服务,图中服 ...

  4. 网络编程(UDP协议-聊天程序)

    网络编程中的UDP协议中聊天程序,发送端口,和接受端口. 发送端口(Send): <span style="font-size:18px;">package cn.it ...

  5. 基于UDP协议的控制台聊天程序(c++版)

    本博客由Rcchio原创,转载请告知作者 ------------------------------------------------------------------------------- ...

  6. Android为TV端助力 UDP协议

    废话不多说.直接上代码! 一. 接收端 1.创建UDP连接 public void init() { try { //开关的作用 isRunning = true; DatagramSocket mU ...

  7. python六十八课——网络编程之UDP协议

    1.1 概述 UDP是无连接通信协议,即在数据传输时,数据的发送端和接收端不建立逻辑连接.简单来说,当一台计算机向另外一台计算机发送数据时,发送端不会确认接收端是否存在,就会发出数据,同样接收端在收到 ...

  8. 网络编程—网络基础概览、socket,TCP/UDP协议

    网络基础概览 socket概览 socket模块—TCP/UDP的实现 TCP/UDP总结 网络基础概览 osi七层协议各层主要的协议 # 物理层传输电信号1010101010 # 数据链路层,以太网 ...

  9. 网络编程----socket介绍、基于tcp协议的套接字实现、基于udp协议的套接字实现

    一.客户端/服务器架构(C/S架构)                                                即C/S架构,包括: 1.硬件C/S架构(打印机) 2.软件C/S架 ...

随机推荐

  1. #pragma once 与 #ifndef 解析

    转自:http://www.cnblogs.com/hokyhu/archive/2009/03/30/1425604.html 为了避免同一个文件被include多次,C/C++中有两种方式,一种是 ...

  2. Jmeter之http性能测试实战 NON-GUI模式 进行分布式压力测试——干货(十二)

    Apache JMeter Distributed Testing Step-by-step This short tutorial explains how to use multiple syst ...

  3. OpenStreetMap数据清洗(SQL&MonogoDB版本)

    目标:通过网上下载的OpenStreetMap.xml数据格式,将该文件的格式进行统计,清洗,并导出成CSV格式的文件,最后倒入到SQLite中 本案例中所需的包 import csv import ...

  4. 【django之用户认证】

    一.auth模块 模块导入 from django.contrib import auth 主要方法如下: 1 .authenticate()    提供了用户认证,即验证用户名以及密码是否正确,一般 ...

  5. Cypher查询语言--Neo4j之聚合函数(五)

    目录 聚合Aggregation 计数 计算节点数 分组计算关系类型 计算实体数 计算非空可以值数 求和sum 平均值avg 最大值max 最小值min 聚类COLLECT 相异DISTINCT 聚合 ...

  6. rsync源目录写法的一点小细节

    原始状态: [root@localhost tmp]# tree . ├── a │ ├── a1 │ └── a2 └── b directories, files [root@localhost ...

  7. hadoop初学

    Hadoop: 官网(hadoop.apache.org)的定义: 一:Hadoop Common: 为Hadoop其它模块提供通用的支持 二:HDFS: 是Hadoop的分布式文件系统,其特点是高度 ...

  8. BZOJ 2806: [Ctsc2012]Cheat [广义后缀自动机 单调队列优化DP 二分]

    2806: [Ctsc2012]Cheat 题意: 多个主串和多个询问串,每次询问将询问串分成多个连续子串,如果一个子串长度>=L且在主串中出现过就是熟悉的 如果熟悉的字符串长度>=询问串 ...

  9. ASM字节码框架学习之动态代理

    ASM字节码操纵框架,可以直接以二进制的形式来来修改已经存在的类或者创建新的类.ASM封装了操作字节码的大部分细节,并提供了非常方便的接口来对字节码进行操作.ASM框架是全功能的,使用ASM字节码框架 ...

  10. 对.Net Core结合Docker和Jexus的实践

    本文基于上次尝试之后的进一步尝试,加入Docker容器.编写Dockerfile,并且jexus结合Docker的使用,总结下自己的个人感想. 一.环境介绍 当前的场景有两种方式将Demo实现运行,一 ...