0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

APM32F4xx_SDK_V1.1中使用IAR9.3进行编译使用printf功能

Geehy极海半导体 来源:21ic论坛 作者:21ic 2022-08-11 10:36 次阅读

单片机玩得很溜了,平时也很少去关注VDD波形,整机测试无异常就完事了。也确实,芯片技术发展多年 前言 最近发现IAR 发布了新版本9.30.1,在新版本中Geehy的众多MCU都完成了支持。 16e0dcf2-191d-11ed-ba43-dac502259ad0.png  我这边刚好有APM32F407IG的MINIBOARD,想着使用IAR编译一下工程下载运行一下程序。不料却发现了问题,APM32F4xx_SDK_V1.1中的IAR例程是基于 IAR8.5制作的,关于printf的重定向都已经在工程内进行了设置。使用8.5的工程也可以正常使用printf功能。但在9.x的IAR对printf重定向有了新的要求,导致IAR 9.x版本无法运行含有printf功能的例程。 本文档就解决APM32F4xx_SDK_V1.1中使用IAR9.3进行编译使用printf功能进行记录分享。 值得注意的是: - printf重定向前需完成对应串口的初始化操作。 1 IAR 8.x的printf重定向 IAR 8.x的printf重定向与Keil并无差异,仅需在内部的任意一个C文件中重定向printf后设置工程的相应参数即可完成。 1. 重定向printf代码如下(发送串口为串口1,头文件需包含stdio.h)

/* Includes */

#include "stdio.h"

/*!

* [url=home.php?mod=space&uid=247401]@brief[/url] Redirect C Library function printf to serial port.

* After Redirection, you can use printf function.

*

* @param ch: The characters that need to be send.

*

* @param *f: pointer to a FILE that can recording all information

* needed to control a stream

*

* @retval The characters that need to be send.

*/

int fputc(int ch, FILE *f)

{

/** send a byte of data to the serial port */

USART_TxData(DEBUG_USART,(uint8_t)ch);

/** wait for the data to be send */

while (USART_ReadStatusFlag(DEBUG_USART, USART_FLAG_TXBE) == RESET);

return (ch);

}

2. 设置工程相应参数,将General Option 的 Library Configuration 选项卡下Library选择为“Full”,CMSIS 项目勾选“Use CMSIS”。

170b6ff8-191d-11ed-ba43-dac502259ad0.jpg

至此程序中便可以正常使用printf函数。 2 IAR 9.x的printf重定向 通过查阅IAR的开发文档。(在Help选项卡下打开“C/C++ Development Guide”)

1727e4da-191d-11ed-ba43-dac502259ad0.jpg

在开发文档的“BRIEFLY ABOUT RETARGETING”章节,我们可以看到IAR9.x要求我们使用printf时需要重定向__write函数。

17419bdc-191d-11ed-ba43-dac502259ad0.png

重定向的详细内容请查阅文档,此处不在赘述。这里给出参考操作。 1. 在源码目录下,新建“write.c”文件用于存放我们重定向的代码。 2. 打开需要重定向的工程,在工程中添加我们刚刚新建的“write.c”。

1775fbc0-191d-11ed-ba43-dac502259ad0.jpg

3. 编辑“write.c”文件,添加重定向代码。代码内容如下。

/*******************

*

* Copyright 1998-2017 IAR Systems AB.

*

* This is a template implementation of the "__write" function used by

* the standard library. Replace it with a system-specific

* implementation.

*

* The "__write" function should output "size" number of bytes from

* "buffer" in some application-specific way. It should return the

* number of characters written, or _LLIO_ERROR on failure.

*

* If "buffer" is zero then __write should perform flushing of

* internal buffers, if any. In this case "handle" can be -1 to

* indicate that all handles should be flushed.

*

* The template implementation below assumes that the application

* provides the function "MyLowLevelPutchar". It should return the

* character written, or -1 on failure.

*

********************/

#include

#include "Board.h"

#include "apm32f4xx.h"

#pragma module_name = "?__write"

uint8_t USART_Transmit(USART_T* usart, uint8_t *pdata, uint16_t Size);

