UD-GS01治具の試作プログラムです
Dependencies: mbed nRF24L01P SDFileSystem
Goto_UD-GS01.cpp
- Committer:
- rgoto
- Date:
- 2020-12-10
- Revision:
- 8:3369eef8f9e1
- Parent:
- 7:bad081470837
- Child:
- 9:086fae0bd5f8
File content as of revision 8:3369eef8f9e1:
//受信用と送信用を一つにする!ボタンで切り替え(元のプログラムは44で、44-2を貼り付ける) #include "mbed.h" #include "nRF24L01P.h" //#include <assert.h> //#include <stdbool.h> #include "SDFileSystem.h" Serial pc(PA_2, PA_3); //ここはpcとケーブルでつないだときにシリアル通信させてたところだから、ここから牛のUARTにつなぐだけで大丈夫なはず。→ここは元々ST基板のPC部分(パキッと折れそうな方)との通信用に使われてるから他のシリアルは無理らしい。 Serial UDGS01(PA_0, PA_1); // UD-GS01とのシリアル通信用にUARTピンを新たに定義。 Ticker interrput; #define TRANSFER_SIZE 32 int out_flg = 0; int rcv_flg = 0; int snd_flg = 0; char txData1[TRANSFER_SIZE]; char txData2[TRANSFER_SIZE]; /*char型で一文字ずつ配列に入れていき、表示する。char型は一つ1バイトなので、32個ずつ溜まったら送るようにする。*/ int txDataIdx = 0; int txDataCnt=0; char rxData1[TRANSFER_SIZE]; char rxData2[TRANSFER_SIZE]; /*char型で一文字ずつ配列に入れていき、表示する。char型は一つ1バイトなので、32個ずつ溜まったら送るようにする。*/ int rxDataIdx = 0; int rxDataCnt=0; int i=0; int which=0; int bufferidx=0; nRF24L01P my_nrf24l01p(D11, D12, D13, D10, D9,D8); // mosi, miso, sck, csn, ce, irq void timer(){ /*タイマー割り込みによるSPEAKER out*/ uint16_t ain; if(rcv_flg == 1) { pc.printf("%s", &rxData2[rxDataIdx]); rxDataIdx++; if (rxDataIdx >= TRANSFER_SIZE) rxDataIdx=0; rcv_flg = 0; } if(rcv_flg == 2) { pc.printf("\r\n"); rcv_flg = 0; } } void recieve(){ if(UDGS01.readable()){ // ...read the data into the receive buffer txData1[txDataIdx] = UDGS01.getc(); //getcharだと、PCからのキーボード入力という標準コンソール?のやつだからだめらしい // pc.printf("tx[%d] = %s", txDataIdx, &txData[txDataIdx]); txDataIdx++; /* if(txData1[txDataIdx] == 0x0A){ //改行(0x0A)があればその時点で送りたい memcpy(txData2, txData1, txDataIdx); txDataIdx = 0; snd_flg = 2; */ }else if (txDataIdx == TRANSFER_SIZE) {//最初の32回 memcpy(txData2, txData1, TRANSFER_SIZE); txDataIdx=0; snd_flg = 1; } // } } //for文でrxData1とrxData2を比較して、まったく同じ中身なら0,違えば1を返す関数のつもり //bool rxData_equal(char* rxData1,/* size_t size1,*/ const char* rxData2/*, size_t size2*/) //{ // assert(rxData1 != NULL); // assert(rxData2 != NULL); // assert(size1 != 0); // assert(size2 != 0); // 要素数が違うなら、絶対に一致しない // if (size1 != size2) { // return false; // } // for (i = 0; i < TRANSFER_SIZE; ++i) { // if (rxData1[i] != rxData2[i]) { // return false; // } // } // return true; //} int main() { pc.baud(115200); UDGS01.baud(115200); my_nrf24l01p.powerUp(); my_nrf24l01p.setRfFrequency(NRF24L01P_MIN_RF_FREQUENCY);//2400-2525 my_nrf24l01p.setRfOutputPower(NRF24L01P_TX_PWR_MINUS_12_DB);//mAX 0 -6 -12 -18 my_nrf24l01p.setAirDataRate(NRF24L01P_DATARATE_1_MBPS);//250k,1000,2000K // Display the (default) setup of the nRF24L01+ chip pc.printf( "nRF24L01+ Frequency : %d MHz\r\n", my_nrf24l01p.getRfFrequency() ); pc.printf( "nRF24L01+ Output power : %d dBm\r\n", my_nrf24l01p.getRfOutputPower() ); pc.printf( "nRF24L01+ Data Rate : %d kbps\r\n", my_nrf24l01p.getAirDataRate() ); pc.printf( "nRF24L01+ TX Address : 0x%010llX\r\n", my_nrf24l01p.getTxAddress() ); // pc.printf( "nRF24L01+ RX Address : 0x%010llX\r\n", my_nrf24l01p.getRxAddress() ); pc.printf( "Type keys to test transfers:\r\n (transfers are grouped into %d characters)\r\n", TRANSFER_SIZE ); my_nrf24l01p.setTransferSize( TRANSFER_SIZE );//mAX 32 my_nrf24l01p.setReceiveMode(); my_nrf24l01p.enable(); wait_ms(100); // my_nrf24l01p.write( NRF24L01P_PIPE_P0, (char*)rxData,1);//dummy interrput.attach(&timer, 0.5);//100 usec 10Khz UDGS01.attach(recieve,Serial::RxIrq);//牛からのデータ受信したら割り込み発生してrecieveを呼び出す // my_nrf24l01p.flush_rx_fifo(); while(1){ if ( my_nrf24l01p.readable(NRF24L01P_PIPE_P0) ) { //受信可能であれば rxDataCnt = my_nrf24l01p.read( NRF24L01P_PIPE_P0, (char*)(rxData1),TRANSFER_SIZE ); if(/*rxData_equal(rxData1, rxData2)==*/1){ //rxData1で読んだ値が以前コピーしたのと完全一致なら0, 違えば1を出す。 memcpy(rxData2, rxData1, TRANSFER_SIZE); SDFileSystem *sd = new SDFileSystem(PB_15, PB_14, PB_13, PB_11, "sd", NC, SDFileSystem::SWITCH_NONE, 20000000); //SDカードのやつ mosi, miso, sclk, cs, name, card detect, sw type, freq FILE *fp; fp = fopen("/sd/log/log(UD-GS01).txt", "a"); fputs(rxData2, fp); wait(1); fclose(fp); rcv_flg = 1; } /*else{ rcv_flg = 2; } */ } if (snd_flg==1) {//最初のバッファ snd_flg=0; my_nrf24l01p.write( NRF24L01P_PIPE_P0, (char *)txData2 , TRANSFER_SIZE ); // memset(txData2, 0, TRANSFER_SIZE/*何バイト書き込むか*/); // for(i=0; i>32; i++){ // pc.printf("tx[%d] = %s", 30, txData[30]); // } pc.putc('1'); wait(1); }else if (snd_flg==2) {//後半のバッファ snd_flg=0; my_nrf24l01p.write( NRF24L01P_PIPE_P0, (char*)txData2 , TRANSFER_SIZE ); pc.putc('2'); wait(1); } } //一番最初のwhileの} }