明石高専ロボ研 drum

Dependencies:   mbed

Revision:
2:141358d84ff4
Parent:
0:ca84ed7518f5
Child:
3:28c77df7c0b6
--- a/scrp_slave.cpp	Thu Jan 02 12:55:09 2020 +0000
+++ b/scrp_slave.cpp	Fri Jan 03 02:37:48 2020 +0000
@@ -10,13 +10,13 @@
 
 ScrpSlave::ScrpSlave(PinName TX1,PinName RX1,PinName REDE1,uint32_t addr):address_(addr){
     mode_ = 1;
-    rede_ = new DigitalOut(REDE1);
+    rede_ = new DigitalOut(REDE1,0);
     init(TX1,RX1);
 }
 
 ScrpSlave::ScrpSlave(PinName TX1,PinName RX1,PinName TX2,PinName RX2,uint32_t addr):address_(addr){
     mode_ = 2;
-    serial_[1] = new BufferedSerial(TX2,RX2);
+    serial_[1] = new Serial(TX2,RX2);
     serial_[1]->baud(115200);
     serial_[1]->attach(callback(this,&ScrpSlave::port2),Serial::RxIrq);
     init(TX1,RX1);
@@ -24,16 +24,21 @@
 
 ScrpSlave::ScrpSlave(PinName TX1,PinName RX1,PinName REDE1,PinName TX2,PinName RX2,uint32_t addr):address_(addr){
     mode_ = 3;
-    rede_ = new DigitalOut(REDE1);
-    serial_[1] = new BufferedSerial(TX2,RX2);
+    rede_ = new DigitalOut(REDE1,0);
+    serial_[1] = new Serial(TX2,RX2);
     serial_[1]->baud(115200);
     serial_[1]->attach(callback(this,&ScrpSlave::port2),Serial::RxIrq);
     init(TX1,RX1);
 }
 
 void ScrpSlave::init(PinName TX,PinName RX){
-    timeout_ = 10;
-    serial_[0] = new BufferedSerial(TX,RX);
+    timeout_ = 500;
+    for(int i = 0;i<2;i++){
+        wait_data_[i] = false;
+        stx_flag_[i] = false;
+        id_ok_[i] = false;
+    }
+    serial_[0] = new Serial(TX,RX);
     serial_[0]->baud(115200);
     serial_[0]->attach(callback(this,&ScrpSlave::port1),Serial::RxIrq);
     flash_ = new FlashIAP;
@@ -46,7 +51,7 @@
         send(111,111,111);
         my_id_ = 10;
     }
-    for(int i = 1;i<255;++i){
+    for(int i = 1;i<256;++i){
         procs_[i] = NULL;
     }
 }
@@ -86,127 +91,140 @@
     uint8_t tx_dataL = tx_data;
     uint8_t tx_dataH = tx_data >> 8;
     uint8_t tx_sum = id + cmd + tx_dataL + tx_dataH;
+    Timer out;
 
-    const uint8_t data[] = {DMY, STX, id, cmd, tx_dataL, tx_dataH, tx_sum, DMY};
+    const uint8_t data[8] = {DMY, STX, id, cmd, tx_dataL, tx_dataH, tx_sum, DMY};  
     if(!serial_[port]->writeable()){
         return -1;
     }
+    wait_data_[port] = true;//データ返信待ち
     if(mode_%2 == 1 && port == 0){
         rede_->write(1);
     }
-    serial_[port]->write(data,8);
-    wait_ms(1);//送信待ち
+    for(int i = 0;i < 8;i++){
+        serial_[port]->putc(data[i]);
+        while(!serial_[port]->writeable());
+    }  
     if(mode_%2 == 1 && port == 0){
         rede_->write(0);
     }
-            
-    int i = 0;
-    bool received = false;
-    bool stxflag = false;
-    uint8_t getdata;
-    uint8_t rx[5]={},sum = 0;
-    Timer out;
+    
+    out.reset();
     out.start();
-    while(out.read_ms() < timeout_ && !received){
-        while(serial_[port]->readable() > 0){
-            getdata = serial_[port]->getc();
-            if(!stxflag && getdata == STX){
-                stxflag = true;
-                continue;
-            }
-            if(stxflag){
-                rx[i] = getdata;
-                sum += rx[i++];
-            }
-            if(i > 4){/*
-                uint8_t sum = 0;
-                for(int j = 0;j<4;j++){
-                    sum += rx[j];
-                }*/
-                if(sum == rx[4]){
-                    received = true;
-                }
-                break;
-            }
+    while(wait_data_[port]){
+        if(out.read_ms() > timeout_){
+           rx_data_[port] = -1;
+           wait_data_[port] = false;
         }
     }
     out.stop();
-    if(!received){
-        return -1;
-    }
-    return (int16_t)(rx[2] + ((int16_t)rx[3] << 8));
+    return rx_data_[port];
 }
 
 void ScrpSlave::check(int port){
-    uint8_t rx_cmd;
-    int16_t rx_data;
-    bool received = false;
-    bool broadcast = false;
-    while(serial_[port]->readable() >= 6){
-        if(serial_[port]->getc() != STX)continue;
-        uint8_t rx_id = serial_[port]->getc();
-        uint8_t tmp_rx_cmd = serial_[port]->getc();
-        uint8_t tmp_rx_dataL = serial_[port]->getc();
-        uint8_t tmp_rx_dataH = serial_[port]->getc();
-        uint8_t rx_sum = serial_[port]->getc();
-        
-        uint8_t sum = rx_id + tmp_rx_cmd + tmp_rx_dataL + tmp_rx_dataH;
-        if(sum != rx_sum){
-            continue;
-        }
-        
-        if(rx_id == 255){
-            broadcast = true;
-        }else if(my_id_ == rx_id){
-            broadcast = false;
-        }else{
-            return;//break;
+    if(id_ok_[port]){
+        tmp_data_[port][data_count_[port]] = serial_[port]->getc();
+        data_count_[port]++;
+        if(data_count_[port] > 4){
+            stx_flag_[port] = false;//通信フラグクリア
+            id_ok_[port] = false;
+            
+            uint8_t sum = 0;
+            for(int i = 0;i<4;i++){
+                sum += tmp_data_[port][i];
+            }
+            if(sum != tmp_data_[port][4]){
+                return;
+            }
+            rx_data_[port] = (int16_t)(tmp_data_[port][2] + ((int16_t)tmp_data_[port][3] << 8));
+            if(wait_data_[port]){//データ返信待ち時
+                wait_data_[port] = false;
+                return;
+            }
+            uint8_t rx_cmd = tmp_data_[port][1];
+            bool broadcast = (tmp_data_[port][0] == 255);
+            
+            int tx_data = rx_data_[port];
+            if(rx_cmd == 0){//通信テスト
+            }else if(rx_cmd == 254){//id変更
+                uint8_t new_id = rx_data_[port];
+                my_id_ = new_id;
+                changeID(new_id);
+            }else if(rx_cmd == 253){//id確認
+                tx_data = my_id_;
+                rx_cmd = 250;
+                broadcast = false;
+            }else if(procs_[rx_cmd] == NULL || !procs_[rx_cmd](rx_data_[port],tx_data)){
+                return;
+            }
+            if(broadcast){
+                return;
+            }
+            uint8_t tx_dataL = tx_data;
+            uint8_t tx_dataH = tx_data >> 8;
+            uint8_t tx_sum = my_id_ + rx_cmd + tx_dataL + tx_dataH;
+    
+            const uint8_t data[8] = {DMY, STX, my_id_, rx_cmd, tx_dataL, tx_dataH, tx_sum, DMY};
+            memcpy(this->send_data_[port],data,8);
+            prime(port);
         }
-        
-        rx_cmd = tmp_rx_cmd;
-        rx_data = tmp_rx_dataL + ((int16_t)tmp_rx_dataH << 8);
-        received = true;
-    }
-    if(!received){
-        return;
-    }
-    int tx_data = rx_data;
-    if(rx_cmd == 0){//通信テスト
-        tx_data = rx_data;
-    }else if(rx_cmd == 254){//id変更
-        uint8_t new_id = rx_data;
-        my_id_ = new_id;
-        changeID(new_id);
-    }else if(rx_cmd == 253){//id確認
-        tx_data = my_id_;
-        rx_cmd = 250;
-        broadcast = false;
-    }else if(procs_[rx_cmd] == NULL || !procs_[rx_cmd](rx_data,tx_data)){
-        return;
-    }
-    if(broadcast){
-        return;
-    }
-    
-    uint8_t tx_dataL = tx_data;
-    uint8_t tx_dataH = tx_data >> 8;
-    uint8_t tx_sum = my_id_ + rx_cmd + tx_dataL + tx_dataH;
-    
-    const uint8_t data[] = {DMY, STX, my_id_, rx_cmd, tx_dataL, tx_dataH, tx_sum, DMY};
-    if(!serial_[port]->writeable()){
-        return;
-    }
-    if(mode_%2 == 1 && port == 0){
-        rede_->write(1);
-    }
-    serial_[port]->write(data,8);
-    wait_ms(1);//1ms待つ多分これだけで送信しきれる。
-    if(mode_%2 == 1 && port == 0){
-        rede_->write(0);
+    }else if(stx_flag_[port]){
+        uint8_t get_data = serial_[port]->getc();
+        if(get_data == my_id_ || get_data == 255){
+            id_ok_[port] = true;
+            tmp_data_[port][0] = get_data;
+            data_count_[port]++;
+        }else{
+            stx_flag_[port] = false;
+        }
+    }else if(serial_[port]->getc() == STX){
+        stx_flag_[port] = true;
+        data_count_[port] = 0;
+        id_ok_[port] = wait_data_[port];//データ返信待ち時はidチェック無し
     }
     return;
 }
 
+void ScrpSlave::data_send1(){
+    while(serial_[0]->writeable()){
+        if(data_count_[0] < 8){
+            serial_[0]->putc(send_data_[0][data_count_[0]++]);
+        }else{
+            serial_[0]->attach(NULL, Serial::TxIrq);
+            if(mode_%2 == 1){
+                rede_->write(0);
+            }
+            break;
+        }
+    }
+}
+
+void ScrpSlave::data_send2(){
+    while(serial_[1]->writeable()){
+        if(data_count_[1] < 8){
+            serial_[1]->putc(send_data_[1][data_count_[1]++]);
+        }else{
+            serial_[1]->attach(NULL, Serial::TxIrq);
+            break;
+        }
+    }
+}
+
+void ScrpSlave::prime(int port){
+    serial_[port]->attach(NULL, Serial::TxIrq);
+    data_count_[port] = 0;
+    if(port == 0){       
+        if(mode_%2 == 1){
+            rede_->write(1);
+        }
+        data_send1();
+        serial_[0]->attach(callback(this, &ScrpSlave::data_send1), Serial::TxIrq);
+    }else{
+        data_send2();
+        serial_[1]->attach(callback(this, &ScrpSlave::data_send2), Serial::TxIrq);
+    }
+}
+
 ScrpSlave::~ScrpSlave(){
     delete serial_[0];
     delete flash_;