STM32L476
Dependencies: MbedJSONValue SDFileSystem WConstants mbed-dev DS1820 TinyGPSPlus epd1in54
Fork of A_SSL_Main by
main.cpp
- Committer:
- WaleedElmughrabi
- Date:
- 2018-08-28
- Revision:
- 4:06edbeb05013
- Parent:
- 3:bc4495101c7b
- Child:
- 5:4525141f69d2
File content as of revision 4:06edbeb05013:
#include "mbed.h" #include "stm32l496g_discovery.h" #include "stm32l496g_discovery_lcd.h" #include "stm32l496g_discovery_sd.h" #include "DS1820.h" #include "epd1in54.h" #include "stdio.h" #include "math.h" //#include "GPS.h" #include "TinyGPSPlus.h" #define TX5 PG_7 #define RX5 PG_8 #define GPSBaud 9600 #define Serial0Baud 115200 #define NUM_OF_BLOCKS 5 #define BLOCK_START_ADDR 0 #define BLOCK_SIZE 512 #define BLOCK_END_ADDR (BLOCK_SIZE * NUM_OF_BLOCKS) #define BUFFER_WORDS_SIZE ((BLOCK_SIZE * NUM_OF_BLOCKS) >> 2) // Total data size in bytes //GPS gps(PG_7, PG_8, 4800); // (Tx, Rx, Baud rate) Serial GPSSerial(TX5, RX5); TinyGPSPlus tgps; void displayInfo(void); int i = 0; //extern Serial serialGPS; //extern TinyGPSPlus gps; //Serial serialGPS(PG_7, PG_8,9600); //serial_baud(serialGPS,9600); //DS18B20 temperature sensor Serial serial(USBTX, USBRX); DS1820 ds1820(PG_15); //pin name connected to the DS1820 data pin float t; float tempSerial; float tCompare = 0; int ab=1; //E-ink Display // Control PinName rst; PinName dc; PinName busy; //SPI communication PinName mosi; PinName miso; PinName sclk; PinName cs; unsigned char frame_black[EPD_HEIGHT*EPD_WIDTH/8]; uint32_t aTxBuffer[BUFFER_WORDS_SIZE]; uint32_t aRxBuffer[BUFFER_WORDS_SIZE]; //SD card //static void print_demo_title(void); //static void print_PASS(void); //static void print_FAIL(void); //static void Fill_Buffer(uint32_t *pBuffer, uint32_t uwBufferLenght, uint32_t uwOffset); //static uint8_t Buffercmp(uint32_t* pBuffer1, uint32_t* pBuffer2, uint16_t BufferLength); static void print_demo_title(void) { BSP_LCD_Init(); BSP_LCD_Clear(LCD_COLOR_WHITE); BSP_LCD_SetTextColor(LCD_COLOR_BLUE); BSP_LCD_FillRect(0, 0, BSP_LCD_GetXSize(), 80); BSP_LCD_SetTextColor(LCD_COLOR_WHITE); BSP_LCD_SetBackColor(LCD_COLOR_BLUE); BSP_LCD_SetFont(&Font24); BSP_LCD_DisplayStringAt(0, 0, (uint8_t *)"SDCARD", CENTER_MODE); BSP_LCD_SetFont(&Font12); BSP_LCD_DisplayStringAt(0, 30, (uint8_t *)"This example shows how to write", CENTER_MODE); BSP_LCD_DisplayStringAt(0, 45, (uint8_t *)"and read data on the SDCard", CENTER_MODE); BSP_LCD_SetFont(&Font20); } //static void print_PASS(void) //{ // BSP_LCD_SetTextColor(LCD_COLOR_BLACK); // BSP_LCD_SetBackColor(LCD_COLOR_GREEN); // BSP_LCD_DisplayStringAt(0, LINE(11), (uint8_t *)"Demo OK", CENTER_MODE); //while(1); //} static void print_FAIL(void) { BSP_LCD_SetBackColor(LCD_COLOR_RED); BSP_LCD_DisplayStringAt(0, LINE(11), (uint8_t *)"Demo FAILED", CENTER_MODE); // while(1); } /** * @brief Fills buffer with user predefined data. * @param pBuffer: pointer on the buffer to fill * @param uwBufferLenght: size of the buffer to fill * @param uwOffset: first value to fill on the buffer * @retval None */ static void Fill_Buffer(uint32_t *pBuffer, uint32_t uwBufferLength, uint32_t uwOffset) { uint32_t tmpIndex = 0; /* Put in global buffer different values */ for (tmpIndex = 0; tmpIndex < uwBufferLength; tmpIndex++ ) { pBuffer[tmpIndex] = tmpIndex + uwOffset; } } /** * @brief Compares two buffers. * @param pBuffer1, pBuffer2: buffers to be compared. * @param BufferLength: buffer's length * @retval 0: pBuffer2 identical to pBuffer1 * 1: pBuffer2 differs from pBuffer1 */ static uint8_t Buffercmp(uint32_t* pBuffer1, uint32_t* pBuffer2, uint16_t BufferLength) { while (BufferLength--) { if (*pBuffer1 != *pBuffer2) { return 1; } pBuffer1++; pBuffer2++; } return 0; } //function to determine if within polygon geofence //first argument is an integer, the rest are floats //The last vertix should be the same as the first vertix int pnpoly(int nvert, float *vertx, float *verty, float testx, float testy) { int i, j, c = 0; for (i = 0, j = nvert-1; i < nvert; j = i++) { if ( ((verty[i]>testy) != (verty[j]>testy)) && (testx < (vertx[j]-vertx[i]) * (testy-verty[i]) / (verty[j]-verty[i]) + vertx[i]) ) c = !c; } return c; } int inCircle(float radius, float xcentre, float ycentre, float testx, float testy) { float distance; int test; distance = (sqrt((testx-xcentre)*(testx-xcentre)+(testy-ycentre)*(testy-ycentre))); if(distance < radius){ test = 1; } else{ test = 0; } return (test); } void displayInfo(void) { serial.printf("Location: "); if (tgps.location.isValid()) { serial.printf("%3.6f, %3.6f", tgps.location.lat(), tgps.location.lng()); } else { serial.printf("INVALID"); } serial.printf(" - Date/Time: "); if (tgps.date.isValid()) { serial.printf("%d/", tgps.date.year()); if (tgps.date.month() < 10) serial.printf("0"); serial.printf("%d/", tgps.date.month()); if (tgps.date.day() < 10) serial.printf("0"); serial.printf("%d", tgps.date.day()); } else { serial.printf("INVALID"); } serial.printf(" "); if (tgps.time.isValid()) { if (tgps.time.hour() < 10) serial.printf("0"); serial.printf("%d:", tgps.time.hour()); if (tgps.time.minute() < 10) serial.printf("0"); serial.printf("%d:", tgps.time.minute()); if (tgps.time.second() < 10) serial.printf("0"); serial.printf("%d\r\n", tgps.time.second()); } else { serial.printf("INVALID\r\n"); } } float getTemp(float t) { // getTemp(tRead); if(ds1820.begin()) { ds1820.startConversion(); wait(1.0); t = ds1820.read(); // read temperature tCompare; serial.printf("temp = %3.1f\r\n", t); // Display temp on terminal } else serial.printf("No DS1820 sensor found!\r\n"); mosi = PB_5; miso = PB_4; sclk = PA_5; cs = PA_15; rst = PI_6; dc = PG_6; busy = PI_11; char cVal[32]; //char* t_str; sprintf(cVal,"%.2f", t); memset(frame_black, 0xFF, sizeof(unsigned char)*EPD_HEIGHT*EPD_WIDTH/8); Epd epd = Epd(mosi, miso, sclk, cs, dc, rst, busy); if (epd.Init(lut_full_update) != 0) { return -1; } /*Write strings to the buffer */ epd.DrawStringAt(frame_black, 50, 30, cVal, &Font24, COLORED); epd.DrawStringAt(frame_black, 28, 10, "Temperature", &Font16, COLORED); /* Display the frame_buffer */ epd.SetFrameMemory(frame_black, 0, 0, epd.width, epd.height); epd.DisplayFrame(); epd.Sleep(); return t; } int main() { GPSSerial.baud(GPSBaud); wait(0.001); uint8_t status; print_demo_title(); wait(0.2); // Initialization status = BSP_SD_Init(); if (status == MSD_OK) { BSP_LCD_DisplayStringAt(0, LINE(5), (uint8_t *)"SD INIT OK", LEFT_MODE); } else if (status == MSD_ERROR_SD_NOT_PRESENT) { BSP_LCD_DisplayStringAt(0, LINE(5), (uint8_t *)"SD CARD NOT FOUND", LEFT_MODE); print_FAIL(); } else { BSP_LCD_DisplayStringAt(0, LINE(5), (uint8_t *)"SD INIT FAIL", LEFT_MODE); print_FAIL(); } // Erase status = BSP_SD_Erase(BLOCK_START_ADDR, BLOCK_END_ADDR); if (status == MSD_OK) { BSP_LCD_DisplayStringAt(0, LINE(6), (uint8_t *)"SD ERASE OK", LEFT_MODE); } else { BSP_LCD_DisplayStringAt(0, LINE(6), (uint8_t *)"SD ERASE FAIL", LEFT_MODE); print_FAIL(); } // Prepare the buffer to write Fill_Buffer(aTxBuffer, BUFFER_WORDS_SIZE, 0x22FF); serial.printf("tx = 0x%02X\n", aTxBuffer); // Write status = BSP_SD_WriteBlocks(aTxBuffer, BLOCK_START_ADDR, NUM_OF_BLOCKS, SD_DATATIMEOUT); //status = BSP_SD_WriteBlocks_DMA(aTxBuffer, BLOCK_START_ADDR, NUM_OF_BLOCKS); if (status == MSD_OK) { BSP_LCD_DisplayStringAt(0, LINE(7), (uint8_t *)"SD WRITE OK", LEFT_MODE); } else { BSP_LCD_DisplayStringAt(0, LINE(7), (uint8_t *)"SD WRITE FAIL", LEFT_MODE); print_FAIL(); } // Read status = BSP_SD_ReadBlocks(aRxBuffer, BLOCK_START_ADDR, NUM_OF_BLOCKS, SD_DATATIMEOUT); //status = BSP_SD_ReadBlocks_DMA(aRxBuffer, BLOCK_START_ADDR, NUM_OF_BLOCKS); if (status == MSD_OK) { BSP_LCD_DisplayStringAt(0, LINE(8), (uint8_t *)"SD READ OK", LEFT_MODE); serial.printf("rx = 0x%02X\n", aRxBuffer); } else { BSP_LCD_DisplayStringAt(0, LINE(8), (uint8_t *)"SD READ FAIL", LEFT_MODE); print_FAIL(); } // Compare data if (Buffercmp(aTxBuffer, aRxBuffer, BUFFER_WORDS_SIZE) == 0) { BSP_LCD_DisplayStringAt(0, LINE(9), (uint8_t *)"SD DATA OK", LEFT_MODE); } else { BSP_LCD_DisplayStringAt(0, LINE(9), (uint8_t *)"SD DATA FAIL", LEFT_MODE); print_FAIL(); } int inpoly; float x[5] = { 1,4,4,1,1}; float y[5] = { 1,1,4,4,1}; float xtest = 1.5; float ytest = 2; float cx = 0; float cy = 0; float r = 5; float ans = 0; while(1){ //inCircle(r, cx, cy, xtest, ytest); //serial.printf("rx = 0x%02X\n", aRxBuffer); //tempSerial = getTemp(t); //inpoly = pnpoly(5,x, y, xtest,ytest); //serial.printf("inpoly = %d\r\n", inpoly); //ans = inCircle(r, cx, cy, xtest, ytest); //serial.printf("distance = %3.1f\r\n", ans); // GPS //if(gps.sample()){ // serial.printf("%f\t%c\t%f\t%c\t%f\t%f\t%f\n\r",gps.longitude, gps.ns,gps.latitude,gps.ew, gps.alt, gps.geoid, gps.time); // serial.printf("%d:%d:%d",gps.hour,gps.minute,gps.seconed); // } while(1) { if (tgps.encode(GPSSerial.getc())) { displayInfo(); wait(0.1); //little delay to prevent double writing } if (millis() > 5000 && tgps.charsProcessed() < 10) { serial.printf("No GPS detected: check wiring.\r\n"); // while(true); break; } } serial.printf("%d\r\n",i); i++; wait(1.0); } wait(5); }