基于AT32_Work_Bench配置AT32工程

基于AT32_Work_Bench配置AT32工程


AT32_Work_Bench工具是用来给AT32 MCU快速构建外设初始化工程软件,类似STM32的STM32CubeMX工具软件。

  • 📍AT32 TOOL系列工具下载地址:https://www.arterytek.com/cn/support/index.jsp?index=4
  • 🏷这里以AT32F435RGT7作为测试对象(对标STMF4系列),创建基于Keil平台编译的代码工程。
  • 🎈对应 Keil AT pack包下载地址:https://www.arterytek.com/cn/support/index.jsp?index=4

📑工程创建

🔖下面列举一些常见外设的基本配置。

    1. 新建工程
      在这里插入图片描述
    1. 根据个人配置习惯,先配置debug,也就是下载和在线调试方式配置。
      在这里插入图片描述
    1. CRM时钟配置:(如果选择关闭,则默认使用内部时钟源)
      在这里插入图片描述
      在这里插入图片描述
  • 点开列表可以参看对应总线上挂载的具体的哪些外设:
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    1. GPIO 配置引脚输出
      在这里插入图片描述
    1. 中断引脚配置
      在这里插入图片描述
    1. NVIC中断配置
      在这里插入图片描述
    1. 串口配置
      在这里插入图片描述
    1. 代码预览功能查看
      在这里插入图片描述
    1. 工程代码生成配置
      在这里插入图片描述
      在这里插入图片描述
  • Firmware Library固件包下载:https://www.arterytek.com/cn/product/AT32F435.jsp#Resource
    在这里插入图片描述
  • 📜生成的工程:
    在这里插入图片描述

    1. 使用DAP-LINK进行程序下载
      在这里插入图片描述
      在这里插入图片描述
  • 串口打印信息:
    在这里插入图片描述

main测试代码

/* add user code begin Header */
/**
  **************************************************************************
  * @file     main.c
  * @brief    main program
  **************************************************************************
  *                       Copyright notice & Disclaimer
  *
  * The software Board Support Package (BSP) that is made available to
  * download from Artery official website is the copyrighted work of Artery.
  * Artery authorizes customers to use, copy, and distribute the BSP
  * software and its related documentation for the purpose of design and
  * development in conjunction with Artery microcontrollers. Use of the
  * software is governed by this copyright notice and the following disclaimer.
  *
  * THIS SOFTWARE IS PROVIDED ON "AS IS" BASIS WITHOUT WARRANTIES,
  * GUARANTEES OR REPRESENTATIONS OF ANY KIND. ARTERY EXPRESSLY DISCLAIMS,
  * TO THE FULLEST EXTENT PERMITTED BY LAW, ALL EXPRESS, IMPLIED OR
  * STATUTORY OR OTHER WARRANTIES, GUARANTEES OR REPRESENTATIONS,
  * INCLUDING BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY,
  * FITNESS FOR A PARTICULAR PURPOSE, OR NON-INFRINGEMENT.
  *
  **************************************************************************
  */
/* add user code end Header */

/* Includes ------------------------------------------------------------------*/
#include "at32f435_437_wk_config.h"

/* private includes ----------------------------------------------------------*/
/* add user code begin private includes */
#include "stdio.h"
#include "at32f435_437_int.h"
/* add user code end private includes */

/* private typedef -----------------------------------------------------------*/
/* add user code begin private typedef */

/* add user code end private typedef */

/* private define ------------------------------------------------------------*/
/* add user code begin private define */
/* delay macros */
#define STEP_DELAY_MS                    50
/**************** define print uart ******************/
#define PRINT_UART                       USART1

/* add user code end private define */

/* private macro -------------------------------------------------------------*/
/* add user code begin private macro */

/* add user code end private macro */

/* private variables ---------------------------------------------------------*/
/* add user code begin private variables */
/* delay variable */
static __IO uint32_t fac_us;
static __IO uint32_t fac_ms;
/* add user code end private variables */

/* private function prototypes --------------------------------------------*/
/* add user code begin function prototypes */
/* delay function */
void delay_init(void);
void delay_us(uint32_t nus);
void delay_ms(uint16_t nms);
void delay_sec(uint16_t sec);
/* add user code end function prototypes */

/* private user code ---------------------------------------------------------*/
/* add user code begin 0 */
/* support printf function, usemicrolib is unnecessary */
#if (__ARMCC_VERSION > 6000000)
__asm(".global __use_no_semihosting\n\t");
void _sys_exit(int x)
{
    x = x;
}
/* __use_no_semihosting was requested, but _ttywrch was */
void _ttywrch(int ch)
{
    ch = ch;
}
FILE __stdout;
#else
#ifdef __CC_ARM
#pragma import(__use_no_semihosting)
struct __FILE {
    int handle;
};
FILE __stdout;
void _sys_exit(int x)
{
    x = x;
}
/* __use_no_semihosting was requested, but _ttywrch was */
void _ttywrch(int ch)
{
    ch = ch;
}
#endif
#endif

