

# Scanning Comparator (ScanComp)

1.10

#### **Features**

- Scan up to 64 single ended or differential channels automatically Note The number of input and output channels will be limited by the hardware available in the device being used.
- Up to 64 outputs routable to digital logic blocks or pins
- Multiple comparison modes



## **General Description**

The Scanning Comparator (ScanComp) component provides a hardware solution to compare up to 64 pairs of analog input voltages signals using just one hardware comparator. The sampled comparator outputs can be enabled for connection in digital hardware. A reference or external voltage can be connected to each input.

#### When to Use a Scanning Comparator

The Scanning Comparator component can provide a comparison of up to 64 analog signals. Although an ADC can be used with software to compare multiple voltage levels, applications requiring fast response or little software intervention are good candidates for this scanning comparator. Some example applications include power supplies, or simple translation from an analog level to a digital signal. This component is useful when more signals must be compared than the number of comparators present in the device.

## Input/Output Connections

This section describes the various input and output connections for the Scanning Comparator. An asterisk (\*) in the list of I/Os states that the I/O may be hidden on the symbol under the conditions listed in the description of that I/O.

### clock - Digital Input\*

The Clock for multiplexing between comparator inputs. Does not exist when the internal clock configuration is used.

### vplus[n] - Analog

Differential pair voltage positive input, usually the signal being compared.

### vminus[n] - Analog\*

Differential pair voltage negative input, usually used as a reference. Does not exist when all inputs have a common negative reference, or when the VDAC is used.

### vminus - Analog\*

Voltage input used as a negative reference for all of the positive inputs. Does not exist when all inputs have independent references, or when the VDAC is used.

#### interrupt - Digital Output

ORed result of all channels interrupts.

### eos - Digital Output

End of scan.

### cmpout[n] - Digital Output\*

Individual comparator outputs for each input.

**Note:** These may be disabled in the customizer.



## **Component Parameters**

Drag a Scanning Comparator onto your design and double click it to open the Configure dialog. This dialog has the following tabs with different parameters.

#### **General Tab**



#### Clock source

This parameter selects a sequencing clock implementation: internal or external. Default setting is internal.

#### Scan Rate

This parameter sets a scan rate in cycles per second when the clock source is internal. This will affect or be affected by the clock frequency parameter. Not available if the clock source is external.

The valid range for the scan rate parameter depends on the range of the Clock Frequency parameter and on the number of channels.



#### **Clock Frequency**

This parameter sets a clock frequency in kHz when the clock source is internal. This will affect or be affected by the scan rate parameter. Frequency selection is not available if the clock source is external. The actual internal clock frequency can be observed in the Design-Wide Resources Clock Editor as "ScanComp Clock int".

| Negative Input Options               | Range of the clock frequency parameter (kHz) |
|--------------------------------------|----------------------------------------------|
| Unique                               | 1–10000. Default is 1.                       |
| Common (default)                     | 1–10000. Default is 1.                       |
| Internal VDAC. VDAC range: 0–1.020 V | 1–2000. Default is 1.                        |
| Internal VDAC. VDAC range: 0–4.080 V | 1–500. Default is 1.                         |

#### **Hardware Outputs Enabled**

This check box enables the latched outputs of the component. Default setting is disabled.

#### **Negative Input**

This parameter selects the negative input mode of the component.

| <b>Negative Input Options</b> | Description                                                                                                                                    |
|-------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| Unique                        | Each channel has its own negative analog input that is multiplexed.                                                                            |
| Common (default)              | All channels use the same negative analog input.                                                                                               |
| Internal VDAC                 | All channels use for their negative analog input the output from a VDAC that is configured by the component. Not available for PSoC 4 devices. |

#### **VDAC Configuration - Range**

This parameter selects one of the two voltage ranges for the internal VDAC. Not applicable if the Negative Input parameter is set to Unique or Common.

| Range                 | Lowest Value | Highest Value | Step Size | Output Equation                          |
|-----------------------|--------------|---------------|-----------|------------------------------------------|
| 0- 1.020 V            | 0.0 mV       | 1.020 V       | 4 mV      | V <sub>OUT</sub> = (value/256) × 1.024 V |
| 0 – 4.080 V (default) | 0.0 mV       | 4.080 V       | 16 mV     | V <sub>OUT</sub> = (value/256) × 4.096 V |



