

Copyrights



# Cypress EZ-PD<sup>™</sup> CCGx SDK User Guide

Revision 3.0.0

Doc. No. 002-12541 Rev. \*A

Cypress Semiconductor 198 Champion Court San Jose, CA 95134-1709 Phone (USA): 800.858.1810 Phone (Intl): 408.943.2600 www.cypress.com



Copyrights

© Cypress Semiconductor Corporation, 2016. This document is the property of Cypress Semiconductor Corporation and its subsidiaries, including Spansion LLC ("Cypress"). This document, including any software or firmware included or referenced in this document ("Software"), is owned by Cypress under the intellectual property laws and treaties of the United States and other countries worldwide. Cypress reserves all rights under such laws and treaties and does not, except as specifically stated in this paragraph, grant any license under its patents, copyrights, trademarks, or other intellectual property rights. If the Software is not accompanied by a license agreement and you do not otherwise have a written agreement with Cypress governing the use of the Software, then Cypress hereby grants you a personal, non-exclusive, nontransferable license (without the right to sublicense) (1) under its copyright rights in the Software (a) for Software provided in source code form, to modify and reproduce the Software solely for use with Cypress hardware products, only internally within your organization, and (b) to distribute the Software in binary code form externally to end users (either directly or indirectly through resellers and distributors), solely for use on Cypress hardware product units, and (2) under those claims of Cypress's patents that are infringed by the Software (as provided by Cypress, unmodified) to make, use, distribute, and import the Software solely for use with Cypress hardware production, translation, or compilation of the Software is prohibited.

TO THE EXTENT PERMITTED BY APPLICABLE LAW, CYPRESS MAKES NO WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, WITH REGARD TO THIS DOCUMENT OR ANY SOFTWARE OR ACCOMPANYING HARDWARE, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. To the extent permitted by applicable law, Cypress reserves the right to make changes to this document without further notice. Cypress does not assume any liability arising out of the application or use of any product or circuit described in this document. Any information provided in this document, including any sample design information or programming code, is provided only for reference purposes. It is the responsibility of the user of this document to properly design, program, and test the functionality and safety of any application made of this information and any resulting product. Cypress products are not designed, intended, or authorized for use as critical components in systems designed or intended for the operation of weapons, weapons systems, nuclear installations, life-support devices or systems, other medical devices or systems (including resuscitation equipment and surgical implants), pollution control or hazardous substances management, or other uses where the failure of the device or system could cause personal injury, death, or property damage ("Unintended Uses"). A critical component is any component of a device or system whose failure to perform can be reasonably expected to cause the failure of the device or system, or to affect its safety or effectiveness. Cypress is not liable, in whole or in part, and you shall and hereby do release Cypress from any claim, damage, or other liability arising from or related to all Unintended Uses of Cypress products. You shall indemnify and hold Cypress harmless from and against all claims, costs, damages, and other liabilities, including claims for personal injury or death, arising from or related to any Unintended Uses of Cypress products.

Cypress, the Cypress logo, Spansion, the Spansion logo, and combinations thereof, PSoC, CapSense, EZ-USB, F-RAM, and Traveo are trademarks or registered trademarks of Cypress in the United States and other countries. For a more complete list of Cypress trademarks, visit cypress.com. Other names and brands may be claimed as property of their respective owners.







| 1.   | Introduction                                 | 4  |
|------|----------------------------------------------|----|
|      | 1.1 USB Type-C and Power Delivery            |    |
|      | 1.2 EZ-PD <sup>TM</sup> Type-C Controllers   |    |
|      | 1.3 CCGx SDK                                 | 4  |
| 2.   | SDK Installation                             |    |
|      | 2.1 SDK Installation                         |    |
|      | 2.2 SDK Limitations                          |    |
|      | 2.3 Tool Dependencies                        |    |
|      | 2.4 Hardware Dependencies                    | 9  |
| 3.   | Getting Started with CCGx                    | 10 |
|      | 3.1 Using the Reference Projects             |    |
|      | 3.2 Updating CCGx Configuration              |    |
| 4.   | Customizing the Firmware Application         | 31 |
|      | 4.1 Solution Structure                       |    |
|      | 4.2 CCG4 Notebook                            |    |
|      | 4.3 CCG3 Notebook                            |    |
|      | 4.4 CCG3 Type C to DP or HDMI/DVI/VGA Dongle |    |
|      | 4.5 CCG3 Power Adapter                       |    |
|      | 4.6 CCG3 Charge-Through Dongle               |    |
|      | 4.7 USB-PD Specification Revisions           | 55 |
| 5.   | Firmware Architecture                        |    |
|      | 5.1 Firmware Blocks                          |    |
|      | 5.2 SDK Usage Model                          |    |
|      | 5.3 Firmware Versioning                      |    |
|      | 5.4 Flash Memory Map                         |    |
|      | 5.5 Bootloader                               |    |
|      | 5.6 Firmware Operation                       | 61 |
| 6.   | Firmware APIs                                |    |
|      | 6.1 API Summary                              |    |
|      | 6.2 API Usage Examples                       |    |
|      | 6.3 Alternate Mode Handling                  |    |
| Revi | ision History                                |    |
|      | Document Revision History                    | 91 |







# 1.1 USB Type-C and Power Delivery

USB Type-C is the new USB-IF standard that solves several challenges faced by today's Type-A and Type-B cables and connectors. USB Type-C uses a slimmer connector (measuring only 2.4 mm in height) to enable increasing miniaturization of consumer and industrial products. The USB Type-C standard is gaining rapid support by enabling small form-factor, easy-to-use connectors, and cables that can transmit multiple protocols. In addition, it offers power delivery up to 100 W – a significant improvement over the 7.5 W for previous standards.

## 1.1.1 USB Type-C Highlights

- New reversible connector measuring only 2.4 mm in height.
- Compliant with USB Power Delivery Specification, providing up to 100 W.
- Double the bandwidth of USB 3.0, increasing to 10 Gbps with SuperSpeedPlus USB 3.1.
- Combines multiple protocols in a single cable, including DisplayPort<sup>™</sup>, PCle<sup>®</sup>, or Thunderbolt<sup>™</sup>.

# 1.2 EZ-PD<sup>™</sup> Type-C Controllers

Cypress offers the EZ-PD line of Type-C controllers, which currently include four product families:

- EZ-PD<sup>™</sup> CCG1: Industry's First Programmable Type-C Port Controller
- EZ-PD<sup>™</sup> CCG2: Industry's Smallest Programmable Type-C Port Controller
- EZ-PD<sup>TM</sup> CCG3: Industry's Most Integrated Type-C Port Controller
- EZ-PD<sup>TM</sup> CCG4: Industry's First Dual-Port Type-C Port Controller

Visit the Cypress Type-C Controller web page for more details on these product families and a feature comparison.

# 1.3 CCGx SDK

The CCGx Software Development Kit (SDK) is a software solution that allows users to harness the capabilities of the CCGx Type-C controllers.

This version of the CCGx SDK supports use of the CCG3 and CCG4 parts. The following applications are supported by the SDK:

- CCG3 and CCG4 based Dual Role solutions such as PD port controllers for notebooks and desktops.
- CCG3 based power adapter port controller solution.
- CCG3 based Display Port (DP) Dongle port controller solution.
- CCG3 based Charge through Dongle (CTD) port controller solution.

The SDK provides a firmware stack compatible with Type-C and USB-PD specifications, along with the necessary drivers and software interfaces required to implement applications using the CCG3 and CCG4 controllers.



The key features for CCGx notebook port controller solution are:

- Supports USB-PD protocol based on the PD 3.0 specification for CCG3 (CYPD3125-40LQXI) and CCG4PD3 (CYPD4126-40LQXI and CYPD4226-40LQXI) parts.
- Supports USB-PD protocol based on the PD 2.0 specification for CCG4PD2 parts (CYPD4125-40LQXI and CYPD4225-40LQXI).
- Supports integrated Rp, Rd resistors on CC1/2 pins.
- Supports dead battery termination.
- Integrated system-level ESD protection for exposed pins.
- Integrated bootloader to support firmware update over I<sup>2</sup>C.
- Over-Voltage Protection (OVP) and Over-Current Protection (OCP). Only CCG3 based solution has internal OCP support.

The key features for CCG3 power adapter port controller solution are:

- USB-PD Protocol as per PD 2.0 specification.
- USB-PD power contract negotiation as provider.
- PFET/NFET selection for producer FETs based on status of GPIO 7.
- Capability of in-system firmware upgrade through the CC in UFP mode.
- Twin firmware images to allow continued system functionality in case of flashing firmware.
- Over-Voltage Protection (OVP) and Over-Current Protection (OCP).

The key features for CCG3 Display Port Dongle port controller solution are:

- USB-PD Protocol as per PD 2.0 specification.
- USB-PD power contract negotiation as consumer.
- Ability to function as Type-C to DP (4-Lane) or Type-C to HDMI/VGA/DVI (4-Lane) based on state of GPIO pin 23.
- Capability of in-system firmware upgrade over USB (HID Class) in firmware and bootloader mode.
- Over-Voltage Protection (OVP).
- Internal bill-board device enumeration.
- Dual firmware images to allow continued system functionality in case of flashing firmware.

The key features for CCG3 Charge Through Dongle port controller solution are:

- USB-PD Protocol as per PD 3.0 specification.
- USB-PD power contract negotiation as dual role port.
- Ability to function as Type-C to HDMI/VGA/DVI (2-Lane) Dongle.
- Capability to be producer when a power adapter is attached to down-stream CCG2 port controller.
- Capability of in-system firmware upgrade over USB (HID Class) in firmware and bootloader mode.
- Internal bill-board device enumeration.
- Dual firmware images to allow continued system functionality in case of flashing firmware.
- Capability of in-system firmware upgrade of the CCG2 port controller via the USB interface.



The CCGx SDK consists of several basic components as shown in Figure 1.





The SDK also includes reference projects implementing standard Type-C applications and documentation that guides the user in customizing existing applications or creating new applications.

#### SDK Directory Structure

At the top level, the following folders are present:

- Documentation: The Documentation folder contains the SDK documentation including release notes, user guide, and API reference guide.
- Firmware: The Firmware folder contains the firmware stack sources, reference projects, and pre-built firmware binaries.
  - binaries:
    - Pre-built CCG3 firmware binary for the CYPD3120-40LQXI part that matches the reference design documented in the CCG3 datasheet.
    - Pre-built firmware binaries for the CYPD3123-40LQXI part that control the upstream port of the Charge-Through Dongle reference application.
    - Pre-built CCG3 firmware binary for the CYPD3125-40LQXI part that matches the hardware design of the CY4531 kit.
    - Pre-built CCG3 firmware binary for the CYPD3135-40LQXI part that matches the reference design documented in the CCG3 datasheet.
    - Pre-built CCG4 firmware binaries for the CYPD4125-40LQXI, CYPD4126-40LQXI, CYPD4225-40LQXI and CYPD4226-40LQXI parts that matches the hardware design of the CY4541 kit.
  - projects: The projects folder contains the sources and PSoC Creator workspaces for the port controller designs based on CYPD3120-40LQXI, CYPD3123-40LQXI, CYPD3125-40LQXI, CYPD3135-40LQXI, CYPD4125-40LQXI CYPD4225-40LQXI, CYPD4126-40LQXI and CYPD4226-40LQXI.



 lib: The lib folder contains the USB-PD stack and Host Processor Interface (HPI) module in a pre-compiled library format.

**NOTE:** This directory is made available for reference. Each reference project has a copy of the relevant libraries added to it locally.

src: The src folder contains the sources for the CCGx firmware stack organized by the firmware module. Sources are provided for all modules except the core USB-PD stack and HPI. This directory is made available for reference. Each reference project has a copy of the src directory is added to it locally.

**NOTE:** This directory is made available for reference. Each reference project has a copy of the src directory added to it locally.

Figure 2 shows the installed directory structure of the CCGx SDK, along with descriptions for all of the important folders.

| EZ-PD CCGX SDK                         |                                                           |
|----------------------------------------|-----------------------------------------------------------|
|                                        | CCG2 SDK Directory                                        |
|                                        | CCG3 and CCG4 SDK Directory                               |
| Documentation                          | Documentation: User quide, API quide etc.                 |
| Firmware                               | bocumentation. Oser guide, nit guide etc.                 |
| —————————————————————————————————————— | Pre-built firmware binaries                               |
| CYPD2122-24LQXI ctd ds                 | Binary for CYPD2122-24LQXI CTD downstream port controller |
|                                        |                                                           |
| CYPD3120-40LQXI_dp_dongle              | Binary for CYPD3120-40LQXI DP dongle port controller      |
| CYPD3123-40LQXI_ctd_us                 | Binary for CYPD3123-40LQXI CTD upstream port controller   |
| CYPD3125-40LQXI_notebook               | Binary for CYPD3125-40LQXI notebook port controller       |
|                                        | Binary for CYPD3135-40LQXI power adapter port controller  |
| CYPD4125-40LQXI_notebook               | Binary for CYPD4125-40LQXI notebook port controller       |
| CYPD4126-40LQXI_notebook               | Binary for CYPD4126-40LQXI notebook port controller       |
| CYPD4225-40LQXI notebook               | Binary for CYPD4225-40LQXI notebook port controller       |
| CYPD4226-40LQXI notebook               | Binary for CYPD4226-40LQXI notebook port controller       |
|                                        |                                                           |
| lib                                    | PD stack and HPI libraries (Reference only)               |
| ccq3                                   | Libraries for CYPD31xx-40LOXI                             |
| ccq4 dualport                          | Libraries for CYPD42x5-40LOXI                             |
|                                        | Libraries for CYPD41x5-40LOXI                             |
|                                        | Libraries for CYPD42x6-40LOXI                             |
| ccg4pd3_singleport                     | Libraries for CYPD41x6-40LOXI                             |
|                                        | Libiditeb for errbitke folgki                             |
| projects                               | Reference Projects                                        |
| CYPD3120-40LQXI dp dongle              | DP dongle project for CYPD3120-40LQXI part                |
| CYPD3123-40LQXI ctd us                 | CTD upstream project for CYPD3123-40LQXI part             |
| CYPD3125-40LQXI notebook               | Notebook project for CYPD3125-40LQXI part                 |
|                                        |                                                           |
|                                        | Power adapter project for CYPD3135-40LQXI part            |
| CYPD4125-40LQXI_notebook               | Notebook project for CYPD4125-40LQXI part                 |
| CYPD4126-40LQXI_notebook               | Notebook project for CYPD4126-40LQXI part                 |
| CYPD4225-40LQXI_notebook               | Notebook project for CYPD4225-40LQXI part                 |
| CYPD4226-40LQXI_notebook               | Notebook project for CYPD4226-40LQXI part                 |
|                                        |                                                           |
| src                                    | Firmware Stack Sources (Reference only)                   |
| app                                    | Application layer                                         |
| ar_slave                               | Alpine Ridge I2C slave interface                          |
| hpiss                                  | HPI protocol headers                                      |
| pd_common                              | PD stack headers                                          |
| pd_hal                                 | PD block low level drivers                                |
| scb                                    | Serial communication block driver                         |
| system                                 | Low level drivers, firmware update, timer                 |
| usb                                    | USB drivers (CCG3 only)                                   |
|                                        |                                                           |

Figure 2:CCGx SDK Directory Structure



# 2. SDK Installation



## 2.1 SDK Installation

Once installed, the directory structure will be as shown in Figure 2Error: Reference source not found.

### 2.1.1 Copy the Firmware files

The firmware sources and reference projects are installed Read-Only under the Windows "Program Files" folder by default. Compiling the projects while they are located in "Program Files" may fail if User Account Control (UAC) is activated in the system. Also, it is desirable to leave the original source files untouched in case you wish to revert to a clean copy to undo any source changes you may have made.

PSoC Creator allows creating copies of the reference projects and workspaces via link in Start Page or using Code Examples Dialog. Refer to Section 3.1 for more details.

You can also make a copy of all the files under the "Firmware" folder, to create a working copy that you can modify. Make sure that the copied files are not read-only.

## 2.2 SDK Limitations

- The CYPD3120-40LQXI\_dp\_dongle, CYPD3123-40LQXI\_ctd\_us and CYPD3135-40LQXI\_power\_adapter projects provided for CCG3 are firmware only projects. There are no hardware reference designs with schematic and BOM for these applications available yet for end customers. The pin assignments used in the CCG3 devices for these example projects closely match the reference application diagrams in the CCG3 datasheet. Cypress is working on making reference designs with schematic and BOM for these example projects available in the future.
- 2. CYPD3123-40LQXI parts are not yet available and so CYPD3120-40LQXI parts can be used for the same. Please note that the boot-loader is different for the project and shall require firmware download via SWD before USB flashing can be enabled.
- 3. CYPD4126-40LQXI and CYPD4226-40LQXI parts are pin compatible with CYPD4125-40LQXI and CYPD4225-40LQXI respectively and CY4541 kit (with the silicon replaced) can be used for evaluation.

## 2.3 Tool Dependencies

#### 2.3.1 PSoC Creator

Cypress's Type-C controllers are based on Cypress's PSoC® 4 programmable system-on-chip architecture, which includes programmable analog and digital blocks, an ARM® Cortex®-M0 core, and internal flash memory.

The PSoC Creator IDE is used for configuring the CCG3 and CCG4 devices, to develop and compile the firmware applications and optionally to program the devices using SWD.

This version of the SDK requires PSoC Creator 3.3 DP1 (build 9674) or higher.



This version of PSoC Creator can be installed and used on a computer along with previous versions of PSoC Creator.

The PSoC Creator release includes the GNU ARM compiler tools required to compile the CCGx firmware applications.

## 2.3.2 EZ-PD Configuration Utility

The CCGx devices are shipped with a pre-programmed bootloader that allows the firmware on the device to be updated through an I<sup>2</sup>C interface, the CC channel or the USB interface, which is part of the Type-C interface.

The EZ-PD Configuration Utility is a Windows-based application, which can be used to program the CCGx devices on Cypress-provided kits (DVKs and EVKs) through the bootloader interface.

The EZ-PD Configuration Utility relies on a Cypress USB controller, which can connect to the CCGx device through I<sup>2</sup>C for programming. Therefore, it will only work with the Cypress-provided kits or other hardware, which includes the Cypress USB - I<sup>2</sup>C bridge devices.

The EZ-PD Configuration Utility is also used for creating custom configurations for the CCGx firmware application, which includes aspects such as the supported power profiles, protection schemes, and so on.

This version of the CCGx SDK requires the latest EZ-PD Configuration Utility Beta version, which includes support for programming and configuring the CCG3 and CCG4 devices.

# 2.4 Hardware Dependencies

Cypress provides a set of kits, which can be used to test and evaluate the SDK functionality.

- The CY4531 EZ-PD<sup>™</sup> CCG3 Evaluation Kit can be used to evaluate this version of the SDK with the CCG3 devices
- The CY4541 EZ-PD<sup>™</sup> CCG4 Evaluation Kit can be used to evaluate this version of the SDK with the CCG4 devices.
- Schematics and hardware design guidelines for the Charge-Through Dongle application will be released soon by Cypress.



# 3.1 Using the Reference Projects

As Error: Reference source not foundFigure 1Figure 2shows, the SDK includes reference projects for the target applications that can be used to obtain a jump-start in the process of developing a CCGx application.

This version of SDK provides the following reference projects for the following applications:

- 1. **CYPD3120-40LQXI\_dp\_dongle**: This project implements a single Type-C port controller for DP dongle application using the CYPD3120-40LQXI device. This project supports PD 2.0 specification.
- 2. **CYPD3123-40LQXI\_ctd\_us**: This project implements the upstream PD port controller for a PD 3.0 enabled Charge-Through Dongle application.
- 3. **CYPD3125-40LQXI\_notebook**: This project implements a single Type-C port controller for notebooks using the CYPD3125-40LQXI device. This project supports PD 3.0 specification.
- 4. **CYPD3135-40LQXI\_power\_adapter**: This project implements a single Type-C port controller for power adapters using the CYPD3135-40LQXI device. This project supports PD 2.0 specification.
- CYPD4125-40LQXI\_notebook: This project implements a single Type-C port controller for notebooks using the CYPD4125-40LQXI device. This device supports PD 2.0 specification. The implementation supports all of the features of the dual-port project with only one difference - the target device supports only a single port.
- CYPD4225-40LQXI\_notebook: This project implements a dual Type-C port controller for notebooks using the CYPD4225-40LQXI device. This device supports PD 2.0 specification. Each of the ports on the device can be configured and function independently with full capabilities.
- 7. **CYPD4126-40LQXI\_notebook**: This project implements a single Type-C port controller for notebooks using the CYPD4126-40LQXI device. This device is similar to CYPD4125-40LQXI with PD 3.0 specification support.
- 8. **CYPD4226-40LQXI\_notebook**: This project implements a dual Type-C port controller for notebooks using the CYPD4225-40LQXI device. This device is similar to CYPD4125-40LQXI with PD 3.0 specification support.
- 9. Each reference project is provided in the form of a PSoC Creator workspace. The workspace can be opened using the PSoC Creator and the projects can be customized and compiled.

**Note:** These projects are designed to work with specific devices mentioned above. Changing the target part number using Device Selector will cause the firmware build to fail.

### 3.1.1 Copying the Project with PSoC Creator

PSoC Creator allows SDK example projects to be copied to a different location without affecting the original installed files. There are mainly two ways of doing this: using the Start Page to copy the workspaces and using the Code Examples.

#### From Start Page

The SDK example projects are listed under *Kits->EZ-PD CCGx SDK* on the Start Page. Click on the workspace name to copy it. When copying the workspace, the complete workspace directory along with all the projects associated with the workspace are copied to the selected destination location. PSoC Creator automatically opens the copied workspace after completing the copy. Figure 3 shows the startup page for Creator.



Figure 3: PSoC Creator Startup Page



Note: If Start Page is not open, it can be accessed via View->Other Windows->Start Page.

#### From Code Examples

PSoC Creator lists the SDK examples under the Code Examples Dialog. The dialog can be accessed via *File->Code Example ...* or during new Project creation.

Figure 4 shows the example projects from Code Examples Dialog. The required Device Family can be selected to narrow down the list of examples and the required project can be copied by clicking the *Create Project* button. When using Code Examples Dialog to copy the project, the complete project directory and the selected project shall be copied. It should be noted that the workspace and the files outside the project directory are not copied. All files required for the SDK examples projects are under the project directory and so shall not have any impact.

**Note:** The *noboot* project shall not be present in the newly created workspace and shall require to be explicitly added to the workspace. But, since the *noboot* project is under the example project directory, it is also copied when the example project is created.

Create Project option also allows to create a new project based on existing example projects. Figure 5 shows how to create a new Project based on example projects.

**Note:** When copying via Create Project option, a wrong device part number may get selected. In this case, the user is expected to change the part number to correct one using **Device Selector Dialog**.



| Figure 4: PSoC | Creator | Code | Exam | ples | Dial | og |
|----------------|---------|------|------|------|------|----|
|                |         |      |      |      |      |    |

| Find Code Example                                                                                                                                 |                                                                                                                                                            |
|---------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Device family: CCG4<br>Filter by:<br>CYPD4125-40LQXI_notebook<br>CYPD4126-40LQXI_notebook<br>CYPD4225-40LQXI_notebook<br>CYPD4226-40LQXI_notebook | <image/> <section-header><image/><image/><image/><image/><image/><image/><image/><image/><image/><image/><image/><image/><image/><image/></section-header> |
| l                                                                                                                                                 | Create Project Cancel                                                                                                                                      |

#### Figure 5: PSoC Creator Create Project Dialog





## 3.1.2 Compiling the Project with PSoC Creator

This section walks you through the procedure to open the reference projects and build them using PSoC Creator. The CYPD4225-40LQXI project is used as an illustration in the following descriptions.

- 1. Navigate to the project folder using Windows Explorer. The project folder contents will look as shown in Figure 6.
- The CYPD4225-40LQXI\_notebook.cywrk file is the PSoC Creator workspace file that can be opened using the PSoC Creator IDE. If you have installed multiple Creator versions, ensure that the appropriate PSoC Creator version is used to open the workspace.



