注册 登录
电子工程世界-论坛 返回首页 EEWORLD首页 频道 EE大学堂 下载中心 Datasheet 专题
LitchiCheng的个人空间 http://home.eeworld.com.cn/space-uid-1003127.html [收藏] [复制] [分享] [RSS]
日志

AG32VF407 AGRV2K 串口printf调试输出

已有 256 次阅读2023-7-30 16:43 |个人分类:AG32VF407

原理图

 

测试代码

新建一个platformio工程,复制如下文件到测试工程目录下

E:\tech\AGM-AG32VF\sdk-release\AgRV_pio\platforms\AgRV\boards\agrv2k_407\board.asf

E:\tech\AGM-AG32VF\sdk-release\AgRV_pio\platforms\AgRV\boards\agrv2k_407\board.ve

E:\tech\AGM-AG32VF\sdk-release\AgRV_pio\platforms\AgRV\examples\example\platformio.ini

 

platformio.ini中增加如下配置,uart调试端口可以查看设备管理器,COM多少,其中速率默认sdk为500000

 

新建src目录,创建uart.c文件,代码如下:

#include "board.h"

int main(void)
{
    board_init();
    int cnt=0;
    #define LED_D3_GPIO GPIO4
    #define LED_D3_GPIO_BITS (1 << 3)
    SYS_EnableAPBClock(APB_MASK_GPIO4);
    GPIO_SetOutput(LED_D3_GPIO, LED_D3_GPIO_BITS);
    GPIO_SetHigh(LED_D3_GPIO, LED_D3_GPIO_BITS);
    int counter = 0;
    while (1) {
        UTIL_IdleMs(500);
        GPIO_Toggle(LED_D3_GPIO, LED_D3_GPIO_BITS);
        printf("test %d\r\n", cnt++);
    }
}

build,upload,然后再点击Serial Monitor,输出如下图

 

printf实现

E:\tech\AGM-AG32VF\sdk-release\AgRV_pio\packages\framework-agrv_sdk\misc\syscalls.c
    int printf(const char* fmt, ...)
          int ret = vprintfmt((void*)putchar, 0, fmt, ap, 0);
E:\tech\AGM-AG32VF\sdk-release\AgRV_pio\packages\framework-agrv_sdk\src\util.c
    int putchar(int ch)
        UART_SendCh(UARTx(LOGGER_UART), ch);
E:\tech\AGM-AG32VF\sdk-release\AgRV_pio\platforms\AgRV\boards\agrv2k_407\board.c
    void board_init(void)
        MSG_UART = UARTx(LOGGER_UART);

视频讲解


 

本文来自论坛,点击查看完整帖子内容。

评论 (0 个评论)

facelist doodle 涂鸦板

您需要登录后才可以评论 登录 | 注册

热门文章