Page 4 of 19 Document Number: 001-95018 Rev. \*\*

#### **VDAC Configuration - Voltage**

This parameter selects the output voltage mode of the internal VDAC. Not applicable if the Negative Input parameter is set to Unique or Common.

| Voltage         | Description                                                                                   |
|-----------------|-----------------------------------------------------------------------------------------------|
| Fixed (default) | A fixed initial value is written to the DAC. It may be changed at run-time using an API call. |
| Per Channel     | Each channel has its own DAC output voltage that is configured in the Channels tab.           |

#### **Channels Tab**



#### Sequenced channels

This parameter selects up to 64 channels. The number of input and output channels will be limited by the hardware available in the device being used. If more channels are used than the device can support, the project will fail to build. Default setting is 4.

#### Interrupt mode

This parameter selects the interrupt detect mode for each channel.

| Interrupt mode | Description                                                                            |
|----------------|----------------------------------------------------------------------------------------|
| Rising Edge    | Interrupt is generated when a rising edge on the output is detected.                   |
| Falling Edge   | Interrupt is generated when a falling edge on the output is detected.                  |
| Both Edges     | Interrupt is generated when either (rising or falling) edge on the output is detected. |



| Interrupt mode | Description                                     |
|----------------|-------------------------------------------------|
| Disable        | Interrupt is disabled.                          |
| Level(default) | Interrupt is generated when the output is high. |

#### **DAC Voltage**

This parameter sets the initial voltage value for each channel in mV. Not applicable if the output voltage mode of the internal VDAC is set to Fixed. Default setting is ½ of the selected DAC range (500 mV or 2000 mV).

## **Application Programming Interface**

Application Programming Interface (API) routines allow you to configure the component using software. The following table lists and describes the interface to each function. The subsequent sections cover each function in more detail.

By default, PSoC Creator assigns the instance name "ScanComp\_1" to the first instance of a component in a given design. You can rename it to any unique value that follows the syntactic rules for identifiers. The instance name becomes the prefix of every global function name, variable, and constant symbol. For readability, the instance name used in the following table is "ScanComp."

#### **Functions**

| Function                        | Description                                                                                   |
|---------------------------------|-----------------------------------------------------------------------------------------------|
| ScanComp_Start()                | Performs all of the required initialization for the component and enables power to the block. |
| ScanComp_Init()                 | Initializes or restores the component according to the customizer settings.                   |
| ScanComp_Enable()               | Activates the hardware and begins component operation.                                        |
| ScanComp_Stop()                 | Turns off the Scanning Comparator.                                                            |
| ScanComp_SetSpeed()             | Sets the drive power and speed.                                                               |
| ScanComp_SetDACRange()          | Sets the DAC to a new range.                                                                  |
| ScanComp_GetDACRange()          | Gets the DAC range setting                                                                    |
| ScanComp_SetDACVoltage()        | Sets the DAC output to a new voltage.                                                         |
| ScanComp_GetDACVoltage()        | Gets the current DAC output voltage setting                                                   |
| ScanComp_SetChannelDACVoltage() | Sets the DAC output for a specific channel to a new voltage.                                  |
| ScanComp_GetChannelDACVoltage() | Gets the DAC output voltage for a specific channel.                                           |
| ScanComp_GetCompare()           | Gets the current comparison result for the selected channel.                                  |



Page 6 of 19 Document Number: 001-95018 Rev. \*\*

| ScanComp_GetInterruptSource()       | Gets the pending interrupt requests from the selected block. Even masked interrupts are returned  |
|-------------------------------------|---------------------------------------------------------------------------------------------------|
| ScanComp_GetInterruptSourceMasked() | Gets the pending interrupt requests from the selected block. Masked interrupts are not returned.  |
| ScanComp_GetInterruptMask()         | Gets the current interrupt mask from the selected block.                                          |
| ScanComp_SetInterruptMask()         | Sets the interrupt masks for the selected block.                                                  |
| ScanComp_Sleep()                    | This is the preferred API to prepare the component for low power mode operation.                  |
| ScanComp_Wakeup()                   | This is the preferred API to restore the component to the state when ScanComp_Sleep() was called. |

#### **Global Variables**

