KL46Z-lab3_full

Dependencies:   SLCD- mbed KL46Z-USBHost TSI MMA8451Q MAG3110 FATFileSystem

Committer:
Lokkus
Date:
Thu Feb 21 07:42:01 2019 +0000
Revision:
0:147f106a5503
KL46Z-lab3_full

Who changed what in which revision?

UserRevisionLine numberNew contents of line
Lokkus 0:147f106a5503 1 //USB Academy - Lab3 rev 00
Lokkus 0:147f106a5503 2 //_____________________________________________________________//
Lokkus 0:147f106a5503 3 //======== INCLUDES ===========================================//
Lokkus 0:147f106a5503 4 //¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯//
Lokkus 0:147f106a5503 5 #include "mbed.h"
Lokkus 0:147f106a5503 6 #include "MMA8451Q.h"
Lokkus 0:147f106a5503 7 #include "MAG3110.h"
Lokkus 0:147f106a5503 8 #include "SLCD.h"
Lokkus 0:147f106a5503 9 #include "TSISensor.h"
Lokkus 0:147f106a5503 10
Lokkus 0:147f106a5503 11 //#include "USBMouse.h" //Lab1-Hid
Lokkus 0:147f106a5503 12 //#include "USBSerial.h" //Lab2-cdc
Lokkus 0:147f106a5503 13 #include "USBHostMSD.h" //Lab3-MSd
Lokkus 0:147f106a5503 14
Lokkus 0:147f106a5503 15
Lokkus 0:147f106a5503 16
Lokkus 0:147f106a5503 17
Lokkus 0:147f106a5503 18
Lokkus 0:147f106a5503 19 //_____________________________________________________________//
Lokkus 0:147f106a5503 20 //======== DEFINES & VARIABLES ================================//
Lokkus 0:147f106a5503 21 //¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯//
Lokkus 0:147f106a5503 22 #define LED_ON 0 //outON, pwmON
Lokkus 0:147f106a5503 23 #define LED_OFF 1 //outOFF,pwmOFF
Lokkus 0:147f106a5503 24 DigitalOut gLED(LED_GREEN); //PTD5
Lokkus 0:147f106a5503 25
Lokkus 0:147f106a5503 26 #define rLEDperiod 150 //[ms]
Lokkus 0:147f106a5503 27 PwmOut rLED(LED_RED); //PTE29
Lokkus 0:147f106a5503 28
Lokkus 0:147f106a5503 29 #define PRESS_ON 0
Lokkus 0:147f106a5503 30 #define PRESS_OFF 1
Lokkus 0:147f106a5503 31 DigitalIn sw1(PTC3); //if(sw1) Release else Press
Lokkus 0:147f106a5503 32 DigitalIn sw3(PTC12); //while(sw3); wait for Press
Lokkus 0:147f106a5503 33
Lokkus 0:147f106a5503 34 #define MMA8451_I2C_ADDRESS (0x1d<<1)
Lokkus 0:147f106a5503 35 MMA8451Q acc(PTE25, PTE24, MMA8451_I2C_ADDRESS);
Lokkus 0:147f106a5503 36
Lokkus 0:147f106a5503 37 SLCD slcd; //[88:88][8.8.8.8] SegmentLCD
Lokkus 0:147f106a5503 38
Lokkus 0:147f106a5503 39 AnalogIn light(PTE22); //analog-light input
Lokkus 0:147f106a5503 40
Lokkus 0:147f106a5503 41 TSISensor slider; //Capacitive Touch Slider
Lokkus 0:147f106a5503 42
Lokkus 0:147f106a5503 43 MAG3110 mag(PTE25, PTE24); //Magnetometer
Lokkus 0:147f106a5503 44
Lokkus 0:147f106a5503 45 Serial usb_osda(USBTX, USBRX); //OpenSDA Terminal
Lokkus 0:147f106a5503 46 #define pf usb_osda //printf out -> osda (lab1,2,3)
Lokkus 0:147f106a5503 47
Lokkus 0:147f106a5503 48 struct KL46_SENSOR_DATA {
Lokkus 0:147f106a5503 49 int sw1State;
Lokkus 0:147f106a5503 50 int sw3State;
Lokkus 0:147f106a5503 51 float accValX;
Lokkus 0:147f106a5503 52 float accValY;
Lokkus 0:147f106a5503 53 float accValZ;
Lokkus 0:147f106a5503 54
Lokkus 0:147f106a5503 55 float slider;
Lokkus 0:147f106a5503 56 float light;
Lokkus 0:147f106a5503 57 int magValX;
Lokkus 0:147f106a5503 58 int magValY;
Lokkus 0:147f106a5503 59 int magValZ;
Lokkus 0:147f106a5503 60
Lokkus 0:147f106a5503 61 float magHeading;
Lokkus 0:147f106a5503 62 } sensorData;
Lokkus 0:147f106a5503 63 #define sD sensorData
Lokkus 0:147f106a5503 64
Lokkus 0:147f106a5503 65 void SLCD_blinking_msg_wait(char *slcd_msg1, char *slcd_msg2);
Lokkus 0:147f106a5503 66
Lokkus 0:147f106a5503 67 int MagCalibrationXY(void); //mag calib
Lokkus 0:147f106a5503 68
Lokkus 0:147f106a5503 69
Lokkus 0:147f106a5503 70
Lokkus 0:147f106a5503 71
Lokkus 0:147f106a5503 72 //_____________________________________________________________//
Lokkus 0:147f106a5503 73 //======== MAIN() =============================================//
Lokkus 0:147f106a5503 74 //¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯//
Lokkus 0:147f106a5503 75 int main(void)
Lokkus 0:147f106a5503 76 {
Lokkus 0:147f106a5503 77 int mag_calib = 0;
Lokkus 0:147f106a5503 78 FILE* fp;
Lokkus 0:147f106a5503 79
Lokkus 0:147f106a5503 80 //---- MAIN/Inits -----------------------------------------//
Lokkus 0:147f106a5503 81
Lokkus 0:147f106a5503 82 sw1.mode(PullUp);
Lokkus 0:147f106a5503 83 sw3.mode(PullUp);
Lokkus 0:147f106a5503 84
Lokkus 0:147f106a5503 85 gLED = LED_ON; //Green LED ON to indicate running/writing
Lokkus 0:147f106a5503 86 rLED = LED_OFF; //Red LED OFF
Lokkus 0:147f106a5503 87 rLED.period(rLEDperiod); //Red LED (rLED) tsi/accZ/mag
Lokkus 0:147f106a5503 88
Lokkus 0:147f106a5503 89 //---- MAIN/Inits (Wait4SW1) -> Start! --------------------//
Lokkus 0:147f106a5503 90
Lokkus 0:147f106a5503 91 //wait for Press SW1 - e.g. for HID/CDC/MSD Windows install.
Lokkus 0:147f106a5503 92 //SLCD_blinking_msg_wait(" o","Helo"); //Helo (no usb);
Lokkus 0:147f106a5503 93 SLCD_blinking_msg_wait(" o","MSd ");//Lab1=Hid;2=cdc;3=Msd
Lokkus 0:147f106a5503 94
Lokkus 0:147f106a5503 95 //---- MAIN/Inits Interface -------------------------------//
Lokkus 0:147f106a5503 96
Lokkus 0:147f106a5503 97 usb_osda.baud(115200);
Lokkus 0:147f106a5503 98 usb_osda.printf("\n___________________________________\r\n");
Lokkus 0:147f106a5503 99 usb_osda.printf("\nFRDM-KL46Z_Lab\r\n \r\n I am a CDC serial port @OpenSDA/mUSB. Baud=115200 \r\n");
Lokkus 0:147f106a5503 100
Lokkus 0:147f106a5503 101 //---- MAIN/Inits Labs ------------------------------------//
Lokkus 0:147f106a5503 102
Lokkus 0:147f106a5503 103 pf.printf("\r\n Lab3: pls plug USB-stick into mUSB/KL46Z \r\n");
Lokkus 0:147f106a5503 104
Lokkus 0:147f106a5503 105 slcd.printf("USb~"); //Lab1=Hid;2=cdc;3=Msd
Lokkus 0:147f106a5503 106 USBHostMSD msd("usb"); //wait for plugged USB-stick
Lokkus 0:147f106a5503 107 if (!msd.connect()) {
Lokkus 0:147f106a5503 108 error(" USB Flash drive not found.\r\n");
Lokkus 0:147f106a5503 109 }
Lokkus 0:147f106a5503 110
Lokkus 0:147f106a5503 111 //Attempt to crete file /usb/usb_lab3.txt @USB-stick.
Lokkus 0:147f106a5503 112 fp = fopen("/usb/usb_lab3.txt", "w"); //rewrite, or create
Lokkus 0:147f106a5503 113 if (fp) {
Lokkus 0:147f106a5503 114 pf.printf(" ... sucess file-open (/usb/usb_lab3.txt @USB-stick)!\r\n\r\n");
Lokkus 0:147f106a5503 115 fprintf(fp, " Lab3: from FRDM-KL46Z \r\n\r\n");
Lokkus 0:147f106a5503 116 fclose(fp); fp=NULL;
Lokkus 0:147f106a5503 117 } else pf.printf(" ... failed file-open (/usb/usb_lab3.txt @USB-stick)!\r\n\r\n");
Lokkus 0:147f106a5503 118
Lokkus 0:147f106a5503 119 //---- MAIN/Inits (Wait4SW1) -> Calib. eCompass -----------//
Lokkus 0:147f106a5503 120
Lokkus 0:147f106a5503 121 while (!mag_calib) {
Lokkus 0:147f106a5503 122 pf.printf(" Press and release SW1 to calibrate eCompass.\r\n");
Lokkus 0:147f106a5503 123 SLCD_blinking_msg_wait(" o","CAL ");
Lokkus 0:147f106a5503 124
Lokkus 0:147f106a5503 125 // Calibrate Magnetometer to eCompass
Lokkus 0:147f106a5503 126 pf.printf(" ... r o t a t e the FRDM board in 3d/360° until [donE].\r\n");
Lokkus 0:147f106a5503 127
Lokkus 0:147f106a5503 128 mag_calib = MagCalibrationXY(); //to wait untill calib or cancel!!!
Lokkus 0:147f106a5503 129
Lokkus 0:147f106a5503 130 if (mag_calib) {
Lokkus 0:147f106a5503 131 if (mag_calib == -1)
Lokkus 0:147f106a5503 132 {
Lokkus 0:147f106a5503 133 pf.printf(" [SKiP]! Calibration skipped! ... See Accelerometer Z-axe.\r\n");
Lokkus 0:147f106a5503 134 SLCD_blinking_msg_wait(" o","SKiP"); //->acc
Lokkus 0:147f106a5503 135 } else {
Lokkus 0:147f106a5503 136 pf.printf(" [donE]! Calibration completed! ... Press and release SW1 to try eCompass.\r\n");
Lokkus 0:147f106a5503 137 SLCD_blinking_msg_wait(" o","donE"); //->mag
Lokkus 0:147f106a5503 138 }
Lokkus 0:147f106a5503 139 break; //while (!mag_calib)
Lokkus 0:147f106a5503 140 } else {
Lokkus 0:147f106a5503 141 slcd.printf("erro");
Lokkus 0:147f106a5503 142 pf.printf("r\n Error Calib !!! try again !!!\r\n\r\n");
Lokkus 0:147f106a5503 143 } //repet calib
Lokkus 0:147f106a5503 144 }
Lokkus 0:147f106a5503 145
Lokkus 0:147f106a5503 146 //---- MAIN/Inits Done! (Wait4SW1) -> MANI/Loop -----------//
Lokkus 0:147f106a5503 147
Lokkus 0:147f106a5503 148 gLED = LED_OFF; //Inits are done
Lokkus 0:147f106a5503 149
Lokkus 0:147f106a5503 150 //---- MAIN/Loop -----------------------------------------//
Lokkus 0:147f106a5503 151 while (1) {
Lokkus 0:147f106a5503 152 //disable all SLCD DPs
Lokkus 0:147f106a5503 153 slcd.DP(0, false); slcd.DP(1, false); slcd.DP(2, false);
Lokkus 0:147f106a5503 154
Lokkus 0:147f106a5503 155 // MAIN/Loop/Sensing and Storing data -----------------//
Lokkus 0:147f106a5503 156 sD.sw1State = sw1; sD.sw3State = sw3;
Lokkus 0:147f106a5503 157 sD.accValX = acc.getAccX(); //accX[-1..1]->mouse (Lab1)
Lokkus 0:147f106a5503 158 sD.accValY = acc.getAccY(); //accY[-1..1]->mouse (Lab1)
Lokkus 0:147f106a5503 159 sD.accValZ = acc.getAccZ(); //accZ[-1..1]->rLED
Lokkus 0:147f106a5503 160
Lokkus 0:147f106a5503 161 sD.slider = slider.readPercentage() * 100;
Lokkus 0:147f106a5503 162 sD.light = light;
Lokkus 0:147f106a5503 163 sD.magValX = mag.readVal(MAG_OUT_X_MSB);
Lokkus 0:147f106a5503 164 sD.magValY = mag.readVal(MAG_OUT_Y_MSB);
Lokkus 0:147f106a5503 165 sD.magValZ = mag.readVal(MAG_OUT_Z_MSB);
Lokkus 0:147f106a5503 166
Lokkus 0:147f106a5503 167 sD.magHeading = mag.getHeading(); //calculate heading
Lokkus 0:147f106a5503 168
Lokkus 0:147f106a5503 169 // MAIN/Loop/Processing and Actions -------------------//
Lokkus 0:147f106a5503 170
Lokkus 0:147f106a5503 171 //sensor -> terminal
Lokkus 0:147f106a5503 172 if (fp) { gLED = !gLED; //blinkig
Lokkus 0:147f106a5503 173 pf.printf("%.2f\t", sD.magHeading); //->terminal
Lokkus 0:147f106a5503 174 fprintf(fp,"%.2f\t ", sD.magHeading); //->usb_file
Lokkus 0:147f106a5503 175
Lokkus 0:147f106a5503 176 pf.printf("% 1.2f\r\n", sD.accValZ); //->terminal
Lokkus 0:147f106a5503 177 fprintf(fp,"% 1.2f\r\n", sD.accValZ); //->usb_file
Lokkus 0:147f106a5503 178 } else gLED = LED_OFF;
Lokkus 0:147f106a5503 179
Lokkus 0:147f106a5503 180 if(!fp && sw1==PRESS_ON) fp=fopen("/usb/usb_lab3.txt", "a");
Lokkus 0:147f106a5503 181 else
Lokkus 0:147f106a5503 182 if(fp && sw1==PRESS_OFF) {fclose(fp); fp=NULL; gLED=LED_OFF;}
Lokkus 0:147f106a5503 183
Lokkus 0:147f106a5503 184 //acc: z-axis 1g min-blinking//acc: z-axis 1g min-blinking
Lokkus 0:147f106a5503 185 rLED = abs(sD.accValZ);
Lokkus 0:147f106a5503 186
Lokkus 0:147f106a5503 187 slcd.CharPosition=0; //prevent slcd rolling
Lokkus 0:147f106a5503 188 slcd.printf("% 3.0f", sD.magHeading);
Lokkus 0:147f106a5503 189
Lokkus 0:147f106a5503 190 wait(0.05); //wait 50ms
Lokkus 0:147f106a5503 191 }
Lokkus 0:147f106a5503 192 }
Lokkus 0:147f106a5503 193
Lokkus 0:147f106a5503 194
Lokkus 0:147f106a5503 195
Lokkus 0:147f106a5503 196
Lokkus 0:147f106a5503 197
Lokkus 0:147f106a5503 198 //_____________________________________________________________//
Lokkus 0:147f106a5503 199 //======== FUNC() =============================================//
Lokkus 0:147f106a5503 200 //¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯//
Lokkus 0:147f106a5503 201
Lokkus 0:147f106a5503 202 //Lab2add
Lokkus 0:147f106a5503 203 void SLCD_blinking_msg_wait(char *slcd_msg1, char *slcd_msg2)
Lokkus 0:147f106a5503 204 {
Lokkus 0:147f106a5503 205 char wait4sw1=0; //~500ms blinking
Lokkus 0:147f106a5503 206
Lokkus 0:147f106a5503 207 //wait for Press SW1 - to start mag calibration
Lokkus 0:147f106a5503 208 while(sw1 == PRESS_ON); //wait for release
Lokkus 0:147f106a5503 209 while(sw1 == PRESS_OFF) { //wait for press
Lokkus 0:147f106a5503 210 if (++wait4sw1 < 150) //300ms
Lokkus 0:147f106a5503 211 slcd.printf(slcd_msg1);
Lokkus 0:147f106a5503 212 else //200ms
Lokkus 0:147f106a5503 213 slcd.printf(slcd_msg2);
Lokkus 0:147f106a5503 214 wait(0.002);
Lokkus 0:147f106a5503 215 }
Lokkus 0:147f106a5503 216 while(sw1 == PRESS_ON); //wait for release
Lokkus 0:147f106a5503 217 }
Lokkus 0:147f106a5503 218
Lokkus 0:147f106a5503 219 //Lab3add
Lokkus 0:147f106a5503 220 int MagCalibrationXY(void)
Lokkus 0:147f106a5503 221 {
Lokkus 0:147f106a5503 222 int newX, tempXmax, tempXmin; int newY, tempYmax, tempYmin;
Lokkus 0:147f106a5503 223 int newZ, tempZmax, tempZmin;
Lokkus 0:147f106a5503 224 int delta_avg=0, delta_avg_min=0, delta_avg_max=0, delta_calib_limit=800;
Lokkus 0:147f106a5503 225
Lokkus 0:147f106a5503 226 tempXmax = tempXmin = mag.readVal(MAG_OUT_X_MSB); //init X
Lokkus 0:147f106a5503 227 tempYmax = tempYmin = mag.readVal(MAG_OUT_Y_MSB); //init Y
Lokkus 0:147f106a5503 228 tempZmax = tempZmin = mag.readVal(MAG_OUT_Z_MSB); //init Z
Lokkus 0:147f106a5503 229
Lokkus 0:147f106a5503 230 // Update min and max values until calPin asserted again
Lokkus 0:147f106a5503 231 while(sw1) {//wait for Press == manual calib stop
Lokkus 0:147f106a5503 232 newX = mag.readVal(MAG_OUT_X_MSB);
Lokkus 0:147f106a5503 233 newY = mag.readVal(MAG_OUT_Y_MSB);
Lokkus 0:147f106a5503 234 newZ = mag.readVal(MAG_OUT_Z_MSB);
Lokkus 0:147f106a5503 235
Lokkus 0:147f106a5503 236 if (newX > tempXmax) tempXmax=newX;
Lokkus 0:147f106a5503 237 if (newX < tempXmin) tempXmin=newX; newX=tempXmax - tempXmin;
Lokkus 0:147f106a5503 238 if (newY > tempYmax) tempYmax=newY;
Lokkus 0:147f106a5503 239 if (newY < tempYmin) tempYmin=newY; newY=tempYmax - tempYmin;
Lokkus 0:147f106a5503 240 if (newZ > tempZmax) tempZmax=newZ;
Lokkus 0:147f106a5503 241 if (newZ < tempZmin) tempZmin=newZ; newZ=tempZmax - tempZmin;
Lokkus 0:147f106a5503 242
Lokkus 0:147f106a5503 243 delta_avg = (newX + newY + newZ);
Lokkus 0:147f106a5503 244
Lokkus 0:147f106a5503 245 //delta is too high? -> error, try new calib!!!
Lokkus 0:147f106a5503 246 if (delta_avg > 5 * delta_calib_limit) {delta_avg=0; break;}
Lokkus 0:147f106a5503 247
Lokkus 0:147f106a5503 248 //div3 with error +0.8 pct
Lokkus 0:147f106a5503 249 delta_avg = (21*(newX + newY + newZ))>>6;
Lokkus 0:147f106a5503 250
Lokkus 0:147f106a5503 251 //calib ok for delat ~800-1200 (~80-120uT)
Lokkus 0:147f106a5503 252 if (delta_avg > delta_calib_limit){
Lokkus 0:147f106a5503 253 delta_avg_min = delta_avg - (delta_avg>>2);
Lokkus 0:147f106a5503 254 delta_avg_max = delta_avg + (delta_avg>>1);
Lokkus 0:147f106a5503 255 if (delta_avg_min < newX && delta_avg_max > newX
Lokkus 0:147f106a5503 256 && delta_avg_min < newY && delta_avg_max > newY
Lokkus 0:147f106a5503 257 && delta_avg_min < newZ && delta_avg_max > newZ) break;
Lokkus 0:147f106a5503 258 }
Lokkus 0:147f106a5503 259
Lokkus 0:147f106a5503 260 //show calib progress 0->100%
Lokkus 0:147f106a5503 261 slcd.printf("C%3.0f", (float)delta_avg/delta_calib_limit*100);
Lokkus 0:147f106a5503 262 }
Lokkus 0:147f106a5503 263
Lokkus 0:147f106a5503 264 if (sw1 == PRESS_ON || delta_avg ) {
Lokkus 0:147f106a5503 265 mag.setCalibration( tempXmin, tempXmax, tempYmin, tempYmax );
Lokkus 0:147f106a5503 266 if (sw1 == PRESS_ON) return -1; //==-1 ..user skip
Lokkus 0:147f106a5503 267 return delta_avg; //>0 .. done, ok calib
Lokkus 0:147f106a5503 268 }
Lokkus 0:147f106a5503 269 return 0; //==0 .. error, no calib
Lokkus 0:147f106a5503 270 }