Figure 6: Contents of the Reference Project Folder

- 3. Once you open the workspace, note that there are two projects:
  - a. CYPD4225-40LQXI\_notebook.cydsn: This is the main firmware project for the application. This application is designed to work on top of the bootloader pre-programmed on the CCG4 device. It also creates two copies of the firmware binary that will be stored in different banks (regions) of the CCG4 device flash so that the system can implement a fail-safe firmware upgrade mechanism. More details on this project are provided in later sections.
  - b. *noboot.cydsn*: The main firmware project in CYPD4225-40LQXI\_*notebook.cydsn* does not support runtime debugging through the SWD interface. The *noboot.cydsn* is a debug-enabled version of the same firmware application, which does not depend on the bootloader. As run-time debugging is only of interest to customers who have access to the SWD interface on the CCG4 device, this firmware overwrites the complete device flash and expects that the device will be programmed through SWD.

**NOTE:** If the project was copied using Code Examples, then only the main project shall be seen on the workspace. The **noboot.cydsn** project can be added to the workspace using **Add Existing Project** option.

- 4. The CYPD4225-40LQXI\_notebook.cydsn project is set as the default project for the workspace. Choose the **Build notebook** menu option from the **Build** menu or the pop-up menu obtained by right-clicking on the project name.
- Ensure that the compiler Toolchain is set to ARM GCC 4.9-2015-q1-update. This can be verified / modified in the Build settings for the project. The Build Settings Dialog can be opened by right clicking the corresponding project. Figure 7 shows the Build Settings Dialog.



| Figure | 7:  | Pro | iect | Build | Settings | s Dia | loa |
|--------|-----|-----|------|-------|----------|-------|-----|
| iguio  | ••• | 110 | 1000 | Dana  | Counige  | שוט   | iug |

| Build Settings   |                  |                                                            |                                                                                                                                       | 8 ×                                                                                                                                                                                                  |  |
|------------------|------------------|------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Configuration:   | Debug (Active)   |                                                            | •                                                                                                                                     |                                                                                                                                                                                                      |  |
| Toolchain:       | ARM GCC 4.9-20   | 15-q                                                       | 1-update   Processor Type                                                                                                             | e CortexM0 👻                                                                                                                                                                                         |  |
| GYPD4125-40      | LQXI_notebook    | ⊿                                                          | Code Generation                                                                                                                       |                                                                                                                                                                                                      |  |
| 🚊 - Code Gen     | eration          |                                                            | Struct Return Method                                                                                                                  | System Default                                                                                                                                                                                       |  |
| 🕀 Debug          |                  |                                                            | Verbose Asm                                                                                                                           | False                                                                                                                                                                                                |  |
| 🛓 🗄 🗠 Customizer | r l              | 4                                                          | General                                                                                                                               |                                                                                                                                                                                                      |  |
| 🖨 ARM GCC        | 4.9-2015-q1-upda |                                                            | Additional Include Directories                                                                                                        | .\src\pd_hal; .\src\app; .\src\pd_ =                                                                                                                                                                 |  |
| 🗄 - Gener        | al               |                                                            | Create Listing File                                                                                                                   | True                                                                                                                                                                                                 |  |
| 🗄 - Assem        | bler             |                                                            | Default Char Unsigned                                                                                                                 | False                                                                                                                                                                                                |  |
| 🚊 - Compi        |                  | Generate Debugging Information<br>Preprocessor Definitions |                                                                                                                                       | True                                                                                                                                                                                                 |  |
| 🗄 - Linker       |                  |                                                            |                                                                                                                                       | DEBUG                                                                                                                                                                                                |  |
|                  |                  |                                                            | Strict Compilation                                                                                                                    | False                                                                                                                                                                                                |  |
|                  |                  |                                                            | Warning Level                                                                                                                         | Hiah                                                                                                                                                                                                 |  |
|                  |                  | Ad<br>list<br>-mc<br>I.\s<br>-I.\c                         | if more than one.<br>pu=cortex-m0 -mthumb -Wno-main -I.<br>rc\system -I.\src\scb -I.\src\hpiss -I.\<br>sommon -IIGenerated_Source\PSo | biler's include paths; use semi-colon delimited<br>\src\pd_hal -l.\src\app -l.\src\pd_common -<br>.src\app\alt_mode -l.\src\ar_slave -l.\src\usb<br>C4 -\va_alh=\${QutputDir}}\${CompileFile}.lst -g |  |
| <                | •                |                                                            | DEBUG -Wall -Werror -ffunction-secti<br>strict-aliasing                                                                               | ons -finline-functions -Os -fito -ffat-lto-objects -                                                                                                                                                 |  |
|                  |                  |                                                            |                                                                                                                                       |                                                                                                                                                                                                      |  |

Figure 8: Pop-up Window for Project Write Permissions



6. You may receive a pop-up window asking for permission to make the project file writeable, as shown in Figure 8. Select Yes to allow the project build to go through. The complete build process may take about two to three minutes. The output window at the bottom of the IDE will look as shown in Figure 9 at the end of the build process.



#### Figure 9: Output Window after the Build is Complete

| Show output from: All 🔹 👻                                                                                                  |          |
|----------------------------------------------------------------------------------------------------------------------------|----------|
| arm-none-eabi-ar.exe -rs .\CortexM0\ARM_GCC_493\Debug\notebook_1.a .\CortexM0\ARM_GCC_493\Debug\cyfitter_cfg_1.o .\CortexM | 10\AR! - |
| arm-none-eabi-ar.exe: creating .\CortexM0\ARM_GCC_493\Debug\notebook_1.a                                                   |          |
| arm-none-eabi-gcc.exe -W1,start-group -o .\CortexM0\ARM_GCC_493\Debug\notebook_1.elf .\CortexM0\ARM_GCC_493\Debug\dpm.o    | .\Co:    |
| arm-none-eabi-ar.exe -rs .\CortexM0\ARM_GCC_493\Debug\notebook_2.a .\CortexM0\ARM_GCC_493\Debug\cyfitter_cfg_2.o .\CortexM | 10\AR1   |
| arm-none-eabi-ar.exe: creating .\CortexM0\ARM_GCC_493\Debug\notebook_2.a                                                   |          |
| arm-none-eabi-gcc.exe -W1,start-group -o .\CortexM0\ARM_GCC_493\Debug\notebook_2.elf .\CortexM0\ARM_GCC_493\Debug\dpm.o    | .\Co:    |
| cyelftool.exe -B "C:\CCGx SDK 0.9.0\fw\projects\CYPD4225-40LQXI\notebook.cydsn\CortexM0\ARM_GCC_493\Debug\notebook_1.elf"  | fla      |
| cyelftool.exe -B "C:\CCGx SDK 0.9.0\fw\projects\CYPD4225-40LQXI\notebook.cydsn\CortexM0\ARM_GCC_493\Debug\notebook_2.elf"  | fla      |
| cyelftool.exe -M "C:\CCGx SDK 0.9.0\fw\projects\CYPD4225-40LQXI\notebook.cydsn\CortexM0\ARM_GCC_493\Debug\notebook_1.elf"  | "C:\(    |
| cyelftool.exe -S "C:\CCGx SDK 0.9.0\fw\projects\CYPD4225-40LQXI\notebook.cydsn\CortexM0\ARM_GCC_493\Debug\notebook_1.elf"  |          |
| Flash used: 59648 of 131072 bytes (45.5 %). Bootloader: 5120 bytes. Application: 54016 bytes. Metadata: 512 bytes.         |          |
| SRAM used: 7616 of 8192 bytes (93.0 %). Stack: 2048 bytes. Heap: 0 bytes.                                                  |          |
| Build Succeeded: 02/25/2016 19:57:23                                                                                       | =        |
|                                                                                                                            | -        |
| <                                                                                                                          | E.       |
| Output Notice List                                                                                                         |          |

- 7. Now, navigate to the project folder using Windows Explorer to locate the compiled firmware binaries. Navigate to the CYPD4225-40LQXI\_notebook.cydsn\CortexM0\ARM\_GCC\_493\Debug folder for the output files. The following three files are the most important output files generated by the build process:
  - a. CYPD4225-40LQXI\_notebook.hex: This is an SWD programmable binary file in the Intel Hex format that combines the bootloader as well as both copies of the notebook port controller firmware application.
  - b. CYPD4225-40LQXI\_notebook\_1.cyacd: This binary file contains the notebook firmware application to be placed in the lower memory bank (region) of the CCG4 device. The format of the file is documented here. The EZ-PD Configuration Utility accepts firmware binaries in the cyacd format and programs them to the CCG4 device using the I<sup>2</sup>C slave interface provided by the bootloader (or firmware itself).
  - c. CYPD4225-40LQXI\_notebook\_2.cyacd: This binary file contains the notebook firmware application to be placed in the upper memory bank of the CCG4 device.

Programming CCGx using the EZ-PD Configuration Utility

This section provides step-by-step instructions for updating the firmware with the EZ-PD Configuration Utility, using the CY4541 kit for illustration. However, this procedure remains the similar for other supported CCGx device families. CCG3 Power adapter requires CC line programming and needs to be connected to the Type-C port via CY4541 kit, CY4531 kit. CCG3 DP Dongle can be connected directly to the PC via Type-C port or via CY4541 kit or CY4531 kit. Refer to the Ez-PD Configuration Utility User Manual for detailed instructions for all applications.

- 1. Power up the CY4541 kit (the base board of the kit needs to be externally powered) and connect the CCG4 daughter board to the host computer using the USB Mini-B to A cable provided with the kit.
- 2. Wait for driver detection and binding for the USB-Serial controller on the CY4541 kit. The driver for this controller can be obtained by searching on Windows Update. Once the driver binding is successful, a "USB-Serial (Dual Channel) Vendor 1" device will be listed under 'Universal Serial Bus Controllers' in the **Device Manager** window. See Figure 10 for the expected device listing.







- 3. If the automatic driver installation does not succeed, you can download and use the Cypress USB Serial Windows Driver Installer. Refer to the USB-Serial Windows Driver Installation Guide document too.
- 4. Open the EZ-PD Configuration Utility GUI. If the device driver binding is successful, the GUI should report one device connected on the lower border of the UI as shown in Figure 11.



Figure 11: Configuration Utility Detecting the Connected CCG4 EVK

| _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | _ |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| EZ-PD Configuration Utility                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | × |
| File Tools Help                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |
| Start Page                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |   |
| CYPRESS'S USB TYPE-C<br>SOLUTIONS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | - |
| USB Type-C is the new USB-IF standard that solves several challenges faced while using today's Type-A and Type-B cables and connectors. USB<br>Type-C uses a simmer connector - measuring only 2.4-mm in height - to allow for increasing miniaturization of consumer and industrial products. The<br>USB Type-C standard is gaining rapid support by enabling small form.factor, easy-to-use connectors and cables with the ability to transmit multiple<br>protocols and offer power delivery up to 100 W. Cypress offers the EZ-PD <sup>TM</sup> family of USB Type-C compliant cables, cables, notebooks, tablets and monitors to<br>market faster. More information on these devices can be found here: <a href="http://www.cypress.com/Type-C/">http://www.cypress.com/Type-C/</a> | н |
| The EZ-PD Configuration Utility is a Windows application that allows users to configure the parameters of a Type-C device implemented using the<br>Cypress EZ-PDT <sup>M</sup> controllers. The tool also allows firmware updates to be flashed onto the controller.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   |
| USB Type-C Host Bridge<br>USB Type-C Host Bridge<br>Cypress USB to<br>Serial Bridge<br>USB Type-C Device<br>Cypress Type-C<br>UFP Controller                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | - |
| C<br>Cypress Type-C<br>Cypress Type-C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |   |
| Help Message                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |   |
| Waiting for device to enter PD Contract with port partner.<br>Clear                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | - |
| Error: Could not establish PD contract Save log                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | j |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |
| Device Connected: 1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   |

- 5. Go to **Tools** > **Firmware Update**. The utility detects and identifies the device at this stage. A firmware update dialog appears at the end of this process (see Figure 12).
- 6. When you click on the **Notebook** node in the device tree, the UI displays information about the CCGx device and the current firmware running on it.

| 🕞 Firmware Update                                                          |                                                                                                 | ? 🗙                                 |
|----------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|-------------------------------------|
| Firmware path 1:       C:\Program Files (x86)\Cyp         Firmware path 2: | Part Number:<br>Device Family:<br>Application Type:<br>Running Firmware:<br>Atternate Firmware: | CYPD4225-40LQXI<br>CCG4<br>NOTEBOOK |
| S Refresh                                                                  | Bootloader Flashing                                                                             | Program Cancel Ready                |

#### Figure 12: Firmware Update Dialog

7. Navigate to the folder containing the firmware binaries generated during the firmware build, and select the CYPD4225-40LQXI\_notebook\_1.cyacd and CYPD4225-40LQXI\_notebook\_2.cyacd files in the two firmware path options in the dialog.

*Note*: The firmware is designed such that notebook\_1 image will allow notebook\_2 to be updated and vice versa. Selecting both files will allow the utility to update using the appropriate file based on the currently running firmware.



- 8. On the CCGx device, it is possible to update the firmware while the device is in PD contract. Hence, the utility does not automatically reset the device at the end of the firmware update sequence. You must do a manual reset or power cycle to activate the newly programmed firmware.
- 9. After the device is reset, use either the Tools > Read from Device or Tools > Firmware Update option to bring up a dialog that can show the current firmware version. If the firmware project from the SDK is used without any changes, the new running firmware version should match the version of firmware downloaded, as shown in Figure 13. The running firmware can be FW1 or FW2 depending on the firmware version, which was running prior to the update operation.
- 10. The CCGx bootloader is designed such that it loads the last programmed firmware binary (irrespective of the firmware version). If desired, you can repeat steps 4 through 8 to update the firmware in the second bank too.

| 😪 Read From Device                                                                                   |                                                                                                 | ? 💌                                                                         |
|------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------|
| Select target:<br>Devices<br>USB-Serial [Dual Channel] (0)<br>NOTEBOOK<br>PORT(0)-DRP<br>PORT(1)-DRP | Part Number:<br>Device Family:<br>Application Type:<br>Running Firmware:<br>Alternate Firmware: | CYPD4225-40LQXI<br>CCG4<br>NOTEBOOK<br>FW:2 (1.0.0.263)<br>FW:1 (0.0.0.183) |
| S Refresh                                                                                            | Bootloader Read                                                                                 | Read Cancel                                                                 |
|                                                                                                      |                                                                                                 | Ready                                                                       |

Figure 13: Firmware Versions after Update Operation

# 3.2 Updating CCGx Configuration

The CCGx firmware design uses a configuration table, which specifies several parameters that control device functionality. These parameters include:

- The VDM responses sent by the device for DISCOVER\_ID, DISCOVER\_SVID, and DISCOVER\_MODE requests when it is functioning as a UFP.
- The power profiles supported by the device as a provider and as a consumer.
- The various alternate mode configurations currently supported by CCGx as a DFP (only DisplayPort alternate mode is supported currently).
- The port roles supported by the device (Source/Sink/Dual Role).
- Enable/disable flags and parameters that control the overvoltage and overcurrent protection schemes implemented by CCGx.

These parameters are stored in a configuration table so that they can be updated/customized without updating the firmware.

Each copy of the CCGx notebook firmware (notebook\_1 and notebook\_2) contains its own embedded configuration table. For safety reasons, the firmware does not update the current configuration. You can update the configuration for the alternate image and then switch control to it, to run with the new configuration.

Configuration using the EZ-PD Configuration Utility

The utility provides an interactive GUI through which all of the contents of the configuration table can be updated.





|                                         | Paramete   | ans                | Value               |                                       |
|-----------------------------------------|------------|--------------------|---------------------|---------------------------------------|
| CCGx configuration                      | Port role  |                    | Dual Role           | -                                     |
| Port 0                                  | Default p  | ort role           | Source              |                                       |
| <ul> <li>Discover Identity</li> </ul>   | Current le |                    | 34                  | •                                     |
| Device IDs                              |            | battery connected  | No                  | •                                     |
| SVID Configuration                      |            | attery connected   | No                  | •                                     |
| Source PDO                              |            | B suspend          | No                  | · · · · · · · · · · · · · · · · · · · |
| Source PDO 0                            |            | 3 communication    | Yes                 | •                                     |
| Source PDO 1                            | Rp - Rd t  |                    | Yes                 | -                                     |
| Source PDO 2<br>Source PDO 3            | Rp suppo   |                    | Default - 1.5A - 3A |                                       |
| Sink PDO                                |            | externally powered | No                  | •                                     |
| Sink PDO 0                              |            | temally powered    | No                  | •                                     |
| Sink PDO 1<br>Sink PDO 2                | Try source |                    | Yes                 | -                                     |
| Sink PDO 2<br>Sink PDO 3                | -          | covery enable      | Yes                 | -                                     |
| Sink PDO 4                              |            | tery enable        | Yes                 | -                                     |
| Port Information                        |            | overy enable       | Yes                 | -                                     |
| DP Mode Parameters<br>Power Protections | DR Swa     | p response         | ACCEPT              | •                                     |
| Port 1                                  |            | p response         | ACCEPT              | •                                     |
| <ul> <li>Discover Identity</li> </ul>   | VCONN      | Swap response      | ACCEPT              | •                                     |
| Message                                 |            |                    |                     |                                       |

Figure 14 shows a snapshot of the UI screens used for configuring the CCGx notebook solution as an example. The entire device configuration is completed by navigating through all of the nodes shown on the left side window of the UI.

Refer to the Configuration Utility User Manual for a description of the various configuration screens provided by the utility. Each UI screen also provides tool-tips that guide you through the process of defining the configuration.



### Table 1: List of CCG3/CCG4 Notebook Configuration Parameters

| Configuration Parameter     | Default Value                      | Change Allowed                                        |
|-----------------------------|------------------------------------|-------------------------------------------------------|
|                             |                                    |                                                       |
|                             |                                    |                                                       |
| Device Parameters           |                                    | -                                                     |
| Manufacturer Info           | "Cypress"                          | Can be changed. Valid only for PD 3.0 configurations. |
| Device IDs                  |                                    |                                                       |
| USB host support            | Yes                                | Not allowed                                           |
| USB device support          | No                                 | Not allowed                                           |
| Modal operation supported   | No                                 | This gets changed when an SVID is added               |
| USB Vendor Id               | 0x04B4                             | Can be changed                                        |
| Product type                | Peripheral                         | Not allowed                                           |
| USB-ID compliance test ID   | 0                                  | Can be changed                                        |
| USB Product ID              | F640 for CCG3<br>F6C0 for CCG4     | Can be changed                                        |
| Bcd device                  | 0                                  | Can be changed                                        |
| SVID Configuration          |                                    |                                                       |
| SVID                        | None                               | Can be changed                                        |
| Mode                        | None                               | Can be changed                                        |
| Source PDOs                 | •                                  |                                                       |
| Source PDO 0                | 5 V @ 3A                           | Not recommended                                       |
| Source PDO 1                | 9 V @ 3A                           | Can be changed based on hardware capabilities         |
| Source PDO 2                | 15 V @ 3A                          | Can be changed based on hardware capabilities         |
| Source PDO 3                | 20 V @ 3A                          | Can be changed based on hardware capabilities         |
| Sink PDOs                   |                                    | · · ·                                                 |
| Sink PDO 0                  | 5 V @ 0.9 A                        | Current can be changed                                |
| Sink PDO 1                  | Variable PDO 7 V<br>to 21 V @0.9 A | Can be changed based on hardware capabilities         |
|                             |                                    |                                                       |
|                             |                                    |                                                       |
|                             |                                    |                                                       |
| Port Information            |                                    |                                                       |
| Port role                   | Dual role                          | Can be changed                                        |
| Default port role           | Source                             | Can be changed                                        |
| Current level               | 3A                                 | Can be changed                                        |
| Is source battery connected | No                                 | Can be changed based on hardware capabilities         |
| Is sink battery connected   | No                                 | Can be changed based on hardware capabilities         |
| Sink USB suspend            | No                                 | Not recommended                                       |



| Configuration Parameter      | Default Value            | Change Allowed                                                              |  |
|------------------------------|--------------------------|-----------------------------------------------------------------------------|--|
| Sink USB communication       | Yes                      | Can be changed                                                              |  |
| Rp-Rd Toggle                 | Yes                      | Not recommended if port role is "Dual role"                                 |  |
| Rp supported                 | Default, 1.5A and 3.0A   | Can be changed                                                              |  |
| Is source externally powered | No                       | Can be changed                                                              |  |
| Is sink externally powered   | No                       | Can be changed                                                              |  |
| DRP preferred role           | Source                   | Can be changed                                                              |  |
| Cable discovery enable       | Yes                      | Can be changed                                                              |  |
| Dead battery enable          | Yes                      | Can be changed                                                              |  |
| Error recovery enable        | Yes                      | Not recommended                                                             |  |
| DR_SWAP response             | ACCEPT                   | Can be changed                                                              |  |
| PR_SWAP response             | ACCEPT                   | Can be changed                                                              |  |
| VCONN_SWAP response          | ACCEPT                   | Can be changed                                                              |  |
| FRS Enable                   | FRS receive              | Can be changed. Valid only for PD 3.0 configurations.                       |  |
| DP Mode Parameters           |                          |                                                                             |  |
| Modes supported              | CDEF                     | Can be changed                                                              |  |
|                              |                          |                                                                             |  |
|                              |                          |                                                                             |  |
| Power Protections            |                          |                                                                             |  |
| Over Voltage Protection      | Enable                   | Not recommended                                                             |  |
| Over Current Protection      | Enable                   | Not recommended                                                             |  |
| OVP Threshold                | 20%                      | Can be changed in the range of 10 % to 50 %                                 |  |
| OVP debounce period          | 1 us                     | Not allowed                                                                 |  |
| OCP Threshold                | CCG4: 0<br>CCG3: 20%     | Not allowed for CCG4. Can be changed in the range of 10 % to 50 % for CCG3. |  |
| OCP debounce period          | CCG4: 0 ms<br>CCG3: 1 ms | Not allowed for CCG4. Can be changed for CCG3.                              |  |
| OCP off time                 | 0                        | Not allowed                                                                 |  |
| OCP retry count              | 0                        | Not allowed                                                                 |  |
| OCP sample period            | 0                        | Not allowed                                                                 |  |
| User Parameters              |                          |                                                                             |  |
| Parameters 1 to 8            | 00                       | Can be changed to any value                                                 |  |

Table 1 shows the list of configuration parameters supported by the CCGx notebook firmware, along with the default values and restrictions on changing them. Note that changing the Source PDO configuration is not recommended while using the EVKs, because the default settings correspond to the actual kit hardware configuration.



### Table 2: List of CCG3 Power Adapter Configuration Parameters

| Configuration Parameter      | Default Value          | Change Allowed                                        |  |
|------------------------------|------------------------|-------------------------------------------------------|--|
| Device Parameters            |                        |                                                       |  |
| Manufacturer Info            | "Cypress"              | Can be changed. Valid only for PD 3.0 configurations. |  |
| Device IDs                   |                        |                                                       |  |
| USB host support             | No                     | Not allowed                                           |  |
| USB device support           | No                     | Not allowed                                           |  |
| Modal operation supported    | Yes                    | This gets changed when an SVID is added               |  |
| USB Vendor Id                | 0x04B4                 | Can be changed                                        |  |
| Product type                 | Undefined              | Not allowed                                           |  |
| USB-ID compliance test ID    | 0                      | Can be changed                                        |  |
| USB Product ID               | F640                   | Can be changed                                        |  |
| Bcd device                   | 0                      | Can be changed                                        |  |
| SVID Configuration           | •                      | •                                                     |  |
| SVID                         | 0x04B4                 | Not allowed                                           |  |
| Mode                         | 0x00000001             | Not recommended                                       |  |
| Source PDOs                  |                        | 1                                                     |  |
| Source PDO 0                 | 5 V @ 3A               | Not recommended                                       |  |
| Source PDO 1                 | 9 V @ 3A               | Can be changed based on hardware capabilities         |  |
| Source PDO 2                 | 15 V @ 3A              | Can be changed based on hardware capabilities         |  |
| Source PDO 3                 | 20 V @ 3A              | Can be changed based on hardware capabilities         |  |
| Dout Information             |                        |                                                       |  |
| Port Information Port role   | Source                 | Not allowed                                           |  |
| Default port role            | Source                 | Not allowed                                           |  |
| Current level                | 3A                     | Can be changed                                        |  |
| Is source battery connected  | No                     | Not allowed                                           |  |
| Is sink battery connected    | No                     | Not allowed                                           |  |
| Sink USB suspend             | No                     | Not recommended                                       |  |
| Sink USB communication       | No                     | Not recommended                                       |  |
| Rp-Rd Toggle                 | No                     | Not allowed                                           |  |
| Rp supported                 | Default, 1.5A and 3.0A | Can be changed                                        |  |
| Is source externally powered | Yes                    | Not allowed                                           |  |
| Is sink externally powered   | No                     | Not allowed                                           |  |
| DRP preferred role           | Source                 | Not allowed                                           |  |
| Cable discovery enable       | Yes                    | Can be changed                                        |  |
| Dead battery enable          | No                     | Not allowed                                           |  |
| Error recovery enable        | Yes                    | Not recommended                                       |  |



| Configuration Parameter | Default Value  | Change Allowed                              |  |
|-------------------------|----------------|---------------------------------------------|--|
| DR_SWAP response        | ACCEPT         | Not recommended                             |  |
| PR_SWAP response        | REJECT         | Can be changed                              |  |
| VCONN_SWAP response     | REJECT         | Can be changed                              |  |
| FRS enable              | None           | Not recommended                             |  |
| Power Protections       |                |                                             |  |
| Over Voltage Protection | Enabled        | Not recommended                             |  |
| Over Current Protection | Polling Method | Not recommended                             |  |
| OVP Threshold           | 20%            | Can be changed in the range of 10 % to 50 % |  |
| OVP debounce period     | 1 us           | Not allowed                                 |  |
| OCP Threshold           | 20%            | Can be changed in range of 10% to 50 %      |  |
| OCP debounce period     | 1 ms           | Can be changed                              |  |
| OCP off time            | 100 ms         | Can be changed                              |  |
| OCP retry count         | 3              | Can be changed                              |  |
| OCP sample period       | 0              | Not allowed                                 |  |
| User Parameters         |                |                                             |  |
| Parameters 1 to 8       | 00             | Can be changed to any value                 |  |

Table 2 shows the list of configuration parameters supported by the CCG3 power adapter firmware, along with the default values and restrictions on changing them.

| Configuration Parameter      | Default Value | Change Allowed                                        |
|------------------------------|---------------|-------------------------------------------------------|
| Device Parameters            |               |                                                       |
| Manufacturer Info            | "Cypress"     | Can be changed. Valid only for PD 3.0 configurations. |
| Device IDs                   |               |                                                       |
| USB host support             | No            | Not allowed                                           |
| USB device support           | Yes           | Not allowed                                           |
| Modal operation supported    | Yes           | This gets changed when an SVID is added               |
| USB Vendor Id                | 0x04B4        | Can be changed                                        |
| Product type                 | AMA           | Not allowed                                           |
| USB-ID compliance test ID    | 0             | Can be changed                                        |
| USB Product ID               | 3120          | Can be changed                                        |
| Bcd device                   | 0             | Can be changed                                        |
| AMA VDO                      |               |                                                       |
| Hardware version             | 0             | Can be changed                                        |
| Firmware version             | 0             | Can be changed                                        |
| SSTX1 directionality support | Fixed         | Can be changed                                        |
| SSTX2 directionality support | Fixed         | Can be changed                                        |



| Configuration Parameter      | Default Value             | Change Allowed                                         |  |
|------------------------------|---------------------------|--------------------------------------------------------|--|
| SSRX1 directionality support | Fixed                     | Can be changed                                         |  |
| SSRX2 directionality support | Fixed                     | Can be changed                                         |  |
| VConn power                  | 1W                        | Can be changed                                         |  |
| VConn required               | Yes                       | Can be changed                                         |  |
| VBUS required                | Yes                       | Can be changed                                         |  |
| USB version                  | USB 2.0<br>Billboard Only | Can be changed                                         |  |
| SVID Configuration           |                           |                                                        |  |
| SVID                         | FF01                      | Not recommended                                        |  |
| Mode                         | 00001405                  | Not recommended                                        |  |
| Sink PDOs                    |                           |                                                        |  |
| Sink PDO 0                   | 5 V @ 0.9 A               | Current can be changed                                 |  |
| Port Information             | ļ                         |                                                        |  |
| Port role                    | Sink                      | Not recommended                                        |  |
| Default port role            | Sink                      | Not recommended                                        |  |
| Current level                | Default                   | Not recommended                                        |  |
| Is source battery connected  | No                        | Not recommended                                        |  |
| Is sink battery connected    | No                        | Can be changed based on hardware capabilities          |  |
| Sink USB suspend             | No                        | Not recommended                                        |  |
| Sink USB communication       | Yes                       | Can be changed                                         |  |
| Rp-Rd Toggle                 | No                        | Not recommended                                        |  |
| Rp supported                 | None                      | Not recommended                                        |  |
| Is source externally powered | No                        | Not recommended                                        |  |
| Is sink externally powered   | No                        | Not recommended                                        |  |
| DRP preferred role           | None                      | Not recommended                                        |  |
| Cable discovery enable       | No                        | Not allowed                                            |  |
| Dead battery enable          | Yes                       | Not recommended                                        |  |
| Error recovery enable        | Yes                       | Not recommended                                        |  |
| DR_SWAP response             | REJECT                    | Not recommended                                        |  |
| PR_SWAP response             | REJECT                    | Not recommended                                        |  |
| VCONN_SWAP response          | REJECT                    | Can be changed                                         |  |
| FRS enable                   | None                      | Not recommended. Valid only for PS 3.0 configurations. |  |
| Billboard Parameters         |                           |                                                        |  |
| Billboard type               | Internal BB<br>device     | Not recommended                                        |  |
| Billboard enable             | BB always<br>enabled      | Can be changed                                         |  |
| Billboard programmer support | Programming interface     | Not recommended                                        |  |



| Configuration Parameter         | Default Value                      | Change Allowed                              |  |
|---------------------------------|------------------------------------|---------------------------------------------|--|
|                                 | enabled                            |                                             |  |
| Billboard timeout               | 600 s                              | Can be changed                              |  |
| Billboard power settings        | Bus powered                        | Can be changed                              |  |
| Billboard container ID settings | Generate based on device UID       | Can be changed                              |  |
| Billboard VConn power setting   | 1W                                 | Can be changed                              |  |
| Billboard serial number setting | Generate based on device UID       | Can be changed                              |  |
| Billboard Settings              |                                    |                                             |  |
| VID                             | 04B4                               | Changes when the Device ID field is updated |  |
| PID                             | 3120                               | Changes when the Device ID field is updated |  |
| Manufacturer                    | Cypress<br>Semiconductor           | Can be changed                              |  |
| Product                         | Type-C DP<br>Dongle                | Can be changed                              |  |
| Configuration                   | Billboard<br>Configuration         | Can be changed                              |  |
| Billboard interface             | Billboard<br>Interface             | Can be changed                              |  |
| HID interface                   | Control Interface                  | Can be changed                              |  |
| Additional info URL             | http://www.cypre<br>ss.com/Type-C/ | Can be changed                              |  |
| Preferred mode                  | 0                                  | Can be changed                              |  |
| Alternate Mode 0                | "Type-C<br>Alternate Mode"         | Can be changed                              |  |
| DP Mode Parameters              |                                    |                                             |  |
| Modes supported                 | С                                  | Can be changed                              |  |
| Preferred DP Mode               | 4-lane<br>DisplayPort              | Can be changed                              |  |
| Power Protections               |                                    |                                             |  |
| Over Voltage Protection         | Enabled                            | Not recommended                             |  |
| Over Current Protection         | Disable                            | Not recommended                             |  |
| OVP Threshold                   | 20%                                | Can be changed in the range of 10 % to 50 % |  |
| OVP debounce period             | 0                                  | Not allowed                                 |  |
| OCP Threshold                   | 0                                  | Not recommended                             |  |
| OCP debounce period             | 0                                  | Not recommended                             |  |
| OCP off time                    | 0                                  | Not allowed                                 |  |
| OCP retry count                 | 0                                  | Not allowed                                 |  |
| OCP sample period               | 0                                  | Not allowed                                 |  |
| User Parameters                 | 1                                  |                                             |  |
| Parameters 1 to 8               | 00                                 | Can be changed to any value                 |  |



Table 3 shows the list of configuration parameters supported by the CCG3 DP Dongle firmware, along with the default values and restrictions on changing them.

| Configuration Parameter      | Default Value                  | Change Allowed                                        |  |
|------------------------------|--------------------------------|-------------------------------------------------------|--|
| Device Parameters            |                                |                                                       |  |
| Manufacturer Info            | "Cypress"                      | Can be changed. Valid only for PD 3.0 configurations. |  |
| Device IDs                   |                                |                                                       |  |
| USB host support             | No                             | Not allowed                                           |  |
| USB device support           | Yes                            | Not allowed                                           |  |
| Modal operation supported    | Yes                            | This gets changed when an SVID is added               |  |
| USB Vendor Id                | 0x04B4                         | Can be changed                                        |  |
| Product type                 | AMA                            | Not allowed                                           |  |
| USB-ID compliance test ID    | 0                              | Can be changed                                        |  |
| USB Product ID               | 0xF649                         | Can be changed                                        |  |
| Bcd device                   | 0                              | Can be changed                                        |  |
| AMA VDO                      |                                |                                                       |  |
| Hardware version             | 0                              | Can be changed                                        |  |
| Firmware version             | 0                              | Can be changed                                        |  |
| SSTX1 directionality support | Fixed                          | Can be changed                                        |  |
| SSTX2 directionality support | Fixed                          | Can be changed                                        |  |
| SSRX1 directionality support | Fixed                          | Can be changed                                        |  |
| SSRX2 directionality support | Fixed                          | Can be changed                                        |  |
| VConn power                  | 1W                             | Can be changed                                        |  |
| VConn required               | Yes                            | Can be changed                                        |  |
| VBUS required                | Yes                            | Can be changed                                        |  |
| USB version                  | [USB 3.1] Gen 1<br>and USB 2.0 | Can be changed                                        |  |
| SVID Configuration           |                                |                                                       |  |
| SVID                         | FF01                           | Not recommended                                       |  |
| Mode                         | 00001405                       | Not recommended                                       |  |
| Source PDOs                  |                                |                                                       |  |
| Source PDO 0                 | 5 V @ 0.9 A                    | Not recommended                                       |  |
| Sink PDOs                    |                                |                                                       |  |
| Sink PDO 0                   | 5 V @ 0.9 A                    | Not recommended                                       |  |
| Port Information             |                                | •                                                     |  |
| Port role                    | Dual Role                      | Not recommended                                       |  |
| Default port role            | Sink                           | Not recommended                                       |  |
| Current level                | Default                        | Not recommended                                       |  |

Table 4: List of CCG3 Charge Through Dongle Upstream Configuration Parameters



| Configuration Parameter         | Default Value                       | Change Allowed                                        |  |
|---------------------------------|-------------------------------------|-------------------------------------------------------|--|
| Is source battery connected     | No                                  | Can be changed                                        |  |
| Is sink battery connected       | No                                  | Can be changed based on hardware capabilities         |  |
| Sink USB suspend                | No                                  | Not recommended                                       |  |
| Sink USB communication          | Yes                                 | Can be changed                                        |  |
| Rp-Rd Toggle                    | Yes                                 | Can be changed                                        |  |
| Rp supported                    | Default, 1.5A<br>and 3.0A           | Can be changed                                        |  |
| Is source externally powered    | Yes                                 | Can be changed                                        |  |
| Is sink externally powered      | Yes                                 | Can be changed                                        |  |
| DRP preferred role              | None                                | Can be changed                                        |  |
| Cable discovery enable          | No                                  | Not allowed                                           |  |
| Dead battery enable             | Yes                                 | Not recommended                                       |  |
| Error recovery enable           | Yes                                 | Not recommended                                       |  |
| DR_SWAP response                | REJECT                              | Can be changed                                        |  |
| PR_SWAP response                | REJECT                              | Can be changed                                        |  |
| VCONN_SWAP response             | REJECT                              | Can be changed                                        |  |
| FRS enable                      | FRS transmit                        | Can be changed. Valid only for PD 3.0 configurations. |  |
| Billboard Parameters            |                                     |                                                       |  |
| Billboard type                  | Internal BB<br>device               | Not recommended                                       |  |
| Billboard enable                | BB always<br>enabled                | Can be changed                                        |  |
| Billboard programmer<br>support | Programming<br>interface<br>enabled | Not recommended                                       |  |
| Billboard timeout               | 600 s                               | Can be changed                                        |  |
| Billboard power settings        | Bus powered                         | Can be changed                                        |  |
| Billboard container ID settings | Generate based<br>on device UID     | Can be changed                                        |  |
| Billboard VConn power setting   | 1W                                  | Can be changed                                        |  |
| Billboard serial number setting | Generate based<br>on device UID     | Can be changed                                        |  |
| Billboard Settings              |                                     |                                                       |  |
| VID                             | 04B4                                | Changes when the Device ID field is updated           |  |
| PID                             | F649                                | Changes when the Device ID field is updated           |  |
| Manufacturer                    | Cypress<br>Semiconductor            | Can be changed                                        |  |
| Product                         | Type-C DP<br>Dongle                 | Can be changed                                        |  |
| Configuration                   | Billboard<br>Configuration          | Can be changed                                        |  |



| Configuration Parameter | Default Value                      | Change Allowed                              |
|-------------------------|------------------------------------|---------------------------------------------|
| Billboard interface     | Billboard<br>Interface             | Can be changed                              |
| HID interface           | Control Interface                  | Can be changed                              |
| Additional info URL     | http://www.cypre<br>ss.com/Type-C/ | Can be changed                              |
| Preferred mode          | 0                                  | Can be changed                              |
| Alternate Mode 0        | "Type-C<br>Alternate Mode"         | Can be changed                              |
| DP Mode Parameters      |                                    |                                             |
| Modes supported         | D                                  | Can be changed                              |
| Preferred DP Mode       | Multi-function<br>DisplayPort      | Can be changed                              |
| Power Protections       |                                    |                                             |
| Over Voltage Protection | Enabled                            | Not recommended                             |
| Over Current Protection | Disable                            | Can be changed                              |
| OVP Threshold           | 20%                                | Can be changed in the range of 10 % to 50 % |
| OVP debounce period     | 0                                  | Not allowed                                 |
| OCP Threshold           | 0                                  | Can be changed                              |
| OCP debounce period     | 0                                  | Can be changed                              |
| OCP off time            | 0                                  | Not allowed                                 |
| OCP retry count         | 0                                  | Not allowed                                 |
| OCP sample period       | 0                                  | Not allowed                                 |
| User Parameters         |                                    |                                             |
| Parameters 1 to 8       | 00                                 | Can be changed to any value                 |

Table 4 shows the list of configuration parameters supported by the CCG3 Charge Through Dongle upstream firmware, along with the default values and restrictions on changing them.

The various fields under Port Information are inter-related, and should be updated to be mutually consistent. Table 5 shows the allowed variations and restrictions on various parameter values across different kinds of CCG applications.

#### Table 5: Port Information Variability across Applications

| Parameter                   | DRP Application | DFP Application | UFP Application |
|-----------------------------|-----------------|-----------------|-----------------|
| Port role                   | Dual role       | Source          | Sink            |
| Default port role           | Variable        | Source          | Sink            |
| Current level               | Variable        | Variable        | Variable        |
| Is source battery connected | Variable        | Variable        | No              |
| Is sink battery connected   | Variable        | No              | Variable        |
| Sink USB suspend            | Variable        | No              | Variable        |
| Sink USB communication      | Variable        | No              | Variable        |
| Rp-Rd Toggle                | Yes             | No              | No              |
| Rp supported                | Variable        | Variable        | None            |



| Parameter                    | DRP Application | DFP Application | UFP Application |
|------------------------------|-----------------|-----------------|-----------------|
| Is source externally powered | Variable        | Variable        | No              |
| Is sink externally powered   | Variable        | No              | Variable        |
| Try source enable            | Variable        | No              | No              |
| Cable discovery enable       | Variable        | Variable        | No              |
| Dead battery enable          | Variable        | Variable        | Variable        |
| Error recovery enable        | Variable        | Variable        | Variable        |
| DR_SWAP response             | Variable        | Variable        | Variable        |
| PR_SWAP response             | Variable        | REJECT          | REJECT          |
| VCONN_SWAP response          | Variable        | Variable        | Variable        |

**Table 6** describes the extended source capabilities message parameters. Extended source capabilities message is supported by all port controllers with Source configuration either in Dual role or Source only mode. This message is used only when both port partners are in PD 3.0 contract.

| Configuration Parameter                        | Default Value      | Change Allowed |
|------------------------------------------------|--------------------|----------------|
| SCEDB Configuration                            | •                  |                |
| XID                                            | 0                  | Can be changed |
| FW Version                                     | 0                  | Can be changed |
| HW Version                                     | 0                  | Can be changed |
| Voltage regulation load step slew rate (mA/us) | 150                | Not allowed    |
| Voltage regulation load step magnitude (%loC)  | 25                 | Can be changed |
| Holdup Time (ms)                               | 3                  | Can be changed |
| LPS compliant                                  | No                 | Can be changed |
| PS1 compliant                                  | No                 | Can be changed |
| PS2 compliant                                  | No                 | Can be changed |
| Low touch current EPS                          | No                 | Can be changed |
| Ground pin                                     | Not supported      | Can be changed |
| Touch temp                                     | Default            | Can be changed |
| Source Inputs-External<br>supplies             | No external supply | Can be changed |
| Source Inputs-Internal<br>batteries            | No                 | Can be changed |
| Hot swappable batteries                        | 0                  | Can be changed |
| Fixed batteries                                | 0                  | Can be changed |
| Peak Current                                   |                    |                |
| Percentage overload (%)                        | 0                  | Can be changed |
| Overload period (ms)                           | 0                  | Can be changed |

 Table 6: Extended Source Capabilities Parameters



| Configuration Parameter | Default Value | Change Allowed |
|-------------------------|---------------|----------------|
| Duty cycle (%)          | 0             | Can be changed |
| Vbus voltage droop      | No            | Can be changed |

After all the parameters are defined, click on the 'Save' button (or go to **File > Save As**) to save a copy of the configuration to the disk. The configuration is stored in the form of an XML file. The utility also generates two additional output files that help the user in deploying the configuration.

- 1. A *cyacd* file is generated, which can be used to program the new configuration data to the device. The EZ-PD utility itself uses the *cyacd* file for device programming.
- 2. A .c file is generated, which can be included in the firmware project to compile a new binary that embeds the desired configuration. More details on the use of this file are provided in later sections of this guide.

After the configuration is saved, use the **Tools** > **Configure Device** option to program the configuration to the device. As mentioned above, the configuration update applies to the current alternate firmware image. The utility issues a warning if the alternate firmware version is older than the current version, and you have the option of aborting the configuration update at this stage.

Resetting the device after a configuration update will cause the device to start running the alternate firmware, which was programmed with a new configuration.



As shown in section 3.2, a major part of the CCGx application functionality can be modified without having to change any of the firmware sources.

Any changes to the hardware design around the CCGx device will, however, require changes to the firmware sources implementing the application. This chapter walks through the process of updating the firmware implementation to work with a different hardware design.

**Note**: As the firmware sources and reference projects are installed in the **Program Files** folder, it is not recommended that you make changes to the original installed version of these files. You can create a copy of the Firmware folder from the SDK installation, and use the copy for making any changes. This will ensure that you have a clean version of the files that you can revert to as well. Refer to section 3.1.1for more details.

Since the target application remains the same, it is expected that the changes are limited to aspects such as the mechanism for voltage selection, FET control, data path MUX/Switch control, and so on. This does not involve changes to the core functionality implemented by the CCGx device.

## 4.1 Solution Structure

.

The CCGx solution structure is shown in Figure 15. The figure uses the CYPD4125-40LQXI\_notebook workspace as reference. The source and header files used in the solution are grouped into different folders.

Figure 15: CCGx Notebook Solution Structure





• Solution: The solution folders contain header and source files that provide user configurations, user hardwarespecific functions and custom code modules. It is expected that these files will need to be changed to match the hardware design and requirements for all customer implementations. The solution-level sources include:

- config.h: Header file that enables/disables firmware features and provides macros or function mappings for hardware-specific functions such as FET control and voltage selection.
- alt\_modes\_config.h: Header file that selects the alternate modes that are supported by the firmware when CCGx is a Downstream Facing Port (DFP) or Upstream Facing Port (UFP).
- stack\_params.h: This header file defines a number of properties that are used to customize the PD stack operation.
- config.c: This source file contains the default run-time configuration for the CCGx notebook application and has been generated using the EZ-PD Configuration Utility.
- datamux\_ctrl.c: This source file contains the functions that control the Type-C data switch that connects the Type-C data pins to the USB and DisplayPort controllers in the system.
- n main.c: This source file contains the main application entry point.

app: The app folders contain header and source files that implement the device policy decisions such as power contract negotiation roles, port role management, power protection schemes, Vendor Defined Message (VDM) handling, and so on. The default implementation provided in the source form uses the configuration table and runtime customizations provided by the EC to handle these tasks. The files can be updated if there is a need to change the way policy decisions are implemented by the CCG firmware. The app source files include:

- app.c: This is the top-level application source file that connects the PD stack to the alternate modes manager as well as the solution level code.
- pdo.c: This source file implements the Power Data Object (PDO) and Request Data Object (RDO) handlers that define the power contract negotiation rules.
- psource.c: This source file implements the power source-related state machines and tasks.
- psink.c: This source file implements the power sink related state machines and tasks.
- <sup>a</sup> swap.c: This source file implements the various swap request handlers.
- vdm.c: This source file implements the handlers for VDMs received by the CCG device.

pd\_hal: The pd\_hal folders header and source files that implement the low level drivers for the PD stack. The header file definitions should not be modified as these are used by the PD stack library and conflicting definitions can result in undefined behavior. The pd\_hal level sources include:

hal\_ccgx.c: This source file implements Over Voltage Protection (OVP) and Over Current Protection (OCP) tasks, which are specific to the CCG device architecture.

alt\_mode: This folder contains header and source files that implement the alternate mode manager functions for when CCG is functioning as DFP and when CCG is functioning as UFP.

hpiss: This folder contains the header files providing the serial communication block (SCB) driver and Host Processor Interface (HPI) protocol interfaces. The actual I<sup>2</sup>C driver and HPI code is provided in library form. The header file definitions should not be modified as these are used by the HPI stack library and conflicting definitions can result in undefined behavior.

pd\_common: Since the PD stack is provided in the library form, the pd\_common folder only contains header files that provide data structure definitions and function declarations for the PD stack. The header file definitions should not be modified as these are used by the PD stack library and conflicting definitions can result in undefined behavior.

• system: This folder contains the base system-level functionality such as GPIO, soft timer implementation, flash driver, and firmware upgrade handlers. The header file definitions should not be modified as these are used by the PD and HPI stack libraries and conflicting definitions can result in undefined behavior.



# 4.2 CCG4 Notebook

## 4.2.1 PSoC Creator Schematic





Most aspects of the hardware design around the CCG4 device are captured in the schematics associated with the PSoC Creator firmware project.

The PSoC Creator schematic can be found in the *TopDesign.cysch* file, which is part of each PSoC Creator project. Doubleclick on this file to open the schematic editor window (see Figure 16).

The schematic shows how internal resources of the CCG4 device are used in the design. This includes all the internal clocks used by the design, the various serial interfaces, and all the GPIO pins used to communicate with external elements.

The analog input pins of the CCG4 device are shown with a red wire connected to it on the right side. See the VBUS\_MON\_P1 signal for example.

Digital input pins are shown with a green wire connected to it on the right side. See the OCP\_FAULT\_P1 signal for example.

Digital output pins are shown with the corresponding pin mapping annotated on the left side. See the VBUS\_P\_CTRL\_P1 signal for example.



Table 7 shows the various schematic elements used in the CCG4 notebook project. The selection of some of these elements is fixed due to the capabilities of the CCG4 device and the bootloader design. The table also points out the changes allowed in the schematic design.

| Schematic Element  | Description                                                                                                                               | Changes Allowed                                                                                                                                       |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bootloadable_1     | This is a software block, which interacts with the bootloader on the CCG4 device.                                                         | No changes should be made to this element.                                                                                                            |
| HPI_IF             | This is an I <sup>2</sup> C slave block through<br>which the CCG4 communicates with<br>the Embedded Controller in the<br>Notebook design. | No changes are allowed as<br>the HPI_IF is also used by<br>the bootloader which is fixed.                                                             |
| MUX_CTRL           | This is an I <sup>2</sup> C master block used by CCG4 to configure the Parade Type-C Interface switch on the CY4541 kit.                  | This block can be changed /<br>replaced by other<br>mechanisms (such as<br>GPIOs), which can control<br>the interface switch on the<br>target design. |
| PDSS_PORT0_RX_CLK  | This is an internal clock that is used for the RX portion of the USB-PD block.                                                            | No changes are allowed.                                                                                                                               |
| PDSS_PORT0_TX_CLK  | This is an internal clock that is used<br>for the TX portion of the USB-PD<br>block.                                                      | No changes are allowed.                                                                                                                               |
| PDSS_PORT0_SAR_CLK | This is an internal clock that is used<br>for the analog portion of the USB-PD<br>block.                                                  | No changes are allowed.                                                                                                                               |
| PDSS_PORT1_RX_CLK  | This is an internal clock that is used for the RX portion of the USB-PD block.                                                            | No changes are allowed.                                                                                                                               |
| PDSS_PORT1_TX_CLK  | This is an internal clock that is used<br>for the TX portion of the USB-PD<br>block.                                                      | No changes are allowed.                                                                                                                               |
| PDSS_PORT1_SAR_CLK | This is an internal clock that is used<br>for the analog portion of the USB-PD<br>block.                                                  | No changes are allowed.                                                                                                                               |
| EC_INT             | This is an output pin used to interrupt<br>the Embedded Controller when there<br>is a state change.                                       | No changes are allowed as<br>EC_INT is also used by boot-<br>loader.                                                                                  |
| I2C_CFG            | This is an input pin used to select the I2C slave address used on the HPI interface.                                                      | No changes are allowed as<br>EC_INT is also used by boot-<br>loader.                                                                                  |
| HPD_P1<br>HPD_P2   | This is the Hotplug Detect output pin<br>from CCG4 to the DisplayPort<br>controller on the notebook.                                      | This pin can be removed if<br>DisplayPort is not used. If<br>used, the pin mapping<br>cannot be changed.                                              |

#### Table 7: Schematic Elements in CCG4 Notebook Design



| Schematic Element                                                    | Description                                                                                              | Changes Allowed                                                                                                                                                                                           |
|----------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FW_LED                                                               | This is the firmware activity LED pin.                                                                   | Actual control is via the GPIO<br>module APIs. See the<br>APP_FW_LED_ENABLE<br>compile-time option for more<br>information.                                                                               |
| VSEL1_P1<br>VSEL2_P1<br>VSEL1_P2<br>VSEL2_P2                         | These are output pins used to select<br>the source voltage to be provided on<br>the Type-C port.         | These can be changed<br>based on the voltage<br>selection mechanism in the<br>target hardware.                                                                                                            |
| VBUS_P_CTRL_P1<br>VBUS_P_CTRL_P2<br>VBUS_C_CTRL_P1<br>VBUS_C_CTRL_P2 | Output pins used to control the provider and consumer FETs in the design.                                | These can be changed<br>based on the FET control<br>mechanism in the target<br>hardware.                                                                                                                  |
| VBUS_DISCHARGE_P1<br>VBUS_DISCHARGE_P2                               | Output pins used to control the VBus discharge path in the design.                                       | These can be changed<br>based on the discharge<br>control mechanism in the<br>target hardware.                                                                                                            |
| VBUS_MON_P1<br>VBUS_MON_P2                                           | Input pins used to monitor the voltage on VBus.                                                          | No changes are allowed as<br>the connectivity to the<br>internal comparators is fixed.                                                                                                                    |
| OCP_FAULT_P1<br>OCP_FAULT_P2                                         | Input pins that notify CCG4 that an overcurrent condition has been detected.                             | These can be removed if<br>OCP fault detection circuitry<br>is not available. If used, the<br>names of the pins should not<br>be changed. However, any<br>available GPIO can be used<br>for this purpose. |
| VBUS_OVP_TRIP_P1<br>VBUS_OVP_TRIP_P2                                 | Output pins from CCG4 that are used<br>for a fast turn-off of the VBus supply<br>in case of overvoltage. | These can be removed if<br>OVP trip functionality is not<br>used. If used, the names of<br>the signals and their pin<br>mapping should not be<br>changed.                                                 |

Closely associated with the schematic is the Design Wide Resources (DWR) view, which maps each schematic element to a pin, clock, or hardware block on the CCG4 device. Open the CYPD4125-40LQXI\_notebook.cydwr file to see the DWR settings for the project.





Figure 17. DWR Project Settings

As shown in Figure 17, the DWR view has several tabs, which configure aspects such as pin mapping, interrupt mapping, clock selection, flash security, and so on. It is recommended that you restrict any changes to the DWR to the pin mapping view. Do not change the clock, interrupt, system, or flash configurations. Even in the pin mapping editor, the changes should be subject to the constraints outlined in Table 7.

## 4.2.2 Updating Code to Match the Schematic

If you make changes in the schematic or pin mapping, you must make corresponding changes in the firmware code that manages these schematic elements.

All of the schematic-dependent code for the notebook application is implemented in the following files:

1. CYPD4125-40LQXI\_notebook.cydsn/config.h: This file defines macros that perform hardware-dependent actions such as selecting source voltage and turning FETs ON/OFF. These are implemented as macros because all of these actions involve simple GPIO updates on the CY4541 kit. If required, add a source file, which implements more complex functions to perform these actions.

**Note**: There is a similar config file in the noboot.cydsn project folder as well. If debugging is used, the schematic-dependent changes should be replicated there as well.

 common/datamux\_ctrl.c: This source file implements a pair of functions that control the Type-C interface switch on the board to select between USB and DisplayPort connections. The default implementation of these functions uses the MUX\_CTRL I2C master block within CCG4.



### **Compile Time Options**

The CCG4 Notebook port controller application supports a set of features that can be enabled/disabled using compile time options. These compile time options are set in the config.h header file that you can find under the solution folder, and are summarized in Table 8.

| Option               | Description                                                                                                                                                                                                                 | Values                                                      |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|
| VBUS_OVP_ENABLE      | Enable flag for the internal comparator-<br>based Over Voltage Protection (OVP)<br>scheme. Even if the OVP feature is<br>enabled using this definition, it can be<br>disabled at run-time using the<br>configuration table. | 1 for OVP enable<br>0 for OVP disable                       |
| VBUS_OCP_ENABLE      | Enable flag for the external load switch based Over Current Protection (OCP) scheme.                                                                                                                                        | 1 for OCP enable<br>0 for OCP disable                       |
| VBUS_OVP_TRIP_ENABLE | Enable flag for a direct supply trip<br>capability from CCG hardware on OVP<br>event. Enabling this requires appropriate<br>circuitry on the target hardware.                                                               | 1 for OVP-TRIP enable<br>0 for OVP-TRIP disable             |
| SYS_DEEPSLEEP_ENABLE | Enable flag for the low power module<br>which keeps CCG in Deep Sleep mode at<br>all possible times.                                                                                                                        | 1 for low power enable<br>0 for low power disable           |
| DFP_ALT_MODE_SUPP    | Enable flag for Alternate mode support when CCG is a DFP.                                                                                                                                                                   | 1 for alternate mode enable<br>0 for alternate mode disable |
| DP_DFP_SUPP          | Enable flag for DisplayPort support when CCG is a DFP.                                                                                                                                                                      | 1 for DisplayPort enable<br>0 for DisplayPort disable       |
| APP_FW_LED_ENABLE    | Enable flag for firmware activity LED indication. When enabled, the user LED blinks at 1 second intervals and the user switch cannot be used.                                                                               | 1 for LED enable<br>0 for LED disable                       |
|                      | Since the LED uses the SWD_IO GPIO, it<br>is necessary to disable it if debugging via<br>SWD.                                                                                                                               |                                                             |
|                      | This LED can be used for development<br>support but is recommended to be left in<br>the OFF state to save power in<br>production designs.                                                                                   |                                                             |

### Table 8: Compile Time Options for CCG4 Notebook Application

### Source Voltage Selection

Refer to the APP\_VBUS\_SET\_XX\_PX macros in the CYPD4125-40LQXI\_notebook.cydsn/config.h file to implement the source voltage selection scheme.

On the CY4541 board, the supported source voltages are 5 V, 9 V, 15 V, and 20 V and a pair of VSEL GPIOs are used to select between them (separate VSEL used for each port).

For example, setting the source voltage on P1 to 15 V is done by the following macro:



```
/* Function/Macro to set P1 source voltage to 15V. */
#define APP VBUS SET 15V P1
                                                          \
{
    VSEL1 P1 Write(0);
   VSEL2 P1 Write(1);
}
```

The implementation of this macro can be changed to use the correct mechanism for voltage selection on the target hardware. You can implement the macros for the voltages that are supported from among 5 V, 9 V, 12 V, 13 V, 15 V, 19 V, and 20 V. The implementation for any unsupported voltage can be left as NULL.

\

\

### FET Control

The provider, consumer, and VBUS discharge FET controls are implemented using the following macros:

- APP VBUS SRC FET ON PX - Turn provider FET ON
- APP VBUS SRC FET OFF PX - Turn provider FET OFF
- APP VBUS SNK FET ON PX - Turn consumer FET ON
- APP VBUS SNK FET OFF PX - Turn consumer FET OFF
- APP DISCHARGE FET ON\_PX - Turn VBus Discharge FET ON
- APP DISCHARGE FET OFF PX - Turn VBus Discharge FET OFF

### Data Switch / MUX Control

The data switch / MUX control is implemented using the following two functions:

1. mux ctrl init: Initialize the MUX / Switch hardware and isolate the Type-C data pins from the USB and DisplayPort connections (ISOLATE mode).

```
/* Initialize the MUX control SCB block. */
bool mux ctrl init(uint8 t port);
```

2. mux ctrl set cfg: Configure the data switch to enable the desired data path. The cfg parameter selects between ISOLATE, USB, 2-lane DisplayPort + USB, and 4-Lane DisplayPort modes. The polarity parameter specifies the Type-C connection orientation.

```
/* Update the data mux settings as required. */
bool mux ctrl set cfg(uint8 t port, mux select t cfg, uint8 t polarity);
```

These functions are currently implemented using a CCG4 internal I<sup>2</sup>C master block to communicate with two different Parade PS8740B switches on the CY4541 kit. These implementations can be changed to make use of the appropriate means for MUX control on the target hardware.

### 4.2.3 Updating the Default Configuration

The CCG4 notebook firmware project has an embedded default configuration in the common/config.c file. The contents of this file can be replaced with that of the .c source file generated by EZ-PD Configuration Utility. Once all of the source changes are completed, rebuild the project to generate the customized binaries.



# 4.3 CCG3 Notebook

### 4.3.1 PSoC Creator Schematic



|                          |              |          | FW LED              |
|--------------------------|--------------|----------|---------------------|
| WBUS_P_CTRL_P1           | M EC_INT     |          |                     |
|                          |              |          |                     |
| WBUS C GTRL P1           | I2C CFG IN   |          | M HPD               |
|                          | ·····        |          |                     |
|                          |              |          |                     |
| WBUS_DISCHARGE_P1        |              |          |                     |
|                          |              |          |                     |
|                          |              |          | PDSS_PORT0_RX_CLK   |
| ···VBUS·MON·P1·⊠→→⊡····· |              |          | 12 06-1             |
|                          |              |          |                     |
|                          |              |          | PDSS_PORT0_TX_CLK   |
| <sup>™</sup> v3EL1_P1    |              |          | 600 kHz             |
|                          |              |          | PDSS_PORT0_SAR_CLK  |
| R VSEL2 P1               |              |          | FD05_FORTU_0AR_CER  |
|                          |              |          | 3.0432              |
|                          |              |          |                     |
|                          |              |          | PDSS_PORT0_SWAP_CLK |
|                          |              | MUX_CTRL | 5/Piz               |
| HPI_IF                   | Bootloadable |          |                     |
| 12C                      | Bootloadable | 12C      |                     |
| 120                      | Bootioadable |          |                     |
|                          |              |          |                     |
|                          |              |          |                     |
|                          |              |          |                     |
| Slave                    |              | Master   |                     |
| Slave                    |              |          |                     |

Most aspects of the hardware design around the CCG3 device are captured in the schematics associated with the PSoC Creator firmware project.

The Creator schematic can be found in the *TopDesign.cysch* file, which is part of each Creator project. Double-click on this file to open the schematic editor window (see Figure 18Error: Reference source not found).

The schematic shows how internal resources of the CCG3 device are used in the design. This includes all of the internal clocks used by the design, the various serial interfaces and all of the GPIO pins used to communicate with external elements.

Table 9 shows the various schematic elements used in the CCG3 notebook project. The selection of some of these elements is fixed due to the capabilities of the CCG3 device and the bootloader design. The table also points out the changes allowed in the schematic design.

| Schematic Element | Description                                                                                                                               | Changes allowed                                                                                                                                      |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bootloadable_1    | This is a software block which interacts with the boot-loader on the CCG3 device.                                                         | No changes should be made to this element.                                                                                                           |
| HPI_IF            | This is an I <sup>2</sup> C slave block through<br>which the CCG3 communicates with<br>the Embedded Controller in the<br>Notebook design. | No changes are allowed as<br>the HPI_IF is also used by<br>the boot-loader which is<br>fixed.                                                        |
| MUX_CTRL          | This is an I <sup>2</sup> C master block used by<br>CCG3 to configure the Parade Type-<br>C Interface switch on the CY4531 kit.           | This block can be changed /<br>replaced by other<br>mechanisms (such as<br>GPIOs) which can control the<br>interface switch on the target<br>design. |

Table 9: Schematic Elements in CCG3 Notebook Design



| Description                                                                                          | Changes allowed                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| This is an internal clock that is used<br>for the RX portion of the USB-PD<br>block.                 | No changes are allowed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| This is an internal clock that is used<br>for the TX portion of the USB-PD<br>block.                 | No changes are allowed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| This is an internal clock that is used<br>for the analog portion of the USB-PD<br>block.             | No changes are allowed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| This is an output pin used to interrupt<br>the Embedded Controller when there<br>is a state change.  | No changes are allowed as EC_INT is also used by boot-<br>loader.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| This is an input pin used to select the I <sup>2</sup> C slave address used on the HPI interface.    | No changes are allowed as<br>EC_INT is also used by boot-<br>loader.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| This is the Hotplug Detect output pin<br>from CCG3 to the DisplayPort<br>controller on the notebook. | This pin can be removed if<br>DisplayPort is not used. If<br>used, the pin mapping<br>cannot be changed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| This is the firmware activity LED pin.                                                               | Actual control is via the GPIO<br>module APIs. See the<br>APP_FW_LED_ENABLE<br>compile-time option for more<br>information.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| These are output pins used to select<br>the source voltage to be provided on<br>the Type-C port.     | These can be changed<br>based on the voltage<br>selection mechanism in the<br>target hardware.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                                                                                      | This is an internal clock that is used<br>for the RX portion of the USB-PD<br>block.This is an internal clock that is used<br>for the TX portion of the USB-PD<br>block.This is an internal clock that is used<br>for the analog portion of the USB-PD<br>block.This is an output pin used to interrupt<br>the Embedded Controller when there<br>is a state change.This is an input pin used to select the<br>l²C slave address used on the HPI<br>interface.This is the Hotplug Detect output pin<br>from CCG3 to the DisplayPort<br>controller on the notebook.This is the firmware activity LED pin.These are output pins used to select<br>the source voltage to be provided on |

Closely associated with the Schematic is the Design Wide Resources (DWR) view, which maps each schematic element to a pin, clock, or hardware block on the CCG3 device. Open the *CYPD3125-40LQXI\_notebook.cydwr* file to see the DWR settings for the project.





#### Figure 19: Design Wide Resource (DWR) View

As shown in Figure 19, the DWR view has several tabs, which configure aspects such as pin mapping, interrupt mapping, clock selection, flash security, and so on. It is recommended that you restrict any changes to the DWR to the pin mapping view. Do not change the clock, interrupt, system, or flash configurations. Even in the pin mapping editor, the changes should be subject to the constraints outlined in Table 9.

## 4.3.2 Updating Code to Match the Schematic

If you change the schematic or pin mapping, you must make corresponding changes in the firmware code that manages these schematic elements.

All of the schematic-dependent code for the notebook application is implemented in the following files:

 CYPD3125-40LQXI\_notebook.cydsn/config.h: This file defines macros that perform hardware-dependent actions such as selecting source voltage and turning FETs ON/OFF. These are implemented as macros because all of these actions involve simple GPIO or device register updates on the CY4531 kit. If required, the user can add a source file which implements more complex functions to perform these actions.

**Note**: There is a similar config file in the noboot.cydsn project folder as well. If debugging is being used, the schematic dependent changes should be replicated there as well.

 common/datamux\_ctrl.c: This source file implements a pair of functions that control the Type-C interface switch on the board to select between USB and DisplayPort connections. The default implementation of these functions uses the MUX\_CTRL I2C master block within CCG3.

### **Compile Time Options**

The CCG3 Notebook port controller application supports a set of features that can be enabled/disabled using compile time options. These compile time options are set in the config.h header file that you can find under the solution folder, and are summarized inTable 10 Table 10.



| Pre-processor Switch         | Description                                                                                                                                            | Values                                                            |
|------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|
| VBUS_OVP_ENABLE              | Enable overvoltage Protection handling<br>on VBus. This feature can be turned off<br>using the configuration table, even if it<br>is enabled here.     | 1 for VBus OVP enable<br>0 for VBus OVP disable                   |
| VBUS_OVP_AUTO_CONTROL_ENABLE | Enable automatic FET control by hardware when an OVP event is detected.                                                                                | 1 for automatic<br>hardware cut-off<br>0 for firmware cut-off     |
| SYS_DEEPSLEEP_ENABLE         | Enable flag for the low power module<br>which keeps CCG in deep sleep mode<br>at all possible times.                                                   | 1 for low power enable<br>0 for low power disable                 |
| DFP_ALT_MODE_SUPP            | Enable Alternate Mode handling when CCG is DFP.                                                                                                        | 1 for alternate mode<br>enable<br>0 for alternate mode<br>disable |
| DP_DFP_SUPP                  | Enable DisplayPort Alternate mode<br>when CCG is DFP. This requires<br>DFP_ALT_MODE_SUPP.                                                              | 1 for DisplayPort<br>enable<br>0 for DisplayPort<br>disable       |
| APP_FW_LED_ENABLE            | Enable flag for firmware activity LED<br>indication. When enabled, the user<br>LED blinks at 1 second intervals and<br>the user switch cannot be used. | 1 for LED enable<br>0 for LED disable                             |
|                              | Since the LED uses the SWD_IO<br>GPIO, it is necessary to disable it if<br>debugging via SWD.                                                          |                                                                   |
|                              | This LED can be used for development<br>support but is recommended to be left<br>in the OFF state to save power in<br>production designs.              |                                                                   |

#### Table 10: Selectable Firmware Features in CCG3 Notebook Application

### Source Voltage Selection

Refer to the APP\_VBUS\_SET\_XX\_PX macros in the CYPD3125-40LQXI\_notebook.cydsn/config.h file to implement the source voltage selection scheme.

On the CY4531 board, the supported source voltages are 5 V, 9 V, 15 V, and 20 V and a pair of VSEL GPIOs are used to select between them (separate VSEL used for each port).

/

\

For example, setting the source voltage on P1 to 15 V is done by the following macro:

```
/* Function/Macro to set P1 source voltage to 15V. */
#define APP_VBUS_SET_15V_P1
{
    VSEL1_P1_Write(0);
    VSEL2_P1_Write(1);
}
```

The implementation of this macro can be changed to use the correct mechanism for voltage selection on the target hardware. The user can implement the macros for the voltages that are supported from among 5 V, 9 V, 12 V, 13 V, 15 V, 19 V, and 20 V. The implementation for any unsupported voltage can be left as NULL.



## FET Control

The provider, consumer, and VBUS discharge FET controls are implemented using the following macros:

- APP\_VBUS\_SRC\_FET\_ON\_PX Turn provider FET ON
- APP\_VBUS\_SRC\_FET\_OFF\_PX Turn provider FET OFF
- APP VBUS SNK FET ON PX Turn consumer FET ON
- APP\_VBUS\_SNK\_FET\_OFF\_PX Turn consumer FET OFF
- APP DISCHARGE FET ON PX Turn VBus Discharge FET ON
- APP DISCHARGE FET OFF PX Turn VBus Discharge FET OFF
- Data Switch / MUX Control

The data switch / MUX control is implemented using the following two functions:

1. mux\_ctrl\_init: Initialize the MUX/Switch hardware and isolate the Type-C data pins from the USB and DisplayPort connections (ISOLATE mode).

```
/* Initialize the MUX control SCB block. */
bool mux_ctrl_init(uint8_t port);
```

 mux\_ctrl\_set\_cfg: Configure the data switch to enable the desired data path. The cfg parameter selects between ISOLATE, USB, 2-lane DisplayPort + USB and 4-Lane DisplayPort modes. The polarity parameter specifies the Type-C connection orientation.

/\* Update the data mux settings as required. \*/
bool mux ctrl set cfg(uint8 t port, mux select t cfg, uint8 t polarity);

These functions are currently implemented using a CCG3 internal I<sup>2</sup>C master block to communicate with two different Parade PS8740B switches on the CY4531 kit. These implementations can be changed to make use of the appropriate means for MUX control on the target hardware.

### 4.3.3 Updating the Default Configuration

The CCG3 notebook firmware project has an embedded default configuration in the common\config.c file. The contents of this file can be replaced with that of the .c source file generated by EZ-PD Configuration Utility. After all the source changes are completed, rebuild the project to generate the customized binaries.



# 4.4 CCG3 Type C to DP or HDMI/DVI/VGA Dongle

CCG3 TypeC to DP or HDMI/DVI/VGA Dongle is Alternate Mode Adapter which can connect a TYPE-C Display Source to DP or HDMI/DVI/VGA Display Sink. It is a bus powered device and can be powered either from VBUS or VCONN. Dongle FW uses a GPIO to determine Display side configuration i.e. DP or HDMI/DVI/VGA. Dongle uses integrated SBU-AUX switch, AUX pull- up/pull-down resistors and billboard controller. It supports FW update interface over HID interface.

# 4.4.1 PSoC Creator Schematic

#### Figure 20: PSoC Creator Schematic for CCG3 Dongle



Open TopDesign.cysch file in the PSoC creator project to access dongle's schematic. Schematic contains hardware resources used by dongle such as clocks, Hot Plug Detect IO etc.

Figure 21Error: Reference source not found shows the various schematic elements used in the CCG3 dongle project. The selection of some of these elements is fixed due to the capabilities of the CCG3 device and the bootloader design. The table also points out the changes allowed in the schematic design.

| Schematic Element | Description                                                                                                                                                                                                                                                                                                          | Changes allowed                                                                     |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|
| Bootloadable_1    | This is a software block which<br>interacts with the boot-loader on the<br>CCG3 device.                                                                                                                                                                                                                              | No changes should be made to this block.                                            |
| HPD               | This is Hot Plug Detect IO which is<br>used by dongle to detect HPD Plug,<br>Unplug and IRQ events.                                                                                                                                                                                                                  | No changes are allowed as<br>this GPIO is routed to internal<br>HPD hardware block. |
| DP_CONFIG_SELECT  | This is a GPIO which is used by<br>dongle to choose between DP and<br>HDMI/DVI/VGA configuration. Dongle<br>FW samples the state of this IO in<br>initialization sequence. If state of IO is<br>detected as low, FW chooses<br>HDMI/DVI/VGA configuration.<br>Otherwise (float/high) it chooses DP<br>configuration. | No changes are allowed as<br>FW functionality depends on<br>this GPIO.              |
| PDSS_PORT0_RX_CLK | This is an internal clock that is used for the RX portion of the USB-PD block.                                                                                                                                                                                                                                       | No changes are allowed.                                                             |

#### Table 11: Schematic Elements in CCG3 Dongle Design



| Schematic Element  | Description                                                                        | Changes allowed         |
|--------------------|------------------------------------------------------------------------------------|-------------------------|
| PDSS_PORT0_TX_CLK  | This is an internal clock that is used for the TX portion of the USB-PD block.     | No changes are allowed. |
| PDSS_PORT0_SAR_CLK | This is an internal clock that is used for the analog portion of the USB-PD block. | No changes are allowed. |

