OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 4624|回复: 6

LWIP移植一直死在startup_stm32f10x_hd.s里面324行,具体见正文,谢谢。

[复制链接]

8

主题

37

帖子

0

精华

初级会员

Rank: 2

积分
160
金钱
160
注册时间
2014-9-7
在线时间
18 小时
发表于 2015-11-5 10:09:35 | 显示全部楼层 |阅读模式
5金钱
在原子哥的基础上将lwip裸移植到mini板上,仿真发现一直死在了下面这里:


网上搜索有人说是中断部分的问题,但是看了下,感觉没问题啊?
u8 ENC28J60_Init(void)
{
u8 version;
u16 retry=0;
u32 temp;

GPIO_InitTypeDef GPIO_InitStructure;
SPI_InitTypeDef  SPI_InitStructure;
EXTI_InitTypeDef EXTI_InitStructure;
NVIC_InitTypeDef NVIC_InitStructure;

RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA|RCC_APB2Periph_GPIOB | RCC_APB2Periph_GPIOC |RCC_APB2Periph_AFIO, ENABLE); 
   
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10; 
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPU ; 
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_Init(GPIOA, &GPIO_InitStructure);
  GPIO_SetBits(GPIOA,GPIO_Pin_10); 
 

GPIO_InitStructure.GPIO_Pin  = GPIO_Pin_12;   
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP; 
GPIO_Init(GPIOB, &GPIO_InitStructure);

GPIO_InitStructure.GPIO_Pin = GPIO_Pin_8; 
  GPIO_Init(GPIOC, &GPIO_InitStructure);
GPIO_SetBits(GPIOC,GPIO_Pin_8); 

GPIO_EXTILineConfig(GPIO_PortSourceGPIOA,GPIO_PinSource10);

EXTI_InitStructure.EXTI_Line = EXTI_Line10;
EXTI_InitStructure.EXTI_Mode = EXTI_Mode_Interrupt;
EXTI_InitStructure.EXTI_Trigger = EXTI_Trigger_Falling;
EXTI_InitStructure.EXTI_LineCmd = ENABLE;
EXTI_Init(&EXTI_InitStructure);

EXTI_ClearITPendingBit(EXTI_Line10); 

NVIC_InitStructure.NVIC_IRQChannel = EXTI15_10_IRQn;
NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 1; 
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0; 
NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
NVIC_Init(&NVIC_InitStructure);
 
SPI1_Init();     
SPI_Cmd(SPI2, DISABLE); 

SPI_InitStructure.SPI_Direction = SPI_Direction_2Lines_FullDuplex; 
SPI_InitStructure.SPI_Mode = SPI_Mode_Master; 
SPI_InitStructure.SPI_DataSize = SPI_DataSize_8b;
SPI_InitStructure.SPI_CPOL = SPI_CPOL_Low; 
SPI_InitStructure.SPI_CPHA = SPI_CPHA_1Edge;
SPI_InitStructure.SPI_NSS = SPI_NSS_Soft; 
SPI_InitStructure.SPI_BaudRatePrescaler = SPI_BaudRatePrescaler_256;
SPI_InitStructure.SPI_FirstBit = SPI_FirstBit_MSB; 
SPI_InitStructure.SPI_CRCPolynomial = 7; 
SPI_Init(SPI2, &SPI_InitStructure);   
SPI_Cmd(SPI2, ENABLE); 
串口中断:
  NVIC_InitStructure.NVIC_IRQChannel = USART2_IRQn;
NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority=3 ;
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 3; 
NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
NVIC_Init(&NVIC_InitStructure); 



最佳答案

