Vybhav Kadaba / Mbed OS EV-PRO-MW1001_Development_20April
Revision:
8:2f2775c34640
Parent:
6:9d393a9677f4
Child:
11:8e6023d2e584
diff -r e75e825c04a4 -r 2f2775c34640 inc/admw1001/admw1001_config.h
--- a/inc/admw1001/admw1001_config.h	Tue Jun 18 09:28:16 2019 +0000
+++ b/inc/admw1001/admw1001_config.h	Thu Jun 20 18:13:57 2019 +0000
@@ -46,10 +46,6 @@
 #include "admw_platform.h"
 #include "admw1001_sensor_types.h"
 
-/* Undefine for versions prior to V2.3. */
-#undef __V2_3_CFG_FMT__
-
-
 /*! @addtogroup ADMW1001_Api
  *  @{
  */
@@ -62,7 +58,8 @@
 #define ADMW1001_SENSOR_COMMAND_MAX_LENGTH 7
 
 /*! ADMW1001 channel priority options */
-typedef enum {
+typedef enum
+{
     ADMW1001_CHANNEL_PRIORITY_0 = 0,
     ADMW1001_CHANNEL_PRIORITY_1,
     ADMW1001_CHANNEL_PRIORITY_2,
@@ -76,26 +73,27 @@
     ADMW1001_CHANNEL_PRIORITY_10,
     ADMW1001_CHANNEL_PRIORITY_11,
     ADMW1001_CHANNEL_PRIORITY_12,
-    ADMW1001_CHANNEL_PRIORITY_13,
-    ADMW1001_CHANNEL_PRIORITY_14,
-    ADMW1001_CHANNEL_PRIORITY_15,
 
     ADMW1001_CHANNEL_PRIORITY_HIGHEST = ADMW1001_CHANNEL_PRIORITY_0,
-    ADMW1001_CHANNEL_PRIORITY_LOWEST  = ADMW1001_CHANNEL_PRIORITY_15,
-} ADMW1001_CHANNEL_PRIORITY;
+    ADMW1001_CHANNEL_PRIORITY_LOWEST  = ADMW1001_CHANNEL_PRIORITY_12,
+
+}   ADMW1001_CHANNEL_PRIORITY;
 
 /*! ADMW1001 operating mode options */
-typedef enum {
+typedef enum
+{
     ADMW1001_OPERATING_MODE_SINGLECYCLE = 0,
     /*!< Executes a single measurement cycle and stops */
     ADMW1001_OPERATING_MODE_CONTINUOUS,
     /*!< Continuously executes measurement cycles */
     ADMW1001_OPERATING_MODE_MULTICYCLE,
     /*!< Executes a burst of measurement cycles, repeated at defined intervals */
-} ADMW1001_OPERATING_MODE;
+
+}   ADMW1001_OPERATING_MODE;
 
 /*! ADMW1001 data ready mode options */
-typedef enum {
+typedef enum
+{
     ADMW1001_DATAREADY_PER_CONVERSION = 0,
     /*!< The DATAREADY signal is asserted after completion of each conversion
      *   - a single data sample only from the latest completed conversion is
@@ -107,25 +105,24 @@
      *   - data samples only from the lastest completed measurement cycle are
      *     stored in this mode
      */
-    ADMW1001_DATAREADY_PER_MULTICYCLE_BURST,
-    /*!< The DATAREADY signal is asserted after completion of each burst of
-     *   measurement cycles
-     *   - applicable only when @ref ADMW1001_OPERATING_MODE_MULTICYCLE
-     *     is also selected
-     *   - data samples only from the lastest completed burst of measurement
-     *     cycles are stored in this mode
+    ADMW1001_DATAREADY_PER_FIFO_FILL,
+    /*!< The DATAREADY signal is asserted after each fill of the data FIFO
+     *   - applicable only when @ref ADMW1001_OPERATING_MODE_CONTINUOUS or
+     *     @ref ADMW1001_OPERATING_MODE_MULTICYCLE is also selected
      */
-} ADMW1001_DATAREADY_MODE;
+
+}   ADMW1001_DATAREADY_MODE;
 
 /*! ADMW1001 power mode options */
-typedef enum {
+typedef enum
+{
     ADMW1001_POWER_MODE_HIBERNATION = 0,
     /*!< module has entede hibernation mode. All analog circuitry is disabled. All peripherals disabled apart from the Wake-up pin functionality. */
     ADMW1001_POWER_MODE_ACTIVE,
     /*!< Part is fully powered up and either cycling through a sequence or awaiting a configuration */
-} ADMW1001_POWER_MODE;
 
-#ifdef __V2_3_CFG_FMT__
+}   ADMW1001_POWER_MODE;
+
 /*! ADMW1001 measurement analog filter settling options */
 typedef enum
 {
@@ -133,22 +130,24 @@
     /*!< Allow full settling time to elapse between every measurement from an analog sensor */
     ADMW1001_FILTER_SETTLING_FAST,
     /*!< Skip settling time between consecutive measurements from an analog sensor */
-} ADMW1001_FILTER_SETTLING;
-#endif
+
+}   ADMW1001_FILTER_SETTLING;
 
 /*! ADMW1001 measurement unit options
  *
  *  Optionally select a measurement unit for final conversion results.
  *  Currently applicable only to specific temperature sensor types.
  */
-typedef enum {
+typedef enum
+{
     ADMW1001_MEASUREMENT_UNIT_UNSPECIFIED = 0,
     /*!< No measurement unit specified */
     ADMW1001_MEASUREMENT_UNIT_CELSIUS,
     /*!< Celsius temperature unit - applicable to temperature sensors only */
     ADMW1001_MEASUREMENT_UNIT_FAHRENHEIT,
     /*!< Fahrenheit temperature unit - applicable to temperature sensors only */
-} ADMW1001_MEASUREMENT_UNIT;
+
+}   ADMW1001_MEASUREMENT_UNIT;
 
 /*! ADMW1001 Open-Sensor Diagnostics frequency
  *
@@ -160,7 +159,8 @@
  *  @note Open-sensor diagnostic checks, when performed, will add a delay to the
  *        start of the next measurement cycle.
  */