Closely associated with the Schematic is the Design Wide Resources (DWR) view, which maps each schematic element to a pin, clock, or hardware block on the CCG3 device. Open the CY{D3120-40LQXI\_dp\_dongle.cydwr file to see the DWR settings for the project.



Figure 21: Design Wide Resource (DWR) View

As shown in Figure 21Error: Reference source not found, the DWR view has several tabs, which configure aspects such as pin mapping, interrupt mapping, clock selection, flash security, and so on. It is recommended to not change the clock, interrupt, system, or flash configurations. Even in the pin mapping editor, the changes should be subject to the constraints outlined in Error: Reference source not found.

# 4.4.2 Compile Time Options

The CCG3 Dongle application supports a set of features that can be enabled/disabled using compile time options. These compile time options are set in the config.h header file, and are summarized in Table 12Error: Reference source not found.

| Pre-processor Switch | Description                                                                                                                                        | Values                                            |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------|
| VBUS_OVF_ENABLE      | Enable overvoltage Protection handling<br>on VBus. This feature can be turned off<br>using the configuration table, even if it<br>is enabled here. | 1 for VBus OVP enable<br>0 for VBus OVP disable   |
| SYS_DEEPSLEEP_ENABLE | Enable flag for the low power module<br>which keeps CCG in deep sleep mode<br>at all possible times.                                               | 1 for low power enable<br>0 for low power disable |

Table 12: Selectable Firmware Features in CCG3 Dongle Application



| Pre-processor Switch     | Description                                                                                                                                                                                                                          | Values                                                                      |
|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------|
| CCG_BB_ENABLE            | Enable billboard functionality. This feature can be turned off using the configuration table, even if it is enabled here.                                                                                                            | 1 for billboard enable<br>0 for billboard disable                           |
| FLASHING_MODE_USB_ENABLE | Enable FW update interface over USB<br>HID. It is recommended to not disable<br>this option as USB is the only interface<br>available for FW update in dongle. If<br>CCG_BB_ENABLE is 0, this option<br>gets automatically disabled. | 1 for FW update<br>interface enable<br>0 for FW update<br>interface disable |
| FLASH_ENABLE_NB_MODE     | Enable non-blocking flash row update<br>feature. CCG3 supports non-blocking<br>row update which allows other<br>interfaces to be active while device's<br>flash is being updated.                                                    | 1 for non-blocking FW<br>update<br>0 for blocking FW<br>update              |
| DP_GPIO_CONFIG_SELECT    | Enable GPIO bases selection of<br>Display configuration: DP or<br>HDMI/DVI/VGA.                                                                                                                                                      | 1 for GPIO based<br>selection<br>0 for fixed<br>configuration: DP only      |

### 4.4.3 Functional Overview

- CCG3 Dongle implements 4 Iane TYPE-C to DP or HDMI/DVI/VGA alternate mode adapter. Display configuration is selected based on GPIO 23. Dongle updates Discover Mode response based on GPIO status. In DP mode, dongle advertises DP Pin E Configuration and in HDMI/DVI/VGA mode it advertises Pin C Configuration.
- 4. It has integrated billboard controller. Billboard related configuration can be updated through configuration table update. Dongle advertises HID interface along with billboard interface which is used for FW update.
- 5. It has integrated SBU-AUX switch which is used to connect SBU-AUX lines based on CC polarity. Refer source file datamux\_ctrl.c.
- 6. It has integrated AUX pull-up/pull-down resistors. Value of the resistors applied depends on Display configuration: DP or HDMI/DVI/VGA. Refer datamux\_ctrl.c.
- 7. It uses HPD hardware block to receive and queue multiple HPD events i.e. Plug, Unplug and IRQ.

# 4.4.4 Updating the Default Configuration

The CCG3 dongle firmware project has an embedded default configuration in the *common\config.c* file. The contents of this file can be replaced with that of the .c source file generated by EZ-PD Configuration Utility. After all the source changes are completed, rebuild the project to generate the customized binaries.



# 4.5 CCG3 Power Adapter

### 4.5.1 PSoC Creator Schematic

Figure 22: PSoC Creator Schematic for CCG3 Power Adapter



Open TopDesign.cysch file in the PSoC creator project to access power adapter's schematic. Schematic contains hardware resources used by power adapter such as clocks, voltage selection IOs etc.

Figure 22Error: Reference source not found shows the various schematic elements used in the CCG3 power adapter project. The selection of some of these elements is fixed due to the capabilities of the CCG3 device and the bootloader design. The table also points out the changes allowed in the schematic design.

| Schematic Element    | Description                                                                                      | Changes allowed                                                                                |
|----------------------|--------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|
| Bootloadable_1       | This is a software block which interacts with the boot-loader on the CCG3 device.                | No changes should be made to this element.                                                     |
| PDSS_PORT0_RX_CLK    | This is an internal clock that is used for the RX portion of the USB-PD block.                   | No changes are allowed.                                                                        |
| PDSS_PORT0_TX_CLK    | This is an internal clock that is used for the TX portion of the USB-PD block.                   | No changes are allowed.                                                                        |
| PDSS_PORT0_SAR_CLK   | This is an internal clock that is used for the analog portion of the USB-PD block.               | No changes are allowed.                                                                        |
| VSEL1_P1<br>VSEL2_P1 | These are output pins used to select<br>the source voltage to be provided on<br>the Type-C port. | These can be changed<br>based on the voltage<br>selection mechanism in the<br>target hardware. |
| VBUS_MON_P1          | Input pin used to monitor the voltage on VBus.                                                   | No changes are allowed as<br>the connectivity to the<br>internal comparators is fixed.         |

Table 13: Schematic Elements in CCG3 Power Adapter Design



| Schematic Element  | Description                                             | Changes allowed                                                                                                                                                            |
|--------------------|---------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FET_TYPE_DETECT_IO | Input pin used to detect type of voltage provider FETs. | No change is allowed as FW<br>behavior depends on this IO.<br>If the IO is floating, then<br>NFETs are being used. If the<br>IO is grounded, then PFETs<br>are being used. |

Closely associated with the Schematic is the Design Wide Resources (DWR) view, which maps each schematic element to a pin, clock, or hardware block on the CCG3 device. Open the CYPD3135-40LQXI\_power\_adapter.cydwr file to see the DWR settings for the project.

| Figure 23: Desig  | n Wide Resource | (DWR) View |
|-------------------|-----------------|------------|
| - iguio 20. Doolg | ,               |            |

| power_adapter.cy     | ydwr 🗎 📃      |                                                             |                       |             |                    |        |     |     | • < | 4 Þ |
|----------------------|---------------|-------------------------------------------------------------|-----------------------|-------------|--------------------|--------|-----|-----|-----|-----|
|                      |               |                                                             |                       |             | Name               | A Po   | ort | Pin |     | Lo  |
|                      |               |                                                             |                       |             | FET_TYPE_DETECT_IO | P1[0]  | -   | 7   | •   |     |
| •                    |               | * * * * * * * *                                             |                       |             | VBUS_MON_P1        | P2 [4] | •   | 23  | •   |     |
|                      | 1 SUBY<br>200 | PP44<br>PP44<br>PP44<br>PP44<br>PP44<br>PP44<br>PP44<br>PP4 |                       |             | VSEL1_P1           | P0[1]  | -   | 28  | •   |     |
|                      | >             | DBC                                                         |                       |             | VSEL2_P1           | P0[0]  | -   | 27  | -   |     |
| 1 VB                 | US_P_CTRL1    | VBLK                                                        | VBUS_C_CTRL0 30       |             |                    |        |     |     |     |     |
|                      | US_P_CTRL0    |                                                             | VBUS_C_CTRL1 29       |             |                    |        |     |     |     |     |
| 3 00                 |               |                                                             | P0(1) 28 V            |             |                    |        |     |     |     |     |
| 4 V5V<br>5 CC        |               |                                                             | P0(0) 27 V<br>XRES 25 | /SEL2_P1    |                    |        |     |     |     |     |
| 6 VD                 | -             | PD3135-40LQXIT                                              | P2(6) 25              |             |                    |        |     |     |     |     |
| TYPE_DETECT_IO 7 P10 | [0]           | 40-QFN                                                      | P2(5) 24              |             |                    |        |     |     |     |     |
| 8 P1(<br>9 P1)       |               |                                                             | n/c 22                | /BUS_MON_P1 |                    |        |     |     |     |     |
| 10 P1(               | [3]           |                                                             | n/c <b>21</b>         |             |                    |        |     |     |     |     |
|                      |               |                                                             |                       |             |                    |        |     |     |     |     |
|                      | 0             |                                                             |                       |             |                    |        |     |     |     |     |
|                      | AUXA          |                                                             |                       |             |                    |        |     |     |     |     |
|                      | = 2           |                                                             |                       |             |                    |        |     |     |     |     |
|                      |               | DE BUG<br>3.3%<br>3.3%                                      |                       |             |                    |        |     |     |     |     |
|                      |               |                                                             |                       |             |                    |        |     |     |     |     |
|                      |               |                                                             |                       |             |                    |        |     |     |     |     |
|                      |               |                                                             |                       |             |                    |        |     |     |     |     |
|                      |               |                                                             |                       |             |                    |        |     |     |     |     |

As shown in Error: Reference source not found, the DWR view has several tabs, which configure aspects such as pin mapping, interrupt mapping, clock selection, flash security, and so on. It is recommended that you restrict any changes to the DWR to the pin mapping view. Do not change the clock, interrupt, system, or flash configurations. Even in the pin mapping editor, the changes should be subject to the constraints outlined in Error: Reference source not found.

# 4.5.2 Updating Code to Match the Schematic

If you change the schematic or pin mapping, you must make corresponding changes in the firmware code that manages these schematic elements.

All of the schematic-dependent code for the power adapter application is implemented in the following file:

8. CYPD3135-40LQXI\_power\_adpater.cydsn/config.h: This file defines macros that perform hardware-dependent actions such as selecting source voltage and turning FETs ON/OFF. These are implemented as macros because all of these actions involve simple GPIO or device register updates. If required, the user can add a source file which implements more complex functions to perform these actions.

**Note**: There is a similar config file in the noboot.cydsn project folder as well. If debugging is being used, the schematic dependent changes should be replicated there as well.



### **Compile Time Options**

The CCG3 power adapter port controller application supports a set of features that can be enabled/disabled using compile time options. These compile time options are set in the config.h header file that you can find under the solution folder, and are summarized in Error: Reference source not found.



| Pre-processor Switch    | Description                                                                                                                                                                       | Values                                                                                                       |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|
| VBUS_OVP_ENABLE         | Enable overvoltage Protection handling<br>on VBus. This feature can be turned off<br>using the configuration table, even if it<br>is enabled here.                                | 1 for VBus OVP enable<br>0 for VBus OVP disable                                                              |
| VBUS_OCP_ENABLE         | Enable overcurrent protection on VBus.<br>This feature can be turned off using the<br>configuration table, even if it is enabled<br>here.                                         | 1 for VBus OCP enable<br>0 for VBus OCP<br>disable                                                           |
| VBUS_OCP_MODE           | This parameter selects various OCP handling modes.                                                                                                                                | 0: OCP is detected by<br>external OCP<br>hardware.                                                           |
|                         |                                                                                                                                                                                   | 1: Internal OCP with<br>neither software<br>debouce nor automatic<br>FET control by<br>hardware.             |
|                         |                                                                                                                                                                                   | 2: Internal OCP with automatic FET control by hardware.                                                      |
|                         |                                                                                                                                                                                   | 3: Internal OCP with<br>software debounce<br>using delay in<br>milliseconds from the<br>configuration table. |
| SYS_DEEPSLEEP_ENABLE    | Enable flag for the low power module<br>which keeps CCG in deep sleep mode<br>at all possible times.                                                                              | 1 for low power enable<br>0 for low power disable                                                            |
| FLASHING_MODE_PD_ENABLE | Enable FW update interface over PD.<br>Recommendation is to keep this<br>enabled as power adapter supports FW<br>update interface only over PD.                                   | 1 for enabling FW<br>update interface<br>0 for disabling FW<br>update interface                              |
| FLASH_ENABLE_NB_MODE    | Enable non-blocking flash row update<br>feature. CCG3 supports non-blocking<br>row update which allows other<br>interfaces to be active while device's<br>flash is being updated. | 1 for non-blocking FW<br>update<br>0 for blocking FW<br>update                                               |

#### Table 14: Selectable Firmware Features in CCG3 Power Adapter Application

### Source Voltage Selection

Refer to the APP\_VBUS\_SET\_XX\_PX macros in the *power\_adpater*.cydsn/config.h file to implement the source voltage selection scheme.

In CCG3 power adapter FW, the supported source voltages are 5 V, 9 V, 15 V, and 20 V and a pair of VSEL GPIOs are used to select between them.

For example, setting the source voltage to 15 V is done by the following macro:



```
/* Function/Macro to set source voltage to 15V. */
#define APP_VBUS_SET_15V_P1
{
    VSEL1_P1_Write(0);
    VSEL2_P1_Write(1);
}
```

The implementation of this macro can be changed to use the correct mechanism for voltage selection on the target hardware. The user can implement the macros for the voltages that are supported from among 5 V, 9 V, 12 V, 13 V, 15 V, 19 V, and 20 V. The implementation for any unsupported voltage can be left as NULL.

## FET Control

The provider and VBUS discharge FET controls are implemented using the following macros:

- APP VBUS SRC FET ON PX Turn provider FET ON
- APP\_VBUS\_SRC\_FET\_OFF\_PX Turn provider FET OFF
- APP\_DISCHARGE\_FET\_ON\_PX Turn VBus Discharge FET ON
- APP DISCHARGE FET OFF PX Turn VBus Discharge FET OFF

## 4.5.3 Updating the Default Configuration

The CCG3 power adapter firmware project has an embedded default configuration in the *common\config.c* file. The contents of this file can be replaced with that of the .c source file generated by EZ-PD Configuration Utility. After all the source changes are completed, rebuild the project to generate the customized binaries.

### 4.5.4 FW update interface

CCG3 Power Adapter supports dual FW images and non-blocking flash update feature to allow FW update without affecting normal operation of the device. PD is the FW update interface. Host (Flashing controller) needs to swap data roles with power adapter and enter CY FW update alternate mode before initiating FW update procedure. Power adapter bootloader does not support any FW update interface.

# 4.6 CCG3 Charge-Through Dongle

### 4.6.1 PSoC Creator Schematic

Figure 24: PSoC Creator Schematic for CCG3 Charge-Through Dongle





Most aspects of the hardware design around the CCG3 device are captured in the schematics associated with the PSoC Creator firmware project.

The Creator schematic can be found in the *TopDesign.cysch* file, which is part of each Creator project. Double-click on this file to open the schematic editor window (see Figure 24).

The schematic shows how internal resources of the CCG3 device are used in the design. This includes all of the internal clocks used by the design, the various serial interfaces and all of the GPIO pins used to communicate with external elements.

Table 15 shows the various schematic elements used in the CCG3 Charge-Through Dongle upstream port controller project. The selection of some of these elements is fixed due to the capabilities of the CCG3 device and the bootloader design. The table also points out the changes allowed in the schematic design.

| Schematic Element   | Description                                                                                                                                | Changes allowed                                                                                          |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|
| Bootloadable_1      | This is a software block which interacts with the boot-loader on the CCG3 device.                                                          | No changes should be made to this element.                                                               |
| HPI_MASTER          | This is an I <sup>2</sup> C master block through<br>which the CCG3 communicates with<br>the PD port controller for the<br>downstream port. | The pins used can be<br>changed to any other I2C<br>(SCB) blocks on the CCG3<br>device.                  |
| PDSS_PORT0_RX_CLK   | This is an internal clock that is used for the RX portion of the USB-PD block.                                                             | No changes are allowed.                                                                                  |
| PDSS_PORT0_TX_CLK   | This is an internal clock that is used for the TX portion of the USB-PD block.                                                             | No changes are allowed.                                                                                  |
| PDSS_PORT0_SAR_CLK  | This is an internal clock that is used for the analog portion of the USB-PD block.                                                         | No changes are allowed.                                                                                  |
| PDSS_PORT0_SWAP_CLK | This is an internal clock that is used<br>for the fast role swap logic in the<br>USB-PD block.                                             | No changes are allowed.                                                                                  |
| HPI_INTR_GPIO       | This is an input pin used by the downstream port controller to notify CCG3 about downstream port state changes.                            | Can be moved to other free GPIOs on the CCG3 device.                                                     |
| FRS_REQ             | This is an input pin which is used to<br>trigger a PD 3.0 fast-role swap from<br>the CCG3 device.                                          | No changes are allowed as<br>the FRS trigger pin on CCG3<br>is fixed.                                    |
| HPD                 | This is the Hotplug Detect input pin from the DisplayPort driver to the CCG3 device.                                                       | This pin can be removed if<br>DisplayPort is not used. If<br>used, the pin mapping<br>cannot be changed. |
| HUB_CTRL            | This is an output pin used to enable<br>the USB 3.0 hub in the dongle<br>design.                                                           | Should not be changed<br>because this pin is used by<br>the fixed function boot-loader<br>as well.       |

Table 15: Schematic Elements in CCG3 Charge-Through Dongle Design



| Schematic Element | Description                                                                                                                         | Changes allowed                                      |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|
| HV_CTRL           | This is an output pin used to enable<br>the pass-through connection of the<br>downstream port power supply to the<br>upstream port. | Can be moved to other free GPIOs on the CCG3 device. |

Closely associated with the Schematic is the Design Wide Resources (DWR) view, which maps each schematic element to a pin, clock, or hardware block on the CCG3 device. Open the CYPD3123-40LQXI\_ctd\_us.cydwr file to see the DWR settings for the project.





#### Figure 25: Design Wide Resource (DWR) View

As shown in Figure 25, the DWR view has several tabs, which configure aspects such as pin mapping, interrupt mapping, clock selection, flash security, and so on. It is recommended that you restrict any changes to the DWR to the pin mapping view. Do not change the clock, interrupt, system, or flash configurations. Even in the pin mapping editor, the changes should be subject to the constraints outlined in Table 15.

### 4.6.2 Updating Code to Match the Schematic

If you change the schematic or pin mapping, you must make corresponding changes in the firmware code that manages these schematic elements.

All of the schematic-dependent code for the charge-through dongle application is implemented in the following files:

- 1. *common/ctd\_us\_solution.c*: This file makes use of the HV\_CTRL GPIO to control the power circuits as required. These operations can be changed as required based on the hardware design.
- 2. *common/datamux\_ctrl.c*: This source file implements a function that controls the internal SBU MUX on the CCG3 device and the external HUB enable GPIO based on the active PD alternate modes.

### Compile Time Options

The CCG3 Charge-Through Dongle upstream port controller application supports a set of features that can be enabled/disabled using compile time options. These compile time options are set in the config.h header file that you can find under the solution folder, and are summarized in Table 16.



| Pre-processor Switch         | Description                                                                                                                                        | Values                                                            |
|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|
| VBUS_OVP_ENABLE              | Enable overvoltage Protection handling<br>on VBus. This feature can be turned off<br>using the configuration table, even if it<br>is enabled here. | 1 for VBus OVP enable<br>0 for VBus OVP disable                   |
| VBUS_OVP_AUTO_CONTROL_ENABLE | Enable automatic FET control by hardware when an OVP event is detected.                                                                            | 1 for automatic<br>hardware cut-off<br>0 for firmware cut-off     |
| SYS_DEEPSLEEP_ENABLE         | Enable flag for the low power module<br>which keeps CCG in deep sleep mode<br>at all possible times.                                               | 1 for low power enable<br>0 for low power disable                 |
| UFP_ALT_MODE_SUPP            | Enable Alternate Mode handling when CCG is UFP.                                                                                                    | 1 for alternate mode<br>enable<br>0 for alternate mode<br>disable |
| DP_UFP_SUPP                  | Enable DisplayPort Alternate mode<br>when CCG is UFP. This requires<br>UFP_ALT_MODE_SUPP.                                                          | 1 for DisplayPort<br>enable<br>0 for DisplayPort<br>disable       |
| CCG_BB_ENABLE                | Enable the internal Billboard USB device operation.                                                                                                | 1 for Billboard enable<br>0 for Billboard disable                 |

#### Table 16: Selectable Firmware Features in CCG3 Charge-Through Dongle Application

### 4.6.3 Updating the Default Configuration

The CCG3 charge through dongle firmware project has an embedded default configuration in the *common\config.c* file. The contents of this file can be replaced with that of the .c source file generated by EZ-PD Configuration Utility. After all the source changes are completed, rebuild the project to generate the customized binaries.

# 4.7 USB-PD Specification Revisions

The example applications provided for CCG3 and CCG4 devices support USB-PD specification revision 3.0 by default. Since PD 3.0 support requires significant code addition, this leaves little room for the addition of customer specific code in these applications.

It is possible to gain more space in the CCG device flash by restricting the applications to USB-PD Revision 2.0 support. The following steps are required to switch applications between PD 3.0 and PD 2.0 support:

- 1. The PD stack parameters configuration file (stack\_params.h) has a few pre-processor definitions that enable PD 3.0 support in the application. The definitions CCG\_PD\_REV3\_ENABLE, CCG\_FRS\_RX\_ENABLE and CCG\_FRS\_TX\_ENABLE should be set to 0 to disable PD 3.0 support.
- 2. Two versions of the PD stack libraries are provided: libccgx\_pd.a and libccgx\_pd3.a. In the linker settings sections of the build settings of the project, switch between ccgx\_pd and ccgx\_pd3 to switch between PD 2.0 and PD 3.0 support.
- 3. The configuration table contents for the application should be changed based on the specification version to be supported. The SRC\_PDO, SNK\_PDO and DISCOVER\_ID response parameters in the configuration table have fields that are defined only for PD 3.0. These values should be adjusted as required when switching between PD revisions.



### Error: Reference source not found Design

Error: Reference source not foundError: Reference source not foundError: Reference source not foundplication

#### **Functional Overview**

### Error: Reference source not found Design

Error: Reference source not foundError: Reference source not foundError: Reference source not found





# 5. Firmware Architecture



# 5.1 Firmware Blocks

The CCGx firmware architecture allows users to implement a variety of USB-PD applications using the CCG3 and CCG4 devices and a fully tested firmware stack. A block diagram of the CCGx firmware architecture is shown in The CCGx firmware architecture allows users to implement a variety of USB-PD applications using the CCG3 and CCG4 devices and a fully tested firmware stack. A block diagram of the CCGx firmware architecture is shown inThe CCGx firmware architecture allows users to implement a variety of USB-PD applications using the CCG3 and CCG4 devices and a fully tested firmware stack. A block diagram of the CCGx firmware architecture is shown inThe CCGx firmware architecture allows users to implement a variety of USB-PD applications using the CCG3 and CCG4 devices and a fully tested firmware stack. A block diagram of the CCGx firmware architecture is shown inThe CCGx firmware architecture allows users to implement a variety of USB-PD applications using the CCG3 and CCG4 devices and a fully tested firmware stack. A block diagram of the CCGx firmware architecture is shown inThe CCGx firmware architecture allows users to implement a variety of USB-PD applications using the CCG3 and CCG4 devices and a fully tested firmware stack. A block diagram of the CCG3 and CCG4 devices and a fully tested firmware stack. A block diagram of USB-PD applications using the CCG3 and CCG4 devices and a fully tested firmware stack. A block diagram of the CCG3 and CCG4 devices and a fully tested firmware stack. A block diagram of the CCG3 and CCG4 devices and a fully tested firmware stack. A block diagram of the CCG3 and CCG4 devices and a fully tested firmware stack. A block diagram of the CCG3 and CCG4 devices and a fully tested firmware stack. A block diagram of the CCG3 and CCG4 devices and a fully tested firmware stack. A block diagram of the CCG3 and CCG4 devices and a fully tested firmware stack. A block diagram of the CCG3 and CCG4 devices and a fully tested firmware stack. A block diagram of the CCG3 and CCG4 devices and a f



### Customizing the Firmware Application Figure 26: CCGx Firmware Block Diagram



The CCGx firmware architecture contains the following components:

- Hardware Adaptation Layer (HAL): This includes the low-level drivers for the various hardware blocks on the CCG device. This includes drivers for the Type-C and USB-PD block, Serial Communication Blocks (SCBs), GPIOs, flash module, timer module and USB full speed device module (only for CCG3 Dongle).
- USB Type-C and USB-PD Protocol Stack: This is the complete USB-PD protocol stack that includes the Type-C and USB-PD port managers, USB-PD protocol layer, the USB-PD policy engine, and the device policy manager. The device policy manager is designed to allow all policy decisions to be made at the application level, either on an external Embedded Controller (EC) or in the CCG firmware itself.
- Firmware update module: This is a firmware module that allows the device firmware maintained in internal flash to be updated. In Notebook PD port controller applications, the firmware update will be done from the EC side through an I2C interface.
- Billboard Management: This module handles all the billboard enumeration sequences and is applicable only for CCG3 Dongle implementations. The billboard module is used internally by the Alternate Modes modules and is not expected to be invoked explicitly.
- Host Processor Interface (HPI): The Host Processor Interface (HPI) is an I2C-based control interface that allows an Embedded Controller (EC) to monitor and control the USB-PD port on the CCG device. The HPI is the means to allow the PC platform to control the PD policy management.
- Port Management: This module handles all of the PD port management functions including the algorithm for optimal contract negotiations, source and sink power control, source voltage selection, port role assignment, and swap request handling.



- Alternate Modes: This module implements the alternate mode handling for CCG as a DFP and UFP. A fully tested implementation of DisplayPort alternate mode with CCG as DFP is provided. The module also allows users to implement their own alternate mode support in both DFP and UFP modes.
- Low Power: This module attempts to keep the CCG device in the low-power standby mode as often as possible to minimize power consumption.
- External Hardware Control: This is a hardware design-dependent module, which controls the external hardware blocks such as FETs, regulators, and Type-C switches.
- Solution specific tasks: This is an application layer module where any custom tasks required by the user solution can be implemented.

# 5.2 SDK Usage Model

Users of the CCG notebook solution must follow these steps to use the SDK components:

- 1. Load the solution workspace using PSoC Creator.
- 2. Edit the project schematics and solution configuration header file if needed.
- 3. Use the EZ-PD Configuration Utility to build the configuration table, and copy the generated C source file into the Creator project if necessary. The configuration table can also be updated by editing the *config.c* file in PSoC Creator Source Editor.
- 4. Build the application projects using the PSoC Creator. The firmware binaries will be generated in ELF, HEX, and CYACD formats suitable for SWD programming, Miniprog, and the EZ-PD configuration utility.
- 5. Load the firmware binary onto the target hardware for evaluation and testing.

This usage flow is illustrated in Figure 27. Many of these steps, such as changing the compile time configurations and using the EZ-PD Configuration Utility to change the configuration table, are only required if the customer wants to change the way the application works.



Customizing the Firmware Application Figure 27. SDK Usage Flow



# 5.3 Firmware Versioning

Each project has a firmware version (base version) and an application version number.

The base firmware version number shall consist of major number, minor number, and patch number in addition to an automatically updated build number.

The base firmware version applies to the whole stack and is common for all applications and projects using the stack. The version information can be found in the *src/system/ccgx\_version.h* header file.

The application version shall be modified for individual customers based on requirements. This shall have a major version, minor version, external circuit specification, and application name. This version information can be updated by users as required, and is located in the *Firmware/projects/<project\_name>/common/app\_version.h* header file.

**Note:** Ensure that you do not change the application name from the value defined for the CCG application type. The application type information is used by the EZ-PD configuration utility to interpret the configuration table content.

The version number information for each firmware shall be stored in an eight-byte data field and shall be retrieved over the HPI interface. The following table denotes the version structure and format.



### Table 17: CCGx Firmware Version Structure

| Bit Field | Name                             | Description                                                                                                                                                                                                                                                                                                                                                                                      |                                              |
|-----------|----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|
| [15:0]    | Base FW Build number             | This field corresponds to base firmware version and shall be<br>automatically incremented during nightly build. This field should<br>be manually edited.                                                                                                                                                                                                                                         |                                              |
|           |                                  | This field is expected to be reset on every SNPP release cycle an not modified throughout the release.                                                                                                                                                                                                                                                                                           |                                              |
| [23:16]   | Base FW Patch version number     | This field corresponds to base firmware patch version number. field shall be updated manually by the core PD team for base firmware releases.                                                                                                                                                                                                                                                    |                                              |
|           |                                  | This field shall be incremented for every ir to customer or an actual patch release pe release.                                                                                                                                                                                                                                                                                                  |                                              |
| [27:24]   | Base FW Minor version<br>number  | This field corresponds to base firmware m<br>field shall be updated manually by the cor-<br>firmware releases.                                                                                                                                                                                                                                                                                   |                                              |
|           |                                  | This field is generally updated once for ev<br>ES100 RC build. The exception is when a<br>release which breaks compatibility.                                                                                                                                                                                                                                                                    |                                              |
| [31:28]   | Base FW Major version<br>number  | This field corresponds to base firmware major version number. This field shall be updated manually by the core PD team for base firmware releases.                                                                                                                                                                                                                                               |                                              |
|           |                                  | The major number is generally updated on a major project level<br>change or when we have cycled through all minor numbers. The<br>number shall be determined at the beginning of every SNPP release<br>cycle.                                                                                                                                                                                    |                                              |
| [47:32]   | Application Name / number        | This field is left for any application / custor done by applications team.                                                                                                                                                                                                                                                                                                                       | ner-specific changes to be                   |
|           |                                  | By default, this field shall be released by t team will have the following values:                                                                                                                                                                                                                                                                                                               | he base firmware version                     |
|           |                                  | Notebook                                                                                                                                                                                                                                                                                                                                                                                         | "nb"                                         |
|           |                                  | Power Adapter                                                                                                                                                                                                                                                                                                                                                                                    | "ра"                                         |
|           |                                  | Alternate Mode Adapter (AMA)                                                                                                                                                                                                                                                                                                                                                                     | "aa"                                         |
|           |                                  | NOTE: This information is used by E2-PD Configuration Utility to determine the applica standard applications.                                                                                                                                                                                                                                                                                    | tion type and should not be modified $ for $ |
| [55:48]   | External circuit number          | <ul> <li>This field is left for any application / customer-specific changes to done by applications team. By default, this field shall be released the base firmware team as 0.</li> <li>The circuit number values from 0x00 to 0x1F are reserved for bas firmware team. This is because base firmware team may have to support same application on multiple platforms in the future.</li> </ul> |                                              |
|           |                                  |                                                                                                                                                                                                                                                                                                                                                                                                  |                                              |
| [59:56]   | Application minor version number | This field is left for any application / custor<br>done by applications team. By default, this<br>the base firmware team as 0                                                                                                                                                                                                                                                                    |                                              |
| [63:60]   | Application major version number | This field is left for any application / custor<br>done by applications team. By default, this<br>the base firmware team as 0                                                                                                                                                                                                                                                                    |                                              |



# 5.4 Flash Memory Map

CCGx has a 128-KB flash memory that is designated to store a bootloader, along with two copies of the firmware binary along with the corresponding configuration table. The flash memory map for the device is shown in Figure 28.

| CCGx Flash Map                |
|-------------------------------|
| FW Metadata                   |
| FW2: CCG Firmware Application |
| FW2 Configuration Table       |
| FW1: CCG Firmware Application |
| FW1 Configuration Table       |
| Bootloader – I2C              |

Figure 28: CCGx Flash Memory Map

The bootloader in notebook and dongle applications is used to upgrade the CCGx application firmware. Bootloader in power adapter application does not support firmware update interface. It is allocated a fixed area. This memory area can only be written to from the SWD interface. CCG4 Notebook only supports I<sup>2</sup>C bootloader and uses 5 KB of memory. CCG3 Notebook also supports I<sup>2</sup>C bootloader and uses 6KB of memory. CCG3 Dongle supports only USB-HID bootloader and uses 6KB of memory.

The configuration table holds the default PD configuration for the CCG application and is located at the beginning of each firmware binary. The size of each configuration table is 1 KB for notebook and power adapter applications. The size of each configuration table is 2KB for dongle application to provide extra space for billboard related parameters.

The CCG firmware area is used for the main CCG firmware application. In all applications, two copies of firmware (called FW1 and FW2) are used.

In case of CCG4, FW1 uses the space from 5 KB to 64 KB, and FW2 uses the remaining space. CCG3 FW1 uses the space from 6 KB to 64 KB and FW2 uses the remaining space.

The metadata area holds metadata about the firmware binaries. The firmware metadata follows the definition provided by the PSoC Creator bootloader component; and includes firmware checksum, size, and start address.

# 5.5 Bootloader

The Flash-based bootloader mainly functions as a boot-strap and is the starting point for firmware execution. It validates the firmware based on checksum stored in Flash. The boot-strap also includes the flashing module in notebook and dongle applications. The bootloader flow diagram follows.



Customizing the Firmware Application Figure 29: Bootloader Flow Diagram



Since CCGx uses redundant firmware images that can update each other, it is expected that the device always has at least one functional image that can be booted by the bootloader. The programming through bootloader capability in notebook and dongle applications will only be used when using a CCGx part programmed with only the bootloader at factory.

As described in Chapter 3, the bootloader keeps track of the last updated firmware image through the metadata; and loads it during start-up.

# 5.6 Firmware Operation

Figure 30 shows the firmware initialization and operation sequence. The notebook firmware is implemented in the form of a set of state machines and tasks that need to be performed periodically.





The code flow for the application is implemented in the *common\main.c* file. As can be seen from the main () function, the implementation is a simple round-robin loop, which services each of the tasks that the application has to perform.

All of the PD management, HPI command handling, and VDM handling is encapsulated in the task handlers in the CCGx Firmware Stack. Refer to the CCGx FW API Guide document for more details of these functions and handlers.



# 6. Firmware APIs



This section provides a summary of the APIs provided by the PD stack and other layers in the CCGx firmware solution. Only the APIs that are expected to be used directly from user code are documented here. Refer to the API Reference Guide for more details on the data structures used and all of the APIs.

# 6.1 API Summary

# 6.1.1 Device Policy Manager (DPM) API

These functions are declared in the *src/pd\_common/dpm.h* header file.

| Function      | Description                                                                                                                                                       | Parameters                                                                                                                              | Return                                                              |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------|
| dpm_init      | Initialize the Device Policy<br>Manager interface for a given<br>USB-PD port. For a dual-port<br>part, the dpm_init needs to be<br>done separately for each port. | port: Port to be initialized<br>app_cbk: Structure with<br>function pointers that the<br>PD stack can call to<br>handle various events. | Call status.                                                        |
| dpm_start     | Start the PD state machine on the given USB-PD port.                                                                                                              | port: Port to be enabled.                                                                                                               | Call status.                                                        |
| dpm_stop      | Stop the PD state machine on the given USB-PD port.                                                                                                               | port: Port to be disabled                                                                                                               | Call status.                                                        |
| dpm_deepsleep | Check for PD state machine idle<br>state and prepare for deep<br>sleep.                                                                                           | port: Port to be checked.                                                                                                               | 1 if deepsleep is<br>possible.<br>0 if PD state<br>machine is busy. |
| dpm_sleep     | Check for PD state machine idle state and prepare for sleep.                                                                                                      | port: Port to be checked.                                                                                                               | 1 if sleep is<br>possible.<br>0 if PD state<br>machine is busy.     |
| dpm_wakeup    | Update the PD block after device resumes from deep sleep.                                                                                                         | port: Port to be re-<br>enabled.                                                                                                        | Always returns 1.                                                   |
| dpm_task      | PD state machine task. This should be called periodically from the main application.                                                                              | port: Port to be serviced.                                                                                                              | Call status.                                                        |

Table 18: List of Device Policy Manager API



| Function                 | Description                                                                                                                                  | Parameters                                                                                   | Return                                     |
|--------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|--------------------------------------------|
| dpm_pd_command           | Initiate a PD command such as VDM, DR_SWAP etc.                                                                                              | port: Port on which<br>command is to be<br>initiated.                                        | Call status.                               |
|                          |                                                                                                                                              | cmd: Command to be initiated.                                                                |                                            |
|                          |                                                                                                                                              | buf_ptr: Command<br>parameters.                                                              |                                            |
|                          |                                                                                                                                              | cmd_cbk: Callback to be<br>called at the end of<br>command.                                  |                                            |
| dpm_typec_command        | Initiate a Type-C command such as Rp change.                                                                                                 | port: Port on which<br>command is to be<br>initiated.                                        | Call status.                               |
|                          |                                                                                                                                              | cmd: Command to be initiated.                                                                |                                            |
|                          |                                                                                                                                              | cmd_cbk: Callback to be<br>called at the end of<br>command.                                  |                                            |
| dpm_get_info             | Get the DPM status for the<br>device. This is mainly intended<br>for use within other layers in the<br>Cypress provided firmware<br>modules. | port: Port whose status is to be queried.                                                    | Pointer to the<br>DPM status<br>structure. |
| dpm_update_swap_response | Update the response that CCG will send for various swap commands.                                                                            | port: Port whose swap<br>handler is to be<br>changed.                                        | Call status.                               |
|                          |                                                                                                                                              | value: Bitmap in the following format.                                                       |                                            |
|                          |                                                                                                                                              | Bits 1:0 => DR_SWAP<br>response                                                              |                                            |
|                          |                                                                                                                                              | Bits 3:2 => PR_SWAP<br>response                                                              |                                            |
|                          |                                                                                                                                              | Bits 5:4 =><br>VCONN_SWAP response                                                           |                                            |
|                          |                                                                                                                                              | 0 => ACCEPT                                                                                  |                                            |
|                          |                                                                                                                                              | 1 => REJECT<br>2 => WAIT                                                                     |                                            |
|                          |                                                                                                                                              | 3 =><br>NOT_SUPPORTED                                                                        |                                            |
| dpm_update_src_cap       | Update the source capabilities<br>PDO list. The provided values<br>will replace the settings from the<br>configuration table.                | port: Port to be updated.<br>count: Number of PDOs<br>in list. Maximum allowed<br>value is 7 | Call status.                               |
|                          |                                                                                                                                              | pdo: Pointer to array containing PDOs.                                                       |                                            |
| dpm_update_src_cap_mask  | Change the mask that enables<br>specific source PDOs from the<br>list.                                                                       | port: Port to be updated.<br>mask: New PDO enable<br>mask.                                   | Call status.                               |



Customizing the Firmware Application

| Function                 | Description                                                                                                                                                                                       | Parameters                                                                                                                                                                                 | Return                                               |
|--------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|
| dpm_update_snk_cap       | Update the sink capabilities PDO<br>list. The provided values will<br>replace the settings from the<br>configuration table.                                                                       | port: Port to be updated.<br>count: Number of PDOs<br>in list. Maximum allowed<br>value is 7<br>pdo: Pointer to array<br>containing PDOs.                                                  | Call status.                                         |
| dpm_update_snk_cap_mask  | Change the mask that enables specific sink PDOs from the list.                                                                                                                                    | port: Port to be updated.<br>mask: New PDO enable<br>mask.                                                                                                                                 | Call status.                                         |
| dpm_update_snk_max_min   | Change the min/max current<br>fields associated with each Sink<br>PDO.                                                                                                                            | port: Port to be updated.<br>count: Number of PDOs<br>in list. Maximum allowed<br>value is 7<br>max_min: Pointer to<br>array containing new<br>Min/Max operating<br>current values.        | Call status.                                         |
| dpm_update_port_config   | Change the USB-PD<br>configuration: port role, default<br>role etc. The port should have<br>been disabled using<br>dpm_typec_command<br>(DPM_CMD_PORT_DISABLE)<br>before the change is attempted. | port: Port to be updated.<br>role: New port role<br>setting.<br>dflt_role: New default<br>port role for DRP.<br>toggle_en: DRP toggle<br>enable flag<br>try_src_en: Try.SRC<br>enable flag | Call status.                                         |
| dpm_get_polarity         | Get the current polarity of the Type-C connection                                                                                                                                                 | port: Port to be queried.                                                                                                                                                                  | 0 if CC1 is<br>connected<br>1 if CC2 is<br>connected |
| dpm_typec_deassert_rp_rd | De-assert both Rp and Rd on the specified PD port.                                                                                                                                                | port: Port to be updated.<br>channel: Channel on<br>which terminations are to<br>be disabled.                                                                                              | Call status.                                         |
| dpm_update_port_status   | Update the USB-PD port status that will be returned by CCG as part of a Get_Status response.                                                                                                      | port: Port to be updated.<br>input: Present power<br>input status<br>battery: Present battery<br>status.                                                                                   | None                                                 |
| dpm_update_ext_src_cap   | Updated the Extended Source<br>Capabilities returned by the<br>CCG device.                                                                                                                        | port: Port to be updated.<br>buf_p: Pointer to buffer<br>containing the extended<br>source capabilities.                                                                                   | None                                                 |
| dpm_update_frs_enable    | Update the Fast-Role Swap<br>feature support in the CCG PD<br>state machines. The change will<br>only take effect after a fresh<br>contract negotiation.                                          | port: Port to be updated.<br>frs_rx_en: Whether FRS<br>receive is to be enabled.<br>frs_tx_en: Whether FRS<br>transmit is to be<br>enabled.                                                | None                                                 |



# 6.1.2 Host Processor Interface (HPI) API

This section documents the APIs provided by the HPI firmware module. Refer to the *src/hpi/hpi.h* file for details. Contact Cypress (<u>ccg\_sw@cypress.com</u>) for access to detailed Host Processor Interface (HPI) documentation.

#### Table 19: List of Host Processor Interface API

| Function                        | Description                                                                                                                                                                                                                    | Parameters                                                                                              | Return                                                                   |
|---------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|
| hpi_init                        | Initialize the HPI protocol module.<br>The serial block index to be used<br>is specified as parameter.<br>However, arbitrary change to the<br>SCB block will not work as the<br>SCB used in the bootloader<br>binary is fixed. | scb_idx: SCB index to be used.                                                                          | None                                                                     |
| hpi_send_fw_ready_event         | Send a firmware ready (device<br>out of reset) notification to the EC<br>through the HPI interface.                                                                                                                            | None                                                                                                    | None                                                                     |
| hpi_set_fixed_slave_addr<br>ess | Configure the HPI slave address<br>to a fixed value. If this API is not<br>called, the HPI slave address is<br>determined based on the state of<br>the I2C_CFG pin.<br>This should be called before                            | slave_addr: Desired<br>slave address minus the<br>read/write bit.                                       | None                                                                     |
|                                 | hpi_init().                                                                                                                                                                                                                    |                                                                                                         |                                                                          |
| hpi_set_no_boot_mode            | Force the HPI interface to run in<br>no-boot mode. The device will not<br>support any flash update<br>commands in this case.<br>This should be called before<br>hpi_init().                                                    | Enable: Whether to enable no-boot mode.                                                                 | None                                                                     |
| hpi_task                        | HPI task handler. HPI commands<br>are queued in ISR and handled<br>here. This should be called<br>periodically from the main<br>application.                                                                                   | None                                                                                                    | None                                                                     |
| hpi_reg_enqueue_event           | Send an event notification to the EC.                                                                                                                                                                                          | section: Specifies the<br>PD port corresponding<br>to the event.<br>status: Type of event to            | true if the event<br>was queued.<br>false if event was<br>dropped due to |
|                                 |                                                                                                                                                                                                                                | send.<br>length: Length of data<br>associated with the<br>event.                                        | queue overflow.                                                          |
|                                 |                                                                                                                                                                                                                                | data: Buffer containing event data.                                                                     |                                                                          |
| hpi_pd_event_handler            | HPI handler for stack event<br>notifications. The solution layer<br>can call this function on getting<br>event notifications from the PD<br>stack.                                                                             | port: Port on which<br>event occurred.<br>evt: Type of event.<br>data: Event data<br>provided by stack. | None                                                                     |



| Function                | Description                                                         | Parameters                                         | Return                                        |
|-------------------------|---------------------------------------------------------------------|----------------------------------------------------|-----------------------------------------------|
|                         | •                                                                   |                                                    |                                               |
| hpi_update_versions     | Update the HPI version registers.<br>See section 5.3                | bl_version: Boot-loader version.                   | None                                          |
|                         |                                                                     | fw1_version: FW1 version.                          |                                               |
|                         |                                                                     | fw2_version: FW2 version.                          |                                               |
| hpi_set_mode_regs       | Update the HPI registers that report device mode.                   | dev_mode: Device mode register value.              | None                                          |
|                         |                                                                     | mode_reason: Boot<br>mode reason register<br>value |                                               |
| hpi_update_fw_locations | Update the firmware locations in HPI registers.                     | fw1_location: Location of FW1 image.               | None                                          |
|                         |                                                                     | fw2_location: Location of FW2 image.               |                                               |
| hpi_sleep_allowed       | Check if the HPI interface is idle, so that device can go to sleep. | None                                               | true if sleep is<br>allowed.                  |
|                         |                                                                     |                                                    | false if HPI is<br>busy.                      |
| hpi_sleep               | Prepare the HPI interface for device deep sleep.                    | None                                               | true if sleep<br>preparation is<br>completed. |
|                         |                                                                     |                                                    | false if HPI is<br>busy.                      |
| hpi_get_port_enable     | Check whether PD ports are enabled.                                 | None                                               | Port enable bit map.                          |

# 6.1.3 Application Layer API

Table 20 lists the application layer APIs provided by the CCGx SDK. These function declarations and definitions can be found under the *src/app* folder.

| Function          | Description                                                                                                                                                 | Parameters                                                                                             | Return                                         |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|------------------------------------------------|
| app_init          | Initializes the application layer for operation.                                                                                                            | None                                                                                                   | None                                           |
| app_task          | Perform application layer<br>tasks. This includes VDM<br>handling and alternate mode<br>implementation.                                                     | port: Port on which the application task is to be performed.                                           | 1 if successful.<br>0 if failure               |
| app_event_handler | Application level handler for<br>PD stack events. This<br>updates the internal<br>application state, and then<br>calls the solution level event<br>handler. | port: Port on which event<br>occurred.<br>evt: Type of event.<br>dat: Event data provided by<br>stack. | None                                           |
| app_get_status    | Get the current application status information.                                                                                                             | port: Port to be queried.                                                                              | Pointer to<br>application status<br>structure. |

Table 20: List of Application Layer APIs



Customizing the Firmware Application

| Function         | Description                                                                                                                                                                                                                                                                          | Parameters                                                                                                                                                                                 | Return                                                                          |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|
| app_sleep        | Check whether the application layer is ready for device low power mode.                                                                                                                                                                                                              | None                                                                                                                                                                                       | true if application<br>layer is idle.<br>false if application<br>layer is busy. |
| app_wakeup       | This is called after device<br>wakes up from sleep, and can<br>be used to restore any state<br>that was saved as part of<br>sleep entry.                                                                                                                                             | None                                                                                                                                                                                       | None                                                                            |
| system_sleep     | Top level sleep mode entry<br>function. This should be<br>called from the main loop to<br>allow CCG device to<br>consume minimal power.                                                                                                                                              | None                                                                                                                                                                                       | None                                                                            |
| eval_src_cap     | Evaluates the source<br>capabilities advertised by the<br>port partner and identifies the<br>optimal power contract<br>setting.                                                                                                                                                      | port: PD port on which SRC.<br>CAP has been received.<br>src_cap: Source capabilities<br>that were received.<br>app_resp_handler: Callback<br>function to be called to<br>report decision. | None                                                                            |
| eval_rdo         | Evaluate a PD request (RDO)<br>received and decide whether<br>to accept/reject.                                                                                                                                                                                                      | port: PD port on which<br>request has been received.<br>rdo: Received RDO value.<br>app_resp_handler: Callback<br>function to be called to<br>report decision.                             | None                                                                            |
| psnk_set_voltage | Power sink (consumer)<br>handler for voltage change.<br>Default implementation sets<br>up the OVP voltage level<br>based on the provided<br>voltage.                                                                                                                                 | port: Port to be updated.<br>volt_50mV: Expected VBus<br>voltage in 50 mV units.                                                                                                           | None                                                                            |
| psnk_set_current | Power sink (consumer)<br>handler for operating current<br>change. The default<br>implementation does not do<br>anything.                                                                                                                                                             | port: Port to be updated.<br>cur_10 mA: Expected<br>operating current in 10 mA<br>units.                                                                                                   | None                                                                            |
| psnk_enable      | Enable the power sink path.                                                                                                                                                                                                                                                          | port: Port to be updated.                                                                                                                                                                  | None                                                                            |
| psnk_disable     | Disable the power sink path.                                                                                                                                                                                                                                                         | port: Port to be updated.                                                                                                                                                                  | None                                                                            |
| psrc_set_voltage | Set the desired voltage for<br>the power source (provider)<br>output. This function is<br>expected to make the<br>regulator updates as well as<br>set the OVP thresholds based<br>on the voltage.<br>This can be updated if the<br>voltage selection mechanism<br>should be changed. | port: Port to be updated.<br>volt_50mV: Expected VBus<br>voltage in 50 mV units.                                                                                                           | None                                                                            |



Customizing the Firmware Application

| Function           | Description                                                                                                  | Parameters                                                                                                                                | Return                                                      |
|--------------------|--------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|
| psrc_set_current   | Set the current level for the<br>power source output. The<br>default implementation does<br>not do anything. | port: Port to be updated.<br>cur_10mA: Expected<br>operating current in 10 mA<br>units.                                                   | None                                                        |
| psrc_enable        | Enable the power source output.                                                                              | port: Port to be updated.                                                                                                                 | None                                                        |
| psrc_disable       | Disable the power source output.                                                                             | port: Port to be updated.                                                                                                                 | None                                                        |
| vconn_enable       | Enable the VConn supply.<br>The VConn FET is internal to<br>CCG4 device.                                     | port: Port to be updated.                                                                                                                 | Call status.                                                |
| vconn_disable      | Disable the VConn supply.                                                                                    | port: Port to be updated.                                                                                                                 | Call status.                                                |
| vconn_is_present   | Check whether VConn supply is present.                                                                       | port: Port to be queried.                                                                                                                 | true if VConn is<br>present<br>false if VConn is<br>absent. |
| vbus_is_present    | Check whether VBus is present within a specific range.                                                       | port: Port to be queried.<br>volt: Expected VBus<br>voltage.<br>per: Allowed variance in<br>voltage as percentage of<br>expected voltage. | true if VConn is<br>present<br>false if VConn is<br>absent. |
| vbus_discharge_on  | Enable the VBus discharge path.                                                                              | port: Port to be updated.                                                                                                                 | None                                                        |
| vbus_discharge_off | Disable the VBus discharge path.                                                                             | port: Port to be updated.                                                                                                                 | None                                                        |
| eval_dr_swap       | Evaluate a DR_SWAP request from the port partner.                                                            | port: Port to be updated.<br>app_resp_handler: Callback<br>function to be called to<br>report decision.                                   | None                                                        |
| eval_pr_swap       | Evaluate a PR_SWAP request from the port partner.                                                            | port: Port to be updated.<br>app_resp_handler: Callback<br>function to be called to<br>report decision.                                   | None                                                        |
| eval_vconn_swap    | Evaluate a VCONN_SWAP request from the port partner.                                                         | port: Port to be updated.<br>app_resp_handler: Callback<br>function to be called to<br>report decision.                                   | None                                                        |
| vdm_data_init      | Initialize the VDM handler<br>data structure with data from<br>configuration table.                          | port: Port to be updated.                                                                                                                 | None                                                        |



| Function        | Description                                                | Parameters                                                                                                                                                                                                                                                                                                                                                                                                                  | Return |
|-----------------|------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|
| vdm_update_data | Update the VDM handler data<br>structure with custom data. | port: Port to be updated.<br>id_vdo_cnt: Number of DOs<br>in Discover ID response.<br>id_vdo_p: Array containing<br>the Discover ID response.<br>svid_vdo_cnt: Number of<br>DOs in Discover SVID<br>response.<br>svid_vdo_p: Array<br>containing the Discover<br>SVID response.<br>mode_resp_len: Total<br>length of all Discover Mode<br>responses.<br>mode_resp_p: Array<br>containing actual Discover<br>Mode responses. | None   |
| eval_vdm        | Evaluate a received PD VDM and respond to it.              | port: Port on which VDM is<br>received.<br>vdm: Received VDM<br>pointer.<br>vdm_resp_handler:<br>Callback to be notified<br>about the VDM response.                                                                                                                                                                                                                                                                         | None   |
| app_ovp_enable  | Enable the Over-Voltage<br>Protection function.            | Port: Port on which OVP is<br>to be enabled.<br>volt_50mV: Allowed<br>maximum voltage in 50 mV<br>units.<br>pfet: Whether the CCG<br>device is power source.<br>ovp_cb: Callback function to<br>be called when OVP is<br>detected.                                                                                                                                                                                          | None   |
| app_ovp_disable | Disable the OVP function on a PD port.                     | port: Port on which OVP is<br>to be disabled.<br>pfet: Whether CCG is a<br>power source at this time.                                                                                                                                                                                                                                                                                                                       | None   |

lists the functions that the PD stack and application layer expect to be implemented at the solution level. These functions must be implemented in the source files within the PSoC Creator project workspace. If the target application does not require one or more of these functions; a stub implementation that does nothing should still be provided.



#### Customizing the Firmware Application Table 21: Solution-level Functions

| Function             | Description                                                                                                                                                                                                                                                                                | Parameters                                                                                                                                                  | Return                                                                                                                                            |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| mux_ctrl_init        | Initialize the Type-C switch<br>and corresponding control<br>interface. The Type-C data<br>pins should be isolated from<br>the USB and DisplayPort<br>controller pins at this stage.                                                                                                       | port: Port to be<br>updated.                                                                                                                                | true if successful.<br>false if failure                                                                                                           |
| mux_ctrl_set_cfg     | Update the Type-C switch to<br>enable/disable the desired<br>USB and DisplayPort<br>connections.                                                                                                                                                                                           | port: Port to be<br>updated.<br>cfg: Desired data<br>connection mode.<br>polarity: Polarity of<br>current Type-C<br>connection. 0 for CC1<br>and 1 for CC2. | true if successful.<br>false if failure                                                                                                           |
| sln_pd_event_handler | This is top level handler for<br>system event notifications<br>provided by the PD stack.<br>The default implementation of<br>this function calls the HPI<br>event handler so that the EC<br>can be notified about these<br>events.                                                         | port: Port on which<br>event occurred.<br>evt: Type of event.<br>data: Event data<br>provided by stack.                                                     | None                                                                                                                                              |
| app_get_callback_ptr | Function that returns a<br>structure filled with callback<br>function pointers for various<br>system events. Default<br>implementations for all of<br>these functions are provided<br>under the app folder, and the<br>structure can be initialized<br>with the corresponding<br>pointers. | port: Port to be<br>queried.                                                                                                                                | Pointer to structure<br>containing callback<br>function pointers. This<br>structure should<br>remain valid<br>throughout the device<br>operation. |

# 6.1.4 Alternate Mode API

This section documents the alternate mode related API provided in the CCGx SDK. These APIs are defined in the sources under *src/app/alt\_mode* and are summarized in Table 22.

#### Table 22: List of Alternate Mode APIs

| Function             | Description                                                                                                                                  | Parameters                   | Return                                                              |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|---------------------------------------------------------------------|
| enable_vdm_task_mngr | Enabled the alternate mode manager.                                                                                                          | port: Port to be updated.    | None                                                                |
| vdm_task_mngr_deinit | De-initialize the alternate mode manager.                                                                                                    | port: Port to be updated.    | None                                                                |
| is_vdm_task_idle     | Check if the alternate<br>mode manager is idle, so<br>that device can enter low<br>power mode. Each port<br>has to be queried<br>separately. | port: Port to be<br>queried. | true if the manager<br>is idle.<br>false if the manager<br>is busy. |
| vdm_task_mngr        | Alt. mode manager state machine task. This is called from app_task.                                                                          | port: Port to be serviced.   | None                                                                |



| Function     | Description                       | Parameters                                        | Return                        |
|--------------|-----------------------------------|---------------------------------------------------|-------------------------------|
| eval_rec_vdm | Evaluate VDM message<br>received. | port: Port to be updated.                         | true if VDM is to be ACKed.   |
|              |                                   | vdm_rcv: Pointer to<br>received attention<br>VDM. | false if VDM is to be NACKed. |
|              |                                   |                                                   |                               |
|              |                                   |                                                   |                               |
|              |                                   |                                                   |                               |
|              |                                   |                                                   |                               |

# 6.1.5 Hardware Adaptation Layer (HAL) API

This section documents the API provided as part of the Hardware Adaptation Layer (HAL), which provides drivers for various hardware blocks on the CCG device.

#### GPIO API

The PSoC Creator GPIO component and associated APIs can be used in all CCG projects. However, the SDK also provides a set of special API for reduced memory footprint. These APIs are defined in the *src/system/gpio.c* file and are summarized in Table 23.

#### Table 23: List of GPIO APIs

| Function              | Description                                                                                                                          | Parameters                                                                                                                                 | Return                                                                  |
|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|
| hsiom_set_config      | Update the IO matrix configuration for a given pin.                                                                                  | port_pin: CCG pin identifier.<br>hsiom_mode: Desired IO<br>configuration                                                                   | None                                                                    |
| gpio_set_drv_mode     | Select GPIO drive mode for a given pin.                                                                                              | port_pin: CCG pin identifier.<br>drv_mode: Desired drive<br>mode                                                                           | None                                                                    |
| gpio_hsiom_set_config | Update IO matrix and drive mode for a given pin.                                                                                     | port_pin: CCG pin identifier.<br>hsiom_mode: Desired IO<br>configuration<br>drv_mode: Desired drive<br>mode<br>value: Desired output state | None                                                                    |
| gpio_int_set_config   | Configure interrupt<br>associated with a given<br>pin.                                                                               | port_pin: CCG pin identifier.<br>int_mode: Desired interrupt<br>configuration.                                                             | None                                                                    |
| gpio_set_value        | Update the output value of<br>a given pin. The IO<br>configuration and drive<br>mode for the pin should<br>have been set separately. | port_pin: CCG pin identifier.<br>value: Desired output state                                                                               | None                                                                    |
| gpio_read_value       | Get the current state of a given pin.                                                                                                | port_pin: CCG pin identifier.                                                                                                              | true if the pin is high.<br>false if the pin is low.                    |
| gpio_get_intr         | Check if there is an active interrupt associated with the given pin.                                                                 | port_pin: CCG pin identifier.                                                                                                              | true if interrupt is<br>active.<br>false if interrupt is not<br>active. |



Customizing the Firmware Application

| Function        | Description                                         | Parameters                    | Return |
|-----------------|-----------------------------------------------------|-------------------------------|--------|
| gpio_clear_intr | Clear any interrupts associated with the given pin. | port_pin: CCG pin identifier. | None   |

# I2C API

The Serial Communication Block component in PSoC Creator can be used with the CCG device. However, the SDK provides a dedicated I<sup>2</sup>C slave mode driver, which is optimized for HPI implementation. These API definitions are provided in *src/scb/i2c.c* and are summarized in Table 24.

| Function              | Description                                                                   | Parameters                                                                            | Return                      |
|-----------------------|-------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|-----------------------------|
| i2c_scb_init          | Initialize the I2C slave block and set driver                                 | scb_index: SCB index to be used.<br>mode: Mode of I2C block operation.                | None                        |
|                       | parameters.                                                                   | clock_freq: Expected bit rate on the interface.                                       |                             |
|                       |                                                                               | slave_addr: Slave address to be used.                                                 |                             |
|                       |                                                                               | slave_mask: Mask to be applied on<br>the slave address to detect I2C<br>addressing.   |                             |
|                       |                                                                               | cb_fun_ptr: Callback function to be<br>called for read/write/error<br>notifications.  |                             |
|                       |                                                                               | scratch_buffer: Pointer to scratch<br>buffer to be used to received<br>incoming data. |                             |
|                       |                                                                               | scratch_buffer_size: Size of scratch<br>buffer.                                       |                             |
| i2c_scb_write         | Write data into the I2C                                                       | scb_index: SCB index to be used.                                                      | None                        |
|                       | block transmit FIFO.                                                          | source_ptr: Location of data to be written.                                           |                             |
|                       |                                                                               | size: Size of data to be written.<br>Should be 8 bytes or lesser.                     |                             |
|                       |                                                                               | count: Return parameter indicating actual size of data written.                       |                             |
| i2c_reset             | Reset the I2C block.                                                          | scb_index: SCB index to be used.                                                      | None                        |
| i2c_slave_ack_ctrl    | Used to enable/disable                                                        | scb_index: SCB index to be used.                                                      | None                        |
|                       | clock stretching in the device address stage.                                 | enable: Enable device address<br>acknowledgement.                                     |                             |
| i2c_scb_is_idle       | Check whether the I2C module is idle.                                         | scb_index: SCB index to be used.                                                      | true if the block is idle.  |
|                       |                                                                               |                                                                                       | false if the block is busy. |
| i2c_scb_enable_wakeup | Enable I2C device<br>addressing as a wakeup<br>source from low power<br>mode. | scb_index: SCB index to be used.                                                      | None                        |



#### Flash API

The flash API provides the core functionality used for CCG configuration and firmware updates. These are wrappers over the PSoC Creator provided flash APIs, and implement checks to ensure that a firmware binary is not corrupted by writing while it is being accessed. The flash related API are defined in *src/system/flash.c* and are summarized in Table 25.

| Function                | Description                                                                                                                                                                                             | Parameters                                                                                                                                                                                                                                                     | Return                                                     |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|
| flash_enter_mode        | Enable flash updates<br>through the specified<br>interface. Flash updates<br>are only allowed through<br>one interface (I2C, CC<br>etc.) at a time.                                                     | is_enable: Whether to enable or<br>disable flash access.<br>mode: Flash access interface                                                                                                                                                                       | None                                                       |
| flash_access_enabled    | Check whether flash<br>access through any of the<br>specified interfaces is<br>enabled.                                                                                                                 | modes: Bitmap representing the flash interfaces to be checked.                                                                                                                                                                                                 | true if flash<br>access is<br>enabled.<br>false otherwise. |
| flash_set_access_limits | Set limits regarding the<br>flash rows that can be<br>accessed. The firmware<br>application should<br>identify the memory<br>range that it is using,<br>and use this API to<br>protect it from updates. | start_row: Lowest flash row that can<br>be accessed.<br>last_row: Highest flash row that can<br>be accessed.<br>md_row: Metadata row that can be<br>accessed.<br>bl_last_row: Last row used by boot-<br>loader. Any flash row above this<br>value can be read. | None                                                       |
| flash_row_clear         | Clear the contents of the specified flash row.                                                                                                                                                          | row_num: Row to be cleared.                                                                                                                                                                                                                                    | Flash erase<br>status                                      |
| flash_row_write         | Write the desired<br>content into a flash row.<br>This is a blocking<br>operation.                                                                                                                      | row_num: Flash row to be updated.<br>data: Buffer containing flash data.<br>cbk: Must be zero as non-blocking<br>writes are not supported by the<br>device.                                                                                                    | Flash write<br>status                                      |
| flash_row_read          | Read the content of a<br>flash row into the<br>provided buffer.                                                                                                                                         | row_num: Flash row to be read.<br>data: Buffer to read the data into.                                                                                                                                                                                          | Flash read<br>status.                                      |

#### Table 25: List of flash API

#### Timer API

The CCG firmware stack uses a soft timer implementation for various timing measurements. The soft timer granularity is 1 ms, and it uses a single hardware timer. If the timer block used is WDT (WatchDog Timer), the timers can be used across device sleep modes; and it is possible to use a tickless implementation which reduces interrupt frequency. The soft timer related API are defined in *src/system/timer.c* and are summarized in Table 26.

#### Table 26: List of timer API

| Function   | Description                                                                                  | Parameters | Return |
|------------|----------------------------------------------------------------------------------------------|------------|--------|
| timer_init | Initialize the timer module.<br>This enables the<br>hardware timer and<br>interrupt as well. | None       | None   |



| Function          | Description                                     | Parameters                                                                                                                                                                                                                                                                                        | Return                                       |
|-------------------|-------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|
| timer_start       | Start one soft<br>timer (one<br>shot).          | <ul> <li>instance: Soft timer group or instance.</li> <li>Separate timer groups are maintained for<br/>each PD port.</li> <li>id: ID of timer to be started. Timer IDs are<br/>assigned statically.</li> <li>period: Timer period in milliseconds.</li> <li>cb: Timer expiry callback.</li> </ul> | true if<br>successful.<br>false if failure.  |
| timer_stop        | Stop a running soft timer.                      | instance: Soft timer group or instance.<br>id: ID of timer to be stopped.                                                                                                                                                                                                                         | None                                         |
| timer_is_running  | Check whether a soft timer is running.          | instance: Soft timer group or instance.<br>id: ID of timer to be queried.                                                                                                                                                                                                                         | true if running.<br>false if not<br>running. |
| timer_stop_all    | Stop all soft timers in a group.                | instance: Timer group to be stopped.                                                                                                                                                                                                                                                              | None                                         |
| timer_stop_range  | Stop all soft timers whose IDs fall in a range. | instance: Timer group to be stopped.<br>start: Lowest timer ID to be stopped.<br>stop: Highest timer ID to be stopped.                                                                                                                                                                            | None                                         |
| timer_num_active  | Get number of active timers in a group.         | instance: Soft timer group or instance.                                                                                                                                                                                                                                                           | Count of active timers.                      |
| timer_enter_sleep | Prepare the timer module for sleep entry.       | None                                                                                                                                                                                                                                                                                              | None                                         |

# 6.1.6 Firmware Update API

CCG application support firmware updates through interfaces like HPI (I2C) and CC (Unstructured VDMs). The firmware update APIs are common functions that are used by each of these protocol modules to implement the firmware update functionality.

The firmware update related API are defined in *src/system/boot.c* and are summarized in Table 27.

#### Table 27: Firmware Update API

| Function                  | Description                                                                                           | Parameters                                                           | Return                               |
|---------------------------|-------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|--------------------------------------|
| boot_validate_fw          | Validate the firmware image in device flash.                                                          | fw_metadata: Pointer to<br>metadata regarding the<br>firmware image. | Valid/invalid<br>status.             |
| boot_validate_configtable | Validate the configuration table in device flash.                                                     | table_p: Pointer to the configuration table.                         | Valid/invalid<br>status.             |
| get_boot_mode_reason      | Compute the boot mode<br>reason register value by<br>validating firmware and<br>configuration tables. | None                                                                 | Boot mode<br>reason bitmap<br>value. |
| boot_get_boot_seq         | Get the flash sequence<br>number associated with a<br>given firmware binary.                          | fwid: ID of firmware binary to be queried.                           | Flash<br>sequence<br>number value.   |
| sys_set_device_mode       | Set the current firmware mode for the CCG device.                                                     | fw_mode: Firmware mode to be set.                                    | None                                 |
| sys_get_device_mode       | Get the current firmware mode for the CCG device.                                                     | None                                                                 | Current firmware mode.               |



# 6.2 API Usage Examples

This section provides a few examples for the usage of the APIs documented under Section 6.1Refer to the API reference guide for more details.

Most of the PD operations are initiated using the  $dpm_pd_command()$  and  $dpm_typec_command()$  APIs. These APIs are non-blocking, and only initiate the operation. A callback function can be passed to the API; and it will be called on completion of the operation. Completion of these operations will require the tasks in the main loop to be executed, and therefore, the caller cannot block waiting for the callback to arrive.

If there is a need to wait for the operation to complete and then initiate other operations, this can be done in two ways:

- 6. Initiate the follow-on operations from the callback function itself.
- 7. Modify the main loop to detect the callback arrival, and then initiate the next operation after this.

#### 6.2.1 Boot API Usage

The bootloader and firmware application communication in the CCGx SDK is built using the PSoC Creator Bootloader and Bootloadable components. This section shows how the PSoC Creator bootloader and bootloadable components along with the wrapper APIs in the SDK to transfer control from the application firmware to the bootloader or to the application in the alternate memory bank.

#### Perform Device Reset

Since the order in which the bootloader prioritizes firmware images is fixed, resetting the device causes the device to boot back into the same mode that it previously was in. The CySoftwareReset() API can be used to initiate a CCG device reset.

#### Jump to Bootloader

This operation is not required because firmware update and flash read functionality is provided by the application firmware itself. Also, the bootloader is a fixed binary application which cannot be updated to include additional functionality.

However, you can use the Bootloadable component API to transfer control to the bootloader from the application firmware. You can do this by specifying the boot type for the next run using the Bootloadable\_SET\_RUN\_TYPE() macro and then initiating a reset using CySoftwareReset().

```
/* Include relevant header files. */
#include <project.h>
#include <boot.h>
void jump_to_bootloader(void)
{
    /* Select the boot mode for the next run. */
    Bootloadable_SET_RUN_TYPE(CCG_BOOT_MODE_RQT_SIG);
    /* Initiate device reset. */
    CySoftwareReset();
}
```



#### Jump to Alternate Firmware

As described in Chapter 5, the CCGx firmware projects are set up such that they generate two copies of the application firmware. While both of these copies are expected to be equivalent, there may be cases where you need to use a fixed backup firmware along with a dynamically updated primary firmware. In such cases, it would be desirable to transfer control to the backup firmware in order to update the primary firmware.

The APIs shown in Section can also be used to transfer control to the alternate firmware binary. You will need to determine the identity of the current firmware binary (FW1 or FW2) and then initiate the switch accordingly.

```
/* Include relevant header files. */
#include <project.h>
#include <boot.h>
void jump to alternate fw(void)
{
      /* Set the next boot mode based on the current FW ID. */
      if (sys get device mode() == SYS FW MODE FWIMAGE 1)
      {
             Bootloadable SET RUN TYPE(CCG FW2 BOOT RQT SIG);
      }
      else
      {
             Bootloadable SET RUN TYPE(CCG FW1 BOOT RQT SIG);
      }
      /* Initiate device reset. */
      CvSoftwareReset();
}
```

#### **GPIO API Usage**

All of the APIs provided by the PSoC Creator Pins component can be used in CCGx firmware solutions. In addition to these, specific APIs to perform common GPIO functions are provided in the CCGx SDK. The list of GPIO APIs is provided in Section .

#### Configuring a CCGx Pin as an Edge Triggered Interrupt Input

The gpio\_hsiom\_set\_config() API is used to set the I/O mapping and drive mode settings for a given CCGx pin. The gpio\_int\_set\_config() API is used to enable interrupt functionality on a CCGx pin. The following code snippet shows how the pin P3[1] on CCGx can be configured as an input signal triggering interrupts on a falling edge.

```
/* We are using P3.1 as the interrupt pin. */
#define INTR_GPIO_PORT_PIN (GPIO_PORT_3_PIN_1)
/* The ISR vector number corresponds to PORT3. */
#define CCGX_PORT3_INTR_NO (3u)
/* ISR for the GPIO interrupt. */
CY_ISR(gpio_isr)
{
    /* Clear the interrupt. */
    gpio_clear_intr(INTR_GPIO_PORT_PIN);
    /* Custom interrupt handling actions here. */
    ...;
```



#### Connecting a pin to the internal ADC

Refer to the CCGx device datasheet to identify pins that can be connected to the internal ADC blocks through the Analog MUX configuration. The hsiom\_set\_config() API can be used to connect a specific pin to the ADC.

```
#define VBUS_MON_PORT_PIN (GPIO_PORT_3_PIN_1)
void connect_vbus_mon_to_adc (void)
{
    /* Connect the pin to AMUXB. */
    hsiom_set_config (VBUS_MON_PORT_PIN, HSIOM_MODE_AMUXB);
}
```

#### 6.2.2 Timer API Usage

The CCGx SDK provides a soft timer module, which can be used for task scheduling. The timer APIs allow users to create one-shot timer objects with callback notification on timer expiry.

Soft timers are identified using a single byte timer ID, and the caller should ensure that the timer ID used does not collide with timers used elsewhere. This is facilitated by reserving the timer ID range from 0xE0 to 0xFF for use by user application code. These timer IDs are not used internally within the CCGx firmware stack and are safe for use.

A soft timer is started using the timer start () API and can be aborted using the timer stop () API.

```
#define APP_TIMER_ID (0xF0)
static void timer_expiry_callback(uint8_t instance, timer_id_t id)
{
    /* Start the desired task here. */
    ...;
}
/* Use a timer to schedule task to be run delay_ms milliseconds later. */
void schedule_task(uint16_t delay_ms)
{
    /* Start an application timer to wait for delay_ms. */
    /* Devices with two USB-PD ports support two sets of timers, and
    the set to be used is selected using the first parameter. */
    timer_start(0, APP_TIMER_ID, delay_ms, timer_expiry_callback);
}
```



### 6.2.3 HPD API Usage

The *HotPlugDetect* output pin from CCGx is used in Notebook implementations to signal interrupts from the far-end DisplayPort (DP) peripheral to the DP controller in the Notebook system. The DP peripheral will signal HPD events to the CCGx Notebook controller through PD messages, and CCGx will relay these HPD events to the DP controller through the GPIO output.

The hpd\_transmit\_init() and hpd\_transmit\_sendevt() APIs are used to initialize the HPD transmit logic and to send event notifications to the DP controller respectively.

```
/* Callback that notifies user of completion of HPD signaling. */
static void hpd callback(uint8 t port, hpd event type t event)
{
       if (event == HPD COMMAND DONE)
       {
             /* Requested HPD command is complete. */
       }
}
/* Initialize the HPD transmit logic for USB-PD port 0, and register
   the command completion callback. */
void initialize hpd logic (void)
{
       hpd transmit init(0, hpd callback);
}
/* Send HPD IRQ to the DP controller. */
void send hpd irq(void)
{
       /* Asynchronous mode: Do not wait for completion. */
       hpd transmit sendevt(0, HPD EVENT IRQ, false);
}
```

# 6.2.4 Sleep Mode Control

The decision to enter device deep sleep mode to save power is made at the application level. The system\_sleep() function call in the main loop can be disabled if deep sleep mode entry is to be disabled.

# 6.2.5 DPM API Usage

#### Enabling a PD port

The  $dpm\_start()$  API can be used to enable a PD port for operation. The  $dpm\_init()$  API should have been called prior to doing this.

```
bool enable_pd_port(uint8_t port)
{
    if (dpm_start(port) == 0)
    {
        /* DPM start failed. Handle errors. */
        return (false);
    }
    return (true);
}
```

# Disabling a PD port

The  $dpm\_stop()$  API should not be used to directly disable a PD port, as the port might already be in contract. The  $dpm\_typec\_command()$  API should be used initiate the DPM\_CMD\_PORT\_DISABLE command. This will ensure that the port is disabled safely and the VBus voltage is discharged to a safe level, before the completion callback is issued.



```
Customizing the Firmware Application
static volatile bool pd disable completed = true;
static volatile bool pd disable issued = false;
/* Callback for the PD disable command. */
static void pd_port_disable_cb(uint8_t port, dpm_typec_cmd_resp_t resp)
{
      pd disable completed = true;
      /* Other APIs can be started here, if required. */
}
bool disable pd port(uint8 t port)
{
       /* Store state of operation. */
      pd disable issued = true;
      pd_disable_completed = false;
       /* Initiate port disable. */
       if (dpm typec command(port, DPM CMD PORT DISABLE,
                    pd port disable cb) != CCG STAT SUCCESS)
       {
             /* Handle error here. */
             pd disable issued = false;
             return false;
       }
       /* Port disable has been queued. We cannot block for callback.
         Wait for callback in the main loop.
       */
      return true;
}
int main ()
{
       /* Init tasks here. */
       ...;
       while (1)
       {
             /* Call regular task handlers (DPM, APP, HPI) here. */
             . . . ;
             if ((pd disable issued) && (pd disable completed))
             {
                    /* Port is now disabled. */
                    . . . ;
                    pd disable issued = false;
             }
      }
}
```



# Sending a DISCOVER\_ID VDM

The  $dpm_pd_command()$  API should be used to send VDMs and other PD commands to the port partner. The send operation is non-blocking and the completion callback will notify that the operation is complete. Note that the main loop should continue to run for proper completion of the VDM operation.

```
static volatile bool
                        abort cmd = false;
static dpm pd cmd buf t cmd buf;
static void pd command cb(uint8 t port, resp status t resp,
        const pd packet t *vdm ptr)
{
       uint32 t response;
       if (status == RES RCVD)
       {
             /* Response received. Check handshake. */
             response = vdm ptr->dat[0].std vdm hdr.cmd type;
             switch (response)
             {
                    case CMD TYPE RESP ACK:
                           /* ACK received. */
                           . . . ;
                           break;
                    case CMD TYPE RESP BUSY:
                           /* BUSY received. */
                           . . . ;
                           break;
                    case CMD TYPE RESP NAK:
                           /* NACK received. */
                           . . . ;
                           break;
             }
              /* Next operation can be started from here. */
       }
}
bool send discover id(uint8 t port)
{
       /* Store state of operation. */
       pd command issued
                          = true;
      pd command completed = false;
       /* Format the command parameters.
          Single DO with standard Discover ID command to SOP controller.
          Timeout is set to 100 ms.
        */
       cmd buf.cmd sop
                            = SOP;
       cmd buf.cmd do[0]
                           = 0xFF008001;
       cmd buf.no_of_cmd_do = 1;
       cmd buf.timeout
                           = 100;
       /* Initiate the command. Keep trying until accepted. */
       while (dpm pd command(port, DPM CMD SEND VDM,
```



# Getting Current PD Port Status

The Device Policy Manager interface layer in the CCGx PD stack maintains a status data structure that provides complete status information about the USB-PD port.

This structure can be retrieved using the  $dpm_get_info()$  API. The API returns a const pointer to a  $dpm_status_t$  structure which includes the following status fields:

- 1. attach: Specifies whether the port is currently attached.
- 2. cur port role: Specifies whether the port is currently a Source or a Sink

Customizing the Firmware Application

- 3. cur port type: Specifies whether the port is currently a DFP or an UFP
- 4. polarity: Specifies the Type-C connection polarity (CC1 or CC2 being used)
- 5. contract\_exist: Specifies whether a PD contract exists
- 6. contract: Specifies the current PD contract (voltage and current) information.
- 7. emca present: Specifies whether CCGx as DFP has detected a cable marker
- 8. src\_sel\_pdo: Specifies the PDO that CCGx as source used to establish contract
- 9. snk sel pdo: Specifies the Source Cap that CCGx as sink accepted to establish contract
- 10. src rdo: Specifies the RDO that CCGx received for PD contract
- 11. snk rdo: Specifies the RDO that CCGx as Sink sent for PD contract.

#### Issue a DR\_SWAP where required

CCGx in a Notebook Port controller application is expected to function as a DFP. You can check the current port type of the CCGx device and initiate a DR\_SWAP if CCGx is a UFP, so that we can ensure that the supported alternate modes can be enabled.

The current port type is checked as described in Section , and the dpm\_pd\_command() API can be used to initiate a DR\_SWAP.



```
} while (status == CCG_STAT_BUSY);
```

}

#### Change the Source Capabilities

}

The  $dpm_update_src_cap()$  and  $dpm_update_src_cap_mask()$  APIs can be used to update the source capabilities supported by CCGx.

At any time, CCGx can support a set of maximum seven source capabilities. These seven capabilities are maintained in the form of a the  $cur\_src\_pdo$  array in the  $dpm\_status\_t$  structure. A subset of these PDOs can be enabled at runtime using a PDO enable bit mask setting. The current PDO enable mask value can be read from the  $src\_pdo\_mask$  field of the  $dpm\_status\_t$  structure.

The PDO enable mask can be changed using the <code>dpm\_update\_src\_cap\_mask()</code> API.

The set of PDOs can be changed using the  $dpm\_update\_src\_cap()$  API. The PDO enable mask will also need to be updated after updating the set of PDOs.

```
/* Function to configure and enable a desired source PDO. */
void select source pdo(pd do t new pdo)
{
      const dpm status t *dpm stat = dpm get info (0);
      uint8 t index;
      bool pdo found = false;
      /* See if the new pdo is already part of the list. */
      for (index = 0; index < dpm stat->src pdo count; index++)
       {
             if (dpm stat->src pdo[index].val == new pdo.val)
              {
                    pdo found = true;
                    break;
             }
       }
      if (pdo_found)
       {
              /* PDO found. Just enable it. */
             dpm update src cap mask(0,
                    (dpm stat->src pdo mask | (1 << index)));</pre>
       }
      else
       {
              /* PDO not found, update the PDO list and enable it.
                Note: For this example, we are replacing the complete list
                with a single PDO. This needs be updated to retain the
                 other required PDOs.
              * /
             dpm update src cap(0, 1, &new pdo);
             dpm update src cap mask(0, 1);
      }
```