查看完整内容[请看2#楼]

找到问题了,在初始化的时候将中断线由NVIC_InitStructure.NVIC_IRQChannel = EXTI1_IRQn;改为NVIC_InitStructure.NVIC_IRQChannel = EXTI15_10_IRQn;,但是在后面的中断服务函数那边没有改,导致了程序进入中断但是没有处理函数,从而挂在了startup里面的324行。谢谢各位。
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

8

主题

37

帖子

0

精华

初级会员

Rank: 2

积分
160
金钱
160
注册时间
2014-9-7
在线时间
18 小时
 楼主| 发表于 2015-11-5 10:09:36 | 显示全部楼层
找到问题了,在初始化的时候将中断线由NVIC_InitStructure.NVIC_IRQChannel = EXTI1_IRQn;改为NVIC_InitStructure.NVIC_IRQChannel = EXTI15_10_IRQn;,但是在后面的中断服务函数那边没有改,导致了程序进入中断但是没有处理函数,从而挂在了startup里面的324行。谢谢各位。
回复

使用道具 举报

8

主题

37

帖子

0

精华

初级会员

Rank: 2

积分
160
金钱
160
注册时间
2014-9-7
在线时间
18 小时
 楼主| 发表于 2015-11-5 10:11:57 | 显示全部楼层
void sys_timeouts_init(void)
{
#if IP_REASSEMBLY
  sys_timeout(IP_TMR_INTERVAL, ip_reass_timer, NULL);
#endif /* IP_REASSEMBLY */
#if LWIP_ARP
  sys_timeout(ARP_TMR_INTERVAL, arp_timer, NULL);
#endif /* LWIP_ARP */
#if LWIP_DHCP
  sys_timeout(DHCP_COARSE_TIMER_MSECS, dhcp_timer_coarse, NULL);
  sys_timeout(DHCP_FINE_TIMER_MSECS, dhcp_timer_fine, NULL);
#endif /* LWIP_DHCP */
#if LWIP_AUTOIP
  sys_timeout(AUTOIP_TMR_INTERVAL, autoip_timer, NULL);
#endif /* LWIP_AUTOIP */
#if LWIP_IGMP
  sys_timeout(IGMP_TMR_INTERVAL, igmp_timer, NULL);
#endif /* LWIP_IGMP */
#if LWIP_DNS
  sys_timeout(DNS_TMR_INTERVAL, dns_timer, NULL);
#endif /* LWIP_DNS */

#if NO_SYS
  /* Initialise timestamp for sys_check_timeouts */
  timeouts_last_time = sys_now();
#endif
}

是在这个函数里面跑挂的。
回复

使用道具 举报

88

主题

7377

帖子

5

精华

资深版主

Rank: 8Rank: 8

积分
14980
金钱
14980
注册时间
2013-11-13
在线时间
1823 小时
发表于 2015-11-5 10:13:54 | 显示全部楼层
这个问题你只能自己硬件仿真检查了,看看具体是在哪个函数里面死掉的
开往春天的手扶拖拉机
回复

使用道具 举报

11

主题

1041

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
3696
金钱
3696
注册时间
2011-5-23
在线时间
2008 小时
发表于 2015-11-5 10:20:10 | 显示全部楼层
看IPSR就知道哪个ISR末实现
RT-Thread RTOS 音频,WIFI,蓝牙
回复

使用道具 举报

8

主题

37

帖子

0

精华

初级会员

Rank: 2

积分
160
金钱
160
注册时间
2014-9-7
在线时间
18 小时
 楼主| 发表于 2015-11-5 10:26:43 | 显示全部楼层
回复【3楼】zuozhongkai:
---------------------------------
netif_set_default(struct netif *netif)
{
  if (netif == NULL) {
    /* remove default route */
    snmp_delete_iprteidx_tree(1, netif);
  } else {
    /* install default route */
    snmp_insert_iprteidx_tree(1, netif);
  }
  netif_default = netif;
  LWIP_DEBUGF(NETIF_DEBUG, ("netif: setting default interface %c%c\n",
           netif ? netif->name[0]: '\'', netif ? netif->name[1]: '\''));
}
在这个函数里面挂掉呢?
回复

使用道具 举报

8

主题

37

帖子

0

精华

初级会员

Rank: 2

积分
160
金钱
160
注册时间
2014-9-7
在线时间
18 小时
 楼主| 发表于 2015-11-5 10:31:04 | 显示全部楼层
回复【4楼】aozima:
---------------------------------
netif_set_default  查出来 是在这个函数里面挂的,是啥问题?
回复

使用道具 举报

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

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2024-11-24 19:13

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表