-typedef enum {
+typedef enum
+{
     ADMW1001_OPEN_SENSOR_DIAGNOSTICS_DISABLED = 0,
     /*!< No Open-Sensor Detection is performed */
     ADMW1001_OPEN_SENSOR_DIAGNOSTICS_PER_CYCLE,
@@ -169,13 +169,15 @@
     /*!< No Open-Sensor Detection is performed at intervals of 100 cycles */
     ADMW1001_OPEN_SENSOR_DIAGNOSTICS_PER_1000_CYCLES,
     /*!< No Open-Sensor Detection is performed at intervals of 1001 cycles */
-} ADMW1001_OPEN_SENSOR_DIAGNOSTICS;
+
+}   ADMW1001_OPEN_SENSOR_DIAGNOSTICS;
 
 /*! ADMW1001 analog input signal amplification gain options
  *
  *  @note applicable only to ADC analog sensor channels
  */
-typedef enum {
+typedef enum
+{
     ADMW1001_ADC_RTD_CURVE_EUROPEAN = 0,
     /*!< EUROPEAN RTD curve used. */
     ADMW1001_ADC_RTD_CURVE_AMERICAN,
@@ -184,12 +186,14 @@
     /*!< JAPANESE RTD curve used. */
     ADMW1001_ADC_RTD_CURVE_ITS90,
     /*!< ITS90 RTD curve used. */
-} ADMW1001_ADC_RTD_CURVE;
+
+}   ADMW1001_ADC_RTD_CURVE;
 /*! ADMW1001 analog input signal amplification gain options
  *
  *  @note applicable only to ADC analog sensor channels
  */
-typedef enum {
+typedef enum
+{
     ADMW1001_ADC_GAIN_1X = 0,
     /*!< no amplification gain */
     ADMW1001_ADC_GAIN_2X,
@@ -206,26 +210,30 @@
     /*!< x64 amplification gain */
     ADMW1001_ADC_GAIN_128X,
     /*!< x128 amplification gain */
-} ADMW1001_ADC_GAIN;
+
+}   ADMW1001_ADC_GAIN;
 
 /*! ADMW1001 analog sensor excitation state options
  *
  *  @note applicable only to ADC analog sensor channels, and
  *        specific sensor types
  */
-typedef enum {
+typedef enum
+{
     ADMW1001_ADC_EXC_STATE_ALWAYS_ON,
     /*!< Excitation for measurement is always on */
     ADMW1001_ADC_EXC_STATE_CYCLE_POWER,
     /*!< Excitation for measurement is active only during measurement */
-} ADMW1001_ADC_EXC_STATE;
+
+}   ADMW1001_ADC_EXC_STATE;
 
 /*! ADMW1001 analog sensor excitation current output level options
  *
  *  @note applicable only to ADC analog sensor channels, and
  *        specific sensor types
  */
-typedef enum {
+typedef enum
+{
     ADMW1001_ADC_EXC_CURRENT_EXTERNAL = 0,
     /*!< External excitation is provided */ 
     ADMW1001_ADC_EXC_CURRENT_50uA,
@@ -238,13 +246,15 @@
     /*!< 500uA excitation current enabled */
     ADMW1001_ADC_EXC_CURRENT_1000uA,
     /*!< 1mA excitation current enabled */
-} ADMW1001_ADC_EXC_CURRENT;
+
+}   ADMW1001_ADC_EXC_CURRENT;
 
 /*! ADMW1001 analog sensor excitation current ratios used for diode sensor
  *
  *  @note applicable only to a diode sensor
  */
-typedef enum {
+typedef enum
+{
     ADMW1001_ADC_EXC_CURRENT_IOUT_DIODE_10UA_100UA = 0, 
     /**< 2 Current measurement 10uA 100uA        */
     ADMW1001_ADC_EXC_CURRENT_IOUT_DIODE_20UA_160UA,  
@@ -261,78 +271,98 @@
     /**< 3 current measuremetn 50uA 150uA 300uA  */
     ADMW1001_ADC_EXC_CURRENT_IOUT_DIODE_100UA_300UA_600UA,
     /**< 3 current measuremetn 100uA 300uA 600uA */
-} ADMW1001_ADC_EXC_CURRENT_DIODE_RATIO;
+
+}   ADMW1001_ADC_EXC_CURRENT_DIODE_RATIO;
 
 /*! ADMW1001 analog reference selection options
  *
  *  @note applicable only to ADC analog sensor channels, and
  *        specific sensor types
  */
-typedef enum {
-    ADMW1001_ADC_REFERENCE_NONE = 0,
-    /*!< No reference is selected */
-
-    ADMW1001_ADC_REFERENCE_RESISTOR_INTERNAL_1,
-    /*!< Internal reference resistor #1 (4320 ohms) is selected */
-    ADMW1001_ADC_REFERENCE_RESISTOR_INTERNAL_2,
-    /*!< Internal reference resistor #2 (10010 ohms) is selected */
-    ADMW1001_ADC_REFERENCE_VOLTAGE_INTERNAL,
-    /*!< Internal ADC voltage reference (2.5V) is selected */
+typedef enum
+{
+    ADMW1001_ADC_REFERENCE_VOLTAGE_INTERNAL = 0,
+    /*!< Internal VRef - 1.2V */
+    ADMW1001_ADC_REFERENCE_VOLTAGE_EXTERNAL_1,
+    /*!< External reference voltage #1 */
+    ADMW1001_ADC_REFERENCE_VOLTAGE_EXTERNAL_2,
+    /*!< External reference voltage #2 */
     ADMW1001_ADC_REFERENCE_VOLTAGE_AVDD,
     /*!< Analag Supply Voltage AVDD reference (typically 3.3V) is selected */
 
-    ADMW1001_ADC_REFERENCE_RESISTOR_EXTERNAL_1,
-    /*!< External user-supplied reference resistor #1 is selected
-     *
-     * @note reference resistor value externalRef1Value must be specified
-     * (see @ref ADMW1001_MEASUREMENT_CONFIG) */
-    ADMW1001_ADC_REFERENCE_RESISTOR_EXTERNAL_2,
-    /*!< External user-supplied reference resistor #2 is selected
-     *
-     * @note reference resistor value externalRef2Value must be specified
-     * (see @ref ADMW1001_MEASUREMENT_CONFIG) */
-    ADMW1001_ADC_REFERENCE_VOLTAGE_EXTERNAL_1,
-    /*!< External user-supplied reference voltage #1 is selected
-     *
-     * @note reference voltage value externalRef1Value must be specified
-     * (see @ref ADMW1001_MEASUREMENT_CONFIG) */
-    ADMW1001_ADC_REFERENCE_VOLTAGE_EXTERNAL_2,
-    /*!< External user-supplied reference voltage #2 is selected
-     *
-     * @note reference voltage value externalRef2Value must be specified
-     * (see @ref ADMW1001_MEASUREMENT_CONFIG) */
-    ADMW1001_ADC_REFERENCE_BRIDGE_EXCITATION,
-    /*!< Bridge Excition Voltage is selected as reference
-     *
-     * @note this reference MUST be selected for 4/6-wire bridge sensor types
-     * (see @ref ADMW1001_ADC_SENSOR_TYPE) */
-} ADMW1001_ADC_REFERENCE_TYPE;
+}   ADMW1001_ADC_REFERENCE_TYPE;
 
 /*! ADMW1001 ADC Reference configuration
  *
  *  @note applicable only to ADC analog sensor channels
  */
