简体   繁体   English

通过FreeRTOS中的队列发送数据

[英]Sending data via a queue in FreeRTOS

I have got two files with code. 我有两个带有代码的文件。

  1. Ethernet 乙太网路
  2. CAN 能够

And between this files I would like sending data. 在这些文件之间,我想发送数据。 So, in the CAN file I created structure: 因此,在CAN文件中,我创建了结构:

struct screenData {
        uint16_t gyroskop_x;
        uint16_t gyroskop_y;
        uint16_t gyroskop_z;
        uint16_t euler_x;
        uint16_t euler_y;
        uint16_t euler_z;
    } data;

And I tried initialise of this structure with my test values. 我尝试使用测试值初始化此结构。

struct screenData * toSend;
    data.gyroskop_x = 1;
    data.gyroskop_y = 2;
    data.gyroskop_z = 3;
    data.euler_x = 4;
    data.euler_y = 5;
    data.euler_z = 6;
    toSend = &data;

And I created new task, whrere I sending data every 1s. 我创建了一个新任务,每1秒发送一次数据。

xQueueSend ( fronta_gyroskop, ( void * ) &toSend , 10 );

In ethernet file I initialise queue. 以太网文件中,我初始化队列。 In ethernet file: 在以太网文件中:

  1. initialise queue 初始化队列
  2. Created receive structure for data 创建数据的接收结构
  3. Receive data from queue 从队列接收数据

Code

xQueueHandle fronta_gyroskop = 0;

extern void init_queue(void)
 {
   fronta_gyroskop = xQueueCreate(6, sizeof(struct ethernetData *));
 }

struct ethernetData {
        uint16_t gyroskop_x;
        uint16_t gyroskop_y;
        uint16_t gyroskop_z;
        uint16_t euler_x;
        uint16_t euler_y;
        uint16_t euler_z;
    } gyro;

And in task I receive data every 1second. 在任务中,我每1秒接收一次数据。

if (xQueueReceive(fronta_gyroskop, &gyro, 20)){ 
}

But the values in gyro aren't my values (1,2,3,4,5,6), but the values are random 32bit values. 但是陀螺仪中的值不是我的值(1、2、3、4、5、6),但是这些值是随机的32位值。 Any idea, what I doing wrong? 任何想法,我做错了什么?

EDIT 编辑

CAN side code CAN边码

#include "Tasky/Ethernet.h"
void *fronta_gyroskop;

can_mb_conf_t tx_mailbox;
can_mb_conf_t rx_mailbox;
/** Receive status */
volatile uint32_t g_ul_recv_status = 0;

void CAN0_Handler(void)
{
    uint32_t ul_status;

    ul_status = can_mailbox_get_status(CAN0, 0);
    if (ul_status & CAN_MSR_MRDY) {
        rx_mailbox.ul_status = ul_status;
        can_mailbox_read(CAN0, &rx_mailbox);
        g_ul_recv_status = 1;
    }
}

struct screenData {
        uint16_t gyroskop_x;
        uint16_t gyroskop_y;
        uint16_t gyroskop_z;
        uint16_t euler_x;
        uint16_t euler_y;
        uint16_t euler_z;
    } data;

extern void task_can_read(void *pvParameters)
{
    UNUSED(pvParameters);
    const portTickType xDelayTime = 10;
    uint8_t nacti = 1;

    /* init test value to sending */
    struct screenData * toSend;
    data.gyroskop_x = 1;
    data.gyroskop_y = 2;
    data.gyroskop_z = 3;
    data.euler_x = 4;
    data.euler_y = 5;
    data.euler_z = 6;
    toSend = &data;

    for (;;){
        if (!g_ul_recv_status) {
            //puts("zadna zprava na CAN sbernici\r");
        } else {
            if ((rx_mailbox.ul_id >> 18) == FIRST_GYRO_ID) //rotation to 11bit number
            {
                //calculate
                nacti = 1;
            }

            if ((rx_mailbox.ul_id >> 18) == SECOND_GYRO_ID)
            {
                //calculate
                xQueueSend ( fronta_gyroskop, ( void * ) &data , 10 );  //send data over queue
                nacti = 0;
            }

            if (nacti == 1)
            {
                rx_mailbox.ul_id = CAN_MID_MIDvA(SECOND_GYRO_ID);
                can_mailbox_init(CAN0, &rx_mailbox);
            }
            if (nacti == 0)
            {
                rx_mailbox.ul_id = CAN_MID_MIDvA(FIRST_GYRO_ID);
                can_mailbox_init(CAN0, &rx_mailbox);
            }

            g_ul_recv_status = 0;   //clear flag
        }

        vTaskDelay(xDelayTime);
    }
}

ETH code ETH代码

#include "Tasky/CAN_TASKs.h"

struct tcp_pcb *output = NULL;
void *dataeth;

struct netif gs_net_if;
uint32_t g_ip_mode;
int8_t g_c_ipconfig[];

struct ethernetData {
        uint16_t gyroskop_x;
        uint16_t gyroskop_y;
        uint16_t gyroskop_z;
        uint16_t euler_x;
        uint16_t euler_y;
        uint16_t euler_z;
    } gyro;


/************************************************************************/
/*                  INIT QUEU to analyze data from TCPIP                */
/************************************************************************/
xQueueHandle fronta_gyroskop = 0;

extern void init_fronta_ethernet(void)
{
    fronta_gyroskop = xQueueCreate(6, sizeof(struct ethernetData *));
}

/************************************************************************/
/*                  TASK of FREERTOS to TCPIP                           */
/************************************************************************/
extern void TCP_connection(void *pvParameters)
{
    UNUSED(pvParameters);

    const portTickType xDelayTime = 1000 / portTICK_RATE_MS;

    uint16_t trest[6];

    while (1){  

        if (xQueueReceive(fronta_gyroskop, &gyro, 10)){ //receive data over queue
            tcp_write(output, (void *)&gyro, sizeof(gyro), TCP_WRITE_FLAG_COPY);    //Write data for sending (but does not send it immediately)
            tcp_sent(output, NULL); //Used to specify the function that should be called when TCP data has been successfully delivered to the remote host
            tcp_output(output); //Find out what we can send and send it.
        }
        vTaskDelay(xDelayTime);
    }
}

The problem is 问题是

xQueueSend ( fronta_gyroskop, ( void * ) &toSend , 10 );

You are sending address of pointer to data. 您正在发送指向数据的指针的地址。

To send data you must send address of data directly: 要发送数据,您必须直接发送数据地址:

xQueueSend ( fronta_gyroskop, ( void * ) &data , 10 );

Ok. 好。 Problem was solved. 问题解决了。

Wrong initialization of queue. 队列初始化错误。

fronta_gyroskop = xQueueCreate(6, sizeof(struct ethernetData *));

Here is good init. 这是一个很好的初始化。

fronta_gyroskop = xQueueCreate(6, sizeof(struct ethernetData));

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM