Analog Comparators#
Introduction#
The Analog Comparator is a peripheral that compares two analog input voltages and triggers an interrupt when non-inverting is higher than inverting. It typically has two input pins for comparing analog voltages.
Analog comparators are often used in:
- Battery Monitoring: Detecting low battery conditions. 
- Threshold Detection: Triggering events when signals exceed predefined thresholds. 
- Sensor Interface: Comparing sensor outputs to reference voltages. 
- Wake-up Signals: Bringing the micro-controller out of low-power modes. 
Key Features:
- Both comparators can take inputs from GPIOs. 
- Each comparator has nine different input sources, two of which are external GPIO pin inputs. 
- Multiple comparison scenarios: - Compare external pin inputs. 
- Compare external pin input to internal voltages. 
- Compare internal voltages. 
 
- The inputs of the two comparators can be independently programmed. 
- Shared resources: The reference buffer, scaler, and resistor bank are shared between the comparators and can only be enabled when at least one comparator is active. 
Configuration#
The Analog Comparator can be configured using several parameters, including:
- Non-Inverting Input Source: Select the positive input for the comparator. 
- Inverting Input Source: Select the negative input for the comparator. 
- Hysteresis: Enable or disable hysteresis to prevent noise from causing rapid toggling of the output. 
- Filter Enable/Disable: Control noise filtering on the input signal. 
These configurations are encapsulated in the sl_analog_comparator_config_t structure and initialized using the sl_si91x_analog_comparator_set_configurations API.
For more details on configuration parameters, see the respective peripheral example readme document.
Usage#
After defining the Analog Comparator configuration structures and passing an instance of sl_analog_comparator_config_t, the following functions can be used to initiate and configure the ACMP module. The typical flow for implementation is as follows:
- Initialize the ACMP driver: sl_si91x_analog_comparator_init 
- Set comparator configurations: sl_si91x_analog_comparator_set_configurations 
- Set reference scaler output (if using a reference scaler): sl_si91x_analog_comparator_set_reference_scaler_output 
- Set resistor bank threshold (if using a resistor bank): sl_si91x_analog_comparator_set_resistor_bank_threshold 
- Register a callback for comparator events: sl_si91x_analog_comparator_register_callback 
- Deinitialize the ACMP driver: sl_si91x_analog_comparator_deinit 
Modules#
Enumerations#
Enumeration to represent the analog comparator number.
Enumeration to represent the types of analog comparator inputs.
Enumeration to represent the hysteresis control values.
Enumeration to represent BOD threshold values for resistor bank output.
Enumeration to represent scale factor values for reference scaler output.
Typedefs#
Typedef for the function pointer of the callback function.
Functions#
To initialize the Analog Comparator and configure the necessary clocks and reference voltage.
To configure the analog comparator settings and initialize the selected comparator.
To register the Analog Comparator interrupt callback and enable its interrupts as per comparator number.
To unregister the Analog Comparator interrupt callback and disable its interrupts as per comparator number.
To configure the Analog Comparator resistor bank threshold.
To configure the reference scaler for the Analog Comparator and set the scale factor.
To de-initialize the Analog Comparator.
Macros#
External GPIO input 0.
External GPIO input 1.
Input from DAC output.
Input from reference buffer output.
Input from reference scaler output.
Input from resistor bank output.
Input from OPAMP1 output.
Input from OPAMP2 output.
Input from OPAMP3 output.
Enumeration Documentation#
sl_analog_comparator_number_t#
sl_analog_comparator_number_t
Enumeration to represent the analog comparator number.
| Enumerator | |
|---|---|
| SL_COMPARATOR_1 | Analog comparator 1. | 
| SL_COMPARATOR_2 | Analog comparator 2. | 
| SL_COMPARATOR_LAST | Last member of enum for validation. | 
sl_analog_comparator_inputs_t#
sl_analog_comparator_inputs_t
Enumeration to represent the types of analog comparator inputs.
| Enumerator | |
|---|---|
| SL_COMPARATOR_GPIO_INPUT_0 | Select GPIO input for comparator non-inverting input. | 
| SL_COMPARATOR_GPIO_INPUT_1 | Select GPIO input for comparator non-inverting input. | 
| SL_COMPARATOR_DAC_OUTPUT | Selects DAC output as comparator input. | 
| SL_COMPARATOR_REFERENCE_BUFFER_OUTPUT | Selects reference buffer output as comparator input. | 
| SL_COMPARATOR_REFERENCE_SCALER_OUTPUT | Selects reference scaler output as comparator input. | 
| SL_COMPARATOR_RESISTOR_BANK_OUTPUT | Selects resistor bank output as comparator input. | 
| SL_COMPARATOR_OPAMP1_OUTPUT | Selects OPAMP1 output as comparator input. | 
| SL_COMPARATOR_OPAMP2_OUTPUT | Selects OPAMP2 output as comparator input. | 
| SL_COMPARATOR_OPAMP3_OUTPUT | Selects OPAMP3 output as comparator input. | 
| SL_COMPARATOR_INPUT_LAST | Last member of enum for validation. | 
sl_analog_comparator_hystersis_values_t#
sl_analog_comparator_hystersis_values_t
Enumeration to represent the hysteresis control values.
| Enumerator | |
|---|---|
| SL_COMPARATOR_HYSTERSIS_VALUE_0 | Hysteresis control value 0. | 
| SL_COMPARATOR_HYSTERSIS_VALUE_1 | Hysteresis control value 1. | 
| SL_COMPARATOR_HYSTERSIS_VALUE_2 | Hysteresis control value 2. | 
| SL_COMPARATOR_HYSTERSIS_VALUE_3 | Hysteresis control value 3. | 
| SL_COMPARATOR_HYSTERSIS_VALUE_LAST | Last member of enum for validation. | 
sl_analog_comparator_threshold_values_t#
sl_analog_comparator_threshold_values_t
Enumeration to represent BOD threshold values for resistor bank output.
Note
- Values of the enumerator are calculated using VBAT = 3.5066 V and these values vary from board to board. 
| Enumerator | |
|---|---|
| SL_COMPARATOR_THRESHOLD_VALUE_FOR_2_27_VOLT | Threshold value to get 2.27 V as resistor bank output voltage. | 
| SL_COMPARATOR_THRESHOLD_VALUE_FOR_2_21_VOLT | Threshold value to get 2.21 V as resistor bank output voltage. | 
| SL_COMPARATOR_THRESHOLD_VALUE_FOR_2_15_VOLT | Threshold value to get 2.1 5V as resistor bank output voltage. | 
| SL_COMPARATOR_THRESHOLD_VALUE_FOR_2_10_VOLT | Threshold value to get 2.10 V as resistor bank output voltage. | 
| SL_COMPARATOR_THRESHOLD_VALUE_FOR_2_05_VOLT | Threshold value to get 2.05 V as resistor bank output voltage. | 
| SL_COMPARATOR_THRESHOLD_VALUE_FOR_2_00_VOLT | Threshold value to get 2.00 V as resistor bank output voltage. | 
| SL_COMPARATOR_THRESHOLD_VALUE_FOR_1_95_VOLT | Threshold value to get 1.95 V as resistor bank output voltage. | 
| SL_COMPARATOR_THRESHOLD_VALUE_FOR_1_91_VOLT | Threshold value to get 1.91 V as resistor bank output voltage. | 
| SL_COMPARATOR_THRESHOLD_VALUE_FOR_1_86_VOLT | Threshold value to get 1.86 V as resistor bank output voltage. | 
| SL_COMPARATOR_THRESHOLD_VALUE_FOR_1_82_VOLT | Threshold value to get 1.82 V as resistor bank output voltage. | 
| SL_COMPARATOR_THRESHOLD_VALUE_FOR_1_79_VOLT | Threshold value to get 1.79 V as resistor bank output voltage. | 
| SL_COMPARATOR_THRESHOLD_VALUE_FOR_1_75_VOLT | Threshold value to get 1.75 V as resistor bank output voltage. | 
| SL_COMPARATOR_THRESHOLD_VALUE_FOR_1_71_VOLT | Threshold value to get 1.71 V as resistor bank output voltage. | 
| SL_COMPARATOR_THRESHOLD_VALUE_FOR_1_68_VOLT | Threshold value to get 1.68 V as resistor bank output voltage. | 
| SL_COMPARATOR_THRESHOLD_VALUE_FOR_1_64_VOLT | Threshold value to get 1.64 V as resistor bank output voltage. | 
| SL_COMPARATOR_THRESHOLD_VALUE_FOR_1_61_VOLT | Threshold value to get 1.61 V as resistor bank output voltage. | 
| SL_COMPARATOR_THRESHOLD_VALUE_FOR_1_58_VOLT | Threshold value to get 1.58 V as resistor bank output voltage. | 
| SL_COMPARATOR_THRESHOLD_VALUE_FOR_1_55_VOLT | Threshold value to get 1.55 V as resistor bank output voltage. | 
| SL_COMPARATOR_THRESHOLD_VALUE_FOR_1_53_VOLT | Threshold value to get 1.53 V as resistor bank output voltage. | 
| SL_COMPARATOR_THRESHOLD_VALUE_FOR_1_50_VOLT | Threshold value to get 1.50 V as resistor bank output voltage. | 
| SL_COMPARATOR_THRESHOLD_VALUE_FOR_1_47_VOLT | Threshold value to get 1.47 V as resistor bank output voltage. | 
| SL_COMPARATOR_THRESHOLD_VALUE_FOR_1_45_VOLT | Threshold value to get 1.45 V as resistor bank output voltage. | 
| SL_COMPARATOR_THRESHOLD_VALUE_FOR_1_42_VOLT | Threshold value to get 1.42 V as resistor bank output voltage. | 
| SL_COMPARATOR_THRESHOLD_VALUE_FOR_1_40_VOLT | Threshold value to get 1.40 V as resistor bank output voltage. | 
| SL_COMPARATOR_THRESHOLD_VALUE_FOR_1_38_VOLT | Threshold value to get 1.38 V as resistor bank output voltage. | 
| SL_COMPARATOR_THRESHOLD_VALUE_FOR_1_35_VOLT | Threshold value to get 1.35 V as resistor bank output voltage. | 
| SL_COMPARATOR_THRESHOLD_VALUE_FOR_1_33_VOLT | Threshold value to get 1.33 V as resistor bank output voltage. | 
| SL_COMPARATOR_THRESHOLD_VALUE_FOR_1_31_VOLT | Threshold value to get 1.31 V as resistor bank output voltage. | 
| SL_COMPARATOR_THRESHOLD_VALUE_FOR_1_29_VOLT | Threshold value to get 1.29 V as resistor bank output voltage. | 
| SL_COMPARATOR_THRESHOLD_VALUE_FOR_1_27_VOLT | Threshold value to get 1.27 V as resistor bank output voltage. | 
| SL_COMPARATOR_THRESHOLD_VALUE_FOR_1_25_VOLT | Threshold value to get 1.25 V as resistor bank output voltage. | 
| SL_COMPARATOR_THRESHOLD_VALUE_LAST | Last member of enum for validation. | 
sl_analog_comparator_scale_factor_values_t#
sl_analog_comparator_scale_factor_values_t
Enumeration to represent scale factor values for reference scaler output.
| Enumerator | |
|---|---|
| SL_COMPARATOR_SCALE_FACTOR_VALUE_FOR_0_1_VOLT | Scale factor value to get 0.1 V as reference scaler output voltage. | 
| SL_COMPARATOR_SCALE_FACTOR_VALUE_FOR_0_2_VOLT | Scale factor value to get 0.2 V as reference scaler output voltage. | 
| SL_COMPARATOR_SCALE_FACTOR_VALUE_FOR_0_3_VOLT | Scale factor value to get 0.3 V as reference scaler output voltage. | 
| SL_COMPARATOR_SCALE_FACTOR_VALUE_FOR_0_4_VOLT | Scale factor value to get 0.4 V as reference scaler output voltage. | 
| SL_COMPARATOR_SCALE_FACTOR_VALUE_FOR_0_5_VOLT | Scale factor value to get 0.5 V as reference scaler output voltage. | 
| SL_COMPARATOR_SCALE_FACTOR_VALUE_FOR_0_6_VOLT | Scale factor value to get 0.6 V as reference scaler output voltage. | 
| SL_COMPARATOR_SCALE_FACTOR_VALUE_FOR_0_7_VOLT | Scale factor value to get 0.7 V as reference scaler output voltage. | 
| SL_COMPARATOR_SCALE_FACTOR_VALUE_FOR_0_8_VOLT | Scale factor value to get 0.8 V as reference scaler output voltage. | 
| SL_COMPARATOR_SCALE_FACTOR_VALUE_FOR_0_9_VOLT | Scale factor value to get 0.9 V as reference scaler output voltage. | 
| SL_COMPARATOR_SCALE_FACTOR_VALUE_FOR_1_VOLT | Scale factor value to get 1 V as reference scaler output voltage. | 
| SL_COMPARATOR_SCALE_FACTOR_VALUE_FOR_1_1_VOLT | Scale factor value to get 1.1 V as reference scaler output voltage. | 
| SL_COMPARATOR_SCALE_FACTOR_VALUE_LAST | Last member of enum for validation. | 
Typedef Documentation#
sl_analog_comparator_callback_t#
typedef void(* sl_analog_comparator_callback_t) (void) )(void)
Typedef for the function pointer of the callback function.
Function Documentation#
sl_si91x_analog_comparator_init#
void sl_si91x_analog_comparator_init (void )
To initialize the Analog Comparator and configure the necessary clocks and reference voltage.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| void | N/A | 
This API enables the system core clock and auxiliary clock with a MHz RC clock. It also configures the reference LDO voltage to 3.3 V.
Note
- This function must be called before using any other analog comparator functions. 
- The system core clock must be properly configured. 
sl_si91x_analog_comparator_set_configurations#
sl_status_t sl_si91x_analog_comparator_set_configurations (sl_analog_comparator_config_t * comparator_config_ptr)
To configure the analog comparator settings and initialize the selected comparator.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| sl_analog_comparator_config_t * | [in] | comparator_config_ptr | Pointer to analog comparator configuration structure sl_analog_comparator_config_t | 
This API configures the analog comparator by selecting the comparator number, non-inverting and inverting inputs, enabling or disabling hysteresis, and enabling or disabling the filter for comparator outputs. It also configures the input pins.
- Pre-condition: 
Returns
- sl_status_t Status code indicating the result: - SL_STATUS_OK - Success, analog comparator parameters configured properly. 
- SL_STATUS_INVALID_PARAMETER - Analog comparator configuration structure member has an invalid value. 
 
