

# ADV7183 DEVICE DRIVER

**DATE: 31 JAN 2006** 

# **Table of Contents**

| 1. O  | verview                                       | 6 |
|-------|-----------------------------------------------|---|
| 2. Fi | les                                           | 6 |
| 2.1   | I. Include Files                              | 6 |
| 2.2   | 2. Source Files                               | 6 |
| 3. Lc | ower Level Drivers                            | 7 |
| 3.1   | I. TWI                                        | 7 |
| 3.2   | 2. PPI                                        | 7 |
| 4. Re | esources Required                             | 8 |
| 4.1   | I. Interrupts                                 | 8 |
| 4.2   | 2. DMA                                        | 8 |
| 4.3   | 3. Timers                                     | 8 |
| 4.4   | I. Real-Time Clock                            | 8 |
| 4.5   | 5. Programmable Flags                         | 8 |
| 4.6   | S. Pins                                       | 8 |
| 5. Sı | upported Features of the Device Driver        | 9 |
| 5.1   | I. Directionality                             | 9 |
| 5.2   | 2. Dataflow Methods                           | 9 |
| 5.3   | 3. Buffer Types                               | 9 |
| 5.4   | I. Command IDs                                | 9 |
|       | 5.4.1. Device Manager Commands                | 9 |
|       | 5.4.2. Common Commands                        | 9 |
|       | 5.4.3. Device Driver Specific Commands        | 9 |
| 5.5   | 5. Callback Events                            | 9 |
|       | 5.5.1. Common Events                          | 9 |
|       | 5.5.2. Device Driver Specific Events          | 9 |
| 5.6   | S. Return Codes                               | 9 |
|       | 5.6.1. Common Return Codes                    | 9 |
|       | 5.6.2. Device Driver Specific Return Codes    | 9 |
| 6. C  | onfiguring the Device Driver                  | 9 |
| 6.1   | I. Entry Point                                | 9 |
| 6.2   | 2. Default Settings                           | 9 |
| 6.3   | 3. Additional Required Configuration Settings | 9 |

| 7. Hardware Considerations                       | 9 |
|--------------------------------------------------|---|
| 8. Appendix                                      | 9 |
| 8.1. Using ADV7183 Device Driver in Applications | 9 |
| 8.2. TWI Configuration tables                    | 9 |
| 8.3. Accessing ADV7183 registers                 | 9 |
| 8.3.1. Read ADV7183 internal registers           | 9 |
| 8.3.2. Configure ADV7183 internal registers      | 9 |

# **List of Tables**

| Table 1 – Revision History                     | 5 |
|------------------------------------------------|---|
| Table 2 – Supported Dataflow Directions        |   |
| Table 3 – Supported Dataflow Methods           |   |
| Table 4 – Default Settings                     |   |
| Table 5 – Additional Required Settings         |   |
| Table 6 – ADV7183 Common Registers             |   |
| Table 7 – ADV7183 Normal (Page 1) Registers    |   |
| Table 8 – ADV7183 Interrupt (Page 2) Registers |   |

Page: 4 of 34

# **Document Revision History**

| Date                                                                             | Description of Changes |  |  |
|----------------------------------------------------------------------------------|------------------------|--|--|
| 2006/01/31                                                                       | Initial release        |  |  |
| 2006/05/15 Updated to new device access interface Added register access examples |                        |  |  |

Table 1 - Revision History

Page: 5 of 34

# 1. Overview

The ADV7183 driver provides the user application control over the ADV7183 video decoder. The decoder's registers are configured using TWI and the video dataflow through PPI port. The application program can configure ADV7183 registers and specific return codes are sent in result of success or any failure. The driver uses Device Access Service (adi device access) to access internal registers of the encoder.

# 2. Files

The files listed below comprise the device driver API and source files.

#### 2.1. Include Files

The driver sources include the following include files:

- <services/services.h> This file contains all definitions, function prototypes etc. for all the System Services.
- <drivers/adi\_dev.h> This file contains all definitions, function prototypes etc. for the Device Manager and general device driver information.
- <drivers/ppi/adi\_ppi.h>
   This file contains all definitions, function prototypes etc.
   specific to PPI device
- <drivers/deviceaccess/adi\_device\_access.h>
   This file contains all definitions, function prototypes etc. for TWI/SPI device access service
- <arraycolor/sdecoder/adi\_ad7183.h>
   This file contains all definitions, function prototypes etc.
   specific to ADV7183 device

#### 2.2. Source Files

The driver sources are contained in the following files, as located in the default installation directory:

• adi ad7183.c

Page: 6 of 34

# 3. Lower Level Drivers

ADV7183 driver is layered on TWI and PPI drivers

### 3.1. TWI

The TWI device driver is used by the ADV7183 driver to configure decoder registers.

### 3.2. PPI

The PPI device driver is used by the ADV7183 to read in the video data from the decoder.

The PPI device to be used shall be specified by the user; by default the ADV7183 driver sets PPI device 0 to be used for its video dataflow.

Application can directly communicate with the PPI device allocated for ADV7183 video dataflow by calling adi\_dev\_Control() function with PDDHandle specific to ADV7183 driver, command specific to the PPI driver and value specific to the command.

Page: 7 of 34

# 4. Resources Required

Device drivers typically consume some amount of system resources. This section describes the resources required by the device driver.

Unless explicitly noted in the sections below, this device driver uses the System Services to access and control any required hardware. The information in this section may be helpful in determining the resources this driver requires, such as the number of interrupt handlers or number of DMA channels etc., from the System Services.

Because dynamic memory allocations are not used in the Device Drivers or System Services, all memory used by the Device Drivers and System Services must be supplied by the application. The Device Drivers and System Services supply macros that can be used by the application to size the amount of base memory and/or the amount of incremental memory required to support the needed functionality. Memory for the Device Manager and System Services is provided in the initialization functions (adi\_xxx\_Init()).

Wherever possible, this device driver uses the System Services to perform the necessary low-level hardware access and control.

The ADV7183 driver uses one PPI port and DMA control and one TWI port, this can be either a hardware TWI if the Blackfin device being used has a hardware port (BF537), or pseudo TWI if no TWI hardware exists(BF533 or BF561). In this case the TWI uses one timer and 2 general purpose flags.

# 4.1. Interrupts

This driver does not use any interrupts directly, please see PPI and TWI documentation for resources required by these drivers.

#### 4.2. DMA

The driver doesn't support DMA directly, but uses a DMA driven PPI for its video dataflow. ADV7183 supports only inbound dataflow and memory should be allocated for one DMA channel.

#### 4.3. Timers

This driver does not use any timers directly, however check the PPI and TWI documentation for timer resources required by these drivers.

### 4.4. Real-Time Clock

This driver does not require the real-time clock.

# 4.5. Programmable Flags

No programmable flags are directly used by this driver. If the client intends to use a pseudo TWI to control ADV7183, a TWI configuration table must be passed with flag settings that will be used for pseudo TWI operation.

#### 4.6. Pins

This driver does not use any external pins.

Page: 8 of 34

# 5. Supported Features of the Device Driver

This section describes what features are supported by the device driver.

# 5.1. Directionality

The driver supports the dataflow directions listed in the table below.

| ADI_DEV_DIRECTION         | Description                                           |
|---------------------------|-------------------------------------------------------|
| ADI_DEV_DIRECTION_INBOUND | Supports the reception of data in through the device. |

Table 2 - Supported Dataflow Directions

#### 5.2. Dataflow Methods

The driver supports the dataflow methods listed in the table below.

| ADI_DEV_MODE                  | Description                                      |
|-------------------------------|--------------------------------------------------|
| ADI_DEV_MODE_CIRCULAR         | Supports the circular buffer method              |
| ADI_DEV_MODE_CHAINED          | Supports the chained buffer method               |
| ADI_DEV_MODE_CHAINED_LOOPBACK | Supports the chained buffer with loopback method |

Table 3 - Supported Dataflow Methods

# 5.3. Buffer Types

The driver supports the buffer types listed in the table below.

- ADI DEV CIRCULAR BUFFER
  - Circular buffer
  - o pAdditionalInfo ignored
- ADI\_DEV\_2D\_BUFFER
  - o Two-dimensional buffer
  - o pAdditionalInfo ignored

#### 5.4. Command IDs

This section enumerates the commands that are supported by the driver. The commands are divided into three sections. The first section describes commands that are supported directly by the Device Manager. The next section describes common commands that the driver supports. The remaining section describes driver specific commands.

Commands are sent to the device driver via the adi\_dev\_Control() function. The adi\_dev\_Control() function accepts three arguments:

- DeviceHandle This parameter is a ADI\_DEV\_DEVICE\_HANDLE type that uniquely identifies the device driver. This handle is provided to the client in the adi\_dev\_Open() function call.
- CommandID This parameter is a u32 data type that specifies the command ID.
- Value This parameter is a void \* whose value is context sensitive to the specific command ID.

The sections below enumerate the command IDs that are supported by the driver and the meaning of the Value parameter for each command ID.

Page: 9 of 34

### **5.4.1. Device Manager Commands**

The commands listed below are supported and processed directly by the Device Manager. As such, all device drivers support these commands.

- ADI\_DEV\_CMD\_TABLE
  - Table of command pairs being passed to the driver
  - Value ADI\_DEV\_CMD\_VALUE\_PAIR \*
- ADI DEV CMD END
  - Signifies the end of a command pair table
  - Value ignored