| Function         | Description                                                                                                                                                                                                                                                                                                                                                             |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ScanComp_initVar | The ScanComp_initVar variable is used to indicate initial configuration of this component. This variable is pre-pended with the component name. The variable is initialized to zero and set to 1 the first time ScanComp_Start() is called. This allows for component initialization without re-initialization in all subsequent calls to the ScanComp_Start() routine. |
|                  | If re-initialization of the component is required the ScanComp_Stop() routine should be called followed by the ScanComp_Init() and ScanComp_Enable().                                                                                                                                                                                                                   |

## void ScanComp\_Start(void)

**Description:** Performs all of the required initialization for the component and enables power to the block.

The first time the routine is executed, the component is initialized to the configuration from the customizer. Power/speed is set based on the configured sample rate and the comparator response time specs, or if an external clock is used, it is set to the maximum. When called to restart the comparator following a ScanComp\_Stop() call, the current component parameter

settings are retained.

Parameters: None
Return Value: None
Side Effects: None



### void ScanComp\_Init(void)

**Description:** Initializes or restores the component according to the customizer settings. It is not necessary

to call ScanComp\_Init() because the ScanComp\_Start() API calls this function and is the

preferred method to begin component operation.

Parameters: None
Return Value: None
Side Effects: None

### void ScanComp\_Enable(void)

**Description:** Activates the hardware and begins component operation. It is not necessary to call

ScanComp\_Enable() because the ScanComp\_Start() API calls this function, which is the

preferred method to begin component operation.

Parameters: None
Return Value: None
Side Effects: None

### void ScanComp\_Stop(void)

**Description:** Turns off the Scanning Comparator by turning off the comparator itself and halting the

muxing of inputs, and turning off the DAC if it is used.

Parameters: NoneReturn Value: NoneSide Effects: None



### void ScanComp\_SetSpeed(uint8 speed)

**Description:** Sets the drive power and speed to one of three settings. Power/speed is set by

ScanComp Start() based on the configured sample rate and the comparator response time

specs, or if an external clock is used, it is set to the maximum.

Parameters: uint8 speed: Enumerated speed mode value

| Speed Setting      | Notes                        |
|--------------------|------------------------------|
| ScanComp_SLOWSPEED | Slow speed / Ultra low power |
| ScanComp_MEDSPEED  | Medium speed / Medium power  |
| ScanComp_HIGHSPEED | High speed / High power      |

Return Value: None
Side Effects: None

### void ScanComp\_SetDACRange(uint8 DACRange)

**Description:** Sets the DAC to a new range. Used only when the Internal DAC is selected.

Parameters: uint8 DACRange – new range to be written to the DAC

| Range                      | Notes                       |
|----------------------------|-----------------------------|
| ScanComp_INTERNAL_RANGE_1V | Full-scale range of 1.020 V |
| ScanComp_INTERNAL_RANGE_4V | Full-scale range of 4.080 V |

Return Value: None Side Effects: None

## uint8 ScanComp\_GetDACRange(void)

**Description:** Gets the DAC range setting. Used only when the Internal DAC is selected.

Parameters: None

Return Value: uint8: Present DAC range.

| Range                      | Notes                       |
|----------------------------|-----------------------------|
| ScanComp_INTERNAL_RANGE_1V | Full-scale range of 1.020 V |
| ScanComp_INTERNAL_RANGE_4V | Full-scale range of 4.080 V |

Side Effects: None



#### void ScanComp\_SetDACVoltage(uint8 DACVoltage)

**Description:** Sets the DAC output to a new voltage. Used only when the Internal DAC is selected.

**Parameters:** uint8 DACVoltage – voltage to be written to the DAC, in units depending on the selected

range (4 or 16 mV per bit in 1 or 4V range, respectively)

Return Value: None
Side Effects: None

#### uint8 ScanComp GetDACVoltage(void)

**Description:** Gets the current DAC output voltage setting. Used only when the Internal DAC is selected.

Parameters: None

Return Value: uint8: Voltage the DAC is configured for, in units depending on the selected range (4 or 16

mV per bit in 1 or 4V range, respectively)

Side Effects: None

### void ScanComp SetChannelDACVoltage(uint8 channel, uint8 DACVoltage)

**Description:** Sets the DAC output for a specific channel to a new voltage. Used only when the Internal

DAC is selected and voltage is "Per channel".

**Parameters:** uint8 channel – specifies the channel whose DAC voltage should be changed.

uint8 DACVoltage - voltage to be written to the DAC, in units depending on the selected

range (4 or 16 mV per bit in 1 or 4V range, respectively)

Return Value: None
Side Effects: None

### uint8 ScanComp\_GetChannelDACVoltage(uint8 channel)

**Description:** Gets the DAC output voltage for a specific channel. Used only when the Internal DAC is

selected and voltage is "Per channel".

**Parameters:** uint8 channel – specifies the channel whose DAC voltage should be returned.

Return Value: uint8: Voltage the DAC is configured for, for the given channel, in units depending on the

selected range (4 or 16 mV per bit in 1 or 4V range, respectively).

Side Effects: None



#### uint8 ScanComp\_GetCompare(uint8 channel)

**Description:** Gets the current comparison result for the selected channel.

**Parameters:** uint8 channel – specifies the channel whose comparison result should be returned.

Return Value: uint8: Comparison result of the selected channel. Returns a non-zero value when the input is

greater than the reference value. Otherwise, the return value is zero.

Side Effects: None

#### uint8 ScanComp GetInterruptSource(uint8 inputBlock)

**Description:** Gets the pending interrupt requests from the selected block. This function can determine

which of the channels generated an interrupt. Even masked interrupts are returned. This

function clears the interrupt status for that input block.

Parameters: uint8 inputBlock – specifies the "block" of 8 or less channels whose interrupt requests should

be returned.

Return Value: uint8: Bit field of interrupt sources from the selected block of 8 or less inputs. Each input has

a mask value: ScanComp\_INTR\_MASK.

Side Effects: None

#### uint8 ScanComp\_GetInterruptSourceMasked(uint8 inputBlock)

**Description:** Gets the pending interrupt requests from the selected block. This function can determine

which of the channels generated an interrupt. Masked interrupts are not returned. This

function clears the interrupt status.

Parameters: uint8 inputBlock – specifies the "block" of 8 or less channels whose interrupt requests should

be returned.

Return Value: uint8: The interrupt source bit-fields for the selected block of 8 or less inputs. Each input has

a mask value: ScanComp\_INTR\_MASK.

Side Effects: None

### uint8 ScanComp\_GetInterruptMask(uint8 inputBlock)

**Description:** Gets the current interrupt mask from the selected block. This function can determine which of

the channels' interrupts are currently masked.

Parameters: uint8 inputBlock - specifies the "block" of 8 or less channels whose interrupt masks should

be returned...

Return Value: uint8: The interrupt mask for the given block of channels. A '1' indicates that the interrupt is

enabled, a '0' indicates that it is masked off. Each input has a mask value:

ScanComp\_INTR\_MASK.

Side Effects: None



#### void ScanComp\_SetInterruptMask(uint8 inputBlock, uint8 mask)

**Description:** Sets the interrupt masks for the set block of 8 or less channels.

**Parameters:** uint8 inputBlock – specifies the "block" of 8 or less channels whose interrupt masks will be

written.

uint8 mask - interrupt mask value for the specified block of 8 or less channels. A '1' indicates

that the interrupt is enabled, a '0' indicates that it is masked off.

Return Value: None
Side Effects: None

#### void ScanComp\_Sleep(void)

**Description:** This is the preferred API to prepare the component for low power mode operation. The

scanning comparator cannot operate in sleep mode in PSoC 3/5LP or in deep sleep mode in

PSoC 4.

Parameters: None
Return Value: None
Side Effects: None

### void ScanComp\_Wakeup(void)

**Description:** This is the preferred API to restore the component to the state when ScanComp Sleep() was

called.

Parameters: None
Return Value: None
Side Effects: None

## **MISRA** Compliance

This section describes the MISRA-C:2004 compliance and deviations for the component. There are two types of deviations defined:

- project deviations deviations that are applicable for all PSoC Creator components
- specific deviations deviations that are applicable only for this component

This section provides information on component-specific deviations. Project deviations are described in the MISRA Compliance section of the *System Reference Guide* along with information on the MISRA compliance verification environment.



The Scanning comparator component does not have any specific deviations.

This component has the following embedded components: Comparator, VDAC8, DMA, Clock, Status Register, Control Register. Refer to the corresponding component datasheet for information on their MISRA compliance and specific deviations.

