OpenEdv-开源电子网

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

STM32 跑RTX 程序运行初始化 os_sem_init() 程序就死机

[复制链接]

2

主题

7

帖子

0

精华

新手上路

积分
39
金钱
39
注册时间
2013-8-30
在线时间
1 小时
发表于 2013-8-30 17:35:21 | 显示全部楼层 |阅读模式

STM32  跑RTX   程序运行初始化 os_sem_init() 程序就死机 

//------------------------------------------------------------- 
//  函数名称 :UARTx_Init
//   功能描述 :初始化uart,设置波特率,校验位,停止位,数据位
//              配置中断,初始化FIFO
//   入口参数1:串口号:uart_base
//   入口参数2:波特率:BaudRate
//   出口参数 :None
//------------------------------------------------------------- 
void UARTx_Init(uint32 uart_base, uint32 baudrate)
{
    unsigned int i;
 _UARTx *UARTx = NULL;

 USART_InitTypeDef USART_InitStructure;
  /* USART1 configured as follow:
        - BaudRate = 115200 baud 
        - Word Length = 8 Bits
        - One Stop Bit
        - No parity
        - Hardware flow control disabled (RTS and CTS signals)
        - Receive and transmit enabled
  */
  USART_InitStructure.USART_BaudRate = baudrate;       //波特率:   115200
  USART_InitStructure.USART_WordLength = USART_WordLength_8b;   //数据数:   8
  USART_InitStructure.USART_StopBits = USART_StopBits_1;     //停止位:  1
  USART_InitStructure.USART_Parity = USART_Parity_No ;      //校以验位: 无
  USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;  //无流控制
  USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;   //Open RX接收和TX发送功能

#ifdef __UART0
 if(uart_base == USART1_BASE)//com0
 {
  UARTx = &UART_0;
        UARTx -> RxBuf = Rx0Buf;
        for(i = 0 ; i < UART0_RxFifo ; i++)
        {
            UARTx -> RxBuf = UART0_END_FLAG;
        }                      
  UART1_GPIO_Configuration();
 
 }
#endif

#ifdef __UART1
 else if(uart_base==USART2_BASE)//com1
 {
  UARTx = &UART_1;
        UARTx -> RxBuf = Rx1Buf;
        for(i = 0; i < UART1_RxFifo; i++)
        {
            UARTx -> RxBuf = UART1_END_FLAG;
        }
  UART2_GPIO_Configuration();
 
 }
#endif

#ifdef __UART2
 else if(uart_base==USART3_BASE)//com2
 {
  UARTx = &UART_2;
        UARTx -> RxBuf = Rx2Buf;
        for(i = 0 ; i < UART2_RxFifo ; i++)
        {
            UARTx -> RxBuf = UART2_END_FLAG;
        }
  UART3_GPIO_Configuration();
 
 }
#endif
 if(UARTx == NULL)
  return;
 /*
 UARTConfigSetExpClk(uart_base, SysCtlClockGet(), baudrate, UART_CONFIG_WLEN_8 | UART_CONFIG_STOP_ONE | UART_CONFIG_PAR_NONE);
//===============串口接收、发送中断设置================================================================== 
 UARTIntEnable(uart_base, UART_INT_RX | UART_INT_RT | UART_INT_TX);

 UARTFIFOLevelSet(uart_base, UART_FIFO_TX1_8, UART_FIFO_RX7_8);//sets fifo level at which transmit and receive interrupts will be generated.
 */
#ifdef __UART0
 if(uart_base == USART1_BASE)//com0
 {
  /* Configure the USART1*/
    USART_Init(USART1, &USART_InitStructure);

    /* Enable USART1 Receive and Transmit interrupts */
    USART_ITConfig(USART1, USART_IT_RXNE, ENABLE); //接收中断模式允许
 
    /* Enable the USART1 */
    USART_Cmd(USART1, ENABLE);   //启动串口1
 }
#endif

#ifdef __UART1
 else if(uart_base==USART2_BASE)//com1
 {
     /* Configure the USART2*/
    USART_Init(USART2, &USART_InitStructure);

    /* Enable USART2 Receive and Transmit interrupts */
    USART_ITConfig(USART2, USART_IT_RXNE, ENABLE); //接收中断模式允许
 
    /* Enable the USART2 */
    USART_Cmd(USART2, ENABLE);   //启动串口2
 }
#endif

#ifdef __UART2
 else if(uart_base==USART3_BASE)//com2
 {
   /* Configure the USART3*/
    USART_Init(USART3, &USART_InitStructure);

    /* Enable USART3 Receive and Transmit interrupts */
    USART_ITConfig(USART3, USART_IT_RXNE, ENABLE); //接收中断模式允许
 
    /* Enable the USART3 */
    USART_Cmd(USART3, ENABLE);   //启动串口2
    }
#endif

    UARTx -> TxPointer = NULL;                 //初始化串口缓冲区
    UARTx -> TxNum     = 0;
    UARTx -> TxEmpty   = TRUE;
    os_sem_init(UARTx -> TxSem , 1);
    os_sem_init(UARTx -> RxSem , 1);
    UARTx -> RxNum       = 0;
    UARTx -> RxMax       = 0;
    UARTx -> RxOverRun   = FALSE;
    UARTx -> RxReadShift = 0;
    UARTx -> RxWriteShift = 0;
// IntEnable(UartInt);
// UARTEnable(uart_base);//enables transmitting and receiving and enables transmit and receive FIFOs
}

