在GD32F4xx上移植FreeRTOS+LWIP

本文介绍了如何在GD32F4xx开发板上移植FreeRTOS操作系统,并提供了LWIP网络库的集成示例,包括初始化、TCPEchoServer的实现,以及如何将这些代码融入到GD32F4xxDemoSuites项目中。
摘要由CSDN通过智能技术生成

参考源码

1,最小系统工程;

2,FreeRTOS官方代码包:

FreeRTOSv202210.01-LTS.zip

还有,官方支持包:FreeRTOSv202212.01.zip

FreeRTOSv202212.01.zip\FreeRTOSv202212.01\FreeRTOS\Demo\CORTEX_M4F_STM32F407ZG-SK

3,LWIP官方代码包:

lwip-2.1.3.zip

官方支持包:contrib-2.1.0.zip

4,GD官方例程:

GD32F4xx_Demo_Suites_V2.6.2.rar

参考工程:GD32F4xx_Demo_Suites_V2.6.2\GD32470Z_EVAL_Demo_Suites\Projects\26_ENET\Projects\FreeRTOS_tcpudp\src

移植FreeRTOS操作系统

核心代码

从GD32F4xx_Demo_Suites_V2.6.2.rar\GD32F4xx_Demo_Suites_V2.6.2\GD32470Z_EVAL_Demo_Suites\Projects\26_ENET\Projects\FreeRTOS_tcpudp\inc 拷贝FreeRTOSConfig.h文件。

跑个简单的程序:

int main(void)
{
    /* configure 4 bits pre-emption priority */
    nvic_priority_group_set(NVIC_PRIGROUP_PRE4_SUB0);

    /* start toogle LED task every 250ms */
    xTaskCreate(led_task, "LED", configMINIMAL_STACK_SIZE, NULL, LED_TASK_PRIO, NULL);

    /* start scheduler */
    vTaskStartScheduler();

    while(1){
    }
}

void led_task(void * pvParameters)
{  
    for( ;; ){
        /* toggle LED3 each 250ms */
        gd_eval_led_toggle(LED3);
        vTaskDelay(250);
    }
}

将代码添加到工程中,并配置文件包含路径,可以正常闪灯。

移植LWIP

核心代码

初始化过程及驱动

参见上一篇LWIP移植过程文档。

移植TcpEchoServer

核心代码

参考:LWIP例程:

\contrib-2.1.0\apps\tcpecho

#include "tcpecho.h"

#include "lwip/opt.h"

#if LWIP_NETCONN

#include "lwip/sys.h"
#include "lwip/api.h"
/*-----------------------------------------------------------------------------------*/
static void tcpecho_thread(void *arg)
{
  struct netconn *conn, *newconn;
  err_t err;
  LWIP_UNUSED_ARG(arg);

  /* Create a new connection identifier. */
  /* Bind connection to well known port number 7. */
  conn = netconn_new(NETCONN_TCP);
  netconn_bind(conn, IP_ADDR_ANY, 7);

  LWIP_ERROR("tcpecho: invalid conn", (conn != NULL), return;);

  /* Tell connection to go into listening mode. */
  netconn_listen(conn);

  while (1) {

    /* Grab new connection. */
    err = netconn_accept(conn, &newconn);
    /*printf("accepted new connection %p\n", newconn);*/
    /* Process the new connection. */
    if (err == ERR_OK) {
      struct netbuf *buf;
      void *data;
      u16_t len;
      
      while ((err = netconn_recv(newconn, &buf)) == ERR_OK) {
        /*printf("Recved\n");*/
        do {
             netbuf_data(buf, &data, &len);
             err = netconn_write(newconn, data, len, NETCONN_COPY);
        } while (netbuf_next(buf) >= 0);
        netbuf_delete(buf);
      }
      /*printf("Got EOF, looping\n");*/ 
      /* Close connection and discard connection identifier. */
      netconn_close(newconn);
      netconn_delete(newconn);
    }
  }
}
/*-----------------------------------------------------------------------------------*/
void tcpecho_init(void)
{
  sys_thread_new("tcpecho_thread", tcpecho_thread, NULL, DEFAULT_THREAD_STACKSIZE, DEFAULT_THREAD_PRIO);
}

或者ST例程:

STSW_STM32070_V1.1.1.zip\STM32F4x7_ETH_LwIP_V1.1.1\Project\FreeRTOS\udptcp_echo_server_netconn\src\tcpecho.c


#include "lwip/opt.h"

#if LWIP_NETCONN

#include "lwip/sys.h"
#include "lwip/api.h"

#define TCPECHO_THREAD_PRIO  ( tskIDLE_PRIORITY + 5 )



/*-----------------------------------------------------------------------------------*/
static void tcpecho_thread(void *arg)
{
  struct netconn *conn, *newconn;
  err_t err, accept_err;
  struct netbuf *buf;
  void *data;
  u16_t len;
  err_t recv_err;
      
  LWIP_UNUSED_ARG(arg);

  /* Create a new connection identifier. */
  conn = netconn_new(NETCONN_TCP);
  
  if (conn!=NULL)
  {  
    /* Bind connection to well known port number 7. */
    err = netconn_bind(conn, NULL, 7);
    
    if (err == ERR_OK)
    {
      /* Tell connection to go into listening mode. */
      netconn_listen(conn);
    
      while (1) 
      {
        /* Grab new connection. */
         accept_err = netconn_accept(conn, &newconn);
    
        /* Process the new connection. */
        if (accept_err == ERR_OK) 
        {
          recv_err = netconn_recv(newconn, &buf);
					while ( recv_err == ERR_OK) 
          {
            do 
            {
              netbuf_data(buf, &data, &len);
              netconn_write(newconn, data, len, NETCONN_COPY);
          
            } 
            while (netbuf_next(buf) >= 0);
          
            netbuf_delete(buf);
						recv_err = netconn_recv(newconn, &buf);
          }
        
          /* Close connection and discard connection identifier. */
          netconn_close(newconn);
          netconn_delete(newconn);
        }
      }
    }
    else
    {
      netconn_delete(newconn);
      printf(" can not bind TCP netconn");
    }
  }
  else
  {
    printf("can not create TCP netconn");
  }
}
/*-----------------------------------------------------------------------------------*/

void tcpecho_init(void)
{
  sys_thread_new("tcpecho_thread", tcpecho_thread, NULL, DEFAULT_THREAD_STACKSIZE, TCPECHO_THREAD_PRIO);
}
/*-----------------------------------------------------------------------------------*/

### 回答1: GD32F4xx是一款基于ARM Cortex-M4内核的微控制器,而FreeRTOS是一款适用于微处理器的实时操作系统。GD32F4xx移植FreeRTOS需要以下步骤: 第一步,选择合适的FreeRTOS版本。需要选择与GD32F4xx芯片相兼容的版本。 第二步,将FreeRTOS的源代码移植GD32F4xx芯片上。这包括将源代码编译为GD32F4xx所支持的格式,并将内存分配到合适的RAM和ROM。 第三步,对FreeRTOS进行配置。可以根据系统需要配置不同的内存分配方式、任务堆栈大小、时间片、任务优先级等参数。 第四步,编写系统初始化代码。在初始化代码中,需要对系统时钟、外设、GPIO等进行初始化,以便正常运行FreeRTOS系统。 第五步,编写任务。在任务中,需要定义任务的执行程序、任务优先级、任务堆栈大小等。同时,可以使用FreeRTOS提供的其他功能,如数据队列、信号量等实现任务与任务之间的通信。 最后要进行的是验证阶段。为了验证系统能够正常运行,需要进行测试和调试。此时,可以使用FreeRTOS提供的调试工具进行调试。 在将FreeRTOS移植GD32F4xx芯片中后,系统可以获得更好的性能和可靠性,提高系统的实时性和可拓展性。移植FreeRTOSGD32F4xx芯片中需要一定的技能水平和经验,但如果正确地进行了操作,将会使系统更加健壮和稳定。 ### 回答2: 首先需要了解GD32F4xx的硬件架构和FreeRTOS的基本概念。GD32F4xx是一种基于ARM Cortex-M4内核的微控制器,具有丰富的外设和功能。FreeRTOS是一个开源的实时操作系统,可以运行在不同的芯片架构上。 移植FreeRTOSGD32F4xx上,需要完成以下步骤: 1. 选择适当的FreeRTOS版本,下载相关的源代码和文档。 2. 配置环境,安装相关软件。需要安装ARM GCC编译器和调试工具,例如OpenOCD。 3. 编译FreeRTOS源代码,生成适用于GD32F4xx的可执行文件。 4. 在GD32F4xx上搭建FreeRTOS环境。在GD32F4xx的开发板上,连接相应的调试接口,并将编译好的可执行文件烧录到芯片中。 5. 编写应用程序代码,并集成到FreeRTOS中。在GD32F4xx上运行FreeRTOS应用程序,包括启动FreeRTOS内核、创建任务、控制任务挂起和挂起等。 6. 调试和测试。通过调试工具,对应用程序进行调试和性能测试,确保FreeRTOSGD32F4xx上正常运行。 需要注意的是,在移植过程中还需要根据GD32F4xx的具体硬件架构和外设进行适当的设置和配置,以确保FreeRTOS可以正确地访问这些硬件和外设。这需要进行一定的代码修改和调试工作。同时,还需要对内存和中断管理进行详细的分析和调试,以保证系统的实时性和稳定性。 总之,移植FreeRTOSGD32F4xx上是一个复杂而繁琐的过程,需要仔细分析和调试。但一旦成功移植,就可以为GD32F4xx提供一个高效、可靠且易于开发的实时操作系统,为各种应用提供更高效的支持。 ### 回答3: 对于想要将freertos移植gd32f4xx上的开发者,需要注意如下几点: 1. 首先要确定gd32f4xx的硬件平台,并且要了解它的处理器架构和外设接口。这包括处理器的位数、SRAM和Flash存储器、时钟、中断控制器以及外设接口,如串口、SPI,I2C等。 2. 在freertos移植过程中,需要进行一些必要的修改,以适配到gd32f4xx的硬件平台。具体来说,需要修改端口文件的寄存器定义、中断处理函数、时钟初始化和任务切换等方面。 3. 在移植过程中还需要完成调度器、任务、任务通信等功能的移植。需要按照要求进行修改和编写,以确保能够运行。 4. 对于初学者来说,移植freertos是一个比较复杂的过程,在移植之前,建议先了解freertosgd32f4xx的基本知识,并阅读官方文档,以便更好地理解和完成移植。 总之,在进行gd32f4xx移植freertos的时候,需要认真学习编写,保证效率和运行质量,充分测试和验证,降低出现异常和bug的概率。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值