-typedef enum {
+typedef enum
+{
     ADMW1001_ADC_GND_SW_OPEN = 0,
     /*!< Ground switch not enabled for measurement. */
     ADMW1001_ADC_GND_SW_CLOSED,
-    /*!< Ground switch closed for measurement. */
-} ADMW1001_ADC_GND_SW;
+    /*!< Ground switch enabled for measurement. */
+
+}   ADMW1001_ADC_GND_SW;
+
+/*! ADMW1001 analog filter chop mode
+ *
+ *  @note applicable only to ADC analog sensor channels
+ */
+typedef enum
+{
+    ADMW1001_CHOP_MD_NONE = 0,
+    /*!< No chop performed. */
+    ADMW1001_CHOP_MD_HW,
+    /*!< Hardware only chop performed. */
+    ADMW1001_CHOP_MD_SW,
+    /*!< Software only chop performed. */
+    ADMW1001_CHOP_MD_HWSW,
+    /*!< Hardware and software chop performed. */
+    
+}   ADMW1001_CHOP_MD;
 
 /*! ADMW1001 analog filter selection options
  *
  *  @note applicable only to ADC analog sensor channels
  */
-typedef enum {
+typedef enum
+{
     ADMW1001_ADC_FILTER_SINC4 = 0,
-    /*!< SINC4 filter
-     *
-     * @note The number of input samples to be averaged by the filter
-     *       must be specified by fs (see @ref ADMW1001_ADC_FILTER_CONFIG).
-     *       The fs value affects the output sample rate and settling times
-     *       of the ADC */
+    /*!< SINC4 - 4th order sinc response filter */
     ADMW1001_ADC_FILTER_SINC3,
-} ADMW1001_ADC_FILTER_TYPE;
+    /*!< SINC3 - 3rd order sinc response filter */
+
+}   ADMW1001_ADC_FILTER_TYPE;
+
+/*! ADMW1001 Sinc Filter range (SF)
+ *
+ *  @note applicable only to ADC analog sensor channels
+ *  @note SF must be set in conjunction with chop mode 
+ *  and sinc filter type to achieve the desired sampling rate.
+ */
+typedef enum
+{
+    ADMW1001_SF_976HZ  = 0,
+    /*!< SF setting for 976Hz sample rate. */
+    ADMW1001_SF_488HZ  = 1,
+    /*!< SF setting for 488Hz sample rate. */
+    ADMW1001_SF_244HZ  = 3,
+    /*!< SF setting for 244Hz sample rate. */
+    ADMW1001_SF_122HZ  = 7,
+    /*!< SF setting for 122Hz sample rate. */
+    ADMW1001_SF_61HZ   = 31,
+    /*!< SF setting for 61Hz sample rate. */
+    ADMW1001_SF_30P5HZ = 51,
+    /*!< SF setting for 61Hz sample rate. */
+    ADMW1001_SF_10HZ   = 124,
+    /*!< SF setting for 10Hz sample rate. */
+    ADMW1001_SF_8P24HZ = 125,
+    /*!< SF setting for 8.24Hz sample rate. */
+    ADMW1001_SF_5HZ    = 127,
+    /*!< SF setting for 5Hz sample rate. */
+
+}   ADMW1001_SINC_FILTER_RANGE;
 
 /*! ADMW1001 I2C clock speed options
  *
@@ -340,11 +370,12 @@
  */
 typedef enum
 {
-  ADMW1001_DIGITAL_SENSOR_COMMS_I2C_CLOCK_SPEED_100K = 0,
+    ADMW1001_DIGITAL_SENSOR_COMMS_I2C_CLOCK_SPEED_100K = 0,
     /*!< 100kHz I2C clock speed */
-  ADMW1001_DIGITAL_SENSOR_COMMS_I2C_CLOCK_SPEED_400K,
+    ADMW1001_DIGITAL_SENSOR_COMMS_I2C_CLOCK_SPEED_400K,
     /*!< 400kHz I2C clock speed */
-} ADMW1001_DIGITAL_SENSOR_COMMS_I2C_CLOCK_SPEED;
+
+}   ADMW1001_DIGITAL_SENSOR_COMMS_I2C_CLOCK_SPEED;
 
 /*! ADMW1001 SPI mode options
  *
@@ -352,15 +383,16 @@
  */
 typedef enum
 {
-  ADMW1001_DIGITAL_SENSOR_COMMS_SPI_MODE_0 = 0,
+    ADMW1001_DIGITAL_SENSOR_COMMS_SPI_MODE_0 = 0,
     /*!< SPI mode 0 Clock Polarity = 0 Clock Phase = 0 */
-  ADMW1001_DIGITAL_SENSOR_COMMS_SPI_MODE_1,
+    ADMW1001_DIGITAL_SENSOR_COMMS_SPI_MODE_1,
     /*!< SPI mode 0 Clock Polarity = 0 Clock Phase = 1 */
-  ADMW1001_DIGITAL_SENSOR_COMMS_SPI_MODE_2,
+    ADMW1001_DIGITAL_SENSOR_COMMS_SPI_MODE_2,
     /*!< SPI mode 0 Clock Polarity = 1 Clock Phase = 0 */
-  ADMW1001_DIGITAL_SENSOR_COMMS_SPI_MODE_3,
+    ADMW1001_DIGITAL_SENSOR_COMMS_SPI_MODE_3,
     /*!< SPI mode 0 Clock Polarity = 1 Clock Phase = 1 */
-} ADMW1001_DIGITAL_SENSOR_COMMS_SPI_MODE;
+
+}   ADMW1001_DIGITAL_SENSOR_COMMS_SPI_MODE;
 
 /*! ADMW1001 SPI clock speed options
  *
@@ -368,60 +400,66 @@
  */
 typedef enum
 {
-  ADMW1001_DIGITAL_SENSOR_COMMS_SPI_CLOCK_13MHZ = 0,
-    /*!< SPI Clock Speed configured to 13MHz */
-  ADMW1001_DIGITAL_SENSOR_COMMS_SPI_CLOCK_6_5MHZ,
-    /*!< SPI Clock Speed configured to 6.5MHz */
-  ADMW1001_DIGITAL_SENSOR_COMMS_SPI_CLOCK_3_25MHZ,
-    /*!< SPI Clock Speed configured to 3.25MHz */
-  ADMW1001_DIGITAL_SENSOR_COMMS_SPI_CLOCK_1_625MHZ,
-    /*!< SPI Clock Speed configured to 1.625MHz */
-  ADMW1001_DIGITAL_SENSOR_COMMS_SPI_CLOCK_812KHZ,
-    /*!< SPI Clock Speed configured to 812kHz */
-  ADMW1001_DIGITAL_SENSOR_COMMS_SPI_CLOCK_406KHZ,
-    /*!< SPI Clock Speed configured to 406kHz */
-  ADMW1001_DIGITAL_SENSOR_COMMS_SPI_CLOCK_203KHZ,
-    /*!< SPI Clock Speed configured to 203kHz */
-  ADMW1001_DIGITAL_SENSOR_COMMS_SPI_CLOCK_101KHZ,
-    /*!< SPI Clock Speed configured to 101kHz */
-  ADMW1001_DIGITAL_SENSOR_COMMS_SPI_CLOCK_50KHZ,
-    /*!< SPI Clock Speed configured to 50kHz */
-  ADMW1001_DIGITAL_SENSOR_COMMS_SPI_CLOCK_25KHZ,
-    /*!< SPI Clock Speed configured to 25kHz */
-  ADMW1001_DIGITAL_SENSOR_COMMS_SPI_CLOCK_12KHZ,
-    /*!< SPI Clock Speed configured to 12kHz */
-  ADMW1001_DIGITAL_SENSOR_COMMS_SPI_CLOCK_6KHZ,
-    /*!< SPI Clock Speed configured to 6kHz */
-  ADMW1001_DIGITAL_SENSOR_COMMS_SPI_CLOCK_3KHZ,
-    /*!< SPI Clock Speed configured to 3kHz */
-  ADMW1001_DIGITAL_SENSOR_COMMS_SPI_CLOCK_1_5KHZ,
-    /*!< SPI Clock Speed configured to 1.5kHz */
-  ADMW1001_DIGITAL_SENSOR_COMMS_SPI_CLOCK_793HZ,
-    /*!< SPI Clock Speed configured to 793hz */
-  ADMW1001_DIGITAL_SENSOR_COMMS_SPI_CLOCK_396HZ,
-    /*!< SPI Clock Speed configured to 396hz */
-} ADMW1001_DIGITAL_SENSOR_COMMS_SPI_CLOCK;
+    ADMW1001_DIGITAL_SENSOR_COMMS_SPI_CLOCK_8MHZ = 0,
+    /*!< SPI Clock Speed configured to 8MHz */
+    ADMW1001_DIGITAL_SENSOR_COMMS_SPI_CLOCK_4MHZ,
+    /*!< SPI Clock Speed configured to 4MHz */
+    ADMW1001_DIGITAL_SENSOR_COMMS_SPI_CLOCK_2MHZ,
+    /*!< SPI Clock Speed configured to 2MHz */
+    ADMW1001_DIGITAL_SENSOR_COMMS_SPI_CLOCK_1MHZ,
+    /*!< SPI Clock Speed configured to 1MHz */
+    ADMW1001_DIGITAL_SENSOR_COMMS_SPI_CLOCK_500KHZ,
+    /*!< SPI Clock Speed configured to 500kHz */
+    ADMW1001_DIGITAL_SENSOR_COMMS_SPI_CLOCK_250KHZ,
+    /*!< SPI Clock Speed configured to 250kHz */
+    ADMW1001_DIGITAL_SENSOR_COMMS_SPI_CLOCK_125KHZ,
+    /*!< SPI Clock Speed configured to 125kHz */
+    ADMW1001_DIGITAL_SENSOR_COMMS_SPI_CLOCK_62P5KHZ,
+    /*!< SPI Clock Speed configured to 62.5kHz */
+    ADMW1001_DIGITAL_SENSOR_COMMS_SPI_CLOCK_31P3KHZ,
+    /*!< SPI Clock Speed configured to 31.3kHz */
+    ADMW1001_DIGITAL_SENSOR_COMMS_SPI_CLOCK_15P6KHZ,
+    /*!< SPI Clock Speed configured to 15.6kHz */
+    ADMW1001_DIGITAL_SENSOR_COMMS_SPI_CLOCK_7P8KHZ,
+    /*!< SPI Clock Speed configured to 7.8kHz */
+    ADMW1001_DIGITAL_SENSOR_COMMS_SPI_CLOCK_3P9KHZ,
+    /*!< SPI Clock Speed configured to 3.9kHz */
+    ADMW1001_DIGITAL_SENSOR_COMMS_SPI_CLOCK_1P9KHZ,
+    /*!< SPI Clock Speed configured to 1.9kHz */
+    ADMW1001_DIGITAL_SENSOR_COMMS_SPI_CLOCK_977HZ,
+    /*!< SPI Clock Speed configured to 977Hz */
+    ADMW1001_DIGITAL_SENSOR_COMMS_SPI_CLOCK_488HZ,
+    /*!< SPI Clock Speed configured to 488Hz */
+    ADMW1001_DIGITAL_SENSOR_COMMS_SPI_CLOCK_244HZ,
+    /*!< SPI Clock Speed configured to 244Hz */
+
+}   ADMW1001_DIGITAL_SENSOR_COMMS_SPI_CLOCK;
 
 /*! ADMW1001 Power Configuration options */