## **Sample Firmware Source Code**

PSoC Creator provides numerous example projects that include schematics and example code in the Find Example Project dialog. For component-specific examples, open the dialog from the Component Catalog or an instance of the component in a schematic. For general examples, open the dialog from the Start Page or **File** menu. As needed, use the **Filter Options** in the dialog to narrow the list of projects available to select.

Refer to the "Find Example Project" topic in the PSoC Creator Help for more information.

## **Functional Description**

The Scanning Comparator component allows analog comparison of multiple sets of signals using just one hardware comparator. The trade-off is between the increased number of comparison channels versus reduced response time to a comparison transition and additional hardware usage. This component is useful when more signals must be compared than the number of comparators present in the device.

This component uses a hardware comparator (CTBm in PSoC 4) and additional hardware to mux between inputs and outputs appropriately. The inputs are automatically multiplexed at a set rate using analog multiplexers. The comparator output is latched once the inputs are stable, and an interrupt output is generated based on the configured interrupt mode.

The interrupts due to comparison results are written into status registers. The individual comparator interrupt states can be observed in firmware by polling the status registers using provided APIs. A single component-wide interrupt output signal is the ORed combination of all unmasked interrupts.

The sampled comparator outputs can be enabled for connection in digital hardware. This consumes additional hardware and is therefore optional.

The Scanning Comparator component operates in one of three compare modes which are selected via the Negative input parameter in the customizer.

- Unique In this mode each channel has its own negative analog input that is multiplexed.
- Common In this mode all channels use the same negative analog input.
- Internal VDAC In this mode all channels use for their negative analog input the output from a VDAC that is configured by the component. The VDAC output value may be changed for each cannel as the channels are scanned using DMA. This mode is not available for PSoC 4 devices.



## Registers

The Scanning Comparator component has several status registers that are used by the firmware APIs to monitor the status of the comparator output value and to store interrupts after edge detection. None of these registers are accessible directly by user firmware.

### Resources

The Scanning Comparator component uses the following device resources:

| Configuration          | on          | Resource       |                |                 |       |      |     | Pins |                                                   |  |
|------------------------|-------------|----------------|----------------|-----------------|-------|------|-----|------|---------------------------------------------------|--|
| Negative Input<br>Mode | Seq.<br>Ch. | Macro<br>cells | Status<br>Reg. | Control<br>Reg. | Cntr7 | Comp | DMA | VDAC | (per External I/O)                                |  |
| Unique                 | 7           | 38             | 2              | 1               | 1     | 1    | _   | _    | Inputs: 1 <sup>[1]</sup> + 2 * Nch <sup>[2]</sup> |  |
|                        | 8           | 32             | 3              |                 |       |      |     |      | Outputs: 2 + Nch [3]                              |  |
|                        | 16          | 50             | 5              |                 |       |      |     |      |                                                   |  |
|                        | 24          | 77             | 7              |                 |       |      |     |      |                                                   |  |
|                        | 32          | 85             | 9              |                 |       |      |     |      |                                                   |  |
| Common                 | 7           | 38             | 2              | 1               | 1     | 1    | _   | _    | Inputs: 1 + 1 [1] + Nch                           |  |
|                        | 8           | 32             | 3              |                 |       |      |     |      | Outputs: 2 + Nch                                  |  |
|                        | 16          | 50             | 5              |                 |       |      |     |      |                                                   |  |
|                        | 24          | 77             | 7              |                 |       |      |     |      |                                                   |  |
|                        | 32          | 85             | 9              |                 |       |      |     |      |                                                   |  |
| Internal VDAC/         | 7           | 38             | 2              | 1               | 1     | 1    | _   | 1    | Inputs: 1 + Nch                                   |  |
| Fixed [4]              | 8           | 32             | 3              |                 |       |      |     |      | Outputs: 2 + Nch                                  |  |
|                        | 16          | 50             | 5              |                 |       |      |     |      |                                                   |  |
|                        | 24          | 77             | 7              |                 |       |      |     |      |                                                   |  |
|                        | 32          | 85             | 9              |                 |       |      |     |      |                                                   |  |



Page 14 of 19 Document Number: 001-95018 Rev. \*\*

