Petter Bellander / Mbed 2 deprecated Saab-BT

Dependencies:   mbed

Committer:
petter
Date:
Mon Jan 04 23:36:50 2016 +0000
Revision:
2:10c60edc8573
Parent:
1:63db3f3124d4
Child:
4:3041a571b7a7
Moved elapsed time timer into CDC; Fixed RN52 status interpretation (ascii hex -> int)

Who changed what in which revision?

UserRevisionLine numberNew contents of line
petter 0:6cf6e566c0da 1 #include "RN52.h"
petter 0:6cf6e566c0da 2 #include "mbed.h"
petter 0:6cf6e566c0da 3
petter 0:6cf6e566c0da 4 // RN52 action command definitions
petter 0:6cf6e566c0da 5 #define PLAYPAUSE "AP\r"
petter 0:6cf6e566c0da 6 #define NEXTTRACK "AT+\r"
petter 0:6cf6e566c0da 7 #define PREVTRACK "AT-\r"
petter 0:6cf6e566c0da 8 #define CONNECT "B\r"
petter 0:6cf6e566c0da 9 #define DISCONNECT "@,1\r"
petter 0:6cf6e566c0da 10 #define REBOOT "R,1\r"
petter 0:6cf6e566c0da 11 #define VOLUMEUP "AV+\r"
petter 0:6cf6e566c0da 12 #define MAXVOLUME "SS,0F\r"
petter 0:6cf6e566c0da 13 #define GETSTATUS "Q\r"
petter 0:6cf6e566c0da 14 #define ASSISTANT "P\r"
petter 0:6cf6e566c0da 15 #define CALLER_ID "T\r"
petter 0:6cf6e566c0da 16 #define TRACK_METADATA "AD\r"
petter 0:6cf6e566c0da 17
petter 0:6cf6e566c0da 18
petter 0:6cf6e566c0da 19 Serial serial(p13, p14); // tx, rx
petter 0:6cf6e566c0da 20 DigitalIn event_pin(p20);
petter 0:6cf6e566c0da 21
petter 0:6cf6e566c0da 22 void RN52::init(){
petter 0:6cf6e566c0da 23 serial.baud(115200);
petter 0:6cf6e566c0da 24 printf("Serial baudrate set\r\n");
petter 0:6cf6e566c0da 25 }
petter 0:6cf6e566c0da 26
petter 0:6cf6e566c0da 27 bool RN52::changed(){
petter 0:6cf6e566c0da 28 static bool last = 0;
petter 0:6cf6e566c0da 29 if(last != event_pin) {
petter 0:6cf6e566c0da 30 last = event_pin;
petter 0:6cf6e566c0da 31 return !event_pin;
petter 0:6cf6e566c0da 32 }
petter 0:6cf6e566c0da 33 last = event_pin;
petter 0:6cf6e566c0da 34 return 0;
petter 0:6cf6e566c0da 35 }
petter 0:6cf6e566c0da 36
petter 0:6cf6e566c0da 37
petter 0:6cf6e566c0da 38 bool RN52::set(RN52_COMMAND cmd){
petter 0:6cf6e566c0da 39 char response[40];
petter 0:6cf6e566c0da 40 switch (cmd) {
petter 0:6cf6e566c0da 41 case RN52_PLAYPAUSE:
petter 0:6cf6e566c0da 42 serial.printf(PLAYPAUSE);
petter 0:6cf6e566c0da 43 break;
petter 0:6cf6e566c0da 44 case RN52_NEXTTRACK:
petter 0:6cf6e566c0da 45 serial.printf(NEXTTRACK);
petter 0:6cf6e566c0da 46 break;
petter 0:6cf6e566c0da 47 case RN52_PREVTRACK:
petter 0:6cf6e566c0da 48 serial.printf(PREVTRACK);
petter 0:6cf6e566c0da 49 break;
petter 0:6cf6e566c0da 50 case RN52_CONNECT:
petter 0:6cf6e566c0da 51 serial.printf(CONNECT);
petter 0:6cf6e566c0da 52 break;
petter 0:6cf6e566c0da 53 case RN52_DISCONNECT:
petter 0:6cf6e566c0da 54 serial.printf(DISCONNECT);
petter 0:6cf6e566c0da 55 break;
petter 0:6cf6e566c0da 56 case RN52_REBOOT:
petter 0:6cf6e566c0da 57 serial.printf(REBOOT);
petter 0:6cf6e566c0da 58 break;
petter 0:6cf6e566c0da 59 case RN52_VOLUMEUP:
petter 0:6cf6e566c0da 60 serial.printf(VOLUMEUP);
petter 0:6cf6e566c0da 61 break;
petter 0:6cf6e566c0da 62 case RN52_MAXVOLUME:
petter 0:6cf6e566c0da 63 serial.printf(MAXVOLUME);
petter 0:6cf6e566c0da 64 break;
petter 0:6cf6e566c0da 65 case RN52_ASSISTANT:
petter 0:6cf6e566c0da 66 serial.printf(ASSISTANT);
petter 0:6cf6e566c0da 67 break;
petter 0:6cf6e566c0da 68 default:
petter 0:6cf6e566c0da 69 return false;
petter 0:6cf6e566c0da 70 }
petter 0:6cf6e566c0da 71 capture_response(response);
petter 0:6cf6e566c0da 72 return (response[0] == 'A');
petter 0:6cf6e566c0da 73 }
petter 0:6cf6e566c0da 74
petter 0:6cf6e566c0da 75 bool RN52::get(RN52_COMMAND cmd, RN52_RESULT * result){
petter 0:6cf6e566c0da 76 switch (cmd) {
petter 0:6cf6e566c0da 77 case RN52_GETSTATUS:
petter 0:6cf6e566c0da 78 serial.printf(GETSTATUS);
petter 0:6cf6e566c0da 79 capture_response(result->response);
petter 2:10c60edc8573 80 int response_value = strtoul(result->response, NULL, 16);
petter 2:10c60edc8573 81 result->media_connected = (response_value & (1 << 10)) >> 10; //byte 0, bit 2
petter 2:10c60edc8573 82 result->phone_connected = (response_value & (1 << 11)) >> 11; //byte 0, bit 3
petter 2:10c60edc8573 83 result->connection = (RN52_CONNECTION)(response_value & 0x0F); //byte 1, bits 0-3
petter 2:10c60edc8573 84 if((response_value & (1 << 12)) >> 12) { //byte 0, bit 4
petter 0:6cf6e566c0da 85 result->event = RN52_CALLER_ID_EVENT;
petter 0:6cf6e566c0da 86 }
petter 2:10c60edc8573 87 else if((response_value & (1 << 13)) >> 13) { //byte 0, bit 5
petter 0:6cf6e566c0da 88 result->event = RN52_TRACK_CHANGE_EVENT;
petter 0:6cf6e566c0da 89 }
petter 0:6cf6e566c0da 90 else {
petter 0:6cf6e566c0da 91 result->event = RN52_NO_EVENT;
petter 0:6cf6e566c0da 92 }
petter 0:6cf6e566c0da 93 break;
petter 0:6cf6e566c0da 94 case RN52_CALLER_ID:
petter 0:6cf6e566c0da 95 serial.printf(CALLER_ID);
petter 0:6cf6e566c0da 96 capture_response(result->response);
petter 0:6cf6e566c0da 97 //parse the response
petter 0:6cf6e566c0da 98 break;
petter 0:6cf6e566c0da 99 case RN52_TRACK_METADATA:
petter 0:6cf6e566c0da 100 serial.printf(TRACK_METADATA);
petter 0:6cf6e566c0da 101 capture_response(result->response);
petter 0:6cf6e566c0da 102 //parse the response
petter 0:6cf6e566c0da 103 default:
petter 0:6cf6e566c0da 104 return 0;
petter 0:6cf6e566c0da 105 }
petter 0:6cf6e566c0da 106 return 1;
petter 0:6cf6e566c0da 107 }
petter 0:6cf6e566c0da 108
petter 0:6cf6e566c0da 109
petter 0:6cf6e566c0da 110 void RN52::capture_response(char * str){
petter 0:6cf6e566c0da 111 char c = ' ';
petter 0:6cf6e566c0da 112 char n = 0;
petter 0:6cf6e566c0da 113 while(c != '\n') {
petter 0:6cf6e566c0da 114 if(serial.readable()) {
petter 0:6cf6e566c0da 115 c = serial.getc();
petter 0:6cf6e566c0da 116 str[n] = c;
petter 0:6cf6e566c0da 117 n++;
petter 0:6cf6e566c0da 118 }
petter 0:6cf6e566c0da 119 }
petter 0:6cf6e566c0da 120 str[n] = '\0';
petter 0:6cf6e566c0da 121 }