#if defined (__GNUC__) && !defined (__clang__)
#define PUTCHAR_PROTOTYPE int __io_putchar(int ch)
#else
#define PUTCHAR_PROTOTYPE int fputc(int ch, FILE *f)
#endif

/**
  * @brief  retargets the c library printf function to the usart.
  * @param  none
  * @retval none
  */
PUTCHAR_PROTOTYPE {
    while(usart_flag_get(PRINT_UART, USART_TDBE_FLAG) == RESET);
    usart_data_transmit(PRINT_UART, (uint16_t)ch);
    while(usart_flag_get(PRINT_UART, USART_TDC_FLAG) == RESET);
    return ch;
}

#if (defined (__GNUC__) && !defined (__clang__)) || (defined (__ICCARM__))
#if defined (__GNUC__) && !defined (__clang__)
int _write(int fd, char *pbuffer, int size)
#elif defined ( __ICCARM__ )
#pragma module_name = "?__write"
int __write(int fd, char *pbuffer, int size)
#endif
{
    for(int i = 0; i < size; i ++) {
        while(usart_flag_get(PRINT_UART, USART_TDBE_FLAG) == RESET);
        usart_data_transmit(PRINT_UART, (uint16_t)(*pbuffer++));
        while(usart_flag_get(PRINT_UART, USART_TDC_FLAG) == RESET);
    }

    return size;
}
#endif


/**
  * @brief  initialize delay function
  * @param  none
  * @retval none
  */
void delay_init()
{
    /* configure systick */
    systick_clock_source_config(SYSTICK_CLOCK_SOURCE_AHBCLK_NODIV);
    fac_us = system_core_clock / (1000000U);
    fac_ms = fac_us * (1000U);
}

/**
  * @brief  inserts a delay time.
  * @param  nus: specifies the delay time length, in microsecond.
  * @retval none
  */
void delay_us(uint32_t nus)
{
    uint32_t temp = 0;
    SysTick->LOAD = (uint32_t)(nus * fac_us);
    SysTick->VAL = 0x00;
    SysTick->CTRL |= SysTick_CTRL_ENABLE_Msk ;
    do {
        temp = SysTick->CTRL;
    } while((temp & 0x01) && !(temp & (1 << 16)));

    SysTick->CTRL &= ~SysTick_CTRL_ENABLE_Msk;
    SysTick->VAL = 0x00;
}

/**
  * @brief  inserts a delay time.
  * @param  nms: specifies the delay time length, in milliseconds.
  * @retval none
  */
void delay_ms(uint16_t nms)
{
    uint32_t temp = 0;
    while(nms) {
        if(nms > STEP_DELAY_MS) {
            SysTick->LOAD = (uint32_t)(STEP_DELAY_MS * fac_ms);
            nms -= STEP_DELAY_MS;
        } else {
            SysTick->LOAD = (uint32_t)(nms * fac_ms);
            nms = 0;
        }
        SysTick->VAL = 0x00;
        SysTick->CTRL |= SysTick_CTRL_ENABLE_Msk;
        do {
            temp = SysTick->CTRL;
        } while((temp & 0x01) && !(temp & (1 << 16)));

        SysTick->CTRL &= ~SysTick_CTRL_ENABLE_Msk;
        SysTick->VAL = 0x00;
    }
}

/**
  * @brief  inserts a delay time.
  * @param  sec: specifies the delay time, in seconds.
  * @retval none
  */
void delay_sec(uint16_t sec)
{
    uint16_t index;
    for(index = 0; index < sec; index++) {
        delay_ms(500);
        delay_ms(500);
    }
}
/* add user code end 0 */

/**
  * @brief main function.
  * @param  none
  * @retval none
  */
int main(void)
{
    /* add user code begin 1 */
    uint32_t TimerUART;
    /* add user code end 1 */

    /* system clock config. */
    wk_system_clock_config();

    /* config periph clock. */
    wk_periph_clock_config();

    /* config systick clock source */
    systick_clock_source_config(SYSTICK_CLOCK_SOURCE_AHBCLK_DIV8);
    /* system tick config */
    /**
     * use systick as time base source and configure 1ms tick.
     * users need add interrupt handler code into the below function in the at32f435_437_int.c file.
     *  --void SystTick_IRQHandler(void)
     */
    systick_interrupt_config(system_core_clock / 8 / 1000);

    /* nvic config. */
    wk_nvic_config();

    /* init usart1 function. */
    wk_usart1_init();

    /* init exint function. */
    wk_exint_config();

    /* init gpio function. */
    wk_gpio_config();

    /* add user code begin 2 */
    TimerUART = HAL_GetTick();
    //	delay_init();
    /* add user code end 2 */

    while(1) {
        /* add user code begin 3 */
        if((HAL_GetTick() - TimerUART) > 3000) {
            /* set GPIO Pin*/
            GPIOA->scr = GPIO_PINS_1;
            /* reset GPIO Pin*/
            GPIOA->clr = GPIO_PINS_1;

            printf("(AT32 Work Bench)AT32F435RG:%d\n", system_core_clock);
            TimerUART = HAL_GetTick();
        }
        /* add user code end 3 */
    }
}

  • 📚测试工程:
    • 🔖AT32F435RGT7
