keil编译出错关于__use_no_semihosting_swi的使用
__use_no_semihosting_swi,即不使用半主機模式,防止程序進入軟件中斷。 1.在嵌入式程序編譯時如果出現printf、fopen、fclose等文件操作,因程序中并沒有對這些函數的底層實現,使得設備運行時會進入軟件中斷BAEB處,這時就需要__use_no_semihosting_swi這 個聲明,使程序遇到這些文件操作函數時不停在此中斷處,具體操作如下,將下列程序加入你的工程中: #pragma import(__use_no_semihosting_swi) #pragma import(_main_redirection) const char __stdin_name[150]; const char __stdout_name[150]; const char __stderr_name[150]; typedef int FILEHANDLE; //重寫標準庫函數,這時printf、fopen、fclose等文件操作函數運行時就會調用你的重寫函數,這些重寫函數只是幾個簡單的例子,并沒有重寫所有的文件操作函數 void _sys_exit(int status) { while(1); } FILEHANDLE _sys_open(const char *name, int openmode) { return 0; } int _sys_close(FILEHANDLE fh) { return 0; } int _sys_write(FILEHANDLE fh, const unsigned char *buf, unsigned len, int mode) { return 0; } int _sys_read(FILEHANDLE fh, unsigned char*buf, unsigned len, int mode) { return 0; } int _sys_istty(FILEHANDLE fh) { return 0; } int _sys_seek(FILEHANDLE fh, long pos) { return 0; } int _sys_ensure(FILEHANDLE fh) { return 0; } long _sys_flen(FILEHANDLE fh) { return 0; } int _sys_tmpnam(char *name, int fileno, unsigned maxlength) { return 0; } void _ttywrch(int ch) { }
time_t time(time_t *t) {return 0; } int remove(const char *filename) {return 0; }char *_sys_command_string(char *cmd, int len) {return 0; }clock_t clock(void) {return 0; } 若出現如下編譯錯誤:Error: L6915E: Library reports error: __use_no_semihosting_swi was requested, but _ttywrch was referenced,此時你只需重寫_ttywrch 函數即可void _ttywrch(int ch){}。2.__use_no_semihosting_swi也常用于對printf的重定向,通常是重定向到串口輸出,這時只需在1中的重寫函數中加入:int fputc(int ch, FILE *f) { uart_send_char(ch);//你的串口發送字符函數?? return ch; }這樣即可。---------------------本文來自 zlm_space 的CSDN 博客 ,全文地址請點擊:https://blog.csdn.net/zlm_space/article/details/50171929?utm_source=copy總結
以上是生活随笔為你收集整理的keil编译出错关于__use_no_semihosting_swi的使用的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: STM32之中断与事件---中断与事件的
- 下一篇: STM32 串口 #pragma imp