デバイスがあり、デバッグの目的でprintf関数を使用してメッセージをIDEに送信したいと考えています。セットアップ:デバッグ時にIDEでprintfメッセージを表示する
ARMのCortex-M3デバイスIはthis linkで利用可能な命令が見ることができるように続いてきた
ULINK2インタフェース
uVision4 IDE
"Debug(printf)Viewer"内のメッセージ。 まず私はITMインターフェイスに出力をリダイレクトするために、「retarget.cに収録」ファイルを変更:
#include <stdio.h>
#include <rt_misc.h>
#pragma import(__use_no_semihosting_swi)
// Para utilização do saida de debug através do ULINK2
#define ITM_Port8(n) (*((volatile unsigned char *)(0xE0000000+4*n)))
#define ITM_Port16(n) (*((volatile unsigned short*)(0xE0000000+4*n)))
#define ITM_Port32(n) (*((volatile unsigned long *)(0xE0000000+4*n)))
#define DEMCR (*((volatile unsigned long *)(0xE000EDFC)))
#define TRCENA 0x01000000
struct __FILE { int handle; /* Add whatever you need here */ };
FILE __stdout;
// Escreve caractere na porta de Debug
int sendchar (int ch) {
if (DEMCR & TRCENA) {
while (ITM_Port32(0) == 0);
ITM_Port8(0) = ch;
}
return(ch);
}
int fputc(int ch, FILE *f) {
return (sendchar(ch));
}
int ferror(FILE *f) {
/* Your implementation of ferror */
return EOF;
}
void _ttywrch(int ch) {
sendchar(ch);
}
void _sys_exit(int return_code) {
label: goto label; /* endless loop */
}
は、それから私は、指示に従って、uVision4でIMTを設定した:
プロジェクトのコンパイル良い。アプリケーションをデバイスにダウンロードし、uVision4でデバッグセッションを開始します。私はprintfをメイン関数の簡単なメッセージで、システムの初期化直後に使用しようとしますが、Debug Viewerは空のままです。 "sendchar"関数にブレークポイントintを入れました。すべての行が期待どおりにヒットしていることがわかります。
ULINK2とuVision4でprintfを使用した人は誰ですか?誰も私がデバッグビューアウィンドウで何も出力を見ることができない理由を手掛かりにしていますか?
私は単純に "retarget.cに収録" で、その結果、既存のITMの機能を使用しようとした
UPDATEは:
int fputc(int ch, FILE *f) {
return (ITM_SendChar((uint32_t)ch));
}
それにもかかわらず、何も出力はデバッグビューアに表示されません。 printf関数呼び出しをステップ実行すると、IDEの一番下に "Trace:Data Overflow"が表示され、続いて "Trace:Communication Error"が表示されます。
そして、もう一つのチェックCoreClock前に、1が使用されている場合、 'HSE_VALUE'は、実際の発振周波数に設定されていることを確認してください。 'DBGMCU_CR *((揮発性の符号なし*)0xE0042004)= 0x00000020;の' TRACE_IOEN'ビットを設定することも重要であることが判明しました。 –