sensor result structure modified

Committer:
Vkadaba
Date:
Thu Apr 23 08:34:45 2020 +0000
Revision:
71:7b5ebd969aa7
Parent:
70:420fac5132f5
Adding extra log for FIFI error

Who changed what in which revision?

UserRevisionLine numberNew contents of line
Vkadaba 55:215da406282b 1
ADIJake 0:85855ecd3257 2 /*
Vkadaba 15:b5d57daeb7c0 3 Copyright 2019 (c) Analog Devices, Inc.
ADIJake 0:85855ecd3257 4
ADIJake 0:85855ecd3257 5 All rights reserved.
ADIJake 0:85855ecd3257 6
ADIJake 0:85855ecd3257 7 Redistribution and use in source and binary forms, with or without
ADIJake 0:85855ecd3257 8 modification, are permitted provided that the following conditions are met:
ADIJake 0:85855ecd3257 9 - Redistributions of source code must retain the above copyright
ADIJake 0:85855ecd3257 10 notice, this list of conditions and the following disclaimer.
ADIJake 0:85855ecd3257 11 - Redistributions in binary form must reproduce the above copyright
ADIJake 0:85855ecd3257 12 notice, this list of conditions and the following disclaimer in
ADIJake 0:85855ecd3257 13 the documentation and/or other materials provided with the
ADIJake 0:85855ecd3257 14 distribution.
ADIJake 0:85855ecd3257 15 - Neither the name of Analog Devices, Inc. nor the names of its
ADIJake 0:85855ecd3257 16 contributors may be used to endorse or promote products derived
ADIJake 0:85855ecd3257 17 from this software without specific prior written permission.
ADIJake 0:85855ecd3257 18 - The use of this software may or may not infringe the patent rights
ADIJake 0:85855ecd3257 19 of one or more patent holders. This license does not release you
ADIJake 0:85855ecd3257 20 from the requirement that you obtain separate licenses from these
ADIJake 0:85855ecd3257 21 patent holders to use this software.
ADIJake 0:85855ecd3257 22 - Use of the software either in source or binary form, must be run
ADIJake 0:85855ecd3257 23 on or directly connected to an Analog Devices Inc. component.
ADIJake 0:85855ecd3257 24
ADIJake 0:85855ecd3257 25 THIS SOFTWARE IS PROVIDED BY ANALOG DEVICES "AS IS" AND ANY EXPRESS OR
ADIJake 0:85855ecd3257 26 IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, NON-INFRINGEMENT,
ADIJake 0:85855ecd3257 27 MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
ADIJake 0:85855ecd3257 28 IN NO EVENT SHALL ANALOG DEVICES BE LIABLE FOR ANY DIRECT, INDIRECT,
ADIJake 0:85855ecd3257 29 INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
ADIJake 0:85855ecd3257 30 LIMITED TO, INTELLECTUAL PROPERTY RIGHTS, PROCUREMENT OF SUBSTITUTE GOODS OR
ADIJake 0:85855ecd3257 31 SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
ADIJake 0:85855ecd3257 32 CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
ADIJake 0:85855ecd3257 33 OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
ADIJake 0:85855ecd3257 34 OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
ADIJake 0:85855ecd3257 35
ADIJake 0:85855ecd3257 36 *****************************************************************************/
ADIJake 0:85855ecd3257 37 /*!
ADIJake 0:85855ecd3257 38 ******************************************************************************
ADIJake 0:85855ecd3257 39 * @file:
ADIJake 0:85855ecd3257 40 *-----------------------------------------------------------------------------
ADIJake 0:85855ecd3257 41 *
ADIJake 0:85855ecd3257 42 */
ADIJake 0:85855ecd3257 43 #include "mbed.h"
Vkadaba 5:0728bde67bdb 44 #include "admw_api.h"
Vkadaba 5:0728bde67bdb 45 #include "admw1001/admw1001_api.h"
Vkadaba 5:0728bde67bdb 46 #include "admw_log.h"
ADIJake 0:85855ecd3257 47 #include "common/utils.h"
ADIJake 0:85855ecd3257 48 #include "common/platform.h"
Vkadaba 54:31921ad29828 49 #include "admw1001/ADMW1001_REGISTERS_typedefs.h"
Vkadaba 14:266ab283b086 50 #include "admw1001/ADMW1001_REGISTERS.h"
Vkadaba 54:31921ad29828 51 #include "admw1001/admw1001_lut_data.h"
Vkadaba 54:31921ad29828 52 #include "admw1001/admw1001_host_comms.h"
Vkadaba 56:38b36e947602 53 #include "mbedVersion.h"
Vkadaba 5:0728bde67bdb 54
Vkadaba 34:b60ee1e0af2b 55 extern ADMW_CONFIG thermocouple_typeK_cjc0_config;
Vkadaba 34:b60ee1e0af2b 56 extern ADMW_CONFIG thermocouple_typeT_cjc0_config;
Vkadaba 34:b60ee1e0af2b 57 extern ADMW_CONFIG thermocouple_typeJ_cjc0_config;
Vkadaba 34:b60ee1e0af2b 58 extern ADMW_CONFIG rtd_3w_pt100_config;
Vkadaba 34:b60ee1e0af2b 59 extern ADMW_CONFIG rtd_4w_config;
Vkadaba 34:b60ee1e0af2b 60 extern ADMW_CONFIG bridge_4w_load_cell_config;
Vkadaba 34:b60ee1e0af2b 61 extern ADMW_CONFIG i2c0_sensirionSHT3X_config;
Vkadaba 47:5b42b9f9d1eb 62 /* Use the following config if adding a configuration file from measureware designer*/
Vkadaba 47:5b42b9f9d1eb 63 extern ADMW_CONFIG measureware_config;
Vkadaba 47:5b42b9f9d1eb 64
Vkadaba 49:c31473bc013e 65 /* Change the following pointer to load or change the configurations */
Vkadaba 70:420fac5132f5 66 static ADMW_CONFIG *pSelectedConfig = &thermocouple_typeK_cjc0_config;
Vkadaba 54:31921ad29828 67
Vkadaba 54:31921ad29828 68 /* use the following to load LUT */
Vkadaba 54:31921ad29828 69 extern ADMW1001_LUT_DESCRIPTOR *lut_desc_list[];
Vkadaba 54:31921ad29828 70 extern ADMW1001_LUT_TABLE_DATA *lut_data_list[];
Vkadaba 54:31921ad29828 71 extern unsigned lut_num_tables;
ADIJake 0:85855ecd3257 72
Vkadaba 5:0728bde67bdb 73 static ADMW_CONNECTION connectionInfo = PLATFORM_CONNECTION_INFO;
ADIJake 0:85855ecd3257 74
Vkadaba 14:266ab283b086 75
ADIJake 0:85855ecd3257 76 int main()
ADIJake 0:85855ecd3257 77 {
Vkadaba 5:0728bde67bdb 78 ADMW_RESULT res;
Vkadaba 5:0728bde67bdb 79 ADMW_STATUS status;
Vkadaba 5:0728bde67bdb 80 ADMW_DEVICE_HANDLE hDevice;
Vkadaba 5:0728bde67bdb 81 ADMW_MEASUREMENT_MODE eMeasurementMode = ADMW_MEASUREMENT_MODE_NORMAL;
ADIJake 0:85855ecd3257 82 bool bDeviceReady;
Vkadaba 56:38b36e947602 83
ADIJake 0:85855ecd3257 84 /*
Vkadaba 19:09d58952b65d 85 * Open an ADMW1001 device instance.
ADIJake 0:85855ecd3257 86 */
Vkadaba 5:0728bde67bdb 87 res = admw_Open(0, &connectionInfo, &hDevice);
Vkadaba 23:bb685f35b08b 88 if (res != ADMW_SUCCESS) {
Vkadaba 5:0728bde67bdb 89 ADMW_LOG_ERROR("Failed to open device instance");
ADIJake 0:85855ecd3257 90 return res;
ADIJake 0:85855ecd3257 91 }
Vkadaba 56:38b36e947602 92 ADMW_LOG_INFO("Mbed Firmware version is %X.%X.%X",MBED_HOST_MAJOR,MBED_HOST_MINOR,MBED_HOST_BUILD);
ADIJake 0:85855ecd3257 93 /*
Vkadaba 19:09d58952b65d 94 * Reset the given ADMW1001 device....
ADIJake 0:85855ecd3257 95 */
Vkadaba 19:09d58952b65d 96 ADMW_LOG_INFO("Resetting ADMW1001 device, please wait...");
Vkadaba 5:0728bde67bdb 97 res = admw_Reset(hDevice);
Vkadaba 23:bb685f35b08b 98 if (res != ADMW_SUCCESS) {
Vkadaba 5:0728bde67bdb 99 ADMW_LOG_ERROR("Failed to reset device");
ADIJake 0:85855ecd3257 100 return res;
ADIJake 0:85855ecd3257 101 }
ADIJake 0:85855ecd3257 102 /*
ADIJake 0:85855ecd3257 103 * ...and wait until the device is ready.
ADIJake 0:85855ecd3257 104 */
ADIJake 0:85855ecd3257 105 do {
ADIJake 0:85855ecd3257 106 wait_ms(100);
Vkadaba 5:0728bde67bdb 107 res = admw_GetDeviceReadyState(hDevice, &bDeviceReady);
Vkadaba 23:bb685f35b08b 108 if (res != ADMW_SUCCESS) {
Vkadaba 5:0728bde67bdb 109 ADMW_LOG_ERROR("Failed to get device ready-state");
ADIJake 0:85855ecd3257 110 return res;
ADIJake 0:85855ecd3257 111 }
ADIJake 0:85855ecd3257 112 } while (! bDeviceReady);
Vkadaba 19:09d58952b65d 113 ADMW_LOG_INFO("ADMW1001 device ready");
ADIJake 0:85855ecd3257 114 /*
ADIJake 0:85855ecd3257 115 * Write configuration settings to the device registers.
Vkadaba 5:0728bde67bdb 116 * Settings are not applied until admw_ApplyConfigUpdates() is called.
ADIJake 0:85855ecd3257 117 */
Vkadaba 5:0728bde67bdb 118 ADMW_LOG_INFO("Setting device configuration");
Vkadaba 5:0728bde67bdb 119 res = admw_SetConfig(hDevice, pSelectedConfig);
Vkadaba 23:bb685f35b08b 120 if (res != ADMW_SUCCESS) {
Vkadaba 5:0728bde67bdb 121 ADMW_LOG_ERROR("Failed to set device configuration");
ADIJake 0:85855ecd3257 122 return res;
ADIJake 0:85855ecd3257 123 }
Vkadaba 54:31921ad29828 124 unsigned lutBufferSize = ADMW_LUT_MAX_SIZE;
Vkadaba 54:31921ad29828 125 ADMW1001_LUT *pLutBuffer = (ADMW1001_LUT *) malloc(lutBufferSize);
Vkadaba 54:31921ad29828 126 if (pLutBuffer == NULL) {
Vkadaba 54:31921ad29828 127 return 1;
Vkadaba 54:31921ad29828 128 }
Vkadaba 54:31921ad29828 129
Vkadaba 54:31921ad29828 130 res=admw1001_AssembleLutData(pLutBuffer, lutBufferSize,
Vkadaba 54:31921ad29828 131 lut_num_tables,
Vkadaba 54:31921ad29828 132 lut_desc_list,
Vkadaba 54:31921ad29828 133 lut_data_list);
Vkadaba 54:31921ad29828 134 if( res != ADMW_SUCCESS ) {
Vkadaba 54:31921ad29828 135 ADMW_LOG_ERROR("Failed to assemble user-defined LUT data");
Vkadaba 54:31921ad29828 136 return res;
Vkadaba 54:31921ad29828 137 }
Vkadaba 54:31921ad29828 138
Vkadaba 54:31921ad29828 139 res=admw1001_SetLutData(hDevice,
Vkadaba 54:31921ad29828 140 pLutBuffer);
Vkadaba 54:31921ad29828 141 if( res != ADMW_SUCCESS ) {
Vkadaba 54:31921ad29828 142 ADMW_LOG_ERROR("Failed to set user-defined LUT data");
Vkadaba 54:31921ad29828 143 }
Vkadaba 54:31921ad29828 144
Vkadaba 54:31921ad29828 145 free( pLutBuffer );
Vkadaba 5:0728bde67bdb 146 res = admw_ApplyConfigUpdates(hDevice);
Vkadaba 23:bb685f35b08b 147 if (res != ADMW_SUCCESS) {
Vkadaba 5:0728bde67bdb 148 ADMW_LOG_ERROR("Failed to apply device configuration");
ADIJake 0:85855ecd3257 149 return res;
ADIJake 0:85855ecd3257 150 }
ADIJake 0:85855ecd3257 151 /*
ADIJake 0:85855ecd3257 152 * Check device status after updating the configuration
ADIJake 0:85855ecd3257 153 */
Vkadaba 5:0728bde67bdb 154 res = admw_GetStatus(hDevice, &status);
Vkadaba 50:d84305e5e1c0 155 admw_deviceInformation(hDevice);
Vkadaba 23:bb685f35b08b 156 if (res != ADMW_SUCCESS) {
Vkadaba 5:0728bde67bdb 157 ADMW_LOG_ERROR("Failed to retrieve device status");
ADIJake 0:85855ecd3257 158 return res;
ADIJake 0:85855ecd3257 159 }
ADIJake 0:85855ecd3257 160 if (status.deviceStatus &
Vkadaba 23:bb685f35b08b 161 (ADMW_DEVICE_STATUS_ERROR | ADMW_DEVICE_STATUS_ALERT)) {
ADIJake 0:85855ecd3257 162 utils_printStatus(&status);
ADIJake 0:85855ecd3257 163 }
ADIJake 0:85855ecd3257 164
ADIJake 0:85855ecd3257 165 /*
ADIJake 0:85855ecd3257 166 * Kick off the measurement cycle here
ADIJake 0:85855ecd3257 167 */
Vkadaba 5:0728bde67bdb 168 ADMW_LOG_INFO("Configuration completed, starting measurement cycles");
ADIJake 0:85855ecd3257 169 utils_runMeasurement(hDevice, eMeasurementMode);
ADIJake 0:85855ecd3257 170
ADIJake 0:85855ecd3257 171 /*
ADIJake 0:85855ecd3257 172 * Clean up and exit
ADIJake 0:85855ecd3257 173 */
Vkadaba 5:0728bde67bdb 174 res = admw_Close(hDevice);
Vkadaba 23:bb685f35b08b 175 if (res != ADMW_SUCCESS) {
Vkadaba 5:0728bde67bdb 176 ADMW_LOG_ERROR("Failed to close device instance");
ADIJake 0:85855ecd3257 177 return res;
ADIJake 0:85855ecd3257 178 }
ADIJake 0:85855ecd3257 179
ADIJake 0:85855ecd3257 180 return 0;
ADIJake 0:85855ecd3257 181 }
ADIJake 0:85855ecd3257 182