For more information on the status documentation, see SL STATUS DOCUMENTATION.
sl_si91x_analog_comparator_register_callback#
sl_status_t sl_si91x_analog_comparator_register_callback (sl_analog_comparator_number_t comparator_number, sl_analog_comparator_callback_t on_comparator_callback)
To register the Analog Comparator interrupt callback and enable its interrupts as per comparator number.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| sl_analog_comparator_number_t | [in] | comparator_number | For comparator number, see sl_analog_comparator_number_t for possible values. | 
| sl_analog_comparator_callback_t | [in] | on_comparator_callback | Callback function pointer sl_analog_comparator_callback_t, to be invoked when a comparator interrupt occurs. | 
This API registers a callback function to be invoked when a comparator interrupt occurs and enables the interrupts for the specified comparator number.
- Pre-conditions: - sl_si91x_analog_comparator_unregister_callback(), if already registered for any interrupt 
 
Returns
- sl_status_t Status code indicating the result: - SL_STATUS_OK - Successfully registered comparator interrupt callback. 
- SL_STATUS_BUSY - The callback is already registered. Unregister the existing callback before registering a new one. 
- SL_STATUS_INVALID_PARAMETER - sl_analog_comparator_callback_t comparator_number parameter has an invalid value. 
- SL_STATUS_NULL_POINTER - sl_analog_comparator_callback_t on_comparator_callback parameter is a null pointer. 
 