Refer to the Alternate Mode module source for more examples of using the DPM APIs.



# 6.2.6 Solution Level Examples

#### PD Event Handling

The PD events raised by the stack are handled at the solution level in the  $sln_pd_event_handler()$  function. In the normal case where policy decisions are handled through the EC, it is sufficient to pass the events onto the EC through the HPI interface. See below for a sample implementation of the event handler.

```
/* Solution PD event handler */
void sln_pd_event_handler(uint8_t port, app_evt_t evt, const void *data)
{
    /* Pass the event onto the EC through HPI. */
    hpi_pd_event_handler(port, evt, data);
}
```

#### Application Callback Registration

The application callbacks that handle various operations requested by the PD stack are registered through a structure that contains pointers to all the functions. The callbacks are registered using the  $app_get_callback_ptr()$  function. A sample implementation of this function is shown below.

```
/*
 * Application callback functions for the DPM. Since this application
  * uses the functions provided by the stack, loading with the stack defaults.
  */
const app cbk t app callback =
{
        app_event_handler, /* Event handler. */
       psrc_set_voltage,
                                                     /* Source voltage update function. */
       psrc_set_voltage, / Source voltage update function. //
psrc_set_current, /* Source current update function. */
psrc_enable, /* Enable source FET. */
psrc_disable, /* Disable source FET. */
vconn_enable, /* Enable VConn supply. */
vconn_is_present, /* Check if VConn is present. */
vbus_is_present, /* Check if VBus is in the expected rate
is present, /* Check if VBus is in the expected rate
is present, /* Check if VBus is in the expected rate
is present, /* Check if VBus is in the expected rate
is present, /* Check if VBus is in the expected rate
is present, /* Check if VBus is in the expected rate
is present, /* Check if VBus is in the expected rate
is present, /* Check if VBus is in the expected rate
is present, /* Check if VBus is in the expected rate
is present.
                                                    /* Check if VBus is in the expected range. */
        vbus_ischarge_on,
                                                   /* Enable VBus discharge path. */
        vbus_discharge_off, /* Disable VBus discharge path. */
       psnk_set_voltage, /* Set sink voltage. */
psnk_set_current, /* Set sink current. */
                                           /* Enable sink FET. */
/* Disable sink FET. */
/* Evaluate source power capabilities. */
/* Evaluate partner power request. */
/* Evaluate partner power request. */
        psnk enable,
        psnk disable,
        eval src cap,
        eval rdo,
       eval_dr_swap, /* Evaluate DR_SWAP command. */
eval_pr_swap, /* Evaluate PR_SWAP command. */
eval_vconn_swap, /* Evaluate VCONN_SWAP command. */
eval_vdm /* Evaluate VCONN_SWAP command. */
                                                     /* Evaluate received VDM. */
        eval vdm
};
app cbk t* app get callback ptr(uint8 t port)
{
        /* Solution callback pointer is same for all ports */
        (void)port;
        return ((app cbk t *)(&app callback));
}
```



#### Change the Source PDO selection logic

The eval\_src\_cap() callback function is invoked by the PD stack on receiving source capabilities message from the Source. The default implementation of the same is available in *src/app/pdo.c*. This function can be overridden during application callback registration (Section ).

The  $eval\_src\_cap()$  and  $is\_src\_acceptable\_snk()$  functions in *src/app/pdo.c* can be used as template and a custom function can be implemented in the solution.

For example, If an additional check needs to be done for maximum current support in the source PDO, then this can be done by changing the  $eval\_src\_cap()$  callback function to  $my\_eval\_src\_cap()$ .

```
/* Custom function to check if the source PDO is acceptable or not. */
void my_is_src_acceptable_snk(uint8_t port, pd_do_t* pdo_src, uint8_t snk_pdo_idx)
{
    case PDO FIXED SUPPLY:
        if(fix volt == pdo snk->fixed snk.voltage)
        {
            compare_temp = GET_MAX (max_min_temp, pdo_snk->fixed_snk.op_current);
            if (pdo_src->fixed_src.max_current >= compare_temp)
            {
                /* Added new check for absolute maximum current. */
                if (pdo src->fixed src.max current <= MY MAX SNK CURRENT)
                 {
                     op cur_power[port] = pdo_snk->fixed_snk.op_current;
                     out = true;
                 }
            }
        }
        break;
    . . .
}
/* Function to evaluate source PDO message. */
void my eval src cap(uint8 t port, const pd packet t* src cap, app resp cbk t
       app resp handler)
{
    . . .
    for(snk pdo index = 0u; snk pdo index < dpm->cur snk pdo count;
              snk pdo index++)
   {
       for(src pdo index = 0u; src_pdo_index < num_src_pdo; src_pdo_index++)</pre>
       {
           if (my is src acceptable snk (port, (pd do t*) (&src cap-
       >dat[src pdo index]),
                    snk pdo index))
           {
               . . .
           }
           . . .
       }
   }
```

Refer to the notebook project source files (main.c) for more examples of the solution level code.



# 6.3 Alternate Mode Handling

Support for USB-PD alternate modes is a critical part of the CCG firmware functionality. Support for the DisplayPort alternate mode is pre-built into the Notebook and dongle applications. Users can add additional alternate mode support to the firmware. The procedure to add additional alternate mode handler to the firmware includes two steps:

- Implementing the handlers for the alternate modes. This includes code that will discover UFP capabilities and handle attention messages in a DFP role, and/or code that will receive and handle alternate mode requests as an UFP.
- 2. Registering the alternate mode handlers with the manager.

# 6.3.1 Implementing the Alternate Mode Handlers

The CCG firmware stack provides a generic alternate mode manager which holds information about the supported alternate modes. This manager will invoke the handler functions specific to the alternate modes registered in the firmware application.

When CCG is a DFP, the alternate mode manager will discover whether the connected UFP supports any alternate modes for which handlers have been registered; and then call the associated handler functions.

When CCG is a UFP, the alternate mode manager will check whether incoming VDMs correspond to any registered alternate modes; and then call the associated handler functions.

#### Alternate Mode Data Structure

The alt\_mode\_info\_t structure serves as the interface between the alternate mode manager and the handlers for each alternate mode. An array of such structures is maintained by the alternate mode manager. This structure incorporates the following fields:

| Field        | Туре                              | Description                                                                                                                                                                                     |
|--------------|-----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| mode_state   | enum alt_mode_state_t             | State of the alternate mode. Can be one of DISABLED,<br>IDLE, INIT, SEND_CMD, WAIT_FOR_RESP, FAIL or<br>EXIT.                                                                                   |
| sop_state[]  | Array of enum<br>alt_mode_state_t | Alternate mode state corresponding to each PD packet<br>type (SOP, SOP' and SOP"). This is useful in cases where<br>the alternate mode requires any EMCA cables to support<br>the mode as well. |
| vdo_max_numb | Unsigned char                     | Maximum number of VDOs that the alternate mode handler can handler.                                                                                                                             |
| alt_mode_id  | Unsigned char                     | The alternate mode id for this mode.                                                                                                                                                            |
| vdm_header   | pd_do_t                           | Holds the VDM header for the received messages.                                                                                                                                                 |
| vdo          | Array of pd_do_t pointers         | Pointers to buffers where alt. mode VDOs with various packet types should be stored. The storage is provided by the alternate mode handler and used by the manager.                             |
| cbk          | Function pointer                  | Callback used by alternate mode manager to invoke the specific alternate mode handler.                                                                                                          |

#### Table 28: List of alternate mode information structure members



#### Alternate Mode Handling Flow

The alternate mode handler uses the mode state to communicate (receive/send VDM) with alternate mode manager.

- IDLE state is responsible for received VDM processing;
- WAIT\_FOR\_RESP state is responsible for received VDM response processing;
- FAIL state is responsible for the failed VDM processing;
- INIT state is responsible for initialization of the alt mode (DFP only);
- EXIT state is responsible for de-initialization/exit of the alt mode (DFP only);
- SEND state should be set by alt mode to inform alt modes manager that a VDM packet is ready and should be sent to the port partner.

The alternate mode handler can use internal states to process the received VDM or VDM responses. These states are not used by the alternate mode manager.

# 6.3.1.1 DFP Handling

When alternate mode is DFP when main DFP state machine operates with five states:

- 1. The INIT state is used to initiate alternate mode handling. This state uses in two cases:
  - a. When DFP alternate mode registrations is successful and we need to initiate alternate mode handling.
  - b. When Alt modes manager initiates asynchronous entry of the alternate mode.
  - c. During initialization next steps should be done:
    - i. Set sop\_state array variables as ALT\_MODE\_STATE\_SEND in the dependence if SOP/SOP'/SOP" VDMs should be send while entering the mode
    - ii. Save pointers to the VDO buffer in the info structure
    - iii. Assign enter mode VDOs if needed
    - iv. Save alt mode DFP state machine function in the info structure
    - v. Save App command handler function in the info structure
    - vi. Set alternate mode state as enter
    - vii. Additional initialization code as required by the alternate mode.
  - 2. IDLE state is used to analyze received VDM related to the alt mode. When a VDM is received, the following steps should be completed:
    - a. Get the received command from VDM header
    - b. Run custom analysis of the received VDM
    - c. If a response VDM should be sent after analysis, then change the internal alternate mode state in compliance with the specific command number, fill the VDO buffer and set alternate mode state to the SEND state.
  - WAIT\_FOR\_RESP state is used to process/analyze received VDM response. When VDM response is received, next steps should be done:
    - a. Get internal alternate mode depending on command from VDM header
    - b. Set alternate mode state to IDLE
    - c. Analyze the received VDM response



- d. If another VDM should be sent based on the received response, then change the internal alternate mode state in compliance with the specific command number, fill the VDO buffer and set alternate mode state to the SEND state.
- 4. FAIL state is used to make decision when sent VDM was failed (e.g. NAKed response, Good CRC was not received etc.)
- 5. EXIT state is used when the alternate mode manager initiates asynchronous exit of the alternate mode. In this case, alternate mode should send exit mode command to the port partner.



Figure 31: Alternate mode handler state machine for DFP

# 6.3.1.2 UFP Handling

Alternate mode handling when CCG is UFP operates in one of two states:

- 1. IDLE state is used to analyze received VDMs related to the alternate mode. When a VDM is received, the following should be done:
  - a. Analyze the VDM based on the alternate mode rules.
  - b. If the VDM received is valid and an ACK response is to be sent, then set alternate mode state to IDLE.
  - c. If an alternate mode specific response is to be returned, fill the vdo array with data to be sent and set the alternate mode state to SEND.
- 2. WAIT\_FOR\_RESP state is used to process/analyze received VDM responses. When a VDM response is received, the following steps should be performed:
  - a. Get internal alternate mode depending on command from VDM header



- b. Set alternate mode state to IDLE
- c. Analyze the response received
- d. If another VDM should be sent after analysis (e.g. attention), then change the internal alternate mode state in compliance with the specific command number, fill the VDO buffer and alternate mode state to the SEND state.



#### Figure 32: Alternate mode handler state machine for UFP

# 6.3.2 Registering the Alternate Mode Handlers

- 1. Update the alt\_modes\_config.h header file in the project to include information about the alternate modes to be supported. This file contains the following definitions which need to be updated.
  - a. DFP\_MAX\_SVID\_SUPP: This constant determines the number of distinct alternate modes supported by CCGx in a DFP role. The number should be less than or equal to 4. If this is non-zero, please ensure that the DFP\_ALT\_MODE\_SUPP setting in config.h is set to 1.



- b. UFP\_MAX\_SVID\_SUPP: This constant determines the number of distinct alternate modes supported by CCGx in an UFP role. The number should be less than or equal to 4. If this is non-zero, please ensure that the UFP\_ALT\_MODE\_SUPP setting in config.h is set to 1.
- c. supp\_svid\_tbl: This array holds the list of SVIDs for the alternate modes supported by the CCG device in either DFP or UFP roles.

e.g: If the design supports two alternate modes with SVIDs SVID1 and SVID2, the table should be initialized as follows:

```
const uint16_t supp_svid_tbl[2] =
{
    SVID1,
    SVID2
};
```

d. is\_alt\_mode\_allowed: This array holds a list of pointers to functions which initialize the corresponding alternate mode operation. The entries in this array should correspond to that in the supp\_svid\_tbl array, and should provide pointers to functions which will check whether the alternate mode operation is allowed, and then perform the appropriate initialization.

e.g.: To register handler functions for two alternate modes, the table should be configured as below: alt mode info t\*

```
(*const is_alt_mode_allowed [2]) (uint8_t, alt_mode_reg_info_t*) =
{
    register_svid1,
    register_svid2
};
```

e. dfp\_compatibility\_mode\_table: This array serves as a registry of alternate modes supported by the CCG firmware in a DFP role. This will be a 2-dimensional array which maps the alternate mode SVID value to a unique alternate mode ID value which will be used by the alternate mode manager. The array is arranged in priority order, with the first mentioned SVID being prioritized over the later ones.

e.g.: If the design supports two alternate modes with SVIDs SVID1 and SVID2, the table can be setup as below:

f. ufp\_compatibility\_mode\_table: This array is similar to the dfp\_compatibility\_mode\_table, and applies when CCG is in the UFP role.

# **Revision History**



# **Document Revision History**

| Document Title: Cypress EZ-PD™ CCGx SDK User Guide |            |                  |                           |
|----------------------------------------------------|------------|------------------|---------------------------|
| Document Number: 002-12541                         |            |                  |                           |
| Revision                                           | Issue Date | Origin of Change | Description of Change     |
| **                                                 |            | KYS              | Initial release           |
| *A                                                 |            | KNI              | Updates for CCGx SDK 3.0. |