- ADI DEV CMD PAIR
  - Single command pair being passed
  - Value ADI DEV CMD PAIR \*
- ADI DEV CMD SET SYNCHRONOUS
  - Enables/disables synchronous mode for the driver
  - Value TRUF/FALSF

#### 5.4.2. Common Commands

The command IDs described in this section are common to many device drivers. The list below enumerates all common command IDs that are supported by this device driver.

- ADI DEV CMD SET DATAFLOW METHOD
  - Specifies the dataflow method the device is to use. The list of dataflow types supported by the device driver is specified in section 5.2.
  - Value ADI DEV MODE enumeration
- ADI DEV CMD SET DATAFLOW
  - Enables/disables dataflow through the device
  - o Value TRUE/FALSE
- ADI DEV CMD GET PERIPHERAL DMA SUPPORT
  - o Determines if the device driver is supported by peripheral DMA
  - Value u32 \* (location where TRUE or FALSE is stored)
- ADI DEV CMD REGISTER\_READ
  - Reads a single device register
  - o Value ADI\_DEV\_ACCESS\_REGISTER \* (register specifics)
- ADI DEV CMD REGISTER FIELD READ
  - Reads a specific field location in a single device register
  - Value ADI DEV ACCESS REGISTER FIELD \* (register specifics)
- ADI DEV CMD REGISTER TABLE READ
  - Reads a table of selective device registers
  - Value ADI DEV ACCESS REGISTER \* (register specifics)
- ADI\_DEV\_CMD\_REGISTER\_FIELD\_TABLE\_READ
  - Reads a table of selective device register fields
  - Value ADI\_DEV\_ACCESS\_REGISTER\_FIELD \* (register specifics)
- ADI DEV CMD REGISTER BLOCK READ
  - Reads a block of consecutive device registers
  - Value ADI\_DEV\_ACCESS\_REGISTER\_BLOCK \* (register specifics)
- ADI DEV CMD REGISTER WRITE
  - Writes to a single device register
  - Value ADI DEV ACCESS REGISTER \* (register specifics)
- ADI DEV CMD REGISTER FIELD WRITE
  - Writes to a specific field location in a single device register
  - Value ADI\_DEV\_ACCESS\_REGISTER\_FIELD \* (register specifics)
- · ADI DEV CMD REGISTER TABLE WRITE
  - Writes to a table of selective device registers
  - Value ADI\_DEV\_ACCESS\_REGISTER \* (register specifics)

Page: 10 of 34

- ADI\_DEV\_CMD\_REGISTER\_FIELD\_TABLE\_WRITE
  - Writes to a table of selective device register fields
  - Value ADI\_DEV\_ACCESS\_REGISTER\_FIELD \* (register specifics)
- ADI DEV CMD REGISTER BLOCK WRITE
  - o Writes to a block of consecutive device registers
  - Value ADI DEV ACCESS REGISTER BLOCK \* (register specifics)

#### 5.4.3. Device Driver Specific Commands

The command IDs listed below are supported and processed by the device driver. These command IDs are unique to this device driver. The driver also supports commands specific to PPI driver. Please refer to PPI driver documentation for further information.

- ADI\_AD7183\_CMD\_SET\_TWI\_DEVICE\_NUMBER
  - Sets the TWI device number to use
  - Value u32 (device number)
- ADI\_AD7183\_CMD\_SET\_TWI\_DEVICE\_ADDRESS
  - Sets the device TWI address
  - o Value u32 (device address)
- ADI\_AD7183\_CMD\_SET\_TWI\_CONFIG\_TABLE
  - Sets the configuration options for TWI device
  - Value ADI DEV CMD VALUE PAIR \* (extra TWI configuration controls)
- ADI AD7183 CMD OPEN PPI
  - Sets PPI device number to be used for ADV7183 video dataflow.
  - Value u32 (device number)
- ADI AD7183 CMD SET VIDEO FORMAT
  - Sets the PPI device control register and Lines Per Frame register to PAL or NTSC mode.
  - Value u32 (0(NTSC) or 1(PAL))
- ADI\_AD7183\_CMD\_SET\_ACTIVE\_VIDEO
  - Sets PPI control register to receive active video field only.
  - Value NULL
- ADI AD7183 CMD SET VERTICAL BLANKING
  - Sets PPI control register to receive vertical blanking only.
  - o Value NULL

#### 5.5. Callback Events

This section enumerates the callback events the device driver is capable of generating. The events are divided into two sections. The first section describes events that are common to many device drivers. The next section describes driver specific event IDs. The callback function of the client should be prepared to process each of the events in these sections.

The callback function is of the type ADI\_DCB\_CALLBACK\_FN. The callback function is passed three parameters. These parameters are:

- ClientHandle This void \* parameter is the value that is passed to the device driver as a parameter in the adi\_dev\_Open() function.
- EventID This is a u32 data type that specifies the event ID.
- Value This parameter is a void \* whose value is context sensitive to the specific event ID.

The sections below enumerate the event IDs that the device driver can generate and the meaning of the Value parameter for each event ID.

Page: 11 of 34

#### 5.5.1. Common Events

The events described in this section are common to many device drivers. The list below enumerates all common event IDs that are supported by this device driver.

- ADI DEV EVENT BUFFER PROCESSED
  - Notifies callback function that a chained or sequential I/O buffer has been processed by the device driver. This event is also used to notify that an entire circular buffer has been processed if the driver was directed to generate a callback upon completion of an entire circular buffer.
  - Value For chained or sequential I/O dataflow methods, this value is the CallbackParameter value that was supplied in the buffer that was passed to the adi\_dev\_Read(), adi\_dev\_Write() or adi\_dev\_SequentialIO() function. For the circular dataflow method, this value is the address of the buffer provided in the adi\_dev\_Read() or adi\_dev\_Write() function.
- ADI DEV EVENT SUB BUFFER PROCESSED
  - Notifies callback function that a sub-buffer within a circular buffer has been processed by the device driver.
  - o Value The address of the buffer provided in the adi dev Read() or adi dev Write() function.
- ADI\_DEV\_EVENT\_DMA\_ERROR\_INTERRUPT
  - Notifies the callback function that a DMA error occurred.
  - Value Null.

### 5.5.2. Device Driver Specific Events

The events listed below are supported and processed by the device driver. These event IDs are unique to this device driver.

This driver does not have any specific events.

### 5.6. Return Codes

All API functions of the device driver return status indicating either successful completion of the function or an indication that an error has occurred. This section enumerates the return codes that the device driver is capable of returning to the client. A return value of ADI\_DEV\_RESULT\_SUCCESS indicates success, while any other value indicates an error or some other informative result. The value ADI\_DEV\_RESULT\_SUCCESS is always equal to the value zero. All other return codes are a non-zero value.

The return codes are divided into two sections. The first section describes return codes that are common to many device drivers. The next section describes driver specific return codes. The client should prepare to process each of the return codes described in these sections.

Typically, the application should check the return code for ADI\_DEV\_RESULT\_SUCCESS, taking appropriate corrective action if ADI\_DEV\_RESULT\_SUCCESS is not returned. For example:

```
if (adi_dev_Xxxx(...) == ADI_DEV_RESULT_SUCCESS) {
    // normal processing
} else {
    // error processing
}
```

#### 5.6.1. Common Return Codes

The return codes described in this section are common to many device drivers. The list below enumerates all common return codes that are supported by this device driver.

Page: 12 of 34

- ADI\_DEV\_RESULT\_SUCCESS
  - The function executed successfully.
- ADI DEV RESULT NOT SUPPORTED
  - The function is not supported by the driver.
- ADI DEV RESULT DEVICE IN USE
  - o The requested device is already in use.
- ADI DEV RESULT NO MEMORY
  - There is insufficient memory available.
- ADI DEV RESULT BAD DEVICE NUMBER
  - The device number is invalid.
- ADI DEV RESULT DIRECTION NOT SUPPORTED
  - The device cannot be opened in the direction specified.
- ADI DEV RESULT BAD DEVICE HANDLE
  - o The handle to the device driver is invalid.
- ADI\_DEV\_RESULT\_BAD\_MANAGER\_HANDLE
  - The handle to the Device Manager is invalid.
- ADI DEV RESULT BAD PDD HANDLE
  - The handle to the physical driver is invalid.
- ADI DEV RESULT INVALID SEQUENCE
  - o The action requested is not within a valid sequence.
- ADI DEV RESULT ATTEMPTED READ ON OUTBOUND DEVICE
  - o The client attempted to provide an inbound buffer for a device opened for outbound traffic only.
- ADI DEV RESULT ATTEMPTED WRITE ON INBOUND DEVICE
  - The client attempted to provide an outbound buffer for a device opened for inbound traffic only.
- ADI DEV RESULT DATAFLOW UNDEFINED
  - o The dataflow method has not yet been declared.
- ADI DEV RESULT DATAFLOW INCOMPATIBLE
  - o The dataflow method is incompatible with the action requested.
- ADI DEV RESULT BUFFER TYPE INCOMPATIBLE
  - The device does not support the buffer type provided.
- ADI DEV RESULT CANT HOOK INTERRUPT
  - The Interrupt Manager failed to hook an interrupt handler.
- ADI DEV RESULT CANT UNHOOK INTERRUPT
  - The Interrupt Manager failed to unhook an interrupt handler.
- ADI\_DEV\_RESULT\_NON\_TERMINATED\_LIST
  - The chain of buffers provided is not NULL terminated.
