2013-02-15 12 views
6

デバイスがあり、デバッグの目的で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を設定した: enter image description here

プロジェクトのコンパイル良い。アプリケーションをデバイスにダウンロードし、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"が表示されます。

答えて

9

"トレース"設定の "CoreClock"フィールドに問題がありました。デバイスの時計と一致しませんでした。デバイスクロックに合わせて変更した後、正しい出力がデバッグビューアに表示されました。

いくつかの便利なリンク:

Trace status in uVision

How to configure the Trace, step by step

+0

そして、もう一つのチェックCoreClock前に、1が使用されている場合、 'HSE_VALUE'は、実際の発振周波数に設定されていることを確認してください。 'DBGMCU_CR *((揮発性の符号なし*)0xE0042004)= 0x00000020;の' TRACE_IOEN'ビットを設定することも重要であることが判明しました。 –

関連する問題