当前位置: 首页 > article >正文

STM32开发避坑指南:KEIL中__use_no_semihosting报错的终极解决方案

STM32开发避坑指南KEIL中__use_no_semihosting报错的终极解决方案在嵌入式开发领域STM32凭借其出色的性能和丰富的外设资源成为众多开发者的首选。然而在使用KEIL MDK进行开发时不少开发者都会遇到一个令人头疼的报错__use_no_semihosting was requested, but _ttywrch was referenced。这个看似简单的编译错误往往会让初学者陷入困境甚至影响整个项目的进度。1. 问题根源深度解析1.1 半主机模式与标准库的纠葛这个报错的本质是KEIL的标准库与开发者设置之间的冲突。当我们在代码中声明#pragma import(__use_no_semihosting)时实际上是告诉编译器我不需要使用半主机模式。然而标准库中的某些函数如_ttywrch却仍然试图调用半主机功能这就导致了矛盾的报错。半主机模式Semihosting是一种让目标板通过调试接口与主机通信的机制常用于调试信息的输出。但在实际产品开发中我们通常会禁用这个功能原因有三性能开销半主机模式会显著增加代码执行时间资源占用需要额外的代码空间支持依赖性必须连接调试器才能正常工作1.2 常见错误处理方法的局限性网上常见的解决方案主要有两种方法一勾选Use MicroLIB选项方法二重定义fputc函数但根据实际测试这两种方法都存在明显缺陷解决方法优点缺点使用微库简单快捷可能导致其他库函数不可用重定义fputc针对性强无法解决_ttywrch引用问题特别是对于使用正点原子开发板的用户这些方法往往不能彻底解决问题因为他们的代码库通常已经包含了特定的串口初始化配置。2. 全面解决方案实施2.1 完整代码实现方案以下是经过验证的完整解决方案适用于大多数STM32系列芯片#if 1 #pragma import(__use_no_semihosting) // 标准库需要的支持函数结构体 struct __FILE { int handle; }; FILE __stdout; // 解决_ttywrch引用问题 void _ttywrch(int ch) { ch ch; // 空实现仅为了满足链接要求 } // 避免半主机模式依赖 void _sys_exit(int x) { x x; // 空实现 } // 重定向printf到串口 int fputc(int ch, FILE *f) { while(!(USART1-SR USART_SR_TXE)); // 等待发送缓冲区空 USART1-DR (ch 0xFF); return ch; } #endif注意这段代码需要放在main.c文件中且确保在包含stdio.h之前定义。USART1应根据实际使用的串口进行修改。2.2 分步实施指南确认硬件连接检查开发板串口连接是否正确确认使用的USART外设与代码一致代码集成步骤将上述代码块复制到main.c文件顶部确保USART初始化代码已正确配置在KEIL选项中取消勾选Use MicroLIB编译验证清理项目后重新编译如果仍有警告可忽略与半主机相关的链接警告3. 进阶优化与调试技巧3.1 多串口支持方案对于需要使用多个串口的项目可以扩展实现如下// 根据条件编译选择不同串口 #ifdef USE_USART1 #define DEBUG_USART USART1 #elif defined USE_USART2 #define DEBUG_USART USART2 #endif int fputc(int ch, FILE *f) { while(!(DEBUG_USART-SR USART_SR_TXE)); DEBUG_USART-DR (ch 0xFF); return ch; }3.2 性能优化建议缓冲发送使用DMA或缓冲区减少CPU占用条件编译通过宏控制调试输出速率匹配确保波特率与终端软件设置一致4. 常见问题排查4.1 问题仍未解决的情况如果按照上述方法仍然报错请检查库版本兼容性确保使用的标准库与KEIL版本匹配链接顺序尝试调整库文件的链接顺序启动文件检查启动文件中是否包含不必要的半主机代码4.2 其他相关错误处理有时可能还会遇到类似问题如__use_no_semihosting_swi was requested, but _sys_exit was referenced解决方法是在代码中添加_sys_exit的空实现如前文所示。5. 工程配置最佳实践5.1 KEIL项目设置要点Target选项取消勾选Use MicroLIB设置正确的芯片型号C/C选项添加必要的预定义宏优化等级建议使用-O1平衡代码大小和速度Linker配置检查分散加载文件是否正确确保没有重复定义的符号5.2 版本控制建议对于团队开发项目建议将以下内容纳入版本控制固定的KEIL版本统一的库文件版本项目配置文件的备份在实际项目中我发现最稳妥的做法是在项目初期就建立完整的开发环境配置文档记录所有必要的设置和依赖项版本。这样当新成员加入或更换开发电脑时可以快速重建一致的开发环境避免因环境差异导致的各类奇怪问题。