<sup>&</sup>lt;sup>1</sup> Depends on the Clock source parameter. This Input is not available for internal clock.

<sup>&</sup>lt;sup>2</sup> Nch – Number of sequenced channels.

<sup>&</sup>lt;sup>3</sup> Depends on the Hardware output enable parameter.

<sup>&</sup>lt;sup>4</sup> Not applicable for PSoC 4.

| Configuration           | n           |                |                | R               | Resource |      |     |      | Pins               |  |
|-------------------------|-------------|----------------|----------------|-----------------|----------|------|-----|------|--------------------|--|
| Negative Input<br>Mode  | Seq.<br>Ch. | Macro<br>cells | Status<br>Reg. | Control<br>Reg. | Cntr7    | Comp | DMA | VDAC | (per External I/O) |  |
| Internal                | 7           | 39             | 2              | 1               | 1        | 1    | 1   | 1    | Inputs: 1 + Nch    |  |
| VDAC/Per<br>channel [4] | 8           | 41             | 3              |                 |          |      |     |      | Outputs: 2+ Nch    |  |
|                         | 16          | 67             | 5              |                 |          |      |     |      |                    |  |
|                         | 24          | 101            | 7              |                 |          |      |     |      |                    |  |
|                         | 32          | 117            | 9              |                 |          |      |     |      |                    |  |

## **API Memory Usage**

The component memory usage varies significantly, depending on the compiler, device, number of APIs used and component configuration. The following table provides the memory usage for all APIs available in the given component configuration.

The measurements have been done with the associated compiler configured in Release mode with optimization set for Size. For a specific design, the map file generated by the compiler can be analyzed to determine the memory usage.

