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

    文章

    173

    浏览量

    18383
  • APM
    APM
    +关注

    关注

    1

    文章

    73

    浏览量

    13751
  • SDK
    SDK
    +关注

    关注

    3

    文章

    1093

    浏览量

    51176
  • Printf
    +关注

    关注

    0

    文章

    84

    浏览量

    14625

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

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

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    AT32F4xx I2C使用轮询模式进行主机发送从机接收

    \\templates 各种编译 环境(例 如IAR6/7/8,keil 4/5)进行简单 修改即可。 1.3 示例使用 1) 打开
    发表于 11-05 14:00

    AT32F4xx I2C使用轮询模式进行主机接收从机发送

    \\templates 各种编译 环境(例 如IAR6/7/8,keil 4/5)进行简单 修改即可。 1.3 示例使用 1) 打开
    发表于 11-05 13:58

    AT32F4xx SPI使用单工模式通讯

    AT32F4xx SPI使用单工模式通讯 示例目的演示AT32F403Axx SPI使用单工模式通讯,其余系列使用方式与此类似。 注:本示例代码是基于雅特力提供的V2.x.x板级支持包(BSP)而
    发表于 11-05 13:34

    printf函数在hbird SDK的应用

    系统,使用newlib作为C运行库,而newlib的C运行库所提供的printf函数最终依赖桩函数write。 在hbird_sdk可以找到write.c文件 内容如下: 其中
    发表于 10-31 08:48

    请问如何在 Keil μVision 或 IAR EWARM 中使用观察点进行调试?

    如何在 Keil μVision 或 IAR EWARM 中使用观察点进行调试?
    发表于 08-20 06:29

    env scons 编译找不到stm32f4xx.h,这个怎么解决?

    env scons 编译找不到stm32f4xx.h,这个怎么解决,我看了文件确实是没有
    发表于 08-15 07:28

    GD32F4xx系列MCU基础工程资料

    GD32F4xx系列MCU基础工程创建.
    发表于 08-04 14:53 2次下载

    APM32F411打造可自动化的命令行工作流

    拿到APM32F411的TINY板卡后,在打开官方提供的SDK发现,他们提供的MDK、IAR、Eclipse的工程示例。非常不错,但是我想着有一些场景下在没有安装IDE的情况下怎么编译
    的头像 发表于 07-11 10:00 1660次阅读
    为<b class='flag-5'>APM32F</b>411打造可自动化的命令行工作流

    极海APM32F411微控制器硬件FPU使用指南

    APM32F411是一款基于32位Arm Cortex-M4F内核的微控制器。硬件FPU是Arm Cortex-M4F的一大优势。合理应用硬件FPU可以大大缩短运算时间。
    的头像 发表于 06-28 11:23 1560次阅读
    极海<b class='flag-5'>APM32F</b>411微控制器硬件FPU使用指南

    IAR Arm开发工具链--function_sections编译选项的使用

    本文主要介绍在IAR Arm开发工具链不修改源代码的情况下使用‑‑function_sections编译选项把函数放到单独的section。
    的头像 发表于 06-13 13:53 1507次阅读
    在<b class='flag-5'>IAR</b> Arm开发工具链<b class='flag-5'>中</b>--function_sections<b class='flag-5'>编译</b>选项的使用

    k230 sdk编译报错的原因?

    %A8%E8%AF%B4%E6%98%8E.html 1、下载K230sdk代码 2、根据教程,进行docker环境准备 3、在docker环境中进行
    发表于 06-10 06:48

    GD32F4xx硬件开发指南

    电子发烧友网站提供《GD32F4xx硬件开发指南.pdf》资料免费下载
    发表于 02-07 17:20 3次下载
    GD32<b class='flag-5'>F4xx</b>硬件开发指南

    GD32F4xx用户手册

    电子发烧友网站提供《GD32F4xx用户手册.pdf》资料免费下载
    发表于 01-16 14:49 14次下载
    GD32<b class='flag-5'>F4xx</b>用户手册

    EE-88:使用21xx编译器在C初始化变量

    电子发烧友网站提供《EE-88:使用21xx编译器在C初始化变量.pdf》资料免费下载
    发表于 01-13 15:54 0次下载
    EE-88:使用21<b class='flag-5'>xx</b><b class='flag-5'>编译</b>器在C<b class='flag-5'>中</b>初始化变量

    怎么用Clion开发APM32

    APM32 官方 SDK 中提供了三种开发环境:Keil、IAR 和 Eclipse。不否认这三种环境的强大,但是在 AI 时代做嵌入式开发,用这三种环境就显得有点不够优雅了。本篇文章主要介绍怎么用
    的头像 发表于 12-17 09:19 2228次阅读
    怎么用Clion开发<b class='flag-5'>APM</b>32