- ADI DEV RESULT NO CALLBACK FUNCTION SUPPLIED
  - No callback function was supplied when it was required.
- ADI\_DEV\_RESULT\_REQUIRES\_UNIDIRECTIONAL\_DEVICE
  - o Requires the device be opened for either inbound or outbound traffic only.
- ADI DEV RESULT REQUIRES BIDIRECTIONAL DEVICE
  - Requires the device be opened for bidirectional traffic only.

#### Return codes specific to TWI/SPI Device access service

- ADI DEV RESULT TWI LOCKED
  - Indicates the present TWI device is locked in other operation
- · ADI DEV RESULT REQUIRES TWI CONFIG TABLE
  - Client need to supply a configuration table for the TWI driver
- ADI\_DEV\_RESULT\_CMD\_NOT\_SUPPORTED
  - Command not supported by the Device Access Service
- ADI\_DEV\_RESULT\_INVALID\_REG\_ADDRESS
  - The client attempting to access an invalid register address
- ADI\_DEV\_RESULT\_INVALID\_REG\_FIELD
  - The client attempting to access an invalid register field location
- ADI DEV RESULT INVALID REG FIELD DATA
  - o The client attempting to write an invalid data to selected register field location

Page: 13 of 34

- ADI\_DEV\_RESULT\_ATTEMPT\_TO\_WRITE\_READONLY\_REG
  - The client attempting to write to a read-only location
- ADI\_DEV\_RESULT\_ATTEMPT\_TO\_ACCESS\_RESERVE\_AREA
  - o The client attempting to access a reserved location
- ADI\_DEV\_RESULT\_ACCESS\_TYPE\_NOT\_SUPPORTED
  - Device Access Service does not support the access type provided by the driver

### 5.6.2. Device Driver Specific Return Codes

The return codes listed below are supported and processed by the device driver. These event IDs are unique to this device driver.

- ADI\_AD7183\_RESULT\_CMD\_NOT\_SUPPORTED
  - o Command supplied by the client is not supported.
- ADI\_AD7183\_RESULT\_PPI\_NOT\_OPENED
  - o Results when client tries to set DataFlow or DataFlow-Method before PPI is opened.
- ADI\_AD7183\_RESULT\_BAD\_VIDEO\_FORMAT
  - o Results when the client provides an invalid video format.

Page: 14 of 34

# 6. Configuring the Device Driver

This section describes the default configuration settings for the device driver and any additional configuration settings required from the client application.

# 6.1. Entry Point

When opening the device driver with the adi\_dev\_Open() function call, the client passes a parameter to the function that identifies the specific device driver that is being opened. This parameter is called the entry point. The entry point for this driver is listed below.

ADIAD7183EntryPoint

# 6.2. Default Settings

The table below describes the default configuration settings for the device driver. If the default values are inappropriate for the given system, the application should use the command IDs listed in the table to configure the device driver appropriately. Any configuration settings not listed in the table below are undefined.

| Item       | Default Value     | Possible Values    | Command ID                      |
|------------|-------------------|--------------------|---------------------------------|
| PPI device | 0                 | 0,1                | ADI_AD7183_CMD_OPEN_PPI         |
| Video      | 0(NTSC)           | 0(NTSC), 1(PAL)    | ADI_AD7183_CMD_SET_VIDEO_FORMAT |
| Format     |                   |                    |                                 |
| TWI        | 0                 | 0,1                | ADI_AD7183_CMD_SET_TWI_DEVICE   |
| device     |                   |                    |                                 |
| TWI        | ADV7183_TWI_ADDR0 | ADV7183_TWI_ADDR0, | ADI_AD7183_CMD_SET_TWI_ADDRESS  |
| address    |                   | ADV7183_TWI_ADDR1  |                                 |

Table 4 - Default Settings

# 6.3. Additional Required Configuration Settings

In addition to the possible overrides of the default driver settings, the device driver requires the application to specify the additional configuration information listed in the table below.

| Item          | Possible Values                    | Command ID                          |
|---------------|------------------------------------|-------------------------------------|
| TWI           | Pointer to TWI configuration table | ADI_AD7183_CMD_SET_TWI_CONFIG_TABLE |
| Configuration | of type                            |                                     |
| Table         | ADI_DEV_CMD_VALUE_PAIR             |                                     |
| PPI device    | 0 (for BF533, BF537)               | ADI_AD7183_CMD_OPEN_PPI             |
|               | 0, 1 (for BF561)                   |                                     |
| Video format  | 0(NTSC), 1(PAL)                    | ADI_AD7183_CMD_SET_VIDEO_FORMAT     |
| Dataflow      | See section 5.2                    | ADI_DEV_CMD_SET_DATAFLOW_METHOD     |
| method        |                                    | <del>_</del>                        |

Table 5 – Additional Required Settings

Page: 15 of 34

# 7. Hardware Considerations

The TWI slave address of ADV7183 can be set by issuing the command 'ADI\_ADV7183\_CMD\_SET\_TWI\_DEVICE\_ADDRESS'. If the client intends to use pseudo TWI to access ADV7183 registers, specific port pins should be set in Blackfin to generate TWI SCL and SDA.

The following table is a list of registers that can be accessed on the ADV7183. Please refer to the ADV7183 device manual for a full description of registers and chip functionality.

Common Registers