For more information on the status documentation, see SL STATUS DOCUMENTATION.
sl_si91x_analog_comparator_unregister_callback#
sl_status_t sl_si91x_analog_comparator_unregister_callback (sl_analog_comparator_number_t comp_number)
To unregister the Analog Comparator interrupt callback and disable its interrupts as per comparator number.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| sl_analog_comparator_number_t | [in] | comp_number | For comparator number, see sl_analog_comparator_number_t for possible values. | 
This API disables the interrupts for the specified comparator number and unregisters the callback function.
- Pre-conditions: 
Returns
- sl_status_t Status code indicating the result: - SL_STATUS_OK - Successfully unregistered comparator interrupt callback. 
- SL_STATUS_INVALID_PARAMETER - comparator_number parameter has an invalid value. 
 
For more information on the status documentation, see SL STATUS DOCUMENTATION.
sl_si91x_analog_comparator_set_resistor_bank_threshold#
sl_status_t sl_si91x_analog_comparator_set_resistor_bank_threshold (sl_analog_comparator_threshold_values_t threshold_value)
To configure the Analog Comparator resistor bank threshold.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| sl_analog_comparator_threshold_values_t | [in] | threshold_value | For comparator resistor bank, see sl_analog_comparator_threshold_values_t for possible values. | 
This API configures the resistor bank output voltage based on the specified threshold value. Use this input when one of the comparator inputs is the resistor bank output.
- Pre-conditions: 
Returns
- sl_status_t Status code indicating the result: - SL_STATUS_OK - Successfully configured the resistor bank threshold. 
- SL_STATUS_INVALID_PARAMETER - threshold_value parameter has an invalid value. 
 