相关文章:

STM32开发避坑指南:KEIL中__use_no_semihosting报错的终极解决方案

STM32开发避坑指南:KEIL中__use_no_semihosting报错的终极解决方案 在嵌入式开发领域,STM32凭借其出色的性能和丰富的外设资源,成为众多开发者的首选。然而,在使用KEIL MDK进行开发时,不少开发者都会遇到一个令人头疼的…...

动画测试与调试完全手册:animation-samples项目中的自动化测试实践

动画测试与调试完全手册:animation-samples项目中的自动化测试实践 【免费下载链接】animation-samples Multiple samples showing the best practices in animation on Android. 项目地址: https://gitcode.com/gh_mirrors/an/animation-samples animation-…...

STM32双路直流电机PWM驱动与霍尔编码器闭环控制

1. 项目概述DCMotorDrive 是专为 RenBuggy 平台设计的双路直流电机驱动固件模块,其核心目标是实现对两台独立直流电机的高精度 PWM 调速控制,并集成霍尔传感器反馈通道,支持实时速度与位移闭环。该模块并非通用电机驱动芯片(如 L2…...

Monolog Bridge 高级用法:FingersCrossed策略与HTTP状态码激活机制完全指南 [特殊字符]

Monolog Bridge 高级用法:FingersCrossed策略与HTTP状态码激活机制完全指南 🚀 【免费下载链接】monolog-bridge Provides integration for Monolog with various Symfony components 项目地址: https://gitcode.com/gh_mirrors/mo/monolog-bridge …...

ComfyUI-Impact-Pack完整指南:3步掌握AI图像增强的强大工具包

ComfyUI-Impact-Pack完整指南:3步掌握AI图像增强的强大工具包 【免费下载链接】ComfyUI-Impact-Pack Custom nodes pack for ComfyUI This custom node helps to conveniently enhance images through Detector, Detailer, Upscaler, Pipe, and more. 项目地址: h…...

Le Git Graph分支管理:动态加载和筛选分支提交的终极指南

Le Git Graph分支管理:动态加载和筛选分支提交的终极指南 【免费下载链接】le-git-graph Browser extension to add git graph to GitHub website. 项目地址: https://gitcode.com/gh_mirrors/le/le-git-graph Le Git Graph是一款强大的浏览器扩展&#xff0…...

MKDV4GCL-ABB嵌入式存储芯片在智能物联网设备中的关键应用解析

1. 为什么物联网设备需要专用存储芯片? 第一次拆解智能家居设备时,我发现很多厂商都在用TF卡扩展存储。但实际使用三个月后,问题就来了——频繁读写导致卡片损坏,设备不断报存储错误。这就是典型选错存储方案的后果。物联网设备对…...

一文读懂10英寸平板尺寸:从屏幕比例到实际机身尺寸

在平板电脑市场中,"10英寸"这一规格始终占据着黄金地位。但当我们搜索"平板10寸多大长和宽"时,得到的答案往往模糊不清。作为行业观察者,我将为您深度解析10英寸平板尺寸的行业标准、设计逻辑及选购策略,带您…...

Horizon 8部署避坑指南:从AD域控、SQL Server配置到Connection Server调优的12个关键检查点

Horizon 8部署实战:12个关键检查点与深度排错手册 在虚拟桌面基础设施(VDI)的部署过程中,每个环节都可能成为影响最终用户体验的关键因素。本文将聚焦VMware Horizon 8部署中最容易出错的12个关键节点,从AD域控配置到C…...

龙芯k - 走马观碑组ST驱动移植傺

正文 异步/等待解决了什么问题? 在传统同步I/O操作中(如文件读取或Web API调用),调用线程会被阻塞直到操作完成。这在UI应用中会导致界面冻结,在服务器应用中则造成线程资源的浪费。async/await通过非阻塞的异步操作解…...

别再只用localhost了!手把手教你用路由侠把本地宝塔面板‘搬’到公网(Windows版)

突破局域网限制:Windows下宝塔面板安全外网访问实战指南 你是否遇到过这样的困境?——在本地环境调试得心应手的项目,当需要向异地同事演示或临时交付客户预览时,却因为网络隔离而束手无策。传统解决方案要么要求部署到正式服务器…...

ComfyUI InstantID:如何实现AI绘图中的精准人脸控制?

ComfyUI InstantID:如何实现AI绘图中的精准人脸控制? 【免费下载链接】ComfyUI_InstantID 项目地址: https://gitcode.com/gh_mirrors/co/ComfyUI_InstantID ComfyUI InstantID是一款专为ComfyUI设计的原生人脸特征控制插件,它无需依…...

Qtile社区贡献指南:从新手到核心贡献者的完整教程

Qtile社区贡献指南:从新手到核心贡献者的完整教程 【免费下载链接】qtile :cookie: A full-featured, hackable tiling window manager written and configured in Python (X11 Wayland) 项目地址: https://gitcode.com/gh_mirrors/qt/qtile Qtile是一个功能…...

Laravel WebSockets终极指南:本地与Redis频道管理器深度对比

Laravel WebSockets终极指南:本地与Redis频道管理器深度对比 【免费下载链接】laravel-websockets Websockets for Laravel. Done right. 项目地址: https://gitcode.com/gh_mirrors/la/laravel-websockets Laravel WebSockets是一款为Laravel框架打造的高效…...

终极指南:ECCV2022-RIFE在边缘设备上的快速部署实践

终极指南:ECCV2022-RIFE在边缘设备上的快速部署实践 【免费下载链接】ECCV2022-RIFE ECCV2022 - Real-Time Intermediate Flow Estimation for Video Frame Interpolation 项目地址: https://gitcode.com/gh_mirrors/ec/ECCV2022-RIFE 在当今视频处理领域&am…...

Go-restful容器管理终极指南:多服务部署与负载均衡完整教程

Go-restful容器管理终极指南:多服务部署与负载均衡完整教程 【免费下载链接】go-restful package for building REST-style Web Services using Go 项目地址: https://gitcode.com/gh_mirrors/go/go-restful Go-restful是一个强大的Go语言RESTful Web服务框架…...

技术团队领导一对一沟通指南:打造高效人员管理与反馈机制

技术团队领导一对一沟通指南:打造高效人员管理与反馈机制 【免费下载链接】tlroadmap Тимлид – это ❄️, потому что в каждой компании он уникален и неповторим. 项目地址: https://gitcode.com/gh_m…...

Vest框架性能优化:10个技巧提升验证效率

Vest框架性能优化:10个技巧提升验证效率 【免费下载链接】vest Vest ✅ Declarative validations framework 项目地址: https://gitcode.com/gh_mirrors/ve/vest Vest是一个声明式验证框架,能够帮助开发者轻松构建高效的表单验证逻辑。随着应用规…...

三步搭建QQ签名服务:Windows环境零代码部署指南

三步搭建QQ签名服务:Windows环境零代码部署指南 【免费下载链接】Qsign Windows的一键搭建签名api 项目地址: https://gitcode.com/gh_mirrors/qs/Qsign 问题引入:为什么需要自建QQ签名服务? 在开发QQ相关应用时,签名验证…...

FastAPI WebSocket完整配置指南:实现实时通信的终极教程

FastAPI WebSocket完整配置指南:实现实时通信的终极教程 【免费下载链接】fastapi FastAPI framework, high performance, easy to learn, fast to code, ready for production 项目地址: https://gitcode.com/GitHub_Trending/fa/fastapi FastAPI WebSocket…...

WebThings Gateway数据库设计与用户配置管理:深入理解网关数据持久化机制

WebThings Gateway数据库设计与用户配置管理:深入理解网关数据持久化机制 【免费下载链接】gateway WebThings Gateway - a self-hosted web application for monitoring and controlling a building over the web 项目地址: https://gitcode.com/gh_mirrors/gat/…...

PF4J高级特性解析:从依赖管理到安全包装器的完整指南

PF4J高级特性解析:从依赖管理到安全包装器的完整指南 【免费下载链接】pf4j Plugin Framework for Java (PF4J) 项目地址: https://gitcode.com/gh_mirrors/pf/pf4j PF4J(Plugin Framework for Java)是一个轻量级、企业级的Java插件框…...

WEF部署完全手册:在Linux系统上配置专业级Wi-Fi测试环境

WEF部署完全手册:在Linux系统上配置专业级Wi-Fi测试环境 【免费下载链接】WEF Wi-Fi Exploitation Framework 项目地址: https://gitcode.com/gh_mirrors/we/WEF Wi-Fi Exploitation Framework(WEF)是一款功能强大的Wi-Fi安全测试工具…...

SpiceAI Cayenne数据加速器:下一代列式存储格式的终极指南

SpiceAI Cayenne数据加速器:下一代列式存储格式的终极指南 【免费下载链接】spiceai A portable accelerated SQL query, search, and LLM-inference engine, written in Rust, for data-grounded AI apps and agents. 项目地址: https://gitcode.com/gh_mirrors/…...

从SST到MLD:手把手教你用xarray处理CMEMS海洋数据,生成月平均图与全局年平均场

从SST到MLD:xarray实战CMEMS海洋数据处理与可视化全流程 海洋数据科学正经历一场由工具革新驱动的效率革命。在哥白尼海洋环境监测服务(CMEMS)等开放数据平台的推动下,获取全球海洋参数已不再是瓶颈,真正的挑战转向如何…...

BiliBiliCCSubtitle:智能解析引擎驱动的B站字幕处理效率革命

BiliBiliCCSubtitle:智能解析引擎驱动的B站字幕处理效率革命 【免费下载链接】BiliBiliCCSubtitle 一个用于下载B站(哔哩哔哩)CC字幕及转换的工具; 项目地址: https://gitcode.com/gh_mirrors/bi/BiliBiliCCSubtitle 在数字内容产业高速发展的今天&#xff0…...

4种突破数字内容壁垒的技术方案:面向研究者与创作者的开源工具指南

4种突破数字内容壁垒的技术方案:面向研究者与创作者的开源工具指南 【免费下载链接】douyin-downloader A practical Douyin downloader for both single-item and profile batch downloads, with progress display, retries, SQLite deduplication, and browser fa…...

search-engine-optimization内容创作黄金法则:如何写出搜索引擎喜爱的文章

search-engine-optimization内容创作黄金法则:如何写出搜索引擎喜爱的文章 【免费下载链接】search-engine-optimization 🔍 A helpful checklist/collection of Search Engine Optimization (SEO) tips and techniques. 项目地址: https://gitcode.co…...

3分钟解锁B站缓存视频:m4s-converter让你真正拥有数字收藏

3分钟解锁B站缓存视频:m4s-converter让你真正拥有数字收藏 【免费下载链接】m4s-converter 一个跨平台小工具,将bilibili缓存的m4s格式音视频文件合并成mp4 项目地址: https://gitcode.com/gh_mirrors/m4/m4s-converter 你是否曾在B站缓存了珍贵的…...

抖音下载器:告别录屏时代,3步打造你的专属内容库

抖音下载器:告别录屏时代,3步打造你的专属内容库 【免费下载链接】douyin-downloader A practical Douyin downloader for both single-item and profile batch downloads, with progress display, retries, SQLite deduplication, and browser fallback…...