LPC1114FN28で同一ポート群から別々にデジタル出力する場合に出力波形が乱れることがあります。この現象を確認するためのテストプログラムです。

Dependencies:   mbed

LPC1114FN28 でのデジタル出力について

LPC1114FN28でデジタル出力をする場合、同一ポート群に対して、個別出力をすると他方の出力に影響を与えます。

<サンプルプログラムの説明>
PIO1_xのポート群(dp13(PIO1_4),dp14(PIO1_5))で確認しました
Tickerで0.1ms周期割り込みでレベル反転(dp14)させ、main()でdp13から固定レベル出力させます。
main()でLo出力しているとき、割り込みで出力させているパルスが乱れます。

main()でHi出力させているときは、パルスは乱れません。
プログラムの 19行目の"NG_LEVEL"define定義を無効にするとこのプログラムになります。

dp13(PIO1_4)をdp1(PIO0_8)の別ポート群にするとパルスは乱れません。
プログラムの18行目の"NG_PORT"define定義を無効にするとこのプログラムになります。

LPC1768(青mbed)では、上記の様な現象は発生しません(P2xポート群(P21(P2.5),P22(P2.4)で確認)
プログラムの17行目の"LPC1114FN28"define定義を無効にして、コンパイラの設定をLPC1768にするとこのプログラムになります。

Files at this revision

API Documentation at this revision

Comitter:
suupen
Date:
Mon Oct 28 12:10:33 2013 +0000
Parent:
0:01c0ed9b80c5
Commit message:
I described a bug workaround for this problem.
;

Changed in this revision

main.cpp Show annotated file Show diff for this revision Revisions of this file
diff -r 01c0ed9b80c5 -r bf75eed34e82 main.cpp
--- a/main.cpp	Sat Oct 26 09:28:02 2013 +0000
+++ b/main.cpp	Mon Oct 28 12:10:33 2013 +0000
@@ -8,8 +8,17 @@
 
 main()でHi出力させているときは、パルスは乱れません。
 dp13(PIO1_4)をdp1(PIO0_8)の別ポート群にするとパルスは乱れません。
+mainでのパルス出力を割り込み禁止にするとパルスは乱れません。
+
+<結論>
+割り込みとmainの双方で同一ポート群へのデジタル出力をすると出力レベルが異常になる場合がある。
+これは、ポート出力処理のbit演算でメモリからの読み出し、書き込みが重複するためと思われる。
+回避方法は、mainルーチンでのデジタル出力時に割り込み禁止にすること。
+
 
 LPC1768(青mbed)では、上記の様な現象は発生しません(P2xポート群(P21(P2.5),P22(P2.4)で確認)
+
+131028 mainでの割り込みと結論を追記
 */
 
 #include "mbed.h"
@@ -17,6 +26,7 @@
 #define LPC1114FN28         // 無効時LPC1768設定になります
 #define NG_PORT             // 無効時、mainでの出力を別ポート群にします
 #define NG_LEVEL            // 無効時、mainでの出力をHiにします
+//#define OK_IRQ              // 有効時mainでの出力時に割り込み禁止にする(波形の乱れは無くなる)
 
 #ifdef LPC1114FN28
 
@@ -47,7 +57,13 @@
 
         while(1) {
 #ifdef NG_LEVEL
+#ifdef OK_IRQ 
+           __disable_irq();     // Disable Interrupts
+#endif // OK_IRQ
             out = 0; 
+#ifdef OK_IRQ
+            __enable_irq();     // Enable Interrupts
+#endif // OK_IRQ
 #else // ~NG_LEVEL
           out = 1; 
 #endif // NG_LEVEL