| Configuration          |                  | PSoC 3 (K        | (eil_PK51)     | PSoC 4           | (GCC)          | PSoC 5LP (GCC)   |                |
|------------------------|------------------|------------------|----------------|------------------|----------------|------------------|----------------|
| Negative Input<br>Mode | Seq.<br>Channels | Flash<br>(bytes) | RAM<br>(bytes) | Flash<br>(bytes) | RAM<br>(bytes) | Flash<br>(bytes) | RAM<br>(bytes) |
| Unique / Common        | 4                | -                | -              | 500              | 7              | _                | _              |
|                        | 8                | 698              | 5              | _                | _              | 688              | 5              |
|                        | 16               | 709              | 5              | _                | _              | 756              | 5              |
|                        | 24               | 724              | 5              | _                | _              | 780              | 5              |
|                        | 32               | 737              | 5              | _                | _              | 804              | 5              |
| Internal               | 8                | 1055             | 10             | _                | _              | 1184             | 10             |
| VDAC/Fixed             | 16               | 1067             | 10             | _                | _              | 1248             | 10             |
|                        | 24               | 1080             | 10             | _                | _              | 1272             | 10             |
|                        | 32               | 1093             | 10             | _                | _              | 1300             | 10             |
| Internal VDAC/Per      | 8                | 1279             | 20             | -                | _              | 1328             | 20             |
| channel                | 16               | 1292             | 28             | -                | -              | 1392             | 28             |
|                        | 24               | 1305             | 36             | _                | -              | 1416             | 36             |
|                        | 32               | 1318             | 44             | _                | _              | 1448             | 44             |



# **Component Debug Window**

The Scanning Comparator component supports the PSoC Creator component debug window. Refer to the appropriate device datasheet for a detailed description of each register. The following registers are displayed in the Scanning Comparator component debug window.

| Register                     | Description                                 |
|------------------------------|---------------------------------------------|
| ScanComp_Out1_8_STATUS_REG   | Status of outputs from 1 to 8 channels      |
| ScanComp_Out9_16_STATUS_REG  | Status of outputs from 9 to 16 channels     |
| ScanComp_Out17_24_STATUS_REG | Status of outputs from 17 to 24 channels    |
| ScanComp_Out25_32_STATUS_REG | Status of outputs from 25 to 32 channels    |
| ScanComp_Out33_40_STATUS_REG | Status of outputs from 33 to 40 channels    |
| ScanComp_Out41_48_STATUS_REG | Status of outputs from 41 to 48 channels    |
| ScanComp_Out49_56_STATUS_REG | Status of outputs from 49 to 56 channels    |
| ScanComp_Out57_64_STATUS_REG | Status of outputs from 57 to 64 channels    |
| ScanComp_Comp_PM_ACT_CFG     | Active power mode configuration register 7  |
| ScanComp_Comp_PM_STBY_CFG    | Standby power mode configuration register 7 |
| ScanComp_Comp_TR0            | Comparator trim register TR0                |
| ScanComp_Comp_TR1            | Comparator trim register TR1                |
| ScanComp_Comp_CR             | Comparator control register                 |
| ScanComp_Comp_SW0            | Comparator analog routing register 0        |
| ScanComp_Comp_SW1            | Comparator analog routing register 1        |
| ScanComp_Comp_SW2            | Comparator analog routing register 2        |
| ScanComp_Comp_SW3            | Comparator analog routing register 3        |
| ScanComp_Comp_SW4            | Comparator analog routing register 4        |
| ScanComp_Comp_SW5            | Comparator analog routing register 5        |
| ScanComp_Comp_SW6            | Comparator analog routing register 6        |
| ScanComp_Comp_CLK            | Comparator clock control register           |
| ScanComp_Comp_WRK            | Comparator output working register          |
| VDAC8_PM_ACT_CFG             | Active power mode configuration register 8  |
| VDAC8_PM_STBY_CFG            | Standby power mode configuration register 7 |
| VDAC8_TR                     | DAC trim register                           |
| VDAC8_CR0                    | DAC block control register 0                |
| VDAC8_CR1                    | DAC block control register 1                |



| Register     | Description                   |
|--------------|-------------------------------|
| VDAC8_SW0    | DAC analog routing register 0 |
| VDAC8_SW2    | DAC analog routing register 1 |
| VDAC8_SW3    | DAC analog routing register 2 |
| VDAC8_SW4    | DAC analog routing register 3 |
| VDAC8_STROBE | DAC strobe register           |
| VDAC8_DATA   | DAC data register             |

### DC and AC Electrical Characteristics

The following values indicate expected performance and are based on initial characterization data.

### **Scanning Comparator DC Specifications**

| Parameter        | Description                                                   | Conditions                                                                | Min | Тур | Max                                                                      | Units |
|------------------|---------------------------------------------------------------|---------------------------------------------------------------------------|-----|-----|--------------------------------------------------------------------------|-------|
| V <sub>OS</sub>  | Input offset voltage in High speed / High power mode [5]      | Factory trim,<br>$V_{DDA} > 2.7 \text{ V},$<br>$V_{IN} \ge 0.5 \text{ V}$ | _   | -   | 10                                                                       | mV    |
|                  | Input offset voltage in Medium speed / Medium power mode [5]  | Factory trim,<br>V <sub>IN</sub> ≥ 0.5 V                                  | -   | -   | 9                                                                        | mV    |
|                  | Input offset voltage in Slow speed / Ultra low power mode [5] | V <sub>DDA</sub> ≤ 4.6 V                                                  | -   | ±12 | _                                                                        | mV    |
| Icmp             | Quiescent current                                             |                                                                           | -   | -   | lcmp = ldac <sup>[6]</sup> + lcomp <sup>[7]</sup> + lbase <sup>[8]</sup> | uA    |
| CMRR             | Common mode rejection ratio                                   |                                                                           | 30  | 50  |                                                                          | dB    |
| V <sub>CMP</sub> | Input common mode voltage [5]                                 | Ultra Low<br>Power mode                                                   | 0   |     | V <sub>DDA</sub> _ 1.1                                                   | V     |

Blase – UDB block's current. The typical value of this current is 45 uA / MHz for the Scanning Comparator component.



\_

<sup>&</sup>lt;sup>5</sup> The Speed Power parameter (which depends on internal clock or High power for External clock) can be observed on the component Display on Hover window.

<sup>&</sup>lt;sup>6</sup> Idac – VDAC operating current. This value is described in the VDAC8 component datasheet. The VDAC is not used when the negative input mode of the component is set to "Unique" or "Common".

<sup>&</sup>lt;sup>7</sup> Icomp – Comparator operating current. This value is described in the Comparator component datasheet.

| Parameter | Description | Conditions           | Min | Тур | Max                    | Units |
|-----------|-------------|----------------------|-----|-----|------------------------|-------|
|           |             | Medium<br>Power mode | 0   |     | V <sub>DDA</sub> – 0.1 | V     |
|           |             | High Power mode      | 0   |     | V <sub>DDA</sub> – 0.1 | V     |

## **Scanning Comparator AC Specifications**

| Parameter         | Description       | Conditions                      | Min                         | Тур | Max               | Units |
|-------------------|-------------------|---------------------------------|-----------------------------|-----|-------------------|-------|
| fclk              | Clock frequency   | Without internal VDAC           | 0.001                       | -   | 10                | MHz   |
|                   |                   | With internal VDAC (scale – 1V) | 0.001                       | _   | 2                 | MHz   |
|                   |                   | With internal VDAC (scale – 4V) | 0.001                       | -   | 0.5               | MHz   |
| T <sub>RESP</sub> | Response time [5] | Ultra Low Power mode            | 55 / 1 <sup>[9]</sup>       | -   | (2*Nch)/fclk [10] | us    |
|                   |                   | Medium Power mode               | 0.155 / 0.4 <sup>[9]</sup>  | ı   | (2*Nch)/fclk [10] | us    |
|                   |                   | High Power mode                 | 0.075 / 0.15 <sup>[9]</sup> | _   | (2*Nch)/fclk [10] | us    |

## **Component Changes**

This section lists the major changes in the component from the previous version.

| Version | Description of Changes                                                              | Reason for Changes / Impact                                                 |
|---------|-------------------------------------------------------------------------------------|-----------------------------------------------------------------------------|
| 1.10    | Added support for PSoC 4200-BL devices.                                             | Updates to support PSoC 4200-BL devices.                                    |
| 1.0.a   | Edited datasheet for Knowledge Base Article KBA94159 (www.cypress.com/go/kba94159). | Document that the component was changed, but there is no impact to designs. |
| 1.0     | New component.                                                                      |                                                                             |



Page 18 of 19 Document Number: 001-95018 Rev. \*\*

<sup>&</sup>lt;sup>9</sup> Response time for PSoC 4.

<sup>&</sup>lt;sup>10</sup> Nch – The number of the sequenced channel; fclk = clock frequency.

© Cypress Semiconductor Corporation, 2014. The information contained herein is subject to change without notice. Cypress Semiconductor Corporation assumes no responsibility for the use of any circuitry other than circuitry embodied in a Cypress product. Nor does it convey or imply any license under patent or other rights. Cypress products are not warranted nor intended to be used for medical, life support, life saving, critical control, or safety applications, unless pursuant to an express written agreement with Cypress. Furthermore, Cypress does not authorize its products for use as critical components in life-support systems where a malfunction or failure may reasonably be expected to result in significant injury to the user. The inclusion of Cypress products in life-support systems application implies that the manufacturer assumes all risk of such use and in doing so indemnifies Cypress against all charges.

PSoC® is a registered trademark, and PSoC Creator™ and Programmable System-on-Chip™ are trademarks of Cypress Semiconductor Corp. All other trademarks or registered trademarks referenced herein are property of the respective corporations.

Any Source Code (software and/or firmware) is owned by Cypress Semiconductor Corporation (Cypress) and is protected by and subject to worldwide patent protection (United States and foreign), United States copyright laws and international treaty provisions. Cypress hereby grants to licensee a personal, non-exclusive, non-transferable license to copy, use, modify, create derivative works of, and compile the Cypress Source Code and derivative works for the sole purpose of creating custom software and or firmware in support of licensee product to be used only in conjunction with a Cypress integrated circuit as specified in the applicable agreement. Any reproduction, modification, translation, compilation, or representation of this Source Code except as specified above is prohibited without the express written permission of Cypress.

Disclaimer: CYPRESS MAKES NO WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, WITH REGARD TO THIS MATERIAL, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. Cypress reserves the right to make changes without further notice to the materials described herein. Cypress does not assume any liability arising out of the application or use of any product or circuit described herein. Cypress does not authorize its products for use as critical components in life-support systems where a malfunction or failure may reasonably be expected to result in significant injury to the user. The inclusion of Cypress' product in a life-support systems application implies that the manufacturer assumes all risk of such use and in doing so indemnifies Cypress against all charges.

Use may be limited by and subject to the applicable Cypress software license agreement.



Document Number: 001-95018 Rev. \*\*