-typedef struct {
+typedef struct
+{
     ADMW1001_POWER_MODE        powerMode;
     /*!< Power mode selection */
-} ADMW1001_POWER_CONFIG;
+
+}   ADMW1001_POWER_CONFIG;
 
 /*! ADMW1001 Multi-Cycle Configuration options
  *
  * @note required only when ADMW1001_OPERATING_MODE_MULTICYCLE is selected
  *       as the operatingMode (@ref ADMW1001_MEASUREMENT_CONFIG)
  */
-typedef struct {
-    uint32_t                         cyclesPerBurst;
+typedef struct
+{
+    uint32_t    cyclesPerBurst;
     /*!< Number of cycles to complete for a single burst */
-    uint32_t                         burstInterval;
+    uint32_t    burstInterval;
     /*!< Interval, in seconds, between each successive burst of cycles */
-} ADMW1001_MULTICYCLE_CONFIG;
+
+}   ADMW1001_MULTICYCLE_CONFIG;
 
 /*! ADMW1001 Measurement Configuration options */
-typedef struct {
+typedef struct
+{
     ADMW1001_OPERATING_MODE    operatingMode;
     /*!< Operating mode - specifies how measurement cycles are scheduled */
     ADMW1001_DATAREADY_MODE    dataReadyMode;
@@ -431,12 +469,6 @@
      *   are scheduled.  Applicable only when operatingMode is
      *   ADMW1001_OPERATING_MODE_MULTICYCLE
      */
-    uint32_t                    cycleInterval;
-    /*!< Cycle interval - specifies the time interval between the start of each
-     *   successive measurement cycle.  Applicable only when operatingMode is
-     *   not ADMW1001_OPERATING_MODE_SINGLECYCLE
-     */
-#ifdef __V2_3_CFG_FMT__
     ADMW1001_FILTER_SETTLING   filterSettling;
     /*!< Analog filter settling - specifies the policy for settling time
      *   between consecutive measurements from an analog channel in a multi-
@@ -444,64 +476,70 @@
      *   configurations, settling time is always skipped between consecutive
      *   measurements in a measurement cycle.
      */
-#endif
-    float32_t                        externalRef1Value;
-    /*!< Resistance/voltage value connected to external reference input #1.
+    uint8_t                     reserved0[3];
+    /*!< Reserved for future use and ensure word alignment.
+     */ 
+    uint32_t                    cycleInterval;
+    /*!< Cycle interval - specifies the time interval between the start of each
+     *   successive measurement cycle.  Applicable only when operatingMode is
+     *   not ADMW1001_OPERATING_MODE_SINGLECYCLE
+     */
+    bool                        vBiasEnable;
+    /*!< Enable voltage Bias output of ADC
+     */
+    float32_t                   externalRef1Value;
+    /*!< Voltage value connected to external reference input #1.
      *   Applicable only if the selected reference type is
-     *   ADMW1001_ADC_REFERENCE_RESISTOR_EXTERNAL_1 or
-     *   ADMW1001_ADC_REFERENCE_VOLTAGE_EXTERNAL_1
+     *   voltage.
      *   (see @ref ADMW1001_ADC_REFERENCE_TYPE)
      */    
-    bool                             enableExternalFlash;
-    /*!< Enable the use of external flash memory for storage of samples.
-     */
-} ADMW1001_MEASUREMENT_CONFIG;
+    uint32_t                    reserved1[4];
+    /*!< Reserved for future use and ensure word alignment.
+     */ 
+
+}   ADMW1001_MEASUREMENT_CONFIG;
 
 /*! ADMW1001 ADC Excitation Current output configuration
  *
  *  @note applicable only to ADC analog sensor channels, and
  *        specific sensor types
  */