链接:https://pan.baidu.com/s/1pBSVw7lunsLLMfdQsT_RLw?pwd=j5z7 
提取码:j5z7

📗BSP例程和在线例程

  • 🎉BSP例程在上面的Firmware Library固件包中。(下载地址https://www.arterytek.com/cn/product/AT32F435.jsp#Resource
  • 🥕在线例程补充:https://www.arterytek.com/cn/support/index.jsp?index=2
<think>好的,用户想在AT32 Work Bench配置FreeRTOS,需要教程或使用指南。首先,我需要确认AT32 Work Bench是否有官方文档支持。根据参考的引用[1],AT32属于国产32位MCU系列,但具体的配置步骤可能需要查阅雅特力科技的官方资源。 用户提到的AT32 Work Bench应该是雅特力提供的开发工具。我需要先检查是否有官方提供的FreeRTOS配置指南。通常,MCU厂商会在产品官网或开发者社区提供SDK、例程和工具使用说明。例如,GD32的MCU产品官网就有相关生态系统资源,AT32可能类似。 接下来,我应该考虑用户可能遇到的问题,比如如何安装AT32 Work Bench、如何导入FreeRTOS库、配置任务和内核参数等。此外,还需要指导用户如何查找官方文档,比如访问雅特力官网,查找应用笔记或用户手册。 用户可能需要具体的步骤,例如在IDE中创建项目、添加FreeRTOS组件、配置内核参数、生成代码等。如果有官方例程,建议用户参考例程结构。同时,注意可能的常见错误,比如堆栈设置、时钟配置等。 最后,确保回答结构清晰,分步骤说明,并引导用户查阅官方资料,确保信息准确。如果有社区或论坛资源,也可以推荐用户参与讨论。</think>### AT32 Work Bench配置FreeRTOS的步骤指南 AT32 Work Bench是雅特力科技(Artery)提供的图形化配置工具,用于快速生成MCU外设初始化和RTOS配置代码。以下是基于通用开发流程的配置步骤(具体细节需结合官方文档): #### **1. 环境准备** - **下载工具**:访问[雅特力科技官网](https://www.arterytek.com/),在“技术支持”或“下载中心”获取最新版AT32 Work BenchAT32 SDK[^1]。 - **安装FreeRTOS支持包**:确认SDK中是否包含FreeRTOS适配层(通常位于`Middlewares/FreeRTOS`目录)。 #### **2. 新建/导入工程** - 启动AT32 Work Bench,选择目标MCU型号(如AT32F403A)。 - 创建新工程或导入官方提供的FreeRTOS例程(推荐优先查找`Examples/FreeRTOS`目录)。 #### **3. 配置FreeRTOS参数** - **内核设置**:在图形界面中找到RTOS配置模块,设置任务堆栈大小、优先级、调度策略(如时间片轮转或抢占式)等。 - **添加任务**:通过界面定义任务函数(如`Task1`、`Task2`),并分配堆栈空间和优先级。 - **硬件依赖配置**:确保系统时钟(SYSCLK)和滴答定时器(SysTick)已正确初始化,FreeRTOS依赖SysTick作为时间基准。 #### **4. 生成代码与验证** - **生成代码**:点击生成按钮,工具会自动创建`FreeRTOSConfig.h`和任务框架代码。 - **检查关键配置**: ```c /* FreeRTOSConfig.h 示例 */ #define configUSE_PREEMPTION 1 // 启用抢占式调度 #define configTOTAL_HEAP_SIZE (20*1024) // 堆内存大小 ``` - **编译与下载**:使用Keil/IAR等IDE编译代码,下载到开发板后通过串口调试输出任务运行状态。 #### **5. 调试与优化** - **内存监控**:使用`vTaskList()`或`uxTaskGetStackHighWaterMark()`监控任务堆栈使用情况。 - **性能调整**:根据实际需求调整`configTICK_RATE_HZ`(系统节拍频率)和任务优先级。 --- ### 注意事项 1. **官方文档优先**:雅特力官网提供详细的《AT32 MCU FreeRTOS应用笔记》和《Work Bench用户手册》,包含外设驱动与RTOS的集成方法。 2. **例程参考**:SDK中的FreeRTOS例程(如任务创建、队列通信)是快速上手的关键。 3. **社区支持**:加入雅特力技术论坛或微信群组,获取实时问题解答。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值