Leo Merel
/
APP4
APP4
Fork of rtos_basic by
main.cpp@22:e73831429e1c, 2018-10-23 (annotated)
- Committer:
- jpbaillargeon
- Date:
- Tue Oct 23 18:21:59 2018 +0000
- Revision:
- 22:e73831429e1c
- Parent:
- 21:846e642eb63e
- Child:
- 23:c704dd99d3f1
final
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
emilmont | 1:491820ee784d | 1 | #include "mbed.h" |
leomerel | 14:42a7d108b134 | 2 | #include "rtos.h" |
jpbaillargeon | 13:3c020f9bfdc7 | 3 | |
leomerel | 14:42a7d108b134 | 4 | DigitalOut dout(p18); |
leomerel | 14:42a7d108b134 | 5 | InterruptIn button(p5); |
leomerel | 15:872151771dec | 6 | DigitalOut led1(LED1); |
leomerel | 15:872151771dec | 7 | DigitalOut led2(LED2); |
leomerel | 15:872151771dec | 8 | DigitalOut led3(LED3); |
leomerel | 14:42a7d108b134 | 9 | DigitalOut flash(LED4); |
leomerel | 15:872151771dec | 10 | DigitalIn pin12(p12); |
leomerel | 12:cfa3dec9e9a3 | 11 | |
jpbaillargeon | 20:b45474290281 | 12 | int periode = 1; //10ms |
leomerel | 15:872151771dec | 13 | int periode_reception = 30; |
leomerel | 12:cfa3dec9e9a3 | 14 | bool PREAMBULE[] = {0,1,0,1,0,1,0,1}; |
leomerel | 12:cfa3dec9e9a3 | 15 | bool START_END[] = {0,1,1,1,1,1,1,0}; |
leomerel | 14:42a7d108b134 | 16 | Thread envoi_t; |
leomerel | 14:42a7d108b134 | 17 | Thread reception_t; |
leomerel | 15:872151771dec | 18 | Thread detection_t; |
leomerel | 15:872151771dec | 19 | |
leomerel | 15:872151771dec | 20 | typedef struct { |
leomerel | 15:872151771dec | 21 | int time; |
leomerel | 15:872151771dec | 22 | bool front; |
leomerel | 15:872151771dec | 23 | } message_t; |
leomerel | 15:872151771dec | 24 | |
jpbaillargeon | 20:b45474290281 | 25 | Mail<message_t,128> mail_box; |
leomerel | 15:872151771dec | 26 | Timer timer; |
leomerel | 15:872151771dec | 27 | int etat; |
jpbaillargeon | 22:e73831429e1c | 28 | const int longMessage = 128; |
jpbaillargeon | 19:ae8e7c9292d6 | 29 | bool messageUtile[longMessage] = {0,0,1,0,1,1,1,0, |
leomerel | 14:42a7d108b134 | 30 | 1,0,1,0,0,0,0,0, |
leomerel | 14:42a7d108b134 | 31 | 0,0,1,1,1,0,1,0, |
leomerel | 14:42a7d108b134 | 32 | 1,1,0,0,0,1,1,0, |
leomerel | 14:42a7d108b134 | 33 | 0,1,0,1,1,0,1,1, |
leomerel | 14:42a7d108b134 | 34 | 1,0,1,0,1,1,1,0, |
leomerel | 14:42a7d108b134 | 35 | 0,0,1,0,1,0,0,0, |
jpbaillargeon | 22:e73831429e1c | 36 | 1,1,0,1,0,1,1,0, |
jpbaillargeon | 22:e73831429e1c | 37 | 0,0,1,0,1,1,1,0, |
jpbaillargeon | 22:e73831429e1c | 38 | 1,0,1,0,0,0,0,0, |
jpbaillargeon | 22:e73831429e1c | 39 | 0,0,1,1,1,0,1,0, |
jpbaillargeon | 22:e73831429e1c | 40 | 1,1,0,0,0,1,1,0, |
jpbaillargeon | 22:e73831429e1c | 41 | 0,1,0,1,1,0,1,1, |
jpbaillargeon | 22:e73831429e1c | 42 | 1,0,1,0,1,1,1,0, |
jpbaillargeon | 22:e73831429e1c | 43 | 0,0,1,0,1,0,0,0, |
jpbaillargeon | 22:e73831429e1c | 44 | 1,1,0,1,0,1,1,0}; |
leomerel | 12:cfa3dec9e9a3 | 45 | |
jpbaillargeon | 16:a163a7c0315b | 46 | //CRC16 (détection des erreurs) ---------------------------------------------------------------------------------------------------- |
jpbaillargeon | 16:a163a7c0315b | 47 | unsigned short crc16(bool* data_p, int length){ |
jpbaillargeon | 16:a163a7c0315b | 48 | unsigned char x; |
jpbaillargeon | 16:a163a7c0315b | 49 | unsigned short crc = 0xFFFF; |
jpbaillargeon | 16:a163a7c0315b | 50 | |
jpbaillargeon | 16:a163a7c0315b | 51 | while (length--){ |
jpbaillargeon | 16:a163a7c0315b | 52 | x = crc >> 8 ^ *data_p++; |
jpbaillargeon | 16:a163a7c0315b | 53 | x ^= x>>4; |
jpbaillargeon | 16:a163a7c0315b | 54 | crc = (crc << 8) ^ ((unsigned short)(x << 12)) ^ ((unsigned short)(x <<5)) ^ ((unsigned short)x); |
jpbaillargeon | 16:a163a7c0315b | 55 | } |
jpbaillargeon | 16:a163a7c0315b | 56 | return crc; |
jpbaillargeon | 16:a163a7c0315b | 57 | } |
jpbaillargeon | 16:a163a7c0315b | 58 | |
leomerel | 14:42a7d108b134 | 59 | //convert length from int to binary ----------------------------------------------------------------------------------------------------- |
leomerel | 14:42a7d108b134 | 60 | bool r; |
leomerel | 14:42a7d108b134 | 61 | void int_to_bin(bool bin[8], int length){ //Fonctionne |
leomerel | 14:42a7d108b134 | 62 | int i = 0; |
jpbaillargeon | 19:ae8e7c9292d6 | 63 | while(length >0 || i<8){ |
jpbaillargeon | 19:ae8e7c9292d6 | 64 | r = length%2; |
jpbaillargeon | 19:ae8e7c9292d6 | 65 | length/=2; |
jpbaillargeon | 19:ae8e7c9292d6 | 66 | bin[7-i]=r; |
jpbaillargeon | 19:ae8e7c9292d6 | 67 | i++; |
jpbaillargeon | 19:ae8e7c9292d6 | 68 | } |
jpbaillargeon | 19:ae8e7c9292d6 | 69 | while(i<8){ |
jpbaillargeon | 19:ae8e7c9292d6 | 70 | bin[i]=0; |
jpbaillargeon | 19:ae8e7c9292d6 | 71 | i++; |
jpbaillargeon | 19:ae8e7c9292d6 | 72 | } |
jpbaillargeon | 19:ae8e7c9292d6 | 73 | } |
jpbaillargeon | 19:ae8e7c9292d6 | 74 | |
jpbaillargeon | 19:ae8e7c9292d6 | 75 | void int_to_bin2(bool bin[8], int length){ //Fonctionne |
jpbaillargeon | 19:ae8e7c9292d6 | 76 | int i = 0; |
jpbaillargeon | 17:53d4674cb37f | 77 | while(length >0 && i<8){ |
leomerel | 14:42a7d108b134 | 78 | r = length%2; |
leomerel | 14:42a7d108b134 | 79 | length/=2; |
leomerel | 14:42a7d108b134 | 80 | bin[7-i]=r; |
leomerel | 14:42a7d108b134 | 81 | i++; |
leomerel | 14:42a7d108b134 | 82 | } |
leomerel | 14:42a7d108b134 | 83 | while(i<8){ |
leomerel | 14:42a7d108b134 | 84 | bin[i]=0; |
leomerel | 14:42a7d108b134 | 85 | i++; |
leomerel | 14:42a7d108b134 | 86 | } |
leomerel | 14:42a7d108b134 | 87 | } |
leomerel | 14:42a7d108b134 | 88 | |
leomerel | 14:42a7d108b134 | 89 | //convert to Manchester ------------------------------------------------------------------------------------------------ |
leomerel | 14:42a7d108b134 | 90 | void convertBitToManchester(bool *manchester, bool bit){ //Fonctionne |
leomerel | 14:42a7d108b134 | 91 | if(bit == 0){ |
leomerel | 14:42a7d108b134 | 92 | manchester[0]=0; |
leomerel | 14:42a7d108b134 | 93 | manchester[1]=1; |
leomerel | 12:cfa3dec9e9a3 | 94 | } |
leomerel | 14:42a7d108b134 | 95 | else if(bit == 1){ |
leomerel | 14:42a7d108b134 | 96 | manchester[0]=1; |
leomerel | 14:42a7d108b134 | 97 | manchester[1]=0; |
emilmont | 1:491820ee784d | 98 | } |
emilmont | 1:491820ee784d | 99 | } |
leomerel | 12:cfa3dec9e9a3 | 100 | |
leomerel | 14:42a7d108b134 | 101 | void convertByteToManchester(bool *manchester, bool byte[8]){ //Fonctionne |
leomerel | 14:42a7d108b134 | 102 | for(int i=0; i<8; i++){ |
leomerel | 14:42a7d108b134 | 103 | if(byte[i] == 0){ |
leomerel | 14:42a7d108b134 | 104 | manchester[i*2]=0; |
leomerel | 14:42a7d108b134 | 105 | manchester[i*2+1]=1; |
leomerel | 14:42a7d108b134 | 106 | } |
leomerel | 14:42a7d108b134 | 107 | else if(byte[i] == 1){ |
leomerel | 14:42a7d108b134 | 108 | manchester[i*2]=1; |
leomerel | 14:42a7d108b134 | 109 | manchester[i*2+1]=0; |
leomerel | 14:42a7d108b134 | 110 | } |
leomerel | 14:42a7d108b134 | 111 | } |
leomerel | 14:42a7d108b134 | 112 | } |
leomerel | 12:cfa3dec9e9a3 | 113 | |
leomerel | 14:42a7d108b134 | 114 | void convertMessageToManchester(bool *manchester, bool *message, int length){ |
leomerel | 14:42a7d108b134 | 115 | for(int i=0; i<length; i++){ |
leomerel | 14:42a7d108b134 | 116 | if(message[i] == 0){ |
leomerel | 14:42a7d108b134 | 117 | manchester[i*2]=0; |
leomerel | 14:42a7d108b134 | 118 | manchester[i*2+1]=1; |
leomerel | 14:42a7d108b134 | 119 | } |
leomerel | 14:42a7d108b134 | 120 | else if(message[i] == 1){ |
leomerel | 14:42a7d108b134 | 121 | manchester[i*2]=1; |
leomerel | 14:42a7d108b134 | 122 | manchester[i*2+1]=0; |
leomerel | 14:42a7d108b134 | 123 | } |
leomerel | 14:42a7d108b134 | 124 | } |
leomerel | 12:cfa3dec9e9a3 | 125 | } |
leomerel | 12:cfa3dec9e9a3 | 126 | |
leomerel | 14:42a7d108b134 | 127 | //création d'une trame -------------------------------------------------------------------------------------------------------------- |
leomerel | 14:42a7d108b134 | 128 | void creationTrame(bool *message, int length){ //Fonctionne |
leomerel | 14:42a7d108b134 | 129 | bool bin[8]; |
leomerel | 14:42a7d108b134 | 130 | int_to_bin(bin, length); |
leomerel | 14:42a7d108b134 | 131 | for(int i=0; i<8; i++){ |
leomerel | 14:42a7d108b134 | 132 | *message=PREAMBULE[i]; |
leomerel | 14:42a7d108b134 | 133 | message++; |
leomerel | 14:42a7d108b134 | 134 | } |
leomerel | 14:42a7d108b134 | 135 | for(int i=0; i<8; i++){ |
leomerel | 14:42a7d108b134 | 136 | *message=START_END[i]; |
leomerel | 14:42a7d108b134 | 137 | message++; |
leomerel | 14:42a7d108b134 | 138 | } |
leomerel | 14:42a7d108b134 | 139 | for(int i=0; i<8; i++){ |
leomerel | 14:42a7d108b134 | 140 | *message=0; |
leomerel | 14:42a7d108b134 | 141 | message++; |
leomerel | 14:42a7d108b134 | 142 | } |
leomerel | 14:42a7d108b134 | 143 | for(int i=0; i<8; i++){ |
leomerel | 14:42a7d108b134 | 144 | *message=bin[i]; |
leomerel | 14:42a7d108b134 | 145 | message++; |
leomerel | 14:42a7d108b134 | 146 | } |
leomerel | 14:42a7d108b134 | 147 | for(int i=0; i<sizeof(messageUtile); i++){ |
leomerel | 14:42a7d108b134 | 148 | *message=messageUtile[i]; |
leomerel | 14:42a7d108b134 | 149 | message++; |
leomerel | 14:42a7d108b134 | 150 | } |
leomerel | 14:42a7d108b134 | 151 | //CRC16 |
jpbaillargeon | 16:a163a7c0315b | 152 | unsigned short crc = crc16(messageUtile, (int)sizeof(messageUtile)); |
jpbaillargeon | 19:ae8e7c9292d6 | 153 | printf("\r\n -----------------CRC ENVOYE: %d-------------\r\n", crc); |
jpbaillargeon | 19:ae8e7c9292d6 | 154 | int_to_bin2(bin, crc); |
leomerel | 14:42a7d108b134 | 155 | for(int i=0; i<8; i++){ |
jpbaillargeon | 16:a163a7c0315b | 156 | *message=bin[i]; |
jpbaillargeon | 16:a163a7c0315b | 157 | message++; |
leomerel | 14:42a7d108b134 | 158 | } |
leomerel | 14:42a7d108b134 | 159 | for(int i=0; i<8; i++){ |
leomerel | 14:42a7d108b134 | 160 | *message=START_END[i]; |
leomerel | 14:42a7d108b134 | 161 | message++; |
leomerel | 14:42a7d108b134 | 162 | } |
leomerel | 14:42a7d108b134 | 163 | } |
leomerel | 14:42a7d108b134 | 164 | |
leomerel | 14:42a7d108b134 | 165 | //Envoi d'une trame ---------------------------------------------------------------------------------------------------------------- |
leomerel | 14:42a7d108b134 | 166 | void envoiTrame(){ |
leomerel | 15:872151771dec | 167 | bool app=false; |
jpbaillargeon | 16:a163a7c0315b | 168 | int length3 = sizeof(messageUtile); |
jpbaillargeon | 16:a163a7c0315b | 169 | bool message3[length3+6*8]; |
jpbaillargeon | 16:a163a7c0315b | 170 | bool manchester3[(length3+6*8)*2]; |
jpbaillargeon | 16:a163a7c0315b | 171 | |
jpbaillargeon | 16:a163a7c0315b | 172 | creationTrame(message3,length3); |
jpbaillargeon | 16:a163a7c0315b | 173 | convertMessageToManchester(manchester3, message3,length3+6*8); |
leomerel | 15:872151771dec | 174 | while(1){ |
leomerel | 15:872151771dec | 175 | if(pin12 && !app){ |
leomerel | 15:872151771dec | 176 | app=true; |
leomerel | 15:872151771dec | 177 | for(int i=0; i<sizeof(manchester3); i++){ |
leomerel | 15:872151771dec | 178 | dout = manchester3[i]; |
leomerel | 15:872151771dec | 179 | Thread::wait(periode); |
leomerel | 15:872151771dec | 180 | } |
leomerel | 15:872151771dec | 181 | } |
leomerel | 15:872151771dec | 182 | else if(!pin12 && app){ |
leomerel | 15:872151771dec | 183 | app=false; |
leomerel | 15:872151771dec | 184 | } |
leomerel | 14:42a7d108b134 | 185 | } |
leomerel | 14:42a7d108b134 | 186 | } |
leomerel | 14:42a7d108b134 | 187 | |
jpbaillargeon | 16:a163a7c0315b | 188 | |
jpbaillargeon | 19:ae8e7c9292d6 | 189 | //Réception des trames |
jpbaillargeon | 19:ae8e7c9292d6 | 190 | void receptionTrames() { |
leomerel | 15:872151771dec | 191 | int compteur = 0; |
leomerel | 15:872151771dec | 192 | int prev_time; |
leomerel | 15:872151771dec | 193 | int t; |
jpbaillargeon | 16:a163a7c0315b | 194 | bool preambule[8]; |
jpbaillargeon | 16:a163a7c0315b | 195 | bool start[8]; |
jpbaillargeon | 16:a163a7c0315b | 196 | bool flag[8]; |
jpbaillargeon | 16:a163a7c0315b | 197 | bool longueur[8]; |
jpbaillargeon | 21:846e642eb63e | 198 | bool message[80*8]; |
jpbaillargeon | 16:a163a7c0315b | 199 | bool checksum[8]; |
jpbaillargeon | 16:a163a7c0315b | 200 | bool end[8]; |
jpbaillargeon | 16:a163a7c0315b | 201 | int longInt; |
jpbaillargeon | 16:a163a7c0315b | 202 | bool bin2[8]; |
jpbaillargeon | 18:5c26a8f38248 | 203 | int temps =0; |
jpbaillargeon | 18:5c26a8f38248 | 204 | int tMax; |
jpbaillargeon | 18:5c26a8f38248 | 205 | int tMin; |
leomerel | 14:42a7d108b134 | 206 | while(1){ |
leomerel | 15:872151771dec | 207 | osEvent evt = mail_box.get(); |
leomerel | 15:872151771dec | 208 | if (evt.status == osEventMail) { |
leomerel | 15:872151771dec | 209 | message_t *f = (message_t*)evt.value.p; |
leomerel | 15:872151771dec | 210 | led3 = f->front; |
leomerel | 15:872151771dec | 211 | t = f->time; |
jpbaillargeon | 16:a163a7c0315b | 212 | if(etat==0) { |
jpbaillargeon | 16:a163a7c0315b | 213 | if(f->front == 0){ |
leomerel | 15:872151771dec | 214 | compteur=0; |
leomerel | 15:872151771dec | 215 | timer.start(); |
leomerel | 15:872151771dec | 216 | printf("%d Time : %d , compteur: %d\r\n", f->front, t, compteur); |
leomerel | 15:872151771dec | 217 | preambule[compteur] = f->front; |
jpbaillargeon | 16:a163a7c0315b | 218 | prev_time = t; |
jpbaillargeon | 16:a163a7c0315b | 219 | compteur++; |
leomerel | 15:872151771dec | 220 | etat = 1; |
jpbaillargeon | 16:a163a7c0315b | 221 | printf("-----ETAT 1-----\r\n"); |
leomerel | 15:872151771dec | 222 | } |
jpbaillargeon | 16:a163a7c0315b | 223 | } |
jpbaillargeon | 16:a163a7c0315b | 224 | |
jpbaillargeon | 16:a163a7c0315b | 225 | else if(etat==1) { |
jpbaillargeon | 16:a163a7c0315b | 226 | if(f->front==1){ |
leomerel | 15:872151771dec | 227 | printf("%d Time : %d , compteur: %d\r\n", f->front, t, compteur); |
leomerel | 15:872151771dec | 228 | preambule[compteur] = f->front; |
jpbaillargeon | 16:a163a7c0315b | 229 | prev_time = t; |
jpbaillargeon | 16:a163a7c0315b | 230 | compteur++; |
jpbaillargeon | 16:a163a7c0315b | 231 | etat = 2; |
jpbaillargeon | 16:a163a7c0315b | 232 | printf("-----ETAT 2-----\r\n"); |
leomerel | 15:872151771dec | 233 | } |
leomerel | 15:872151771dec | 234 | } |
jpbaillargeon | 16:a163a7c0315b | 235 | |
jpbaillargeon | 16:a163a7c0315b | 236 | else if(etat==2) { |
jpbaillargeon | 16:a163a7c0315b | 237 | printf("%d Time : %d , compteur: %d\r\n", f->front, t, compteur); |
jpbaillargeon | 16:a163a7c0315b | 238 | preambule[compteur] = f->front; |
jpbaillargeon | 18:5c26a8f38248 | 239 | temps += t-prev_time; |
jpbaillargeon | 16:a163a7c0315b | 240 | prev_time = t; |
jpbaillargeon | 16:a163a7c0315b | 241 | compteur++; |
jpbaillargeon | 16:a163a7c0315b | 242 | } |
jpbaillargeon | 16:a163a7c0315b | 243 | |
jpbaillargeon | 16:a163a7c0315b | 244 | else if(etat ==3) { |
jpbaillargeon | 19:ae8e7c9292d6 | 245 | if(((t-prev_time)<=tMax)&& ((t-prev_time)>=tMin)){ |
leomerel | 15:872151771dec | 246 | printf("%d Time : %d , compteur: %d\r\n", f->front, t, compteur); |
jpbaillargeon | 16:a163a7c0315b | 247 | start[compteur-8] = f->front; |
jpbaillargeon | 16:a163a7c0315b | 248 | prev_time = t; |
jpbaillargeon | 16:a163a7c0315b | 249 | compteur++; |
leomerel | 15:872151771dec | 250 | } |
jpbaillargeon | 16:a163a7c0315b | 251 | } |
jpbaillargeon | 16:a163a7c0315b | 252 | |
jpbaillargeon | 16:a163a7c0315b | 253 | else if(etat ==4) { |
jpbaillargeon | 19:ae8e7c9292d6 | 254 | if(((t-prev_time)<=tMax)&& ((t-prev_time)>=tMin)){ |
jpbaillargeon | 16:a163a7c0315b | 255 | printf("%d Time : %d , compteur: %d\r\n", f->front, t, compteur); |
jpbaillargeon | 16:a163a7c0315b | 256 | flag[compteur-16] = f->front; |
jpbaillargeon | 16:a163a7c0315b | 257 | prev_time = t; |
jpbaillargeon | 16:a163a7c0315b | 258 | compteur++; |
jpbaillargeon | 16:a163a7c0315b | 259 | } |
jpbaillargeon | 16:a163a7c0315b | 260 | } |
jpbaillargeon | 16:a163a7c0315b | 261 | |
jpbaillargeon | 16:a163a7c0315b | 262 | else if(etat ==5) { |
jpbaillargeon | 19:ae8e7c9292d6 | 263 | if(((t-prev_time)<=tMax)&& ((t-prev_time)>=tMin)){ |
leomerel | 15:872151771dec | 264 | printf("%d Time : %d , compteur: %d\r\n", f->front, t, compteur); |
jpbaillargeon | 16:a163a7c0315b | 265 | longueur[compteur-24] = f->front; |
jpbaillargeon | 16:a163a7c0315b | 266 | prev_time = t; |
jpbaillargeon | 16:a163a7c0315b | 267 | compteur++; |
jpbaillargeon | 16:a163a7c0315b | 268 | } |
jpbaillargeon | 16:a163a7c0315b | 269 | } |
jpbaillargeon | 16:a163a7c0315b | 270 | else if(etat ==6) { |
jpbaillargeon | 19:ae8e7c9292d6 | 271 | if(((t-prev_time)<=tMax)&& ((t-prev_time)>=tMin)){ |
jpbaillargeon | 16:a163a7c0315b | 272 | printf("%d Time : %d , compteur: %d\r\n", f->front, t, compteur); |
jpbaillargeon | 16:a163a7c0315b | 273 | message[compteur-32]= f->front; |
jpbaillargeon | 16:a163a7c0315b | 274 | prev_time = t; |
jpbaillargeon | 16:a163a7c0315b | 275 | compteur++; |
leomerel | 15:872151771dec | 276 | } |
jpbaillargeon | 16:a163a7c0315b | 277 | } |
jpbaillargeon | 16:a163a7c0315b | 278 | else if(etat ==7) { |
jpbaillargeon | 19:ae8e7c9292d6 | 279 | if(((t-prev_time)<=tMax)&& ((t-prev_time)>=tMin)){ |
jpbaillargeon | 16:a163a7c0315b | 280 | printf("%d Time : %d , compteur: %d\r\n", f->front, t, compteur); |
jpbaillargeon | 16:a163a7c0315b | 281 | checksum[compteur-32-longInt]= f->front; |
jpbaillargeon | 16:a163a7c0315b | 282 | prev_time = t; |
jpbaillargeon | 16:a163a7c0315b | 283 | compteur++; |
jpbaillargeon | 16:a163a7c0315b | 284 | } |
jpbaillargeon | 16:a163a7c0315b | 285 | } |
jpbaillargeon | 16:a163a7c0315b | 286 | else if(etat ==8) { |
jpbaillargeon | 19:ae8e7c9292d6 | 287 | if(((t-prev_time)<=tMax)&& ((t-prev_time)>=tMin)){ |
jpbaillargeon | 16:a163a7c0315b | 288 | printf("%d Time : %d , compteur: %d\r\n", f->front, t, compteur); |
jpbaillargeon | 16:a163a7c0315b | 289 | end[compteur-40-longInt]= f->front; |
jpbaillargeon | 16:a163a7c0315b | 290 | prev_time = t; |
jpbaillargeon | 16:a163a7c0315b | 291 | compteur++; |
jpbaillargeon | 16:a163a7c0315b | 292 | } |
jpbaillargeon | 16:a163a7c0315b | 293 | } |
leomerel | 15:872151771dec | 294 | mail_box.free(f); |
leomerel | 15:872151771dec | 295 | } |
jpbaillargeon | 16:a163a7c0315b | 296 | |
jpbaillargeon | 17:53d4674cb37f | 297 | if((compteur ==8) && (etat ==2)){ |
jpbaillargeon | 17:53d4674cb37f | 298 | etat = 3; |
jpbaillargeon | 16:a163a7c0315b | 299 | for(int i=0; i<8;i++){ |
jpbaillargeon | 17:53d4674cb37f | 300 | if((preambule[i]!= PREAMBULE[i]) && (etat !=0 )) |
jpbaillargeon | 16:a163a7c0315b | 301 | { |
jpbaillargeon | 16:a163a7c0315b | 302 | etat =0; |
jpbaillargeon | 17:53d4674cb37f | 303 | printf("\r\n------Pas le bon PREAMBULE------\r\n"); |
leomerel | 15:872151771dec | 304 | } |
leomerel | 15:872151771dec | 305 | printf("%d", preambule[i]); |
leomerel | 15:872151771dec | 306 | } |
leomerel | 15:872151771dec | 307 | printf("\r\n"); |
jpbaillargeon | 17:53d4674cb37f | 308 | if(etat != 0) |
jpbaillargeon | 17:53d4674cb37f | 309 | { |
jpbaillargeon | 18:5c26a8f38248 | 310 | temps /=6; |
jpbaillargeon | 19:ae8e7c9292d6 | 311 | tMin = 0.75*temps; |
jpbaillargeon | 19:ae8e7c9292d6 | 312 | tMax = 1.25*temps; |
jpbaillargeon | 18:5c26a8f38248 | 313 | printf("-----ETAT 3 %d-----\r\n", temps); |
jpbaillargeon | 17:53d4674cb37f | 314 | } |
leomerel | 15:872151771dec | 315 | } |
jpbaillargeon | 17:53d4674cb37f | 316 | else if((compteur ==16) && (etat == 3)) { |
jpbaillargeon | 17:53d4674cb37f | 317 | etat =4; |
jpbaillargeon | 16:a163a7c0315b | 318 | for(int i=0; i<8;i++){ |
jpbaillargeon | 17:53d4674cb37f | 319 | if((start[i]!= START_END[i]) && (etat != 0)) |
jpbaillargeon | 16:a163a7c0315b | 320 | { |
jpbaillargeon | 16:a163a7c0315b | 321 | etat =0; |
jpbaillargeon | 17:53d4674cb37f | 322 | printf("\r\n------Pas le bon START------\r\n"); |
jpbaillargeon | 16:a163a7c0315b | 323 | } |
jpbaillargeon | 16:a163a7c0315b | 324 | printf("%d", start[i]); |
jpbaillargeon | 16:a163a7c0315b | 325 | } |
jpbaillargeon | 16:a163a7c0315b | 326 | printf("\r\n"); |
jpbaillargeon | 17:53d4674cb37f | 327 | if(etat != 0) |
jpbaillargeon | 17:53d4674cb37f | 328 | { |
jpbaillargeon | 17:53d4674cb37f | 329 | printf("-----ETAT 4-----\r\n"); |
jpbaillargeon | 17:53d4674cb37f | 330 | } |
jpbaillargeon | 16:a163a7c0315b | 331 | } |
jpbaillargeon | 17:53d4674cb37f | 332 | else if((compteur==24) && (etat ==4)) { |
jpbaillargeon | 16:a163a7c0315b | 333 | for(int i=0; i<8;i++){ |
jpbaillargeon | 16:a163a7c0315b | 334 | printf("%d", flag[i]); |
jpbaillargeon | 16:a163a7c0315b | 335 | } |
jpbaillargeon | 16:a163a7c0315b | 336 | printf("\r\n"); |
jpbaillargeon | 16:a163a7c0315b | 337 | etat =5; |
jpbaillargeon | 16:a163a7c0315b | 338 | printf("-----ETAT 5 -----\r\n"); |
jpbaillargeon | 16:a163a7c0315b | 339 | } |
jpbaillargeon | 17:53d4674cb37f | 340 | else if((compteur==32) && (etat ==5)) { |
jpbaillargeon | 16:a163a7c0315b | 341 | longInt=0; |
jpbaillargeon | 16:a163a7c0315b | 342 | for(int i = 0; i<8; i++) { |
jpbaillargeon | 16:a163a7c0315b | 343 | longInt = longInt*2+longueur[i]; |
jpbaillargeon | 16:a163a7c0315b | 344 | } |
jpbaillargeon | 16:a163a7c0315b | 345 | printf("%d\r\n", longInt); |
jpbaillargeon | 16:a163a7c0315b | 346 | etat =6; |
jpbaillargeon | 16:a163a7c0315b | 347 | printf("-----ETAT 6 -----\r\n"); |
jpbaillargeon | 16:a163a7c0315b | 348 | } |
jpbaillargeon | 17:53d4674cb37f | 349 | else if((compteur==32+longInt) && (etat ==6)) { |
jpbaillargeon | 16:a163a7c0315b | 350 | for(int i=0; i<longInt;i++){ |
jpbaillargeon | 16:a163a7c0315b | 351 | printf("%d", message[i]); |
jpbaillargeon | 16:a163a7c0315b | 352 | } |
jpbaillargeon | 16:a163a7c0315b | 353 | printf("\r\n"); |
jpbaillargeon | 16:a163a7c0315b | 354 | etat =7; |
jpbaillargeon | 16:a163a7c0315b | 355 | printf("-----ETAT 7-----\r\n"); |
jpbaillargeon | 16:a163a7c0315b | 356 | } |
jpbaillargeon | 16:a163a7c0315b | 357 | |
jpbaillargeon | 17:53d4674cb37f | 358 | else if((compteur == 40 +longInt) && (etat ==7)) { |
jpbaillargeon | 17:53d4674cb37f | 359 | etat =8; |
jpbaillargeon | 21:846e642eb63e | 360 | unsigned short crc = crc16(message, longInt); |
jpbaillargeon | 19:ae8e7c9292d6 | 361 | printf("\r\n -----------------CRC RECALCULE: %d-------------\r\n", crc); |
jpbaillargeon | 19:ae8e7c9292d6 | 362 | int_to_bin2(bin2, crc); |
jpbaillargeon | 16:a163a7c0315b | 363 | for(int i=0; i<8;i++){ |
jpbaillargeon | 17:53d4674cb37f | 364 | printf("%d", bin2[i]); |
jpbaillargeon | 17:53d4674cb37f | 365 | if((bin2[i] != checksum[i]) && (etat !=0)) { |
jpbaillargeon | 16:a163a7c0315b | 366 | etat =0; |
jpbaillargeon | 17:53d4674cb37f | 367 | printf("\r\n------Pas le bon CRC------\r\n"); |
jpbaillargeon | 17:53d4674cb37f | 368 | } |
jpbaillargeon | 16:a163a7c0315b | 369 | } |
jpbaillargeon | 16:a163a7c0315b | 370 | |
jpbaillargeon | 16:a163a7c0315b | 371 | printf("\r\n"); |
jpbaillargeon | 17:53d4674cb37f | 372 | if(etat != 0) |
jpbaillargeon | 17:53d4674cb37f | 373 | { |
jpbaillargeon | 17:53d4674cb37f | 374 | printf("-----ETAT 8-----\r\n"); |
jpbaillargeon | 17:53d4674cb37f | 375 | } |
jpbaillargeon | 16:a163a7c0315b | 376 | } |
jpbaillargeon | 17:53d4674cb37f | 377 | else if((compteur == 48 +longInt) && (etat ==8)) { |
jpbaillargeon | 16:a163a7c0315b | 378 | for(int i=0; i<8;i++){ |
jpbaillargeon | 16:a163a7c0315b | 379 | if(end[i]!= START_END[i]) |
jpbaillargeon | 16:a163a7c0315b | 380 | { |
jpbaillargeon | 16:a163a7c0315b | 381 | etat =0; |
jpbaillargeon | 17:53d4674cb37f | 382 | printf("\r\n------Pas le bon END------\r\n"); |
jpbaillargeon | 16:a163a7c0315b | 383 | } |
jpbaillargeon | 16:a163a7c0315b | 384 | printf("%d", end[i]); |
jpbaillargeon | 16:a163a7c0315b | 385 | } |
jpbaillargeon | 16:a163a7c0315b | 386 | printf("\r\n"); |
jpbaillargeon | 16:a163a7c0315b | 387 | etat =0; |
jpbaillargeon | 16:a163a7c0315b | 388 | printf("-----ETAT 0-----\r\n"); |
jpbaillargeon | 16:a163a7c0315b | 389 | } |
leomerel | 14:42a7d108b134 | 390 | } |
leomerel | 14:42a7d108b134 | 391 | } |
leomerel | 14:42a7d108b134 | 392 | |
leomerel | 15:872151771dec | 393 | void rise() { |
leomerel | 15:872151771dec | 394 | led1 = !led1; |
leomerel | 15:872151771dec | 395 | message_t *a = mail_box.alloc(); |
leomerel | 15:872151771dec | 396 | a->time = timer.read_ms();; |
jpbaillargeon | 22:e73831429e1c | 397 | a->front = 0; //Si rise, il s'agit d'un 0 en Manchester |
leomerel | 15:872151771dec | 398 | mail_box.put(a); |
leomerel | 15:872151771dec | 399 | } |
leomerel | 15:872151771dec | 400 | |
leomerel | 15:872151771dec | 401 | void fall() { |
leomerel | 15:872151771dec | 402 | led2 = !led2; |
leomerel | 15:872151771dec | 403 | message_t *a = mail_box.alloc(); |
leomerel | 15:872151771dec | 404 | a->time = timer.read_ms();; |
jpbaillargeon | 22:e73831429e1c | 405 | a->front = 1; //Si fall, il s'agit d'un 1 en Manchester |
leomerel | 15:872151771dec | 406 | mail_box.put(a); |
leomerel | 14:42a7d108b134 | 407 | } |
leomerel | 14:42a7d108b134 | 408 | |
leomerel | 14:42a7d108b134 | 409 | |
emilmont | 1:491820ee784d | 410 | int main() { |
jpbaillargeon | 22:e73831429e1c | 411 | printf("\r\n\r\n**********Debut**********\r\n"); |
jpbaillargeon | 22:e73831429e1c | 412 | int length = sizeof(messageUtile); |
jpbaillargeon | 22:e73831429e1c | 413 | bool message[length+6*8]; //Taille total du message avec les entêtes |
jpbaillargeon | 22:e73831429e1c | 414 | bool manchester[(length+6*8)*2]; |
jpbaillargeon | 22:e73831429e1c | 415 | creationTrame(message,length); |
jpbaillargeon | 22:e73831429e1c | 416 | |
jpbaillargeon | 22:e73831429e1c | 417 | //Afficher les bits envoyés |
jpbaillargeon | 22:e73831429e1c | 418 | printf("\r\nMessage : \r\n"); |
jpbaillargeon | 22:e73831429e1c | 419 | for(int i=0; i<sizeof(message); i++){ |
jpbaillargeon | 22:e73831429e1c | 420 | if(i>0 && i%8 == 0){ |
jpbaillargeon | 22:e73831429e1c | 421 | printf(" "); |
leomerel | 14:42a7d108b134 | 422 | } |
jpbaillargeon | 22:e73831429e1c | 423 | printf("%d",message[i]); |
jpbaillargeon | 22:e73831429e1c | 424 | } |
jpbaillargeon | 22:e73831429e1c | 425 | printf("\r\n"); |
jpbaillargeon | 22:e73831429e1c | 426 | |
jpbaillargeon | 22:e73831429e1c | 427 | convertMessageToManchester(manchester, message, length+6*8); |
jpbaillargeon | 22:e73831429e1c | 428 | |
jpbaillargeon | 22:e73831429e1c | 429 | //Affiche les bits en manchester |
jpbaillargeon | 22:e73831429e1c | 430 | printf("\r\nMessage Manchester: \r\n"); |
jpbaillargeon | 22:e73831429e1c | 431 | for(int i=0; i<sizeof(manchester); i++){ |
jpbaillargeon | 22:e73831429e1c | 432 | if(i>0 && i%16 == 0){ |
jpbaillargeon | 22:e73831429e1c | 433 | printf("\r\n"); |
jpbaillargeon | 22:e73831429e1c | 434 | } |
jpbaillargeon | 22:e73831429e1c | 435 | if(i>0 && i%2 == 0){ |
jpbaillargeon | 22:e73831429e1c | 436 | printf(" "); |
leomerel | 14:42a7d108b134 | 437 | } |
jpbaillargeon | 22:e73831429e1c | 438 | printf("%d",manchester[i]); |
jpbaillargeon | 22:e73831429e1c | 439 | } |
jpbaillargeon | 22:e73831429e1c | 440 | printf("\r\n"); |
jpbaillargeon | 22:e73831429e1c | 441 | |
jpbaillargeon | 22:e73831429e1c | 442 | //Démarrage des threads |
jpbaillargeon | 22:e73831429e1c | 443 | envoi_t.start(envoiTrame); |
jpbaillargeon | 22:e73831429e1c | 444 | reception_t.start(receptionTrames); |
jpbaillargeon | 22:e73831429e1c | 445 | |
jpbaillargeon | 22:e73831429e1c | 446 | button.rise(&rise); // attach the address of the flip function to the rising edge |
jpbaillargeon | 22:e73831429e1c | 447 | button.fall(&fall); |
jpbaillargeon | 22:e73831429e1c | 448 | while(1) { // wait around, interrupts will interrupt this! |
jpbaillargeon | 22:e73831429e1c | 449 | flash = !flash; |
jpbaillargeon | 22:e73831429e1c | 450 | wait(0.25); |
jpbaillargeon | 22:e73831429e1c | 451 | //Permet d'indiquer si l'application tourne |
jpbaillargeon | 22:e73831429e1c | 452 | } |
emilmont | 1:491820ee784d | 453 | } |
jpbaillargeon | 16:a163a7c0315b | 454 |