-typedef struct {
+typedef struct
+{
     ADMW1001_ADC_EXC_STATE                excitationState;
     /*!< Excitation current state */
     ADMW1001_ADC_EXC_CURRENT              outputLevel;
     /*!< Excitation current output level */
     ADMW1001_ADC_EXC_CURRENT_DIODE_RATIO  diodeRatio;
     /*!< Excitation current output diode ratio */
-} ADMW1001_ADC_EXC_CURRENT_CONFIG;
+
+}   ADMW1001_ADC_EXC_CURRENT_CONFIG;
 
 /*! ADMW1001 ADC Filter configuration
  *
  *  @note applicable only to ADC analog sensor channels
  */
-typedef struct {
-    ADMW1001_ADC_FILTER_TYPE   type;
+typedef struct
+{
+    ADMW1001_ADC_FILTER_TYPE    type;
     /*!< Filter type selection */
-    uint32_t                    sf;
-    /*!< SF value used along with filter type to determine speed */
-    bool                  filterChop;
+    ADMW1001_SINC_FILTER_RANGE  sf;
+    /*!< SF value used along with filter type and chop mode to determine speed */
+    ADMW1001_CHOP_MD            filterChop;
     /*!< Enable filter chop */
-    bool                  notch1p2;
+    bool                        notch1p2;
     /*!< Enable Notch 2 Filter Mode */
-    ADMW1001_ADC_GND_SW             groundSwitch;
+    ADMW1001_ADC_GND_SW         groundSwitch;
     /*!< Option to open or close sensor ground switch */
-} ADMW1001_ADC_FILTER_CONFIG;
 
-/*! ADMW1001 ADC Referemce configuration
- *
- *  @note applicable only to ADC analog sensor channels
- */
-typedef struct {
-    ADMW1001_ADC_REFERENCE_TYPE    type;
-    /*!< Filter type selection */
-} ADMW1001_ADC_REFERENCE_CONFIG;
+}   ADMW1001_ADC_FILTER_CONFIG;
 
 /*! ADMW1001 ADC analog channel configuration details
  *
  *  @note applicable only to ADC analog sensor channels
  */