| Register         Address         Value         r/w         Description           ADV7183_INPUT_CTR         0x00         0x00         rw         Input Control           ADV7183_VIDEO_SELECTION         0x01         0xC8         rw         Video Selection           ADV7183_OUTPUT_CTR         0x03         0x0C         rw         Output Control           ADV7183_EXTENDED_OUTPUT_CTR         0x04         0x45         rw         Extended Output Control           ADV7183_AUTODETECT_ENABLE         0x07         0x7F         rw         Autodetect Enable           ADV7183_CONTRAST         0x08         0x80         rw         Contrast           ADV7183_BRIGHTNESS         0x0A         0x00         rw         Brightness           ADV7183_DEF_VALUE_Y         0x0B         0x00         rw         Hue           ADV7183_DEF_VALUE_Y         0x0C         0x36         rw         Default Value Y           ADV7183_ADI_CTR         0x0E         0x0D         0x7C         rw         Default Value C           ADV7183_POWER_MGM         0x0F         0x00         rw         ADI Control           ADV7183_STATUS1_RO         0x11         0xxx         r         Status 1           ADV7183_STATUS2_RO         0x12 |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ADV7183 VIDEO SELECTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| ADV7183   OUTPUT_CTR   Ox03   Ox0C   rw   Output Control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| ADV7183 EXTENDED OUTPUT CTR         0x04         0x45         rw         Extended Output Control           ADV7183 AUTODETECT_ENABLE         0x07         0x7F         rw         Autodetect Enable           ADV7183 CONTRAST         0x08         0x80         rw         Contrast           ADV7183 BRIGHTNESS         0x0A         0x00         rw         Brightness           ADV7183 HUE         0x0B         0x00         rw         Hue           ADV7183 DEF_VALUE_Y         0x0C         0x36         rw         Default Value Y           ADV7183 DEF_VALUE_C         0x0D         0x7C         rw         Default Value C           ADV7183 POWER_MGM         0x0F         0x00         rw         ADI Control           ADV7183 STATUS1_RO         0x10         0xxx         r         Status 1           ADV7183 STATUS2_RO         0x12         0xxx         r         Status 2           ADV7183_STATUS3_RO         0x13         0xxx         r         Status 3           ADV7183_ANALOG_CLAMP_CTR         0x14         0x12         rw         Analog Clamp Control                                                                                                                                                   |
| ADV7183 AUTODETECT_ENABLE         0x07         0x7F         rw         Autodetect Enable           ADV7183 CONTRAST         0x08         0x80         rw         Contrast           ADV7183 BRIGHTNESS         0x0A         0x00         rw         Brightness           ADV7183 HUE         0x0B         0x00         rw         Hue           ADV7183 DEF_VALUE_Y         0x0C         0x36         rw         Default Value Y           ADV7183 DEF_VALUE_C         0x0D         0x7C         rw         Default Value C           ADV7183 ADI_CTR         0X0E         0x00         rw         ADI Control           ADV7183 POWER_MGM         0x0F         0x00         rw         Power Management           ADV7183 STATUS1_RO         0x10         0xxx         r         Status 1           ADV7183 STATUS2_RO         0x12         0xxx         r         Status 2           ADV7183_ANALOG_CLAMP_CTR         0x14         0x12         rw         Analog Clamp Control                                                                                                                                                                                                                                                        |
| ADV7183 CONTRAST         0x08         0x80         rw         Contrast           ADV7183 BRIGHTNESS         0x0A         0x0D         rw         Brightness           ADV7183 HUE         0x0B         0x0D         rw         Hue           ADV7183 DEF VALUE Y         0x0C         0x36         rw         Default Value Y           ADV7183 DEF VALUE C         0x0D         0x7C         rw         Default Value C           ADV7183 ADI CTR         0X0E         0x00         rw         ADI Control           ADV7183 POWER MGM         0x0F         0x00         rw         Power Management           ADV7183 STATUS1 RO         0x10         0xxx         r         Status 1           ADV7183 STATUS2 RO         0x12         0xxx         r         Status 2           ADV7183 STATUS3 RO         0x13         0xxx         r         Status 3           ADV7183 ANALOG_CLAMP_CTR         0x14         0x12         rw         Analog Clamp Control                                                                                                                                                                                                                                                                         |
| ADV7183_BRIGHTNESS         0x0A         0x00         rw         Brightness           ADV7183_HUE         0x0B         0x0C         rw         Hue           ADV7183_DEF_VALUE_Y         0x0C         0x36         rw         Default Value Y           ADV7183_DEF_VALUE_C         0x0D         0x7C         rw         Default Value C           ADV7183_ADI_CTR         0X0E         0x00         rw         ADI Control           ADV7183_POWER_MGM         0x0F         0x00         rw         Power Management           ADV7183_STATUS1_RO         0x10         0xxx         r         Status 1           ADV7183_STATUS2_RO         0x12         0xxx         r         Status 2           ADV7183_STATUS3_RO         0x13         0xxx         r         Status 3           ADV7183_ANALOG_CLAMP_CTR         0x14         0x12         rw         Analog Clamp Control                                                                                                                                                                                                                                                                                                                                                          |
| ADV7183_HUE         0x0B         0x0C         rw         Hue           ADV7183_DEF_VALUE_Y         0x0C         0x36         rw         Default Value Y           ADV7183_DEF_VALUE_C         0x0D         0x7C         rw         Default Value C           ADV7183_ADI_CTR         0X0E         0x00         rw         ADI Control           ADV7183_POWER_MGM         0x0F         0x00         rw         Power Management           ADV7183_STATUS1_RO         0x10         0xxx         r         Status 1           ADV7183_STATUS2_RO         0x12         0xxx         r         Status 2           ADV7183_STATUS3_RO         0x13         0xxx         r         Status 3           ADV7183_ANALOG_CLAMP_CTR         0x14         0x12         rw         Analog Clamp Control                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| ADV7183 DEF_VALUE_Y         0x0C         0x36         rw         Default Value Y           ADV7183_DEF_VALUE_C         0x0D         0x7C         rw         Default Value C           ADV7183_ADI_CTR         0X0E         0x00         rw         ADI Control           ADV7183_POWER_MGM         0x0F         0x00         rw         Power Management           ADV7183_STATUS1_RO         0x10         0xxx         r         Status 1           ADV7183_STATUS2_RO         0x11         0xxx         r         Status 2           ADV7183_STATUS3_RO         0x13         0xxx         r         Status 3           ADV7183_ANALOG_CLAMP_CTR         0x14         0x12         rw         Analog Clamp Control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| ADV7183 DEF_VALUE_C         0x0D         0x7C         rw         Default Value C           ADV7183 ADI_CTR         0X0E         0x00         rw         ADI Control           ADV7183 POWER_MGM         0x0F         0x00         rw         Power Management           ADV7183 STATUS1_RO         0x10         0xxx         r         Status 1           ADV7183 IDENT_RO         0x11         0xxx         r         Ident           ADV7183 STATUS2_RO         0x12         0xxx         r         Status 2           ADV7183_STATUS3_RO         0x13         0xxx         r         Status 3           ADV7183_ANALOG_CLAMP_CTR         0x14         0x12         rw         Analog Clamp Control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| ADV7183 ADI_CTR         0X0E         0x00         rw         ADI Control           ADV7183 POWER_MGM         0x0F         0x00         rw         Power Management           ADV7183 STATUS1_RO         0x10         0xxx         r         Status 1           ADV7183 IDENT_RO         0x11         0xxx         r         Ident           ADV7183 STATUS2_RO         0x12         0xxx         r         Status 2           ADV7183_STATUS3_RO         0x13         0xxx         r         Status 3           ADV7183_ANALOG_CLAMP_CTR         0x14         0x12         rw         Analog Clamp Control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| ADV7183_POWER_MGM         0x0F         0x00         rw         Power Management           ADV7183_STATUS1_RO         0x10         0xxx         r         Status 1           ADV7183_IDENT_RO         0x11         0xxx         r         Ident           ADV7183_STATUS2_RO         0x12         0xxx         r         Status 2           ADV7183_STATUS3_RO         0x13         0xxx         r         Status 3           ADV7183_ANALOG_CLAMP_CTR         0x14         0x12         rw         Analog Clamp Control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| ADV7183_STATUS1_RO         0x10         0xxx         r         Status 1           ADV7183_IDENT_RO         0x11         0xxx         r         Ident           ADV7183_STATUS2_RO         0x12         0xxx         r         Status 2           ADV7183_STATUS3_RO         0x13         0xxx         r         Status 3           ADV7183_ANALOG_CLAMP_CTR         0x14         0x12         rw         Analog Clamp Control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| ADV7183_IDENT_RO         0x11         0xxx         r         Ident           ADV7183_STATUS2_RO         0x12         0xxx         r         Status 2           ADV7183_STATUS3_RO         0x13         0xxx         r         Status 3           ADV7183_ANALOG_CLAMP_CTR         0x14         0x12         rw         Analog Clamp Control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| ADV7183_STATUS2_RO         0x12         0xxx         r         Status 2           ADV7183_STATUS3_RO         0x13         0xxx         r         Status 3           ADV7183_ANALOG_CLAMP_CTR         0x14         0x12         rw         Analog Clamp Control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| ADV7183_STATUS3_RO         0x13         0xxx         r         Status 3           ADV7183_ANALOG_CLAMP_CTR         0x14         0x12         rw         Analog Clamp Control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| ADV7183_ANALOG_CLAMP_CTR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| ADV7183_DIGITAL_CLAMP_CTR1  0x15  0x40 rw Digital Clamp Control 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| ADV7183 SHAPING FILTER CTR 0x17 0x01 rw Shaping Filter Control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| ADV7183 SHAPING FILTER CTR2 0x18 0x93 rw Shaping Filter Control 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| ADV7183_COMB_FILTER_CTR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| ADV7183 ADI CTR2 0x1D 0x00 rw ADI Control 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| ADV7183_PIXEL_DELAY_CTR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| ADV7183_MISC_GAIN_CTR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| ADV7183_AGC_MODE_CTR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| ADV7183_CHROMA_GAIN_CTR1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| ADV7183_CHROMA_GAIN_CTR2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| ADV7183 LUMA GAIN CTR1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| ADV7183 LUMA GAIN CTR2 0x30 0xxx rw Luma Gain Control 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| ADV7183 VSYNC FIELD CTR1 0x31 0x12 rw VSync Field Control 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| ADV7183 VSYNC FIELD CTR2 0x32 0x41 rw Vsync Field Control 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| ADV7183 VSYNC FIELD CTR3 0x33 0x84 rw Vsync Field Control 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| ADV7183 HSYNC POS CTR1 0x34 0x00 rw Hsync Position Control 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| ADV7183_HSYNC_POS_CTR2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| ADV7183_HSYNC_POS_CTR3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| ADV7183_POLARITY 0x37 0x01 rw Polarity                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| ADV7183 NTSC COMB CTR 0x38 0x80 rw NTSC Comb Control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| ADV7183_PAL_COMB_CTR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| ADV7183_ADC_CTR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| ADV7183_MANUAL_WINDOW_CTR 0x3D 0x43 rw Manual Window Control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

Table 6 - ADV7183 Common Registers

Page: 16 of 34

#### List of register fields.

Register Address: ADV7183\_INPUT\_CTR

Register Fields:

- ADV7183\_VID\_SEL
- ADV7183\_INSEL

Register Address: ADV7183\_VIDEO\_SELECTION

Register Fields:

- ADV7183\_ENHSPLL
- ADV7183\_BETACAM
- ADV7183 ENVSPROC

Register Address: ADV7183\_OUTPUT\_CTR

Register Fields:

- ADV7183\_VBI\_EN
- ADV7183 TOD
- ADV7183 OF SEL
- ADV7183 SD DUP AV

Register Address: ADV7183\_EXTENDED\_OUTPUT\_CTR Register Fields:

- ADV7183\_BT656\_4
- ADV7183 TIM OE
- ADV7183\_BL\_C\_VBI
- ADV7183\_EN\_SFL\_PI
- ADV7183\_RANGE

Register Address: ADV7183\_AUTODETECT\_ENABLE Register Fields:

- ADV7183\_AD\_SEC525\_EN
- ADV7183 AD SECAM EN
- ADV7183 AD N443 EN
- ADV7183\_ADP60\_EN
- ADV7183\_AD\_PALN\_EN
- ADV7183\_AD\_PALM\_ENADV7183 AD NTSC EN
- ADV/7102\_AD\_DAL\_EN
- ADV7183\_AD\_PAL\_EN

Register Address: ADV7183\_CONTRAST

Register Fields:

ADV7183\_CON

Register Address: ADV7183\_BRIGHTNESS

Register Fields:

ADV7183 BRI

Register Address: ADV7183 HUE

Register Fields:

ADV7183 HUE0

Register Address: ADV7183 DEF VALUE Y

Register Fields:

ADV7183\_DEF\_Y

Page: 17 of 34

ADV7183\_DEF\_VAL\_EN

Register Address: ADV7183\_DEF\_VALUE\_C

Register Fields:

ADV7183\_DEF\_C

Register Address: ADV7183\_ADI\_CTR

Register Fields:

ADV7183\_SUB\_USR\_EN

Register Address: ADV7183\_POWER\_MGM

Register Fields:

ADV7183\_RESADV7183\_PWRDNADV7183\_PDBP

Register Address: ADV7183\_STATUS1\_RO Register Fields:

