This is the latest working repository used in our demo video for the Maxim to display temperature readings on Bluetooth

Dependencies:   USBDevice

Revision:
3:36de8b9e4b1a
Parent:
2:86d928355813
Child:
4:1fcd660d72fe
--- a/HSP/RpcServer/RpcServer.cpp	Sat Apr 10 02:05:01 2021 +0000
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,477 +0,0 @@
-/*******************************************************************************
- * Copyright (C) 2016 Maxim Integrated Products, Inc., All Rights Reserved.
- *
- * Permission is hereby granted, free of charge, to any person obtaining a
- * copy of this software and associated documentation files (the "Software"),
- * to deal in the Software without restriction, including without limitation
- * the rights to use, copy, modify, merge, publish, distribute, sublicense,
- * and/or sell copies of the Software, and to permit persons to whom the
- * Software is furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be included
- * in all copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
- * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
- * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
- * IN NO EVENT SHALL MAXIM INTEGRATED BE LIABLE FOR ANY CLAIM, DAMAGES
- * OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
- * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
- * OTHER DEALINGS IN THE SOFTWARE.
- *
- * Except as contained in this notice, the name of Maxim Integrated
- * Products, Inc. shall not be used except as stated in the Maxim Integrated
- * Products, Inc. Branding Policy.
- *
- * The mere transfer of this software does not imply any licenses
- * of trade secrets, proprietary technology, copyrights, patents,
- * trademarks, maskwork rights, or any other form of intellectual
- * property whatsoever. Maxim Integrated Products, Inc. retains all
- * ownership rights.
- *******************************************************************************
- */
-#include "RpcServer.h"
-#include "StringInOut.h"
-#include "StringHelper.h"
-#include "MAX30001_RPC.h"
-#include "MAX30101_RPC.h"
-#include "LIS2DH_RPC.h"
-#include "Logging_RPC.h"
-#include "Peripherals.h"
-#include "I2C_RPC.h"
-#include "BMP280_RPC.h"
-#include "MAX30205_RPC.h"
-#include "HspLed_RPC.h"
-#include "S25FS512_RPC.h"
-#include "Testing_RPC.h"
-#include "MAX14720_RPC.h"
-#include "RpcDeclarations.h"
-#include "Device_Logging.h"
-
-/// define the version string that is reported with a RPC "ReadVer" command
-#define FW_VERSION_STRING "HSP FW Version 3.0.1 4/21/16"
-
-char args[32][32];
-char results[32][32];
-
-/// define a fifo for incoming USB data
-static fifo_t fifo;
-/// define a buffer for incoming USB data
-static uint8_t fifoBuffer[128];
-/// define stream out fifo
-static fifo_t fifoStreamOut;
-/// allocate a large fifo buffer for streaming out
-static uint32_t streamOutBuffer[0xC000 / 4];
-
-/// define a device log for the BMP280, keeps track of mission and loggin status
-Device_Logging *bmp280_Logging;
-/// define a device log for the MAX30205 (instance 0), keeps track of mission
-/// and loggin status
-Device_Logging *MAX30205_0_Logging;
-/// define a device log for the MAX30205 (instance 1), keeps track of mission
-/// and loggin status
-Device_Logging *MAX30205_1_Logging;
-
-///Defines a timer to detect if a series of binary pages are being transfered via RPC
-Timer rpcFlashPagesTransferTimer;
-bool rpcFlashPagesTransferTimer_running;
-
-//******************************************************************************
-fifo_t *GetUSBIncomingFifo(void) { return &fifo; }
-
-//******************************************************************************
-fifo_t *GetStreamOutFifo(void) { return &fifoStreamOut; }
-
-//******************************************************************************
-int System_ReadVer(char argStrs[32][32], char replyStrs[32][32]) {
-  strcpy(replyStrs[0], FW_VERSION_STRING);
-  strcpy(replyStrs[1], "\0");
-  return 0;
-}
-
-//******************************************************************************
-bool RPC_IsTransferingFlashPages(void) {
-  if (rpcFlashPagesTransferTimer_running == true) {
-    if (rpcFlashPagesTransferTimer.read_ms() < 200) {
-      return true;
-    } else {
-      rpcFlashPagesTransferTimer.stop();
-      rpcFlashPagesTransferTimer_running = false;
-    }
-  }
-  return false;
-}
-
-//******************************************************************************
-void RPC_TransferingFlashPages(void) {
-  if (rpcFlashPagesTransferTimer_running == false) {
-    rpcFlashPagesTransferTimer.start();
-    rpcFlashPagesTransferTimer_running = true;
-  }
-  rpcFlashPagesTransferTimer.reset();
-}
-
-//******************************************************************************
-int System_ReadBuildTime(char argStrs[32][32], char replyStrs[32][32]) {
-  // strcpy(replyStrs[0],buildTime);
-  // strcpy(replyStrs[1],"\0");
-  return 0;
-}
-
-//******************************************************************************
-int System_SystemCoreClock(char argStrs[32][32], char replyStrs[32][32]) {
-  sprintf(replyStrs[0], "SystemCoreClock = %d", (unsigned int)SystemCoreClock);
-  strcpy(replyStrs[1], "\0");
-  return 0;
-}
-
-//******************************************************************************
-int System_GetTimestamp(char argStrs[32][32], char replyStrs[32][32]) {
-  sprintf(replyStrs[0], "GetTimestamp = %d", 0);
-  strcpy(replyStrs[1], "\0");
-  return 0;
-}
-
-static struct RPC_Object RPC_Procedures = {NULL, NULL};
-
-//******************************************************************************
-void RPC_addProcedure(struct RPC_registeredProcedure *procedure) {
-  struct RPC_Object *obj = &RPC_Procedures;
-  if (obj->last != NULL) {
-    obj->last->next = procedure;
-  }
-  if (obj->head == NULL) {
-    obj->head = procedure;
-  }
-  procedure->next = NULL;
-  obj->last = procedure;
-}
-
-//******************************************************************************
-void RPC_init(void) {
-  bmp280_Logging = new Device_Logging();
-  MAX30205_0_Logging = new Device_Logging();
-  MAX30205_1_Logging = new Device_Logging();
-
-  rpcFlashPagesTransferTimer_running = false;
-
-  fifo_init(&fifo, fifoBuffer, sizeof(fifoBuffer));
-  fifo_init(&fifoStreamOut, streamOutBuffer,
-            sizeof(streamOutBuffer) / sizeof(uint32_t));
-
-  // I2c
-  RPC_addProcedure(&Define_I2c_WriteRead);
-
-  // MAX30101
-  RPC_addProcedure(&Define_MAX30101_WriteReg);
-  RPC_addProcedure(&Define_MAX30101_ReadReg);
-  RPC_addProcedure(&Define_MAX30101_SpO2mode_Init);
-  RPC_addProcedure(&Define_MAX30101_HRmode_Init);
-  RPC_addProcedure(&Define_MAX30101_Multimode_init);
-  RPC_addProcedure(&Define_MAX30101_SpO2mode_InitStart);
-  RPC_addProcedure(&Define_MAX30101_HRmode_InitStart);
-  RPC_addProcedure(&Define_MAX30101_Multimode_InitStart);
-  RPC_addProcedure(&Define_MAX30101_SpO2mode_stop);
-  RPC_addProcedure(&Define_MAX30101_HRmode_stop);
-  RPC_addProcedure(&Define_MAX30101_Multimode_stop);
-
-  // MAX30001
-  RPC_addProcedure(&Define_MAX30001_WriteReg);
-  RPC_addProcedure(&Define_MAX30001_ReadReg);
-  RPC_addProcedure(&Define_MAX30001_Start);
-  RPC_addProcedure(&Define_MAX30001_Stop);
-  RPC_addProcedure(&Define_MAX30001_Enable_ECG_LeadON);
-  RPC_addProcedure(&Define_MAX30001_Enable_BIOZ_LeadON);
-  RPC_addProcedure(&Define_MAX30001_Read_LeadON);
-  RPC_addProcedure(&Define_MAX30001_StartTest);
-  RPC_addProcedure(&Define_MAX30001_INT_assignment);
-  RPC_addProcedure(&Define_MAX30001_Rbias_FMSTR_Init);
-  RPC_addProcedure(&Define_MAX30001_CAL_InitStart);
-  RPC_addProcedure(&Define_MAX30001_ECG_InitStart);
-  RPC_addProcedure(&Define_MAX30001_ECGFast_Init);
-  RPC_addProcedure(&Define_MAX30001_PACE_InitStart);
-  RPC_addProcedure(&Define_MAX30001_BIOZ_InitStart);
-  RPC_addProcedure(&Define_MAX30001_RtoR_InitStart);
-  RPC_addProcedure(&Define_MAX30001_Stop_ECG);
-  RPC_addProcedure(&Define_MAX30001_Stop_PACE);
-  RPC_addProcedure(&Define_MAX30001_Stop_BIOZ);
-  RPC_addProcedure(&Define_MAX30001_Stop_RtoR);
-  RPC_addProcedure(&Define_MAX30001_Stop_Cal);
-
-  // Logging
-  RPC_addProcedure(&Define_Logging_StartMissionDefine);
-  RPC_addProcedure(&Define_Logging_AppendMissionCmd);
-  RPC_addProcedure(&Define_Logging_EndMissionDefine);
-  RPC_addProcedure(&Define_Logging_WriteMission);
-  RPC_addProcedure(&Define_Logging_ReadMission);
-  RPC_addProcedure(&Define_Logging_EraseMission);
-  RPC_addProcedure(&Define_Logging_EraseWrittenSectors);
-  RPC_addProcedure(&Define_Logging_StartLoggingUsb);
-  RPC_addProcedure(&Define_Logging_StartLoggingFlash);
-  RPC_addProcedure(&Define_Logging_GetLastWrittenPage);
-  RPC_addProcedure(&Define_Logging_Start);
-
-  // LIS2HD
-  RPC_addProcedure(&Define_LIS2DH_InitStart);
-  RPC_addProcedure(&Define_LIS2DH_ReadReg);
-  RPC_addProcedure(&Define_LIS2DH_WriteReg);
-  RPC_addProcedure(&Define_LIS2DH_Stop);
-
-  // BMP280
-  RPC_addProcedure(&Define_BMP280_InitStart);
-
-  // MAX30205 and MAX31725 Alias
-  RPC_addProcedure(&Define_MAX30205_1_InitStart);
-  RPC_addProcedure(&Define_MAX30205_2_InitStart);
-  RPC_addProcedure(&Define_MAX31725_1_InitStart);
-  RPC_addProcedure(&Define_MAX31725_2_InitStart);
-
-  // led
-  RPC_addProcedure(&Define_Led_On);
-  RPC_addProcedure(&Define_Led_Off);
-  RPC_addProcedure(&Define_Led_BlinkHz);
-  RPC_addProcedure(&Define_Led_BlinkPattern);
-
-  // S25FS512
-  RPC_addProcedure(&Define_S25FS512_ReadId);
-  RPC_addProcedure(&Define_S25FS512_ReadPagesBinary);
-  RPC_addProcedure(&Define_S25FS512_Reset);
-  RPC_addProcedure(&Define_S25FS512_EnableHWReset);
-  RPC_addProcedure(&Define_S25FS512_SpiWriteRead);
-  RPC_addProcedure(&Define_S25FS512_SpiWriteRead4Wire);
-
-  // Testing
-  RPC_addProcedure(&Define_Testing_Test_S25FS512);
-  RPC_addProcedure(&Define_Testing_Test_BMP280);
-  RPC_addProcedure(&Define_Testing_Test_LIS2DH);
-  RPC_addProcedure(&Define_Testing_Test_LSM6DS3);
-  RPC_addProcedure(&Define_Testing_Test_MAX30205_1);
-  RPC_addProcedure(&Define_Testing_Test_MAX30205_2);
-  RPC_addProcedure(&Define_Testing_Test_MAX30101);
-  RPC_addProcedure(&Define_Testing_Test_MAX30001);
-  RPC_addProcedure(&Define_Testing_Test_EM9301);
-
-  // System
-  RPC_addProcedure(&Define_System_ReadVer);
-  RPC_addProcedure(&Define_System_ReadBuildTime);
-
-  // MAX14720
-  RPC_addProcedure(&Define_MAX14720_ReadBoostVSet);
-  RPC_addProcedure(&Define_MAX14720_WriteBoostVSet);
-  RPC_addProcedure(&Define_MAX14720_ReadReg);
-  RPC_addProcedure(&Define_MAX14720_WriteReg);
-}
-
-//******************************************************************************
-struct RPC_registeredProcedure *RPC_lookup(char *objectName, char *methodName) {
-  struct RPC_registeredProcedure *ptr;
-  // lookup all registered methods
-  ptr = RPC_Procedures.head;
-  while (ptr != NULL) {
-    if (strcmp(ptr->objectName, objectName) == 0 &&
-        strcmp(ptr->methodName, methodName) == 0) {
-      // we found a match... return with it
-      return ptr;
-    }
-    ptr = ptr->next;
-  }
-  return NULL;
-}
-
-//******************************************************************************
-char *GetToken(char *inStr, char *outStr, int start, char ch) {
-  int i;
-  int index = 0;
-  int length = strlen(inStr);
-  for (i = start; i < length; i++) {
-    if (inStr[i] != ch) {
-      outStr[index++] = inStr[i];
-    } else {
-      break;
-    }
-  }
-  outStr[index++] = 0;
-  return outStr;
-}
-
-//******************************************************************************
-void SendCommandList(char *reply) {
-  struct RPC_registeredProcedure *ptr;
-  reply[0] = 0;
-  ptr = RPC_Procedures.head;
-  while (ptr != NULL) {
-    strcat(reply, "/");
-    strcat(reply, ptr->objectName);
-    strcat(reply, "/");
-    strcat(reply, ptr->methodName);
-    strcat(reply, ",");
-    ptr = ptr->next;
-  }
-  strcat(reply, "\r\n");
-}
-
-//******************************************************************************
-int CheckForDoubleQuote(const char *str) {
-  int doubleQuoteFound;
-  // scan through arguments, see if there is a double quote for a string
-  // argument
-  doubleQuoteFound = 0;
-  while (*str != 0) {
-    if (*str == '\"') {
-      doubleQuoteFound = 1;
-      break;
-    }
-    str++;
-  }
-  return doubleQuoteFound;
-}
-
-//******************************************************************************
-void ExtractDoubleQuoteStr(const char *src, char *dst) {
-  int start;
-
-  dst[0] = 0;
-  start = 0;
-  while (*src != 0) {
-    // look for start
-    if ((*src == '\"') && (start == 0)) {
-      start = 1;
-      src++;
-      continue;
-    }
-    // look for end
-    if ((*src == '\"') && (start == 1)) {
-      *dst = 0; // terminate the string
-      break;
-    }
-    if (start == 1) {
-      *dst = *src;
-      dst++;
-    }
-    src++;
-  }
-}
-
-//******************************************************************************
-void RPC_call_test(void) {
-  int doubleQuoteFound;
-  char doubleQuoteStr[64];
-  const char *request = "/Logging/AppendMissionCmd \"BMP280 InitStart 1\"";
-
-  // scan through arguments, see if there is a double quote for a string
-  // argument
-  doubleQuoteFound = CheckForDoubleQuote(request);
-  if (doubleQuoteFound) {
-    ExtractDoubleQuoteStr(request, doubleQuoteStr);
-  }
-}
-
-//******************************************************************************
-void RPC_call(char *request, char *reply) {
-  const char slash[2] = "/";
-  const char space[2] = " ";
-  char *objectName;
-  char *methodName;
-  char doubleQuoteStr[64];
-  char requestCpy[128];
-  char *token;
-  int argIndex;
-  int resultIndex;
-  int doubleQuoteFound;
-  struct RPC_registeredProcedure *procedurePtr;
-  int callResult;
-
-  // clear out the reply
-  reply[0] = 0;
-  // copy the request for scanning and extraction later
-  strcpy(requestCpy, request);
-  // check for beginning forward slash
-  if (request[0] != '/') {
-    return;
-  }
-  // check for only a forward slash
-  if (request[0] == '/' && request[1] == 0) {
-    SendCommandList(reply);
-    return;
-  }
-  strcat(request, " ");
-  // get the object name
-  token = strtok(request, slash);
-  // token = GetToken(request, tokenBuffer, 1, '/');
-  objectName = token;
-  if (objectName == NULL)
-    return; // must have an object name
-  // get the method name
-  token = strtok(NULL, space);
-  methodName = token;
-  if (methodName == NULL)
-    return; // must have a method name
-
-  // scan through arguments, see if there is a double quote for a string
-  // argument
-  doubleQuoteFound = CheckForDoubleQuote(requestCpy);
-
-  if (doubleQuoteFound == 0) {
-    // walk through arguments
-    argIndex = 0;
-    token = strtok(NULL, space);
-    while (token != NULL) {
-      // save this arg in array
-      strcpy(args[argIndex++], token);
-      // read next token arg if any
-      token = strtok(NULL, space);
-    }
-    // terminate the end of the string array with an empty string
-    strcpy(args[argIndex], "\0");
-    strcpy(results[0], "\0");
-  } else {
-    // grab out the double quote string
-    ExtractDoubleQuoteStr(requestCpy, doubleQuoteStr);
-    argIndex = 0;
-    // token = strtok(NULL, quote);
-    strcpy(args[argIndex++], doubleQuoteStr);
-  }
-
-  //
-  // alias the MAX30001 and MAX30003 names
-  //
-  if (strcmp(objectName, MAX30003_NAME) == 0) {
-    strcpy(objectName, MAX30001_NAME);
-  }
-
-  callResult = 0;
-  procedurePtr = RPC_lookup(objectName, methodName);
-  if (procedurePtr != NULL) {
-    // printf("RPC_call: %s processing\n",requestCpy);
-    callResult = procedurePtr->func(args, results);
-  } else {
-    printf("RPC_call: %s not found\n", requestCpy);
-    // printf("Unable to lookup %s %s", objectName, methodName);
-  }
-
-  // loop while (if) there are results to return
-  resultIndex = 0;
-  strcpy(reply, "\0");
-  if (callResult != RPC_SKIP_CRLF) { 
-    while (results[resultIndex][0] != '\0') {
-      strcat(reply, results[resultIndex++]);
-      strcat(reply, " ");
-    }
-    strcat(reply, "\r\n");
-  }
-}
-
-//******************************************************************************
-void RPC_ProcessCmds(char *cmds) {
-  char cmd[32 * 32];
-  char *ptrCmds;
-  char reply[512];
-  ptrCmds = cmds;
-
-  while (*ptrCmds != 0) {
-    ptrCmds = ParseUntilCRLF(ptrCmds, cmd, sizeof(cmd));
-    if (*cmd != 0) {
-      RPC_call(cmd, reply);
-    }
-  }
-}