Temporary Connector Reversed Version
Dependencies: UniGraphic mbed vt100
afero_poc15_180403R , J1 のピン配置を反転させたヴァージョンです。
Color2系を使用するためには以下のピンをジャンパで接続してください。
J1-D7 <-> J1-D0
J1-D6 <-> J1-D1
(調査中) また、こちらでテストした範囲では、
FRDM-KL25Z の V3.3 を、Modulo2 の VCC_3V3 ピンに接続してやる必要がありました。
尚、J1-D1, D0 を使用するために UART を無効にしているため
ログは表示されません。
TFTモジュールについて
aitendoのTFTモジュールはデフォルトでは8bit bus モードになっています。
半田のジャンパを変えて、SPIの設定にしてください。
サーミスタについて
POC1.5 では サーミスタは 25℃の時に抵抗値が 50.0kΩになる502AT-11 が
4.95kΩのプルアップ(実際は10kΩx2の並列)で使用されていました。
今回の試作では抵抗値が 10.0kΩの 103AT-11 が
5.1kΩのプルアップで使用されていますので、係数を合わせるために
SMTC502AT-11 のコンストラクタを
R0 = 10.0
R1 = 5.1
B = 3435
T0 = 298.15
で呼ぶように変更しました。
Diff: af_utils/mbedSPI.cpp
- Revision:
- 0:0b6732b53bf4
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/af_utils/mbedSPI.cpp Tue Apr 24 08:58:33 2018 +0000 @@ -0,0 +1,74 @@ +#include "mbed.h" +#include "vt100.h" +#include "afSPI.h" +#include "mbedSPI.h" + +#if defined (TARGET_KL25Z) || defined (TARGET_TEENSY3_1) + #ifndef SPI0_C1 + #define SPI0_C1 (*(uint8_t *)0x40076000) + #endif +#endif +/* +class mbedSPI : public afSPI { +public: + mbedSPI(PinName mosi, PinName miso, PinName sckl, PinName cs) ; + virtual void begin() ; + virtual void beginSPI() ; + virtual void endSPI() ; + virtual void transfer(char *bytes,int len) ; +private: + SPI _spi ; + DigitalOut _cs ; +} ; +*/ + +mbedSPI::mbedSPI(PinName mosi, PinName miso, PinName sckl, PinName cs) : + _spi(mosi, miso, sckl), _cs(cs, 1) +{ + _spi.format(8, 0) ; + _spi.frequency(1000000) ; /* 1MHz */ + +#if defined (TARGET_KL25Z) || defined (TARGET_TEENSY3_1) + #ifndef SPI0_C1 + #define SPI0_C1 (*(uint8_t *)0x40076000) + #endif +// SPI0_C1 |= 0x01 ; /* LSB First */ +// SPI0_C1 &= 0xFE ; /* MSB First */ +#endif + +} + +void mbedSPI::begin(void) +{ +} + +void mbedSPI::beginSPI() +{ +// printf("+") ; fflush(stdout) ; + _cs = 0 ; + SPI0_C1 |= 0x01 ; /* LSB First */ + wait_us(1) ; +} + +void mbedSPI::endSPI() +{ + _cs = 1 ; + SPI0_C1 &= 0xFE ; /* MSB First */ + wait_us(1) ; +// printf("-") ; fflush(stdout) ; +} + +/** + * on 17-Jan-2018 disable/enable irq added + * before and after of each _spi.writes + */ +void mbedSPI::transfer(char *bytes, int len) +{ + int i ; + for (i = 0 ; i < len ; i++ ) { + __disable_irq() ; // Disable Interrupts + bytes[i] = _spi.write(bytes[i]) ; + __enable_irq() ; // Enable Interrupts + } +} +