3636|2

1

帖子

0

TA的资源

一粒金砂(初级)

楼主
 

LM3S9B90 UDP通信为什么总是进入死循环呢,是按照历程上面来改的。麻烦大师指导指... [复制链接]

#include "inc/hw_ints.h"
#include "inc/hw_memmap.h"
#include "inc/hw_nvic.h"
#include "inc/hw_types.h"
#include "driverlib/ethernet.h"
#include "driverlib/flash.h"
#include "driverlib/gpio.h"
#include "driverlib/interrupt.h"
#include "driverlib/rom.h"
#include "driverlib/sysctl.h"
#include "driverlib/systick.h"
#include "utils/locator.h"
#include "utils/lwiplib.h"
#include "driverlib/timer.h"
#include "utils/uartstdio.h"
#include "httpserver_raw/httpd.h"
//#include "DAQwendu.h"
//#include "driverlib/watchdog.h"
//#include "get_temperature.h"


#define SYSTICKHZ               100
#define SYSTICKMS               (1000 / SYSTICKHZ)
/********************************************************************************************************/
//定义网络通信的IP地址、网关、子网掩码
#define My_Mac_ID         {0X00,0x1A,0xFF,0x00,0x05,0xA7}  //存储以太网控制器的物理地址,即MAC地址
#define IP_MARK_ID         {255,255,255,0}                          //255.255.255.0,子网掩码
#define MY_IP_ID               {192,168,1,10}                   //以太网通信的IP地址
#define MY_GATEWAY_ID   {192,168,1,1}                  //以太网通信的网关地址

unsigned int pack;
static const unsigned char MACAddress[] = My_Mac_ID;
unsigned char IPAddress[] = MY_IP_ID;
unsigned char NetMaskAddr[] = IP_MARK_ID;
unsigned char GwWayAddr[] = MY_GATEWAY_ID;

typedef unsigned char   uint8;     //数据类型重定义—ZZH
typedef signed char     int8;     //数据类型重定义—ZZH

const static int8 UDPData[]="LwIP UDP客户端在Luminary微控制器上的测试\r\n";

//*****************************************************************************
// The error routine that is called if the driver library encounters an error.
//*****************************************************************************
#ifdef DEBUG
void
__error__(char *pcFilename, unsigned long ulLine)
{
}
#endif

//*****************************************************************************
//
// Required by lwIP library to support any host-related timer functions.
//
//*****************************************************************************
void
lwIPHostTimerHandler(void)
{
    UARTprintf("FA SONG CHENG GONG!!!!!!!!!!!!!!!!!!! \n");
}

//*****************************************************************************
//
// The interrupt handler for the SysTick interrupt.
//
//*****************************************************************************
void
SysTickIntHandler(void)
{
    //
    // Call the lwIP timer handler.
    //
    lwIPTimer(SYSTICKMS);
}




/******* 这是一个回调函数,当有UDP数据收到时会被调用UDP_Receive********/
void UDP_Receive(void *arg, struct udp_pcb *upcb, struct pbuf *p_rx,
                 struct ip_addr *addr, u16_t port)
{

  //struct ip_addr destAddr = *addr;    /*  获取远程主机 IP 地址          */
  UARTprintf("FA SONG CHENG GONG!!!!!!!!!!!!!!!!!!! \n");
  pbuf_free(p_rx);                      // 释放缓冲区数据

// if(p!= NULL)               //如果收到的数据不为空              
  //{
   // UARTprintf("FA SONG CHENG GONG!!!!!!!!!!!!!!!!!!! \n");
    //udp_sendto(upcb,p,&destAddr,port);  //将收到的数据再发送出去         
   // pbuf_free(p);                      // 释放缓冲区数据
  //}
}
void  Delay(unsigned long  ulVal)//延时函数
{
    while ( --ulVal  !=  0 );
}


//*****************************************************************************
//
// This example demonstrates the use of the Ethernet Controller.
//
//*****************************************************************************
int
main(void)
{
     //int i;  

    struct ip_addr xIpAddr, xNetMask, xGateway;

    //
    // Set the clocking to run directly from the crystal.
    //
    ROM_SysCtlClockSet(SYSCTL_SYSDIV_2_5 | SYSCTL_USE_PLL | SYSCTL_OSC_MAIN |
                       SYSCTL_XTAL_16MHZ);

    //
    // Initialize the UART.
    //
    ROM_SysCtlPeripheralEnable(SYSCTL_PERIPH_GPIOA);                          
    ROM_GPIOPinTypeUART(GPIO_PORTA_BASE, GPIO_PIN_0 | GPIO_PIN_1);
    UARTStdioInit(0);

    ROM_SysCtlPeripheralEnable(SYSCTL_PERIPH_ETH);//初始化以太网时钟
    ROM_SysCtlPeripheralReset(SYSCTL_PERIPH_ETH);

    //
    // Enable Port F for Ethernet LEDs.
    //
    ROM_SysCtlPeripheralEnable(SYSCTL_PERIPH_GPIOF);
    GPIOPinConfigure(GPIO_PF2_LED1);
    GPIOPinConfigure(GPIO_PF3_LED0);
    ROM_GPIODirModeSet(GPIO_PORTF_BASE, GPIO_PIN_2 | GPIO_PIN_3,GPIO_DIR_MODE_HW); //这两条也是趟师兄调剂的,不象??——ZZH                     
    ROM_GPIOPadConfigSet(GPIO_PORTF_BASE, GPIO_PIN_2 | GPIO_PIN_3,
                         GPIO_STRENGTH_2MA, GPIO_PIN_TYPE_STD);

    ROM_IntMasterEnable();     /* 使能总的中断*/
    UARTprintf("\r通道1数据为:\n");         

    IP4_ADDR(&xIpAddr,IPAddress[0],IPAddress[1],IPAddress[2],IPAddress[3]);
    IP4_ADDR(&xNetMask,NetMaskAddr[0],NetMaskAddr[1],NetMaskAddr[2],NetMaskAddr[3]);
    IP4_ADDR(&xGateway,GwWayAddr[0],GwWayAddr[1],GwWayAddr[2],GwWayAddr[3]);
    UARTprintf("\r进入lwip:\n");     

    lwIPInit(MACAddress,xIpAddr, xNetMask,xGateway,IPADDR_USE_STATIC); /* 初始化协议栈*/

    struct udp_pcb *UdpPcb;
    //struct ip_addr ipaddr;
    struct pbuf *p_tx;


    p_tx = pbuf_alloc(PBUF_RAW,sizeof(UDPData),PBUF_RAM);
     UARTprintf("\r进入 p = pbuf_alloc:\n");

    p_tx->payload=(void *)UDPData;

    //IP4_ADDR(&ipaddr,192,168,1,16);  //远程Ip地址   
    UdpPcb = udp_new();
    udp_bind(UdpPcb,&xIpAddr,1025);//为指定的连接绑定本地IP 地址和端口号IP_ADDR_ANY

    udp_connect(UdpPcb,IP_ADDR_ANY,1025);    //ipaddr为远程ip,1666为远程端口&ipaddr1   
    udp_recv(UdpPcb,UDP_Receive,NULL);                   /*  设置数据接收时的回调函数       */

     Delay(1000000UL);

     Delay(1000000UL);
     IntMasterEnable();     /* 使能总的中断*/

      while(1)  
    {  


               //udp_send(UdpPcb,p_tx);
              // Delay(1000000UL);
              // Delay(1000000UL);
               //Delay(1000000UL);



     }
}               

  总是运行到 p_tx = pbuf_alloc(PBUF_RAW,sizeof(UDPData),PBUF_RAM); 这一句就进入了死循环,麻烦各位看看,指点指点啊。。谢谢

最新回复

没有加中断向量表。   详情 回复 发表于 2015-2-12 13:57

点评

编译没有报错的话, 实际上并不是死循环,应该是产生了 fault,将堆栈设置改一下试试看。  详情 回复 发表于 2013-4-11 11:17
 
点赞 关注(1)

回复
举报

1803

帖子

0

TA的资源

五彩晶圆(高级)

沙发
 

回复 楼主 涉水红尘 的帖子

编译没有报错的话,
实际上并不是死循环,应该是产生了 fault,将堆栈设置改一下试试看。
 
 

回复

29

帖子

0

TA的资源

一粒金砂(中级)

板凳
 
没有加中断向量表。
 
 
 

回复
您需要登录后才可以回帖 登录 | 注册

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/10 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表