## SOC Encoder System

## **API Specification**

Version 2.3

© 2019 SOC Technologies Inc.



SOC is disclosing this user manual (the "Documentation") to you solely for use in the development of designs to operate with SOC hardware devices. You may not reproduce, distribute, republish, download, display, post, or transmit the Documentation in any form or by any means including, but not limited to, electronic, mechanical, photocopying, recording, or otherwise, without the prior written consent of SOC. SOC expressly disclaims any liability arising out of your use of the Documentation. SOC reserves the right, at its sole discretion, to change the Documentation without notice at any time. SOC assumes no obligation to correct any errors contained in the Documentation, or to advise you of any corrections or updates. SOC expressly disclaims any liability in connection with technical support or assistance that may be provided to you in connection with the Information.

THE DOCUMENTATION IS DISCLOSED TO YOU "AS-IS" WITH NO WARRANTY OF ANY KIND. SOC MAKES NO OTHER WARRANTIES, WHETHER EXPRESSED, IMPLIED, OR STATUTORY, REGARDING THE DOCUMENTATION, INCLUDING ANY WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, OR NONINFRINGEMENT OF THIRD-PARTY RIGHTS. IN NO EVENT WILL SOC BE LIABLE FOR ANY CONSEQUENTIAL, INDIRECT, EXEMPLARY, SPECIAL, OR INCIDENTAL DAMAGES, INCLUDING ANY LOSS OF DATA OR LOST PROFITS, ARISING FROM YOUR USE OF THE DOCUMENTATION.

© 2008-2019 SOC, Inc. All rights reserved.

SOC, the SOC logo, the Brand Window, and other designated brands included herein are trademarks of SOC, Inc.

## Table-1: Encoder System Configuration

| Addr<br>(HEX)                                                                                   | Information                                                                                                                                                                                                                                                                                                                                                                                                                                          | Access | Default          |  |
|-------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------------|--|
| 92                                                                                              | <ul> <li>Bit[2:0]: Multi-Channel/Time Sharing API Core Selection</li> <li>0 – Selects all cores for writing</li> <li>1-7 = Core #</li> <li>Note only 1 core can be read at a time. A value of 0 should not be used for reading registers This register is also used for indexing sub-API blocks such as Video Input, H264 Encoder</li> </ul>                                                                                                         | R/W    | 0x0000<br>0x0001 |  |
| The following registers are unique to each time-shared core (when used)                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                      |        |                  |  |
| 94                                                                                              | Bit[15:8]: Real-Time Encoding Frame Rate<br>Bit[7:0]: Target Frame Rate                                                                                                                                                                                                                                                                                                                                                                              | R      | NA               |  |
| 96                                                                                              | Bit[15:0]: (Presentation Latency / 2.84ms)<br>- Example: 0x1E = 85.2ms                                                                                                                                                                                                                                                                                                                                                                               | R/W    | 0x0010           |  |
| 97                                                                                              | Bit[9:0]: Target Bit Rate Value / 10 (Mbps)<br>- Example: 150(decimal) = 15Mbps                                                                                                                                                                                                                                                                                                                                                                      | R/W    | *0x0032          |  |
| 9E                                                                                              | <ul> <li>The constant bitrate register is used to restrict the output rate to a specific duty cycle. Care must be taken to ensure the CBR is larger than the Target Bit Rate (0x97).</li> <li>Bit[14:0]: Constant Bitrate Value / 10 (Mbps)</li> <li>Example: 150(decimal) = 15Mbps</li> <li>Bit[15]: Null TS Padding</li> <li>When a transport stream is used the 'unused bandwidth' can be null-packet padded when this bit is enabled.</li> </ul> | R/W    | 0x0000           |  |
| The following registers are shared between all cores even when muli/time-sharing cores are used |                                                                                                                                                                                                                                                                                                                                                                                                                                                      |        |                  |  |
| E5                                                                                              | Bit[31:16]: Codec Type: E265 = Encoder H265<br>Bit[15:0]: Firmware Version                                                                                                                                                                                                                                                                                                                                                                           |        |                  |  |
| E6                                                                                              | Bit[31:0]: Build Date<br>YYYYMMDD                                                                                                                                                                                                                                                                                                                                                                                                                    | R      | NA               |  |
| E7                                                                                              | Bit[31:0]: Build Time Stamp<br>- ##HHMMSS                                                                                                                                                                                                                                                                                                                                                                                                            | R      | NA               |  |
| 9D                                                                                              | Bit[21]: Time limted Core Expired<br>Bit[16]: Authentication Passed                                                                                                                                                                                                                                                                                                                                                                                  | R/W*   |                  |  |



|    | Bit[15]: EEPROM passed                                       |          |        |
|----|--------------------------------------------------------------|----------|--------|
|    | Bit[14]: DNA Passed                                          |          |        |
|    | Bit[13]: User TX Ready                                       |          |        |
|    | Bit[11]: Output Buffer Ready                                 |          | NA     |
|    | Bit[9]: DDR Fifo Buffer Present                              |          |        |
|    | Bit[8]: EEPROM Authentication Present                        |          |        |
|    | Bit[7]: DNA Authentication Present                           |          |        |
|    | Bit[6]: Bypass Output DDR Fifo*                              |          |        |
|    | Bit[3]: Disable CODEC Read*                                  |          |        |
|    | Bit[2]: Force CODEC Read*                                    |          |        |
|    | Bit[1]: Bypass Trsansport Stream DDR Fifo*                   |          |        |
|    | Bit[0]: Bypass Transport Stream Encoder*                     |          |        |
|    |                                                              |          |        |
|    | Note: Bit with (*) is toggle bit, i,e. write '1' to this bit |          |        |
|    | toggle the current value.                                    |          |        |
| 9F | Bit[11:8]: Max encoding channel number                       |          |        |
|    | Bit[3]: 4K encoding enabled                                  |          |        |
|    | Bit[2]: Audio enabled                                        | R        | NA     |
|    | Bit[1]: FPS60 enabled                                        |          |        |
|    | Bit[0]: 10 bits encoding enabled                             |          |        |
| E0 | Bit[5]: Final Encoder Reset                                  |          |        |
|    | Bit[2]: WatchDog Reset                                       |          |        |
|    | Bit[1]: Enable WatchDog*                                     | D / 147* | 0,0012 |
|    | (Wrtie x4321 to disable, x4320 to enable)                    | K/ VV    | 0X0012 |
|    | Bit[0]: API Controlled Reset*                                |          |        |
|    | (Write x55AA to trigger API reset)                           |          |        |
| E1 | Bit[5:4]: Audio Select for Transport Stream                  |          |        |
|    | The following Bits are toggle by writing '1' to the          |          |        |
|    | corresponding bit                                            | R/W      | 0x0010 |
|    | Bit[3]: Disable Video                                        |          |        |
|    | Bit[2]: Disable Audio                                        |          |        |

Default values with \* may vary depending on customer request of initial value. Default values marked 'NA' have no default value as they are dependent on user content, vary by build (build date).