-typedef struct {
+typedef struct
+{
     ADMW1001_ADC_SENSOR_TYPE        sensor;
     /*!< Sensor type selection */
     ADMW1001_ADC_RTD_CURVE          rtdCurve;
@@ -512,11 +550,30 @@
     /*!< ADC Excitation Current configuration */
     ADMW1001_ADC_FILTER_CONFIG      filter;
     /*!< ADC Filter configuration */
-    ADMW1001_ADC_REFERENCE_CONFIG   reference;
+    ADMW1001_ADC_REFERENCE_TYPE     reference;
     /*!< ADC Reference configuration */
-    bool                             enableVbias;
-    /*!< Option to enable internal ADC voltage bias */
-} ADMW1001_ADC_CHANNEL_CONFIG;
+    uint8_t                         reserved0[3];
+    /*!< Reserved for future use and ensure word alignment. */
+    uint32_t                        reserved1[6];
+    /*!< Reserved for future use and ensure word alignment. */
+
+}   ADMW1001_ADC_CHANNEL_CONFIG;
+
+/*! ADMW1001 look-up table selection
+ *  Select table used to linearise the measurement.
+ */
+typedef enum
+{
+    ADMW1001_LUT_DEFAULT  = 0,
+    /*!< Default LUT */
+    ADMW1001_LUT_UNITY    = 1,
+    /*!< Unity LUT */
+    ADMW1001_LUT_CUSTOM   = 2,
+    /*!< User defined custom LUT */
+    ADMW1001_LUT_RESERVED = 3,
+    /*!< Reserved for future use */
+    
+}   ADMW1001_LUT_SELECT;
 
 /*! ADMW1001 digital sensor data encoding
  *
@@ -524,7 +581,7 @@
  */
 typedef enum
 {
-    ADMW1001_DIGITAL_SENSOR_DATA_CODING_NONE,
+    ADMW1001_DIGITAL_SENSOR_DATA_CODING_NONE = 0,
     /**< None/Invalid - data format is ignored if coding is set to this value */
     ADMW1001_DIGITAL_SENSOR_DATA_CODING_UNIPOLAR,
     /**< Unipolar - unsigned integer values */
@@ -533,13 +590,15 @@
     ADMW1001_DIGITAL_SENSOR_DATA_CODING_OFFSET_BINARY,
     /**< Offset Binary - used to represent signed values with unsigned integers,
      *   with the mid-range value representing 0 */
-} ADMW1001_DIGITAL_SENSOR_DATA_CODING;
+
+}   ADMW1001_DIGITAL_SENSOR_DATA_CODING;
 
 /*! ADMW1001 digital sensor data format configuration
  *
  *  @note applicable only to SPI and I2C digital sensor channels
  */
-typedef struct {
+typedef struct
+{
     ADMW1001_DIGITAL_SENSOR_DATA_CODING coding;
     /**< Data Encoding of Sensor Result */
     bool littleEndian;
@@ -552,24 +611,30 @@
     /**< Number of relevant data bits to extract from the data frame */
     uint8_t bitOffset;
     /**< Data bit offset, relative to data alignment within the data frame */
-} ADMW1001_DIGITAL_SENSOR_DATA_FORMAT;
+    uint8_t reserved[2];
+    /*!< Reserved for future use and ensure word alignment. */
+
+}   ADMW1001_DIGITAL_SENSOR_DATA_FORMAT;
 
 /*! ADMW1001 digital sensor command
  *
  *  @note applicable only to SPI and I2C digital sensor channels
  */
-typedef struct {
+typedef struct
+{
     uint8_t command[ADMW1001_SENSOR_COMMAND_MAX_LENGTH];
     /*!< Optional command bytes to send to the device */
     uint8_t commandLength;
     /*!< Number of valid command bytes.  Set to 0 if unused */
-} ADMW1001_DIGITAL_SENSOR_COMMAND;
+
+}   ADMW1001_DIGITAL_SENSOR_COMMAND;
 
 /*! ADMW1001 digital sensor calibration param
  *
  *  @note applicable only to digital sensor channels
  */
-typedef struct {
+typedef struct
+{
     uint32_t calibrationParam;
     /*!< Independently established environmental variable used during calibration
      *   of a digital sensor. Used only if the sensor supports calibration
@@ -577,68 +642,80 @@
      */
     bool enableCalibrationParam;
     /*!< Allow Calibration_Parameter to be used during calibration of any digital sensor */
-} ADMW1001_DIGITAL_CALIBRATION_COMMAND;
+    uint8_t                         reserved[3];
+    /*!< Reserved for future use and ensure word alignment. */
+
+}   ADMW1001_DIGITAL_CALIBRATION_COMMAND;
 
 /*! ADMW1001 digital sensor communication config
  *
  *  @note applicable only to digital sensor channels
  */
-typedef struct {
-    bool  useCustomCommsConfig;
+typedef struct
+{
+    bool                                            useCustomCommsConfig;
     /*!< Optional parameter to enable user digital communication settings */
-    ADMW1001_DIGITAL_SENSOR_COMMS_I2C_CLOCK_SPEED     i2cClockSpeed;
+    ADMW1001_DIGITAL_SENSOR_COMMS_I2C_CLOCK_SPEED   i2cClockSpeed;
     /*!< Optional parameter to configure specific i2c speed for i2c sensor */
-    ADMW1001_DIGITAL_SENSOR_COMMS_SPI_MODE            spiMode;
+    ADMW1001_DIGITAL_SENSOR_COMMS_SPI_MODE          spiMode;
     /*!< Optional parameter to configure specific spi mode for spi sensor */
-    ADMW1001_DIGITAL_SENSOR_COMMS_SPI_CLOCK           spiClock;
+    ADMW1001_DIGITAL_SENSOR_COMMS_SPI_CLOCK         spiClock;
     /*!< Optional parameter to configure specific spi clock for spi sensor */
-} ADMW1001_DIGITAL_SENSOR_COMMS;
+
+}   ADMW1001_DIGITAL_SENSOR_COMMS;
 
 /*! ADMW1001 I2C digital channel configuration details
  *
  *  @note applicable only to I2C digital sensor channels
  */