- ADV7183 COL KILL
- ADV7183\_AD\_RESULT2
- ADV7183\_AD\_RESULT1
- ADV7183\_AD\_RESULT0
- ADV7183 FOLLOW PW
- ADV7183 FSC LOCK
- ADV7183 LOST LOCK
- ADV7183\_IN\_LOCK

Register Address: ADV7183\_IDENT\_RO Register Fields:

ADV7183\_IDENT

Register Address: ADV7183\_STATUS2\_RO Register Fields:

- ADV7183 FSCNSTD
- ADV7183 LLNSTD
- ADV7183\_MVAGCDET
- ADV7183 MVPSDET
- ADV7183\_MVCST3
- ADV7183\_MVCSDET

Register Address: ADV7183\_STATUS3\_RO Register Fields:

- ADV7183\_PALSWLOCK
- ADV7183\_INTERLACE
- ADV7183 STDFLDLEN
- ADV7183\_FREE\_RUN\_ACT
- ADV7183\_SD\_OP\_50HZ
- ADV7183 GEMD
- ADV7183\_INST\_HLOCK

Register Address: ADV7183\_ANALOG\_CLAMP\_CTR

Register Fields:

ADV7183 CCLEN

Register Address: ADV7183\_DIGITAL\_CLAMP\_CTR1

Register Fields:

ADV7183\_DCT

Page: 18 of 34

Register Address: ADV7183\_SHAPING\_FILTER\_CTR Register Fields:

- ADV7183\_CSFM
- ADV7183 YSFM

Register Address: ADV7183\_SHAPING\_FILTER\_CTR2 Register Fields:

- ADV7183 WYSFMOVR
- ADV7183 WYSFM

Register Address: ADV7183\_COMB\_FILTER\_CTR Register Fields:

- ADV7183\_NSFSEL
- ADV7183\_PSFSEL

Register Address: ADV7183\_ADI\_CTR2 Register Fields:

- ADV7183 TRI LLC
- ADV7183 EN28XTAL
- ADV7183\_VS\_JIT\_COMP\_EN

Register Address: ADV7183\_PIXEL\_DELAY\_CTR Register Fields:

- ADV7183 SWPC
- ADV7183 AUTO PDC EN
- ADV7183 CTA
- ADV7183 LTA

Register Address: ADV7183\_MISC\_GAIN\_CTR Register Fields:

- ADV7183 CKE
- ADV7183\_PW\_UPD

Register Address: ADV7183\_AGC\_MODE\_CTR Register Fields:

- ADV7183 LAGC
- ADV7183\_CAGC

Register Address: ADV7183\_CHROMA\_GAIN\_CTR1 Register Fields:

- ADV7183 CAGT
- ADV7183\_CMG8

Register Address: ADV7183\_CHROMA\_GAIN\_CTR2 Register Fields:

ADV7183\_CMG0

Register Address: ADV7183\_LUMA\_GAIN\_CTR1 Register Fields:

- ADV7183\_LAGT
- ADV7183\_LMG8

Register Address: ADV7183\_LUMA\_GAIN\_CTR2 Register Fields:

ADV7183\_LMG0

Page: 19 of 34

Register Address: ADV7183\_VSYNC\_FIELD\_CTR1 Register Fields:

- ADV7183\_NEWAVMODE
- ADV7183 HVSTIM

Register Address: ADV7183\_VSYNC\_FIELD\_CTR2 Register Fields:

- ADV7183\_VSBHO
- ADV7183\_VSBHE

Register Address: ADV7183\_VSYNC\_FIELD\_CTR3 Register Fields:

- ADV7183\_VSEHO
- ADV7183\_VSEHE

Register Address: ADV7183\_HSYNC\_POS\_CTR1 Register Fields:

- ADV7183 HSB8
- ADV7183 HSE8

Register Address: ADV7183\_HSYNC\_POS\_CTR2 Register Fields:

ADV7183\_HSB0

Register Address: ADV7183\_HSYNC\_POS\_CTR3 Register Fields:

ADV7183 HSE0

Register Address: ADV7183\_POLARITY

Register Fields:

- ADV7183 PHS
- ADV7183 PVS
- ADV7183\_PF
- ADV7183\_PCLK

Register Address: ADV7183\_NTSC\_COMB\_CTR Register Fields:

- ADV7183 CTAPSN
- ADV7183 CCMN
- ADV7183\_YCMN

Register Address: ADV7183\_PAL\_COMB\_CTR

Register Fields:

- ADV7183\_CTAPSP
- ADV7183\_CCMP
- ADV7183\_YCMP

Register Address: ADV7183\_ADC\_CTR

Register Fields:

- ADV7183 PWRDN ADC0
- ADV7183\_PWRDN\_ADC1
- ADV7183\_PWRDN\_ADC2

Register Address: ADV7183\_MANUAL\_WINDOW\_CTR

Register Fields:

• ADV7183\_CKILLTHR

Page: 20 of 34

Normal (page1) registers

|                              | Normal (page1) registers |       |     |                       |  |  |
|------------------------------|--------------------------|-------|-----|-----------------------|--|--|
| Register                     | Address                  | Value | r/w | Description           |  |  |
| ADV7183_RESAMPLE_CTR         | 0x41                     | 0x41  | rw  | Resample Control      |  |  |
| ADV7183_GEMSTAR_CTR1         | 0x48                     | 0x00  | rw  | Gemstar Control 1     |  |  |
| ADV7183_GEMSTAR_CTR2         | 0x49                     | 0x00  | rw  | Gemstar Control 2     |  |  |
| ADV7183_GEMSTAR_CTR3         | 0x4A                     | 0x00  | rw  | Gemstar Control 3     |  |  |
| ADV7183_GEMSTAR_CTR4         | 0x4B                     | 0x00  | rw  | Gemstar Control 4     |  |  |
| ADV7183_GEMSTAR_CTR5         | 0x4C                     | 0xx0  | rw  | Gemstar Control 5     |  |  |
| ADV7183_CTI_DNR_CTR1         | 0x4D                     | 0xEF  | rw  | CTI DNR Control 1     |  |  |
| ADV7183_CTI_DNR_CTR2         | 0x4E                     | 0x08  | rw  | CTI DNR Control 2     |  |  |
| ADV7183_CTI_DNR_CTR4         | 0x50                     | 0x08  | rw  | CTI DNR Control 4     |  |  |
| ADV7183_LOCK_COUNT           | 0x51                     | 0x24  | rw  | Lock Count            |  |  |
| ADV7183_FREERUN_LINE_LENGTH1 | 0x8F                     | 0x00  | W   | Freerun Line Length 1 |  |  |
| ADV7183_VBI_INFO_RO          | 0x90                     | 0xxx  | r   | VBI Info              |  |  |
| ADV7183_WSS1_RO              | 0x91                     | 0xxx  | r   | WSS 1                 |  |  |
| ADV7183_WSS2_RO              | 0x92                     | 0xxx  | r   | WSS 2                 |  |  |
| ADV7183_EDTV1_RO             | 0x93                     | 0xxx  | r   | EDTV 1                |  |  |
| ADV7183 EDTV2 RO             | 0x94                     | 0xxx  | r   | EDTV 2                |  |  |
| ADV7183 EDTV3 RO             | 0x95                     | 0xxx  | r   | EDTV 3                |  |  |
| ADV7183 CGMS1 RO             | 0x96                     | 0xxx  | r   | CGMS 1                |  |  |
| ADV7183 CGMS2 RO             | 0x97                     | 0xxx  | r   | CGMS 2                |  |  |
| ADV7183 CGMS3 RO             | 0x98                     | 0xxx  | r   | CGMS 3                |  |  |
| ADV7183 CCAP1 RO             | 0x99                     | 0xxx  | r   | CCAP 1                |  |  |
| ADV7183 CCAP2 RO             | 0x9A                     | 0xxx  | r   | CCAP 2                |  |  |
| ADV7183 LETTERBOX1 RO        | 0x9B                     | 0xxx  | r   | Letter Box 1          |  |  |
| ADV7183 LETTERBOX2 RO        | 0x9C                     | 0xxx  | r   | Letter Box 2          |  |  |
| ADV7183 LETTERBOX3 RO        | 0x9D                     | 0xxx  | r   | Letter Box 3          |  |  |
| ADV7183_CRC_ENABLE           | 0xB2                     | 0x1C  | w   | CRC enable            |  |  |
| ADV7183 ADC SWITCH1          | 0xC3                     | 0xxx  | rw  | ADC Switch 1          |  |  |
| ADV7183 ADC SWITCH2          | 0xC4                     | 0xxx  | rw  | ADC Switch 2          |  |  |
| ADV7183_LETTERBOX_CTR1       | 0xDC                     | 0xAC  | rw  | Letterbox Control1    |  |  |
| ADV7183 LETTERBOX CTR2       | 0xDD                     | 0x4C  | rw  | Letterbox Control2    |  |  |
| ADV7183 SD OFFSET CB         | 0xE1                     | 0x80  | rw  | SD Offset Cb          |  |  |
| ADV7183 SD OFFSET CR         | 0xE2                     | 0x80  | rw  | SD Offset Cr          |  |  |
| ADV7183 SD SATURATION CB     | 0xE3                     | 0x80  | rw  | SD Saturation Cb      |  |  |
| ADV7183 SD SATURATION CR     | 0xE4                     | 0x80  | rw  | SD Saturation Cr      |  |  |
| ADV7183 NTSC VBIT BEGIN      | 0xE5                     | 0x25  | rw  | NTSC V Bit Begin      |  |  |
| ADV7183 NTSC VBIT END        | 0xE6                     | 0x04  | rw  | NTSC V Bit End        |  |  |
| ADV7183 NTSC FBIT TOGGLE     | 0xE7                     | 0x63  | rw  | NTSC F Bit Toggle     |  |  |
| ADV7183 PAL VBIT BEGIN       | 0xE8                     | 0x65  | rw  | PAL V Bit Begin       |  |  |
| ADV7183 PAL VBIT END         | 0xE9                     | 0x14  | rw  | PAL V Bit End         |  |  |
| ADV7183 PAL FBIT TOGGLE      | 0xEA                     | 0x63  | rw  | PAL F Bit Toggle      |  |  |
| ADV7183 DRIVE STRENGTH       | 0xF4                     | 0x15  | rw  | Drive Strength        |  |  |
| ADV7183 IF COMP CTR          | 0xF8                     | 0x00  | rw  | IF Comp Control       |  |  |
| ADV7183 VS MODE CTR          | 0xF9                     | 0x00  | rw  | VS Mode Control       |  |  |
| /.b +. 100_+0_mobl_ont       | JA1 0                    | 0.00  | 1   | 10 11000 00111101     |  |  |

Table 7 – ADV7183 Normal (Page 1) Registers

List of register fields.

Register Address: ADV7183\_RESAMPLE\_CTR

Register Fields:

ADV7183\_SFL\_INV

Page: 21 of 34

Register Address: ADV7183\_GEMSTAR\_CTR1 Register Fields:

ADV7183\_CDECEL8

Register Address: ADV7183\_GEMSTAR\_CTR2 Register Fields:

ADV7183\_CDECEL0

Register Address: ADV7183\_GEMSTAR\_CTR3 Register Fields:

ADV7183 CDECOL8

Register Address: ADV7183\_GEMSTAR\_CTR4 Register Fields:

ADV7183\_CDECOL0

Register Address: ADV7183\_GEMSTAR\_CTR5 Register Fields:

ADV7183 CDECAD

Register Address: ADV7183\_CTIDNR\_CTR1 Register Fields:

- ADV7183\_DNR\_EN
- ADV7183\_CTI\_AB
- ADV7183\_CTI\_AB\_EN
- ADV7183 CTI EN

Register Address: ADV7183\_CTIDNR\_CTR2 Register Fields:

ADV7183\_CTI\_TH

Register Address: ADV7183\_CTIDNR\_CTR4 Register Fields:

ADV7183\_DNR\_TH

Register Address: ADV7183\_LOCK\_COUNT Register Fields:

- ADV7183 FSCLE
- ADV7183 SRLS
- ADV7183 COL
- ADV7183\_CIL

Register Address: ADV7183\_FREERUN\_LINE\_LENGTH1

Register Fields:

ADV7183\_LLC\_PAD\_SEL

Register Address: ADV7183\_VBI\_INFO\_RO

Register Fields:

- ADV7183 CGMSD
- ADV7183\_EDTVD
- ADV7183 CCAPD
- ADV7183\_WSSD

Register Address: ADV7183\_WSS1\_RO

Page: 22 of 34

Register Fields:

ADV7183\_WSS1

Register Address: ADV7183 WSS2 RO

Register Fields:

ADV7183 WSS2

Register Address: ADV7183\_EDTV1\_RO

Register Fields:

ADV7183 EDTV1

Register Address: ADV7183\_EDTV2\_RO

Register Fields:

ADV7183\_EDTV2

Register Address: ADV7183\_EDTV3\_RO

Register Fields:

ADV7183\_EDTV3

Register Address: ADV7183\_CGMS1\_RO

Register Fields:

ADV7183\_CGMS1

Register Address: ADV7183\_CGMS2\_RO

Register Fields:

ADV7183\_CGMS2

Register Address: ADV7183\_CGMS3\_RO

Register Fields:

• ADV7183\_CGMS3

Register Address: ADV7183\_CCAP1\_RO

Register Fields:

ADV7183\_CCAP1

Register Address: ADV7183\_CCAP2\_RO

Register Fields:

ADV7183\_CCAP2

Register Address: ADV7183\_LETTERBOX1\_RO

Register Fields:

ADV7183\_LB\_LCT

Register Address: ADV7183\_LETTERBOX2\_RO

Register Fields:

ADV7183\_LB\_LCM

Register Address: ADV7183\_LETTERBOX3\_RO

Register Fields:

ADV7183\_LB\_LCB

Register Address: ADV7183\_CRC\_ENABLE\_WR

Register Fields:

• ADV7183\_CRC\_ENABLE

Register Address: ADV7183\_ADC\_SWITCH1

Register Fields:

Page: 23 of 34

- ADV7183 ADC1 SW
- ADV7183\_ADCO\_SW

Register Address: ADV7183\_ADC\_SWITCH2 Register Fields:

- ADV7183 ADC SW MAN
- ADV7183\_ADC2\_SW

Register Address: ADV7183\_LETTERBOX\_CTR1 Register Fields:

• ADV7183 LB TH

Register Address: ADV7183\_LETTERBOX\_CTR2 Register Fields:

- ADV7183\_LB\_SL
- ADV7183 LB EL

Register Address: ADV7183\_SD\_OFFSET\_CB Register Fields:

ADV7183\_SD\_OFF\_CB

Register Address: ADV7183\_SD\_OFFSET\_CR Register Fields:

ADV7183\_SD\_OFF\_CR

Register Address: ADV7183\_SD\_SATURATION\_CB Register Fields:

ADV7183\_SD\_SAT\_CB

Register Address: ADV7183\_SD\_SATURATION\_CR Register Fields:

ADV7183\_SD\_SAT\_CR

Register Address: ADV7183\_NTSC\_VBIT\_BEGIN Register Fields:

- ADV7183 NVBEGDELO
- ADV7183\_NVBEGDELE
- ADV7183 NVBEGSIGN
- ADV7183\_NVBEG

Register Address: ADV7183\_NTSC\_VBIT\_END Register Fields:

- ADV7183 NVENDDELO
- ADV7183 NVENDDELE
- ADV7183\_NVENDSIGN
- ADV7183\_NVEND

Register Address: ADV7183\_NTSC\_FBIT\_TOGGLE Register Fields:

- ADV7183\_NFTOGDELO
- ADV7183\_NFTOGDELE
- ADV7183 NFTOGSIGN
- ADV7183\_NFTOG

Register Address: ADV7183\_PAL\_VBIT\_BEGIN

Register Fields:

ADV7183\_PVBEGDELO

Page: 24 of 34

- ADV7183 PVBEGDELE
- ADV7183\_PVBEGSIGN
- ADV7183 PVBEG

Register Address: ADV7183\_PAL\_VBIT\_END Register Fields:

- ADV7183\_PVENDDELO
- ADV7183\_PVENDDELE
- ADV7183 PVENDSIGN
- ADV7183\_PVEND

Register Address: ADV7183\_PAL\_FBIT\_TOGGLE Register Fields:

- ADV7183 PFTOGDELO
- ADV7183\_PFTOGDELE
- ADV7183\_PFTOGSIGN
- ADV7183\_PFTOG

Register Address: ADV7183\_DRIVE\_STRENGTH Register Fields:

- ADV7183\_DR\_STR
- ADV7183 DR STR C
- ADV7183\_DR\_STR\_S

Register Address: ADV7183\_IF\_COMP\_CTR

Register Fields:

ADV7183\_IFFILTSEL

Register Address: ADV7183\_VS\_MODE\_CTR

Register Fields:

- ADV7183\_VS\_COAST\_MODE
- ADV7183\_EXTEND\_VS\_MIN\_FREQ
- ADV7183\_EXTEND\_VS\_MAX\_FREQ

Interrupt (page2) registers

| Register             | Address | Value | r/w | Description        |
|----------------------|---------|-------|-----|--------------------|
| ADV7183_INT_CONFIG0  | 0x40    | 0x10  | rw  | Interrupt Config 0 |
| ADV7183_INT_STATUS1  | 0x42    |       | r   | Interrupt Status 1 |
| ADV7183_INT_CLEAR1   | 0x43    | 0x00  | W   | Interrupt Clear 1  |
| ADV7183_INT_MASK1    | 0x44    | 0x00  | rw  | Interrupt Maskb 1  |
| ADV7183_INT_STATUS2  | 0x46    |       | r   | Interrupt Status 2 |
| ADV7183_INT_CLEAR2   | 0x47    | 0xx0  | W   | Interrupt Clear 2  |
| ADV7183_INT_MASK2    | 0x48    | 0xx0  | rw  | Interrupt Maskb 2  |
| ADV7183_RAW_STATUS3  | 0x49    |       | r   | Raw Status 3       |
| ADV7183_CTI_DNR_CTR4 | 0x4A    |       | r   | Interrupt Status 3 |
| ADV7183_INT_CLEAR3   | 0x4B    | 0x00  | W   | Interrupt Clear 3  |
| ADV7183_INT_MASK3    | 0x4C    | 0x00  | rw  | Interrupt Maskb 3  |

Table 8 - ADV7183 Interrupt (Page 2) Registers

List of register fields.

Page: 25 of 34

Register Address: ADV7183\_INT\_CONFIG0 Register Fields:

- ADV7183 INTRQ DUR SEL
- ADV7183 MV INTRQ SEL
- ADV7183 MPU STIM INTRQ
- ADV7183\_INTRO\_OP\_SEL

Register Address: ADV7183\_INT\_STATUS1 Register Fields:

- ADV7183 MV PS CS Q
- ADV7183\_SD\_FR\_CHNG\_Q
- ADV7183\_SD\_UNLOCK\_Q
- ADV7183 SD LOCK Q

Register Address: ADV7183\_INT\_CLEAR1 Register Fields:

- ADV7183 MV PS CS CLR
- ADV7183\_SD\_FR\_CHNG\_CLR
- ADV7183\_SD\_UNLOCK\_CLR
- ADV7183\_SD\_LOCK\_CLR

Register Address: ADV7183\_INT\_MASK1 Register Fields:

- ADV7183 MV PS CS MSKB
- ADV7183\_SD\_FR\_CHNG\_MSKB
- ADV7183 SD UNLOCK MSKB
- ADV7183\_SD\_LOCK\_MSKB

Register Address: ADV7183\_INT\_STATUS2 Register Fields:

- ADV7183\_WSS\_CHNGD\_Q
- ADV7183 CGMS CHNGD Q
- ADV7183 CEMD Q
- ADV7183\_CCAPD\_Q

Register Address: ADV7183\_INT\_CLEAR2 Register Fields:

- ADV7183 MPU STIM INTRQ CLR
- ADV7183 WSS CHNGD CLR
- ADV7183 CGMS CHNGD CLR
- ADV7183 CEMD CLR
- ADV7183 CCAPD CLR

Register Address: ADV7183\_INT\_MASK2 Register Fields:

- ADV7183\_MPU\_STIM\_INTRQ\_MSKB
- ADV7183\_WSS\_CHNGD\_MSKB
- ADV7183 CGMS CHNGD MSKB
- ADV7183\_CEMD\_MSKB
- ADV7183\_CCAPD\_MSKB

Register Address: ADV7183\_RAW\_STATUS3 Register Fields:

- ADV7183\_SCM\_LOCK
- ADV7183\_SD\_H\_LOCK
- ADV7183 SD V LOCK

Page: 26 of 34

ADV7183\_SD\_OP\_50HZ\_RS

Register Address: ADV7183\_INT\_STATUS3 Register Fields:

- ADV7183\_PAL\_SW\_LK\_CHNG\_Q
- ADV7183 SCM LOCK CHNG Q
- ADV7183\_SD\_AD\_CHNG\_Q
- ADV7183\_SD\_H\_LOCK\_CHNG\_Q
- ADV7183\_SD\_V\_LOCK\_CHNG\_Q
- ADV7183\_SD\_OP\_CHNG\_Q

Register Address: ADV7183\_INT\_CLEAR3 Register Fields:

- ADV7183\_PAL\_SW\_LK\_CHNG\_CLR
- ADV7183\_SCM\_LOCK\_CHNG\_CLR
- ADV7183\_SD\_AD\_CHNG\_CLR
- ADV7183\_SD\_H\_LOCK\_CHNG\_CLR
- ADV7183\_SD\_V\_LOCK\_CHNG\_CLR
- ADV7183\_SD\_OP\_CHNG\_CLR

Register Address: ADV7183\_INT\_MASK3 Register Fields:

- ADV7183\_PAL\_SW\_LK\_CHNG\_MSKB
- ADV7183\_SCM\_LOCK\_CHNG\_MSKB
- ADV7183\_SD\_AD\_CHNG\_MSKB
- ADV7183\_SD\_H\_LOCK\_CHNG\_MSKB
- ADV7183 SD V LOCK CHNG MSKB
- ADV7183\_SD\_OP\_CHNG\_MSKB

Page: 27 of 34

# 8. Appendix

# 8.1. Using ADV7183 Device Driver in Applications

This section explains how to use ADV7183 device driver with an application.

#### **Device Manager Data memory allocation**

This section explains device manager memory allocation requirements for applications using this driver. The application should allocate base memory + memory for one TWI device + memory for one PPI device + memory for ADV7183 device + memory for other devices used by the application

#### **DMA Manager Data memory allocation**

This section explains DMA manager memory allocation requirements for applications using this driver. The application should allocate base memory + memory for 1 DMA channel for PPI device + memory for DMA channels used for devices included in the application

Initialize Ez-Kit, Interrupt manager, Deferred Callback Manager, DMA Manager, Device Manager (all application dependent)

#### a. ADV7183 (driver) initialization

- Step 1: Open ADV7183 Device driver with device specific entry point (refer section 6.1 for valid entry points)
- Step 2: Set TWI device number
- Step 3: Pass TWI Configuration table (refer section 8.2 for TWI configuration table examples)
- Step 4: Set PPI device number to be used for ADV7183 video data flow Example: // Set ADV7183 to use PPI 0 for video dataflow adi dev Control (ADV7183DriverHandle, ADI ADV7183 CMD OPEN PPI, (void \*) 0);
- Step 5: Command PPI to operate in NTSC or PAL mode Example:

// Set PPI to operate in PAL mode

adi dev Control (ADV7183DriverHandle, ADI AD7183 CMD SET VIDEO FORMAT, (void \*) 1);

### b. ADV7183 (hardware) initialization

Step 6: Set ADV7183 TWI device address

Example:

// set ADV7183 TWI device address

adi dev Control(ADV7183DriverHandle ADI AD7183 CMD SET TWI ADDRESS, (void \*) ADV7183 TWI ADDR0);

Step 7: Configure ADV7183 device to specific mode using device access commands (refer section 8.3.2 for examples)

> Page: 28 of 34

adi\_adv7183

### c. Video Dataflow configuration

Step 8: Set video dataflow method

Step 9: Load ADV7183 video buffers

Step10: Enable ADV7183 video dataflow

### d. Terminating ADV7183 driver

Step11: Terminate ADV7183 driver with adi\_dev\_Terminate()

Terminate DMA Manager, Deferred Callback etc.., (application dependent)

Page: 29 of 34

# 8.2. TWI Configuration tables

This section contains TWI configuration table examples to access ADV7183 internal registers using BF533, BF537 and BF561 Ez-Kits

```
// Select TWI clock frequency & duty cycle (in this case its 100MHz & 50% Duty Cycle) adi twi bit rate rate = { 100, 50 };
```

#### ADSP-BF533 EZ-KIT Lite & ADSP-BF561 EZ-KIT Lite

BF533 and BF561 do not have an inbuilt TWI peripheral. Analog Devices TWI device driver (adi\_twi.c) can be configured in pseudo mode to mimic TWI operation with selected port pins and a timer. BF533 and BF561 Ez-Kits are designed to use PF0 and PF1 to generate TWI SCL and SDA signals respectively.

```
// BF533 TWI mimic pins and timer (PF0=SCL, PF1=SDA & General purpose Timer 0 used for pseudo TWI)
// BF561 TWI mimic pins and timer (PF0=SCL, PF1=SDA & General purpose Timer 2 used for pseudo TWI)\
#if defined ( ADSPBF533 )
                                  // for BF533
adi twi pseudo port
                    pseudo = { ADI FLAG PF0, ADI FLAG PF1, ADI TMR GP TIMER 0,
                                  (ADI_INT_PERIPHERAL_ID) NULL };
#elif defined ( ADSPBF561 )
                                  // for BF561
adi twi pseudo port
                    pseudo = { ADI FLAG PF0, ADI FLAG PF1, ADI TMR GP TIMER 3,
                                  (ADI INT PERIPHERAL ID) NULL }:
#endif
// Pseudo TWI configuration table
ADI DEV CMD VALUE PAIR TWIConfig[] = {
       { ADI TWI CMD SET PSEUDO,
                                                       (void *)(&pseudo)
       ADI DEV CMD SET DATAFLOW METHOD,
                                                       (void *)ADI DEV MODE SEQ CHAINED
                                                       (void *)0x0000
       ADI TWI CMD SET FIFO.
                                                       (void *)(&rate)
(void *)1
       ADI TWI CMD SET RATE,
       ADI TWI CMD SET LOSTARB,
       ADI TWI CMD SET ANAK,
                                                       (void *)0
       ADI_TWI_CMD_SET_DNAK,
                                                       (void *)0
       { ADI_DEV_CMD_SET_DATAFLOW,
                                                       (void *)TRUE
       { ADI DEV CMD END,
                                                       NULL
```

#### **ADSP-BF537 EZ-KIT Lite**

BF537 have an inbuilt TWI peripheral and the TWI device driver (adi twi.c) can be configured to use hardware TWI

```
// Hardware TWI configuration table
ADI DEV CMD VALUE PAIR TWIConfig [] = {
       { ADI TWI CMD SET HARDWARE,
                                                      (void *)ADI INT TWI
       { ADI DEV CMD SET DATAFLOW METHOD,
                                                      (void *)ADI DEV MODE SEQ CHAINED
       { ADI_TWI_CMD_SET_FIFO,
                                                      (void *)0x0000
                                                                                               },
},
},
},
       ADI TWI CMD SET LOSTARB,
                                                      (void *)1
                                                      (void *)(&rate)
       ADI TWI CMD SET RATE,
       ADI TWI CMD SET ANAK,
                                                      (void *)0
       { ADI TWI CMD SET DNAK,
                                                      (void *)0
       ADI DEV CMD SET DATAFLOW,
                                                      (void *)TRUE
       { ADI DEV CMD END,
                                                      NULL
```

Page: 30 of 34

# 8.3. Accessing ADV7183 registers

This section explains how to access the ADV7183 internal registers using driver specific commands and device access commands (refer 'deviceaccess' documentation for more information).

For ADV7183 register map details, refer to ADV7183-decoder datasheet.

- Common register address 0x00 to 0x3F. (refer to Table 6)
- Page 1(Normal) register address 0x40 to 0xF9. (refer to Table 7)
- Page 2(Interrupt) register address 0x40 to 0x4C. (refer to Table 8)

Depending of the bit field ADV7183\_SUB\_USR\_EN value (0 or 1) of the ADV7183\_ADI\_CTR register, the page 1 or page 2 registers can be accessed by the user application program.

Using register access command with register macro name and field bit, the user does not have to manually set or clear the bit field ADV7183\_SUB\_USR\_EN of the ADV7183\_ADI\_CTR register to access page 1 or 2 registers. The device driver sets automatically the bit field ADV7183\_SUB\_USR\_EN of the ADV7183\_ADI\_CTR register to 0 if page 1 register is accessed or set to 1 if page 2 register is accessed.

### 8.3.1. Read ADV7183 internal registers

#### 1. Read a single register

```
// define the structure to access a single device register
ADI_DEV_ACCESS_REGISTER Read_Reg;

// Load the register address to be read
Read_Reg.Address = ADV7183_IDENT_RO;

// clear the Data location
Read_Reg.Data = 0;

// Application calls adi_dev_Control() function with corresponding command and value

// Register value will be read back to location - Read_Reg.Data
adi dev Control(DriverHandle, ADI_DEV_CMD_REGISTER_READ, (void *) & Read_Reg);
```

### 2. Read a specific register field

```
// define the structure to access a specific device register field
ADI_DEV_ACCESS_REGISTER_FIELD Read_Field;

// Load the device register address to be accessed
Read_Field.Address = ADV7183_STATUS1_RO;
// Load the device register field location to be read
Read_Field.Address = ADV7183_IN_LOCK;

// Clear the Read_Field.Data location
Read_Field.Data = 0;
// Application calls adi_dev_Control() function with corresponding command and value
// The register field value will be read back to location - Read_Field.Data
adi_dev_Control (DriverHandle, ADI_DEV_CMD_REGISTER_FIELD_READ, (void *) & Read_Field);
```

Page: 31 of 34

#### 3. Read table of registers

```
// define the structure to access table of device registers
    ADI_DEV_ACCESS_REGISTER Read_Regs[] = {
                                      {ADV7183_STATUS1 RO.
                                                                    0},
                                      {ADV7183_IDENT_RO,
                                                                    0},
                                      {ADV7183__STATUS2_RO,
                                                                    0},
                                      {ADI_DEV_REGEND, 0}
       /*MUST include delimiter */
                                                                    // Register access delimiter
    // Application calls adi_dev_Control() function with corresponding command and value
    // Present value of registers listed above will be read to corresponding Data location in Read Regs array
    //i.e., value of ADV7183 STATUS1 RO will be read to Read Regs[0].Data,
    // ADV7183_IDENT_RO to Read_Regs[1].Data and ADV7183_STATUS2_RO to Read_Regs[2].Data
    adi dev Control(DriverHandle, ADI DEV CMD REGISTER TABLE READ, (void *) &Read Regs[0]);
4. Read table of register(s) fields
    // define the structure to access table of device register(s) fields
    ADI_DEV_ACCESS_REGISTER_FIELD Read_Fields [] = {
                              {ADV7183 STATUS1 RO,
                                                             ADV7183 IN LOCK,
                                                                                           0},
                              {ADV7183_STATUS3_RO, 
{ADV7183_STATUS3_RO,
                                                             ADV7183 INTERLACE,
                                                                                           0},
                                                             ADV7183 STDFLDLEN,
                                                                                           0}.
    /*MUST include delimiter */ {ADI_DEV_REGEND,
                                                                    0}
                                                                            // Register access delimiter
                              }:
    // Application calls adi dev Control() function with corresponding command and value
    // Present value of register fields listed above will be read to corresponding Data location in Read_Fields array
    // i.e., value of ADV7183 IN LOCK will be read to Read Fields[0]. Data,
    // ADV7183_INTERLACE to Read_Fields [1].Data and ADV7183_STDFLDLEN to Read_Fields [2].Data
    adi_dev_Control(DriverHandle, ADI_DEV_CMD_REGISTER_TABLE_READ, (void *) & Read_Fields [0]);
5. Read block of registers
    // define the structure to access a block of registers
    ADI_DEV_ACCESS_REGISTER_BLOCK Read_Block;
    // load the number of registers to be read
    Read_Block.Count = 4;
    // load the starting address of the register block to be read
    Read_Block.Address = ADV7183_STATUS1_RO;
    // define a 'Count' sized array to hold register data read from the device
    u16 Block Data[4] = { 0 };
    // load the start address of the above array to Read_Block data pointer
    Read Block.pData = & Block Data [0];
```

// Application calls adi dev Control() function with corresponding command and value

// Present value of the registers in the given block will be read to corresponding Block\_Data[] array

adi dev Control(DriverHandle, ADI DEV CMD REGISTER BLOCK READ, (void \*) & Read Block);

// ADV7183 STATUS2 RO to Block Data[2] and ADV7183 STATUS3 RO to Block Data[3]

// value of ADV7183\_STATUS1\_RO will be read to Block\_Data [0], ADV7183\_IDENT\_RO to Block\_Data[1],

Page: 32 of 34

#### 8.3.2. Configure ADV7183 internal registers

#### 1. Configure a single ADV7183 register

/\*MUST include this\*/

```
// define the structure to access a single device register
    ADI_DEV_ACCESS_REGISTER Cfg_Reg;
    // Load the register address to be configured
    Cfg Reg.Address = ADV7183 EXTENDED OUTPUT CTR;
    //Load the configuration value to Cfg_Reg.Data location
    Cfg Reg.Data = 0x44;
    // Application calls adi_dev_Control() function with corresponding command and value
    //The device register will be configured with the value in Cfg_Reg.Data
    adi dev Control(DriverHandle, ADI DEV CMD REGISTER WRITE, (void *) & Cfg Reg);
2. Configure a specific register field
    // define the structure to access a specific device register field
    ADI_DEV_ACCESS_REGISTER_FIELD Cfg_Field;
    // Load the device register address to be accessed
    Cfg Field.Address = ADV7183 EXTENDED OUTPUT CTR;
    // Load the device register field location to be configured
    Cfg Field.Address = ADV7183 RANGE;
    // load the new field value
    Cfg Field.Data = 0;
    // Application calls adi_dev_Control() function with corresponding command and value
    // Selected register field will be configured with the value in Cfg_Field.Data
    adi_dev_Control(DriverHandle, ADI_DEV_CMD_REGISTER_FIELD_WRITE, (void *) & Cfg_Field);
3. Configure table of registers
    // define the structure to access table of device registers (register address, register configuration value)
    ADI_DEV_ACCESS_REGISTER Cfg_Regs[] = {
                                      {ADV7183 INPUT CTR,
                                                                            0x00.
                                      {ADV7183_VIDEO_SELECTION,
                                                                            0xC8},
                                      {ADV7183 OUTPUT CTR,
                                                                            0x0C}.
                                      {ADI_DEV_REGEND, 0 } };
       /*MUST include this*/
                                                                            // Register access delimiter
    // Application calls adi dev Control() function with corresponding command and value
    // Registers listed in the table will be configured with corresponding table Data values
    adi dev Control(DriverHandle, ADI DEV CMD REGISTER TABLE WRITE, (void *) & Cfg Regs[0]);
4. Configure a table of register(s) fields
    // define the structure to access table of device register(s) fields
    // register address, register field to configure, field configuration value
    ADI DEV ACCESS REGISTER FIELD Cfg Fields [] = {
```

{ADV7183 INPUT CTR, ADV7183 VID SEL,

{ADI DEV REGEND, 0 } };

{ADV7183 OUTPUT CTR, ADV7183 OF SEL,

{ADV7183 VIDEO SELECTION, ADV7183 BETACAM, 1},

Page: 33 of 34

// Register access delimiter

// Application calls adi\_dev\_Control() function with corresponding command and value
// Register fields listed in the above table will be configured with corresponding Data values
adi\_dev\_Control(DriverHandle, ADI\_DEV\_CMD\_REGISTER\_TABLE\_WRITE, (void \*) & Cfg\_Fields [0]);

#### 5. Configure a block of registers

```
// define the structure to access a block of registers
ADI_DEV_ACCESS_REGISTER_BLOCK Cfg_Block;

// load the number of registers to be configured
Cfg_Block.Count = 3;

// load the starting address of the register block to be configured
Cfg_Block.Address = ADV7183_INPUT_CTR;

// define a 'Count' sized array to hold register data read from the device
u16 Block_Cfg [3] = { 0x00, 0xC8, 0x0C };

// load the start address of the above array to Cfg_Block data pointer
Cfg_Block.pData = & Block_Cfg [0];

// Application calls adi_dev_Control() function with corresponding command and value
// Registers in the given block will be configured with corresponding values in Block_Cfg[] array
adi_dev_Control (DriverHandle, ADI_DEV_CMD_REGISTER_TABLE_WRITE, (void *) &Cfg_Block);
```

Page: 34 of 34