0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
电子发烧友
开通电子发烧友VIP会员 尊享10大特权
海量资料免费下载
精品直播免费看
优质内容免费畅学
课程9折专享价
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

APM32F4xx_SDK_V1.1中使用IAR9.3進(jìn)行編譯使用printf功能

Geehy極海半導(dǎo)體 ? 來(lái)源:21ic論壇 ? 作者:21ic ? 2022-08-11 10:36 ? 次閱讀

單片機(jī)玩得很溜了,平時(shí)也很少去關(guān)注VDD波形,整機(jī)測(cè)試無(wú)異常就完事了。也確實(shí),芯片技術(shù)發(fā)展多年 前言 最近發(fā)現(xiàn)IAR 發(fā)布了新版本9.30.1,在新版本中Geehy的眾多MCU都完成了支持。 16e0dcf2-191d-11ed-ba43-dac502259ad0.png ?我這邊剛好有APM32F407IG的MINIBOARD,想著使用IAR編譯一下工程下載運(yùn)行一下程序。不料卻發(fā)現(xiàn)了問(wèn)題,APM32F4xx_SDK_V1.1中的IAR例程是基于 IAR8.5制作的,關(guān)于printf的重定向都已經(jīng)在工程內(nèi)進(jìn)行了設(shè)置。使用8.5的工程也可以正常使用printf功能。但在9.x的IAR對(duì)printf重定向有了新的要求,導(dǎo)致IAR 9.x版本無(wú)法運(yùn)行含有printf功能的例程。 本文檔就解決APM32F4xx_SDK_V1.1中使用IAR9.3進(jìn)行編譯使用printf功能進(jìn)行記錄分享。 值得注意的是: - printf重定向前需完成對(duì)應(yīng)串口的初始化操作。 1 IAR 8.x的printf重定向 IAR 8.x的printf重定向與Keil并無(wú)差異,僅需在內(nèi)部的任意一個(gè)C文件中重定向printf后設(shè)置工程的相應(yīng)參數(shù)即可完成。 1. 重定向printf代碼如下(發(fā)送串口為串口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. 設(shè)置工程相應(yīng)參數(shù),將General Option 的 Library Configuration 選項(xiàng)卡下Library選擇為“Full”,CMSIS 項(xiàng)目勾選“Use CMSIS”。

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

至此程序中便可以正常使用printf函數(shù)。 2 IAR 9.x的printf重定向 通過(guò)查閱IAR的開(kāi)發(fā)文檔。(在Help選項(xiàng)卡下打開(kāi)“C/C++ Development Guide”)

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

在開(kāi)發(fā)文檔的“BRIEFLY ABOUT RETARGETING”章節(jié),我們可以看到IAR9.x要求我們使用printf時(shí)需要重定向__write函數(shù)。

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

重定向的詳細(xì)內(nèi)容請(qǐng)查閱文檔,此處不在贅述。這里給出參考操作。 1. 在源碼目錄下,新建“write.c”文件用于存放我們重定向的代碼。 2. 打開(kāi)需要重定向的工程,在工程中添加我們剛剛新建的“write.c”。

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

3. 編輯“write.c”文件,添加重定向代碼。代碼內(nèi)容如下。

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

*

* 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函數(shù)為IAR要求我們進(jìn)行重定向的函數(shù),這里使用的發(fā)送串口是串口1,若需要使用其他串口,請(qǐng)相應(yīng)修改“USART_Transmit(USART1,(uint8_t *)buffer,size) == 1”中的USART1參數(shù)。 USART_Transmit函數(shù)是為了便捷使用發(fā)送功能進(jìn)行定義的函數(shù),其采用的是輪訓(xùn)發(fā)送的操作,有超時(shí)設(shè)置,返回1為發(fā)送成功,返回0為發(fā)送失敗。 至此程序中便可以正常使用printf函數(shù)。 以上便是APM32F4xx_SDK_V1.1中的IAR工程使用9.30打開(kāi)后如何使用printf進(jìn)行打印的全部?jī)?nèi)容。

審核編輯 :李倩


聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 芯片技術(shù)
    +關(guān)注

    關(guān)注

    1

    文章

    162

    瀏覽量

    17909
  • APM
    APM
    +關(guān)注

    關(guān)注

    1

    文章

    72

    瀏覽量

    13206
  • SDK
    SDK
    +關(guān)注

    關(guān)注

    3

    文章

    1057

    瀏覽量

    47231
  • Printf
    +關(guān)注

    關(guān)注

    0

    文章

    83

    瀏覽量

    13996

原文標(biāo)題:APM32芯得 EP.07 | APM32F407 使用IAR9.3調(diào)用printf打印信息

文章出處:【微信號(hào):geehysemi,微信公眾號(hào):Geehy極海半導(dǎo)體】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 0人收藏

    評(píng)論

    相關(guān)推薦

    GD32F4xx硬件開(kāi)發(fā)指南

    電子發(fā)燒友網(wǎng)站提供《GD32F4xx硬件開(kāi)發(fā)指南.pdf》資料免費(fèi)下載
    發(fā)表于 02-07 17:20 ?0次下載
    GD32<b class='flag-5'>F4xx</b>硬件開(kāi)發(fā)指南

    GD32F4xx用戶(hù)手冊(cè)

    電子發(fā)燒友網(wǎng)站提供《GD32F4xx用戶(hù)手冊(cè).pdf》資料免費(fèi)下載
    發(fā)表于 01-16 14:49 ?14次下載
    GD32<b class='flag-5'>F4xx</b>用戶(hù)手冊(cè)

    EE-88:使用21xx編譯器在C初始化變量

    電子發(fā)燒友網(wǎng)站提供《EE-88:使用21xx編譯器在C初始化變量.pdf》資料免費(fèi)下載
    發(fā)表于 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開(kāi)發(fā)APM32

    APM32 官方 SDK 中提供了三種開(kāi)發(fā)環(huán)境:Keil、IAR 和 Eclipse。不否認(rèn)這三種環(huán)境的強(qiáng)大,但是在 AI 時(shí)代做嵌入式開(kāi)發(fā),用這三種環(huán)境就顯得有點(diǎn)不夠優(yōu)雅了。本篇文章主要介紹怎么用
    的頭像 發(fā)表于 12-17 09:19 ?1439次閱讀
    怎么用Clion開(kāi)發(fā)<b class='flag-5'>APM</b>32

    RK3588 SDK入門(mén)之編譯使用篇

    前言:在上一篇文章,我們已經(jīng)配置好了Ubuntu虛擬機(jī)。本期將重點(diǎn)介紹如何Ubuntu虛擬機(jī)中使用RK3588的SDK。具體內(nèi)容包括SDK的下載與安裝、環(huán)境變量的配置、以及
    的頭像 發(fā)表于 11-22 01:07 ?2862次閱讀
    RK3588 <b class='flag-5'>SDK</b>入門(mén)之<b class='flag-5'>編譯</b>使用篇

    用戶(hù)手冊(cè) | 全志T113-S3開(kāi)發(fā)板——SDK編譯指南

    ,不像發(fā)行版那樣需要編譯整個(gè)linux系統(tǒng),只需要指定特定開(kāi)發(fā)的功能進(jìn)行交叉編譯即可。本文為大家介紹全志T113-S3開(kāi)發(fā)板在眺望電子提供的SDK
    的頭像 發(fā)表于 11-01 08:08 ?3716次閱讀
    用戶(hù)手冊(cè) | 全志T113-S3開(kāi)發(fā)板——<b class='flag-5'>SDK</b><b class='flag-5'>編譯</b>指南

    APM32F10xx進(jìn)入低功耗模式的問(wèn)題分析

    近日,在學(xué)習(xí)APM32開(kāi)發(fā)板關(guān)于PMU模塊的內(nèi)容,看到很多內(nèi)容都是調(diào)用WFI內(nèi)核指令進(jìn)入低功耗模式,于是自己想嘗試調(diào)用WFE內(nèi)核指令進(jìn)入低功耗模式,但在APM32F10xx,我運(yùn)用按鍵中斷,在中斷
    的頭像 發(fā)表于 10-18 16:13 ?647次閱讀
    <b class='flag-5'>APM32F10xx</b>進(jìn)入低功耗模式的問(wèn)題分析

    從MSP430F4xx遷移到MSP430FR4xx系列

    電子發(fā)燒友網(wǎng)站提供《從MSP430F4xx遷移到MSP430FR4xx系列.pdf》資料免費(fèi)下載
    發(fā)表于 10-10 11:34 ?0次下載
    從MSP430<b class='flag-5'>F4xx</b>遷移到MSP430FR<b class='flag-5'>4xx</b>系列

    使用MSP430FR4xx和MSP430FR2xx ADC進(jìn)行設(shè)計(jì)

    電子發(fā)燒友網(wǎng)站提供《使用MSP430FR4xx和MSP430FR2xx ADC進(jìn)行設(shè)計(jì).pdf》資料免費(fèi)下載
    發(fā)表于 09-21 09:04 ?0次下載
    使用MSP430FR<b class='flag-5'>4xx</b>和MSP430FR2<b class='flag-5'>xx</b> ADC<b class='flag-5'>進(jìn)行</b>設(shè)計(jì)

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

    GD32F4xx 系列 MCU 是基于 Arm? Cortex?-M4 處理器的 32 位通用微控制器,與 STM32F4xx系列 MCU 保持高度兼容。本文主要從以下三個(gè)方面進(jìn)行介紹
    的頭像 發(fā)表于 09-06 09:40 ?2080次閱讀
    【GD32 MCU 移植教程】8、從 STM32<b class='flag-5'>F4xx</b> 系列移植到 GD32<b class='flag-5'>F4xx</b> 系

    Simplelink CC32xx SDK整數(shù)溢出問(wèn)題

    電子發(fā)燒友網(wǎng)站提供《Simplelink CC32xx SDK整數(shù)溢出問(wèn)題.pdf》資料免費(fèi)下載
    發(fā)表于 09-03 10:28 ?0次下載
    Simplelink CC32<b class='flag-5'>xx</b> <b class='flag-5'>SDK</b>整數(shù)溢出問(wèn)題

    RK3568 編譯sdk技巧

    我司RK3568對(duì)外提供源代碼是以sdk的形式提供,包括但不僅限于uboot、kernel、buildroot、debian源碼。在編譯sdk的過(guò)程往往需要安裝大量的第三方安裝包,同
    的頭像 發(fā)表于 08-30 11:44 ?860次閱讀
    RK3568 <b class='flag-5'>編譯</b><b class='flag-5'>sdk</b>技巧

    在RTOS v 1.5.0編譯驅(qū)動(dòng)程序庫(kù)報(bào)錯(cuò)的原因?

    我剛剛嘗試在新的 RTOS v 1.5.0 編譯驅(qū)動(dòng)程序庫(kù)。 光盤(pán) ~/ESP8266_RTOS_SDK/driver_lib ./make_lib.sh 驅(qū)動(dòng)程序 第一個(gè)錯(cuò)誤
    發(fā)表于 07-18 06:35

    IAR中使用KitProg3進(jìn)行調(diào)試,無(wú)法檢測(cè)到目標(biāo)是怎么回事?

    我試圖在 IAR 中使用 KitProg3 進(jìn)行調(diào)試,但遇到以下錯(cuò)誤: 看來(lái) KitProg3 設(shè)備已被識(shí)別。 似乎無(wú)法檢測(cè)到目標(biāo)。 考慮到 LED4 和 LED1 在模式下閃爍,
    發(fā)表于 06-03 06:15

    芯海通用 MCU應(yīng)用筆記 :在 IAR 及 MDK 開(kāi)發(fā)環(huán)境下使用 printf 函數(shù)重定向移植差異指南

    和調(diào)試printf 函數(shù)是常用的打印函數(shù),通常通過(guò) fputc 接口的重定向,即可以通過(guò) printf 輸出串口的信息。 但在 IAR8.x 下,需要一些 IDE 的額外配置,MC
    發(fā)表于 05-16 11:56

    電子發(fā)燒友

    中國(guó)電子工程師最喜歡的網(wǎng)站

    • 2931785位工程師會(huì)員交流學(xué)習(xí)
    • 獲取您個(gè)性化的科技前沿技術(shù)信息
    • 參加活動(dòng)獲取豐厚的禮品