For more information on status codes, see SL STATUS DOCUMENTATION.
sl_si91x_analog_comparator_set_reference_scaler_output#
sl_status_t sl_si91x_analog_comparator_set_reference_scaler_output (sl_analog_comparator_scale_factor_values_t scale_factor_value)
To configure the reference scaler for the Analog Comparator and set the scale factor.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| sl_analog_comparator_scale_factor_values_t | [in] | scale_factor_value | For comparator's reference scale, see sl_analog_comparator_scale_factor_values_t for possible values. | 
This API sets the scale factor for the analog comparator module's reference scaler. As per this scale factor, the reference scaler output voltage will be set. Use this input when one of the comparator inputs is the reference scaler output.
- Pre-conditions: 
Returns
- sl_status_t Status code indicating the result: - SL_STATUS_OK - Successfully configured the reference scaler output. For more information on the status documentation, see SL STATUS DOCUMENTATION. 
- SL_STATUS_INVALID_PARAMETER - scale_factor_value parameter has an invalid value. For more information on the status documentation, see SL STATUS DOCUMENTATION. 
 
sl_si91x_analog_comparator_deinit#
void sl_si91x_analog_comparator_deinit (void )
To de-initialize the Analog Comparator.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| void | N/A | 
This API de-initializes the analog comparator by disabling the peripheral clock & comparator interrupts.
- Pre-conditions: