Vybhav Kadaba
/
EV-PRO-MW1001_Development
added wait_us(31) in admw_spi.cpp to support hibernation mode
Diff: inc/admw_api.h
- Revision:
- 5:0728bde67bdb
- Parent:
- 3:cc09ac626ab3
- Child:
- 6:9d393a9677f4
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/inc/admw_api.h Wed Jun 05 05:39:15 2019 +0000 @@ -0,0 +1,701 @@ +/* +Copyright 2017 (c) Analog Devices, Inc. + +All rights reserved. + +Redistribution and use in source and binary forms, with or without +modification, are permitted provided that the following conditions are met: + - Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. + - Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in + the documentation and/or other materials provided with the + distribution. + - Neither the name of Analog Devices, Inc. nor the names of its + contributors may be used to endorse or promote products derived + from this software without specific prior written permission. + - The use of this software may or may not infringe the patent rights + of one or more patent holders. This license does not release you + from the requirement that you obtain separate licenses from these + patent holders to use this software. + - Use of the software either in source or binary form, must be run + on or directly connected to an Analog Devices Inc. component. + +THIS SOFTWARE IS PROVIDED BY ANALOG DEVICES "AS IS" AND ANY EXPRESS OR +IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, NON-INFRINGEMENT, +MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. +IN NO EVENT SHALL ANALOG DEVICES BE LIABLE FOR ANY DIRECT, INDIRECT, +INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT +LIMITED TO, INTELLECTUAL PROPERTY RIGHTS, PROCUREMENT OF SUBSTITUTE GOODS OR +SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, +OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE +OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. +*/ + +/* + ****************************************************************************** + * @file: admw_api.h + * @brief: ADMW Host Library Application Programming Interface (API) + *----------------------------------------------------------------------------- + */ + +#ifndef __ADMW_API_H__ +#define __ADMW_API_H__ + +#include "inc/admw_types.h" +#include "inc/admw_config_types.h" +#include "inc/admw_platform.h" +#include "inc/admw_gpio.h" +#include "inc/admw_spi.h" +#include "inc/admw_log.h" +#include "inc/admw_time.h" + +/*! @defgroup ADMW_Api ADMW Host Library API + * Host library API common to the ADMW product family. + * @{ + */ + +#ifdef __cplusplus +extern "C" { +#endif + +/*! The maximum number of channels supported by this API + * @note Specific ADMW products may implement a lower number of channels */ +#define ADMW_MAX_CHANNELS 16 + +/*! A handle used in all API functions to identify the ADMW device. */ +typedef void* ADMW_DEVICE_HANDLE; + +/*! Supported connection types for communication with the ADMW device. */ +typedef enum { + ADMW_CONNECTION_TYPE_SPI = 1, + /*!< Serial Peripheral Interface (SPI) connection type */ +} ADMW_CONNECTION_TYPE; + +/*! Connection details for communication with a ADMW device instance. */ +typedef struct { + ADMW_CONNECTION_TYPE type; + /*!< Connection type selection */ + ADMW_PLATFORM_SPI_CONFIG spi; + /*!< SPI connection parameters, required if SPI connection type is used */ + ADMW_PLATFORM_GPIO_CONFIG gpio; + /*!< GPIO connection parameters, for device reset and status I/O signals */ + ADMW_PLATFORM_LOG_CONFIG log; + /*!< Log interface connection parameters, for display/routing of log messages */ +} ADMW_CONNECTION; + +/*! Bit masks (flags) for the different device status indicators. */ +typedef enum { + ADMW_DEVICE_STATUS_BUSY = (1 << 0), + /*!< Indicates that a command is currently running on the device */ + ADMW_DEVICE_STATUS_DATAREADY = (1 << 1), + /*!< Indicates the availability of measurement data for retrieval */ + ADMW_DEVICE_STATUS_ERROR = (1 << 2), + /*!< Indicates that an error condition has been detected by the device */ + ADMW_DEVICE_STATUS_ALERT = (1 << 3), + /*!< Indicates that an alert condition has been detected by the device */ + ADMW_DEVICE_STATUS_FIFO_ERROR = (1 << 4), + /*!< Indicates that a FIFO error condition has been detected by the device */ + ADMW_DEVICE_STATUS_CONFIG_ERROR = (1 << 5), + /*!< Indicates that a configuration error condition has been detected by the device */ + ADMW_DEVICE_STATUS_LUT_ERROR = (1 << 6), + /*!< Indicates that a look-up table error condition has been detected by the device */ + ADMW_DEVICE_STATUS_EXT_FLASH_ERROR = (1 << 7), + /*!< Indicates that an external flash memory error condition has been detected by the device */ +} ADMW_DEVICE_STATUS_FLAGS; + +/*! Bit masks (flags) for the different diagnostics status indicators. */ +typedef enum { + ADMW_DIAGNOSTICS_STATUS_CHECKSUM_ERROR = (1 << 0), + /*!< Indicates Error on Internal Checksum Calculations */ + ADMW_DIAGNOSTICS_STATUS_COMMS_ERROR = (1 << 1), + /*!< Indicates Error on Internal Device Communications */ + ADMW_DIAGNOSTICS_STATUS_SUPPLY_MONITOR_ERROR = (1 << 2), + /*!< Indicates Low Voltage on Internal Supply Voltages */ + ADMW_DIAGNOSTICS_STATUS_SUPPLY_CAP_ERROR = (1 << 3), + /*!< Indicates Fault on Internal Supply Regulator Capacitor */ + ADMW_DIAGNOSTICS_STATUS_CONVERSION_ERROR = (1 << 8), + /*!< Indicates Error During Internal ADC Conversions */ + ADMW_DIAGNOSTICS_STATUS_CALIBRATION_ERROR = (1 << 9), + /*!< Indicates Error During Internal Device Calibrations */ +} ADMW_DIAGNOSTICS_STATUS_FLAGS; + +/*! Bit masks (flags) for the different channel alert indicators. */ +typedef enum { + ADMW_CHANNEL_ALERT_TIMEOUT = (1 << 0), + /*!< Indicates timeout condition detected on the channel */ + ADMW_CHANNEL_ALERT_UNDER_RANGE = (1 << 1), + /*!< Indicates raw sample under valid input range, possibly clamped */ + ADMW_CHANNEL_ALERT_OVER_RANGE = (1 << 2), + /*!< Indicates raw sample over valid input range, possibly clamped */ + ADMW_CHANNEL_ALERT_LOW_LIMIT = (1 << 3), + /*!< Indicates measurement result was below configured minimum threshold */ + ADMW_CHANNEL_ALERT_HIGH_LIMIT = (1 << 4), + /*!< Indicates measurement result was above configured maximum threshold */ + ADMW_CHANNEL_ALERT_SENSOR_OPEN = (1 << 5), + /*!< Indicates open circuit or mis-wire condition detected on the channel */ + ADMW_CHANNEL_ALERT_REF_DETECT = (1 << 6), + /*!< Indicates reference-detect error condition detected on the channel */ + ADMW_CHANNEL_ALERT_CONFIG_ERR = (1 << 7), + /*!< Indicates configuration error condition detected on the channel */ + ADMW_CHANNEL_ALERT_LUT_ERR = (1 << 8), + /*!< Indicates look-up table error condition detected on the channel */ + ADMW_CHANNEL_ALERT_SENSOR_NOT_READY = (1 << 9), + /*!< Indicates digital sensor not-ready error condition detected on the channel */ + ADMW_CHANNEL_ALERT_COMP_NOT_READY = (1 << 10), + /*!< Indicates compensation channel not-ready error condition detected on the channel */ + ADMW_CHANNEL_ALERT_LUT_UNDER_RANGE = (1 << 13), + /*!< Indicates raw sample was under the available LUT/equation range */ + ADMW_CHANNEL_ALERT_LUT_OVER_RANGE = (1 << 14), + /*!< Indicates raw sample was over the available LUT/equation range */ +} ADMW_CHANNEL_ALERT_FLAGS; + +/*! Status details retreived from the ADMW device. */ +typedef struct { + ADMW_DEVICE_STATUS_FLAGS deviceStatus; + /*!< General summary status information from the device */ + ADMW_DIAGNOSTICS_STATUS_FLAGS diagnosticsStatus; + /*!< Diagnostic error status information from the device */ + ADMW_CHANNEL_ALERT_FLAGS channelAlerts[ADMW_MAX_CHANNELS]; + /*!< Per-channel alert status information from the device */ + uint32_t errorCode; + /*!< Code identifying the last error signalled by the device */ + uint32_t alertCode; + /*!< Code identifying the last alert signalled by the device */ + uint32_t debugCode; + /*!< Supplementary code related to the last error/alert */ + uint32_t channelAlertCodes[ADMW_MAX_CHANNELS]; + /*!< Per-channel code identifying the last alert signalled for each channel */ +} ADMW_STATUS; + +/*! Data sample details retreived from the ADMW device. */ +typedef struct { + ADMW_DEVICE_STATUS_FLAGS status; + /*!< Device summary status snapshot when the sample was recorded */ + uint32_t channelId; + /*!< The measurement channel from which this sample was obtained */ + int32_t rawValue; + /*!< The raw (unprocessed) value obtained directly from the measurement + * channel, if available + */ + float32_t processedValue; + /*!< The processed value obtained from the measurement channel, as a final + * measurement value, following calibration and linearisation correction, + * and conversion into an appropriate unit of measurement. + */ +} ADMW_DATA_SAMPLE; + +/*! Measurement mode options for the ADMW device. + * @ref admw_StartMeasurement + */ +typedef enum { + ADMW_MEASUREMENT_MODE_HEALTHCHECK = 1, + /*!< In this mode, a special health-check measurement cycle is executed, + * carrying out a single conversion per channel with measurement + * diagnostics enabled, intended for use as a system health check. */ + ADMW_MEASUREMENT_MODE_NORMAL, + /*!< In this mode, normal measurement cycle(s) are executed and data samples + * are returned with raw measurement values included. */ + ADMW_MEASUREMENT_MODE_OMIT_RAW, + /*!< In this mode, normal measurement cycle(s) are executed and data samples + * are returned with raw measurement values omitted for efficiency. */ + ADMW_MEASUREMENT_MODE_FFT, + /*!< In this mode, FFT mode measurement cycle(s) are executed and data + * samples are returned based on FFT-specific configuration parameters. */ +} ADMW_MEASUREMENT_MODE; + +/*! Identifiers for the user configuration slots in persistent memory. */ +typedef enum { + ADMW_FLASH_CONFIG_1, + ADMW_FLASH_CONFIG_2, + ADMW_FLASH_CONFIG_3, + ADMW_FLASH_CONFIG_4, +} ADMW_USER_CONFIG_SLOT; + + +/****************************************************************************** + * ADMW High-Level API function prototypes + *****************************************************************************/ + +/*! + * @brief Open ADMW device handle and set up communication interface. + * + * @param[in] nDeviceIndex Zero-based index number identifying this device + * instance. Note that this will be used to + * retrieve a specific device configuration for + * this device (see @ref admw_SetConfig + * and @ref ADMW_CONFIG) + * @param[in] pConnectionInfo Host-specific connection details (e.g. SPI, GPIO) + * @param[out] phDevice Pointer to return an ADMW device handle + * + * @return Status + * - #ADMW_SUCCESS Call completed successfully. + * - #ADMW_NO_MEM Failed to allocate memory resources. + * - #ADMW_INVALID_DEVICE_NUM Invalid device index specified + * + * @details Configure and initialise the Log interface and the SPI/GPIO + * communication interface to the ADMW module. + */ +ADMW_RESULT admw_Open( + unsigned const nDeviceIndex, + ADMW_CONNECTION * const pConnectionInfo, + ADMW_DEVICE_HANDLE * const phDevice); + +/*! + * @brief Close ADMW device context and free resources. + * + * @param[in] hDevice ADMW device context handle + * + * @return Status + * - #ADMW_SUCCESS Call completed successfully. + */ +ADMW_RESULT admw_Close( + ADMW_DEVICE_HANDLE const hDevice); + +/*! + * @brief Get the current state of the specified GPIO input signal. + * + * @param[in] hDevice ADMW device context handle + * @param[in] ePinId GPIO pin to query + * @param[out] pbAsserted Pointer to return the state of the status signal GPIO pin + * + * @return Status + * - #ADMW_SUCCESS Call completed successfully. + * - #ADMW_INVALID_DEVICE_NUM Invalid GPIO pin specified. + * + * @details Sets *pbAsserted to true if the status signal is asserted, or false + * otherwise. + */ +ADMW_RESULT admw_GetGpioState( + ADMW_DEVICE_HANDLE const hDevice, + ADMW_GPIO_PIN const ePinId, + bool * const pbAsserted); + +/*! + * @brief Register an application-defined callback function for GPIO interrupts + * + * @param[in] hDevice ADMW context handle (@ref admw_Open) + * @param[in] ePinId GPIO pin on which to enable/disable interrupts + * @param[in] callbackFunction Function to be called when an interrupt occurs. + * Specify NULL here to disable interrupts. + * @param[in] pCallbackParam Optional opaque parameter passed to the callback + * + * @return Status + * - #ADMW_SUCCESS Call completed successfully. + * - #ADMW_INVALID_DEVICE_NUM Invalid GPIO pin specified. + */ +ADMW_RESULT admw_RegisterGpioCallback( + ADMW_DEVICE_HANDLE const hDevice, + ADMW_GPIO_PIN const ePinId, + ADMW_GPIO_CALLBACK const callbackFunction, + void * const pCallbackParam); + +/*! + * @brief Trigger a shut down of the device. + * + * @param[in] hDevice ADMW device context handle + * + * @return Status + * - #ADMW_SUCCESS Call completed successfully. + * + * @details Instructs the ADMW device to initiate a shut down, + * typically used to conserve power when the device is not + * in use. The device may be restarted by calling + * @ref admw_Reset(). Note that active configuration + * settings are not preserved during shutdown and must be + * reloaded after the device has become ready again. + * + * @note No other command must be running when this is called. + */ +ADMW_RESULT admw_Shutdown( + ADMW_DEVICE_HANDLE const hDevice); + +/*! + * @brief Reset the ADMW device. + * + * @param[in] hDevice ADMW device context handle + * + * @return Status + * - #ADMW_SUCCESS Call completed successfully. + * + * @details Trigger a hardware-reset of the ADMW device. + * + * @note The device may require several seconds before it is ready for use + * again. @ref admw_GetDeviceReadyState may be used to check if + * the device is ready. + */ +ADMW_RESULT admw_Reset( + ADMW_DEVICE_HANDLE const hDevice); + +/*! + * @brief Check if the device is ready, following power-up or a reset. + * + * @param[in] hDevice ADMW device context handle + * @param[out] pbReady Pointer to return true if the device is ready, or false + * otherwise + * + * @return Status + * - #ADMW_SUCCESS Call completed successfully. + * + * @details This function attempts to read a fixed-value device register via + * the communication interface. + */ +ADMW_RESULT admw_GetDeviceReadyState( + ADMW_DEVICE_HANDLE const hDevice, + bool * const pbReady); + +/*! + * @brief Obtain the product ID from the device. + * + * @param[in] hDevice ADMW device context handle + * @param[out] pProductId Pointer to return the product ID value + * + * @return Status + * - #ADMW_SUCCESS Call completed successfully. + * + * @details Reads the product ID registers on the device and returns the value. + */ +ADMW_RESULT admw_GetProductID( + ADMW_DEVICE_HANDLE const hDevice, + ADMW_PRODUCT_ID * const pProductId); + +/*! + * @brief Write full configuration settings to the device registers. + * + * @param[in] hDevice ADMW device context handle + * @param[out] pConfig Pointer to the configuration data structure + * + * @return Status + * - #ADMW_SUCCESS Call completed successfully. + * + * @details Translates configuration details provided into device-specific + * register settings and updates device configuration registers. + * + * @note Settings are not applied until admw_ApplyConfigUpdates() is called + */ +ADMW_RESULT admw_SetConfig( + ADMW_DEVICE_HANDLE const hDevice, + ADMW_CONFIG * const pConfig); + +/*! + * @brief Apply the configuration settings currently stored in device registers + * + * @param[in] hDevice ADMW device context handle + * + * @return Status + * - #ADMW_SUCCESS Call completed successfully. + * + * @details Instructs the ADMW device to reload and apply configuration + * from the device configuration registers. Changes to configuration + * registers are ignored by the device until this function is called. + * + * @note No other command must be running when this is called. + */ +ADMW_RESULT admw_ApplyConfigUpdates( + ADMW_DEVICE_HANDLE const hDevice); + +/*! + * @brief Store the configuration settings to persistent memory on the device. + * + * @param[in] hDevice ADMW device context handle + * @param[in] eSlotId User configuration slot in persistent memory + * + * @return Status + * - #ADMW_SUCCESS Call completed successfully. + * + * @details Instructs the ADMW device to save the current contents of its + * device configuration registers to non-volatile memory. + * + * @note No other command must be running when this is called. + * @note Do not power down the device while this command is running. + */ +ADMW_RESULT admw_SaveConfig( + ADMW_DEVICE_HANDLE const hDevice, + ADMW_USER_CONFIG_SLOT const eSlotId); + +/*! + * @brief Restore configuration settings from persistent memory on the device. + * + * @param[in] hDevice ADMW device context handle + * @param[in] eSlotId User configuration slot in persistent memory + * + * @return Status + * - #ADMW_SUCCESS Call completed successfully. + * + * @details Instructs the ADMW device to restore the contents of its + * device configuration registers from non-volatile memory. + * + * @note No other command must be running when this is called. + */ +ADMW_RESULT admw_RestoreConfig( + ADMW_DEVICE_HANDLE const hDevice, + ADMW_USER_CONFIG_SLOT const eSlotId); + +/*! + * @brief Erases the external flash memory. + * + * @param[in] hDevice ADMW device context handle + * + * @return Status + * - #ADMW_SUCCESS Call completed successfully. + * + * @details Sends the bulk erase instruction to the external flash + * device. All stored samples are deleted. + * It is a blocking operation and takes tens of seconds to + * complete. + * + * @note No other command must be running when this is called. + */ +ADMW_RESULT admw_EraseExternalFlash( + ADMW_DEVICE_HANDLE const hDevice); + +/*! + * @brief Gets the number of samples stored in the external flash + * memory. + * + * @param[in] hDevice ADMW device context handle + * @param[in] pSampleCount Address of the return value. + * + * @return Status + * - #ADMW_SUCCESS Call completed successfully. + * + * @note No other command must be running when this is called. + */ +ADMW_RESULT admw_GetExternalFlashSampleCount( + ADMW_DEVICE_HANDLE const hDevice, + uint32_t * nSampleCount); + +// DEBUG - TO BE DELETED +ADMW_RESULT admw_SetExternalFlashIndex( + ADMW_DEVICE_HANDLE const hDevice, + uint32_t nStartIndex); + +/*! + * @brief Read measurement samples stored in the the external flash memory. + * + * @param[in] hDevice ADMW device context handle + * @param[out] pSamples Pointer to return a set of requested data + * samples. + * @param[in] nStartIndex Index of first sample to retrieve. + * @param[in] nBytesPerSample The size, in bytes, of each sample. + * @param[in] nRequested Number of requested data samples. + * @param[out] pnReturned Number of valid data samples successfully + * retrieved. + * + * @return Status + * - #ADMW_SUCCESS Call completed successfully. + * + * @details Reads the status registers and extracts the relevant information + * to return to the caller. + * + */ +ADMW_RESULT admw_GetExternalFlashData( + ADMW_DEVICE_HANDLE const hDevice, + ADMW_DATA_SAMPLE * const pSamples, + uint32_t const nIndex, + uint32_t const nRequested, + uint32_t * const pnReturned); + +/*! + * @brief Store the LUT data to persistent memory on the device. + * + * @param[in] hDevice ADMW device context handle + * + * @return Status + * - #ADMW_SUCCESS Call completed successfully. + * + * @details Instructs the ADMW device to save the current contents of its + * LUT data buffer, set using @ref admw_SetLutData, to + * non-volatile memory. + * + * @note No other command must be running when this is called. + * @note Do not power down the device while this command is running. + */ +ADMW_RESULT admw_SaveLutData( + ADMW_DEVICE_HANDLE const hDevice); + +/*! + * @brief Restore LUT data from persistent memory on the device. + * + * @param[in] hDevice ADMW device context handle + * + * @return Status + * - #ADMW_SUCCESS Call completed successfully. + * + * @details Instructs the ADMW device to restore the contents of its + * LUT data, previously stored with @ref admw_SaveLutData, from + * non-volatile memory. + * + * @note No other command must be running when this is called. + */ +ADMW_RESULT admw_RestoreLutData( + ADMW_DEVICE_HANDLE const hDevice); + +/*! + * @brief Start the measurement cycles on the device. + * + * @param[in] hDevice ADMW device context handle + * @param[in] eMeasurementMode Allows a choice of special modes for the + * measurement. See @ref ADMW_MEASUREMENT_MODE + * for further information. + * + * @return Status + * - #ADMW_SUCCESS Call completed successfully. + * + * @details Instructs the ADMW device to start executing measurement cycles + * according to the current applied configuration settings. The + * DATAREADY status signal will be asserted whenever new measurement + * data is published, according to selected settings. + * Measurement cycles may be stopped by calling @ref + * admw_StopMeasurement. + * + * @note No other command must be running when this is called. + */ +ADMW_RESULT admw_StartMeasurement( + ADMW_DEVICE_HANDLE const hDevice, + ADMW_MEASUREMENT_MODE const eMeasurementMode); + +/*! + * @brief Stop the measurement cycles on the device. + * + * @param[in] hDevice ADMW device context handle + * + * @return Status + * - #ADMW_SUCCESS Call completed successfully. + * + * @details Instructs the ADMW device to stop executing measurement cycles. + * The command may be delayed until the current conversion, if any, has + * been completed and published. + * + * @note To be used only if a measurement command is currently running. + */ +ADMW_RESULT admw_StopMeasurement( + ADMW_DEVICE_HANDLE const hDevice); + +/*! + * @brief Run built-in diagnostic checks on the device. + * + * @param[in] hDevice ADMW device context handle + * + * @return Status + * - #ADMW_SUCCESS Call completed successfully. + * + * @details Instructs the ADMW device to execute its built-in diagnostic + * tests, on any enabled measurement channels, according to the current + * applied configuration settings. Device status registers will be + * updated to indicate if any errors were detected by the diagnostics. + * + * @note No other command must be running when this is called. + */ +ADMW_RESULT admw_RunDiagnostics( + ADMW_DEVICE_HANDLE const hDevice); + +/*! + * @brief Run built-in calibration on the device. + * + * @param[in] hDevice ADMW device context handle + * + * @return Status + * - #ADMW_SUCCESS Call completed successfully. + * + * @details Instructs the ADMW device to execute its self-calibration + * routines, on any enabled measurement channels, according to the + * current applied configuration settings. Device status registers + * will be updated to indicate if any errors were detected. + * + * @note No other command must be running when this is called. + */ +ADMW_RESULT admw_RunCalibration( + ADMW_DEVICE_HANDLE const hDevice); + +/*! + * @brief Run built-in digital calibration on the device. + * + * @param[in] hDevice ADMW device context handle + * + * @return Status + * - #ADMW_SUCCESS Call completed successfully. + * + * @details Instructs the ADMW device to execute its calibration + * routines, on any enabled digital channels, according to the + * current applied configuration settings. Device status registers + * will be updated to indicate if any errors were detected. + * + * @note No other command must be running when this is called. + */ +ADMW_RESULT admw_RunDigitalCalibration( + ADMW_DEVICE_HANDLE const hDevice); + +/*! + * @brief Read the current status from the device registers. + * + * @param[in] hDevice ADMW device context handle + * @param[out] pStatus Pointer to return the status summary obtained from the + * device. + * + * @return Status + * - #ADMW_SUCCESS Call completed successfully. + * + * @details Reads the status registers and extracts the relevant information + * to return to the caller. + * + * @note This may be called at any time, assuming the device is ready. + */ +ADMW_RESULT admw_GetStatus( + ADMW_DEVICE_HANDLE const hDevice, + ADMW_STATUS * const pStatus); + +/*! + * @brief Read measurement data samples from the device registers. + * + * @param[in] hDevice ADMW device context handle + * @param[in] eMeasurementMode Must be set to the same value used for @ref + * admw_StartMeasurement(). + * @param[out] pSamples Pointer to return a set of requested data samples. + * @param[in] nBytesPerSample The size, in bytes, of each sample. + * @param[in] nRequested Number of requested data samples. + * @param[out] pnReturned Number of valid data samples successfully retrieved. + * + * @return Status + * - #ADMW_SUCCESS Call completed successfully. + * + * @details Reads the status registers and extracts the relevant information + * to return to the caller. + * + * @note This is intended to be called only when the DATAREADY status signal + * is asserted. + */ +ADMW_RESULT admw_GetData( + ADMW_DEVICE_HANDLE const hDevice, + ADMW_MEASUREMENT_MODE const eMeasurementMode, + ADMW_DATA_SAMPLE * const pSamples, + uint8_t const nBytesPerSample, + uint32_t const nRequested, + uint32_t * const pnReturned); + +/*! + * @brief Check if a command is currently running on the device. + * + * @param[in] hDevice ADMW device context handle + * @param[out] pbCommandRunning Pointer to return the command running status + * + * @return Status + * - #ADMW_SUCCESS Call completed successfully. + * + * @details Reads the device status register to check if a command is running. + */ +ADMW_RESULT admw_GetCommandRunningState( + ADMW_DEVICE_HANDLE hDevice, + bool *pbCommandRunning); + +#ifdef __cplusplus +} +#endif + +/*! + * @} + */ + +#endif /* __ADMW_API_H__ */ +