Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Dependencies: SDFileSystem max32630fthr USBDevice
Fork of FTHR_SD_Demo by
main.cpp@22:fe94be11bae0, 2019-03-21 (annotated)
- Committer:
- cyberjoey
- Date:
- Thu Mar 21 23:15:26 2019 +0000
- Revision:
- 22:fe94be11bae0
- Parent:
- 21:0f358a702561
- Child:
- 23:aa2407a3b30d
changed log file name to MAX30208 instead of MAX30207
Who changed what in which revision?
| User | Revision | Line number | New contents of line | 
|---|---|---|---|
| switches | 0:60a522ae2e35 | 1 | #include "mbed.h" | 
| switches | 1:90313362ec11 | 2 | #include "SDFileSystem.h" | 
| cyberjoey | 9:36ba3626aab7 | 3 | #include "max32630fthr.h" | 
| cyberjoey | 9:36ba3626aab7 | 4 | #include "USBSerial.h" | 
| cyberjoey | 11:94a7379c0db8 | 5 | #include <ctype.h> | 
| switches | 0:60a522ae2e35 | 6 | |
| cyberjoey | 9:36ba3626aab7 | 7 | #define PERIOD 10 // Logging period in seconds | 
| cyberjoey | 9:36ba3626aab7 | 8 | |
| cyberjoey | 9:36ba3626aab7 | 9 | //OT07 Registers | 
| cyberjoey | 9:36ba3626aab7 | 10 | #define OT07_STATUS 0x00 // OT07 status regiter | 
| cyberjoey | 9:36ba3626aab7 | 11 | #define OT07_INT_EN 0x01 // OT07 Interrupt Enable | 
| cyberjoey | 9:36ba3626aab7 | 12 | #define OT07_FIFO_W 0x04 // OT07 FIFO Write Pointer | 
| cyberjoey | 9:36ba3626aab7 | 13 | #define OT07_FIFO_R 0x05 // OT07 FIFO Read Pointer | 
| cyberjoey | 9:36ba3626aab7 | 14 | #define OT07_FIFO_OF 0x06 // OT07 FIFO Overflow Counter | 
| cyberjoey | 9:36ba3626aab7 | 15 | #define OT07_FIFO_COUNT 0x07 // OT07 FIFO Data Count | 
| cyberjoey | 9:36ba3626aab7 | 16 | #define OT07_FIFO_DATA 0x08 // OT07 FIFO Data | 
| cyberjoey | 9:36ba3626aab7 | 17 | #define OT07_FIFO_CNFG1 0x09 // OT07 FIFO Configuration 1 (FIFO_A_FULL) | 
| cyberjoey | 9:36ba3626aab7 | 18 | #define OT07_FIFO_CNFG2 0x0A // OT07 FIFO Configuration 2 | 
| cyberjoey | 9:36ba3626aab7 | 19 | #define OT07_SYS 0x0C // OT07 System Configuration | 
| cyberjoey | 9:36ba3626aab7 | 20 | #define OT07_ALARM_HIGH_MSB 0x10 // OT07 Alarm High MSB | 
| cyberjoey | 9:36ba3626aab7 | 21 | #define OT07_ALARM_HIGH_LSB 0x11 // OT07 Alarm High LSB | 
| cyberjoey | 9:36ba3626aab7 | 22 | #define OT07_ALARM_LOW_MSB 0x12 // OT07 Alarm Low MSB | 
| cyberjoey | 9:36ba3626aab7 | 23 | #define OT07_ALARM_LOW_LSB 0x13 // OT07 Alarm LOW LSB | 
| cyberjoey | 17:401a5bb8d403 | 24 | #define OT07_ADC_SETUP 0x14 // OT07 Temp Seneor Setup (ADC_RES[7:6]) & Convert Temperature [0] | 
| cyberjoey | 9:36ba3626aab7 | 25 | #define OT07_GPIO_SETUP 0x20 // OT07 GPIO Setup, sets GPIO modes | 
| cyberjoey | 17:401a5bb8d403 | 26 | #define OT07_GPIO_CTRL 0x21 // OT07 GPIO control | 
| cyberjoey | 9:36ba3626aab7 | 27 | #define OT07_ROM_ID 0x30 // OT07 ROM_ID address of LSB? | 
| cyberjoey | 9:36ba3626aab7 | 28 | |
| cyberjoey | 9:36ba3626aab7 | 29 | |
| cyberjoey | 9:36ba3626aab7 | 30 | #define MAX_DEVICES 64 // Maximum number of rom devices allowed | 
| cyberjoey | 9:36ba3626aab7 | 31 | #define ID_LENGTH 8 // Rom ID length in bytes | 
| cyberjoey | 9:36ba3626aab7 | 32 | |
| cyberjoey | 9:36ba3626aab7 | 33 | |
| cyberjoey | 9:36ba3626aab7 | 34 | #define BS 8 // ASCII Back Space | 
| cyberjoey | 9:36ba3626aab7 | 35 | #define CR 13 // ASCII Carriage Return | 
| cyberjoey | 9:36ba3626aab7 | 36 | |
| cyberjoey | 17:401a5bb8d403 | 37 | struct OT07_struct { | 
| cyberjoey | 17:401a5bb8d403 | 38 | char rom_id[ID_LENGTH]; // device 8 byte ROM ID | 
| cyberjoey | 17:401a5bb8d403 | 39 | char I2C_address; // I2C addess, based on GPIO0 and GPIO1 at power up | 
| cyberjoey | 17:401a5bb8d403 | 40 | }; | 
| cyberjoey | 17:401a5bb8d403 | 41 | |
| cyberjoey | 10:148da21c297e | 42 | const char* settings_file = "/sd/settings.txt"; | 
| cyberjoey | 22:fe94be11bae0 | 43 | const char* log_file = "/sd/MAX30208Log.csv"; | 
| cyberjoey | 10:148da21c297e | 44 | |
| cyberjoey | 9:36ba3626aab7 | 45 | //global variable | 
| cyberjoey | 9:36ba3626aab7 | 46 | |
| cyberjoey | 9:36ba3626aab7 | 47 | //******************** init Feather Boared Hardware *********************** | 
| cyberjoey | 9:36ba3626aab7 | 48 | |
| cyberjoey | 9:36ba3626aab7 | 49 | MAX32630FTHR pegasus(MAX32630FTHR::VIO_3V3); | 
| cyberjoey | 9:36ba3626aab7 | 50 | |
| cyberjoey | 9:36ba3626aab7 | 51 | //microSD logging file system setup | 
| cyberjoey | 9:36ba3626aab7 | 52 | SDFileSystem sd(P0_5, P0_6, P0_4, P0_7, "sd"); // mosi, miso, sclk, cs | 
| cyberjoey | 9:36ba3626aab7 | 53 | |
| cyberjoey | 9:36ba3626aab7 | 54 | //SD card insertion detection pin | 
| cyberjoey | 9:36ba3626aab7 | 55 | DigitalIn SDDetect(P2_2, PullUp); | 
| cyberjoey | 11:94a7379c0db8 | 56 | InterruptIn SDInsert(P2_2); | 
| cyberjoey | 9:36ba3626aab7 | 57 | |
| cyberjoey | 9:36ba3626aab7 | 58 | |
| cyberjoey | 9:36ba3626aab7 | 59 | // Virtual serial port over USB | 
| cyberjoey | 15:61dce4bef44f | 60 | USBSerial pc(0x0B6A, 0x0042, 0x0001, false); | 
| cyberjoey | 9:36ba3626aab7 | 61 | |
| cyberjoey | 9:36ba3626aab7 | 62 | // I2C setup | 
| cyberjoey | 9:36ba3626aab7 | 63 | I2C i2c(P3_4,P3_5); // P3_4 -> I2C1_SDA, P3_5-> I2C1_SCL | 
| cyberjoey | 9:36ba3626aab7 | 64 | |
| cyberjoey | 9:36ba3626aab7 | 65 | //Timer setup | 
| cyberjoey | 9:36ba3626aab7 | 66 | Ticker timer_1; // timer for blinking led heartbeat | 
| cyberjoey | 9:36ba3626aab7 | 67 | |
| cyberjoey | 9:36ba3626aab7 | 68 | bool tick_flag; // used for counting seconds | 
| cyberjoey | 9:36ba3626aab7 | 69 | bool log_flag = false; | 
| cyberjoey | 9:36ba3626aab7 | 70 | bool led_toggle_flag = false; | 
| cyberjoey | 9:36ba3626aab7 | 71 | bool button_flag = false; | 
| cyberjoey | 11:94a7379c0db8 | 72 | bool sd_insert_flag = false; | 
| cyberjoey | 9:36ba3626aab7 | 73 | bool error_flag; | 
| cyberjoey | 9:36ba3626aab7 | 74 | int error_ticks; | 
| cyberjoey | 9:36ba3626aab7 | 75 | |
| cyberjoey | 9:36ba3626aab7 | 76 | //LED blink setup | 
| switches | 1:90313362ec11 | 77 | DigitalOut rLED(LED1); | 
| switches | 1:90313362ec11 | 78 | DigitalOut gLED(LED2); | 
| cyberjoey | 9:36ba3626aab7 | 79 | DigitalOut bLED(LED3); | 
| switches | 0:60a522ae2e35 | 80 | |
| cyberjoey | 9:36ba3626aab7 | 81 | InterruptIn button(SW1); | 
| cyberjoey | 9:36ba3626aab7 | 82 | |
| cyberjoey | 9:36ba3626aab7 | 83 | |
| cyberjoey | 9:36ba3626aab7 | 84 | void LED_blink_callback(){ // LED Heart beat | 
| cyberjoey | 9:36ba3626aab7 | 85 | |
| cyberjoey | 9:36ba3626aab7 | 86 | led_toggle_flag = !led_toggle_flag; | 
| cyberjoey | 9:36ba3626aab7 | 87 | |
| cyberjoey | 9:36ba3626aab7 | 88 | if(log_flag) //if logging | 
| cyberjoey | 9:36ba3626aab7 | 89 | { | 
| cyberjoey | 9:36ba3626aab7 | 90 | |
| cyberjoey | 9:36ba3626aab7 | 91 | if(led_toggle_flag) | 
| cyberjoey | 9:36ba3626aab7 | 92 | { | 
| cyberjoey | 9:36ba3626aab7 | 93 | //toggle red led | 
| cyberjoey | 9:36ba3626aab7 | 94 | rLED = LED_ON; | 
| cyberjoey | 9:36ba3626aab7 | 95 | } | 
| cyberjoey | 9:36ba3626aab7 | 96 | else | 
| cyberjoey | 9:36ba3626aab7 | 97 | { | 
| cyberjoey | 9:36ba3626aab7 | 98 | rLED = LED_OFF; | 
| cyberjoey | 9:36ba3626aab7 | 99 | gLED = LED_OFF; | 
| cyberjoey | 9:36ba3626aab7 | 100 | bLED = LED_OFF; | 
| cyberjoey | 9:36ba3626aab7 | 101 | } | 
| cyberjoey | 9:36ba3626aab7 | 102 | } | 
| cyberjoey | 9:36ba3626aab7 | 103 | else if(error_flag) //if error (no sd card) | 
| cyberjoey | 9:36ba3626aab7 | 104 | { | 
| cyberjoey | 9:36ba3626aab7 | 105 | if(led_toggle_flag) | 
| cyberjoey | 9:36ba3626aab7 | 106 | { | 
| cyberjoey | 9:36ba3626aab7 | 107 | //toggle red led | 
| cyberjoey | 9:36ba3626aab7 | 108 | rLED = LED_ON; | 
| cyberjoey | 9:36ba3626aab7 | 109 | gLED = LED_ON; | 
| cyberjoey | 9:36ba3626aab7 | 110 | } | 
| cyberjoey | 9:36ba3626aab7 | 111 | else | 
| cyberjoey | 9:36ba3626aab7 | 112 | { | 
| cyberjoey | 9:36ba3626aab7 | 113 | rLED = LED_OFF; | 
| cyberjoey | 9:36ba3626aab7 | 114 | gLED = LED_OFF; | 
| cyberjoey | 9:36ba3626aab7 | 115 | bLED = LED_OFF; | 
| cyberjoey | 9:36ba3626aab7 | 116 | } | 
| cyberjoey | 9:36ba3626aab7 | 117 | error_ticks--; | 
| cyberjoey | 9:36ba3626aab7 | 118 | if(error_ticks <= 0) | 
| cyberjoey | 9:36ba3626aab7 | 119 | error_flag = false; | 
| cyberjoey | 9:36ba3626aab7 | 120 | } | 
| cyberjoey | 9:36ba3626aab7 | 121 | else | 
| cyberjoey | 9:36ba3626aab7 | 122 | { | 
| cyberjoey | 9:36ba3626aab7 | 123 | if(led_toggle_flag) | 
| cyberjoey | 9:36ba3626aab7 | 124 | { | 
| cyberjoey | 9:36ba3626aab7 | 125 | //toggle teal leds | 
| cyberjoey | 9:36ba3626aab7 | 126 | gLED = LED_ON; | 
| cyberjoey | 9:36ba3626aab7 | 127 | bLED = LED_ON; | 
| cyberjoey | 9:36ba3626aab7 | 128 | } | 
| cyberjoey | 9:36ba3626aab7 | 129 | else | 
| cyberjoey | 9:36ba3626aab7 | 130 | { | 
| cyberjoey | 9:36ba3626aab7 | 131 | rLED = LED_OFF; | 
| cyberjoey | 9:36ba3626aab7 | 132 | gLED = LED_OFF; | 
| cyberjoey | 9:36ba3626aab7 | 133 | bLED = LED_OFF; | 
| cyberjoey | 9:36ba3626aab7 | 134 | } | 
| cyberjoey | 9:36ba3626aab7 | 135 | } | 
| cyberjoey | 9:36ba3626aab7 | 136 | |
| cyberjoey | 9:36ba3626aab7 | 137 | tick_flag = true; | 
| cyberjoey | 9:36ba3626aab7 | 138 | } | 
| cyberjoey | 9:36ba3626aab7 | 139 | |
| cyberjoey | 9:36ba3626aab7 | 140 | void btn_pressed() //button pressed isr | 
| cyberjoey | 9:36ba3626aab7 | 141 | { | 
| cyberjoey | 9:36ba3626aab7 | 142 | button_flag = true; | 
| cyberjoey | 9:36ba3626aab7 | 143 | } | 
| cyberjoey | 9:36ba3626aab7 | 144 | |
| cyberjoey | 11:94a7379c0db8 | 145 | void sd_insert() //sd_insert pressed isr | 
| cyberjoey | 11:94a7379c0db8 | 146 | { | 
| cyberjoey | 11:94a7379c0db8 | 147 | sd_insert_flag = true; | 
| cyberjoey | 11:94a7379c0db8 | 148 | } | 
| cyberjoey | 11:94a7379c0db8 | 149 | |
| cyberjoey | 9:36ba3626aab7 | 150 | |
| cyberjoey | 9:36ba3626aab7 | 151 | // ***************************************************************************** | 
| cyberjoey | 9:36ba3626aab7 | 152 | // Define CRC-8 Table | 
| cyberjoey | 9:36ba3626aab7 | 153 | // ***************************************************************************** | 
| cyberjoey | 9:36ba3626aab7 | 154 | |
| cyberjoey | 9:36ba3626aab7 | 155 | static unsigned char crc_table[] = { | 
| cyberjoey | 9:36ba3626aab7 | 156 | 0, 94,188,226, 97, 63,221,131,194,156,126, 32,163,253, 31, 65, | 
| cyberjoey | 9:36ba3626aab7 | 157 | 157,195, 33,127,252,162, 64, 30, 95, 1,227,189, 62, 96,130,220, | 
| cyberjoey | 9:36ba3626aab7 | 158 | 35,125,159,193, 66, 28,254,160,225,191, 93, 3,128,222, 60, 98, | 
| cyberjoey | 9:36ba3626aab7 | 159 | 190,224, 2, 92,223,129, 99, 61,124, 34,192,158, 29, 67,161,255, | 
| cyberjoey | 9:36ba3626aab7 | 160 | 70, 24,250,164, 39,121,155,197,132,218, 56,102,229,187, 89, 7, | 
| cyberjoey | 9:36ba3626aab7 | 161 | 219,133,103, 57,186,228, 6, 88, 25, 71,165,251,120, 38,196,154, | 
| cyberjoey | 9:36ba3626aab7 | 162 | 101, 59,217,135, 4, 90,184,230,167,249, 27, 69,198,152,122, 36, | 
| cyberjoey | 9:36ba3626aab7 | 163 | 248,166, 68, 26,153,199, 37,123, 58,100,134,216, 91, 5,231,185, | 
| cyberjoey | 9:36ba3626aab7 | 164 | 140,210, 48,110,237,179, 81, 15, 78, 16,242,172, 47,113,147,205, | 
| cyberjoey | 9:36ba3626aab7 | 165 | 17, 79,173,243,112, 46,204,146,211,141,111, 49,178,236, 14, 80, | 
| cyberjoey | 9:36ba3626aab7 | 166 | 175,241, 19, 77,206,144,114, 44,109, 51,209,143, 12, 82,176,238, | 
| cyberjoey | 9:36ba3626aab7 | 167 | 50,108,142,208, 83, 13,239,177,240,174, 76, 18,145,207, 45,115, | 
| cyberjoey | 9:36ba3626aab7 | 168 | 202,148,118, 40,171,245, 23, 73, 8, 86,180,234,105, 55,213,139, | 
| cyberjoey | 9:36ba3626aab7 | 169 | 87, 9,235,181, 54,104,138,212,149,203, 41,119,244,170, 72, 22, | 
| cyberjoey | 9:36ba3626aab7 | 170 | 233,183, 85, 11,136,214, 52,106, 43,117,151,201, 74, 20,246,168, | 
| cyberjoey | 9:36ba3626aab7 | 171 | 116, 42,200,150, 21, 75,169,247,182,232, 10, 84,215,137,107, 53}; | 
| cyberjoey | 9:36ba3626aab7 | 172 | |
| cyberjoey | 9:36ba3626aab7 | 173 | |
| cyberjoey | 9:36ba3626aab7 | 174 | |
| cyberjoey | 9:36ba3626aab7 | 175 | // ----------------------------------------------------------------------------- | 
| cyberjoey | 9:36ba3626aab7 | 176 | // Calculate the CRC8 of the byte value provided with the current total | 
| cyberjoey | 9:36ba3626aab7 | 177 | // calc_crc8(unsigned char, unsigned char) crc8 total, byte to add | 
| cyberjoey | 9:36ba3626aab7 | 178 | // pass crc8 total = 0 to start new crc sum. | 
| cyberjoey | 9:36ba3626aab7 | 179 | |
| cyberjoey | 9:36ba3626aab7 | 180 | // Returns new crc8 total | 
| cyberjoey | 9:36ba3626aab7 | 181 | // ----------------------------------------------------------------------------- | 
| cyberjoey | 9:36ba3626aab7 | 182 | |
| cyberjoey | 9:36ba3626aab7 | 183 | unsigned char calc_crc8(unsigned char crc8, unsigned char value){ | 
| cyberjoey | 9:36ba3626aab7 | 184 | |
| cyberjoey | 9:36ba3626aab7 | 185 | return crc_table[crc8 ^ value]; | 
| cyberjoey | 9:36ba3626aab7 | 186 | } | 
| cyberjoey | 9:36ba3626aab7 | 187 | |
| cyberjoey | 9:36ba3626aab7 | 188 | // ***************************************************************************** | 
| cyberjoey | 17:401a5bb8d403 | 189 | // OT07_write_register(char, char, char) writes single byte to OT07 | 
| cyberjoey | 17:401a5bb8d403 | 190 | // char I2C address | 
| cyberjoey | 17:401a5bb8d403 | 191 | // char OT07 register address | 
| cyberjoey | 17:401a5bb8d403 | 192 | // char data byte to be writen | 
| cyberjoey | 17:401a5bb8d403 | 193 | // returns 0 on success ACK, 1 on NACK | 
| cyberjoey | 17:401a5bb8d403 | 194 | // ***************************************************************************** | 
| cyberjoey | 17:401a5bb8d403 | 195 | |
| cyberjoey | 17:401a5bb8d403 | 196 | int OT07_write_register(char I2C_add, char reg_add, char byte){ | 
| cyberjoey | 17:401a5bb8d403 | 197 | char data[2]; | 
| cyberjoey | 17:401a5bb8d403 | 198 | int error; | 
| cyberjoey | 17:401a5bb8d403 | 199 | data[0] = reg_add; | 
| cyberjoey | 17:401a5bb8d403 | 200 | data[1] = byte; | 
| cyberjoey | 17:401a5bb8d403 | 201 | error = i2c.write(I2C_add,data,2); | 
| cyberjoey | 17:401a5bb8d403 | 202 | //if(DEBUG)db.printf("wr[%02X %02X %d]\r\n", data[0], data[1], error); | 
| cyberjoey | 17:401a5bb8d403 | 203 | return error; | 
| cyberjoey | 17:401a5bb8d403 | 204 | |
| cyberjoey | 17:401a5bb8d403 | 205 | } | 
| cyberjoey | 17:401a5bb8d403 | 206 | |
| cyberjoey | 17:401a5bb8d403 | 207 | /// **************************************************************************** | 
| cyberjoey | 17:401a5bb8d403 | 208 | // OT07_write_register(char, char, char *, int) writes multiple bytes to OT07 | 
| cyberjoey | 17:401a5bb8d403 | 209 | // char I2C address | 
| cyberjoey | 17:401a5bb8d403 | 210 | // char OT07 register address | 
| cyberjoey | 17:401a5bb8d403 | 211 | // char * data vector of bytes to be written | 
| cyberjoey | 17:401a5bb8d403 | 212 | // int number of bytes to write | 
| cyberjoey | 17:401a5bb8d403 | 213 | // returns 0 on success ACK, 1 on NACK | 
| cyberjoey | 17:401a5bb8d403 | 214 | // ***************************************************************************** | 
| cyberjoey | 17:401a5bb8d403 | 215 | |
| cyberjoey | 17:401a5bb8d403 | 216 | int OT07_write_register(char I2C_add, char reg_add, char *bytes, int n){ | 
| cyberjoey | 17:401a5bb8d403 | 217 | int i; | 
| cyberjoey | 17:401a5bb8d403 | 218 | //set start address | 
| cyberjoey | 17:401a5bb8d403 | 219 | char data[16]; | 
| cyberjoey | 17:401a5bb8d403 | 220 | int error; | 
| cyberjoey | 17:401a5bb8d403 | 221 | data[0] = reg_add; | 
| cyberjoey | 17:401a5bb8d403 | 222 | for(i=1;i<=n;i++){ | 
| cyberjoey | 17:401a5bb8d403 | 223 | data[i] = bytes[i-1]; | 
| cyberjoey | 17:401a5bb8d403 | 224 | } | 
| cyberjoey | 17:401a5bb8d403 | 225 | error = i2c.write(I2C_add,data,n+1); // send n bytes of data | 
| cyberjoey | 17:401a5bb8d403 | 226 | |
| cyberjoey | 17:401a5bb8d403 | 227 | return error; | 
| cyberjoey | 17:401a5bb8d403 | 228 | } | 
| cyberjoey | 17:401a5bb8d403 | 229 | |
| cyberjoey | 17:401a5bb8d403 | 230 | // ***************************************************************************** | 
| cyberjoey | 17:401a5bb8d403 | 231 | // OT07_read_register(char, char, char *, int) writes single byte to OT07 | 
| cyberjoey | 17:401a5bb8d403 | 232 | // char I2C address | 
| cyberjoey | 17:401a5bb8d403 | 233 | // char OT07 register address | 
| cyberjoey | 17:401a5bb8d403 | 234 | // char * data vector for read bytes to be stored in | 
| cyberjoey | 17:401a5bb8d403 | 235 | // int number of bytes to read | 
| cyberjoey | 17:401a5bb8d403 | 236 | // returns 0 on success, 1 on fail | 
| cyberjoey | 17:401a5bb8d403 | 237 | // ***************************************************************************** | 
| cyberjoey | 17:401a5bb8d403 | 238 | |
| cyberjoey | 17:401a5bb8d403 | 239 | int OT07_read_register(char I2C_add, char reg_add, char *bytes, int n){ | 
| cyberjoey | 17:401a5bb8d403 | 240 | int error; | 
| cyberjoey | 17:401a5bb8d403 | 241 | error = i2c.write(I2C_add,®_add,1,1); | 
| cyberjoey | 17:401a5bb8d403 | 242 | if(error)return error; | 
| cyberjoey | 17:401a5bb8d403 | 243 | error = i2c.read(I2C_add,bytes,n); | 
| cyberjoey | 17:401a5bb8d403 | 244 | //if(DEBUG)db.printf("rr e[%d]\r\n",error); | 
| cyberjoey | 17:401a5bb8d403 | 245 | return error; | 
| cyberjoey | 17:401a5bb8d403 | 246 | } | 
| cyberjoey | 17:401a5bb8d403 | 247 | |
| cyberjoey | 17:401a5bb8d403 | 248 | // ***************************************************************************** | 
| cyberjoey | 17:401a5bb8d403 | 249 | // search_I2C_bus(OT07_struct *) searches I2C address 0xA0, 0xA2, 0xA4 and 0xA6 | 
| cyberjoey | 17:401a5bb8d403 | 250 | // OT07_struct * structure array to holds I2C address and rom_ids | 
| cyberjoey | 17:401a5bb8d403 | 251 | // returns number of devices found | 
| cyberjoey | 17:401a5bb8d403 | 252 | // ***************************************************************************** | 
| cyberjoey | 17:401a5bb8d403 | 253 | |
| cyberjoey | 17:401a5bb8d403 | 254 | int search_I2C_bus(OT07_struct OT07[]){ | 
| cyberjoey | 17:401a5bb8d403 | 255 | char data[16]; | 
| cyberjoey | 17:401a5bb8d403 | 256 | char I2C_add; | 
| cyberjoey | 17:401a5bb8d403 | 257 | //char GPIO; | 
| cyberjoey | 17:401a5bb8d403 | 258 | int error; | 
| cyberjoey | 17:401a5bb8d403 | 259 | int device_count = 0; | 
| cyberjoey | 17:401a5bb8d403 | 260 | int i; | 
| cyberjoey | 17:401a5bb8d403 | 261 | int j; | 
| cyberjoey | 17:401a5bb8d403 | 262 | for(i = 0;i<4;i++){ | 
| cyberjoey | 17:401a5bb8d403 | 263 | I2C_add = 0xA0 + i*2; | 
| cyberjoey | 17:401a5bb8d403 | 264 | error = OT07_read_register(I2C_add,0xff,data,1); | 
| cyberjoey | 17:401a5bb8d403 | 265 | |
| cyberjoey | 17:401a5bb8d403 | 266 | if(error == 0){ | 
| cyberjoey | 17:401a5bb8d403 | 267 | if(data[0] == 0x30){ | 
| cyberjoey | 17:401a5bb8d403 | 268 | |
| cyberjoey | 17:401a5bb8d403 | 269 | OT07[device_count].I2C_address = I2C_add; | 
| cyberjoey | 17:401a5bb8d403 | 270 | |
| cyberjoey | 17:401a5bb8d403 | 271 | OT07_read_register(I2C_add,OT07_ROM_ID,data,8); | 
| cyberjoey | 17:401a5bb8d403 | 272 | for(j=7;j>=0;j--){ | 
| cyberjoey | 17:401a5bb8d403 | 273 | OT07[device_count].rom_id[j] = data[j]; | 
| cyberjoey | 17:401a5bb8d403 | 274 | |
| cyberjoey | 17:401a5bb8d403 | 275 | } | 
| cyberjoey | 17:401a5bb8d403 | 276 | device_count++; | 
| cyberjoey | 17:401a5bb8d403 | 277 | } | 
| cyberjoey | 17:401a5bb8d403 | 278 | } | 
| cyberjoey | 17:401a5bb8d403 | 279 | |
| cyberjoey | 17:401a5bb8d403 | 280 | } | 
| cyberjoey | 17:401a5bb8d403 | 281 | return device_count; | 
| cyberjoey | 17:401a5bb8d403 | 282 | } | 
| cyberjoey | 17:401a5bb8d403 | 283 | |
| cyberjoey | 17:401a5bb8d403 | 284 | // ***************************************************************************** | 
| cyberjoey | 17:401a5bb8d403 | 285 | // convert_temperature(char) sends convert command to OT07 device | 
| cyberjoey | 17:401a5bb8d403 | 286 | // char I2C address | 
| cyberjoey | 17:401a5bb8d403 | 287 | // ***************************************************************************** | 
| cyberjoey | 17:401a5bb8d403 | 288 | |
| cyberjoey | 17:401a5bb8d403 | 289 | void convert_temperature(char I2C_add){ // set convert bit to start conversion | 
| cyberjoey | 17:401a5bb8d403 | 290 | |
| cyberjoey | 17:401a5bb8d403 | 291 | char data[2]; | 
| cyberjoey | 17:401a5bb8d403 | 292 | |
| cyberjoey | 17:401a5bb8d403 | 293 | //read ADC_SETUP register 0x14 | 
| cyberjoey | 17:401a5bb8d403 | 294 | OT07_read_register(I2C_add, OT07_ADC_SETUP,data,1); | 
| cyberjoey | 17:401a5bb8d403 | 295 | |
| cyberjoey | 17:401a5bb8d403 | 296 | //mask convert register value with 0x01 and write back register 0x14 | 
| cyberjoey | 17:401a5bb8d403 | 297 | OT07_write_register(I2C_add, OT07_ADC_SETUP, data[0]|0x01); | 
| cyberjoey | 17:401a5bb8d403 | 298 | } | 
| cyberjoey | 17:401a5bb8d403 | 299 | |
| cyberjoey | 17:401a5bb8d403 | 300 | //****************************************************************************** | 
| cyberjoey | 17:401a5bb8d403 | 301 | // get_temperature(char) read temperature from OT07 device FIFO register | 
| cyberjoey | 17:401a5bb8d403 | 302 | // char I2C address | 
| cyberjoey | 17:401a5bb8d403 | 303 | // returns double temperature in oC | 
| cyberjoey | 17:401a5bb8d403 | 304 | //****************************************************************************** | 
| cyberjoey | 17:401a5bb8d403 | 305 | |
| cyberjoey | 17:401a5bb8d403 | 306 | double get_temperature(char I2C_add){ | 
| cyberjoey | 17:401a5bb8d403 | 307 | char data[2]; | 
| cyberjoey | 17:401a5bb8d403 | 308 | double T; | 
| cyberjoey | 17:401a5bb8d403 | 309 | int count; | 
| cyberjoey | 17:401a5bb8d403 | 310 | |
| cyberjoey | 17:401a5bb8d403 | 311 | OT07_read_register(I2C_add,OT07_FIFO_DATA,data,2); // Read temperature from FIFO, 2 bytes | 
| cyberjoey | 17:401a5bb8d403 | 312 | //if(DEBUG)db.printf("get_temperature -- FIFO[%02X %02X]\r\n",data[0],data[1]); | 
| cyberjoey | 17:401a5bb8d403 | 313 | //calculate temperture from data | 
| cyberjoey | 17:401a5bb8d403 | 314 | count = (int)(data[0]*256 + data[1]); | 
| cyberjoey | 17:401a5bb8d403 | 315 | if (count >= 32768)count = count - 65536; // 2s comp | 
| cyberjoey | 17:401a5bb8d403 | 316 | T = (double)count*0.005; | 
| cyberjoey | 17:401a5bb8d403 | 317 | |
| cyberjoey | 17:401a5bb8d403 | 318 | return T; | 
| cyberjoey | 17:401a5bb8d403 | 319 | } | 
| cyberjoey | 17:401a5bb8d403 | 320 | |
| cyberjoey | 9:36ba3626aab7 | 321 | |
| cyberjoey | 10:148da21c297e | 322 | void write_settings_file(int interval, bool device_logged[MAX_DEVICES]) | 
| cyberjoey | 10:148da21c297e | 323 | { | 
| cyberjoey | 10:148da21c297e | 324 | FILE *fp = fopen(settings_file, "w"); | 
| cyberjoey | 10:148da21c297e | 325 | if (fp != NULL) | 
| cyberjoey | 10:148da21c297e | 326 | { | 
| cyberjoey | 10:148da21c297e | 327 | fprintf(fp, "i %d\r\n", interval); | 
| cyberjoey | 10:148da21c297e | 328 | |
| cyberjoey | 10:148da21c297e | 329 | fprintf(fp, "d"); | 
| cyberjoey | 10:148da21c297e | 330 | |
| cyberjoey | 10:148da21c297e | 331 | for(int i = 0; i < MAX_DEVICES; i++) | 
| cyberjoey | 10:148da21c297e | 332 | { | 
| cyberjoey | 10:148da21c297e | 333 | if(device_logged[i] == true) | 
| cyberjoey | 10:148da21c297e | 334 | { | 
| cyberjoey | 10:148da21c297e | 335 | fprintf(fp," %d", i); | 
| cyberjoey | 10:148da21c297e | 336 | } | 
| cyberjoey | 10:148da21c297e | 337 | } | 
| cyberjoey | 10:148da21c297e | 338 | fprintf(fp,"\r\n"); | 
| cyberjoey | 10:148da21c297e | 339 | |
| cyberjoey | 10:148da21c297e | 340 | fclose(fp); | 
| cyberjoey | 10:148da21c297e | 341 | } | 
| cyberjoey | 10:148da21c297e | 342 | return; | 
| cyberjoey | 10:148da21c297e | 343 | } | 
| cyberjoey | 10:148da21c297e | 344 | |
| cyberjoey | 20:ba06efe24970 | 345 | void clear_log_file() | 
| cyberjoey | 20:ba06efe24970 | 346 | { | 
| cyberjoey | 21:0f358a702561 | 347 | FILE *fp = fopen(log_file, "w"); | 
| cyberjoey | 20:ba06efe24970 | 348 | if (fp != NULL) | 
| cyberjoey | 20:ba06efe24970 | 349 | { | 
| cyberjoey | 20:ba06efe24970 | 350 | fclose(fp); | 
| cyberjoey | 20:ba06efe24970 | 351 | } | 
| cyberjoey | 20:ba06efe24970 | 352 | return; | 
| cyberjoey | 20:ba06efe24970 | 353 | } | 
| cyberjoey | 20:ba06efe24970 | 354 | |
| cyberjoey | 10:148da21c297e | 355 | bool print_settings_file() | 
| cyberjoey | 10:148da21c297e | 356 | { | 
| cyberjoey | 10:148da21c297e | 357 | FILE *fp = fopen(settings_file, "r"); | 
| cyberjoey | 10:148da21c297e | 358 | if (fp != NULL) | 
| cyberjoey | 10:148da21c297e | 359 | { | 
| cyberjoey | 10:148da21c297e | 360 | pc.printf("*\r\n"); | 
| cyberjoey | 10:148da21c297e | 361 | |
| cyberjoey | 10:148da21c297e | 362 | // Read contents from file | 
| cyberjoey | 10:148da21c297e | 363 | char c = fgetc(fp); | 
| cyberjoey | 11:94a7379c0db8 | 364 | |
| cyberjoey | 10:148da21c297e | 365 | while (!feof(fp)) | 
| cyberjoey | 10:148da21c297e | 366 | { | 
| cyberjoey | 10:148da21c297e | 367 | pc.printf("%c", c); | 
| cyberjoey | 10:148da21c297e | 368 | c = fgetc(fp); | 
| cyberjoey | 10:148da21c297e | 369 | } | 
| cyberjoey | 10:148da21c297e | 370 | |
| cyberjoey | 10:148da21c297e | 371 | pc.printf("*\r\n"); | 
| cyberjoey | 10:148da21c297e | 372 | |
| cyberjoey | 10:148da21c297e | 373 | fclose(fp); | 
| cyberjoey | 10:148da21c297e | 374 | } | 
| cyberjoey | 10:148da21c297e | 375 | else | 
| cyberjoey | 10:148da21c297e | 376 | { | 
| cyberjoey | 10:148da21c297e | 377 | return false; | 
| cyberjoey | 10:148da21c297e | 378 | } | 
| cyberjoey | 10:148da21c297e | 379 | return true; | 
| cyberjoey | 10:148da21c297e | 380 | } | 
| cyberjoey | 10:148da21c297e | 381 | |
| cyberjoey | 10:148da21c297e | 382 | bool print_log_file() | 
| cyberjoey | 10:148da21c297e | 383 | { | 
| cyberjoey | 10:148da21c297e | 384 | FILE *fp = fopen(log_file, "r"); | 
| cyberjoey | 10:148da21c297e | 385 | if (fp != NULL) | 
| cyberjoey | 10:148da21c297e | 386 | { | 
| cyberjoey | 10:148da21c297e | 387 | pc.printf("*\r\n"); | 
| cyberjoey | 10:148da21c297e | 388 | |
| cyberjoey | 10:148da21c297e | 389 | // Read contents from file | 
| cyberjoey | 10:148da21c297e | 390 | char c = fgetc(fp); | 
| cyberjoey | 10:148da21c297e | 391 | while (!feof(fp)) | 
| cyberjoey | 10:148da21c297e | 392 | { | 
| cyberjoey | 10:148da21c297e | 393 | pc.printf("%c", c); | 
| cyberjoey | 10:148da21c297e | 394 | c = fgetc(fp); | 
| cyberjoey | 10:148da21c297e | 395 | } | 
| cyberjoey | 10:148da21c297e | 396 | |
| cyberjoey | 10:148da21c297e | 397 | pc.printf("*\r\n"); | 
| cyberjoey | 10:148da21c297e | 398 | |
| cyberjoey | 10:148da21c297e | 399 | fclose(fp); | 
| cyberjoey | 10:148da21c297e | 400 | } | 
| cyberjoey | 10:148da21c297e | 401 | else | 
| cyberjoey | 10:148da21c297e | 402 | { | 
| cyberjoey | 10:148da21c297e | 403 | return false; | 
| cyberjoey | 10:148da21c297e | 404 | } | 
| cyberjoey | 10:148da21c297e | 405 | return true; | 
| cyberjoey | 10:148da21c297e | 406 | } | 
| cyberjoey | 10:148da21c297e | 407 | |
| cyberjoey | 11:94a7379c0db8 | 408 | int getline(char **lineptr, int *n, FILE *stream) { | 
| cyberjoey | 11:94a7379c0db8 | 409 | char *bufptr = NULL; | 
| cyberjoey | 11:94a7379c0db8 | 410 | char *p = bufptr; | 
| cyberjoey | 11:94a7379c0db8 | 411 | size_t size; | 
| cyberjoey | 11:94a7379c0db8 | 412 | int c; | 
| cyberjoey | 11:94a7379c0db8 | 413 | |
| cyberjoey | 11:94a7379c0db8 | 414 | if (lineptr == NULL) { | 
| cyberjoey | 11:94a7379c0db8 | 415 | return -1; | 
| cyberjoey | 11:94a7379c0db8 | 416 | } | 
| cyberjoey | 11:94a7379c0db8 | 417 | if (stream == NULL) { | 
| cyberjoey | 11:94a7379c0db8 | 418 | return -1; | 
| cyberjoey | 11:94a7379c0db8 | 419 | } | 
| cyberjoey | 11:94a7379c0db8 | 420 | if (n == NULL) { | 
| cyberjoey | 11:94a7379c0db8 | 421 | return -1; | 
| cyberjoey | 11:94a7379c0db8 | 422 | } | 
| cyberjoey | 11:94a7379c0db8 | 423 | bufptr = *lineptr; | 
| cyberjoey | 11:94a7379c0db8 | 424 | size = *n; | 
| cyberjoey | 11:94a7379c0db8 | 425 | |
| cyberjoey | 11:94a7379c0db8 | 426 | c = fgetc(stream); | 
| cyberjoey | 11:94a7379c0db8 | 427 | if (c == EOF) { | 
| cyberjoey | 11:94a7379c0db8 | 428 | return -1; | 
| cyberjoey | 11:94a7379c0db8 | 429 | } | 
| cyberjoey | 11:94a7379c0db8 | 430 | if (bufptr == NULL) { | 
| cyberjoey | 11:94a7379c0db8 | 431 | bufptr = (char *)malloc(128); | 
| cyberjoey | 11:94a7379c0db8 | 432 | if (bufptr == NULL) { | 
| cyberjoey | 11:94a7379c0db8 | 433 | return -1; | 
| cyberjoey | 11:94a7379c0db8 | 434 | } | 
| cyberjoey | 11:94a7379c0db8 | 435 | size = 128; | 
| cyberjoey | 11:94a7379c0db8 | 436 | } | 
| cyberjoey | 11:94a7379c0db8 | 437 | p = bufptr; | 
| cyberjoey | 11:94a7379c0db8 | 438 | while(c != EOF) { | 
| cyberjoey | 11:94a7379c0db8 | 439 | if ((p - bufptr) > (size - 1)) { | 
| cyberjoey | 11:94a7379c0db8 | 440 | size = size + 128; | 
| cyberjoey | 11:94a7379c0db8 | 441 | bufptr = (char *)realloc(bufptr, size); | 
| cyberjoey | 11:94a7379c0db8 | 442 | if (bufptr == NULL) { | 
| cyberjoey | 11:94a7379c0db8 | 443 | return -1; | 
| cyberjoey | 11:94a7379c0db8 | 444 | } | 
| cyberjoey | 11:94a7379c0db8 | 445 | } | 
| cyberjoey | 11:94a7379c0db8 | 446 | *p++ = c; | 
| cyberjoey | 11:94a7379c0db8 | 447 | if (c == '\n') { | 
| cyberjoey | 11:94a7379c0db8 | 448 | break; | 
| cyberjoey | 11:94a7379c0db8 | 449 | } | 
| cyberjoey | 11:94a7379c0db8 | 450 | c = fgetc(stream); | 
| cyberjoey | 11:94a7379c0db8 | 451 | } | 
| cyberjoey | 11:94a7379c0db8 | 452 | |
| cyberjoey | 11:94a7379c0db8 | 453 | *p++ = '\0'; | 
| cyberjoey | 11:94a7379c0db8 | 454 | *lineptr = bufptr; | 
| cyberjoey | 11:94a7379c0db8 | 455 | *n = size; | 
| cyberjoey | 11:94a7379c0db8 | 456 | |
| cyberjoey | 11:94a7379c0db8 | 457 | return p - bufptr - 1; | 
| cyberjoey | 11:94a7379c0db8 | 458 | } | 
| cyberjoey | 11:94a7379c0db8 | 459 | |
| cyberjoey | 14:480f2398fe6a | 460 | bool print_settings_file_2() | 
| cyberjoey | 14:480f2398fe6a | 461 | { | 
| cyberjoey | 14:480f2398fe6a | 462 | char * line = NULL; | 
| cyberjoey | 14:480f2398fe6a | 463 | int len = 0; | 
| cyberjoey | 14:480f2398fe6a | 464 | |
| cyberjoey | 14:480f2398fe6a | 465 | FILE *fp = fopen(settings_file, "r"); | 
| cyberjoey | 14:480f2398fe6a | 466 | if (fp != NULL) | 
| cyberjoey | 14:480f2398fe6a | 467 | { | 
| cyberjoey | 14:480f2398fe6a | 468 | pc.printf("*\r\n"); | 
| cyberjoey | 14:480f2398fe6a | 469 | |
| cyberjoey | 14:480f2398fe6a | 470 | // Read contents from file | 
| cyberjoey | 14:480f2398fe6a | 471 | while ((getline(&line, &len, fp)) != -1) | 
| cyberjoey | 14:480f2398fe6a | 472 | { | 
| cyberjoey | 14:480f2398fe6a | 473 | pc.printf("%s", line); | 
| cyberjoey | 14:480f2398fe6a | 474 | } | 
| cyberjoey | 14:480f2398fe6a | 475 | pc.printf("*\r\n"); | 
| cyberjoey | 14:480f2398fe6a | 476 | |
| cyberjoey | 14:480f2398fe6a | 477 | fclose(fp); | 
| cyberjoey | 14:480f2398fe6a | 478 | } | 
| cyberjoey | 14:480f2398fe6a | 479 | else | 
| cyberjoey | 14:480f2398fe6a | 480 | { | 
| cyberjoey | 14:480f2398fe6a | 481 | return false; | 
| cyberjoey | 14:480f2398fe6a | 482 | } | 
| cyberjoey | 14:480f2398fe6a | 483 | return true; | 
| cyberjoey | 14:480f2398fe6a | 484 | } | 
| cyberjoey | 14:480f2398fe6a | 485 | |
| cyberjoey | 11:94a7379c0db8 | 486 | //returns true if settings file exists and is in the proper format | 
| cyberjoey | 11:94a7379c0db8 | 487 | bool apply_settings_file(bool (&logged_devices)[MAX_DEVICES], int& interval) | 
| cyberjoey | 11:94a7379c0db8 | 488 | { | 
| cyberjoey | 11:94a7379c0db8 | 489 | |
| cyberjoey | 11:94a7379c0db8 | 490 | char * line = NULL; | 
| cyberjoey | 11:94a7379c0db8 | 491 | int len = 0; | 
| cyberjoey | 11:94a7379c0db8 | 492 | int line_number = 0; | 
| cyberjoey | 11:94a7379c0db8 | 493 | |
| cyberjoey | 11:94a7379c0db8 | 494 | |
| cyberjoey | 11:94a7379c0db8 | 495 | FILE *fp = fopen("/sd/settings.txt", "r"); | 
| cyberjoey | 11:94a7379c0db8 | 496 | if (fp != NULL) | 
| cyberjoey | 11:94a7379c0db8 | 497 | { | 
| cyberjoey | 11:94a7379c0db8 | 498 | |
| cyberjoey | 11:94a7379c0db8 | 499 | //initialize devices to all false; | 
| cyberjoey | 11:94a7379c0db8 | 500 | for(int i = 0; i < MAX_DEVICES; i++) | 
| cyberjoey | 11:94a7379c0db8 | 501 | { | 
| cyberjoey | 11:94a7379c0db8 | 502 | logged_devices[i] = false; | 
| cyberjoey | 11:94a7379c0db8 | 503 | } | 
| cyberjoey | 11:94a7379c0db8 | 504 | |
| cyberjoey | 11:94a7379c0db8 | 505 | // Read contents from file | 
| cyberjoey | 11:94a7379c0db8 | 506 | while ((getline(&line, &len, fp)) != -1) | 
| cyberjoey | 11:94a7379c0db8 | 507 | { | 
| cyberjoey | 11:94a7379c0db8 | 508 | line_number++; | 
| cyberjoey | 11:94a7379c0db8 | 509 | |
| cyberjoey | 11:94a7379c0db8 | 510 | char i = 0; | 
| cyberjoey | 11:94a7379c0db8 | 511 | char c = line[i]; | 
| cyberjoey | 11:94a7379c0db8 | 512 | while(c != '\0') | 
| cyberjoey | 11:94a7379c0db8 | 513 | { | 
| cyberjoey | 11:94a7379c0db8 | 514 | int number; | 
| cyberjoey | 11:94a7379c0db8 | 515 | int n; | 
| cyberjoey | 11:94a7379c0db8 | 516 | sscanf((line+i), "%d%n", &number, &n); | 
| cyberjoey | 11:94a7379c0db8 | 517 | if(isdigit(c)) | 
| cyberjoey | 11:94a7379c0db8 | 518 | { | 
| cyberjoey | 11:94a7379c0db8 | 519 | if(line_number == 1) | 
| cyberjoey | 11:94a7379c0db8 | 520 | { | 
| cyberjoey | 11:94a7379c0db8 | 521 | interval = number; | 
| cyberjoey | 11:94a7379c0db8 | 522 | } | 
| cyberjoey | 11:94a7379c0db8 | 523 | else if(line_number == 2) | 
| cyberjoey | 11:94a7379c0db8 | 524 | { | 
| cyberjoey | 11:94a7379c0db8 | 525 | logged_devices[number] = true; | 
| cyberjoey | 11:94a7379c0db8 | 526 | } | 
| cyberjoey | 11:94a7379c0db8 | 527 | if(n > 1) | 
| cyberjoey | 11:94a7379c0db8 | 528 | i = i + (n - 1); | 
| cyberjoey | 11:94a7379c0db8 | 529 | } | 
| cyberjoey | 11:94a7379c0db8 | 530 | i++; | 
| cyberjoey | 11:94a7379c0db8 | 531 | c = line[i]; | 
| cyberjoey | 11:94a7379c0db8 | 532 | } | 
| cyberjoey | 11:94a7379c0db8 | 533 | } | 
| cyberjoey | 11:94a7379c0db8 | 534 | |
| cyberjoey | 11:94a7379c0db8 | 535 | fclose(fp); | 
| cyberjoey | 11:94a7379c0db8 | 536 | } | 
| cyberjoey | 11:94a7379c0db8 | 537 | else | 
| cyberjoey | 11:94a7379c0db8 | 538 | { | 
| cyberjoey | 11:94a7379c0db8 | 539 | return false; | 
| cyberjoey | 11:94a7379c0db8 | 540 | } | 
| cyberjoey | 11:94a7379c0db8 | 541 | |
| cyberjoey | 11:94a7379c0db8 | 542 | return true; | 
| cyberjoey | 11:94a7379c0db8 | 543 | |
| cyberjoey | 11:94a7379c0db8 | 544 | } | 
| cyberjoey | 11:94a7379c0db8 | 545 | |
| cyberjoey | 9:36ba3626aab7 | 546 | //****************************************************************************** | 
| cyberjoey | 9:36ba3626aab7 | 547 | // main() | 
| cyberjoey | 9:36ba3626aab7 | 548 | //****************************************************************************** | 
| cyberjoey | 9:36ba3626aab7 | 549 | |
| cyberjoey | 9:36ba3626aab7 | 550 | |
| switches | 0:60a522ae2e35 | 551 | int main() | 
| switches | 0:60a522ae2e35 | 552 | { | 
| cyberjoey | 17:401a5bb8d403 | 553 | OT07_struct OT07[4]; // structure that holds I2C address and ROM_ID | 
| cyberjoey | 9:36ba3626aab7 | 554 | char data[130]; | 
| cyberjoey | 9:36ba3626aab7 | 555 | int device_count = 0; // number of OW devices found by search_rom() | 
| cyberjoey | 9:36ba3626aab7 | 556 | int i; | 
| cyberjoey | 9:36ba3626aab7 | 557 | int j; | 
| cyberjoey | 9:36ba3626aab7 | 558 | int k; | 
| cyberjoey | 9:36ba3626aab7 | 559 | |
| cyberjoey | 9:36ba3626aab7 | 560 | |
| cyberjoey | 9:36ba3626aab7 | 561 | char device_id[ID_LENGTH]; //8 byte rom id of current slected device | 
| cyberjoey | 9:36ba3626aab7 | 562 | char rom_id_list[MAX_DEVICES][ID_LENGTH]; //List of rom id for each device on OW bus | 
| cyberjoey | 9:36ba3626aab7 | 563 | |
| cyberjoey | 9:36ba3626aab7 | 564 | double T[MAX_DEVICES]; | 
| cyberjoey | 9:36ba3626aab7 | 565 | |
| cyberjoey | 10:148da21c297e | 566 | bool device_logged[MAX_DEVICES]; | 
| cyberjoey | 11:94a7379c0db8 | 567 | //initialize device_logged to all false; | 
| cyberjoey | 11:94a7379c0db8 | 568 | for(int i = 0; i < MAX_DEVICES; i++) | 
| cyberjoey | 11:94a7379c0db8 | 569 | { | 
| cyberjoey | 11:94a7379c0db8 | 570 | device_logged[i] = false; | 
| cyberjoey | 11:94a7379c0db8 | 571 | } | 
| cyberjoey | 10:148da21c297e | 572 | |
| cyberjoey | 9:36ba3626aab7 | 573 | // i/o variables | 
| cyberjoey | 9:36ba3626aab7 | 574 | char rx_buff[128]; // comport input buffer | 
| cyberjoey | 9:36ba3626aab7 | 575 | int rx_index; // rx_buffer pointer | 
| cyberjoey | 9:36ba3626aab7 | 576 | char c; // command type character | 
| cyberjoey | 9:36ba3626aab7 | 577 | int n; // argument count | 
| cyberjoey | 9:36ba3626aab7 | 578 | int arg1; // argumnet 1 | 
| cyberjoey | 9:36ba3626aab7 | 579 | int arg2; // argument 2 | 
| cyberjoey | 9:36ba3626aab7 | 580 | int device; // device argument | 
| cyberjoey | 9:36ba3626aab7 | 581 | int num_bytes; | 
| cyberjoey | 9:36ba3626aab7 | 582 | |
| cyberjoey | 9:36ba3626aab7 | 583 | int time_count; | 
| cyberjoey | 9:36ba3626aab7 | 584 | int log_interval = PERIOD; | 
| cyberjoey | 9:36ba3626aab7 | 585 | int time_to_sample; | 
| cyberjoey | 9:36ba3626aab7 | 586 | |
| cyberjoey | 11:94a7379c0db8 | 587 | apply_settings_file(device_logged, log_interval); | 
| cyberjoey | 11:94a7379c0db8 | 588 | |
| cyberjoey | 9:36ba3626aab7 | 589 | //************* init ticker timer callbacks **************** | 
| cyberjoey | 12:aa9fff0aec91 | 590 | timer_1.attach(&LED_blink_callback,0.5); //start ticker, once per sec. | 
| cyberjoey | 9:36ba3626aab7 | 591 | |
| cyberjoey | 9:36ba3626aab7 | 592 | |
| cyberjoey | 12:aa9fff0aec91 | 593 | i2c.frequency(400000); //set I2C clock to 400kHz | 
| cyberjoey | 9:36ba3626aab7 | 594 | |
| cyberjoey | 9:36ba3626aab7 | 595 | rLED = LED_OFF; | 
| switches | 6:96d8d823e292 | 596 | gLED = LED_ON; | 
| cyberjoey | 9:36ba3626aab7 | 597 | bLED = LED_ON; | 
| cyberjoey | 9:36ba3626aab7 | 598 | |
| cyberjoey | 9:36ba3626aab7 | 599 | |
| cyberjoey | 9:36ba3626aab7 | 600 | // reset DS2484 | 
| cyberjoey | 17:401a5bb8d403 | 601 | //data[0] = 0xE1; | 
| cyberjoey | 17:401a5bb8d403 | 602 | //data[1] = 0xF0; | 
| cyberjoey | 17:401a5bb8d403 | 603 | //i2c.write(DS2484_ADD,data,1,1); | 
| cyberjoey | 17:401a5bb8d403 | 604 | //i2c.read(DS2484_ADD,data,1); | 
| cyberjoey | 9:36ba3626aab7 | 605 | |
| cyberjoey | 9:36ba3626aab7 | 606 | // ****************** search for all OW devices on bus ***************** | 
| cyberjoey | 9:36ba3626aab7 | 607 | |
| cyberjoey | 17:401a5bb8d403 | 608 | //device_count = search_rom(rom_id_list); | 
| cyberjoey | 17:401a5bb8d403 | 609 | device_count = search_I2C_bus(OT07); | 
| cyberjoey | 9:36ba3626aab7 | 610 | |
| cyberjoey | 17:401a5bb8d403 | 611 | /*for(j=0;j<device_count;j++){ | 
| cyberjoey | 9:36ba3626aab7 | 612 | for(k=0;k<8;k++){ | 
| cyberjoey | 9:36ba3626aab7 | 613 | device_id[k] = rom_id_list[j][k]; // get device_id from rom_id_list | 
| cyberjoey | 9:36ba3626aab7 | 614 | } | 
| cyberjoey | 9:36ba3626aab7 | 615 | set_test_mode(device_id); | 
| cyberjoey | 17:401a5bb8d403 | 616 | }*/ | 
| cyberjoey | 9:36ba3626aab7 | 617 | |
| cyberjoey | 9:36ba3626aab7 | 618 | |
| cyberjoey | 9:36ba3626aab7 | 619 | rx_index = 0; //character buffer index for input from PC | 
| cyberjoey | 9:36ba3626aab7 | 620 | |
| cyberjoey | 9:36ba3626aab7 | 621 | button.fall(&btn_pressed); | 
| cyberjoey | 11:94a7379c0db8 | 622 | SDInsert.fall(&sd_insert); | 
| cyberjoey | 11:94a7379c0db8 | 623 | |
| cyberjoey | 11:94a7379c0db8 | 624 | sd.disk_initialize(); //initialize sd card | 
| cyberjoey | 9:36ba3626aab7 | 625 | |
| cyberjoey | 9:36ba3626aab7 | 626 | while(1) { // start main loop, take data if logging, check for input, repeat | 
| cyberjoey | 9:36ba3626aab7 | 627 | |
| cyberjoey | 11:94a7379c0db8 | 628 | if(sd_insert_flag == true) | 
| cyberjoey | 11:94a7379c0db8 | 629 | { | 
| cyberjoey | 11:94a7379c0db8 | 630 | sd.disk_initialize(); | 
| cyberjoey | 11:94a7379c0db8 | 631 | sd_insert_flag = false; | 
| cyberjoey | 11:94a7379c0db8 | 632 | } | 
| cyberjoey | 11:94a7379c0db8 | 633 | |
| cyberjoey | 9:36ba3626aab7 | 634 | if(button_flag == true) | 
| cyberjoey | 9:36ba3626aab7 | 635 | { | 
| cyberjoey | 9:36ba3626aab7 | 636 | if(log_flag == false){ //start logging | 
| cyberjoey | 9:36ba3626aab7 | 637 | |
| cyberjoey | 9:36ba3626aab7 | 638 | if(SDDetect)//if SD card not detected | 
| cyberjoey | 9:36ba3626aab7 | 639 | { | 
| cyberjoey | 9:36ba3626aab7 | 640 | error_flag = true; | 
| cyberjoey | 9:36ba3626aab7 | 641 | error_ticks = 6; | 
| cyberjoey | 9:36ba3626aab7 | 642 | log_flag = false; | 
| cyberjoey | 9:36ba3626aab7 | 643 | } | 
| cyberjoey | 9:36ba3626aab7 | 644 | else | 
| cyberjoey | 9:36ba3626aab7 | 645 | { | 
| cyberjoey | 11:94a7379c0db8 | 646 | apply_settings_file(device_logged, log_interval); | 
| cyberjoey | 11:94a7379c0db8 | 647 | |
| cyberjoey | 10:148da21c297e | 648 | FILE *fp = fopen(log_file, "a"); | 
| cyberjoey | 9:36ba3626aab7 | 649 | if (fp != NULL) | 
| cyberjoey | 9:36ba3626aab7 | 650 | { | 
| cyberjoey | 17:401a5bb8d403 | 651 | fprintf(fp,"Device List\r\n"); | 
| cyberjoey | 17:401a5bb8d403 | 652 | fprintf(fp,"Device Number, ROM Code\r\n"); | 
| cyberjoey | 17:401a5bb8d403 | 653 | for(j=0;j<device_count;j++) | 
| cyberjoey | 17:401a5bb8d403 | 654 | { | 
| cyberjoey | 17:401a5bb8d403 | 655 | if(device_logged[j]) | 
| cyberjoey | 17:401a5bb8d403 | 656 | { | 
| cyberjoey | 17:401a5bb8d403 | 657 | fprintf(fp,"%d,0x",j); | 
| cyberjoey | 17:401a5bb8d403 | 658 | for(i=7;i>=0;i--) | 
| cyberjoey | 17:401a5bb8d403 | 659 | { | 
| cyberjoey | 21:0f358a702561 | 660 | fprintf(fp,"%02X",OT07[j].rom_id[i]); | 
| cyberjoey | 17:401a5bb8d403 | 661 | } | 
| cyberjoey | 17:401a5bb8d403 | 662 | fprintf(fp,"\r\n"); | 
| cyberjoey | 17:401a5bb8d403 | 663 | } | 
| cyberjoey | 17:401a5bb8d403 | 664 | } | 
| cyberjoey | 17:401a5bb8d403 | 665 | |
| cyberjoey | 9:36ba3626aab7 | 666 | fprintf(fp, "Time(s)"); | 
| cyberjoey | 9:36ba3626aab7 | 667 | |
| cyberjoey | 9:36ba3626aab7 | 668 | for(j=0;j<device_count;j++) | 
| cyberjoey | 9:36ba3626aab7 | 669 | { | 
| cyberjoey | 11:94a7379c0db8 | 670 | if(device_logged[j]) | 
| cyberjoey | 16:2f373d3c8214 | 671 | fprintf(fp,",Device %d Temperature (C)",j); | 
| cyberjoey | 9:36ba3626aab7 | 672 | } | 
| cyberjoey | 9:36ba3626aab7 | 673 | fprintf(fp,"\r\n"); | 
| cyberjoey | 9:36ba3626aab7 | 674 | |
| cyberjoey | 9:36ba3626aab7 | 675 | fclose(fp); | 
| cyberjoey | 9:36ba3626aab7 | 676 | } | 
| cyberjoey | 9:36ba3626aab7 | 677 | |
| cyberjoey | 9:36ba3626aab7 | 678 | time_count = 0; | 
| cyberjoey | 9:36ba3626aab7 | 679 | |
| cyberjoey | 9:36ba3626aab7 | 680 | time_to_sample = 0; // force sample at time = 0; | 
| cyberjoey | 9:36ba3626aab7 | 681 | tick_flag = true; // force sample at time = 0; | 
| cyberjoey | 9:36ba3626aab7 | 682 | log_flag = true; | 
| cyberjoey | 9:36ba3626aab7 | 683 | } | 
| cyberjoey | 9:36ba3626aab7 | 684 | }else{ | 
| cyberjoey | 9:36ba3626aab7 | 685 | log_flag = false; | 
| cyberjoey | 9:36ba3626aab7 | 686 | } | 
| cyberjoey | 9:36ba3626aab7 | 687 | button_flag = false; | 
| cyberjoey | 9:36ba3626aab7 | 688 | } | 
| switches | 1:90313362ec11 | 689 | |
| cyberjoey | 9:36ba3626aab7 | 690 | while(tick_flag == false){ //check for input while waiting for next tick | 
| cyberjoey | 9:36ba3626aab7 | 691 | |
| cyberjoey | 9:36ba3626aab7 | 692 | // ---------------------------------------------------------------------------- | 
| cyberjoey | 9:36ba3626aab7 | 693 | // test for charater input for USB com port | 
| cyberjoey | 9:36ba3626aab7 | 694 | // ---------------------------------------------------------------------------- | 
| cyberjoey | 9:36ba3626aab7 | 695 | |
| cyberjoey | 9:36ba3626aab7 | 696 | //test if PC sent some charaters | 
| cyberjoey | 9:36ba3626aab7 | 697 | while(pc.readable()){ //characters in buffer, get them | 
| cyberjoey | 9:36ba3626aab7 | 698 | rx_buff[rx_index] = pc.getc(); | 
| cyberjoey | 9:36ba3626aab7 | 699 | |
| cyberjoey | 9:36ba3626aab7 | 700 | if(rx_buff[rx_index] == CR){ | 
| cyberjoey | 9:36ba3626aab7 | 701 | rx_buff[++rx_index] = 0; | 
| cyberjoey | 9:36ba3626aab7 | 702 | rx_index = -1; // because i++ at end of while give i=0 on next loop | 
| cyberjoey | 9:36ba3626aab7 | 703 | device = 0; | 
| cyberjoey | 9:36ba3626aab7 | 704 | arg1 = 0; | 
| cyberjoey | 9:36ba3626aab7 | 705 | arg2 = 0; | 
| cyberjoey | 9:36ba3626aab7 | 706 | |
| cyberjoey | 9:36ba3626aab7 | 707 | n = sscanf(rx_buff, " %c %d %x %x", &c, & device, &arg1, &arg2); | 
| cyberjoey | 9:36ba3626aab7 | 708 | //process input | 
| cyberjoey | 9:36ba3626aab7 | 709 | if(n > 0){//got input so process it | 
| cyberjoey | 9:36ba3626aab7 | 710 | switch(c){ | 
| cyberjoey | 9:36ba3626aab7 | 711 | case 'a': | 
| cyberjoey | 9:36ba3626aab7 | 712 | case 'A': // alarm search | 
| cyberjoey | 9:36ba3626aab7 | 713 | // ****************** search for all OW devices with alarm triggered on bus ***************** | 
| cyberjoey | 17:401a5bb8d403 | 714 | /* | 
| cyberjoey | 9:36ba3626aab7 | 715 | device_count = alarm_search(rom_id_list); | 
| cyberjoey | 9:36ba3626aab7 | 716 | |
| cyberjoey | 9:36ba3626aab7 | 717 | pc.printf("%d devices:\r\n", device_count); | 
| cyberjoey | 9:36ba3626aab7 | 718 | for(j=0;j<device_count;j++){ | 
| cyberjoey | 9:36ba3626aab7 | 719 | pc.printf("device[%02X] rom id[",j); | 
| cyberjoey | 9:36ba3626aab7 | 720 | for(i=7;i>=0;i--){ | 
| cyberjoey | 9:36ba3626aab7 | 721 | pc.printf("%02X",rom_id_list[j][i]); | 
| cyberjoey | 9:36ba3626aab7 | 722 | } | 
| cyberjoey | 9:36ba3626aab7 | 723 | pc.printf("]\r\n"); | 
| cyberjoey | 17:401a5bb8d403 | 724 | } */ | 
| cyberjoey | 9:36ba3626aab7 | 725 | break; | 
| cyberjoey | 11:94a7379c0db8 | 726 | case 'c': | 
| cyberjoey | 11:94a7379c0db8 | 727 | case 'C': | 
| cyberjoey | 11:94a7379c0db8 | 728 | if(!SDDetect) | 
| cyberjoey | 11:94a7379c0db8 | 729 | pc.printf("y\r\n"); | 
| cyberjoey | 11:94a7379c0db8 | 730 | else | 
| cyberjoey | 11:94a7379c0db8 | 731 | pc.printf("n\r\n"); | 
| cyberjoey | 11:94a7379c0db8 | 732 | break; | 
| cyberjoey | 10:148da21c297e | 733 | case 'd': | 
| cyberjoey | 10:148da21c297e | 734 | case 'D': | 
| cyberjoey | 10:148da21c297e | 735 | if(n==1) // if no device number is given | 
| cyberjoey | 10:148da21c297e | 736 | { | 
| cyberjoey | 10:148da21c297e | 737 | //clear device_logged array | 
| cyberjoey | 10:148da21c297e | 738 | for(int i = 0; i < MAX_DEVICES; i++) | 
| cyberjoey | 10:148da21c297e | 739 | { | 
| cyberjoey | 10:148da21c297e | 740 | device_logged[i] = false; | 
| cyberjoey | 10:148da21c297e | 741 | } | 
| cyberjoey | 10:148da21c297e | 742 | |
| cyberjoey | 10:148da21c297e | 743 | write_settings_file(log_interval, device_logged); | 
| cyberjoey | 10:148da21c297e | 744 | } | 
| cyberjoey | 10:148da21c297e | 745 | if(n == 2) | 
| cyberjoey | 10:148da21c297e | 746 | { | 
| cyberjoey | 10:148da21c297e | 747 | device_logged[device] = true; | 
| cyberjoey | 10:148da21c297e | 748 | write_settings_file(log_interval, device_logged); | 
| cyberjoey | 10:148da21c297e | 749 | } | 
| cyberjoey | 10:148da21c297e | 750 | break; | 
| cyberjoey | 9:36ba3626aab7 | 751 | case 'f': | 
| cyberjoey | 9:36ba3626aab7 | 752 | case 'F': //f is for "flash" for microSD | 
| cyberjoey | 12:aa9fff0aec91 | 753 | if(!SDDetect) | 
| cyberjoey | 9:36ba3626aab7 | 754 | pc.printf("y\r\n"); | 
| cyberjoey | 9:36ba3626aab7 | 755 | else | 
| cyberjoey | 12:aa9fff0aec91 | 756 | pc.printf("n\r\n"); | 
| cyberjoey | 9:36ba3626aab7 | 757 | break; | 
| cyberjoey | 10:148da21c297e | 758 | case 'g': | 
| cyberjoey | 10:148da21c297e | 759 | case 'G': | 
| cyberjoey | 10:148da21c297e | 760 | if(n == 2) | 
| cyberjoey | 10:148da21c297e | 761 | { | 
| cyberjoey | 21:0f358a702561 | 762 | //0 means get config, 1 means get log, 2 means clear log | 
| cyberjoey | 10:148da21c297e | 763 | bool fileExists = false; | 
| cyberjoey | 10:148da21c297e | 764 | if(device == 0)//get config | 
| cyberjoey | 10:148da21c297e | 765 | { | 
| cyberjoey | 10:148da21c297e | 766 | fileExists = print_settings_file(); | 
| cyberjoey | 10:148da21c297e | 767 | } | 
| cyberjoey | 10:148da21c297e | 768 | if(device == 1)//get log | 
| cyberjoey | 10:148da21c297e | 769 | { | 
| cyberjoey | 10:148da21c297e | 770 | fileExists = print_log_file(); | 
| cyberjoey | 10:148da21c297e | 771 | } | 
| cyberjoey | 21:0f358a702561 | 772 | if(device == 2)//get log | 
| cyberjoey | 21:0f358a702561 | 773 | { | 
| cyberjoey | 21:0f358a702561 | 774 | clear_log_file(); | 
| cyberjoey | 21:0f358a702561 | 775 | fileExists = true; | 
| cyberjoey | 21:0f358a702561 | 776 | } | 
| cyberjoey | 10:148da21c297e | 777 | if(!fileExists) | 
| cyberjoey | 10:148da21c297e | 778 | { | 
| cyberjoey | 10:148da21c297e | 779 | pc.printf("no_file\r\n"); | 
| cyberjoey | 10:148da21c297e | 780 | } | 
| cyberjoey | 10:148da21c297e | 781 | } | 
| cyberjoey | 20:ba06efe24970 | 782 | // read all registers command | 
| cyberjoey | 20:ba06efe24970 | 783 | //i.e. ("g 0 0" means readAll from device 0 "g 1 0" means readAll from device 1) | 
| cyberjoey | 20:ba06efe24970 | 784 | if(n == 3) | 
| cyberjoey | 20:ba06efe24970 | 785 | { | 
| cyberjoey | 20:ba06efe24970 | 786 | //device holds device number 0 means readAll command | 
| cyberjoey | 20:ba06efe24970 | 787 | OT07_read_register(OT07[device].I2C_address,0x00,data,1); | 
| cyberjoey | 20:ba06efe24970 | 788 | pc.printf("device[%02X] add[%02X] data[%02X] crc[FF FF]\r\n",device,0x00,data[0]); | 
| cyberjoey | 20:ba06efe24970 | 789 | OT07_read_register(OT07[device].I2C_address,0x01,data,1); | 
| cyberjoey | 20:ba06efe24970 | 790 | pc.printf("device[%02X] add[%02X] data[%02X] crc[FF FF]\r\n",device,0x01,data[0]); | 
| cyberjoey | 20:ba06efe24970 | 791 | OT07_read_register(OT07[device].I2C_address,0x04,data,1); | 
| cyberjoey | 20:ba06efe24970 | 792 | pc.printf("device[%02X] add[%02X] data[%02X] crc[FF FF]\r\n",device,0x04,data[0]); | 
| cyberjoey | 20:ba06efe24970 | 793 | OT07_read_register(OT07[device].I2C_address,0x05,data,1); | 
| cyberjoey | 20:ba06efe24970 | 794 | pc.printf("device[%02X] add[%02X] data[%02X] crc[FF FF]\r\n",device,0x05,data[0]); | 
| cyberjoey | 20:ba06efe24970 | 795 | OT07_read_register(OT07[device].I2C_address,0x06,data,1); | 
| cyberjoey | 20:ba06efe24970 | 796 | pc.printf("device[%02X] add[%02X] data[%02X] crc[FF FF]\r\n",device,0x06,data[0]); | 
| cyberjoey | 20:ba06efe24970 | 797 | OT07_read_register(OT07[device].I2C_address,0x07,data,1); | 
| cyberjoey | 20:ba06efe24970 | 798 | pc.printf("device[%02X] add[%02X] data[%02X] crc[FF FF]\r\n",device,0x07,data[0]); | 
| cyberjoey | 20:ba06efe24970 | 799 | OT07_read_register(OT07[device].I2C_address,0x08,data,1); | 
| cyberjoey | 20:ba06efe24970 | 800 | pc.printf("device[%02X] add[%02X] data[%02X] crc[FF FF]\r\n",device,0x08,data[0]); | 
| cyberjoey | 20:ba06efe24970 | 801 | OT07_read_register(OT07[device].I2C_address,0x09,data,1); | 
| cyberjoey | 20:ba06efe24970 | 802 | pc.printf("device[%02X] add[%02X] data[%02X] crc[FF FF]\r\n",device,0x09,data[0]); | 
| cyberjoey | 20:ba06efe24970 | 803 | OT07_read_register(OT07[device].I2C_address,0x0A,data,1); | 
| cyberjoey | 20:ba06efe24970 | 804 | pc.printf("device[%02X] add[%02X] data[%02X] crc[FF FF]\r\n",device,0x0A,data[0]); | 
| cyberjoey | 20:ba06efe24970 | 805 | OT07_read_register(OT07[device].I2C_address,0x0C,data,1); | 
| cyberjoey | 20:ba06efe24970 | 806 | pc.printf("device[%02X] add[%02X] data[%02X] crc[FF FF]\r\n",device,0x0C,data[0]); | 
| cyberjoey | 20:ba06efe24970 | 807 | OT07_read_register(OT07[device].I2C_address,0x10,data,1); | 
| cyberjoey | 20:ba06efe24970 | 808 | pc.printf("device[%02X] add[%02X] data[%02X] crc[FF FF]\r\n",device,0x10,data[0]); | 
| cyberjoey | 20:ba06efe24970 | 809 | OT07_read_register(OT07[device].I2C_address,0x11,data,1); | 
| cyberjoey | 20:ba06efe24970 | 810 | pc.printf("device[%02X] add[%02X] data[%02X] crc[FF FF]\r\n",device,0x11,data[0]); | 
| cyberjoey | 20:ba06efe24970 | 811 | OT07_read_register(OT07[device].I2C_address,0x12,data,1); | 
| cyberjoey | 20:ba06efe24970 | 812 | pc.printf("device[%02X] add[%02X] data[%02X] crc[FF FF]\r\n",device,0x12,data[0]); | 
| cyberjoey | 20:ba06efe24970 | 813 | OT07_read_register(OT07[device].I2C_address,0x13,data,1); | 
| cyberjoey | 20:ba06efe24970 | 814 | pc.printf("device[%02X] add[%02X] data[%02X] crc[FF FF]\r\n",device,0x13,data[0]); | 
| cyberjoey | 20:ba06efe24970 | 815 | OT07_read_register(OT07[device].I2C_address,0x14,data,1); | 
| cyberjoey | 20:ba06efe24970 | 816 | pc.printf("device[%02X] add[%02X] data[%02X] crc[FF FF]\r\n",device,0x14,data[0]); | 
| cyberjoey | 20:ba06efe24970 | 817 | OT07_read_register(OT07[device].I2C_address,0x20,data,1); | 
| cyberjoey | 20:ba06efe24970 | 818 | pc.printf("device[%02X] add[%02X] data[%02X] crc[FF FF]\r\n",device,0x20,data[0]); | 
| cyberjoey | 20:ba06efe24970 | 819 | OT07_read_register(OT07[device].I2C_address,0x21,data,1); | 
| cyberjoey | 20:ba06efe24970 | 820 | pc.printf("device[%02X] add[%02X] data[%02X] crc[FF FF]\r\n",device,0x21,data[0]); | 
| cyberjoey | 20:ba06efe24970 | 821 | OT07_read_register(OT07[device].I2C_address,0x30,data,1); | 
| cyberjoey | 20:ba06efe24970 | 822 | pc.printf("device[%02X] add[%02X] data[%02X] crc[FF FF]\r\n",device,0x30,data[0]); | 
| cyberjoey | 20:ba06efe24970 | 823 | OT07_read_register(OT07[device].I2C_address,0x31,data,1); | 
| cyberjoey | 20:ba06efe24970 | 824 | pc.printf("device[%02X] add[%02X] data[%02X] crc[FF FF]\r\n",device,0x31,data[0]); | 
| cyberjoey | 20:ba06efe24970 | 825 | OT07_read_register(OT07[device].I2C_address,0x32,data,1); | 
| cyberjoey | 20:ba06efe24970 | 826 | pc.printf("device[%02X] add[%02X] data[%02X] crc[FF FF]\r\n",device,0x32,data[0]); | 
| cyberjoey | 20:ba06efe24970 | 827 | OT07_read_register(OT07[device].I2C_address,0x33,data,1); | 
| cyberjoey | 20:ba06efe24970 | 828 | pc.printf("device[%02X] add[%02X] data[%02X] crc[FF FF]\r\n",device,0x33,data[0]); | 
| cyberjoey | 20:ba06efe24970 | 829 | OT07_read_register(OT07[device].I2C_address,0x34,data,1); | 
| cyberjoey | 20:ba06efe24970 | 830 | pc.printf("device[%02X] add[%02X] data[%02X] crc[FF FF]\r\n",device,0x34,data[0]); | 
| cyberjoey | 20:ba06efe24970 | 831 | OT07_read_register(OT07[device].I2C_address,0x35,data,1); | 
| cyberjoey | 20:ba06efe24970 | 832 | pc.printf("device[%02X] add[%02X] data[%02X] crc[FF FF]\r\n",device,0x35,data[0]); | 
| cyberjoey | 20:ba06efe24970 | 833 | OT07_read_register(OT07[device].I2C_address,0x36,data,1); | 
| cyberjoey | 20:ba06efe24970 | 834 | pc.printf("device[%02X] add[%02X] data[%02X] crc[FF FF]\r\n",device,0x36,data[0]); | 
| cyberjoey | 20:ba06efe24970 | 835 | OT07_read_register(OT07[device].I2C_address,0x37,data,1); | 
| cyberjoey | 20:ba06efe24970 | 836 | pc.printf("device[%02X] add[%02X] data[%02X] crc[FF FF]\r\n",device,0x37,data[0]); | 
| cyberjoey | 20:ba06efe24970 | 837 | OT07_read_register(OT07[device].I2C_address,0xFF,data,1); | 
| cyberjoey | 20:ba06efe24970 | 838 | pc.printf("device[%02X] add[%02X] data[%02X] crc[FF FF]\r\n",device,0xFF,data[0]); | 
| cyberjoey | 20:ba06efe24970 | 839 | } | 
| cyberjoey | 10:148da21c297e | 840 | break; | 
| cyberjoey | 9:36ba3626aab7 | 841 | case 'i': | 
| cyberjoey | 9:36ba3626aab7 | 842 | case 'I': //Set Logging sample intreval in seconds | 
| cyberjoey | 9:36ba3626aab7 | 843 | |
| cyberjoey | 9:36ba3626aab7 | 844 | log_interval = device; | 
| cyberjoey | 9:36ba3626aab7 | 845 | if(log_interval < 1)log_interval = 1; | 
| cyberjoey | 10:148da21c297e | 846 | if(log_interval > 60)log_interval = 60; | 
| cyberjoey | 10:148da21c297e | 847 | write_settings_file(log_interval, device_logged); | 
| cyberjoey | 9:36ba3626aab7 | 848 | break; | 
| cyberjoey | 9:36ba3626aab7 | 849 | case 'l': | 
| cyberjoey | 17:401a5bb8d403 | 850 | case 'L': | 
| cyberjoey | 17:401a5bb8d403 | 851 | |
| cyberjoey | 17:401a5bb8d403 | 852 | /* | 
| cyberjoey | 17:401a5bb8d403 | 853 | // Toggle logging | 
| cyberjoey | 9:36ba3626aab7 | 854 | |
| cyberjoey | 9:36ba3626aab7 | 855 | if(log_flag == false){ //start logging | 
| cyberjoey | 9:36ba3626aab7 | 856 | if(SDDetect)//if SD card not detected | 
| cyberjoey | 9:36ba3626aab7 | 857 | { | 
| cyberjoey | 9:36ba3626aab7 | 858 | error_flag = true; | 
| cyberjoey | 9:36ba3626aab7 | 859 | error_ticks = 6; | 
| cyberjoey | 9:36ba3626aab7 | 860 | log_flag = false; | 
| cyberjoey | 9:36ba3626aab7 | 861 | } | 
| cyberjoey | 9:36ba3626aab7 | 862 | else | 
| cyberjoey | 9:36ba3626aab7 | 863 | { | 
| cyberjoey | 10:148da21c297e | 864 | FILE *fp = fopen(log_file, "a"); | 
| cyberjoey | 9:36ba3626aab7 | 865 | if (fp != NULL) | 
| cyberjoey | 9:36ba3626aab7 | 866 | { | 
| cyberjoey | 9:36ba3626aab7 | 867 | fprintf(fp, "Time(s)"); | 
| cyberjoey | 9:36ba3626aab7 | 868 | |
| cyberjoey | 9:36ba3626aab7 | 869 | for(j=0;j<device_count;j++) | 
| cyberjoey | 9:36ba3626aab7 | 870 | { | 
| cyberjoey | 16:2f373d3c8214 | 871 | fprintf(fp,",Device %d Temperature (C)",j); | 
| cyberjoey | 9:36ba3626aab7 | 872 | } | 
| cyberjoey | 9:36ba3626aab7 | 873 | fprintf(fp,"\r\n"); | 
| cyberjoey | 9:36ba3626aab7 | 874 | |
| cyberjoey | 9:36ba3626aab7 | 875 | fclose(fp); | 
| cyberjoey | 9:36ba3626aab7 | 876 | } | 
| cyberjoey | 9:36ba3626aab7 | 877 | |
| cyberjoey | 9:36ba3626aab7 | 878 | time_count = 0; | 
| cyberjoey | 9:36ba3626aab7 | 879 | |
| cyberjoey | 9:36ba3626aab7 | 880 | time_to_sample = 0; // force sample at time = 0; | 
| cyberjoey | 9:36ba3626aab7 | 881 | tick_flag = true; // force sample at time = 0; | 
| cyberjoey | 9:36ba3626aab7 | 882 | log_flag = true; | 
| cyberjoey | 9:36ba3626aab7 | 883 | } | 
| cyberjoey | 9:36ba3626aab7 | 884 | }else{ | 
| cyberjoey | 9:36ba3626aab7 | 885 | //pc.printf("<stop logging>\r\n"); | 
| cyberjoey | 9:36ba3626aab7 | 886 | log_flag = false; | 
| cyberjoey | 17:401a5bb8d403 | 887 | }*/ | 
| cyberjoey | 9:36ba3626aab7 | 888 | break; | 
| cyberjoey | 9:36ba3626aab7 | 889 | case 'P': | 
| cyberjoey | 9:36ba3626aab7 | 890 | case 'p': // power down One Wire buss | 
| cyberjoey | 17:401a5bb8d403 | 891 | /*if(n == 2){ | 
| cyberjoey | 9:36ba3626aab7 | 892 | if (device == 0){ // power down mode ON. | 
| cyberjoey | 9:36ba3626aab7 | 893 | data[0] = WDC; // 0xD2 Write Device Config | 
| cyberjoey | 9:36ba3626aab7 | 894 | data[1] = 0xD2; // 1101 0010 set 1WS = 0, SPU = 0, PDN = 1, APU = 0 | 
| cyberjoey | 9:36ba3626aab7 | 895 | i2c.write(DS2484_ADD,data,2,0); | 
| cyberjoey | 9:36ba3626aab7 | 896 | pc.printf("<Power down DQ>\r\n"); | 
| cyberjoey | 9:36ba3626aab7 | 897 | }else{ // power down mode OFF | 
| cyberjoey | 9:36ba3626aab7 | 898 | data[0] = WDC; // 0xD2 Write Device Config | 
| cyberjoey | 9:36ba3626aab7 | 899 | data[1] = 0xE1; // 1110 0001 set 1WS = 0, SPU = 0, PDN = 0, APU = 1 | 
| cyberjoey | 9:36ba3626aab7 | 900 | i2c.write(DS2484_ADD,data,2,0); | 
| cyberjoey | 9:36ba3626aab7 | 901 | pc.printf("<Power up DQ>\r\n"); | 
| cyberjoey | 9:36ba3626aab7 | 902 | } | 
| cyberjoey | 17:401a5bb8d403 | 903 | }*/ | 
| cyberjoey | 9:36ba3626aab7 | 904 | break; | 
| cyberjoey | 9:36ba3626aab7 | 905 | case 'r': | 
| cyberjoey | 17:401a5bb8d403 | 906 | case 'R': | 
| cyberjoey | 17:401a5bb8d403 | 907 | //read register "r device radd.start radd.end" | 
| cyberjoey | 9:36ba3626aab7 | 908 | if(n==3){ //read single register from selected device | 
| cyberjoey | 17:401a5bb8d403 | 909 | OT07_read_register(OT07[device].I2C_address,arg1,data,1); | 
| cyberjoey | 17:401a5bb8d403 | 910 | pc.printf("device[%02X] add[%02X] data[%02X] crc[FF FF]\r\n",device,arg1,data[0]); | 
| cyberjoey | 9:36ba3626aab7 | 911 | } | 
| cyberjoey | 9:36ba3626aab7 | 912 | if(n==4){ //read a range of regesters from selected device | 
| cyberjoey | 9:36ba3626aab7 | 913 | num_bytes = arg2-arg1 + 1; // calculate number of bytes to read | 
| cyberjoey | 9:36ba3626aab7 | 914 | if (num_bytes < 1) num_bytes = 1; // if arg2 <= arg 1 just read arg1 address. | 
| cyberjoey | 17:401a5bb8d403 | 915 | OT07_read_register(OT07[device].I2C_address,arg1,data,num_bytes); | 
| cyberjoey | 9:36ba3626aab7 | 916 | for(i=0;i<num_bytes;i++){ | 
| cyberjoey | 20:ba06efe24970 | 917 | pc.printf("device[%02X] add[%02X] data[%02X]\r\n",device,arg1+i,data[i]); | 
| cyberjoey | 17:401a5bb8d403 | 918 | } | 
| cyberjoey | 9:36ba3626aab7 | 919 | } | 
| cyberjoey | 9:36ba3626aab7 | 920 | break; | 
| cyberjoey | 9:36ba3626aab7 | 921 | |
| cyberjoey | 9:36ba3626aab7 | 922 | case 's': | 
| cyberjoey | 9:36ba3626aab7 | 923 | case 'S': // search rom | 
| cyberjoey | 17:401a5bb8d403 | 924 | // ****************** search for I2C devices on bus ***************** | 
| cyberjoey | 17:401a5bb8d403 | 925 | //NOTE: MUST ADD I2C ADDRESS TODO | 
| cyberjoey | 17:401a5bb8d403 | 926 | device_count = search_I2C_bus(OT07); | 
| cyberjoey | 9:36ba3626aab7 | 927 | pc.printf("%d devices:\r\n", device_count); | 
| cyberjoey | 9:36ba3626aab7 | 928 | for(j=0;j<device_count;j++){ | 
| cyberjoey | 19:7081d6f6288b | 929 | pc.printf("device[%02X] addr[%02X] rom id[",j, OT07[j].I2C_address); | 
| cyberjoey | 9:36ba3626aab7 | 930 | for(i=7;i>=0;i--){ | 
| cyberjoey | 17:401a5bb8d403 | 931 | pc.printf("%02X",OT07[j].rom_id[i]); | 
| cyberjoey | 9:36ba3626aab7 | 932 | } | 
| cyberjoey | 9:36ba3626aab7 | 933 | pc.printf("]\r\n"); | 
| cyberjoey | 13:674c647d12dd | 934 | } | 
| cyberjoey | 17:401a5bb8d403 | 935 | |
| cyberjoey | 9:36ba3626aab7 | 936 | break; | 
| cyberjoey | 9:36ba3626aab7 | 937 | |
| cyberjoey | 9:36ba3626aab7 | 938 | case 'T': | 
| cyberjoey | 9:36ba3626aab7 | 939 | case 't': | 
| cyberjoey | 17:401a5bb8d403 | 940 | |
| cyberjoey | 17:401a5bb8d403 | 941 | if(n == 2){//get temperatures from selected device | 
| cyberjoey | 17:401a5bb8d403 | 942 | |
| cyberjoey | 17:401a5bb8d403 | 943 | convert_temperature(OT07[device].I2C_address); //send OW convert selected device | 
| cyberjoey | 17:401a5bb8d403 | 944 | wait(0.02); //wait 20 ms for convert temperature to complete | 
| cyberjoey | 17:401a5bb8d403 | 945 | T[device] = get_temperature(OT07[device].I2C_address); | 
| cyberjoey | 17:401a5bb8d403 | 946 | pc.printf("device[%02X] temperature[%.3f]\r\n",device,T[device]); | 
| cyberjoey | 17:401a5bb8d403 | 947 | } | 
| cyberjoey | 17:401a5bb8d403 | 948 | |
| cyberjoey | 17:401a5bb8d403 | 949 | if(n == 3){ // "t 1 3" get temperature for devices 1 thru 3 | 
| cyberjoey | 17:401a5bb8d403 | 950 | //sprintf(str,"%x",arg1); //convert arg1 input as hex to decimal i.e. 0x10 becomes 10 dec | 
| cyberjoey | 17:401a5bb8d403 | 951 | //sscanf(str,"%d",&arg1); | 
| cyberjoey | 17:401a5bb8d403 | 952 | //IS THIS NEEDED? ^^^ | 
| cyberjoey | 17:401a5bb8d403 | 953 | |
| cyberjoey | 17:401a5bb8d403 | 954 | for(j=device;j<=arg1;j++){ | 
| cyberjoey | 17:401a5bb8d403 | 955 | convert_temperature(OT07[j].I2C_address); //send convert to all devices | 
| cyberjoey | 17:401a5bb8d403 | 956 | wait(0.02); //wait 20ms for convert temperature to complete | 
| cyberjoey | 17:401a5bb8d403 | 957 | T[j] = get_temperature(OT07[j].I2C_address); | 
| cyberjoey | 17:401a5bb8d403 | 958 | } | 
| cyberjoey | 17:401a5bb8d403 | 959 | |
| cyberjoey | 17:401a5bb8d403 | 960 | for(j=device;j<=arg1;j++){ | 
| cyberjoey | 17:401a5bb8d403 | 961 | pc.printf("device[%02X] temperature[%.3f]\r\n",j,T[j]); | 
| cyberjoey | 17:401a5bb8d403 | 962 | } | 
| cyberjoey | 17:401a5bb8d403 | 963 | } | 
| cyberjoey | 17:401a5bb8d403 | 964 | |
| cyberjoey | 9:36ba3626aab7 | 965 | break; | 
| cyberjoey | 9:36ba3626aab7 | 966 | |
| cyberjoey | 9:36ba3626aab7 | 967 | case 'w': | 
| cyberjoey | 17:401a5bb8d403 | 968 | case 'W': //write register "w device w.addr data" | 
| cyberjoey | 9:36ba3626aab7 | 969 | |
| cyberjoey | 17:401a5bb8d403 | 970 | OT07_write_register(OT07[device].I2C_address,arg1, arg2); | 
| cyberjoey | 17:401a5bb8d403 | 971 | pc.printf("write -- device[%02X] add[%02X] data[%02X] crc[FF FF]\r\n",device,arg1,arg2); | 
| cyberjoey | 9:36ba3626aab7 | 972 | break; | 
| cyberjoey | 9:36ba3626aab7 | 973 | |
| cyberjoey | 9:36ba3626aab7 | 974 | case 'x': | 
| cyberjoey | 9:36ba3626aab7 | 975 | case 'X': // experimental modes | 
| cyberjoey | 9:36ba3626aab7 | 976 | // ****************** set up ADC enabled in test mode***************** | 
| cyberjoey | 18:d913ec9dd9c2 | 977 | /* | 
| cyberjoey | 9:36ba3626aab7 | 978 | pc.printf("<set ADC_ENABLED in test mode>\r\n"); | 
| cyberjoey | 9:36ba3626aab7 | 979 | |
| cyberjoey | 9:36ba3626aab7 | 980 | for(j=0;j<device_count;j++){ | 
| cyberjoey | 9:36ba3626aab7 | 981 | for(k=0;k<8;k++){ | 
| cyberjoey | 9:36ba3626aab7 | 982 | device_id[k] = rom_id_list[j][k]; // get device_id from rom_id_list | 
| cyberjoey | 9:36ba3626aab7 | 983 | } | 
| cyberjoey | 9:36ba3626aab7 | 984 | set_test_mode(device_id); | 
| cyberjoey | 18:d913ec9dd9c2 | 985 | } */ | 
| cyberjoey | 9:36ba3626aab7 | 986 | break; | 
| cyberjoey | 9:36ba3626aab7 | 987 | |
| cyberjoey | 9:36ba3626aab7 | 988 | |
| cyberjoey | 9:36ba3626aab7 | 989 | }//end switch(c) | 
| cyberjoey | 9:36ba3626aab7 | 990 | }//if(n>0) | 
| cyberjoey | 9:36ba3626aab7 | 991 | }//end if(CR) | 
| cyberjoey | 9:36ba3626aab7 | 992 | if(rx_buff[rx_index] == BS){//backspace received, back up buffer pointer | 
| cyberjoey | 9:36ba3626aab7 | 993 | if(rx_index>0)rx_index--;//remove last char from buffer if not at start. | 
| cyberjoey | 9:36ba3626aab7 | 994 | }else rx_index++; | 
| cyberjoey | 9:36ba3626aab7 | 995 | }//end while(pc.redable()) | 
| cyberjoey | 9:36ba3626aab7 | 996 | wait(0.1); // slow down polling | 
| switches | 0:60a522ae2e35 | 997 | |
| cyberjoey | 9:36ba3626aab7 | 998 | }// end (while tick == false) | 
| cyberjoey | 9:36ba3626aab7 | 999 | tick_flag = false; // set to false for next time | 
| cyberjoey | 9:36ba3626aab7 | 1000 | |
| cyberjoey | 9:36ba3626aab7 | 1001 | // only reached when tick_flag = true otherwise stuck in pc.readable() loop | 
| cyberjoey | 13:674c647d12dd | 1002 | if(log_flag == true){ | 
| cyberjoey | 9:36ba3626aab7 | 1003 | if(time_count >= time_to_sample){ //take next sample | 
| cyberjoey | 9:36ba3626aab7 | 1004 | time_to_sample += log_interval; // calculate time for next sample | 
| cyberjoey | 18:d913ec9dd9c2 | 1005 | |
| cyberjoey | 18:d913ec9dd9c2 | 1006 | ///////////////////////temp conversion and assignment to T[]////////////////////////////////////// | 
| cyberjoey | 9:36ba3626aab7 | 1007 | // start conversion | 
| cyberjoey | 18:d913ec9dd9c2 | 1008 | /*convert_temperature(); | 
| cyberjoey | 9:36ba3626aab7 | 1009 | wait(0.02); //wait 20ms for convert to complete | 
| cyberjoey | 9:36ba3626aab7 | 1010 | for(j=0;j<device_count;j++){ | 
| cyberjoey | 9:36ba3626aab7 | 1011 | for(k=0;k<8;k++){ | 
| cyberjoey | 9:36ba3626aab7 | 1012 | device_id[k] = rom_id_list[j][k]; // get device_id from rom_id_list | 
| cyberjoey | 9:36ba3626aab7 | 1013 | } | 
| cyberjoey | 9:36ba3626aab7 | 1014 | T[j] = get_temperature(device_id); | 
| cyberjoey | 18:d913ec9dd9c2 | 1015 | }*/ | 
| cyberjoey | 18:d913ec9dd9c2 | 1016 | for(j=0;j<device_count;j++){ | 
| cyberjoey | 18:d913ec9dd9c2 | 1017 | convert_temperature(OT07[j].I2C_address); | 
| cyberjoey | 18:d913ec9dd9c2 | 1018 | wait(0.02); //wait 20ms for convert temperature to complete | 
| cyberjoey | 18:d913ec9dd9c2 | 1019 | T[j] = get_temperature(OT07[j].I2C_address); | 
| cyberjoey | 9:36ba3626aab7 | 1020 | } | 
| cyberjoey | 18:d913ec9dd9c2 | 1021 | ///////////////////////////////////////////////////////////////////////////////////////////////// | 
| cyberjoey | 13:674c647d12dd | 1022 | |
| cyberjoey | 13:674c647d12dd | 1023 | //open file for microSD logging | 
| cyberjoey | 10:148da21c297e | 1024 | FILE *fp = fopen(log_file, "a"); | 
| cyberjoey | 9:36ba3626aab7 | 1025 | if (fp != NULL) | 
| cyberjoey | 9:36ba3626aab7 | 1026 | { | 
| cyberjoey | 9:36ba3626aab7 | 1027 | //fprintf(fp, "\n"); | 
| cyberjoey | 10:148da21c297e | 1028 | fprintf(fp, "%d",time_count); | 
| cyberjoey | 9:36ba3626aab7 | 1029 | for(j=0;j<device_count;j++) | 
| cyberjoey | 9:36ba3626aab7 | 1030 | { | 
| cyberjoey | 11:94a7379c0db8 | 1031 | if(device_logged[j]) | 
| cyberjoey | 11:94a7379c0db8 | 1032 | { | 
| cyberjoey | 16:2f373d3c8214 | 1033 | fprintf(fp,",%.3f",T[j]); | 
| cyberjoey | 11:94a7379c0db8 | 1034 | } | 
| cyberjoey | 11:94a7379c0db8 | 1035 | |
| cyberjoey | 9:36ba3626aab7 | 1036 | } | 
| cyberjoey | 9:36ba3626aab7 | 1037 | fprintf(fp,"\r\n"); | 
| cyberjoey | 9:36ba3626aab7 | 1038 | |
| cyberjoey | 9:36ba3626aab7 | 1039 | fclose(fp); | 
| cyberjoey | 9:36ba3626aab7 | 1040 | } | 
| cyberjoey | 9:36ba3626aab7 | 1041 | }// end if(time_count >= time_to_sample) | 
| cyberjoey | 9:36ba3626aab7 | 1042 | time_count ++; // | 
| cyberjoey | 9:36ba3626aab7 | 1043 | |
| cyberjoey | 9:36ba3626aab7 | 1044 | }// end if(log_flag) | 
| cyberjoey | 9:36ba3626aab7 | 1045 | |
| cyberjoey | 9:36ba3626aab7 | 1046 | }//end while(1) | 
| switches | 0:60a522ae2e35 | 1047 | } | 