-typedef struct {
-    ADMW1001_I2C_SENSOR_TYPE        sensor;
+typedef struct
+{
+    ADMW1001_I2C_SENSOR_TYPE                sensor;
     /*!< Sensor type selection */
-    uint32_t                              deviceAddress;
+    uint8_t                                 deviceAddress;
     /*!< I2C device address (7-bit) */
-    ADMW1001_DIGITAL_SENSOR_COMMAND configurationCommand;
+    uint8_t                                 reserved;
+    /*!< Reserved for future use and ensure word alignment. */
+    ADMW1001_DIGITAL_SENSOR_COMMAND         configurationCommand;
     /*!< Optional configuration command to send to the device at start-up.
      *   A default configuration command will be used if this is not specified.
      *   Applicable only to specific I2C sensor types.
      */
-    ADMW1001_DIGITAL_SENSOR_COMMAND dataRequestCommand;
+    ADMW1001_DIGITAL_SENSOR_COMMAND         dataRequestCommand;
     /*!< Optional data request command to send to the device for each sample.
      *   A default data request command will be used if this is not specified.
      *   Applicable only to specific I2C sensor types.
      */
-    ADMW1001_DIGITAL_SENSOR_DATA_FORMAT dataFormat;
+    ADMW1001_DIGITAL_SENSOR_DATA_FORMAT     dataFormat;
     /*!< Optional data format configuration to parse/extract data from the device.
      *   A default data format will be used if this is not specified.
      *   Applicable only to specific I2C sensor types
      */
-    ADMW1001_DIGITAL_CALIBRATION_COMMAND digitalCalibrationParam;
+    ADMW1001_DIGITAL_CALIBRATION_COMMAND    digitalCalibrationParam;
     /*!< This is used to supply an independently established environmental variable
      *   that must be used during calibration of a [digital] sensor which a)
      *   supports calibration and b) expects an environmental parameter.
      *   An example is a CO2 sensor, which may require the CO2 concentration level
      *   when performing a calibration
      */
-    ADMW1001_DIGITAL_SENSOR_COMMS configureComms;
+    ADMW1001_DIGITAL_SENSOR_COMMS           configureComms;
     /*!< Optional configuration to setup a user communication config.
      *   A default configuration  will be used if this is not specified.
      *   Applicable only to specific I2C sensor types.
      */
-} ADMW1001_I2C_CHANNEL_CONFIG;
+
+}   ADMW1001_I2C_CHANNEL_CONFIG;
 
 /*! ADMW1001 SPI digital channel configuration details
  *
  *  @note applicable only to SPI digital sensor channels
  */
-typedef struct {
+typedef struct
+{
     ADMW1001_SPI_SENSOR_TYPE        sensor;
     /*!< Sensor type selection */
+    uint8_t                         reserved[2];
+    /*!< Reserved for future use and ensure word alignment. */    
     ADMW1001_DIGITAL_SENSOR_COMMAND configurationCommand;
     /*!< Optional configuration command to send to the device at start-up.
      *   A default configuration command will be used if this is not specified.
@@ -661,84 +738,85 @@
      *   An example is a CO2 sensor, which may require the CO2 concentration level
      *   when performing a calibration
      */
-    ADMW1001_DIGITAL_SENSOR_COMMS configureComms;
+    ADMW1001_DIGITAL_SENSOR_COMMS       configureComms;
     /*!< Optional configuration to setup a user communication config.
      *   A default configuration  will be used if this is not specified.
      *   Applicable only to specific SPI sensor types.
      */
-} ADMW1001_SPI_CHANNEL_CONFIG;
 
+}   ADMW1001_SPI_CHANNEL_CONFIG;
 
 /*! ADMW1001 Measurement Channel configuration details */
-typedef struct {
-    bool                                 enableChannel;
+typedef struct
+{
+    bool                                enableChannel;
     /*!< Option to include this channel in normal measurement cycles */
-    bool                                 disablePublishing;
+    bool                                disablePublishing;
     /*!< Option to disable publishing of data samples from this channel.  The
      *   channel may still be included in measurement cycles, but data samples
      *   obtained from this channel will not be published.  This is typically
      *   used for channels which are required only as a compensation reference
      *   for another channel (e.g. Cold-Junction Compensation channels).
      */
-    ADMW1001_CHANNEL_ID                compensationChannel;
-    /*!< Optional compensation channel.  Set to ADMW1001_CHANNEL_ID_NONE if not
+    ADMW1001_CH_ID                      compensationChannel;
+    /*!< Optional compensation channel.  Set to ADMW1001_CH_ID_NONE if not
      *   required.  Typically used for thermocouple sensors that require a
      *   separate measurement of the "cold-junction" temperature, which can be
      *   be provided by an RTD temperature sensor connected on a separate
      *   "compensation channel" */
-    bool                                 enableUnityLut;
-    /*!< Option to choose the LUT for calculations, this implies that the
+    ADMW1001_LUT_SELECT                 lutSelect;
+    /*!<Select Look Up Table LUT for calculations, this implies that the
      * fundamental measurement for the sensor (typically mV or Ohms)
-     * would be returned as the measurement result.
+     * 0 = default, 1= unity, 2 = custom
      */
-    ADMW1001_MEASUREMENT_UNIT          measurementUnit;
+    ADMW1001_MEASUREMENT_UNIT           measurementUnit;
     /*!< Optional measurement unit selection for conversion results.  Applicable
      *   only for certain sensor types.  Set to
      *   ADMW1001_MEASUREMENT_UNIT_DEFAULT if not applicable.
      */
-    float32_t                            lowThreshold;
+    float32_t                           lowThreshold;
     /*!< Optional minimum threshold value for each processed sample, to be
      *   checked prior to publishing.  A channel ALERT condition is raised
      *   if the processed value is lower than this threshold.  Set to NaN
      *   if not required.
      */
-    float32_t                            highThreshold;
+    float32_t                           highThreshold;
     /*!< Optional maximum threshold value for each processed sample, to be
      *   checked prior to publishing.  A channel ALERT condition is raised
      *   if the processed value is higher than this threshold.  Set to NaN
      *   if not required.
      */
-    float32_t                            offsetAdjustment;
+    float32_t                           offsetAdjustment;
     /*!< Optional offset adjustment value applied to each processed sample.
      *   Set to NaN or 0.0 if not required.
      */
-    float32_t                            gainAdjustment;
+    float32_t                           gainAdjustment;
     /*!< Optional gain adjustment value applied to each processed sample.
      *   Set to NaN or 1.0 if not required.
      */
-    float32_t                            sensorParameter;
+    float32_t                           sensorParameter;
     /*!< Optional sensor parameter adjustment.
      *   Set to NaN or 0 if not required.
      */
-    uint32_t                             measurementsPerCycle;
+    uint32_t                            measurementsPerCycle;
     /*!< The number of measurements to obtain from this channel within each
      *   cycle.  Each enabled channel is measured in turn, until the number of
      *   measurements requested for the channel has been reached.  A different
      *   number of measurements-per-cycle may be specified for each channel.
      */
-    uint32_t                             cycleSkipCount;
+    uint32_t                            cycleSkipCount;
     /*!< Optional number of cycles to skip, such that this channel is included
      *   in the sequence in only one of every (cycleSkipCount + 1) cycles that
      *   occur.  If set to 0 (default), this channel is included in every cycle;
      *   if set to 1, this channel is included in every 2nd cycle; if set to 2,
      *   this channel is included in every 3rd cycle, and so on.
      */
-    uint32_t                             extraSettlingTime;
+    uint32_t                            extraSettlingTime;
     /*!< A minimum settling time is applied internally for each channel, based
      *   on the sensor type.  However, additional settling time (microseconds)
      *   can optionally be specified.  Set to 0 if not required.
      */
-    ADMW1001_CHANNEL_PRIORITY          priority;
+    ADMW1001_CHANNEL_PRIORITY           priority;
     /*!< By default, channels are arranged in the measurement sequence based on
      *   ascending order of channel ID.  However, a priority-level may be
      *   specified per channel to force a different ordering of the channels,
@@ -747,48 +825,51 @@
      *   ID.  Lower numbers indicate higher priority, with 0 being the highest.
      *   Set to 0 if not required.
      */
-    union {
-        ADMW1001_ADC_CHANNEL_CONFIG adcChannelConfig;
+    union 
+    {
+        ADMW1001_ADC_CHANNEL_CONFIG     adcChannelConfig;
         /*!< ADC channel configuration - applicable only to ADC channels */
-        ADMW1001_I2C_CHANNEL_CONFIG i2cChannelConfig;
+        ADMW1001_I2C_CHANNEL_CONFIG     i2cChannelConfig;
         /*!< I2C channel configuration - applicable only to I2C channels */
-        ADMW1001_SPI_CHANNEL_CONFIG spiChannelConfig;
+        ADMW1001_SPI_CHANNEL_CONFIG     spiChannelConfig;
         /*!< SPI channel configuration - applicable only to SPI channels */
     };
     /*!< Only one of adcChannelConfig, i2cChannelConfig, spiChannelConfig
      *  is required, depending on the channel designation
      *   (analog, I2C, SPI)
      */
-} ADMW1001_CHANNEL_CONFIG;
+
+}   ADMW1001_CHANNEL_CONFIG;
 
 /*! ADMW1001 Diagnostics configuration details */
-typedef struct {
-    bool                                   disableGlobalDiag;
+typedef struct
+{
+    bool                                disableGlobalDiag;
     /*!< Option to disable the following diagnostic checks on the ADC:
      *   - Reference Detection errors
      *   - Input under-/over-voltage errors
      *   - Calibration, Conversion and Saturation errors
      */
-    bool                                   disableMeasurementDiag;
+    bool                                disableMeasurementDiag;
     /*!< Option to disable additional checks per measurement channel:
      *   - High/low threshold limit violation
      */
-#ifdef __V2_3_CFG_FMT__
-    bool                                   disableCriticalTempAbort;
+
+    bool                                disableCriticalTempAbort;
     /*!< Option to disable abort of measurement cycle if the operating
      *   temperature of the ADMW1001 has exceeded critical limits
      */
-#endif
-    ADMW1001_OPEN_SENSOR_DIAGNOSTICS osdFrequency;
+
+    ADMW1001_OPEN_SENSOR_DIAGNOSTICS    osdFrequency;
     /*!< Option to enable Open-Circuit Detection at a selected cycle interval */
-} ADMW1001_DIAGNOSTICS_CONFIG;
 
-#ifdef __V2_3_CFG_FMT__
+}   ADMW1001_DIAGNOSTICS_CONFIG;
+
 typedef uint16_t ADMW1001_ADVANCED_ACCESS_KEY;
-#endif
 
 /*! ADMW1001 Device configuration details */
-typedef struct {
+typedef struct
+{
     ADMW1001_POWER_CONFIG           power;
     /*!< Power configuration details */
     ADMW1001_MEASUREMENT_CONFIG     measurement;
@@ -797,11 +878,10 @@
     /*!< FFT configuration details */
     ADMW1001_CHANNEL_CONFIG         channels[ADMW1001_MAX_CHANNELS];
     /*!< Channel-specific configuration details */
-#ifdef __V2_3_CFG_FMT__
     ADMW1001_ADVANCED_ACCESS_KEY    advancedAccessKey;
-#endif
     /*!< Key to enable access to advanced sensor configuration options */
-} ADMW1001_CONFIG;
+
+}   ADMW1001_CONFIG;
 
 #ifdef __cplusplus
 }