【FreeRTOS(十四)】StreamBuffer

数据流

创建 xStreamBufferCreate

StreamBufferHandle_t xStreamBufferCreate( size_t xBufferSizeBytes,
										  size_t xTriggerLevelBytes );

参数:
	xBufferSizeBytes:buffer的最大容量字节数
	xTriggerLevelBytes:最小有效触发字节,意思是,当buffer至少有大于等于这个值的字节数时,消息才能被接收,该值最小为1,如果设置为0,内部会自动将其设置为1

返回值:
	NULL:创建失败

发送 xStreamBufferSend

size_t xStreamBufferSend( StreamBufferHandle_t xStreamBuffer,
						  const void *pvTxData,
						  size_t xDataLengthBytes,
					   	  TickType_t xTicksToWait );

参数:
	xStreamBuffer:句柄
	pvTxData:待发送消息的指针
	xDataLengthBytes:拷贝到stream buffer的字节数量
	xTicksToWait:stream buffer 满了后发送的等待时间

返回值:
	最终拷贝到stream buffer的字节数量

接受 xStreamBufferReceive

size_t xStreamBufferReceive( StreamBufferHandle_t xStreamBuffer,
						 	 void *pvRxData,
							 size_t xBufferLengthBytes,
							 TickType_t xTicksToWait );

参数:
	xStreamBuffer:句柄
	pvRxData:接收buffer的指针
	xBufferLengthBytes:一次最大的接收长度
	xTicksToWait:等待时间

返回值:
	实际接收到的长度

查询流缓冲区 xStreamBufferSpacesAvailable

查询流缓冲区以查看它包含多少可用空间,这等于在流缓冲区满之前可以发送到流缓冲区的数据量。

size_t xStreamBufferSpacesAvailable(StreamBufferHandle_t xStreamBuffer);

参数:
	xStreamBuffer 正在查询的流缓冲区的句柄。

返回值:
	在流缓冲区满之前可以写入流缓冲区的字节数。

代码示例

#include <stdio.h>
#include <string.h>
#include "sdkconfig.h"
#include "freertos/FreeRTOS.h"
#include "freertos/task.h"
#include "esp_system.h"
#include "esp_spi_flash.h"
#include "freertos/stream_buffer.h"


StreamBufferHandle_t StreamBufferHandle = NULL;

void Task1(void *pvParam)
{
    int i = 0;
    int str_len = 0;
    int send_bytes = 0;
    char tx_buf[50];

    while (1)
    {
        i++;
        str_len = sprintf(tx_buf, "i = %d", i);

        send_bytes = xStreamBufferSend(StreamBufferHandle, (void *)tx_buf, str_len, portMAX_DELAY);

        printf("----------------!\n");
        printf("send: str_len = %d, send_bytes = %d!\n",str_len, send_bytes);

        vTaskDelay(pdMS_TO_TICKS(3000));
    }
}

void Task2(void *pvParam)
{
    char rx_buf[50];
    int rec_bytes = 0;

    while (1)
    {
        memset(rx_buf, 0, sizeof(rx_buf));

        rec_bytes = xStreamBufferReceive(StreamBufferHandle, (void *)rx_buf, sizeof(rx_buf), portMAX_DELAY);

        printf("----------------!\n");
        printf("receive: rec_bytes = %d, data { %s }!\n",rec_bytes, rx_buf);
    }
}

void Task3(void *pvParam)
{
	int buf_space = 0;
	int min_space = 1000;
    while (1)
    {
    	
    	buf_space = xStreamBufferSpacesAvailable(StreamBufferHandle);
    	if(buf_space < min_space)
    	{
    		min_space = buf_space;
    	}

		printf("----------------!\n");
        printf("buf_space = %d, min_space = %d!\n", buf_space, min_space);

		vTaskDelay(pdMS_TO_TICKS(3000));
    }
}

void app_main(void)
{
    StreamBufferHandle = xStreamBufferCreate(1000, 5);

    if (StreamBufferHandle != NULL)
    {
        vTaskSuspendAll();

        xTaskCreate(Task1, "Task1", 1024 * 5, NULL, 1, NULL);
        xTaskCreate(Task2, "Task2", 1024 * 5, NULL, 1, NULL);
        xTaskCreate(Task3, "Task3", 1024 * 5, NULL, 1, NULL);

        xTaskResumeAll();
    }
    else
    {
        printf("Fail to create stream buffer!\n");
    }
}

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
FreeRTOSStreamBuffer是一种用于在任务之间传输数据的机制。通过使用StreamBuffer,任务可以安全地发送和接收数据,而不需要使用信号量或队列。StreamBuffer的功能可以通过在构建中包含FreeRTOS/source/stream_buffer.c源文件来启用\[2\]。 在使用StreamBuffer时,可以使用一些关键函数来创建、发送和接收数据。例如,可以使用xStreamBufferCreate函数来创建一个StreamBuffer,并指定其大小\[1\]。要发送数据到StreamBuffer,可以使用xStreamBufferSend函数。而要从StreamBuffer接收数据,可以使用xStreamBufferReceive函数\[3\]。 在使用xStreamBufferReceive函数时,需要提供一个指向接收数据缓冲区的指针,以及缓冲区的长度。还可以指定一个等待时间,如果在指定的时间内没有可用的数据,则函数将等待直到有数据可用或超时\[3\]。 总之,FreeRTOSStreamBuffer提供了一种方便的方式来在任务之间传输数据。通过使用关键函数,可以创建、发送和接收数据,从而实现任务之间的通信。 #### 引用[.reference_title] - *1* [FreeRTOS学习笔记-Stream Buffer](https://blog.csdn.net/ai_ljh/article/details/126817128)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [FreeRTOSStream Buffers(流缓冲区)](https://blog.csdn.net/shallowing/article/details/117385089)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Eiker_3169

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值