程序跑到
    os_sem_init(UARTx -> TxSem , 1);
    os_sem_init(UARTx -> RxSem , 1);   就不动  死机
STM32  跑RTX系统  高手帮忙解决下这个问题。


正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2013-8-30 18:08:34 | 显示全部楼层
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

2

主题

1446

帖子

1

精华

金牌会员

Rank: 6Rank: 6

积分
2256
金钱
2256
注册时间
2010-12-16
在线时间
206 小时
发表于 2013-8-30 20:00:39 | 显示全部楼层
OS_SEM semaphore1;

__task void task1 (void) {
   ..
  os_sem_init (&semaphore1, 0);
  os_sem_send (&semaphore1);
   ..
}

这是RTX的例子,LZ的代码看不到哪里声明了SEM.

如果结构体里声明的是指针,但又没有申请对应的空间,那就会将NULL或者不确定的地址放进os_sem_init,错误是正常的.

如果结构体里声明的是变量,那应该调用如下代码.

os_sem_init(&(UARTx -> TxSem) , 1);
技术讨论请发帖 , 需要我回复请点左下的 < 回复 > 让系统通知我 . 本人不通过其他方式返回任何参数.
回复 支持 反对

使用道具 举报

2

主题

7

帖子

0

精华

新手上路

积分
39
金钱
39
注册时间
2013-8-30
在线时间
1 小时
 楼主| 发表于 2013-8-31 11:54:38 | 显示全部楼层
回复【3楼】shihantu:
---------------------------------
//变量声明 
    struct _UARTX
    {
        unsigned char* TxPointer;                 //串口发送缓冲区指针
        unsigned int TxNum;                       //待发送数据的长度
        unsigned char TxEmpty;                    //发送缓冲区空标志
        OS_SEM         TxSem;
        OS_SEM         RxSem;
        unsigned int RxNum;                       //串口接收缓冲区中的数据长度。
        unsigned int RxMax;                       //待接收的数据长度
        unsigned char RxOverRun;                  //接收缓冲区溢出标志.
        unsigned short RxReadShift;               //串口接收缓冲区读出偏移量
        unsigned short RxWriteShift;              //串口接收缓冲区写入偏移量
        unsigned char* RxBuf;                     //串口接收到数据的缓冲区指针。
    }; 
    typedef struct _UARTX _UARTx;


这个是变量申明   


os_sem_init(&(UARTx -> TxSem) , 1);   修改了下好像也是一样啊
回复 支持 反对

使用道具 举报

2

主题

1446

帖子

1

精华

金牌会员

Rank: 6Rank: 6

积分
2256
金钱
2256
注册时间
2010-12-16
在线时间
206 小时
发表于 2013-8-31 15:10:10 | 显示全部楼层
这个UART_0是哪里来的?
技术讨论请发帖 , 需要我回复请点左下的 < 回复 > 让系统通知我 . 本人不通过其他方式返回任何参数.
回复 支持 反对

使用道具 举报

2

主题

7

帖子

0

精华

新手上路

积分
39
金钱
39
注册时间
2013-8-30
在线时间
1 小时
 楼主| 发表于 2013-9-2 08:42:18 | 显示全部楼层
#ifdef __UART0
        EXT_USERUART _UARTx UART_0;
        EXT_USERUART OS_TID tid_uart0_rx;                  //定义任务ID
        EXT_USERUART unsigned char Rx0Buf[UART0_RxFifo];   //存储串口接收到数据的缓冲区。
#endif 

有定义 的   是变量申明 那边定义
回复 支持 反对

使用道具 举报

2

主题

1446

帖子

1

精华

金牌会员

Rank: 6Rank: 6

积分
2256
金钱
2256
注册时间
2010-12-16
在线时间
206 小时
发表于 2013-9-2 15:53:49 | 显示全部楼层
好像永远问不到底的节奏...

这样吧,os_sem_init传入的第一个参数是指向(声明为OS_SEM的内存的地址)的指针,好好检查吧.
技术讨论请发帖 , 需要我回复请点左下的 < 回复 > 让系统通知我 . 本人不通过其他方式返回任何参数.
回复 支持 反对

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-7-13 22:17

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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