1. 程式人生 > >keil編譯出錯關於__use_no_semihosting_swi的使用

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