/*

* If the __write implementation uses internal buffering, uncomment

* the following line to ensure that we are called with "buffer" as 0

* (i.e. flush) when the application terminates.

*/

size_t __write(int handle, const unsigned char * buffer, size_t size)

{

if (buffer == 0)

{

/*

* This means that we should flush internal buffers. Since we

* don't we just return. (Remember, "handle" == -1 means that all

* handles should be flushed.)

*/

return 0;

}

/* This template only writes to "standard out" and "standard err",

* for all other file handles it returns failure. */

if (handle != _LLIO_STDOUT && handle != _LLIO_STDERR)

{

return _LLIO_ERROR;

}

/* Sending in normal mode */

if(USART_Transmit(USART1,(uint8_t *)buffer,size) == 1)

{

return size;

}

else

{

return _LLIO_ERROR;

}

}

uint8_t USART_Transmit(USART_T* usart, uint8_t *pdata, uint16_t Size)

{

uint8_t ch = 0;

uint16_t i = 0;

uint16_t timeout = 0x1000;

for(i=0;i

{

ch = pdata[i];

/** send a byte of data to the serial port */

USART_TxData(usart,(uint8_t)ch);

/** wait for the data to be send */

while ((USART_ReadStatusFlag(usart, USART_FLAG_TXBE) == RESET) && (timeout -- ));

if(timeout == 0)

{

return 0;

}

timeout = 0x1000;

}

return 1;

}

__write函数为IAR要求我们进行重定向的函数,这里使用的发送串口是串口1,若需要使用其他串口,请相应修改“USART_Transmit(USART1,(uint8_t *)buffer,size) == 1”中的USART1参数。 USART_Transmit函数是为了便捷使用发送功能进行定义的函数,其采用的是轮训发送的操作,有超时设置,返回1为发送成功,返回0为发送失败。 至此程序中便可以正常使用printf函数。 以上便是APM32F4xx_SDK_V1.1中的IAR工程使用9.30打开后如何使用printf进行打印的全部内容。

审核编辑 :李倩


声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 芯片技术
    +关注

    关注

    1

    文章

    159

    浏览量

    17484
  • APM
    APM
    +关注

    关注

    1

    文章

    71

    浏览量

    12987
  • SDK
    SDK
    +关注

    关注

    3

    文章

    1026

    浏览量

    45763
  • Printf
    +关注

    关注

    0

    文章

    81

    浏览量

    13623

原文标题:APM32芯得 EP.07 | APM32F407 使用IAR9.3调用printf打印信息

文章出处:【微信号:geehysemi,微信公众号:Geehy极海半导体】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    RK3588 SDK入门之编译使用篇

    前言:在上一篇文章,我们已经配置好了Ubuntu虚拟机。本期将重点介绍如何Ubuntu虚拟机中使用RK3588的SDK。具体内容包括SDK的下载与安装、环境变量的配置、以及
    的头像 发表于 11-22 01:07 7次阅读
    RK3588 <b class='flag-5'>SDK</b>入门之<b class='flag-5'>编译</b>使用篇

    用户手册 | 全志T113-S3开发板——SDK编译指南

    ,不像发行版那样需要编译整个linux系统,只需要指定特定开发的功能进行交叉编译即可。本文为大家介绍全志T113-S3开发板在眺望电子提供的SDK
    的头像 发表于 11-01 08:08 719次阅读
    用户手册 | 全志T113-S3开发板——<b class='flag-5'>SDK</b><b class='flag-5'>编译</b>指南

    APM32F10xx进入低功耗模式的问题分析

    近日,在学习APM32开发板关于PMU模块的内容,看到很多内容都是调用WFI内核指令进入低功耗模式,于是自己想尝试调用WFE内核指令进入低功耗模式,但在APM32F10xx,我运用按键中断,在中断
    的头像 发表于 10-18 16:13 203次阅读
    <b class='flag-5'>APM32F10xx</b>进入低功耗模式的问题分析

    从MSP430F4xx迁移到MSP430FR4xx系列

    电子发烧友网站提供《从MSP430F4xx迁移到MSP430FR4xx系列.pdf》资料免费下载
    发表于 10-10 11:34 0次下载
    从MSP430<b class='flag-5'>F4xx</b>迁移到MSP430FR<b class='flag-5'>4xx</b>系列

    【GD32 MCU 移植教程】8、从 STM32F4xx 系列移植到 GD32F4xx

    GD32F4xx 系列 MCU 是基于 Arm® Cortex®-M4 处理器的 32 位通用微控制器,与 STM32F4xx系列 MCU 保持高度兼容。本文主要从以下三个方面进行介绍
    的头像 发表于 09-06 09:40 958次阅读
    【GD32 MCU 移植教程】8、从 STM32<b class='flag-5'>F4xx</b> 系列移植到 GD32<b class='flag-5'>F4xx</b> 系

    RK3568 编译sdk技巧

    我司RK3568对外提供源代码是以sdk的形式提供,包括但不仅限于uboot、kernel、buildroot、debian源码。在编译sdk的过程往往需要安装大量的第三方安装包,同
    的头像 发表于 08-30 11:44 411次阅读
    RK3568 <b class='flag-5'>编译</b><b class='flag-5'>sdk</b>技巧

    IAR中使用KitProg3进行调试,无法检测到目标是怎么回事?

    我试图在 IAR 中使用 KitProg3 进行调试,但遇到以下错误: 看来 KitProg3 设备已被识别。 似乎无法检测到目标。 考虑到 LED4 和 LED1 在模式下闪烁,
    发表于 06-03 06:15

    芯海通用 MCU应用笔记 :在 IAR 及 MDK 开发环境下使用 printf 函数重定向移植差异指南

    和调试printf 函数是常用的打印函数,通常通过 fputc 接口的重定向,即可以通过 printf 输出串口的信息。 但在 IAR8.x 下,需要一些 IDE 的额外配置,MC
    发表于 05-16 11:56

    在macos下SW4STM32编译,调用printf异常怎么解决?

    刚开始在MACOS下开发STM32的程序,现在出现了一些很奇怪的问题,看是否大家有遇到这样的问题。 开发配置如下 1.STM32cube427,STM32Cube FW_F4 V
    发表于 04-17 06:48

    CKS32F4xx系列FSMC功能简介

    本课讲为大家讲解CKS32F4xx系列产品的FSMC应用实例,FSMC全称是Flexible Static Memory Controller,读作灵活的静态存储控制器,顾名思义,MCU可以通过FSMC扩展静态内存
    的头像 发表于 04-14 15:06 858次阅读
    CKS32<b class='flag-5'>F4xx</b>系列FSMC<b class='flag-5'>功能</b>简介

    先楫半导体 hpm_sdk v1.5.0 正式发布

    先楫半导体 hpm_sdk v1.5.0 正式发布!功能升级更强大 版本更新概况 新支持的IDE IAR Embedded Workbench for RISC-
    发表于 04-08 11:14

    STM32G4XX不能够像STM32F1XX STM32F4XX那样对GPIO进行位带操作呢?

    请教下,在STM32G4XX系列里面,GPIO挂载在AHB2总线上面,地址在0x4800 0000. 是不是也就意味着,STM32G4XX不能够在像STM32F1XX STM32F4XX
    发表于 03-21 07:16

    CKS32F4xx系列DSP功能介绍

    CKS32F4xx系列使用高性能的32位内核,支持浮点运算单元(FPU),同时还支持DSP指令以及存储保护(MPU)用来加强应用的安全性。
    的头像 发表于 03-04 13:43 1503次阅读
    CKS32<b class='flag-5'>F4xx</b>系列DSP<b class='flag-5'>功能</b>介绍

    Mini51DE_Series_BSP_CMSIS_v3.02.000为何在IAR编译报错?

    IAR 8.32 编译时报如下错误: Error[Pe235]: variable \"__stdout\" was declared with a
    发表于 01-15 08:22

    基于CKS32F4xx系列的MCU互补PWM方案

    互补输出实际跟比较输出章节一样使用的是定时器的功能,所以相关的函数设置同样在库函数文件CKS32f4xx_tim.h和CKS32f4xx_tim.c文件。 1)开启TIM1和GPIO
    发表于 12-02 10:13 587次阅读
    基于CKS32<b class='flag-5'>F4xx</b>系列的MCU互补PWM方案