IAR 9.30.1 GD32F427 printf无法打印

IAR 9.30.1 GD32F427 printf无法打印

由于编译的工程文件存在typeof函数,编译一直不通过:查询得知低版本的IAR不支持typeof()

​ 原因:typeof()是GNU C的关键字,有的编译器支持,有的编译器不支持。因此将低版本替换至高版本iar

低版本的9.10.1工程中可正常打印信息,高版本9.30.1打开该工程无法使用。总结一下方法步骤:

1、打开IAR的安装目录,查找write.c文件 D:\IAR\arm\src\lib\file

2、修改write.c文件,修改以下位置:

(1)将原版本重定义函数复制到write.c文件:(本文以gd为例)

`int fputc(int ch, FILE *f)
{
    usart_data_transmit(USART0, (uint8_t)ch);
    while(RESET == usart_flag_get(USART0, USART_FLAG_TBE));
    return ch;
}`

原write.c文件修改为:

`int MyLowLevelPutchar(int ch);
{
    usart_data_transmit(USART0, (uint8_t)ch);
    while(RESET == usart_flag_get(USART0, USART_FLAG_TBE));
    return ch;
}`

(2)将原函数的if#0 修改为if 1

修改完成后的write.c文件如下:

#include <LowLevelIOInterface.h>
#include "gd32f4xx.h"
#include <stdio.h>

#pragma module_name = "?__write"
#define EVAL_COM1 USART0


int MyLowLevelPutchar(int ch);

int MyLowLevelPutchar(int ch);
{
    usart_data_transmit(EVAL_COM1, (uint8_t)ch);
    while(RESET == usart_flag_get(EVAL_COM1, USART_FLAG_TBE));
    return ch;
}

/*
 * 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)
{
  /* Remove the #if #endif pair to enable the implementation */
#if 1

  size_t nChars = 0;

  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;
  }

  for (/* Empty */; size != 0; --size)
  {
    if (MyLowLevelPutchar(*buffer++) < 0)
    {
      return _LLIO_ERROR;
    }

    ++nChars;
  }

  return nChars;

#else

  /* Always return error code when implementation is disabled. */
  return _LLIO_ERROR;

#endif

}

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
提供的源码资源涵盖了安卓应用、小程序、Python应用和Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。
要配置iar9.30.1环境,您需要按照以下步骤进行操作: 1. 首先,确保您已经下载并安装了IAR Embedded Workbench软件的9.30.1版本。您可以从IAR Systems官方网站下载安装程序。 2. 打开IAR Embedded Workbench软件,并创建一个新的工程或打开您现有的工程。 3. 在工程窗口中,右键单击您的工程,并选择“Options...”选项。 4. 在弹出的选项对话框中,选择您的目标设备。如果您的目标设备不在列表中,您可以选择“Add...”按钮并添加设备描述文件。 5. 在选项对话框的左侧面板中,选择“Debugger”选项,并确保您选择了正确的调试器。如果您使用的是J-Link调试器,您可以选择“Segger J-Link”并配置连接参数。 6. 在选项对话框的左侧面板中,选择“C/C++ Compiler”选项,并确保您选择了正确的编译器。根据您的需求配置编译器选项,如优化级别、警告级别等。 7. 在选项对话框的左侧面板中,选择“Linker”选项,并配置链接器选项。根据您的需求配置堆栈大小、堆大小、链接脚本等。 8. 完成配置后,点击“OK”按钮保存更改并关闭选项对话框。 9. 现在您可以编译和调试您的工程了。选择“Build”菜单中的“Make”选项编译工程。如果您需要调试工程,您可以选择“Debug”菜单中的“Start Without Download”选项启动调试会话。 请注意,具体的环境配置步骤可能会根据您的具体需求和目标设备而有所不同。上述步骤仅作为一般指南,您可能需要参考IAR Embedded Workbench的用户手册或官方文档以获取更详细的配置信息。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值