

# Intel(R) IXP400 Software API Reference Manual

Automatically generated from sources, September 25, 2005.

INFORMATION IN THIS DOCUMENT IS PROVIDED IN CONNECTION WITH INTEL® PRODUCTS. NO LICENSE, EXPRESS OR IMPLIED, BY ESTOPPEL OR OTHERWISE, TO ANY INTELLECTUAL PROPERTY RIGHTS IS GRANTED BY THIS DOCUMENT. EXCEPT AS PROVIDED IN INTEL'S TERMS AND CONDITIONS OF SALE FOR SUCH PRODUCTS, INTEL ASSUMES NO LIABILITY WHATSOEVER, AND INTEL DISCLAIMS ANY EXPRESS OR IMPLIED WARRANTY, RELATING TO SALE AND/OR USE OF INTEL PRODUCTS INCLUDING LIABILITY OR WARRANTIES RELATING TO FITNESS FOR A PARTICULAR PURPOSE, MERCHANTABILITY, OR INFRINGEMENT OF ANY PATENT, COPYRIGHT OR OTHER INTELLECTUAL PROPERTY RIGHT. Intel products are not intended for use in medical, life saving, life sustaining, critical control or safety systems, or in nuclear facility applications.

Intel may make changes to specifications and product descriptions at any time, without notice.

Intel Corporation may have patents or pending patent applications, trademarks, copyrights, or other intellectual property rights that relate to the presented subject matter. The furnishing of documents and other materials and information does not provide any license, express or implied, by estoppel or otherwise, to any such patents, trademarks, copyrights, or other intellectual property rights.

Designers must not rely on the absence or characteristics of any features or instructions marked "reserved" or "undefined." Intel reserves these for future definition and shall have no responsibility whatsoever for conflicts or incompatibilities arising from future changes to them.

Intel processor numbers are not a measure of performance. Processor numbers differentiate features within each processor family, not across different processor families. See <a href="http://www.intel.com/products/processor">http://www.intel.com/products/processor</a> number for details.

Intel® IXP400 Software may contain design defects or errors known as errata which may cause the product to deviate from published specifications. Current characterized errata are available on request.

MPEG is an international standard for video compression/decompression promoted by ISO. Implementations of MPEG CODECs, or MPEG enabled platforms may require licenses from various entities, including Intel Corporation.

This document and the software described in it are furnished under license and may only be used or copied in accordance with the terms of the license. The information in this document is furnished for informational use only, is subject to change without notice, and should not be construed as a commitment by Intel Corporation. Intel Corporation assumes no responsibility or liability for any errors or inaccuracies that may appear in this document or any software that may be provided in association with this document. Except as permitted by such license, no part of this document may be reproduced, stored in a retrieval system, or transmitted in any form or by any means without the express written consent of Intel Corporation.

Except as permitted by such license, no part of this document may be reproduced, stored in a retrieval system, or transmitted in any form or by any means without the express written consent of Intel Corporation.

Contact your local Intel sales office or your distributor to obtain the latest specifications and before placing your product order.

Copies of documents which have an order number and are referenced in this document, or other Intel literature, may be obtained by calling 1–800–548–4725, or by visiting Intel's website at http://www.intel.com.

Intel, the Intel logo, and Intel XScale are trademarks or registered trademarks of Intel Corporation or its subsidiaries in the United States and other countries.

\*Other names and brands may be claimed as the property of others.

Copyright © Intel Corporation 2005

| Intel (R) IXP400 Software ADSL Driver APL                      | 1                             |
|----------------------------------------------------------------|-------------------------------|
| Typedefs                                                       |                               |
| Enumerations                                                   |                               |
| Functions                                                      | 2                             |
| Detailed Description                                           | 2                             |
| Typedef Documentation                                          |                               |
| Enumeration Type Documentation                                 |                               |
| Function Documentation                                         |                               |
|                                                                |                               |
| Intel (R) IXP400 Software Assertion Macros (IxAssert) API      | 12                            |
| Intel (R) IXP400 Software ATM Driver Access (IxAtmdAcc) API    | 12                            |
| Defines                                                        |                               |
| Typedefs                                                       |                               |
| Enumerations.                                                  |                               |
| Functions                                                      |                               |
| Detailed Description                                           |                               |
| Define Documentation                                           |                               |
| Typedef Documentation                                          |                               |
| Enumeration Type Documentation                                 |                               |
| Function Documentation                                         |                               |
| Function Documentation                                         |                               |
| Intel (R) IXP400 Software ATM Driver Access (IxAtmdAcc) Contro |                               |
| Modules                                                        | 36                            |
| Defines                                                        | 36                            |
| Typedefs                                                       | 36                            |
| Functions                                                      |                               |
| Detailed Description                                           | 39                            |
| Define Documentation                                           | 39                            |
| Typedef Documentation                                          | 39                            |
| Function Documentation                                         | 43                            |
| Intel (R) IXP400 Software ATM Driver Access (IxAtmdAcc) Utopia | Control ADI (Intol (D) IVD400 |
| Software ATM Driver Access (IxAtmdAcc) Ctopia                  |                               |
| Data Structures                                                |                               |
| Detailed Description                                           |                               |
| Detailed Description                                           |                               |
| Intel (R) IXP400 Software ATM Manager (IxAtmm) APL             |                               |
| Data Structures                                                | 60                            |
| Defines                                                        | 60                            |
| Typedefs                                                       | 61                            |
| Enumerations.                                                  |                               |
| Functions                                                      | 62                            |
| Detailed Description.                                          | 63                            |
| Define Documentation                                           | 63                            |
| Typedef Documentation                                          | 65                            |
| Enumeration Type Documentation                                 |                               |
| Function Documentation                                         | 66                            |

| Inte | el (R) IXP400 Software ATM Transmit Scheduler (IxAtmSch) API | 77  |
|------|--------------------------------------------------------------|-----|
|      | Defines                                                      |     |
|      | Functions                                                    |     |
|      | Detailed Description.                                        |     |
|      | Define Documentation                                         |     |
|      | Function Documentation                                       |     |
| Inte | el (R) IXP400 Software ATM Types (IxAtmTypes)                | 86  |
|      | Data Structures                                              |     |
|      | Defines                                                      | 86  |
|      | Typedefs                                                     | 87  |
|      | Enumerations                                                 | 88  |
|      | Detailed Description                                         | 88  |
|      | Define Documentation                                         | 88  |
|      | Typedef Documentation                                        | 91  |
|      | Enumeration Type Documentation                               | 92  |
| Inte | el (R) IXP400 Software Security (IxCryptoAcc) API            | 94  |
|      | Data Structures                                              | 94  |
|      | Defines                                                      | 94  |
|      | Typedefs                                                     | 96  |
|      | Enumerations                                                 | 97  |
|      | Functions                                                    | 99  |
|      | Detailed Description                                         | 101 |
|      | Define Documentation                                         | 101 |
|      | Typedef Documentation                                        | 105 |
|      | Enumeration Type Documentation                               | 108 |
|      | Function Documentation                                       | 112 |
| Inte | el (R) IXP400 Software DMA Types (IxDmaTypes)                | 131 |
|      | Enumerations                                                 | 131 |
|      | Detailed Description.                                        | 132 |
|      | Enumeration Type Documentation                               | 132 |
| Inte | el (R) IXP400 Software DMA Access Driver (IxDmaAcc) API      | 135 |
|      | Defines                                                      | 135 |
|      | Typedefs                                                     | 135 |
|      | Functions                                                    | 135 |
|      | Detailed Description.                                        | 136 |
|      | Define Documentation                                         | 136 |
|      | Typedef Documentation                                        | 136 |
|      | Function Documentation                                       | 136 |
| Inte | el (R) IXP400 Software Ethernet Access (IxEthAcc) API        | 139 |
|      | Data Structures                                              | 139 |
|      | Defines                                                      | 139 |
|      | Typedefs                                                     | 141 |
|      | Enumerations                                                 | 142 |

| Intel (R) IXP400 Software Ethernet Access (IxEthAcc) API                                |     |
|-----------------------------------------------------------------------------------------|-----|
| Functions                                                                               | 143 |
| Detailed Description.                                                                   | 14  |
| Define Documentation                                                                    | 14  |
| Typedef Documentation                                                                   | 150 |
| Enumeration Type Documentation                                                          | 159 |
| Function Documentation                                                                  | 16  |
| Intel (R) IXP400 Software Ethernet Database (IxEthDB) APL                               | 196 |
| Data Structures                                                                         |     |
| Defines                                                                                 |     |
| Typedefs                                                                                |     |
| Enumerations                                                                            |     |
| Functions                                                                               |     |
| Detailed Description.                                                                   |     |
| Define Documentation.                                                                   |     |
| Typedef Documentation                                                                   |     |
| Enumeration Type Documentation                                                          |     |
| Function Documentation                                                                  |     |
| Punction Documentation.                                                                 | 203 |
| Intel (R) IXP400 Software Ethernet Database Port Definitions (IxEthDBPortDefs)          |     |
| Data Structures                                                                         |     |
| Defines                                                                                 |     |
| Enumerations                                                                            |     |
| Variables                                                                               | 256 |
| Detailed Description.                                                                   | 250 |
| Define Documentation                                                                    | 250 |
| Enumeration Type Documentation                                                          | 258 |
| Variable Documentation                                                                  | 259 |
| Intel (R) IXP400 Software Ethernet Phy Access (IxEthMii) API                            | 26  |
| Functions                                                                               |     |
| Detailed Description.                                                                   |     |
| Function Documentation.                                                                 |     |
|                                                                                         |     |
| Intel (R) IXP400 Software Feature Control (IxFeatureCtrl) API                           |     |
| Modules                                                                                 |     |
| Defines                                                                                 | 265 |
| Typedefs                                                                                |     |
| Functions                                                                               | 26  |
| Detailed Description.                                                                   | 268 |
| Define Documentation                                                                    |     |
| Typedef Documentation                                                                   | 27  |
| Function Documentation                                                                  | 27  |
| Intel (R) IXP400 Software Configuration for Access Component [Intel (R) IXP400 Software | are |
| Feature Control (IxFeatureCtrl) API]                                                    |     |
| Defines                                                                                 | 2.7 |

| Intel (R) IXP400 Software Configuration for Access Compone Control (IxFeatureCtrl) API]   | ent [Intel (R) IXP400 Software Feature |
|-------------------------------------------------------------------------------------------|----------------------------------------|
| Enumerations                                                                              | 275                                    |
| Detailed Description.                                                                     |                                        |
| Define Documentation                                                                      |                                        |
| Enumeration Type Documentation                                                            |                                        |
| Intel (R) IXP400 Software HSS Access (IxHssAcc) APL                                       | 279                                    |
| Data Structures                                                                           |                                        |
| Defines                                                                                   | 279                                    |
| Typedefs                                                                                  | 280                                    |
| Enumerations                                                                              | 281                                    |
| Functions                                                                                 | 284                                    |
| Detailed Description                                                                      | 287                                    |
| Define Documentation                                                                      | 288                                    |
| Typedef Documentation                                                                     | 291                                    |
| Enumeration Type Documentation                                                            | 293                                    |
| Function Documentation                                                                    | 300                                    |
| Intel (R) IXP400 Software I2C Driver(IxI2cDrv) APL                                        | 311                                    |
| Data Structures                                                                           |                                        |
| Defines                                                                                   |                                        |
| Typedefs                                                                                  |                                        |
| Enumerations                                                                              |                                        |
| Functions.                                                                                |                                        |
| Detailed Description.                                                                     |                                        |
| Define Documentation                                                                      |                                        |
| Typedef Documentation                                                                     |                                        |
| Enumeration Type Documentation                                                            |                                        |
| Function Documentation                                                                    |                                        |
| Intel (R) IXP400 Software NPE–Downloader (IxNpeDl) API                                    | 329                                    |
| Modules                                                                                   |                                        |
| Defines                                                                                   |                                        |
| Functions                                                                                 |                                        |
| Detailed Description.                                                                     |                                        |
| Define Documentation                                                                      |                                        |
| Function Documentation                                                                    |                                        |
| Intel (D) IVD400 Seftware NDE Image ID Definition [Intel (D                               | IVD400 Coftware                        |
| Intel (R) IXP400 Software NPE Image ID Definition [Intel (R NPE–Downloader (IxNpeDl) API] |                                        |
| Defines                                                                                   |                                        |
| Enumerations                                                                              |                                        |
| Detailed Description.                                                                     |                                        |
| Define Documentation                                                                      |                                        |
| Enumeration Type Documentation                                                            |                                        |

| Intel (R) IXP400 Software NPE Message Handler (IxNpeMh) APL         | 339 |
|---------------------------------------------------------------------|-----|
| Data Structures                                                     |     |
| Defines                                                             |     |
| Typedefs                                                            |     |
| Enumerations                                                        |     |
| Functions                                                           |     |
| Detailed Description.                                               |     |
| Define Documentation                                                |     |
| Typedef Documentation                                               |     |
| Enumeration Type Documentation                                      |     |
| Function Documentation                                              |     |
| IXP400 NPE Microcode Image Library                                  | 349 |
| Defines                                                             | 349 |
| Detailed Description                                                | 352 |
| Define Documentation                                                | 352 |
| Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) APL | 359 |
| Data Structures                                                     |     |
| Typedefs                                                            |     |
| Enumerations                                                        |     |
| Functions                                                           |     |
| Detailed Description                                                |     |
| Typedef Documentation                                               |     |
| Enumeration Type Documentation                                      |     |
| Function Documentation                                              |     |
| Intel (R) IXP400 Software Performance Profiling (IxPerfProfAcc) API | 374 |
| Data Structures                                                     |     |
| Defines                                                             |     |
| Enumerations                                                        |     |
| Functions                                                           |     |
| Detailed Description.                                               |     |
| Define Documentation.                                               |     |
| Enumeration Type Documentation                                      |     |
| Function Documentation                                              |     |
| Intel (R) IXP400 Software Queue Manager (IxQMgr) API                | 404 |
| Data Structures                                                     |     |
| Defines                                                             |     |
| Typedefs                                                            |     |
| Enumerations                                                        |     |
| Functions.                                                          |     |
| Variables                                                           |     |
| Detailed Description.                                               |     |
| Define Documentation                                                |     |
| Typedef Documentation                                               |     |
| Enumeration Type Documentation                                      |     |

| Intel (R) IXP400 Software Queue Manager (IxQMgr) API            |     |
|-----------------------------------------------------------------|-----|
| Function Documentation                                          | 432 |
|                                                                 |     |
| Intel (R) IXP400 Software SSP Serial Port Access (IxSspAcc) API |     |
| Data Structures                                                 |     |
| Typedefs                                                        |     |
| Enumerations.                                                   |     |
| Functions                                                       |     |
| Detailed Description.                                           |     |
| Typedef Documentation                                           | 454 |
| Enumeration Type Documentation                                  | 455 |
| Function Documentation                                          | 45^ |
| Intel (R) IXP400 Software Timer Control (IxTimerCtrl) API       | 472 |
| Defines                                                         | 472 |
| Typedefs                                                        | 472 |
| Enumerations                                                    | 472 |
| Functions                                                       | 472 |
| Detailed Description                                            | 473 |
| Define Documentation                                            | 473 |
| Typedef Documentation                                           | 473 |
| Enumeration Type Documentation                                  | 474 |
| Function Documentation                                          | 474 |
| Intel (R) IXP400 Software Time Sync Access Component API        | 47  |
| Data Structures                                                 |     |
| Typedefs                                                        | 478 |
| Enumerations                                                    | 478 |
| Functions                                                       | 479 |
| Detailed Description                                            | 480 |
| Typedef Documentation                                           | 48  |
| Enumeration Type Documentation                                  |     |
| Function Documentation                                          |     |
| Intel (R) IXP400 Software Types (IxTypes)                       | 492 |
| Defines                                                         | 492 |
| Typedefs                                                        | 492 |
| Detailed Description                                            | 492 |
| Intel (R) IXP400 Software UART Access (IxUARTAcc) API           | 49  |
| Modules                                                         | 493 |
| Data Structures                                                 | 493 |
| Enumerations                                                    | 493 |
| Functions                                                       | 493 |
| Detailed Description                                            | 494 |
| Enumeration Type Documentation                                  | 494 |
| Function Documentation                                          |     |

| Defines for Default Values [Intel (R) IXP400 Software UART Access (IxUARTAcc) API]   |     |
|--------------------------------------------------------------------------------------|-----|
| Defines                                                                              |     |
| Detailed Description.                                                                |     |
| Define Documentation                                                                 | 497 |
| Defines for IOCTL Commands [Intel (R) IXP400 Software UART Access (IxUARTAcc) API].  | 499 |
| Defines                                                                              | 499 |
| Detailed Description                                                                 | 499 |
| Define Documentation                                                                 | 499 |
| Defines for IOCTL Arguments [Intel (R) IXP400 Software UART Access (IxUARTAcc) API]. | 501 |
| Defines                                                                              | 501 |
| Detailed Description                                                                 | 501 |
| Define Documentation                                                                 | 502 |
| Intel (R) IXP400 Software Version ID (IxVersionId)                                   | 504 |
| Defines                                                                              |     |
| Detailed Description.                                                                | 505 |
| Define Documentation                                                                 | 505 |
| Intel(R) IXP400 Software USB Driver Public API                                       | 508 |
| Data Structures                                                                      |     |
| Defines                                                                              | 508 |
| Typedefs                                                                             | 513 |
| Enumerations                                                                         | 513 |
| Functions                                                                            | 515 |
| Detailed Description                                                                 | 517 |
| Define Documentation                                                                 | 517 |
| Enumeration Type Documentation                                                       | 530 |
| Function Documentation                                                               | 532 |
| Intel (R) IXP400 Software Codelets                                                   | 539 |
| Modules                                                                              | 539 |
| Detailed Description.                                                                | 540 |
| IXP400 ATM Codelet (IxAtmCodelet) API [Intel (R) IXP400 Software Codelets]           | 541 |
| Defines                                                                              | 541 |
| Functions                                                                            | 541 |
| Detailed Description                                                                 | 542 |
| Define Documentation.                                                                | 546 |
| Function Documentation                                                               | 547 |
| Intel (R) IXP400 Software DMA Access Codelet (IxDmaAccCodelet) API [Intel (R) IXP400 |     |
| Software Codelets]                                                                   |     |
| Defines                                                                              |     |
| Functions                                                                            |     |
| Detailed Description.                                                                |     |
| Define Documentation.                                                                | 549 |

| Intel (<br>Code | (R) IXP400 Software DMA Access Codelet (IxDmaAccCodelet) API [Intel (R) IXP400 Soft                                           | ware        |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------|-------------|
| Couc            | Function Documentation                                                                                                        | 550         |
| Intol (         | (D) IVD400 Software Ethanet Asl5 (IvEthAsl5Ann) ADI (Intel (D) IVD400 Software                                                |             |
|                 | (R) IXP400 Software Ethenet Aal5 (IxEthAal5App) API [Intel (R) IXP400 Software elets]                                         | 551         |
| Coue            | Defines                                                                                                                       |             |
|                 | Functions                                                                                                                     |             |
|                 | Detailed Description.                                                                                                         |             |
|                 | Define Documentation.                                                                                                         |             |
|                 | Function Documentation.                                                                                                       |             |
|                 |                                                                                                                               |             |
|                 | (R) IXP400 Software Ethernet Access Codelet (IxEthAccCodelet) API [Intel (R) IXP400                                           |             |
| Softw           | vare Codelets]                                                                                                                |             |
|                 | Defines                                                                                                                       | 562         |
|                 | Enumerations                                                                                                                  | 563         |
|                 | Functions                                                                                                                     | 563         |
|                 | Detailed Description.                                                                                                         | 563         |
|                 | Define Documentation.                                                                                                         | 566         |
|                 | Enumeration Type Documentation.                                                                                               | 568         |
| T 4 1 4         | (D) WD400 C 64                                                                                                                |             |
|                 | (R) IXP400 Software HSS Access Codelet (IxHssAccCodelet) API [Intel (R) IXP400                                                | <b>55</b> 0 |
| Soitw           | ware Codelets]                                                                                                                |             |
|                 | Defines                                                                                                                       |             |
|                 | Functions                                                                                                                     |             |
|                 | Detailed Description                                                                                                          | 570         |
| Intel (         | (R) IXP400 Software PerfProf Access Codelet [Intel (R) IXP400 Software Codelets]                                              | 574         |
| ,               | Defines                                                                                                                       |             |
|                 | Enumerations                                                                                                                  |             |
|                 | Functions                                                                                                                     |             |
|                 | Detailed Description.                                                                                                         |             |
|                 | Define Documentation                                                                                                          |             |
|                 | Enumeration Type Documentation.                                                                                               |             |
|                 |                                                                                                                               |             |
|                 | (R) IXP400 Software USB RNDIS Codelet (IxUSBRNDIS) API [Intel (R) IXP400 Software                                             |             |
| Code            | elets]                                                                                                                        | 579         |
|                 | Modules                                                                                                                       | 579         |
|                 | Functions                                                                                                                     | 579         |
|                 | Detailed Description                                                                                                          | 580         |
|                 | Function Documentation                                                                                                        | 580         |
| T 4 T :         | (D) IVIDAGO C C                                                                                                               |             |
|                 | (R) IXP400 Software USB RNDIS End Driver Codelet (IxUSBRNDIS) API [Intel (R) 100 Software USB RNDIS Codelet (IxUSBRNDIS) API] | <b>50</b> 1 |
| 1AP4            | Defines                                                                                                                       |             |
|                 |                                                                                                                               |             |
|                 | Functions                                                                                                                     |             |
|                 | Detailed Description  Define Documentation                                                                                    |             |
|                 | Define Documentation.                                                                                                         |             |

|           | ) IXP400 Software USB RNDIS End Driver Codelet (IxUSBRNDIS) API [Intel (R) IXP4<br>re USB RNDIS Codelet (IxUSBRNDIS) API] | 100 |
|-----------|---------------------------------------------------------------------------------------------------------------------------|-----|
|           | Function Documentation                                                                                                    | 58′ |
| I4-1 (D)  | A IVD400 CR4 LICD DNIDIC V J C JL-4 /ILICDDNIDIC) [I4-1 (D) IVD400                                                        |     |
|           | IXP400 Software USB RNDIS Vendor Codelet (IxUSBRNDIS) [Intel (R) IXP400 to USB RNDIS Codelet (IxUSBRNDIS) API]            | 500 |
|           | Defines                                                                                                                   |     |
|           | Detailed Description                                                                                                      |     |
|           | Define Documentation                                                                                                      |     |
| 1         | Seriic Documentation.                                                                                                     |     |
| Intel (R) | IXP400 Software Parity Error Notifier Access Codelet [Intel (R) IXP400 Software                                           |     |
|           | s]                                                                                                                        | 59  |
|           | Defines                                                                                                                   |     |
| F         | Functions                                                                                                                 | 592 |
| I         | Detailed Description                                                                                                      | 592 |
|           | Define Documentation                                                                                                      |     |
| F         | Function Documentation                                                                                                    | 590 |
|           |                                                                                                                           |     |
| Intel (R) | IXP400 Software Time Sync Access Codelet [Intel (R) IXP400 Software Codelets]                                             | 598 |
| Ι         | Data Structures                                                                                                           | 598 |
| I         | Defines                                                                                                                   | 598 |
| 7         | Гуреdefs                                                                                                                  | 600 |
|           | Enumerations                                                                                                              |     |
| F         | Functions                                                                                                                 | 600 |
| I         | Detailed Description                                                                                                      | 600 |
| Ι         | Define Documentation                                                                                                      | 603 |
| 7         | Typedef Documentation                                                                                                     | 60′ |
|           | Enumeration Type Documentation                                                                                            |     |
| F         | Function Documentation                                                                                                    | 60′ |
|           |                                                                                                                           |     |
|           | IXP400 Software Crypto Access Codelet [Intel (R) IXP400 Software Codelets]                                                |     |
|           | Defines                                                                                                                   |     |
|           | Functions                                                                                                                 |     |
|           | Detailed Description                                                                                                      |     |
|           | Define Documentation                                                                                                      |     |
| F         | Function Documentation                                                                                                    | 619 |
| Channel   | lisedStats Struct Reference                                                                                               | 62  |
|           | Data Fields                                                                                                               |     |
|           | Detailed Description                                                                                                      |     |
|           |                                                                                                                           |     |
| General   | Stats Struct Reference                                                                                                    | 622 |
| I         | Data Fields                                                                                                               | 622 |
| Ι         | Detailed Description                                                                                                      | 622 |
| IvAtmC    | odeletStats Struct Reference                                                                                              | 62  |
|           | Data Fields                                                                                                               |     |
|           | Detailed Description                                                                                                      |     |
| 1         | //wii/g //ovii/Uth                                                                                                        |     |

| IxAtmdAccUtopiaConfig Struct Reference [Intel (R) IXP400 Software ATM Driver Access  |     |
|--------------------------------------------------------------------------------------|-----|
| (IxAtmdAcc) Utopia Control API]                                                      | 624 |
| Data Fields                                                                          | 624 |
| Detailed Description.                                                                | 625 |
| Field Documentation                                                                  | 625 |
| IxAtmdAccUtopiaConfig::UtRxConfig_Struct Reference [Intel (R) IXP400 Software ATM    |     |
| Driver Access (IxAtmdAcc) Utopia Control API]                                        |     |
| Data Fields.                                                                         |     |
| Detailed Description.                                                                |     |
| Field Documentation                                                                  |     |
| IxAtmdAccUtopiaConfig::UtRxDefineIdle_ Struct Reference [Intel (R) IXP400 Software A | TM  |
| Driver Access (IxAtmdAcc) Utopia Control API]                                        | 635 |
| Data Fields                                                                          | 635 |
| Detailed Description.                                                                | 635 |
| Field Documentation                                                                  |     |
| IxAtmdAccUtopiaConfig::UtRxEnableFields_ Struct Reference [Intel (R) IXP400 Software | ATM |
| Driver Access (IxAtmdAcc) Utopia Control API]                                        | 637 |
| Data Fields                                                                          | 637 |
| Detailed Description.                                                                | 639 |
| Field Documentation                                                                  | 639 |
| IxAtmdAccUtopiaConfig::UtRxStatsConfig_ Struct Reference [Intel (R) IXP400 Software  | ATM |
| Driver Access (IxAtmdAcc) Utopia Control API]                                        | 645 |
| Data Fields                                                                          | 645 |
| Detailed Description                                                                 | 645 |
| Field Documentation                                                                  | 646 |
| IxAtmdAccUtopiaConfig::UtRxTransTable0_ Struct Reference [Intel (R) IXP400 Software  |     |
| Driver Access (IxAtmdAcc) Utopia Control API]                                        | 647 |
| Data Fields                                                                          |     |
| Detailed Description                                                                 |     |
| Field Documentation                                                                  | 647 |
| IxAtmdAccUtopiaConfig::UtRxTransTable1_ Struct Reference [Intel (R) IXP400 Software  |     |
| Driver Access (IxAtmdAcc) Utopia Control API]                                        | 650 |
| Data Fields                                                                          |     |
| Detailed Description                                                                 | 650 |
| Field Documentation                                                                  | 650 |
| IxAtmdAccUtopiaConfig::UtRxTransTable2_ Struct Reference [Intel (R) IXP400 Software  |     |
| Driver Access (IxAtmdAcc) Utopia Control API]                                        |     |
| Data Fields                                                                          |     |
| Detailed Description                                                                 |     |
| Field Documentation                                                                  | 653 |

| IxAtmdAccUtopiaConfig::UtRxTransTable3_ Struct Reference [Intel (R) IXP400 Software A' | TM  |
|----------------------------------------------------------------------------------------|-----|
| Driver Access (IxAtmdAcc) Utopia Control API]                                          | 656 |
| Data Fields                                                                            | 656 |
| Detailed Description                                                                   | 656 |
| Field Documentation                                                                    | 656 |
| IxAtmdAccUtopiaConfig::UtRxTransTable4_ Struct Reference [Intel (R) IXP400 Software A' | тм  |
| Driver Access (IxAtmdAcc) Utopia Control API]                                          |     |
| Data Fields.                                                                           |     |
| Detailed Description.                                                                  |     |
| Field Documentation                                                                    |     |
| IxAtmdAccUtopiaConfig::UtRxTransTable5_ Struct Reference [Intel (R) IXP400 Software A' | TM  |
| Driver Access (IxAtmdAcc) Utopia Control API]                                          |     |
| Data Fields.                                                                           |     |
| Detailed Description.                                                                  |     |
| Field Documentation                                                                    |     |
| IxAtmdAccUtopiaConfig::UtSysConfig_Struct Reference [Intel (R) IXP400 Software ATM     |     |
| Driver Access (IxAtmdAcc) Utopia Control API]                                          | 663 |
| Data Fields.                                                                           |     |
| Detailed Description.                                                                  |     |
| Field Documentation                                                                    | 664 |
| IxAtmdAccUtopiaConfig::UtTxConfig_ Struct Reference [Intel (R) IXP400 Software ATM     |     |
| Driver Access (IxAtmdAcc) Utopia Control API]                                          | 666 |
| Data Fields.                                                                           | 666 |
| Detailed Description.                                                                  | 667 |
| Field Documentation                                                                    | 667 |
| IxAtmdAccUtopiaConfig::UtTxDefineIdle_ Struct Reference [Intel (R) IXP400 Software ATM | 1   |
| Driver Access (IxAtmdAcc) Utopia Control API]                                          | 671 |
| Data Fields                                                                            | 671 |
| Detailed Description.                                                                  | 671 |
| Field Documentation                                                                    | 672 |
| IxAtmdAccUtopiaConfig::UtTxEnableFields_ Struct Reference [Intel (R) IXP400 Software A | TM  |
| Driver Access (IxAtmdAcc) Utopia Control API]                                          |     |
| Data Fields                                                                            |     |
| Detailed Description.                                                                  | 674 |
| Field Documentation                                                                    | 674 |
| IxAtmdAccUtopiaConfig::UtTxStatsConfig_ Struct Reference [Intel (R) IXP400 Software AT |     |
| Driver Access (IxAtmdAcc) Utopia Control API]                                          |     |
| Data Fields                                                                            |     |
| Detailed Description.                                                                  |     |
| Field Documentation                                                                    | 679 |

| IxAtmdAccUtopiaConfig::UtTxTransTable0_ Struct Reference [Intel (R) IXP400 Software A7 | ГМ  |
|----------------------------------------------------------------------------------------|-----|
| Driver Access (IxAtmdAcc) Utopia Control API]                                          | 680 |
| Data Fields                                                                            | 680 |
| Detailed Description                                                                   | 680 |
| Field Documentation                                                                    | 680 |
| IxAtmdAccUtopiaConfig::UtTxTransTable1_ Struct Reference [Intel (R) IXP400 Software AT | ГМ  |
| Driver Access (IxAtmdAcc) Utopia Control API]                                          |     |
| Data Fields.                                                                           |     |
| Detailed Description.                                                                  |     |
| Field Documentation                                                                    |     |
| IxAtmdAccUtopiaConfig::UtTxTransTable2_ Struct Reference [Intel (R) IXP400 Software A  | ГМ  |
| Driver Access (IxAtmdAcc) Utopia Control API]                                          |     |
| Data Fields.                                                                           |     |
| Detailed Description.                                                                  |     |
| Field Documentation                                                                    |     |
| IxAtmdAccUtopiaConfig::UtTxTransTable3_ Struct Reference [Intel (R) IXP400 Software A  | ГМ  |
| Driver Access (IxAtmdAcc) Utopia Control API]                                          | 689 |
| Data Fields                                                                            | 689 |
| Detailed Description                                                                   | 689 |
| Field Documentation                                                                    | 689 |
| IxAtmdAccUtopiaConfig::UtTxTransTable4_ Struct Reference [Intel (R) IXP400 Software A  | ΓМ  |
| Driver Access (IxAtmdAcc) Utopia Control API]                                          | 692 |
| Data Fields                                                                            | 692 |
| Detailed Description                                                                   | 692 |
| Field Documentation                                                                    | 692 |
| IxAtmdAccUtopiaConfig::UtTxTransTable5_ Struct Reference [Intel (R) IXP400 Software A  |     |
| Driver Access (IxAtmdAcc) Utopia Control API]                                          |     |
| Data Fields.                                                                           |     |
| Detailed Description.                                                                  |     |
| Field Documentation                                                                    | 695 |
| IxAtmdAccUtopiaStatus Struct Reference [Intel (R) IXP400 Software ATM Driver Access    |     |
| (IxAtmdAcc) Utopia Control API]                                                        |     |
| Data Fields                                                                            |     |
| Detailed Description                                                                   |     |
| Field Documentation                                                                    | 697 |
| IxAtmdAccUtopiaStatus::UtRxCellConditionStatus_Struct Reference [Intel (R) IXP400      |     |
| Software ATM Driver Access (IxAtmdAcc) Utopia Control API]                             |     |
| Data Fields                                                                            |     |
| Detailed Description.                                                                  |     |
| Field Documentation                                                                    | 700 |

| $IxAtmdAccUtopiaStatus:: UtTxCellConditionStatus\_Struct\ Reference\ [Intel\ (R)\ IXP400$ | Software    |
|-------------------------------------------------------------------------------------------|-------------|
| ATM Driver Access (IxAtmdAcc) Utopia Control API]                                         |             |
| Data Fields                                                                               | 702         |
| Detailed Description                                                                      | 702         |
| Field Documentation                                                                       | 702         |
| IxAtmmPortCfg Struct Reference [Intel (R) IXP400 Software ATM Manager (IxAtmm)            | API]705     |
| Data Fields                                                                               | 705         |
| Detailed Description.                                                                     | 705         |
| Field Documentation                                                                       | 705         |
| IxAtmmVc Struct Reference [Intel (R) IXP400 Software ATM Manager (IxAtmm) API]            | 707         |
| Data Fields                                                                               | 707         |
| Detailed Description                                                                      | 707         |
| Field Documentation                                                                       | 707         |
| IxAtmScheduleTable Struct Reference [Intel (R) IXP400 Software ATM Types (IxAtmTy         | ypes)]709   |
| Data Fields                                                                               | 709         |
| Detailed Description                                                                      | 709         |
| Field Documentation                                                                       | 709         |
| IxAtmScheduleTableEntry Struct Reference [Intel (R) IXP400 Software ATM Types             |             |
| (IxAtmTypes)]                                                                             | 711         |
| Data Fields                                                                               | 711         |
| Detailed Description.                                                                     | 711         |
| Field Documentation                                                                       | 711         |
| IxAtmTrafficDescriptor Struct Reference [Intel (R) IXP400 Software ATM Types (IxAtn       | nTypes)]713 |
| Data Fields                                                                               | 713         |
| Detailed Description.                                                                     | 713         |
| Field Documentation                                                                       | 714         |
| IxCryptoAccAuthCtx Struct Reference [Intel (R) IXP400 Software Security (IxCryptoAc       | cc) API]716 |
| Data Fields                                                                               | 716         |
| Detailed Description                                                                      | 716         |
| Field Documentation                                                                       | 717         |
| IxCryptoAccCipherCtx Struct Reference [Intel (R) IXP400 Software Security (IxCryptoA      | Acc) API    |
| ]                                                                                         |             |
| Data Fields.                                                                              |             |
| Detailed Description.                                                                     |             |
| Field Documentation                                                                       | 720         |
| IxCryptoAccCtx Struct Reference [Intel (R) IXP400 Software Security (IxCryptoAcc) AF      | _           |
| Data Fields                                                                               |             |
| Detailed Description.                                                                     |             |
| Field Documentation                                                                       | 722         |

| IxCryptoAccPkeEauBnAddSubMulOperands Struct Reference [Intel (R) IXP400 Software                                                                                                    |     |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| Security (IxCryptoAcc) API]                                                                                                                                                         | 724 |
| Data Fields                                                                                                                                                                         | 724 |
| Detailed Description.                                                                                                                                                               | 724 |
| Field Documentation                                                                                                                                                                 | 724 |
| IxCryptoAccPkeEauBnModOperands Struct Reference [Intel (R) IXP400 Software Security                                                                                                 |     |
| (IxCryptoAcc) API]                                                                                                                                                                  | 725 |
| Data Fields.                                                                                                                                                                        |     |
| Detailed Description.                                                                                                                                                               |     |
| Field Documentation.                                                                                                                                                                |     |
| IxCryptoAccPkeEauInOperands Union Reference [Intel (R) IXP400 Software Security                                                                                                     |     |
| (IxCryptoAcc) API]                                                                                                                                                                  | 726 |
| Data Fields.                                                                                                                                                                        | 726 |
| Detailed Description.                                                                                                                                                               | 726 |
| Field Documentation                                                                                                                                                                 |     |
| IxCryptoAccPkeEauModExpOperands Struct Reference [Intel (R) IXP400 Software Security                                                                                                |     |
| (IxCryptoAcc) API]                                                                                                                                                                  | 728 |
| Data Fields                                                                                                                                                                         | 728 |
| Detailed Description.                                                                                                                                                               | 728 |
| Field Documentation                                                                                                                                                                 | 728 |
| IxCryptoAccPkeEauOperand Struct Reference [Intel (R) IXP400 Software Security                                                                                                       |     |
| (IxCryptoAcc) API]                                                                                                                                                                  | 730 |
| Data Fields                                                                                                                                                                         | 730 |
| Detailed Description.                                                                                                                                                               | 730 |
| Field Documentation                                                                                                                                                                 | 730 |
| IxCryptoCodeletServiceParam Struct Reference                                                                                                                                        |     |
| Data Fields                                                                                                                                                                         |     |
| Detailed Description.                                                                                                                                                               |     |
| Field Documentation                                                                                                                                                                 | 732 |
| IxEthAccMacAddr Struct Reference [Intel (R) IXP400 Software Ethernet Access (IxEthAcc) API                                                                                          |     |
| J                                                                                                                                                                                   |     |
| Detailed Description.                                                                                                                                                               |     |
| Field Documentation.                                                                                                                                                                |     |
| 1 leid Documentation                                                                                                                                                                | 133 |
| IxEthAccNe Struct Reference [Intel (R) IXP400 Software Ethernet Access (IxEthAcc) API, Intel (R) IXP400 Software Ethernet Access (IxEthAcc) API, Intel (R) IXP400 Software Ethernet |     |
| Access (IxEthAcc) API]                                                                                                                                                              | 736 |
| Data Fields.                                                                                                                                                                        |     |
| Detailed Description.                                                                                                                                                               |     |
| Field Documentation                                                                                                                                                                 |     |

| IxEthDBMacAddr Struct Reference [Intel (R) IXP400 Software Ethernet Database (IxEthDB)          |     |
|-------------------------------------------------------------------------------------------------|-----|
| API]                                                                                            |     |
| Data Fields                                                                                     | 739 |
| Detailed Description                                                                            | 739 |
| IxEthDBPortDefinition Struct Reference [Intel (R) IXP400 Software Ethernet Database Port        |     |
| Definitions (IxEthDBPortDefs)]                                                                  | 740 |
| Data Fields                                                                                     | 740 |
| Detailed Description                                                                            | 740 |
| IxEthDBWiFiRecData Struct Reference [Intel (R) IXP400 Software Ethernet Database (IxEthDB) API] | 7/1 |
| Data Fields.                                                                                    |     |
| Detailed Description.                                                                           |     |
| Detailed Description.                                                                           | /41 |
| IxEthEthObjStats Struct Reference [Intel (R) IXP400 Software Ethernet Access (IxEthAcc) API].   |     |
| Data Fields                                                                                     |     |
| Detailed Description                                                                            |     |
| Field Documentation                                                                             | /44 |
| IxHssAccCodeletStats Struct Reference                                                           |     |
| Data Fields                                                                                     |     |
| Detailed Description                                                                            | 748 |
| IxHssAccConfigParams Struct Reference [Intel (R) IXP400 Software HSS Access (IxHssAcc) API      |     |
| Data Fields.                                                                                    |     |
| Detailed Description.                                                                           |     |
| Field Documentation.                                                                            |     |
|                                                                                                 |     |
| IxHssAccHdlcMode Struct Reference [Intel (R) IXP400 Software HSS Access (IxHssAcc) API]         |     |
| Data Fields                                                                                     |     |
| Detailed Description                                                                            |     |
| Field Documentation                                                                             | 752 |
| IxHssAccPktHdlcFraming Struct Reference [Intel (R) IXP400 Software HSS Access (IxHssAcc)        |     |
| API]                                                                                            |     |
| Data Fields                                                                                     |     |
| Detailed Description                                                                            |     |
| Field Documentation                                                                             | 754 |
| IxHssAccPortConfig Struct Reference [Intel (R) IXP400 Software HSS Access (IxHssAcc) API]       | 756 |
| Data Fields                                                                                     | 756 |
| Detailed Description                                                                            | 757 |
| Field Documentation                                                                             | 757 |

| IxI2cInitVars Struct Reference [Intel (R) IXP400 Software I2C Driver(IxI2cDrv) API]                                                                                                     | 761 |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| Data Fields.                                                                                                                                                                            | 761 |
| Detailed Description.                                                                                                                                                                   | 761 |
| Field Documentation                                                                                                                                                                     | 762 |
| IxI2cStatsCounters Struct Reference [Intel (R) IXP400 Software I2C Driver(IxI2cDrv) API]                                                                                                | 764 |
| Data Fields                                                                                                                                                                             | 764 |
| Detailed Description                                                                                                                                                                    | 764 |
| Field Documentation                                                                                                                                                                     | 765 |
| IxNpeMhMessage Struct Reference [Intel (R) IXP400 Software NPE Message Handler                                                                                                          | 767 |
| (IxNpeMh) API]  Data Fields.                                                                                                                                                            |     |
| Data Fields  Detailed Description                                                                                                                                                       |     |
| *                                                                                                                                                                                       |     |
| Field Documentation                                                                                                                                                                     | /6/ |
| IxOamITU610Cell Struct Reference                                                                                                                                                        |     |
| Data Fields                                                                                                                                                                             |     |
| Detailed Description.                                                                                                                                                                   | 768 |
| IxOamITU610GenericPayload Struct Reference                                                                                                                                              | 769 |
| Data Fields                                                                                                                                                                             | 769 |
| Detailed Description                                                                                                                                                                    | 769 |
| IxOamITU610LbPayload Struct Reference                                                                                                                                                   | 770 |
| Data Fields.                                                                                                                                                                            |     |
| Detailed Description                                                                                                                                                                    |     |
| IxOamITU610Payload Union Reference                                                                                                                                                      | 771 |
| Data Fields.                                                                                                                                                                            |     |
| Detailed Description.                                                                                                                                                                   |     |
| Detailed Description.                                                                                                                                                                   | //1 |
| IxParityENAccAHBErrorTransaction Struct Reference [Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API, Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) |     |
| API, Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API]                                                                                                               | 772 |
| Data Fields                                                                                                                                                                             | 772 |
| Detailed Description.                                                                                                                                                                   | 772 |
| Field Documentation                                                                                                                                                                     | 772 |
| IxParityENAccEbcConfig Struct Reference [Intel (R) IXP400 Software Parity Error Notifier                                                                                                |     |
| (IxParityENAcc) API, Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API,                                                                                               |     |
| Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API]                                                                                                                    |     |
| Data Fields                                                                                                                                                                             |     |
| Detailed Description                                                                                                                                                                    |     |
| Field Documentation                                                                                                                                                                     | 775 |

| IxParityENAccEbcParityErrorStats Struct Reference [Intel (R) IXP400 Software Parity Error     |     |
|-----------------------------------------------------------------------------------------------|-----|
| Notifier (IxParityENAcc) API, Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) |     |
| API, Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API]                     | 777 |
| Data Fields                                                                                   | 777 |
| Detailed Description.                                                                         | 777 |
| Field Documentation                                                                           | 777 |
| IxParityENAccHWParityConfig Struct Reference [Intel (R) IXP400 Software Parity Error          |     |
| Notifier (IxParityENAcc) API, Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) |     |
| API, Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API                      |     |
| Data Fields.                                                                                  |     |
| Detailed Description.                                                                         |     |
| Field Documentation                                                                           |     |
|                                                                                               |     |
| IxParityENAccMcuConfig Struct Reference [Intel (R) IXP400 Software Parity Error Notifier      |     |
| (IxParityENAcc) API, Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API,     |     |
| Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API]                          | 781 |
| Data Fields.                                                                                  |     |
| Detailed Description.                                                                         | 781 |
| Field Documentation                                                                           | 781 |
|                                                                                               |     |
| IxParityENAccMcuParityErrorStats Struct Reference [Intel (R) IXP400 Software Parity Error     |     |
| Notifier (IxParityENAcc) API, Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) |     |
| API, Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API]                     | 783 |
| Data Fields                                                                                   | 783 |
| Detailed Description                                                                          | 783 |
| Field Documentation                                                                           | 783 |
|                                                                                               |     |
| IxParityENAccNpeConfig Struct Reference [Intel (R) IXP400 Software Parity Error Notifier      |     |
| (IxParityENAcc) API, Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API,     |     |
| Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API]                          |     |
| Data Fields                                                                                   |     |
| Detailed Description                                                                          |     |
| Field Documentation                                                                           | 785 |
| IxParityENAccNpeParityErrorStats Struct Reference [Intel (R) IXP400 Software Parity Error     |     |
|                                                                                               |     |
| Notifier (IxParityENAcc) API, Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) |     |
| API, Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API]                     |     |
| Data Fields.                                                                                  |     |
| Detailed Description.                                                                         |     |
| Field Documentation                                                                           | /86 |
| IxParityENAccParityErrorContextMessage Struct Reference [Intel (R) IXP400 Software Parity     |     |
| Error Notifier (IxParityENAcc) API, Intel (R) IXP400 Software Parity Error Notifier           |     |
| (IxParityENAcc) API, Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API,     | 788 |
| Data Fields.                                                                                  |     |
| Detailed Description.                                                                         |     |
| Field Documentation                                                                           |     |

| IxParityENAccParityErrorStats Struct Reference [Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API, Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc)   | )   |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| API, Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API]                                                                                                              | 790 |
| Data Fields                                                                                                                                                                            |     |
| Detailed Description.                                                                                                                                                                  | 790 |
| Field Documentation                                                                                                                                                                    | 790 |
| IxParityENAccPbcConfig Struct Reference [Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API, Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API,     |     |
| Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API]                                                                                                                   | 792 |
| Data Fields                                                                                                                                                                            |     |
| Detailed Description.                                                                                                                                                                  |     |
| Field Documentation                                                                                                                                                                    |     |
|                                                                                                                                                                                        |     |
| IxParityENAccPbcParityErrorStats Struct Reference [Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API, Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc | )   |
| API, Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API]                                                                                                              |     |
| Data Fields                                                                                                                                                                            | 793 |
| Detailed Description.                                                                                                                                                                  | 793 |
| Field Documentation                                                                                                                                                                    | 793 |
|                                                                                                                                                                                        |     |
| IxPerfProfAccBusPmuResults Struct Reference [Intel (R) IXP400 Software Performance                                                                                                     | 704 |
| Profiling (IxPerfProfAcc) API]                                                                                                                                                         |     |
| Data Fields.                                                                                                                                                                           |     |
| Detailed Description.                                                                                                                                                                  |     |
| Field Documentation                                                                                                                                                                    | /94 |
| IxPerfProfAccXcycleResults Struct Reference [Intel (R) IXP400 Software Performance Profiling                                                                                           |     |
| (IxPerfProfAcc) API]                                                                                                                                                                   | 795 |
| Data Fields                                                                                                                                                                            | 795 |
| Detailed Description                                                                                                                                                                   | 795 |
| Field Documentation                                                                                                                                                                    | 795 |
| IxPerfProfAccXscalePmuEvtCnt Struct Reference [Intel (R) IXP400 Software Performance                                                                                                   |     |
| Profiling (IxPerfProfAcc) API]                                                                                                                                                         | 797 |
| Data Fields.                                                                                                                                                                           |     |
| Detailed Description.                                                                                                                                                                  |     |
| Field Documentation                                                                                                                                                                    |     |
|                                                                                                                                                                                        |     |
| IxPerfProfAccXscalePmuResults Struct Reference [Intel (R) IXP400 Software Performance                                                                                                  | 700 |
| Profiling (IxPerfProfAcc) API]                                                                                                                                                         |     |
| Data Fields                                                                                                                                                                            |     |
| Detailed Description.                                                                                                                                                                  |     |
| Field Documentation                                                                                                                                                                    | /99 |
| IxPerfProfAccXscalePmuSamplePcProfile Struct Reference [Intel (R) IXP400 Software                                                                                                      |     |
| Performance Profiling (IxPerfProfAcc) API]                                                                                                                                             | 801 |
| Data Fields                                                                                                                                                                            | 801 |

| Profiling (IxPerfProfAcc) API                                                                                                                                                      | ance |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| Detailed Description                                                                                                                                                               | 801  |
| Field Documentation.                                                                                                                                                               |      |
| Pieta Documentation.                                                                                                                                                               | 601  |
| IxQMgrQInlinedReadWriteInfo Struct Reference [Intel (R) IXP400 Software Queue Manager                                                                                              | 903  |
| (IxQMgr) API]                                                                                                                                                                      |      |
| Data Fields                                                                                                                                                                        |      |
| Detailed Description.                                                                                                                                                              |      |
| Field Documentation                                                                                                                                                                | 802  |
| IxSspAccStatsCounters Struct Reference [Intel (R) IXP400 Software SSP Serial Port Access                                                                                           | 00=  |
| (IxSspAcc) API, Intel (R) IXP400 Software SSP Serial Port Access (IxSspAcc) API]                                                                                                   |      |
| Data Fields                                                                                                                                                                        |      |
| Detailed Description.                                                                                                                                                              |      |
| Field Documentation                                                                                                                                                                | 805  |
| IxSspInitVars Struct Reference [Intel (R) IXP400 Software SSP Serial Port Access (IxSspAcc)                                                                                        |      |
| API, Intel (R) IXP400 Software SSP Serial Port Access (IxSspAcc) API]                                                                                                              | 807  |
| Data Fields                                                                                                                                                                        | 807  |
| Detailed Description.                                                                                                                                                              | 808  |
| Field Documentation.                                                                                                                                                               | 808  |
| Access Codelet, Intel (R) IXP400 Software Time Sync Access Codelet]                                                                                                                | 811  |
| IxTimeSyncAccCodeletUninitFuncMap Struct Reference [Intel (R) IXP400 Software Time Sync                                                                                            |      |
| Access Codelet, Intel (R) IXP400 Software Time Sync Access Codelet]                                                                                                                | 812  |
| Data Fields                                                                                                                                                                        |      |
| Detailed Description.                                                                                                                                                              | 812  |
| Field Documentation                                                                                                                                                                |      |
| IxTimeSyncAccPtpMsgData Struct Reference [Intel (R) IXP400 Software Time Sync Access Component API, Intel (R) IXP400 Software Time Sync Access Component API, Intel (R) IXP400     | )    |
| Software Time Sync Access Component API]                                                                                                                                           | 814  |
| Data Fields                                                                                                                                                                        | 814  |
| Detailed Description                                                                                                                                                               | 814  |
| Field Documentation.                                                                                                                                                               | 814  |
| IxTimeSyncAccStats Struct Reference [Intel (R) IXP400 Software Time Sync Access Component API, Intel (R) IXP400 Software Time Sync Access Component API, Intel (R) IXP400 Software |      |
| Time Sync Access Component API]                                                                                                                                                    | 816  |
| Data Fields                                                                                                                                                                        |      |
| Detailed Description                                                                                                                                                               |      |
| Field Documentation                                                                                                                                                                | 816  |

| IxTimeSyncAccTimeValue Struct Reference [Intel (R) IXP400 Software Time Sync Access Component API, Intel (R) IXP400 Software Time Sync Access Component API, Intel (R) IXP400     |     |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| Software Time Sync Access Component API, Intel (R) 1AF 400 Software Time Sync Access Component API,                                                                               | 817 |
| Data Fields                                                                                                                                                                       |     |
| Detailed Description.                                                                                                                                                             |     |
| Field Documentation.                                                                                                                                                              |     |
|                                                                                                                                                                                   |     |
| IxTimeSyncAccUuid Struct Reference [Intel (R) IXP400 Software Time Sync Access Component API, Intel (R) IXP400 Software Time Sync Access Component API, Intel (R) IXP400 Software |     |
| Time Sync Access Component API]                                                                                                                                                   | 818 |
| Data Fields                                                                                                                                                                       | 818 |
| Detailed Description                                                                                                                                                              | 818 |
| Field Documentation                                                                                                                                                               | 818 |
| ixUARTDev Struct Reference [Intel (R) IXP400 Software UART Access (IxUARTAcc) API, Intel                                                                                          |     |
| (R) IXP400 Software UART Access (IxUARTAcc) API]                                                                                                                                  |     |
| Data Fields.                                                                                                                                                                      |     |
| Detailed Description.                                                                                                                                                             |     |
| Field Documentation.                                                                                                                                                              |     |
|                                                                                                                                                                                   |     |
| ixUARTStats Struct Reference [Intel (R) IXP400 Software UART Access (IxUARTAcc) API,                                                                                              | 001 |
| Intel (R) IXP400 Software UART Access (IxUARTAcc) API]                                                                                                                            |     |
| Data Fields.                                                                                                                                                                      |     |
| Detailed Description.                                                                                                                                                             | 821 |
| PacketisedStats Struct Reference                                                                                                                                                  | 822 |
| Data Fields                                                                                                                                                                       | 822 |
| Detailed Description.                                                                                                                                                             | 822 |
| USBDevice Struct Reference [Intel(R) IXP400 Software USB Driver Public API]                                                                                                       | 823 |
| Data Fields                                                                                                                                                                       |     |
| Detailed Description.                                                                                                                                                             |     |
| Field Documentation                                                                                                                                                               |     |
|                                                                                                                                                                                   | 023 |
| USBDeviceCounters Struct Reference                                                                                                                                                | 825 |
| Data Fields                                                                                                                                                                       | 825 |
| Detailed Description.                                                                                                                                                             | 825 |
| USBSetupPacket Struct Reference [Intel(R) IXP400 Software USB Driver Public API]                                                                                                  | 826 |
| Data Fields                                                                                                                                                                       |     |
| Detailed Description.                                                                                                                                                             |     |
| 2 tourt 2 tour production                                                                                                                                                         | 520 |

### Intel (R) IXP400 Software ADSL Driver API

The public API for the IXP400 ADSL Driver.

### **Typedefs**

typedef void(\* **IxAdslStateChangeCallback** )(UINT32 lineNum, **IxAdslLineState** lineState) Callback function to indicate of the changes on the line state.

### **Enumerations**

```
enum IxAdslStatus {
     IX_ADSL_STATUS_SUCCESS,
      IX_ADSL_STATUS_FAIL,
     IX_ADSL_STATUS_UNSUPPORTED_MODE,
     IX ADSL STATUS ALREADY DOWN
     These status will be used by the APIs to return to the client.
enum IxAdslLineState {
     IX ADSL LINE STATE UP DUAL LATENCY,
      IX_ADSL_LINE_STATE_WAIT_FOR_ACTIVATING,
     IX ADSL LINE STATE ACTIVATING,
      IX_ADSL_LINE_STATE_DOWN,
     IX_ADSL_LINE_STATE_UP_FASTCHANNEL,
     IX ADSL LINE STATE UP INTERLEAVECHANNEL,
     IX_ADSL_LINE_STATE_INVALID
     These status will be used to indicate the line state.
enum IxAdslLineType {
     IX_ADSL_AUTOSELECT,
     IX_ADSL_GLITE,
      IX_ADSL_DMT,
     IX_ADSL_ANSI,
     IX ADSL LOOPBACK,
     IX_ADSL_INVALID_MODE
     Used to indicate the type of ADSL line type used.
enum IxAdslPhyType {
      IX_ADSL_PHY_CPE,
     IX_ADSL_PHY_INVALID
     Used to indicate the ADSL physical type – CPE.
```

### **Functions**

# PUBLICixAdslLineOpen (UINT32 lineNum, IxAdslLineType lineType, IxAdslPhyType IxAdslStatus phyType)

Open the given ADSL line in the specified mode and type.

**PUBLIC** 

#### IxAdslStatus ixAdslLineClose (UINT32 lineNum)

Closes a previously opened ADSL line.

#### PUBLICixAdslLineStateChangeCallbackRegister (UINT32 lineNum,

#### **IxAdslStatus IxAdslStateChangeCallback** lineChangeCallbackFn)

This is a notification registration procedure that gets called if the line state of the given ADSL line changes. The maximum callbacks that can be registered is defined as IX\_ADSL\_SIZEOF\_CALLBACK\_LIST (The default value is 10).

**PUBLIC** 

#### IxAdslLineState ixAdslLineStateGet (UINT32 lineNum)

Returns the current state of the given ADSL line.

#### PUBLIC UINT32 ixAdslLineRateUpstreamGet (UINT32 lineNum)

Return the current upstream line speed of the given ADSL line.

#### PUBLIC UINT32 ixAdslLineRateDownstreamGet (UINT32 lineNum)

Return the current downstream line speed of the given ADSL line.

**PUBLIC** 

#### IxAdslStatus ixAdslDyingGaspEnable (UINT32 lineNum)

Enables the function that informs ATU-C when condition that leads to shutdown of the given Adsl line has been detected.

PUBLICixAdslVendorCodeSet (UINT32 lineNum, UINT8 ixAdslItuVendoridCountrycode, IxAdslStatus UINT8 ixAdslItuVendoridVendorcode1, UINT8 ixAdslItuVendoridVendorcode2, UINT8 ixAdslItuVendoridVendorcode4, UINT8 ixAdslItuVendoridVendorcode4, UINT8 ixAdslItuVendoridVendorspecific1, UINT8 ixAdslItuVendoridVendorspecific2)

Set the vendor specific bytes in the given ADSL line.

#### PUBLIC void **ixAdslShow** (UINT32 lineNum)

This function will show the current statistics associated with the given ADSL Line.

#### PUBLIC void ixAdslMemoryUnmap (void)

This function will unmap the dynamically allocated addresses.

### **Detailed Description**

The public API for the IXP400 ADSL Driver.

Functions 2

### **Typedef Documentation**

typedef void(\* IxAdslStateChangeCallback)( UINT32 lineNum, IxAdslLineState lineState)

Callback function to indicate of the changes on the line state.

Definition at line 142 of file IxAdsl.h.

### **Enumeration Type Documentation**

#### enum IxAdslLineState

These status will be used to indicate the line state.

#### **Enumeration values:**

IX\_ADSL\_LINE\_STATE\_UP\_DUAL\_LATENCY The line is in showtime state.

Fast & Interleaved Channel

IX\_ADSL\_LINE\_STATE\_WAIT\_FOR\_ACTIVATING The line is waiting for the peer to

activate.

IX\_ADSL\_LINE\_STATE\_ACTIVATING

The line is negotiating with its

peer.

IX\_ADSL\_LINE\_STATE\_DOWN The line is down.

IX\_ADSL\_LINE\_STATE\_UP\_FASTCHANNEL The line is in showtime state.

Fast Channel

IX\_ADSL\_LINE\_STATE\_UP\_INTERLEAVECHANNEL The line is in showtime state.

Interleaved Channel

IX\_ADSL\_LINE\_STATE\_INVALID ADSL line in an unknown state.

Definition at line 55 of file IxAdsl.h.

#### enum IxAdslLineType

Used to indicate the type of ADSL line type used.

#### **Enumeration values:**

IX\_ADSL\_AUTOSELECT This is an auto-select mode for the CPE to auto-configure based on

the CO/DSLAM line type; DMT, ANSI or G.lite.

 $IX\_ADSL\_GLITE$  G.lite line type.  $IX\_ADSL\_DMT$  DMT line type.  $IX\_ADSL\_ANSI$  ANSI line type.

*IX\_ADSL\_LOOPBACK* Utopia Loopback line type.

IX\_ADSL\_INVALID\_MODE Used internally to indicate last valid enum.

Definition at line **96** of file **IxAdsl.h**.

#### enum IxAdslPhyType

Used to indicate the ADSL physical type – CPE.

#### Note:

IxAdslPhyType is declared as an enum due to forward compatibility to support CO (fast and interleaved mode) in the future.

#### **Enumeration values:**

IX\_ADSL\_PHY\_CPE Adsl type is CPE.
IX\_ADSL\_PHY\_INVALID Adsl type is invalid.

Definition at line 125 of file IxAdsl.h.

#### enum IxAdslStatus

These status will be used by the APIs to return to the client.

#### **Enumeration values:**

IX\_ADSL\_STATUS\_SUCCESS Successful API execution.

IX ADSL\_STATUS FAIL Failed API execution.

IX\_ADSL\_STATUS\_UNSUPPORTED\_MODE Unsupported mode type for IxAdslLineOpen

function.

IX\_ADSL\_STATUS\_ALREADY\_DOWN Line is already down.

Definition at line **34** of file **IxAdsl.h**.

### **Function Documentation**

ixAdslDyingGaspEnable (UINT32 lineNum)

Enables the function that informs ATU-C when condition that leads to shutdown of the given Adsl line has been detected.

Note:

The parameter lineNum exists for future Multi-PHY support. Only lineNum = 0 is valid.

Blocking: This call is a non-blocking

Impacts On Global Data: None

Pre-Conditions: Task level calls only. Only Available in ATU-R.

Post-Conditions: None.

Exceptions: None.

#### Parameters:

lineNum UINT32 [in] – is the parameter showing which ADSL line is being used.

#### Returns:

```
♦ IX_ADSL_STATUS_SUCCESS – Dying Gasp is enabled. successfully.
```

♦ IX\_ADSL\_STATUS\_FAILED – Failed to enable Dying Gasp.

```
ixAdslLineClose (UINT32 lineNum)
```

Closes a previously opened ADSL line.

The line will closed and put in the idle state.

#### Note:

The parameter lineNum exists for future Multi-PHY support. Only lineNum = 0 is valid.

Blocking: Non-blocking

Impacts On Global Data: Sets the lineEnable State . Notifies a callback routine.

Pre-Conditions: Code should only be called from task level.

Post-Conditions: No cleanup after this call is required.

#### Parameters:

lineNum UINT32 [in] – is the parameter showing which ADSL line is being used and to be closed.

#### Returns:

```
\Diamond IX_ADSL_STATUS_SUCCESS – Line was closed successfully.
```

```
♦ IX_ADSL_STATUS_FAILED – Line failed to close properly.
```

♦ IX\_ADSL\_STATUS\_ALREADY\_DOWN – Line was not open before close.

Open the given ADSL line in the specified mode and type.

Opens the given ADSL line in the specified mode and puts it in the 'Showtime' state, i.e. available to carry user data.

#### Note:

- The parameter lineNum exists for future Multi-PHY support. Only lineNum = 0 is valid.
- The parameter phyType exists for future CO support.

Blocking: This call may block for several seconds while the link is established.

Impacts On Global Data: Sets the lineEnable State.

Pre–Conditions: The code must only be called once the operating system is running, i.e. do not call as part of the hardware init as this code requires base services such as Atmd, Atmm, Atm scheduler and Utopia. The code should only be called from task level.

Post-Conditions: No cleanup after this call is required.

Exceptions: None.

#### Parameters:

```
lineNum UINT32 [in] – is the parameter showing which ADSL line is being used.
```

*lineType* **IxAdslLineType** [in] – indicates type of ADSL to be opened.

*phyType* **IxAdslPhyType** [in] – is the type of Phy used – CPE.

#### Returns:

```
♦ IX_ADSL_STATUS_SUCCESS – Line was opened and is in 'showtime' state
```

```
♦ IX ADSL STATUS FAILED – Line failed to open properly.
```

♦ IX\_ADSL\_STATUS\_UNSUPPORTED\_MODE – Illegal ADSL type for IxAdslLineOpen function.

#### ixAdslLineRateDownstreamGet ( UINT32 lineNum )

Return the current downstream line speed of the given ADSL line.

The data returned by this API is the received (Rx) rate of the line the ATU device.

#### Note:

The parameter lineNum exists for future Multi-PHY support. Only lineNum = 0 is valid.

Blocking: This call is a non-blocking

Impacts On Global Data: None

Pre-Conditions: Task level calls only.

Post-Conditions: None.

Exceptions: None.

#### Parameters:

lineNum UINT32 [in] – is the parameter showing which ADSL line is being used.

#### Returns:

♦ Integer – bit rate in kbits/second. N.B. Returns zero if the line is not in 'Showtime' state.

#### ixAdslLineRateUpstreamGet (UINT32 lineNum)

Return the current upstream line speed of the given ADSL line.

#### Note:

The parameter lineNum exists for future Multi-PHY support. Only lineNum = 0 is valid.

The data returned by this API represents the transmit (Tx) rate of the line from the ATU device.

Blocking: This call is a non-blocking

Impacts On Global Data: None

Pre-Conditions: Task level calls only.

Post-Conditions: None.

Exceptions: None.

#### Parameters:

*lineNum* UINT32 [in] – is the parameter showing which ADSL line is being used.

#### Returns:

♦ Integer – bit rate in kbits/second. N.B. Returns zero if the line is not in 'Showtime' state.

This is a notification registration procedure that gets called if the line state of the given ADSL line changes. The maximum callbacks that can be registered is defined as IX\_ADSL\_SIZEOF\_CALLBACK\_LIST (The default value is 10).

#### Note:

The parameter lineNum exists for future Multi-PHY support. Only lineNum = 0 is valid.

Blocking: This call is a non-blocking function.

Impacts On Global Data: This sets a global callback handler.

Pre-Conditions: There are no pre conditions to this call.

Post–Conditions: A global line state handler for ADSL line state changes shall be registered. It is advisable to register the callback before the given ADSL line is opened.

Exceptions: None.

#### Parameters:

lineNum UINT32 [in] – is the parameter showing which ADSL line is being used.
 lineChangeCallbackFn IxAdslStateChangeCallback [in] – is the callback function that will be invoked when there is a state change

#### Returns:

♦ IX\_ADSL\_STATUS\_SUCCESS – The callback function was registered successfully.

♦ IX\_ADSL\_STATUS\_FAILED – Internal error, registration of the callback function failed.

#### ixAdslLineStateGet (UINT32 lineNum)

Returns the current state of the given ADSL line.

#### Note:

The parameter lineNum exists for future Multi–PHY support. Only lineNum = 0 is valid.

Blocking: This call is a non-blocking

Impacts On Global Data: None

Pre–Conditions: Task level calls only.

Post-Conditions: None.

Exceptions: None.

#### Parameters:

*lineNum* UINT32 [in] – is the parameter showing which ADSL line is being used.

#### Returns:

♦ IX\_ADSL\_LINE\_STATE\_UP\_FAST – The line is in show time state.

♦ IX\_ADSL\_LINE\_STATE\_WAIT\_FOR\_ACTIVATING – The line is waiting fo the peer to activate.

♦ IX\_ADSL\_LINE\_STATE\_ACTIVATING – The line is negotiating with its peer.

♦ IX ADSL LINE STATE DOWN – The line is idle.

♦ IX\_ADSL\_LINE\_STATE\_INVALID – The line is in an unknown state.

#### ixAdslMemoryUnmap (void)

This function will unmap the dynamically allocated addresses.

Blocking: This call is non-blocking.

Impacts On Global Data: None

Pre-Conditions: Task level calls only.

Post-Conditions: None.

Exceptions: None.

#### Parameters:

None

#### Returns:

None

#### ixAdslShow (UINT32 lineNum)

This function will show the current statistics associated with the given ADSL Line.

#### Note:

The parameter lineNum exists for future Multi-PHY support. Only lineNum = 0 is valid.

The list of statistics to be shown by IxAdslShow:

- Controller SW Version
- ADSL Line State
- Line Number
- Upstream and Downstream Rate
- Training Statistics for Upstream and Downstream Rates
- ADSL Near End Operational Data such as Upstream Relative Capacity Occupancy, Noise Margin Upstream, Output Pwr Downstream, Attenuation Upstream, Downstream Fast Bitrate, Downstream Interleaved Bitrate, Near—end defect bitmap, Loss of Frame (secs), Loss of Cell delineation (secs), Loss of Signal (secs), Loss of Margin (secs), Errored seconds, HEC and FEC Errors.
- ADSL Far End Operational Data such as Downstream Relative Capacity Occupancy, Noise Margin Downstream, Output Pwr Upstream, Attenuation Downstream, Upstream Fast Bitrate, Upstream Interleaved Bitrate, Far–end defect bitmap

9

• Tx and Rx ATM Cell Counters

Blocking: This call is non-blocking.

Impacts On Global Data: None

Pre-Conditions: Task level calls only.

Post-Conditions: None.

Exceptions: None.

#### Parameters:

*lineNum* UINT32 [in] – is the parameter showing which ADSL line is being used.

#### Returns:

None

Set the vendor specific bytes in the given ADSL line.

The vendor ID must be set before the line is open, if not the default vendor ID shall be sent to the peer modem upon request.

#### Note:

- Vendor specific values are taken by the phy and linked together to form a single code
- Note that the parameter lineNum exists for future Multi-PHY support. Only lineNum = 0 is valid.

Blocking: This call is a non-blocking

Impacts On Global Data: Sets an internal ADSL global data structure. This shall be used for all subsequent ADSL line open commands.

Pre-Conditions: Task level calls only.

Post-Conditions: None.

Exceptions: None.

#### Parameters:

lineNum UINT32 [in] – is the parameter showing which ADSL line is

being used.

ixAdslItuVendoridCountrycode UINT8 [in] – is the vendor country code that are predefined in

standards.

ixAdslItuVendoridVendorcode1 UINT8 [in] – is the vendor code 1 that are predefined in

standards.

ixAdslItuVendoridVendorcode2 UINT8 [in] – is the vendor code 2 that are predefined in

standards.

ixAdslItuVendoridVendorcode3 UINT8 [in] – is the vendor code 3 that are predefined in

standards.

ixAdslItuVendoridVendorcode4 UINT8 [in] – is the vendor code 4 that are predefined in

standards.

ixAdslItuVendoridVendorspecific1 UINT8 [in] – is the vendor specific 1 that are predefined in

standards.

ixAdslItuVendoridVendorspecific2 UINT8 [in] – is the vendor specific 2 that are predefined in

standards.

#### Returns:

♦ IX\_ADSL\_STATUS\_SUCCESS – Set Vendor Code successful.

♦ IX\_ADSL\_STATUS\_FAILED – Set Vendor Code failed because the line is up.

# Intel (R) IXP400 Software Assertion Macros (IxAssert) API

Assertion support.

# Intel (R) IXP400 Software ATM Driver Access (IxAtmdAcc) API

The public API for the IXP400 Atm Driver Data component.

### **Defines**

#### #define IX ATMDACC WARNING

Warning return code.

#### #define IX ATMDACC BUSY

Busy return code.

#### #define IX ATMDACC RESOURCES STILL ALLOCATED

Disconnect return code.

#### #define IX\_ATMDACC\_DEFAULT\_REPLENISH\_COUNT

Default resources usage for RxVcFree replenish mechanism.

#### #define IX\_ATMDACC\_OAM\_TX\_VPI

The reserved value used for the dedicated OAM Tx connection. This "well known" value is used by atmdAcc and its clients to dsicriminate the OAM channel, and should be chosen so that it does not coencide with the VPI value used in an AALO/AAL5 connection. Any attempt to connect a service type other than OAM on this VPI will fail.

#### #define IX ATMDACC OAM TX VCI

The reserved value used for the dedicated OAM Tx connection. This "well known" value is used by atmdAcc and its clients to dsicriminate the OAM channel, and should be chosen so that it does not coencide with the VCI value used in an AALO/AAL5 connection. Any attempt to connect a service type other than OAM on this VCI will fail.

#### #define IX\_ATMDACC\_OAM\_RX\_PORT

The reserved dummy PORT used for all dedicated OAM Rx connections. Note that this is not a real port but must have a value that lies within the valid range of port values.

#### #define IX ATMDACC OAM RX VPI

The reserved value value used for the dedicated OAM Rx connection. This value should be chosen so that it does not coencide with the VPI value used in an AALO/AAL5 connection. Any attempt to connect a service type other than OAM on this VPI will fail.

#### #define IX\_ATMDACC\_OAM\_RX\_VCI

The reserved value value used for the dedicated OAM Rx connection. This value should be chosen so that it does not coencide with the VCI value used in an AALO/AAL5 connection. Any attempt to connect a service type other than OAM on this VCI will fail.

# **Typedefs**

```
typedef
unsigned int IxAtmdAccUserId
User-supplied Id.

typedef void(* IxAtmdAccRxVcRxCallback )(IxAtmLogicalPort port, IxAtmdAccUserId userId,
IxAtmdAccPduStatus status, IxAtmdAccClpStatus clp, IX_OSAL_MBUF *mbufPtr)
Rx callback prototype.

typedef void(* IxAtmdAccRxVcFreeLowCallback )(IxAtmdAccUserId userId)
Callback prototype for free buffer level is low.

typedef void(* IxAtmdAccTxVcBufferReturnCallback )(IxAtmdAccUserId userId, IX_OSAL_MBUF *mbufPtr)
Buffer callback prototype.
```

# **Enumerations**

```
enum IxAtmdAccPduStatus {
     IX_ATMDACC_AAL0_VALID,
     IX_ATMDACC_OAM_VALID,
     IX_ATMDACC_AAL2_VALID,
     IX_ATMDACC_AAL5_VALID,
     IX_ATMDACC_AAL5_PARTIAL,
     IX_ATMDACC_AAL5_CRC_ERROR,
     IX_ATMDACC_MBUF_RETURN
    IxAtmdAcc Pdu status:.
enum IxAtmdAccAalType {
     IX_ATMDACC_AAL5,
     IX_ATMDACC_AAL2,
     IX_ATMDACC_AAL0_48,
     IX_ATMDACC_AAL0_52,
     IX_ATMDACC_OAM,
     IX_ATMDACC_MAX_SERVICE_TYPE
    IxAtmdAcc AAL Service Type :.
enum IxAtmdAccClpStatus {
     IX_ATMDACC_CLP_NOT_SET,
     IX_ATMDACC_CLP_SET
    IxAtmdAcc CLP indication.
```

Typedefs 14

# **Functions**

**PUBLIC** 

IX\_STATUS ixAtmdAccInit (void)

Initialise the IxAtmdAcc Component.

**PUBLIC** 

IX STATUS ixAtmdAccUninit (void)

Uninitialise the IxAtmdAcc Component.

PUBLIC void ixAtmdAccShow (void)

Show IxAtmdAcc configuration on a per port basis.

PUBLIC void ixAtmdAccStatsShow (void)

Show all IxAtmdAcc stats.

PUBLIC void ixAtmdAccStatsReset (void)

Reset all IxAtmdAcc stats.

PUBLICixAtmdAccRxVcConnect (IxAtmLogicalPort port, unsigned int vpi, unsigned int vci, IX\_STATUS IxAtmdAccAalType aalServiceType, IxAtmRxQueueId rxQueueId, IxAtmdAccUserId userCallbackId, IxAtmdAccRxVcRxCallback rxCallback, unsigned int minimumReplenishCount, IxAtmConnId \*connIdPtr, IxAtmNpeRxVcId \*npeVcIdPtr) Connect to a Aal Pdu receive service for a particular port/vpi/vci, and service type.

**PUBLIC** 

IX\_STATUS **ixAtmdAccRxVcFreeReplenish** (**IxAtmConnId** connId, IX\_OSAL\_MBUF \*mbufPtr) Provide free mbufs for data reception on a connection.

PUBLICixAtmdAccRxVcFreeLowCallbackRegister (IxAtmConnId connId, unsigned int IX STATUS numberOfMbufs, IxAtmdAccRxVcFreeLowCallback callback)

Configure the RX Free threshold value and register a callback to handle threshold notifications.

PUBLICixAtmdAccRxVcFreeEntriesQuery (IxAtmConnId connId, unsigned int

IX\_STATUS \*numberOfMbufsPtr)

Get the number of rx mbufs the system can accept to replenish the the rx reception mechanism on a particular channel.

**PUBLIC** 

IX\_STATUS ixAtmdAccRxVcEnable (IxAtmConnId connId)

Start the RX service on a VC.

**PUBLIC** 

IX\_STATUS ixAtmdAccRxVcDisable (IxAtmConnId connId)

Stop the RX service on a VC.

**PUBLIC** 

IX\_STATUS ixAtmdAccRxVcTryDisconnect (IxAtmConnId connId)

Disconnect a VC from the RX service.

Functions 15

PUBLICixAtmdAccTxVcConnect (IxAtmLogicalPort port, unsigned int vpi, unsigned int vci, IX\_STATUS IxAtmdAccAalType aalServiceType, IxAtmdAccUserId userId,

**IxAtmdAccTxVcBufferReturnCallback** bufferFreeCallback, **IxAtmConnId** \*connIdPtr) *Connect to a Aal Pdu transmit service for a particular port/vpi/vci and service type.* 

PUBLIC**ixAtmdAccTxVcPduSubmit** (**IxAtmConnId** connId, IX\_OSAL\_MBUF \*mbufPtr, IX\_STATUS **IxAtmdAccClpStatus** clp, unsigned int numberOfCells)

Submit a Pdu for transmission on connection.

**PUBLIC** 

IX\_STATUS ixAtmdAccTxVcTryDisconnect (IxAtmConnId connId)

Disconnect from a Aal Pdu transmit service for a particular port/vpi/vci.

# **Detailed Description**

The public API for the IXP400 Atm Driver Data component.

IxAtmdAcc is the low level interface by which AAL0/AAL5 and OAM data gets transmitted to,and received from the Utopia bus.

For AAL0/AAL5 services transmit and receive connections may be established independantly for unique combinations of port,VPI,and VCI.

Two AAL0 services supporting 48 or 52 byte cell data are provided. Submitted AAL0 PDUs must be a multiple of the cell data size (48/52). AAL0\_52 is a raw cell service the client must format the PDU with an ATM cell header (excluding HEC) at the start of each cell, note that AtmdAcc does not validate the cell headers in a submitted PDU.

OAM cells cannot be received over the AAL0 service but instead are received over a dedicated OAM service.

For the OAM service an "OAM Tx channel" may be enabled for a port by establishing a single dedicated OAM Tx connection on that port. A single "OAM Rx channel" for all ports may be enabled by establishing a dedicated OAM Rx connection.

The OAM service allows buffers containing 52 byte OAM F4/F5 cells to be transmitted and received over the dedicated OAM channels. HEC is appended/removed, and CRC-10 performed by the NPE. The OAM service offered by AtmdAcc is a raw cell transport service. It is assumed that ITU I.610 procedures that make use of this service are implemented above AtmdAcc.

Note that the dedicated OAM connections are established on reserved VPI,VCI, and (in the case of Rx) port values defined below. These values are used purely to descriminate the dedicated OAM channels and do not identify a particular OAM F4/F5 flow. F4/F5 flows may be realised for particular VPI/VCIs by manipulating the VPI,VCI fields of the ATM cell headers of cells in the buffers passed to AtmdAcc. Note that AtmdAcc does not validate the cell headers in a submitted OAM PDU.

This part is related to the User datapath processing

# **Define Documentation**

# #define IX\_ATMDACC\_BUSY

Busy return code.

This constant is used to tell IxAtmDAcc user that the request is correct, but cannot be processed because the IxAtmAcc resources are already used. The user has to retry its request later

Definition at line 107 of file IxAtmdAcc.h.

# #define IX\_ATMDACC\_DEFAULT\_REPLENISH\_COUNT

Default resources usage for RxVcFree replenish mechanism.

This constant is used to tell IxAtmDAcc to allocate and use the minimum of resources for rx free replenish.

### See also:

### ixAtmdAccRxVcConnect

Definition at line 138 of file IxAtmdAcc.h.

# #define IX ATMDACC OAM RX PORT

The reserved dummy PORT used for all dedicated OAM Rx connections. Note that this is not a real port but must have a value that lies within the valid range of port values.

Definition at line 179 of file IxAtmdAcc.h.

# #define IX\_ATMDACC\_OAM\_RX\_VCI

The reserved value value used for the dedicated OAM Rx connection. This value should be chosen so that it does not coencide with the VCI value used in an AAL0/AAL5 connection. Any attempt to connect a service type other than OAM on this VCI will fail.

Definition at line 203 of file IxAtmdAcc.h.

# #define IX\_ATMDACC\_OAM\_RX\_VPI

The reserved value value used for the dedicated OAM Rx connection. This value should be chosen so that it does not coencide with the VPI value used in an AAL0/AAL5 connection. Any attempt to connect a service type other than OAM on this VPI will fail.

Definition at line 191 of file IxAtmdAcc.h.

Define Documentation 17

# #define IX ATMDACC OAM TX VCI

The reserved value used for the dedicated OAM Tx connection. This "well known" value is used by atmdAcc and its clients to dsicriminate the OAM channel, and should be chosen so that it does not coencide with the VCI value used in an AALO/AAL5 connection. Any attempt to connect a service type other than OAM on this VCI will fail.

Definition at line 167 of file IxAtmdAcc.h.

# #define IX\_ATMDACC\_OAM\_TX\_VPI

The reserved value used for the dedicated OAM Tx connection. This "well known" value is used by atmdAcc and its clients to dsicriminate the OAM channel, and should be chosen so that it does not coencide with the VPI value used in an AAL0/AAL5 connection. Any attempt to connect a service type other than OAM on this VPI will fail.

Definition at line 154 of file IxAtmdAcc.h.

# #define IX\_ATMDACC\_RESOURCES\_STILL\_ALLOCATED

Disconnect return code.

This constant is used to tell IxAtmDAcc user that the disconnect functions are not complete because the resources used by the driver are not yet released. The user has to retry the disconnect call later.

Definition at line 123 of file IxAtmdAcc.h.

# #define IX\_ATMDACC\_WARNING

Warning return code.

This constant is used to tell IxAtmDAcc user about a special case.

Definition at line 92 of file IxAtmdAcc.h.

# **Typedef Documentation**

typedef void(\* IxAtmdAccRxVcFreeLowCallback)(**IxAtmdAccUserId** userId)

Callback prototype for free buffer level is low.

IxAtmdAccRxVcFreeLowCallback is the prototype of the user function which get called on a per–VC basis, when more mbufs are needed to continue the ATM data reception. This function is likely to supply more available mbufs by one or many calls to the replenish function *ixAtmdAccRxVcFreeReplenish()* 

This function is called when the number of available buffers for reception is going under the threshold level as defined in *ixAtmdAccRxVcFreeLowCallbackRegister()* 

This function is called inside an Qmgr dispatch context. No system resource or interrupt—unsafe feature should be used inside this callback.

# See also:

ix Atm d Acc Rx Vc Free Low Callback Register

IxAtmdAccRxVcFreeLowCallback

ixAtmdAccRxVcFreeReplenish

ixAtmdAccRxVcFreeEntriesQuery

ixAtmdAccRxVcConnect

# Parameters:

userId **IxAtmdAccUserId** [in] – user Id provided in the call to *ixAtmdAccRxVcConnect()* 

### Returns:

None

Definition at line **372** of file **IxAtmdAcc.h**.

typedef void(\* IxAtmdAccRxVcRxCallback)(**IxAtmLogicalPort** port, **IxAtmdAccUserId** userId, **IxAtmdAccPduStatus** status, **IxAtmdAccClpStatus** clp, IX\_OSAL\_MBUF \* mbufPtr)

Rx callback prototype.

IxAtmdAccRxVcRxCallback is the prototype of the Rx callback user function called once per PDU to pass a receive Pdu to a user on a partilcular connection. The callback is likely to push the mbufs to a protocol layer, and recycle the mbufs for a further use.

# Note:

-This function is called ONLY in the context of the *ixAtmdAccRxDispatch()* function

# See also:

ixAtmdAccRxDispatch

# ixAtmdAccRxVcConnect

# Parameters:

port **IxAtmLogicalPort** [in] – the port on which this PDU was received a logical PHY port

 $[IX\_UTOPIA\_PORT\_0 \ .. \ IX\_UTOPIA\_MAX\_PORTS - 1]$ 

userId IxAtmdAccUserId [in] – user Id provided in the call to ixAtmdAccRxVcConnect()
 status IxAtmdAccPduStatus [in] – an indication about the PDU validity. In the case of AAL0

the only possibile value is AAL0\_VALID, in this case the client may optionally determine that an rx timeout occured by checking if the mbuf is completely or only

partially filled, the later case indicating a timeout. In the case of OAM the only possible value is OAM valid. The status is set to *IX\_ATMDACC\_MBUF\_RETURN* when the mbuf is released during a disconnect process.

clp **IxAtmdAccClpStatus** [in] – clp indication for this PDU. For AAL5/AAL0\_48 this information is set if the clp bit of any rx cell is set For AAL0–52/OAM the client may inspect the CLP in individual cell headers in the PDU, and this parameter is set to 0.

\*mbufPtr [in] – depending on the servive type a pointer to an mbuf (AAL5/AAL0/OAM) or mbuf chain (AAL5 only), that comprises the complete PDU data.

This parameter is guaranteed not to be a null pointer.

Definition at line **334** of file **IxAtmdAcc.h**.

typedef void(\* IxAtmdAccTxVcBufferReturnCallback)(**IxAtmdAccUserId** userId, IX\_OSAL\_MBUF \* mbufPtr)

Buffer callback prototype.

This function is called to relinguish ownership of a transmitted buffer chain to the user.

### Note:

-In the case of a chained mbuf the AmtdAcc component can chain many user buffers together and pass ownership to the user in one function call.

# Parameters:

userId IxAtmdAccUserId [in] – user If provided at registration of this callback.mbufPtr [in] – a pointer to mbufs or chain of mbufs and is guaranteed not to be a null pointer.

Definition at line **397** of file **IxAtmdAcc.h**.

# IxAtmdAccUserId

User-supplied Id.

IxAtmdAccUserId is passed through callbacks and allows the IxAtmdAcc user to identify the source of a call back. The range of this user–owned Id is [0...2^32–1)].

The user provides this own Ids on a per-channel basis as a parameter in a call to *ixAtmdAccRxVcConnect()* or *ixAtmdAccRxVcConnect()* 

# See also:

ixAtmdAccRxVcConnect

ixAtmdAccTxVcConnect

Definition at line 286 of file IxAtmdAcc.h.

# **Enumeration Type Documentation**

# enum IxAtmdAccAalType

IxAtmdAcc AAL Service Type :.

IxAtmdAccAalType defines the type of traffic to run on this VC

# **Enumeration values:**

IX\_ATMDACC\_AAL5 ITU-T AAL5.

IX\_ATMDACC\_AAL2 ITU-T AAL2 reserved for future

use.

IX\_ATMDACC\_AAL0\_48 AAL0 48 byte payloads (cell header

is added by NPE).

IX\_ATMDACC\_AAL0\_52 AAL0 52 byte cell data (HEC is

added by NPE).

IX\_ATMDACC\_OAM OAM cell transport service (HEC is

added by NPE).

IX\_ATMDACC\_MAX\_SERVICE\_TYPE not a service, used for parameter

validation

Definition at line **241** of file **IxAtmdAcc.h**.

# enum IxAtmdAccClpStatus

IxAtmdAcc CLP indication.

IxAtmdAccClpStatus defines the CLP status of the current PDU

# Enumeration values:

IX\_ATMDACC\_CLP\_NOT\_SET CLP indication is not

set.

IX\_ATMDACC\_CLP\_SET CLP indication is set.

Definition at line **262** of file **IxAtmdAcc.h**.

# enum IxAtmdAccPduStatus

IxAtmdAcc Pdu status:.

IxAtmdAccPduStatus is used during a RX operation to indicate the status of the received PDU

# **Enumeration values:**

IX\_ATMDACC\_AALO\_VALID aal0 pdu
IX\_ATMDACC\_OAM\_VALID OAM pdu.

IX\_ATMDACC\_AAL2\_VALIDaal2 pdu reserved for future useIX\_ATMDACC\_AAL5\_VALIDaal5 pdu complete and trailer is validIX\_ATMDACC\_AAL5\_PARTIALaal5 pdu not complete, trailer is missingIX\_ATMDACC\_AAL5\_CRC\_ERRORaal5 pdu not complete, crc error/length errorIX\_ATMDACC\_MBUF\_RETURNempty buffer returned to the user

Definition at line **218** of file **IxAtmdAcc.h**.

# **Function Documentation**

ixAtmdAccInit (void)

Initialise the IxAtmdAcc Component.

This function initialise the IxAtmdAcc component. This function shall be called before any other function of the API. Its role is to initialise all internal resources of the IxAtmdAcc component.

The ixQmgr component needs to be initialized prior the use of *ixAtmdAccInit*()

# Parameters:

*none* Failing to initilialize the IxAtmdAcc API before any use of it will result in a failed status. If the specified component is not present, a success status will still be returned, however, a warning indicating the NPE to download to is not present will be issued.

## Returns:

- ♦ IX\_SUCCESS initialisation is complete (in case of component not being present, a warning is clearly indicated)
- ♦ IX\_FAIL unable to process this request either because this IxAtmdAcc is already initialised or some unspecified error has occrred.

```
ixAtmdAccRxVcConnect ( IxAtmLogicalPort
                                                    port,
                        unsigned int
                                                    vpi,
                        unsigned int
                                                    vci,
                        IxAtmdAccAalType
                                                    aalServiceType,
                        IxAtmRxOueueId
                                                    rxOueueId.
                        IxAtmdAccUserId
                                                    userCallbackId,
                        IxAtmdAccRxVcRxCallback rxCallback.
                        unsigned int
                                                    minimumReplenishCount,
                        IxAtmConnId *
                                                    connIdPtr,
                        IxAtmNpeRxVcId *
                                                    npeVcIdPtr
```

Connect to a Aal Pdu receive service for a particular port/vpi/vci, and service type.

This function allows a user to connect to an Aal5/Aal0/OAM Pdu receive service for a particular port/vpi/vci. It registers the callback and allocates internal resources and a Connection Id to be used in further API calls related to this VCC.

The function will setup VC receive service on the specified rx queue.

This function is blocking and makes use internal locks, and hence should not be called from an interrupt context.

On return from *ixAtmdAccRxVcConnect()* with a failure status, the connection Id parameter is unspecified. Its value cannot be used. A connId is the reference by which IxAtmdAcc refers to a connected VC. This identifier is the result of a successful call to a connect function. This identifier is invalid after a successful call to a disconnect function.

Calling this function for the same combination of Vpi, Vci and more than once without calling *ixAtmdAccRxVcTryDisconnect()* will result in a failure status.

If this function returns success the user should supply receive buffers by calling *ixAtmdAccRxVcFreeReplenish()* and then call *ixAtmdAccRxVcEnable()* to begin receiving pdus.

There is a choice of two receive Qs on which the VC pdus could be receive. The user must associate the VC with one of these. Essentially having two qs allows more flexible system configuration such as have high priority traffic on one q (e.g. voice) and low priority traffic on the other (e.g. data). The high priority Q could be serviced in preference to the low priority Q. One queue may be configured to be serviced as soon as there is traffic, the other queue may be configured to be serviced by a polling mechanism running at idle time.

Two AAL0 services supporting 48 or 52 byte cell data are provided. Received AAL0 PDUs will be be a multiple of the cell data size (48/52). AAL0\_52 is a raw cell service and includes an ATM cell header (excluding HEC) at the start of each cell.

A single "OAM Rx channel" for all ports may be enabled by establishing a dedicated OAM Rx connection.

The OAM service allows buffers containing 52 byte OAM F4/F5 cells to be transmitted and received over the dedicated OAM channels. HEC is appended/removed, and CRC-10 performed by the NPE. The OAM service offered by AtmdAcc is a raw cell transport service. It is assumed that ITU I.610 procedures that make use of this service are implemented above AtmdAcc.

Note that the dedicated OAM connections are established on reserved VPI,VCI, and (in the case of Rx) port values. These values are used purely to descriminate the dedicated OAM channels and do not identify a particular OAM F4/F5 flow. F4/F5 flows may be realised for particular VPI/VCIs by manipulating the VPI,VCI fields of the ATM cell headers of cells in the buffers passed to AtmdAcc.

Calling this function prior to enable the port will fail.

See also:

**ixAtmdAccRxDispatch** 

ixAtmdAccRxVcEnable

### ixAtmdAccRxVcDisable

# ix Atm d Acc Rx Vc Try Disconnect

## ixAtmdAccPortEnable

# Parameters:

 $[IX\_UTOPIA\_PORT\_0 .. IX\_UTOPIA\_MAX\_PORTS-1]$ 

*vpi* unsigned int [in] – VC identification : ATM Vpi [0..255] or

IX ATMDACC OAM VPI

vci unsigned int [in] – VC identification : ATM Vci [0..65535] or

IX\_ATMDACC\_OAM\_VCI

or OAM

use.when icoming traffic is processed

rxCallback.

rxCallback [in] – function called when mbufs are received. This parameter cannot be

a null pointer.

bufferFreeCallback [in] – function to be called to return ownership of buffers to IxAtmdAcc

user.

minimumReplenishCount unsigned int [in] - For AAL5/AAL0 the number of free mbufs to be used

with this channel. Use a high number when the expected traffic rate on this channel is high, or when the user's mbufs are small, or when the RxVcFreeLow Notification has to be invoked less often. When this value is IX\_ATMDACC\_DEFAULT\_REPLENISH\_COUNT, the minimum of resources will be used. Depending on traffic rate, pdu size and mbuf size, rxfree queue size, polling/interrupt rate, this value may require to be replaced by a different value in the range 1–128 For OAM the rxFree

queue size is fixed by atmdAcc and this parameter is ignored.

connIdPtr IxAtmConnId [out] – pointer to a connection Id This parameter cannot

be a null pointer.

npeVcIdPtr IxAtmNpeRxVcId [out] – pointer to an npe Vc Id This parameter cannot

be a null pointer.

# Returns:

♦ IX SUCCESS successful call to IxAtmdAccRxVcConnect

♦ IX\_ATMDACC\_BUSY cannot process this request : no VC is available

♦ IX\_FAIL parameter error, VC already in use, attempt to connect AAL service on reserved OAM VPI/VCI, attempt to connect OAM service on VPI/VCI other than the reserved OAM VPI/VCI, port is not initialised, or some other error occurs during processing.

# ixAtmdAccRxVcDisable ( **IxAtmConnId** connId )

Stop the RX service on a VC.

This functions stops the traffic reception for a particular VC connection.

Once invoked, incoming Pdus are discarded by the hardware. Any Pdus pending will be freed to the user

Hence once this function returns no more receive callbacks will be called for that VC. However, buffer free callbacks will be invoked until such time as all buffers supplied by the user have been freed back to the user

Calling this function doe not invalidate the connId. *ixAtmdAccRxVcEnable()* can be invoked to enable Pdu reception again.

If the traffic is already stopped, this function returns IX SUCCESS.

This function is not reentrant and should not be used inside an interrupt context.

# See also:

ixAtmdAccRxVcConnect

ixAtmdAccRxVcEnable

ixAtmdAccRxVcDisable

### Parameters:

### Returns:

♦ IX\_SUCCESS successful call to *ixAtmdAccRxVcDisable()*.

♦ IX\_ATMDACC\_WARNING the channel is already disabled

♦ IX\_FAIL invalid parameters or some unspecified internal error occured

# ixAtmdAccRxVcEnable ( **IxAtmConnId** connId )

Start the RX service on a VC.

This functions kicks—off the traffic reception for a particular VC. Once invoked, incoming PDUs will be made available by the hardware and are eventually directed to the *IxAtmdAccRxVcRxCallback()* callback registered for the connection.

If the traffic is already running, this function returns IX\_SUCCESS. This function can be invoked many times.

IxAtmdAccRxVcFreeLowCallback event will occur only after *ixAtmdAccRxVcEnable()* function is invoked.

Before using this function, the ixAtmdAccRxVcFreeReplenish() function has to be used to replenish the

RX Free queue. If not, incoming traffic may be discarded and in the case of interrupt driven reception the *IxAtmdAccRxVcFreeLowCallback()* callback may be invoked as a side effect during a replenish action.

This function is not reentrant and should not be used inside an interrupt context.

For an VC connection this function can be called after a call to *ixAtmdAccRxVcDisable()* and should not be called after *ixAtmdAccRxVcTryDisconnect()* 

### See also:

ixAtmdAccRxVcDisable

ixAtmdAccRxVcConnect

ixAtmdAccRxVcFreeReplenish

### Parameters:

connId **IxAtmConnId** [in] – connection Id as resulted from a successfull call to IxAtmdAccRxVcConnect()

### Returns:

◊ IX SUCCESS successful call to ixAtmdAccRxVcEnable

♦ IX ATMDACC WARNING the channel is already enabled

♦ IX\_FAIL invalid parameters or some unspecified internal error occured.

```
ixAtmdAccRxVcFreeEntriesQuery ( IxAtmConnId connId, unsigned int * numberOfMbufsPtr )
```

Get the number of rx mbufs the system can accept to replenish the the rx reception mechanism on a particular channel.

The ixAtmdAccRxVcFreeEntriesQuery function is used to retrieve the current number of available mbuf entries for reception, on a per–VC basis. This function can be used to know the number of mbufs which can be provided using *ixAtmdAccRxVcFreeReplenish()*.

This function can be used from a timer context, or can be associated with a threshold event, or can be used inside an active polling mechanism which is under user control.

This function is reentrant and does not use system resources and can be invoked from an interrupt context.

# Parameters:

*numberOfMbufsPtr* unsigned int [out] – Pointer to the number of available entries. . This parameter cannot be a null pointer.

### Returns:

♦ IX\_SUCCESS the current number of mbufs not yet used for incoming traffic

♦ IX\_FAIL invalid parameter

## See also:

# ix Atm d Acc Rx Vc Free Replenish

Configure the RX Free threshold value and register a callback to handle threshold notifications.

The function ixAtmdAccRxVcFreeLowCallbackRegister sets the threshold value for a particular RX VC. When the number of buffers reaches this threshold the callback is invoked.

This function should be called once per VC before RX traffic is enabled. This function will fail if the curent level of the free buffers is equal or less than the threshold value.

# See also:

ix Atm d Acc Rx Vc Free Low Callback Register

**IxAtmdAccRxVcFreeLowCallback** 

ix Atm d Acc Rx Vc Free Replenish

ix Atm d Acc Rx Vc Free Entries Query

ixAtmdAccRxVcConnect

# Parameters:

IxAtmdAccRxVcConnect()

number Of Mbufs unsigned int [in] – threshold number of buffers. This number has to be a power of

2, one of the values 0,1,2,4,8,16,32.... The maximum value cannot be more than

half of the rxFree queue size (which can be retrieved using *ixAtmdAccRxVcFreeEntriesQuery(*) before any use of the

ixAtmdAccRxVcFreeReplenish() function)

callback **IxAtmdAccRxVcFreeLowCallback** [in] – function telling the user that the

number of free buffers has reduced to the threshold value.

# Returns:

♦ IX\_SUCCESS Threshold set successfully.

♦ IX\_FAIL parameter error or the current number of free buffers is less than or equal to the threshold supplied or some unspecified error has occrred.

# Note:

- the callback will be called when the threshold level will drop from exactly (numberOfMbufs + 1) to (numberOfMbufs).

```
ixAtmdAccRxVcFreeReplenish ( IxAtmConnId connId, IX_OSAL_MBUF * mbufPtr )
```

Provide free mbufs for data reception on a connection.

This function provides mbufs for data reception by the hardware. This function needs to be called by the user on a regular basis to ensure no packet loss. Providing free buffers is a connection—based feature; each connection can have different requirements in terms of buffer size number of buffers, recycling rate. This function could be invoked from within the context of a *IxAtmdAccRxVcFreeLowCallback()* callback for a particular VC

Mbufs provided through this function call can be chained. They will be unchained internally. A call to this function with chained mbufs or multiple calls with unchained mbufs are equivalent, but calls with unchained mbufs are more efficients.

Mbufs provided to this interface need to be able to hold at least one full cell payload (48/52 bytes, depending on service type). Chained buffers with a size less than the size supported by the hardware will be returned through the rx callback provided during the connect step.

Failing to invoke this function prior to enabling the RX traffic can result in packet loss.

This function is not reentrant for the same connId.

This function does not use system resources and can be invoked from an interrupt context.

### Note:

- Over replenish is detected, and extra mbufs are returned through the rx callback provided during the connect step.
- Mbuf provided to the replenish function should have a length greater or equal to 48/52 bytes according to service type.
- The memory cache of mMbuf payload should be invalidated prior to Mbuf submission. Flushing the Mbuf headers is handled by IxAtmdAcc.
- When a chained mbuf is provided, this function process the mbufs up to the hardware limit and invokes the user-supplied callback to release extra buffers.

# See also:

ixAtmdAccRxVcFreeLowCallbackRegister

IxAtmdAccRxVcFreeLowCallback

ixAtmdAccRxVcConnect

### Parameters:

connId **IxAtmConnId** [in] – connection Id as returned from a successfull call to IxAtmdAccRxVcConnect()

*mbufPtr* [in] – pointer to a mbuf structure to be used for data reception. The mbuf pointed to by this parameter can be chained to an other mbuf.

### Returns:

- ♦ IX\_SUCCESS successful call to *ixAtmdAccRxVcFreeReplenish(*) and the mbuf is now ready to use for incoming traffic.
- ♦ IX\_ATMDACC\_BUSY cannot process this request because the max number of outstanding free buffers has been reached or the internal resources have exhausted for this VC. The user is responsible for retrying this request later.
- ♦ IX\_FAIL cannot process this request because of parameter errors or some unspecified internal error has occurred.

### Note:

- It is not always guaranteed the replenish step to be as fast as the hardware is consuming Rx Free mbufs. There is nothing in IxAtmdAcc to guarantee that replenish reaches the rxFree threshold level. If the threshold level is not reached, the next rxFree low notification for this channel will not be triggered. The preferred ways to replenish can be as follows (depending on applications and implementations):
  - ♦ Replenish in a rxFree low notification until the function **ixAtmdAccRxVcFreeReplenish()** returns IX\_ATMDACC\_BUSY
  - ♦ Query the queue level using

# See also:

**ixAtmdAccRxVcFreeEntriesQuery**, then , replenish using *ixAtmdAccRxVcFreeReplenish()*, then query the queue level again, and replenish if the threshold is still not reached.

♦ Trigger replenish from an other event source and use rxFree starvation to throttle the Rx traffic

# ixAtmdAccRxVcTryDisconnect ( **IxAtmConnId** connId )

Disconnect a VC from the RX service.

This function deregisters the VC and guarantees that all resources associated with this VC are free. After its execution, the connection Id is not available.

This function will fail until such time as all resources allocated to the VC connection have been freed. The user is responsible to delay and call again this function many times until a success status is returned.

This function needs internal locks and should not be called from an interrupt context

### Parameters:

# Returns:

- ♦ IX\_SUCCESS successful call to ixAtmdAccRxVcDisable
- ♦ IX\_ATMDACC\_RESOURCES\_STILL\_ALLOCATED not all resources associated with the connection have been freed.
- ♦ IX\_FAIL cannot process this request because of a parameter error

# ixAtmdAccShow (void)

Show IxAtmdAcc configuration on a per port basis.

# Parameters:

none

# Returns:

none

# Note:

– Display use printf() and are redirected to stdout

# ixAtmdAccStatsReset (void )

Reset all IxAtmdAcc stats.

# Parameters:

none

### Returns:

none

# ixAtmdAccStatsShow (void)

Show all IxAtmdAcc stats.

# Parameters:

none

# Returns:

none

# Note:

- Stats display use printf() and are redirected to stdout

```
ixAtmdAccTxVcConnect ( IxAtmLogicalPort port,
unsigned int vpi,
unsigned int vci,
IxAtmdAccAalType aalServiceType,
IxAtmdAccUserId userId,
IxAtmdAccTxVcBufferReturnCallback bufferFreeCallback,
IxAtmConnId * connIdPtr
```

Connect to a Aal Pdu transmit service for a particular port/vpi/vci and service type.

This function allows a user to connect to an Aal5/Aal0/OAM Pdu transmit service for a particular port/vpi/vci. It registers the callback and allocates internal resources and a Connection Id to be used in further API calls related to this VC.

The function will setup VC transmit service on the specified on the specified port. A connId is the reference by which IxAtmdAcc refers to a connected VC. This identifier is the result of a successful call to a connect function. This identifier is invalid after a successful call to a disconnect function.

This function needs internal locks, and hence should not be called from an interrupt context.

On return from *ixAtmdAccTxVcConnect()* with a failure status, the connection Id parameter is unspecified. Its value cannot be used.

Calling this function for the same combination of port, Vpi, Vci and more than once without calling *ixAtmdAccTxVcTryDisconnect()* will result in a failure status.

Two AAL0 services supporting 48 or 52 byte cell data are provided. Submitted AAL0 PDUs must be a multiple of the cell data size (48/52). AAL0\_52 is a raw cell service the client must format the PDU with an ATM cell header (excluding HEC) at the start of each cell, note that AtmdAcc does not validate the cell headers in a submitted PDU.

For the OAM service an "OAM Tx channel" may be enabled for a port by establishing a single dedicated OAM Tx connection on that port.

The OAM service allows buffers containing 52 byte OAM F4/F5 cells to be transmitted and received over the dedicated OAM channels. HEC is appended/removed, and CRC-10 performed by the NPE. The OAM service offered by AtmdAcc is a raw cell transport service. It is assumed that ITU I.610 procedures that make use of this service are implemented above AtmdAcc.

Note that the dedicated OAM connections are established on reserved VPI,VCI, and (in the case of Rx) port values. These values are used purely to descriminate the dedicated OAM channels and do not identify a particular OAM F4/F5 flow. F4/F5 flows may be realised for particular VPI/VCIs by manipulating the VPI,VCI fields of the ATM cell headers of cells in the buffers passed to AtmdAcc.

Calling this function before enabling the port will fail.

### See also:

# ix Atm d Acc Tx Vc Try Disconnect

# ix Atm d Acc Port Tx Scheduled Mode Enable

# **ixAtmdAccPortEnable**

### Parameters:

port IxAtmLogicalPort [in] – VC identification : logical PHY port

[IX\_UTOPIA\_PORT\_0 .. IX\_UTOPIA\_MAX\_PORTS - 1]

*vpi* unsigned int [in] – VC identification : ATM Vpi [0..255] or

IX\_ATMDACC\_OAM\_VPI

vci unsigned int [in] – VC identification : ATM Vci [0..65535] or

IX\_ATMDACC\_OAM\_VCI

**OAM** 

userId IxAtmdAccUserId [in] – user id to be used later during callbacks related to

this channel

bufferFreeCallback IxAtmdAccTxVcBufferReturnCallback [in] – function called when mbufs

transmission is complete. This parameter cannot be a null pointer.

connldPtr IxAtmConnld [out] – Pointer to a connection Id. This parameter cannot be a

null pointer.

# Returns:

♦ IX SUCCESS successful call to *IxAtmdAccRxVcConnect()*.

♦ IX\_ATMDACC\_BUSY cannot process this request because no VC is available

♦ IX\_FAIL parameter error, VC already in use, attempt to connect AAL service on reserved OAM VPI/VCI, attempt to connect OAM service on VPI/VCI other than the reserved OAM VPI/VCI, port is not initialised, or some other error occurs during processing.

Submit a Pdu for transmission on connection.

A data user calls this function to submit an mbufs containing a Pdu to be transmitted. The buffer supplied can be chained and the Pdu it contains must be complete.

The transmission behavior of this call depends on the operational mode of the port on which the connection is made.

In unscheduled mode the mbuf will be submitted to the hardware immediately if sufficent resource is available. Otherwise the function will return failure.

In scheduled mode the buffer is queued internally in IxAtmdAcc. The cell demand is made known to the traffic shaping entity. Cells from the buffers are MUXed onto the port some time later as dictated by the traffic shaping entity. The traffic shaping entity does this by sending transmit schedules to IxAtmdAcc via

# ixAtmdAccPortTxProcess() function call.

Note that the dedicated OAM channel is scheduled just like any other channel. This means that any OAM traffic relating to an active AAL0/AAL5 connection will be scheduled independently of the AAL0/AAL5 traffic for that connection.

When transmission is complete, the TX Done mechanism will give the owmnership of these buffers back to the customer. The tx done mechanism must be in operation before transmission is attempted.

For AAL0/OAM submitted AAL0 PDUs must be a multiple of the cell data size (48/52). AAL0\_52 and OAM are raw cell services, and the client must format the PDU with an ATM cell header (excluding HEC) at the start of each cell, note that AtmdAcc does not validate the cell headers in a submitted PDU.

# See also:

# IxAtmdAccTxVcBufferReturnCallback

# ixAtmdAccTxDoneDispatch

## Parameters:

| cicis.        |                                                                                                                       |
|---------------|-----------------------------------------------------------------------------------------------------------------------|
| connId        | <b>IxAtmConnId</b> [in] – connection Id as resulted from a successfull call to <i>ixAtmdAccTxVcConnect()</i>          |
| mbufPtr       | [in] – pointer to a chained structure of mbufs to transmit. This parameter cannot be a null pointer.                  |
| clp           | <b>IxAtmdAccClpStatus</b> [in] – clp indication for this PDU. All cells of this pdu will be sent with the clp bit set |
| numberOfCell. | s unsigned int [in] – number of cells in the PDU.                                                                     |

# Returns:

- ♦ IX\_SUCCESS successful call to *ixAtmdAccTxVcPduSubmit*() The pdu pointed by the mbufPtr parameter will be transmitted
- ♦ IX\_ATMDACC\_BUSY unable to process this request because internal resources are all used. The caller is responsible for retrying this request later.
- ♦ IX\_FAIL unable to process this request because of error in the parameters (wrong connId supplied, or wrong mbuf pointer supplied), the total length of all buffers in the chain should be a multiple of the cell size ( 48/52 depending on the service type ), or unspecified error during processing

# Note:

- This function in not re–entrant for the same VC (e.g. : two thread cannot send PDUs for the same VC). But two threads can safely call this function with a different connection Id
- In unscheduled mode, this function is not re-entrant on a per port basis. The size of pdus is limited to 8Kb.
- 0-length mbufs should be removed from the chain before submission. The total length of the pdu (sdu + padding +trailer) has to be updated in the header of the first mbuf of a chain of mbufs.
- Aal5 trailer information (UUI, CPI, SDU length) has to be supplied before submission.

- The payload memory cache should be flushed, if needed, prior to transmission. Mbuf headers are flushed by IxAtmdAcc
- This function does not use system resources and can be used inside an interrupt context

# ixAtmdAccTxVcTryDisconnect ( **IxAtmConnId** connId )

Disconnect from a Aal Pdu transmit service for a particular port/vpi/vci.

This function deregisters the VC and guarantees that all resources associated with this VC are free. After its execution, the connection Id is not available.

This function will fail until such time as all resources allocated to the VC connection have been freed. The user is responsible to delay and call again this function many times until a success status is returned.

After its execution, the connection Id is not available.

### Parameters:

### Returns:

- ♦ IX\_SUCCESS successful call to *ixAtmdAccTxVcTryDisconnect(*)
- ♦ IX\_ATMDACC\_RESOURCES\_STILL\_ALLOCATED not all resources associated with the connection have been freed. This condition will disappear after Tx and TxDone is complete for this channel.
- ♦ IX\_FAIL unable to process this request because of errors in the parameters (wrong connId supplied)

# Note:

- This function needs internal locks and should not be called from an interrupt context
- If the *IX\_ATMDACC\_RESOURCES\_STILL\_ALLOCATED* error does not clear after a while, this may be linked to a previous problem of cell overscheduling. Diabling the port and retry a disconnect will free the resources associated with this channel.

# See also:

# ixAtmdAccPortTxProcess

# ixAtmdAccUninit (void)

Uninitialise the IxAtmdAcc Component.

This function uninitialises the IxAtmdAcc component. Its role is to uninitialise all internal resources of the IxAtmdAcc component. It de-allocatess all the buffers allocated during intialization and also destroys the mutex taken. This should be the last function to be called to clean up all resources.

# Parameters:

none

# Returns:

- ♦ IX\_SUCCESS uninitialisation is complete
- ♦ IX\_FAIL unable to process this request either because this IxAtmdAcc is already uninitialised or some unspecified error has occurred.

# Intel (R) IXP400 Software ATM Driver Access (IxAtmdAcc) Control API

The public API for the IXP400 Atm Driver Control component.

# **Modules**

Intel (R) IXP400 Software ATM Driver Access (IxAtmdAcc) Utopia Control API

The public API for the IXP400 Atm Driver Control component.

# **Defines**

#define IX\_ATMDACC\_PORT\_DISABLE\_IN\_PROGRESS

Port enable return code.

#define **IX\_ATMDACC\_ALLPDUS** *All PDUs*.

# **Typedefs**

typedef**IxAtmdAccRxDispatcher** )(**IxAtmRxQueueId** rxQueueId, unsigned int IX\_STATUS(\* numberOfPdusToProcess, unsigned int \*reservedPtr)

Callback prototype for notification of available PDUs for an Rx Q.

 $typedef \textbf{IxAtmdAccTxDoneDispatcher} \ ) (unsigned \ int \ number Of Pdus To Process, \ unsigned \ int \ IX\_STATUS (**reserved Ptr)$ 

Callback prototype for transmitted mbuf when threshold level is crossed.

 $typedef\ void (*\ \textbf{IxAtmdAccPortTxLowCallback}\ ) (\textbf{IxAtmLogicalPort}\ port,\ unsigned\ int number Of Available Cells)$ 

Notification that the threshold number of scheduled cells remains in a port's transmit Q.

 $typedef \textbf{IxAtmdAccTxVcDemandUpdateCallback} \ ) (\textbf{IxAtmLogicalPort} \ port, \ int \ vcId, \ unsigned \ IX\_STATUS(* \ int \ numberOfCells)$ 

Prototype to submit cells for transmission.

typedef void(\* **IxAtmdAccTxVcDemandClearCallback** )(**IxAtmLogicalPort** port, int vcId) prototype to remove all currently queued cells from a registered VC

typedef**IxAtmdAccTxSchVcIdGetCallback** )(**IxAtmLogicalPort** port, unsigned int vpi, unsigned IX\_STATUS(\* int vci, **IxAtmConnId** connId, int \*vcId)

\*\*prototype to get a scheduler vc id\*\*

Intel (R) IXP400 Software ATM Driver Access (IxAtmdAcc) Control API

# **Functions**

 $PUBLIC \textbf{ix} \textbf{Atm} \textbf{AccRxD} \textbf{ispatcherRegister} \ (\textbf{Ix} \textbf{Atm} \textbf{Rx} \textbf{QueueId} \ \textbf{queueId},$ 

IX\_STATUS **IxAtmdAccRxDispatcher** callback)

Register a notification callback to be invoked when there is at least one entry on a particular Rx queue.

**PUBLIC** 

IX\_STATUS ixAtmdAccRxDispatcherUnregister (IxAtmRxQueueId)

UnRegister a notification callback to be invoked when there is at least one entry on a particular Rx queue.

PUBLICixAtmdAccRxDispatch (IxAtmRxQueueId rxQueueId, unsigned int

IX\_STATUS numberOfPdusToProcess, unsigned int \*numberOfPdusProcessedPtr)

Control function which executes Rx processing for a particular Rx stream.

PUBLIC**ixAtmdAccRxLevelQuery** (**IxAtmRxQueueId** rxQueueId, unsigned int IX STATUS \*numberOfPdusPtr)

Query the number of entries in a particular RX queue.

PUBLIC**ixAtmdAccRxQueueSizeQuery** (**IxAtmRxQueueId** rxQueueId, unsigned int IX\_STATUS \*numberOfPdusPtr)

Query the size of a particular RX queue.

PUBLICixAtmdAccPortTxFreeEntriesQuery (IxAtmLogicalPort port, unsigned int IX STATUS \*numberOfCellsPtr)

Get the number of available cells the system can accept for transmission.

PUBLICixAtmdAccPortTxCallbackRegister (IxAtmLogicalPort port, unsigned int IX STATUS numberOfCells, IxAtmdAccPortTxLowCallback callback)

Configure the Tx port threshold value and register a callback to handle threshold notifications.

PUBLIC void ixAtmdAccPortTxCallbackUnregister (IxAtmLogicalPort port)

Unregister a callback to handle threshold notifications.

PUBLICixAtmdAccPortTxScheduledModeEnable (IxAtmLogicalPort port,

IX\_STATUS **IxAtmdAccTxVcDemandUpdateCallback** vcDemandUpdateCallback,

IxAtmdAccTxVcDemandClearCallback vcDemandClearCallback,

IxAtmdAccTxSchVcIdGetCallback vcIdGetCallback)

Put the port into Scheduled Mode.

**PUBLIC** 

 $IX\_STATUS \ \textbf{ixAtmdAccPortTxScheduledModeDisable} \ (\textbf{IxAtmLogicalPort} \ port)$ 

Put the port into UnScheduled Mode.

 $PUBLIC \textbf{ixAtmdAccPortTxProcess} \ (\textbf{IxAtmLogicalPort} \ port, \ \textbf{IxAtmScheduleTable} \ IX\_STATUS \ *scheduleTablePtr)$ 

Functions 37

*Transmit queue cells to the H/W based on the supplied schedule table.* 

# PUBLIC**ixAtmdAccTxDoneDispatch** (unsigned int numberOfPdusToProcess, unsigned int IX STATUS \*numberOfPdusProcessedPtr)

*Process a number of pending transmit done pdus from the hardware.* 

**PUBLIC** 

# IX\_STATUS **ixAtmdAccTxDoneLevelQuery** (unsigned int \*numberOfPdusPtr)

Query the current number of transmit pdus ready for recycling.

**PUBLIC** 

# IX\_STATUS **ixAtmdAccTxDoneQueueSizeQuery** (unsigned int \*numberOfPdusPtr)

Query the TxDone queue size.

# PUBLICixAtmdAccTxDoneDispatcherRegister (unsigned int numberOfPdus,

# IX STATUS **IxAtmdAccTxDoneDispatcher** notificationCallback)

Configure the Tx Done stream threshold value and register a callback to handle threshold notifications.

# PUBLIC void ixAtmdAccTxDoneDispatcherUnregister (void)

Unregister a callback to handle threshold notifications.

# PUBLICixAtmdAccUtopiaConfigSet (const IxAtmdAccUtopiaConfig

IX\_STATUS \*ixAtmdAccUtopiaConfigPtr)

Send the configuration structure to the Utopia interface.

**PUBLIC** 

# IX\_STATUS ixAtmdAccUtopiaStatusGet (IxAtmdAccUtopiaStatus \*ixAtmdAccUtopiaStatus)

Get the Utopia interface configuration.

**PUBLIC** 

# IX\_STATUS ixAtmdAccPortEnable (IxAtmLogicalPort port)

enable a PHY logical port

**PUBLIC** 

# IX\_STATUS ixAtmdAccPortDisable (IxAtmLogicalPort port)

disable a PHY logical port

# PUBLIC BOOL ixAtmdAccPortDisableComplete (IxAtmLogicalPort port)

disable a PHY logical port

PUBLIC

# IX STATUS ixAtmdAccUtopiaConfigReset (const IxAtmdAccUtopiaConfig \*utConfig)

Reset the configuration structure to the Utopia interface initializes configuration registers and write to NPE-A Load and get response from NPE-A and resets the Utopia interface.

Functions 38

# **Detailed Description**

The public API for the IXP400 Atm Driver Control component.

IxAtmdAcc is the low level interface by which AAL PDU get transmitted to, and received from the Utopia bus

This part is related to the Control configuration

# **Define Documentation**

# #define IX\_ATMDACC\_ALLPDUS

All PDUs.

This constant is used to tell IxAtmDAcc to process all PDUs from the RX queue or the TX Done

See also:

IxAtmdAccRxD is patcher

IxAtmdAccTxDoneDispatcher

Definition at line **74** of file **IxAtmdAccCtrl.h**.

# #define IX\_ATMDACC\_PORT\_DISABLE\_IN\_PROGRESS

Port enable return code.

This constant is used to tell IxAtmDAcc user that the port disable functions are not complete. The user can call **ixAtmdAccPortDisableComplete()** to find out when the disable has finished. The port enable can then proceed.

Definition at line **57** of file **IxAtmdAccCtrl.h**.

# **Typedef Documentation**

typedef void(\* IxAtmdAccPortTxLowCallback)(**IxAtmLogicalPort** port, unsigned int numberOfAvailableCells)

Notification that the threshold number of scheduled cells remains in a port's transmit Q.

The is the prototype for of the user notification function which gets called on a per–port basis, when the number of remaining scheduled cells to be transmitted decreases to the threshold level. The number of cells passed as a parameter can be used for scheduling purposes as the maximum number of cells that can be passed in a schedule table to the *ixAtmdAccPortTxProcess()* function.

### See also:

ix Atm d Acc Port Tx Callback Register

ixAtmdAccPortTxProcess

ixAtmdAccPortTxFreeEntriesQuery

### Parameters:

port **IxAtmLogicalPort** [in] – logical PHY port [IX\_UTOPIA\_PORT\_0 ...

 $IX\_UTOPIA\_MAX\_PORTS - 1$ 

numberOfAvailableCells unsigned int [in] – number of available cell entries.for the port

# Note:

- This functions shall not use system resources when used inside an interrupt context.

Definition at line 188 of file IxAtmdAccCtrl.h.

typedef IX\_STATUS(\* IxAtmdAccRxDispatcher)(**IxAtmRxQueueId** rxQueueId, unsigned int numberOfPdusToProcess, unsigned int \*reservedPtr)

Callback prototype for notification of available PDUs for an Rx Q.

This a protoype for a function which is called when there is at least one Pdu available for processing on a particular Rx Q.

This function should call *ixAtmdAccRxDispatch()* with the appropriate number of parameters to read and process the Rx Q.

# See also:

ixAtmdAccRxDispatch

ixAtmdAccRxVcConnect

ixAtmdAccRxDispatcherRegister

# Parameters:

numberOfPdusToProcess unsigned int [in] indicates the minimum number of PDUs available to

process all PDUs from the queue.

reservedPtr unsigned int\* [out] pointer to a int location which can be written to, but

does not retain written values. This is provided to make this prototype

compatible with *ixAtmdAccRxDispatch()* 

# Returns:

 $\Diamond$  int – ignored.

Definition at line 108 of file IxAtmdAccCtrl.h.

typedef IX\_STATUS(\* IxAtmdAccTxDoneDispatcher)(unsigned int numberOfPdusToProcess, unsigned int \*reservedPtr)

Callback prototype for transmitted mbuf when threshold level is crossed.

IxAtmdAccTxDoneDispatcher is the prototype of the user function which get called when pdus are completely transmitted. This function is likely to call the *ixAtmdAccTxDoneDispatch()* function.

This function is called when the number of available pdus for reception is crossing the threshold level as defined in *ixAtmdAccTxDoneDispatcherRegister()* 

This function is called inside an Qmgr dispatch context. No system resource or interrupt—unsafe feature should be used inside this callback.

Transmitted buffers recycling implementation is a sytem—wide mechanism and needs to be set before any traffic is started. If this threshold mechanism is not used, the user is responsible for polling the transmitted buffers with *ixAtmdAccTxDoneDispatch()* and *ixAtmdAccTxDoneLevelQuery()* functions.

### See also:

ixAtmdAccTxDoneDispatcherRegister

ixAtmdAccTxDoneDispatch

ixAtmdAccTxDoneLevelQuery

### Parameters:

numberOfPdusToProcess unsigned int [in] - The current number of pdus currently available for

recycling

\*reservedPtr unsigned int [out] – pointer to a int location which can be written to but

does not retain written values. This is provided to make this prototype

compatible with ixAtmdAccTxDoneDispatch()

# Returns:

♦ IX\_SUCCESS This is provided to make this prototype compatible with ixAtmdAccTxDoneDispatch()

♦ IX\_FAIL invalid parameters or some unspecified internal error occured. This is provided to make this prototype compatible with *ixAtmdAccTxDoneDispatch()* 

Definition at line 159 of file IxAtmdAccCtrl.h.

typedef IX\_STATUS(\* IxAtmdAccTxSchVcIdGetCallback)(**IxAtmLogicalPort** port, unsigned int vpi, unsigned int vci, **IxAtmConnId** connId, int \*vcId)

prototype to get a scheduler vc id

IxAtmdAccTxSchVcIdGetCallback is the prototype of the function to get a scheduler vcId

See also:

# IxAtmdAccTxVcDemandUpdateCallback

### **IxAtmdAccTxVcDemandClearCallback**

# **IxAtmdAccTxSchVcIdGetCallback**

# ix Atm d Acc Port Tx Scheduled Mode Enable

### Parameters:

port IxAtmLogicalPort [in] – Specifies the ATM logical port on which the VC is established

*vpi* unsigned int [in] – For AAL0/AAL5 specifies the ATM vpi on which the VC is established. For OAM specifies the dedicated "OAM Tx channel" VPI.

vci unsigned int [in] – For AAL0/AAL5 specifies the ATM vci on which the VC is established. For OAM specifies the dedicated "OAM Tx channel" VCI.

connId IxAtmConnId [in] – specifies the IxAtmdAcc connection Id already associated with this VC

vcId int\* [out] – pointer to a vcId

### Returns:

♦ IX\_SUCCESS the function is returning a Scheduler vcId for this VC

♦ IX\_FAIL the function cannot process scheduling for this VC. the contents of vcId is unspecified

Definition at line **288** of file **IxAtmdAccCtrl.h**.

# typedef void(\* IxAtmdAccTxVcDemandClearCallback)(IxAtmLogicalPort port, int vcId)

prototype to remove all currently queued cells from a registered VC

IxAtmdAccTxVcDemandClearCallback is the prototype of the function to remove all currently queued cells from a registered VC. The pending cell count for the specified VC is reset to zero. After the use of this callback, the scheduler shall not schedule more cells for this VC.

This callback function is called during a VC disconnection *ixAtmdAccTxVcTryDisconnect(*)

# See also:

Ix Atm d Acc Tx Vc Demand Update Callback

**IxAtmdAccTxVcDemandClearCallback** 

**IxAtmdAccTxSchVcIdGetCallback** 

ix Atm d Acc Port Tx Scheduled Mode Enable

ixAtmdAccTxVcTryDisconnect

### Parameters:

port

**IxAtmLogicalPort** [in] – Specifies the ATM port on which the VC to be cleared is established

vcId int [in] – Identifies the VC to be cleared. This is the value returned by the IxAtmdAccTxSchVcIdGetCallback() call .

### Returns:

none

Definition at line 253 of file IxAtmdAccCtrl.h.

typedef IX\_STATUS(\* IxAtmdAccTxVcDemandUpdateCallback)(**IxAtmLogicalPort** port, int vcId, unsigned int numberOfCells)

Prototype to submit cells for transmission.

IxAtmdAccTxVcDemandUpdateCallback is the prototype of the callback function used by AtmD to notify an ATM Scheduler that the user of a VC has submitted cells for transmission.

# See also:

Ix Atm d Acc Tx Vc Demand Update Callback

**IxAtmdAccTxVcDemandClearCallback** 

**IxAtmdAccTxSchVcIdGetCallback** 

ixAtmdAccPortTxScheduledModeEnable

# Parameters:

port IxAtmLogicalPort [in] – Specifies the ATM port on which the VC to be updated

is established

vcId int [in] – Identifies the VC to be updated. This is the value returned by the

IxAtmdAccTxSchVcIdGetCallback() call .

numberOfCells unsigned int [in] – Indicates how many ATM cells should be added to the queue for

this VC.

# Returns:

♦ IX\_SUCCESS the function is registering the cell demand for this VC.

♦ IX\_FAIL the function cannot register cell for this VC : the scheduler maybe overloaded or misconfigured

Definition at line 219 of file IxAtmdAccCtrl.h.

# **Function Documentation**

ixAtmdAccPortDisable ( **IxAtmLogicalPort** port )

disable a PHY logical port

This function disable the transmission over one port.

When a port is disabled, the cell transmission to the Utopia interface is stopped.

### Parameters:

```
port IxAtmLogicalPort [in] – logical PHY port [IX_UTOPIA_PORT_0 .. IX_UTOPIA_MAX_PORTS – 1]
```

### Returns:

- ♦ IX\_SUCCESS disable is complete
- ♦ IX\_ATMDACC\_WARNING port already disabled
- ♦ IX\_FAIL disable failed, wrong parameter .

# Note:

- This function needs internal locks and should not be called from an interrupt context
- The response from hardware is done through the txDone mechanism to ensure the synchrnisation with tx resources. Therefore, the txDone mechanism needs to be serviced to make a PortDisable complete.

# See also:

**ixAtmdAccPortEnable** 

ix Atm d Acc Port D is able Complete

ixAtmdAccTxDoneDispatch

# ixAtmdAccPortDisableComplete ( IxAtmLogicalPort port )

disable a PHY logical port

This function indicates if the port disable for a port has completed. This function will return TRUE if the port has never been enabled.

# Parameters:

# Returns:

- ♦ TRUE disable is complete
- ♦ FALSE disable failed, wrong parameter .

# Note:

- This function needs internal locks and should not be called from an interrupt context

### See also:

# ixAtmdAccPortEnable

# ixAtmdAccPortDisable

```
ixAtmdAccPortEnable ( IxAtmLogicalPort port )
```

enable a PHY logical port

This function enables the transmission over one port. It should be called before accessing any resource from this port and before the establishment of a VC.

When a port is enabled, the cell transmission to the Utopia interface is started. If there is no traffic already running, idle cells are sent over the interface.

This function can be called multiple times.

# Parameters:

### Returns:

- ♦ IX\_SUCCESS enable is complete
- ♦ IX\_ATMDACC\_WARNING port already enabled
- ♦ IX\_FAIL enable failed, wrong parameter, or cannot initialise this port (the port is maybe already in use, or there is a hardware issue)

### Note:

- This function needs internal locks and should not be called from an interrupt context

# See also:

# ixAtmdAccPortDisable

Configure the Tx port threshold value and register a callback to handle threshold notifications.

This function sets the threshold in cells

### See also:

ix Atm d Acc Port Tx Callback Register

ixAtmdAccPortTxProcess

# ixAtmdAccPortTxFreeEntriesQuery

### Parameters:

**IxAtmLogicalPort** [in] – logical PHY port [IX UTOPIA PORT 0... port

 $IX\_UTOPIA\_MAX\_PORTS - 1$ 

numberOfCells unsigned int [in] – threshold value which triggers the callback invocation, This

number has to be one of the values 0,1,2,4,8,16,32 .... The maximum value cannot

be more than half of the txVc queue size (which can be retrieved using

*ixAtmdAccPortTxFreeEntriesQuery()* before any Tx traffic is sent for this port) **IxAtmdAccPortTxLowCallback** [in] – callback function to invoke when the

threshold level is reached. This parameter cannot be a null pointer.

## Returns:

callback

♦ IX\_SUCCESS Successful call to *ixAtmdAccPortTxCallbackRegister(*)

\$\delta \text{IX} \text{ FAIL error in the parameters, Tx channel already set for this port threshold level is not correct or within the range regarding the queue size:or unspecified error during processing:

### Note:

- This callback function get called when the threshold level drops from (numberOfCells+1) cells to (numberOfCells) cells
- This function should be called during system initialisation, outside an interrupt context

# ixAtmdAccPortTxCallbackUnregister ( **IxAtmLogicalPort** port )

Unregister a callback to handle threshold notifications.

### Parameters:

```
port IxAtmLogicalPort [in] – logical PHY port [IX_UTOPIA_PORT_0 ...
    IX UTOPIA MAX PORTS – 1]
```

### Returns:

♦ none

# Note:

- This function should be called during system un-initialisation, outside an interrupt context

```
ixAtmdAccPortTxFreeEntriesQuery ( IxAtmLogicalPort port,
                                   unsigned int *
                                                     numberOfCellsPtr
```

Get the number of available cells the system can accept for transmission.

The function is used to retrieve the number of cells that can be queued for transmission to the hardware.

This number is based on the worst schedule table where one cell is stored in one schedule table entry, depending on the pdus size and mbuf size and fragmentation.

This function doesn't use system resources and can be used from a timer context, or can be associated with a threshold event, or can be used inside an active polling mechanism

### Parameters:

```
port IxAtmLogicalPort [in] – logical PHY port [IX_UTOPIA_PORT_0 .. IX_UTOPIA_MAX_PORTS – 1]
```

numberOfCellsPtr unsigned int\* [out] – number of available cells. This parameter cannot be a null pointer.

### See also:

# ixAtmdAccPortTxProcess

### Returns:

♦ IX\_SUCCESS numberOfCellsPtr contains the number of cells that can be scheduled for this port.

♦ IX\_FAIL error in the parameters, or some processing error occured.

Transmit queue cells to the H/W based on the supplied schedule table.

This function *ixAtmdAccPortTxProcess()* process the schedule table provided as a parameter to the function. As a result cells are sent to the underlaying hardware for transmission.

The schedule table is executed in its entirety or not at all. So the onus is on the caller not to submit a table containing more cells than can be transmitted at that point. The maximum numbers that can be transmitted is guaranteed to be the number of cells as returned by the function *ixAtmdAccPortTxFreeEntriesQuery()*.

When the scheduler is invoked on a threshold level, IxAtmdAcc gives the minimum number of cells (to ensure the callback will fire again later) and the maximum number of cells that *ixAtmdAccPortTxProcess()* will be able to process (assuming the ATM scheduler is able to produce the worst–case schedule table, i.e. one entry per cell).

When invoked ouside a threshold level, the overall number of cells of the schedule table should be less than the number of cells returned by the *ixAtmdAccPortTxFreeEntriesQuery()* function.

After invoking the *ixAtmdAccPortTxProcess()* function, it is the user choice to query again the queue level with the function *ixAtmdAccPortTxFreeEntriesQuery()* and, depending on a new cell number, submit an other schedule table.

IxAtmdAcc will check that the number of cells in the schedule table is compatible with the current transmit level. If the

Obsolete or invalid connection Id will be silently discarded.

This function is not reentrant for the same port.

This functions doesn't use system resources and can be used inside an interrupt context.

This function is used as a response to the hardware requesting more cells to transmit.

## See also:

ix Atm d Acc Port Tx Scheduled Mode Enable

ixAtmdAccPortTxFreeEntriesQuery

ix Atm d Acc Port Tx Callback Register

ixAtmdAccPortEnable

### Parameters:

port **IXAtmLogicalPort** [in] – logical PHY port [IX\_UTOPIA\_PORT\_0 ...

 $IX\_UTOPIA\_MAX\_PORTS - 1$ 

 $schedule Table Ptr \ \textbf{IxAtmScheduleTable}* \ [in] - pointer \ to \ a \ scheduler \ update \ table. \ The \ content \ of \ a \ scheduler \ update \ table \ a \ scheduler \ update \ a \ scheduler \ update \ a \ update \ upda$ 

this table is not modified by this function. This parameter cannot be a null

pointer.

## Returns:

- ♦ IX\_SUCCESS the schedule table process is complete and cells are transmitted to the hardware
- ◊ IX\_ATMDACC\_WARNING: Traffic will be dropped: the schedule table exceed the hardware capacity If this error is ignored, further traffic and schedule will work correctly. Overscheduling does not occur when the schedule table does not contain more entries that the number of free entries returned by ixAtmdAccPortTxFreeEntriesQuery(). However, Disconnect attempts just after this error will fail permanently with the error code IX\_ATMDACC\_RESOURCES\_STILL\_ALLOCATED, and it is necessary to disable the port to make ixAtmdAccTxVcTryDisconnect() successful.
- ♦ IX\_FAIL a wrong parameter is supplied, or the format of the schedule table is invalid, or the port is not Enabled, or an internal severe error occured. No cells is transmitted to the hardware

### Note:

– If the failure is linked to an overschedule of data cells the result is an inconsistency in the output traffic (one or many cells may be missing and the traffic contract is not respected).

# ixAtmdAccPortTxScheduledModeDisable ( **IxAtmLogicalPort** port )

Put the port into UnScheduled Mode.

# Parameters:

### Returns:

♦ IX\_SUCCESS scheduler unregistration is complete and the port is now in unscheduled mode.

♦ IX FAIL failed (wrong parameters)

Put the port into Scheduled Mode.

This function puts the specified port into scheduled mode of transmission which means an external s/w entity controls the transmission of cells on this port. This faciltates traffic shaping on the port.

Any buffers submitted on a VC for this port will be queued in IxAtmdAcc. The transmission of these buffers to and by the hardware will be driven by a transmit schedule submitted regulary in calls to *ixAtmdAccPortTxProcess()* by traffic shaping entity.

The transmit schedule is expected to be dynamic in nature based on the demand in cells for each VC on the port. Hence the callback parameters provided to this function allow IxAtmdAcc to inform the shaping entity of demand changes for each VC on the port.

By default a port is in Unscheduled Mode so if this function is not called, transmission of data is done without sheduling rules, on a first–come, first–out basis.

Once a port is put in scheduled mode it cannot be reverted to un–scheduled mode.

### Note:

- This function should be called before any VCs have be connected on a port. Otherwise this function call will return failure.
- This function uses internal locks and should not be called from an interrupt context

# See also:

IxAtmdAccTxVcDemandUpdateCallback

IxAtmdAccTxVcDemandClearCallback

**IxAtmdAccTxSchVcIdGetCallback** 

ixAtmdAccPortTxProcess

### Parameters:

port **IxAtmLogicalPort** [in] – logical PHY port [IX\_UTOPIA\_PORT\_0 .. IX\_UTOPIA\_MAX\_PORTS – 1]

*vcDemandUpdateCallback* **IxAtmdAccTxVcDemandUpdateCallback** [in] – callback function used to update the number of outstanding cells for transmission. This

parameter cannot be a null pointer.

vcDemandClearCallback [in] – callback function used

to remove all clear the number of outstanding cells for a VC. This

parameter cannot be a null pointer.

vcIdGetCallback [in] – callback function used to

exchange vc Identifiers between IxAtmdAcc and the entity supplying

the transmit schedule. This parameter cannot be a null pointer.

#### Returns:

♦ IX\_SUCCESS scheduler registration is complete and the port is now in scheduled mode.

♦ IX\_FAIL failed (wrong parameters, or traffic is already enabled on this port, possibly without ATM shaping)

```
ixAtmdAccRxDispatch ( IxAtmRxQueueId rxQueueId, unsigned int numberOfPdusToProcess, unsigned int * numberOfPdusProcessedPtr
)
```

Control function which executes Rx processing for a particular Rx stream.

The IxAtmdAccRxDispatch() function is used to process received Pdus available from one of the two incoming RX streams. When this function is invoked, the incoming traffic (up to the number of PDUs passed as a parameter) will be transferred to the IxAtmdAcc users through the callback IxAtmdAccRxVcRxCallback(), as registered during the ixAtmdAccRxVcConnect() call.

The user receive callbacks will be executed in the context of this function.

Failing to use this function on a regular basis when there is traffic will block incoming traffic and can result in Pdus being dropped by the hardware.

This should be used to control when received pdus are handed off from the hardware to Aal users from a particluar stream. The function can be used from a timer context, or can be registered as a callback in response to an rx stream threshold event, or can be used inside an active polling mechanism which is under user control.

#### Note:

- The signature of this function is directly compatible with the callback prototype which can be register with *ixAtmdAccRxDispatcherRegister()*.

#### See also:

ixAtmdAccRxDispatcherRegister

**IxAtmdAccRxVcRxCallback** 

ixAtmdAccRxVcFreeEntriesQuery

#### Parameters:

numberOfPdusToProcess

unsigned int [in] – indicates the maxiumum number of PDU to remove from the RX queue. A value of IX\_ATMDACC\_ALLPDUS indicates to process all PDUs from the queue. This includes at least the PDUs in the queue when the fuction is invoked. Because of real–time constraints, there is no guarantee thatthe queue will be empty when the function exits. If this parameter is greater than the number of entries of the queues, the function will succeed and the parameter numberOfPdusProcessedPtr will reflect the exact number of PDUs processed.

\*numberOfPdusProcessedPtr unsigned int [out] – indicates the actual number of PDU processed during this call. This parameter cannot be a null pointer.

#### Returns:

- ♦ IX\_SUCCESS the number of PDUs as indicated in numberOfPdusProcessedPtr are removed from the RX queue and the VC callback are called.
- ♦ IX\_FAIL invalid parameters or some unspecified internal error occured.

```
ixAtmdAccRxDispatcherRegister ( IxAtmRxQueueId queueId, IxAtmdAccRxDispatcher callback )
```

Register a notification callback to be invoked when there is at least one entry on a particular Rx queue.

This function registers a callback to be invoked when there is at least one entry in a particular queue. The registered callback is called every time when the hardware adds one or more pdus to the specified Rx queue.

This function cannot be used when a Rx Vc using this queue is already existing.

#### Note:

-The callback function can be the API function *ixAtmdAccRxDispatch()*: every time the threhold level of the queue is reached, the *ixAtmdAccRxDispatch()* is invoked to remove all entries from the queue.

#### See also:

ixAtmdAccRxDispatch

#### **IxAtmdAccRxDispatcher**

#### Parameters:

queueld IxAtmRxQueueld [in] RX queue identification

*callback* **IxAtmdAccRxDispatcher** [in] function triggering the delivery of incoming traffic. This parameter cannot be a null pointer.

#### Returns:

- ♦ IX\_SUCCESS Successful call to *ixAtmdAccRxDispatcherRegister(*)
- ♦ IX\_FAIL error in the parameters, or there is an already active RX VC for this queue or

#### ixAtmdAccRxDispatcherUnregister ( **IxAtmRxQueueId** atmdQueueId )

UnRegister a notification callback to be invoked when there is at least one entry on a particular Rx queue.

#### Parameters:

queueld IxAtmRxQueueld [in] RX queue identification

#### Returns:

```
♦ IX_SUCCESS Successful call
```

♦ IX\_FAIL error in the parameters

```
ixAtmdAccRxLevelQuery ( IxAtmRxQueueId rxQueueId, unsigned int * numberOfPdusPtr )
```

Query the number of entries in a particular RX queue.

This function is used to retrieve the number of pdus received by the hardware and ready for distribution to users.

#### Parameters:

```
rxQueueld IxAtmRxQueueId [in] – indicates which of two RX queues to query.

numberOfPdusPtr unsigned int* [out] – Pointer to store the number of available PDUs in the RX queue. This parameter cannot be a null pointer.
```

#### Returns:

- ♦ IX\_SUCCESS the value in numberOfPdusPtr specifies the number of incoming pdus waiting in this queue
- ♦ IX\_FAIL an error occurs during processing. The value in numberOfPdusPtr is unspecified.

#### Note:

- This function is reentrant, doesn't use system resources and can be used from an interrupt context.

```
ixAtmdAccRxQueueSizeQuery ( IxAtmRxQueueId rxQueueId, unsigned int * numberOfPdusPtr )
```

Query the size of a particular RX queue.

This function is used to retrieve the number of pdus the system is able to queue when reception is complete.

#### Parameters:

```
rxQueueId [in] – indicates which of two RX queues to query.
```

numberOfPdusPtr unsigned int\* [out] – Pointer to store the number of pdus the system is able to queue in the RX queue. This parameter cannot be a null pointer.

#### Returns:

- ♦ IX\_SUCCESS the value in numberOfPdusPtr specifies the number of pdus the system is able to queue.
- ♦ IX\_FAIL an error occurs during processing. The value in numberOfPdusPtr is unspecified.

#### Note:

- This function is reentrant, doesn't use system resources and can be used from an interrupt context.

Process a number of pending transmit done pdus from the hardware.

As a by-product of Atm transmit operation buffers which transmission is complete need to be recycled to users. This function is invoked to service the oustanding list of transmitted buffers and pass them to VC users.

Users are handed back pdus by invoking the free callback registered during the *ixAtmdAccTxVcConnect*() call.

There is a single Tx done stream servicing all active Atm Tx ports which can contain a maximum of 64 entries. If this stream fills port transmission will stop so this function must be call sufficently frequently to ensure no disruption to the transmit operation.

This function can be used from a timer context, or can be associated with a TxDone level threshold event (see *ixAtmdAccTxDoneDispatcherRegister()*), or can be used inside an active polling mechanism under user control.

For ease of use the signature of this function is compatible with the TxDone threshold event callback prototype.

This functions can be used inside an interrupt context.

#### See also:

ixAtmdAccTxDoneDispatcherRegister

**IxAtmdAccTxVcBufferReturnCallback** 

ixAtmdAccTxDoneLevelQuery

#### Parameters:

numberOfPdusToProcess unsigned int [in] – maxiumum number of pdus to remove from the TX Done queue

\*numberOfPdusProcessedPtr unsigned int [out] – number of pdus removed from the TX Done

queue. This parameter cannot be a null pointer.

#### Returns:

- ♦ IX\_SUCCESS the number of pdus as indicated in numberOfPdusToProcess are removed from the TX Done hardware and passed to the user through the Tx Done callback registered during a call to *ixAtmdAccTxVcConnect()*
- ♦ IX\_FAIL invalid parameters or numberOfPdusProcessedPtr is a null pointer or some unspecified internal error occured.

Configure the Tx Done stream threshold value and register a callback to handle threshold notifications.

This function sets the threshold level in term of number of pdus at which the supplied notification function should be called.

The higher the threshold value is, the less events will be necessary to process transmitted buffers.

Transmitted buffers recycling implementation is a sytem—wide mechanism and needs to be set prior any traffic is started. If this threshold mechanism is not used, the user is responsible for polling the transmitted buffers thanks to *ixAtmdAccTxDoneDispatch()* and *ixAtmdAccTxDoneLevelQuery()* functions.

This function should be called during system initialisation outside an interrupt context

#### See also:

ixAtmdAccTxDoneDispatcherRegister

ixAtmdAccTxDoneDispatch

ix Atm d Acc Tx Done Level Query

#### Parameters:

numberOfPdus unsigned int [in] – The number of TxDone pdus which

triggers the callback invocation This number has to be a power of 2, one of the values 0,1,2,4,8,16,32 ... The maximum value cannot be more than half of the txDone

queue size (which can be retrieved using ixAtmdAccTxDoneQueueSizeQuery())

invoke. (This parameter can be

ixAtmdAccTxDoneDispatch()). This parameter ust not be a

null pointer.

#### Returns:

♦ IX\_SUCCESS Successful call to ixAtmdAccTxDoneDispatcherRegister

#### ♦ IX\_FAIL error in the parameters:

#### Note:

- The notificationCallback will be called exactly when the threshold level will increase from (numberOfPdus) to (numberOfPdus+1)
- If there is no Tx traffic, there is no guarantee that TxDone Pdus will be released to the user (when txDone level is permanently under the threshold level. One of the preffered way to return resources to the user is to use a mix of txDone notifications, used together with a slow rate timer and an exclusion mechanism protecting from re–entrancy
- The TxDone threshold will only hand back buffers when the threshold level is crossed. Setting this threshold to a great number reduce the interrupt rate and the cpu load, but also increase the number of outstanding mbufs and has a system wide impact when these mbufs are needed by other components.

#### ixAtmdAccTxDoneDispatcherUnregister (void)

Unregister a callback to handle threshold notifications.

#### Parameters:

NONE.

#### Returns:

**NONE** 

#### ixAtmdAccTxDoneLevelQuery ( unsigned int \* numberOfPdusPtr )

Query the current number of transmit pdus ready for recycling.

This function is used to get the number of transmitted pdus which the hardware is ready to hand back to user.

This function can be used from a timer context, or can be associated with a threshold event, on can be used inside an active polling mechanism

#### See also:

#### ix Atm d Acc Tx Done Dispatch

#### Parameters:

\*numberOfPdusPtr unsigned int [out] – Pointer to the number of pdus transmitted at the time

of this function call, and ready for recycling This parameter cannot be a

null pointer.

#### Returns:

♦ IX\_SUCCESS numberOfPdusPtr contains the number of pdus ready for recycling at the time of this function call

♦ IX\_FAIL wrong parameter (null pointer as parameter).or unspecified rocessing error occurs..The value in numberOfPdusPtr is unspecified.

#### ixAtmdAccTxDoneQueueSizeQuery (unsigned int \* numberOfPdusPtr)

Query the TxDone queue size.

This function is used to get the number of pdus which the hardware is able to store after transmission is complete

The returned value can be used to set a threshold and enable a callback to be notified when the number of pdus is going over the threshold.

#### See also:

#### ixAtmdAccTxDoneDispatcherRegister

#### Parameters:

\*numberOfPdusPtr unsigned int [out] – Pointer to the number of pdus the system is able to queue after transmission

#### Returns:

- ♦ IX\_SUCCESS numberOfPdusPtr contains the the number of pdus the system is able to queue after transmission
- ♦ IX\_FAIL wrong parameter (null pointer as parameter).or unspecified rocessing error occurs..The value in numberOfPdusPtr is unspecified.

#### Note:

- This function is reentrant, doesn't use system resources and can be used from an interrupt context.

#### ixAtmdAccUtopiaConfigReset ( const **IxAtmdAccUtopiaConfig** \* utConfig )

Reset the configuration structure to the Utopia interface initializes configuration registers and write to NPE-A Load and get response from NPE-A and resets the Utopia interface.

#### Parameters:

\*ixAtmdAccNPEConfigPtr IxAtmdAccUtopiaConfig [in] – pointer to a structure to download to

#### Returns:

♦ IX\_SUCCESS successful unload

♦ IX\_FAIL error in the parameters

#### ixAtmdAccUtopiaConfigSet ( const **IxAtmdAccUtopiaConfig** \* ixAtmdAccUtopiaConfigPtr )

Send the configuration structure to the Utopia interface.

This function downloads the *IxAtmdAccUtopiaConfig* structure to the Utopia and has the following effects

- setup the Utopia interface
- initialise the NPE
- reset the Utopia cell counters and status registers to known values

This action has to be done once at initialisation. A lock is preventing the concurrent use of *ixAtmdAccUtopiaStatusGet()* and *ixAtmdAccUtopiaConfigSet()* 

#### Parameters:

\*ixAtmdAccNPEConfigPtr **IxAtmdAccUtopiaConfig** [in] – pointer to a structure to download to Utopia. This parameter cannot be a null pointer.

#### Returns:

♦ IX\_SUCCESS successful download

♦ IX\_FAIL error in the parameters, or configuration is not complete or failed

#### See also:

#### ixAtmdAccUtopiaStatusGet

#### ixAtmdAccUtopiaStatusGet ( **IxAtmdAccUtopiaStatus** \* ixAtmdAccUtopiaStatus )

Get the Utopia interface configuration.

This function reads the Utopia registers and the Cell counts and fills the IxAtmdAccUtopiaStatus structure

A lock is preventing the concurrent use of *ixAtmdAccUtopiaStatusGet()* and *ixAtmdAccUtopiaConfigSet()* 

#### Parameters:

*ixAtmdAccUtopiaStatus* [out] – pointer to structure to be updated from internal hardware counters. This parameter cannot be a NULL pointer.

#### Returns:

♦ IX\_SUCCESS successful read

♦ IX\_FAIL error in the parameters null pointer, or configuration read is not complete or failed

#### See also:

#### ixAtmdAccUtopiaConfigSet

# Intel (R) IXP400 Software ATM Driver Access (IxAtmdAcc) Utopia Control API

[Intel (R) IXP400 Software ATM Driver Access (IxAtmdAcc) Control API]

The public API for the IXP400 Atm Driver Control component.

### **Data Structures**

struct **IxAtmdAccUtopiaConfig** *Utopia configuration.* 

struct **IxAtmdAccUtopiaConfig::UtRxConfig\_** *Utopia Rx config Register.* 

struct **IxAtmdAccUtopiaConfig::UtRxDefineIdle\_** *Utopia Rx idle cells config Register.* 

struct **IxAtmdAccUtopiaConfig::UtRxEnableFields\_** *Utopia Rx enable Register.* 

struct **IxAtmdAccUtopiaConfig::UtRxStatsConfig\_** *Utopia Rx stats config Register.* 

struct **IxAtmdAccUtopiaConfig::UtRxTransTable0**\_ *Utopia Rx translation table Register*.

struct **IxAtmdAccUtopiaConfig::UtRxTransTable1\_** *Utopia Rx translation table Register.* 

struct **IxAtmdAccUtopiaConfig::UtRxTransTable2**\_ *Utopia Rx translation table Register*.

struct **IxAtmdAccUtopiaConfig::UtRxTransTable3**\_ *Utopia Rx translation table Register*.

struct **IxAtmdAccUtopiaConfig::UtRxTransTable4**\_ *Utopia Rx translation table Register*.

struct **IxAtmdAccUtopiaConfig::UtRxTransTable5\_** *Utopia Rx translation table Register.* 

struct **IxAtmdAccUtopiaConfig::UtSysConfig\_** *NPE setup Register*.

struct **IxAtmdAccUtopiaConfig::UtTxConfig\_** *Utopia Tx Config Register.* 

## struct **IxAtmdAccUtopiaConfig::UtTxDefineIdle\_** *Utopia Tx idle cells Register.*

## struct **IxAtmdAccUtopiaConfig::UtTxEnableFields\_** *Utopia Tx ienable fields Register.*

## struct **IxAtmdAccUtopiaConfig::UtTxStatsConfig\_** *Utopia Tx stats Register*.

## struct **IxAtmdAccUtopiaConfig::UtTxTransTable0\_** *Utopia Tx translation table Register.*

## struct **IxAtmdAccUtopiaConfig::UtTxTransTable1**\_ *Utopia Tx translation table Register*.

## struct **IxAtmdAccUtopiaConfig::UtTxTransTable2**\_ *Utopia Tx translation table Register*.

## struct **IxAtmdAccUtopiaConfig::UtTxTransTable3**\_ *Utopia Tx translation table Register*.

## struct **IxAtmdAccUtopiaConfig::UtTxTransTable4\_** *Utopia Tx translation table Register.*

## struct **IxAtmdAccUtopiaConfig::UtTxTransTable5\_** *Utopia Tx translation table Register.*

## struct **IxAtmdAccUtopiaStatus** *Utopia status*.

## struct **IxAtmdAccUtopiaStatus::UtRxCellConditionStatus\_** *Utopia Rx Status Register.*

## struct **IxAtmdAccUtopiaStatus::UtTxCellConditionStatus\_** *Utopia Tx Status Register.*

### **Detailed Description**

The public API for the IXP400 Atm Driver Control component.

IxAtmdAcc is the low level interface by which AAL PDU get transmitted to,and received from the Utopia bus

This part is related to the UTOPIA configuration.

Detailed Description 59

# Intel (R) IXP400 Software ATM Manager (IxAtmm) API

IXP400 ATM Manager component Public API.

### **Data Structures**

#### struct IxAtmmPortCfg

Structure contains port—specific information required to initialize IxAtmm, and specifically, the IXP400 UTOPIA Level—2 device.

#### struct IxAtmmVc

This structure describes the required attributes of a virtual connection.

### **Defines**

#### #define IX ATMM RET ALREADY INITIALIZED

Component has already been initialized.

#### #define IX\_ATMM\_RET\_INVALID\_PORT

Specified port does not exist or is out of range.

#### #define IX\_ATMM\_RET\_INVALID\_VC\_DESCRIPTOR

The VC description does not adhere to ATM standards.

#### #define IX ATMM RET VC CONFLICT

The VPI/VCI values supplied are either reserved, or they conflict with a previously registered VC on this port.

#### #define IX\_ATMM\_RET\_PORT\_CAPACITY\_IS\_FULL

The virtual connection cannot be established on the port because the remaining port capacity is not sufficient to support it.

#### #define IX ATMM RET NO SUCH VC

No registered VC, as described by the supplied VCI/VPI or VC identifier values, exists on this port.

#### #define IX\_ATMM\_RET\_INVALID\_VC\_ID

The specified VC identifier is out of range.

#### #define IX ATMM RET INVALID PARAM PTR

A pointer parameter was NULL.

#### #define IX\_ATMM\_UTOPIA\_SPHY\_ADDR

The phy address when in SPHY mode.

#### #define IX ATMM THREAD PRI HIGH

The value of high priority thread.

### **Typedefs**

typedef void(\* IxAtmmVcChangeCallback )(IxAtmmVcChangeEvent eventType, IxAtmLogicalPort port, const IxAtmmVc \*vcChanged)

Callback type used with **ixAtmmVcChangeCallbackRegister** interface Defines a callback type which will be used to notify registered users of registration/deregistration events on a particular port.

### **Enumerations**

```
enum IxAtmmVcDirection {
      IX_ATMM_VC_DIRECTION_TX,
      IX_ATMM_VC_DIRECTION_RX,
      IX_ATMM_VC_DIRECTION_INVALID
     Definition for use in the IxAtmmVc structure. Indicates the direction of a VC.
enum IxAtmmVcChangeEvent {
      IX_ATMM_VC_CHANGE_EVENT_REGISTER,
      IX_ATMM_VC_CHANGE_EVENT_DEREGISTER,
      IX_ATMM_VC_CHANGE_EVENT_INVALID
     Definition for use with IxAtmmVcChangeCallback callback. Indicates that the event type
     represented by the callback for this VC.
enum IxAtmmUtopiaLoopbackMode {
      IX_ATMM_UTOPIA_LOOPBACK_DISABLED,
      IX_ATMM_UTOPIA_LOOPBACK_ENABLED,
      IX_ATMM_UTOPIA_LOOPBACK_INVALID
     Definitions for use with interface to indicate that UTOPIA loopback should be enabled or
     disabled on initialisation.
enum IxAtmmPhyMode {
      IX_ATMM_MPHY_MODE,
      IX_ATMM_SPHY_MODE,
      IX_ATMM_PHY_MODE_INVALID
     Definitions for use with ixAtmmUtopiaInit interface to indicate that UTOPIA
```

Typedefs 61

multi-phy/single-phy mode is used.

### **Functions**

**PUBLIC** 

#### IX\_STATUS ixAtmmInit (void)

*Interface to initialize the IxAtmm software component. Can be called once only.* 

**PUBLIC** 

#### IX\_STATUS ixAtmmUninit (void)

Interface to uninitialize the IxAtmm software component. This function deallocates/destroys the allocated buffer/Mutex done during initialization Should be the last function to be called.

## PUBLICixAtmmUtopiaInit (unsigned numPorts, IxAtmmPhyMode phyMode, IxAtmmPortCfg IX\_STATUS portCfgs[], IxAtmmUtopiaLoopbackMode loopbackMode)

Interface to initialize the UTOPIA Level-2 ATM coprocessor for the specified number of physical ports. The function must be called before the ixAtmmPortInitialize interface can operate successfully.

**PUBLIC** 

#### IX\_STATUS ixAtmmUtopiaUninit (void)

Interface to uninitialize the UTOPIA Level-2 ATM coprocessor.

**PUBLIC** 

IX\_STATUS **ixAtmmPortInitialize** (**IxAtmLogicalPort** port, unsigned txPortRate, unsigned rxPortRate)

The interface is called following **ixAtmmUtopiaInit** () and before calls to any other IxAtmm interface. It serves to activate the registered ATM port with IxAtmm.

**PUBLIC** 

#### IX\_STATUS ixAtmmPortUninitialize (IxAtmLogicalPort port)

It serves to uninitialise the respective port passed as a parameter. Excutes only if Utopia Intialization is done. Uninitializes the Data Path. Unintializes the specified port.

**PUBLIC** 

IX\_STATUS **ixAtmmPortModify** (**IxAtmLogicalPort** port, unsigned txPortRate, unsigned rxPortRate)

A client may call this interface to change the existing port rate (expressed in bits/second) on an established ATM port.

**PUBLIC** 

IX\_STATUS **ixAtmmPortQuery** (**IxAtmLogicalPort** port, unsigned \*txPortRate, unsigned \*rxPortRate)

The client may call this interface to request details on currently registered transmit and receive rates for an ATM port.

**PUBLIC** 

#### IX\_STATUS ixAtmmPortEnable (IxAtmLogicalPort port)

The client call this interface to enable transmit for an ATM port. At initialisation, all the ports are disabled.

**PUBLIC** 

#### IX\_STATUS ixAtmmPortDisable (IxAtmLogicalPort port)

The client call this interface to disable transmit for an ATM port. At initialisation, all the ports are disabled.

Functions 62

#### PUBLICixAtmmVcRegister (IxAtmLogicalPort port, IxAtmmVc \*vcToAdd,

#### IX\_STATUS **IxAtmSchedulerVcId** \*vcId)

This interface is used to register an ATM Virtual Connection on the specified ATM port.

**PUBLIC** 

#### IX\_STATUS ixAtmmVcDeregister (IxAtmLogicalPort port, IxAtmSchedulerVcId vcId)

Function called by a client to deregister a VC from the system.

#### PUBLICixAtmmVcQuery (IxAtmLogicalPort port, unsigned vpi, unsigned vci,

#### IX\_STATUS IxAtmmVcDirection direction, IxAtmSchedulerVcId \*vcId, IxAtmmVc \*vcDesc)

This interface supplies information about an active VC on a particular port when supplied with the VPI, VCI and direction of that VC.

## PUBLICixAtmmVcIdQuery (IxAtmLogicalPort port, IxAtmSchedulerVcId vcId, IxAtmmVc IX STATUS \*vcDesc)

This interface supplies information about an active VC on a particular port when supplied with a vcId for that VC.

**PUBLIC** 

#### IX\_STATUS ixAtmmVcChangeCallbackRegister (IxAtmmVcChangeCallback callback)

This interface is invoked to supply a function to IxAtmm which will be called to notify the client if a new VC is registered with IxAtmm or an existing VC is removed.

**PUBLIC** 

#### IX\_STATUS ixAtmmVcChangeCallbackDeregister (IxAtmmVcChangeCallback callback)

This interface is invoked to deregister a previously supplied callback function.

**PUBLIC** 

#### IX\_STATUS ixAtmmUtopiaStatusShow (void)

Display utopia status counters.

**PUBLIC** 

#### IX STATUS ixAtmmUtopiaCfgShow (void)

Display utopia information(config registers and status registers).

### **Detailed Description**

IXP400 ATM Manager component Public API.

### **Define Documentation**

#### #define IX\_ATMM\_RET\_ALREADY\_INITIALIZED

Component has already been initialized.

Definition at line 40 of file **IxAtmm.h**.

Detailed Description 63

#### #define IX ATMM RET INVALID PARAM PTR

A pointer parameter was NULL.

Definition at line **86** of file **IxAtmm.h**.

#### #define IX\_ATMM\_RET\_INVALID\_PORT

Specified port does not exist or is out of range.

Definition at line 46 of file IxAtmm.h.

#### #define IX\_ATMM\_RET\_INVALID\_VC\_DESCRIPTOR

The VC description does not adhere to ATM standards.

Definition at line **52** of file **IxAtmm.h**.

#### #define IX\_ATMM\_RET\_INVALID\_VC\_ID

The specified VC identifier is out of range.

Definition at line 80 of file IxAtmm.h.

#### #define IX\_ATMM\_RET\_NO\_SUCH\_VC

No registered VC, as described by the supplied VCI/VPI or VC identifier values, exists on this port.

Definition at line **74** of file **IxAtmm.h**.

#### #define IX\_ATMM\_RET\_PORT\_CAPACITY\_IS\_FULL

The virtual connection cannot be established on the port because the remaining port capacity is not sufficient to support it.

Definition at line **67** of file **IxAtmm.h**.

#### #define IX\_ATMM\_RET\_VC\_CONFLICT

The VPI/VCI values supplied are either reserved, or they conflict with a previously registered VC on this port.

Detailed Description 64

Definition at line **59** of file **IxAtmm.h**.

#### #define IX\_ATMM\_THREAD\_PRI\_HIGH

The value of high priority thread.

Definition at line 98 of file IxAtmm.h.

#### #define IX\_ATMM\_UTOPIA\_SPHY\_ADDR

The phy address when in SPHY mode.

Definition at line 92 of file IxAtmm.h.

### **Typedef Documentation**

typedef void(\* IxAtmmVcChangeCallback)(IxAtmmVcChangeEvent eventType, IxAtmLogicalPort port, const IxAtmmVc\* vcChanged)

Callback type used with **ixAtmmVcChangeCallbackRegister** interface Defines a callback type which will be used to notify registered users of registration/deregistration events on a particular port.

#### Parameters:

supplied has been added or removed

port IxAtmLogicalPort [in] – Specifies the port on which the event has

occurred

vcChanged IxAtmmVc\* [in] – Pointer to a structure which gives details of the VC

which has been added or removed on the port

Definition at line **189** of file **IxAtmm.h**.

### **Enumeration Type Documentation**

#### enum IxAtmmPhyMode

Definitions for use with **ixAtmmUtopiaInit** interface to indicate that UTOPIA multi-phy/single-phy mode is used.

#### **Enumeration values:**

IX\_ATMM\_MPHY\_MODE Atmm phy mode mphy.IX\_ATMM\_SPHY\_MODE Atmm phy mode sphy.IX\_ATMM\_PHY\_MODE\_INVALID Atmm phy mode invalid.

Definition at line 150 of file IxAtmm.h.

#### enum IxAtmmUtopiaLoopbackMode

Definitions for use with interface to indicate that UTOPIA loopback should be enabled or disabled on initialisation.

#### **Enumeration values:**

```
IX_ATMM_UTOPIA_LOOPBACK_DISABLED Atmm Utopia loopback mode disabled.IX_ATMM_UTOPIA_LOOPBACK_ENABLED Atmm Utopia loopback mode enabled.IX_ATMM_UTOPIA_LOOPBACK_INVALID Atmm Utopia loopback mode invalid.
```

Definition at line 126 of file IxAtmm.h.

#### enum IxAtmmVcChangeEvent

Definition for use with **IxAtmmVcChangeCallback** callback. Indicates that the event type represented by the callback for this VC.

#### **Enumeration values:**

```
IX_ATMM_VC_CHANGE_EVENT_REGISTER Atmm Vc event register.

IX_ATMM_VC_CHANGE_EVENT_DEREGISTER Atmm Vc event de-register.

IX_ATMM_VC_CHANGE_EVENT_INVALID Atmm Vc event invalid.
```

Definition at line 116 of file IxAtmm.h.

#### enum IxAtmmVcDirection

Definition for use in the **IxAtmmVc** structure. Indicates the direction of a VC.

#### **Enumeration values:**

```
IX_ATMM_VC_DIRECTION_TX Atmm Vc direction transmit.

IX_ATMM_VC_DIRECTION_RX Atmm Vc direction receive.

IX_ATMM_VC_DIRECTION_INVALID Atmm Vc direction invalid.
```

Definition at line **106** of file **IxAtmm.h**.

### **Function Documentation**

```
ixAtmmInit (void )
```

Interface to initialize the IxAtmm software component. Can be called once only.

Must be called before any other IxAtmm API is called.

#### Parameters:

none

#### Returns:

- ♦ IX\_SUCCESS : IxAtmm has been successfully initialized. Calls to other IxAtmm interfaces may now be performed.
- ♦ IX\_FAIL : IxAtmm has already been initialized.

#### ixAtmmPortDisable ( IxAtmLogicalPort port )

The client call this interface to disable transmit for an ATM port. At initialisation, all the ports are disabled.

#### Parameters:

port IxAtmLogicalPort [in] - Value identifies the port

#### Returns:

- ♦ IX\_SUCCESS : Transmission over this port is stopped.
- ♦ IX\_FAIL : The port parameter is not valid, or the port is already disabled

#### Note:

- When a port is disabled, Rx and Tx VC Connect requests will fail
- This function call does not stop RX traffic. It is supposed that this function is invoked when a serious problem is detected (e.g. physical layer broken). Then, the RX traffic is not passing.
- This function is blocking until the hw acknowledge that the transmission is stopped.
- This function uses system resources and should not be used inside an interrupt context.

#### See also:

#### **ixAtmmPortEnable**

#### ixAtmmPortEnable ( **IxAtmLogicalPort** port )

The client call this interface to enable transmit for an ATM port. At initialisation, all the ports are disabled.

#### Parameters:

port **IxAtmLogicalPort** [in] – Value identifies the port

#### Returns:

- ♦ IX\_SUCCESS : Transmission over this port is started.
- ♦ IX\_FAIL : The port parameter is not valid, or the port is already enabled

#### Note:

- When a port is disabled, Rx and Tx VC Connect requests will fail

- This function uses system resources and should not be used inside an interrupt context.

#### See also:

#### **ixAtmmPortDisable**

```
ixAtmmPortInitialize ( IxAtmLogicalPort port, unsigned txPortRate, unsigned rxPortRate
```

The interface is called following **ixAtmmUtopiaInit** () and before calls to any other IxAtmm interface. It serves to activate the registered ATM port with IxAtmm.

The transmit and receive port rates are specified in bits per second. This translates to ATM cells per second according to the following formula: CellsPerSecond = portRate / (53\*8) The IXP400 device supports only 53 byte cells. The client shall make sure that the off-chip physical layer device has already been initialized.

IxAtmm will configure IxAtmdAcc and IxAtmSch to enable scheduling on the port.

This interface must be called once for each active port in the system. The first time the interface is invoked, it will configure the mechanism by which the handling of transmit, transmit—done and receive are driven with the IxAtmdAcc component.

This function is reentrant.

#### Note:

The minimum tx rate that will be accepted is 424 bit/s which equates to 1 cell (53 bytes) per second.

#### Parameters:

port **IxAtmLogicalPort** [in] – Identifies the port which is to be initialized.

*txPortRate* unsigned [in] – Value specifies the transmit port rate for this port in bits/second. This value is used by the ATM Scheduler component is evaluating VC access requests for the port.

rxPortRate unsigned [in] – Value specifies the receive port rate for this port in bits/second.

#### Returns:

- ♦ IX\_SUCCESS: The specificed ATM port has been successfully initialized. IxAtmm is ready to accept VC registrations on this port.
- ♦ IX\_ATMM\_RET\_ALREADY\_INITIALIZED : ixAtmmPortInitialize has already been called successfully on this port. The current call is rejected.
- ♦ IX\_ATMM\_RET\_INVALID\_PORT : The port value indicated in the input is not valid. The request is rejected.
- ♦ IX\_FAIL : IxAtmm could not initialize the port because the inputs are not understood.

#### See also:

#### ixAtmmPortEnable, ixAtmmPortDisable

```
ixAtmmPortModify ( IxAtmLogicalPort port, unsigned txPortRate, unsigned rxPortRate )
```

A client may call this interface to change the existing port rate (expressed in bits/second) on an established ATM port.

#### Parameters:

port **IxAtmLogicalPort** [in] – Identifies the port which is to be initialized.

*txPortRate* unsigned [in] – Value specifies the`` transmit port rate for this port in bits/second. This value is used by the ATM Scheduler component is evaluating VC access requests for the port.

rxPortRate unsigned [in] – Value specifies the receive port rate for this port in bits/second.

#### Returns:

- ♦ IX\_SUCCESS : The indicated ATM port rates have been successfully modified.
- ♦ IX\_ATMM\_RET\_INVALID\_PORT : The port value indicated in the input is not valid. The request is rejected.
- ♦ IX\_FAIL : IxAtmm could not update the port because the inputs are not understood, or the interface was called before the port was initialized.

```
ixAtmmPortQuery ( IxAtmLogicalPort port, unsigned * txPortRate, unsigned * rxPortRate
```

The client may call this interface to request details on currently registered transmit and receive rates for an ATM port.

#### Parameters:

port **IxAtmLogicalPort** [in] – Value identifies the port from which the rate details are requested.

\*txPortRate unsigned [out] – Pointer to a value which will be filled with the value of the transmit port rate specified in bits/second.

\*rxPortRate unsigned [out] – Pointer to a value which will be filled with the value of the receive port rate specified in bits/second.

#### Returns:

- ♦ IX\_SUCCESS : The information requested on the specified port has been successfully supplied in the output.
- ♦ IX\_ATMM\_RET\_INVALID\_PORT : The port value indicated in the input is not valid. The request is rejected.

- ♦ IX\_ATMM\_RET\_INVALID\_PARAM\_PTR : A pointer parameter was NULL.
- ♦ IX\_FAIL : IxAtmm could not update the port because the inputs are not understood, or the interface was called before the port was initialized.

#### ixAtmmPortUninitialize ( IxAtmLogicalPort port )

It serves to uninitialise the respective port passed as a parameter. Excutes only if Utopia Intialization is done. Uninitializes the Data Path. Unintializes the specified port.

#### Parameters:

port **IxAtmLogicalPort** [in] – Identifies the port which is to be uninitialized.

#### Returns:

- ♦ IX\_SUCCESS : The specificed ATM port has been successfully uninitialized.
- ♦ IX\_FAIL : IxAtmm could not uninitialize the port because the inputs are not understood or because of some other internal error.

#### ixAtmmUninit (void)

Interface to uninitialize the IxAtmm software component. This function deallocates/destroys the allocated buffer/Mutex done during initialization Should be the last function to be called.

#### Parameters:

none

#### Returns:

- ♦ IX\_SUCCESS: IxAtmm has been successfully uninitialized. Calls to other IxAtmm interfaces cannot be performed after this.
- ♦ IX\_FAIL : IxAtmm has already been uninitialized.

#### ixAtmmUtopiaCfgShow (void)

Display utopia information(config registers and status registers).

#### Parameters:

none

#### Returns:

♦ IX\_SUCCESS : Show function was successful

◊ IX FAIL : Internal failure

Interface to initialize the UTOPIA Level–2 ATM coprocessor for the specified number of physical ports. The function must be called before the ixAtmmPortInitialize interface can operate successfully.

#### Parameters:

numPorts unsigned [in] – Indicates the total number of logical ports that are active on the

device. Up to 12 ports are supported.

phyMode [in] – Put the Utopia coprocessor in SPHY or MPHY mode.portCfgs[]IxAtmmPortCfg [in] – Pointer to an array of elements detailing the UTOPIA

specific port characteristics. The length of the array must be equal to the number of ports activated. ATM ports are referred to by the relevant offset in this array in all

subsequent IxAtmm interface calls.

loopbackMode [in] - Value must be one of

IX\_ATMM\_UTOPIA\_LOOPBACK\_ENABLED or

**IX\_ATMM\_UTOPIA\_LOOPBACK\_DISABLED** indicating whether loopback should be enabled on the device. Loopback can only be supported on a single PHY, therefore the numPorts parameter must be 1 if loopback is enabled.

#### Returns:

- ♦ IX\_SUCCESS : Indicates that the UTOPIA device has been successfully initialized for the supplied ports.
- ♦ IX\_ATMM\_RET\_ALREADY\_INITIALIZED : The UTOPIA device has already been initialized.
- ♦ IX\_FAIL : The supplied parameters are invalid or have been rejected by the UTOPIA–NPE device.

#### Warning:

This interface may only be called once. Port identifiers are assumed to range from 0 to (numPorts – 1) in all instances. In all subsequent calls to interfaces supplied by IxAtmm, the specified port value is expected to represent the offset in the portCfgs array specified in this interface. i.e. The first port in this array will subsequently be represented as port 0, the second port as port 1, and so on.

#### ixAtmmUtopiaStatusShow (void )

Display utopia status counters.

#### Parameters:

none

#### Returns:

♦ IX\_SUCCESS : Show function

was successful

#### ◊ IX FAIL : Internal failure

#### ixAtmmUtopiaUninit (void)

Interface to uninitialize the UTOPIA Level-2 ATM coprocessor.

#### Parameters:

none

#### Returns:

♦ IX\_SUCCESS : Indicates that the UTOPIA device has been successfully uninitialized .

♦ IX FAIL :Uninitialise of the UTOPIA–NPE device did not work.

#### ixAtmmVcChangeCallbackDeregister ( IxAtmmVcChangeCallback callback )

This interface is invoked to deregister a previously supplied callback function.

#### Parameters:

callback IxAtmmVcChangeCallback [in] – Callback which complies with the IxAtmmVcChangeCallback definition. This function will removed from the table of callbacks.

#### Returns:

♦ IX\_SUCCESS : The specified callback has been deregistered successfully from IxAtmm.

♦ IX\_FAIL : Either the supplied callback is invalid, or is not currently registered with IxAtmm.

#### ixAtmmVcChangeCallbackRegister ( **IxAtmmVcChangeCallback** callback )

This interface is invoked to supply a function to IxAtmm which will be called to notify the client if a new VC is registered with IxAtmm or an existing VC is removed.

The callback, when invoked, will run within the context of the call to **ixAtmmVcRegister** or **ixAtmmVcDeregister** which caused the change of state.

A maximum of 32 calbacks may be registered in with IxAtmm.

#### Parameters:

callback IxAtmmVcChangeCallback [in] – Callback which complies with the IxAtmmVcChangeCallback definition. This function will be invoked by IxAtmm with the appropriate parameters for the relevant VC when any VC has been registered or deregistered with IxAtmm.

#### Returns:

- ♦ IX\_SUCCESS: The specified callback has been registered successfully with IxAtmm and will be invoked when appropriate.
- ♦ IX\_FAIL : Either the supplied callback is invalid, or IxAtmm has already registered 32 and connot accommodate any further registrations of this type. The request is rejected.

#### Warning:

The client must not call either the **ixAtmmVcRegister** or **ixAtmmVcDeregister** interfaces from within the supplied callback function.

```
ixAtmmVcDeregister ( IxAtmLogicalPort port, IxAtmSchedulerVcId vcId )
```

Function called by a client to deregister a VC from the system.

With the removal of each new VC from a port, a series of registered callback functions are invoked by the IxAtmm component to notify possible external components of the change. The callback functions are registered using the **ixAtmmVcChangeCallbackRegister**.

The IxAtmSch component is notified of the removal of transmit VCs.

#### Parameters:

port IxAtmLogicalPort [in] – Identifies port on which the VC to be removed is currently registered.

vcId IxAtmSchedulerVcId [in] – VC identifier value of the VC to be deregistered. This value was supplied to the client when the VC was originally registered. This value can also be queried from the IxAtmm component through the ixAtmmVcQuery interface.

#### Returns:

- ♦ IX SUCCESS: The specified VC has been successfully removed from this port.
- ♦ IX\_ATMM\_RET\_INVALID\_PORT : The port value indicated in the input is not valid or has not been initialized. The request is rejected.
- ♦ IX\_FAIL : There is no registered VC associated with the supplied identifier registered on this port.

This interface supplies information about an active VC on a particular port when supplied with a vcId for that VC.

#### Parameters:

port

**IxAtmLogicalPort** [in] – Identifies port on which the VC to be queried is currently registered.

*vcId* **IxAtmSchedulerVcId** [in] – Value returned by **ixAtmmVcRegister** which uniquely identifies the requested VC on this port.

\*vcDesc **IxAtmmVc** [out] – Pointer to an **IxAtmmVc** structure which will be filled with the specific details of the requested VC, if it exists on this port.

#### Returns:

- ♦ IX\_SUCCESS: The specified VC has been found on this port and the requested details have been returned.
- ♦ IX\_ATMM\_RET\_INVALID\_PORT : The port value indicated in the input is not valid or has not been initialized. The request is rejected.
- ♦ IX\_ATMM\_RET\_NO\_SUCH\_VC : No VC exists on the specified port which matches the supplied identifier. No data is returned.
- ♦ IX\_ATMM\_RET\_INVALID\_PARAM\_PTR : A pointer parameter was NULL.

This interface supplies information about an active VC on a particular port when supplied with the VPI, VCI and direction of that VC.

#### Parameters:

*port* **IxAtmLogicalPort** [in] – Identifies port on which the VC to be queried is currently registered.

*vpi* unsigned [in] – ATM VPI value of the requested VC.

vci unsigned [in] – ATM VCI value of the requested VC.

direction **IxAtmmVcDirection** [in] – One of **IX\_ATMM\_VC\_DIRECTION\_TX** or **IX\_ATMM\_VC\_DIRECTION\_RX** indicating the direction (Tx or Rx) of the requested VC.

\*vcId **IxAtmSchedulerVcId** [out] – Pointer to an integer value which will be filled with the VC identifier value for the requested VC (as returned by **ixAtmmVcRegister**), if it exists on this port.

\*vcDesc **IxAtmmVc** [out] – Pointer to an **IxAtmmVc** structure which will be filled with the specific details of the requested VC, if it exists on this port.

#### Returns:

♦ IX\_SUCCESS: The specified VC has been found on this port and the requested details have been returned.

74

- ♦ IX\_ATMM\_RET\_INVALID\_PORT : The port value indicated in the input is not valid or has not been initialized. The request is rejected.
- ♦ IX\_ATMM\_RET\_NO\_SUCH\_VC : No VC exists on the specified port which matches the search criteria (VPI, VCI, direction) given. No data is returned.
- ♦ IX\_ATMM\_RET\_INVALID\_PARAM\_PTR : A pointer parameter was NULL.

This interface is used to register an ATM Virtual Connection on the specified ATM port.

Each call to this interface registers a unidirectional virtual connection with the parameters specified. If a bi-directional VC is needed, the function should be called twice (once for each direction, Tx & Rx) where the VPI and VCI and port parameters in each call are identical.

With the addition of each new VC to a port, a series of callback functions are invoked by the IxAtmm component to notify possible external components of the change. The callback functions are registered using the **ixAtmmVcChangeCallbackRegister** interface.

The IxAtmSch component is notified of the registration of transmit VCs.

#### Parameters:

IxAtmLogicalPort [in] – Identifies port on which the specified VC is to be registered.
 \*vcToAdd IxAtmmVc [in] – Pointer to an IxAtmmVc structure containing a description of the VC to be registered. The client shall fill the vpi, vci and direction and relevant trafficDesc members of this structure before calling this function.

\*vcId **IxAtmSchedulerVcId** [out] – Pointer to an integer value which is filled with the per–port unique identifier value for this VC. This identifier will be required when a request is made to deregister or change this VC. VC identifiers for transmit VCs will have a value between 0–43, i.e. 32 data Tx VCs + 12 OAM Tx Port VCs. Receive VCs will have a value between 44–66, i.e. 32 data Rx VCs + 1 OAM Rx VC.

#### Returns:

- ♦ IX\_SUCCESS: The VC has been successfully registered on this port. The VC is ready for a client to configure IxAtmdAcc for receive and transmit operations on the VC.
- ♦ IX\_ATMM\_RET\_INVALID\_PORT : The port value indicated in the input is not valid or has not been initialized. The request is rejected.
- ♦ IX\_ATMM\_RET\_INVALID\_VC\_DESCRIPTOR : The descriptor pointed to by vcToAdd is invalid. The registration request is rejected.
- ♦ IX\_ATMM\_RET\_VC\_CONFLICT : The VC requested conflicts with reserved VPI and/or VCI values or with another VC already activated on this port.

- ♦ IX\_ATMM\_RET\_PORT\_CAPACITY\_IS\_FULL : The VC cannot be registered in the port becuase the port capacity is insufficient to support the requested ATM traffic contract. The registration request is rejected.
- ♦ IX\_ATMM\_RET\_INVALID\_PARAM\_PTR : A pointer parameter was NULL.

#### Warning:

IxAtmm has no capability of signaling or negotiating a virtual connection. Negotiation of the admission of the VC to the network is beyond the scope of this function. This is assumed to be performed by the calling client, if appropriate, before or after this function is called.

# Intel (R) IXP400 Software ATM Transmit Scheduler (IxAtmSch) API

IXP400 ATM scheduler component Public API.

### **Defines**

#### #define IX ATMSCH RET NOT ADMITTED

Indicates that CAC function has rejected VC registration due to insufficient line capacity.

#### #define IX ATMSCH RET QUEUE FULL

Indicates that the VC queue is full, no more demand can be queued at this time.

#### #define IX ATMSCH RET QUEUE EMPTY

Indicates that all VC queues on this port are empty and therefore there are no cells to be scheduled at this time.

### **Functions**

**PUBLIC** 

#### IX STATUS ixAtmSchInit (void)

This function is used to initialize the ixAtmSch component. It should be called before any other IxAtmSch API function.

**PUBLIC** 

#### IX STATUS ixAtmSchUninit (void)

This function is used to uninitialize the ixAtmSch component.

## PUBLICixAtmSchPortModelInitialize (IxAtmLogicalPort port, unsigned int portRate, unsigned int IX\_STATUS minCellsToSchedule)

This function shall be called first to initialize an ATM port before any other ixAtmSch API calls may be made for that port.

**PUBLIC** 

#### IX\_STATUS ixAtmSchPortModelUninitialize (IxAtmLogicalPort port)

This function shall be called to uninitialize an ATM port.

**PUBLIC** 

#### IX STATUS ixAtmSchPortRateModify (IxAtmLogicalPort port, unsigned int portRate)

This function is called to modify the portRate on a previously initialized port, typically in the event that the line condition of the port changes.

## $PUBLIC ix Atm Sch Vc Model Setup \ (Ix Atm Logical Port \ port, Ix Atm Traffic Descriptor \ *traffic Descrip$

A client calls this interface to set up an upstream (transmitting) virtual connection model (VC) on the specified ATM port. This function also provides the virtual \* connection

admission control (CAC) service to the client.

### PUBLICixAtmSchVcConnIdSet (IxAtmLogicalPort port, IxAtmSchedulerVcId vcId,

IX\_STATUS IxAtmConnId vcUserConnId)

A client calls this interface to set the vcUserConnId for a VC on the specified ATM port. This vcUserConnId will default to IX\_ATM\_IDLE\_CELLS\_CONNID if this function is not called for a VC. Hence if the client does not call this function for a VC then only idle cells will be scheduled for this VC.

#### **PUBLIC**

#### IX\_STATUS ixAtmSchVcModelRemove (IxAtmLogicalPort port, IxAtmSchedulerVcId vcId)

Interface called by the client to remove a previously established VC on a particular port.

## PUBLICixAtmSchVcQueueUpdate (IxAtmLogicalPort port, IxAtmSchedulerVcId vcId, unsigned IX STATUS int numberOfCells)

The client calls this function to notify IxAtmSch that the user of a VC has submitted cells for transmission.

#### **PUBLIC**

#### IX\_STATUS ixAtmSchVcQueueClear (IxAtmLogicalPort port, IxAtmSchedulerVcId vcId)

The client calls this function to remove all currently queued cells from a registered VC. The pending cell count for the specified VC is reset to zero.

#### PUBLICixAtmSchTableUpdate (IxAtmLogicalPort port, unsigned int maxCells,

#### IX\_STATUS **IxAtmScheduleTable** \*\*rettable)

The client calls this function to request an update of the schedule table for a particular ATM port.

#### PUBLIC void ixAtmSchShow (void)

Utility function which will print statistics on the current and accumulated state of VCs and traffic in the ATM scheduler component. Output is sent to the default output device.

#### PUBLIC void ixAtmSchStatsClear (void)

Utility function which will reset all counter statistics in the ATM scheduler to zero.

### **Detailed Description**

IXP400 ATM scheduler component Public API.

### **Define Documentation**

#### #define IX\_ATMSCH\_RET\_NOT\_ADMITTED

Indicates that CAC function has rejected VC registration due to insufficient line capacity.

Definition at line **52** of file **IxAtmSch.h**.

Detailed Description 78

#### #define IX ATMSCH RET QUEUE EMPTY

Indicates that all VC queues on this port are empty and therefore there are no cells to be scheduled at this time.

Definition at line 70 of file IxAtmSch.h.

#### #define IX\_ATMSCH\_RET\_QUEUE\_FULL

Indicates that the VC queue is full, no more demand can be queued at this time.

Definition at line **61** of file **IxAtmSch.h**.

### **Function Documentation**

```
ixAtmSchInit (void)
```

This function is used to initialize the ixAtmSch component. It should be called before any other IxAtmSch API function.

#### Parameters:

None

#### Returns:

- **♦ IX SUCCESS:** indicates that
  - 1. The ATM scheduler component has been successfully initialized.
  - 2. The scheduler is ready to accept Port modelling requests.
- ♦ **IX\_FAIL**: Some internal error has prevented the scheduler component from initialising.

```
ixAtmSchPortModelInitialize ( IxAtmLogicalPort port,
                              unsigned int
                                                 portRate.
                              unsigned int
                                                 minCellsToSchedule
```

This function shall be called first to initialize an ATM port before any other ixAtmSch API calls may be made for that port.

#### Parameters:

**IxAtmLogicalPort** [in] – The specific port to initialize. Valid values range port

from 0 to IX\_UTOPIA\_MAX\_PORTS – 1, representing a maximum of

IX\_UTOPIA\_MAX\_PORTS possible ports.

unsigned int [in] – Value indicating the upstream capacity of the indicated portRate

port. The value should be supplied in units of ATM (53 bytes) cells per

second. A port rate of 800Kbits/s is the equivalent of 1886 cells per second

minCellsToSchedule unsigned int [in] - This parameter specifies the minimum number of cells

which the scheduler will put in a schedule table for this port. This value sets the worst case CDVT for VCs on this port i.e. CDVT = 1\*minCellsToSchedule/portRate.

#### Returns:

**◊ IX SUCCESS :** indicates that

- 1. The ATM scheduler has been successfully initialized.
- 2. The requested port model has been established.
- 3. The scheduler is ready to accept VC modelling requests on the ATM port.
- ♦ **IX\_FAIL** : indicates the requested port could not be initialized.

#### ixAtmSchPortModelUninitialize ( **IxAtmLogicalPort** port )

This function shall be called to uninitialize an ATM port.

#### Parameters:

port IxAtmLogicalPort [in] – The specific port to uninitialize. Valid values range from 0 to IX\_UTOPIA\_MAX\_PORTS – 1, representing a maximum of IX\_UTOPIA\_MAX\_PORTS possible ports.

#### Returns:

```
    ♦ IX_SUCCESS: indicates that
    1. The ATM scheduler has been successfully uninitialized.
    ♦ IX FAIL: indicates the requested port could not be uninitialized.
```

```
ixAtmSchPortRateModify ( IxAtmLogicalPort port, unsigned int portRate )
```

This function is called to modify the portRate on a previously initialized port, typically in the event that the line condition of the port changes.

#### Parameters:

```
    port IxAtmLogicalPort [in] – Specifies the ATM port which is to be modified.
    portRate unsigned int [in] – Value indicating the new upstream capacity for this port in cells/second. A port rate of 800Kbits/s is the equivalent of 1886 cells per second
```

#### Returns:

- ♦ **IX\_SUCCESS**: The port rate has been successfully modified.
- ♦ **IX\_FAIL**: The port rate could not be modified, either because the input data was invalid, or the new port rate is insufficient to support established ATM VC contracts on this port.

#### Warning:

The IxAtmSch component will validate the supplied port rate is sufficient to support all established VC contracts on the port. If the new port rate is insufficient to support all established contracts then the request to modify the port rate will be rejected. In this event, the user is expected to remove established contracts using the ixAtmSchVcModelRemove interface and then retry this interface.

#### See also:

#### ixAtmSchVcModelRemove()

```
ixAtmSchShow (void)
```

Utility function which will print statistics on the current and accumulated state of VCs and traffic in the ATM scheduler component. Output is sent to the default output device.

#### Parameters:

none

#### Returns:

none

```
ixAtmSchStatsClear (void)
```

Utility function which will reset all counter statistics in the ATM scheduler to zero.

#### Parameters:

none

#### Returns:

none

```
ixAtmSchTableUpdate ( IxAtmLogicalPort port, unsigned int maxCells, IxAtmScheduleTable ** rettable
```

The client calls this function to request an update of the schedule table for a particular ATM port.

This is called when the client decides it needs a new sequence of cells to send (probably because the transmit queue is near to empty for this ATM port). The scheduler will use its stored information on the cells submitted for transmit (i.e. data supplied via <code>ixAtmSchVcQueueUpdate</code> function) with the traffic descriptor information of all established VCs on the ATM port to decide the sequence of cells to be sent and fill the schedule table for a period of time into the future.

IxAtmSch will guarantee a minimum of minCellsToSchedule if there is at least one cell ready to send. If there are no cells then IX\_ATMSCH\_RET\_QUEUE\_EMPTY is returned.

This implementation of ixAtmSchTableUpdate uses no operating system or external facilities, either directly or indirectly. This allows clients to call this function form within an FIQ interrupt handler.

#### Parameters:

```
port IxAtmLogicalPort [in] – Specifies the ATM port for which requested schedule table is to be generated.
```

*maxCells* 

unsigned [in] – Specifies the maximum number of cells that must be scheduled in the supplied table during any call to the interface.

\*\*table

**IxAtmScheduleTable** [out] – A pointer to an area of storage is returned which contains the generated schedule table. The client should not modify the contents of this table.

#### Returns:

- ♦ **IX\_SUCCESS**: The schedule table has been published. Currently there is at least one VC queue that is nonempty.
- ♦ IX\_ATMSCH\_RET\_QUEUE\_EMPTY: Currently all VC queues on this port are empty. The schedule table returned is set to NULL. The client is not expected to invoke this function again until more cells have been submitted on this port through the ixAtmSchVcQueueUpdate function.
- ♦ **IX\_FAIL**: The input are invalid. No action is taken.

#### Warning:

IxAtmSch assumes that the calling software ensures that calls to ixAtmSchVcQueueUpdate, ixAtmSchVcQueueClear and ixAtmSchTableUpdate are both self and mutually exclusive for the same port.

Subsequent calls to this function for the same port will overwrite the contents of previously supplied schedule tables. The client must be completely finished with the previously supplied schedule table before calling this function again for the same port.

#### See also:

ixAtmSchVcQueueUpdate(), ixAtmSchVcQueueClear(), ixAtmSchTableUpdate().

#### ixAtmSchUninit (void)

This function is used to uninitialize the ixAtmSch component.

#### Parameters:

None

#### Returns:

- **◊ IX SUCCESS:** indicates that
  - 1. The ATM scheduler component has been successfully uninitialized.
- ♦ **IX\_FAIL**: Some internal error has prevented the scheduler component from uninitialising.

A client calls this interface to set the vcUserConnId for a VC on the specified ATM port. This vcUserConnId will default to IX\_ATM\_IDLE\_CELLS\_CONNID if this function is not called for a VC. Hence if the client does not call this function for a VC then only idle cells will be scheduled for this VC.

#### Parameters:

port **IxAtmLogicalPort** [in] – Specifies the ATM port on which the upstream VC is has

been established.

vcId **IxAtmSchedulerVcId** [in] – This is the unique identifier for this virtual connection.

A valid identification is a non–negative number and is all ports.

vcUserConnId IxAtmConnId [in] – The connId is used to refer to a VC in schedule table entries. It is treated as the Id by which the scheduler client knows the VC. It is used in any communicatations from the Scheduler to the scheduler user e.g. schedule table

entries.

#### Returns:

```
♦ IX_SUCCESS: The id has successfully been set.
```

♦ **IX\_FAIL**: Input data are invalid. connId id is not established.

Interface called by the client to remove a previously established VC on a particular port.

#### Parameters:

port IxAtmLogicalPort [in] – Specifies the ATM port on which the VC to be removed is established.

*vcId* **IxAtmSchedulerVcId** [in] – Identifies the VC to be removed. This is the value returned by the **ixAtmSchVcModelSetup** call which established the relevant VC.

#### Returns:

- ◊ IX\_SUCCESS: The VC has been successfully removed from this port. It is no longer modelled on this port.
- ♦ **IX\_FAIL**: Input data are invalid. The VC is still being modeled by the traffic shaper.

#### See also:

ixAtmSchVcModelSetup()

A client calls this interface to set up an upstream (transmitting) virtual connection model (VC) on the specified ATM port. This function also provides the virtual \* connection admission control (CAC) service to the client.

#### Parameters:

*port* **IxAtmLogicalPort** [in] – Specifies the ATM port on which the upstream VC is to be established.

\*trafficDesc IxAtmTrafficDescriptor [in] – Pointer to a structure describing the requested traffic contract of the VC to be established. This structure contains the typical ATM traffic

#### Returns:

- ♦ **IX\_SUCCESS**: The VC has been successfully established on this port. The client may begin to submit demand on this VC.
- ♦ IX\_ATMSCH\_RET\_NOT\_ADMITTED: The VC cannot be established on this port because there is insufficient upstream capacity available to support the requested traffic contract descriptor
- ♦ **IX FAIL**: Input data are invalid. VC has not been established.

```
ixAtmSchVcQueueClear ( IxAtmLogicalPort port, IxAtmSchedulerVcId vcId )
```

The client calls this function to remove all currently queued cells from a registered VC. The pending cell count for the specified VC is reset to zero.

This interface is structurally compatible with the IxAtmdAccSchQueueClear callback type definition required for IXP400 ATM scheduler interoperability.

#### Parameters:

*port* **IxAtmLogicalPort** [in] – Specifies the ATM port on which the VC to be cleared is established.

*vcId* **IxAtmSchedulerVcId** [in] – Identifies the VC to be cleared. This is the value returned by the **ixAtmSchVcModelSetup** call which established the relevant VC.

#### Returns:

- $\Diamond$   $IX\_SUCCESS$  : The VC queue has been successfully cleared.
- ♦ **IX\_FAIL**: The input are invalid. No VC queue is modified.

#### Warning:

IxAtmSch assumes that the calling software ensures that calls to ixAtmSchVcQueueUpdate, ixAtmSchVcQueueClear and ixAtmSchTableUpdate are both self and mutually exclusive for the same port.

#### See also:

ixAtmSchVcQueueUpdate(), ixAtmSchVcQueueClear(), ixAtmSchTableUpdate().

The client calls this function to notify IxAtmSch that the user of a VC has submitted cells for transmission.

This information is stored, aggregated from a number of calls to ixAtmSchVcQueueUpdate and eventually used in the call to ixAtmSchTableUpdate.

Normally IxAtmSch will update the VC queue by adding the number of cells to the current queue length. However, if IxAtmSch determines that the user has over—submitted for the VC and exceeded its transmission quota the queue request can be rejected. The user should resubmit the request later when the queue has been depleted.

This implementation of ixAtmSchVcQueueUpdate uses no operating system or external facilities, either directly or indirectly. This allows clients to call this function form within an interrupt handler.

This interface is structurally compatible with the IxAtmdAccSchQueueUpdate callback type definition required for IXP400 ATM scheduler interoperability.

#### Parameters:

port IxAtmLogicalPort [in] – Specifies the ATM port on which the VC to be updated

is established.

vcId **IxAtmSchedulerVcId** [in] – Identifies the VC to be updated. This is the value

returned by the **ixAtmSchVcModelSetup** call which established the relevant VC.

numberOfCells unsigned int [in] – Indicates how many ATM cells should be added to the queue for this VC.

#### Returns:

- ♦ **IX\_SUCCESS**: The VC queue has been successfully updated.
- ♦ IX\_ATMSCH\_RET\_QUEUE\_FULL: The VC queue has reached a preset limit. This indicates the client has over—submitted and exceeded its transmission quota. The request is rejected. The VC queue is not updated. The VC user is advised to resubmit the request later.
- ♦ **IX\_FAIL**: The input are invalid. No VC queue is updated.

#### Warning:

IxAtmSch assumes that the calling software ensures that calls to ixAtmSchVcQueueUpdate, ixAtmSchVcQueueClear and ixAtmSchTableUpdate are both self and mutually exclusive for the same port.

#### See also:

ixAtmSchVcQueueUpdate(), ixAtmSchVcQueueClear(), ixAtmSchTableUpdate().

## Intel (R) IXP400 Software ATM Types (IxAtmTypes)

The common set of types used in many Atm components.

## **Data Structures**

### struct IxAtmScheduleTable

This structure defines a schedule table which gives details on which data (from which VCs) should be transmitted for a forthcoming period of time for a particular port and the order in which that data should be transmitted.

### struct IxAtmScheduleTableEntry

ATM Schedule Table entry.

### struct IxAtmTrafficDescriptor

Structure describing an ATM traffic contract for a Virtual Connection (VC).

## **Defines**

### #define IX\_ATM\_CELL\_PAYLOAD\_SIZE

Size of a ATM cell payload.

### #define IX\_ATM\_CELL\_SIZE

Size of a ATM cell, including header.

### #define IX\_ATM\_CELL\_SIZE\_NO\_HEC

Size of a ATM cell, excluding HEC byte.

### #define IX\_ATM\_OAM\_CELL\_SIZE\_NO\_HEC

Size of a OAM cell, excluding HEC byte.

### #define IX\_ATM\_AAL0\_48\_CELL\_PAYLOAD\_SIZE

Size of a AALO 48 Cell payload.

### #define IX\_ATM\_AAL5\_CELL\_PAYLOAD\_SIZE

Size of a AAL5 Cell payload.

### #define IX\_ATM\_AAL0\_52\_CELL\_SIZE\_NO\_HEC

Size of a AAL0 52 Cell, excluding HEC byte.

### #define IX ATM MAX VPI

Maximum value of an ATM VPI.

### #define IX\_ATM\_MAX\_VCI

Maximum value of an ATM VCI.

### #define IX\_ATM\_MAX\_NUM\_AAL\_VCS

Maximum number of active AAL5/AAL0 VCs in the system.

### #define IX ATM MAX NUM VC

Maximum number of active AAL5/AAL0 VCs in the system The use of this macro is depreciated, it is retained for backward compatibility. For current software release and beyond the define IX\_ATM\_MAX\_NUM\_AAL\_VC should be used.

### #define IX ATM MAX NUM OAM TX VCS

Maximum number of active OAM Tx VCs in the system, 1 OAM VC per port.

### #define IX ATM MAX NUM OAM RX VCS

Maximum number of active OAM Rx VCs in the system, 1 OAM VC shared accross all ports.

### #define IX ATM MAX NUM AAL OAM TX VCS

Maximum number of active AAL5/AAL0/OAM Tx VCs in the system.

### #define IX\_ATM\_MAX\_NUM\_AAL\_OAM\_RX\_VCS

Maximum number of active AAL5/AAL0/OAM Rx VCs in the system.

### #define IX ATM IDLE CELLS CONNID

VC Id used to indicate idle cells in the returned schedule table.

### #define **IX\_ATM\_CELL\_HEADER\_VCI\_GET**(cellHeader)

get the VCI field from a cell header

### #define IX\_ATM\_CELL\_HEADER\_VPI\_GET(cellHeader)

get the VPI field from a cell header

### #define **IX\_ATM\_CELL\_HEADER\_PTI\_GET**(cellHeader)

get the PTI field from a cell header

## **Typedefs**

typedef unsigned

### int IxAtmCellHeader

ATM Cell Header, does not contain 4 byte HEC, added by NPE-A.

typedef unsigned

### int IxAtmConnId

ATM VC data connection identifier.

### typedef int IxAtmSchedulerVcId

ATM VC scheduling connection identifier.

typedef unsigned

int IxAtmNpeRxVcId

Typedefs 87

## **Enumerations**

```
enum IxAtmLogicalPort {
      IX_UTOPIA_PORT_0,
      IX_UTOPIA_MAX_PORTS
     Logical Port Definitions:.
enum IxAtmServiceCategory {
      IX_ATM_CBR,
      IX_ATM_RTVBR,
      IX_ATM_VBR,
      IX_ATM_UBR,
      IX_ATM_ABR
     Enumerated type representing available ATM service categories. For more informatoin on these
     categories, see "Traffic Management Specification" v4.1, published by the ATM Forum -
     http://www.atmforum.com.
enum IxAtmRxQueueId {
      IX_ATM_RX_A,
      IX_ATM_RX_B,
      IX_ATM_MAX_RX_STREAMS
     Rx Queue Type for RX traffic.
```

## **Detailed Description**

The common set of types used in many Atm components.

## **Define Documentation**

```
#define IX_ATM_AAL0_48_CELL_PAYLOAD_SIZE
```

Size of a AAL0 48 Cell payload.

Definition at line **85** of file **IxAtmTypes.h**.

### #define IX\_ATM\_AAL0\_52\_CELL\_SIZE\_NO\_HEC

Size of a AAL0 52 Cell, excluding HEC byte.

Definition at line 97 of file IxAtmTypes.h.

### #define IX\_ATM\_AAL5\_CELL\_PAYLOAD\_SIZE

Size of a AAL5 Cell payload.

Definition at line 91 of file IxAtmTypes.h.

### #define IX\_ATM\_CELL\_HEADER\_PTI\_GET ( cellHeader )

get the PTI field from a cell header

Definition at line **180** of file **IxAtmTypes.h**.

### #define IX\_ATM\_CELL\_HEADER\_VCI\_GET ( cellHeader )

get the VCI field from a cell header

Definition at line **166** of file **IxAtmTypes.h**.

### #define IX\_ATM\_CELL\_HEADER\_VPI\_GET ( cellHeader )

get the VPI field from a cell header

Definition at line 173 of file IxAtmTypes.h.

### #define IX\_ATM\_CELL\_PAYLOAD\_SIZE

Size of a ATM cell payload.

Definition at line 61 of file IxAtmTypes.h.

### #define IX\_ATM\_CELL\_SIZE

Size of a ATM cell, including header.

Definition at line 67 of file IxAtmTypes.h.

### #define IX\_ATM\_CELL\_SIZE\_NO\_HEC

Size of a ATM cell, excluding HEC byte.

Definition at line 73 of file IxAtmTypes.h.

### #define IX\_ATM\_IDLE\_CELLS\_CONNID

VC Id used to indicate idle cells in the returned schedule table.

Definition at line **159** of file **IxAtmTypes.h**.

### #define IX\_ATM\_MAX\_NUM\_AAL\_OAM\_RX\_VCS

Maximum number of active AAL5/AAL0/OAM Rx VCs in the system.

Definition at line 153 of file IxAtmTypes.h.

### #define IX\_ATM\_MAX\_NUM\_AAL\_OAM\_TX\_VCS

Maximum number of active AAL5/AAL0/OAM Tx VCs in the system.

Definition at line **147** of file **IxAtmTypes.h**.

### #define IX\_ATM\_MAX\_NUM\_AAL\_VCS

Maximum number of active AAL5/AAL0 VCs in the system.

Definition at line 116 of file IxAtmTypes.h.

### #define IX\_ATM\_MAX\_NUM\_OAM\_RX\_VCS

Maximum number of active OAM Rx VCs in the system, 1 OAM VC shared accross all ports.

Definition at line **141** of file **IxAtmTypes.h**.

### #define IX\_ATM\_MAX\_NUM\_OAM\_TX\_VCS

Maximum number of active OAM Tx VCs in the system, 1 OAM VC per port.

Definition at line **134** of file **IxAtmTypes.h**.

### #define IX\_ATM\_MAX\_NUM\_VC

Maximum number of active AAL5/AAL0 VCs in the system The use of this macro is depreciated, it is

retained for backward compatiblity. For current software release and beyond the define IX\_ATM\_MAX\_NUM\_AAL\_VC should be used.

Definition at line **125** of file **IxAtmTypes.h**.

### #define IX\_ATM\_MAX\_VCI

Maximum value of an ATM VCI.

Definition at line 110 of file IxAtmTypes.h.

### #define IX\_ATM\_MAX\_VPI

Maximum value of an ATM VPI.

Definition at line 104 of file IxAtmTypes.h.

### #define IX\_ATM\_OAM\_CELL\_SIZE\_NO\_HEC

Size of a OAM cell, excluding HEC byte.

Definition at line 79 of file IxAtmTypes.h.

## **Typedef Documentation**

### IxAtmCellHeader

ATM Cell Header, does not contain 4 byte HEC, added by NPE-A.

Definition at line **188** of file **IxAtmTypes.h**.

### IxAtmConnId

ATM VC data connection identifier.

This is generated by IxAtmdAcc when a successful connection is made on a VC. The is the ID by which IxAtmdAcc knows an active VC and should be used in IxAtmdAcc API calls to reference a specific VC.

Definition at line **276** of file **IxAtmTypes.h**.

### IxAtmNpeRxVcId

ATM Rx VC identifier used by the ATM Npe.

This Id is generated by IxAtmdAcc when a successful data connection is made on a rx VC.

Definition at line **300** of file **IxAtmTypes.h**.

### **IxAtmSchedulerVcId**

ATM VC scheduling connection identifier.

This id is generated and used by ATM Tx controller, generally the traffic shaper (e.g. IxAtmSch). The IxAtmdAcc component will request one of these Ids whenever a data connection on a Tx VC is requested. This ID will be used in callbacks to the ATM Transmission Ctrl s/w (e.g. IxAtmm) to reference a particular VC.

Definition at line 290 of file IxAtmTypes.h.

## **Enumeration Type Documentation**

### enum IxAtmLogicalPort

Logical Port Definitions:.

Only 1 port is available in SPHY configuration 12 ports are enabled in MPHY configuration

### Enumeration values:

```
IX_UTOPIA_PORT_0 Port 0.IX_UTOPIA_MAX_PORTS Not a port – just a definition for the maximum possible ports.
```

Definition at line **36** of file **IxAtmTypes.h**.

### enum IxAtmRxQueueId

Rx Queue Type for RX traffic.

IxAtmRxQueueId defines the queues involved for receiving data.

There are two queues to facilitate prioritisation handling and processing the 2 queues with different algorithms and constraints

e.g.: one queue can carry voice (or time-critical traffic), the other queue can carry non-voice traffic

### **Enumeration values:**

| $IX\_ATM\_RX\_A$ | RX queue A. |
|------------------|-------------|
| $IX\_ATM\_RX\_B$ | RX queue B. |

IX\_ATM\_MAX\_RX\_STREAMS Maximum number of RX streams.

Definition at line 225 of file IxAtmTypes.h.

### enum IxAtmServiceCategory

Enumerated type representing available ATM service categories. For more information on these categories, see "Traffic Management Specification" v4.1, published by the ATM Forum – http://www.atmforum.com.

### **Enumeration values:**

*IX\_ATM\_CBR* Constant Bit Rate.

IX\_ATM\_RTVBR Real Time Variable Bit Rate.

IX\_ATM\_VBR Variable Bit Rate.IX\_ATM\_UBR Unspecified Bit Rate.

*IX\_ATM\_ABR* Available Bit Rate (not supported).

Definition at line 199 of file IxAtmTypes.h.

# Intel (R) IXP400 Software Security (IxCryptoAcc) API

IXP400 Security component Public API.

### **Data Structures**

### struct IxCryptoAccAuthCtx

Structure storing authentication configuration parameters required to perform security functionality.

### struct IxCryptoAccCipherCtx

Structure storing cipher configuration parameters required to perform security functionality.

### struct IxCryptoAccCtx

Structure storing configuration parameters required to perform security functionality.

### struct IxCryptoAccPkeEauBnAddSubMulOperands

Structure storing input operands for large number addition (Carry | R = A + B) or subtraction operation (Borrow | R = A - B) or multiplication (R = A \* B).

### struct IxCryptoAccPkeEauBnModOperands

Structure storing input operands for large number modular reduction operation  $(R = A \mod N)$ .

### union IxCryptoAccPkeEauInOperands

Union storing input operands required for all EAU operations. These input operands will be supplied to **ixCryptoAccPkeEauPerform** interface to perform EAU functionalities.

### struct IxCryptoAccPkeEauModExpOperands

Structure storing input operands for large number modular exponential operation ( $C = M^e \mod N$ ).

### struct IxCryptoAccPkeEauOperand

Structure storing operand / result data pointer and length for EAU functionality performing through ixCryptoAccPkeEauPerform interface.

## **Defines**

### #define IX\_CRYPTO\_ACC\_MAX\_CIPHER\_KEY\_LENGTH

*Max length (byte) of cipher key for DES (64 bit), 3DES (192 bit), AES (128, 192 & 256 bit).* 

### #define IX\_CRYPTO\_ACC\_MAX\_CIPHER\_IV\_LENGTH

Max IV length in bytes.

### #define IX CRYPTO ACC MAX AUTH KEY LENGTH

Max length (byte) of authentication key for SHA1 and MD5.

### #define IX CRYPTO ACC MAX AUTH IV LENGTH

Max length (byte) of initial chaining variable for SHA1 (160 bit) and MD5 (128 bit).

### #define IX\_CRYPTO\_ACC\_MAX\_QUEUE\_DEPTH

Max queue depth supported by the Queue Manager.

### #define IX\_CRYPTO\_ACC\_MAX\_ACTIVE\_SA\_TUNNELS

Maximum active tunnels supported could be changed by the client based on the application's requirements.

### #define IX\_CRYPTO\_ACC\_DES\_KEY\_64

DES key length in bytes.

### #define IX\_CRYPTO\_ACC\_DES\_BLOCK\_64

DES cipher block length in bytes.

### #define IX CRYPTO ACC DES IV 64

DES initialization vector length in bytes.

### #define IX CRYPTO ACC 3DES KEY 192

3DES key length in bytes

### #define IX CRYPTO ACC AES KEY 128

AES-128 key length in bytes.

### #define IX CRYPTO ACC AES KEY 192

AES-192 key length in bytes.

### #define IX\_CRYPTO\_ACC\_AES\_KEY\_256

*AES*–256 key length in bytes.

### #define IX\_CRYPTO\_ACC\_AES\_BLOCK\_128

AES cipher block length in bytes.

### #define IX CRYPTO ACC AES CBC IV 128

AES initialization vector length in bytes for CBC mode.

### #define IX CRYPTO ACC AES CTR IV 128

AES initialization vector length in bytes for CTR mode.

### #define IX CRYPTO ACC CCM AAD LEN 384

48 Bytes of additional authenticated data for CBC-MAC computation

## #define IX\_CRYPTO\_ACC\_AES\_CCM\_IV\_512

CCM Initialization vector has 2 components to it.

### #define IX CRYPTO ACC ARC4 KEY 128

Key length for ARC4 algorithms.

### #define IX CRYPTO ACC ARC4 BLOCK 8

ARC4 algorithm block size.

### #define IX\_CRYPTO\_ACC\_SHA1\_KEY\_160

SHA1 key length in bytes.

### #define IX CRYPTO ACC SHA1 DIGEST 160

SHA1 message digest length in bytes.

### #define IX\_CRYPTO\_ACC\_MD5\_KEY\_128

MD5 key length in bytes.

### #define IX CRYPTO ACC MD5 DIGEST 128

MD5 message digest length in bytes.

### #define IX\_CRYPTO\_ACC\_CCM\_DIGEST\_64

CCM digest length in bytes.

### #define IX\_CRYPTO\_ACC\_WEP\_CRC\_DIGEST\_32

Digest length of WEP ICV in bytes.

### #define ixCryptoAccHashPerform

alias function name to ixCryptoAccHashKeyGenerate

## **Typedefs**

typedef

### IxCryptoAccPkeEauOperand IxCryptoAccPkeEauOpResult

Structure storing result of EAU operation.

### typedef void(\* IxCryptoAccRegisterCompleteCallback)(UINT32 cryptoCtxId, IX\_OSAL\_MBUF \*pMbuf, IxCryptoAccStatus status)

Cryptographic Context registration complete callback notification.

### typedef void(\* IxCryptoAccHashKeyGenCompleteCallback )(UINT32 hashKeyId,

IX\_OSAL\_MBUF \*pMbufHashKey, IxCryptoAccStatus status)

Hash key generation complete callback notification.

### typedef void(\* IxCryptoAccPerformCompleteCallback )(UINT32 cryptoCtxId,

IX\_OSAL\_MBUF \*pSrcMbuf, IX\_OSAL\_MBUF \*pDestMbuf,

IxCryptoAccStatus status)

Hardware accelerator service request complete callback notification.

**Typedefs** 96

```
typedef void(* IxCryptoAccPkeHashPerformCompleteCallback )(UINT8 *pDigest, IxCryptoAccStatus status)
```

PKE Crypto Engine SHA engine hashing perform complete callback notification.

### $typedef\ void (*\ IxCryptoAccPkeEauPerformCompleteCallback$

)(IxCryptoAccPkeEauOperation operation,

**IxCryptoAccPkeEauOpResult** \*pResult, BOOL carryOrBorrow,

IxCryptoAccStatus status)

EAU perform complete callback notification.

### **Enumerations**

```
enum IxCryptoAccCfg {
     IX_CRYPTO_ACC_CFG_WEP_XSCALE_ACC_EN,
     IX_CRYPTO_ACC_CFG_CRYPTO_NPE_ACC_EN,
     IX_CRYPTO_ACC_CFG_WEP_NPE_ACC_EN,
     IX_CRYPTO_ACC_CFG_CRYPTO_WEP_NPE_ACC_EN,
     IX_CRYPTO_ACC_CFG_TYPE
    Possible configuration definitions.
enum IxCryptoAccOperation {
     IX_CRYPTO_ACC_OP_ENCRYPT,
     IX CRYPTO ACC OP DECRYPT,
     IX_CRYPTO_ACC_OP_AUTH_CALC,
     IX_CRYPTO_ACC_OP_AUTH_CHECK,
     IX_CRYPTO_ACC_OP_ENCRYPT_AUTH,
     IX_CRYPTO_ACC_OP_AUTH_DECRYPT,
     IX_CRYPTO_ACC_OP_TYPE_OF_OPERATION
    Cryptographic Operation Definitions.
enum IxCryptoAccCipherAlgo {
     IX_CRYPTO_ACC_CIPHER_NULL,
     IX_CRYPTO_ACC_CIPHER_DES,
     IX_CRYPTO_ACC_CIPHER_3DES,
     IX_CRYPTO_ACC_CIPHER_AES,
     IX_CRYPTO_ACC_CIPHER_ARC4,
     IX_CRYPTO_ACC_CIPHER_ALGO_TYPE
    Cipher Algorithm Definitions.
enum IxCryptoAccCipherMode {
     IX CRYPTO ACC MODE NULL.
     IX_CRYPTO_ACC_MODE_ECB,
     IX_CRYPTO_ACC_MODE_CBC,
     IX_CRYPTO_ACC_MODE_CTR,
```

Enumerations 97

IX\_CRYPTO\_ACC\_MODE\_CCM,

```
IX CRYPTO ACC MODE TYPE
    Cipher Mode Definitions.
enum IxCrvptoAccAuthAlgo {
     IX CRYPTO ACC AUTH NULL,
     IX CRYPTO ACC AUTH SHA1.
     IX_CRYPTO_ACC_AUTH_MD5,
     IX CRYPTO ACC AUTH CBC MAC,
     IX_CRYPTO_ACC_AUTH_WEP_CRC,
     IX_CRYPTO_ACC_AUTH_TYPE
    Authentication Algorithm Definitions.
enum IxCrvptoAccPkeEauOperation {
     IX_CRYPTO_ACC_OP_EAU_MOD_EXP,
     IX CRYPTO ACC OP EAU BN MUL.
     IX_CRYPTO_ACC_OP_EAU_BN_ADD,
     IX CRYPTO ACC OP EAU BN MOD,
     IX_CRYPTO_ACC_OP_EAU_BN_SUB,
     IX CRYPTO ACC OP TYPE OF EAU OPERATION
    EAU (Exponentiation Acceleration Unit) Operation Definitions.
enum IxCrvptoAccStatus {
     IX_CRYPTO_ACC_STATUS_SUCCESS,
     IX CRYPTO ACC STATUS FAIL.
     IX_CRYPTO_ACC_STATUS_WAIT,
     IX CRYPTO ACC STATUS RETRY,
     IX CRYPTO ACC STATUS QUEUE FULL.
     IX CRYPTO ACC STATUS OPERATION NOT SUPPORTED,
     IX CRYPTO ACC STATUS CIPHER ALGO NOT SUPPORTED.
     IX CRYPTO ACC STATUS CIPHER MODE NOT SUPPORTED,
     IX CRYPTO ACC STATUS CIPHER INVALID KEY LEN,
     IX CRYPTO ACC STATUS CIPHER INVALID IV LEN.
     IX CRYPTO ACC STATUS CIPHER INVALID BLOCK LEN,
     IX CRYPTO ACC STATUS AUTH ALGO NOT SUPPORTED.
     IX CRYPTO ACC STATUS AUTH INVALID DIGEST LEN,
     IX CRYPTO ACC STATUS AUTH INVALID KEY LEN,
     IX_CRYPTO_ACC_STATUS_AUTH_FAIL,
     IX CRYPTO ACC STATUS CRYPTO CTX NOT VALID,
     IX CRYPTO ACC STATUS EXCEED MAX TUNNELS.
     IX CRYPTO ACC STATUS AUTH INVALID AAD LEN,
     IX CRYPTO ACC STATUS NULL PTR ERR,
     IX CRYPTO ACC STATUS OUT OF RANGE ERR
    Status Definitions.
```

## **Functions**

### PUBLIC IxCryptoAccStatus ixCryptoAccConfig (IxCryptoAccCfg compCfg)

Selects which interfaces need to be initialized when crypto-access init is called.

### PUBLIC IxCryptoAccStatus ixCryptoAccInit (void)

Initialise the Security Access component.

### PUBLIC IxCryptoAccStatus ixCryptoAccUninit (void)

Uninitialise the Security Access component.

PUBLIC **IxCryptoAccStatus ixCryptoAccCtxRegister** (**IxCryptoAccCtx** \*pAccCtx, IX\_OSAL\_MBUF \*pMbufPrimaryChainVar, IX\_OSAL\_MBUF \*pMbufSecondaryChainVar,

 $\textbf{IxCryptoAccRegisterCompleteCallback} \ registerCallbackFn,$ 

IxCryptoAccPerformCompleteCallback performCallbackFn, UINT32

\*pCryptoCtxId)

Crypto context registration. Cryptographic Context ID (cryptoCtxId) for the registered crypto context obtained from this registration request will be used in perform service requests.

### PUBLIC IxCryptoAccStatus ixCryptoAccCtxUnregister (UINT32 cryptoCtxId)

Unregister the crypto context from Cryptographic Context Database.

PUBLIC IxCryptoAccStatus ixCryptoAccAuthCryptPerform (UINT32 cryptoCtxId, IX\_OSAL\_MBUF

\*pSrcMbuf, IX\_OSAL\_MBUF \*pDestMbuf, UINT16 authStartOffset, UINT16 authDataLen, UINT16 cryptStartOffset, UINT16 cryptDataLen,

UINT16 icvOffset, UINT8 \*pIV)

Perform Authentication and Decryption/Encryption functionalities.

PUBLIC IxCryptoAccStatus ixCryptoAccNpeWepPerform (UINT32 cryptoCtxId, IX\_OSAL\_MBUF

\*pSrcMbuf, IX\_OSAL\_MBUF \*pDestMbuf, UINT16 startOffset, UINT16 dataLen, UINT16 icvOffset, UINT8 \*pKey)

Function to invoke ARC4 and WEP ICV computations on NPE.

 $PUBLIC \ \textbf{IxCryptoAccStatus ixCryptoAccXScaleWepPerform} \ (UINT32 \ cryptoCtxId, IX\_OSAL\_MBUF)$ 

\*pSrcMbuf, IX\_OSAL\_MBUF \*pDestMbuf, UINT16 startOffset, UINT16 dataLen, UINT16 icvOffset, UINT8 \*pKey)

 $Function \ to \ support \ ARC4 \ and \ WEP \ ICV \ computations \ on \ Intel \ XScale(R)$ 

Core.

PUBLIC IxCryptoAccStatus ixCryptoAccCtxCipherKeyUpdate (UINT32 cryptoCtxId, UINT8

\*pCipherKey)

Change keys for the specified registered context.

PUBLIC void ixCryptoAccShow (void)

API for printing statistics and status.

PUBLIC void ixCryptoAccShowWithId (UINT32 cryptoCtxId)

API for printing statistic and status.

Functions 99

### PUBLIC IxCryptoAccStatus ixCryptoAccCryptoServiceStop (void)

Function to stop the crypto services.

## PUBLIC **IxCryptoAccStatus ixCryptoAccHashKeyGenerate** (**IxCryptoAccAuthAlgo** hashAlgo, IX OSAL MBUF \*pMbufHashKey,

**IxCryptoAccHashKeyGenCompleteCallback** hashKeyCallbackFn, UINT16 hashKeyStartOffset, UINT16 hashKeyLen, UINT16 hashKeyDestOffset, UINT32 \*pHashKeyId)

This function is used to generate authentication key needed in HMAC authentication if the authentication key is greater than 64 bytes. New authentication key of L bytes size will be generated in this function (L=20 for SHA1, L=16 for MD5). Please refer to RFC2104 for more details on the key size. The authentication key is padded (extended) so that its length (in bits) is congruent to 448, modulo 512 (please refer to RFC1321 & RFC3174). Authentication key is padded inside cryptoAcc on the mbuf which holds the authentication key. Therefore, mbuf allocated to store authentication key need to take into account the space needed for padding process. Padding space (extra memory allocation) needed is between the range of 9-72 bytes, it varies based on the authentication key size specified by client. Minimum of 9 bytes are needed, as 8 bytes is for total length of authentication key (hash data), and 1 bytes is for start of padding indication. The extra padding space is derived from the padding scheme stated in RFC1321 & RFC3174.

## PUBLIC **IxCryptoAccStatus ixCryptoAccPkeHashPerform** (**IxCryptoAccAuthAlgo** hashAlgo, UINT8 \*pHashData, UINT32 hashDataLen,

This function is used to hash the input data and return the digest generated via callback function supplied by client. L bytes size of digest will be generated (L=20 for SHA1). The hash data is padded inside the function so that its length (in bits) is congruent to 448, modulo 512 (please refer to RFC1321). The length of data in bytes to be hashed must be greater than 0.

### PUBLIC IxCryptoAccStatus ixCryptoAccPkePseudoRandomNumberGet (UINT32

pseudoRandomNumberLen, UINT32 \*pPseudoRandomNumber) This function will return the pseudo-random number generated in hardware to the client via the data pointer supplied. The length of pseudo-random number requested must be in words count (pseudoRandomNumberLen >= 1 word). If bigger pseudo-random number is requested, then this function will take longer time to complete.

### PUBLIC IxCryptoAccStatus ixCryptoAccPkeEauExpConfig (BOOL enableSE, BOOL enableFE)

This function is used to configure short exponent setting (SE – skipping leading 0s while performing modular exponential) and fast exponent setting (FE – skipping all 0s while performing modular exponential) for EAU modular exponential operation. By default, these 2 settings are DISABLED to prevent timing attacks on keys and also ensure best protection on keys. These 2 setting will have direct impact on function call to

*ixCryptoAccPkeEauPerform*. Client may change it accordingly to achieve different level of protection and also performance.

Functions 100

## $PUBLIC\ \textbf{IxCryptoAccPkeEauPerform}\ (\textbf{IxCryptoAccPkeEauOperation}\ operation,\\ \textbf{IxCryptoAccPkeEauInOperands}\ *pOpr,$

This function is used to performed large number exponential arithmetic operation requested by client by using EAU (Exponentiation Acceleration Unit) on PKE (Public Key Exchange) Crypto Engine. The result computed will be returned via callback function supplied by client. All the operand size must be specified in words (32-bit), the output data pointer must be big enough to hold the result.

## **Detailed Description**

IXP400 Security component Public API.

## **Define Documentation**

### #define IX\_CRYPTO\_ACC\_3DES\_KEY\_192

3DES key length in bytes

Definition at line **106** of file **IxCryptoAcc.h**.

### #define IX\_CRYPTO\_ACC\_AES\_BLOCK\_128

AES cipher block length in bytes.

Definition at line 123 of file IxCryptoAcc.h.

### #define IX CRYPTO ACC AES CBC IV 128

AES initialization vector length in bytes for CBC mode.

Definition at line **126** of file **IxCryptoAcc.h**.

### #define IX\_CRYPTO\_ACC\_AES\_CCM\_IV\_512

CCM Initialization vector has 2 components to it.

First is the IV for the CTR mode encryption and second is the additional authentication data for the CBC–MAC generation.

Definition at line 143 of file IxCryptoAcc.h.

### #define IX\_CRYPTO\_ACC\_AES\_CTR\_IV\_128

AES initialization vector length in bytes for CTR mode.

Definition at line 130 of file IxCryptoAcc.h.

### #define IX\_CRYPTO\_ACC\_AES\_KEY\_128

AES-128 key length in bytes.

Definition at line 114 of file IxCryptoAcc.h.

### #define IX\_CRYPTO\_ACC\_AES\_KEY\_192

AES-192 key length in bytes.

Definition at line **117** of file **IxCryptoAcc.h**.

### #define IX\_CRYPTO\_ACC\_AES\_KEY\_256

AES-256 key length in bytes.

Definition at line 120 of file IxCryptoAcc.h.

### #define IX\_CRYPTO\_ACC\_ARC4\_BLOCK\_8

ARC4 algorithm block size.

Definition at line 160 of file IxCryptoAcc.h.

### #define IX\_CRYPTO\_ACC\_ARC4\_KEY\_128

Key length for ARC4 algorithms.

Definition at line 157 of file IxCryptoAcc.h.

### #define IX\_CRYPTO\_ACC\_CCM\_AAD\_LEN\_384

48 Bytes of additional authenticated data for CBC-MAC computation

Currently only this value is supported.

Definition at line 135 of file IxCryptoAcc.h.

### #define IX\_CRYPTO\_ACC\_CCM\_DIGEST\_64

CCM digest length in bytes.

Currently only this value (of 8 bytes)is supported for CCM digest length.

Definition at line 192 of file IxCryptoAcc.h.

### #define IX\_CRYPTO\_ACC\_DES\_BLOCK\_64

DES cipher block length in bytes.

Definition at line **99** of file **IxCryptoAcc.h**.

### #define IX CRYPTO ACC DES IV 64

DES initialization vector length in bytes.

Definition at line **102** of file **IxCryptoAcc.h**.

### #define IX\_CRYPTO\_ACC\_DES\_KEY\_64

DES key length in bytes.

Definition at line **96** of file **IxCryptoAcc.h**.

### #define IX\_CRYPTO\_ACC\_MAX\_ACTIVE\_SA\_TUNNELS

Maximum active tunnels supported could be changed by the client based on the application's requirements.

Number of active tunnels will not impact the overall performance but will have an impact on the memory needed to keep the crypto context information. Overall memory requirement depends on the number of tunnels.

Definition at line **75** of file **IxCryptoAcc.h**.

### #define IX\_CRYPTO\_ACC\_MAX\_AUTH\_IV\_LENGTH

Max length (byte) of initial chaining variable for SHA1 (160 bit) and MD5 (128 bit).

Definition at line **65** of file **IxCryptoAcc.h**.

### #define IX\_CRYPTO\_ACC\_MAX\_AUTH\_KEY\_LENGTH

Max length (byte) of authentication key for SHA1 and MD5.

Key size > 64 bytes need to be hashed to produce shorter key by calling API **ixCryptoAccHashKeyGenerate()**. (SHA1 : 20 bytes, MD5 : 16 bytes by default according to RFC2104. If L <= key size <= 64 bytes (L=16 for MD5 & 20 for SHA1) authentication key can be used for registration directly. If key size < L, client will need to pad the key with 0s to length L before calling **ixCryptoAccCtxRegister()** API.

Definition at line **44** of file **IxCryptoAcc.h**.

### #define IX\_CRYPTO\_ACC\_MAX\_CIPHER\_IV\_LENGTH

Max IV length in bytes.

Definition at line **41** of file **IxCryptoAcc.h**.

### #define IX\_CRYPTO\_ACC\_MAX\_CIPHER\_KEY\_LENGTH

Max length (byte) of cipher key for DES (64 bit), 3DES (192 bit), AES (128, 192 & 256 bit).

Definition at line 35 of file IxCryptoAcc.h.

### #define IX\_CRYPTO\_ACC\_MAX\_QUEUE\_DEPTH

Max queue depth supported by the Queue Manager.

Definition at line **71** of file **IxCryptoAcc.h**.

### #define IX CRYPTO ACC MD5 DIGEST 128

MD5 message digest length in bytes.

Definition at line **184** of file **IxCryptoAcc.h**.

### #define IX\_CRYPTO\_ACC\_MD5\_KEY\_128

MD5 key length in bytes.

Definition at line **181** of file **IxCryptoAcc.h**.

### #define IX\_CRYPTO\_ACC\_SHA1\_DIGEST\_160

SHA1 message digest length in bytes.

Definition at line **171** of file **IxCryptoAcc.h**.

### #define IX\_CRYPTO\_ACC\_SHA1\_KEY\_160

SHA1 key length in bytes.

Definition at line **168** of file **IxCryptoAcc.h**.

### #define IX\_CRYPTO\_ACC\_WEP\_CRC\_DIGEST\_32

Digest length of WEP ICV in bytes.

Definition at line **204** of file **IxCryptoAcc.h**.

### #define ixCryptoAccHashPerform

alias function name to ixCryptoAccHashKeyGenerate

Definition at line **1692** of file **IxCryptoAcc.h**.

## **Typedef Documentation**

typedef void(\* IxCryptoAccHashKeyGenCompleteCallback)( UINT32 hashKeyId, IX\_OSAL\_MBUF \*pMbufHashKey, IxCryptoAccStatus status)

Hash key generation complete callback notification.

This function is called to notify a client that the hash key has been generated. This function will return the status through the associated hashKeyId once the key is calculated by Network Processor Engine (NPE).

hashKeyId becomes invalid once the notification callback is called.

### Parameters:

hashKeyId UINT32 [in] – This hashKeyId is provided when client sends in request to hash

the key.

\*pMbufHashKey [in] – Pointer to the mbuf that contains original key and generated hash key.

Client will need to copy the generated hash key from the mbuf into crypto context and used it as hash key for crypto registration request. This mbuf will be freed by

client.

### Note:

♦ IX\_CRYPTO\_ACC\_STATUS\_SUCCESS – hash key generation is successful.

♦ IX\_CRYPTO\_ACC\_STATUS\_FAIL – hash key generation failed.

Definition at line **715** of file **IxCryptoAcc.h**.

typedef void(\* IxCryptoAccPerformCompleteCallback)( UINT32 cryptoCtxId, IX\_OSAL\_MBUF \*pSrcMbuf, IX\_OSAL\_MBUF \*pDestMbuf, IxCryptoAccStatus status)

Hardware accelerator service request complete callback notification.

This function is called to notify a client that the cryptographic transaction has been completed. The cryptoCtxId and status of completed operation are returned to the client through this callback function to indicate operation which crypto context has been completed. The CryptoCtxId is obtained via ixCryptoAccCtxRegister, and this ID is unique to a particular IPSec tunnel.

### Parameters:

cryptoCtxId UINT32 [in] – This crypto context ID is provided when client sends in request via ixCryptoAccCtxRegister API to register crypto context. cryptoCtxId points to a struct consists of cryptographic parameters required by the Network Processor Engine (NPE) in CCD database.

\*pSrcMbuf [in] – Pointer to the source mbuf which contains the data to be processed. It is also the output mbuf which contains the processed data if UseDifferentSrcAndDestMbufs is FALSE.

\*pDestMbuf [in] – Only used if UseDifferentSrcAndDestMbufs is TRUE. Pointer to the output mbuf which contains processed data.

status IxCryptoAccStatus [in] – Status reporting to the client via IxCryptoAccStatus.

### Note:

♦ IX\_CRYPTO\_ACC\_STATUS\_SUCCESS – Operation is completed successfully.

♦ IX\_CRYPTO\_ACC\_STATUS\_FAIL – Operation failed.

♦ IX\_CRYPTO\_ACC\_STATUS\_AUTH\_FAIL – Authentication is unsuccessful. Note that when authentication fails, the content of the destination mbuf (which is the same as the source mbuf if a normal in–place operation is performed) will be undetermined.

Definition at line **756** of file **IxCryptoAcc.h**.

### typedef IxCryptoAccPkeEauOperand IxCryptoAccPkeEauOpResult

Structure storing result of EAU operation.

Definition at line **586** of file **IxCryptoAcc.h**.

typedef void(\* IxCryptoAccPkeEauOperation operation, IxCryptoAccPkeEauOperation operation, IxCryptoAccPkeEauOpResult \*pResult, BOOL carryOrBorrow, IxCryptoAccStatus status)

EAU perform complete callback notification.

This function is called to notify a client that the result from EAU operation is ready. This function will return the status, result computed (IxCryptoAccPkeEauOpResult) and carry/borrow flag as a result of add/sub operation.

### Parameters:

operation **IxCryptoAccPkeEauOperation** [in] – EAU operation performed.

\*pResult IxCryptoAccPkeEauOpResult [in] – pointer to a structure which store EAU

operation result.

carryOrBorrow BOOL [in] - carry/borrow bit status as resulted from large number

addition/subtraction operation.

### Note:

♦ IX\_CRYPTO\_ACC\_STATUS\_SUCCESS – EAU operation is successful.

♦ IX\_CRYPTO\_ACC\_STATUS\_FAIL – EAU operation failed.

Definition at line **810** of file **IxCryptoAcc.h**.

typedef void(\* IxCryptoAccPkeHashPerformCompleteCallback)( UINT8 \*pDigest, **IxCryptoAccStatus** status)

PKE Crypto Engine SHA engine hashing perform complete callback notification.

This function is called to notify a client that the digest from hashing on AHB-SHA engine in PKE Crypto Engine has been generated. This function will return the status and digest calculated.

### Parameters:

```
*pDigest UINT8 [in] – Pointer to the flat buffer that contains computed digest.

status IxCryptoAccStatus [in] – Status (IxCryptoAccStatus) reporting to client.
```

### Note:

```
♦ IX_CRYPTO_ACC_STATUS_SUCCESS – hash digest generation is successful.
```

♦ IX\_CRYPTO\_ACC\_STATUS\_FAIL – hash digest generation failed.

Definition at line 782 of file IxCryptoAcc.h.

typedef void(\* IxCryptoAccRegisterCompleteCallback)( UINT32 cryptoCtxId, IX\_OSAL\_MBUF \*pMbuf, IxCryptoAccStatus status)

Cryptographic Context registration complete callback notification.

This function is called to notify a client that the Crypto Context has been registered. This function returns status through the associated cryptoCtxId once the initial values needed are calculated by Network Processor Engine (NPE) and stored in Cryptographic Context Database (CCD).

The CryptoCtxId is valid until ixCryptoAccCtxUnregister is invoked.

If the callback function returns the IX\_CRYPTO\_ACC\_STATUS\_WAIT status, it indicates that registration is not complete yet, but the mbuf pointer needs to be freed by client. Client needs to wait for the next completion indication. Registration complete successfully only if status IX\_CRYPTO\_ACC\_STATUS\_SUCCESS is received.

### Parameters:

cryptoCtxId UINT32 [in] – This crypto context ID is provided when client sends in request via

ixCryptoAccCtxRegister API to register crypto context. cryptoCtxId points to a struct consists of cryptographic parameters required by the Network Processor Engine (NPE)

in CCD database.

\*pMbuf [in] – Pointer to the mbuf (to be freed by client). The client should free any mbuf that

is not NULL.

### Note:

♦ IX\_CRYPTO\_ACC\_STATUS\_SUCCESS – registration is successful.

♦ IX\_CRYPTO\_ACC\_STATUS\_FAIL – registration failed.

♦ IX\_CRYPTO\_ACC\_STATUS\_WAIT – registration is not complete yet, wait for next completion indication. NPE is busy in calculating the initial variables needed for the registration.

Definition at line **683** of file **IxCryptoAcc.h**.

## **Enumeration Type Documentation**

### enum IxCryptoAccAuthAlgo

Authentication Algorithm Definitions.

### Note:

Only two authentication algorithms are supported, SHA1 and MD5 for IPSEC application, while WEP\_CRC is only for WEP application.

Only SHA1 is supported in AHB-SHA engine in PKE Crypto Engine

### Enumeration values:

IX\_CRYPTO\_ACC\_AUTH\_NULL NULL authentication. IX\_CRYPTO\_ACC\_AUTH\_SHA1 SHA1 algorithm.

IX\_CRYPTO\_ACC\_AUTH\_MD5 MD5 algorithm.

IX\_CRYPTO\_ACC\_AUTH\_CBC\_MAC CBC MAC algorithm only applicable along with CCM

cipher mode.

IX\_CRYPTO\_ACC\_AUTH\_WEP\_CRC WEP CRC algorithm.

IX\_CRYPTO\_ACC\_AUTH\_TYPE Maximum value for types of authentication algorithm.

Definition at line **345** of file **IxCryptoAcc.h**.

### enum IxCryptoAccCfg

Possible configuration definitions.

#### Note:

Enums to define various possible configurations.

PKE acceleration support (by using EAU, RNG and AHB-SHA engines) is enabled by default if the silicone variants support that.

### **Enumeration values:**

IX\_CRYPTO\_ACC\_CFG\_WEP\_XSCALE\_ACC\_EN Enable access to WEP Intel XScale(R)

Core processing only.

Access to WEP-NPE and hardware

accelerators are disabled

IX\_CRYPTO\_ACC\_CFG\_CRYPTO\_NPE\_ACC\_EN Enable access to Hardware accelerators

(WEP Intel XScale(R) Core is also

enabled).

This is the default configuration for the

cryptoAcc component.

IX\_CRYPTO\_ACC\_CFG\_WEP\_NPE\_ACC\_EN Enable access to WEP NPE and Intel

XScale(R) Core.

IX\_CRYPTO\_ACC\_CFG\_CRYPTO\_WEP\_NPE\_ACC\_EN Enable access to the Hardware

accelerators, WEP – NPE and Intel

XScale(R) Core.

IX\_CRYPTO\_ACC\_CFG\_TYPE Maximum value for types of

configurations.

Definition at line 223 of file IxCryptoAcc.h.

### enum IxCryptoAccCipherAlgo

Cipher Algorithm Definitions.

### Note:

3DES and AES will be supported if not violating import/export rules.

### **Enumeration values:**

IX\_CRYPTO\_ACC\_CIPHER\_NULLNULL encryption.IX\_CRYPTO\_ACC\_CIPHER\_DESDES algorithm.IX\_CRYPTO\_ACC\_CIPHER\_3DESTriple DES algorithm.IX\_CRYPTO\_ACC\_CIPHER\_AESAES algorithm.IX\_CRYPTO\_ACC\_CIPHER\_ARC4ARC4 Algorithm.IX\_CRYPTO\_ACC\_CIPHER\_ALGO\_TYPEMaximum value for types of cipher

Definition at line **294** of file **IxCryptoAcc.h**.

### enum IxCryptoAccCipherMode

Cipher Mode Definitions.

### Note:

CFB and OFB are not supported.

### **Enumeration values:**

IX\_CRYPTO\_ACC\_MODE\_NULL NULL cipher mode.IX\_CRYPTO\_ACC\_MODE\_ECB ECB mode of operation.IX\_CRYPTO\_ACC\_MODE\_CBC CBC mode of operation.

*IX\_CRYPTO\_ACC\_MODE\_CTR* CTR mode of operation, only applicable to AES.

algorithm.

Algo.

IX\_CRYPTO\_ACC\_MODE\_TYPE Maximum value for types of operation.

Definition at line **316** of file **IxCryptoAcc.h**.

### enum IxCryptoAccOperation

Cryptographic Operation Definitions.

### **Enumeration values:**

IX\_CRYPTO\_ACC\_OP\_ENCRYPTEncrypt operation.IX\_CRYPTO\_ACC\_OP\_DECRYPTDecrypt operation.IX\_CRYPTO\_ACC\_OP\_AUTH\_CALCAuthentication calculation operation.

IX\_CRYPTO\_ACC\_OP\_AUTH\_CHECK Authentication verification operation.

IX\_CRYPTO\_ACC\_OP\_ENCRYPT\_AUTH Encryption followed by authentication

calculation operation.

IX\_CRYPTO\_ACC\_OP\_AUTH\_DECRYPT Authentication verification followed by

decryption.

IX\_CRYPTO\_ACC\_OP\_TYPE\_OF\_OPERATION Maximum value for types of operation.

Definition at line 258 of file IxCryptoAcc.h.

### enum IxCryptoAccPkeEauOperation

EAU (Exponentiation Acceleration Unit) Operation Definitions.

### Enumeration values:

IX\_CRYPTO\_ACC\_OP\_EAU\_MOD\_EXP Modular exponential operation.
IX\_CRYPTO\_ACC\_OP\_EAU\_BN\_MUL Large number multiplication

operation.

IX\_CRYPTO\_ACC\_OP\_EAU\_BN\_ADD Large number addition operation.
IX\_CRYPTO\_ACC\_OP\_EAU\_BN\_MOD Large number modular reduction

operation.

IX\_CRYPTO\_ACC\_OP\_EAU\_BN\_SUB Large number subtraction operation. IX\_CRYPTO\_ACC\_OP\_TYPE\_OF\_EAU\_OPERATION Maximum value for types of EAU

operation.

Definition at line **367** of file **IxCryptoAcc.h**.

### enum IxCryptoAccStatus

Status Definitions.

### Note:

These status will be used by the APIs to return to the client.

### **Enumeration values:**

IX\_CRYPTO\_ACC\_STATUS\_SUCCESSSuccess status.IX\_CRYPTO\_ACC\_STATUS\_FAILFail status.IX\_CRYPTO\_ACC\_STATUS\_WAITWait status.IX\_CRYPTO\_ACC\_STATUS\_RETRYRetry status.IX\_CRYPTO\_ACC\_STATUS\_QUEUE\_FULLQueue full.IX\_CRYPTO\_ACC\_STATUS\_OPERATION\_NOT\_SUPPORTEDInvalid operation.

IX\_CRYPTO\_ACC\_STATUS\_CIPHER\_ALGO\_NOT\_SUPPORTED Invalid cipher algorithm. IX\_CRYPTO\_ACC\_STATUS\_CIPHER\_MODE\_NOT\_SUPPORTED Invalid cipher mode of

operation.

IX\_CRYPTO\_ACC\_STATUS\_CIPHER\_INVALID\_KEY\_LEN Invalid cipher key length.

IX\_CRYPTO\_ACC\_STATUS\_CIPHER\_INVALID\_IV\_LEN Invalid IV length.

IX\_CRYPTO\_ACC\_STATUS\_CIPHER\_INVALID\_BLOCK\_LEN Invalid cipher block length.

IX\_CRYPTO\_ACC\_STATUS\_AUTH\_ALGO\_NOT\_SUPPORTED Invalid authentication

algorithm.

IX\_CRYPTO\_ACC\_STATUS\_AUTH\_INVALID\_DIGEST\_LEN Invalid message digest length.
IX\_CRYPTO\_ACC\_STATUS\_AUTH\_INVALID\_KEY\_LEN Invalid authentication key

length.

IX\_CRYPTO\_ACC\_STATUS\_AUTH\_FAIL Authentication verification

failed.

IX\_CRYPTO\_ACC\_STATUS\_CRYPTO\_CTX\_NOT\_VALID
IX\_CRYPTO\_ACC\_STATUS\_EXCEED\_MAX\_TUNNELS

Invalid crypto context ID. Exceed maximum number of crypto contexts allocation. IX\_CRYPTO\_ACC\_STATUS\_AUTH\_INVALID\_AAD\_LEN

IX\_CRYPTO\_ACC\_STATUS\_NULL\_PTR\_ERR

IX\_CRYPTO\_ACC\_STATUS\_OUT\_OF\_RANGE\_ERR

Invalid additional authentication length. buffer pointer or callback function pointer is NULL Operand size or buffer size is less than minimum size allowed or greater than maximum size allowed.

Definition at line **398** of file **IxCryptoAcc.h**.

## **Function Documentation**

```
IxCryptoAccStatus ixCryptoAccAuthCryptPerform ( UINT32
                                                                  cryptoCtxId,
                                               IX OSAL MBUF * pSrcMbuf,
                                               IX_OSAL_MBUF * pDestMbuf,
                                               UINT16
                                                                  authStartOffset,
                                               UINT16
                                                                  authDataLen,
                                               UINT16
                                                                  cryptStartOffset,
                                               UINT16
                                                                  cryptDataLen,
                                               UINT16
                                                                  icvOffset,
                                               UINT8 *
                                                                  pIV
```

Perform Authentication and Decryption/Encryption functionalities.

This function is called for authentication and decryption/encryption functionalities service request. For a combined encryption and authentication request with cipher algorithms as AES or DES and authentication algorithm as MD5 and SHA1 the following restriction must be met: That the crypted data must be a subset of the authenticated data. The boundary relationship of [(authStartOffset + authDataLen) >= (cryptDataLen + cryptStartOffset) >= (cryptStartOffset >= authStartOffset] MUST BE SATISFIED. There should not be any chained mbuf boundary within an ICV field.

For performing ARC4 and WEP ICV computations call the ixCryptoAccNpeWepPerform or ixCryptoAccXScaleWepPerform functions. The ARC4 and WEP ICV operations are not supported by this function.

A valid cryptoCtxId must be obtained via **ixCryptoAccCtxRegister** API in order to proceed to perform the functionalities above.

### Parameters:

cryptoCtxId UINT32 [in] – is the crypto context pointer to be supplied by the client. This

cryptoCtxId is obtained via ixCryptoAccCtxRegister. The cryptoCtxId must be a

valid Id.

\*pSrcMbuf [in] – is a pointer to mbuf which contains data to be processed. This mbuf structure

is allocated by client. Result of this request will be stored in the same mbuf and

overwritten the original data if UseDifferentSrcAndDestMbufs flag in **IxCryptoAccCtx** is set to FALSE (in–place operation). Otherwise, if

UseDifferentSrcAndDestMbufs flag is set to TRUE, the result will be written into destination mbuf (non in–place operation) and the original data in this mbuf will remain unchanged. The same pointer is then returned to the client via registered IxCryptoAccPerformCompleteCallback callback function.

\*pDestMbuf

[in] – only used if UseDifferentSrcAndDestMbufs is TRUE. This is the buffer where the result is written to. This mbuf structure is allocated by client. The length of mbuf MUST be big enough to hold the result of operation. The result of operation COULD NOT span into two or more different mbufs, thus the mbuf supplied must be at least the length of expected result. The same pointer is then returned to the client via registered IxCryptoAccPerformCompleteCallback callback function. The data is written back at the 'authStartOffset',if it's a authentication only or a combined request. If it's a crypt only request the data is written starting from 'cryptStartOffset'.

*authStartOffset* UINT16 [in] – supplied by the client to indicate the start of the payload to be authenticated. Ignored when performing request with Cipher Mode set to CCM.

authDataLen UINT16 [in] – supplied by the client to indicate the length of the payload to be

authenticated in Bytes. The maximum data length must not exceed 65471 bytes. Ignored when performing request with Cipher Mode set to CCM.

cryptStartOffset UINT16 [in] – supplied by the client to indicate the start of the payload to be decrypted/encrypted.

cryptDataLen UINT16 [in] – supplied by the client to indicate the length of the payload to be decrypted/encrypted in Bytes. The payload to be decrypted/encrypted must have

the length that is multiple of cipher block length in size.

icvOffset UINT16 [in] – supplied by the client to indicate the start of the ICV (Integrity

Check Value) used for the authentication. This ICV field should not be split across

multiple mbufs in a chained mbuf.

\*pIV UINT8 [in] – Initialization Vector supplied by the client to be used for the

decryption/encryption processes. For CCM mode of operation, this parameter points to the CTR–IV followed by the 16 bytes of initial block (called – B0, in RFC 3610 and CCM Initial block in 802.11i spec), followed by additional

authentication data (lengths – defined in respective standards).

### Returns:

- ♦ IX\_CRYPTO\_ACC\_STATUS\_SUCCESS Operation requested is successfully enqueued to hardware accelerator for processing.
- ♦ IX\_CRYPTO\_ACC\_STATUS\_FAIL Cryptographic process failed for some unspecified internal reasons.
- ♦ IX\_CRYPTO\_ACC\_STATUS\_QUEUE\_FULL Cryptographic queue is full.
- ♦ IX\_CRYPTO\_ACC\_STATUS\_CIPHER\_INVALID\_BLOCK\_LEN Invalid plaintext / ciphertext block size passed in by the client.
- ♦ IX\_CRYPTO\_ACC\_STATUS\_CRYPTO\_CTX\_NOT\_VALID Crypto context is not registered.

### Note:

♦ Client shall handle IP mutable fields.

- ♦ Client shall pad the IP datagram to be a multiple of cipher block size, using ESP trailer for encryption (RFC2406, explicit padding)
- ♦ NPE shall pad the IP datagram to be a multiple of hashing block size, specified by the authentication algorithm (RFC2402, implicit padding)
- ♦ For authentication generation operation, client needs to clear the field which hold the authentication data (ICV) to zeroes. While for the authentication verification operation, client needs to supply the authentication data at the ICV field for NPE to verify the ICV value. If ICV is embedded in the payload, client DOES NOT need to move the ICV to the front / the back of the payload and clear the original ICV field. cryptoAcc access component will handle this.
- ♦ Client shall construct the AES CTR counter block (4 bytes NONCE + 8 bytes IV + 4 bytes counter). CTR counter block implementation should be based on internet draft / RFC for IPSEC AES CTR mode recommendation, which can be found at IETF website, www.ietf.org. Counter block will be passed in as IV in this case.
- ♦ Depending upon the operating system and task switching mechanism, the operation might "seem" to complete before this function returns to the caller. However, the return status with value success only implies that the request was successfully enqueued to the hardware accelerator. The call of performCallBackFn indicates the completion of operation by the hardware engine.

### **Assumption:**

- Different clients should NOT hold the same crypto context. All the requests for same crypto context should be initiated from same client (thread).
- This function is reentrant, and the client could submit multiple requests for the same crypto context.

Reentrant : yesISR Callable : yes

### **IxCryptoAccStatus** ixCryptoAccConfig ( **IxCryptoAccCfg** compCfg )

Selects which interfaces need to be initialized when crypto–access init is called.

This function will set the configuration bits for initializing the interfaces to the Hardware Accelerator engines on NPE–C and WEP Encryption engine on the WAN–NPE. If this function is not called then, only the Hardware Accelerator engine is initialized by default in the crypto–access init function. This function should be called prior to call ixCyptoAccInit function.

Consideration on using WEP encryption engine on Intel XScale(R) Core & WAN-NPE

- 1. Enabling WEP encryption engine on Intel XScale(R) Core
   Pros:
  - i. Higher throughput compared to WEP running on WAN-NPE.
  - ii. Still can process WEP request on Intel XScale(R) Core if WEP engine on WAN-NPE is not available due to hardware is not present or some interfaces(e.g. ATM/HSS/DMA) on the NPE that is being used.

#### Cons:

- Lesser memory headroom and CPU bandwidth on Intel XScale(R) Core for application stack.
- Note: By default WEP encryption engine on Intel XScale(R) Core is always enabled for all options.

2. Enabling WEP encryption engine on WAN-NPE

Pros:

i. Can process WEP request via WEP engines on both Intel XScale(R) Core and WAN-NPE.

Cons:

- i. Whole WAN-NPE is dedicated for WEP processing, no other interfaces (such as ATM, HSS, DMA) can be enabled for this case.
- ii. Lower throughput rate compared to WEP on Intel XScale(R) Core due to NPE core running at lower frequency compared to Intel XScale(R) Core.

Note: By default WEP encryption on WAN NPE is disabled.

### Note:

PKE acceleration support (by using EAU, RNG and AHB–SHA engines) is enabled by default if the network processor on the system has PKE bridge. Client does not need to enable it explicitly.

### Parameters:

compCfg IxCryptoAccCfg [in] – Indicates the appropriate interfaces to be initialized for

cryptoAcc access component.

### Returns:

♦ IX\_CRYPTO\_ACC\_STATUS\_SUCCESS – Setting the configuration was successful.

♦ IX\_CRYPTO\_ACC\_STATUS\_FAIL—The configuration setting was invalid.

♦ Reentrant : no♦ ISR Callable : yes

### **IxCryptoAccStatus** ixCryptoAccCryptoServiceStop (void )

Function to stop the crypto services.

### Warning:

THIS FUNCTION HAS BEEN DEPRECATED AND SHOULD NOT BE USED. It will be removed in future release. See ixCryptoAccUninit for more information.

This function is called to stop the Hardware Accelerator services and (if enabled) WEP engine services. All the requests pending in queues will be completed before the services are shutdown. Any new requests issued after this call will be rejected. All the Crypto Contexts will be unregistered in this function call.

### Returns:

- ♦ IX\_CRYPTO\_ACC\_STATUS\_SUCCESS Operation requested is successful with all the pending requests are completed and CCD is cleared.
- ♦ IX\_CRYPTO\_ACC\_STATUS\_FAIL Cryptographic stop request failed for some unspecified internal reasons.

♦ Reentrant : no♦ ISR Callable : no

Change keys for the specified registered context.

This function is called to change the key value of a previously registered context. Key change for a registered context is only supported for CCM cipher mode. This is done in order to quickly change keys for CCM mode, without going through the process of context deregistration and registration. Changes to the key lengths are not allowed for a registered context. This function should only be used if one is invoking cryptographic operations using CCM as cipher mode. For contexts registered with other modes the the client should unregister and re–register a context for the particular security association in order to change keys and other parameters. The client should make sure that there are no pending requests on the "cryptoCtxtId" for the key change to happen successfully. If there are pending requests on this context the result of those operations are undefined.

### Parameters:

cryptoCtxId UINT32 [in] – The previously registered context id. This context should be registered for CCM cipher mode. Keys updates for other types of registered cipher modes are not supported at this time.

\*pCipherKey UINT8 [in] – The new key value. The number of bytes expected in keys is the "cipherKeyLen" used during the registration of the context.

### Returns:

♦ IX\_CRYPTO\_ACC\_STATUS\_SUCCESS : Keys were changed successfully.

♦ IX\_CRYPTO\_ACC\_STATUS\_CRYPTO\_CTX\_NOT\_VALID: cryptoCtxtId is not valid.

♦ IX\_CRYPTO\_ACC\_STATUS\_OPERATION\_NOT\_SUPPORTED: Returned when the context is not registered for doing operations on NPE C or if the operation was anything other than CCM.

♦ IX\_CRYPTO\_ACC\_STATUS\_FAIL: If the component has not been initialized.

♦ Reentrant : yes♦ ISR Callable : yes

Crypto context registration. Cryptographic Context ID (cryptoCtxId) for the registered crypto context obtained from this registration request will be used in perform service requests.

This function is used to register all the required information (eg. key, cipher algorithm, etc) for hardware accelerator services with IxCryptoAcc component. Those information will be stored in CCD database. All the information will be converted into a cryptographic parameters structure to be shared with NPE. The structure will be associated with a unique crypto context ID (cryptoCtxId). cryptoCtxId is passed back to client for future reference in callback function and also for hardware accelerator service requests. Besides, two empty mbuf are required to be passed in through interface for the use of access component and NPE to compute the primary and secondary initial chaining variables. pMbufPrimaryChainVar and pMbufSecondaryChainVar mbuf pointers must be NULL if authentication or combined service is not selected. When initializing authentication context for WEP CRC (i.e when auth algo is IX\_CRYPTO\_ACC\_AUTH\_WEP\_CRC), variables authKeyLen and keys should be ignored. The authDigestLen should be set to IX\_CRYPTO\_ACC\_WEP\_CRC\_DIGEST\_32.

Client should send in perform service request based on the crypto context registered. 2 different applications are supported by calling different perform functions as below:

- 1. If the crypto context is registered for crypto hardware accelerator service (DES, 3DES, AES, MD5, SHA1), client could only call the crypto hw accelerator perform function listed below: ixCryptoAccAuthCryptPerform ()
- 2. If the crypto context is registered for WEP services (WEP\_ARC4, WEP\_CRC), client could only call the WEP perform functions listed below: ixCryptoAccNpeWepPerform () ixCryptoAccXScaleWepPerform ()

### Note:

3 scenarios of crypto context registration depending on authentication key size (in bytes) (only applicable to HMAC–SHA1 and HMAC–MD5): 1. If ( $L \le \text{key size} \le 64$ ), then call this API (ixCryptoAccCtxRegister) directly. L = 16 for MD5 and L = 20 for SHA1. 2. If (key size > 64), then authentication key needs to be hashed to become shorter key first by calling another API ixCryptoAccHashKeyGenerate (). Please follow steps below for this case

- ♦ Call ixCryptoAccHashKeyGenerate () to hash the authentication key
- ♦ Wait for the callback from ixCryptoAccHashKeyGenerate (). Copy generated authentication key from mbuf into IxCryptoAccCtx as authentication key.
- ♦ Call this API (ixCryptoAccCtxRegister) to register the context. 3. If (key size < L), client MUST pad the authentication key with 0s to become L bytes of key before calling this API (ixCryptoAccCtxRegister).

Context registration concept is not applicable to PKE acceleration operations (such as EAU perform, Pseudo-random Number Get, PKE SHA engine hashing).

### Parameters:

\*pAccCtx

IxCryptoAccCtx [in] – is a pointer to hardware accelerator context. Information required in hardware accelerator context, such as key and algorithm configuration can be extracted from Security Association Database (SAD). Important Note: When the crypt algorithm is ARC4, the keys supplied during the registration process are ignored. The caller should pass the per packet keys in the ixCryptoAccXScaleWepPerform function's pIV parameter.

\*pMbufPrimaryChainVar

[in] – a pointer to an empty mbuf(must not be chained) for the use of access component to compute primary chaining variables for SHA1/MD5. This mbuf structure is allocated by the client (minimum size of the cluster required is 64 bytes), only if SHA1/MD5 is selected, and the mbuf pointer must be NULL if SHA1/MD5 is not selected. After the NPE complete the computation, the mbuf is returned separately through the client's registered callback.

\*pMbufSecondaryChainVar

[in] – a pointer to an empty mbuf(must not be chained) for the use of access component to compute secondary chaining variables for SHA1/MD5. This mbuf structure is allocated by the client (minimum size of the cluster required is 64 bytes), only if SHA1/MD5 is selected, and the mbuf pointer must be NULL if SHA1/MD5 is not selected. After the NPE complete the computation, the mbuf is returned separately through the client's registered callback.

registerCallbackFn

IxCryptoAccRegisterCompleteCallback [in] callback function pointer to return crypto context registration status to client when the registration is complete. This cannot be NULL.

performCallbackFn

IxCryptoAccPerformCompleteCallback [in] callback function pointer to return the processed buffer to the client with respect to the unique CryptoCtxId. This cannot be NULL, however this function will not be called if its the requested to be executed by the engine running on Intel XScale(R) Core.

\*pCryptoCtxId

UINT32 [inout] – Crypto Context ID returned by access

component for the crypto context registered.

#### Returns:

- ♦ IX\_CRYPTO\_ACC\_STATUS\_SUCCESS Registration parameters are valid
- ♦ IX\_CRYPTO\_ACC\_STATUS\_FAIL Registration failed for some unspecified internal reasons.
- ♦ IX\_CRYPTO\_ACC\_STATUS\_OPERATION\_NOT\_SUPPORTED Invalid operation requested by the client.
- ♦ IX\_CRYPTO\_ACC\_STATUS\_CIPHER\_ALGO\_NOT\_SUPPORTED Invalid cipher algorithm requested by the client.
- ♦ IX\_CRYPTO\_ACC\_STATUS\_CIPHER\_MODE\_NOT\_SUPPORTED Invalid cipher mode requested by the client.
- ♦ IX CRYPTO ACC STATUS CIPHER INVALID KEY LEN Invalid cipher key length passed in by the client.
- ♦ IX CRYPTO ACC STATUS CIPHER INVALID BLOCK LEN Invalid cipher block

length passed in by the client

- ♦ IX\_CRYPTO\_ACC\_STATUS\_CIPHER\_INVALID\_IV\_LEN Invalid IV length passed in by the client.
- ♦ IX\_CRYPTO\_ACC\_STATUS\_AUTH\_ALGO\_NOT\_SUPPORTED Invalid authentication algorithm requested by the client.
- ♦ IX\_CRYPTO\_ACC\_STATUS\_AUTH\_INVALID\_DIGEST\_LEN Invalid authentication digest length.
- ♦ IX\_CRYPTO\_ACC\_STATUS\_AUTH\_INVALID\_KEY\_LEN Invalid authentication key length.
- ♦ IX\_CRYPTO\_ACC\_STATUS\_EXCEED\_MAX\_TUNNELS Exceed maximum tunnels permitted.
- ♦ IX\_CRYPTO\_ACC\_STATUS\_QUEUE\_FULL Queue full status returned and the registration request will be rejected.
- ♦ Reentrant : yes♦ ISR Callable : no

### **IxCryptoAccStatus** ixCryptoAccCtxUnregister ( UINT32 cryptoCtxId )

Unregister the crypto context from Cryptographic Context Database.

This function is for freeing the particular crypto context (reference through CryptoCtxId) from the Cryptographic Context Database.

### Parameters:

cryptoCtxId UINT32 [in] – is pointer to crypto context that is required to be freed, which will be supplied by the client. The CryptoCtxId must be a valid Id.

### Returns:

- ♦ IX\_CRYPTO\_ACC\_STATUS\_SUCCESS successfully unregister the crypto context.
- ♦ IX\_CRYPTO\_ACC\_STATUS\_FAIL Unregistration failed for some unspecified internal reasons, e.g. uninitialized.
- ♦ IX\_CRYPTO\_ACC\_STATUS\_CRYPTO\_CTX\_NOT\_VALID invalid crypto context.
- ♦ IX\_CRYPTO\_ACC\_STATUS\_RETRY retry the unregister operation as there are still some ixCryptoAccAuthCryptPerform requests associated with the cryptoCtxId pending on the NPE queue.
- ♦ Reentrant : yes♦ ISR Callable : no

### **Assumption:**

• It is client's responsibility to ensure no pending requests for the crypto context before it proceeds to

| IxCryptoAccStatus ixCryptoAccHashKeyGenerate | ( IxCryptoAccAuthAlgo                | hashAlgo,                   |
|----------------------------------------------|--------------------------------------|-----------------------------|
|                                              | IX_OSAL_MBUF *                       | pMbufHashKey,               |
|                                              | IxCryptoAccHashKeyGenCompleteCallbac | <b>k</b> hashKeyCallbackFn, |
|                                              | UINT16                               | hashKeyStartOffset,         |
|                                              | UINT16                               | hashKeyLen,                 |
|                                              | UINT16                               | hashKeyDestOffset,          |
|                                              | UINT32 *                             | pHashKeyId                  |
|                                              | )                                    |                             |

This function is used to generate authentication key needed in HMAC authentication if the authentication key is greater than 64 bytes. New authentication key of L bytes size will be generated in this function (L = 20 for SHA1, L = 16 for MD5). Please refer to RFC2104 for more details on the key size. The authentication key is padded (extended) so that its length (in bits) is congruent to 448, modulo 512 (please refer to RFC1321 & RFC3174). Authentication key is padded inside cryptoAcc on the mbuf which holds the authentication key. Therefore, mbuf allocated to store authentication key need to take into account the space needed for padding process. Padding space (extra memory allocation) needed is between the range of 9-72 bytes, it varies based on the authentication key size specified by client. Minimum of 9 bytes are needed, as 8 bytes is for total length of authentication key (hash data), and 1 bytes is for start of padding indication. The extra padding space is derived from the padding scheme stated in RFC1321 & RFC3174.

This function has been extended to become a generic hashing function other than above mentioned functionality. It could be used to hash any key size or data that are greater than 0 and less than 65399 bytes. In order to map to extention of functioality, this function has been aliased to a name ixCryptoAccHashPerform. The hashing operation is carried out by NPE. The request will be sent to NPE for further processing.

### Note:

1. This API will need to be called if the authentication key > 64 bytes. If key size is >=L and <= 64 bytes, authentication key is used directly in Crypto context for registration, no further hashing is needed. 2. This function must be called prior the Crypto Context registration if the key size > 64. Result from this function will be used as authentication key in the Crypto Context registration. 3. It is client's responsibility to ensure the mbuf is big enough to hold the result (generated authentication key) and for padding process stated. No checking on mbuf length will be done.

### Parameters:

hashAlgo

|               | the hash key. hashAlgo used to generate the key must be the same algorithm      |
|---------------|---------------------------------------------------------------------------------|
|               | that will be used in crypto register and crypto perform services.               |
| *pMbufHashKey | [in] – a pointer to an mbuf that contains the authentication key to be hashed.  |
|               | This mbuf structure is allocated by the client and the mbuf pointer must not be |
|               | NULL. After the NPE complete the computation, the mbuf is returned              |
|               | separately through the client's registered callback. The authentication key     |
|               | generated will be stored in this mbuf, pointed by hashKeyDestOffset. This       |
|               | must NOT be a chained mbuf.                                                     |

**IxCryptoAccAuthAlgo** [in] – is hashing algorithm to be used in generating

120

hashKeyCallbackFn IxCryptoAccHashKeyGenCompleteCallback [in] – callback function pointer to be called when the hash key generation operation is completed. This

cannot be NULL.

hashKeyStartOffset UINT16 [in] – offset to the mbuf mdata which contain the original hash key.

hashKeyLen UINT16 [in] – key size

hashKeyDestOffset UINT16 [in] - offset to the mbuf mdata to store the generated result

(authentication key)

\*pHashKeyId UINT32 [inout] – Hash Key ID returned by access component to identify hash

key generation.

### Returns:

♦ IX\_CRYPTO\_ACC\_STATUS\_SUCCESS – Hash key generation parameters are valid

♦ IX CRYPTO ACC STATUS FAIL – Hash key generation failed.

♦ IX\_CRYPTO\_ACC\_STATUS\_AUTH\_ALGO\_NOT\_SUPPORTED – Invalid hash algorithm requested by the client.

♦ IX\_CRYPTO\_ACC\_STATUS\_AUTH\_INVALID\_KEY\_LEN – Invalid hash key length (0 == hashKeyLen or 65399 < hashKeyLen)

♦ IX\_CRYPTO\_ACC\_STATUS\_QUEUE\_FULL – Queue full status returned and the authentication key generation request will be rejected.

♦ Reentrant : yes♦ ISR Callable : no

### IxCryptoAccStatus ixCryptoAccInit (void)

Initialise the Security Access component.

This function will initialize all the internal resources of IxCryptoAcc access component depending upon the configuration set by the ixCryptoAccConfig function. When Hardware Accelerator engine is specified, it will check whether the specified AES, DES osr hash coprocessor is present and issue a warning if not. When WEP engine is specified, it checks whether AAL coprocessor is present or not. This function will check whether PKE (public key exchange) Crypto Unit is present or not and issue warning if not. If PKE Crypto Engine does not exist, the subsequent call to PKE Crypto Engine related APIs will be rejected.

This function should be called before any request processing functions are invoked on the component. This function is called only once.

### Returns:

♦ IX\_CRYPTO\_ACC\_STATUS\_SUCCESS – successfully initialize the component; a warning is issued if coprocessor is not present.

♦ IX\_CRYPTO\_ACC\_STATUS\_FAIL – Initialization failed for some unspecified internal reasons.

♦ Reentrant : no♦ ISR Callable : no

```
IxCryptoAccStatus ixCryptoAccNpeWepPerform (UINT32
                                                              cryptoCtxId,
                                            IX_OSAL_MBUF * pSrcMbuf,
                                            IX_OSAL_MBUF * pDestMbuf,
                                            UINT16
                                                              startOffset,
                                            UINT16
                                                              dataLen,
                                                              icvOffset,
                                            UINT16
                                            UINT8 *
                                                              pKey
```

Function to invoke ARC4 and WEP ICV computations on NPE.

This function submits the request to the NPE to perform ARC4 and WEP ICV operations. If the request was not submitted to the NPE, the function returns failure and the client has the ownership of the buffers. If the function returns success, then request is in the request queue or is being executed by the NPE and the client should not assume the ownership of the buffers. When the processing of the request completes, the performCallBackFn is called with the buffer pointers submitted initially and the client can then assume the ownership of the buffers. When WEP ICV verification operation is requested, the computed ICV is written out at the ICV location for in-place mode of operation. The supplied ICV is overwritten as a result. For non-inplace mode of operation, the ICV is written out at the destination mbuf and the original ICV from the source is left intact. This behavior is true irrespective whether it's WEP ICV verify or a combined

• ARC4 decrypt and WEP ICV request.

A valid cryptoCtxId must be obtained via ixCryptoAccCtxRegister API in order to proceed to perform the functionalities above.

#### Parameters:

```
cryptoCtxId UINT32 [in] – is the crypto context id to be supplied by the client. This is obtained by
            calling ixCryptoAccCtxRegister function.
```

[in] – is a pointer to mbuf which contains data to be processed. This mbuf structure is allocated by client. Result of this request will be stored in the same mbuf and overwritten the original data if UseDifferentSrcAndDestMbufs flag in **IxCryptoAccCtx** is set to FALSE (in–place operation). Otherwise, if UseDifferentSrcAndDestMbufs flag is set to TRUE, the result will be written into destination mbuf (non in-place operation) and the original data in this mbuf will remain unchanged.

\*pDestMbuf[in] - only used if UseDifferentSrcAndDestMbufs is TRUE. This is the buffer where the result is written to. This mbuf structure is allocated by client. The length of mbuf MUST be big enough to hold the result of operation. The result of operation COULD NOT span into two or more different mbufs, thus the mbuf supplied must be at least the length of expected result. The data is written back starting at startOffset in the pDestMbuf.

startOffset UINT16 [in] – supplied by the client to indicate the start of the payload to be

decrypted/encrypted or authenticated.

dataLen UINT16 [in] – supplied by the client to indicate the length of the payload to be

decrypted/encrypted in number of bytes.

icvOffset UINT16 [in] – supplied by the client to indicate the start of the ICV (Integrity Check Value) used for the authentication. This ICV field should not be split across multiple

mbufs in a chained mbuf.

\*pKey

UINT8 [in] – Pointer to IX\_CRYPTO\_ACC\_ARC4\_KEY\_128 bytes of per packet ARC4 keys. This pointer can be NULL if the request is WEP IV gen or verify only.

#### Returns:

- ♦ IX\_CRYPTO\_ACC\_STATUS\_SUCCESS The parameters check passed and the request was submitted to the NPE.
- ♦ IX\_CRYPTO\_ACC\_STATUS\_FAIL The request failed because there was a parameter inconsistency or an invalid valid operation was requested.

#### Note:

♦ Depending upon the operating system and task switching mechanism, the operation might "seem" to complete before this function returns to the caller. However, the return status with value success only implies that the request was successfully enqueued to the hardware accelerator. The call of performCallBackFn indicates the completion of operation by the hardware engine.

Reentrant : yesISR Callable : yes

```
IxCryptoAccStatus ixCryptoAccPkeEauExpConfig ( BOOL enableSE, BOOL enableFE )
```

This function is used to configure short exponent setting (SE – skipping leading 0s while performing modular exponential) and fast exponent setting (FE – skipping all 0s while performing modular exponential) for EAU modular exponential operation. By default, these 2 settings are DISABLED to prevent timing attacks on keys and also ensure best protection on keys. These 2 setting will have direct impact on function call to **ixCryptoAccPkeEauPerform**. Client may change it accordingly to achieve different level of protection and also performance.

#### Note:

EAU exponential configuration is global setting for cryptoAcc component. All the function call to **ixCryptoAccPkeEauPerform** will follow these setting when performing modular exponential operation.

#### Parameters:

```
enableSE BOOL [in] If TRUE, then SE is enabled. enableFE BOOL [in] If TRUE, then FE is enabled.
```

#### Returns:

- ♦ IX\_CRYPTO\_ACC\_STATUS\_SUCCESS EAU exponential configuration is set successfully
- ♦ IX\_CRYPTO\_ACC\_STATUS\_FAIL Configuration failed.
- ♦ Reentrant : no♦ ISR Callable : yes

#### 

This function is used to performed large number exponential arithmetic operation requested by client by using EAU (Exponentiation Acceleration Unit) on PKE (Public Key Exchange) Crypto Engine. The result computed will be returned via callback function supplied by client. All the operand size must be specified in words (32–bit), the output data pointer must be big enough to hold the result.

```
Large Number Computation operation supported on EAU
 1. Modular Exponential ( C = M^e MOD N )
3 words <= N <= 64 words (2048 bits)
1 word <= \{M, e\} <= 64 \text{ words with } M < N \text{ and } e < N \text{ in value}
MSB and LSB of N = 1
sizeof(C) >= sizeof(N)
 2. Large Number Multiplication ( R = A * B )
1 word <= {A, B} <= 64 words (2048-bit)
sizeof(R) >= sizeof(A) + sizeof(B)
 3. Large Number Addition ( Carry | R = A + B )
1 word <= {A, B} <= 64 words (2048-bit)
sizeof(R) >= sizeof(A) or sizeof(B); whichever is greater
Carry bit might be set in operation of addition, carry bit status is
        passed to the client in callback
 4. Modular Reduction ( R = A MOD N )
3 word <= N <= 64 words (2048-bit)
1 word <= A <= 128 words (4096-bit) with sizeof(A) <= 2 * sizeof(N)
MSB of N = 1
sizeof(R) >= sizeof(N)
 5. Large Number Subtraction (Borrow | R = A - B)
1 word <= {A, B} <= 64 words (2048-bit)
sizeof(R) >= sizeof(A) or sizeof(B); whichever is greater
Borrow bit might be set in operation of subtraction, borrow bit status
        is passed to the client in callback
```

#### Note:

- 1. All the result of exponential (C), add/sub/mul/mod (R) will be retured in callback via \*pResult.
- 2. This API is designed to offload the large number operation needed for PKE. 3. Only one request can be processed by the EAU co-processor on PKE bridge at one time, queuing system was not implemented. 4. This API is only targeted for network processors Intel (R) IXP4XX Product Line of Network Processors which support it. 5. By default, short exponent (skipping leading 0s in modular exponential) and fast exponent (skipping all 0s in modular exponential) are disabled. This

is to prevent timing attacks on keys and also ensure best protection. Client may choose to enabled SE & FE by calling **ixCryptoAccPkeEauExpConfig** function. 6. It is client's responsibility to ensure that the result pointer buffer is cleared to zero for the case of buffer size is greater than the actual result returned.

#### Parameters:

\*pOpr IxCryptoAccPkeEauInOperands [in] – a structure pointer which contains

input operands (data pointers and data length). length. This data structure is allocated by the client and the data pointers inside the structure must not be NULL depending on EAU operation requested. The data length of operand

also must be within the range supported.

 $eau Perform Callback Fn \ \textbf{IxCryptoAccPkeEauPerformCompleteCallback} \ [in] - callback \ function$ 

pointer to be called when the EAU operation is completed. This cannot be

NULL.

\*pResult IxCryptoAccPkeEauOpResult [out] – a structure pointer which store

EAU operation result. Size of output data pointer must be big enough to hold the result computed. This structure must remain valid until the EAU operation requested is complete and client's callback is called. This pointer

will be passed back to the client in callback to return the result.

#### Returns:

♦ IX\_CRYPTO\_ACC\_STATUS\_SUCCESS – EAU operation start successfully

♦ IX\_CRYPTO\_ACC\_STATUS\_FAIL – EAU operation request failed.

♦ IX\_CRYPTO\_ACC\_STATUS\_OUT\_OF\_RANGE\_ERR – Invalid operand length / range

♦ IX\_CRYPTO\_ACC\_STATUS\_NULL\_PTR\_ERR – NULL pointer error, input or output data pointers are NULL.

♦ IX\_CRYPTO\_ACC\_STATUS\_OPERATION\_NOT\_SUPPORTED – invalid operation requested.

♦ IX\_CRYPTO\_ACC\_STATUS\_RETRY – coprocessor is busy and the request is rejected, resend the request after a random interval.

♦ Reentrant : yes

♦ ISR Callable : yes

# IxCryptoAccStatus ixCryptoAccPkeHashPerform UINT8 \* pHashData, UINT32 hashDataLen, IxCryptoAccPkeHashPerformCompleteCallbackhashPerformCallbackFn, UINT8 \* pDigest

This function is used to hash the input data and return the digest generated via callback function supplied by client. L bytes size of digest will be generated (L = 20 for SHA1). The hash data is padded inside the function so that its length (in bits) is congruent to 448, modulo 512 (please refer to RFC1321). The length of data in bytes to be hashed must be greater than 0.

#### Note:

1. This API will use the hash engine on PKE (Public Key Exchange) bridge and not NPE. 2. The hash algorithm supported is SHA–1 ONLY. 3. This API is designed to offload the hashing operation needed for PKE. 4. This API will use more Intel XScale(R) Core bandwidth compared to NPE hashing API ixCryptoAccHashPerform as Intel XScale(R) Core will act as the master to the SHA engine on PKE Crypto Engine to kick off hashing operation. This involves memory accessing (read/write) from Intel XScale(R) Core to SHA engine. 5. Client can decide to either hashing data by using SHA engine on PKE Crypto Engine or NPE hashing co–processor depend on their needs and interface. The input data is a flat buffer for this API and is IX\_OSAL\_MBUF for ixCryptoAccHashPerform on NPE. 6. ixCryptoAccPkeHashPerform will ensure that the hashing request is processed immediately if PKE SHA engine is not busy. However, hashing request to NPE will be enqueued into AQM hardware queues. It might take longer time to have hashing done if the queue is full with other bulk encryption / authentication requests. 7. Only one request can be processed by the SHA engine on PKE Crypto Engine at one time, queuing system was not implemented. 8. This API is only targeted for network processors Intel (R) IXP4XX Product Line of Network Processors which support it.

#### Parameters:

hashAlgo IxCryptoAccAuthAlgo [in] – hashing algorithm to be used. Only SHA–1

is supported now. This parameter was introduced for future expansion since only 1 hash algorithm is supported now. Other hashing algo will be

rejected.

\*pHashData UINT8 [in] – a pointer to a flat buffer that contains the data to be hashed.

This buffer is allocated by the client and the buffer pointer must not be NULL. This buffer should hold the data to be hashed until Intel XScale(R) Core complete the hashing operation and the client's callback is called The

digest is returned separately through the client's callback.

hashDataLen UINT32 [in] – hash data size in bytes

 $hash Perform Callback Fn \ \textbf{IxCryptoAccPkeHashPerformCompleteCallback} \ [in] - callback$ 

function pointer to be called when the hashing operation is completed.

This cannot be NULL.

\*pDigest UINT8 [out] – a pointer to a flat buffer which will be used to hold the

digest computated. This buffer is allocated by the client and the buffer

pointer must not be NULL.

#### Returns:

♦ IX CRYPTO ACC STATUS SUCCESS – Hashing operation start successfully

♦ IX\_CRYPTO\_ACC\_STATUS\_FAIL – Hashing operation request failed

♦ IX\_CRYPTO\_ACC\_STATUS\_AUTH\_ALGO\_NOT\_SUPPORTED – Invalid hash algorithm requested by the client.

♦ IX\_CRYPTO\_ACC\_STATUS\_OUT\_OF\_RANGE\_ERR – Invalid hash data length (0 == hashDataLen or 65399 < hashDataLen)

- ♦ IX\_CRYPTO\_ACC\_STATUS\_NULL\_PTR\_ERR NULL pointer error, either pHashData, pDigest or callback function pointer is NULL.
- ♦ IX\_CRYPTO\_ACC\_STATUS\_RETRY coprocessor is busy and the request is rejected, resend the request after a random interval.

♦ Reentrant : yes♦ ISR Callable : yes

```
      IxCryptoAccStatus
      ixCryptoAccPkePseudoRandomNumberGet
      ( UINT32  pseudoRandomNumberLen, UINT32 * pPseudoRandomNumber
```

This function will return the pseudo-random number generated in hardware to the client via the data pointer supplied. The length of pseudo-random number requested must be in words count (pseudoRandomNumberLen >= 1 word). If bigger pseudo-random number is requested, then this function will take longer time to complete.

#### Note:

1. Client may randomize the output of RNG by calling **ixCryptoAccPkeHashPerform**. Output of this API is used as seed (hash data) to ixCryptoAccPkeHashPerform API. 2. The random number generator (RNG) resided in PKE (Public Key Exchange) Crypto Engine and not NPE. 3. This is synchronous function call, the pseudo–random number is ready when this function return. 4. This API is designed to generate pseudo–random number needed for PKE. 5. Only one request can be processed at one time, queuing system was not implemented. 6. This API is only targeted for network processors Intel (R) IXP4XX Product Line of Network Processors which support it.

#### Parameters:

\*pPseudoRandomNumberLen\* UINT32 [in] – pseudo–random number length in words

\*pPseudoRandomNumber\* UINT32 [out] – a pointer to a flat buffer which will be used to hold the random number generated. This buffer is allocated by the client and the buffer pointer must not be NULL.

#### Returns:

- ♦ IX\_CRYPTO\_ACC\_STATUS\_SUCCESS Pseudo random number get operation complete successfully.
- ♦ IX\_CRYPTO\_ACC\_STATUS\_FAIL operation failed
- ♦ IX CRYPTO ACC STATUS NULL PTR ERR pPseudoRandomNumber is NULL
- ♦ IX\_CRYPTO\_ACC\_STATUS\_OUT\_OF\_RANGE\_ERR pseudoRandomNumberLen <= 0
- ♦ IX\_CRYPTO\_ACC\_STATUS\_RETRY coprocessor is busy and the request is rejected, resend the request after a random interval.
- ♦ Reentrant : yes♦ ISR Callable : yes

#### void ixCryptoAccShow (void)

API for printing statistics and status.

This function is called by the client to print statistics, such as number of packets returned with operation fail, number of packets encrypted/decrypted/authenticated while the function also print the current status of the queue, whether the queue is empty or full or current queue length.

This function also print out statistics of large number arithmetic operation counter and counter of hashing operation done on PKE Crypto Engine if PKE Crypto Engine is present.

#### Returns:

None

Reentrant : yesISR Callable : no

#### void ixCryptoAccShowWithId (UINT32 cryptoCtxId)

API for printing statistic and status.

This function prints all the statistics provided by ixCryptoAccShow. In addition the function will print out the contents of the Crypto Context corresponding to the CryptoCtxId supplied through the API

#### Parameters:

cryptoCtxId UINT32 [in] - Crypto Context ID which has been registered

#### Returns:

None

Reentrant : yesISR Callable : no

#### **IxCryptoAccStatus** ixCryptoAccUninit (void )

Uninitialise the Security Access component.

#### Note:

This function should be used to replace the ixCryptoAccCryptoServiceStop function.

#### Parameters:

none

#### Returns:

♦ IX\_CRYPTO\_ACC\_STATUS\_SUCCESS – successfully uninitialize the component.

```
    ♦ IX_CRYPTO_ACC_STATUS_FAIL – fail to uninitialize the component.
    ♦ Reentrant : no
    ♦ ISR Callable : no
```

Function to support ARC4 and WEP ICV computations on Intel XScale(R) Core.

This function executes ARC4 and WEP ICV algorithms on Intel XScale(R) Core. The request is not forwarded to the NPE. The operation is executed on Intel XScale(R) Core synchronously and therefore the perform done call back function would not be called on its return. The caller can assume the ownership of the buffers when the function returns. Restrictions: This function does not support non–in–place mode of operation. When WEP ICV verification operation is requested, the computed ICV is written out at the ICV location for in–place mode of operation. The supplied ICV is overwritten as a result. This behavior is true irrespective whether it's WEP ICV verify or a combined

• ARC4 decrypt and WEP ICV request.

A valid cryptoCtxId must be obtained via **ixCryptoAccCtxRegister** API in order to proceed to perform the functionalities above.

#### Parameters:

*cryptoCtxId* UINT32 [in] – is the crypto context id to be supplied by the client. This is obtained by calling ixCryptoAccCtxRegister function.

\*pSrcMbuf [in] – is a pointer to mbuf which contains data to be processed. This mbuf structure is allocated by client. Result of this request will be stored in the same mbuf and overwritten the original data if UseDifferentSrcAndDestMbufs flag in IxCryptoAccCtx is set to FALSE (in–place operation). Otherwise, if UseDifferentSrcAndDestMbufs flag is set to TRUE, the result will be written into destination mbuf (non in–place operation) and the original data in this mbuf will remain unchanged.

\*pDestMbuf [in] – only used if UseDifferentSrcAndDestMbufs is TRUE. This is the buffer where the result is written to. This mbuf structure is allocated by client. The length of mbuf MUST be big enough to hold the result of operation. The result of operation COULD NOT span into two or more different mbufs, thus the mbuf supplied must be at least the length of expected result. The data is written back starting at startOffset in the pDestMbuf. Non–in–place operations are not supported therefore this parameter is ignored for now.

startOffset UINT16 [in] – supplied by the client to indicate the start of the payload to be decrypted/encrypted or authenticated.

dataLen

UINT16 [in] – supplied by the client to indicate the length of the payload to be decrypted/encrypted in number of bytes.

icvOffset UINT16 [in] – supplied by the client to indicate the start of the ICV (Integrity Check

Value) used for the authentication. This ICV field should not be split across multiple

mbufs in a chained mbuf.

\*pKey UINT8 [in] – Pointer to IX\_CRYPTO\_ACC\_ARC4\_KEY\_128 bytes of per packet

ARC4 keys. This pointer can be NULL if the request is WEP IV gen or verify only.

#### Note:

This function operates synchronously and will not return status until the operation is completed.

#### Returns:

- ♦ IX\_CRYPTO\_ACC\_STATUS\_SUCCESS The specified operation was performed successfully. If the operation type was WEP ICV verify, then this value means the verification was success as well.
- ♦ IX\_CRYPTO\_ACC\_STATUS\_FAIL The request failed because there was a parameter inconsistency or an invalid valid operation was requested.
- ♦ IX\_CRYPTO\_ACC\_STATUS\_AUTH\_FAIL— The specified operation was performed, but the WEP ICV verification failed.
- ♦ IX CRYPTO ACC STATUS CRYPTO CTX NOT VALID Crypto context is invalid.

#### Note:

Statistics collection for Intel XScale(R) Core WEP perform will only be enabled in DEBUG mode. Interrupt locking mechanism is used in protecting the critical section for statistic collection.

Reentrant : yesISR Callable : yes

Function Documentation

130

# Intel (R) IXP400 Software DMA Types (IxDmaTypes)

The common set of types used in the DMA component.

#### **Enumerations**

```
enum IxDmaReturnStatus {
     IX DMA SUCCESS,
     IX_DMA_FAIL,
     IX DMA INVALID TRANSFER WIDTH,
     IX_DMA_INVALID_TRANSFER_LENGTH,
     IX_DMA_INVALID_TRANSFER_MODE,
     IX DMA INVALID ADDRESS MODE,
     IX_DMA_REQUEST_FIFO_FULL
    Dma return status definitions.
enum IxDmaTransferMode {
     IX_DMA_COPY_CLEAR,
     IX DMA COPY,
     IX_DMA_COPY_BYTE_SWAP,
     IX_DMA_COPY_REVERSE,
     IX DMA TRANSFER MODE INVALID
    Dma transfer mode definitions.
enum IxDmaAddressingMode {
     IX DMA INC SRC INC DST,
     IX_DMA_INC_SRC_FIX_DST,
     IX DMA FIX SRC INC DST,
     IX_DMA_FIX_SRC_FIX_DST,
     IX\_DMA\_ADDRESSING\_MODE\_INVALID
    Dma addressing mode definitions.
enum IxDmaTransferWidth {
     IX_DMA_32_SRC_32_DST,
     IX DMA 32 SRC 16 DST,
     IX_DMA_32_SRC_8_DST,
     IX DMA 16 SRC 32 DST.
     IX_DMA_16_SRC_16_DST,
     IX_DMA_16_SRC_8_DST,
     IX DMA 8 SRC 32 DST,
     IX_DMA_8_SRC_16_DST,
     IX DMA 8 SRC 8 DST,
     IX_DMA_8_SRC_BURST_DST,
     IX_DMA_16_SRC_BURST_DST,
     IX DMA 32 SRC BURST DST,
```

```
IX_DMA_BURST_SRC_8_DST,
IX_DMA_BURST_SRC_16_DST,
IX_DMA_BURST_SRC_32_DST,
IX_DMA_BURST_SRC_BURST_DST,
IX_DMA_TRANSFER_WIDTH_INVALID

}

Dma transfer width definitions Fixed addresses (either source or destination) do not support burst transfer width.

enum IxDmaNpeId {
    IX_DMA_NPEID_NPEA,
    IX_DMA_NPEID_NPEB,
    IX_DMA_NPEID_NPEC,
    IX_DMA_NPEID_MAX
    }

NpeId numbers to identify NPE A, B or C.
```

# **Detailed Description**

The common set of types used in the DMA component.

# **Enumeration Type Documentation**

#### enum IxDmaAddressingMode

Dma addressing mode definitions.

#### Note:

Fixed source address to fixed destination address addressing mode is not supported.

#### **Enumeration values:**

IX\_DMA\_INC\_SRC\_INC\_DST Incremental source address to incremental

destination address.

IX\_DMA\_INC\_SRC\_FIX\_DST Incremental source address to incremental

destination address.

IX\_DMA\_FIX\_SRC\_INC\_DST Incremental source address to incremental

destination address.

IX\_DMA\_FIX\_SRC\_FIX\_DST Incremental source address to incremental

destination address.

IX\_DMA\_ADDRESSING\_MODE\_INVALID Invalid Addressing Mode.

Definition at line 65 of file IxDmaAcc.h.

#### enum IxDmaNpeId

NpeId numbers to identify NPE A, B or C.

#### Warning:

This enum is deprecated and will be removed in future IXP400 Software release. Please use IxNpeDlNpeId enum instead.

#### **Enumeration values:**

IX\_DMA\_NPEID\_NPEA Identifies NPE A.IX\_DMA\_NPEID\_NPEB Identifies NPE B.IX\_DMA\_NPEID\_NPEC Identifies NPE C.IX\_DMA\_NPEID\_MAX Total Number of NPEs.

Definition at line 109 of file IxDmaAcc.h.

#### enum IxDmaReturnStatus

Dma return status definitions.

#### Enumeration values:

IX\_DMA\_SUCCESS DMA Transfer

Success.

IX\_DMA\_FAIL DMA Transfer

Fail.

IX\_DMA\_INVALID\_TRANSFER\_WIDTH Invalid transfer

width.

IX\_DMA\_INVALID\_TRANSFER\_LENGTH Invalid transfer

length.

IX\_DMA\_INVALID\_TRANSFER\_MODE Invalid transfer

mode.

IX\_DMA\_INVALID\_ADDRESS\_MODE Invalid address

mode.

IX\_DMA\_REQUEST\_FIFO\_FULL DMA request

queue is full.

Definition at line 33 of file IxDmaAcc.h.

#### enum IxDmaTransferMode

Dma transfer mode definitions.

#### Note:

Copy and byte swap, and copy and reverse modes only support multiples of word data length.

#### **Enumeration values:**

IX\_DMA\_COPY\_CLEAR copy and clear source

IX\_DMA\_COPY copy

IX\_DMA\_COPY\_BYTE\_SWAP copy and byte swap (endian)IX\_DMA\_COPY\_REVERSE copy and reverseIX\_DMA\_TRANSFER\_MODE\_INVALID Invalid transfer mode.

Definition at line **50** of file **IxDmaAcc.h**.

#### enum IxDmaTransferWidth

Dma transfer width definitions Fixed addresses (either source or destination) do not support burst transfer width.

#### **Enumeration values:**

| IX_DMA_32_SRC_16_DST32-bit src to 16-bit dstIX_DMA_32_SRC_8_DST32-bit src to 8-bit dstIX_DMA_16_SRC_32_DST16-bit src to 32-bit dstIX_DMA_16_SRC_16_DST16-bit src to 16-bit dstIX_DMA_16_SRC_8_DST16-bit src to 8-bit dstIX_DMA_8_SRC_32_DST8-bit src to 32-bit dstIX_DMA_8_SRC_16_DST8-bit src to 16-bit dstIX_DMA_8_SRC_8_DST8-bit src to 8-bit dstIX_DMA_8_SRC_BURST_DST8-bit src to burst dst - Not supported for fixed destination addressIX_DMA_16_SRC_BURST_DST16-bit src to burst dst - Not supported for fixed destination addressIX_DMA_32_SRC_BURST_DST32-bit src to burst dst - Not supported for fixed destination addressIX_DMA_BURST_SRC_8_DSTburst src to 8-bit dst - Not supported for fixed source addressIX_DMA_BURST_SRC_16_DSTburst src to 16-bit dst - Not supported for fixed source addressIX_DMA_BURST_SRC_32_DSTburst src to 16-bit dst - Not supported for fixed source addressIX_DMA_BURST_SRC_32_DSTburst src to 32-bit dst - Not supported for fixed source addressIX_DMA_BURST_SRC_BURST_DSTburst src to burst dst - Not supported for fixed source addressIX_DMA_BURST_SRC_BURST_DSTburst src to burst dst - Not supported for fixed source and destination addressIX_DMA_TRANSFER_WIDTH_INVALIDInvalid transfer width. | IX_DMA_32_SRC_32_DST                | 32-bit src to 32-bit dst                          |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|---------------------------------------------------|
| IX_DMA_16_SRC_32_DST16-bit src to 32-bit dstIX_DMA_16_SRC_16_DST16-bit src to 32-bit dstIX_DMA_16_SRC_8_DST16-bit src to 8-bit dstIX_DMA_8_SRC_32_DST8-bit src to 32-bit dstIX_DMA_8_SRC_16_DST8-bit src to 16-bit dstIX_DMA_8_SRC_8_DST8-bit src to 8-bit dstIX_DMA_8_SRC_BURST_DST8-bit src to burst dst - Not supported for fixed destination addressIX_DMA_16_SRC_BURST_DST16-bit src to burst dst - Not supported for fixed destination addressIX_DMA_32_SRC_BURST_DST32-bit src to burst dst - Not supported for fixed destination addressIX_DMA_BURST_SRC_8_DSTburst src to 8-bit dst - Not supported for fixed source addressIX_DMA_BURST_SRC_16_DSTburst src to 16-bit dst - Not supported for fixed source addressIX_DMA_BURST_SRC_32_DSTburst src to 32-bit dst - Not supported for fixed source addressIX_DMA_BURST_SRC_32_DSTburst src to 32-bit dst - Not supported for fixed source addressIX_DMA_BURST_SRC_BURST_DSTburst src to burst dst - Not supported for fixed source addressburst src to burst dst - Not supported for fixed source address                                                                                                                                                                                     | IX_DMA_32_SRC_16_DST                | 32-bit src to 16-bit dst                          |
| IX_DMA_16_SRC_16_DST16-bit src to 16-bit dstIX_DMA_16_SRC_8_DST16-bit src to 8-bit dstIX_DMA_8_SRC_32_DST8-bit src to 32-bit dstIX_DMA_8_SRC_16_DST8-bit src to 16-bit dstIX_DMA_8_SRC_8_DST8-bit src to 8-bit dstIX_DMA_8_SRC_BURST_DST8-bit src to burst dst - Not supported for fixed destination addressIX_DMA_16_SRC_BURST_DST16-bit src to burst dst - Not supported for fixed destination addressIX_DMA_32_SRC_BURST_DST32-bit src to burst dst - Not supported for fixed destination addressIX_DMA_BURST_SRC_8_DSTburst src to 8-bit dst - Not supported for fixed source addressIX_DMA_BURST_SRC_16_DSTburst src to 16-bit dst - Not supported for fixed source addressIX_DMA_BURST_SRC_32_DSTburst src to 32-bit dst - Not supported for fixed source addressIX_DMA_BURST_SRC_BURST_DSTburst src to burst dst - Not supported for fixed source addressIX_DMA_BURST_SRC_BURST_DSTburst src to burst dst - Not supported for fixed source address                                                                                                                                                                                                                                                                                              | IX_DMA_32_SRC_8_DST                 | 32-bit src to 8-bit dst                           |
| IX_DMA_16_SRC_8_DST16-bit src to 8-bit dstIX_DMA_8_SRC_32_DST8-bit src to 32-bit dstIX_DMA_8_SRC_16_DST8-bit src to 16-bit dstIX_DMA_8_SRC_8_DST8-bit src to 8-bit dstIX_DMA_8_SRC_BURST_DST8-bit src to burst dst - Not supported for fixed destination addressIX_DMA_16_SRC_BURST_DST16-bit src to burst dst - Not supported for fixed destination addressIX_DMA_32_SRC_BURST_DST32-bit src to burst dst - Not supported for fixed destination addressIX_DMA_BURST_SRC_8_DSTburst src to 8-bit dst - Not supported for fixed source addressIX_DMA_BURST_SRC_16_DSTburst src to 16-bit dst - Not supported for fixed source addressIX_DMA_BURST_SRC_32_DSTburst src to 32-bit dst - Not supported for fixed source addressIX_DMA_BURST_SRC_BURST_DSTburst src to burst dst - Not supported for fixed source addressIX_DMA_BURST_SRC_BURST_DSTburst src to burst dst - Not supported for fixed source address                                                                                                                                                                                                                                                                                                                                          | IX_DMA_16_SRC_32_DST                | 16-bit src to 32-bit dst                          |
| IX_DMA_8_SRC_32_DST8-bit src to 32-bit dstIX_DMA_8_SRC_16_DST8-bit src to 16-bit dstIX_DMA_8_SRC_8_DST8-bit src to 8-bit dstIX_DMA_8_SRC_BURST_DST8-bit src to burst dst - Not supported for fixed destination addressIX_DMA_16_SRC_BURST_DST16-bit src to burst dst - Not supported for fixed destination addressIX_DMA_32_SRC_BURST_DST32-bit src to burst dst - Not supported for fixed destination addressIX_DMA_BURST_SRC_8_DSTburst src to 8-bit dst - Not supported for fixed source addressIX_DMA_BURST_SRC_16_DSTburst src to 16-bit dst - Not supported for fixed source addressIX_DMA_BURST_SRC_32_DSTburst src to 32-bit dst - Not supported for fixed source addressIX_DMA_BURST_SRC_BURST_DSTburst src to burst dst - Not supported for fixed source addressburst src to burst dst - Not supported for fixed source address                                                                                                                                                                                                                                                                                                                                                                                                              | IX_DMA_16_SRC_16_DST                | 16-bit src to 16-bit dst                          |
| IX_DMA_8_SRC_16_DST8-bit src to 16-bit dstIX_DMA_8_SRC_8_DST8-bit src to 8-bit dstIX_DMA_8_SRC_BURST_DST8-bit src to burst dst - Not supported for fixed destination addressIX_DMA_16_SRC_BURST_DST16-bit src to burst dst - Not supported for fixed destination addressIX_DMA_32_SRC_BURST_DST32-bit src to burst dst - Not supported for fixed destination addressIX_DMA_BURST_SRC_8_DSTburst src to 8-bit dst - Not supported for fixed source addressIX_DMA_BURST_SRC_16_DSTburst src to 16-bit dst - Not supported for fixed source addressIX_DMA_BURST_SRC_32_DSTburst src to 32-bit dst - Not supported for fixed source addressIX_DMA_BURST_SRC_BURST_DSTburst src to burst dst - Not supported for fixed source address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | IX_DMA_16_SRC_8_DST                 | 16-bit src to 8-bit dst                           |
| IX_DMA_8_SRC_8_DST8-bit src to 8-bit dstIX_DMA_8_SRC_BURST_DST8-bit src to burst dst - Not supported for fixed destination addressIX_DMA_16_SRC_BURST_DST16-bit src to burst dst - Not supported for fixed destination addressIX_DMA_32_SRC_BURST_DST32-bit src to burst dst - Not supported for fixed destination addressIX_DMA_BURST_SRC_8_DSTburst src to 8-bit dst - Not supported for fixed source addressIX_DMA_BURST_SRC_16_DSTburst src to 16-bit dst - Not supported for fixed source addressIX_DMA_BURST_SRC_32_DSTburst src to 32-bit dst - Not supported for fixed source addressIX_DMA_BURST_SRC_BURST_DSTburst src to burst dst - Not supported for fixed source address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | IX_DMA_8_SRC_32_DST                 | 8-bit src to 32-bit dst                           |
| IX_DMA_8_SRC_BURST_DST8-bit src to burst dst - Not supported for fixed destination addressIX_DMA_16_SRC_BURST_DST16-bit src to burst dst - Not supported for fixed destination addressIX_DMA_32_SRC_BURST_DST32-bit src to burst dst - Not supported for fixed destination addressIX_DMA_BURST_SRC_8_DSTburst src to 8-bit dst - Not supported for fixed source addressIX_DMA_BURST_SRC_16_DSTburst src to 16-bit dst - Not supported for fixed source addressIX_DMA_BURST_SRC_32_DSTburst src to 32-bit dst - Not supported for fixed source addressIX_DMA_BURST_SRC_BURST_DSTburst src to burst dst - Not supported for fixed source address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | IX_DMA_8_SRC_16_DST                 | 8-bit src to 16-bit dst                           |
| destination address  IX_DMA_16_SRC_BURST_DST  16-bit src to burst dst - Not supported for fixed destination address  IX_DMA_32_SRC_BURST_DST  32-bit src to burst dst - Not supported for fixed destination address  IX_DMA_BURST_SRC_8_DST  burst src to 8-bit dst - Not supported for fixed source address  IX_DMA_BURST_SRC_16_DST  burst src to 16-bit dst - Not supported for fixed source address  IX_DMA_BURST_SRC_32_DST  burst src to 32-bit dst - Not supported for fixed source address  IX_DMA_BURST_SRC_BURST_DST  burst src to burst dst - Not supported for fixed source address  burst src to burst dst - Not supported for fixed source address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | IX_DMA_8_SRC_8_DST                  | 8-bit src to 8-bit dst                            |
| IX_DMA_16_SRC_BURST_DST16-bit src to burst dst - Not supported for fixed destination addressIX_DMA_32_SRC_BURST_DST32-bit src to burst dst - Not supported for fixed destination addressIX_DMA_BURST_SRC_8_DSTburst src to 8-bit dst - Not supported for fixed source addressIX_DMA_BURST_SRC_16_DSTburst src to 16-bit dst - Not supported for fixed source addressIX_DMA_BURST_SRC_32_DSTburst src to 32-bit dst - Not supported for fixed source addressIX_DMA_BURST_SRC_BURST_DSTburst src to burst dst - Not supported for fixed source address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | IX_DMA_8_SRC_BURST_DST              | 8-bit src to burst dst - Not supported for fixed  |
| destination address  IX_DMA_32_SRC_BURST_DST  32-bit src to burst dst - Not supported for fixed destination address  IX_DMA_BURST_SRC_8_DST  burst src to 8-bit dst - Not supported for fixed source address  IX_DMA_BURST_SRC_16_DST  burst src to 16-bit dst - Not supported for fixed source address  IX_DMA_BURST_SRC_32_DST  burst src to 32-bit dst - Not supported for fixed source address  IX_DMA_BURST_SRC_BURST_DST  burst src to burst dst - Not supported for fixed source address  burst src to burst dst - Not supported for fixed source address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                     | destination address                               |
| IX_DMA_32_SRC_BURST_DST32-bit src to burst dst - Not supported for fixed destination addressIX_DMA_BURST_SRC_8_DSTburst src to 8-bit dst - Not supported for fixed source addressIX_DMA_BURST_SRC_16_DSTburst src to 16-bit dst - Not supported for fixed source addressIX_DMA_BURST_SRC_32_DSTburst src to 32-bit dst - Not supported for fixed source addressIX_DMA_BURST_SRC_BURST_DSTburst src to burst dst - Not supported for fixed source address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | IX_DMA_16_SRC_BURST_DST             |                                                   |
| destination address  IX_DMA_BURST_SRC_8_DST  burst src to 8-bit dst - Not supported for fixed source address  IX_DMA_BURST_SRC_16_DST  burst src to 16-bit dst - Not supported for fixed source address  IX_DMA_BURST_SRC_32_DST  burst src to 32-bit dst - Not supported for fixed source address  IX_DMA_BURST_SRC_BURST_DST  burst src to burst dst - Not supported for fixed source address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                     | destination address                               |
| IX_DMA_BURST_SRC_8_DSTburst src to 8-bit dst - Not supported for fixed source addressIX_DMA_BURST_SRC_16_DSTburst src to 16-bit dst - Not supported for fixed source addressIX_DMA_BURST_SRC_32_DSTburst src to 32-bit dst - Not supported for fixed source addressIX_DMA_BURST_SRC_BURST_DSTburst src to burst dst - Not supported for fixed source and destination address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | IX_DMA_32_SRC_BURST_DST             | 32-bit src to burst dst – Not supported for fixed |
| address  IX_DMA_BURST_SRC_16_DST  burst src to 16-bit dst - Not supported for fixed source address  IX_DMA_BURST_SRC_32_DST  burst src to 32-bit dst - Not supported for fixed source address  IX_DMA_BURST_SRC_BURST_DST  burst src to burst dst - Not supported for fixed source and destination address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                     | destination address                               |
| <ul> <li>IX_DMA_BURST_SRC_16_DST</li> <li>burst src to 16-bit dst - Not supported for fixed source address</li> <li>IX_DMA_BURST_SRC_32_DST</li> <li>burst src to 32-bit dst - Not supported for fixed source address</li> <li>IX_DMA_BURST_SRC_BURST_DST</li> <li>burst src to burst dst - Not supported for fixed source and destination address</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | IX_DMA_BURST_SRC_8_DST              |                                                   |
| address  IX_DMA_BURST_SRC_32_DST  burst src to 32-bit dst - Not supported for fixed source address  IX_DMA_BURST_SRC_BURST_DST  burst src to burst dst - Not supported for fixed source and destination address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                     |                                                   |
| address  IX_DMA_BURST_SRC_BURST_DST address  burst src to burst dst – Not supported for fixed source and destination address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | IX_DMA_BURST_SRC_16_DST             |                                                   |
| and destination address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | IX_DMA_BURST_SRC_32_DST             | **                                                |
| IX_DMA_TRANSFER_WIDTH_INVALID Invalid transfer width.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | IX_DMA_BURST_SRC_BURST_DST          | **                                                |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | $IX\_DMA\_TRANSFER\_WIDTH\_INVALID$ | Invalid transfer width.                           |

Definition at line 80 of file IxDmaAcc.h.

# Intel (R) IXP400 Software DMA Access Driver (IxDmaAcc) API

The public API for the Intel (R) IXP400 Software IxDmaAcc component.

#### **Defines**

#### #define IX\_DMA\_REQUEST\_FULL

DMA request queue is full This constant is a return value used to tell the user that the IxDmaAcc queue is full.

# **Typedefs**

#### typedef UINT32 IxDmaAccRequestId

DMA Request Id type.

#### typedef void(\* IxDmaAccDmaCompleteCallback )(IxDmaReturnStatus status)

DMA completion notification This function is called to notify a client that the DMA has been completed.

#### **Functions**

#### PUBLIC IX\_STATUS ixDmaAccInit (IxNpeDINpeId npeId)

Initialise the DMA Access component This function will initialise the DMA Access component internals.

#### PUBLIC IX\_STATUS ixDmaAccUninit (IxNpeDlNpeId npeId)

Uninitialise the DMA Access component This function will uninitialise the DMA Access component internals.

#### PUBLIC IxDmaReturnStatus ixDmaAccDmaTransfer (IxDmaAccDmaCompleteCallback

callback, UINT32 SourceAddr, UINT32 DestinationAddr, UINT16

TransferLength, **IxDmaTransferMode** TransferMode, **IxDmaAddressingMode** AddressingMode,

**IxDmaTransferWidth** TransferWidth)

Perform DMA transfer This function will perform DMA transfer between devices within the Intel (R) IXP400 Software memory map.

#### PUBLIC IX STATUS ixDmaAccShow (void)

Display some component information for debug purposes Show some internal operation information relating to the DMA service. At a minimum the following will show. –the number of the DMA pend (in queue).

# **Detailed Description**

The public API for the Intel (R) IXP400 Software IxDmaAcc component.

#### **Define Documentation**

#define IX DMA REQUEST FULL

DMA request queue is full This constant is a return value used to tell the user that the IxDmaAcc queue is full.

Definition at line **140** of file **IxDmaAcc.h**.

# **Typedef Documentation**

typedef void(\* IxDmaAccDmaCompleteCallback)(**IxDmaReturnStatus** status)

DMA completion notification This function is called to notify a client that the DMA has been completed.

#### Parameters:

status IxDmaReturnStatus [out] – reporting to client

Definition at line 149 of file IxDmaAcc.h.

typedef UINT32 IxDmaAccRequestId

DMA Request Id type.

Definition at line 130 of file IxDmaAcc.h.

#### **Function Documentation**

Perform DMA transfer This function will perform DMA transfer between devices within the Intel (R) IXP400 Software memory map.

#### Note:

The following are restrictions for IxDmaAccDmaTransfer:

- ♦ The function is non re–entrant.
- ♦ The function assumes host devices are operating in big—endian mode.
- ♦ Fixed address does not suport burst transfer width
- ♦ Fixed source address to fixed destinatiom address mode is not suported
- ♦ The incrementing source address for expansion bus will not support a burst transfer width and copy and clear mode

#### Parameters:

when the DMA transfer is completed. This cannot be NULL.

SourceAddr UINT32 [in] – Starting address of DMA source. Must be a valid Intel (R) IXP400

Software memory map address.

DestinationAddr UINT32 [in] – Starting address of DMA destination. Must be a valid Intel (R)

IXP400 Software memory map address.

TransferLength UINT16 [in] – The size of DMA data transfer. The range must be from

1–64Kbyte

TransferMode IxDmaTransferMode [in] – The DMA transfer mode

AddressingMode IxDmaAddressingMode [in] – The DMA addressing mode

TransferWidth IxDmaTransferWidth [in] – The DMA transfer width

#### Returns:

♦ IX\_DMA\_SUCCESS Notification that the DMA request is successful

♦ IX\_DMA\_FAIL IxDmaAcc not yet initialised or some internal error has occured

♦ IX\_DMA\_INVALID\_TRANSFER\_WIDTH Transfer width is nit valid

♦ IX\_DMA\_INVALID\_TRANSFER\_LENGTH Transfer length outside of valid range

♦ IX\_DMA\_INVALID\_TRANSFER\_MODE Transfer Mode not valid

♦ IX\_DMA\_REQUEST\_FIFO\_FULL IxDmaAcc request queue is full

#### ixDmaAccInit ( **IxNpeDlNpeId** npeId )

Initialise the DMA Access component This function will initialise the DMA Access component internals.

#### Parameters:

npeld **IxNpeDlNpeld** [in] – NPE to use for Dma Transfer

#### Returns:

♦ IX\_SUCCESS successfully initialised the component

♦ IX\_FAIL Initialisation failed for some unspecified internal reason.

#### ixDmaAccShow (void)

Display some component information for debug purposes Show some internal operation information relating to the DMA service. At a minimum the following will show. –the number of the DMA pend (in queue).

#### Parameters:

None

#### Returns:

◊ None

#### ixDmaAccUninit ( IxNpeDlNpeId npeId )

Uninitialise the DMA Access component This function will uninitialise the DMA Access component internals.

#### Parameters:

npeld **IxNpeDlNpeId** [in] – NPE to use for Dma Transfer

#### Returns:

♦ IX\_SUCCESS successfully uninitialised the component

♦ IX\_FAIL Unnitialisation failed for some unspecified internal reason.

# Intel (R) IXP400 Software Ethernet Access (IxEthAcc) API

ethAcc is a library that does provides access to the internal IXP4XX Product Line of Network Processors 10/100Bt Ethernet MACs.

#### **Data Structures**

#### struct IxEthAccMacAddr

Definition of the IEEE 802.3 Ethernet MAC address structure.

#### struct IxEthAccNe

Definition of service-specific informations.

#### struct IxEthAccNe

Definition of service-specific informations.

#### struct IxEthAccNe

Definition of service-specific informations.

#### struct IxEthEthObjStats

This struct defines the statistics returned by this component.

#### **Defines**

#### #define ixEthAccUnload

#### #define IX\_ETH\_ACC\_NUMBER\_OF\_PORTS

Definition of the number of ports.

#### #define IX\_IEEE803\_MAC\_ADDRESS\_SIZE

Definition of the size of the MAC address.

#### #define IX\_ETH\_ACC\_NUM\_TX\_PRIORITIES

Definition of the number of transmit priorities.

#### #define IX\_ETHACC\_NE\_PORT\_UNKNOWN

Contents of the field IX\_ETHACC\_NE\_DESTPORTID when no destination port can be found by the NPE for this frame.

#### #define **IX\_ETHACC\_NE\_PADLENGTH**(mBufPtr)

The location of the number of padding bytes in the Mbuf header.

#### #define **IX\_ETHACC\_NE\_DESTMAC**(mBufPtr)

The location of the destination MAC address in the Mbuf header.

#define IX ETHACC NE SOURCEMAC(mBufPtr)

The location of the source MAC address in the Mbuf header.

#### #define IX ETHACC NE VLANTCI(mBufPtr)

The VLAN Tag Control Information associated with this frame.

#### #define **IX\_ETHACC\_NE\_SOURCEPORTID**(mBufPtr)

The port where this frame came from.

#### #define **IX ETHACC NE DESTPORTID**(mBufPtr)

The destination port where this frame should be sent.

#### #define **IX\_ETHACC\_NE\_QOS**(mBufPtr)

QualityOfService class (QoS) for this received frame.

#### #define **IX\_ETHACC\_NE\_FLAGS**(mBufPtr)

Bit Mask of the different flags associated with a frame.

#### #define IX ETHACC NE BCASTMASK

This mask defines if a received frame is a broadcast frame.

#### #define IX\_ETHACC\_NE\_MCASTMASK

This mask defines if a received frame is a multicast frame.

#### #define IX\_ETHACC\_NE\_IPMASK

This mask defines if a received frame is a IP frame.

#### #define IX ETHACC NE IPV6MASK

This mask defines if a received frame is a IP frame.

#### #define IX\_ETHACC\_NE\_LINKMASK

This mask is the link layer protocol indicator.

#### #define IX ETHACC NE STMASK

This mask defines if a received frame is a Spanning Tree frame.

#### #define IX\_ETHACC\_NE\_FILTERMASK

This bit indicates whether a frame has been filtered by the Rx service.

#### #define IX ETHACC NE PORTOVERMASK

This mask defines the rule to transmit a frame.

#### #define IX ETHACC NE TAGMODEMASK

This mask defines the tagging rules to apply to a transmit frame.

#### #define IX ETHACC NE TAGOVERMASK

This mask defines the rule to transmit a frame.

#### #define IX\_ETHACC\_NE\_LOCALMACMASK

This mask defines the rule to receive a frame to local mac.

#### #define IX\_ETHACC\_NE\_VLANMASK

This mask defines if a received frame is VLAN tagged.

#### #define IX ETHACC NE VLANENABLEMASK

This mask defines if a frame is a VLAN frame or not.

#### #define IX\_ETHACC\_NE\_NEWSRCMASK

This mask defines if a received frame has been learned.

#### #define IX ETHACC RX MBUF MIN SIZE

This defines the recommanded minimum size of MBUF's submitted to the frame receive service.

#### #define IXP400 ETH ACC MII MAX ADDR

This defines the highest MII address of any attached PHYs.

#### #define IXP425 ETH ACC MII MAX ADDR

This defines the highest MII address of any attached PHYs.

#### #define IxEthAccTxSchedulerDiscipline

Deprecated definition for the port transmit scheduling discipline.

#### #define **ixEthAccMiiPhyScan**(phyPresent)

: deprecated API entry point. This definition ensures backward compatibility

#### #define **ixEthAccMiiPhyConfig**(phyAddr, speed100, fullDuplex, autonegotiate)

: deprecated API entry point. This definition ensures backward compatibility

#### #define ixEthAccMiiPhyReset(phyAddr)

: deprecated API entry point. This definition ensures backward compatibility

#### #define **ixEthAccMiiLinkStatus**(phyAddr, linkUp, speed100, fullDuplex, autoneg)

: deprecated API entry point. This definition ensures backward compatibility

#### #define ixEthAccMiiShow(phyAddr)

: deprecated API entry point. This definition ensures backward compatibility

### **Typedefs**

typedef void(\* **IxEthAccPortTxDoneCallback**)(UINT32 callbackTag, IX\_OSAL\_MBUF \*buffer)
Function prototype for Ethernet Tx Buffer Done callback. Registered via
ixEthAccTxBufferDoneCallbackRegister.

typedef void(\* **IxEthAccPortRxCallback** )(UINT32 callbackTag, IX\_OSAL\_MBUF \*buffer, UINT32 reserved)

Function prototype for Ethernet Frame Rx callback. Registered via ixEthAccPortRxCallbackRegister.

typedef void(\* **IxEthAccPortMultiBufferRxCallback** )(UINT32 callbackTag, IX\_OSAL\_MBUF \*\*buffer)

Typedefs 141

#### **Enumerations**

```
enum IxEthAccStatus {
     IX_ETH_ACC_SUCCESS,
     IX_ETH_ACC_FAIL,
     IX_ETH_ACC_INVALID_PORT,
     IX_ETH_ACC_PORT_UNINITIALIZED,
     IX_ETH_ACC_MAC_UNINITIALIZED,
     IX_ETH_ACC_INVALID_ARG,
     IX_ETH_TX_Q_FULL,
     IX_ETH_ACC_NO_SUCH_ADDR
     Definition of the Ethernet Access status.
enum IxEthAccPortId {
     IX_ETH_PORT_1,
     IX ETH PORT 2.
     IX ETH PORT 3
     Definition of the IXP400 Mac Ethernet device.
enum IxEthAccTxPriority {
     IX_ETH_ACC_TX_PRIORITY_0,
     IX_ETH_ACC_TX_PRIORITY_1,
     IX_ETH_ACC_TX_PRIORITY_2,
     IX_ETH_ACC_TX_PRIORITY_3,
     IX_ETH_ACC_TX_PRIORITY_4,
     IX_ETH_ACC_TX_PRIORITY_5,
     IX_ETH_ACC_TX_PRIORITY_6,
     IX_ETH_ACC_TX_PRIORITY_7,
     IX_ETH_ACC_TX_DEFAULT_PRIORITY
     Definition of the relative priority used to transmit a frame.
enum IxEthAccRxFrameType {
     IX_ETHACC_RX_LLCTYPE,
     IX ETHACC RX ETHTYPE,
     IX_ETHACC_RX_STATYPE,
     IX_ETHACC_RX_APTYPE
     Identify the type of a frame.
enum IxEthAccDuplexMode {
     IX_ETH_ACC_FULL_DUPLEX,
     IX_ETH_ACC_HALF_DUPLEX
     }
```

Enumerations 142

Definition to provision the duplex mode of the MAC.

```
enum IxEthAccSchedulerDiscipline {
    FIFO_NO_PRIORITY,
    FIFO_PRIORITY
}
Definition for the port scheduling discipline.
```

#### **Functions**

**PUBLIC** 

#### IxEthAccStatus ixEthAccInit (void)

Initializes the Intel (R) IXP400 Software Ethernet Access Service.

**PUBLIC** 

#### IxEthAccStatus ixEthAccUninit (void)

*Un–Initializes the Intel (R) IXP400 Software Ethernet Access Service.* 

**PUBLIC** 

#### IxEthAccStatus ixEthAccPortInit (IxEthAccPortId portId)

Initializes an NPE/Ethernet MAC Port.

# PUBLICixEthAccPortTxFrameSubmit (IxEthAccPortId portId, IX\_OSAL\_MBUF \*buffer, IxEthAccStatus IxEthAccTxPriority priority)

This function shall be used to submit MBUFs buffers for transmission on a particular MAC device.

#### PUBLICixEthAccPortTxDoneCallbackRegister (IxEthAccPortId portId,

#### IxEthAccStatus IxEthAccPortTxDoneCallback txCallbackFn, UINT32 callbackTag)

Register a callback function to allow the transmitted buffers to return to the user.

UINT32 ixEthRxPriorityPoll (UINT32 reserved, UINT32 maxQEntries)

UINT32 ixEthRxMultiBufferPriorityPoll (UINT32 reserved, UINT32 maxQEntries)

PUBLICixEthAccPortRxCallbackRegister (IxEthAccPortId portId, IxEthAccPortRxCallback

**IxEthAccStatus** rxCallbackFn, UINT32 callbackTag)

Register a callback function to allow the reception of frames.

#### PUBLICixEthAccPortMultiBufferRxCallbackRegister (IxEthAccPortId portId,

#### **IxEthAccPortMultiBufferRxCallback** rxCallbackFn, UINT32 callbackTag)

Register a callback function to allow the reception of frames.

**PUBLIC** 

#### IxEthAccStatus ixEthAccPortRxFreeReplenish (IxEthAccPortId portId, IX\_OSAL\_MBUF \*buffer)

This function provides buffers for the Ethernet receive path.

**PUBLIC** 

#### IxEthAccStatus ixEthAccPortEnable (IxEthAccPortId portId)

This enables an Ethernet port for both Tx and Rx.

#### **PUBLIC**

#### IxEthAccStatus ixEthAccPortDisable (IxEthAccPortId portId)

This disables an Ethernet port for both Tx and Rx.

**PUBLIC** 

#### IxEthAccStatus ixEthAccPortEnabledQuery (IxEthAccPortId portId, BOOL \*enabled)

*Get the enabled state of a port.* 

**PUBLIC** 

#### IxEthAccStatus ixEthAccPortPromiscuousModeClear (IxEthAccPortId portId)

Put the Ethernet MAC device in non-promiscuous mode.

**PUBLIC** 

#### IxEthAccStatus ixEthAccPortPromiscuousModeSet (IxEthAccPortId portId)

Put the MAC device in promiscuous mode.

# $PUBLIC ix Eth Acc Port Unicast Mac Address Set \ (Ix Eth Acc Port Id \ port Id, \ Ix Eth Acc Mac Addr Ix Eth Acc Status * mac Addr)$

Configure unicast MAC address for a particular port.

# PUBLICixEthAccPortUnicastMacAddressGet (IxEthAccPortId portId, IxEthAccMacAddr IxEthAccStatus \*macAddr)

Get unicast MAC address for a particular MAC port.

# $PUBLIC ix Eth Acc Port Multicast Address Join \ (Ix Eth Acc Port Id \ port Id, \ Ix Eth Acc Mac Addr Ix Eth Acc Status * mac Addr)$

Add a multicast address to the MAC address table.

**PUBLIC** 

#### IxEthAccStatus ixEthAccPortMulticastAddressJoinAll (IxEthAccPortId portId)

Filter all frames with multicast dest.

# $PUBLIC ix Eth Acc Port Multicast Address Leave \ (Ix Eth Acc Port Id \ port Id, \ Ix Eth Acc Mac Addr Ix Eth Acc Status * mac Addr)$

Remove a multicast address from the MAC address table.

**PUBLIC** 

#### IxEthAccStatus ixEthAccPortMulticastAddressLeaveAll (IxEthAccPortId portId)

This function unconfigures the multicast filtering settings.

**PUBLIC** 

#### IxEthAccStatus ixEthAccPortUnicastAddressShow (IxEthAccPortId portId)

Displays unicast MAC address.

#### PUBLIC void ixEthAccPortMulticastAddressShow (IxEthAccPortId portId)

Displays multicast MAC address.

**PUBLIC** 

# **IxEthAccStatus ixEthAccPortDuplexModeSet** (**IxEthAccPortId** portId, **IxEthAccDuplexMode** mode) Set the duplex mode for the MAC.

#### $PUBLIC ix Eth Acc Port Duplex Mode Get \ (Ix Eth Acc Port Id, Ix Eth Acc Duplex Mode Get) \\$

IxEthAccStatus \*mode)

Get the duplex mode for the MAC.

**PUBLIC** 

 $IxEthAccStatus\ ixEthAccPortTxFrameAppendPaddingEnable\ (IxEthAccPortId\ portId)$ 

Enable padding bytes to be appended to runt frames submitted to this port.

**PUBLIC** 

IxEthAccStatus ixEthAccPortTxFrameAppendPaddingDisable (IxEthAccPortId portId)

Disable padding bytes to be appended to runt frames submitted to this port.

**PUBLIC** 

IxEthAccStatus ixEthAccPortTxFrameAppendFCSEnable (IxEthAccPortId portId)

*Enable the appending of Ethernet FCS to all frames submitted to this port.* 

**PUBLIC** 

IxEthAccStatus ixEthAccPortTxFrameAppendFCSDisable (IxEthAccPortId portId)

Disable the appending of Ethernet FCS to all frames submitted to this port.

**PUBLIC** 

IxEthAccStatus ixEthAccPortRxFrameAppendFCSEnable (IxEthAccPortId portId)

Forward frames with FCS included in the receive buffer.

**PUBLIC** 

 $IxEthAccStatus\ ixEthAccPortRxFrameAppendFCSD is able\ (IxEthAccPortId\ portId)$ 

Do not forward the FCS portion of the received Ethernet frame to the user. The FCS is striped from the receive buffer. The received frame length does not include the FCS size (4 bytes). Frame FCS validity checks are still carried out on all received frames.

PUBLICixEthAccTxSchedulingDisciplineSet (IxEthAccPortId portId,

IxEthAccStatus IxEthAccSchedulerDiscipline sched)

Set the port scheduling to one of IxEthAccSchedulerDiscipline.

**PUBLIC** 

IxEthAccStatus ixEthAccRxSchedulingDisciplineSet (IxEthAccSchedulerDiscipline sched)

Set the Rx scheduling to one of IxEthAccSchedulerDiscipline.

**PUBLIC** 

IxEthAccStatus ixEthAccPortNpeLoopbackEnable (IxEthAccPortId portId)

**PUBLIC** 

IxEthAccStatus ixEthAccPortNpeLoopbackDisable (IxEthAccPortId portId)

Disable NPE loopback.

**PUBLIC** 

IxEthAccStatus ixEthAccPortTxEnable (IxEthAccPortId portId)

*Enable Tx on the port.* 

**PUBLIC** 

IxEthAccStatus ixEthAccPortTxDisable (IxEthAccPortId portId)

Disable Tx on the port.

#### **PUBLIC**

#### IxEthAccStatus ixEthAccPortRxEnable (IxEthAccPortId portId)

Enable Rx on the port.

**PUBLIC** 

#### IxEthAccStatus ixEthAccPortRxDisable (IxEthAccPortId portId)

Disable Rx on the port.

**PUBLIC** 

#### IxEthAccStatus ixEthAccPortMacReset (IxEthAccPortId portId)

Reset MAC core on the port.

#### PUBLIC void ixEthAccQMgrRxNotificationDisable (void)

Disable queue interrupts for all Rx queues.

#### PUBLIC void **ixEthAccQMgrRxNotificationEnable** (void)

Enable queue interrupts for all Rx queues.

#### PUBLIC void ixEthAccQMgrRxQEntryGet (UINT32 \*numEntries)

*Get the total number of receive buffers in all rx queues.* 

**PUBLIC** 

#### IxEthAccStatus ixEthAccMibIIStatsGet (IxEthAccPortId portId, IxEthEthObjStats \*retStats)

Returns the statistics maintained for a port.

**PUBLIC** 

#### IxEthAccStatus ixEthAccMibIIStatsGetClear (IxEthAccPortId portId, IxEthEthObjStats \*retStats)

Returns and clears the statistics maintained for a port.

**PUBLIC** 

#### IxEthAccStatus ixEthAccMibIIStatsClear (IxEthAccPortId portId)

Clears the statistics maintained for a port.

**PUBLIC** 

#### IxEthAccStatus ixEthAccMacInit (IxEthAccPortId portId)

*Initializes the ethernet MAC settings.* 

**PUBLIC** 

#### IxEthAccStatus ixEthAccMacUninit (IxEthAccPortId portId)

*Un–Initializes the ethernet MAC settings.* 

#### PUBLIC void ixEthAccStatsShow (IxEthAccPortId portId)

Displays a ports statistics on the standard io console using printf.

**PUBLIC** 

#### IxEthAccStatus ixEthAccMiiReadRtn (UINT8 phyAddr, UINT8 phyReg, UINT16 \*value)

Reads a 16 bit value from a PHY.

ixEthAccMiiWriteRtn (UINT8 phyAddr, UINT8 phyReg, UINT16 value)

#### **PUBLIC**

#### **IxEthAccStatus**

Writes a 16 bit value to a PHY.

**PUBLIC** 

IxEthAccStatus ixEthAccMiiAccessTimeoutSet (UINT32 timeout, UINT32 retryCount) PUBLIC

IxEthAccStatus ixEthAccMiiStatsShow (UINT32 phyAddr)

Displays detailed information on a specified PHY.

# **Detailed Description**

ethAcc is a library that does provides access to the internal IXP4XX Product Line of Network Processors 10/100Bt Ethernet MACs.

#### **Define Documentation**

#### #define IX\_ETH\_ACC\_NUM\_TX\_PRIORITIES

Definition of the number of transmit priorities.

Definition at line 110 of file IxEthAcc.h.

#### #define IX\_ETH\_ACC\_NUMBER\_OF\_PORTS

Definition of the number of ports.

Definition at line **78** of file **IxEthAcc.h**.

#### #define IX\_ETHACC\_NE\_BCASTMASK

This mask defines if a received frame is a broadcast frame.

This mask defines if a received frame is a broadcast frame. The BCAST flag is set when the destination MAC address of a frame is broadcast.

See also:

#### IX\_ETHACC\_NE\_FLAGS

Definition at line 325 of file IxEthAcc.h.

#### #define IX\_ETHACC\_NE\_DESTMAC ( mBufPtr )

The location of the destination MAC address in the Mbuf header.

Definition at line **214** of file **IxEthAcc.h**.

#### #define IX\_ETHACC\_NE\_DESTPORTID ( mBufPtr )

The destination port where this frame should be sent.

The destination port where this frame should be sent.

- In the transmit direction, this field contains the destination port and is ignored unless *IX\_ETHACC\_NE\_FLAG\_DST* is set.
- In the receive direction, this field contains the port where the destination MAC addresses has been learned. If the destination MAC address is unknown, then this value is set to the reserved value *IX\_ETHACC\_NE\_PORT\_UNKNOWN*

Definition at line **273** of file **IxEthAcc.h**.

#### #define IX\_ETHACC\_NE\_FILTERMASK

This bit indicates whether a frame has been filtered by the Rx service.

This mask applies to *IX\_ETHACC\_NE\_FLAGS*. Certain frames, which should normally be fully filtered by the NPE to due the destination MAC address being on the same segment as the Rx port are still forwarded to the XScale (although the payload is invalid) in order to learn the MAC address of the transmitting station, if this is unknown. Normally EthAcc will filter and recycle these framess internally and no frames with the FILTER bit set will be received by the client.

#### See also:

#### IX\_ETHACC\_NE\_FLAGS

Definition at line **432** of file **IxEthAcc.h**.

#### #define IX\_ETHACC\_NE\_FLAGS ( mBufPtr )

Bit Mask of the different flags associated with a frame.

The flags are the bit-oring combination of the following different fields:

- IP flag (Rx *IX\_ETHACC\_NE\_IPMASK*)
- Spanning Tree flag (Rx *IX\_ETHACC\_NE\_STMASK*)
- Link layer type (Rx and Tx IX ETHACC NE LINKMASK)
- VLAN Tagged Frame (Rx IX ETHACC NE VLANMASK)
- New source MAC address (Rx IX\_ETHACC\_NE\_NEWSRCMASK)
- Multicast flag (Rx IX ETHACC NE MCASTMASK)
- Broadcast flag (Rx IX\_ETHACC\_NE\_BCASTMASK)

- Destination port flag (Tx IX\_ETHACC\_NE\_PORTMASK)
- Tag/Untag Tx frame (Tx IX\_ETHACC\_NE\_TAGMODEMASK)
- Overwrite destination port (Tx IX ETHACC NE PORTOVERMASK)
- Filtered frame (Rx IX ETHACC NE STMASK)
- VLAN Enabled (Rx and Tx IX\_ETHACC\_NE\_VLANENABLEMASK)
- Local MAC (Rx IX\_ETHACC\_NE\_LOCALMACMASK)

Definition at line **309** of file **IxEthAcc.h**.

#### #define IX\_ETHACC\_NE\_IPMASK

This mask defines if a received frame is a IP frame.

This mask applies to *IX\_ETHACC\_NE\_FLAGS* and defines if a received frame is a IPv4 frame. The IP flag is set on Rx direction, depending on the frame contents. The flag is set when the length/type field of a received frame is 0x8000.

#### See also:

#### IX\_ETHACC\_NE\_FLAGS

Definition at line **358** of file **IxEthAcc.h**.

#### #define IX ETHACC NE IPV6MASK

This mask defines if a received frame is a IP frame.

This mask applies to *IX\_ETHACC\_NE\_FLAGS* and defines if a received frame is a IPv6 frame. The IP flag is set on Rx direction, depending on the frame contents. The flag is set when the length/type field of a received frame is 0x86DD.

#### See also:

#### IX\_ETHACC\_NE\_FLAGS

Definition at line 375 of file IxEthAcc.h.

#### #define IX\_ETHACC\_NE\_LINKMASK

This mask is the link layer protocol indicator.

This mask applies to *IX\_ETHACC\_NE\_FLAGS*. It reflects the state of a frame as it exits an NPE on the Rx path or enters an NPE on the Tx path. Its values are as follows:

- 0x00 IEEE802.3 8802 (Rx) / IEEE802.3 8802 (Tx)
- 0x01 IEEE802.3 Ethernet (Rx) / IEEE802.3 Ethernet (Tx)
- $\bullet$  0x02 IEEE802.11 AP –> STA (Rx) / IEEE802.11 STA -> AP (Tx)

•  $0x03 - IEEE802.11 \text{ AP} \rightarrow AP (Rx) / IEEE802.11 \text{ AP} \rightarrow AP (Tx)$ 

See also:

IX ETHACC NE FLAGS

Definition at line **395** of file **IxEthAcc.h**.

#### #define IX\_ETHACC\_NE\_LOCALMACMASK

This mask defines the rule to receive a frame to local mac.

This mask defines the rule to receive a frame to local mac. When set, the default receive rules of a port are overriden. When not set, the default rules as set by **Intel** (**R**) **IXP400 Software Ethernet Database** (**IxEthDB**) **API** should apply.

See also:

IX\_ETHACC\_NE\_FLAGS

IX ETHACC NE LOCALMACMASK

Definition at line 506 of file IxEthAcc.h.

#### #define IX\_ETHACC\_NE\_MCASTMASK

This mask defines if a received frame is a multicast frame.

This mask defines if a received frame is a multicast frame. The MCAST flag is set when the destination MAC address of a frame is multicast.

See also:

IX\_ETHACC\_NE\_FLAGS

Definition at line **341** of file **IxEthAcc.h**.

#### #define IX\_ETHACC\_NE\_NEWSRCMASK

This mask defines if a received frame has been learned.

This mask defines if the source MAC address of a frame is already known. If the bit is set, the source MAC address was unknown to the NPE at the time the frame was received.

See also:

IX\_ETHACC\_NE\_FLAGS

Definition at line 562 of file IxEthAcc.h.

#### #define IX ETHACC NE PADLENGTH ( mBufPtr )

The location of the number of padding bytes in the Mbuf header.

Definition at line 204 of file IxEthAcc.h.

#### #define IX\_ETHACC\_NE\_PORT\_UNKNOWN

Contents of the field *IX\_ETHACC\_NE\_DESTPORTID* when no destination port can be found by the NPE for this frame.

Definition at line 194 of file IxEthAcc.h.

#### #define IX\_ETHACC\_NE\_PORTOVERMASK

This mask defines the rule to transmit a frame.

This mask defines the rule to transmit a frame. When set, a frame is transmitted to the destination port as set by the macro *IX\_ETHACC\_NE\_DESTPORTID*. If not set, the destination port is searched using the destination MAC address.

#### Note:

This flag is meaningful only for multiport Network Engines.

#### See also:

IX\_ETHACC\_NE\_FLAGS

IX\_ETHACC\_NE\_DESTPORTID

Definition at line 452 of file IxEthAcc.h.

#### #define IX\_ETHACC\_NE\_QOS ( mBufPtr )

QualityOfService class (QoS) for this received frame.

Definition at line 283 of file IxEthAcc.h.

#### #define IX\_ETHACC\_NE\_SOURCEMAC ( mBufPtr )

The location of the source MAC address in the Mbuf header.

Definition at line **224** of file **IxEthAcc.h**.

#### #define IX\_ETHACC\_NE\_SOURCEPORTID ( mBufPtr )

The port where this frame came from.

The port where this frame came from. This field is set on receive with the port information. This field is ignored on Transmit path.

Definition at line **253** of file **IxEthAcc.h**.

#### #define IX\_ETHACC\_NE\_STMASK

This mask defines if a received frame is a Spanning Tree frame.

This mask applies to *IX\_ETHACC\_NE\_FLAGS*. On rx direction, it defines if a received if frame is a Spanning Tree frame. Setting this fkag on transmit direction overrides the port settings regarding the VLAN options and

See also:

IX\_ETHACC\_NE\_FLAGS

Definition at line 412 of file IxEthAcc.h.

#### #define IX\_ETHACC\_NE\_TAGMODEMASK

This mask defines the tagging rules to apply to a transmit frame.

This mask defines the tagging rules to apply to a transmit frame regardless of the default setting for a port. When used together with *IX\_ETHACC\_NE\_TAGOVERMASK* and when set, the frame will be tagged prior to transmission. When not set, the frame will be untagged prior to transmission. This is accomplished irrespective of the Egress tagging rules, constituting a per–frame override.

See also:

IX\_ETHACC\_NE\_FLAGS

IX\_ETHACC\_NE\_TAGOVERMASK

Definition at line 472 of file IxEthAcc.h.

#### #define IX\_ETHACC\_NE\_TAGOVERMASK

This mask defines the rule to transmit a frame.

This mask defines the rule to transmit a frame. When set, the default transmit rules of a port are overriden. When not set, the default rules as set by **Intel** (**R**) **IXP400 Software Ethernet Database** (**IxEthDB**) **API** should apply.

See also:

IX\_ETHACC\_NE\_FLAGS

#### IX\_ETHACC\_NE\_TAGMODEMASK

Definition at line **489** of file **IxEthAcc.h**.

#### #define IX\_ETHACC\_NE\_VLANENABLEMASK

This mask defines if a frame is a VLAN frame or not.

When set, frames undergo normal VLAN processing on the Tx path (membership filtering, tagging, tag removal etc). If this flag is not set, the frame is considered to be a regular non–VLAN frame and no VLAN processing will be performed.

Note that VLAN-enabled NPE images will always set this flag in all Rx frames, and images which are not VLAN enabled will clear this flag for all received frames.

See also:

IX\_ETHACC\_NE\_FLAGS

Definition at line **546** of file **IxEthAcc.h**.

#### #define IX\_ETHACC\_NE\_VLANMASK

This mask defines if a received frame is VLAN tagged.

This mask defines if a received frame is VLAN tagged. When set, the Rx frame is VLAN–tagged and the tag value is available thru *IX\_ETHACC\_NE\_VLANID*. Note that when sending frames which are already tagged this flag should be set, to avoid inserting another VLAN tag.

See also:

IX\_ETHACC\_NE\_FLAGS

IX\_ETHACC\_NE\_VLANID

Definition at line **525** of file **IxEthAcc.h**.

#### #define IX\_ETHACC\_NE\_VLANTCI ( mBufPtr )

The VLAN Tag Control Information associated with this frame.

The VLAN Tag Control Information associated with this frame. On Rx path, this field is extracted from the packet header. On Tx path, the value of this field is inserted in the frame when the port is configured to insert or replace vlan tags in the egress frames.

See also:

IX\_ETHACC\_NE\_FLAGS

Definition at line **241** of file **IxEthAcc.h**.

#### #define IX\_ETHACC\_RX\_MBUF\_MIN\_SIZE

This defines the recommanded minimum size of MBUF's submitted to the frame receive service.

Definition at line **571** of file **IxEthAcc.h**.

```
#define IX_IEEE803_MAC_ADDRESS_SIZE
```

Definition of the size of the MAC address.

Definition at line **88** of file **IxEthAcc.h**.

```
#define ixEthAccMiiLinkStatus ( phyAddr, linkUp, speed100, fullDuplex, autoneg )
```

: deprecated API entry point. This definition ensures backward compatibility

#### See ixEthMiiLinkStatus

Note:

this feature is board specific

Definition at line 2691 of file IxEthAcc.h.

```
#define ixEthAccMiiPhyConfig ( phyAddr, speed100, fullDuplex, autonegotiate )
```

: deprecated API entry point. This definition ensures backward compatibility

#### See ixEthMiiPhyConfig

Note:

this feature is board specific

Definition at line **2661** of file **IxEthAcc.h**.

```
#define ixEthAccMiiPhyReset ( phyAddr )
```

: deprecated API entry point. This definition ensures backward compatibility

#### See ixEthMiiPhyReset

Note:

this feature is board specific

Definition at line 2676 of file IxEthAcc.h.

#### #define ixEthAccMiiPhyScan (phyPresent)

: deprecated API entry point. This definition ensures backward compatibility

#### See ixEthMiiPhyScan

Note:

this feature is board specific

Definition at line **2647** of file **IxEthAcc.h**.

#### #define ixEthAccMiiShow (phyAddr)

: deprecated API entry point. This definition ensures backward compatibility

#### See ixEthMiiPhyShow

Note:

this feature is board specific

Definition at line 2708 of file IxEthAcc.h.

#### #define IxEthAccTxSchedulerDiscipline

Deprecated definition for the port transmit scheduling discipline.

Definition at line 1898 of file IxEthAcc.h.

#### #define IXP400\_ETH\_ACC\_MII\_MAX\_ADDR

This defines the highest MII address of any attached PHYs.

The maximum number for PHY address is 31, add on for range checking.

Definition at line **581** of file **IxEthAcc.h**.

#### #define IXP425\_ETH\_ACC\_MII\_MAX\_ADDR

This defines the highest MII address of any attached PHYs.

The maximum number for PHY address is 31, add on for range checking. This is maintained to provide backward compatibility. It will be deprecated in future release.

Definition at line **593** of file **IxEthAcc.h**.

# **Typedef Documentation**

typedef void(\* IxEthAccPortMultiBufferRxCallback)(UINT32 callbackTag, IX\_OSAL\_MBUF \*\*buffer)

Function prototype for Ethernet Frame Rx callback. Registered via *ixEthAccPortMultiBufferRxCallbackRegister*.

It is the responsibility of the user function to free any MBUF's which it receives.

- Reentrant yes, The user provided function should be reentrant.
- ISR Callable yes , The user provided function must be callable from an ISR.

This function dispatches many frames to the user level via the provided function. The invocation shall be made for multiple frames dequeued from the Ethernet QM queue. The user is required to free any MBUF's supplied via this callback. In addition the registered callback must free up MBUF's from the receive free queue when the port is disabled

If called several times the latest callback shall be registered for a particular port.

#### **Calling Context:**

This callback is called in the context of the queue manager dispatch loop *ixQmgrDispatcherLoopRun* within the **Intel (R) IXP400 Software Queue Manager (IxQMgr) API** component. The calling context may be from interrupt or high priority thread. The decision is system specific.

#### Parameters:

callbackTag – This tag is that provided when the callback was registered for a particular MAC via ixEthAccPortMultiBufferRxCallbackRegister. It allows the same callback to be used for multiple MACs.

mbuf

– Pointer to an array of Rx mbuf headers. Mbufs may be chained if the frame length is greater than the supplied mbuf length. The end of the array contains a zeroed entry (NULL pointer).

#### Returns:

void

#### Note:

The mbufs passed to this callback have the same structure than the buffers passed to *IxEthAccPortRxCallback* interfac.

The usage of this callback is exclusive with the usage of *ixEthAccPortRxCallbackRegister* and *IxEthAccPortRxCallback* 

#### See also:

#### ix Eth Acc Port Multi Buffer Rx Callback Register

#### **IxEthAccPortMultiBufferRxCallback**

#### ixEthAccPortRxCallbackRegister

#### IxEthAccPortRxCallback

Definition at line 929 of file IxEthAcc.h.

typedef void(\* IxEthAccPortRxCallback)(UINT32 callbackTag, IX\_OSAL\_MBUF \*buffer, UINT32 reserved)

Function prototype for Ethernet Frame Rx callback. Registered via ixEthAccPortRxCallbackRegister.

It is the responsibility of the user function to free any MBUF's which it receives.

- Reentrant yes , The user provided function should be reentrant.
- ISR Callable yes, The user provided function must be callable from an ISR.

This function dispatches frames to the user level via the provided function. The invocation shall be made for each frame dequeued from the Ethernet QM queue. The user is required to free any MBUF's supplied via this callback. In addition the registered callback must free up MBUF's from the receive free queue when the port is disabled

If called several times the latest callback shall be registered for a particular port.

#### **Calling Context:**

This callback is called in the context of the queue manager dispatch loop *ixQmgrgrDispatcherLoopRun* within the **Intel** (**R**) **IXP400 Software Queue Manager** (**IxQMgr**) **API** component. The calling context may be from interrupt or high priority thread. The decision is system specific.

#### Parameters:

callbackTag UINT32 [in] - This tag is that provided when the callback was registered for a

 $particular\ MAC\ via\ \textit{ixEthAccPortRxCallbackRegister}.\ It\ allows\ the\ same\ callback\ to$ 

be used for multiple MACs.

mbuf [in] – Pointer to the Rx mbuf header. Mbufs may be chained if the frame length is

greater than the supplied mbuf length.

reserved [in] – deprecated parameter The information is passed thru the **IxEthAccNe** header

destination port ID field (

#### See also:

**IX\_ETHACC\_NE\_DESTPORTID**). For backward compatibility, the value is equal to **IX\_ETH\_DB\_UNKNOWN\_PORT** (0xff).

#### Returns:

void

Note:

Buffers may not be filled up to the length supplied in *ixEthAccPortRxFreeReplenish()*. The firmware fills them to the previous 64 bytes boundary. The user has to be aware that the length of the received mbufs may be smaller than the length of the supplied mbufs. The mbuf header contains the following modified field

- ♦ IX\_OSAL\_MBUF\_PKT\_LEN is set in the header of the first mbuf and indicates the total frame size
- ◊ IX\_OSAL\_MBUF\_MLEN is set each mbuf header and indicates the payload length
- ♦ IX\_OSAL\_MBUF\_NEXT\_BUFFER\_IN\_PKT\_PTR contains a pointer to the next mbuf, or NULL at the end of a chain.
- ♦ IX\_OSAL\_MBUF\_NEXT\_PKT\_IN\_CHAIN\_PTR is modified. Its value is reset to NULL
- ♦ *IX\_OSAL\_MBUF\_FLAGS* contains the bit 4 set for a broadcast packet and the bit 5 set for a multicast packet. Other bits are unmodified.

Definition at line **879** of file **IxEthAcc.h**.

typedef void(\* IxEthAccPortTxDoneCallback)( UINT32 callbackTag, IX\_OSAL\_MBUF \*buffer )

Function prototype for Ethernet Tx Buffer Done callback. Registered via *ixEthAccTxBufferDoneCallbackRegister*.

This function is called once the previously submitted buffer is no longer required by this service. It may be returned upon successful transmission of the frame or during the shutdown of the port prior to the transmission of a queued frame. The calling of this registered function is not a guarantee of successful transmission of the buffer.

- Reentrant yes, The user provided function should be reentrant.
- ISR Callable yes , The user provided function must be callable from an ISR.

## **Calling Context:**

This callback is called in the context of the queue manager dispatch loop *ixQmgrgrDispatcherLoopRun* within the **Intel** (**R**) **IXP400 Software Queue Manager** (**IxQMgr**) **API** component. The calling context may be from interrupt or high priority thread. The decision is system specific.

#### Parameters:

callbackTag UINT32 [in] – This tag is that provided when the callback was registered for a particular MAC via ixEthAccPortTxDoneCallbackRegister. It allows the same callback to be used for multiple MACs.

*mbuf* [in] – Pointer to the Tx mbuf descriptor.

#### Returns:

void

## Note:

The field IX\_OSAL\_MBUF\_NEXT\_PKT\_IN\_CHAIN\_PTR is modified by the access layer and reset to NULL.

Definition at line **776** of file **IxEthAcc.h**.

# **Enumeration Type Documentation**

## enum IxEthAccDuplexMode

Definition to provision the duplex mode of the MAC.

#### **Enumeration values:**

IX\_ETH\_ACC\_FULL\_DUPLEX Full duplex operation of the MAC.
IX\_ETH\_ACC\_HALF\_DUPLEX Half duplex operation of the MAC.

Definition at line 155 of file IxEthAcc.h.

#### enum IxEthAccPortId

Definition of the IXP400 Mac Ethernet device.

#### **Enumeration values:**

IX\_ETH\_PORT\_1 Ethernet Port 1.IX\_ETH\_PORT\_2 Ethernet port 2.IX\_ETH\_PORT\_3 Ethernet port 3.

Definition at line **52** of file **IxEthAcc.h**.

## enum IxEthAccRxFrameType

Identify the type of a frame.

## See also:

IX\_ETHACC\_NE\_FLAGS

IX ETHACC NE LINKMASK

## Enumeration values:

IX\_ETHACC\_RX\_LLCTYPE 802.3 – 8802, with LLC/SNAP

IX\_ETHACC\_RX\_ETHTYPE 802.3 (Ethernet) without LLC/SNAP

IX\_ETHACC\_RX\_STATYPE 802.11, AP <=> STA

IX\_ETHACC\_RX\_APTYPE 802.11, AP <=> AP

Definition at line **141** of file **IxEthAcc.h**.

## enum IxEthAccSchedulerDiscipline

Definition for the port scheduling discipline.

Select the port scheduling discipline on receive and transmit path

- FIFO: No Priority: In this configuration all frames are processed in the access component in the strict order in which the component received them.
- FIFO: Priority: This shall be a very simple priority mechanism. Higher prior—ity frames shall be forwarded before lower priority frames. There shall be no fairness mechanisms applied across different priorities. Higher priority frames could starve lower priority frames indefinitely.

#### **Enumeration values:**

FIFO\_NO\_PRIORITY frames submitted with no priority
FIFO\_PRIORITY higher prority frames submitted before lower priority

Definition at line **1885** of file **IxEthAcc.h**.

#### enum IxEthAccStatus

Definition of the Ethernet Access status.

#### **Enumeration values:**

IX\_ETH\_ACC\_SUCCESS return success IX\_ETH\_ACC\_FAIL return fail

IX\_ETH\_ACC\_INVALID\_PORT return invalid port

IX\_ETH\_ACC\_PORT\_UNINITIALIZED return

uninitialized

IX\_ETH\_ACC\_MAC\_UNINITIALIZED return MAC

uninitialized

IX\_ETH\_ACC\_INVALID\_ARG return invalid arg
IX\_ETH\_TX\_Q\_FULL return tx queue is

full

IX\_ETH\_ACC\_NO\_SUCH\_ADDR return no such

address

Definition at line **35** of file **IxEthAcc.h**.

## enum IxEthAccTxPriority

Definition of the relative priority used to transmit a frame.

#### **Enumeration values:**

| IX_ETH_ACC_TX_PRIORITY_0       | Lowest Priority submission.             |
|--------------------------------|-----------------------------------------|
| IX_ETH_ACC_TX_PRIORITY_1       | submission prority of 1 (0 is lowest)   |
| IX_ETH_ACC_TX_PRIORITY_2       | submission prority of 2 (0 is lowest)   |
| IX_ETH_ACC_TX_PRIORITY_3       | submission prority of 3 (0 is lowest)   |
| IX_ETH_ACC_TX_PRIORITY_4       | submission prority of 4 (0 is lowest)   |
| IX_ETH_ACC_TX_PRIORITY_5       | submission prority of 5 (0 is lowest)   |
| IX_ETH_ACC_TX_PRIORITY_6       | submission prority of 6 (0 is lowest)   |
| IX_ETH_ACC_TX_PRIORITY_7       | Highest priority submission.            |
| IX_ETH_ACC_TX_DEFAULT_PRIORITY | By default send all packets with lowest |
|                                | priority.                               |

Definition at line 118 of file IxEthAcc.h.

# **Function Documentation**

```
ixEthAccInit ( void )
```

Initializes the Intel (R) IXP400 Software Ethernet Access Service.

- Reentrant yes
- ISR Callable no

This should be called once per module initialization. Secord call to this function yields SUCCESS.

## Precondition:

The NPE must first be downloaded with the required microcode which supports all required features.

## Returns:

#### **IxEthAccStatus**

- ♦ *IX\_ETH\_ACC\_SUCCESS* : Init Done successfully or already initialized
- ♦ *IX\_ETH\_ACC\_FAIL* : Service has failed to initialize EthDB, Dataplane, MII, MemInit, Mutex Init.

## ixEthAccMacInit ( **IxEthAccPortId** portId )

Initializes the ethernet MAC settings.

- Reentrant no
- ISR Callable no

## Parameters:

## portId IxEthAccPortId [in]

#### Returns:

```
IxEthAccStatus

◊ IX_ETH_ACC_SUCCESS

◊ IX_ETH_ACC_INVALID_PORT:
portId is invalid.
```

## ixEthAccMacUninit ( **IxEthAccPortId** portId )

Un-Initializes the ethernet MAC settings.

- Reentrant no
- ISR Callable no

#### Parameters:

```
portId IxEthAccPortId [in]
```

#### Returns:

```
IxEthAccStatus

◊ IX_ETH_ACC_SUCCESS

◊ IX_ETH_ACC_INVALID_PORT:
portId is invalid.
```

## ixEthAccMibIIStatsClear ( **IxEthAccPortId** portId )

Clears the statistics maintained for a port.

- Reentrant yes
- ISR Callable no

## Precondition:

#### Parameters:

portId **IxEthAccPortId** [in]

#### Returns:

```
IxEthAccStatus
```

- *♦ IX\_ETH\_ACC\_SUCCESS*
- ◊ *IX\_ETH\_ACC\_FAIL* : Invalid arguments.
- ♦ *IX\_ETH\_ACC\_INVALID\_PORT* : portId is invalid.
- ♦ *IX\_ETH\_ACC\_PORT\_UNINITIALIZED* : portId is un–initialized

Returns the statistics maintained for a port.

- Reentrant yes
- ISR Callable no

## Precondition:

#### Parameters:

portId IxEthAccPortId [in]
retStats IxEthEthObjStats [out]

#### Note:

Please note the user is responsible for cache coheriency of the retStat buffer. The data is actually populated via the NPE's. As such cache safe memory should be used in the retStats argument.

#### Returns:

#### **IxEthAccStatus**

```
♦ IX_ETH_ACC_SUCCESS
```

- ♦ *IX\_ETH\_ACC\_FAIL* : Invalid arguments.
- ♦ *IX\_ETH\_ACC\_INVALID\_PORT* : portId is invalid.
- ♦ IX\_ETH\_ACC\_PORT\_UNINITIALIZED : portId is un–initialized

Returns and clears the statistics maintained for a port.

- Reentrant yes
- ISR Callable yes

## Precondition:

#### Parameters:

```
portId IxEthAccPortId [in] retStats IxEthEthObjStats [out]
```

#### Note:

Please note the user is responsible for cache coheriency of the retStats buffer. The data is actually populated via the NPE's. As such cache safe memory should be used in the retStats argument.

#### Returns:

```
IxEthAccStatus 

◊ IX_ETH_ACC_SUCCESS
```

```
    ◊ IX_ETH_ACC_FAIL : invalid arguments.
    ◊ IX_ETH_ACC_INVALID_PORT : portId is invalid.
    ◊ IX_ETH_ACC_PORT_UNINITIALIZED : portId is un–initialized
```

Reads a 16 bit value from a PHY.

Reads a 16-bit word from a register of a MII-compliant PHY. Reading is performed through the MII management interface. This function returns when the read operation has successfully completed, or when a timeout has elapsed.

- Reentrant no
- ISR Callable no

#### Precondition:

The MAC on Ethernet Port 2 (NPE C) must be initialised, and generating the MDIO clock.

#### Parameters:

```
    phyAddr UINT8 [in] – the address of the Ethernet PHY (0–31)
    phyReg UINT8 [in] – the number of the MII register to read (0–31)
    value UINT16 [in] – the value read from the register
```

#### Returns:

```
IxEthAccStatus

♦ IX_ETH_ACC_SUCCESS

♦ IX_ETH_ACC_FAIL: failed to read the register.
```

```
ixEthAccMiiStatsShow (UINT32 phyAddr)
```

Displays detailed information on a specified PHY.

Displays the current values of the first eigth MII registers for a PHY,

- Reentrant no
- ISR Callable no

## Precondition:

The MAC on Ethernet Port 2 (NPE C) must be initialised, and generating the MDIO clock.

#### Parameters:

```
phyAddr UINT32 [in] – the address of the Ethernet PHY (0–31)
```

#### Returns:

```
IxEthAccStatus

◊ IX_ETH_ACC_SUCCESS

◊ IX_ETH_ACC_FAIL: invalid arguments.
```

Writes a 16 bit value to a PHY.

Writes a 16-bit word from a register of a MII-compliant PHY. Writing is performed through the MII management interface. This function returns when the write operation has successfully completed, or when a timeout has elapsed.

- Reentrant no
- ISR Callable no

#### Precondition:

The MAC on Ethernet Port 2 (NPE C) must be initialised, and generating the MDIO clock.

#### Parameters:

```
    phyAddr UINT8 [in] – the address of the Ethernet PHY (0–31)
    phyReg UINT8 [in] – the number of the MII register to write (0–31)
    value UINT16 [out] – the value to write to the register
```

#### Returns:

```
IxEthAccStatus

◊ IX_ETH_ACC_SUCCESS

◊ IX_ETH_ACC_FAIL: failed to write register.
```

#### ixEthAccPortDisable ( **IxEthAccPortId** portId )

This disables an Ethernet port for both Tx and Rx.

Free MBufs are returned to the user via the registered callback when the port is disabled

- Reentrant yes
- ISR Callable no

#### **Precondition:**

The port must be enabled with *ixEthAccPortEnable*, otherwise this function has no effect

#### Parameters:

## portId IxEthAccPortId [in] - Port id to act upon.

#### Returns:

```
IxEthAccStatus
```

- *♦ IX\_ETH\_ACC\_SUCCESS*
- ♦ *IX\_ETH\_ACC\_INVALID\_PORT* : portId is invalid.
- ♦ *IX\_ETH\_ACC\_PORT\_UNINITIALIZED* : portId is not initialized
- ♦ *IX\_ETH\_ACC\_MAC\_UNINITIALIZED* : port MAC address is not initialized

Get the duplex mode for the MAC.

return the duplex configuration of the IXP400 MAC.

#### Note:

The configuration should match that provisioned on the PHY. See *ixEthAccDuplexModeSet* 

- Reentrant yes
- ISR Callable no

#### Parameters:

```
portId IxEthAccPortId [in]
*mode IxEthAccDuplexMode [out]
```

## Returns:

```
IxEthAccStatus
```

```
♦ IX ETH ACC SUCCESS
```

- ♦ *IX\_ETH\_ACC\_INVALID\_PORT* : portId is invalid.
- ♦ IX\_ETH\_ACC\_PORT\_UNINITIALIZED : portId is un-initialized

```
ixEthAccPortDuplexModeSet ( IxEthAccPortId portId, IxEthAccDuplexMode mode )
```

Set the duplex mode for the MAC.

Configure the IXP400 MAC to either full or half duplex.

#### Note:

The configuration should match that provisioned on the PHY.

- Reentrant yes
- ISR Callable no

## Parameters:

```
portId IxEthAccPortId [in]
mode IxEthAccDuplexMode [in]
```

#### Returns:

```
IxEthAccStatus
```

```
♦ IX_ETH_ACC_SUCCESS
```

♦ *IX\_ETH\_ACC\_INVALID\_PORT* : portId is invalid.

♦ *IX\_ETH\_ACC\_PORT\_UNINITIALIZED* : portId is un–initialized

## ixEthAccPortEnable ( IxEthAccPortId portId )

This enables an Ethernet port for both Tx and Rx.

- Reentrant yes
- ISR Callable no

#### Precondition:

The port must first be initialized via *ixEthAccPortInit* and the MAC address must be set using *ixEthAccUnicastMacAddressSet* before enabling it The rx and Tx Done callbacks registration via *ixEthAccPortTxDoneCallbackRegister* amd *ixEthAccPortRxCallbackRegister* has to be done before enabling the traffic.

#### Parameters:

portId **IxEthAccPortId** [in] – Port id to act upon.

#### Returns:

## **IxEthAccStatus**

```
♦ IX_ETH_ACC_SUCCESS
```

- ♦ *IX\_ETH\_ACC\_INVALID\_PORT* : portId is invalid.
- ♦ *IX\_ETH\_ACC\_PORT\_UNINITIALIZED* : portId is not initialized
- ♦ IX\_ETH\_ACC\_MAC\_UNINITIALIZED : port MAC address is not initialized

```
ixEthAccPortEnabledQuery ( IxEthAccPortId portId, BOOL * enabled
```

Get the enabled state of a port.

- Reentrant yes
- ISR Callable yes

## Precondition:

The port must first be initialized via *ixEthAccPortInit* 

#### Parameters:

```
portId IxEthAccPortId [in] – Port id to act upon.enabled BOOL [out] – location to store the state of the port
```

#### Returns:

```
IxEthAccStatus

◊ IX_ETH_ACC_SUCCESS

◊ IX_ETH_ACC_INVALID_PORT : portId is invalid
```

#### ixEthAccPortInit ( **IxEthAccPortId** portId )

Initializes an NPE/Ethernet MAC Port.

The NPE/Ethernet port initialisation includes the following steps

- Initialize the NPE/Ethernet MAC hardware.
- Verify NPE downloaded and operational.
- The NPE shall be available for usage once this API returns.
- Verify that the Ethernet port is present before initializing
- Reentrant no
- ISR Callable no

This should be called once per mac device. The NPE/MAC shall be in disabled state after init.

#### Precondition:

The component must be initialized via *ixEthAccInit* The NPE must first be downloaded with the required microcode which supports all required features.

Dependant on Services: (Must be initialized before using this service may be initialized) ixNPEmh – NPE Message handling service. ixQmgr – Queue Manager component.

#### Parameters:

```
portId IxEthAccPortId [in]
```

## Returns:

#### **IxEthAccStatus**

- ◊ *IX\_ETH\_ACC\_SUCCESS*: if the ethernet port is not present, a warning is issued.
- ◊ *IX\_ETH\_ACC\_FAIL* : The NPE processor has failed to initialize.
- ♦ *IX\_ETH\_ACC\_INVALID\_PORT* : portId is invalid.

## IxEthAccStatus ixEthAccPortMacReset (IxEthAccPortId portId )

Reset MAC core on the port.

This function will perform a MAC core reset (NPE Ethernet coprocessor). This function is inherently unsafe and the NPE recovery is not guaranteed after this function is called. The proper manner of performing port disable and enable (which will reset the MAC as well) is ixEthAccPortEnable/ixEthAccPortDisable.

This function is the recommended usage scenario for hardware failure recovery and should never be used for throttling traffic.

- Reentrant yes
- ISR Callable no

## Precondition:

#### Note:

Calling ixEthAccPortDisable followed by ixEthAccPortEnable is guaranteed to restore correct Ethernet Tx/Rx operation.

#### Parameters:

portId: ID of the port

#### Returns:

#### **IxEthAccStatus**

```
♦ IX_ETH_ACC_SUCCESS : MAC core reset
```

◊ IX\_ETH\_ACC\_FAIL : Invalid port or Ethernet service not initialized

♦ *IX\_ETH\_ACC\_INVALID\_PORT* : portId is invalid.

◊ IX ETH ACC PORT UNINITIALIZED: portId is un-initialized

```
ixEthAccPortMultiBufferRxCallbackRegister ( IxEthAccPortId portId, IxEthAccPortMultiBufferRxCallback rxCallbackFn, UINT32 callbackTag
```

Register a callback function to allow the reception of frames.

The registered callback function is called once a frame is received by this service. If many frames are already received, the function is called once.

If called several times the latest callback shall be registered for a particular port.

- Reentrant yes
- ISR Callable yes

#### Parameters:

- Register callback for a particular MAC device.

```
rxCallbackFn - IxEthAccMultiBufferRxCallbackFn - Function to be called when Ethernet frames are availble.
```

callbackTag - This tag shall be provided to the callback function.

#### Returns:

```
IxEthAccStatus
```

- *♦ IX\_ETH\_ACC\_SUCCESS*
- ♦ *IX\_ETH\_ACC\_INVALID\_PORT* : portId is invalid.
- ◊ IX\_ETH\_ACC\_PORT\_UNINITIALIZED : portId is un-initialized
- ♦ IX\_ETH\_ACC\_INVALID\_ARG : An argument other than portId is invalid.

#### See also:

ix Eth Acc Port Multi Buffer Rx Callback Register

IxEthAccPortMultiBufferRxCallback

ix Eth Acc Port Rx Callback Register

**IxEthAccPortRxCallback** 

Add a multicast address to the MAC address table.

#### Note:

Due to the operation of the Ethernet MAC multicast filtering mechanism, frames which do not have a multicast destination address which were provisioned via this API may be forwarded to the NPE's. This is a result of the hardware comparison algorithm used in the destination mac address logic within the Ethernet MAC.

See Also: Intel (R) IXP4XX Product Line of Network Processors hardware development manual.

Other functions modify the MAC filtering

- ixEthAccPortMulticastAddressJoinAll() all multicast frames are forwarded to the application
- *ixEthAccPortMulticastAddressLeaveAll()* rollback the effects of *ixEthAccPortMulticastAddressJoinAll()*
- *ixEthAccPortMulticastAddressLeave()* unprovision a new filtering address
- ixEthAccPortMulticastAddressJoin() provision a new filtering address
- *ixEthAccPortPromiscuousModeSet()* all frames are forwarded to the application regardless of the multicast address provisioned
- *ixEthAccPortPromiscuousModeClear()* frames are forwarded to the application following the multicast address provisioned

In all cases, unicast and broadcast addresses are forwarded to the application.

- Reentrant yes
- ISR Callable no

#### Parameters:

#### Returns:

#### **IxEthAccStatus**

```
♦ IX_ETH_ACC_SUCCESS
```

- ◊ IX ETH ACC FAIL : Error writing to the MAC registers
- ♦ *IX\_ETH\_ACC\_INVALID\_PORT* : portId is invalid.
- $\Diamond$  *IX\_ETH\_ACC\_PORT\_UNINITIALIZED* : portId is un–initialized

## ixEthAccPortMulticastAddressJoinAll ( IxEthAccPortId portId )

Filter all frames with multicast dest.

This function clears the MAC address table, and then sets the MAC to forward ALL multicast frames to the NPE. Specifically, it forwards all frames whose destination address has the LSB of the highest byte set (01:00:00:00:00:00). This bit is commonly referred to as the "multicast bit". Broadcast frames will still be forwarded.

Other functions modify the MAC filtering

- ixEthAccPortMulticastAddressJoinAll() all multicast frames are forwarded to the application
- *ixEthAccPortMulticastAddressLeaveAll()* rollback the effects of *ixEthAccPortMulticastAddressJoinAll()*
- ixEthAccPortMulticastAddressLeave() unprovision a new filtering address
- *ixEthAccPortMulticastAddressJoin()* provision a new filtering address
- *ixEthAccPortPromiscuousModeSet()* all frames are forwarded to the application regardless of the multicast address provisioned
- *ixEthAccPortPromiscuousModeClear()* frames are forwarded to the application following the multicast address provisioned

In all cases, unicast and broadcast addresses are forwarded to the application.

- Reentrant yes
- ISR Callable no

## Parameters:

```
portId IxEthAccPortId [in] – Ethernet port id.
```

#### Returns:

#### **IxEthAccStatus**

- ♦ IX\_ETH\_ACC\_SUCCESS
- ♦ IX ETH ACC INVALID PORT : portId is invalid.
- ♦ IX\_ETH\_ACC\_PORT\_UNINITIALIZED : portId is un–initialized

Remove a multicast address from the MAC address table.

Other functions modify the MAC filtering

- ixEthAccPortMulticastAddressJoinAll() all multicast frames are forwarded to the application
- ixEthAccPortMulticastAddressLeaveAll() rollback the effects of ixEthAccPortMulticastAddressJoinAll()
- *ixEthAccPortMulticastAddressLeave()* unprovision a new filtering address
- *ixEthAccPortMulticastAddressJoin()* provision a new filtering address
- *ixEthAccPortPromiscuousModeSet()* all frames are forwarded to the application regardless of the multicast address provisioned
- *ixEthAccPortPromiscuousModeClear()* frames are forwarded to the application following the multicast address provisioned

In all cases, unicast and broadcast addresses are forwarded to the application.

- Reentrant yes
- ISR Callable no

#### Parameters:

#### Returns:

#### **IxEthAccStatus**

```
♦ IX_ETH_ACC_SUCCESS
```

◊ IX ETH ACC NO SUCH ADDR: Failed if MAC address was not in the table.

♦ *IX\_ETH\_ACC\_INVALID\_PORT* : portId is invalid.

♦ IX ETH ACC PORT UNINITIALIZED : portId is un-initialized

## ixEthAccPortMulticastAddressLeaveAll ( **IxEthAccPortId** portId )

This function unconfigures the multicast filtering settings.

This function first clears the MAC address table, and then sets the MAC as configured by the promiscuous mode current settings.

Other functions modify the MAC filtering

• ixEthAccPortMulticastAddressJoinAll() – all multicast frames are forwarded to the application

- *ixEthAccPortMulticastAddressLeaveAll()* rollback the effects of *ixEthAccPortMulticastAddressJoinAll()*
- *ixEthAccPortMulticastAddressLeave()* unprovision a new filtering address
- ixEthAccPortMulticastAddressJoin() provision a new filtering address
- *ixEthAccPortPromiscuousModeSet()* all frames are forwarded to the application regardless of the multicast address provisioned
- *ixEthAccPortPromiscuousModeClear()* frames are forwarded to the application following the multicast address provisioned

In all cases, unicast and broadcast addresses are forwarded to the application.

- Reentrant yes
- ISR Callable no

#### Parameters:

portId IxEthAccPortId [in] - Ethernet port id.

#### Returns:

## **IxEthAccStatus**

- *♦ IX\_ETH\_ACC\_SUCCESS*
- ♦ *IX\_ETH\_ACC\_INVALID\_PORT* : portId is invalid.
- $\Diamond$  *IX\_ETH\_ACC\_PORT\_UNINITIALIZED* : portId is un–initialized

## ixEthAccPortMulticastAddressShow ( IxEthAccPortId portId )

Displays multicast MAC address.

Displays multicast address which have been configured using ixEthAccMulticastAddressJoin

- Reentrant yes
- ISR Callable no

#### Parameters:

portId **IxEthAccPortId** [in] – Ethernet port id.

#### Returns:

void

## **IxEthAccStatus** ixEthAccPortNpeLoopbackDisable ( **IxEthAccPortId** portId )

Disable NPE loopback.

This function is used to disable the NPE loopback if previously enabled using ixEthAccNpeLoopbackEnable.

This function is recommended for power—up diagnostic checks and should never be used under normal Ethernet traffic operations.

- Reentrant yes
- ISR Callable no

#### Precondition:

#### Note:

Calling ixEthAccPortDisable followed by ixEthAccPortEnable is guaranteed to restore correct Ethernet Tx/Rx operation.

#### Parameters:

portId: ID of the port

#### Returns:

#### **IxEthAccStatus**

- ♦ IX\_ETH\_ACC\_SUCCESS : NPE loopback successfully disabled
- ◊ IX ETH ACC FAIL: Invalid port or Ethernet service not initialized
- ♦ *IX\_ETH\_ACC\_INVALID\_PORT* : portId is invalid.
- ♦ *IX\_ETH\_ACC\_PORT\_UNINITIALIZED* : portId is un–initialized

## ixEthAccPortPromiscuousModeClear ( IxEthAccPortId portId )

Put the Ethernet MAC device in non-promiscuous mode.

In non–promiscuous mode the MAC filters all frames other than destination MAC address which matches the following criteria:

- Unicast address provisioned via ixEthAccUnicastMacAddressSet
- All broadcast frames.
- Multicast addresses provisioned via ixEthAccMulticastAddressJoin

Other functions modify the MAC filtering

- ixEthAccPortMulticastAddressJoinAll() all multicast frames are forwarded to the application
- ixEthAccPortMulticastAddressLeaveAll() rollback the effects of ixEthAccPortMulticastAddressJoinAll()
- ixEthAccPortMulticastAddressLeave() unprovision a new filtering address
- *ixEthAccPortMulticastAddressJoin()* provision a new filtering address
- *ixEthAccPortPromiscuousModeSet()* all frames are forwarded to the application regardless of the multicast address provisioned
- *ixEthAccPortPromiscuousModeClear()* frames are forwarded to the application following the multicast address provisioned

In all cases, unicast and broadcast addresses are forwarded to the application.

• Reentrant – yes

• ISR Callable – no

#### See also:

## ix Eth Acc Port Promiscuous Mode Set

#### Parameters:

```
portId IxEthAccPortId [in] – Ethernet port id.
```

#### Returns:

```
IxEthAccStatus
```

```
♦ IX ETH ACC SUCCESS
```

- ♦ *IX\_ETH\_ACC\_INVALID\_PORT* : portId is invalid.
- ◊ IX ETH ACC PORT UNINITIALIZED: portId is un-initialized

## ixEthAccPortPromiscuousModeSet ( IxEthAccPortId portId )

Put the MAC device in promiscuous mode.

If the device is in promiscuous mode then all all received frames shall be forwared to the NPE for processing.

Other functions modify the MAC filtering

- ixEthAccPortMulticastAddressJoinAll() all multicast frames are forwarded to the application
- *ixEthAccPortMulticastAddressLeaveAll()* rollback the effects of *ixEthAccPortMulticastAddressJoinAll()*
- ixEthAccPortMulticastAddressLeave() unprovision a new filtering address
- *ixEthAccPortMulticastAddressJoin()* provision a new filtering address
- *ixEthAccPortPromiscuousModeSet()* all frames are forwarded to the application regardless of the multicast address provisioned
- *ixEthAccPortPromiscuousModeClear()* frames are forwarded to the application following the multicast address provisioned

In all cases, unicast and broadcast addresses are forwarded to the application.

- Reentrant yes
- ISR Callable no

## See also:

#### ixEthAccPortPromiscuousModeClear

## Parameters:

```
portId IxEthAccPortId [in] – Ethernet port id.
```

#### Returns:

## **IxEthAccStatus**

```
♦ IX ETH ACC SUCCESS
```

♦ *IX\_ETH\_ACC\_INVALID\_PORT* : portId is invalid.

```
ixEthAccPortRxCallbackRegister ( IxEthAccPortId portId, IxEthAccPortRxCallback rxCallbackFn, UINT32 callbackTag
```

Register a callback function to allow the reception of frames.

The registered callback function is called once a frame is received by this service.

If called several times the latest callback shall be registered for a particular port.

- Reentrant yes
- ISR Callable yes

#### Parameters:

```
    portId IxEthAccPortId [in] – Register callback for a particular MAC device.
    rxCallbackFn IxEthAccPortRxCallback [in] – Function to be called when Ethernet frames are availble.
    callbackTag UINT32 [in] – This tag shall be provided to the callback function.
```

#### Returns:

```
IxEthAccStatus
```

```
♦ IX_ETH_ACC_SUCCESS
```

- ♦ IX\_ETH\_ACC\_INVALID\_PORT : portId is invalid.
- ♦ *IX\_ETH\_ACC\_PORT\_UNINITIALIZED* : portId is un–initialized
- ◊ IX\_ETH\_ACC\_INVALID\_ARG : An argument other than portId is invalid.

## **IxEthAccStatus** ixEthAccPortRxDisable ( **IxEthAccPortId** portId )

Disable Rx on the port.

This function can be used to disable Rx in the MAC core. Rx can be re–enabled, although this is not guaranteed, by performing a MAC core reset (*ixEthAccPortMacReset*) and calling ixEthAccPortRxEnable. Note that using this function is not recommended, except for shutting down Rx for emergency reasons. For proper port shutdown and re–enabling see ixEthAccPortEnable and ixEthAccPortDisable.

This function is the recommended usage scenario for emergency security shutdown and hardware failure recovery and should never be used for throttling traffic.

- Reentrant yes
- ISR Callable no

## Precondition:

#### Note:

Calling ixEthAccPortDisable followed by ixEthAccPortEnable is guaranteed to restore correct Ethernet Tx/Rx operation.

#### Parameters:

portId: ID of the port

#### Returns:

## **IxEthAccStatus**

- ♦ IX\_ETH\_ACC\_SUCCESS : Rx successfully disabled
- ♦ IX\_ETH\_ACC\_FAIL : Invalid port or Ethernet service not initialized
- ♦ *IX\_ETH\_ACC\_INVALID\_PORT* : portId is invalid.
- ◊ IX ETH ACC PORT UNINITIALIZED: portId is un-initialized

## IxEthAccStatus ixEthAccPortRxEnable ( IxEthAccPortId portId )

Enable Rx on the port.

This function is the complement of ixEthAccPortRxDisable and should be used only after Rx was disabled.

This function is the recommended usage scenario for emergency security shutdown and hardware failure recovery and should never be used for throttling traffic.

- Reentrant yes
- ISR Callable no

#### Note:

Calling ixEthAccPortDisable followed by ixEthAccPortEnable is guaranteed to restore correct Ethernet Tx/Rx operation.

#### Precondition:

#### Parameters:

portId: ID of the port

#### Returns:

#### **IxEthAccStatus**

- ♦ IX\_ETH\_ACC\_SUCCESS : Rx successfully enabled
- ♦ IX\_ETH\_ACC\_FAIL : Invalid port or Ethernet service not initialized
- ♦ *IX\_ETH\_ACC\_INVALID\_PORT* : portId is invalid.
- ♦ IX\_ETH\_ACC\_PORT\_UNINITIALIZED : portId is un-initialized

#### ixEthAccPortRxFrameAppendFCSDisable ( **IxEthAccPortId** portId )

Do not forward the FCS portion of the received Ethernet frame to the user. The FCS is striped from the receive buffer. The received frame length does not include the FCS size (4 bytes). Frame FCS validity

checks are still carried out on all received frames.

This is the default behavior of the component. Do not change this behaviour while the port is enabled.

```
• Reentrant – yes
```

• ISR Callable - no

#### Parameters:

```
portId IxEthAccPortId [in]
```

#### Returns:

```
IxEthAccStatus
```

```
♦ IX ETH ACC SUCCESS
```

- ◊ IX ETH ACC INVALID PORT : portId is invalid.
- ♦ IX\_ETH\_ACC\_PORT\_UNINITIALIZED: portId is un–initialized

## ixEthAccPortRxFrameAppendFCSEnable ( IxEthAccPortId portId )

Forward frames with FCS included in the receive buffer.

The FCS is not striped from the receive buffer. The received frame length includes the FCS size (4 bytes). ie. A minimum sized ethernet frame shall have a length of 64bytes.

Frame FCS validity checks are still carried out on all received frames.

This is not the default behavior of the access component.

- Reentrant yes
- ISR Callable no

## Parameters:

```
portId IxEthAccPortId [in]
```

#### Returns:

```
IxEthAccStatus
```

```
♦ IX_ETH_ACC_SUCCESS
```

- ♦ *IX\_ETH\_ACC\_INVALID\_PORT* : portId is invalid.
- ♦ IX\_ETH\_ACC\_PORT\_UNINITIALIZED: portId is un–initialized

```
ixEthAccPortRxFreeReplenish ( IxEthAccPortId portId, IX_OSAL_MBUF * buffer )
```

This function provides buffers for the Ethernet receive path.

This component does not have a buffer management mechanisms built in. All Rx buffers must be supplied to it via this interface.

- Reentrant yes
- ISR Callable yes

#### Parameters:

portld IxEthAccPortId [in] – Provide buffers only to specific Rx MAC.

buffer [in] – Provide an MBUF to the Ethernet receive mechanism. Buffers size smaller than IX\_ETHACC\_RX\_MBUF\_MIN\_SIZE may result in poor performances and excessive buffer chaining. Buffers larger than this size may be suitable for jumbo frames. Chained packets are not supported and the field IX\_OSAL\_MBUF\_NEXT\_PKT\_IN\_CHAIN\_PTR must be NULL.

#### Returns:

## **IxEthAccStatus**

- *♦ IX\_ETH\_ACC\_SUCCESS*
- ◊ *IX\_ETH\_ACC\_FAIL* : Not able to queue the buffer in the receive service.
- ♦ IX\_ETH\_ACC\_FAIL : Buffer size is less than IX\_ETHACC\_RX\_MBUF\_MIN\_SIZE
- ♦ IX\_ETH\_ACC\_INVALID\_PORT : portId is invalid.
- ♦ IX\_ETH\_ACC\_PORT\_UNINITIALIZED : portId is un-initialized

#### Note:

If the buffer replenish operation fails it is the responsibility of the user to free the buffer.

Sufficient buffers must be supplied to the component to maintain receive throughput and avoid rx buffer underflow conditions. To meet this goal, It is expected that the user preload the component with a sufficient number of buffers prior to enabling the NPE Ethernet receive path. The recommended minimum number of buffers is 8.

For maximum performances, the mbuf size should be greater than the maximum frame size (Ethernet header, payload and FCS) + 64. Supplying smaller mbufs to the service results in mbuf chaining and degraded performances. The recommended size is

*IX\_ETHACC\_RX\_MBUF\_MIN\_SIZE*, which is enough to take care of 802.3 frames and "baby jumbo" frames without chaining, and "jumbo" frame within chaining.

Buffers may not be filled up to their length. The firware fills them up to the previous 64 bytes boundary. The user has to be aware that the length of the received mbufs may be smaller than the length of the supplied mbufs.

## Warning:

This function checks the parameters if the NDEBUG flag is not defined. Turning on the argument checking (disabled by default) results in a lower EthAcc performance as this function is part of the data path.

## **IxEthAccStatus** ixEthAccPortTxDisable ( **IxEthAccPortId** portId )

Disable Tx on the port.

This function can be used to disable Tx in the MAC core. Tx can be re–enabled, although this is not guaranteed, by performing a MAC core reset (*ixEthAccPortMacReset*) and calling ixEthAccPortTxEnable. Note that using this function is not recommended, except for shutting down Tx for emergency reasons. For proper port shutdown and re–enabling see ixEthAccPortEnable and ixEthAccPortDisable.

This function is the recommended usage scenario for emergency security shutdown and hardware failure recovery and should never be used for throttling traffic.

- Reentrant yes
- ISR Callable no

#### Note:

Calling ixEthAccPortDisable followed by ixEthAccPortEnable is guaranteed to restore correct Ethernet Tx/Rx operation.

#### Precondition:

#### Parameters:

portId: ID of the port

#### Returns:

#### **IxEthAccStatus**

- ♦ IX\_ETH\_ACC\_SUCCESS : Tx successfully disabled
- ◊ *IX\_ETH\_ACC\_FAIL* : Invalid port or Ethernet service not initialized
- ♦ *IX\_ETH\_ACC\_INVALID\_PORT* : portId is invalid.
- ♦ *IX\_ETH\_ACC\_PORT\_UNINITIALIZED* : portId is un–initialized

```
ixEthAccPortTxDoneCallbackRegister ( IxEthAccPortId portId, IxEthAccPortTxDoneCallback txCallbackFn, UINT32 callbackTag
```

Register a callback function to allow the transmitted buffers to return to the user.

This function registers the transmit buffer done function callback for a particular port.

The registered callback function is called once the previously submitted buffer is no longer required by this service. It may be returned upon successful transmission of the frame or shutdown of port prior to submission. The calling of this registered function is not a guarantee of successful transmission of the buffer.

If called several times the latest callback shall be registered for a particular port.

- Reentrant yes
- ISR Callable yes

#### Precondition:

The port must be initialized via ixEthAccPortInit

#### Parameters:

txCallbackFn IxEthAccPortTxDoneCallback [in] – Function to be called to return transmit

buffers to the user.

callbackTag UINT32 [in] – This tag shall be provided to the callback function.

#### Returns:

## **IxEthAccStatus**

- *♦ IX\_ETH\_ACC\_SUCCESS*
- ♦ *IX\_ETH\_ACC\_INVALID\_PORT* : portId is invalid.
- $\Diamond$  *IX\_ETH\_ACC\_PORT\_UNINITIALIZED* : portId is un–initialized
- ◊ IX\_ETH\_ACC\_INVALID\_ARG : An argument other than portId is invalid.

## **IxEthAccStatus** ixEthAccPortTxEnable ( **IxEthAccPortId** portId )

Enable Tx on the port.

This function is the complement of ixEthAccPortTxDisable and should be used only after Tx was disabled. A MAC core reset is required before this function is called (see *ixEthAccPortMacReset*).

This function is the recommended usage scenario for emergency security shutdown and hardware failure recovery and should never be used for throttling traffic.

- Reentrant yes
- ISR Callable no

#### Precondition:

#### Note:

Calling ixEthAccPortDisable followed by ixEthAccPortEnable is guaranteed to restore correct Ethernet Tx/Rx operation.

#### Parameters:

portId: ID of the port

#### Returns:

#### **IxEthAccStatus**

- ♦ *IX\_ETH\_ACC\_SUCCESS* : Tx successfully enabled
- ♦ IX\_ETH\_ACC\_FAIL : Invalid port or Ethernet service not initialized
- ♦ *IX\_ETH\_ACC\_INVALID\_PORT* : portId is invalid.
- ♦ IX\_ETH\_ACC\_PORT\_UNINITIALIZED : portId is un-initialized

## ixEthAccPortTxFrameAppendFCSDisable ( **IxEthAccPortId** portId )

Disable the appending of Ethernet FCS to all frames submitted to this port.

When disabled, the Ethernet FCS is not added to the submitted frames. This is not the default behavior of the access component.

#### Note:

Since the FCS is not appended to the frame it is expected that the frame submitted to the component includes a valid FCS at the end of the data, although this will not be validated.

The component shall forward the frame to the Ethernet MAC WITHOUT modification.

Do not change this behaviour while the port is enabled.

#### Note:

Tx FCS append is not disabled while Tx padding is enabled.

- Reentrant yes
- ISR Callable no

#### See also:

## ix Eth Acc Port Tx Frame Append Padding Enable

#### Parameters:

```
portId IxEthAccPortId [in]
```

#### Returns:

```
IxEthAccStatus
```

```
♦ IX_ETH_ACC_SUCCESS
```

- ♦ *IX\_ETH\_ACC\_INVALID\_PORT* : portId is invalid.
- $\Diamond$  *IX\_ETH\_ACC\_PORT\_UNINITIALIZED* : portId is un–initialized

## ixEthAccPortTxFrameAppendFCSEnable ( IxEthAccPortId portId )

Enable the appending of Ethernet FCS to all frames submitted to this port.

When enabled, the FCS is added to the submitted frames. This is the default behavior of the access component. Do not change this behaviour while the port is enabled.

- Reentrant yes
- ISR Callable no

#### Parameters:

```
portld IxEthAccPortId [in]
```

## Returns:

#### **IxEthAccStatus**

- *♦ IX\_ETH\_ACC\_SUCCESS*
- ♦ *IX\_ETH\_ACC\_INVALID\_PORT* : portId is invalid.
- ◊ IX ETH ACC PORT UNINITIALIZED: portId is un-initialized

## ixEthAccPortTxFrameAppendPaddingDisable ( **IxEthAccPortId** portId )

Disable padding bytes to be appended to runt frames submitted to this port.

Disable padding bytes to be appended to runt frames submitted to this port. This is not the default behavior of the access component.

#### Warning:

Do not change this behaviour while the port is enabled.

- Reentrant yes
- ISR Callable no

#### Parameters:

```
portId IxEthAccPortId [in]
```

#### Returns:

```
IxEthAccStatus
```

```
♦ IX_ETH_ACC_SUCCESS
```

- ♦ *IX\_ETH\_ACC\_INVALID\_PORT* : portId is invalid.
- ♦ *IX\_ETH\_ACC\_PORT\_UNINITIALIZED* : portId is un–initialized

## ixEthAccPortTxFrameAppendPaddingEnable ( IxEthAccPortId portId )

Enable padding bytes to be appended to runt frames submitted to this port.

Enable up to 60 null-bytes padding bytes to be appended to runt frames submitted to this port. This is the default behavior of the access component.

#### Warning:

Do not change this behaviour while the port is enabled.

#### Note:

When Tx padding is enabled, Tx FCS generation is turned on

- Reentrant yes
- ISR Callable no

#### See also:

ix Eth Acc Port Tx Frame Append FCS Dusable

#### Parameters:

```
portId IxEthAccPortId [in]
```

#### Returns:

```
IxEthAccStatus

◊ IX_ETH_ACC_SUCCESS

◊ IX_ETH_ACC_INVALID_PORT : portId is invalid.
```

```
ixEthAccPortTxFrameSubmit ( IxEthAccPortId portId, IX_OSAL_MBUF * buffer, IxEthAccTxPriority priority )
```

This function shall be used to submit MBUFs buffers for transmission on a particular MAC device.

When the frame is transmitted, the buffer shall be returned thru the callback *IxEthAccPortTxDoneCallback*.

In case of over–submitting, the order of the frames on the network may be modified.

Buffers shall be not queued for transmission if the port is disabled. The port can be enabled using *ixEthAccPortEnable* 

- Reentrant yes
- ISR Callable yes

#### Precondition:

*ixEthAccPortTxDoneCallbackRegister* must be called to register a function to allow this service to return the buffer to the calling service.

## Note:

If the buffer submit fails for any reason the user has retained ownership of the buffer.

#### Parameters:

```
portId IxEthAccPortId [in] – MAC port ID to transmit Ethernet frame on.
buffer [in] – pointer to an MBUF formatted buffer. Chained buffers are supported for transmission. Chained packets are not supported and the field IX_OSAL_MBUF_NEXT_PKT_IN_CHAIN_PTR is ignored.
priority IxEthAccTxPriority [in]
```

#### Returns:

```
IxEthAccStatus
```

```
♦ IX_ETH_ACC_SUCCESS
```

- ◊ *IX\_ETH\_ACC\_FAIL* : Failed to queue frame for transmission.
- ♦ *IX\_ETH\_ACC\_INVALID\_PORT* : portId is invalid.
- ♦ *IX\_ETH\_ACC\_PORT\_UNINITIALIZED* : portId is un–initialized

## ixEthAccPortUnicastAddressShow ( IxEthAccPortId portId )

Displays unicast MAC address.

Displays unicast address which is configured using *ixEthAccUnicastMacAddressSet*. This function also displays the MAC filter used to filter multicast frames.

Other functions modify the MAC filtering

- ixEthAccPortMulticastAddressJoinAll() all multicast frames are forwarded to the application
- ixEthAccPortMulticastAddressLeaveAll() rollback the effects of ixEthAccPortMulticastAddressJoinAll()
- *ixEthAccPortMulticastAddressLeave()* unprovision a new filtering address
- *ixEthAccPortMulticastAddressJoin()* provision a new filtering address
- *ixEthAccPortPromiscuousModeSet()* all frames are forwarded to the application regardless of the multicast address provisioned
- *ixEthAccPortPromiscuousModeClear()* frames are forwarded to the application following the multicast address provisioned

In all cases, unicast and broadcast addresses are forwarded to the application.

- Reentrant yes
- ISR Callable no

#### Parameters:

portId **IxEthAccPortId** [in] – Ethernet port id.

#### Returns:

void

Get unicast MAC address for a particular MAC port.

#### Precondition:

The MAC address must first be set via *ixEthAccMacPromiscuousModeSet* If the MAC address has not been set, the function returns a IX\_ETH\_ACC\_MAC\_UNINITIALIZED status

- Reentrant yes
- ISR Callable no

#### Parameters:

```
portId IxEthAccPortId [in] – Ethernet port id.*macAddr IxEthAccMacAddr [out] – Ethernet MAC address.
```

## Returns:

#### **IxEthAccStatus**

```
♦ IX_ETH_ACC_SUCCESS
```

- ♦ *IX\_ETH\_ACC\_INVALID\_PORT* : portId is invalid.
- ♦ *IX\_ETH\_ACC\_MAC\_UNINITIALIZED* : port MAC address is not initialized.
- ◊ *IX\_ETH\_ACC\_FAIL* : macAddr is invalid.

Configure unicast MAC address for a particular port.

```
• Reentrant – yes
```

• ISR Callable - no

#### Parameters:

## Returns:

```
IxEthAccStatus

$\langle IX_ETH_ACC_SUCCESS$

$\langle IX_ETH_ACC_INVALID_PORT : portId is invalid.

$\langle IX_ETH_ACC_PORT_UNINITIALIZED : portId is un-initialized
```

#### void ixEthAccQMgrRxNotificationDisable (void)

Disable queue interrupts for all Rx queues.

This function will write to the QMgr interrupt enable register, clearing the bits associated with the receive queues. It will then write to the QMgr status interrupt to clear any already pending interrupts associated with the receive queues. This means that no more interrupts can occur for these queues until the conditions are satisfied: the queues are completely drained, then the interrupt i enable register bits for the queues are re–enabled using **ixEthAccQMgrRxNotificationEnable()**.

```
• Reentrant – no
```

• ISR Callable – yes

#### void ixEthAccQMgrRxNotificationEnable (void)

Enable queue interrupts for all Rx queues.

This function will write to the QMgr interrupt enable register, adding the bits associated with the receive queues. After calling this function interrupts can occur for these queues given that the queues were properly drained prior to calling the function.

```
• Reentrant – no
```

• ISR Callable – yes

## **IxEthAccStatus** ixEthAccQMgrRxQEntryGet ( UINT32 \* numEntries )

Get the total number of receive buffers in all rx queues.

This function will queuery QMgr to get each receive queue's number of entries and store the total in the UINT32 pointed to by the numEntries parameter.

- Reentrant yes
- ISR Callable yes

## Precondition:

#### Parameters:

numEntries: pointer to UINT32 where the number of total entries can be written

## ixEthAccRxSchedulingDisciplineSet ( **IxEthAccSchedulerDiscipline** sched )

Set the Rx scheduling to one of *IxEthAccSchedulerDiscipline*.

The default behavior of the component is FIFO\_NO\_PRIORITY.

- Reentrant yes
- ISR Callable no

#### **Precondition:**

#### Parameters:

sched: IxEthAccSchedulerDiscipline

#### Returns:

## **IxEthAccStatus**

- ◊ IX\_ETH\_ACC\_SUCCESS : Set appropriate discipline.
- ◊ *IX\_ETH\_ACC\_FAIL* : Port is busy/priority scheduling not supported for A0.
- ♦ *IX\_ETH\_ACC\_INVALID\_ARG* : Invalid/unsupported discipline.

## ixEthAccStatsShow ( **IxEthAccPortId** portId )

Displays a ports statistics on the standard io console using printf.

• Reentrant – no

```
• ISR Callable - no
```

```
Precondition:
```

```
Parameters:
```

portId IxEthAccPortId [in]

#### Returns:

void

```
ixEthAccTxSchedulingDisciplineSet ( IxEthAccPortId portId, IxEthAccSchedulerDiscipline sched )
```

Set the port scheduling to one of *IxEthAccSchedulerDiscipline*.

The default behavior of the component is FIFO\_NO\_PRIORITY.

- Reentrant yes
- ISR Callable no

#### Precondition:

## Parameters:

```
portId IxEthAccPortId [in]
sched IxEthAccSchedulerDiscipline [in]
```

#### Returns:

```
IxEthAccStatus
```

```
    ◊ IX_ETH_ACC_SUCCESS : Set appropriate discipline.
    ◊ IX_ETH_ACC_INVALID_ARG : Invalid/unsupported discipline.
    ◊ IX_ETH_ACC_INVALID_PORT : portId is invalid.
```

♦ *IX\_ETH\_ACC\_PORT\_UNINITIALIZED* : portId is un–initialized

```
ixEthAccUninit ( void )
```

Un-Initializes the Intel (R) IXP400 Software Ethernet Access Service.

- Reentrant no
- ISR Callable no

This should be called once per module Un-initialization.

## Returns:

IxEthAccStatus

 $\Diamond$  IX\_ETH\_ACC\_SUCCESS

◊ *IX\_ETH\_ACC\_FAIL* : Service has failed to Un–initialize.

# Intel (R) IXP400 Software Ethernet Database (IxEthDB) API

ethDB is a library that does provides a MAC address database learning/filtering capability

## **Data Structures**

## struct IxEthDBMacAddr

The IEEE 802.3 Ethernet MAC address structure.

#### struct IxEthDBWiFiRecData

The user wi-fi input parameters structure.

# **Defines**

#define INLINE

#define IX ETH DB PRIVATE

#define IX\_ETH\_DB\_PUBLIC

#define IX IEEE803 MAC ADDRESS SIZE

The size of the MAC address.

## #define IX\_IEEE802\_1Q\_QOS\_PRIORITY\_COUNT

Number of QoS priorities defined by IEEE802.1Q.

## #define IX\_ETH\_DB\_802\_1Q\_VLAN\_MASK

VLAN mask.

## #define IX\_ETH\_DB\_802\_1Q\_QOS\_MASK

QoS Mask.

#### #define IX ETH DB 802 1Q MAX VLAN ID

Maximum VLAN IDs.

## #define IX ETH DB SET VLAN ID(vlanTag, vlanID)

returns the given 802.1Q tag with the VLAN ID field substituted with the given VLAN ID

## #define **IX\_ETH\_DB\_GET\_VLAN\_ID**(vlanTag)

returns the VLAN ID from the given 802.1Q tag

## #define IX\_ETH\_DB\_GET\_QOS\_PRIORITY(vlanTag)

gets the QOS priority from the given 802.1Q tag

## #define **IX\_ETH\_DB\_SET\_QOS\_PRIORITY**(vlanTag, priority)

sets the QOS priority to the given 802.1Q tag

- #define **IX\_ETH\_DB\_CHECK\_VLAN\_TAG**(vlanTag) checks the VLAN ID of the given 802.1Q tag
- #define **IX\_ETH\_DB\_CHECK\_VLAN\_ID**(vlanId) checks the VLAN ID
- #define **IX\_IEEE802\_1Q\_VLAN\_TPID**returns the VLAN TPID (0x8100)
- #define **IX\_ETH\_DB\_QOS\_TRAFFIC\_CLASS\_COUNT\_PROPERTY**Property identifying number the supported number of traffic classes.
- #define IX\_ETH\_DB\_QOS\_TRAFFIC\_CLASS\_0\_RX\_QUEUE\_PROPERTY

  Rx queue assigned to traffic class 0.
- #define IX\_ETH\_DB\_QOS\_TRAFFIC\_CLASS\_1\_RX\_QUEUE\_PROPERTY

  Rx queue assigned to traffic class 1.
- #define IX\_ETH\_DB\_QOS\_TRAFFIC\_CLASS\_2\_RX\_QUEUE\_PROPERTY Rx queue assigned to traffic class 2.
- #define IX\_ETH\_DB\_QOS\_TRAFFIC\_CLASS\_3\_RX\_QUEUE\_PROPERTY Rx queue assigned to traffic class 3.
- #define IX\_ETH\_DB\_QOS\_TRAFFIC\_CLASS\_4\_RX\_QUEUE\_PROPERTY

  Rx queue assigned to traffic class 4.
- #define IX\_ETH\_DB\_QOS\_TRAFFIC\_CLASS\_5\_RX\_QUEUE\_PROPERTY Rx queue assigned to traffic class 5.
- #define IX\_ETH\_DB\_QOS\_TRAFFIC\_CLASS\_6\_RX\_QUEUE\_PROPERTY

  Rx queue assigned to traffic class 6.
- #define IX\_ETH\_DB\_QOS\_TRAFFIC\_CLASS\_7\_RX\_QUEUE\_PROPERTY

  Rx queue assigned to traffic class 7.
- #define IX\_ETH\_DB\_QOS\_QUEUE\_CONFIGURATION\_COMPLETE

  Queue configuration complete.
- #define **IX\_ETH\_DB\_WIFI\_MIN\_PAD\_SIZE** *Minimum pad size.*
- #define IX\_ETH\_DB\_WIFI\_MAX\_PAD\_SIZE

  Maximum pad size.
- #define IX\_ETH\_DB\_MAINTENANCE\_TIME

  The ixEthDBDatabaseMaintenance must be called by the user at a frequency of IX\_ETH\_DB\_MAINTENANCE\_TIME.
- #define IX\_ETH\_DB\_LEARNING\_ENTRY\_AGE\_TIME

The define specifies the filtering database age entry time. Static entries older than IX\_ETH\_DB\_LEARNING\_ENTRY\_AGE\_TIME +/- IX\_ETH\_DB\_MAINTENANCE\_TIME shall be removed.

# **Typedefs**

## typedef UINT32 IxEthDBVlanId

VLAN ID type, valid range is 0..4094, 0 signifying no VLAN membership.

## typedef UINT32 IxEthDBVlanTag

802.1Q VLAN tag, contains 3 bits user priority, 1 bit CFI, 12 bits VLAN ID

## typedef UINT32 IxEthDBPriority

QoS priority/traffic class type, valid range is 0..7, 0 being the lowest.

## typedef UINT8 **IxEthDBPriorityTable** [8]

Priority mapping table; 0..7 QoS priorities used to index, table contains traffic classes.

## typedef UINT8 IxEthDBVlanSet [512]

A 4096 bit array used to map the complete VLAN ID range.

## typedef UINT32 IxEthDBProperty

Property ID type.

## typedef UINT32 IxEthDBPortId

Definition of an IXP400 port.

## typedef UINT8 IxEthDBPortMap [32]

Port dependency map definition.

# **Enumerations**

#### enum IxEthDBStatus {

IX\_ETH\_DB\_SUCCESS,

IX\_ETH\_DB\_FAIL,

IX\_ETH\_DB\_INVALID\_PORT,

IX\_ETH\_DB\_PORT\_UNINITIALIZED,

IX\_ETH\_DB\_MAC\_UNINITIALIZED,

IX\_ETH\_DB\_INVALID\_ARG,

IX\_ETH\_DB\_NO\_SUCH\_ADDR,

IX\_ETH\_DB\_NOMEM,

IX\_ETH\_DB\_BUSY,

IX\_ETH\_DB\_END,

IX\_ETH\_DB\_INVALID\_VLAN,

IX\_ETH\_DB\_INVALID\_PRIORITY,

IX\_ETH\_DB\_NO\_PERMISSION,

IX\_ETH\_DB\_FEATURE\_UNAVAILABLE,

Typedefs 192

```
IX ETH DB INVALID KEY,
     IX ETH DB INVALID RECORD TYPE
    Ethernet Database API return values.
enum IxEthDBFrameFilter {
     IX ETH DB UNTAGGED FRAMES.
     IX ETH DB VLAN TAGGED FRAMES,
     IX ETH DB PRIORITY TAGGED FRAMES,
     IX_ETH_DB_ACCEPT_ALL_FRAMES
enum IxEthDBTaggingAction {
     IX ETH DB PASS THROUGH,
     IX ETH DB ADD TAG,
     IX ETH DB REMOVE TAG.
     IX ETH DB ENABLE VLAN,
     IX ETH DB DISABLE VLAN
enum IxEthDBFirewallMode {
     IX_ETH_DB_FIREWALL_WHITE_LIST,
     IX ETH DB FIREWALL BLACK LIST
enum IxEthDBRecordType {
     IX ETH DB FILTERING RECORD,
     IX_ETH_DB_FILTERING_VLAN_RECORD,
     IX_ETH_DB_WIFI_RECORD,
     IX ETH DB FIREWALL RECORD.
     IX ETH DB GATEWAY RECORD,
     IX ETH DB MASK RECORD,
     IX ETH DB MAX RECORD TYPE INDEX.
     IX ETH DB NO RECORD TYPE,
     IX ETH DB ALL FILTERING RECORDS.
     IX ETH DB MASKED FIREWALL RECORD,
     IX ETH DB ALL RECORD TYPES
enum IxEthDBFeature {
     IX ETH DB LEARNING.
     IX ETH DB FILTERING,
     IX ETH DB VLAN QOS,
     IX ETH DB FIREWALL,
     IX ETH DB SPANNING TREE PROTOCOL,
     IX ETH DB WIFI HEADER CONVERSION.
     IX_ETH_DB_ADDRESS_MASKING
enum IxEthDBPropertyType {
     IX ETH DB INTEGER PROPERTY,
     IX ETH DB STRING PROPERTY,
     IX_ETH_DB_MAC_ADDR_PROPERTY,
     IX ETH DB BOOL PROPERTY
enum
```

Typedefs 193

```
IXEthDBWiFiRecordType {
    IX_ETH_DB_WIFI_AP_TO_STA,
    IX_ETH_DB_WIFI_AP_TO_AP,
    IX_ETH_DB_WIFI_TO_ETHER,
    IX_ETH_DB_WIFI_TO_LOCAL
    }
    The WI-FI record types enum.

enum IxEthDBWiFiVlanTag {
    IX_ETH_DB_WIFI_VLAN_NOTAG,
    IX_ETH_DB_WIFI_VLAN_TAG
    }
    The WI-FI VLAN tag/untag enum.
```

### **Functions**

IX\_ETH\_DB\_PUBLIC

IxEthDBStatus ixEthDBInit (void)

Initializes the Ethernet learning/filtering database.

IX ETH DB PUBLIC

IxEthDBStatus ixEthDBUnload (void)

Stops and prepares the EthDB component for unloading.

IX\_ETH\_DB\_PUBLIC

void ixEthDBPortInit (IxEthDBPortId portID)

Initializes a port.

IX ETH DB PUBLIC

IxEthDBStatus ixEthDBPortEnable (IxEthDBPortId portID)

Enables a port.

IX\_ETH\_DB\_PUBLIC

IxEthDBStatus ixEthDBPortDisable (IxEthDBPortId portID)

Disables processing on a port.

IX\_ETH\_DB\_PUBLIC

IxEthDBStatus ixEthDBPortAddressSet (IxEthDBPortId portID, IxEthDBMacAddr \*macAddr)

Sets the port MAC address.

IX\_ETH\_DB\_PUBLICixEthDBFilteringPortMaximumFrameSizeSet (IxEthDBPortId portID, UINT32 IxEthDBStatus maximumFrameSize)

Set the maximum frame size supported on the given port ID.

IX\_ETH\_DB\_PUBLICixEthDBFilteringStaticEntryProvision (IxEthDBPortId portID,

IxEthDBStatus IxEthDBMacAddr \*macAddr)

Populate the Ethernet learning/filtering database with a static MAC address.

### $IX\_ETH\_DB\_PUBLIC \textbf{ixEthDBFilteringDynamicEntryProvision} \ (\textbf{IxEthDBPortId} \ portID, \\ \textbf{IxEthDBStatus} \ \textbf{IxEthDBMacAddr} \ *macAddr)$

*Populate the Ethernet learning/filtering database with a dynamic MAC address.* 

#### IX\_ETH\_DB\_PUBLIC

#### $\textbf{IxEthDBS} \textbf{tatus ixEthDBF} \textbf{ilteringEntryDelete} \ (\textbf{IxEthDBMacAddr} \ * \textbf{macAddr})$

Removes a MAC address entry from the Ethernet learning/filtering database.

### IX\_ETH\_DB\_PUBLICixEthDBFilteringPortSearch (IxEthDBPortId portID, IxEthDBMacAddr IxEthDBStatus \*macAddr)

Search the Ethernet learning/filtering database for the given MAC address and port ID.

### IX\_ETH\_DB\_PUBLICixEthDBFilteringDatabaseSearch (IxEthDBPortId \*portID, IxEthDBMacAddr IxEthDBStatus \*macAddr)

Search the Ethernet learning/filtering database for a MAC address and return the port ID.

### $IX\_ETH\_DB\_PUBLIC \textbf{ix} \textbf{Eth} \textbf{DBFilteringPortUpdatingSearch} \ (\textbf{Ix} \textbf{Eth} \textbf{DBPortId} \ *portID,$

#### **IxEthDBStatus IxEthDBMacAddr** \*macAddr)

Search the filtering database for a MAC address, return the port ID and reset the record age.

#### IX\_ETH\_DB\_PUBLIC

### $\textbf{IxEthDBS} tatus \ \textbf{ixEthDBPortAgingDisable} \ (\textbf{IxEthDBPortId} \ portID)$

Disable the aging function for a specific port.

#### IX ETH DB PUBLIC

#### IxEthDBStatus ixEthDBPortAgingEnable (IxEthDBPortId portID)

Enable the aging function for a specific port.

#### IX ETH DB PUBLIC

#### void ixEthDBDatabaseMaintenance (void)

*Performs a maintenance operation on the Ethernet learning/filtering database.* 

#### IX ETH DB PUBLIC

#### IxEthDBStatus ixEthDBFilteringDatabaseShow (IxEthDBPortId portID)

This function displays the Mac Ethernet MAC address filtering tables.

#### IX\_ETH\_DB\_PUBLIC

#### void ixEthDBFilteringDatabaseShowAll (void)

Displays the MAC address recorded in the filtering database for all registered ports (see *IxEthDBPortDefs.h*), grouped by port ID.

### IX\_ETH\_DB\_PUBLICixEthDBFilteringDatabaseShowRecords (IxEthDBPortId portID,

 $IxEthDBS tatus\ IxEthDBRecordType\ {\tt recordFilter})$ 

This function displays per port database records, given a record type filter.

### IX\_ETH\_DB\_PUBLICixEthDBPortDependencyMapSet (IxEthDBPortId portID, IxEthDBPortMap IxEthDBStatus dependencyPortMap)

Sets the dependency port map for a port.

### IX\_ETH\_DB\_PUBLICixEthDBPortDependencyMapGet (IxEthDBPortId portID, IxEthDBPortMap IxEthDBStatus dependencyPortMap)

Retrieves the dependency port map for a port.

#### IX ETH DB PUBLIC

**IxEthDBStatus ixEthDBPortVlanTagSet** (**IxEthDBPortId** portID, **IxEthDBVlanTag** vlanTag)

Sets the default 802.1Q VLAN tag for a given port.

#### IX ETH DB PUBLIC

**IxEthDBStatus ixEthDBPortVlanTagGet** (**IxEthDBPortId** portID, **IxEthDBVlanTag** \*vlanTag)

Retrieves the default 802.1Q port VLAN tag for a given port (see also

ixEthDBPortVlanTagSet).

#### IX ETH DB PUBLIC

**IxEthDBStatus ixEthDBVlanTagSet (IxEthDBMacAddr** \*macAddr, **IxEthDBVlanTag** vlanTag)

Sets the 802.1Q VLAN tag for a database record.

### IX\_ETH\_DB\_PUBLICixEthDBVlanTagGet (IxEthDBMacAddr \*macAddr, IxEthDBVlanTag IxEthDBStatus \*vlanTag)

Retrieves the 802.1Q VLAN tag from a database record given the record MAC address.

### IX\_ETH\_DB\_PUBLICixEthDBPortVlanMembershipAdd (IxEthDBPortId portID, IxEthDBVlanId IxEthDBStatus vlanID)

Adds a VLAN ID to a port's VLAN membership table.

# IX\_ETH\_DB\_PUBLICixEthDBPortVlanMembershipRangeAdd (IxEthDBPortId portID, IxEthDBStatus IxEthDBVlanId vlanIDMin, IxEthDBVlanId vlanIDMax)

Adds a VLAN ID range to a port's VLAN membership table.

### IX\_ETH\_DB\_PUBLICixEthDBPortVlanMembershipRemove (IxEthDBPortId portID, IxEthDBVlanId IxEthDBStatus vlanID)

Removes a VLAN ID from a port's VLAN membership table.

## $IX\_ETH\_DB\_PUBLIC \textbf{ixEthDBPortVlanMembershipRangeRemove} \ (\textbf{IxEthDBPortId} \ portID, \\ \textbf{IxEthDBStatus} \ \textbf{IxEthDBVlanId} \ vlanIDMin, \ \textbf{IxEthDBVlanId} \ vlanIDMax)$

Removes a VLAN ID range from a port's VLAN membership table.

## IX\_ETH\_DB\_PUBLICixEthDBPortVlanMembershipSet (IxEthDBPortId portID, IxEthDBVlanSet IxEthDBStatus vlanSet)

Sets a port's VLAN membership table.

## IX\_ETH\_DB\_PUBLICixEthDBPortVlanMembershipGet (IxEthDBPortId portID, IxEthDBVlanSet IxEthDBStatus vlanSet)

Retrieves a port's VLAN membership table.

### IX\_ETH\_DB\_PUBLICixEthDBAcceptableFrameTypeSet (IxEthDBPortId portID, IxEthDBStatus IxEthDBFrameFilter)

Sets a port's acceptable frame type filter.

### IX\_ETH\_DB\_PUBLICixEthDBAcceptableFrameTypeGet (IxEthDBPortId portID, IxEthDBStatus IxEthDBFrameFilter \*frameFilter)

Retrieves a port's acceptable frame type filter.

### IX\_ETH\_DB\_PUBLICixEthDBPriorityMappingTableSet (IxEthDBPortId portID, IxEthDBStatus IxEthDBPriorityTable priorityTable)

Sets a port's priority mapping table.

### IX\_ETH\_DB\_PUBLICixEthDBPriorityMappingTableGet (IxEthDBPortId portID, IxEthDBStatus IxEthDBPriorityTable)

Retrieves a port's priority mapping table.

## IX\_ETH\_DB\_PUBLICixEthDBPriorityMappingClassSet (IxEthDBPortId portID, IxEthDBPriority IxEthDBStatus userPriority, IxEthDBPriority trafficClass)

Sets one QoS/user priority => traffic class mapping in a port's priority mapping table.

## IX\_ETH\_DB\_PUBLICixEthDBPriorityMappingClassGet (IxEthDBPortId portID, IxEthDBPriority IxEthDBStatus userPriority, IxEthDBPriority \*trafficClass)

Retrieves one QoS/user priority => traffic class mapping in a port's priority mapping table.

### IX\_ETH\_DB\_PUBLICixEthDBEgressVlanEntryTaggingEnabledSet (IxEthDBPortId portID, IxEthDBStatus IxEthDBVlanId vlanID, BOOL enabled)

Enables or disables Egress VLAN tagging for a port and a given VLAN.

## $IX\_ETH\_DB\_PUBLIC \textbf{ixEthDBE} \textbf{gressVlanEntryTaggingEnabledGet} \ (\textbf{IxEthDBPortId} \ portID, \\ \textbf{IxEthDBS} \textbf{tatus} \ \textbf{IxEthDBVlanId} \ vlanID, \ BOOL \ *enabled)$

Retrieves the Egress VLAN tagging enabling status for a port and VLAN ID.

# IX\_ETH\_DB\_PUBLICixEthDBEgressVlanRangeTaggingEnabledSet (IxEthDBPortId portID, IxEthDBStatus IxEthDBVlanId vlanIDMin, IxEthDBVlanId vlanIDMax, BOOL enabled) Enables or disables Egress VLAN tagging for a port and given VLAN range.

## IX\_ETH\_DB\_PUBLICixEthDBEgressVlanTaggingEnabledSet (IxEthDBPortId portID, IxEthDBStatus IxEthDBVlanSet vlanSet)

*Sets the complete Egress VLAN tagging table for a port.* 

## IX\_ETH\_DB\_PUBLICixEthDBEgressVlanTaggingEnabledGet (IxEthDBPortId portID, IxEthDBStatus IxEthDBVlanSet vlanSet)

Retrieves the complete Egress VLAN tagging table from a port.

## IX\_ETH\_DB\_PUBLICixEthDBIngressVlanTaggingEnabledSet (IxEthDBPortId portID, IxEthDBStatus IxEthDBTaggingAction taggingAction)

Sets the Ingress VLAN tagging behavior for a port.

## IX\_ETH\_DB\_PUBLICixEthDBIngressVlanTaggingEnabledGet (IxEthDBPortId portID, IxEthDBStatus IxEthDBTaggingAction \*taggingAction)

Retrieves the Ingress VLAN tagging behavior from a port (see ixEthDBIngressVlanTaggingEnabledSet).

#### IX ETH DB PUBLIC

**IxEthDBStatus ixEthDBVlanPortExtractionEnable (IxEthDBPortId** portID, BOOL enable) *Enables or disables port ID extraction.* 

### IX\_ETH\_DB\_PUBLICixEthDBFeatureCapabilityGet (IxEthDBPortId portID, IxEthDBFeature IxEthDBStatus \*featureSet)

Retrieves the feature capability set for a port.

### IX\_ETH\_DB\_PUBLICixEthDBFeatureEnable (IxEthDBPortId portID, IxEthDBFeature feature, BOOL IxEthDBStatus enabled)

Enables or disables one or more EthDB features.

### IX\_ETH\_DB\_PUBLICixEthDBFeatureStatusGet (IxEthDBPortId portID, IxEthDBFeature feature, IxEthDBStatus BOOL \*present, BOOL \*enabled)

Retrieves the availability and status of a feature set.

# IX\_ETH\_DB\_PUBLICixEthDBFeaturePropertyGet (IxEthDBPortId portID, IxEthDBFeature feature, IxEthDBStatus IxEthDBProperty property, IxEthDBPropertyType \*type, void \*value) \*Retrieves the value of a feature property.

## IX\_ETH\_DB\_PUBLICixEthDBFeaturePropertySet (IxEthDBPortId portID, IxEthDBFeature feature, IxEthDBStatus IxEthDBProperty property, void \*value)

Sets the value of a feature property.

## IX\_ETH\_DB\_PUBLICixEthDBDatabaseClear (IxEthDBPortId portID, IxEthDBRecordType IxEthDBStatus recordType)

*Deletes a set of record types from the Ethernet Database.* 

## IX\_ETH\_DB\_PUBLICixEthDBWiFiRecordEntryAdd (IxEthDBPortId portID, IxEthDBMacAddr IxEthDBStatus \*macAddr, IxEthDBWiFiRecData \*wifiRecData)

Adds "APMAC/BSSID/STATIONS" record to the database, for 802.3 => 802.11 frame header conversion.

## $IX\_ETH\_DB\_PUBLIC \textbf{ixEthDBWiFiStationEntryAdd} \ (\textbf{IxEthDBPortId} \ portID, \textbf{IxEthDBMacAddr} \\ \textbf{IxEthDBStatus} \ *macAddr)$

Adds an "Access Point to Station" record to the database, for 802.3 => 802.11 frame header conversion.

### IX\_ETH\_DB\_PUBLICixEthDBWiFiAccessPointEntryAdd (IxEthDBPortId portID, IxEthDBMacAddr IxEthDBStatus \*macAddr, IxEthDBMacAddr \*gatewayMacAddr)

Adds an "Access Point to Access Point" record to the database.

### IX\_ETH\_DB\_PUBLICixEthDBWiFiEntryRemove (IxEthDBPortId portID, IxEthDBMacAddr IxEthDBStatus \*macAddr)

Removes a WiFi station record.

#### IX ETH DB PUBLIC

 $\textbf{IxEthDBS} \textbf{tatus ixEthDBWiFiConversionTableDownload} \ (\textbf{IxEthDBPortId} \ portID)$ 

Downloads the MAC address table for 802.3 = 802.11 frame header conversion to the NPE.

#### IX ETH DB PUBLIC

**IxEthDBStatus ixEthDBWiFiFrameControlSet** (**IxEthDBPortId** portID, UINT16 frameControl) *Sets the GlobalFrameControl field.* 

#### IX ETH DB PUBLIC

**IxEthDBStatus ixEthDBWiFiDurationIDSet** (**IxEthDBPortId** portID, UINT16 durationID)

Sets the GlobalDurationID field.

#### IX ETH DB PUBLIC

**IxEthDBStatus ixEthDBWiFiBSSIDSet** (**IxEthDBPortId** portID, **IxEthDBMacAddr** \*bssid)

Sets the BSSID field.

IX\_ETH\_DB\_PUBLICixEthDBSpanningTreeBlockingStateSet (IxEthDBPortId portID, BOOL IxEthDBStatus blocked)

Sets the STP blocked/unblocked state for a port.

IX\_ETH\_DB\_PUBLICixEthDBSpanningTreeBlockingStateGet (IxEthDBPortId portID, BOOL IxEthDBStatus \*blocked)

Retrieves the STP blocked/unblocked state for a port.

IX\_ETH\_DB\_PUBLICixEthDBFirewallModeSet (IxEthDBPortId portID, IxEthDBFirewallMode IxEthDBStatus mode)

Sets the firewall mode to use white or black listing.

IX\_ETH\_DB\_PUBLICixEthDBFirewallInvalidAddressFilterEnable (IxEthDBPortId portID, BOOL IxEthDBStatus enable)

Enables or disables invalid MAC address filtering.

 $IX\_ETH\_DB\_PUBLIC \textbf{ixEthDBFirewallEntryAdd} \ (\textbf{IxEthDBPortId} \ portID, \textbf{IxEthDBMacAddr} \\ \textbf{IxEthDBStatus} * macAddr)$ 

Adds a MAC address to the firewall address list.

 $IX\_ETH\_DB\_PUBLIC \textbf{ixEthDBFirewallEntryRemove} \ (\textbf{IxEthDBPortId} \ portID, \textbf{IxEthDBMacAddr} \\ \textbf{IxEthDBStatus} \ *macAddr)$ 

Removes a MAC address from the firewall address list.

IX\_ETH\_DB\_PUBLICixEthDBFirewallMaskedEntryAdd (IxEthDBPortId portID, IxEthDBMacAddr IxEthDBStatus \*macAddr, IxEthDBMacAddr \*addrMask)

Adds a MAC address + mask to the firewall address list.

IX\_ETH\_DB\_PUBLICixEthDBFirewallMaskedEntryRemove (IxEthDBPortId portID, IxEthDBStatus IxEthDBMacAddr \*macAddr, IxEthDBMacAddr \*addrMask)

Removes a MAC address + mask from the firewall address list.

IX ETH DB PUBLIC

IxEthDBStatus ixEthDBFirewallTableDownload (IxEthDBPortId portID)

Downloads the MAC firewall table to a port.

IX\_ETH\_DB\_PUBLICixEthDBUserFieldSet (IxEthDBRecordType recordType, IxEthDBMacAddr IxEthDBStatus \*macAddr, IxEthDBPortId portID, IxEthDBVlanId vlanID, void \*field)

Adds a user-defined field to a database record.

IX\_ETH\_DB\_PUBLICixEthDBUserFieldGet (IxEthDBRecordType recordType, IxEthDBMacAddr IxEthDBStatus \*macAddr, IxEthDBPortId portId, IxEthDBVlanId vlanID, void \*\*field)

Retrieves a user—defined field from a database record.

### **Detailed Description**

ethDB is a library that does provides a MAC address database learning/filtering capability

### **Define Documentation**

#define IX\_ETH\_DB\_802\_1Q\_MAX\_VLAN\_ID

Maximum VLAN IDs.

Definition at line **85** of file **IxEthDB.h**.

#define IX\_ETH\_DB\_802\_1Q\_QOS\_MASK

QoS Mask.

Definition at line 83 of file IxEthDB.h.

#define IX\_ETH\_DB\_802\_1Q\_VLAN\_MASK

VLAN mask.

Definition at line 82 of file IxEthDB.h.

#define IX\_ETH\_DB\_CHECK\_VLAN\_ID ( vlanId )

checks the VLAN ID

Definition at line 129 of file IxEthDB.h.

#define IX\_ETH\_DB\_CHECK\_VLAN\_TAG ( vlanTag )

checks the VLAN ID of the given 802.1Q tag

Definition at line 123 of file IxEthDB.h.

#### #define IX\_ETH\_DB\_GET\_QOS\_PRIORITY ( vlanTag )

gets the QOS priority from the given 802.1Q tag

Definition at line 111 of file IxEthDB.h.

#### #define IX\_ETH\_DB\_GET\_VLAN\_ID ( vlanTag )

returns the VLAN ID from the given 802.1Q tag

Definition at line 105 of file IxEthDB.h.

#### #define IX\_ETH\_DB\_LEARNING\_ENTRY\_AGE\_TIME

The define specifies the filtering database age entry time. Static entries older than IX\_ETH\_DB\_LEARNING\_ENTRY\_AGE\_TIME +/- IX\_ETH\_DB\_MAINTENANCE\_TIME shall be removed.

Definition at line **644** of file **IxEthDB.h**.

#### #define IX\_ETH\_DB\_MAINTENANCE\_TIME

The **ixEthDBDatabaseMaintenance** must be called by the user at a frequency of IX\_ETH\_DB\_MAINTENANCE\_TIME.

Definition at line **633** of file **IxEthDB.h**.

#### #define IX\_ETH\_DB\_QOS\_QUEUE\_CONFIGURATION\_COMPLETE

Queue configuration complete.

Definition at line 222 of file IxEthDB.h.

#### #define IX\_ETH\_DB\_QOS\_TRAFFIC\_CLASS\_0\_RX\_QUEUE\_PROPERTY

Rx queue assigned to traffic class 0.

Definition at line 212 of file IxEthDB.h.

#### #define IX ETH DB QOS TRAFFIC CLASS 1 RX QUEUE PROPERTY

Rx queue assigned to traffic class 1.

Definition at line **213** of file **IxEthDB.h**.

#### #define IX\_ETH\_DB\_QOS\_TRAFFIC\_CLASS\_2\_RX\_QUEUE\_PROPERTY

Rx queue assigned to traffic class 2.

Definition at line 214 of file IxEthDB.h.

#### #define IX\_ETH\_DB\_QOS\_TRAFFIC\_CLASS\_3\_RX\_QUEUE\_PROPERTY

Rx queue assigned to traffic class 3.

Definition at line 215 of file IxEthDB.h.

#### #define IX\_ETH\_DB\_QOS\_TRAFFIC\_CLASS\_4\_RX\_QUEUE\_PROPERTY

Rx queue assigned to traffic class 4.

Definition at line 216 of file IxEthDB.h.

#### #define IX\_ETH\_DB\_QOS\_TRAFFIC\_CLASS\_5\_RX\_QUEUE\_PROPERTY

Rx queue assigned to traffic class 5.

Definition at line 217 of file IxEthDB.h.

#### #define IX\_ETH\_DB\_QOS\_TRAFFIC\_CLASS\_6\_RX\_QUEUE\_PROPERTY

Rx queue assigned to traffic class 6.

Definition at line 218 of file IxEthDB.h.

#### #define IX\_ETH\_DB\_QOS\_TRAFFIC\_CLASS\_7\_RX\_QUEUE\_PROPERTY

Rx queue assigned to traffic class 7.

Definition at line 219 of file IxEthDB.h.

#### #define IX\_ETH\_DB\_QOS\_TRAFFIC\_CLASS\_COUNT\_PROPERTY

Property identifying number the supported number of traffic classes.

Definition at line 211 of file IxEthDB.h.

```
#define IX_ETH_DB_SET_QOS_PRIORITY ( vlanTag, priority )
```

sets the QOS priority to the given 802.1Q tag

Definition at line 117 of file IxEthDB.h.

```
#define IX_ETH_DB_SET_VLAN_ID ( vlanTag, vlanID )
```

returns the given 802.1Q tag with the VLAN ID field substituted with the given VLAN ID

This macro is used to change the VLAN ID in a 802.1Q tag.

Example:

```
tag = IX\_ETH\_DB\_SET\_VLAN\_ID(tag, 32)
```

inserts the VLAN ID "32" in the given tag.

Definition at line 99 of file IxEthDB.h.

#### #define IX\_ETH\_DB\_WIFI\_MAX\_PAD\_SIZE

Maximum pad size.

Definition at line 226 of file IxEthDB.h.

### #define IX\_ETH\_DB\_WIFI\_MIN\_PAD\_SIZE

Minimum pad size.

Definition at line 225 of file IxEthDB.h.

#### #define IX\_IEEE802\_1Q\_QOS\_PRIORITY\_COUNT

Number of QoS priorities defined by IEEE802.1Q.

Definition at line 41 of file IxEthDB.h.

#### #define IX\_IEEE802\_1Q\_VLAN\_TPID

returns the VLAN TPID (0x8100)

Definition at line 135 of file IxEthDB.h.

#### #define IX\_IEEE803\_MAC\_ADDRESS\_SIZE

The size of the MAC address.

Definition at line 35 of file IxEthDB.h.

### **Typedef Documentation**

#### typedef UINT32 IxEthDBPortId

Definition of an IXP400 port.

Definition at line 290 of file IxEthDB.h.

#### typedef UINT8 IxEthDBPortMap[32]

Port dependency map definition.

Definition at line 297 of file IxEthDB.h.

#### typedef UINT32 IxEthDBPriority

QoS priority/traffic class type, valid range is 0..7, 0 being the lowest.

Definition at line **74** of file **IxEthDB.h**.

#### typedef UINT8 IxEthDBPriorityTable[8]

Priority mapping table; 0..7 QoS priorities used to index, table contains traffic classes.

Definition at line 77 of file **IxEthDB.h**.

#### typedef UINT32 IxEthDBProperty

Property ID type.

Definition at line **200** of file **IxEthDB.h**.

#### typedef UINT32 IxEthDBVlanId

VLAN ID type, valid range is 0..4094, 0 signifying no VLAN membership.

Definition at line **68** of file **IxEthDB.h**.

#### typedef UINT8 IxEthDBVlanSet[512]

A 4096 bit array used to map the complete VLAN ID range.

Definition at line **80** of file **IxEthDB.h**.

#### typedef UINT32 IxEthDBVlanTag

802.1Q VLAN tag, contains 3 bits user priority, 1 bit CFI, 12 bits VLAN ID

Definition at line **71** of file **IxEthDB.h**.

### **Enumeration Type Documentation**

#### enum IxEthDBFeature

| Enume    | ration | val | 1105. |
|----------|--------|-----|-------|
| Lilluine | uuioii | rui | uvs.  |

IX\_ETH\_DB\_LEARNING Learning feature; enables EthDB to learn MAC

address (filtering) records, including 802.1Q

enabled records.

IX\_ETH\_DB\_FILTERING Filtering feature; enables EthDB to communicate

with the NPEs for downloading filtering

information in the NPEs; depends on the learning

feature.

IX\_ETH\_DB\_VLAN\_QOS VLAN/QoS feature; enables EthDB to configure

NPEs to operate in VLAN/QoS aware modes.

IX\_ETH\_DB\_FIREWALL Firewall feature; enables EthDB to configure NPEs

to operate in firewall mode, using white/black

address lists.

IX\_ETH\_DB\_SPANNING\_TREE\_PROTOCOL Spanning tree protocol feature; enables EthDB to

configure the NPEs as STP nodes.

IX\_ETH\_DB\_WIFI\_HEADER\_CONVERSION WiFi 802.3 to 802.11 header conversion feature;

enables EthDB to handle WiFi conversion data.

IX\_ETH\_DB\_ADDRESS\_MASKING

Masking of MAC addresses using an address mask.

Currently only usable in conjunction with the IX ETH DB FIREWALL feature

Definition at line 189 of file IxEthDB.h.

#### enum IxEthDBFirewallMode

#### Enumeration values:

*IX\_ETH\_DB\_FIREWALL\_WHITE\_LIST* Firewall operates in white–list mode (MAC address based admission).

*IX\_ETH\_DB\_FIREWALL\_BLACK\_LIST* Firewall operates in black–list mode (MAC address based blocking).

Definition at line 155 of file IxEthDB.h.

#### enum IxEthDBFrameFilter

#### **Enumeration values:**

IX\_ETH\_DB\_UNTAGGED\_FRAMES Accepts untagged frames. IX\_ETH\_DB\_VLAN\_TAGGED\_FRAMES Accepts tagged frames.

IX\_ETH\_DB\_PRIORITY\_TAGGED\_FRAMES Accepts tagged frames with VLAN ID set to 0 (no

VLAN membership).

IX\_ETH\_DB\_ACCEPT\_ALL\_FRAMES Accepts all the frames.

Definition at line 137 of file IxEthDB.h.

#### enum IxEthDBPropertyType

#### **Enumeration values:**

*IX\_ETH\_DB\_INTEGER\_PROPERTY* 4 byte unsigned integer type

IX\_ETH\_DB\_STRING\_PROPERTY NULL—terminated string type of maximum 255

characters (including the terminator).

IX\_ETH\_DB\_MAC\_ADDR\_PROPERTY 6 byte MAC address type

IX\_ETH\_DB\_BOOL\_PROPERTY 4 byte boolean type; can contain only TRUE and FALSE

values

Definition at line 202 of file IxEthDB.h.

#### enum IxEthDBRecordType

**Enumeration values:** 

IX\_ETH\_DB\_FILTERING\_RECORD Filtering record

MAC address static/dynamic type age

IX\_ETH\_DB\_FILTERING\_VLAN\_RECORD VLAN—enabled filtering record

MAC address static/dynamic type age 802.1Q tag

IX\_ETH\_DB\_WIFI\_RECORD WiFi header conversion record

MAC optional gateway MAC address

IX\_ETH\_DB\_FIREWALL\_RECORD Firewall record

MAC address

IX\_ETH\_DB\_GATEWAY\_RECORD For internal use only
IX\_ETH\_DB\_MASK\_RECORD For internal use only
IX\_ETH\_DB\_MAX\_RECORD\_TYPE\_INDEX For internal use only

IX\_ETH\_DB\_NO\_RECORD\_TYPE None of the registered record types.

IX\_ETH\_DB\_ALL\_FILTERING\_RECORDS All the filtering records. IX\_ETH\_DB\_MASKED\_FIREWALL\_RECORD Masked firewall records.

IX\_ETH\_DB\_ALL\_RECORD\_TYPES All the record types registered within

EthDB.

Definition at line 161 of file IxEthDB.h.

#### enum IxEthDBStatus

Ethernet Database API return values.

#### Enumeration values:

IX\_ETH\_DB\_SUCCESSSuccess.IX\_ETH\_DB\_FAILFailure.IX\_ETH\_DB\_INVALID\_PORTInvalid port.IX\_ETH\_DB\_PORT\_UNINITIALIZEDPort not initialized.IX\_ETH\_DB\_MAC\_UNINITIALIZEDMAC not initialized.IX\_ETH\_DB\_INVALID\_ARGInvalid argument.

IX\_ETH\_DB\_NO\_SUCH\_ADDR Address not found for search or delete operations.

IX\_ETH\_DB\_NOMEM Learning database memory full.

IX\_ETH\_DB\_BUSY Learning database cannot complete operation, access

temporarily blocked.

IX\_ETH\_DB\_END Database browser passed the end of the record set.

IX\_ETH\_DB\_INVALID\_VLAN Invalid VLAN ID (valid range is 0..4094, 0 signifies no VLAN membership, used for priority tagged frames).

IX\_ETH\_DB\_INVALID\_PRIORITY Invalid QoS priority/traffic class (valid range for QoS

priority is 0..7, valid range for traffic class depends on

run-time configuration).

IX\_ETH\_DB\_NO\_PERMISSION No permission for attempted operation. IX\_ETH\_DB\_FEATURE\_UNAVAILABLE Feature not available (or not enabled).

IX\_ETH\_DB\_INVALID\_KEY Invalid search key.
IX\_ETH\_DB\_INVALID\_RECORD\_TYPE Invalid record type.

Definition at line 47 of file IxEthDB.h.

#### enum IxEthDBTaggingAction

#### Enumeration values:

*IX\_ETH\_DB\_PASS\_THROUGH* Leave frame as–is.

IX\_ETH\_DB\_ADD\_TAG Add default port

VLAN tag.

IX\_ETH\_DB\_REMOVE\_TAG Remove VLAN tag

from frame.

IX\_ETH\_DB\_ENABLE\_VLAN VLAN enable bit.IX\_ETH\_DB\_DISABLE\_VLAN VLAN disable bit.

Definition at line 146 of file IxEthDB.h.

#### enum IxEthDBWiFiRecordType

The WI-FI record types enum.

The type value should be any of the types

#### **Enumeration values:**

IX\_ETH\_DB\_WIFI\_AP\_TO\_STA Ap to Sta

record.

IX\_ETH\_DB\_WIFI\_AP\_TO\_AP Ap to Ap

record.

*IX\_ETH\_DB\_WIFI\_TO\_ETHER* To Ether

record.

IX\_ETH\_DB\_WIFI\_TO\_LOCAL To Local

record.

Definition at line **248** of file **IxEthDB.h**.

#### enum IxEthDBWiFiVlanTag

The WI-FI VLAN tag/untag enum.

The tag value should be either tag or untag

#### **Enumeration values:**

```
IX_ETH_DB_WIFI_VLAN_NOTAG Tag 802.11 frames.

IX_ETH_DB_WIFI_VLAN_TAG Untag 802.11 frames.
```

Definition at line 263 of file IxEthDB.h.

### **Function Documentation**

```
      IxEthDBStatus
      ixEthDBAcceptableFrameTypeGet
      ( IxEthDBPortId portID, IxEthDBFrameFilter * frameFilter * frameFilter * frameFilter )
```

Retrieves a port's acceptable frame type filter.

For a description of the acceptable frame types see ixEthDBAcceptableFrameTypeSet

- Reentrant no
- ISR Callable no

#### Parameters:

portID **IxEthDBPortId** [in] – port ID to retrieve the acceptable frame type filter from frameFilter **IxEthDBFrameFilter** [out] – location to store the acceptable frame type filter

#### Return values:

```
    IX_ETH_DB_SUCCESS operation completed successfully
    IX_ETH_DB_INVALID_PORT portID is not a valid port identifier
    IX_ETH_DB_PORT_UNINITIALIZED port is not initialized
    IX_ETH_DB_INVALID_ARG invalid frameFilter pointer argument
    IX_ETH_DB_FEATURE_UNAVAILABLE VLAN/QoS feature is not available or not enabled for the port
```

```
      IxEthDBStatus ixEthDBAcceptableFrameTypeSet (IxEthDBPortId portID, IxEthDBFrameFilter frameFilter)
```

Sets a port's acceptable frame type filter.

The acceptable frame type is one (or a combination) of the following values:

- IX\_ETH\_DB\_ACCEPT\_ALL\_FRAMES accepts all the frames
- IX\_ETH\_DB\_UNTAGGED\_FRAMES accepts untagged frames
- IX ETH DB VLAN TAGGED FRAMES accepts tagged frames
- IX\_ETH\_DB\_PRIORITY\_TAGGED\_FRAMES accepts tagged frames with VLAN ID set to 0 (no VLAN membership)

Except for using the exact values given above only the following combinations are valid:

- IX ETH DB UNTAGGED FRAMES | IX ETH DB VLAN TAGGED FRAMES
- IX\_ETH\_DB\_UNTAGGED\_FRAMES | IX\_ETH\_DB\_PRIORITY\_TAGGED\_FRAMES

Please note that IX\_ETH\_DB\_UNTAGGED\_FRAMES | IX\_ETH\_DB\_VLAN\_TAGGED\_FRAMES is equivalent to IX\_ETH\_DB\_ACCEPT\_ALL\_FRAMES.

- Reentrant no
- ISR Callable no

#### Note:

by default the acceptable frame type filter is set to IX ETH DB ACCEPT ALL FRAMES

setting the acceptable frame type to PRIORITY\_TAGGED\_FRAMES is internally accomplished by changing the frame filter to VLAN\_TAGGED\_FRAMES and setting the VLAN membership list to include only VLAN ID 0; the membership list will need to be restored manually to an appropriate value if the acceptable frame type filter is changed back to ACCEPT\_ALL\_FRAMES or VLAN\_TAGGED\_FRAMES; failure to do so will filter all VLAN traffic bar frames tagged with VLAN ID 0

#### Parameters:

portID **IxEthDBPortId** [in] – port ID to set the acceptable frame type filter to frameFilter **IxEthDBFrameFilter** [in] – acceptable frame type filter

#### Return values:

IX\_ETH\_DB\_SUCCESS operation completed successfully
 IX\_ETH\_DB\_INVALID\_PORT portID is not a valid port identifier
 IX\_ETH\_DB\_PORT\_UNINITIALIZED port is not initialized
 IX\_ETH\_DB\_INVALID\_ARG invalid frame type filter
 IX\_ETH\_DB\_FEATURE\_UNAVAILABLE VLAN/QoS feature is not available or not enabled for the port
 IX\_FAIL unknown OS or NPE communication error

```
      IxEthDBStatus
      ixEthDBPortId
      portID,

      IxEthDBRecordType
      recordType
```

Deletes a set of record types from the Ethernet Database.

This function deletes all the records of certain types (specified in the recordType filter) associated with a port. Additionally, the IX\_ETH\_DB\_ALL\_PORTS value can be used as port ID to indicate that the specified record types should be deleted for all the ports.

The record type filter can be an ORed combination of the following types:

#### Record types

• IX\_ETH\_DB\_FILTERING\_RECORD

#### Filtering record

MAC address static/dynamic type age

#### • IX\_ETH\_DB\_FILTERING\_VLAN\_RECORD

VLAN-enabled filtering record

MAC address static/dynamic type age 802.1Q tag

#### • IX\_ETH\_DB\_WIFI\_RECORD

WiFi header conversion record

MAC address optional gateway MAC address

### • IX\_ETH\_DB\_FIREWALL\_RECORD

Firewall record

MAC address

• IX\_ETH\_DB\_ALL\_RECORD\_TYPES

Any combination of the above types is valid e.g.

(IX\_ETH\_DB\_FILTERING\_RECORD | IX\_ETH\_DB\_FILTERING\_VLAN\_RECORD | IX\_ETH\_DB\_FIREWALL\_RECORD),

although some might be redundant (it is not an error to do so) e.g.

(IX\_ETH\_DB\_FILTERING\_RECORD | IX\_ETH\_DB\_ALL\_RECORD\_TYPES)

#### Parameters:

portID **IxEthDBPortId** [in] – ID of the port

recordType **IxEthDBRecordType** [in] – record type filter

#### Return values:

IX\_ETH\_DB\_SUCCESS operation completed successfully IX\_ETH\_DB\_INVALID\_PORT portID is not a valid port identifier IX\_ETH\_DB\_INVALID\_ARG invalid recordType filter

#### Note:

If the record type filter contains any unrecognized value (hence the IX\_ETH\_DB\_INVALID\_ARG error value is returned) no actual records will be deleted.

#### void ixEthDBDatabaseMaintenance (void)

Performs a maintenance operation on the Ethernet learning/filtering database.

In order to perform a database maintenance this function must be called every **IX\_ETH\_DB\_MAINTENANCE\_TIME** seconds. It should be called regardless of whether learning is enabled or not.

- Reentrant no
- ISR Callable no

#### Note:

this function call will be ignored if the learning feature is disabled

```
      IxEthDBStatus
      ixEthDBEgressVlanEntryTaggingEnabledGet
      ( IxEthDBPortId portID, IxEthDBVlanId vlanID, BOOL * enabled
```

Retrieves the Egress VLAN tagging enabling status for a port and VLAN ID.

#### Parameters:

portID [in] – ID of the port to extract the Egress VLAN ID tagging status from
 vlanID VLAN [in] – ID whose tagging status is to be extracted
 enabled [in] – user–specifed location where the status is copied to; following the successfull execution of this function the value will be TRUE if Egress VLAN tagging is enabled for the given port and VLAN ID, and FALSE otherwise

- Reentrant no
- ISR Callable no

#### See also:

#### ix Eth DBE gress Vlan Entry Tagging Enabled Get

#### Return values:

IX\_ETH\_DB\_SUCCESS operation completed successfully
 IX\_ETH\_DB\_INVALID\_PORT portID is not a valid port identifier
 IX\_ETH\_DB\_PORT\_UNINITIALIZED port is not initialized
 IX\_ETH\_DB\_INVALID\_VLAN invalid VLAN ID (out of range)
 IX\_ETH\_DB\_INVALID\_ARG invalid enabled argument pointer
 IX\_ETH\_DB\_FEATURE\_UNAVAILABLE VLAN/QoS feature is not available or not enabled for the port

```
      IxEthDBStatus ixEthDBEgressVlanEntryTaggingEnabledSet (IxEthDBPortId portID, IxEthDBVlanId vlanID, BOOL enabled)
```

Enables or disables Egress VLAN tagging for a port and a given VLAN.

This function enables or disables Egress VLAN tagging for the given port and VLAN ID. If the VLAN tagging for a certain VLAN ID is enabled then all the frames to be transmitted on the given port tagged with the same VLAN ID will be transmitted in a tagged format. If tagging is not enabled for the given VLAN ID, the VLAN tag from the frames matching this VLAN ID will be removed (the frames will be untagged).

VLAN ID 4095 is reserved and should never be used with this function. VLAN ID 0 has the special meaning of "No VLAN membership" and it is used in this context to allow the port to send priority—tagged frames or not.

By default, no Egress VLAN tagging is enabled on any port.

- Reentrant no
- ISR Callable no

#### Parameters:

portID IxEthDBPortId [in] – ID of the port to enable or disable the VLAN ID Egress tagging on vlanID IxEthDBVlanId [in] – VLAN ID to be matched against outgoing frames
 enabled BOOL [in] – TRUE to enable Egress VLAN tagging on the port and given VLAN, and FALSE to disable Egress VLAN tagging

#### Return values:

IX\_ETH\_DB\_SUCCESSoperation completed successfullyIX\_ETH\_DB\_INVALID\_PORTportID is not a valid port identifierIX\_ETH\_DB\_PORT\_UNINITIALIZEDport is not initializedIX\_ETH\_DB\_INVALID\_VLANinvalid VLAN ID (out of range)IX\_ETH\_DB\_FEATURE\_UNAVAILABLEVLAN/QoS feature is not available or not enabled for the portIX\_FAILunknown OS or NPE communication error

```
      IxEthDBStatus ixEthDBEgressVlanRangeTaggingEnabledSet ( IxEthDBPortId portID, IxEthDBVlanId vlanIDMin, IxEthDBVlanId vlanIDMin, IxEthDBVlanId vlanIDMax, BOOL enabled )
```

Enables or disables Egress VLAN tagging for a port and given VLAN range.

This function is very similar to **ixEthDBEgressVlanEntryTaggingEnabledSet** with the difference that it can manipulate the Egress tagging status on multiple VLAN IDs, defined by a contiguous range. Note that both limits in the range are explicitly included in the execution of this function.

- Reentrant no
- ISR Callable no

#### Parameters:

portID **IxEthDBPortId** [in] – ID of the port to enable or disable the VLAN ID Egress tagging on

vlanIDMin IxEthDBVlanId [in] – start of the VLAN range to be matched against outgoing frames
 vlanIDMax IxEthDBVlanId [in] – end of the VLAN range to be matched against outgoing frames
 enabled BOOL [in] – TRUE to enable Egress VLAN tagging on the port and given VLAN range, and FALSE to disable Egress VLAN tagging

#### Return values:

IX\_ETH\_DB\_SUCCESS operation completed successfully IX\_ETH\_DB\_INVALID\_PORT portID is not a valid port identifier

IX\_ETH\_DB\_PORT\_UNINITIALIZED port is not initialized

IX\_ETH\_DB\_INVALID\_VLAN invalid VLAN ID (out of range), or do not constitute a

range

IX\_ETH\_DB\_FEATURE\_UNAVAILABLE VLAN/QoS feature is not available or not enabled for

the port

IX\_ETH\_DB\_NO\_PERMISSION attempted to explicitly remove the default port VLAN

ID from the tagging table

IX\_FAIL unknown OS or NPE communication error

#### Note:

Specifically removing the default port VLAN ID from the Egress tagging table by setting both vlanIDMin and vlanIDMax to the VLAN ID portion of the PVID is not allowed by this function and will return IX\_ETH\_DB\_NO\_PERMISSION. However, this can be circumvented, should the user specifically desire this, by either using a larger range (vlanIDMin < vlanIDMax) or by using ixEthDBEgressVlanEntryTaggingEnabledSet.

# IxEthDBStatus ixEthDBEgressVlanTaggingEnabledGet ( IxEthDBPortId portID, IxEthDBVlanSet vlanSet )

Retrieves the complete Egress VLAN tagging table from a port.

This function copies the 4096 bit table controlling the Egress VLAN tagging into a user specified area. Each bit in the array indicates whether tagging for the corresponding VLAN (the bit position in the array) is enabled (the bit is set) or not (the bit is unset).

Bit 4095 is reserved and should not be set (it will be ignored if set).

#### See also:

#### ix Eth DB Egress Vlan Tagging Enabled Set

#### Parameters:

portID **IxEthDBPortId** [in] – ID of the port whose Egress VLAN tagging behavior is

retrieved

vlanSet [out] – user location to copy the Egress tagging table into;

should have room to store 4096 bits (512 bytes)

#### Return values:

IX\_ETH\_DB\_SUCCESS operation completed successfully IX\_ETH\_DB\_INVALID\_PORT portID is not a valid port identifier

```
    IX_ETH_DB_PORT_UNINITIALIZED port is not initialized
    IX_ETH_DB_INVALID_ARG invalid vlanSet pointer
    IX_ETH_DB_FEATURE_UNAVAILABLE VLAN/QoS feature is not available or not enabled for the port
```

```
      IxEthDBStatus ixEthDBEgressVlanTaggingEnabledSet ( IxEthDBPortId portID, IxEthDBVlanSet vlanSet )
```

Sets the complete Egress VLAN tagging table for a port.

This function is used to set the VLAN tagging/untagging per VLAN ID for a given port covering the entire VLAN ID range (0..4094). The *vlanSet* parameter is a 4096 bit array, each bit indicating the Egress behavior for the corresponding VLAN ID. If a bit is set then outgoing frames with the corresponding VLAN ID will be transmitted with the VLAN tag, otherwise the frame will be transmitted without the VLAN tag.

Bit 0 has a special significance, indicating tagging or tag removal for priority–tagged frames.

Bit 4095 is reserved and should never be set (it will be ignored if set).

- Reentrant no
- ISR Callable no

#### Parameters:

portID **IxEthDBPortId** [in] – ID of the port whose Egress VLAN tagging behavior is set vlanSet **IxEthDBVlanSet** [in] – 4096 bit array controlling per–VLAN tagging and untagging

#### Return values:

| IX_ETH_DB_SUCCESS                   | operation completed successfully                     |
|-------------------------------------|------------------------------------------------------|
| IX_ETH_DB_INVALID_PORT              | portID is not a valid port identifier                |
| IX_ETH_DB_PORT_UNINITIALIZED        | port is not initialized                              |
| IX_ETH_DB_INVALID_ARG               | invalid vlanSet pointer                              |
| $IX\_ETH\_DB\_FEATURE\_UNAVAILABLE$ | VLAN/QoS feature is not available or not enabled for |
|                                     | the port                                             |
| IX_FAIL                             | unknown OS or NPE communication error                |

#### Warning:

This function will automatically add the default port VLAN ID to the Egress tagging table every time it is called. The user should manually call ixEthDBEgressVlanEntryTaggingEnabledSet to prevent tagging on the default port VLAN ID if the default behavior is not intended.

```
      IxEthDBStatus
      ixEthDBFeature
      portID

      IxEthDBFeature * featureSet
      )
```

Retrieves the feature capability set for a port.

This function retrieves the feature capability set for a port or the common capabilities shared between all the ports, writing the feature capability set in a user specified location.

The feature capability set will consist of a set formed by OR-ing one or more of the following values:

- IX\_ETH\_DB\_LEARNING Learning feature; enables EthDB to learn MAC address (filtering) records, including 802.1Q enabled records
- IX\_ETH\_DB\_FILTERING Filtering feature; enables EthDB to communicate with the NPEs for downloading filtering information in the NPEs; depends on the learning feature
- IX\_ETH\_DB\_VLAN\_QOS VLAN/QoS feature; enables EthDB to configure NPEs to operate in VLAN/QoS aware modes
- IX\_ETH\_DB\_FIREWALL Firewall feature; enables EthDB to configure NPEs to operate in firewall mode, using white/black address lists
- IX\_ETH\_DB\_SPANNING\_TREE\_PROTOCOL Spanning tree protocol feature; enables EthDB to configure the NPEs as STP nodes
- IX\_ETH\_DB\_WIFI\_HEADER\_CONVERSION WiFi 802.3 to 802.11 header conversion feature; enables EthDB to handle WiFi conversion data

Note that EthDB provides only the LEARNING feature for non–NPE ports.

#### Parameters:

```
portID IxEthDBPortId [in] – ID of the port to retrieve the capability set for (use IX_ETH_DB_ALL_PORTS to retrieve the common capabilities shared between all the ports)
```

featureSet IxEthDBFeature [out] – location where the capability set will be written to

#### Return values:

```
IX_ETH_DB_SUCCESSoperation completed successfullyIX_ETH_DB_INVALID_PORTportID is not a valid port identifierIX_ETH_DB_PORT_UNINITIALIZEDport is not initializedIX_ETH_DB_INVALID_ARGinvalid featureSet pointer
```

```
IxEthDBStatus ixEthDBFeatureEnable ( IxEthDBPortId portID, IxEthDBFeature feature, BOOL enabled )
```

Enables or disables one or more EthDB features.

Selects one or more features (see **ixEthDBFeatureCapabilityGet** for a description of the supported features) to be enabled or disabled on the selected port (or all the ports).

Note that some features are mutually incompatible:

• IX\_ETH\_DB\_FILTERING is incompatible with IX\_ETH\_DB\_WIFI\_HEADER\_CONVERSION

Also note that some features require other features to be enabled:

#### • IX\_ETH\_DB\_FILTERING requires IX\_ETH\_DB\_LEARNING

This function will either enable the entire selected feature set for the selected port (or all the ports), in which case it will return IX\_ETH\_DB\_SUCCESS, or in case of error it will not enable any feature at all and return an appropriate error message.

The following features are enabled by default (for ports with the respective capability), for compatibility reasons with previous versions of CSR:

- IX\_ETH\_DB\_LEARNING
- IX\_ETH\_DB\_FILTERING

All other features are disabled by default and require manual enabling using ixEthDBFeatureEnable.

#### Default settings for VLAN, QoS, Firewall and WiFi header conversion features:

#### VLAN

When the VLAN/QoS feature is enabled for a port for the first time the default VLAN behavior of the port is set to be as **permissive** (it will accept all the frames) and **non-interferential** (it will not change any frames) as possible:

- the port VLAN ID (VID) is set to 0
- the Ingress acceptable frame filter is set to accept all frames
- the VLAN port membership is set to the complete VLAN range (0 4094)
- the Ingress tagging mode is set to pass—through (will not change frames)
- the Egress tagging mode is to send tagged frames in the entire VLAN range (0-4094)

Note that further disabling and re-enabling the VLAN feature for a given port will not reset the port VLAN behavior to the settings listed above. Any VLAN settings made by the user are kept.

#### OoS

The following default priority mapping table will be used (as per IEEE 802.1Q and IEEE 802.1D):

#### QoS traffic classes

| QoS priority | Default traffic class | Traffic type                                       |
|--------------|-----------------------|----------------------------------------------------|
| 0            | 1                     | Best effort, default class for unexpedited traffic |
| 1            | 0                     | Background traffic                                 |
| 2            | 0                     | Spare bandwidth                                    |
| 3            | 1                     | Excellent effort                                   |
| 4            | 2                     | Controlled load                                    |
| 5            | 2                     | Video traffic                                      |
| 6            | 3                     | Voice traffic                                      |
| 7            | 3                     | Network control                                    |

#### **Firewall**

The port firewall is configured by default in black—list mode, and the firewall address table is empty. This means the firewall will not filter any frames until the feature is configured and the firewall table is downloaded to the NPE.

#### Spanning Tree

The port is set to STP unblocked mode, therefore it will accept all frames until re-configured.

#### WiFi header conversion

The WiFi header conversion database is empty, therefore no actual header conversion will take place until this feature is configured and the conversion table downloaded to the NPE.

#### Parameters:

```
    portID IxEthDBPortId [in] – ID of the port to enable or disable the features on (use IX_ETH_DB_ALL_PORTS for all the ports)
    feature IxEthDBFeature [in] – feature or feature set to enable or disable enabled BOOL [in] – TRUE to enable the feature and FALSE to disable it
```

#### Note:

Certain features, from a functional point of view, cannot be disabled as such at NPE level; when such features are set to *disabled* using the EthDB API they will be configured in such a way to determine a behavior equivalent to the feature being disabled. As well as this, disabled features cannot be configured or accessed via the EthDB API (except for getting their status).

#### Return values:

```
IX_ETH_DB_SUCCESSoperation completed successfullyIX_ETH_DB_INVALID_PORTportID is not a valid port identifierIX_ETH_DB_PORT_UNINITIALIZEDport is not initializedIX_ETH_DB_NO_PERMISSIONattempted to enable mutually exclusive features, or a feature that depends on another feature which is not present or enabledIX_ETH_DB_FEATURE_UNAVAILABLEat least one of the features selected is unavailable unknown OS or NPE communication error
```

```
IxEthDBStatus ixEthDBFeaturePropertyGet ( IxEthDBPortId portID, IxEthDBFeature feature, IxEthDBProperty property, IxEthDBPropertyType * type, void * value )
```

Retrieves the value of a feature property.

The EthDB features usually contain feature—specific properties describing or controlling how the feature operates. We (e.g. the firewall operating mode) have their own API, secondary properties can be retrieved using this function.

Properties can be read—only or read—write. ixEthDBFeaturePropertyGet operates with both types of features.

Properties have types associated with them. A descriptor indicating the property type is returned in the type argumen

The currently supported properties and their corresponding features are as follows:

Properties for IX\_ETH\_DB\_VLAN\_QOS

| Property identifier                             | Property type            |
|-------------------------------------------------|--------------------------|
| IX_ETH_DB_QOS_TRAFFIC_CLASS_COUNT_PROPERTY      | IX_ETH_DB_INTEGER_PROPER |
| IX_ETH_DB_QOS_TRAFFIC_CLASS_0_RX_QUEUE_PROPERTY | IX_ETH_DB_INTEGER_PROPER |
| IX_ETH_DB_QOS_TRAFFIC_CLASS_1_RX_QUEUE_PROPERTY | IX_ETH_DB_INTEGER_PROPER |
| IX_ETH_DB_QOS_TRAFFIC_CLASS_2_RX_QUEUE_PROPERTY | IX_ETH_DB_INTEGER_PROPER |
| IX_ETH_DB_QOS_TRAFFIC_CLASS_3_RX_QUEUE_PROPERTY | IX_ETH_DB_INTEGER_PROPER |
| IX_ETH_DB_QOS_TRAFFIC_CLASS_4_RX_QUEUE_PROPERTY | IX_ETH_DB_INTEGER_PROPER |
| IX_ETH_DB_QOS_TRAFFIC_CLASS_5_RX_QUEUE_PROPERTY | IX_ETH_DB_INTEGER_PROPER |
| IX_ETH_DB_QOS_TRAFFIC_CLASS_6_RX_QUEUE_PROPERTY | IX_ETH_DB_INTEGER_PROPER |
|                                                 | 11                       |

#### IX\_ETH\_DB\_QOS\_TRAFFIC\_CLASS\_7\_RX\_QUEUE\_PROPERTY

#### IX\_ETH\_DB\_INTEGER\_PROPER

#### See also:

#### ixEthDBFeaturePropertySet

#### Parameters:

portID **IxEthDBPortId** [in] – ID of the port

feature **IxEthDBFeature** [in] – EthDB feature for which the property is retrieved

property IxEthDBProperty [in] – property identifier

*type* **IxEthDBPropertyType** [out] – location where the property type will be stored

value void [out] – location where the property value will be stored

#### Return values:

IX\_ETH\_DB\_SUCCESS operation completed successfully IX\_ETH\_DB\_INVALID\_PORT portID is not a valid port identifier

IX\_ETH\_DB\_INVALID\_ARG invalid property identifier, type or value pointer arguments

IX ETH DB FAIL incorrect property value or unknown error

```
IxEthDBStatus ixEthDBFeaturePropertySet ( IxEthDBPortId portID, IxEthDBFeature feature, IxEthDBProperty property, void * value )
```

Sets the value of a feature property.

Unlike ixEthDBFeaturePropertyGet, this function operates only with read-write properties

The currently supported properties and their corresponding features are as follows:

• IX\_ETH\_DB\_QOS\_QUEUE\_CONFIGURATION\_COMPLETE (for IX\_ETH\_DB\_VLAN\_QOS): freezes the availability of traffic classes to the number of traffic classes currently in use

Note that this function creates deep copies of the property values; once the function is invoked the client can free or reuse the memory area containing the original property value.

Copy behavior for different property types is defined as follows:

- IX\_ETH\_DB\_INTEGER\_PROPERTY 4 bytes are copied from the source location
- IX\_ETH\_DB\_STRING\_PROPERTY the source string will be copied up to the NULL " string terminator, maximum of 255 characters
- IX ETH DB MAC ADDR PROPERTY 6 bytes are copied from the source location
- IX\_ETH\_DB\_BOOL\_PROPERTY 4 bytes are copied from the source location; the only allowed values are TRUE (1L) and false (0L)

#### See also:

#### ixEthDBF eature Property Set

#### Warning:

IX\_ETH\_DB\_QOS\_QUEUE\_CONFIGURATION\_COMPLETE is provided for EthAcc internal use; do not attempt to set this property directly

#### Parameters:

```
portID IxEthDBPortId [in] – ID of the port
```

feature **IxEthDBFeature** [in] – EthDB feature for which the property is set

property IxEthDBProperty [in] – property identifier

value void [in] – location where the property value is to be copied from

#### Return values:

```
IX_ETH_DB_SUCCESS operation completed successfully IX_ETH_DB_INVALID_PORT portID is not a valid port identifier
```

IX\_ETH\_DB\_INVALID\_ARG invalid property identifier, value pointer, or invalid property value

```
IxEthDBStatus ixEthDBFeatureStatusGet ( IxEthDBPortId portID, IxEthDBFeature feature, BOOL * present, BOOL * enabled )
```

Retrieves the availability and status of a feature set.

This function returns the availability and status for a feature set. Note that if more than one feature is selected (e.g. IX\_ETH\_DB\_LEARNING | IX\_ETH\_DB\_FILTERING) the "present" and "enabled" return values will be set to TRUE only if all the features in the feature set are present and enabled (not only some).

#### Parameters:

portID **IxEthDBPortId** [in] – ID of the port

feature [in] – identifier of the feature to retrieve the status for present BOOL [out] – location where a boolean flag indicating whether this feature is

present will be written to

enabled BOOL [out] – location where a boolean flag indicating whether this feature is

enabled will be written to

#### Return values:

IX\_ETH\_DB\_SUCCESS operation completed successfully IX\_ETH\_DB\_INVALID\_PORT portID is not a valid port identifier

IX\_ETH\_DB\_PORT\_UNINITIALIZED port is not initialized

IX\_ETH\_DB\_INVALID\_ARG either present or enabled pointer argument is invalid

```
      IxEthDBStatus
      ixEthDBFilteringDatabaseSearch
      ( IxEthDBPortId * portID, IxEthDBMacAddr * macAddr * macAddr
```

Search the Ethernet learning/filtering database for a MAC address and return the port ID.

Searches the database for a MAC address. The function returns the portID for the MAC address record, if found. If no match is found the function returns IX\_ETH\_DB\_NO\_SUCH\_ADDR. The portID is only valid if the function finds a match.

- Reentrant yes
- ISR Callable no

#### Parameters:

#### Return values:

IX\_ETH\_DB\_SUCCESS the record exists in the databaseIX\_ETH\_DB\_NO\_SUCH\_ADDR the record was not found in the databaseIX\_ETH\_DB\_INVALID\_ARG invalid macAddr or portID pointer argument(s)

#### **IxEthDBStatus** ixEthDBFilteringDatabaseShow ( **IxEthDBPortId** portID )

This function displays the Mac Ethernet MAC address filtering tables.

It displays the MAC address, port ID, entry type (dynamic/static), and age for the given port ID.

- Reentrant no
- ISR Callable no

#### Parameters:

portID **IxEthDBPortId** [in] – port ID to display the MAC address entries

#### Return values:

IX\_ETH\_DB\_SUCCESS operation completed successfully

IX\_ETH\_DB\_INVALID\_PORT portID is invalid
IX\_ETH\_DB\_PORT\_UNINITIALIZED port ID is not initialized

IX ETH DB FAIL record browser failed due to an internal busy or lock

condition

#### Note:

this function is deprecated and kept for compatibility reasons; use **ixEthDBFilteringDatabaseShowRecords** instead

#### See also:

ix Eth DB Filtering Database Show Records

void ixEthDBFilteringDatabaseShowAll (void )

Displays the MAC address recorded in the filtering database for all registered ports (see **IxEthDBPortDefs.h**), grouped by port ID.

```
* - Reentrant - no
```

• ISR Callable - no

#### Return values:

void

Note:

this function is deprecated and kept for compatibility reasons; use **ixEthDBFilteringDatabaseShowRecords** instead

See also:

ix Eth DB Filtering Database Show Records

```
      IxEthDBStatus
      ixEthDBFilteringDatabaseShowRecords
      ( IxEthDBPortId portID, IxEthDBRecordType recordFilter )
```

This function displays per port database records, given a record type filter.

The supported record type filters are:

- IX\_ETH\_DB\_FILTERING\_RECORD displays the non–VLAN filtering records (MAC address, age, static/dynamic)
- IX\_ETH\_DB\_FILTERING\_VLAN\_RECORD displays the VLAN filtering records (MAC address, age, static/dynamic, VLAN ID, CFI, QoS class)
- IX\_ETH\_DB\_FILTERING\_RECORD | IX\_ETH\_DB\_FILTERING\_VLAN\_RECORD displays the previous two types of records
- IX\_ETH\_DB\_WIFI\_RECORD displays the WiFi header conversion records (MAC address, optional gateway MAC address) and WiFi header conversion parameters (BSSID, Duration/ID)
- IX\_ETH\_DB\_FIREWALL\_RECORD displays the firewall MAC address table and firewall operating mode (white list/black list)
- IX\_ETH\_DB\_ALL\_RECORD\_TYPES displays all the record types
- IX ETH DB NO RECORD TYPE displays only the port status (no records are displayed)

Additionally, the status of each port will be displayed, containg the following information: type, capabilities, enabled status, aging enabled status, group membership and maximum frame size.

The port ID can either be an actual port or IX\_ETH\_DB\_ALL\_PORTS, in which case the requested information will be displayed for all the ports (grouped by port)

- Reentrant no
- ISR Callable no

#### Parameters:

portID ID of the port to display information on (use IX\_ETH\_DB\_ALL\_PORTS for all the

#### ports)

recordFilter record type filter

#### Return values:

IX\_ETH\_DB\_SUCCESS operation completed successfullyIX\_ETH\_DB\_INVALID\_PORT portID is invalidIX\_ETH\_DB\_PORT\_UNINITIALIZED port ID is not initialized

```
      IxEthDBStatus
      ixEthDBFilteringDynamicEntryProvision
      ( IxEthDBPortId portID, IxEthDBMacAddr * macAddr )
```

Populate the Ethernet learning/filtering database with a dynamic MAC address.

Populates the Ethernet learning/filtering database with a dynamic MAC address. This entry will be subject to normal aging function, if aging is enabled on its port. If there is an entry (static or dynamic) with the same MAC address on any port this entry will take precedence. Any other entry with the same MAC address will be removed.

- Reentrant yes
- ISR Callable yes

#### Parameters:

#### Return values:

IX\_ETH\_DB\_SUCCESS the add was successful

IX\_ETH\_DB\_FAIL failed to populate the database entry

IX ETH DB BUSY failed due to a temporary busy condition (i.e. lack of

CPU cycles), try again later

IX\_ETH\_DB\_INVALID\_PORT portID is invalid IX\_ETH\_DB\_PORT\_UNINITIALIZED port is not initialized

IX\_ETH\_DB\_INVALID\_ARG invalid macAddr pointer argument

IX ETH DB FEATURE UNAVAILABLE learning feature is disabled

#### **IxEthDBStatus** ixEthDBFilteringEntryDelete ( **IxEthDBMacAddr** \* macAddr )

Removes a MAC address entry from the Ethernet learning/filtering database.

#### Parameters:

macAddr IxEthDBMacAddr [in] – MAC address to remove

- Reentrant yes
- ISR Callable no

#### Return values:

IX\_ETH\_DB\_SUCCESS the removal was successful

IX\_ETH\_DB\_NO\_SUCH\_ADDR failed to remove the address (not in the database)

IX\_ETH\_DB\_INVALID\_ARG invalid macAddr pointer argument

IX\_ETH\_DB\_BUSY failed due to a temporary busy condition (i.e. lack of CPU

cycles), try again later

# IxEthDBStatus ixEthDBFilteringPortMaximumFrameSizeSet ( IxEthDBPortId portID, UINT32 maximumFrameSize )

Set the maximum frame size supported on the given port ID.

This functions set the maximum frame size supported on a specific port ID

- Reentrant yes
- ISR Callable no

#### Parameters:

portID **IxEthDBPortId** [in] – port ID to configure maximumFrameSize UINT32 [in] – maximum frame size to configure

#### Return values:

IX\_ETH\_DB\_SUCCESS the port is configured

IX\_ETH\_DB\_PORT\_UNINITIALIZED the port has not been initialized

IX\_ETH\_DB\_INVALID\_PORT portID is invalid

IX\_ETH\_DB\_INVALID\_ARG size parameter is out of range

IX\_ETH\_DB\_NO\_PERMISSION selected port is not an Ethernet NPE

IX FAIL unknown OS or NPE communication error

#### Note:

This maximum frame size is used to filter the frames based on their destination addresses and the capabilities of the destination port. The mximum value that can be set for a NPE port is 16320. (IX\_ETHNPE\_ACC\_FRAME\_LENGTH\_MAX)

```
      IxEthDBStatus
      ixEthDBFilteringPortSearch
      ( IxEthDBPortId portID, IxEthDBMacAddr * macAddr )
```

Search the Ethernet learning/filtering database for the given MAC address and port ID.

This functions searches the database for a specific port ID and MAC address. Both the port ID and the MAC address have to match in order for the record to be reported as found.

- Reentrant yes
- ISR Callable no

#### Parameters:

#### Return values:

```
    IX_ETH_DB_SUCCESS the record exists in the database
    IX_ETH_DB_INVALID_ARG invalid macAddr pointer argument
    IX_ETH_DB_NO_SUCH_ADDR the record was not found in the database
    IX_ETH_DB_INVALID_PORT portID is invalid
    IX_ETH_DB_PORT_UNINITIALIZED port ID is not initialized
    IX_ETH_DB_FEATURE_UNAVAILABLE learning feature is disabled
```

```
      IxEthDBStatus
      ixEthDBFilteringPortUpdatingSearch
      ( IxEthDBPortId * portID, IxEthDBMacAddr * macAddr )
```

Search the filtering database for a MAC address, return the port ID and reset the record age.

Searches the database for a MAC address. The function returns the portID for the MAC address record and resets the entry age to 0, if found. If no match is found the function returns IX ETH DB NO SUCH ADDR. The portID is only valid if the function finds a match.

- Reentrant yes
- ISR Callable no

#### Return values:

```
IX_ETH_DB_SUCCESS the MAC address was found

IX_ETH_DB_NO_SUCH_ADDR the MAC address was not found

IX_ETH_DB_INVALID_ARG invalid macAddr or portID pointer argument(s)
```

```
      IxEthDBStatus
      ixEthDBFilteringStaticEntryProvision
      ( IxEthDBPortId portID, IxEthDBMacAddr * macAddr )
```

Populate the Ethernet learning/filtering database with a static MAC address.

Populates the Ethernet learning/filtering database with a static MAC address. The entry will not be subject to aging. If there is an entry (static or dynamic) with the corresponding MAC address on any port this entry will take precedence. Any other entry with the same MAC address will be removed.

- Reentrant yes
- ISR Callable yes

#### Parameters:

```
portID IxEthDBPortId [in] – port ID to add the static address to macAddr IxEthDBMacAddr [in] – static MAC address to add
```

#### Return values:

IX\_ETH\_DB\_SUCCESS the add was successful

IX\_ETH\_DB\_FAIL failed to populate the database entry

IX\_ETH\_DB\_BUSY failed due to a temporary busy condition (i.e. lack of

CPU cycles), try again later

IX\_ETH\_DB\_INVALID\_PORT portID is invalid IX\_ETH\_DB\_PORT\_UNINITIALIZED port is not initialized

IX\_ETH\_DB\_INVALID\_ARG invalid macAddr pointer argument

IX\_ETH\_DB\_FEATURE\_UNAVAILABLE learning feature is disabled

Adds a MAC address to the firewall address list.

Note that adding the same MAC address twice will not return an error but will not actually accomplish anything.

The firewall MAC address list has a limited number of entries; once the maximum number of entries has been reached this function will failed to add more addresses, returning IX\_ETH\_DB\_NOMEM.

#### Parameters:

#### Return values:

IX\_ETH\_DB\_SUCCESS operation completed successfully IX\_ETH\_DB\_INVALID\_PORT portID is not a valid port identifier

IX\_ETH\_DB\_PORT\_UNINITIALIZED port not initialized

IX\_ETH\_DB\_INVALID\_ARG invalid macAddr pointer argument IX\_ETH\_DB\_FAIL maximum number of records reached

IX\_ETH\_DB\_BUSY lock condition or transaction in progress, try again later

IX\_ETH\_DB\_FEATURE\_UNAVAILABLE Firewall feature not enabled

```
      IxEthDBStatus
      ixEthDBFirewallEntryRemove
      ( IxEthDBPortId portID, IxEthDBMacAddr * macAddr

      )
      )
```

Removes a MAC address from the firewall address list.

#### Parameters:

portID IxEthDBPortId [in] – ID of the portmacAddr IxEthDBMacAddr [in] – MAC address to be removed

#### Return values:

IX ETH DB SUCCESS

operation completed successfully

IX\_ETH\_DB\_INVALID\_PORT portID is not a valid port identifier

IX\_ETH\_DB\_PORT\_UNINITIALIZED port not initialized invalid macAddr pointer argument ix\_ETH\_DB\_NO\_SUCH\_ADDR address not found IX\_ETH\_DB\_FEATURE\_UNAVAILABLE Firewall feature not enabled

```
ixEthDBFirewallInvalidAddressFilterEnable ( IxEthDBPortId portID, BOOL enable )
```

Enables or disables invalid MAC address filtering.

According to IEEE802 it is illegal for a source address to be a multicast or broadcast address. If this feature is enabled the NPE inspects the source MAC addresses of incoming frames and discards them if invalid addresses are detected.

By default this service is enabled, if the firewall feature is supported by the NPE image.

#### Parameters:

```
portID ID of the portenable TRUE to enable invalid MAC address filtering and FALSE to disable it
```

#### Return values:

```
IX_ETH_DB_SUCCESSoperation completed successfullyIX_ETH_DB_INVALID_PORTportID is not a valid port identifierIX_ETH_DB_PORT_UNINITIALIZEDport not initializedIX_ETH_DB_FEATURE_UNAVAILABLEFirewall feature not enabledIX_ETH_DB_FAILunknown OS or NPE communication error
```

```
      IxEthDBStatus ixEthDBFirewallMaskedEntryAdd ( IxEthDBPortId portID, IxEthDBMacAddr * macAddr, IxEthDBMacAddr * addrMask )
```

Adds a MAC address + mask to the firewall address list.

Note that adding the same MAC address twice will not return an error but will not actually accomplish anything.

The firewall MAC address list has a limited number of entries; once the maximum number of entries has been reached this function will failed to add more addresses, returning IX\_ETH\_DB\_NOMEM.

```
Parameters:
```

portID **IxEthDBPortId** [in] – ID of the port

macAddr IxEthDBMacAddr [in] – MAC address to be added addrMask IxEthDBMacAddr [in] – address mask to be added

#### Return values:

IX\_ETH\_DB\_SUCCESS operation completed successfully IX\_ETH\_DB\_INVALID\_PORT portID is not a valid port identifier

IX\_ETH\_DB\_PORT\_UNINITIALIZED port not initialized

IX\_ETH\_DB\_INVALID\_ARG invalid macAddr pointer argument IX\_ETH\_DB\_FAIL maximum number of records reached

IX\_ETH\_DB\_BUSY lock condition or transaction in progress, try again later

IX\_ETH\_DB\_FEATURE\_UNAVAILABLE Firewall feature not enabled

 IxEthDBStatus ixEthDBFirewallMaskedEntryRemove ( IxEthDBPortId portID, IxEthDBMacAddr \* macAddr, IxEthDBMacAddr \* addrMask )

Removes a MAC address + mask from the firewall address list.

#### Parameters:

portID **IxEthDBPortId** [in] – ID of the port

macAddr [in] – MAC address to be

removed

addrMask IxEthDBMacAddr [in] – address mask to be added

#### Return values:

IX\_ETH\_DB\_SUCCESS operation completed

successfully

IX\_ETH\_DB\_INVALID\_PORT portID is not a valid

port identifier

IX\_ETH\_DB\_PORT\_UNINITIALIZED port not initialized IX\_ETH\_DB\_INVALID\_ARG invalid macAddr

pointer argument

IX\_ETH\_DB\_NO\_SUCH\_ADDR address not found IX\_ETH\_DB\_FEATURE\_UNAVAILABLE Firewall feature not

enabled

 IxEthDBStatus
 ixEthDBFirewallMode
 portID
 portID

 IxEthDBFirewallMode
 mode

Sets the firewall mode to use white or black listing.

When enabled, the NPE MAC address based firewall support operates in two modes:

- white-list mode (MAC address based admission)
  - ♦ *mode* set to IX\_ETH\_DB\_FIREWALL\_WHITE\_LIST
  - ♦ only packets originating from MAC addresses contained in the firewall address list are allowed on the Rx path
- black-list mode (MAC address based blocking)
  - ♦ mode set to IX ETH DB FIREWALL BLACK LIST
  - packets originating from MAC addresses contained in the firewall address list are discarded

#### Parameters:

```
portID IxEthDBPortId [in] – ID of the port
```

*mode* **IxEthDBFirewallMode** [in] – firewall mode (IX\_ETH\_DB\_FIREWALL\_WHITE\_LIST or IX\_ETH\_DB\_FIREWALL\_BLACK\_LIST)

#### Note:

by default the firewall operates in black-list mode with an empty address list, hence it doesn't filter any packets

#### Return values:

IX\_ETH\_DB\_SUCCESS operation completed successfully IX\_ETH\_DB\_INVALID\_PORT portID is not a valid port identifier

IX\_ETH\_DB\_PORT\_UNINITIALIZED port not initialized

IX\_ETH\_DB\_FEATURE\_UNAVAILABLE Firewall feature not enabled

IX\_ETH\_DB\_INVALID\_ARGUMENT mode argument is not a valid firewall configuration

mode

IX\_ETH\_DB\_FAIL unknown OS or NPE communication error

#### **IxEthDBStatus** ixEthDBFirewallTableDownload ( **IxEthDBPortId** portID )

Downloads the MAC firewall table to a port.

# Parameters:

portID ID of the port

# Return values:

IX\_ETH\_DB\_SUCCESS operation completed

successfully

IX\_ETH\_DB\_INVALID\_PORT portID is not a valid

port identifier

*IX\_ETH\_DB\_PORT\_UNINITIALIZED* port not initialized *IX\_ETH\_DB\_FEATURE\_UNAVAILABLE* Firewall feature not

enabled

IX\_ETH\_DB\_FAIL unknown OS or NPE

communication error

 IxEthDBStatus
 ixEthDBIngressVlanTaggingEnabledGet
 (
 IxEthDBPortId
 portID,

 IxEthDBTaggingAction
 \*
 taggingAction

Retrieves the Ingress VLAN tagging behavior from a port (see ixEthDBIngressVlanTaggingEnabledSet).

#### Parameters:

portID **IxEthDBPortId** [in] – ID of the port whose Ingress VLAN tagging behavior is set taggingAction **IxEthDBTaggingAction** [out] – location where the tagging behavior for the port is written to

#### Return values:

IX\_ETH\_DB\_SUCCESS operation completed successfully IX\_ETH\_DB\_INVALID\_PORT portID is not a valid port identifier

IX\_ETH\_DB\_PORT\_UNINITIALIZED port is not initialized

IX\_ETH\_DB\_INVALID\_ARG invalid taggingAction pointer argument

IX\_ETH\_DB\_FEATURE\_UNAVAILABLE VLAN/QoS feature is not available or not enabled for

the port

 IxEthDBStatus
 ixEthDBIngressVlanTaggingEnabledSet
 ( IxEthDBPortId portID, IxEthDBTaggingAction taggingAction )

Sets the Ingress VLAN tagging behavior for a port.

A port's Ingress tagging behavior is controlled by the taggingAction parameter, which can take one of the following values:

- IX\_ETH\_DB\_PASS\_THROUGH leaves the frame unchanged (does not add or remove the VLAN tag)
- IX\_ETH\_DB\_ADD\_TAG adds the VLAN tag if not present, using the default port VID
- IX\_ETH\_DB\_REMOVE\_TAG removes the VLAN tag if present

#### Parameters:

portID **IxEthDBPortId** [in] – ID of the port whose Ingress VLAN tagging behavior is set taggingAction **IxEthDBTaggingAction** [in] – tagging behavior for the port

#### Return values:

IX\_ETH\_DB\_SUCCESS operation completed successfully IX\_ETH\_DB\_INVALID\_PORT portID is not a valid port identifier

IX\_ETH\_DB\_PORT\_UNINITIALIZED port is not initialized

IX\_ETH\_DB\_INVALID\_ARG invalid taggingAction argument

IX\_ETH\_DB\_FEATURE\_UNAVAILABLE VLAN/QoS feature is not available or not enabled for

the port

IX FAIL unknown OS or NPE communication error

#### **IxEthDBStatus** ixEthDBInit (void )

Initializes the Ethernet learning/filtering database.

#### Note:

calling this function multiple times does not constitute an error; redundant calls will be ignored, returning IX\_ETH\_DB\_SUCCESS

#### Return values:

```
IX_ETH_DB_SUCCESS initialization was successful IX_ETH_DB_FAIL initialization failed (OS error)
```

```
      IxEthDBStatus
      ixEthDBPortId
      portID

      IxEthDBMacAddr
      macAddr
```

Sets the port MAC address.

This function is to be called from the Ethernet Access component top—level ixEthDBUnicastAddressSet(). Event processing cannot be enabled for a port until its MAC address has been set.

#### Parameters:

## Return values:

```
IX_ETH_DB_SUCCESS MAC address was set successfully
```

IX\_ETH\_DB\_FAIL MAC address was not set due to a message handler failure

IX\_ETH\_DB\_INVALID\_PORT if the port is not an Ethernet NPE

#### See also:

IxEthDBPortDefs.h for port definitions

# **IxEthDBStatus** ixEthDBPortAgingDisable ( **IxEthDBPortId** portID )

Disable the aging function for a specific port.

#### Parameters:

```
portID IxEthDBPortId [in] – port ID to disable aging on
```

- Reentrant yes
- ISR Callable no

#### Return values:

```
IX_ETH_DB_SUCCESS aging disabled successfully IX_ETH_DB_INVALID_PORT portID is invalid
```

IX\_ETH\_DB\_PORT\_UNINITIALIZED port ID is not initialized
IX\_ETH\_DB\_FEATURE\_UNAVAILABLE learning feature is disabled

# **IxEthDBStatus** ixEthDBPortAgingEnable ( **IxEthDBPortId** portID )

Enable the aging function for a specific port.

Enables the aging of dynamic MAC address entries stored in the learning/filtering database

#### Note:

The aging function relies on the **ixEthDBDatabaseMaintenance** being called with a period of **IX\_ETH\_DB\_MAINTENANCE\_TIME** seconds.

- Reentrant yes
- ISR Callable no

#### Parameters:

portID IxEthDBPortId [in] - port ID to enable aging on

#### Return values:

IX\_ETH\_DB\_SUCCESS aging enabled successfully
 IX\_ETH\_DB\_INVALID\_PORT portID is invalid
 IX\_ETH\_DB\_PORT\_UNINITIALIZED port ID is not initialized
 IX\_ETH\_DB\_FEATURE\_UNAVAILABLE learning feature is disabled

```
      IxEthDBStatus
      ixEthDBPortDependencyMapGet
      ( IxEthDBPortId portID, IxEthDBPortMap dependencyPortMap )
```

Retrieves the dependency port map for a port.

#### Parameters:

portID ID of the port to set the dependency map to dependencyPortMap location where the port dependency map is to be copied

This function will copy the port dependency map to a user specified location.

- Reentrant no
- ISR Callable no

#### Return values:

IX\_ETH\_DB\_SUCCESSoperation completed successfullyIX\_ETH\_DB\_INVALID\_PORTportID is not a valid port identifierIX\_ETH\_DB\_PORT\_UNINITIALIZEDport is not initializedIX\_ETH\_DB\_INVALID\_ARGinvalid dependencyPortMap pointer

# IX\_ETH\_DB\_FEATURE\_UNAVAILABLE Filtering is not available or not enabled for the port

```
      IxEthDBStatus
      ixEthDBPortDependencyMapSet
      ( IxEthDBPortId portID, IxEthDBPortMap dependencyPortMap

      )
      )
```

Sets the dependency port map for a port.

#### Parameters:

portID ID of the port to set the dependency map to

dependencyPortMap new dependency map (as bitmap, each bit set indicates a port being

included)

This function is used to share filtering information between ports. By adding a port into another port's dependency map the target port filtering data will import the filtering data from the port it depends on. Any changes to filtering data for a port – such as adding, updating or removing records – will trigger updates in the filtering information for all the ports depending on on the updated port.

For example, if ports 2 and 3 are set in the port 0 dependency map the filtering information for port 0 will also include the filtering information from ports 2 and 3. Adding a record to port 2 will also trigger an update not only on port 2 but also on port 0.

The dependency map is a 256 bit array where each bit corresponds to a port corresponding to the bit offset (bit 0 - port 0, bit 1 - port 1 etc). Setting a bit to 1 indicates that the corresponding port is the port map. For example, a dependency port map of 0x14 consists in the ports with IDs 2 and 4. Note that the last bit (offset 255) is reserved and should never be set (it will be automatically cleared by the function).

By default, each port has a dependency port map consisting only of itself, i.e.

```
IxEthDBPortMap portMap;

// clear all ports from port map
memset(portMap, 0, sizeof (portMap));

// include portID in port map
portMap[portID / 8] = 1 << (portID % 8);</pre>
```

- Reentrant no
- ISR Callable no

#### Note:

Setting dependency maps is useful for NPE ports, which benefit from automatic updates of filtering information. Setting dependency maps for user-defined ports is not an error but will have no actual effect.

Including a port in its own dependency map is not compulsory, however note that in this case updating the port will not trigger an update on the port itself, which might not be the intended behavior

#### Return values:

IX\_ETH\_DB\_SUCCESS operation completed successfully IX\_ETH\_DB\_INVALID\_PORT portID is not a valid port identifier

IX\_ETH\_DB\_PORT\_UNINITIALIZED port is not initialized

IX\_ETH\_DB\_INVALID\_ARG invalid dependencyPortMap pointer

IX\_ETH\_DB\_FEATURE\_UNAVAILABLE Filtering is not available or not enabled for the port

### **IxEthDBStatus** ixEthDBPortDisable ( **IxEthDBPortId** portID )

Disables processing on a port.

This function is called automatically from the Ethernet Access component **ixEthAccPortDisable()** routine for Ethernet NPE ports and should be manually called for any user-defined port (any port that is not one of the Ethernet NPEs).

#### Note:

Calling **ixEthAccPortDisable()** will disable the respective Ethernet NPE. After Ethernet NPEs are disabled they are stopped therefore when re—enabled they need to be reset, downloaded with microcode and started. For learning to restart working the user needs to call again ixEthAccPortUnicastMacAddressSet or ixEthDBUnicastAddressSet with the respective port MAC address. Residual MAC addresses learnt before the port was disabled are deleted as soon as the port is disabled. This only applies to dynamic (learnt) entries, static entries do not dissapear when the port is disabled.

#### Parameters:

portID **IxEthDBPortId** [in] – ID of the port to disable processing on

## Return values:

IX ETH DB SUCCESS if disabling is successful

IX\_ETH\_DB\_FAIL if the disabling was not successful due to a message handler error

IX ETH DB INVALID PORT if portID is invalid

#### Note:

calling this function multiple times after the first time completed successfully does not constitute an error; redundant calls will be ignored and return IX ETH DB SUCCESS

# **IxEthDBStatus** ixEthDBPortEnable ( **IxEthDBPortId** portID )

# Enables a port.

This function is called automatically from the Ethernet Access component **ixEthAccPortEnable()** routine for Ethernet NPE ports and should be manually called for any user—defined port (any port that is not one of the Ethernet NPEs).

#### Parameters:

portID IxEthDBPortId [in] – ID of the port to enable processing on

#### Return values:

IX\_ETH\_DB\_SUCCESS if enabling is successful

IX\_ETH\_DB\_FAIL if the enabling was not successful due to a message handler

error

IX\_ETH\_DB\_MAC\_UNINITIALIZED the MAC address of this port was not initialized (only for

Ethernet NPEs)

IX\_ETH\_DB\_INVALID\_PORT if portID is invalid

#### Precondition:

ixEthDBPortAddressSet needs to be called prior to enabling the port events for Ethernet NPEs

#### See also:

ixEthDBPortAddressSet

IxEthDBPortDefs.h for port definitions

#### Note:

calling this function multiple times does not constitute an error; redundant calls will be ignored

# void ixEthDBPortInit ( IxEthDBPortId portID )

Initializes a port.

This function is called automatically by the Ethernet Access **ixEthAccPortInit**() routine for Ethernet NPE ports and should be manually called for any user-defined port (any port that is not one of the two Ethernet NPEs).

#### Parameters:

portID **IxEthDBPortId** [in] – ID of the port to be initialized

#### See also:

**IxEthDBPortDefs.h** for port definitions

#### Note:

calling this function multiple times does not constitute an error; redundant calls will be ignored

# IxEthDBStatus ixEthDBPortVlanMembershipAdd ( IxEthDBPortId portID, IxEthDBVlanId vlanID )

Adds a VLAN ID to a port's VLAN membership table.

Adding a VLAN ID to a port's VLAN membership table will cause frames tagged with the specified VLAN ID to be accepted by the frame filter, if Ingress VLAN membership filtering is enabled.

- Reentrant no
- ISR Callable no

#### Parameters:

portID IxEthDBPortId [in] – ID of the port to add the VLAN ID membership tovlanID IxEthDBVlanId [in] – VLAN ID to be added to the port membership table

#### Return values:

IX\_ETH\_DB\_SUCCESS operation completed successfully IX\_ETH\_DB\_INVALID\_PORT portID is not a valid port identifier

IX\_ETH\_DB\_PORT\_UNINITIALIZED port is not initialized

IX ETH DB INVALID VLAN vlanID is not a valid VLAN ID

IX\_ETH\_DB\_FEATURE\_UNAVAILABLE VLAN/QoS feature is not available or not enabled for

the port

*IX\_FAIL* unknown OS or NPE communication error

#### Note:

A port's default VLAN ID is always in its own membership table, hence there is no need to explicitly add it using this function (although it is not an error to do so)

```
IxEthDBStatus ixEthDBPortVlanMembershipGet ( IxEthDBPortId portID, IxEthDBVlanSet vlanSet )
```

Retrieves a port's VLAN membership table.

Retrieves the complete VLAN membership table from a port, containing all the possible 4096 VLAN IDs. The table format is an array containing 4096 bits (512 bytes), where each bit indicates whether the VLAN at that bit index is in the port's membership list (if set) or not (unset).

The bit at index 0, indicating VLAN ID 0, indicates no VLAN membership and therefore no other bit will be set if bit 0 is set.

The bit at index 4095 is reserved and will not be set (it will be ignored if set).

The bit referencing the same VLAN ID as the default port VLAN ID will always be set, as the membership list must contain at least the default port VLAN ID.

- Reentrant no
- ISR Callable no

## Parameters:

portID IxEthDBPortId [in] – port ID to retrieve the VLAN membership table from
 vlanSet IxEthDBVlanSet [out] – pointer a location where the VLAN membership table will be written to

#### Return values:

IX\_ETH\_DB\_SUCCESSoperation completed successfullyIX\_ETH\_DB\_INVALID\_PORTportID is not a valid port identifierIX\_ETH\_DB\_PORT\_UNINITIALIZEDport is not initialized

IX\_ETH\_DB\_INVALID\_ARG invalid vlanSet pointer

# IX\_ETH\_DB\_FEATURE\_UNAVAILABLE VLAN/QoS feature is not available or not enabled for the port

 IxEthDBStatus ixEthDBPortVlanMembershipRangeAdd ( IxEthDBPortId portID, IxEthDBVlanId vlanIDMin, IxEthDBVlanId vlanIDMin, IxEthDBVlanId vlanIDMax )

Adds a VLAN ID range to a port's VLAN membership table.

All the VLAN IDs in the specified range will be added to the port VLAN membership table, including the range start and end VLAN IDs. Tagged frames with VLAN IDs in the specified range will be accepted by the frame filter, if Ingress VLAN membership filtering is enabled.

- Reentrant no
- ISR Callable no

#### Parameters:

portID IxEthDBPortId [in] – port ID to add the VLAN membership range into
 vlanIDMin IxEthDBVlanId [in] – start of the VLAN ID range
 vlanIDMax IxEthDBVlanId [in] – end of the VLAN ID range

#### Return values:

| IX_ETH_DB_SUCCESS             | operation completed successfully                        |
|-------------------------------|---------------------------------------------------------|
| IX_ETH_DB_INVALID_PORT        | portID is not a valid port identifier                   |
| IX_ETH_DB_PORT_UNINITIALIZED  | port is not initialized                                 |
| IX_ETH_DB_INVALID_VLAN        | the specified VLAN IDs are invalid or do not constitute |
|                               | a range                                                 |
| IX_ETH_DB_FEATURE_UNAVAILABLE | VLAN/QoS feature is not available or not enabled for    |
|                               | the port                                                |
| IX_FAIL                       | unknown OS or NPE communication error                   |

#### Note:

Is is valid to use the same VLAN ID for both vlanIDMin and vlanIDMax, in which case this function will behave as **ixEthDBPortVlanMembershipAdd** 

A port's default VLAN ID is always in its own membership table, hence there is no need to explicitly add it using this function (although it is not an error to do so)

```
      IxEthDBStatus ixEthDBPortVlanMembershipRangeRemove (IxEthDBPortId portID, IxEthDBVlanId vlanIDMin, IxEthDBVlanId vlanIDMin, IxEthDBVlanId vlanIDMax )
```

Removes a VLAN ID range from a port's VLAN membership table.

All the VLAN IDs in the specified range will be removed from the port VLAN membership table, including the range start and end VLAN IDs. Tagged frames with VLAN IDs in the range will be discarded by the frame filter, if Ingress membership filtering is enabled.

- Reentrant no
- ISR Callable no

#### Parameters:

portID **IxEthDBPortId** [in] – ID of the port to remove the VLAN membership range from

vlanIDMin IxEthDBVlanId [in] – start of the VLAN ID rangevlanIDMax IxEthDBVlanId [in] – end of the VLAN ID range

### Return values:

IX\_ETH\_DB\_SUCCESS operation completed successfully IX\_ETH\_DB\_INVALID\_PORT portID is not a valid port identifier

IX\_ETH\_DB\_PORT\_UNINITIALIZED port is not initialized

IX\_ETH\_DB\_INVALID\_VLAN the specified VLAN IDs are invalid or do not constitute

a range

IX\_ETH\_DB\_NO\_PERMISSION attempted to remove the default VLAN ID from the port

membership table (both vlanIDMin and vlanIDMax

were set to the default port VLAN ID)

IX\_ETH\_DB\_FEATURE\_UNAVAILABLE VLAN/QoS feature is not available or not enabled for

the port

IX\_FAIL unknown OS or NPE communication error

#### Note:

Is is valid to use the same VLAN ID for both vlanIDMin and vlanIDMax, in which case function will behave as **ixEthDBPortVlanMembershipRemove** 

If the given range overlaps the default port VLAN ID this function will remove all the VLAN IDs in the range except for the port VLAN ID from its own membership table. This situation will be silently dealt with (no error message will be returned) as long as the range contains more than one value (i.e. at least one other value, apart from the default port VLAN ID). If the function is called with the vlanIDMin and vlanIDMax parameters both set to the port default VLAN ID, the function will infer that an attempt was specifically made to remove the default port VLAN ID from the port membership table, in which case the return value will be IX\_ETH\_DB\_NO\_PERMISSION.

```
      IxEthDBStatus
      ixEthDBPortId
      portID

      IxEthDBVlanId
      vlanID
```

Removes a VLAN ID from a port's VLAN membership table.

Frames tagged with a VLAN ID which is not in a port's VLAN membership table will be discarded by the frame filter, if Ingress membership filtering is enabled.

• Reentrant – no

• ISR Callable – no

#### Parameters:

portID IxEthDBPortId [in] – ID of the port to remove the VLAN ID membership from vlanID IxEthDBVlanId [in] – VLAN ID to be removed from the port membership table

#### Return values:

IX\_ETH\_DB\_SUCCESSoperation completed successfullyIX\_ETH\_DB\_INVALID\_PORTportID is not a valid port identifierIX\_ETH\_DB\_INVALID\_VLANvlanID is not a valid VLAN ID

IX\_ETH\_DB\_NO\_PERMISSION attempted to remove the default VLAN ID from the port

membership table (vlanID was set to the default port

VLAN ID)

IX\_ETH\_DB\_FEATURE\_UNAVAILABLE VLAN/QoS feature is not available or not enabled for

the port

IX\_FAIL unknown OS or NPE communication error

#### Note:

A port's default VLAN ID cannot be removed from the port's membership table; attempting it will return IX\_ETH\_DB\_NO\_PERMISSION

```
IxEthDBStatus ixEthDBPortVlanMembershipSet ( IxEthDBPortId portID, IxEthDBVlanSet vlanSet )
```

Sets a port's VLAN membership table.

Sets a port's VLAN membership table from a complete VLAN table containing all the possible 4096 VLAN IDs. The table format is an array containing 4096 bits (512 bytes), where each bit indicates whether the VLAN at that bit index is in the port's membership list (if set) or not (unset).

The bit at index 0, indicating VLAN ID 0, indicates no VLAN membership and therefore no other bit must be set if bit 0 is set.

The bit at index 4095 is reserved and should never be set (it will be ignored if set).

The bit referencing the same VLAN ID as the default port VLAN ID should always be set, as the membership list must contain at least the default port VLAN ID.

- Reentrant no
- ISR Callable no

## Parameters:

portID IxEthDBPortId [in] – port ID to set the VLAN membership table tovlanSet IxEthDBVlanSet [in] – pointer to the VLAN membership table

#### Return values:

IX\_ETH\_DB\_SUCCESS operation completed successfully IX\_ETH\_DB\_INVALID\_PORT portID is not a valid port identifier

IX\_ETH\_DB\_PORT\_UNINITIALIZED port is not initialized
 IX\_ETH\_DB\_INVALID\_ARG invalid vlanSet pointer
 IX\_ETH\_DB\_FEATURE\_UNAVAILABLE VLAN/QoS feature is not available or not enabled for the port
 IX\_FAIL unknown OS or NPE communication error

```
      IxEthDBStatus
      ixEthDBPortVlanTagGet
      ( IxEthDBPortId portID, IxEthDBVlanTag * vlanTag

      )
```

Retrieves the default 802.1Q port VLAN tag for a given port (see also **ixEthDBPortVlanTagSet**).

#### Parameters:

portID **IxEthDBPortId** [in] – ID of the port to retrieve the default VLAN tag from vlanTag **IxEthDBVlanTag** [out] – location to write the default port 802.1Q VLAN tag to

- Reentrant no
- ISR Callable no

#### Return values:

IX\_ETH\_DB\_SUCCESS operation completed successfully
 IX\_ETH\_DB\_INVALID\_PORT portID is not a valid port identifier
 IX\_ETH\_DB\_PORT\_UNINITIALIZED port is not initialized
 IX\_ETH\_DB\_INVALID\_ARG invalid vlanTag pointer
 IX\_ETH\_DB\_FEATURE\_UNAVAILABLE VLAN/QoS feature is not available or not enabled for the port

```
      IxEthDBStatus
      ixEthDBPortVlanTagSet
      ( IxEthDBPortId portID, IxEthDBVlanTag vlanTag

      )
      )
```

Sets the default 802.1Q VLAN tag for a given port.

#### Parameters:

```
portID IxEthDBPortId [in] – ID of the port to set the default VLAN tag tovlanTag IxEthDBVlanTag [in] – default 802.1Q VLAN tag
```

The tag format has 16 bits and it is defined in the IEEE802.1Q specification. This tag will be used for tagging untagged frames (if enabled) and classifying unexpedited traffic into an internal traffic class (using the user priority field).

# 802.1Q tag format

| 3 bits        | 1 bit | 12<br>bits |
|---------------|-------|------------|
| user priority | CFI   | VID        |

User Priority: Defines user priority, giving eight (2^3) priority levels. IEEE 802.1P defines the operation for these 3 user priority bits

CFI: Canonical Format Indicator is always set to zero for Ethernet switches. CFI is used for compatibility reason between Ethernet type network and Token Ring type network. If a frame received at an Ethernet port has a CFI set to 1, then that frame should not be forwarded as it is to an untagged port.

VID: VLAN ID is the identification of the VLAN, which is basically used by the standard 802.1Q. It has 12 bits and allow the id entification of 4096 (2^12) VLANs. Of the 4096 possible VIDs, a VID of 0 is used to identify priority frames and value 4095 (FFF) is reserved, so the maximum possible VLAN configurations are 4,094.

- Reentrant no
- ISR Callable no

#### Return values:

```
IX_ETH_DB_SUCCESS operation completed successfully
IX_ETH_DB_INVALID_PORT portID is not a valid port identifier
IX_ETH_DB_PORT_UNINITIALIZED port is not initialized
IX_ETH_DB_FEATURE_UNAVAILABLE VLAN/QoS feature is not available or not enabled for the port
IX_ETH_DB_INVALID_VLAN vlanTag argument does not parse to a valid 802.1Q
VLAN tag
```

#### Note:

a VLAN ID value of 0 indicates that the port is not part of any VLAN

the value of the cannonical frame indicator (CFI) field is ignored, the field being used only in frame tagging operations

```
      IxEthDBStatus ixEthDBPriority MappingClassGet (IxEthDBPriority portID,

      IxEthDBPriority userPriority,

      IxEthDBPriority * trafficClass

      )
```

Retrieves one QoS/user priority => traffic class mapping in a port's priority mapping table.

This function retrieves the internal traffic class associated with a QoS (user) priority from a given port's priority mapping table. Use this function when not all the QoS priority mappings are required (see also ixEthDBPriorityMappingTableGet)

- Reentrant no
- ISR Callable no

# Parameters:

class to

Return values:

IX\_ETH\_DB\_SUCCESS operation completed successfully IX\_ETH\_DB\_INVALID\_PORT portID is not a valid port identifier

IX\_ETH\_DB\_PORT\_UNINITIALIZED port is not initialized

IX\_ETH\_DB\_INVALID\_PRIORITY invalid userPriority value (out of range)

IX\_ETH\_DB\_FEATURE\_UNAVAILABLE VLAN/QoS feature is not available or not enabled for

the port

IX\_ETH\_DB\_INVALID\_ARG invalid trafficClass pointer argument

**IxEthDBStatus** ixEthDBPriorityMappingClassSet ( **IxEthDBPortId** portID,

**IxEthDBPriority** userPriority, **IxEthDBPriority** trafficClass

1

Sets one QoS/user priority => traffic class mapping in a port's priority mapping table.

This function establishes a mapping between a user (QoS) priority and an internal traffic class. The mapping will be saved in the port's priority mapping table. Use this function when not all the QoS priorities need remapping (see also **ixEthDBPriorityMappingTableSet**)

- Reentrant no
- ISR Callable no

#### Parameters:

portID **IxEthDBPortId** [in] – ID of the port to set the mapping to

userPriority IxEthDBPriority [in] – user (QoS) priority, between 0 and 7 (0 being the

lowest)

lowest)

#### Return values:

IX\_ETH\_DB\_SUCCESS operation completed successfully IX\_ETH\_DB\_INVALID\_PORT portID is not a valid port identifier

IX\_ETH\_DB\_PORT\_UNINITIALIZED port is not initialized

IX\_ETH\_DB\_INVALID\_PRIORITY userPriority out of range or trafficClass is beyond the

number of currently available traffic classes

IX\_ETH\_DB\_FEATURE\_UNAVAILABLE VLAN/QoS feature is not available or not enabled for

the port

IX FAIL unknown OS or NPE communication error

**IxEthDBStatus** ixEthDBPriorityMappingTableGet ( **IxEthDBPortId** portID,

**IxEthDBPriorityTable** *priorityTable* 

)

Retrieves a port's priority mapping table.

The priority mapping table for the given port will be copied in the location specified by the caller using "priorityTable"

- Reentrant no
- ISR Callable no

#### Parameters:

portID ID **IxEthDBPortId** [in] – of the port to retrieve the priority mapping table from priorityTable **IxEthDBPriorityTable** [out] – pointer to a user specified location where the table will be copied to

#### Return values:

IX\_ETH\_DB\_SUCCESS operation completed successfully
 IX\_ETH\_DB\_INVALID\_PORT portID is not a valid port identifier
 IX\_ETH\_DB\_PORT\_UNINITIALIZED port is not initialized
 IX\_ETH\_DB\_INVALID\_ARG invalid priorityTable pointer
 IX\_ETH\_DB\_FEATURE\_UNAVAILABLE VLAN/QoS feature is not available or not enabled for the port

```
      IxEthDBStatus
      ixEthDBPriorityMappingTableSet
      ( IxEthDBPortId portID, IxEthDBPriorityTable priorityTable prior
```

Sets a port's priority mapping table.

The priority mapping table is an 8x2 table mapping a QoS (user) priority into an internal traffic class. There are 8 valid QoS priorities (0..7, 0 being the lowest) which can be mapped into one of the 4 available traffic classes (0..3, 0 being the lowest). If a custom priority mapping table is not specified using this function the following default priority table will be used (as per IEEE 802.1Q and IEEE 802.1D):

# QoS traffic classes

| QoS priority | Default traffic class | Traffic type                                       |
|--------------|-----------------------|----------------------------------------------------|
| 0            | 1                     | Best effort, default class for unexpedited traffic |
| 1            | 0                     | Background traffic                                 |
| 2            | 0                     | Spare bandwidth                                    |
| 3            | 1                     | Excellent effort                                   |
| 4            | 2                     | Controlled load                                    |
| 5            | 2                     | Video traffic                                      |
| 6            | 3                     | Voice traffic                                      |
| 7            | 3                     | Network control                                    |

- Reentrant no
- ISR Callable no

#### Parameters:

portID **IxEthDBPortId** [in] – port ID of the port to set the priority mapping table to priorityTable **IxEthDBPriorityTable** [in] – location of the user priority table

#### Note:

The provided table will be copied into internal data structures in EthDB and can be deallocated by the called after this function has completed its execution, if so desired

# Warning:

The number of available traffic classes differs depending on the NPE images and queue configuration. Check **IxEthDBQoS.h** for up—to—date information on the availability of traffic classes. Note that specifiying a traffic class in the priority map which exceeds the system availability will produce an IX\_ETH\_DB\_INVALID\_PRIORITY return error code and no priority will be remapped.

#### Return values:

IX\_ETH\_DB\_SUCCESSoperation completed successfullyIX\_ETH\_DB\_INVALID\_PORTportID is not a valid port identifierIX\_ETH\_DB\_PORT\_UNINITIALIZEDport is not initializedIX\_ETH\_DB\_INVALID\_ARGinvalid priorityTable pointerIX\_ETH\_DB\_INVALID\_PRIORITYat least one priority value exceeds the current number of available traffic classesIX\_ETH\_DB\_FEATURE\_UNAVAILABLEVLAN/QoS feature is not available or not enabled for the portIX\_FAILunknown OS or NPE communication error

```
      IxEthDBStatus ixEthDBSpanningTreeBlockingStateGet (IxEthDBPortId portID, BOOL * blocked

      )
      BOOL * blocked
```

Retrieves the STP blocked/unblocked state for a port.

#### Parameters:

```
portID IxEthDBPortId [in] - ID of the port
blocked BOOL * [in] - set to TRUE if the port is STP blocked, FALSE
otherwise
```

#### Return values:

IX\_ETH\_DB\_SUCCESS operation completed successfully
 IX\_ETH\_DB\_INVALID\_PORT portID is not a valid port identifier
 IX\_ETH\_DB\_PORT\_UNINITIALIZED port not initialized
 IX\_ETH\_DB\_INVALID\_ARG invalid blocked pointer argument
 IX\_ETH\_DB\_FEATURE\_UNAVAILABLE Spanning Tree Protocol feature not enabled

```
      IxEthDBStatus ixEthDBSpanningTreeBlockingStateSet (IxEthDBPortId portID, BOOL blocked)

      )
      BOOL blocked
```

Sets the STP blocked/unblocked state for a port.

#### Parameters:

```
portID IxEthDBPortId [in] – ID of the portblocked BOOL [in] – TRUE to set the port as STP blocked, FALSE to set it as unblocked
```

#### Return values:

```
IX_ETH_DB_SUCCESSoperation completed successfullyIX_ETH_DB_INVALID_PORTportID is not a valid port identifierIX_ETH_DB_PORT_UNINITIALIZEDport not initializedIX_ETH_DB_FEATURE_UNAVAILABLESpanning Tree Protocol feature not enabledIX_ETH_DB_FAILunknown OS or NPE communication error
```

#### **IxEthDBStatus** ixEthDBUnload (void )

Stops and prepares the EthDB component for unloading.

# Return values:

```
IX_ETH_DB_SUCCESS de-initialization was successful
IX_ETH_DB_BUSY de-initialization failed, ports must be disabled first
IX_ETH_DB_FAIL de-initialization failed (OS error)
```

```
IxEthDBStatus ixEthDBUserFieldGet ( IxEthDBRecordType recordType, IxEthDBMacAddr * macAddr, IxEthDBPortId portId, IxEthDBVlanId vlanID, void ** field
```

Retrieves a user-defined field from a database record.

The database record is identified using a combination of the given parameters, depending on the record type. All the record types require the record MAC address.

- IX\_ETH\_DB\_FILTERING\_RECORD requires only the MAC address
- IX\_ETH\_DB\_VLAN\_FILTERING\_RECORD requires the MAC address and the VLAN ID
- IX\_ETH\_DB\_WIFI\_RECORD requires the MAC address and the portID
- IX\_ETH\_DB\_FIREWALL\_RECORD requires the MAC address and the portID

Please note that if a parameter is not required it is completely ignored (it does not undergo parameter checking).

If no user-defined field was registered with the specified record then **NULL** will be written at the location specified by *field*.

#### Parameters:

#### Return values:

```
    IX_ETH_DB_SUCCESS operation completed successfully
    IX_ETH_DB_INVALID_PORT portID was required but it is not a valid port identifier
    IX_ETH_DB_INVALID_ARG invalid macAddr or field pointer arguments
    IX_ETH_DB_NO_SUCH_ADDR record not found
```

```
IxEthDBStatus ixEthDBUserFieldSet ( IxEthDBRecordType recordType, IxEthDBMacAddr * macAddr, IxEthDBPortId portID, IxEthDBVlanId vlanID, void * field
```

Adds a user-defined field to a database record.

This function associates a user-defined field to a database record. The user-defined field is passed as a (*void* \*) parameter, hence it can be used for any purpose (such as identifying a structure). Retrieving the user-defined field from a record is done using **ixEthDBUserFieldGet**. Note that EthDB never uses the user-defined field for any internal operation and it is not aware of the significance of its contents. The field is only stored as a pointer.

The database record is identified using a combination of the given parameters, depending on the record type. All the record types require the record MAC address.

- IX ETH DB FILTERING RECORD requires only the MAC address
- IX\_ETH\_DB\_VLAN\_FILTERING\_RECORD requires the MAC address and the VLAN ID
- IX ETH\_DB\_WIFI\_RECORD requires the MAC address and the portID
- IX\_ETH\_DB\_FIREWALL\_RECORD requires the MAC address and the portID

Please note that if a parameter is not required it is completely ignored (it does not undergo parameter checking). The user-defined field can be cleared using a **NULL** *field* parameter.

# Parameters:

recordType

**IxEthDBRecordType** [in] – type of record (can be

IX\_ETH\_DB\_FILTERING\_RECORD,

IX\_ETH\_DB\_FILTERING\_VLAN\_RECORD, IX\_ETH\_DB\_WIFI\_RECORD or

IX\_ETH\_DB\_FIREWALL\_RECORD)

portID **IxEthDBPortId** [in] – ID of the port (required only for WIFI and FIREWALL records)

macAddr IxEthDBMacAddr \* [in] – MAC address of the record

vlanID **IxEthDBVlanId** [in] – VLAN ID of the record (required only for FILTERING\_VLAN

records)

field void \* [in] – user defined field

#### Return values:

IX\_ETH\_DB\_SUCCESS operation completed successfully

IX\_ETH\_DB\_INVALID\_PORT portID was required but it is not a valid port identifier

IX\_ETH\_DB\_INVALID\_ARG invalid macAddr pointer argument

IX ETH DB NO SUCH ADDR record not found

# IxEthDBStatus ixEthDBVlanPortExtractionEnable ( IxEthDBPortId portID, BOOL enable )

Enables or disables port ID extraction.

This feature can be used in the situation when a multi-port device (e.g. a switch) is connected to an IXP4xx port and the device can provide incoming frame port identification by tagging the TPID field in the Ethernet frame. Enabling port extraction will instruct the NPE to copy the TPID field from the frame and place it in the *ixp\_ne\_src\_port* of the *ixp\_buf* header. In addition, the NPE restores the TPID field to 0.

If the frame is not tagged the NPE will fill the *ixp\_ne\_src\_port* with the port ID of the MII interface the frame was received from.

The TPID field is the least significant byte of the type/length field, which is normally set to 0x8100 for 802.1Q-tagged frames.

This feature is disabled by default.

#### Parameters:

portID ID of the port to configure port ID extraction onenable TRUE to enable port ID extraction and FALSE to disable it

#### Return values:

IX\_ETH\_DB\_SUCCESS operation completed successfully IX\_ETH\_DB\_INVALID\_PORT portID is not a valid port identifier

IX\_ETH\_DB\_PORT\_UNINITIALIZED port is not initialized

IX\_ETH\_DB\_FEATURE\_UNAVAILABLE VLAN/QoS feature is not available or not enabled for

the port

*IX\_FAIL* unknown OS or NPE communication error

Retrieves the 802.1Q VLAN tag from a database record given the record MAC address.

#### Parameters:

macAddr MAC address
vlanTag location to write the record 802.1Q VLAN tag to

#### Note:

VLAN tags can be retrieved only from IX\_ETH\_DB\_FILTERING\_VLAN\_RECORD type records

This function is used together with ixEthDBVlanTagSet to provide MAC-based VLAN classification support. Please note that the bridging application must contain specific code to make use of this feature (see ixEthDBVlanTagSet).

- Reentrant no
- ISR Callable no

#### Return values:

IX\_ETH\_DB\_SUCCESS operation completed successfully
 IX\_ETH\_DB\_INVALID\_ARG invalid macAddr or vlanTag pointer
 IX\_ETH\_DB\_NO\_SUCH\_ADDR a filtering record with the specified MAC address was not found

```
      IxEthDBStatus
      ixEthDBVlanTagSet
      ( IxEthDBMacAddr * macAddr, IxEthDBVlanTag

      vlanTag
      )
```

Sets the 802.1Q VLAN tag for a database record.

# Parameters:

```
macAddr MAC address vlanTag 802.1Q VLAN tag
```

This function is used together with **ixEthDBVlanTagGet** to provide MAC-based VLAN classification support. Please note that the bridging application must contain specific code to make use of this feature (see below).

VLAN tags can be set only in IX\_ETH\_DB\_FILTERING\_RECORD or IX\_ETH\_DB\_FILTERING\_VLAN\_RECORD type records. If to an IX\_ETH\_DB\_FILTERING\_RECORD

type record is added a VLAN tag the record type is automatically changed to IX\_ETH\_DB\_FILTERING\_VLAN\_RECORD. Once this has occurred the record type will never revert to a

non-VLAN type (unless deleted and re-added).

Record types used for different purposes (such as IX\_ETH\_DB\_WIFI\_RECORD) will be ignored by this function.

After using this function to associate a VLAN ID with a MAC address the VLAN ID can be extracted knowing the MAC address using **ixEthDBVlanTagGet**. This mechanism can be used to implement MAC-based VLAN classification if a bridging application searches for the VLAN tag when receiving a frame based on the source MAC address (contained in the <code>ixp\_ne\_src\_mac</code> field of the buffer header). If found in the database, the application can instruct the NPE to tag the frame by writing the VLAN tag in the <code>ixp\_ne\_vlan\_tci</code> field of the buffer header. This way the NPE will inspect the Egress tagging rule associated with the given VLAN ID on the Tx port and tag the frame if Egress tagging on the VLAN is allowed. Additionally, Egress tagging can be forced by setting the <code>ixp\_ne\_tx\_flags.tag\_over</code> and <code>ixp\_ne\_tx\_flags.tag\_mode</code> flags in the buffer header.

- Reentrant no
- ISR Callable no

#### Note:

this function will **not** add a filtering record, it can only be used to update an existing one

#### Return values:

```
IX_ETH_DB_SUCCESSoperation completed successfullyIX_ETH_DB_INVALID_ARGinvalid macAddr pointerIX_ETH_DB_NO_SUCH_ADDRa filtering record with the specified MAC address was not foundIX_ETH_DB_INVALID_VLANvlanTag argument does not parse to a valid 802.1Q VLAN tag
```

```
      IxEthDBStatus ixEthDBWiFiAccessPointEntryAdd ( IxEthDBPortId portID, IxEthDBMacAddr * macAddr, IxEthDBMacAddr * gatewayMacAddr * gatewayMacAddr )
```

Adds an "Access Point to Access Point" record to the database.

## See also:

# ix Eth DBW i Fi Station Entry Add

Note that adding the same MAC address twice will simply overwrite the previously defined gateway MAC address value in the same record, if the record was previously of the "Access Point to Access Point" type.

Re-adding a MAC address as "Access Point to Access Point", which was previously added as "Access Point to Station" will migrate the record type to "Access Point to Access Point" and record the gateway MAC address.

#### Parameters:

portID **IxEthDBPortId** [in] – ID of the port

macAddr [in] – MAC address to add

gatewayMacAddr IxEthDBMacAddr [in] - MAC address of the gateway Access Point

## Return values:

IX\_ETH\_DB\_SUCCESSoperation completed successfullyIX\_ETH\_DB\_INVALID\_PORTportID is not a valid port identifier

*IX\_ETH\_DB\_PORT\_UNINITIALIZED* port is not initialized *IX\_ETH\_DB\_FEATURE\_UNAVAILABLE* WiFi feature not enabled

IX\_ETH\_DB\_INVALID\_ARG invalid macAddr or gatewayMacAddr or bssid pointer

argument

IX\_ETH\_DB\_FAIL maximum number of records reached

IX\_ETH\_DB\_BUSY lock condition or transaction in progress, try again later

```
      IxEthDBStatus
      ixEthDBWiFiBSSIDSet
      ( IxEthDBPortId portID, IxEthDBMacAddr * bssid )
```

Sets the BSSID field.

The BSSID field is a 6-byte value which identifies the infrastructure of the service set managed by the Access Point having the IXP400 as its processor. The value is written in the *BSSID* field of the 802.11 frame header. The BSSID value is the MAC address of the Access Point.

#### Parameters:

portID IxEthDBPortId [in] - ID of the port

bssid **IxEthDBMacAddr** [in] – pointer to 6 bytes containing the BSSID

### Return values:

IX\_ETH\_DB\_SUCCESS operation completed successfully IX\_ETH\_DB\_INVALID\_PORT portID is not a valid port identifier

IX\_ETH\_DB\_PORT\_UNINITIALIZED port not initialized

IX\_ETH\_DB\_INVALID\_ARG invalid bssid pointer argument IX\_ETH\_DB\_FEATURE\_UNAVAILABLE WiFi feature not enabled

IX\_ETH\_DB\_FAIL unknown OS or NPE communication error

### **IxEthDBStatus** ixEthDBWiFiConversionTableDownload ( **IxEthDBPortId** portID )

Downloads the MAC address table for 802.3 => 802.11 frame header conversion to the NPE.

Note that the frame conversion MAC address table must be individually downloaded to each NPE for which the frame header conversion feature is enabled (i.e. it is not possible to specify IX\_ETH\_DB\_ALL\_PORTS).

#### Parameters:

portID **IxEthDBPortId** [in] – ID of the port

#### Return values:

IX\_ETH\_DB\_SUCCESS operation completed successfully

IX\_ETH\_DB\_PORT\_UNINITIALIZED port not initialized

IX\_ETH\_DB\_INVALID\_PORT portID is not a valid port identifier

IX\_ETH\_DB\_FEATURE\_UNAVAILABLE WiFi feature not enabled

IX\_ETH\_DB\_FAIL unknown OS or NPE communication error

```
IxEthDBStatus ixEthDBWiFiDurationIDSet ( IxEthDBPortId portID, UINT16 durationID )
```

Sets the GlobalDurationID field.

The GlobalDurationID field is a 2-byte value inserted in the *Duration/ID* field for all 802.3 to 802.11 frame header conversions

#### Parameters:

```
portID IxEthDBPortId [in] – ID of the port durationID UINT16 [in] – GlobalDurationID field
```

#### Return values:

IX\_ETH\_DB\_SUCCESS operation completed successfully IX\_ETH\_DB\_INVALID\_PORT portID is not a valid port identifier

IX\_ETH\_DB\_PORT\_UNINITIALIZED port not initialized IX\_ETH\_DB\_FEATURE\_UNAVAILABLE WiFi feature not enabled

IX\_ETH\_DB\_FAIL unknown OS or NPE communication error

```
      IxEthDBStatus
      ixEthDBWiFiEntryRemove
      ( IxEthDBPortId portID, IxEthDBMacAddr * macAddr )
```

Removes a WiFi station record.

This function removes both types of WiFi records ("Access Point to Station" and "Access Point to Access Point").

#### Parameters:

## Return values:

IX\_ETH\_DB\_SUCCESS operation completed successfully IX\_ETH\_DB\_INVALID\_PORT portID is not a valid port identifier

IX\_ETH\_DB\_PORT\_UNINITIALIZED port is not initialized

IX\_ETH\_DB\_INVALID\_ARG invalid macAddr pointer argument

IX\_ETH\_DB\_NO\_SUCH\_ADDR specified address was not found in the database

IX\_ETH\_DB\_FEATURE\_UNAVAILABLE WiFi feature not enabled

IX\_ETH\_DB\_BUSY lock condition or transaction in progress, try again later

Sets the GlobalFrameControl field.

The GlobalFrameControl field is a 2-byte value inserted in the *Frame Control* field for all 802.3 to 802.11 frame header conversions

#### Parameters:

```
portID IxEthDBPortId [in] – ID of the port frameControl UINT16 [in] – GlobalFrameControl value
```

#### Return values:

IX\_ETH\_DB\_SUCCESS operation completed successfully IX\_ETH\_DB\_INVALID\_PORT portID is not a valid port identifier

IX\_ETH\_DB\_PORT\_UNINITIALIZED port not initialized IX\_ETH\_DB\_FEATURE\_UNAVAILABLE WiFi feature not enabled

IX\_ETH\_DB\_FAIL unknown OS or NPE communication error

```
      IxEthDBStatus
      ixEthDBWiFiRecordEntryAdd
      ( IxEthDBPortId portID, IxEthDBMacAddr * macAddr, IxEthDBWiFiRecData * wifiRecData * wifiRecData
```

Adds "APMAC/BSSID/STATIONS" record to the database, for 802.3 => 802.11 frame header conversion.

Frame header conversion is controlled by the set of MAC addresses and bssids, for the backward compatibility the old APIs are still usable to add gateway MAC address and station entry ixEthDBWiFiAccessPointEntryAdd and ixEthDBWiFiStationEntryAdd. Conversion arguments are added using ixEthDBWiFiFrameControlSet, ixEthDBWiFiDurationIDSet and ixEthDBWiFiRecordEntryAdd.

Note that adding the same MAC address twice will not return an error (but will not accomplish anything either)

# Parameters:

portID **IxEthDBPortId** [in] – ID of the port

macAddr IxEthDBMacAddr [in] – MAC address to add wifiRecData pointer to the wifi specific data (flags, gw etc.)

#### Return values:

IX\_ETH\_DB\_SUCCESS operation completed successfully IX\_ETH\_DB\_INVALID\_PORT portID is not a valid port identifier

IX\_ETH\_DB\_FEATURE\_UNAVAILABLE WiFi feature not enabled

IX\_ETH\_DB\_INVALID\_ARG invalid macAddr, wifiRecData, recType, logPort,

vlanFlag or padLen arguments

IX\_ETH\_DB\_FAIL maximum number of records reached

IX\_ETH\_DB\_BUSY lock condition or transaction in progress, try again later

```
      IxEthDBStatus
      ixEthDBWiFiStationEntryAdd
      ( IxEthDBPortId portID, IxEthDBMacAddr * macAddr )
```

Adds an "Access Point to Station" record to the database, for 802.3 => 802.11 frame header conversion.

Frame header conversion is controlled by the set of MAC addresses added using ixEthDBWiFiStationEntryAdd and ixEthDBWiFiAccessPointEntryAdd. Conversion arguments are added using ixEthDBWiFiFrameControlSet, ixEthDBWiFiDurationIDSet and ixEthDBWiFiBSSIDSet.

Note that adding the same MAC address twice will not return an error (but will not accomplish anything either), while re-adding a record previously added as an "Access Point to Access Point" will migrate the record to the "Access Point to Station" type.

#### Parameters:

#### Return values:

IX\_ETH\_DB\_SUCCESS operation completed successfully IX\_ETH\_DB\_INVALID\_PORT portID is not a valid port identifier

IX\_ETH\_DB\_FEATURE\_UNAVAILABLE WiFi feature not enabled

IX\_ETH\_DB\_INVALID\_ARG invalid macAddr or bssid pointer argument IX\_ETH\_DB\_FAIL maximum number of records reached

IX\_ETH\_DB\_BUSY lock condition or transaction in progress, try again later

# Intel (R) IXP400 Software Ethernet Database Port Definitions (IxEthDBPortDefs)

IXP400 Public definition of the ports and port capabilities.

# **Data Structures**

#### struct IxEthDBPortDefinition

*Port Definition – a structure contains the Port type and capabilities.* 

# **Defines**

# #define IX\_ETH\_DB\_NUMBER\_OF\_PORTS

number of supported ports

### #define IX ETH DB UNKNOWN PORT

definition of an unknown port

### #define IX ETH DB ALL PORTS

Special port ID indicating all the ports.

#### #define IX ETH DB PORTS ASSERTION

catch invalid port definitions (<2) with a compile-time assertion resulting in a duplicate case error.

#### #define IX ETH DB CHECK PORT(portID)

safety checks to verify whether the port is invalid or uninitialized

## #define **IX\_ETH\_DB\_CHECK\_PORT\_ALL**(portID)

safety checks to verify whether the port is invalid or uninitialized; tolerates the use of IX\_ETH\_DB\_ALL\_PORTS

# #define IX\_ETH\_DB\_QUEUE\_UNAVAILABLE

alias to indicate a queue (traffic class) is not available

# #define IX\_IEEE802\_1Q\_QOS\_PRIORITY\_COUNT

number of QoS priorities, according to IEEE 802.1Q

#### #define IX ETH DB NPE A FUNCTIONALITY ID INDEX

value used to index the NPE A functionality ID in the traffic class definition table

# #define IX\_ETH\_DB\_TRAFFIC\_CLASS\_COUNT\_INDEX

value used to index the traffic class count in the traffic class definition table

# #define IX\_ETH\_DB\_QUEUE\_ASSIGNMENT\_INDEX

value used to index the queue assignment index in the traffic class definition table

# **Enumerations**

# **Variables**

**IxEthDBPortDefinition ixEthDBPortDefinitions** [IX\_ETH\_DB\_NUMBER\_OF\_PORTS] *Port definitions structure, indexed on the port ID.* 

capabilities.

# **Detailed Description**

IXP400 Public definition of the ports and port capabilities.

# **Define Documentation**

#define IX\_ETH\_DB\_ALL\_PORTS

Special port ID indicating all the ports.

Note:

This port ID can be used only by a subset of the EthDB API; each function specifically mentions whether this is a valid parameter as the port ID

Definition at line 83 of file IxEthDBPortDefs.h.

Enumerations 256

# #define IX\_ETH\_DB\_CHECK\_PORT ( portID )

safety checks to verify whether the port is invalid or uninitialized

Definition at line **96** of file **IxEthDBPortDefs.h**.

# #define IX\_ETH\_DB\_CHECK\_PORT\_ALL ( portID )

safety checks to verify whether the port is invalid or uninitialized; tolerates the use of IX\_ETH\_DB\_ALL\_PORTS

Definition at line 114 of file IxEthDBPortDefs.h.

# #define IX\_ETH\_DB\_NPE\_A\_FUNCTIONALITY\_ID\_INDEX

value used to index the NPE A functionality ID in the traffic class definition table

Definition at line **51** of file **IxEthDBQoS.h**.

# #define IX\_ETH\_DB\_NUMBER\_OF\_PORTS

number of supported ports

Definition at line **57** of file **IxEthDBPortDefs.h**.

# #define IX\_ETH\_DB\_PORTS\_ASSERTION

catch invalid port definitions (<2) with a compile–time assertion resulting in a duplicate case error.

Definition at line 90 of file IxEthDBPortDefs.h.

# #define IX\_ETH\_DB\_QUEUE\_ASSIGNMENT\_INDEX

value used to index the queue assignment index in the traffic class definition table

Definition at line 61 of file IxEthDBQoS.h.

# #define IX\_ETH\_DB\_QUEUE\_UNAVAILABLE

alias to indicate a queue (traffic class) is not available

Definition at line 25 of file IxEthDBQoS.h.

Enumerations 257

# #define IX ETH DB TRAFFIC CLASS COUNT INDEX

value used to index the traffic class count in the traffic class definition table

Definition at line 56 of file IxEthDBQoS.h.

# #define IX\_ETH\_DB\_UNKNOWN\_PORT

definition of an unknown port

Definition at line **75** of file **IxEthDBPortDefs.h**.

# #define IX\_IEEE802\_1Q\_QOS\_PRIORITY\_COUNT

number of QoS priorities, according to IEEE 802.1Q

Definition at line **32** of file **IxEthDBQoS.h**.

# **Enumeration Type Documentation**

# enum IxEthDBPortCapability

Port capabilities – used by ixEthAccDatabaseMaintenance to decide whether it should manually age entries or not depending on the port capabilities.

Ethernet NPEs have aging capabilities, meaning that they will age the entries automatically (by themselves).

#### **Enumeration values:**

IX\_ETH\_NO\_CAPABILITIES no aging capabilities IX\_ETH\_ENTRY\_AGING aging capabilities present

Definition at line **37** of file **IxEthDBPortDefs.h**.

# enum IxEthDBPortType

Port types – currently only Ethernet NPEs are recognized as specific types All other (user–defined) ports must be specified as IX\_ETH\_GENERIC.

### **Enumeration values:**

IX\_ETH\_GENERIC generic ethernet port IX\_ETH\_NPE specific Ethernet NPE

Definition at line 25 of file IxEthDBPortDefs.h.

# **Variable Documentation**

# **IxEthDBPortDefinition** ixEthDBPortDefinitions[IX\_ETH\_DB\_NUMBER\_OF\_PORTS]

Port definitions structure, indexed on the port ID.

# Warning:

Ports 0 and 1 are used by the Ethernet access component therefore it is essential to be left untouched. Port 2 can be Ethernet Port or WAN port. Port 3 here (WAN) is given as an example port. The NPE firmware also assumes the NPE B to be the port 0, NPE C to be the port 1, and NPE A to be port 2.

# Note:

that only 32 ports (0..31) are supported by EthDB

Definition at line 69 of file IxEthDBPortDefs.h.

Variable Documentation 259

# Intel (R) IXP400 Software Ethernet Phy Access (IxEthMii) API

ethMii is a library that does provides access to the Ethernet PHYs

# **Functions**

**PUBLIC** 

IX\_STATUS ixEthMiiPhyScan (BOOL phyPresent[], UINT32 maxPhyCount)

Scan the MDIO bus for PHYs This function scans PHY addresses 0 through 31, and sets phyPresent[n] to TRUE if a phy is discovered at address n.

PUBLIC**ixEthMiiPhyConfig** (UINT32 phyAddr, BOOL speed100, BOOL fullDuplex, BOOL IX STATUS autonegotiate)

Configure a PHY Configure a PHY's speed, duplex and autonegotiation status.

**PUBLIC** 

IX STATUS ixEthMiiPhyLoopbackEnable (UINT32 phyAddr)

Enable PHY Loopback in a specific Eth MII port.

**PUBLIC** 

IX\_STATUS ixEthMiiPhyLoopbackDisable (UINT32 phyAddr)

Disable PHY Loopback in a specific Eth MII port.

**PUBLIC** 

IX\_STATUS ixEthMiiPhyReset (UINT32 phyAddr)

Reset a PHY Reset a PHY.

PUBLICixEthMiiLinkStatus (UINT32 phyAddr, BOOL \*linkUp, BOOL \*speed100, BOOL

IX\_STATUS \*fullDuplex, BOOL \*autoneg)

Retrieve the current status of a PHY Retrieve the link, speed, duplex and autonegotiation status of a PHY.

**PUBLIC** 

IX\_STATUS ixEthMiiPhyShow (UINT32 phyAddr)

Display information on a specified PHY Display link status, speed, duplex and Auto Negotiation status.

# **Detailed Description**

ethMii is a library that does provides access to the Ethernet PHYs

# **Function Documentation**

```
ixEthMiiLinkStatus ( UINT32 phyAddr,
BOOL * linkUp,
BOOL * speed100,
BOOL * fullDuplex,
BOOL * autoneg
)
```

Retrieve the current status of a PHY Retrieve the link, speed, duplex and autonegotiation status of a PHY.

```
* - Reentrant - no
```

• ISR Callable - no

#### Precondition:

The MAC on Ethernet Port 2 (NPE C) must be initialised, and generating the MDIO clock.

#### Parameters:

```
    phyAddr UINT32 [in] – the address of the Ethernet PHY (0–31)
    linkUp BOOL [out] – set to TRUE if the link is up
    speed100 BOOL [out] – set to TRUE indicates 100Mbit/s, FALSE indicates 10Mbit/s
    fullDuplex BOOL [out] – set to TRUE indicates Full Duplex, FALSE indicates Half Duplex
    autoneg BOOL [out] – set to TRUE indicates autonegotiation is enabled, FALSE indicates autonegotiation is disabled
```

# Returns:

```
ixEthMiiPhyConfig ( UINT32 phyAddr,

BOOL speed100,

BOOL fullDuplex,

BOOL autonegotiate
)
```

Configure a PHY Configure a PHY's speed, duplex and autonegotiation status.

```
* - Reentrant - no
```

• ISR Callable - no

#### **Precondition:**

The MAC on Ethernet Port 2 (NPE C) must be initialised, and generating the MDIO clock.

```
Parameters:
```

phyAddr UINT32 [in]

speed100 BOOL [in] – set to TRUE for 100Mbit/s operation, FALSE for

10Mbit/s

fullDuplex BOOL [in] – set to TRUE for Full Duplex, FALSE for Half Duplex

autonegotiate BOOL [in] - set to TRUE to enable autonegotiation

#### Returns:

```
IX_STATUS
```

**♦ IX SUCCESS** 

♦ IX\_FAIL : invalid arguments.

# ixEthMiiPhyLoopbackDisable (UINT32 phyAddr)

Disable PHY Loopback in a specific Eth MII port.

```
* - Reentrant - no
```

• ISR Callable – no

#### Parameters:

```
phyAddr UINT32 [in] – the address of the Ethernet PHY (0–31)
```

# Returns:

```
IX_STATUS
```

♦ IX\_SUCCESS

♦ IX\_FAIL : invalid arguments.

# ixEthMiiPhyLoopbackEnable (UINT32 phyAddr)

Enable PHY Loopback in a specific Eth MII port.

#### Note:

When PHY Loopback is enabled, frames sent out to the PHY from the IXP400 will be looped back to the IXP400. They will not be transmitted out on the wire.

- Reentrant no
- ISR Callable no

#### Parameters:

```
phyAddr UINT32 [in] – the address of the Ethernet PHY (0–31)
```

#### Returns:

IX\_STATUS

♦ IX\_FAIL : invalid arguments.

# ixEthMiiPhyReset (UINT32 phyAddr)

Reset a PHY Reset a PHY.

- \* Reentrant no
  - ISR Callable no

# Precondition:

The MAC on Ethernet Port 2 (NPE C) must be initialised, and generating the MDIO clock.

#### Parameters:

phyAddr UINT32 [in] – the address of the Ethernet PHY (0–31)

#### Returns:

Scan the MDIO bus for PHYs This function scans PHY addresses 0 through 31, and sets phyPresent[n] to TRUE if a phy is discovered at address n.

- \* Reentrant no
  - ISR Callable no

#### Precondition:

The MAC on Ethernet Port 2 (NPE C) must be initialised, and generating the MDIO clock.

#### Parameters:

```
phyPresent BOOL [in] – boolean array of IXP400_ETH_ACC_MII_MAX_ADDR entriesmaxPhyCount UINT32 [in] – number of PHYs to search for (the scan will stop when the indicated number of PHYs is found).
```

#### Returns:

# ixEthMiiPhyShow (UINT32 phyAddr)

Display information on a specified PHY Display link status, speed, duplex and Auto Negotiation status.

```
* – Reentrant – no
```

• ISR Callable - no

# Precondition:

The MAC on Ethernet Port 2 (NPE C) must be initialised, and generating the MDIO clock.

#### Parameters:

phyAddr UINT32 [in] – the address of the Ethernet PHY (0–31)

# Returns:

IX\_STATUS

♦ IX\_SUCCESS

♦ IX\_FAIL : invalid arguments.

# Intel (R) IXP400 Software Feature Control (IxFeatureCtrl) API

The Public API for the IXP400 Feature Control.

# **Modules**

Intel (R) IXP400 Software Configuration for Access Component

This section describes software configuration in access component. The configuration can be changed at run—time. ixFeatureCtrlSwConfigurationCheck() will be used across applicable access component to check the configuration. ixFeatureCtrlSwConfigurationWrite() is used to write the software configuration.

# **Defines**

### #define IX FEATURE CTRL COMPONENT DISABLED

Hardware Component is disabled/unavailable. Return status by ixFeatureCtrlComponentCheck().

# #define IX\_FEATURE\_CTRL\_COMPONENT\_ENABLED

Hardware Component is available. Return status by ixFeatureCtrlComponentCheck().

# #define IX\_FEATURE\_CTRL\_SILICON\_TYPE\_A0

This is the value of A0 Silicon in product ID.

# #define IX\_FEATURE\_CTRL\_SILICON\_TYPE\_B0

This is the value of B0 Silicon in product ID.

# #define IX\_FEATURE\_CTRL\_SILICON\_STEPPING\_MASK

This is the mask of silicon stepping in product ID.

# #define IX\_FEATURE\_CTRL\_DEVICE\_TYPE\_MASK

This is the mask of silicon stepping in product ID.

#### #define IX FEATURE CTRL DEVICE TYPE OFFSET

This is the mask of silicon stepping in product ID.

#### #define IX FEATURE CTRL XSCALE FREQ 533

This is the value of 533MHz Intel XScale(R) Core in product ID.

#define IX\_FEATURE\_CTRL\_XSCALE\_FREQ\_400

This is the value of 400MHz Intel XScale(R) Core in product ID.

#### #define IX FEATURE CTRL XSCALE FREQ 266

This is the value of 266MHz Intel XScale(R) Core in product ID.

#### #define IX\_FEATURE\_CTRL\_XSCALE\_FREQ\_MASK

*This is the mask of Intel XScale(R) Core in product ID.* 

#### #define IX\_FEATURECTRL\_REG\_UTOPIA\_32PHY

Maximum UTOPIA PHY available is 32.

#### #define IX\_FEATURECTRL\_REG\_UTOPIA\_16PHY

Maximum UTOPIA PHY available is 16.

#### #define IX\_FEATURECTRL\_REG\_UTOPIA\_8PHY

Maximum UTOPIA PHY available to is 8.

#### #define IX FEATURECTRL REG UTOPIA 4PHY

Maximum UTOPIA PHY available to is 4.

#### #define IX\_FEATURECTRL\_REG\_XSCALE\_533FREQ

Maximum frequency available to Intel (R) IXP46X Product Line of Network Processors is 533 MHz.

#### #define IX\_FEATURECTRL\_REG\_XSCALE\_667FREQ

Maximum frequency available to Intel (R) IXP46X Product Line of Network Processors is 667 MHz.

#### #define IX\_FEATURECTRL\_REG\_XSCALE\_400FREQ

Maximum frequency available to Intel (R) IXP46X Product Line of Network Processors is 400 MHz.

#### #define IX\_FEATURECTRL\_REG\_XSCALE\_266FREQ

Maximum frequency available to Intel (R) IXP46X Product Line of Network Processors is 266 MHz.

#### #define IX\_FEATURECTRL\_COMPONENT\_NOT\_AVAILABLE

Component selected is not available for device.

#### #define IX\_FEATURECTRL\_COMPONENT\_ALWAYS\_AVAILABLE

Component selected is not available for device.

# **Typedefs**

#### typedef UINT32 IxFeatureCtrlReg

Feature Control Register that contains hardware components' availability information.

#### typedef UINT32 IxFeatureCtrlProductId

Typedefs 266

Product ID of Silicon that contains Silicon Stepping and Maximum Intel XScale(R) Core Frequency information.

## **Functions**

#### **PUBLIC**

#### IxFeatureCtrlReg ixFeatureCtrlRead (void)

This function reads out the CURRENT value of Feature Control Register. The current value may not be the same as that of the hardware component availability.

#### IxFeatureCtrlDeviceId ixFeatureCtrlDeviceRead (void)

This function gets the type of device that the software is currently running on.

#### IxFeatureCtrlBuildDevice ixFeatureCtrlSoftwareBuildGet (void)

This function refers to the value set by the compiler flag to determine the type of device the software is built for.

#### **PUBLIC**

#### IxFeatureCtrlReg ixFeatureCtrlHwCapabilityRead (void)

This function reads out the hardware capability of a silicon type as defined in feature control register. This value is different from that returned by ixFeatureCtrlRead() because this function returns the actual hardware component availability.

#### PUBLIC void **ixFeatureCtrlWrite** (**IxFeatureCtrlReg** expUnitReg)

This function write the value stored in IxFeatureCtrlReg expUnitReg to the Feature Control Register.

#### $PUBLIC\ IX\_STATUS\ \textbf{ix} \textbf{FeatureCtrlComponentCheck}\ (\textbf{Ix} \textbf{FeatureCtrlComponentType}$

componentType)

This function will check the availability of hardware component specified as componentType value.

#### **PUBLIC**

#### IxFeatureCtrlProductId ixFeatureCtrlProductIdRead (void)

This function will return IXP400 product ID i.e. CP15, Register 0.

#### PUBLIC IX\_STATUS ixFeatureCtrlSwConfigurationCheck (IxFeatureCtrlSwConfig

swConfigType)

This function checks whether the specified software configuration is enabled or disabled.

#### PUBLIC void ixFeatureCtrlSwConfigurationWrite (IxFeatureCtrlSwConfig

swConfigType, BOOL enabled)

This function enable/disable the specified software configuration.

#### PUBLIC void ixFeatureCtrlIxp400SwVersionShow (void)

# **Detailed Description**

The Public API for the IXP400 Feature Control.

# **Define Documentation**

#### #define IX\_FEATURE\_CTRL\_COMPONENT\_DISABLED

Hardware Component is disabled/unavailable. Return status by ixFeatureCtrlComponentCheck().

Definition at line 48 of file IxFeatureCtrl.h.

#### #define IX\_FEATURE\_CTRL\_COMPONENT\_ENABLED

Hardware Component is available. Return status by ixFeatureCtrlComponentCheck().

Definition at line **58** of file **IxFeatureCtrl.h**.

#### #define IX FEATURE CTRL DEVICE TYPE MASK

This is the mask of silicon stepping in product ID.

Definition at line 128 of file IxFeatureCtrl.h.

#### #define IX\_FEATURE\_CTRL\_DEVICE\_TYPE\_OFFSET

This is the mask of silicon stepping in product ID.

Definition at line 137 of file IxFeatureCtrl.h.

#### #define IX\_FEATURE\_CTRL\_SILICON\_STEPPING\_MASK

This is the mask of silicon stepping in product ID.

Definition at line 119 of file IxFeatureCtrl.h.

#### #define IX\_FEATURE\_CTRL\_SILICON\_TYPE\_A0

This is the value of A0 Silicon in product ID.

Definition at line 101 of file IxFeatureCtrl.h.

#### #define IX\_FEATURE\_CTRL\_SILICON\_TYPE\_B0

This is the value of B0 Silicon in product ID.

Definition at line 110 of file IxFeatureCtrl.h.

#### #define IX\_FEATURE\_CTRL\_XSCALE\_FREQ\_266

This is the value of 266MHz Intel XScale(R) Core in product ID.

Definition at line **165** of file **IxFeatureCtrl.h**.

#### #define IX\_FEATURE\_CTRL\_XSCALE\_FREQ\_400

This is the value of 400MHz Intel XScale(R) Core in product ID.

Definition at line **156** of file **IxFeatureCtrl.h**.

#### #define IX\_FEATURE\_CTRL\_XSCALE\_FREQ\_533

This is the value of 533MHz Intel XScale(R) Core in product ID.

Definition at line **147** of file **IxFeatureCtrl.h**.

#### #define IX\_FEATURE\_CTRL\_XSCALE\_FREQ\_MASK

This is the mask of Intel XScale(R) Core in product ID.

Definition at line 174 of file IxFeatureCtrl.h.

#### #define IX\_FEATURECTRL\_COMPONENT\_ALWAYS\_AVAILABLE

Component selected is not available for device.

Definition at line 280 of file IxFeatureCtrl.h.

#### #define IX\_FEATURECTRL\_COMPONENT\_NOT\_AVAILABLE

Component selected is not available for device.

Definition at line **270** of file **IxFeatureCtrl.h**.

#### #define IX\_FEATURECTRL\_REG\_UTOPIA\_16PHY

Maximum UTOPIA PHY available is 16.

Definition at line **194** of file **IxFeatureCtrl.h**.

#### #define IX\_FEATURECTRL\_REG\_UTOPIA\_32PHY

Maximum UTOPIA PHY available is 32.

Definition at line **184** of file **IxFeatureCtrl.h**.

#### #define IX\_FEATURECTRL\_REG\_UTOPIA\_4PHY

Maximum UTOPIA PHY available to is 4.

Definition at line **214** of file **IxFeatureCtrl.h**.

#### #define IX\_FEATURECTRL\_REG\_UTOPIA\_8PHY

Maximum UTOPIA PHY available to is 8.

Definition at line **204** of file **IxFeatureCtrl.h**.

#### #define IX\_FEATURECTRL\_REG\_XSCALE\_266FREQ

Maximum frequency available to Intel (R) IXP46X Product Line of Network Processors is 266 MHz.

Definition at line **259** of file **IxFeatureCtrl.h**.

#### #define IX\_FEATURECTRL\_REG\_XSCALE\_400FREQ

Maximum frequency available to Intel (R) IXP46X Product Line of Network Processors is 400 MHz.

Definition at line **248** of file **IxFeatureCtrl.h**.

#### #define IX\_FEATURECTRL\_REG\_XSCALE\_533FREQ

Maximum frequency available to Intel (R) IXP46X Product Line of Network Processors is 533 MHz.

Definition at line **226** of file **IxFeatureCtrl.h**.

#### #define IX\_FEATURECTRL\_REG\_XSCALE\_667FREQ

Maximum frequency available to Intel (R) IXP46X Product Line of Network Processors is 667 MHz.

Definition at line 237 of file IxFeatureCtrl.h.

# **Typedef Documentation**

#### IxFeatureCtrlProductId

Product ID of Silicon that contains Silicon Stepping and Maximum Intel XScale(R) Core Frequency information.

Definition at line **492** of file **IxFeatureCtrl.h**.

#### **IxFeatureCtrlReg**

Feature Control Register that contains hardware components' availability information.

Definition at line **482** of file **IxFeatureCtrl.h**.

# **Function Documentation**

#### IX\_STATUS ixFeatureCtrlComponentCheck ( **IxFeatureCtrlComponentType** )

This function will check the availability of hardware component specified as component Type value.

Usage Example:

- if(IX\_FEATURE\_CTRL\_COMPONENT\_DISABLED != ixFeatureCtrlComponentCheck(IX\_FEATURECTRL\_ETH0))
- if(IX\_FEATURE\_CTRL\_COMPONENT\_ENABLED == ixFeatureCtrlComponentCheck(IX\_FEATURECTRL\_PCI))

This function is typically called during component initialization time.

#### Parameters:

componentType **IxFeatureCtrlComponentType** [in] – the type of a component as defined above as IX\_FEATURECTRL\_XXX (Exp: IX\_FEATURECTRL\_PCI, IX\_FEATURECTRL\_ETH0)

#### Returns:

♦ IX\_FEATURE\_CTRL\_COMPONENT\_ENABLED if component is available ♦ IX\_FEATURE\_CTRL\_COMPONENT\_DISABLED if component is unavailable

#### IxFeatureDeviceId ixFeatureCtrlDeviceRead (void)

This function gets the type of device that the software is currently running on.

This function reads the feature Ctrl register specifically to obtain the device id. The definitions of the avilable IDs are as above.

#### Returns:

♦ IxFeatureCtrlDeviceId – the type of device currently running

#### **IxFeatureCtrlReg** ixFeatureCtrlHwCapabilityRead (void )

This function reads out the hardware capability of a silicon type as defined in feature control register. This value is different from that returned by **ixFeatureCtrlRead()** because this function returns the actual hardware component availability.

The bit location of each hardware component is defined above. A value of '1' in bit means the hardware component is not available. A value of '0' means the hardware component is available.

#### Returns:

♦ IxFeatureCtrlReg – the hardware capability of IXP400.

#### Warning:

♦ This function must not be called when IXP400 is running as the result is undefined.

#### void ixFeatureCtrlIxp400SwVersionShow (void)

This function shows the current software release information for IXP400.

#### Returns:

none

#### **IxFeatureCtrlProductId** ixFeatureCtrlProductIdRead (void )

This function will return IXP400 product ID i.e. CP15, Register 0.

#### Returns:

♦ IxFeatureCtrlProductId – the value of product ID.

#### **IxFeatureCtrlReg** ixFeatureCtrlRead (void )

This function reads out the CURRENT value of Feature Control Register. The current value may not be the same as that of the hardware component availability.

The bit location of each hardware component is defined above. A value of '1' in bit means the hardware component is not available. A value of '0' means the hardware component is available.

#### Returns:

♦ IxFeatureCtrlReg – the current value of IXP400 Feature Control Register

#### IxFeatureCtrlBuildDevice ixFeatureCtrlSoftwareBuildGet (void )

This function refers to the value set by the compiler flag to determine the type of device the software is built for.

The function reads the compiler flag to determine the device the software is built for. When the user executes build in the command line, a compile time flag (\_\_ixp42X/\_\_ixp46X is set. This API reads this flag and returns the software build type to the calling client.

#### Returns:

♦ IxFeatureCtrlBuildDevice – the type of device software is built for.

#### IX\_STATUS ixFeatureCtrlSwConfigurationCheck ( **IxFeatureCtrlSwConfig** swConfigType )

This function checks whether the specified software configuration is enabled or disabled.

Usage Example:

- if(IX\_FEATURE\_CTRL\_SWCONFIG\_DISABLED != ixFeatureCtrlSwConfigurationCheck(IX\_FEATURECTRL\_ETH\_LEARNING))
- if(IX\_FEATURE\_CTRL\_SWCONFIG\_ENABLED == ixFeatureCtrlSwConfigurationCheck(IX\_FEATURECTRL\_ETH\_LEARNING))

This function is typically called during access component initialization time.

#### Parameters:

swConfigType Intel (R) IXP400 Software Configuration for Access Component [in] – the type of a software configuration defined in IxFeatureCtrlSwConfig enumeration.

#### Returns:

♦ IX\_FEATURE\_CTRL\_SWCONFIG\_ENABLED if software configuration is enabled. ♦ IX\_FEATURE\_CTRL\_SWCONFIG\_DISABLED if software configuration is disabled.

```
void ixFeatureCtrlSwConfigurationWrite ( IxFeatureCtrlSwConfig swConfigType, BOOL enabled )
```

This function enable/disable the specified software configuration.

#### Usage Example:

- ixFeatureCtrlSwConfigurationWrite(IX\_FEATURECTRL\_ETH\_LEARNING, TRUE) is used to enable Ethernet Learning Feature
- ixFeatureCtrlSwConfigurationWrite(IX\_FEATURECTRL\_ETH\_LEARNING, FALSE) is used to disable Ethernet Learning Feature

#### Parameters:

swConfigType IxFeatureCtrlSwConfig [in] - the type of a software configuration defined in

IxFeatureCtrlSwConfig enumeration.

enabled BOOL [in] – To enable(TRUE) / disable (FALSE) the specified software

configuration.

#### Returns:

none

#### void ixFeatureCtrlWrite ( **IxFeatureCtrlReg** expUnitReg )

This function write the value stored in IxFeatureCtrlReg expUnitReg to the Feature Control Register.

The bit location of each hardware component is defined above. The write is only effective on available hardware components. Writing '1' in a bit will software disable the respective hardware component. A '0' will mean that the hardware component will remain to be operable.

#### Parameters:

expUnitReg IxFeatureCtrlReg [in] – The value to be written to feature control register.

#### Returns:

none

# Intel (R) IXP400 Software Configuration for Access Component

[Intel (R) IXP400 Software Feature Control (IxFeatureCtrl) API]

This section describes software configuration in access component. The configuration can be changed at run—time. **ixFeatureCtrlSwConfigurationCheck()** will be used across applicable access component to check the configuration. **ixFeatureCtrlSwConfigurationWrite()** is used to write the software configuration.

### **Defines**

#define **IX\_FEATURE\_CTRL\_SWCONFIG\_DISABLED**Software configuration is disabled.

#define **IX\_FEATURE\_CTRL\_SWCONFIG\_ENABLED**Software configuration is enabled.

# **Enumerations**

```
enum IxFeatureCtrlBuildDevice {
     IX_FEATURE_CTRL_SW_BUILD_IXP42X,
     IX_FEATURE_CTRL_SW_BUILD_IXP46X
    Indicates software build type.
enum IxFeatureCtrlSwConfig {
     IX_FEATURECTRL_ETH_LEARNING,
     IX_FEATURECTRL_ORIGBO_DISPATCHER,
     IX_FEATURECTRL_SWCONFIG_MAX
    Enumeration for software configuration in access components.
enum IxFeatureCtrlComponentType {
     IX_FEATURECTRL_RCOMP,
     IX_FEATURECTRL_USB,
     IX_FEATURECTRL_HASH,
     IX_FEATURECTRL_AES,
     IX_FEATURECTRL_DES,
     IX_FEATURECTRL_HDLC,
     IX_FEATURECTRL_AAL,
     IX_FEATURECTRL_HSS,
     IX_FEATURECTRL_UTOPIA,
     IX_FEATURECTRL_ETH0,
     IX_FEATURECTRL_ETH1,
     IX_FEATURECTRL_NPEA,
     IX_FEATURECTRL_NPEB,
```

```
IX_FEATURECTRL_NPEC,
     IX FEATURECTRL PCI.
     IX FEATURECTRL ECC TIMESYNC,
     IX FEATURECTRL UTOPIA PHY LIMIT,
     IX FEATURECTRL UTOPIA PHY LIMIT BIT2,
     IX_FEATURECTRL_USB_HOST_CONTROLLER,
     IX FEATURECTRL NPEA ETH,
     IX_FEATURECTRL_NPEB_ETH,
     IX FEATURECTRL RSA,
     IX_FEATURECTRL_XSCALE_MAX_FREQ,
     IX_FEATURECTRL_XSCALE_MAX_FREQ_BIT2,
     IX_FEATURECTRL_MAX_COMPONENTS
    Enumeration for components available.
enum IxFeatureCtrlDeviceId {
     IX_FEATURE_CTRL_DEVICE_TYPE_IXP42X,
     IX FEATURE CTRL DEVICE TYPE IXP46X,
     IX FEATURE CTRL DEVICE TYPE MAX
    Enumeration for device type.
```

# **Detailed Description**

This section describes software configuration in access component. The configuration can be changed at run—time. **ixFeatureCtrlSwConfigurationCheck()** will be used across applicable access component to check the configuration. **ixFeatureCtrlSwConfigurationWrite()** is used to write the software configuration.

Note:

All software configurations are default to be enabled.

# **Define Documentation**

```
#define IX_FEATURE_CTRL_SWCONFIG_DISABLED
```

Software configuration is disabled.

Definition at line **304** of file **IxFeatureCtrl.h**.

```
#define IX_FEATURE_CTRL_SWCONFIG_ENABLED
```

Software configuration is enabled.

Definition at line 314 of file IxFeatureCtrl.h.

# **Enumeration Type Documentation**

#### enum IxFeatureCtrlBuildDevice

Indicates software build type.

Default build type is IXP42X

#### **Enumeration values:**

Definition at line **330** of file **IxFeatureCtrl.h**.

#### enum IxFeatureCtrlComponentType

Enumeration for components available.

#### **Enumeration values:**

IX FEATURECTRL RCOMP bit location for RComp Circuitry IX\_FEATURECTRL\_USB bit location for USB Controller IX\_FEATURECTRL\_HASH bit location for Hashing Coprocessor bit location for AES Coprocessor IX\_FEATURECTRL\_AES bit location for DES Coprocessor IX\_FEATURECTRL\_DES IX\_FEATURECTRL\_HDLC bit location for HDLC Coprocessor bit location for AAL Coprocessor IX FEATURECTRL AAL IX\_FEATURECTRL\_HSS bit location for HSS Coprocessor bit location for UTOPIA Coprocessor IX FEATURECTRL UTOPIA bit location for Ethernet 0 Coprocessor IX\_FEATURECTRL\_ETH0 IX\_FEATURECTRL\_ETH1 bit location for Ethernet 1 Coprocessor IX\_FEATURECTRL\_NPEA bit location for NPE A bit location for NPE B IX FEATURECTRL NPEB  $IX\_FEATURECTRL\_NPEC$ bit location for NPE C  $IX\_FEATURECTRL\_PCI$ bit location for PCI Controller IX\_FEATURECTRL\_ECC\_TIMESYNC bit location for TimeSync Coprocessor  $IX\_FEATURECTRL\_UTOPIA\_PHY\_LIMIT$ bit location for Utopia PHY Limit Status IX\_FEATURECTRL\_UTOPIA\_PHY\_LIMIT\_BIT2 2nd bit of PHY limit status IX\_FEATURECTRL\_USB\_HOST\_CONTROLLER bit location for USB host controller bit location for NPE-A Ethernet IX FEATURECTRL NPEA ETH Disable IX FEATURECTRL NPEB ETH bit location for NPE-B Ethernet 1-3 Coprocessors Disable

IX\_FEATURECTRL\_RSA bit location for RSA Crypto block

Coprocessors Disable

IX\_FEATURECTRL\_XSCALE\_MAX\_FREQ bit location for Intel XScale(R) Core

max frequency

IX\_FEATURECTRL\_XSCALE\_MAX\_FREQ\_BIT2 2nd xscale max freq bit NOT TO BE

**USED** 

Definition at line **414** of file **IxFeatureCtrl.h**.

#### enum IxFeatureCtrlDeviceId

Enumeration for device type.

#### Warning:

This enum is closely related to the npe image. Its format should comply with formats used in the npe image ImageID. This is indicated by the first nibble of the image ID. This should also be in sync with the with what is defined in CP15. Current available formats are

♦ IXP42X - 0000♦ IXP46X - 0001

# Enumeration values:

IX\_FEATURE\_CTRL\_DEVICE\_TYPE\_IXP42X Device type is IXP42X. IX\_FEATURE\_CTRL\_DEVICE\_TYPE\_IXP46X Device type is IXP46X. IX FEATURE CTRL DEVICE TYPE MAX Max devices.

Definition at line 458 of file IxFeatureCtrl.h.

#### enum IxFeatureCtrlSwConfig

Enumeration for software configuration in access components.

Entry for new run–time software configuration should be added here.

#### Enumeration values:

IX\_FEATURECTRL\_ETH\_LEARNING EthDB Learning Feature.

IX FEATURECTRL ORIGBO DISPATCHER IXP42X B0 Silicon and IXP46X processor

dispatcher without livelock prevention functionality

Feature.

IX\_FEATURECTRL\_SWCONFIG\_MAX Maximum boudary for IxFeatureCtrlSwConfig.

Definition at line **345** of file **IxFeatureCtrl.h**.

# Intel (R) IXP400 Software HSS Access (IxHssAcc) API

The public API for the IXP400 HssAccess component.

## **Data Structures**

#### struct IxHssAccConfigParams

Structure containing HSS configuration parameters.

#### struct IxHssAccHdlcMode

This structure contains 56Kbps, HDLC-mode configuration parameters.

#### struct IxHssAccPktHdlcFraming

This structure contains information required by the NPE to configure the HDLC co-processor.

#### struct IxHssAccPortConfig

Structure containing HSS port configuration parameters.

# **Defines**

#### #define IX\_HSSACC\_TSLOTS\_PER\_HSS\_PORT

The max number of TDM timeslots supported per HSS port -4E1's = 32x4 = 128.

#### #define IX HSSACC CHAN TSLOTSWITCH NUM GCT ENTRY MAX

The max number of entries supported per gain control table for a timeslot switching voice channel.

#### #define IX\_HSSACC\_CHAN\_TSLOTSWITCH\_NUM\_CHAN\_MIN

The minimum number of TDM timeslots that must be setup as channelised timeslots before timeslot switching service can be enabled. This is to maximize NPE resource utilization in order to guarantee high voice quality and minimum latency. Client can choose to ignore the unwanted channelised timeslots.

#### #define IX HSSACC CHAN TSLOTSWITCH NUM BYPASS MAX

The max number of timeslot switching (bypass) channels supported per HSS port at any one time. In current release, only HSS port 0 supports this feature.

#### #define IX\_HSSACC\_CHAN\_TSLOTSWITCH\_NUM\_HSS\_PORT\_MAX

The max number of HSS ports that support timeslot switching (bypass) feature. In current release, only HSS port 0 supports this feature.

#### #define IX\_HSSACC\_PARAM\_ERR

HssAccess function return value for a parameter error.

#### #define IX HSSACC RESOURCE ERR

HssAccess function return value for a resource error.

#### #define IX HSSACC PKT DISCONNECTING

Indicates that a disconnect call is progressing and will disconnect soon.

#### #define IX HSSACC Q WRITE OVERFLOW

Indicates that an attempt to Tx or to replenish an RxFree Q failed due to Q overflow.

#### #define IX\_HSSACC\_NO\_ERROR

HSS port no error present.

#### #define IX HSSACC TX FRM SYNC ERR

HSS port TX Frame Sync error.

#### #define IX\_HSSACC\_TX\_OVER\_RUN\_ERR

HSS port TX over-run error.

#### #define IX\_HSSACC\_CHANNELISED\_SW\_TX\_ERR

NPE software error in channelised TX.

#### #define IX\_HSSACC\_PACKETISED\_SW\_TX\_ERR

NPE software error in packetised TX.

#### #define IX\_HSSACC\_RX\_FRM\_SYNC\_ERR

HSS port RX Frame Sync error.

#### #define IX HSSACC RX OVER RUN ERR

HSS port RX over-run error.

#### #define IX HSSACC CHANNELISED SW RX ERR

NPE software error in channelised RX.

#### #define IX HSSACC PACKETISED SW RX ERR

NPE software error in packetised TX.

#### #define IX\_HSSACC\_PKT\_MIN\_RX\_MBUF\_SIZE

Minimum size of the Rx mbuf in bytes which the client must supply to the component.

# **Typedefs**

typedef

#### UINT32 IxHssAccPktUserId

The client supplied value which will be supplied as a parameter with a given callback.

typedef

#### void(\* IxHssAccLastErrorCallback )(unsigned lastHssError, unsigned servicePort)

*Prototype of the clients function to accept notification of the last error.* 

Typedefs 280

```
typedefIxHssAccPktRxCallback)(IX_OSAL_MBUF *buffer, unsigned numHssErrs,
      void(* IxHssAccPktStatus pktStatus, IxHssAccPktUserId rxUserId)
            Prototype of the clients function to accept notification of packetised rx.
      typedef
      void(* IxHssAccPktRxFreeLowCallback )(IxHssAccPktUserId rxFreeLowUserId)
            Prototype of the clients function to accept notification of requirement of more Rx Free buffers.
      typedefIxHssAccPktTxDoneCallback )(IX OSAL MBUF *buffer, unsigned numHssErrs,
      void(* IxHssAccPktStatus pktStatus, IxHssAccPktUserId txDoneUserId)
            Prototype of the clients function to accept notification of completion with Tx buffers.
      typedefIxHssAccChanRxCallback)(IxHssAccHssPort hssPortId, unsigned rxOffset, unsigned
      void(* txOffset, unsigned numHssErrs)
            Prototype of the clients function to accept notification of channelised rx.
Enumerations
      enum IxHssAccHssPort {
             IX_HSSACC_HSS_PORT_0,
             IX_HSSACC_HSS_PORT_1,
             IX_HSSACC_HSS_PORT_MAX
            The HSS port ID – There are two identical ports (0-1).
      enum IxHssAccHdlcPort {
             IX_HSSACC_HDLC_PORT_0,
             IX_HSSACC_HDLC_PORT_1,
             IX_HSSACC_HDLC_PORT_2,
             IX HSSACC HDLC PORT 3.
             IX_HSSACC_HDLC_PORT_MAX
            The HDLC port ID – There are four identical HDLC ports (0-3) per HSS port and they
            correspond to the 4 E1/T1 trunks.
      enum IxHssAccTdmSlotUsage {
             IX_HSSACC_TDMMAP_UNASSIGNED,
             IX_HSSACC_TDMMAP_HDLC,
             IX_HSSACC_TDMMAP_VOICE56K,
             IX_HSSACC_TDMMAP_VOICE64K,
             IX_HSSACC_TDMMAP_MAX
            The HSS TDM stream timeslot assignment types.
      enum IxHssAccFrmSyncType {
             IX_HSSACC_FRM_SYNC_ACTIVE_LOW,
```

Enumerations 281

IX\_HSSACC\_FRM\_SYNC\_ACTIVE\_HIGH, IX\_HSSACC\_FRM\_SYNC\_FALLINGEDGE, IX\_HSSACC\_FRM\_SYNC\_RISINGEDGE,

```
IX_HSSACC_FRM_SYNC_TYPE_MAX
     The HSS frame sync pulse type.
enum IxHssAccFrmSvncEnable {
     IX_HSSACC_FRM_SYNC_INPUT,
     IX_HSSACC_FRM_SYNC_INVALID_VALUE,
     IX_HSSACC_FRM_SYNC_OUTPUT_FALLING,
     IX HSSACC FRM SYNC OUTPUT RISING,
     IX_HSSACC_FRM_SYNC_ENABLE_MAX
     The IxHssAccFrmSyncEnable determines how the frame sync pulse is used.
enum IxHssAccClkEdge {
     IX_HSSACC_CLK_EDGE_FALLING,
     IX_HSSACC_CLK_EDGE_RISING,
     IX_HSSACC_CLK_EDGE_MAX
     IxHssAccClkEdge is used to determine the clk edge to use for framing and data.
enum IxHssAccClkDir {
     IX_HSSACC_SYNC_CLK_DIR_INPUT,
     IX HSSACC SYNC CLK DIR OUTPUT,
     IX HSSACC SYNC CLK DIR MAX
     The HSS clock direction.
enum IxHssAccFrmPulseUsage {
     IX HSSACC FRM PULSE ENABLED,
     IX_HSSACC_FRM_PULSE_DISABLED,
     IX_HSSACC_FRM_PULSE_MAX
     The HSS frame pulse usage.
enum IxHssAccDataRate {
     IX_HSSACC_CLK_RATE,
     IX HSSACC HALF CLK RATE,
     IX_HSSACC_DATA_RATE_MAX
     The HSS Data rate in relation to the clock.
enum IxHssAccDataPolarity {
     IX_HSSACC_DATA_POLARITY_SAME,
     IX_HSSACC_DATA_POLARITY_INVERT,
     IX_HSSACC_DATA_POLARITY_MAX
     The HSS data polarity type.
enum IxHssAccBitEndian {
     IX_HSSACC_LSB_ENDIAN,
     IX_HSSACC_MSB_ENDIAN,
```

Enumerations 282

```
IX_HSSACC_ENDIAN_MAX
     HSS Data endianness.
enum IxHssAccDrainMode {
      IX_HSSACC_TX_PINS_NORMAL,
      IX_HSSACC_TX_PINS_OPEN_DRAIN,
      IX_HSSACC_TX_PINS_MAX
     Tx pin open drain mode.
enum IxHssAccSOFType {
      IX_HSSACC_SOF_FBIT,
      IX_HSSACC_SOF_DATA,
      IX_HSSACC_SOF_MAX
     HSS start of frame types.
enum IxHssAccDataEnable {
      IX_HSSACC_DE_TRI_STATE,
      IX_HSSACC_DE_DATA,
      IX_HSSACC_DE_MAX
     IxHssAccDataEnable is used to determine whether or not to drive the data pins.
enum IxHssAccTxSigType {
      IX_HSSACC_TXSIG_LOW,
      IX_HSSACC_TXSIG_HIGH,
      IX_HSSACC_TXSIG_HIGH_IMP,
      IX_HSSACC_TXSIG_MAX
     IxHssAccTxSigType is used to determine how to drive the data pins.
enum IxHssAccFbType {
      IX_HSSACC_FB_FIFO,
      IX_HSSACC_FB_HIGH_IMP,
      IX_HSSACC_FB_MAX
     IxHssAccFbType determines how to drive the Fbit.
enum IxHssAcc56kEndianness {
      IX_HSSACC_56KE_BIT_7_UNUSED,
      IX_HSSACC_56KE_BIT_0_UNUSED,
      IX HSSACC 56KE MAX
     56k data endianness when using the 56k type
enum IxHssAcc56kSel {
      IX HSSACC 56KS 32 8 DATA,
      IX_HSSACC_56KS_56K_DATA,
      IX_HSSACC_56KS_MAX
```

Enumerations 283

```
56k data transmission type when using the 56k type
enum IxHssAccClkSpeed {
     IX HSSACC CLK SPEED 512KHZ.
     IX HSSACC CLK SPEED 1536KHZ,
     IX HSSACC CLK SPEED 1544KHZ,
     IX_HSSACC_CLK_SPEED_2048KHZ,
     IX HSSACC CLK SPEED 4096KHZ,
     IX_HSSACC_CLK_SPEED_8192KHZ,
     IX_HSSACC_CLK_SPEED_MAX
    IxHssAccClkSpeed represents the HSS clock speeds available.
enum IxHssAccPktStatus {
     IX HSSACC PKT OK,
     IX HSSACC STOP SHUTDOWN ERROR.
     IX_HSSACC_HDLC_ALN_ERROR,
     IX HSSACC HDLC FCS ERROR,
     IX_HSSACC_RXFREE_Q_EMPTY_ERROR,
     IX HSSACC HDLC MAX FRAME SIZE EXCEEDED,
     IX HSSACC HDLC ABORT ERROR.
     IX HSSACC DISCONNECT IN PROGRESS
    Indicates the status of packets passed to the client.
enum IxHssAccPktCrcTvpe {
     IX_HSSACC_PKT_16_BIT_CRC,
     IX HSSACC PKT 32 BIT CRC
    HDLC CRC type.
enum IxHssAccPktHdlcIdleType {
     IX HSSACC HDLC IDLE ONES,
     IX_HSSACC_HDLC_IDLE_FLAGS
    HDLC idle transmission type.
```

# **Functions**

PUBLICixHssAccPortInit (IxHssAccHssPort hssPortId, IxHssAccConfigParams \*configParams, IX\_STATUS IxHssAccTdmSlotUsage \*tdmMap, IxHssAccLastErrorCallback lastHssErrorCallback)

Initialise a HSS port. No channelised or packetised connections should exist in the HssAccess layer while this interface is being called.

#### **PUBLIC**

#### IX\_STATUS ixHssAccLastErrorRetrievalInitiate (IxHssAccHssPort hssPortId)

Initiate the retrieval of the last HSS error. The HSS port should be configured before attempting to call this interface.

#### **PUBLIC**

#### IX STATUS ixHssAccInit (void)

This function is responsible for initialising resources for use by the packetised and channelised clients. It should be called after HSS NPE image has been downloaded into NPE-A and before any other HssAccess interface is called. No other HssAccPacketised interface should be called while this interface is being processed.

#### **PUBLIC**

#### IX\_STATUS ixHssAccUninit (void)

This function is responsible for un–initialize of resources for use by the packetised and channelised clients. It internally calls the uninitialize functions of sub components. This function should be the last function to be called before exiting HssAcc component.

PUBLICixHssAccPktPortConnect (IxHssAccHssPort hssPortId, IxHssAccHdlcPort hdlcPortId, IX\_STATUS BOOL hdlcFraming, IxHssAccHdlcMode hdlcMode, BOOL hdlcBitInvert, unsigned blockSizeInWords, UINT32 rawIdleBlockPattern, IxHssAccPktHdlcFraming hdlcTxFraming, IxHssAccPktHdlcFraming hdlcRxFraming, unsigned frmFlagStart, IxHssAccPktRxCallback rxCallback, IxHssAccPktUserId rxUserId, IxHssAccPktRxFreeLowCallback rxFreeLowCallback, IxHssAccPktUserId rxFreeLowUserId, IxHssAccPktTxDoneCallback txDoneCallback, IxHssAccPktUserId txDoneUserId)

This function is responsible for connecting a client to one of the 4 available HDLC ports. The HSS port should be configured before attempting a connect. No other HssAccPacketised interface should be called while this connect is being processed.

#### **PUBLIC**

#### IX\_STATUS ixHssAccPktPortEnable (IxHssAccHssPort hssPortId, IxHssAccHdlcPort hdlcPortId)

This function is responsible for enabling a packetised service for the specified HSS/HDLC port combination. It enables the RX flow. The client must have already connected to a packetised service and is responsible for ensuring an adequate amount of RX mbufs have been supplied to the access component before enabling the packetised service. This function must be called on a given port before any call to ixHssAccPktPortTx on the same port. No other HssAccPacketised interface should be called while this interface is being processed.

#### **PUBLIC**

#### IX\_STATUS ixHssAccPktPortDisable (IxHssAccHssPort hssPortId, IxHssAccHdlcPort hdlcPortId)

This function is responsible for disabling a packetised service for the specified HSS/HDLC port combination. It disables the RX flow. The client must have already connected to and enabled a packetised service for the specified HDLC port. This disable interface can be called before a disconnect, but is not required to.

#### **PUBLIC**

#### IX\_STATUS ixHssAccPktPortDisconnect (IxHssAccHssPort hssPortId, IxHssAccHdlcPort hdlcPortId)

This function is responsible for disconnecting a client from one of the 4 available HDLC ports. It is not required that the Rx Flow has been disabled before calling this function. If the RX Flow has not been disabled, the disconnect will disable it before proceeding with the disconnect. No other HssAccPacketised interface should be called while this interface is being processed.

# PUBLICixHssAccPktPortIsDisconnectComplete (IxHssAccHssPort hssPortId, IxHssAccHdlcPort BOOL hdlcPortId)

This function is called to check if a given HSS/HDLC port combination is in a connected state or not. This function may be called at any time to determine a ports state. No other HssAccPacketised interface should be called while this interface is being processed.

# PUBLICixHssAccPktPortRxFreeReplenish (IxHssAccHssPort hssPortId, IxHssAccHdlcPort IX\_STATUS hdlcPortId, IX\_OSAL\_MBUF \*buffer)

Function which the client calls at regular intervals to provide mbufs to the access component for RX. A connection should exist for the specified hssPortId/hdlcPortId combination before attempting to call this interface. Also, the connection should not be in a disconnecting state.

# PUBLICixHssAccPktPortTx (IxHssAccHssPort hssPortId, IxHssAccHdlcPort hdlcPortId, IX\_STATUS IX\_OSAL\_MBUF \*buffer)

Function which the client calls when it wants to transmit packetised data. An enabled connection should exist on the specified hssPortId/hdlcPortId combination before attempting to call this interface. No other HssAccPacketised interface should be called while this interface is being processed.

PUBLICixHssAccChanConnect (IxHssAccHssPort hssPortId, unsigned bytesPerTSTrigger, UINT8 IX\_STATUS \*rxCircular, unsigned numRxBytesPerTS, UINT32 \*txPtrList, unsigned numTxPtrLists, unsigned numTxBytesPerBlk, IxHssAccChanRxCallback rxCallback)

This function allows the client to connect to the Tx/Rx NPE Channelised Service. There can only be one client per HSS port. The client is responsible for ensuring that the HSS port is configured appropriately before its connect request. No other HssAccChannelised interface should be called while this interface is being processed.

#### **PUBLIC**

#### IX\_STATUS ixHssAccChanPortEnable (IxHssAccHssPort hssPortId)

This function is responsible for enabling a channelised service for the specified HSS port. It enables the NPE RX flow. The client must have already connected to a channelised service before enabling the channelised service. No other HssAccChannelised interface should be called while this interface is being processed.

#### **PUBLIC**

#### IX\_STATUS ixHssAccChanPortDisable (IxHssAccHssPort hssPortId)

This function is responsible for disabling a channelised service for the specified HSS port. It disables the NPE RX flow. The client must have already connected to and enabled a channelised service for the specified HSS port. This disable interface can be called before a disconnect, but is not required to. No other HssAccChannelised interface should be called while this interface is being processed.

#### **PUBLIC**

#### IX STATUS ixHssAccChanDisconnect (IxHssAccHssPort hssPortId)

This function allows the client to Disconnect from a channelised service. If the NPE RX Flow has not been disabled, the disconnect will disable it before proceeding with other disconnect functionality. No other HssAccChannelised interface should be called while this interface is being processed.

PUBLICixHssAccChanStatusQuery (IxHssAccHssPort hssPortId, BOOL \*dataRecvd, unsigned IX\_STATUS \*rxOffset, unsigned \*txOffset, unsigned \*numHssErrs)

This function is called by the client to query whether or not channelised data has been received. If there is, hssChanAcc will return the details in the output parameters. An enabled connection should exist on the specified hssPortId before attempting to call this interface. No other HssAccChannelised interface should be called while this interface is being processed.

PUBLICixHssAccChanTslotSwitchEnable (IxHssAccHssPort hssPortId, UINT32 srcTimeslot, IX\_STATUS UINT32 destTimeslot, UINT32 \*tsSwitchHandle)

This function is responsible for enabling timeslot switching (bypass) channel between two voice channels for the specified HSS port. The voice channels must have already been configured as channelised timeslot for the specified HSS port. In current release, only up to two timeslot switching channels can be enabled at any one time. In order to minimize bypass delay and ensure better voice quality, this function requires at least 8 TDM timeslots on the specified HSS port to be setup as channelised timeslots. In timeslot switching mode, data received on srcTimeslot is transmitted onto a partner timeslot (i.e. destTimeslot) at NPE level. A copy of the received data on srcTimeslot is also sent to client via HssAccess component. No other HssAccChannelised interface should be called while this interface is being processed.

#### **PUBLIC**

IX\_STATUS ixHssAccChanTslotSwitchDisable (IxHssAccHssPort hssPortId, UINT32 tsSwitchHandle)

This function is responsible for disabling timeslot switching (bypass) channel, that is associated with tsSwitchHandle, for the specified HSS port. The bypass channel to be disabled must have already been enabled for the specified HSS port. No other HssAccChannelised interface should be called while this interface is being processed.

PUBLICixHssAccChanTslotSwitchGctDownload (IxHssAccHssPort hssPortId, UINT8 IX STATUS \*gainCtrlTable, UINT32 tsSwitchHandle)

This function is responsible for downloading a gain control table (256 bytes) to NPE for the specified timeslot switching (bypass) channel, associated with tsSwitchHandle, on the specified HSS port. The bypass voice channel must have already been enabled for the specified HSS port before this API can be called to download the gain control table to NPE. No other HssAccChannelised interface should be called while this interface is being processed.

#### PUBLIC void **ixHssAccShow** (void)

This function will display the current state of the IxHssAcc component. The output is sent to stdout.

#### PUBLIC void ixHssAccStatsInit (void)

This function will reset the IxHssAcc statistics.

# **Detailed Description**

The public API for the IXP400 HssAccess component.

IxHssAcc is the access layer to the HSS packetised and channelised services

#### **Design Notes**

• When a packet—pipe is configured for 56Kbps RAW mode, byte alignment of the transmitted data is not preserved. All raw data that is transmitted will be received in proper order by the receiver, but the first bit of the packet may be seen at any offset within a byte; all subsequent bytes will have the same offset for the duration of the packet. The same offset also applies to all subsequent packets received on the packet—pipe too. (Similar results will occur for data received from remote end.) While this behavior will also occur for 56Kbps HDLC mode, the HDLC encoding/decoding will preserve the original byte alignment at the receiver end.

#### 56Kbps Packetised Service Bandwidth Limitation

• IxHssAcc supports 56Kbps packetised service at a maximum aggregate rate for all HSS ports/HDLC channels of 12.288Mbps[1] in each direction, i.e. it supports 56Kbps packetised service on up to 8 T1 trunks. It does not support 56Kbps packetised service on 8 E1 trunks (i.e. 4 trunks per HSS port) unless those trunks are running 'fractional E1' with maximum aggregate rate of 12.288 Mbps in each direction.

[1] 12.288Mbps = 1.536Mbp \* 8 T1

## **Define Documentation**

#### #define IX\_HSSACC\_CHAN\_TSLOTSWITCH\_NUM\_BYPASS\_MAX

The max number of timeslot switching (bypass) channels supported per HSS port at any one time. In current release, only HSS port 0 supports this feature.

Definition at line **94** of file **IxHssAcc.h**.

#### #define IX\_HSSACC\_CHAN\_TSLOTSWITCH\_NUM\_CHAN\_MIN

The minimum number of TDM timeslots that must be setup as channelised timeslots before timeslot switching service can be enabled. This is to maximize NPE resource utilization in order to guarantee high voice quality and minimum latency. Client can choose to ignore the unwanted channelised timeslots.

Definition at line **85** of file **IxHssAcc.h**.

#### #define IX\_HSSACC\_CHAN\_TSLOTSWITCH\_NUM\_GCT\_ENTRY\_MAX

The max number of entries supported per gain control table for a timeslot switching voice channel.

Definition at line **74** of file **IxHssAcc.h**.

#### #define IX\_HSSACC\_CHAN\_TSLOTSWITCH\_NUM\_HSS\_PORT\_MAX

The max number of HSS ports that support timeslot switching (bypass) feature. In current release, only HSS port 0 supports this feature.

Define Documentation 288

Definition at line 102 of file IxHssAcc.h.

#### #define IX\_HSSACC\_CHANNELISED\_SW\_RX\_ERR

NPE software error in channelised RX.

Definition at line **196** of file **IxHssAcc.h**.

#### #define IX\_HSSACC\_CHANNELISED\_SW\_TX\_ERR

NPE software error in channelised TX.

Definition at line **168** of file **IxHssAcc.h**.

#### #define IX\_HSSACC\_NO\_ERROR

HSS port no error present.

Definition at line **147** of file **IxHssAcc.h**.

#### #define IX\_HSSACC\_PACKETISED\_SW\_RX\_ERR

NPE software error in packetised TX.

Definition at line 203 of file IxHssAcc.h.

#### #define IX\_HSSACC\_PACKETISED\_SW\_TX\_ERR

NPE software error in packetised TX.

Definition at line 175 of file IxHssAcc.h.

#### #define IX\_HSSACC\_PARAM\_ERR

HssAccess function return value for a parameter error.

Definition at line 114 of file IxHssAcc.h.

#### #define IX\_HSSACC\_PKT\_DISCONNECTING

Indicates that a disconnect call is progressing and will disconnect soon.

Define Documentation 289

Definition at line 129 of file IxHssAcc.h.

#### #define IX\_HSSACC\_PKT\_MIN\_RX\_MBUF\_SIZE

Minimum size of the Rx mbuf in bytes which the client must supply to the component.

Definition at line 215 of file IxHssAcc.h.

#### #define IX\_HSSACC\_Q\_WRITE\_OVERFLOW

Indicates that an attempt to Tx or to replenish an RxFree Q failed due to Q overflow.

Definition at line 137 of file IxHssAcc.h.

#### #define IX\_HSSACC\_RESOURCE\_ERR

HssAccess function return value for a resource error.

Definition at line 121 of file IxHssAcc.h.

#### #define IX\_HSSACC\_RX\_FRM\_SYNC\_ERR

HSS port RX Frame Sync error.

Definition at line 182 of file IxHssAcc.h.

#### #define IX\_HSSACC\_RX\_OVER\_RUN\_ERR

HSS port RX over-run error.

Definition at line 189 of file IxHssAcc.h.

#### #define IX\_HSSACC\_TSLOTS\_PER\_HSS\_PORT

The max number of TDM timeslots supported per HSS port -4E1's = 32x4 = 128.

Definition at line **66** of file **IxHssAcc.h**.

#### #define IX\_HSSACC\_TX\_FRM\_SYNC\_ERR

HSS port TX Frame Sync error.

Define Documentation 290

Definition at line **154** of file **IxHssAcc.h**.

#### #define IX\_HSSACC\_TX\_OVER\_RUN\_ERR

HSS port TX over–run error.

Definition at line **161** of file **IxHssAcc.h**.

# **Typedef Documentation**

#### IxHssAccChanRxCallback

Prototype of the clients function to accept notification of channelised rx.

This callback, if defined by the client in the connect, will get called in the context of an IRQ. The IRQ will be triggered when the hssSyncQMQ is not empty. The queued entry will be dequeued and this function will be executed.

#### Parameters:

hssPortId **IxHssAccHssPort** – The HSS port Id. There are two identical ports (0-1). txOffset unsigned [in] – an offset indicating from where within the txPtrList the NPE is

currently transmitting from.

rxOffset unsigned [in] – an offset indicating where within the receive buffers the NPE has just

written the received data to.

numHssErrs unsigned [in] – This is the number of hssErrors the Npe has received

#### Returns:

void

Definition at line **732** of file **IxHssAcc.h**.

#### **IxHssAccLastErrorCallback**

Prototype of the clients function to accept notification of the last error.

This function is registered through the config. The client will initiate the last error retrieval. The HssAccess component will send a message to the NPE through the NPE Message Handler. When a response to the read is received, the NPE Message Handler will callback the HssAccess component which will execute this function in the same IxNpeMh context. The client will be passed the last error and the related service port (packetised 0–3, channelised 0)

#### Parameters:

```
lastHssError unsigned [in] – The last Hss error registered that has been registered.

servicePort unsigned [in] – This is the service port number. (packetised 0–3, channelised 0)
```

#### Returns:

void

Definition at line **641** of file **IxHssAcc.h**.

#### IxHssAccPktRxCallback

Prototype of the clients function to accept notification of packetised rx.

This function is registered through the ixHssAccPktPortConnect. hssPktAcc will pass received data in the form of mbufs to the client. The mbuf passed back to the client could contain a chain of buffers, depending on the packet size received.

#### Parameters:

\*buffer [in] – This is the mbuf which contains the payload received.

numHssErrs unsigned [in] - This is the number of hssErrors the Npe has received

pktStatus [in] – This is the status of the mbuf that has been received.

ixHssAccPktPortConnect time which is now returned to the client.

#### Returns:

void

Definition at line **665** of file **IxHssAcc.h**.

#### IxHssAccPktRxFreeLowCallback

Prototype of the clients function to accept notification of requirement of more Rx Free buffers.

The client can choose to register a callback of this type when calling a connecting. This function is registered through the ixHssAccPktPortConnect. If defined, the access layer will provide the trigger for this callback. The callback will be responsible for supplying mbufs to the access layer for use on the receive path from the HSS using ixHssPktAccFreeBufReplenish.

#### Returns:

void

Definition at line **684** of file **IxHssAcc.h**.

#### IxHssAccPktTxDoneCallback

Prototype of the clients function to accept notification of completion with Tx buffers.

This function is registered through the ixHssAccPktPortConnect. It enables the hssPktAcc to pass buffers back to the client when transmission is complete.

#### Parameters:

\*buffer [in] – This is the mbuf which contained the payload that was for Tx.

numHssErrs unsigned [in] – This is the number of hssErrors the Npe has received

pktStatus [in] – This is the status of the mbuf that has been transmitted.

txDoneUserId IxHssAccPktUserId [in] – This is the client supplied value passed in at ixHssAccPktPortConnect time which is now returned to the client.

#### Returns:

void

Definition at line **706** of file **IxHssAcc.h**.

#### UINT32 IxHssAccPktUserId

The client supplied value which will be supplied as a parameter with a given callback.

This value will be passed into the ixHssAccPktPortConnect function once each with given callbacks. This value will then be passed back to the client as one of the parameters to each of these callbacks, when these callbacks are called.

Definition at line 618 of file IxHssAcc.h.

# **Enumeration Type Documentation**

#### enum IxHssAcc56kEndianness

56k data endianness when using the 56k type

#### **Enumeration values:**

IX\_HSSACC\_56KE\_BIT\_7\_UNUSED High bit is unused.
IX\_HSSACC\_56KE\_BIT\_0\_UNUSED Low bit is unused.
IX\_HSSACC\_56KE\_MAX
Delimiter for error checks.

Definition at line **437** of file **IxHssAcc.h**.

#### enum IxHssAcc56kSel

56k data transmission type when using the 56k type

#### **Enumeration values:**

IX\_HSSACC\_56KS\_32\_8\_DATA 32/8 bit data
IX\_HSSACC\_56KS\_56K\_DATA 56K data
IX\_HSSACC\_56KS\_MAX Delimiter for

error checks.

Definition at line **449** of file **IxHssAcc.h**.

#### enum IxHssAccBitEndian

HSS Data endianness.

#### **Enumeration values:**

IX\_HSSACC\_LSB\_ENDIAN TX/RX Least Significant Bit first.IX\_HSSACC\_MSB\_ENDIAN TX/RX Most Significant Bit first.IX\_HSSACC\_ENDIAN\_MAX Delimiter for the purposes of error checks.

Definition at line **360** of file **IxHssAcc.h**.

#### enum IxHssAccClkDir

The HSS clock direction.

#### **Enumeration values:**

IX\_HSSACC\_SYNC\_CLK\_DIR\_INPUT Clock is an input.
IX\_HSSACC\_SYNC\_CLK\_DIR\_OUTPUT Clock is an output.
IX\_HSSACC\_SYNC\_CLK\_DIR\_MAX Delimiter for error checks.

Definition at line 310 of file IxHssAcc.h.

#### enum IxHssAccClkEdge

IxHssAccClkEdge is used to determine the clk edge to use for framing and data.

#### **Enumeration values:**

IX\_HSSACC\_CLK\_EDGE\_FALLING Clock sampled off a falling edge.
IX\_HSSACC\_CLK\_EDGE\_RISING Clock sampled off a rising edge.
IX\_HSSACC\_CLK\_EDGE\_MAX Delimiter for error checks.

Definition at line **298** of file **IxHssAcc.h**.

#### enum IxHssAccClkSpeed

IxHssAccClkSpeed represents the HSS clock speeds available.

#### **Enumeration values:**

IX\_HSSACC\_CLK\_SPEED\_512KHZ 512KHz
IX\_HSSACC\_CLK\_SPEED\_1536KHZ 1.536MHz
IX\_HSSACC\_CLK\_SPEED\_1544KHZ 1.544MHz
IX\_HSSACC\_CLK\_SPEED\_2048KHZ 2.048MHz
IX\_HSSACC\_CLK\_SPEED\_4096KHZ 4.096MHz
IX\_HSSACC\_CLK\_SPEED\_8192KHZ 8.192MHz
IX\_HSSACC\_CLK\_SPEED\_MAX Delimiter for error checking.

Definition at line **462** of file **IxHssAcc.h**.

#### enum IxHssAccDataEnable

IxHssAccDataEnable is used to determine whether or not to drive the data pins.

#### **Enumeration values:**

IX\_HSSACC\_DE\_TRI\_STATE TRI-State the data pins.IX\_HSSACC\_DE\_DATA Push data out the data pins.IX\_HSSACC\_DE\_MAX Delimiter for error checks.

Definition at line 398 of file IxHssAcc.h.

#### enum IxHssAccDataPolarity

The HSS data polarity type.

#### Enumeration values:

IX\_HSSACC\_DATA\_POLARITY\_SAME Don't invert data between NPE and HSS FIFOs

FIFOs.

IX\_HSSACC\_DATA\_POLARITY\_INVERT Invert data between NPE and HSS

IX\_HSSACC\_DATA\_POLARITY\_MAX Delimiter for error checks.

Definition at line **346** of file **IxHssAcc.h**.

#### enum IxHssAccDataRate

The HSS Data rate in relation to the clock.

#### **Enumeration values:**

IX\_HSSACC\_CLK\_RATE Data rate is at the configured clk speed.

IX HSSACC HALF CLK RATE

Data rate is half the configured clk speed.

IX\_HSSACC\_DATA\_RATE\_MAX Delimiter for error checks.

Definition at line **334** of file **IxHssAcc.h**.

#### enum IxHssAccDrainMode

Tx pin open drain mode.

#### **Enumeration values:**

IX\_HSSACC\_TX\_PINS\_NORMAL Normal

mode.

IX\_HSSACC\_TX\_PINS\_OPEN\_DRAIN Open Drain

mode.

IX\_HSSACC\_TX\_PINS\_MAX Delimiter

for error checks.

Definition at line **373** of file **IxHssAcc.h**.

#### enum IxHssAccFbType

IxHssAccFbType determines how to drive the Fbit.

#### Warning:

This will only be used for T1 @ 1.544MHz

#### **Enumeration values:**

IX\_HSSACC\_FB\_FIFO Fbit is dictated in

FIFO.

IX\_HSSACC\_FB\_HIGH\_IMP Fbit is high

impedance.

*IX\_HSSACC\_FB\_MAX* Delimiter for

error checks.

Definition at line 425 of file IxHssAcc.h.

#### enum IxHssAccFrmPulseUsage

The HSS frame pulse usage.

#### Enumeration values:

*IX\_HSSACC\_FRM\_PULSE\_ENABLED* Generate/Receive frame pulses.

IX\_HSSACC\_FRM\_PULSE\_DISABLED Disregard frame pulses.

IX\_HSSACC\_FRM\_PULSE\_MAX Delimiter for error checks.

Definition at line 322 of file IxHssAcc.h.

#### enum IxHssAccFrmSyncEnable

The IxHssAccFrmSyncEnable determines how the frame sync pulse is used.

#### **Enumeration values:**

IX\_HSSACC\_FRM\_SYNC\_INPUT Frame sync is sampled as an input.

IX\_HSSACC\_FRM\_SYNC\_INVALID\_VALUE 1 is not used

IX\_HSSACC\_FRM\_SYNC\_OUTPUT\_FALLING Frame sync is an output generated off a falling

clock edge.

IX\_HSSACC\_FRM\_SYNC\_OUTPUT\_RISING Frame sync is an output generated off a rising

clock edge.

*IX\_HSSACC\_FRM\_SYNC\_ENABLE\_MAX* Delimiter for error checks.

Definition at line **281** of file **IxHssAcc.h**.

#### enum IxHssAccFrmSyncType

The HSS frame sync pulse type.

#### Enumeration values:

IX\_HSSACC\_FRM\_SYNC\_ACTIVE\_LOW Frame sync is

sampled low.

IX\_HSSACC\_FRM\_SYNC\_ACTIVE\_HIGH sampled high

IX\_HSSACC\_FRM\_SYNC\_FALLINGEDGE sampled on a

falling edge

IX\_HSSACC\_FRM\_SYNC\_RISINGEDGE sampled on a rising

edge

IX\_HSSACC\_FRM\_SYNC\_TYPE\_MAX Delimiter for error

checks.

Definition at line **267** of file **IxHssAcc.h**.

#### enum IxHssAccHdlcPort

The HDLC port ID – There are four identical HDLC ports (0–3) per HSS port and they correspond to the 4 E1/T1 trunks.

#### **Enumeration values:**

IX\_HSSACC\_HDLC\_PORT\_0 HDLC Port 0.IX\_HSSACC\_HDLC\_PORT\_1 HDLC Port 1.IX\_HSSACC\_HDLC\_PORT\_2 HDLC Port 2.

```
IX_HSSACC_HDLC_PORT_3 HDLC Port 3.IX_HSSACC_HDLC_PORT_MAX Delimiter for error checks.
```

Definition at line 239 of file IxHssAcc.h.

#### enum IxHssAccHssPort

The HSS port ID – There are two identical ports (0-1).

#### Enumeration values:

```
IX_HSSACC_HSS_PORT_0 HSS Port 0.IX_HSSACC_HSS_PORT_1 HSS Port 1.IX_HSSACC_HSS_PORT_MAX Delimiter for error checks.
```

Definition at line **226** of file **IxHssAcc.h**.

#### enum IxHssAccPktCrcType

HDLC CRC type.

#### **Enumeration values:**

```
IX_HSSACC_PKT_16_BIT_CRC 16 bit CRC is being used

IX_HSSACC_PKT_32_BIT_CRC 32 bit CRC is being used
```

Definition at line **502** of file **IxHssAcc.h**.

#### enum IxHssAccPktHdlcIdleType

HDLC idle transmission type.

#### **Enumeration values:**

Definition at line 513 of file IxHssAcc.h.

#### enum IxHssAccPktStatus

Indicates the status of packets passed to the client.

#### **Enumeration values:**

IX HSSACC PKT OK Error free.

IX\_HSSACC\_STOP\_SHUTDOWN\_ERROR Errored due to stop or shutdown

occurrance.

IX\_HSSACC\_HDLC\_ALN\_ERROR HDLC alignment error.

IX\_HSSACC\_HDLC\_FCS\_ERROR HDLC Frame Check Sum error.

IX\_HSSACC\_RXFREE\_Q\_EMPTY\_ERROR RxFree Q became empty while receiving

this packet.

IX\_HSSACC\_HDLC\_MAX\_FRAME\_SIZE\_EXCEEDED HDLC frame size received is greater than

max specified at connect.

IX\_HSSACC\_HDLC\_ABORT\_ERROR HDLC frame received is invalid due to an

abort sequence received.

IX\_HSSACC\_DISCONNECT\_IN\_PROGRESS Packet returned because a disconnect is in

progress.

Definition at line 478 of file IxHssAcc.h.

#### enum IxHssAccSOFType

HSS start of frame types.

#### Enumeration values:

IX\_HSSACC\_SOF\_FBIT Framing bit transmitted and expected on

rx.

IX\_HSSACC\_SOF\_DATA Framing bit not transmitted nor expected

on rx

*IX\_HSSACC\_SOF\_MAX* Delimiter for error checks.

Definition at line **385** of file **IxHssAcc.h**.

#### enum IxHssAccTdmSlotUsage

The HSS TDM stream timeslot assignment types.

#### **Enumeration values:**

*IX\_HSSACC\_TDMMAP\_UNASSIGNED* Unassigned.

IX\_HSSACC\_TDMMAP\_HDLC HDLC -

packetised.

IX\_HSSACC\_TDMMAP\_VOICE56K Voice56K -

channelised.

IX HSSACC TDMMAP VOICE64K Voice64K -

channelised.

IX HSSACC TDMMAP MAX Delimiter for

error checks.

#### enum IxHssAccTxSigType

IxHssAccTxSigType is used to determine how to drive the data pins.

#### **Enumeration values:**

IX\_HSSACC\_TXSIG\_LOW Drive the data pins low.IX\_HSSACC\_TXSIG\_HIGH Drive the data pins high.IX\_HSSACC\_TXSIG\_HIGH\_IMP Drive the data pins with high

impedance.

*IX\_HSSACC\_TXSIG\_MAX* Delimiter for error checks.

Definition at line **410** of file **IxHssAcc.h**.

## **Function Documentation**

This function allows the client to connect to the Tx/Rx NPE Channelised Service. There can only be one client per HSS port. The client is responsible for ensuring that the HSS port is configured appropriately before its connect request. No other HssAccChannelised interface should be called while this interface is being processed.

#### Parameters:

hssPortId IxHssAccHssPort [in] – The HSS port Id. There are two identical ports (0–1).

bytesPerTSTrigger unsigned [in] - The NPE will trigger the access component after

bytesPerTSTrigger have been received for all trunk timeslots. This figure is a

multiple of 8 e.g. 8 for 1ms trigger, 16 for 2ms trigger.

\*rxCircular UINT8 [in] – A pointer to memory allocated by the client to be filled by data

received. The buffer at this address is part of a pool of buffers to be accessed in a circular fashion. This address will be written to by the NPE. Therefore, it

needs to be a physical address.

numRxBytesPerTS unsigned [in] – The number of bytes allocated per timeslot within the receive

memory. This figure will depend on the latency of the system. It needs to be deep enough for data to be read by the client before the NPE re-writes over that

memory e.g. if the client samples at a rate of 40bytes per timeslot,

numRxBytesPerTS may need to be 40bytes \* 3. This would give the client 3 \*

5ms of time before received data is over-written.

Function Documentation 300

\*txPtrList UINT32 [in] – The address of an area of contiguous memory allocated by the

client to be populated with pointers to data for transmission. Each pointer list contains a pointer per active channel. The txPtrs will point to data to be transmitted by the NPE. Therefore, they must point to physical addresses.

numTxPtrLists unsigned [in] – The number of pointer lists in txPtrList. This figure is dependent

on jitter.

numTxBytesPerBlk unsigned [in] – The size of the Tx data, in bytes, that each pointer within the

PtrList points to.

rxCallback [in] – A client function pointer to be called back to

handle the actual tx/rx of channelised data. If this is not NULL, an ISR will call this function. If this pointer is NULL, it implies that the client will use a polling mechanism to detect when the tx and rx of channelised data is to occur. The

client will use hssChanAccStatus for this.

#### Returns:

♦ IX\_SUCCESS The function executed successfully

♦ IX\_FAIL The function did not execute successfully

♦ IX\_HSSACC\_PARAM\_ERR The function did not execute successfully due to a parameter error

#### IX STATUS ixHssAccChanDisconnect ( IxHssAccHssPort hssPortId )

This function allows the client to Disconnect from a channelised service. If the NPE RX Flow has not been disabled, the disconnect will disable it before proceeding with other disconnect functionality. No other HssAccChannelised interface should be called while this interface is being processed.

#### Parameters:

(0-1).

#### Returns:

♦ IX\_SUCCESS The function executed successfully

♦ IX\_FAIL The function did not execute successfully

♦ IX\_HSSACC\_PARAM\_ERR The function did not execute successfully due to a parameter error

#### IX\_STATUS ixHssAccChanPortDisable ( **IxHssAccHssPort** hssPortId )

This function is responsible for disabling a channelised service for the specified HSS port. It disables the NPE RX flow. The client must have already connected to and enabled a channelised service for the specified HSS port. This disable interface can be called before a disconnect, but is not required to. No other HssAccChannelised interface should be called while this interface is being processed.

#### Parameters:

(0-1).

#### Returns:

Function Documentation 301

- ♦ IX SUCCESS The function executed successfully
- ♦ IX\_FAIL The function did not execute successfully
- ♦ IX\_HSSACC\_PARAM\_ERR The function did not execute successfully due to a parameter error

## IX\_STATUS ixHssAccChanPortEnable ( **IxHssAccHssPort** hssPortId )

This function is responsible for enabling a channelised service for the specified HSS port. It enables the NPE RX flow. The client must have already connected to a channelised service before enabling the channelised service. No other HssAccChannelised interface should be called while this interface is being processed.

#### Parameters:

hssPortId **IxHssAccHssPort** [in] – The HSS port Id. There are two identical ports (0-1).

#### Returns:

- ♦ IX\_SUCCESS The function executed successfully
- ♦ IX\_FAIL The function did not execute successfully
- ♦ IX\_HSSACC\_PARAM\_ERR The function did not execute successfully due to a parameter error

```
IX_STATUS ixHssAccChanStatusQuery(IxHssAccHssPort hssPortId,
BOOL* dataRecvd,
unsigned * rxOffset,
unsigned * txOffset,
unsigned * numHssErrs
)
```

This function is called by the client to query whether or not channelised data has been received. If there is, hssChanAcc will return the details in the output parameters. An enabled connection should exist on the specified hssPortId before attempting to call this interface. No other HssAccChannelised interface should be called while this interface is being processed.

#### Parameters:

\*rxOffset | IxHssAccHssPort [in] - The HSS port Id. There are two identical ports (0–1).

\*dataRecvd | BOOL [out] - This BOOL indicates to the client whether or not the access component has read any data for the client. If FALSE, the other output parameters will not have been written to.

\*rxOffset | unsigned [out] - An offset to indicate to the client where within the receive buffers the NPE has just written the received data to.

\*txOffset | unsigned [out] - An offset to indicate to the client from where within the txPtrList the NPE is currently transmitting from

\*numHssErrs unsigned [out] – The total number of HSS port errors since initial port configuration

#### Returns:

- ♦ IX\_SUCCESS The function executed successfully ♦ IX\_FAIL The function did not execute successfully
- -

♦ IX\_HSSACC\_PARAM\_ERR The function did not execute successfully due to a parameter error

```
IX_STATUS ixHssAccChanTslotSwitchDisable ( IxHssAccHssPort hssPortId, UINT32 tsSwitchHandle )
```

This function is responsible for disabling timeslot switching (bypass) channel, that is associated with tsSwitchHandle, for the specified HSS port. The bypass channel to be disabled must have already been enabled for the specified HSS port. No other HssAccChannelised interface should be called while this interface is being processed.

#### Parameters:

*IxHssAccHssPort* hssPortId (in) – The HSS port Id. There are two identical ports (0–1). Only port 0 will be supported.

UINT32 tsSwitchHandle (in) – The handle that hooks to the bypass channel. This handle

is the parameter returned to client by ixHssAccChanTslotSwitchEnable during

timeslot switching channel enabling operation.

#### Returns:

- ♦ IX\_SUCCESS The function executed successfully
- ♦ IX FAIL The function did not execute successfully
- ♦ IX\_HSSACC\_PARAM\_ERR The function did not execute successfully due to a parameter error

```
IX_STATUS ixHssAccChanTslotSwitchEnable ( IxHssAccHssPort hssPortId, UINT32 srcTimeslot, UINT32 destTimeslot, UINT32 * tsSwitchHandle )
```

This function is responsible for enabling timeslot switching (bypass) channel between two voice channels for the specified HSS port. The voice channels must have already been configured as channelised timeslot for the specified HSS port. In current release, only up to two timeslot switching channels can be enabled at any one time. In order to minimize bypass delay and ensure better voice quality, this function requires at least 8 TDM timeslots on the specified HSS port to be setup as channelised timeslots. In timeslot switching mode, data received on srcTimeslot is transmitted onto a partner timeslot (i.e. destTimeslot) at NPE level. A copy of the received data on srcTimeslot is also sent to client via HssAccess component. No other HssAccChannelised interface should be called while this interface is being processed.

#### Parameters:

IxHssAccHssPort hssPortId (in) – The HSS port Id. There are two identical ports (0–1). Only port 0

will be supported.

UINT32 srcTimeslot (in) – The voice channel Id whose its receive side will be used in the

bypass (0-127).

UINT32 destTimeslot (in) – The voice channel Id whose its transmit side will be used in

the bypass (0-127).

UINT32

\*tsSwitchHandle (out) – The handle returned to client, that hooks to the bypass channel established between srcTimeslot and destTimeslot. This handle will be the mean by which client disables or downloads gain control table to NPE for the bypass channel that associates with this handle. Client must ignore the value returned through this handle if bypass channel fails to setup.

#### Returns:

- ♦ IX SUCCESS The function executed successfully
- ♦ IX\_FAIL The function did not execute successfully
- ♦ IX\_HSSACC\_PARAM\_ERR The function did not execute successfully due to a parameter error

```
IX_STATUS ixHssAccChanTslotSwitchGctDownload ( IxHssAccHssPort hssPortId, UINT8 * gainCtrlTable, UINT32 tsSwitchHandle )
```

This function is responsible for downloading a gain control table (256 bytes) to NPE for the specified timeslot switching (bypass) channel, associated with tsSwitchHandle, on the specified HSS port. The bypass voice channel must have already been enabled for the specified HSS port before this API can be called to download the gain control table to NPE. No other HssAccChannelised interface should be called while this interface is being processed.

#### Parameters:

IxHssAccHssPort hssPortId (in) – The HSS port Id. There are two identical ports (0–1). Only port 0

will be supported.

*UINT8* \*gainCtrlTable (in) – A pointer to an array of size

IX\_HSSACC\_ENTRIES\_PER\_GAIN\_CTRL\_TABLE, defining each entry for a

gain control table for the specified bypass voice channel.

UINT32 tsSwitchHandle (in) – The handle that hooks to the bypass channel. This handle

is the parameter returned to client by ixHssAccChanTslotSwitchEnable during

timeslot switching channel enabling operation.

## Returns:

- ♦ IX\_SUCCESS The function executed successfully
- ♦ IX FAIL The function did not execute successfully
- ♦ IX\_HSSACC\_PARAM\_ERR The function did not execute successfully due to a parameter error

# IX\_STATUS ixHssAccInit (void )

This function is responsible for initialising resources for use by the packetised and channelised clients. It should be called after HSS NPE image has been downloaded into NPE-A and before any other HssAccess interface is called. No other HssAccPacketised interface should be called while this interface is being processed.

#### Returns:

♦ IX\_SUCCESS The function executed successfully

- ♦ IX\_FAIL The function did not execute successfully
- ♦ IX\_HSSACC\_RESOURCE\_ERR The function did not execute successfully due to a resource error

# IX\_STATUS ixHssAccLastErrorRetrievalInitiate ( **IxHssAccHssPort** hssPortId )

Initiate the retrieval of the last HSS error. The HSS port should be configured before attempting to call this interface.

#### Parameters:

hssPortId IxHssAccHssPort [in] - the HSS port ID

#### Returns:

- ♦ IX SUCCESS The function executed successfully
- ♦ IX\_FAIL The function did not execute successfully
- ♦ IX\_HSSACC\_PARAM\_ERR The function did not execute successfully due to a parameter error

| ixHssAccPktPortConnect ( | IxHssAccHssPort              | hssPortId,           |
|--------------------------|------------------------------|----------------------|
|                          | IxHssAccHdlcPort             | hdlcPortId,          |
|                          | BOOL                         | hdlcFraming,         |
|                          | IxHssAccHdlcMode             | hdlcMode,            |
|                          | BOOL                         | hdlcBitInvert,       |
|                          | unsigned                     | blockSizeInWords,    |
|                          | UINT32                       | rawIdleBlockPattern, |
|                          | IxHssAccPktHdlcFraming       | hdlcTxFraming,       |
|                          | IxHssAccPktHdlcFraming       | hdlcRxFraming,       |
|                          | unsigned                     | frmFlagStart,        |
|                          | IxHssAccPktRxCallback        | rxCallback,          |
|                          | IxHssAccPktUserId            | rxUserId,            |
|                          | IxHssAccPktRxFreeLowCallback | rxFreeLowCallback,   |
|                          | <b>IxHssAccPktUserId</b>     | rxFreeLowUserId,     |
|                          | IxHssAccPktTxDoneCallback    | txDoneCallback,      |
|                          | IxHssAccPktUserId            | txDoneUserId         |
| )                        |                              |                      |

This function is responsible for connecting a client to one of the 4 available HDLC ports. The HSS port should be configured before attempting a connect. No other HssAccPacketised interface should be called while this connect is being processed.

#### Parameters:

hssPortId IxHssAccHssPort [in] – The HSS port Id. There are two identical ports

(0-1).

hdlcPortId IxHssAccHdlcPort [in] – This is the number of the HDLC port and it

corresponds to the physical E1/T1 trunk i.e. 0, 1, 2, 3

hdlcFraming BOOL [in] – This value determines whether the service will use HDLC data

or the debug, raw data type i.e. no HDLC processing

hdlcMode

**IxHssAccHdlcMode** [in] – This structure contains 56Kbps, HDLC–mode

configuration parameters

hdlcBitInvert BOOL [in] – This value determines whether bit inversion will occur between

HDLC and HSS co-processors i.e. post-HDLC processing for transmit and pre-HDLC processing for receive, for the specified HDLC Termination Point

blockSizeInWords unsigned [in] – The max tx/rx block size rawIdleBlockPattern UINT32 [in] – Tx idle pattern in raw mode

hdlcTxFraming [in] – This structure contains the following

information required by the NPE to configure the HDLC co-processor for TX

hdlcRxFraming [in] – This structure contains the following

information required by the NPE to configure the HDLC co-processor for RX

frmFlagStart unsigned – Number of flags to precede to transmitted flags (0–2).

an argument to the supplied rxCallback

rxFreeLowCallback IxHssAccPktRxFreeLowCallback [in] – Pointer to the clients Rx free buffer

request function. If NULL, assume client will trigger independently.

passed back as an argument to the supplied rxFreeLowCallback

function

back as an argument to the supplied txDoneCallback

#### Returns:

- ♦ IX\_SUCCESS The function executed successfully
- ♦ IX\_FAIL The function did not execute successfully
- ♦ IX\_HSSACC\_PARAM\_ERR The function did not execute successfully due to a parameter error
- ♦ IX\_HSSACC\_RESOURCE\_ERR The function did not execute successfully due to a resource error

```
IX_STATUS ixHssAccPktPortDisable ( IxHssAccHssPort hssPortId, 
 IxHssAccHdlcPort hdlcPortId
```

This function is responsible for disabling a packetised service for the specified HSS/HDLC port combination. It disables the RX flow. The client must have already connected to and enabled a packetised service for the specified HDLC port. This disable interface can be called before a disconnect, but is not required to.

#### Parameters:

hssPortId IxHssAccHssPort [in] – The HSS port Id. There are two identical ports (0–1). hdlcPortId IxHssAccHdlcPort [in] – The port id (0,1,2,3) to disable the service on.

## Returns:

- ♦ IX\_SUCCESS The function executed successfully
- ♦ IX\_FAIL The function did not execute successfully

♦ IX\_HSSACC\_PARAM\_ERR The function did not execute successfully due to a parameter error

This function is responsible for disconnecting a client from one of the 4 available HDLC ports. It is not required that the Rx Flow has been disabled before calling this function. If the RX Flow has not been disabled, the disconnect will disable it before proceeding with the disconnect. No other HssAccPacketised interface should be called while this interface is being processed.

#### Parameters:

hssPortId IxHssAccHssPort [in] – The HSS port Id. There are two identical ports

(0-1).

and it corresponds to the physical E1/T1 trunk i.e. 0, 1, 2, 3

#### Returns:

- ♦ IX\_SUCCESS The function executed successfully
- ♦ IX\_FAIL The function did not execute successfully
- ♦ IX\_HSSACC\_PKT\_DISCONNECTING The function has initiated the disconnecting procedure but it has not completed yet.

```
IX_STATUS ixHssAccPktPortEnable ( IxHssAccHssPort hssPortId, IxHssAccHdlcPort hdlcPortId )
```

This function is responsible for enabling a packetised service for the specified HSS/HDLC port combination. It enables the RX flow. The client must have already connected to a packetised service and is responsible for ensuring an adequate amount of RX mbufs have been supplied to the access component before enabling the packetised service. This function must be called on a given port before any call to ixHssAccPktPortTx on the same port. No other HssAccPacketised interface should be called while this interface is being processed.

#### Parameters:

hssPortId **IxHssAccHssPort** [in] – The HSS port Id. There are two identical ports (0–1). hdlcPortId **IxHssAccHdlcPort** [in] – The port id (0,1,2,3) to enable the service on.

#### Returns:

- ♦ IX\_SUCCESS The function executed successfully
- ♦ IX FAIL The function did not execute successfully
- ♦ IX\_HSSACC\_PARAM\_ERR The function did not execute successfully due to a parameter error

This function is called to check if a given HSS/HDLC port combination is in a connected state or not. This function may be called at any time to determine a ports state. No other HssAccPacketised interface should be called while this interface is being processed.

#### Parameters:

hssPortId **IxHssAccHssPort** [in] – The HSS port Id. There are two identical ports (0–1). hdlcPortId **IxHssAccHdlcPort** [in] – This is the number of the HDLC port to disconnect and it corresponds to the physical E1/T1 trunk i.e. 0, 1, 2, 3

#### Returns:

- ♦ TRUE The state of this HSS/HDLC port combination is disconnected, so if a disconnect was called, it is now completed.
- ♦ FALSE The state of this HSS/HDLC port combination is connected, so if a disconnect was called, it is not yet completed.

Function which the client calls at regular intervals to provide mbufs to the access component for RX. A connection should exist for the specified hssPortId/hdlcPortId combination before attempting to call this interface. Also, the connection should not be in a disconnecting state.

#### Parameters:

```
    hssPortId IxHssAccHssPort [in] – The HSS port Id. There are two identical ports (0–1).
    hdlcPortId IxHssAccHdlcPort [in] – This is the number of the HDLC port and it corresponds to the physical E1/T1 trunk i.e. 0, 1, 2, 3
    *buffer [in] – A pointer to a free mbuf to filled with payload.
```

# Returns:

- ♦ IX SUCCESS The function executed successfully
- ♦ IX\_FAIL The function did not execute successfully
- ♦ IX\_HSSACC\_PARAM\_ERR The function did not execute successfully due to a parameter error
- ♦ IX\_HSSACC\_RESOURCE\_ERR The function did not execute successfully due to a resource error
- ♦ IX\_HSSACC\_Q\_WRITE\_OVERFLOW The function did not succeed due to a Q overflow

Function which the client calls when it wants to transmit packetised data. An enabled connection should exist on the specified hssPortId/hdlcPortId combination before attempting to call this interface. No other HssAccPacketised interface should be called while this interface is being processed.

#### Parameters:

hssPortId **IxHssAccHssPort** [in] – The HSS port Id. There are two identical ports (0–1).

hdlcPortId IxHssAccHdlcPort [in] - This is the number of the HDLC port and it corresponds to

the physical E1/T1 trunk i.e. 0, 1, 2, 3

\*buffer [in] – A pointer to a chain of mbufs which the client has filled with the payload

## Returns:

- ♦ IX\_SUCCESS The function executed successfully
- ♦ IX\_FAIL The function did not execute successfully
- ♦ IX\_HSSACC\_PARAM\_ERR The function did not execute successfully due to a parameter error
- ♦ IX\_HSSACC\_RESOURCE\_ERR The function did not execute successfully due to a resource error. See note.
- ♦ IX\_HSSACC\_Q\_WRITE\_OVERFLOW The function did not succeed due to a Q overflow

#### Note:

IX\_HSSACC\_RESOURCE\_ERR is returned when a free descriptor cannot be obtained to send the chain of mbufs to the NPE. This is a normal scenario. HssAcc has a pool of descriptors and this error means that they are currently all in use. The recommended approach to this is to retry until a descriptor becomes free and the packet is successfully transmitted. Alternatively, the user could wait until the next IxHssAccPktTxDoneCallback callback is triggered, and then retry, as it is this event that causes a transmit descriptor to be freed.

| IX_STATUS ixHssAccPortInit ( IxHssAccHssPort | hssPortId,           |
|----------------------------------------------|----------------------|
| IxHssAccConfigParams *                       | configParams,        |
| IxHssAccTdmSlotUsage *                       | tdmMap,              |
| IxHssAccLastErrorCallback                    | lastHssErrorCallback |
| )                                            |                      |

Initialise a HSS port. No channelised or packetised connections should exist in the HssAccess layer while this interface is being called.

#### Parameters:

hssPortId IxHssAccHssPort [in] – The HSS port Id. There are two identical ports

(0-1).

\*configParams | IxHssAccConfigParams [in] – A pointer to the HSS configuration structure

IX\_HSSACC\_TSLOTS\_PER\_HSS\_PORT, defining the slot usage over the

**HSS** port

lastHssErrorCallback IxHssAccLastErrorCallback [in] – Client callback to report last error

#### Returns:

- ♦ IX\_SUCCESS The function executed successfully
- ♦ IX FAIL The function did not execute successfully

♦ IX\_HSSACC\_PARAM\_ERR The function did not execute successfully due to a parameter error

# void ixHssAccShow (void)

This function will display the current state of the IxHssAcc component. The output is sent to stdout.

#### Returns:

void

# void ixHssAccStatsInit ( void )

This function will reset the IxHssAcc statistics.

#### Returns:

void

# IX\_STATUS ixHssAccUninit ( void )

This function is responsible for un–initialize of resources for use by the packetised and channelised clients. It internally calls the uninitialize functions of sub components. This function should be the last function to be called before exiting HssAcc component.

#### Returns:

- ♦ IX\_SUCCESS The function executed successfully
- ♦ IX\_FAIL The function did not execute successfully

# Intel (R) IXP400 Software I2C Driver(IxI2cDrv) API

IXP400 I2C Driver Public API.

# **Data Structures**

#### struct IxI2cInitVars

contains all the variables required to initialize the I2C unit

#### struct IxI2cStatsCounters

contains results of counters and their overflow

# **Defines**

# #define IX\_I2C\_US\_POLL\_FOR\_XFER\_STATUS

The interval of micro/mili seconds the Intel (R) IXP4XX Product Line of Network Processors will wait before it polls for status from the ixI2cIntrXferStatus; Every 20us is 1 byte @ 400Kbps and 4 bytes @ 100Kbps. This is dependent on delay type selected through the API ixI2cDrvDelayTypeSelect.

#### #define IX I2C NUM OF TRIES TO CALL CALLBACK FUNC

The number of tries that will be attempted to call a callback function if the callback does not or is unable to resolve the issue it is called to resolve.

# #define IX\_I2C\_NUM\_TO\_POLL\_IDBR\_RX\_FULL

Number of tries slave will poll the IDBR Rx full bit before it gives up.

# #define IX\_I2C\_NUM\_TO\_POLL\_IDBR\_TX\_EMPTY

*Number of tries slave will poll the IDBR Tx empty bit before it gives up.* 

# **Typedefs**

# typedef void(\* IxI2cMasterReadCallbackP)(IxI2cMasterStatus, IxI2cXferMode, char \*, UINT32)

The pointer to the function that will be called when the master has completed its receive. The parameter that is passed will provide the status of the read (success, arb loss, or bus error), the transfer mode (normal or repeated start, the buffer pointer and number of bytes transferred.

# typedef void(\* IxI2cMasterWriteCallbackP )(IxI2cMasterStatus, IxI2cXferMode, char \*, UINT32)

The pointer to the function that will be called when the master has completed its transmit. The parameter that is passed will provide the status of the write (success, arb loss, or buss error), the transfer mode (normal or repeated start), the buffer pointer and number of bytes transferred.

typedef void(\* IxI2cSlaveReadCallbackP)(IX\_I2C\_STATUS, char \*, UINT32, UINT32)

The pointer to the function that will be called when a slave address detected in interrupt mode for a read. The parameters that is passed will provide the read status, buffer pointer, buffer size, and the bytes received. When a start of a read is initiated there will be no buffer allocated and this callback will be called to request for a buffer. While receiving, if the buffer gets filled, this callback will be called to request for a new buffer while sending the filled buffer's pointer and size, and data size received. When the receive is complete, this callback will be called to process the data and free the memory by passing the buffer's pointer and size, and data size received.

# typedef void(\* IxI2cSlaveWriteCallbackP)(IX\_I2C\_STATUS, char \*, UINT32, UINT32)

The pointer to the function that will be called when a slave address detected in interrupt mode for a write. The parameters that is passed will provide the write status, buffer pointer, buffer size, and the bytes received. When a start of a write is initiated there will be no buffer allocated and this callback will be called to request for a buffer and to fill it with data. While transmitting, if the data in the buffer empties, this callback will be called to request for more data to be filled in the same or new buffer. When the transmit is complete, this callback will be called to free the memory or other actions to be taken.

# typedef void(\* IxI2cGenCallCallbackP)(IX\_I2C\_STATUS, char \*, UINT32, UINT32)

The pointer to the function that will be called when a general call detected in interrupt mode for a read. The parameters that is passed will provide the read status, buffer pointer, buffer size, and the bytes received. When a start of a read is initiated there will be no buffer allocated and this callback will be called to request for a buffer. While receiving, if the buffer gets filled, this callback will be called to request for a new buffer while sending the filled buffer's pointer and size, and data size received. When the receive is complete, this callback will be called to process the data and free the memory by passing the buffer's pointer and size, and data size received.

# **Enumerations**

enum IxI2cMasterStatus {

```
IX_I2C_MASTER_XFER_COMPLETE,
     IX_I2C_MASTER_XFER_BUS_ERROR,
     IX_I2C_MASTER_XFER_ARB_LOSS
    The master status – transfer complete, bus error or arbitration loss.
enum IX_I2C_STATUS {
     IX_I2C_SUCCESS,
     IX I2C FAIL,
     IX I2C NOT SUPPORTED,
     IX I2C NULL POINTER,
     IX_I2C_INVALID_SPEED_MODE_ENUM_VALUE,
     IX_I2C_INVALID_FLOW_MODE_ENUM_VALUE,
     IX I2C SLAVE ADDR CB MISSING.
     IX_I2C_GEN_CALL_CB_MISSING,
     IX_I2C_INVALID_SLAVE_ADDR,
     IX_I2C_INT_BIND_FAIL,
     IX_I2C_INT_UNBIND_FAIL,
```

Enumerations 312

```
IX I2C NOT INIT,
      IX I2C MASTER BUS BUSY.
      IX I2C MASTER ARB LOSS,
      IX I2C MASTER XFER ERROR,
      IX I2C MASTER BUS ERROR.
      IX I2C MASTER NO BUFFER,
      IX I2C MASTER INVALID XFER MODE.
      IX I2C SLAVE ADDR NOT DETECTED,
      IX I2C GEN CALL ADDR DETECTED,
      IX_I2C_SLAVE_READ_DETECTED,
      IX_I2C_SLAVE_WRITE_DETECTED,
      IX I2C_SLAVE_NO_BUFFER,
      IX I2C DATA SIZE ZERO,
      IX I2C SLAVE WRITE BUFFER EMPTY,
      IX_I2C_SLAVE_WRITE_ERROR,
      IX I2C SLAVE OR GEN READ BUFFER FULL,
      IX I2C SLAVE OR GEN READ ERROR
     The status that can be returned in a I2C driver initialization.
enum IxI2cSpeedMode {
      IX_I2C_NORMAL_MODE,
     IX_I2C_FAST_MODE
     Type of speed modes supported by the I2C hardware.
enum IxI2cXferMode {
      IX_I2C_NORMAL,
     IX I2C REPEATED START
     Used for indicating it is a repeated start or normal transfer.
enum IxI2cFlowMode {
      IX I2C POLL MODE,
      IX_I2C_INTERRUPT_MODE
     Used for indicating it is a poll or interrupt mode.
enum IxI2cDelayMode {
      IX_I2C_LOOP_DELAY,
     IX I2C SCHED DELAY
     Used for selecting looping delay or OS scheduler delay.
```

# **Functions**

**PUBLIC** 

IX\_I2C\_STATUS ixI2cDrvInit (IxI2cInitVars \*InitVarsSelected)

Functions 313

Initializes the I2C Driver.

#### **PUBLIC**

# IX I2C STATUS ixI2cDrvUninit (void)

Disables the I2C hardware.

#### **PUBLIC**

# IX\_I2C\_STATUS ixI2cDrvSlaveAddrSet (UINT8 SlaveAddrSet)

Sets the I2C Slave Address.

#### **PUBLIC**

# IX\_I2C\_STATUS ixI2cDrvBusScan (void)

scans the I2C bus for slave devices

PUBLICixI2cDrvWriteTransfer (UINT8 SlaveAddr, char \*bufP, UINT32 dataSize,

IX I2C STATUS IxI2cXferMode XferModeSelect)

PUBLICixI2cDrvReadTransfer (UINT8 SlaveAddr, char \*bufP, UINT32 dataSize,

IX\_I2C\_STATUS IxI2cXferMode XferModeSelect)

Initiates a transfer to receive bytes of data from a slave device through the I2C bus.

#### **PUBLIC**

#### IX I2C STATUS ixI2cDrvSlaveAddrAndGenCallDetectedCheck (void)

Checks the I2C Status Register to determine if a slave address is detected.

PUBLICixI2cDrvSlaveOrGenDataReceive (char \*bufP, const UINT32 bufSize, UINT32 IX I2C STATUS \*dataSizeRcvd)

Performs the slave receive or general call receive data transfer.

# PUBLICixI2cDrvSlaveDataTransmit (char \*bufP, const UINT32 dataSize, UINT32 IX I2C STATUS \*dataSizeXmtd)

Performs the slave write data transfer.

# PUBLIC void ixI2cDrvSlaveOrGenCallBufReplenish (char \*bufP, UINT32 bufSize)

Replenishes the buffer which stores buffer info for both slave and general call.

#### **PUBLIC**

# IX\_I2C\_STATUS ixI2cDrvStatsGet (IxI2cStatsCounters \*I2cStats)

Returns the I2C Statistics through the pointer passed in.

# PUBLIC void ixI2cDrvStatsReset (void)

Reset I2C statistics counters.

#### **PUBLIC**

# IX\_I2C\_STATUS ixI2cDrvShow (void)

Displays the I2C status register and the statistics counter.

# PUBLIC void **ixI2cDrvDelayTypeSelect** (**IxI2cDelayMode** delayTypeSelect)

Sets the delay type of either looping delay or OS scheduler delay according to the argument provided.

Functions 314

# **Detailed Description**

IXP400 I2C Driver Public API.

# **Define Documentation**

## #define IX I2C NUM OF TRIES TO CALL CALLBACK FUNC

The number of tries that will be attempted to call a callback function if the callback does not or is unable to resolve the issue it is called to resolve.

Definition at line 44 of file IxI2cDrv.h.

# #define IX\_I2C\_NUM\_TO\_POLL\_IDBR\_RX\_FULL

Number of tries slave will poll the IDBR Rx full bit before it gives up.

Definition at line **52** of file **IxI2cDrv.h**.

# #define IX\_I2C\_NUM\_TO\_POLL\_IDBR\_TX\_EMPTY

Number of tries slave will poll the IDBR Tx empty bit before it gives up.

Definition at line 59 of file IxI2cDrv.h.

# #define IX\_I2C\_US\_POLL\_FOR\_XFER\_STATUS

The interval of micro/mili seconds the Intel (R) IXP4XX Product Line of Network Processors will wait before it polls for status from the ixI2cIntrXferStatus; Every 20us is 1 byte @ 400Kbps and 4 bytes @ 100Kbps. This is dependent on delay type selected through the API ixI2cDrvDelayTypeSelect.

Definition at line 36 of file IxI2cDrv.h.

# **Typedef Documentation**

# typedef void(\* IxI2cGenCallCallbackP)(IX\_I2C\_STATUS, char\*, UINT32, UINT32)

The pointer to the function that will be called when a general call detected in interrupt mode for a read. The parameters that is passed will provide the read status, buffer pointer, buffer size, and the bytes received. When a start of a read is initiated there will be no buffer allocated and this callback will be called to request

Detailed Description 315

for a buffer. While receiving, if the buffer gets filled, this callback will be called to request for a new buffer while sending the filled buffer's pointer and size, and data size received. When the receive is complete, this callback will be called to process the data and free the memory by passing the buffer's pointer and size, and data size received.

Definition at line 242 of file IxI2cDrv.h.

#### typedef void(\* IxI2cMasterReadCallbackP)(IxI2cMasterStatus, IxI2cXferMode, char\*, UINT32)

The pointer to the function that will be called when the master has completed its receive. The parameter that is passed will provide the status of the read (success, arb loss, or bus error), the transfer mode (normal or repeated start, the buffer pointer and number of bytes transferred.

Definition at line 180 of file IxI2cDrv.h.

# typedef void(\* IxI2cMasterWriteCallbackP)(IxI2cMasterStatus, IxI2cXferMode, char\*, UINT32)

The pointer to the function that will be called when the master has completed its transmit. The parameter that is passed will provide the status of the write (success, arb loss, or buss error), the transfer mode (normal or repeated start), the buffer pointer and number of bytes transferred.

Definition at line **191** of file **IxI2cDrv.h**.

## typedef void(\* IxI2cSlaveReadCallbackP)(IX I2C STATUS, char\*, UINT32, UINT32)

The pointer to the function that will be called when a slave address detected in interrupt mode for a read. The parameters that is passed will provide the read status, buffer pointer, buffer size, and the bytes received. When a start of a read is initiated there will be no buffer allocated and this callback will be called to request for a buffer. While receiving, if the buffer gets filled, this callback will be called to request for a new buffer while sending the filled buffer's pointer and size, and data size received. When the receive is complete, this callback will be called to process the data and free the memory by passing the buffer's pointer and size, and data size received.

Definition at line **208** of file **IxI2cDrv.h**.

# typedef void(\* IxI2cSlaveWriteCallbackP)(IX\_I2C\_STATUS, char\*, UINT32, UINT32)

The pointer to the function that will be called when a slave address detected in interrupt mode for a write. The parameters that is passed will provide the write status, buffer pointer, buffer size, and the bytes received. When a start of a write is initiated there will be no buffer allocated and this callback will be called to request for a buffer and to fill it with data. While transmitting, if the data in the buffer empties, this callback will be called to request for more data to be filled in the same or new buffer. When the transmit is complete, this callback will be called to free the memory or other actions to be taken.

Definition at line 225 of file IxI2cDrv.h.

Detailed Description 316

# **Enumeration Type Documentation**

#### enum IX\_I2C\_STATUS

The status that can be returned in a I2C driver initialization.

## **Enumeration values:**

IX\_I2C\_SUCCESS Success status.
IX\_I2C\_FAIL Success status.

IX\_I2C\_NOT\_SUPPORTED hardware does not have dedicated I2C hardware IX\_I2C\_NULL\_POINTER parameter passed in is

NULL

IX\_I2C\_INVALID\_SPEED\_MODE\_ENUM\_VALUE speed mode selected is

invalid

IX\_I2C\_INVALID\_FLOW\_MODE\_ENUM\_VALUE flow mode selected is

invalid

IX\_I2C\_SLAVE\_ADDR\_CB\_MISSING slave callback is NULL IX\_I2C\_GEN\_CALL\_CB\_MISSING general callback is

**NULL** 

IX\_I2C\_INVALID\_SLAVE\_ADDR invalid slave address

specified

IX\_I2C\_INT\_BIND\_FAILinterrupt bind failIX\_I2C\_INT\_UNBIND\_FAILinterrupt unbind failIX\_I2C\_NOT\_INITI2C is not initialized

yet.

IX\_I2C\_MASTER\_BUS\_BUSY master detected a I2C

bus busy

IX\_I2C\_MASTER\_ARB\_LOSS master experienced

arbitration loss

IX\_I2C\_MASTER\_XFER\_ERROR master experienced a

transfer error

IX\_I2C\_MASTER\_BUS\_ERROR master detected a I2C

bus error

IX\_I2C\_MASTER\_NO\_BUFFER no buffer provided for

master transfer

IX\_I2C\_MASTER\_INVALID\_XFER\_MODE xfer mode selected is

invalid

IX\_I2C\_SLAVE\_ADDR\_NOT\_DETECTED polled slave addr not

detected

IX\_I2C\_GEN\_CALL\_ADDR\_DETECTED polling detected general

call

IX\_I2C\_SLAVE\_READ\_DETECTED polling detected slave

read request

IX\_I2C\_SLAVE\_WRITE\_DETECTED polling detected slave

write request

no buffer provided for

slave transfers

data size transfer is zero IX\_I2C\_DATA\_SIZE\_ZERO

- invalid

slave buffer is used till IX\_I2C\_SLAVE\_WRITE\_BUFFER\_EMPTY

empty

IX\_I2C\_SLAVE\_WRITE\_ERROR slave write experienced

an error

IX\_I2C\_SLAVE\_OR\_GEN\_READ\_BUFFER\_FULL slave buffer is filled up IX\_I2C\_SLAVE\_OR\_GEN\_READ\_ERROR

slave read experienced

an error

Definition at line 87 of file IxI2cDrv.h.

*IX\_I2C\_SLAVE\_NO\_BUFFER* 

# enum IxI2cDelayMode

Used for selecting looping delay or OS scheduler delay.

# Enumeration values:

IX\_I2C\_LOOP\_DELAY delay in microseconds IX\_I2C\_SCHED\_DELAY delay in miliseconds

Definition at line 165 of file IxI2cDrv.h.

#### enum IxI2cFlowMode

Used for indicating it is a poll or interrupt mode.

Definition at line 152 of file IxI2cDrv.h.

# enum IxI2cMasterStatus

The master status – transfer complete, bus error or arbitration loss.

Definition at line 72 of file IxI2cDrv.h.

# enum IxI2cSpeedMode

Type of speed modes supported by the I2C hardware.

Definition at line 126 of file IxI2cDrv.h.

#### enum IxI2cXferMode

Used for indicating it is a repeated start or normal transfer.

Definition at line 139 of file IxI2cDrv.h.

# **Function Documentation**

ixI2cDrvBusScan (void)

scans the I2C bus for slave devices

#### Parameters:

- None

Global Data:

• None.

This API will prompt all slave addresses for a reply except its own

# Returns:

```
    ♦ IX_I2C_SUCCESS – found at least one slave device
    ♦ IX_I2C_FAIL – Fail to find even one slave device
    ♦ IX_I2C_BUS_BUSY – The I2C bus is busy (held by another I2C master)
    ♦ IX_I2C_ARB_LOSS – The I2C bus was loss to another I2C master
    ♦ IX_I2C_NOT_INIT – I2C not init yet.
```

Reentrant : yesISR Callable : yes

# ixI2cDrvDelayTypeSelect ( **IxI2cDelayMode** *delayTypeSelect* )

Sets the delay type of either looping delay or OS scheduler delay according to the argument provided.

# Parameters:

- "IxI2cDelayMode [in] delayTypeSelect" - the I2C delay type selected

Global Data:

• None.

This API will set the delay type used by the I2C Driver to either looping delay or OS scheduler delay.

#### Returns:

#### ♦ None

Reentrant : yesISR Callable : no

# ixI2cDrvInit ( IxI2cInitVars \* InitVarsSelected )

Initializes the I2C Driver.

#### Parameters:

IxI2cInitVars [in] \*InitVarsSelected - struct containing required variables for initialization

#### Global Data:

• None.

This API will check if the hardware supports this I2C driver and the validity of the parameters passed in. It will continue to process the parameters passed in by setting the speed of the I2C unit (100kbps or 400kbps), setting the flow to either interrupt or poll mode, setting the address of the I2C unit, enabling/disabling the respond to General Calls, enabling/disabling the respond to Slave Address and SCL line driving. If it is interrupt mode, then it will register the callback routines for master, slavetransfer and general call receive.

#### Returns:

- ♦ IX\_I2C\_SUCCESS Successfully initialize and enable the I2C hardware.
- ♦ IX\_I2C\_NOT\_SUPPORTED The hardware does not support or have a dedicated I2C unit to support this driver
- ♦ IX\_I2C\_NULL\_POINTER The parameter passed in is a NULL pointed
- ♦ IX\_I2C\_INVALID\_SPEED\_MODE\_ENUM\_VALUE The speed mode selected in the InitVarsSelected is invalid
- ♦ IX\_I2C\_INVALID\_FLOW\_MODE\_ENUM\_VALUE The flow mode selected in the InitVarsSelected is invalid
- ♦ IX I2C INVALID SLAVE ADDR The address 0x0 is reserved for general call.
- ♦ IX\_I2C\_SLAVE\_ADDR\_CB\_MISSING interrupt mode is selected but slave address callback pointer is NULL
- ♦ IX\_I2C\_GEN\_CALL\_CB\_MISSING interrupt mode is selected but general call callback pointer is NULL
- ♦ IX I2C INT BIND FAIL The ISR for the I2C failed to bind
- ♦ IX\_I2C\_INT\_UNBIND\_FAIL The ISR for the I2C failed to unbind

Reentrant : yesISR Callable : yes

Initiates a transfer to receive bytes of data from a slave device through the I2C bus.

#### Parameters:

UINT8 [in] SlaveAddr

char [out] \*bufP — The pointer to the buffer to store the requested data.
 UINT32 [in] dataSize — The number of bytes requested.
 IxI2cXferMode [in] — the transfer mode selected, either repeated start (ends w/o stop) or normal (start and stop)

- The slave address to request data from.

#### Global Data:

• None.

This API will try to obtain master control of the I2C bus and receive the number of bytes, specified by dataSize, from the user specified address into the receive buffer. It will use either interrupt or poll mode depending on the mode selected.

If in interrupt mode and IxI2cMasterReadCallbackP is not NULL, the driver will initiate the transfer and return immediately. The function pointed to by IxI2cMasterReadCallbackP will be called in the interrupt service handlers when the operation is complete.

If in interrupt mode and IxI2cMasterReadCallbackP is NULL, then the driver will wait for the operation to complete, and then return.

And if the repeated start transfer mode is selected, then it will not send a stop signal at the end of all the transfers. \*NOTE\*: If repeated start transfer mode is selected, it has to end with a normal mode transfer mode else the bus will continue to be held by the Intel (R) IXP4XX Product Line of Network Processors.

#### Returns:

```
    ♦ IX_I2C_SUCCESS – Successfuuly read slave data
    ♦ IX_I2C_MASTER_BUS_BUSY – The I2C bus is busy (held by another I2C master)
    ♦ IX_I2C_MASTER_ARB_LOSS – The I2C bus was loss to another I2C master
    ♦ IX_I2C_MASTER_XFER_ERROR – There was a bus error during transfer
    ♦ IX_I2C_MASTER_BUS_ERROR – There was a bus error during transfer
    ♦ IX_I2C_MASTER_NO_BUFFER – buffer pointer is NULL
    ♦ IX_I2C_MASTER_INVALID_XFER_MODE – Xfer mode selected is invalid
    ♦ IX_I2C_INVALID_SLAVE_ADDR – invalid slave address (zero) specified
    ♦ IX_I2C_DATA_SIZE_ZERO – dataSize passed in is zero, which is invalid
    ♦ IX_I2C_NOT_INIT – I2C not init yet.
```

Reentrant : noISR Callable : no

# ixI2cDrvShow (void)

Displays the I2C status register and the statistics counter.

#### Parameters:

- None

Function Documentation

321

#### Global Data:

• None.

This API will display the I2C Status register and is useful if any error occurs. It displays the detection of bus error, slave address, general call, address, IDBR receive full, IDBR transmit empty, arbitration loss, slave STOP signal, I2C bus busy, unit busy, ack/nack, read/write mode, and delay type selected. It will also call the ixI2cDrvGetStats and then display the statistics counter.

#### Returns:

♦ IX\_I2C\_SUCCESS – successfully displayed statistics and status register 
♦ IX\_I2C\_NOT\_INIT – I2C not init yet.

Reentrant : yesISR Callable : no

# ixI2cDrvSlaveAddrAndGenCallDetectedCheck (void)

Checks the I2C Status Register to determine if a slave address is detected.

#### Parameters:

- None

#### Global Data:

• None.

This API is used in polled mode to determine if the I2C unit is requested for a slave or general call transfer. If it is requested for a slave transfer then it will determine if it is a general call (read only), read, or write transfer requested.

#### Returns:

- ♦ IX\_I2C\_SLAVE\_ADDR\_NOT\_DETECTED The I2C unit is not requested for slave transfer
- ♦ IX\_I2C\_GEN\_CALL\_ADDR\_DETECTED The I2C unit is not requested for slave transfer but for general call
- ♦ IX\_I2C\_SLAVE\_READ\_DETECTED The I2C unit is requested for a read
- ♦ IX\_I2C\_SLAVE\_WRITE\_DETECTED The I2C unit is requested for a write
- ♦ IX I2C NOT INIT I2C not init yet.

Reentrant : noISR Callable : no

# ixI2cDrvSlaveAddrSet ( UINT8 SlaveAddrSet )

Sets the I2C Slave Address.

#### Parameters:

UINT8 [in] SlaveAddrSet - Slave Address to be inserted into ISAR

#### Global Data:

None.

This API will insert the SlaveAddrSet into the ISAR.

#### Returns:

```
    ◇ IX_I2C_SUCCESS – successfuly set the slave addr
    ◇ IX_I2C_INVALID_SLAVE_ADDR – invalid slave address (zero) specified
    ◇ IX_I2C_NOT_INIT – I2C not init yet.
```

Reentrant : yesISR Callable : yes

Performs the slave write data transfer.

#### Parameters:

```
    char [in] – the pointer to the buffer for data to be transmitted "const UINT32 [in] bufSize" – the
    *bufP buffer size allocated "UINT32 [in] *dataSizeRcvd" – the length of data transmitted in bytes
```

#### Global Data:

• None.

This API is only used in polled mode to perform the slave transmit data. It will continuously transmit the data from bufP until complete or until bufP is empty in which it will return IX\_I2C\_SLAVE\_WRITE\_BUFFER\_EMPTY. If in interrupt mode, the callback will be used.

## Returns:

- ♦ IX I2C SUCCESS The I2C driver transferred the data successfully.
- ♦ IX\_I2C\_SLAVE\_WRITE\_BUFFER\_EMPTY The I2C driver needs more data to transmit.
- ♦ IX\_I2C\_SLAVE\_WRITE\_ERROR –The I2C driver didn't manage to detect the IDBR Tx empty bit or the slave stop bit.
- ♦ IX I2C DATA SIZE ZERO dataSize passed in is zero, which is invalid
- ♦ IX\_I2C\_SLAVE\_NO\_BUFFER buffer pointer is NULL
- ♦ IX\_I2C\_NULL\_POINTER dataSizeXmtd is NULL
- ♦ IX\_I2C\_NOT\_INIT I2C not init yet.
- Reentrant : no

• ISR Callable: no

```
ixI2cDrvSlaveOrGenCallBufReplenish ( char * bufP,
UINT32 bufSize
)
```

Replenishes the buffer which stores buffer info for both slave and general call.

#### Parameters:

char [in] \*bufP - pointer to the buffer allocated "UINT32 [in] bufSize" - size of the buffer

Global Data:

• None.

This API is only used in interrupt mode for replenishing the same buffer that is used by both slave and generall call by updating the buffer info with new info and clearing previous offsets set by previous transfers.

#### Returns:

♦ None

Reentrant : noISR Callable : no

```
ixI2cDrvSlaveOrGenDataReceive ( char * bufP, const UINT32 bufSize, UINT32 * dataSizeRcvd )
```

Performs the slave receive or general call receive data transfer.

#### Parameters:

```
    char [in] – the pointer to the buffer to store data "const UINT32 [in] bufSize" – the buffer size
    *bufP allocated "UINT32 [in] *dataSizeRcvd" – the length of data received in bytes
```

Global Data:

• None.

This API is only used in polled mode to perform the slave read or general call receive data. It will continuously store the data received into bufP until complete or until bufP is full in which it will return IX\_I2C\_SLAVE\_OR\_GEN\_READ\_BUFFER\_FULL. If in interrupt mode, the callback will be used.

#### Returns:

- ♦ IX\_I2C\_SUCCESS The I2C driver transferred the data successfully.
- ♦ IX\_I2C\_SLAVE\_OR\_GEN\_READ\_BUFFER\_FULL The I2C driver has ran out of space to store the received data.

- ♦ IX\_I2C\_SLAVE\_OR\_GEN\_READ\_ERROR The I2C driver didn't manage to detect the IDBR Rx Full bit
- ♦ IX\_I2C\_DATA\_SIZE\_ZERO bufSize passed in is zero, which is invalid
- ♦ IX I2C SLAVE NO BUFFER buffer pointer is NULL
- ♦ IX\_I2C\_NULL\_POINTER dataSizeRcvd is NULL
- $\Diamond$  IX\_I2C\_NOT\_INIT I2C not init yet.

Reentrant : noISR Callable : no

# ixI2cDrvStatsGet ( **IxI2cStatsCounters** \* *I2cStats* )

Returns the I2C Statistics through the pointer passed in.

#### Parameters:

"IxI2cStatsCounters [out] \*I2cStats" – I2C statistics counter will be read and written to the location pointed by this pointer.

## Global Data:

• None.

This API will return the statistics counters of the I2C driver.

#### Returns:

♦ IX\_I2C\_NULL\_POINTER – pointer passed in is NULL ♦ IX\_I2C\_SUCCESS – successfully obtained I2C statistics

Reentrant : yesISR Callable : no

# ixI2cDrvStatsReset (void)

Reset I2C statistics counters.

#### Parameters:

- None

# Global Data:

• None.

This API will reset the statistics counters of the I2C driver.

#### Returns:

◊ None

• Reentrant : yes

• ISR Callable : no

#### ixI2cDrvUninit (void)

Disables the I2C hardware.

#### Parameters:

- None

#### Global Data:

• None.

This API will disable the I2C hardware, unbind interrupt, and unmap memory.

#### Returns:

```
    ◇ IX_I2C_SUCCESS – successfully un–initialized I2C
    ◇ IX_I2C_INT_UNBIND_FAIL – failed to unbind the I2C interrupt
    ◇ IX_I2C_NOT_INIT – I2C not init yet.
```

Reentrant : yesISR Callable : yes

#### Parameters:

```
    UINT8 [in] SlaveAddr
    Char [in] *bufP
    The pointer to the data to be transmitted.
    UINT32 [in] dataSize
    The number of bytes requested.
    IxI2cXferMode [in]
    The transfer mode selected, either repeated start (ends w/o stop) or normal (start and stop)
```

# Global Data:

• None.

This API will try to obtain master control of the I2C bus and transmit the number of bytes, specified by dataSize, to the user specified slave address from the buffer pointer. It will use either interrupt or poll mode depending on the method selected.

If in interrupt mode and IxI2cMasterWriteCallbackP is not NULL, the driver will initiate the transfer and return immediately. The function pointed to by IxI2cMasterWriteCallbackP will be called in the interrupt

service handlers when the operation is complete.

If in interrupt mode and IxI2cMasterWriteCallbackP is NULL, then the driver will wait for the operation to complete, and then return.

And if the repeated start transfer mode is selected, then it will not send a stop signal at the end of all the transfers. \*NOTE\*: If repeated start transfer mode is selected, it has to end with a normal mode transfer mode else the bus will continue to be held by the Intel (R) IXP4XX Product Line of Network Processors.

#### Returns:

- ♦ IX\_I2C\_SUCCESS Successfuuly wrote data to slave.
- ♦ IX\_I2C\_MASTER\_BUS\_BUSY The I2C bus is busy (held by another I2C master)
- ♦ IX I2C MASTER ARB LOSS The I2C bus was loss to another I2C master
- ♦ IX I2C MASTER XFER ERROR There was a transfer error
- ♦ IX\_I2C\_MASTER\_BUS\_ERROR There was a bus error during transfer
- ♦ IX\_I2C\_MASTER\_NO\_BUFFER buffer pointer is NULL
- ♦ IX\_I2C\_MASTER\_INVALID\_XFER\_MODE Xfer mode selected is invalid
- ♦ IX\_I2C\_DATA\_SIZE\_ZERO dataSize passed in is zero, which is invalid
- ♦ IX\_I2C\_NOT\_INIT I2C not init yet.

Reentrant : noISR Callable : no

# Intel (R) IXP400 Software NPE-Downloader (IxNpeDI) API

The Public API for the IXP400 NPE Downloader.

# **Modules**

Intel (R) IXP400 Software NPE Image ID Definition

Definition of NPE Image ID to be passed to ixNpeDlNpeInitAndStart() as input of type UINT32 which has the following fields format:.

# **Defines**

#### #define IX NPEDL PARAM ERR

*NpeDl function return value for a parameter error.* 

#### #define IX NPEDL RESOURCE ERR

NpeDl function return value for a resource error.

#### #define IX NPEDL CRITICAL NPE ERR

NpeDl function return value for a Critical NPE error occuring during download. Assume NPE is left in unstable condition if this value is returned or NPE is hang / halt.

#### #define IX NPEDL CRITICAL MICROCODE ERR

NpeDl function return value for a Critical Microcode error discovered during download. Assume NPE is left in unstable condition if this value is returned.

# #define IX\_NPEDL\_DEVICE\_ERR

NpeDl function return value when image being downloaded is not meant for the device in use

# **Functions**

**PUBLIC** 

IX\_STATUS ixNpeDlNpeInitAndStart (UINT32 npeImageId)

Stop, reset, download microcode (firmware) and finally start NPE.

PUBLIC

IX\_STATUS **ixNpeDlCustomImageNpeInitAndStart** (UINT32 \*imageLibrary, UINT32 npeImageId) *Stop, reset, download microcode* (firmware) and finally start NPE.

PUBLICixNpeDlLoadedImageFunctionalityGet (IxNpeDlNpeId npeId, UINT8 \*functionalityId)

IX STATUS

Gets the functionality of the image last loaded on a particular NPE.

**PUBLIC** 

IX\_STATUS ixNpeDlNpeStopAndReset (IxNpeDlNpeId npeId)

Stops and Resets an NPE.

**PUBLIC** 

IX\_STATUS ixNpeDlNpeExecutionStart (IxNpeDlNpeId npeId)

Starts code execution on a NPE.

**PUBLIC** 

IX\_STATUS ixNpeDlNpeExecutionStop (IxNpeDlNpeId npeId)

Stops code execution on a NPE.

**PUBLIC** 

IX\_STATUS ixNpeDlUnload (void)

This function will uninitialise the IxNpeDl component.

PUBLIC void ixNpeDlStatsShow (void)

This function will display run—time statistics from the IxNpeDl component.

PUBLIC void ixNpeDlStatsReset (void)

This function will reset the statistics of the IxNpeDl component.

# **Detailed Description**

The Public API for the IXP400 NPE Downloader.

# **Define Documentation**

#### #define IX NPEDL CRITICAL MICROCODE ERR

NpeDl function return value for a Critical Microcode error discovered during download. Assume NPE is left in unstable condition if this value is returned.

Definition at line **65** of file **IxNpeDl.h**.

# #define IX\_NPEDL\_CRITICAL\_NPE\_ERR

NpeDl function return value for a Critical NPE error occurring during download. Assume NPE is left in unstable condition if this value is returned or NPE is hang / halt.

Definition at line **56** of file **IxNpeDl.h**.

Detailed Description 329

#### #define IX NPEDL DEVICE ERR

NpeDl function return value when image being downloaded is not meant for the device in use.

Definition at line **73** of file **IxNpeDl.h**.

# #define IX\_NPEDL\_PARAM\_ERR

NpeDl function return value for a parameter error.

Definition at line **40** of file **IxNpeDl.h**.

## #define IX\_NPEDL\_RESOURCE\_ERR

NpeDl function return value for a resource error.

Definition at line **47** of file **IxNpeDl.h**.

# **Function Documentation**

```
PUBLIC IX_STATUS ixNpeDlCustomImageNpeInitAndStart ( UINT32 * imageLibrary, UINT32 * npeImageId )
```

Stop, reset, download microcode (firmware) and finally start NPE.

#### Parameters:

imageId UINT32 [in] – Id of the microcode image to download.

This function locates the image specified by the *imageId* parameter from the specified microcode image library which is pointed to by the *imageLibrary* parameter. It then stops and resets the NPE, loads the firmware image onto the NPE, and then restarts the NPE.

This is a facility for users who wish to use an image from an external library of NPE firmware images. To use a standard image from the built—in library, see **ixNpeDlNpeInitAndStart** instead.

#### Note:

A list of valid image IDs is included in this header file. See #defines with prefix IX\_NPEDL\_NPEIMAGE\_...

This function, along with **ixNpeDlNpeInitAndStart** and **ixNpeDlLoadedImageFunctionalityGet**, supercedes the following functions which are deprecated and will be removed completely in a future release:

- **♦** ixNpeDlNpeExecutionStop
- **◊** ixNpeDlNpeStopAndReset

# **♦** ixNpeDlNpeExecutionStart

#### Precondition:

- ♦ The Client is responsible for ensuring mutual access to the NPE.
- ♦ The image library supplied must be in the correct format for use by the NPE Downloader (IxNpeDl) component. Details of the library format are contained in the Functional Specification document for IxNpeDl.

#### Postcondition:

- ♦ The NPE Instruction Pipeline will be cleared if State Information has been downloaded.
- ♦ If the download fails with a critical error, the NPE may be left in an ususable state.

#### Returns:

- ♦ IX SUCCESS if the download was successful;
- ♦ IX\_NPEDL\_PARAM\_ERR if a parameter error occured
- ♦ IX NPEDL CRITICAL NPE ERR if a critical NPE error occured during download
- ♦ IX\_NPEDL\_CRITICAL\_MICROCODE\_ERR if a critical microcode error occured during download
- ♦ IX\_NPEDL\_DEVICE\_ERR if the image being loaded is not meant for the device currently running.
- ♦ IX\_FAIL if NPE is not available or image is failed to be located. A warning is issued if the NPE is not present.

```
PUBLIC IX_STATUS ixNpeDlLoadedImageFunctionalityGet ( IxNpeDlNpeId npeId, UINT8 * functionalityId )
```

Gets the functionality of the image last loaded on a particular NPE.

# Parameters:

```
npeId IxNpeDlNpeId [in] – Id of the target NPE.

functionalityId UINT8* [out] – the functionality ID of the image last loaded on the NPE.
```

This function retrieves the functionality ID of the image most recently downloaded successfully to the specified NPE. If the NPE does not contain a valid image, this function returns a FAIL status.

#### Warning:

This function is not intended for general use, as a knowledge of how to interpret the functionality ID is required. As such, this function should only be used by other Access Layer components of the IXP400 Software Release.

#### Precondition:

#### Postcondition:

#### Returns:

- ♦ IX\_SUCCESS if the operation was successful
- ♦ IX\_NPEDL\_PARAM\_ERR if a parameter error occured
- ♦ IX FAIL if the NPE does not have a valid image loaded

#### PUBLIC IX STATUS ixNpeDlNpeExecutionStart ( **IxNpeDlNpeId** npeId )

Starts code execution on a NPE.

#### Parameters:

*npeld* **IxNpeDlNpeId** [in] – Id of the target NPE

Starts execution of code on a particular NPE. A client would typically use this after a download to NPE is performed, to start/restart code execution on the NPE.

#### Note:

It is no longer necessary to call this function after downloading a new image to the NPE. It is left on the API only to allow greater control of NPE execution if required. Where appropriate, use **ixNpeDlNpeInitAndStart** or **ixNpeDlCustomImageNpeInitAndStart** instead.

## Warning:

THIS FUNCTION HAS BEEN DEPRECATED AND SHOULD NOT BE USED. It will be removed in a future release. See ixNpeDlNpeInitAndStart and ixNpeDlCustomImageNpeInitAndStart.

#### Precondition:

- ♦ The Client is responsible for ensuring mutual access to the NPE.
- ♦ Note that this function does not set the NPE Next Program Counter (NextPC), so it should be set beforehand if required by downloading appropriate State Information (using ixNpeDlVersionDownload()).

#### Postcondition:

#### Returns:

- ♦ IX SUCCESS if the operation was successful
- ♦ IX\_NPEDL\_PARAM\_ERR if a parameter error occured
- ♦ IX\_FAIL otherwise

# PUBLIC IX\_STATUS ixNpeDlNpeExecutionStop ( **IxNpeDlNpeId** npeId )

Stops code execution on a NPE.

#### Parameters:

*npeld* **IxNpeDlNpeId** [in] – Id of the target NPE

Stops execution of code on a particular NPE. This would typically be used by a client before a download to NPE is performed, to stop code execution on an NPE, unless **ixNpeDlNpeStopAndReset()** is used instead. Unlike **ixNpeDlNpeStopAndReset()**, this function only halts the NPE and leaves all registers and settings intact. This is useful, for example, between stages of a multi–stage download, to stop the NPE prior to downloading the next image while leaving the current state of the NPE intact..

# Warning:

THIS FUNCTION HAS BEEN DEPRECATED AND SHOULD NOT BE USED. It will be removed in a future release. See ixNpeDlNpeInitAndStart and

#### ix NpeDlCustomImageNpeInitAndStart.

#### Precondition:

♦ The Client is responsible for ensuring mutual access to the NPE.

#### Postcondition:

#### Returns:

- ♦ IX SUCCESS if the operation was successful
- ♦ IX\_NPEDL\_PARAM\_ERR if a parameter error occured
- ♦ IX FAIL otherwise

# PUBLIC IX\_STATUS ixNpeDlNpeInitAndStart (UINT32 npeImageId )

Stop, reset, download microcode (firmware) and finally start NPE.

#### Parameters:

imageId UINT32 [in] - Id of the microcode image to download.

This function locates the image specified by the *imageId* parameter from the default microcode image library which is included internally by this component. It then stops and resets the NPE, loads the firmware image onto the NPE, and then restarts the NPE.

#### Note:

A list of valid image IDs is included in this header file. See #defines with prefix IX\_NPEDL\_NPEIMAGE\_...

This function, along with  $ixNpeDlCustomImageNpeInitAndStart\ and$ 

**ixNpeDlLoadedImageFunctionalityGet**, supercedes the following functions which are deprecated and will be removed completely in a future release:

- **♦** ixNpeDlNpeExecutionStop
- **♦** ixNpeDlNpeStopAndReset
- **◊** ixNpeDlNpeExecutionStart

#### Precondition:

♦ The Client is responsible for ensuring mutual access to the NPE.

#### Postcondition:

- ♦ The NPE Instruction Pipeline will be cleared if State Information has been downloaded.
- ♦ If the download fails with a critical error, the NPE may be left in an ususable state.

#### Returns:

- ♦ IX SUCCESS if the download was successful;
- ♦ IX\_NPEDL\_PARAM\_ERR if a parameter error occured
- ♦ IX\_NPEDL\_CRITICAL\_NPE\_ERR if a critical NPE error occured during download
- ♦ IX\_NPEDL\_CRITICAL\_MICROCODE\_ERR if a critical microcode error occured during download
- ♦ IX\_NPEDL\_DEVICE\_ERR if the image being loaded is not meant for the device currently

running.

♦ IX\_FAIL if NPE is not available or image is failed to be located. A warning is issued if the NPE is not present.

# PUBLIC IX\_STATUS ixNpeDlNpeStopAndReset ( **IxNpeDlNpeId** npeId )

Stops and Resets an NPE.

#### Parameters:

*npeld* **IxNpeDlNpeId** [in] – Id of the target NPE.

This function performs a soft NPE reset by writing reset values to particular NPE registers. Note that this does not reset NPE co-processors. This implicitly stops NPE code execution before resetting the NPE.

#### Note:

It is no longer necessary to call this function before downloading a new image to the NPE. It is left on the API only to allow greater control of NPE execution if required. Where appropriate, use **ixNpeDlNpeInitAndStart** or **ixNpeDlCustomImageNpeInitAndStart** instead.

# Warning:

THIS FUNCTION HAS BEEN DEPRECATED AND SHOULD NOT BE USED. It will be removed in a future release. See ixNpeDlNpeInitAndStart and ixNpeDlCustomImageNpeInitAndStart.

#### Precondition:

♦ The Client is responsible for ensuring mutual access to the NPE.

#### Postcondition:

#### Returns:

- ♦ IX\_SUCCESS if the operation was successful
- ♦ IX\_NPEDL\_PARAM\_ERR if a parameter error occured
- ♦ IX\_FAIL otherwise
- ♦ IX\_NPEDL\_CRITICAL\_NPE\_ERR failed to reset NPE due to timeout error. Timeout error could happen if NPE hang

# PUBLIC void ixNpeDlStatsReset (void)

This function will reset the statistics of the IxNpeDl component.

#### Returns:

none

#### PUBLIC void ixNpeDlStatsShow (void )

This function will display run–time statistics from the IxNpeDl component.

#### Returns:

none

# PUBLIC IX\_STATUS ixNpeDlUnload (void)

This function will uninitialise the IxNpeDl component.

This function will uninitialise the IxNpeDl component. It should only be called once, and only if the IxNpeDl component has already been initialised by calling any of the following functions:

- ixNpeDlNpeInitAndStart
- $\bullet ix NpeDlCustomImageNpeInitAndStart\\$

If possible, this function should be called before a soft reboot or unloading a kernel module to perform any clean up operations required for IxNpeDl.

The following actions will be performed by this function:

• Unmapping of any kernel memory mapped by IxNpeDl

# Returns:

- ♦ IX\_SUCCESS if the operation was successful
- ♦ IX\_FAIL otherwise

# Intel (R) IXP400 Software NPE Image ID Definition

[Intel (R) IXP400 Software NPE-Downloader (IxNpeDI) API]

Definition of NPE Image ID to be passed to **ixNpeDlNpeInitAndStart()** as input of type UINT32 which has the following fields format:.

# **Defines**

 ${\tt \#define}\; \mathbf{IX\_NPEDL\_NPEIMAGE\_FIELD\_MASK}$ 

Mask for NPE Image ID's Field.

#define IX\_NPEDL\_NPEIMAGE\_NPEID\_MASK

Mask for NPE Image NPE ID's Field.

#define IX\_NPEDL\_NPEIMAGE\_DEVICEID\_MASK

Mask for NPE Image Device ID's Field.

# **Enumerations**

# **Detailed Description**

Definition of NPE Image ID to be passed to **ixNpeDlNpeInitAndStart()** as input of type UINT32 which has the following fields format:.

# **Define Documentation**

#define IX\_NPEDL\_NPEIMAGE\_DEVICEID\_MASK

Mask for NPE Image Device ID's Field.

Definition at line 120 of file IxNpeDl.h.

# #define IX\_NPEDL\_NPEIMAGE\_FIELD\_MASK

Mask for NPE Image ID's Field.

# Warning:

THIS #define HAS BEEN DEPRECATED AND SHOULD NOT BE USED. It will be removed in a future release. See ixNpeDlNpeInitAndStart for more information.

Definition at line **104** of file **IxNpeDl.h**.

# #define IX\_NPEDL\_NPEIMAGE\_NPEID\_MASK

Mask for NPE Image NPE ID's Field.

Definition at line **112** of file **IxNpeDl.h**.

# **Enumeration Type Documentation**

# enum IxNpeDlNpeId

NpeId numbers to identify NPE A, B or C.

# Note:

In this context, for B0 Silicon of the Intel (R) IXP42X Product Line:

- ♦ NPE-A has HDLC, HSS, AAL and UTOPIA Coprocessors.
- ♦ NPE-B has Ethernet Coprocessor.
- ♦ NPE-C has Ethernet, AES, DES and HASH Coprocessors.
- ♦ Intel (R) IXP4XX Product Line of Network Processors have different combinations of coprocessors.

#### **Enumeration values:**

IX\_NPEDL\_NPEID\_NPEA Identifies NPE A.

Define Documentation 337

```
IX_NPEDL_NPEID_NPEB Identifies NPE B.IX_NPEDL_NPEID_NPEC Identifies NPE C.IX_NPEDL_NPEID_MAX Total Number of NPEs.
```

Definition at line 139 of file IxNpeDl.h.

#### enum IxNpePortId

NPE Port ID numbers to identify NPE A, B or C.

#### Enumeration values:

 $IX\_NPEB\_PORT$  Identifies NPE B.  $IX\_NPEC\_PORT$  Identifies NPE C.  $IX\_NPEA\_PORT$  Identifies

 $X_NPEA_PORT$  Identifies NPE A.

Definition at line **150** of file **IxNpeDl.h**.

Define Documentation 338

# Intel (R) IXP400 Software NPE Message Handler (IxNpeMh) API

The public API for the IXP400 NPE Message Handler component.

## **Data Structures**

#### struct IxNpeMhMessage

The 2-word message structure to send to and receive from the NPEs.

## **Defines**

#### #define IX\_NPEMH\_MIN\_MESSAGE\_ID

minimum valid message ID

#### #define IX\_NPEMH\_MAX\_MESSAGE\_ID

maximum valid message ID

#### #define IX\_NPEMH\_SEND\_RETRIES\_DEFAULT

default msg send retries

#### #define IX\_NPEMH\_CRITICAL\_NPE\_ERR

NpeMH function return value for a Critical NPE error occurring during sending/receiving message. Assume NPE hang / halt if this value is returned.

## **Typedefs**

typedef UINT32 IxNpeMhMessageId

message ID

#### typedef void(\* IxNpeMhCallback )(IxNpeMhNpeId, IxNpeMhMessage)

This prototype shows the format of a message callback function.

## **Enumerations**

The ID of a particular NPE.

## 

Indicator specifying whether or not NPE interrupts should drive receiving of messages from the NPEs.

## **Functions**

PUBLIC IX\_STATUS ixNpeMhInitialize (IxNpeMhNpeInterrupts npeInterrupts)

This function will initialise the IxNpeMh component.

PUBLIC IX\_STATUS ixNpeMhUnload (void)

This function will uninitialise the IxNpeMh component.

PUBLIC IX\_STATUS ixNpeMhUnsolicitedCallbackRegister (IxNpeMhNpeId npeId, IxNpeMhMessageId messageId, IxNpeMhCallback

unsolicitedCallback)

This function will register an unsolicited callback for a particular NPE and message ID.

- PUBLIC IX\_STATUS ixNpeMhUnsolicitedCallbackForRangeRegister (IxNpeMhNpeId npeId, IxNpeMhMessageId minMessageId, IxNpeMhMessageId maxMessageId, IxNpeMhCallback unsolicitedCallback)

  This function will register an unsolicited callback for a particular NPE and range of message IDs.
- PUBLIC IX\_STATUS **ixNpeMhMessageSend** (**IxNpeMhNpeId** npeId, **IxNpeMhMessage** message, UINT32 maxSendRetries)

  This function will send a message to a particular NPE.
- PUBLIC IX\_STATUS ixNpeMhMessageWithResponseSend (IxNpeMhNpeId npeId, IxNpeMhMessage message, IxNpeMhMessageId solicitedMessageId, IxNpeMhCallback solicitedCallback, UINT32 maxSendRetries)

  This function is equivalent to the ixNpeMhMessageSend() function, but must be used when the message being sent will solicited a response.
- PUBLIC IX\_STATUS ixNpeMhMessagesReceive (IxNpeMhNpeId npeId)

This function will receive messages from a particular NPE and pass each message to the client via a solicited callback (for solicited messages) or an unsolicited callback (for unsolicited messages).

PUBLIC IX\_STATUS ixNpeMhShow (IxNpeMhNpeId npeId)

This function will display the current state of the IxNpeMh component.

PUBLIC IX\_STATUS ixNpeMhShowReset (IxNpeMhNpeId npeId)

Functions 340

## **Detailed Description**

The public API for the IXP400 NPE Message Handler component.

## **Define Documentation**

#### #define IX\_NPEMH\_CRITICAL\_NPE\_ERR

NpeMH function return value for a Critical NPE error occurring during sending/receiving message. Assume NPE hang / halt if this value is returned.

Definition at line **44** of file **IxNpeMh.h**.

#### #define IX\_NPEMH\_MAX\_MESSAGE\_ID

maximum valid message ID

Definition at line **32** of file **IxNpeMh.h**.

#### #define IX\_NPEMH\_MIN\_MESSAGE\_ID

minimum valid message ID

Definition at line **31** of file **IxNpeMh.h**.

#### #define IX\_NPEMH\_SEND\_RETRIES\_DEFAULT

default msg send retries

Definition at line **34** of file **IxNpeMh.h**.

## **Typedef Documentation**

#### IxNpeMhCallback

This prototype shows the format of a message callback function.

This prototype shows the format of a message callback function. The message callback will be passed the message to be handled and will also be told from which NPE the message was received. The message callback will either be registered by <code>ixNpeMhUnsolicitedCallbackRegister()</code> or passed as a parameter to <code>ixNpeMhMessageWithResponseSend()</code>. It will be called from within an ISR triggered by the NPE's "outFIFO not empty" interrupt (see <code>ixNpeMhInitialize())</code>. The parameters passed are the ID of the NPE that the message was received from, and the message to be handled.

**Re-entrancy:** This function is only a prototype, and will be implemented by the client. It does not need to be re-entrant.

Definition at line 109 of file IxNpeMh.h.

typedef UINT32 IxNpeMhMessageId

message ID

Definition at line **90** of file **IxNpeMh.h**.

## **Enumeration Type Documentation**

#### enum IxNpeMhNpeId

The ID of a particular NPE.

#### Note:

In this context, for B0 Silicon of the Intel (R) IXP42X Product Line:

- ♦ NPE-A has HDLC, HSS, AAL and UTOPIA Coprocessors.
- ♦ NPE–B has Ethernet Coprocessor.
- ♦ NPE-C has Ethernet, AES, DES and HASH Coprocessors.
- ♦ Intel (R) IXP4XX Product Line of Network Processors have different combinations of coprocessors.

#### **Enumeration values:**

*IX\_NPEMH\_NPEID\_NPEA* ID for NPE-A.

*IX\_NPEMH\_NPEID\_NPEB* ID for NPE-B.

IX\_NPEMH\_NPEID\_NPEC ID for NPE-C.

*IX\_NPEMH\_NUM\_NPES* Number of NPEs.

Definition at line **58** of file **IxNpeMh.h**.

#### enum IxNpeMhNpeInterrupts

Indicator specifying whether or not NPE interrupts should drive receiving of messages from the NPEs.

#### **Enumeration values:**

*IX\_NPEMH\_NPEINTERRUPTS\_NO* Don't use NPE interrupts.

Definition at line **73** of file **IxNpeMh.h**.

## **Function Documentation**

IX\_STATUS ixNpeMhInitialize ( **IxNpeMhNpeInterrupts** *npeInterrupts* )

This function will initialise the IxNpeMh component.

#### Parameters:

npeInterrupts **IxNpeMhNpeInterrupts** [in] – This parameter dictates whether or not the IxNpeMh component will service NPE "outFIFO not empty" interrupts to trigger receiving and processing of messages from the NPEs. If not then the client must use **ixNpeMhMessagesReceive()** to control message receiving and processing.

This function will initialise the IxNpeMh component. It should only be called once, prior to using the IxNpeMh component. The following actions will be performed by this function:

- 1. Initialization of internal data structures (e.g. solicited and unsolicited callback tables).
- 2. Configuration of the interface with the NPEs (e.g. enabling of NPE "outFIFO not empty" interrupts).
- 3. Registration of ISRs that will receive and handle messages when the NPEs' "outFIFO not empty" interrupts fire (if npeInterrupts equals IX\_NPEMH\_NPEINTERRUPTS\_YES).

#### Returns:

The function returns a status indicating success or failure.

```
IX_STATUS ixNpeMhMessageSend ( IxNpeMhNpeId npeId, IxNpeMhMessage message, UINT32 maxSendRetries )
```

This function will send a message to a particular NPE.

#### Parameters:

```
    npeId IxNpeMhNpeId [in] – The ID of the NPE to send the message to.
    message IxNpeMhMessage [in] – The message to send.
    maxSendRetries UINT32 [in] – Max num. of retries to perform if the NPE's inFIFO is full.
```

This function will send a message to a particular NPE. It will be the client's responsibility to ensure that the message is properly formed. The return status will signify to the client if the message was successfully sent or not.

If the message is sent to the NPE then this function will return a status of success. Note that this will only mean the message has been placed in the NPE's inFIFO. There will be no way of knowing that the NPE has actually read the message, but once in the incoming message queue it will be safe to assume that the NPE

will process it.

The inFIFO may fill up sometimes if the Xscale is sending messages faster than the NPE can handle them. This forces us to retry attempts to send the message until the NPE services the inFIFO. The client should specify a ceiling value for the number of retries suitable to their needs.

IX\_NPEMH\_SEND\_RETRIES\_DEFAULT can be used as a default value for the *maxSendRetries* parameter for this function. Each retry exceeding this default number will incur a blocking delay of 1 microsecond, to avoid consuming too much AHB bus bandwidth while performing retries.

Note this function **must** only be used for messages. that do not solicit responses. If the message being sent will solicit a response then the **ixNpeMhMessageWithResponseSend()** function **must** be used to ensure that the response is correctly handled.

This function will return timeout status if NPE hang / halt while sending message. The timeout error is not related to the *maxSendRetries* as mentioned above. The timeout error will only occur if the first word of the message has been sent to NPE (not exceeding *maxSendRetries* when sending 1st message word), but the second word of the message can't be written to NPE's inFIFO due to NPE hang / halt after maximum waiting time (IX NPE MH MAX NUM OF RETRIES).

**Re-entrancy:** This function will be callable from any thread at any time. IxOsal will be used for any necessary resource protection.

#### Returns:

The function returns a status indicating success, failure or timeout.

#### IX\_STATUS ixNpeMhMessagesReceive ( **IxNpeMhNpeId** npeId )

This function will receive messages from a particular NPE and pass each message to the client via a solicited callback (for solicited messages) or an unsolicited callback (for unsolicited messages).

#### Parameters:

npeld **IxNpeMhNpeld** [in] – The ID of the NPE to receive and process messages from.

This function will receive messages from a particular NPE and pass each message to the client via a solicited callback (for solicited messages) or an unsolicited callback (for unsolicited messages).

If the IxNpeMh component is initialised to service NPE "outFIFO not empty" interrupts (see **ixNpeMhInitialize()**) then there is no need to call this function. This function is only provided as an alternative mechanism to control the receiving and processing of messages from the NPEs.

This function will return timeout status if NPE hang / halt while receiving message. The timeout error will only occur if this function has read the first word of the message and can't read second word of the message from NPE's outFIFO after maximum retries (IX\_NPE\_MH\_MAX\_NUM\_OF\_RETRIES).

Note this function cannot be called from within an ISR as it will use resource protection mechanisms.

**Re–entrancy:** This function will be callable from any thread at any time. IxOsal will be used for any necessary resource protection.

#### Returns:

The function returns a status indicating success, failure or timeout.

```
IX_STATUS ixNpeMhMessageWithResponseSend ( IxNpeMhNpeId npeId, IxNpeMhMessage message, IxNpeMhMessageId solicitedMessageId, IxNpeMhCallback volicitedCallback, UINT32 maxSendRetries
```

This function is equivalent to the **ixNpeMhMessageSend()** function, but must be used when the message being sent will solicited a response.

#### Parameters:

*npeId* **IxNpeMhNpeId** [in] – The ID of the NPE to send the message to.

message [in] – The message to send.

solicitedMessageId IxNpeMhMessageId [in] - The ID of the solicited response message.

solicitedCallback IxNpeMhCallback [in] – The function to use to pass the response message

back to the client. A value of NULL will cause the response message to be

discarded.

maxSendRetries UINT32 [in] – Max num. of retries to perform if the NPE's inFIFO is full.

This function is equivalent to the **ixNpeMhMessageSend()** function, but must be used when the message being sent will solicited a response.

The client must specify the ID of the solicited response message to allow the response to be recognised when it is received. The client must also specify a callback function to handle the received response. The IxNpeMh component will not offer the facility to send a message to a NPE and receive a response within the same context.

Note if the client is not interested in the response, specifying a NULL callback will cause the response message to be discarded.

The solicited callback will be stored and called some time later from an ISR that will be triggered by the NPE's "outFIFO not empty" interrupt (see **ixNpeMhInitialize()**) to handle the response message corresponding to the message sent. Response messages will be handled in the order they are received.

The inFIFO may fill up sometimes if the Xscale is sending messages faster than the NPE can handle them. This forces us to retry attempts to send the message until the NPE services the inFIFO. The client should specify a ceiling value for the number of retries suitable to their needs.

IX\_NPEMH\_SEND\_RETRIES\_DEFAULT can be used as a default value for the *maxSendRetries* parameter for this function. Each retry exceeding this default number will incur a blocking delay of 1 microsecond, to avoid consuming too much AHB bus bandwidth while performing retries.

This function will return timeout status if NPE hang / halt while sending message. The timeout error is not related to the *maxSendRetries* as mentioned above. The timeout error will only occur if the first word of the message has been sent to NPE (not exceeding *maxSendRetries* when sending 1st message word), but the second word of the message can't be written to NPE's inFIFO due to NPE hang / halt after maximum waiting time (IX\_NPE\_MH\_MAX\_NUM\_OF\_RETRIES).

**Re-entrancy:** This function will be callable from any thread at any time. IxOsal will be used for any necessary resource protection.

#### Returns:

The function returns a status indicating success or failure.

#### IX\_STATUS ixNpeMhShow ( **IxNpeMhNpeId** npeId )

This function will display the current state of the IxNpeMh component.

**Re-entrancy:** This function will be callable from any thread at any time. However, no resource protection will be used so as not to impact system performance. As this function is only reading statistical information then this is acceptable.

#### Parameters:

npeId **IxNpeMhNpeId** [in] – The ID of the NPE to display state information for.

#### Returns:

The function returns a status indicating success or failure.

#### IX\_STATUS ixNpeMhShowReset ( IxNpeMhNpeId npeId )

This function will reset the current state of the IxNpeMh component.

**Re-entrancy:** This function will be callable from any thread at any time. However, no resource protection will be used so as not to impact system performance. As this function is only writing statistical information then this is acceptable.

#### Parameters:

*npeld* **IxNpeMhNpeId** [in] – The ID of the NPE to reset state information for.

#### Returns:

The function returns a status indicating success or failure.

#### IX\_STATUS ixNpeMhUnload ( void )

This function will uninitialise the IxNpeMh component.

This function will uninitialise the IxNpeMh component. It should only be called once, and only if the IxNpeMh component has already been initialised. No other IxNpeMh API functions should be called until **ixNpeMhInitialize** is called again. If possible, this function should be called before a soft reboot or unloading a kernel module to perform any clean up operations required for IxNpeMh.

The following actions will be performed by this function:

1. Unmapping of kernel memory mapped by the function **ixNpeMhInitialize**.

#### Returns:

The function returns a status indicating success or failure.

IX\_STATUS ixNpeMhUnsolicitedCallbackForRangeRegister ( IxNpeMhNpeId npeId, IxNpeMhMessageId minMessageId, IxNpeMhMessageId maxMessageId, IxNpeMhCallback unsolicitedCallback )

This function will register an unsolicited callback for a particular NPE and range of message IDs.

#### Parameters:

npeId IxNpeMhNpeId [in] – The ID of the NPE whose messages the unsolicited

callback will handle.

IDs the unsolicited callback will handle.

maxMessageId IxNpeMhMessageId [in] – The maximum message ID in the range of

message IDs the unsolicited callback will handle.

unsolicitedCallback IxNpeMhCallback [in] - The unsolicited callback function. A value of NULL

will deregister any previously registered callback(s) for this NPE and range of

message IDs.

This function will register an unsolicited callback for a particular NPE and range of message IDs. It is a convenience function that is effectively the same as calling **ixNpeMhUnsolicitedCallbackRegister()** for each ID in the specified range. See **ixNpeMhUnsolicitedCallbackRegister()** for more information.

**Re-entrancy:** This function will be callable from any thread at any time. IxOsal will be used for any necessary resource protection.

#### Returns:

The function returns a status indicating success or failure.

IX\_STATUS ixNpeMhUnsolicitedCallbackRegister ( IxNpeMhNpeId npeId, IxNpeMhMessageId messageId, IxNpeMhCallback unsolicitedCallback )

This function will register an unsolicited callback for a particular NPE and message ID.

#### Parameters:

npeld IxNpeMhNpeId [in] – The ID of the NPE whose messages the unsolicited

callback will handle.

will handle.

unsolicitedCallback IxNpeMhCallback [in] - The unsolicited callback function. A value of NULL

will deregister any previously registered callback for this NPE and message

ID.

This function will register an unsolicited message callback for a particular NPE and message ID.

If an unsolicited callback is already registered for the specified NPE and message ID then the callback will be overwritten. Only one client will be responsible for handling a particular message ID associated with a NPE. Registering a NULL unsolicited callback will deregister any previously registered callback.

The callback function will be called from an ISR that will be triggered by the NPE's "outFIFO not empty" interrupt (see **ixNpeMhInitialize()**) to handle any unsolicited messages of the specific message ID received from the NPE. Unsolicited messages will be handled in the order they are received.

If no unsolicited callback can be found for a received message then it is assumed that the message is solicited.

If more than one client may be interested in a particular unsolicited message then the suggested strategy is to register a callback for the message that can itself distribute the message to multiple clients as necessary.

See also ixNpeMhUnsolicitedCallbackForRangeRegister().

**Re–entrancy:** This function will be callable from any thread at any time. IxOsal will be used for any necessary resource protection.

#### Returns:

The function returns a status indicating success or failure.

## **IXP400 NPE Microcode Image Library**

Library containing a set of NPE firmware images, for use with NPE Downloader s/w component.

## **Defines**

#### #define IX\_NPE\_IMAGE\_INCLUDE

Wrap the following Image identifiers with "#if IX\_NPE\_IMAGE\_INCLUDE ... #endif" to include the image in library.

#### #define IX\_NPE\_IMAGE\_OMIT

Wrap the following Image identifiers with "#if IX\_NPE\_IMAGE\_OMIT ... #endif" to OMIT the image from the

#### #define IX\_NPEDL\_NPEIMAGE\_NPEA\_HSS0

NPE Image Id for NPE-A with HSS-0 Only feature. It supports 32 channelized and 4 packetized.

#### #define IX\_NPEDL\_NPEIMAGE\_NPEA\_HSS0\_ATM\_SPHY\_1\_PORT

NPE Image Id for NPE-A with HSS-0 and ATM feature. For HSS, it supports 16/32 channelized and 4/0 pac For ATM, it supports AAL5, AAL0 and OAM for UTOPIA SPHY, 1 logical port, 32 VCs. It also has Fast Path

#### #define IX\_NPEDL\_NPEIMAGE\_NPEA\_HSS0\_ATM\_MPHY\_1\_PORT

NPE Image Id for NPE-A with HSS-0 and ATM feature. For HSS, it supports 16/32 channelized and 4/0 packers ATM, it supports AAL5, AAL0 and OAM for UTOPIA MPHY, 1 logical port, 32 VCs. It also has Fast Patential Control of the ATM of

#### #define IX\_NPEDL\_NPEIMAGE\_NPEA\_ATM\_MPHY\_12\_PORT

NPE Image Id for NPE-A with ATM-Only feature. It supports AAL5, AAL0 and OAM for UTOPIA MPHY, 1 ports, 32 VCs. It also has Fast Path support.

#### #define IX\_NPEDL\_NPEIMAGE\_NPEA\_DMA

NPE Image Id for NPE-A with DMA-Only feature.

#### #define IX\_NPEDL\_NPEIMAGE\_NPEA\_HSS\_2\_PORT

NPE Image Id for NPE-A with HSS-0 and HSS-1 feature. Each HSS port supports 32 channelized and 4 parts

#### #define IX\_NPEDL\_NPEIMAGE\_NPEA\_ETH

NPE Image Id for NPE-A with Basic Ethernet Rx/Tx which includes: MAC\_FILTERING, MAC\_LEARNING, SPANNING\_TREE, FIREWALL.

#### #define IX\_NPEDL\_NPEIMAGE\_NPEA\_ETH\_LEARN\_FILTER\_SPAN\_FIREWALL

NPE Image Id for NPE-A with Basic Ethernet Rx/Tx which includes: MAC\_FILTERING, MAC\_LEARNING, SPANNING\_TREE, FIREWALL.

#### #define IX\_NPEDL\_NPEIMAGE\_NPEA\_ETH\_LEARN\_FILTER\_SPAN\_FIREWALL\_VLAN\_QOS

NPE Image Id for NPE-A with Ethernet Rx/Tx which includes: MAC\_FILTERING, MAC\_LEARNING, SPANNING\_TREE, FIREWALL, VLAN\_QOS.

#### #define IX\_NPEDL\_NPEIMAGE\_NPEA\_ETH\_SPAN\_FIREWALL\_VLAN\_QOS\_HDR\_CONV

NPE Image Id for NPE-A with Ethernet Rx/Tx which includes: SPANNING\_TREE, FIREWALL, VLAN\_QOS

HEADER\_CONVERSION.

#### #define IX\_NPEDL\_NPEIMAGE\_NPEA\_HSS\_TSLOT\_SWITCH

NPE Image Id for NPE-A with HSS-0 and timeslot switching feature. It supports 32 channelized and 4 packet HSS-0 as well.

- #define IX\_NPEDL\_NPEIMAGE\_NPEA\_ETH\_LEARN\_FILTER\_SPAN\_MASK\_FIREWALL\_VLAN\_QOS\_ NPE Image Id for NPE—A with Basic Ethernet Rx/Tx which includes: MAC\_FILTERING, MAC\_LEARNING, SPANNING\_TREE, MASK\_BASED\_FIREWALL, VLAN\_QOS, EXTENDED MIBII.
- #define IX\_NPEDL\_NPEIMAGE\_NPEA\_ETH\_SPAN\_VLAN\_QOS\_HDR\_CONV\_EXTMIB

  NPE Image Id for NPE—A with Basic Ethernet Rx/Tx which includes: SPANNING\_TREE, VLAN\_QOS,
  HEADER\_CONVERSION, EXTENDED MIBII.
- #define IX\_NPEDL\_NPEIMAGE\_NPEA\_ETH\_SPAN\_MASK\_FIREWALL\_VLAN\_QOS\_HDR\_CONV\_EXT NPE Image Id for NPE—A with Basic Ethernet Rx/Tx which includes: SPANNING\_TREE, MASK\_BASED\_FI. VLAN\_QOS, HEADER\_CONVERSION, EXTENDED MIBII.
- #define IX\_NPEDL\_NPEIMAGE\_NPEB\_ETH

NPE Image Id for NPE-B with Basic Ethernet Rx/Tx which includes: MAC\_FILTERING, MAC\_LEARNING, SPANNING\_TREE, FIREWALL.

#define IX\_NPEDL\_NPEIMAGE\_NPEB\_ETH\_LEARN\_FILTER\_SPAN\_FIREWALL

NPE Image Id for NPE-B with Basic Ethernet Rx/Tx which includes: MAC\_FILTERING, MAC\_LEARNING,

SPANNING\_TREE, FIREWALL.

- #define IX\_NPEDL\_NPEIMAGE\_NPEB\_ETH\_LEARN\_FILTER\_SPAN\_FIREWALL\_VLAN\_QOS

  NPE Image Id for NPE-B with Ethernet Rx/Tx which includes: MAC\_FILTERING, MAC\_LEARNING,
  SPANNING\_TREE, FIREWALL, VLAN\_QOS.
- #define IX\_NPEDL\_NPEIMAGE\_NPEB\_ETH\_SPAN\_FIREWALL\_VLAN\_QOS\_HDR\_CONV

  NPE Image Id for NPE-B with Ethernet Rx/Tx which includes: SPANNING\_TREE, FIREWALL, VLAN\_QOS HEADER\_CONVERSION.
- #define **IX\_NPEDL\_NPEIMAGE\_NPEB\_DMA**NPE Image Id for NPE-B with DMA-Only feature.
- #define IX\_NPEDL\_NPEIMAGE\_NPEB\_ETH\_LEARN\_FILTER\_SPAN\_MASK\_FIREWALL\_VLAN\_QOS\_ NPE Image Id for NPE-B with Basic Ethernet Rx/Tx which includes: MAC\_FILTERING, MAC\_LEARNING, SPANNING\_TREE, MASK\_BASED\_FIREWALL, VLAN\_QOS, EXTENDED MIBII.
- #define IX\_NPEDL\_NPEIMAGE\_NPEB\_ETH\_SPAN\_VLAN\_QOS\_HDR\_CONV\_EXTMIB

  NPE Image Id for NPE—B with Basic Ethernet Rx/Tx which includes: SPANNING\_TREE, VLAN\_QOS,
  HEADER CONVERSION, EXTENDED MIBII.
- #define IX\_NPEDL\_NPEIMAGE\_NPEB\_ETH\_SPAN\_MASK\_FIREWALL\_VLAN\_QOS\_HDR\_CONV\_EXT NPE Image Id for NPE—B with Basic Ethernet Rx/Tx which includes: SPANNING\_TREE, MASK\_BASED\_FIVLAN\_QOS, HEADER\_CONVERSION, EXTENDED MIBII.
- #define IX\_NPEDL\_NPEIMAGE\_NPEC\_ETH

NPE Image Id for NPE-C with Basic Ethernet Rx/Tx which includes: MAC\_FILTERING, MAC\_LEARNING, SPANNING\_TREE, FIREWALL.

- #define IX\_NPEDL\_NPEIMAGE\_NPEC\_ETH\_LEARN\_FILTER\_SPAN\_FIREWALL
  - NPE Image Id for NPE-C with Basic Ethernet Rx/Tx which includes: MAC\_FILTERING, MAC\_LEARNING, SPANNING\_TREE, FIREWALL.
- #define IX\_NPEDL\_NPEIMAGE\_NPEC\_ETH\_LEARN\_FILTER\_SPAN\_FIREWALL\_VLAN\_QOS

  NPE Image Id for NPE-C with Ethernet Rx/Tx which includes: MAC\_FILTERING, MAC\_LEARNING,
  SPANNING\_TREE, FIREWALL, VLAN\_QOS.
- #define IX\_NPEDL\_NPEIMAGE\_NPEC\_ETH\_SPAN\_FIREWALL\_VLAN\_QOS\_HDR\_CONV

  NPE Image Id for NPE-C with Ethernet Rx/Tx which includes: SPANNING\_TREE, FIREWALL, VLAN\_QOS\_HEADER\_CONVERSION.
- #define **IX\_NPEDL\_NPEIMAGE\_NPEA\_WEP**NPE Image Id for NPE-A with ARC4 and WEP CRC engines.
- #define IX\_NPEDL\_NPEIMAGE\_NPEC\_CRYPTO\_ETH\_LEARN\_FILTER\_SPAN\_FIREWALL

  NPE Image Id for NPE-C with Crypto and Basic Ethernet Rx/Tx which includes: MAC\_FILTERING,

  MAC\_LEARNING, SPANNING\_TREE, FIREWALL.
- #define IX\_NPEDL\_NPEIMAGE\_NPEC\_CRYPTO\_AES\_CCM\_ETH

  NPE Image Id for NPE-C with AES and CCM Crypto and Basic Ethernet Rx/Tx.
- #define IX\_NPEDL\_NPEIMAGE\_NPEC\_CRYPTO\_AES\_ETH\_LEARN\_FILTER\_FIREWALL

  NPE Image Id for NPE-C with AES Crypto and Basic Ethernet Rx/Tx which includes: MAC\_FILTERING,

  MAC\_LEARNING, FIREWALL.
- #define IX\_NPEDL\_NPEIMAGE\_NPEC\_CRYPTO\_AES\_ETH\_LEARN\_FILTER\_SPAN

  NPE Image Id for NPE-C with AES Crypto and Basic Ethernet Rx/Tx which includes: MAC\_FILTERING,

  MAC\_LEARNING, SPANNING\_TREE.
- #define **IX\_NPEDL\_NPEIMAGE\_NPEC\_DMA**NPE Image Id for NPE-C with DMA-Only feature.
- #define IX\_NPEDL\_NPEIMAGE\_NPEC\_ETH\_LEARN\_FILTER\_SPAN\_MASK\_FIREWALL\_VLAN\_QOS\_ NPE Image Id for NPE-C with Basic Ethernet Rx/Tx which includes: MAC\_FILTERING, MAC\_LEARNING, SPANNING\_TREE, MASK\_BASED\_FIREWALL, VLAN\_QOS, EXTENDED MIBII.
- #define IX\_NPEDL\_NPEIMAGE\_NPEC\_ETH\_SPAN\_VLAN\_QOS\_HDR\_CONV\_EXTMIB

  NPE Image Id for NPE-C with Basic Ethernet Rx/Tx which includes: SPANNING\_TREE, VLAN\_QOS,
  HEADER\_CONVERSION, EXTENDED MIBII.
- #define IX\_NPEDL\_NPEIMAGE\_NPEC\_ETH\_SPAN\_MASK\_FIREWALL\_VLAN\_QOS\_HDR\_CONV\_EXT NPE Image Id for NPE—C with Basic Ethernet Rx/Tx which includes: SPANNING\_TREE, MASK\_BASED\_FIVLAN\_QOS, HEADER\_CONVERSION, EXTENDED MIBII.
- #define IX\_NPE\_MICROCODE\_AVAILABLE\_VERSIONS\_COUNT

## **Detailed Description**

Library containing a set of NPE firmware images, for use with NPE Downloader s/w component.

## **Define Documentation**

#### #define IX\_NPE\_IMAGE\_INCLUDE

Wrap the following Image identifiers with "#if IX\_NPE\_IMAGE\_INCLUDE ... #endif" to include the image in the library.

Definition at line **29** of file **IxNpeMicrocode.h**.

#### #define IX\_NPE\_IMAGE\_OMIT

Wrap the following Image identifiers with "#if IX\_NPE\_IMAGE\_OMIT ... #endif" to OMIT the image from the library.

Definition at line **36** of file **IxNpeMicrocode.h**.

#### #define IX\_NPEDL\_NPEIMAGE\_NPEA\_ATM\_MPHY\_12\_PORT

NPE Image Id for NPE-A with ATM-Only feature. It supports AAL5, AAL0 and OAM for UTOPIA MPHY, 12 logical ports, 32 VCs. It also has Fast Path support.

Definition at line **72** of file **IxNpeMicrocode.h**.

#### #define IX\_NPEDL\_NPEIMAGE\_NPEA\_DMA

NPE Image Id for NPE-A with DMA-Only feature.

Definition at line **81** of file **IxNpeMicrocode.h**.

#### #define IX\_NPEDL\_NPEIMAGE\_NPEA\_ETH

NPE Image Id for NPE-A with Basic Ethernet Rx/Tx which includes: MAC\_FILTERING, MAC\_LEARNING, SPANNING\_TREE, FIREWALL.

Definition at line **99** of file **IxNpeMicrocode.h**.

#### #define IX NPEDL NPEIMAGE NPEA ETH LEARN FILTER SPAN FIREWALL

NPE Image Id for NPE-A with Basic Ethernet Rx/Tx which includes: MAC\_FILTERING, MAC\_LEARNING, SPANNING\_TREE, FIREWALL.

Definition at line **108** of file **IxNpeMicrocode.h**.

#define IX\_NPEDL\_NPEIMAGE\_NPEA\_ETH\_LEARN\_FILTER\_SPAN\_FIREWALL\_VLAN\_QOS

NPE Image Id for NPE-A with Ethernet Rx/Tx which includes: MAC\_FILTERING, MAC\_LEARNING, SPANNING\_TREE, FIREWALL, VLAN\_QOS.

Definition at line 117 of file IxNpeMicrocode.h.

#### #define

IX\_NPEDL\_NPEIMAGE\_NPEA\_ETH\_LEARN\_FILTER\_SPAN\_MASK\_FIREWALL\_VLAN\_QOS\_EXTMIB

NPE Image Id for NPE-A with Basic Ethernet Rx/Tx which includes: MAC\_FILTERING, MAC\_LEARNING, SPANNING\_TREE, MASK\_BASED\_FIREWALL, VLAN\_QOS, EXTENDED MIBII.

Definition at line **144** of file **IxNpeMicrocode.h**.

#define IX\_NPEDL\_NPEIMAGE\_NPEA\_ETH\_SPAN\_FIREWALL\_VLAN\_QOS\_HDR\_CONV

NPE Image Id for NPE-A with Ethernet Rx/Tx which includes: SPANNING\_TREE, FIREWALL, VLAN\_QOS, HEADER\_CONVERSION.

Definition at line **126** of file **IxNpeMicrocode.h**.

#### #define

IX\_NPEDL\_NPEIMAGE\_NPEA\_ETH\_SPAN\_MASK\_FIREWALL\_VLAN\_QOS\_HDR\_CONV\_EXTMIB

NPE Image Id for NPE-A with Basic Ethernet Rx/Tx which includes: SPANNING\_TREE, MASK\_BASED\_FIREWALL, VLAN\_QOS, HEADER\_CONVERSION, EXTENDED MIBII.

Definition at line 162 of file IxNpeMicrocode.h.

#define IX\_NPEDL\_NPEIMAGE\_NPEA\_ETH\_SPAN\_VLAN\_QOS\_HDR\_CONV\_EXTMIB

NPE Image Id for NPE-A with Basic Ethernet Rx/Tx which includes: SPANNING\_TREE, VLAN\_QOS, HEADER\_CONVERSION, EXTENDED MIBII.

Definition at line **153** of file **IxNpeMicrocode.h**.

#### #define IX NPEDL NPEIMAGE NPEA HSS0

NPE Image Id for NPE-A with HSS-0 Only feature. It supports 32 channelized and 4 packetized.

Definition at line **45** of file **IxNpeMicrocode.h**.

#### #define IX\_NPEDL\_NPEIMAGE\_NPEA\_HSS0\_ATM\_MPHY\_1\_PORT

NPE Image Id for NPE-A with HSS-0 and ATM feature. For HSS, it supports 16/32 channelized and 4/0 packetized. For ATM, it supports AAL5, AAL0 and OAM for UTOPIA MPHY, 1 logical port, 32 VCs. It also has Fast Path support.

Definition at line **63** of file **IxNpeMicrocode.h**.

#### #define IX\_NPEDL\_NPEIMAGE\_NPEA\_HSS0\_ATM\_SPHY\_1\_PORT

NPE Image Id for NPE-A with HSS-0 and ATM feature. For HSS, it supports 16/32 channelized and 4/0 packetized. For ATM, it supports AAL5, AAL0 and OAM for UTOPIA SPHY, 1 logical port, 32 VCs. It also has Fast Path support.

Definition at line **54** of file **IxNpeMicrocode.h**.

#### #define IX\_NPEDL\_NPEIMAGE\_NPEA\_HSS\_2\_PORT

NPE Image Id for NPE-A with HSS-0 and HSS-1 feature. Each HSS port supports 32 channelized and 4 packetized.

Definition at line 90 of file IxNpeMicrocode.h.

#### #define IX\_NPEDL\_NPEIMAGE\_NPEA\_HSS\_TSLOT\_SWITCH

NPE Image Id for NPE-A with HSS-0 and timeslot switching feature. It supports 32 channelized and 4 packetized on HSS-0 as well.

Definition at line **135** of file **IxNpeMicrocode.h**.

#### #define IX\_NPEDL\_NPEIMAGE\_NPEA\_WEP

NPE Image Id for NPE-A with ARC4 and WEP CRC engines.

Definition at line **279** of file **IxNpeMicrocode.h**.

#### #define IX NPEDL NPEIMAGE NPEB DMA

NPE Image Id for NPE-B with DMA-Only feature.

Definition at line **207** of file **IxNpeMicrocode.h**.

#### #define IX\_NPEDL\_NPEIMAGE\_NPEB\_ETH

NPE Image Id for NPE-B with Basic Ethernet Rx/Tx which includes: MAC\_FILTERING, MAC\_LEARNING, SPANNING\_TREE, FIREWALL.

Definition at line **171** of file **IxNpeMicrocode.h**.

#### #define IX\_NPEDL\_NPEIMAGE\_NPEB\_ETH\_LEARN\_FILTER\_SPAN\_FIREWALL

NPE Image Id for NPE-B with Basic Ethernet Rx/Tx which includes: MAC\_FILTERING, MAC\_LEARNING, SPANNING\_TREE, FIREWALL.

Definition at line **180** of file **IxNpeMicrocode.h**.

#### #define IX\_NPEDL\_NPEIMAGE\_NPEB\_ETH\_LEARN\_FILTER\_SPAN\_FIREWALL\_VLAN\_QOS

NPE Image Id for NPE-B with Ethernet Rx/Tx which includes: MAC\_FILTERING, MAC\_LEARNING, SPANNING\_TREE, FIREWALL, VLAN\_QOS.

Definition at line 189 of file IxNpeMicrocode.h.

#### #define

IX NPEDL NPEIMAGE NPEB ETH LEARN FILTER SPAN MASK FIREWALL VLAN QOS EXTMIB

NPE Image Id for NPE-B with Basic Ethernet Rx/Tx which includes: MAC\_FILTERING, MAC\_LEARNING, SPANNING\_TREE, MASK\_BASED\_FIREWALL, VLAN\_QOS, EXTENDED MIBII.

Definition at line **216** of file **IxNpeMicrocode.h**.

#### #define IX\_NPEDL\_NPEIMAGE\_NPEB\_ETH\_SPAN\_FIREWALL\_VLAN\_QOS\_HDR\_CONV

NPE Image Id for NPE-B with Ethernet Rx/Tx which includes: SPANNING\_TREE, FIREWALL, VLAN QOS, HEADER CONVERSION.

Definition at line **198** of file **IxNpeMicrocode.h**.

#### #define

IX\_NPEDL\_NPEIMAGE\_NPEB\_ETH\_SPAN\_MASK\_FIREWALL\_VLAN\_QOS\_HDR\_CONV\_EXTMIB

NPE Image Id for NPE-B with Basic Ethernet Rx/Tx which includes: SPANNING\_TREE, MASK\_BASED\_FIREWALL, VLAN\_QOS, HEADER\_CONVERSION, EXTENDED MIBII.

Definition at line **234** of file **IxNpeMicrocode.h**.

#### #define IX\_NPEDL\_NPEIMAGE\_NPEB\_ETH\_SPAN\_VLAN\_QOS\_HDR\_CONV\_EXTMIB

NPE Image Id for NPE-B with Basic Ethernet Rx/Tx which includes: SPANNING\_TREE, VLAN\_QOS, HEADER\_CONVERSION, EXTENDED MIBII.

Definition at line **225** of file **IxNpeMicrocode.h**.

#### #define IX\_NPEDL\_NPEIMAGE\_NPEC\_CRYPTO\_AES\_CCM\_ETH

NPE Image Id for NPE-C with AES and CCM Crypto and Basic Ethernet Rx/Tx.

Definition at line **297** of file **IxNpeMicrocode.h**.

#### #define IX\_NPEDL\_NPEIMAGE\_NPEC\_CRYPTO\_AES\_ETH\_LEARN\_FILTER\_FIREWALL

NPE Image Id for NPE-C with AES Crypto and Basic Ethernet Rx/Tx which includes: MAC\_FILTERING, MAC\_LEARNING, FIREWALL.

Definition at line **306** of file **IxNpeMicrocode.h**.

#### #define IX NPEDL NPEIMAGE NPEC CRYPTO AES ETH LEARN FILTER SPAN

NPE Image Id for NPE–C with AES Crypto and Basic Ethernet Rx/Tx which includes: MAC\_FILTERING, MAC\_LEARNING, SPANNING\_TREE.

Definition at line **315** of file **IxNpeMicrocode.h**.

#### #define IX\_NPEDL\_NPEIMAGE\_NPEC\_CRYPTO\_ETH\_LEARN\_FILTER\_SPAN\_FIREWALL

NPE Image Id for NPE–C with Crypto and Basic Ethernet Rx/Tx which includes: MAC\_FILTERING, MAC\_LEARNING, SPANNING\_TREE, FIREWALL.

Definition at line **288** of file **IxNpeMicrocode.h**.

#### #define IX NPEDL NPEIMAGE NPEC DMA

NPE Image Id for NPE-C with DMA-Only feature.

Definition at line **324** of file **IxNpeMicrocode.h**.

#### #define IX\_NPEDL\_NPEIMAGE\_NPEC\_ETH

NPE Image Id for NPE–C with Basic Ethernet Rx/Tx which includes: MAC\_FILTERING, MAC\_LEARNING, SPANNING\_TREE, FIREWALL.

Definition at line **243** of file **IxNpeMicrocode.h**.

#### #define IX\_NPEDL\_NPEIMAGE\_NPEC\_ETH\_LEARN\_FILTER\_SPAN\_FIREWALL

NPE Image Id for NPE–C with Basic Ethernet Rx/Tx which includes: MAC\_FILTERING, MAC\_LEARNING, SPANNING\_TREE, FIREWALL.

Definition at line **252** of file **IxNpeMicrocode.h**.

#### #define IX\_NPEDL\_NPEIMAGE\_NPEC\_ETH\_LEARN\_FILTER\_SPAN\_FIREWALL\_VLAN\_QOS

NPE Image Id for NPE-C with Ethernet Rx/Tx which includes: MAC\_FILTERING, MAC\_LEARNING, SPANNING\_TREE, FIREWALL, VLAN\_QOS.

Definition at line **261** of file **IxNpeMicrocode.h**.

#### #define

IX\_NPEDL\_NPEIMAGE\_NPEC\_ETH\_LEARN\_FILTER\_SPAN\_MASK\_FIREWALL\_VLAN\_QOS\_EXTMIB

NPE Image Id for NPE-C with Basic Ethernet Rx/Tx which includes: MAC\_FILTERING, MAC\_LEARNING, SPANNING\_TREE, MASK\_BASED\_FIREWALL, VLAN\_QOS, EXTENDED MIBII.

Definition at line **333** of file **IxNpeMicrocode.h**.

#### #define IX\_NPEDL\_NPEIMAGE\_NPEC\_ETH\_SPAN\_FIREWALL\_VLAN\_QOS\_HDR\_CONV

NPE Image Id for NPE-C with Ethernet Rx/Tx which includes: SPANNING\_TREE, FIREWALL, VLAN QOS, HEADER CONVERSION.

Definition at line **270** of file **IxNpeMicrocode.h**.

#### #define

IX\_NPEDL\_NPEIMAGE\_NPEC\_ETH\_SPAN\_MASK\_FIREWALL\_VLAN\_QOS\_HDR\_CONV\_EXTMIB

NPE Image Id for NPE-C with Basic Ethernet Rx/Tx which includes: SPANNING\_TREE, MASK\_BASED\_FIREWALL, VLAN\_QOS, HEADER\_CONVERSION, EXTENDED MIBII.

Definition at line **351** of file **IxNpeMicrocode.h**.

#### #define IX\_NPEDL\_NPEIMAGE\_NPEC\_ETH\_SPAN\_VLAN\_QOS\_HDR\_CONV\_EXTMIB

NPE Image Id for NPE-C with Basic Ethernet Rx/Tx which includes: SPANNING\_TREE, VLAN\_QOS, HEADER\_CONVERSION, EXTENDED MIBII.

Definition at line 342 of file IxNpeMicrocode.h.

# Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API

The public API for the Parity Error Notifier.

### **Data Structures**

#### struct IxParityENAccAHBErrorTransaction

The Master and Slave on the AHB bus interface whose transaction might have resulted in the parity error notification to Intel XScale(R) Core.

#### struct IxParityENAccAHBErrorTransaction

The Master and Slave on the AHB bus interface whose transaction might have resulted in the parity error notification to Intel XScale(R) Core.

#### struct IxParityENAccAHBErrorTransaction

The Master and Slave on the AHB bus interface whose transaction might have resulted in the parity error notification to Intel XScale(R) Core.

#### struct IxParityENAccEbcConfig

Expansion Bus Controller parity detection is to be enabled or disabled.

#### struct IxParityENAccEbcConfig

Expansion Bus Controller parity detection is to be enabled or disabled.

#### struct IxParityENAccEbcConfig

Expansion Bus Controller parity detection is to be enabled or disabled.

#### struct IxParityENAccEbcParityErrorStats

Expansion Bus Controller parity error statistics.

#### struct IxParityENAccEbcParityErrorStats

Expansion Bus Controller parity error statistics.

#### struct IxParityENAccEbcParityErrorStats

Expansion Bus Controller parity error statistics.

#### struct IxParityENAccHWParityConfig

Parity error configuration of the Hardware Blocks.

#### struct IxParityENAccHWParityConfig

Parity error configuration of the Hardware Blocks.

#### struct IxParityENAccHWParityConfig

Parity error configuration of the Hardware Blocks.

#### struct IxParityENAccMcuConfig

MCU pairty detection is to be enabled/disabled.

#### struct IxParityENAccMcuConfig

MCU pairty detection is to be enabled/disabled.

#### struct IxParityENAccMcuConfig

MCU pairty detection is to be enabled/disabled.

#### struct IxParityENAccMcuParityErrorStats

DDR Memory Control Unit parity error statistics.

#### struct IxParityENAccMcuParityErrorStats

DDR Memory Control Unit parity error statistics.

#### struct IxParityENAccMcuParityErrorStats

DDR Memory Control Unit parity error statistics.

#### struct IxParityENAccNpeConfig

NPE parity detection is to be enabled/disabled.

#### struct IxParityENAccNpeConfig

NPE parity detection is to be enabled/disabled.

#### struct IxParityENAccNpeConfig

NPE parity detection is to be enabled/disabled.

#### struct IxParityENAccNpeParityErrorStats

NPE parity error statistics.

#### struct IxParityENAccNpeParityErrorStats

NPE parity error statistics.

#### struct IxParityENAccNpeParityErrorStats

NPE parity error statistics.

#### $struct \ \ \textbf{IxParityENAccParityErrorContextMessage}$

Parity Error Context Message.

#### struct IxParityENAccParityErrorContextMessage

Parity Error Context Message.

#### struct IxParityENAccParityErrorContextMessage

Parity Error Context Message.

#### struct IxParityENAccParityErrorStats

Parity Error Statistics for the all the hardware blocks.

#### struct IxParityENAccParityErrorStats

Parity Error Statistics for the all the hardware blocks.

#### struct IxParityENAccParityErrorStats

Parity Error Statistics for the all the hardware blocks.

#### struct IxParityENAccPbcConfig

PCI Bus Controller parity detection is to be enabled or disabled.

#### struct IxParityENAccPbcConfig

PCI Bus Controller parity detection is to be enabled or disabled.

#### struct IxParityENAccPbcConfig

PCI Bus Controller parity detection is to be enabled or disabled.

#### struct IxParityENAccPbcParityErrorStats

PCI Bus Controller parity error statistics.

#### struct IxParityENAccPbcParityErrorStats

PCI Bus Controller parity error statistics.

#### struct IxParityENAccPbcParityErrorStats

PCI Bus Controller parity error statistics.

## **Typedefs**

#### typedef UINT32 IxParityENAccParityErrorAddress

The memory location which has parity error.

#### typedef UINT32 IxParityENAccParityErrorData

The data read from the memory location which has parity error.

#### typedef void(\* IxParityENAccCallback )(void)

This prototype shows the format of a callback function.

## **Enumerations**

Typedefs 361

```
enum IxParityENAccConfigOption {
     IX PARITYENACC DISABLE,
     IX_PARITYENACC_ENABLE
     The parity error enable/disable configuration option.
enum IxParityENAccParityErrorSource {
     IX_PARITYENACC_NPE_A_IMEM,
     IX_PARITYENACC_NPE_A_DMEM,
     IX_PARITYENACC_NPE_A_EXT,
     IX_PARITYENACC_NPE_B_IMEM,
     IX PARITYENACC NPE B DMEM,
     IX_PARITYENACC_NPE_B_EXT,
     IX_PARITYENACC_NPE_C_IMEM,
     IX PARITYENACC NPE C DMEM.
     IX_PARITYENACC_NPE_C_EXT,
     IX_PARITYENACC_SWCP,
     IX_PARITYENACC_AQM,
     IX PARITYENACC MCU SBIT,
     IX_PARITYENACC_MCU_MBIT,
     IX_PARITYENACC_MCU_OVERFLOW,
     IX PARITYENACC PBC INITIATOR,
     IX_PARITYENACC_PBC_TARGET,
     IX_PARITYENACC_EBC_CS,
     IX_PARITYENACC_EBC_EXTMST
     The source of the parity error notification.
enum IxParityENAccParityErrorAccess {
     IX_PARITYENACC_READ,
     IX_PARITYENACC_WRITE
     The type of access resulting in parity error.
enum IxParityENAccParityErrorRequester {
     IX_PARITYENACC_MPI,
     IX PARITYENACC AHB BUS
     The requester interface through which the SDRAM memory access resulted in the
    parity error.
enum IxParityENAccAHBErrorMaster {
     IX_PARITYENACC_AHBN_MST_NPE_A,
     IX_PARITYENACC_AHBN_MST_NPE_B,
     IX_PARITYENACC_AHBN_MST_NPE_C,
     IX_PARITYENACC_AHBS_MST_XSCALE,
     IX_PARITYENACC_AHBS MST PBC.
     IX_PARITYENACC_AHBS_MST_EBC,
     IX_PARITYENACC_AHBS_MST_AHB_BRIDGE,
```

Typedefs 362

## IX\_PARITYENACC\_AHBS\_MST\_USBH

The Master on the AHB bus interface whose transaction might have resulted in the parity error notification to Intel XScale(R) Core.

The Slave on the AHB bus interface whose transaction might have resulted in the parity error notification to Intel XScale(R) Core.

## **Functions**

**PUBLIC** 

#### IxParityENAccStatus ixParityENAccInit (void)

This function will initialise the IxParityENAcc component.

#### PUBLICixParityENAccCallbackRegister (IxParityENAccCallback

**IxParityENAccStatus** parityErrNfyCallBack)

This function will register a new callback with IxParityENAcc component. It can also reregister a new callback replacing the old callback.

#### PUBLICixParityENAccParityDetectionConfigure (const

#### IxParityENAccStatus IxParityENAccHWParityConfig \*hwParityConfig)

This interface allows the client application to enable the parity error detection on the underlying hardware block.

# PUBLICixParityENAccParityDetectionQuery (IxParityENAccHWParityConfig \*const IxParityENAccStatus hwParityConfig)

This interface allows the client application to determine the status of the parity error detection on the specified hardware blocks.

#### PUBLIC ixParityENAccParityErrorContextGet

#### IxParityENAccStatus (IxParityENAccParityErrorContextMessage \*const pecMessage)

This interface allows the client application to determine the status of the parity error context on hardware block for which the current parity error interrupt triggered.

#### PUBLICixParityENAccParityErrorInterruptClear (const

#### IxParityENAccStatus IxParityENAccParityErrorContextMessage \*pecMessage)

This interface helps the client application to clear off the interrupt condition on the hardware block identified in the parity error context message. Please refer to the

Functions 363

table below as the operation varies depending on the interrupt source.

#### PUBLICixParityENAccStatsGet (IxParityENAccParityErrorStats \*const

#### IxParityENAccStatus ixParityErrorStats)

This interface allows the client application to retrieve parity error statistics for all the hardware blocks.

**PUBLIC** 

#### IxParityENAccStatus ixParityENAccStatsShow (void)

This interface allows the client application to print all the parity error statistics.

**PUBLIC** 

#### IxParityENAccStatus ixParityENAccStatsReset (void)

This interface allows the client application to reset all the parity error statistics.

## **Detailed Description**

The public API for the Parity Error Notifier.

## **Typedef Documentation**

#### IxParityENAccCallback

This prototype shows the format of a callback function.

The callback will be used to notify the parity error to the client application. The callback will be registered by **ixParityENAccCallbackRegister**.

It will be called from an ISR when a parity error is detected and thus needs to follow the interrupt callable function conventions.

Definition at line **418** of file **IxParityENAcc.h**.

#### **IxParityENAccParityErrorAddress**

The memory location which has parity error.

Definition at line **290** of file **IxParityENAcc.h**.

#### **IxParityENAccParityErrorData**

The data read from the memory location which has parity error.

## **Enumeration Type Documentation**

#### enum IxParityENAccAHBErrorMaster

The Master on the AHB bus interface whose transaction might have resulted in the parity error notification to Intel XScale(R) Core .

#### **Enumeration values:**

 $IX\_PARITYENACC\_AHBN\_MST\_NPE\_A$  NPE - A.  $IX\_PARITYENACC\_AHBN\_MST\_NPE\_B$  NPE - B.  $IX\_PARITYENACC\_AHBN\_MST\_NPE\_C$  NPE - C.

IX\_PARITYENACC\_AHBS\_MST\_XSCALE Intel XScale(R) Core Bus Interface Unit.

IX\_PARITYENACC\_AHBS\_MST\_PBC PCI Bus Controller.
IX\_PARITYENACC\_AHBS\_MST\_EBC Expansion Bus Controller.

IX\_PARITYENACC\_AHBS\_MST\_AHB\_BRIDGE AHB Bridge.

IX\_PARITYENACC\_AHBS\_MST\_USBH USB Host Controller.

Definition at line **323** of file **IxParityENAcc.h**.

#### enum IxParityENAccAHBErrorSlave

The Slave on the AHB bus interface whose transaction might have resulted in the parity error notification to Intel XScale(R) Core .

#### **Enumeration values:**

IX\_PARITYENACC\_AHBN\_SLV\_MCU Memory Control Unit.

IX\_PARITYENACC\_AHBN\_SLV\_AHB\_BRIDGE AHB Bridge.

IX\_PARITYENACC\_AHBS\_SLV\_MCU Intel XScale(R) Core Bus Interface Unit.

IX\_PARITYENACC\_AHBS\_SLV\_APB\_BRIDGE APB Bridge.

IX\_PARITYENACC\_AHBS\_SLV\_AQM AQM.

IX\_PARITYENACC\_AHBS\_SLV\_RSARSA (Crypto Bus).IX\_PARITYENACC\_AHBS\_SLV\_PBCPCI Bus Controller.IX\_PARITYENACC\_AHBS\_SLV\_EBCExpansion Bus Controller.IX\_PARITYENACC\_AHBS\_SLV\_USBHUSB Host Controller.

Definition at line **343** of file **IxParityENAcc.h**.

#### enum IxParityENAccConfigOption

The parity error enable/disable configuration option.

#### **Enumeration values:**

IX\_PARITYENACC\_DISABLE Disable parity error detection.

IX\_PARITYENACC\_ENABLE Enable parity error detection.

Definition at line 69 of file IxParityENAcc.h.

#### enum IxParityENAccParityErrorAccess

The type of access resulting in parity error.

#### **Enumeration values:**

Definition at line **277** of file **IxParityENAcc.h**.

#### enum IxParityENAccParityErrorRequester

The requester interface through which the SDRAM memory access resulted in the parity error.

#### Enumeration values:

IX\_PARITYENACC\_MPI Direct Memory Port Interface.
IX PARITYENACC AHB BUS South or North AHB Bus.

Definition at line **309** of file **IxParityENAcc.h**.

#### enum IxParityENAccParityErrorSource

The source of the parity error notification.

#### Enumeration values:

IX\_PARITYENACC\_NPE\_A\_IMEM NPE A – Instruction memory. IX\_PARITYENACC\_NPE\_A\_DMEM NPE A – Data memory. IX\_PARITYENACC\_NPE\_A\_EXT NPE A – External Entity. IX\_PARITYENACC\_NPE\_B\_IMEM NPE B – Instruction memory. IX\_PARITYENACC\_NPE\_B\_DMEM NPE B – Data memory. IX\_PARITYENACC\_NPE\_B\_EXT NPE B – External Entity. IX PARITYENACC NPE C IMEM NPE C – Instruction memory. IX\_PARITYENACC\_NPE\_C\_DMEM NPE C – Data memory. IX\_PARITYENACC\_NPE\_C\_EXT NPE C – External Entity. IX\_PARITYENACC\_SWCP SWCP.

 $IX\_PARITYENACC\_AQM$  AQM.

IX\_PARITYENACC\_MCU\_SBIT
 IX\_PARITYENACC\_MCU\_MBIT
 IX\_PARITYENACC\_MCU\_OVERFLOW
 DDR Memory Controller Unit – Multi bit parity.
 IX\_PARITYENACC\_MCU\_OVERFLOW
 DDR Memory Controller Unit – Parity errors in excess

of two.

IX\_PARITYENACC\_PBC\_INITIATORPCI Bus Controller as Initiator.IX\_PARITYENACC\_PBC\_TARGETPCI Bus Controller as Target.

IX\_PARITYENACC\_EBC\_CS Expansion Bus Controller – Chip Select.

IX\_PARITYENACC\_EBC\_EXTMST Expansion Bus Controller – External Master.

Definition at line **248** of file **IxParityENAcc.h**.

#### enum IxParityENAccParityType

Odd or Even Parity Type.

#### **Enumeration values:**

IX\_PARITYENACC\_EVEN\_PARITYEven

Parity.

IX\_PARITYENACC\_ODD\_PARITY Odd

Parity.

Definition at line **56** of file **IxParityENAcc.h**.

#### enum IxParityENAccStatus

The status as returend from the API.

#### **Enumeration values:**

IX\_PARITYENACC\_SUCCESS The request is successful.

IX\_PARITYENACC\_INVALID\_PARAMETERS Invalid or NULL parameters passed.

IX\_PARITYENACC\_NOT\_INITIALISED Access layer has not been initialised before

accessing the APIs.

IX\_PARITYENACC\_ALREADY\_INITIALISED Access layer has already been initialised.

IX\_PARITYENACC\_OPERATION\_FAILED Operation did not succeed due to hardware failure.

IX\_PARITYENACC\_NO\_PARITY No parity condition exits or has already been

cleared.

Definition at line **39** of file **IxParityENAcc.h**.

## **Function Documentation**

| IxParityENAccStatus           | ( IxParityENAccCallback parityErrNfyCallBack ) |
|-------------------------------|------------------------------------------------|
| ixParityENAccCallbackRegister |                                                |

This function will register a new callback with IxParityENAcc component. It can also reregister a new callback replacing the old callback.

#### Parameters:

parityErrNfyCallBack [in] – This parameter will specify the call–back function supplied by the client application.

This interface registers the user application supplied call-back handler with the parity error handling access component after the init.

The callback function will be called from an ISR that will be triggered by the parity error in the IXP400 silicon.

The following actions will be performed by this function:

1. Check for the prior initialisation of the module before registering or re–registering of the callback. Check for parity error detection disabled before re–registration of the callback.

Re-entrant : NoISR Callable : No

#### Returns:

- ♦ IX\_PARITYENACC\_SUCCESS The parameters check passed and the registration is successful.
- ♦ IX\_PARITYENACC\_INVALID\_PARAMETERS Request failed due to NULL parameter passed.
- ♦ IX\_PARITYENACC\_OPERATION\_FAILED The request failed because the parity error detection not yet disabled.
- ♦ IX\_PARITYENACC\_NOT\_INITIALISED The operation requested prior to the initialisation of the access layer.

#### **IxParityENAccStatus** ixParityENAccInit (void )

This function will initialise the IxParityENAcc component.

This function will initialise the IxParityENAcc component. It should only be called once, prior to using the IxParityENAcc component.

1. It initialises the internal data structures, registers the ISR that will be triggered when a parity error occurs in the supported Intel (R) IXP4XX Product Line of Network processors.

Re–entrant : NoISR Callable : No

#### Returns:

- ♦ IX\_PARITYENACC\_SUCCESS Initialization is successful
- ♦ IX\_PARITYENACC\_ALREADY\_INITIALISED The access layer has already been initialized
- ♦ IX\_PARITYENACC\_OPERATION\_FAILED The request failed because the operation

didn't succeed on the hardware. Refer to error trace/log for details.

| IxParityENAccStatus                   | ( const                       | hwParityConfig ) |
|---------------------------------------|-------------------------------|------------------|
| ixParityENAccParityDetectionConfigure | IxParityENAccHWParityConfig * |                  |

This interface allows the client application to enable the parity error detection on the underlying hardware block.

#### Parameters:

hwParityConfig [in] – Hardware blocks for which the parity error detection is to be enabled or disabled.

The client application allocates and provides the reference to the buffer.

It will also verify whether the specific hardware block is functional or not.

NOTE: Failure in enabling or disabling of one or more components result in trace message but still returns IX\_PARITYENACC\_SUCCESS. Refer to the function **ixParityENAccParityDetectionQuery** on how to verify the failures while enabling/disabling paritys error detection.

It shall be invoked after the Init and CallbackRegister functions but before any other function of the IxParityENAcc layer.

Re–entrant : NoISR Callable : No

#### Returns:

- ♦ IX\_PARITYENACC\_SUCCESS The parameters check passed and the request to enable/disable is successful.
- ♦ IX\_PARITYENACC\_INVALID\_PARAMETERS—The request failed due to NULL parameter supplied.
- ♦ IX\_PARITYENACC\_OPERATION\_FAILED The request failed because the operation didn't succeed on the hardware.
- ♦ IX\_PARITYENACC\_NOT\_INITIALISED The operation requested prior to the initialisation of the access layer.

| IxParityENAccStatus               | ( IxParityENAccHWParityConfig | hwParityConfig ) |
|-----------------------------------|-------------------------------|------------------|
| ixParityENAccParityDetectionQuery | *const                        |                  |

This interface allows the client application to determine the status of the parity error detection on the specified hardware blocks.

#### Parameters:

hwParityConfig [out] – Hardware blocks whose parity error detection has been enabled or disabled.

The client application allocates and provides the reference to the buffer.

This interface can be used immediately after the interface **ixParityENAccParityDetectionConfigure** to see on which of the hardware blocks the parity error detection has either been enabled or disabled based on the client application request.

Re–entrant : NoISR Callable : No

#### Returns:

- ♦ IX\_PARITYENACC\_SUCCESS The parameters check passed and the request to query on whether the hardware parity error detection is enabled or disabled is successful.
- ♦ IX\_PARITYENACC\_INVALID\_PARAMETERS—The request failed due to NULL parameter or invalid values supplied.
- ♦ IX\_PARITYENACC\_NOT\_INITIALISED The operation requested prior to the initialisation of the access layer.

# IxParityENAccStatus (IxParityENAccParityErrorContextMessage pecMessage ) ixParityENAccParityErrorContextGet \*const

This interface allows the client application to determine the status of the parity error context on hardware block for which the current parity error interrupt triggered.

#### Parameters:

pecMessage [out] – The parity error context information of the parity interrupt currently being process.

The client application allocates and provides the reference to the buffer.

Refer to the data structure IxParityENAccParityErrorContextMessage for details.

The routine will will fetch the parity error context in the following priority, if multiple parity errors observed.

```
0 - MCU (Multi-bit and single-bit in that order)
1 - NPE-A
2 - NPE-B
3 - NPE-C
4 - SWCP
5 - QM
6 - PCI
7 - EXP
```

NOTE: The information provided in the IxParityENAccAHBErrorTransaction may be of help for the client application to decide on the course of action to take. This info is taken from the Performance Monitoring Unit register which records most recent error observed on the AHB bus. This information might have been overwritten by some other error by the time it is retrieved.

Re-entrant : NoISR Callable : Yes

#### Returns:

- ♦ IX\_PARITYENACC\_SUCCESS—The parameters check passed and the request to get the parity error context information is successful.
- ♦ IX\_PARITYENACC\_INVALID\_PARAMETERS—The request failed due to NULL parameter is passed
- ♦ IX\_PARITYENACC\_OPERATION\_FAILED The request failed because the operation didn't succeed on the hardware.
- ♦ IX\_PARITYENACC\_NOT\_INITIALISED The operation requested prior to the initialisation of the access layer.
- ♦ IX\_PARITYENACC\_NO\_PARITY No parity condition exits or has already been cleared

| IxParityENAccStatus                    | ( const                                  | pecMessage ) |
|----------------------------------------|------------------------------------------|--------------|
| ixParityENAccParityErrorInterruptClear | IxParityENAccParityErrorContextMessage * |              |

This interface helps the client application to clear off the interrupt condition on the hardware block identified in the parity error context message. Please refer to the table below as the operation varies depending on the interrupt source.

#### Parameters:

pecMessage [in] – The parity error context information of the hardware block whose parity error interrupt condition is to disabled.

The client application allocates and provides the reference to the buffer.

| Parity Source | Actions taken during Interrupt clear                                                                                                                                                                                                                                                                                                                                |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NPE-A         | Interrupt will be masked off at the interrupt controllers to that it will not trigger continuously.  Client application has to take appropriate action and re-configure the parity error detection subsequently. The client application will not be notified of further interrupts, until the re-configuration is done using ixParityENAccParityDetectionConfigure. |
| NPE-B         | Interrupt will be masked off at the interrupt controllers to that it will not trigger continuously.  Client application has to take appropriate action and re-configure the parity error detection subsequently. The client application will not be notified of further interrupts, until the re-configuration is done using ixParityENAccParityDetectionConfigure. |
| NPE-C         | Interrupt will be masked off at the interrupt controller Client application has to take appropriate action and re-configure the parity error detection subsequently. The client application will not be notified of further interrupts, until the re-configuration is done using ixParityENAccParityDetectionConfigure.                                             |
| SWCP          | Interrupt will be masked off at the interrupt controller                                                                                                                                                                                                                                                                                                            |

Client application has to take appropriate action and re-configure the parity error detection subsequently. The client application will not be notified of further interrupts, until the re-configuration is done using ixParityENAccParityDetectionConfigure.

AQM Interrupt will be masked off at the interrupt controller.

Client application has to take appropriate action and re-configure the parity error detection subsequently.

The client application will not be notified of further interrupts, until the re-configuration is done using ixParityENAccParityDetectionConfigure.

Parity interrupt condition is cleared at the SDRAM MCU for the following:

- 1. Single-bit
- 2. Multi-bit
- Overflow condition i.e., more than two parity conditions occurred

Note that single-parity errors do not result in data abort and not all data aborts caused by multi-bit parity error.

PCI Interrupt condition is cleared at the PCI bus controller.

Parity interrupt condition is cleared at the expansion bus controller for the following:

- 1. External master initiated Inbound write
- 2. Internal master (IXP400) initiated Outbound read

Re-entrant : NoISR Callable : No

#### Returns:

EXP

MCU

- ♦ IX\_PARITYENACC\_SUCCESS—The parameters check passed and the request to clear the parity error interrupt condition is successful.
- ♦ IX\_PARITYENACC\_INVALID\_PARAMETERS—The request failed due to NULL parameters have been passed or contents have been supplied with invalid values.
- ♦ IX\_PARITYENACC\_OPERATION\_FAILED The request failed because the operation didn't succeed on the hardware.
- ♦ IX\_PARITYENACC\_NOT\_INITIALISED The operation requested prior to the initialisation of the access layer.

| IxParityENAccStatus   | ( IxParityENAccParityErrorStats | ixParityErrorStats ) |
|-----------------------|---------------------------------|----------------------|
| ixParityENAccStatsGet | *const                          |                      |

This interface allows the client application to retrieve parity error statistics for all the hardware blocks.

#### Parameters:

ixParityErrorStats - [out] The statistics for all the hardware blocks.

The client application allocates and provides the reference to the buffer.

Re-entrant : NoISR Callable : Yes

#### Returns:

- ♦ IX\_PARITYENACC\_SUCCESS—The parameters check passed and the request to retrieve parity error statistics for the hardware block is successful.
- ♦ IX\_PARITYENACC\_INVALID\_PARAMETERS—The request failed due to a NULL parameter passed.
- ♦ IX\_PARITYENACC\_NOT\_INITIALISED The operation requested prior to the initialisation of the access layer.

#### **IxParityENAccStatus** ixParityENAccStatsReset (void )

This interface allows the client application to reset all the parity error statistics.

Re–entrant : NoISR Callable : No

#### Returns:

- ♦ IX\_PARITYENACC\_SUCCESS The request to reset the parity error statistics is successful.
- ♦ IX\_PARITYENACC\_NOT\_INITIALISED The operation requested prior to the initialisation of the access layer.

#### **IxParityENAccStatus** ixParityENAccStatsShow (void )

This interface allows the client application to print all the parity error statistics.

Re–entrant : NoISR Callable : No

#### Returns:

- ♦ IX\_PARITYENACC\_SUCCESS The request to show the pairty error statistics is successful.
- ♦ IX\_PARITYENACC\_NOT\_INITIALISED The operation requested prior to the initialisation of the access layer.

# Intel (R) IXP400 Software Performance Profiling (IxPerfProfAcc) API

IXP400 Performance Profiling Utility component Public API.

• NOTE: Xcycle measurement is not supported in Linux\*.

## **Data Structures**

## struct IxPerfProfAccBusPmuResults

Results obtained from running the Bus Pmu component. The results are obtained when the get functions is called.

## struct IxPerfProfAccXcycleResults

Results obtained from Xcycle run.

## struct IxPerfProfAccXscalePmuEvtCnt

contains results of a counter

#### struct IxPerfProfAccXscalePmuResults

contains results of counters and their overflow

## struct IxPerfProfAccXscalePmuSamplePcProfile

contains summary of samples taken

## **Defines**

## #define IX\_PERFPROF\_ACC\_XSCALE\_PMU\_MAX\_PROFILE\_SAMPLES

This is the maximum number of profiling samples allowed, which can be modified according to user's discretion.

## #define IX\_PERFPROF\_ACC\_BUS\_PMU\_MAX\_PECS

This is the maximum number of Programmable Event Counters available. This is a hardware spand fixed value. Do not change.

## #define IX\_PERFPROF\_ACC\_XCYCLE\_MAX\_NUM\_OF\_MEASUREMENTS

Max number of measurement allowed. This constant is used when creating storage array for Xc When run in continuous mode, Xcycle will wrap around and re—use buffer.

## #define IX\_PERFPROF\_ACC\_XSCALE\_PMU\_SYMBOL\_ACCURACY

Level of accuracy required for matching the PC Address to symbol address. This is used when t Intel XScale(R) Core PMU time/event sampling functions get the PC address and search for the corresponding symbol address.

#define IX\_PERFPROF\_ACC\_LOG(level, device, str, a, b, c, d, e, f)

## **Enumerations**

```
enum IxPerfProfAccBusPmuEventCounters1 {
     IX_PERFPROF_ACC_BUS_PMU_PEC1_NORTH_NPEA_GRANT_SELECT,
     IX_PERFPROF_ACC_BUS_PMU_PEC1_NORTH_NPEB_GRANT_SELECT,
     IX_PERFPROF_ACC_BUS_PMU_PEC1_NORTH_NPEC_GRANT_SELECT,
     IX PERFPROF ACC BUS PMU PEC1 NORTH BUS IDLE SELECT,
     IX PERFPROF ACC BUS PMU PEC1 NORTH NPEA REO SELECT,
     IX_PERFPROF_ACC_BUS_PMU_PEC1_NORTH_NPEB_REQ_SELECT,
     IX PERFPROF ACC BUS_PMU_PEC1_NORTH_NPEC_REQ_SELECT,
     IX PERFPROF ACC BUS PMU PEC1 SOUTH GSKT GRANT SELECT.
     IX PERFPROF ACC BUS PMU PEC1 SOUTH ABB GRANT SELECT,
     IX PERFPROF ACC BUS PMU PEC1 SOUTH PCI GRANT SELECT.
     IX_PERFPROF_ACC_BUS_PMU_PEC1_SOUTH_APB_GRANT_SELECT,
     IX PERFPROF ACC BUS PMU PEC1 SOUTH GSKT REQ SELECT,
     IX_PERFPROF_ACC_BUS_PMU_PEC1_SOUTH_ABB_REQ_SELECT,
     IX PERFPROF ACC BUS PMU PEC1 SOUTH PCI REQ SELECT,
     IX PERFPROF ACC BUS PMU PEC1 SOUTH APB REO SELECT.
     IX PERFPROF ACC BUS PMU PEC1 SDR 0 HIT SELECT,
     IX PERFPROF ACC BUS PMU PEC1 SDR 1 HIT SELECT,
     IX_PERFPROF_ACC_BUS_PMU_PEC1_SDR_2_HIT_SELECT,
     IX_PERFPROF_ACC_BUS_PMU_PEC1_SDR_3_HIT_SELECT,
     IX PERFPROF ACC BUS PMU PEC1 SDR 4 MISS SELECT.
     IX PERFPROF ACC BUS PMU PEC1 SDR 5 MISS SELECT,
     IX PERFPROF ACC BUS PMU PEC1 SDR 6 MISS SELECT,
     IX_PERFPROF_ACC_BUS_PMU_PEC1_SDR_7_MISS_SELECT
    Type of bus pmu events supported on PEC 1.
```

## enum IxPerfProfAccBusPmuEventCounters2 {

```
IX PERFPROF_ACC_BUS_PMU_PEC2_NORTH_NPEA_XFER_SELECT,
IX PERFPROF ACC BUS PMU PEC2 NORTH NPEB XFER SELECT,
IX PERFPROF ACC BUS PMU PEC2 NORTH NPEC XFER SELECT.
IX PERFPROF ACC BUS PMU PEC2 NORTH BUS WRITE SELECT,
IX PERFPROF ACC BUS PMU PEC2 NORTH NPEA OWN SELECT,
IX_PERFPROF_ACC_BUS_PMU_PEC2_NORTH_NPEB_OWN_SELECT,
IX PERFPROF ACC BUS PMU PEC2 NORTH NPEC OWN SELECT,
IX PERFPROF ACC BUS PMU PEC2 SOUTH GSKT XFER SELECT.
IX PERFPROF ACC BUS PMU PEC2 SOUTH ABB XFER SELECT,
IX PERFPROF ACC BUS PMU PEC2 SOUTH PCI XFER SELECT,
IX PERFPROF ACC BUS PMU PEC2 SOUTH APB XFER SELECT.
IX_PERFPROF_ACC_BUS_PMU_PEC2_SOUTH_GSKT_OWN_SELECT,
IX PERFPROF ACC BUS PMU PEC2 SOUTH ABB OWN SELECT.
IX PERFPROF ACC BUS PMU PEC2 SOUTH PCI OWN SELECT,
IX PERFPROF ACC BUS PMU PEC2 SOUTH APB OWN SELECT,
IX PERFPROF_ACC_BUS_PMU_PEC2_SDR_1_HIT_SELECT,
IX_PERFPROF_ACC_BUS_PMU_PEC2_SDR_2_HIT_SELECT,
```

Type of bus pmu events supported on PEC 2.

#### enum IxPerfProfAccBusPmuEventCounters3 {

IX PERFPROF ACC BUS PMU PEC3 NORTH NPEA RETRY SELECT, IX PERFPROF ACC BUS PMU PEC3 NORTH NPEB RETRY SELECT. IX PERFPROF ACC BUS PMU PEC3 NORTH NPEC RETRY SELECT, IX PERFPROF ACC BUS PMU PEC3 NORTH BUS READ SELECT, IX PERFPROF ACC BUS PMU PEC3 NORTH NPEA WRITE SELECT, IX PERFPROF ACC BUS PMU PEC3 NORTH NPEB WRITE SELECT, IX PERFPROF ACC BUS PMU PEC3 NORTH NPEC WRITE SELECT. IX PERFPROF ACC BUS PMU PEC3 SOUTH GSKT RETRY SELECT, IX PERFPROF ACC BUS PMU PEC3 SOUTH ABB RETRY SELECT, IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC3\_SOUTH\_PCI\_RETRY\_SELECT, IX PERFPROF ACC BUS PMU PEC3 SOUTH APB RETRY SELECT, IX PERFPROF ACC BUS PMU PEC3 SOUTH GSKT WRITE SELECT. IX PERFPROF ACC BUS PMU PEC3 SOUTH ABB WRITE SELECT, IX PERFPROF ACC BUS PMU PEC3 SOUTH PCI WRITE SELECT, IX PERFPROF ACC BUS PMU PEC3 SOUTH APB WRITE SELECT, IX PERFPROF ACC BUS PMU PEC3 SDR 2 HIT SELECT, IX PERFPROF ACC BUS PMU PEC3 SDR 3 HIT SELECT. IX PERFPROF ACC BUS PMU PEC3 SDR 4 HIT SELECT, IX PERFPROF ACC BUS PMU PEC3 SDR 5 HIT SELECT, IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC3\_SDR\_6\_MISS\_SELECT, IX PERFPROF ACC BUS PMU PEC3 SDR 7 MISS SELECT, IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC3\_SDR\_0\_MISS\_SELECT, IX PERFPROF ACC BUS PMU PEC3 SDR 1 MISS SELECT

## Type of bus pmu events supported on PEC 3.

## enum IxPerfProfAccBusPmuEventCounters4 {

IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC4\_SOUTH\_PCI\_SPLIT\_SELECT,
IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC4\_SOUTH\_EXP\_SPLIT\_SELECT,
IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC4\_SOUTH\_APB\_GRANT\_SELECT,
IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC4\_SOUTH\_APB\_XFER\_SELECT,
IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC4\_SOUTH\_GSKT\_READ\_SELECT,
IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC4\_SOUTH\_ABB\_READ\_SELECT,
IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC4\_SOUTH\_PCI\_READ\_SELECT,
IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC4\_SOUTH\_APB\_READ\_SELECT,
IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC4\_NORTH\_ABB\_SPLIT\_SELECT,
IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC4\_NORTH\_NPEA\_REQ\_SELECT,
IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC4\_NORTH\_NPEA\_READ\_SELECT,
IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC4\_NORTH\_NPEB\_READ\_SELECT,
IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC4\_NORTH\_NPEB\_READ\_SELECT,
IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC4\_NORTH\_NPEC\_READ\_SELECT,
IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC4\_NORTH\_NPEC\_READ\_SELECT,
IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC4\_SDR\_3\_HIT\_SELECT,

```
IX_PERFPROF_ACC_BUS_PMU_PEC4_SDR_4_HIT_SELECT,
IX_PERFPROF_ACC_BUS_PMU_PEC4_SDR_5_HIT_SELECT,
IX_PERFPROF_ACC_BUS_PMU_PEC4_SDR_6_HIT_SELECT,
IX_PERFPROF_ACC_BUS_PMU_PEC4_SDR_7_MISS_SELECT,
IX_PERFPROF_ACC_BUS_PMU_PEC4_SDR_0_MISS_SELECT,
IX_PERFPROF_ACC_BUS_PMU_PEC4_SDR_1_MISS_SELECT,
IX_PERFPROF_ACC_BUS_PMU_PEC4_SDR_2_MISS_SELECT,
IX_PERFPROF_ACC_BUS_PMU_PEC4_SDR_2_MISS_SELECT
}
```

Type of bus pmu events supported on PEC 4.

## enum IxPerfProfAccBusPmuEventCounters5 {

IX PERFPROF ACC BUS PMU PEC5 SOUTH ABB GRANT SELECT. IX PERFPROF ACC BUS PMU PEC5 SOUTH ABB XFER SELECT, IX PERFPROF ACC BUS PMU PEC5 SOUTH ABB RETRY SELECT, IX PERFPROF ACC BUS PMU PEC5 SOUTH EXP SPLIT SELECT. IX PERFPROF ACC BUS PMU PEC5 SOUTH ABB REQ SELECT, IX PERFPROF ACC BUS PMU PEC5 SOUTH ABB OWN SELECT. IX PERFPROF ACC BUS PMU PEC5 SOUTH BUS IDLE SELECT, IX PERFPROF ACC BUS PMU PEC5 NORTH NPEB GRANT SELECT, IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC5\_NORTH\_NPEB\_XFER\_SELECT, IX PERFPROF ACC BUS PMU PEC5 NORTH NPEB RETRY SELECT, IX PERFPROF ACC BUS PMU PEC5 NORTH NPEB REO SELECT, IX PERFPROF ACC BUS PMU PEC5 NORTH NPEB OWN SELECT, IX PERFPROF ACC BUS PMU PEC5 NORTH NPEB WRITE SELECT, IX PERFPROF ACC BUS PMU PEC5 NORTH NPEB READ SELECT, IX PERFPROF ACC BUS PMU PEC5 SDR 4 HIT SELECT, IX PERFPROF ACC BUS PMU PEC5 SDR 5 HIT SELECT. IX PERFPROF ACC BUS PMU PEC5 SDR 6 HIT SELECT, IX PERFPROF ACC BUS PMU PEC5 SDR 7 HIT SELECT, IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC5\_SDR\_0\_MISS\_SELECT, IX PERFPROF ACC BUS PMU PEC5 SDR 1 MISS SELECT, IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC5\_SDR\_2\_MISS\_SELECT, IX PERFPROF ACC BUS PMU PEC5 SDR 3 MISS SELECT

## Type of bus pmu events supported on PEC 5.

enum IxPerfProfAccBusPmuEventCounters6 {

IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC6\_SOUTH\_PCI\_GRANT\_SELECT,
IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC6\_SOUTH\_PCI\_XFER\_SELECT,
IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC6\_SOUTH\_PCI\_RETRY\_SELECT,
IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC6\_SOUTH\_PCI\_SPLIT\_SELECT,
IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC6\_SOUTH\_PCI\_REO\_SELECT,

IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC6\_SOUTH\_PCI\_OWN\_SELECT,
IX\_PERFPROF\_ACC\_RUS\_PMU\_PEC6\_SOUTH\_RUS\_WRITE\_SELECT

IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC6\_SOUTH\_BUS\_WRITE\_SELECT, IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC6\_NORTH\_NPEC\_GRANT\_SELECT.

IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC6\_NORTH\_NPEC\_XFER\_SELECT,

IX PERFPROF ACC BUS PMU PEC6 NORTH NPEC RETRY SELECT,

 ${\bf IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC6\_NORTH\_NPEC\_REQ\_SELECT},$ 

IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC6\_NORTH\_NPEC\_OWN\_SELECT, IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC6\_NORTH\_NPEB\_WRITE\_SELECT,

IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC6\_NORTH\_NPEC\_READ\_SELECT,

```
IX PERFPROF ACC BUS PMU PEC6 SDR 5 HIT SELECT,
     IX_PERFPROF_ACC_BUS_PMU_PEC6_SDR_6_HIT_SELECT,
     IX PERFPROF ACC BUS PMU PEC6 SDR 7 HIT SELECT,
     IX PERFPROF ACC BUS PMU PEC6 SDR 0 HIT SELECT,
     IX PERFPROF ACC BUS PMU PEC6 SDR 1 MISS SELECT.
     IX PERFPROF ACC BUS PMU PEC6 SDR 2 MISS SELECT,
     IX PERFPROF ACC BUS PMU PEC6 SDR 3 MISS SELECT.
     IX PERFPROF ACC BUS PMU PEC6 SDR 4 MISS SELECT
    Type of bus pmu events supported on PEC 6.
enum IxPerfProfAccBusPmuEventCounters7 {
     IX PERFPROF ACC BUS PMU PEC7 SOUTH APB RETRY SELECT,
     IX PERFPROF ACC BUS PMU PEC7 SOUTH APB REQ SELECT,
     IX PERFPROF ACC BUS PMU PEC7 SOUTH APB OWN SELECT,
     IX PERFPROF ACC BUS PMU PEC7 SOUTH BUS READ SELECT,
     IX PERFPROF ACC BUS PMU PEC7 CYCLE COUNT SELECT
    Type of bus pmu events supported on PEC 7.
enum IxPerfProfAccXscalePmuEvent {
     IX_PERFPROF_ACC_XSCALE_PMU_EVENT_CACHE_MISS,
     IX PERFPROF ACC XSCALE PMU EVENT CACHE INSTRUCTION,
     IX PERFPROF ACC XSCALE PMU EVENT STALL,
     IX PERFPROF ACC XSCALE PMU EVENT INST TLB MISS.
     IX_PERFPROF_ACC_XSCALE_PMU_EVENT_DATA_TLB_MISS,
     IX PERFPROF ACC XSCALE PMU EVENT BRANCH EXEC.
     IX_PERFPROF_ACC_XSCALE_PMU_EVENT_BRANCH_MISPREDICT,
     IX PERFPROF ACC XSCALE PMU EVENT INST EXEC,
     IX_PERFPROF_ACC_XSCALE_PMU_EVENT_FULL_EVERYCYCLE,
     IX PERFPROF ACC XSCALE PMU EVENT ONCE,
     IX_PERFPROF_ACC_XSCALE_PMU_EVENT_DATA_CACHE_ACCESS,
     IX PERFPROF ACC XSCALE PMU EVENT DATA CACHE MISS,
     IX PERFPROF ACC XSCALE PMU EVENT DATA CACHE WRITEBACK,
     IX PERFPROF ACC XSCALE PMU EVENT SW CHANGE PC.
     IX_PERFPROF_ACC_XSCALE_PMU_EVENT_MAX
    Type of Intel XScale (R) Core PMU events supported.
enum IxPerfProfAccStatus {
     IX PERFPROF ACC STATUS SUCCESS,
     IX_PERFPROF_ACC_STATUS_FAIL,
     IX PERFPROF ACC STATUS ANOTHER UTIL IN PROGRESS,
     IX PERFPROF ACC STATUS XCYCLE MEASUREMENT IN PROGRESS,
     IX PERFPROF ACC STATUS XCYCLE NO BASELINE.
     IX PERFPROF ACC STATUS XCYCLE MEASUREMENT REQUEST OUT OF I
     IX PERFPROF ACC STATUS XCYCLE PRIORITY SET FAIL.
     IX_PERFPROF_ACC_STATUS_XCYCLE_THREAD_CREATE_FAIL,
     IX PERFPROF ACC STATUS XCYCLE PRIORITY RESTORE FAIL,
     IX_PERFPROF_ACC_STATUS_XCYCLE_MEASUREMENT_NOT_RUNNING,
     IX_PERFPROF_ACC_STATUS_XSCALE_PMU_NUM_INVALID,
```

```
IX_PERFPROF_ACC_STATUS_XSCALE_PMU_EVENT_INVALID,
     IX_PERFPROF_ACC_STATUS_XSCALE_PMU_START_NOT_CALLED,
     IX_PERFPROF_ACC_STATUS_BUS_PMU_MODE_ERROR,
     IX PERFPROF ACC STATUS BUS PMU PEC1 ERROR,
     IX PERFPROF ACC STATUS BUS PMU PEC2 ERROR.
     IX_PERFPROF_ACC_STATUS_BUS_PMU_PEC3_ERROR,
     IX PERFPROF ACC STATUS BUS PMU PEC4 ERROR.
     IX_PERFPROF_ACC_STATUS_BUS_PMU_PEC5_ERROR,
     IX PERFPROF ACC STATUS BUS PMU PEC6 ERROR,
     IX_PERFPROF_ACC_STATUS_BUS_PMU_PEC7_ERROR,
     IX PERFPROF ACC STATUS BUS PMU START NOT CALLED,
     IX_PERFPROF_ACC_STATUS_COMPONENT_NOT_SUPPORTED
    Invalid Status Definitions.
enum IxPerfProfAccBusPmuMode {
     IX_PERFPROF_ACC_BUS_PMU_MODE_HALT,
     IX_PERFPROF_ACC_BUS_PMU_MODE_SOUTH,
     IX PERFPROF ACC BUS PMU MODE NORTH,
     IX_PERFPROF_ACC_BUS_PMU_MODE_SDRAM
    State selection of counters.
```

## **Functions**

PUBLICixPerfProfAccXscalePmuEventCountStart (BOOL clkCntDiv, UINT32 numEvents, IxPerfProfAccStatus IxPerfProfAccXscalePmuEvent pmuEvent1, IxPerfProfAccXscalePmuEvent pmuEvent2, IxPerfProfAccXscalePmuEvent pmuEvent3, IxPerfProfAccXscalePmuEvent pmuEvent4)

This API will start the clock and event counting.

 $PUBLIC \textbf{ixPerfProfAccXscalePmuEventCountStop} \ (\textbf{IxPerfProfAccXscalePmuResults} \ \textbf{IxPerfProfAccStatus} \ * eventCountStopResults)$ 

This API will stop the clock and event counting.

**PUBLIC** 

**IxPerfProfAccStatus ixPerfProfAccXscalePmuTimeSampStart** (UINT32 samplingRate, BOOL clkCntDiv) *Starts the time based sampling.* 

PUBLIC ix PerfProfAccX scalePmuTimeSampStop~(Ix PerfProfAccX scalePmuEvtCnt~\*clkCount, Ix PerfProfAccS tatus~Ix PerfProfAccX scalePmuSamplePcProfile~\*timeProfile)

Stops the time based sampling.

PUBLICixPerfProfAccXscalePmuEventSampStart (UINT32 numEvents, IxPerfProfAccXscalePmuIxPerfProfAccStatus pmuEvent1, UINT32 eventRate1, IxPerfProfAccXscalePmuEvent pmuEvent2, UINT32 eventIxPerfProfAccXscalePmuEvent pmuEvent3, UINT32 eventRate3, IxPerfProfAccXscalePmupmuEvent4, UINT32 eventRate4)

Starts the event based sampling.

Functions 379

## $PUBLIC ix PerfProfAccX scale PmuEventSampStop\ (Ix PerfProfAccX scale PmuSample PcProfile) and the profile of the profile of$

 $\textbf{IxPerfProfAccStatus} * \textbf{eventProfile1}, \textbf{IxPerfProfAccXscalePmuSamplePcProfile} * \textbf{eventProfile2}, \\ \textbf{IxPerfProfAccXscalePmuSamplePcProfile2} * \textbf{eventProfile2}, \\ \textbf{eventProfIle2} * \textbf{eventPro$ 

IxPerfProfAccXscalePmuSamplePcProfile \*eventProfile3, IxPerfProfAccXscalePmuSamplePcProfile \*eventProfile4)

Stops the event based sampling.

## PUBLIC void ixPerfProfAccXscalePmuResultsGet (IxPerfProfAccXscalePmuResults \*results)

Reads the current value of the counters and their overflow.

## $PUBLIC ix PerfProfAcc BusPmuStart\ (Ix PerfProfAcc BusPmuMode\ \mathsf{mode},$

IxPerfProfAccStatus IxPerfProfAccBusPmuEventCounters1 pecEvent1, IxPerfProfAccBusPmuEventCounters2 pecEvent2, IxPerfProfAccBusPmuEventCounters3 pecEvent3,

IxPerfProfAccBusPmuEventCounters4 pecEvent4, IxPerfProfAccBusPmuEventCounters5

pecEvent5, IxPerfProfAccBusPmuEventCounters6 pecEvent6,

IxPerfProfAccBusPmuEventCounters7 pecEvent7)

Initializes all the counters and selects events to be monitored.

#### **PUBLIC**

## IxPerfProfAccStatus ixPerfProfAccBusPmuStop (void)

Stops all counters.

## PUBLIC void ixPerfProfAccBusPmuResultsGet (IxPerfProfAccBusPmuResults \*BusPmuResults)

Gets values of all counters.

## PUBLIC void **ixPerfProfAccBusPmuPMSRGet** (UINT32 \*pmsrValue)

Get values of PMSR.

#### **PUBLIC**

## IxPerfProfAccStatus ixPerfProfAccXcycleBaselineRun (UINT32 \*numBaselineCycle)

Perform baseline for Xcycle.

## **PUBLIC**

## IxPerfProfAccStatus ixPerfProfAccXcycleStart (UINT32 numMeasurementsRequested)

Start the measurement.

#### **PUBLIC**

## IxPerfProfAccStatus ixPerfProfAccXcycleStop (void)

Stop the Xcycle measurement.

#### **PUBLIC**

## $Ix PerfProfAcc X cycle Results Get \ (Ix PerfProfAcc X cycle Results * x cycle Result)$

Get the results of Xcycle measurement.

## PUBLIC BOOL ixPerfProfAccXcycleInProgress (void)

Check if Xcycle is running.

- int int int \*eof, void \*data) int int \*eof, void \*data) int int \*eof, void \*data)
- int ixPerfProfAccXscalePmuEventSampCreateProcFile (char \*buf, char \*\*start, off\_t offset, int
  int \*eof, void \*data)

Functions 380

## **Detailed Description**

IXP400 Performance Profiling Utility component Public API.

• NOTE: Xcycle measurement is not supported in Linux\*.

## **Define Documentation**

## #define IX\_PERFPROF\_ACC\_BUS\_PMU\_MAX\_PECS

This is the maximum number of Programmable Event Counters available. This is a hardware specific and fixed value. Do not change.

Definition at line **49** of file **IxPerfProfAcc.h**.

```
#define IX_PERFPROF_ACC_LOG ( level, device, str, a, b, c, d, e, f )
```

Mechanism for logging a formatted message for the PerfProfAcc component.

## Parameters:

```
level
            UINT32 [in] – trace level
device
            UINT32 [in] – output device
str
            char* [in] – format string, similar to
            printf().
            UINT32 [in] - first argument to display
a
            UINT32 [in] – second argument to
b
            display
            UINT32 [in] – third argument to display
c
            UINT32 [in] – fourth argument to
d
            display
            UINT32 [in] – fifth argument to display
e
            UINT32 [in] – sixth argument to display
```

#### Returns:

none

Definition at line **95** of file **IxPerfProfAcc.h**.

Detailed Description 381

## #define IX PERFPROF ACC XCYCLE MAX NUM OF MEASUREMENTS

Max number of measurement allowed. This constant is used when creating storage array for Xcycle. When run in continuous mode, Xcycle will wrap around and re—use buffer.

Definition at line **60** of file **IxPerfProfAcc.h**.

## #define IX\_PERFPROF\_ACC\_XSCALE\_PMU\_MAX\_PROFILE\_SAMPLES

This is the maximum number of profiling samples allowed, which can be modified according to the user's discretion.

Definition at line 38 of file **IxPerfProfAcc.h**.

## #define IX PERFPROF ACC XSCALE PMU SYMBOL ACCURACY

Level of accuracy required for matching the PC Address to symbol address. This is used when the Intel XScale(R) Core PMU time/event sampling functions get the PC address and search for the corresponding symbol address.

Definition at line **72** of file **IxPerfProfAcc.h**.

## **Enumeration Type Documentation**

## enum IxPerfProfAccBusPmuEventCounters1

Type of bus pmu events supported on PEC 1.

Lists all bus pmu events.

| IX_PERFPROF_ACC_BUS_PMU_PEC1_NORTH_NPEA_GRANT_SELECT | Select North NPEA grant on PEC1. |
|------------------------------------------------------|----------------------------------|
| IX_PERFPROF_ACC_BUS_PMU_PEC1_NORTH_NPEB_GRANT_SELECT | Select North NPEB grant on PEC1. |
| IX_PERFPROF_ACC_BUS_PMU_PEC1_NORTH_NPEC_GRANT_SELECT | Select North NPEC grant on PEC1. |
| IX_PERFPROF_ACC_BUS_PMU_PEC1_NORTH_BUS_IDLE_SELECT   | Select North bus idle on PEC1.   |
| IX_PERFPROF_ACC_BUS_PMU_PEC1_NORTH_NPEA_REQ_SELECT   | Select North NPEA req on PEC1.   |
| IX_PERFPROF_ACC_BUS_PMU_PEC1_NORTH_NPEB_REQ_SELECT   | Select North NPEB req on PEC1.   |
| IX_PERFPROF_ACC_BUS_PMU_PEC1_NORTH_NPEC_REQ_SELECT   | Select North NPEC req on PEC1.   |

| IX_PERFPROF_ACC_BUS_PMU_PEC1_SOUTH_GSKT_GRANT_SELECT     | - C                               |
|----------------------------------------------------------|-----------------------------------|
| IX_PERFPROF_ACC_BUS_PMU_PEC1_SOUTH_ABB_GRANT_SELECT      | grant on PEC1. Select south abb   |
| IX_I ERFI ROF_ACC_BOS_I MO_I ECI_SOOTII_ABB_GRANI_SELECI | grant on PEC1.                    |
| IX_PERFPROF_ACC_BUS_PMU_PEC1_SOUTH_PCI_GRANT_SELECT      | Select south pci                  |
|                                                          | grant on PEC1.                    |
| IX_PERFPROF_ACC_BUS_PMU_PEC1_SOUTH_APB_GRANT_SELECT      | Select south apb                  |
|                                                          | grant on PEC1.                    |
| IX_PERFPROF_ACC_BUS_PMU_PEC1_SOUTH_GSKT_REQ_SELECT       | Select south gasket               |
| IX_PERFPROF_ACC_BUS_PMU_PEC1_SOUTH_ABB_REQ_SELECT        | request on PEC1. Select south abb |
| IX_I ERFI ROF_ACC_BOS_I MO_I ECI_SOOTII_ABB_REQ_SELECT   | request on PEC1.                  |
| IX_PERFPROF_ACC_BUS_PMU_PEC1_SOUTH_PCI_REQ_SELECT        | Select south pci                  |
|                                                          | request on PEC1.                  |
| IX_PERFPROF_ACC_BUS_PMU_PEC1_SOUTH_APB_REQ_SELECT        | Select south apb                  |
|                                                          | request on PEC1.                  |
| IX_PERFPROF_ACC_BUS_PMU_PEC1_SDR_0_HIT_SELECT            | Select sdram0 hit on PEC1.        |
| IX_PERFPROF_ACC_BUS_PMU_PEC1_SDR_1_HIT_SELECT            | Select sdram1 hit on              |
| IX_I ENT NOT _NEC_BOS_I MO_I ECT_SDX_I_IIII_SEELET       | PEC1.                             |
| IX_PERFPROF_ACC_BUS_PMU_PEC1_SDR_2_HIT_SELECT            | Select sdram2 hit on              |
|                                                          | PEC1.                             |
| IX_PERFPROF_ACC_BUS_PMU_PEC1_SDR_3_HIT_SELECT            | Select sdram3 hit on              |
| Ny DEDENDAE AGG DUG DALI DEGI CDD 4 MICG GELEGT          | PEC1.                             |
| IX_PERFPROF_ACC_BUS_PMU_PEC1_SDR_4_MISS_SELECT           | Select sdram4 miss on PEC1.       |
| IX_PERFPROF_ACC_BUS_PMU_PEC1_SDR_5_MISS_SELECT           | Select sdram5 miss                |
|                                                          | on PEC1.                          |
| IX_PERFPROF_ACC_BUS_PMU_PEC1_SDR_6_MISS_SELECT           | Select sdram6 miss                |
|                                                          | on PEC1.                          |
| IX_PERFPROF_ACC_BUS_PMU_PEC1_SDR_7_MISS_SELECT           | Select sdram7 miss on PEC1.       |
|                                                          | OII PECI.                         |

Definition at line 186 of file IxPerfProfAcc.h.

## enum IxPerfProfAccBusPmuEventCounters2

Type of bus pmu events supported on PEC 2.

Lists all bus pmu events.

## **Enumeration values:**

IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC2\_NORTH\_NPEA\_XFER\_SELECT Select North NPEA transfer on PEC2.

IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC2\_NORTH\_NPEB\_XFER\_SELECT Select North NPEB transfer on PEC2.

IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC2\_NORTH\_NPEC\_XFER\_SELECT Select North NPEC transfer on PEC2.

| IX_PERFPROF_ACC_BUS_PMU_PEC2_NORTH_BUS_WRITE_SELECT           | Select North bus write on PEC2.        |
|---------------------------------------------------------------|----------------------------------------|
| IX_PERFPROF_ACC_BUS_PMU_PEC2_NORTH_NPEA_OWN_SELECT            | Select North NPEA own on PEC2.         |
| IX_PERFPROF_ACC_BUS_PMU_PEC2_NORTH_NPEB_OWN_SELECT            | Select North NPEB own on PEC2.         |
| IX_PERFPROF_ACC_BUS_PMU_PEC2_NORTH_NPEC_OWN_SELECT            | Select North NPEC own on PEC2.         |
| IX_PERFPROF_ACC_BUS_PMU_PEC2_SOUTH_GSKT_XFER_SELECT           | Select South gasket transfer on PEC2.  |
| IX_PERFPROF_ACC_BUS_PMU_PEC2_SOUTH_ABB_XFER_SELECT            | Select South abb transfer on PEC2.     |
| IX_PERFPROF_ACC_BUS_PMU_PEC2_SOUTH_PCI_XFER_SELECT            | Select South pci transfer on PEC2.     |
| IX_PERFPROF_ACC_BUS_PMU_PEC2_SOUTH_APB_XFER_SELECT            | Select South apb transfer on PEC2.     |
| $IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC2\_SOUTH\_GSKT\_OWN\_SELECT$ | Select South gasket own on PEC2.       |
| IX_PERFPROF_ACC_BUS_PMU_PEC2_SOUTH_ABB_OWN_SELECT             | Select South abb own on PEC2.          |
| IX_PERFPROF_ACC_BUS_PMU_PEC2_SOUTH_PCI_OWN_SELECT             | Select South pci own on PEC2.          |
| IX_PERFPROF_ACC_BUS_PMU_PEC2_SOUTH_APB_OWN_SELECT             | Select South apb own transfer on PEC2. |
| IX_PERFPROF_ACC_BUS_PMU_PEC2_SDR_1_HIT_SELECT                 | Select sdram1 hit on PEC2.             |
| IX_PERFPROF_ACC_BUS_PMU_PEC2_SDR_2_HIT_SELECT                 | Select sdram2 hit on PEC2.             |
| IX_PERFPROF_ACC_BUS_PMU_PEC2_SDR_3_HIT_SELECT                 | Select sdram3 hit on PEC2.             |
| IX_PERFPROF_ACC_BUS_PMU_PEC2_SDR_4_HIT_SELECT                 | Select sdram4 hit on PEC2.             |
| IX_PERFPROF_ACC_BUS_PMU_PEC2_SDR_5_MISS_SELECT                | Select sdram5 miss on PEC2.            |
| IX_PERFPROF_ACC_BUS_PMU_PEC2_SDR_6_MISS_SELECT                | Select sdram6 miss on PEC2.            |
| IX_PERFPROF_ACC_BUS_PMU_PEC2_SDR_7_MISS_SELECT                | Select sdram7 miss on PEC2.            |
| IX_PERFPROF_ACC_BUS_PMU_PEC2_SDR_0_MISS_SELECT                | Select sdram0 miss on PEC2.            |
|                                                               |                                        |

Definition at line **224** of file **IxPerfProfAcc.h**.

enum IxPerfProfAccBusPmuEventCounters3

Type of bus pmu events supported on PEC 3.

Lists all bus pmu events.

| nc | ranon vanaes.                                        |                                    |
|----|------------------------------------------------------|------------------------------------|
|    | IX_PERFPROF_ACC_BUS_PMU_PEC3_NORTH_NPEA_RETRY_SELECT | Select north NPEA retry on PEC3.   |
|    | IX_PERFPROF_ACC_BUS_PMU_PEC3_NORTH_NPEB_RETRY_SELECT | •                                  |
|    | IX_PERFPROF_ACC_BUS_PMU_PEC3_NORTH_NPEC_RETRY_SELECT | Select north NPEC retry on PEC3.   |
|    | IX_PERFPROF_ACC_BUS_PMU_PEC3_NORTH_BUS_READ_SELECT   | Select north bus read on PEC3.     |
|    | IX_PERFPROF_ACC_BUS_PMU_PEC3_NORTH_NPEA_WRITE_SELECT | Select north NPEA write on PEC3.   |
|    | IX_PERFPROF_ACC_BUS_PMU_PEC3_NORTH_NPEB_WRITE_SELECT | Select north NPEB write on PEC3.   |
|    | IX_PERFPROF_ACC_BUS_PMU_PEC3_NORTH_NPEC_WRITE_SELECT | Select north NPEC wirte on PEC3.   |
|    | IX_PERFPROF_ACC_BUS_PMU_PEC3_SOUTH_GSKT_RETRY_SELECT | Select south gasket retry on PEC3. |
|    | IX_PERFPROF_ACC_BUS_PMU_PEC3_SOUTH_ABB_RETRY_SELECT  | Select south abb retry on PEC3.    |
|    | IX_PERFPROF_ACC_BUS_PMU_PEC3_SOUTH_PCI_RETRY_SELECT  | Select south pci retry on PEC3.    |
|    | IX_PERFPROF_ACC_BUS_PMU_PEC3_SOUTH_APB_RETRY_SELECT  | Select south apb retry on PEC3.    |
|    | IX_PERFPROF_ACC_BUS_PMU_PEC3_SOUTH_GSKT_WRITE_SELECT | Select south gasket write on PEC3. |
|    | IX_PERFPROF_ACC_BUS_PMU_PEC3_SOUTH_ABB_WRITE_SELECT  | Select south abb write on PEC3.    |
|    | IX_PERFPROF_ACC_BUS_PMU_PEC3_SOUTH_PCI_WRITE_SELECT  | Select south pci write on PEC3.    |
|    | IX_PERFPROF_ACC_BUS_PMU_PEC3_SOUTH_APB_WRITE_SELECT  | Select south apb write on PEC3.    |
|    | IX_PERFPROF_ACC_BUS_PMU_PEC3_SDR_2_HIT_SELECT        | Select sdram2 hit on PEC3.         |
|    | IX_PERFPROF_ACC_BUS_PMU_PEC3_SDR_3_HIT_SELECT        | Select sdram3 hit on PEC3.         |
|    | IX_PERFPROF_ACC_BUS_PMU_PEC3_SDR_4_HIT_SELECT        | Select sdram4 hit on PEC3.         |
|    | IX_PERFPROF_ACC_BUS_PMU_PEC3_SDR_5_HIT_SELECT        | Select sdram5 hit on PEC3.         |
|    | IX_PERFPROF_ACC_BUS_PMU_PEC3_SDR_6_MISS_SELECT       | Select sdram6 miss on PEC3.        |
|    | IX_PERFPROF_ACC_BUS_PMU_PEC3_SDR_7_MISS_SELECT       | Select sdram7 miss on PEC3.        |
|    | IX_PERFPROF_ACC_BUS_PMU_PEC3_SDR_0_MISS_SELECT       | Select sdram0 miss                 |

## IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC3\_SDR\_1\_MISS\_SELECT

on PEC3. Select sdram1 miss on PEC3.

Definition at line 262 of file IxPerfProfAcc.h.

## enum IxPerfProfAccBusPmuEventCounters4

Type of bus pmu events supported on PEC 4.

Lists all bus pmu events.

| auon vaines.                                        |                                       |  |
|-----------------------------------------------------|---------------------------------------|--|
| IX_PERFPROF_ACC_BUS_PMU_PEC4_SOUTH_PCI_SPLIT_SELECT | Select south pci split on PEC4.       |  |
| IX_PERFPROF_ACC_BUS_PMU_PEC4_SOUTH_EXP_SPLIT_SELECT | Select south expansion split on PEC4. |  |
| IX_PERFPROF_ACC_BUS_PMU_PEC4_SOUTH_APB_GRANT_SELECT | Select south apb grant on PEC4.       |  |
| IX_PERFPROF_ACC_BUS_PMU_PEC4_SOUTH_APB_XFER_SELECT  | Select south apb transfer on PEC4.    |  |
| IX_PERFPROF_ACC_BUS_PMU_PEC4_SOUTH_GSKT_READ_SELECT | Select south gasket read on PEC4.     |  |
| IX_PERFPROF_ACC_BUS_PMU_PEC4_SOUTH_ABB_READ_SELECT  | Select south abb read on PEC4.        |  |
| IX_PERFPROF_ACC_BUS_PMU_PEC4_SOUTH_PCI_READ_SELECT  | Select south pci read on PEC4.        |  |
| IX_PERFPROF_ACC_BUS_PMU_PEC4_SOUTH_APB_READ_SELECT  | Select south apb read on PEC4.        |  |
| IX_PERFPROF_ACC_BUS_PMU_PEC4_NORTH_ABB_SPLIT_SELECT | Select north abb split on PEC4.       |  |
| IX_PERFPROF_ACC_BUS_PMU_PEC4_NORTH_NPEA_REQ_SELECT  | Select north NPEA req on PEC4.        |  |
| IX_PERFPROF_ACC_BUS_PMU_PEC4_NORTH_NPEA_READ_SELECT | Select north NPEA read on PEC4.       |  |
| IX_PERFPROF_ACC_BUS_PMU_PEC4_NORTH_NPEB_READ_SELECT | Select north NPEB read on PEC4.       |  |
| IX_PERFPROF_ACC_BUS_PMU_PEC4_NORTH_NPEC_READ_SELECT | Select north NPEC read on PEC4.       |  |
| IX_PERFPROF_ACC_BUS_PMU_PEC4_SDR_3_HIT_SELECT       | Select sdram3 hit on PEC4.            |  |
| IX_PERFPROF_ACC_BUS_PMU_PEC4_SDR_4_HIT_SELECT       | Select sdram4 hit on PEC4.            |  |
| IX_PERFPROF_ACC_BUS_PMU_PEC4_SDR_5_HIT_SELECT       | Select sdram5 hit on PEC4.            |  |
| IX_PERFPROF_ACC_BUS_PMU_PEC4_SDR_6_HIT_SELECT       | Select sdram6 hit on PEC4.            |  |
|                                                     |                                       |  |

| IX_PERFPROF_ACC_BUS_PMU_PEC4_SDR_7_MISS_SELECT | Select sdram7 miss on PEC4. |
|------------------------------------------------|-----------------------------|
| IX_PERFPROF_ACC_BUS_PMU_PEC4_SDR_0_MISS_SELECT | Select sdram0 miss on PEC4. |
| IX_PERFPROF_ACC_BUS_PMU_PEC4_SDR_1_MISS_SELECT | Select sdram1 miss on PEC4. |
| IX_PERFPROF_ACC_BUS_PMU_PEC4_SDR_2_MISS_SELECT | Select sdram2 miss on PEC4. |

Definition at line **300** of file **IxPerfProfAcc.h**.

## enum IxPerfProfAccBusPmuEventCounters5

Type of bus pmu events supported on PEC 5.

Lists all bus pmu events.

| IX_PERFPROF_ACC_BUS_PMU_PEC5_SOUTH_ABB_GRANT_SELECT             | Select south abb                |
|-----------------------------------------------------------------|---------------------------------|
| IX PERFPROF ACC BUS PMU PEC5 SOUTH ABB XFER SELECT              | grant on PEC5. Select south abb |
| IX_I ERFI ROF_ACC_BOS_I MO_I ECS_SOUTH_ABB_AFER_SELECT          | transfer on PEC5.               |
| IX_PERFPROF_ACC_BUS_PMU_PEC5_SOUTH_ABB_RETRY_SELECT             | Select south abb                |
|                                                                 | retry on PEC5.                  |
| IX_PERFPROF_ACC_BUS_PMU_PEC5_SOUTH_EXP_SPLIT_SELECT             | Select south                    |
|                                                                 | expansion split on PEC5.        |
| IX_PERFPROF_ACC_BUS_PMU_PEC5_SOUTH_ABB_REQ_SELECT               | Select south abb                |
|                                                                 | request on PEC5.                |
| IX_PERFPROF_ACC_BUS_PMU_PEC5_SOUTH_ABB_OWN_SELECT               | Select south abb own on PEC5.   |
| IX_PERFPROF_ACC_BUS_PMU_PEC5_SOUTH_BUS_IDLE_SELECT              | Select south bus idle on PEC5.  |
| IX PERFPROF ACC BUS PMU PEC5 NORTH NPEB GRANT SELECT            |                                 |
| IA_FERFFROF_ACC_BUS_FMU_FECS_NORTH_NFEB_GRANT_SELECT            | grant on PEC5.                  |
| IX_PERFPROF_ACC_BUS_PMU_PEC5_NORTH_NPEB_XFER_SELECT             | Select north NPEB               |
|                                                                 | transfer on PEC5.               |
| $IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC5\_NORTH\_NPEB\_RETRY\_SELECT$ | Select north NPEB               |
|                                                                 | retry on PEC5.                  |
| IX_PERFPROF_ACC_BUS_PMU_PEC5_NORTH_NPEB_REQ_SELECT              | Select north NPEB               |
| IN DEDENDAR ACC DUE DAIL DECE MADEL ADED OUN ERLECT             | request on PEC5.                |
| IX_PERFPROF_ACC_BUS_PMU_PEC5_NORTH_NPEB_OWN_SELECT              | Select north NPEB own on PEC5.  |
| IX_PERFPROF_ACC_BUS_PMU_PEC5_NORTH_NPEB_WRITE_SELECT            |                                 |
|                                                                 | write on PEC5.                  |
| IX_PERFPROF_ACC_BUS_PMU_PEC5_NORTH_NPEB_READ_SELECT             | Select north NPEB               |
|                                                                 | read on PEC5.                   |
| IX_PERFPROF_ACC_BUS_PMU_PEC5_SDR_4_HIT_SELECT                   |                                 |
|                                                                 |                                 |

hit on PEC5. IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC5\_SDR\_5\_HIT\_SELECT Select north sdram5 hit on PEC5. IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC5\_SDR\_6\_HIT\_SELECT Select north sdram6 hit on PEC5. IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC5\_SDR\_7\_HIT\_SELECT Select north sdram7 hit on PEC5. IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC5\_SDR\_0\_MISS\_SELECT Select north sdram0 miss on PEC5. IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC5\_SDR\_1\_MISS\_SELECT Select north sdram1 miss on PEC5. IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC5\_SDR\_2\_MISS\_SELECT Select north sdram2 miss on PEC5. IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC5\_SDR\_3\_MISS\_SELECT Select north sdram3 miss on PEC5.

Definition at line **336** of file **IxPerfProfAcc.h**.

## enum IxPerfProfAccBusPmuEventCounters6

Type of bus pmu events supported on PEC 6.

Lists all bus pmu events.

## Enumeration values:

|            |                |               |                  | grant on PEC6.                      |
|------------|----------------|---------------|------------------|-------------------------------------|
| IX_PERFPRO | F_ACC_BUS_PMU_ | PEC6_SOUTH_PC | I_XFER_SELECT    | Select south pci transfer on PEC6.  |
| IX_PERFPRO | F_ACC_BUS_PMU_ | PEC6_SOUTH_PC | I_RETRY_SELECT   | Select south pci retry on PEC6.     |
| IX_PERFPRO | F_ACC_BUS_PMU_ | PEC6_SOUTH_PC | I_SPLIT_SELECT   | Select south pci split on PEC6.     |
| IX_PERFPRO | F_ACC_BUS_PMU_ | PEC6_SOUTH_PC | I_REQ_SELECT     | Select south pci request on PEC6.   |
| IX_PERFPRO | F_ACC_BUS_PMU_ | PEC6_SOUTH_PC | I_OWN_SELECT     | Select south pci own on PEC6.       |
| IX_PERFPRO | F_ACC_BUS_PMU_ | PEC6_SOUTH_BU | S_WRITE_SELECT   | Select south pci write on PEC6.     |
| IX_PERFPRO | F_ACC_BUS_PMU_ | PEC6_NORTH_NF | PEC_GRANT_SELECT | Select north NPEC grant on PEC6.    |
| IX_PERFPRO | F_ACC_BUS_PMU_ | PEC6_NORTH_NF | PEC_XFER_SELECT  | Select north NPEC transfer on PEC6. |
| IX_PERFPRO | F_ACC_BUS_PMU_ | PEC6_NORTH_NF | PEC_RETRY_SELECT | Select north NPEC retry on PEC6.    |
| IX_PERFPRO | F_ACC_BUS_PMU_ | PEC6_NORTH_NF | PEC_REQ_SELECT   | Select north NPEC request on PEC6.  |

IX\_PERFPROF\_ACC\_BUS\_PMU\_PEC6\_SOUTH\_PCI\_GRANT\_SELECT

Select north sdram4

Select south pci

| IX_PERFPROF_ACC_BUS_PMU_PEC6_NORTH_NPEC_OWN_SELECT   | Select north NPEC own on PEC6.   |
|------------------------------------------------------|----------------------------------|
| IX_PERFPROF_ACC_BUS_PMU_PEC6_NORTH_NPEB_WRITE_SELECT | Select north NPEB write on PEC6. |
| IX_PERFPROF_ACC_BUS_PMU_PEC6_NORTH_NPEC_READ_SELECT  | Select north NPEC read on PEC6.  |
| IX_PERFPROF_ACC_BUS_PMU_PEC6_SDR_5_HIT_SELECT        | Select sdram5 hit on PEC6.       |
| IX_PERFPROF_ACC_BUS_PMU_PEC6_SDR_6_HIT_SELECT        | Select sdram6 hit on PEC6.       |
| IX_PERFPROF_ACC_BUS_PMU_PEC6_SDR_7_HIT_SELECT        | Select sdram7 hit on PEC6.       |
| IX_PERFPROF_ACC_BUS_PMU_PEC6_SDR_0_HIT_SELECT        | Select sdram0 hit on PEC6.       |
| IX_PERFPROF_ACC_BUS_PMU_PEC6_SDR_1_MISS_SELECT       | Select sdram1 miss on PEC6.      |
| IX_PERFPROF_ACC_BUS_PMU_PEC6_SDR_2_MISS_SELECT       | Select sdram2 miss on PEC6.      |
| IX_PERFPROF_ACC_BUS_PMU_PEC6_SDR_3_MISS_SELECT       | Select sdram3 miss on PEC6.      |
| IX_PERFPROF_ACC_BUS_PMU_PEC6_SDR_4_MISS_SELECT       | Select sdram4 miss on PEC6.      |

Definition at line 373 of file IxPerfProfAcc.h.

## enum IxPerfProfAccBusPmuEventCounters7

Type of bus pmu events supported on PEC 7.

Lists all bus pmu events.

## Enumeration values:

| IX_PERFPROF_ACC_BUS_PMU_PEC7_SOUTH_APB_RETRY_SELECT | Select south apb retry on PEC7.   |
|-----------------------------------------------------|-----------------------------------|
| IX_PERFPROF_ACC_BUS_PMU_PEC7_SOUTH_APB_REQ_SELECT   | Select south apb request on PEC7. |
| IX_PERFPROF_ACC_BUS_PMU_PEC7_SOUTH_APB_OWN_SELECT   | Select south apb own on PEC7.     |
| IX_PERFPROF_ACC_BUS_PMU_PEC7_SOUTH_BUS_READ_SELECT  | Select south bus read on PEC7.    |
| IX_PERFPROF_ACC_BUS_PMU_PEC7_CYCLE_COUNT_SELECT     | Select cycle count on PEC7.       |

Definition at line 410 of file IxPerfProfAcc.h.

## enum IxPerfProfAccBusPmuMode

State selection of counters.

These states will be used to determine the counters whose values are to be read.

## **Enumeration values:**

IX\_PERFPROF\_ACC\_BUS\_PMU\_MODE\_HALT halt state
IX\_PERFPROF\_ACC\_BUS\_PMU\_MODE\_SOUTH south state
IX\_PERFPROF\_ACC\_BUS\_PMU\_MODE\_NORTH north state
IX\_PERFPROF\_ACC\_BUS\_PMU\_MODE\_SDRAM SDRAM state.

Definition at line **532** of file **IxPerfProfAcc.h**.

## enum IxPerfProfAccStatus

Invalid Status Definitions.

These status will be used by the APIs to return to the user.

## **Enumeration values:**

| ation values:                                               |                         |
|-------------------------------------------------------------|-------------------------|
| IX_PERFPROF_ACC_STATUS_SUCCESS                              | success                 |
| IX_PERFPROF_ACC_STATUS_FAIL                                 | fail                    |
| IX_PERFPROF_ACC_STATUS_ANOTHER_UTIL_IN_PROGRESS             | another utility         |
|                                                             | in progress             |
| IX_PERFPROF_ACC_STATUS_XCYCLE_MEASUREMENT_IN_PROGRESS       | measurement             |
|                                                             | in progress             |
| IX_PERFPROF_ACC_STATUS_XCYCLE_NO_BASELINE                   | no baseline             |
|                                                             | yet                     |
| IX_PERFPROF_ACC_STATUS_XCYCLE_MEASUREMENT_REQUEST_OUT_OF_RA |                         |
|                                                             | chosen is out           |
| W. DEDEDD OF A G. CHATNE WOULE DRIODEN CET FAM              | of range.               |
| IX_PERFPROF_ACC_STATUS_XCYCLE_PRIORITY_SET_FAIL             | Cannot set              |
| IN DEDENDAG ACC CTATUC VCVCLE TUDEAD CDEATE FAIL            | task priority.          |
| IX_PERFPROF_ACC_STATUS_XCYCLE_THREAD_CREATE_FAIL            | Fail create thread.     |
| IX_PERFPROF_ACC_STATUS_XCYCLE_PRIORITY_RESTORE_FAIL         |                         |
| IA_FERFFROF_ACC_STATUS_ACTCLE_FRIORITI_RESTORE_FAIL         | cannot restore priority |
| IX_PERFPROF_ACC_STATUS_XCYCLE_MEASUREMENT_NOT_RUNNING       | xcycle not              |
| IX_I ERT ROF_ACC_STATOS_ACTCLE_MEASOREMENT_NOT_ROTNING      | running                 |
| IX_PERFPROF_ACC_STATUS_XSCALE_PMU_NUM_INVALID               | invalid                 |
| M_1 BRIT ROT_TICO_STRICO_REGERED_T MC_TYOM_INVIEND          | number                  |
|                                                             | entered                 |
| IX_PERFPROF_ACC_STATUS_XSCALE_PMU_EVENT_INVALID             | invalid pmu             |
|                                                             | event                   |
| IX_PERFPROF_ACC_STATUS_XSCALE_PMU_START_NOT_CALLED          | a start process         |
|                                                             | was not called          |
|                                                             | before                  |
|                                                             |                         |

attempting a stop or results

| IX_PERFPROF_ACC_STATUS_BUS_PMU_MODE_ERROR<br>IX_PERFPROF_ACC_STATUS_BUS_PMU_PEC1_ERROR |
|----------------------------------------------------------------------------------------|
| IX_PERFPROF_ACC_STATUS_BUS_PMU_PEC2_ERROR                                              |
| IX_PERFPROF_ACC_STATUS_BUS_PMU_PEC3_ERROR                                              |
| IX_PERFPROF_ACC_STATUS_BUS_PMU_PEC4_ERROR                                              |
| IX_PERFPROF_ACC_STATUS_BUS_PMU_PEC5_ERROR                                              |
| IX_PERFPROF_ACC_STATUS_BUS_PMU_PEC6_ERROR                                              |
| IX_PERFPROF_ACC_STATUS_BUS_PMU_PEC7_ERROR                                              |
| IX_PERFPROF_ACC_STATUS_BUS_PMU_START_NOT_CALLED                                        |
|                                                                                        |

get invalid mode invalid pec1 entered invalid pec2 entered invalid pec3 entered invalid pec4 entered invalid pec5 entered invalid pec6 entered invalid pec7 entered a start process was not called before attempting a stop Device or OS does not support component.

 $IX\_PERFPROF\_ACC\_STATUS\_COMPONENT\_NOT\_SUPPORTED$ 

Definition at line **469** of file **IxPerfProfAcc.h**.

## enum IxPerfProfAccXscalePmuEvent

Type of Intel XScale (R) Core PMU events supported.

Lists all Intel XScale (R) Core PMU events. The maximum is a default value that the user should not exceed.

| IX_PERFPROF_ACC_XSCALE_PMU_EVENT_CACHE_MISS        | cache miss           |
|----------------------------------------------------|----------------------|
| IX_PERFPROF_ACC_XSCALE_PMU_EVENT_CACHE_INSTRUCTION | cache instruction    |
| IX_PERFPROF_ACC_XSCALE_PMU_EVENT_STALL             | event stall          |
| IX_PERFPROF_ACC_XSCALE_PMU_EVENT_INST_TLB_MISS     | instruction tlb miss |
| IX_PERFPROF_ACC_XSCALE_PMU_EVENT_DATA_TLB_MISS     | data tlb miss        |
| IX_PERFPROF_ACC_XSCALE_PMU_EVENT_BRANCH_EXEC       | branch executed      |
| IX_PERFPROF_ACC_XSCALE_PMU_EVENT_BRANCH_MISPREDICT | branch mispredict    |
| IX_PERFPROF_ACC_XSCALE_PMU_EVENT_INST_EXEC         | instruction          |
|                                                    | executed             |
| IX_PERFPROF_ACC_XSCALE_PMU_EVENT_FULL_EVERYCYCLE   | Stall – data cache   |
|                                                    | buffers are full.    |

IX\_PERFPROF\_ACC\_XSCALE\_PMU\_EVENT\_ONCE

This event occurs every cycle where condition present Stall – data cache buffers are full. This event occurs once for each contiguous sequence. data cache access

IX\_PERFPROF\_ACC\_XSCALE\_PMU\_EVENT\_DATA\_CACHE\_ACCESS data cache access
IX\_PERFPROF\_ACC\_XSCALE\_PMU\_EVENT\_DATA\_CACHE\_MISS data cache miss
IX\_PERFPROF\_ACC\_XSCALE\_PMU\_EVENT\_DATA\_CACHE\_WRITEBACK data cache

writeback sw change pc

max value

IX\_PERFPROF\_ACC\_XSCALE\_PMU\_EVENT\_SW\_CHANGE\_PC
IX\_PERFPROF\_ACC\_XSCALE\_PMU\_EVENT\_MAX

Definition at line **429** of file **IxPerfProfAcc.h**.

## **Function Documentation**

ixPerfProfAccBusPmuPMSRGet ( UINT32 \* pmsrValue )

Get values of PMSR.

This API gets the Previous Master Slave Register value and returns it to the calling function. This value indicates which master or slave accessed the north, south bus or sdram last. The value returned by this function is a 32 bit value and is read from location of an offset 0x0024 of the base value.

The PMSR value returned indicate the following:

```
*************************
* [31:18] *Reserved*
 [17:12] * PSS * Indicates which of the slaves on
             * ARBS was previously
             * accessed by the AHBS.
             * [000001] Expansion Bus
             * [000010] SDRAM Controller
             * [000100] PCI
             * [001000] Queue Manager
             * [010000] AHB-APB Bridge
      * * [100000] Reserved
*************************
* [11:8] * PSN * Indicates which of the Slaves on
              * ARBN was previously
              * accessed the AHBN.
              * [0001] SDRAM Controller
              * [0010] AHB-AHB Bridge
```

```
* [0100] Reserved
      ******************************
 [7:4] * PMS * Indicates which of the Masters on
        * ARBS was previously
           * accessing the AHBS.
           * [0001] Gasket
            * [0010] AHB-AHB Bridge
            * [0100] PCI
           * [1000] APB
 *******************
 [3:0] * PMN * Indicates which of the Masters on
           * ARBN was previously
           * accessing the AHBN.
           * [0001] NPEA
           * [0010] NPEB
           * [0100] NPEC
```

#### Parameters:

\*pmsrValue

UINT32 [out] – Pointer to return PMSR value. Users need to allocate storage for psmrValue.

## Returns:

none

Reentrant : noISR Callable : no

## ixPerfProfAccBusPmuResults \* BusPmuResults \* BusPmuResults )

Gets values of all counters.

This function is responsible for getting all the counter values from the lower API and putting it into an array for the user.

#### Parameters:

\*busPmuResults IxPerfProfAccBusPmuResults [out]

♦ Pointer to a structure of arrays to store all counter values.

#### Returns:

none

Reentrant : noISR Callable : no

Initializes all the counters and selects events to be monitored.

Function initializes all the counters and assigns the events associated with the counters. Users send in the mode and events they want to count. This API verifies if the combination chosen is appropriate and sets all the registers accordingly. Selecting HALT mode will result in an error. User should use **ixPerfProfAccBusPmuStop()** to HALT.

#### Parameters:

```
    mode [in] – Mode selection.
    pecEvent1 IxPerfProfAccBusPmuEventCounters1 [in] – Event for PEC1.
    pecEvent2 IxPerfProfAccBusPmuEventCounters2 [in] – Event for PEC2.
    pecEvent3 IxPerfProfAccBusPmuEventCounters3 [in] – Event for PEC3.
    pecEvent4 IxPerfProfAccBusPmuEventCounters4 [in] – Event for PEC4.
    pecEvent5 IxPerfProfAccBusPmuEventCounters5 [in] – Event for PEC5.
    pecEvent6 IxPerfProfAccBusPmuEventCounters6 [in] – Event for PEC6.
    pecEvent7 IxPerfProfAccBusPmuEventCounters7 [in] – Event for PEC7.
```

## Returns:

- ♦ IX\_PERFPROF\_ACC\_STATUS\_SUCCESS Initialization executed successfully.
- ♦ IX\_PERFPROF\_ACC\_STATUS\_BUS\_PMU\_MODE\_ERROR Error in selection of mode. Only NORTH, SOUTH and SDRAM modes are allowed.
- ♦ IX\_PERFPROF\_ACC\_STATUS\_BUS\_PMU\_PEC1\_ERROR Error in selection of event for PEC1
- ♦ IX\_PERFPROF\_ACC\_STATUS\_BUS\_PMU\_PEC2\_ERROR Error in selection of event for PEC2
- ♦ IX\_PERFPROF\_ACC\_STATUS\_BUS\_PMU\_PEC3\_ERROR Error in selection of event for PEC3
- ♦ IX\_PERFPROF\_ACC\_STATUS\_BUS\_PMU\_PEC4\_ERROR Error in selection of event for PEC4
- ♦ IX\_PERFPROF\_ACC\_STATUS\_BUS\_PMU\_PEC5\_ERROR Error in selection of event for PEC5
- ♦ IX\_PERFPROF\_ACC\_STATUS\_BUS\_PMU\_PEC6\_ERROR Error in selection of event for PEC6
- ♦ IX\_PERFPROF\_ACC\_STATUS\_BUS\_PMU\_PEC7\_ERROR Error in selection of event for PEC7
- ♦ IX\_PERFPROF\_ACC\_STATUS\_ANOTHER\_UTIL\_IN\_PROGRESS another utility is running
- ♦ IX\_PERFPROF\_ACC\_STATUS\_FAIL Failed to start because interrupt service routine fails to bind.

Reentrant : noISR Callable : no

## ixPerfProfAccBusPmuStop (void )

Stops all counters.

This function stops all the PECs by setting the halt bit in the ESR.

#### Returns:

- ♦ IX\_PERFPROF\_ACC\_STATUS\_SUCCESS Counters successfully halted.
- ♦ IX\_PERFPROF\_ACC\_STATUS\_FAIL Counters could'nt be halted.
- ♦ IX\_PERFPROF\_ACC\_STATUS\_BUS\_PMU\_START\_NOT\_CALLED the ixPerfProfAccBusPmuStart() function is not called.

Reentrant : noISR Callable : no

ixPerfProfAccXcycleBaselineRun ( UINT32 \* numBaselineCycle )

Perform baseline for Xcycle.

#### Parameters:

\*numBaselineCycle UINT32 [out] – pointer to baseline value after calibration. Calling function are responsible for allocating memory space for this pointer.

#### Global Data:

• None.

This function MUST be run before the Xcycle tool can be used. This function must be run immediately when the OS boots up with no other addition programs running. Addition note: This API will measure the time needed to perform a fix amount of CPU instructions (~ 1 second worth of loops) as a highest priority task and with interrupt disabled. The time measured is known as the baseline – interpreted as the shortest time needed to complete the amount of CPU instructions. The baseline is returned as unit of time in 66Mhz clock tick.

#### Returns:

- ♦ IX\_PERFPROF\_ACC\_STATUS\_SUCCESS successful run, result is returned
- ♦ IX\_PERFPROF\_ACC\_STATUS\_XCYCLE\_PRIORITY\_SET\_FAIL failed to change task priority
- ♦ IX\_PERFPROF\_ACC\_STATUS\_XCYCLE\_PRIORITY\_RESTORE\_FAIL failed to restore task priority
- ♦ IX\_PERFPROF\_ACC\_STATUS\_ANOTHER\_UTIL\_IN\_PROGRESS another utility is running
- ♦ IX\_PERFPROF\_ACC\_STATUS\_XCYCLE\_MEASUREMENT\_IN\_PROGRESS Xcycle tool has already started

Reentrant : noISR Callable : no

## ixPerfProfAccXcycleInProgress (void)

Check if Xcycle is running.

## Parameters:

```
None Global Data : 

◊ None.
```

Check if Xcycle measuring task is running.

#### Returns:

```
♦ TRUE – Xcycle is running♦ FALSE – Xcycle is not running
```

Reentrant : noISR Callable : no

## ixPerfProfAccXcycleResultsGet ( IxPerfProfAccXcycleResults \* xcycleResult )

Get the results of Xcycle measurement.

## Parameters:

\*xcycleResult **IxPerfProfAccXcycleResults** [out] – Pointer to results of last measurements. Calling function are responsible for allocating memory space for this pointer.

#### Global Data:

• None.

Retrieve the results of last measurement. User should use **ixPerfProfAccXcycleInProgress**() to check if measurement is completed before getting the results.

#### Returns:

```
♦ IX_PERFPROF_ACC_STATUS_SUCCESS – successful
```

- ♦ IX\_PERFPROF\_ACC\_STATUS\_FAIL result is not complete.
- ♦ IX\_PERFPROF\_ACC\_STATUS\_XCYCLE\_NO\_BASELINE baseline is performed
- $\Diamond$  IX\_PERFPROF\_ACC\_STATUS\_XCYCLE\_MEASUREMENT\_IN\_PROGRESS Xcycle tool is still running

Reentrant : noISR Callable : no

ixPerfProfAccXcycleStart (UINT32 numMeasurementsRequested)

Start the measurement.

#### Parameters:

numMeasurementsRequested UINT32 [in] – number of measurements to perform. Value can be 0 to IX\_PERFPROF\_ACC\_XCYCLE\_MAX\_NUM\_OF\_MEASUREMENTS. 0 indicate continuous measurement.

#### Global Data:

• None.

Start the measurements immediately. numMeasurementsRequested specifies number of measurements to run. If numMeasurementsRequested is set to 0, the measurement will be performed continuously until IxPerfProfAccXcycleStop() is called. It is estimated that 1 measurement takes approximately 1 second during low CPU utilization, therefore 128 measurement takes approximately 128 sec. When CPU utilization is high, the measurement will take longer. This function spawn a task the perform the measurement and returns. The measurement may continue even if this function returns.

IMPORTANT: Under heavy CPU utilization, the task spawn by this function may starve and fail to respond to stop command. User may need to kill the task manually in this case.

There are only IX\_PERFPROF\_ACC\_XCYCLE\_MAX\_NUM\_OF\_MEASUREMENTS storage available so storing is wrapped around if measurements are more than IX\_PERFPROF\_ACC\_XCYCLE\_MAX\_NUM\_OF\_MEASUREMENTS.

## Returns:

- ♦ IX\_PERFPROF\_ACC\_STATUS\_SUCCESS successful start, a thread is created in the background to perform measurement.
- ♦ IX\_PERFPROF\_ACC\_STATUS\_XCYCLE\_PRIORITY\_SET\_FAIL failed to set task priority
- ♦ IX\_PERFPROF\_ACC\_STATUS\_XCYCLE\_THREAD\_CREATE\_FAIL failed to create thread to perform measurement.
- ♦ IX\_PERFPROF\_ACC\_STATUS\_XCYCLE\_NO\_BASELINE baseline is not available
- ♦ IX\_PERFPROF\_ACC\_STATUS\_XCYCLE\_MEASUREMENT\_REQUEST\_OUT\_OF\_RANGE value is larger than
  - IX\_PERFPROF\_ACC\_XCYCLE\_MAX\_NUM\_OF\_MEASUREMENTS
- ♦ IX\_PERFPROF\_ACC\_STATUS\_XCYCLE\_MEASUREMENT\_IN\_PROGRESS Xcycle tool has already started
- ♦ IX\_PERFPROF\_ACC\_STATUS\_ANOTHER\_UTIL\_IN\_PROGRESS another utility is running

Reentrant : noISR Callable : no

## ixPerfProfAccXcycleStop (void )

Stop the Xcycle measurement.

#### Parameters:

Stop Xcycle measurements immediately. If the measurements have stopped or not started, return IX\_PERFPROF\_STATUS\_XCYCLE\_MEASUREMENT\_NOT\_RUNNING. Note: This function does not stop measurement cold. The measurement thread may need a few seconds to complete the last measurement. User needs to use **ixPerfProfAccXcycleInProgress()** to determine if measurement is indeed completed.

## Returns:

- ♦ IX\_PERFPROF\_ACC\_STATUS\_SUCCESS successful measurement is stopped
  ♦ IX\_PERFPROF\_STATUS\_XCYCLE\_MEASUREMENT\_NOT\_RUNNING no measurement running
- Reentrant : noISR Callable : no

This API will start the clock and event counting.

## Parameters:

- clkCntDiv BOOL [in] enables/disables the clock divider. When true, the divider is enabled and the clock count will be incremented by one at each 64th processor clock cycle. When false, the divider is disabled and the clock count will be incremented at every processor clock cycle.
- numEvents UINT32 [in] the number of PMU events that are to be monitored as specified by the user. For clock counting only, this is set to zero.
- pmuEvent1 IxPerfProfAccXscalePmuEvent [in] the specific PMU event to be monitored by counter 1
- pmuEvent2 IxPerfProfAccXscalePmuEvent [in] the specific PMU event to be monitored by counter 2
- pmuEvent3 IxPerfProfAccXscalePmuEvent [in] the specific PMU event to be monitored by counter 3
- pmuEvent4 IxPerfProfAccXscalePmuEvent [in] the specific PMU event to be monitored by counter 4

This API will start the clock and Intel XScale (R) Core PMU event counting. Up to 4 events can be monitored simultaneously. This API has to be called before ixPerfProfAccXscalePmuEventCountStop can be called.

## Returns:

- ♦ IX\_PERFPROF\_ACC\_STATUS\_SUCCESS if clock and events counting are started successfully
- ♦ IX\_PERFPROF\_ACC\_STATUS\_FAIL if unable to start the counting
- ♦ IX\_PERFPROF\_ACC\_STATUS\_XSCALE\_PMU\_NUM\_INVALID if the number of events specified is out of the valid range
- ♦ IX\_PERFPROF\_ACC\_STATUS\_XSCALE\_PMU\_EVENT\_INVALID if the value of the PMU event specified does not exist
- ♦ IX\_PERFPROF\_ACC\_STATUS\_ANOTHER\_UTIL\_IN\_PROGRESS another utility is running

Reentrant : noISR Callable : no

ixPerfProfAccXscalePmuEventCountStop ( IxPerfProfAccXscalePmuResults \* eventCountStopResults )

This API will stop the clock and event counting.

## Parameters:

\*eventCountStopResults IxPerfProfAccXscalePmuResults [out] – pointer to struct containing results of counters and their overflow. It is the users's responsibility to allocate the memory for this pointer.

This API will stop the clock and Intel XScale (R) Core PMU events that are being counted. The results of the clock and events count will be stored in the pointer allocated by the user. It can only be called once IxPerfProfAccEventCountStart has been called.

## Returns:

- ♦ IX\_PERFPROF\_ACC\_STATUS\_SUCCESS if clock and events counting are stopped successfully
- ♦ IX\_PERFPROF\_ACC\_STATUS\_XSCALE\_PMU\_START\_NOT\_CALLED if ixPerfProfAccXscalePmuEventCountStart is not called first.

Reentrant : noISR Callable : no

Starts the event based sampling.

#### Parameters:

- numEvents UINT32 [in] the number of PMU events that are to be monitored as specified by the user. The value should be between 1–4 events at a time.
- pmuEvent1 IxPerfProfAccXscalePmuEvent [in] the specific PMU event to be monitored by counter 1
- eventRate1 UINT32 [in] sampling rate of counter 1. The rate is the number of events before a sample taken. If 0 is specified, the the full counter value (0xFFFFFFF) is used. The rate must not be greater than the full counter value.
- pmuEvent2 IxPerfProfAccXscalePmuEvent [in] the specific PMU event to be monitored by counter 2
- eventRate2 UINT32 [in] sampling rate of counter 2. The rate is the number of events before a sample taken. If 0 is specified, the full counter value (0xFFFFFFF) is used. The rate must not be greater than the full counter value.
- pmuEvent3 IxPerfProfAccXscalePmuEvent [in] the specific PMU event to be monitored by counter 3
- eventRate3 UINT32 [in] sampling rate of counter 3. The rate is the number of events before a sample taken. If 0 is specified, the full counter value (0xFFFFFFF) is used. The rate must not be greater than the full counter value.
- pmuEvent4 **IxPerfProfAccXscalePmuEvent** [in] the specific PMU event to be monitored by counter 4
- eventRate4 UINT32 [in] sampling rate of counter 4. The rate is the number of events before a sample taken. If 0 is specified, the full counter value (0xFFFFFFF) is used. The rate must not be greater than the full counter value.

Starts the event based sampling to determine the frequency with which events are being executed. The sampling rate is the number of events, as specified by the user, before a counter overflow interrupt is generated. A sample is taken at each counter overflow interrupt. At each sample,the value of the program counter determines the corresponding location in the code. Each of these occurrences are recorded to determine the frequency with which the Xscale code in each event is executed. This API has to be called before ixPerfProfAccXscalePmuEventSampStop can be called.

## Returns:

- ♦ IX\_PERFPROF\_ACC\_STATUS\_SUCCESS if event based sampling is started successfully
- ♦ IX\_PERFPROF\_ACC\_STATUS\_FAIL if unable to start the sampling
- ♦ IX\_PERFPROF\_ACC\_STATUS\_XSCALE\_PMU\_NUM\_INVALID if the number of events specified is out of the valid range
- ♦ IX\_PERFPROF\_ACC\_STATUS\_XSCALE\_PMU\_EVENT\_INVALID if the value of the PMU event specified does not exist
  - · IX\_PERFPROF\_ACC\_STATUS\_ANOTHER\_UTIL\_IN\_PROGRESS another utility is running

Reentrant : noISR Callable : no

Stops the event based sampling.

## Parameters:

- \*eventProfile1 IxPerfProfAccXscalePmuSamplePcProfile [out] pointer to the array of profiles for each program counter value; the user should set the size of the array to IX\_PERFPROF\_ACC\_XSCALE\_PMU\_MAX\_PROFILE\_SAMPLES. It is the users's responsibility to allocate memory for this pointer.
- \*eventProfile2 IxPerfProfAccXscalePmuSamplePcProfile [out] pointer to the array of profiles for each program counter value; the user should set the size of the array to IX\_PERFPROF\_ACC\_XSCALE\_PMU\_MAX\_PROFILE\_SAMPLES. It is the users's responsibility to allocate memory for this pointer.
- \*eventProfile3 IxPerfProfAccXscalePmuSamplePcProfile [out] pointer to the array of profiles for each program counter value; the user should set the size of the array to IX\_PERFPROF\_ACC\_XSCALE\_PMU\_MAX\_PROFILE\_SAMPLES. It is the users's responsibility to allocate memory for this pointer.
- \*eventProfile4 IxPerfProfAccXscalePmuSamplePcProfile [out] pointer to the array of profiles for each program counter value; the user should set the size of the array to IX\_PERFPROF\_ACC\_XSCALE\_PMU\_MAX\_PROFILE\_SAMPLES. It is the users's responsibility to allocate memory for this pointer.

This API stops the event based sampling. The results are stored in the pointers allocated by the user. It can only be called once ixPerfProfAccEventSampStart has been called.

## Returns:

- ♦ IX\_PERFPROF\_ACC\_STATUS\_SUCCESS if event based sampling is stopped successfully
- ♦ IX\_PERFPROF\_ACC\_STATUS\_XSCALE\_PMU\_START\_NOT\_CALLED if ixPerfProfAccEventSampStart not called first.

Reentrant : noISR Callable : no

ixPerfProfAccXscalePmuResultsGet ( IxPerfProfAccXscalePmuResults \* results )

Reads the current value of the counters and their overflow.

## Parameters:

\*results **IxPerfProfAccXscalePmuResults** [out] – pointer to the results struct. It is the user's responsibility to allocate memory for this pointer

This API reads the value of all four event counters and the clock counter, and the associated overflows. It does not give results associated with sampling, i.e. PC and their frequencies. This API can be called at any time once a process has been started. If it is called before a process has started the user should be aware that

the values it contains are default values and might be meaningless. The values of the counters are stored in the pointer allocated by the client.

#### Returns:

none

Reentrant : noISR Callable : no

```
ixPerfProfAccXscalePmuTimeSampStart ( UINT32 samplingRate, BOOL clkCntDiv )
```

Starts the time based sampling.

#### Parameters:

samplingRate UINT32 [in] – sampling rate is the number of clock counts before a counter overflow interrupt is generated, at which, a sample is taken; the rate specified cannot be greater

than the counter size of 32bits or set to zero.

clkCntDiv BOOL [in] – enables/disables the clock divider. When true, the divider is enabled

and the clock count will be incremented by one at each 64th processor clock cycle. When false, the divider is disabled and the clock count will be incremented at every

processor clock cycle.

This API starts the time based sampling to determine the frequency with which lines of code are being executed. Sampling is done at the rate specified by the user. At each sample, the value of the program counter is determined. Each of these occurrences are recorded to determine the frequency with which the Xscale code is being executed. This API has to be called before ixPerfProfAccXscalePmuTimeSampStop can be called.

#### Returns:

- $\lozenge \ IX\_PERFPROF\_ACC\_STATUS\_SUCCESS \ if \ time \ based \ sampling \ is \ started \ successfully$
- ♦ IX\_PERFPROF\_ACC\_STATUS\_FAIL if unable to start the sampling
- ♦ IX\_PERFPROF\_ACC\_STATUS\_ANOTHER\_UTIL\_IN\_PROGRESS another utility is running

Reentrant : noISR Callable : no

```
ix Perf Prof Acc X scale Pmu Evt Cnt * clk Count, \\ Ix Perf Prof Acc X scale Pmu Sample Pc Profile * time Profile \\ )
```

Stops the time based sampling.

#### Parameters:

\*clkCount **IxPerfProfAccXscalePmuEvtCnt** [out] – pointer to the struct containing the final clock count and its overflow. It is the user's responsibility to allocate the memory for

this pointer.

\*timeProfile IxPerfProfAccXscalePmuSamplePcProfile [out] – pointer to the array of profiles for each program counter value; the user should set the size of the array to IX\_PERFPROF\_ACC\_XSCALE\_PMU\_MAX\_PROFILE\_SAMPLES. It is the user's responsibility to allocate the memory for this pointer.

This API stops the time based sampling. The results are stored in the pointers allocated by the user. It can only be called once ixPerfProfAccXscalePmuTimeSampStart has been called.

#### Returns:

- ♦ IX\_PERFPROF\_ACC\_STATUS\_SUCCESS if time based sampling is stopped successfully
- ♦ IX\_PERFPROF\_ACC\_STATUS\_XSCALE\_PMU\_START\_NOT\_CALLED if ixPerfProfAccXscalePmuTimeSampStart not called first

Reentrant : noISR Callable : no

## Intel (R) IXP400 Software Queue Manager (IxQMgr) API

The public API for the IXP400 QMgr component.

## **Data Structures**

## struct IxQMgrQInlinedReadWriteInfo

Internal structure to facilitate inlining functions in **IxQMgr.h**.

## **Defines**

#define IX\_QMGR\_INLINE\_READ\_LONG

#define IX\_QMGR\_INLINE\_WRITE\_LONG

#define IX\_QMGR\_INLINE

Inline definition, for inlining of Queue Access functions on API.

## #define IX\_QMGR\_MAX\_NUM\_QUEUES

Number of queues supported by the AQM.

## #define IX\_QMGR\_MIN\_QID

Minimum queue identifier.

## #define IX\_QMGR\_MAX\_QID

Maximum queue identifier.

## #define IX\_QMGR\_MIN\_QUEUPP\_QID

Minimum queue identifier for reduced functionality queues.

## #define IX\_QMGR\_MAX\_QNAME\_LEN

Maximum queue name length.

## #define IX\_QMGR\_WARNING

Warning return code.

## #define IX QMGR PARAMETER ERROR

Parameter error return code (NULL pointer etc..).

## #define IX\_QMGR\_INVALID\_Q\_ENTRY\_SIZE

Invalid entry size return code.

## #define IX\_QMGR\_INVALID\_Q\_ID

Invalid queue identifier return code.

#define IX\_QMGR\_INVALID\_CB\_ID

Invalid callback identifier return code.

## #define IX QMGR CB ALREADY SET

Callback set error return code.

## #define IX\_QMGR\_NO\_AVAILABLE\_SRAM

Sram consumed return code.

## #define IX\_QMGR\_INVALID\_INT\_SOURCE\_ID

Invalid queue interrupt source identifier return code.

## #define IX\_QMGR\_INVALID\_QSIZE

Invalid queue size error code.

## #define IX\_QMGR\_INVALID\_Q\_WM

Invalid queue watermark return code.

## #define IX\_QMGR\_Q\_NOT\_CONFIGURED

Queue not configured return code.

## #define IX\_QMGR\_Q\_ALREADY\_CONFIGURED

Queue already configured return code.

## #define IX QMGR Q UNDERFLOW

Underflow return code.

## #define IX\_QMGR\_Q\_OVERFLOW

Overflow return code.

## #define IX\_QMGR\_Q\_INVALID\_PRIORITY

Invalid priority return code.

## #define IX QMGR ENTRY INDEX OUT OF BOUNDS

Entry index out of bounds return code.

## #define ixQMgrDispatcherLoopRun

Map old function name ixQMgrDispatcherLoopRun () to ixQMgrDispatcherLoopRunA0 ().

## #define IX\_QMGR\_QUEUE\_0

Queue Number 0.

## #define IX\_QMGR\_QUEUE\_1

Queue Number 1.

## #define IX\_QMGR\_QUEUE\_2

Queue Number 2.

## #define IX QMGR QUEUE 3

Queue Number 3.

- #define **IX\_QMGR\_QUEUE\_4** *Queue Number 4.*
- #define **IX\_QMGR\_QUEUE\_5** *Queue Number 5.*
- #define **IX\_QMGR\_QUEUE\_6** *Queue Number 6.*
- #define **IX\_QMGR\_QUEUE\_7** *Queue Number 7.*
- #define **IX\_QMGR\_QUEUE\_8** *Queue Number 8.*
- #define **IX\_QMGR\_QUEUE\_9** *Queue Number 9.*
- #define **IX\_QMGR\_QUEUE\_10** *Queue Number 10.*
- #define **IX\_QMGR\_QUEUE\_11** *Queue Number 11*.
- #define **IX\_QMGR\_QUEUE\_12** *Queue Number 12.*
- #define IX\_QMGR\_QUEUE\_13 *Queue Number 13*.
- #define **IX\_QMGR\_QUEUE\_14** *Queue Number 14.*
- #define **IX\_QMGR\_QUEUE\_15** *Queue Number 15.*
- #define **IX\_QMGR\_QUEUE\_16** *Queue Number 16.*
- #define **IX\_QMGR\_QUEUE\_17** *Queue Number 17.*
- #define **IX\_QMGR\_QUEUE\_18** *Queue Number 18.*
- #define **IX\_QMGR\_QUEUE\_19** *Queue Number 19.*
- #define **IX\_QMGR\_QUEUE\_20** *Queue Number 20.*

- #define **IX\_QMGR\_QUEUE\_21** *Queue Number 21.*
- #define **IX\_QMGR\_QUEUE\_22** *Queue Number 22.*
- #define **IX\_QMGR\_QUEUE\_23** *Queue Number 23.*
- #define **IX\_QMGR\_QUEUE\_24** *Queue Number 24.*
- #define **IX\_QMGR\_QUEUE\_25** *Queue Number 25.*
- #define **IX\_QMGR\_QUEUE\_26** *Queue Number 26.*
- #define **IX\_QMGR\_QUEUE\_27** *Queue Number 27.*
- #define **IX\_QMGR\_QUEUE\_28** *Queue Number 28.*
- #define **IX\_QMGR\_QUEUE\_29** *Queue Number 29.*
- #define IX\_QMGR\_QUEUE\_30 *Queue Number 30.*
- #define **IX\_QMGR\_QUEUE\_31** *Queue Number 31*.
- #define **IX\_QMGR\_QUEUE\_32** *Queue Number 32.*
- #define **IX\_QMGR\_QUEUE\_33** *Queue Number 33*.
- #define **IX\_QMGR\_QUEUE\_34** *Queue Number 34*.
- #define **IX\_QMGR\_QUEUE\_35** *Queue Number 35.*
- #define **IX\_QMGR\_QUEUE\_36** *Queue Number 36.*
- #define **IX\_QMGR\_QUEUE\_37** *Queue Number 37.*

- #define **IX\_QMGR\_QUEUE\_38** *Queue Number 38.*
- #define **IX\_QMGR\_QUEUE\_39** *Queue Number 39.*
- #define **IX\_QMGR\_QUEUE\_40** *Queue Number 40.*
- #define **IX\_QMGR\_QUEUE\_41** *Queue Number 41.*
- #define **IX\_QMGR\_QUEUE\_42** *Queue Number 42.*
- #define **IX\_QMGR\_QUEUE\_43** *Queue Number 43.*
- #define **IX\_QMGR\_QUEUE\_44** *Queue Number 44.*
- #define **IX\_QMGR\_QUEUE\_45** *Queue Number 45*.
- #define **IX\_QMGR\_QUEUE\_46** *Queue Number 46.*
- #define **IX\_QMGR\_QUEUE\_47** *Queue Number 47.*
- #define **IX\_QMGR\_QUEUE\_48** *Queue Number 48.*
- #define **IX\_QMGR\_QUEUE\_49** *Queue Number 49.*
- #define **IX\_QMGR\_QUEUE\_50** *Queue Number 50.*
- #define **IX\_QMGR\_QUEUE\_51** *Queue Number 51.*
- #define **IX\_QMGR\_QUEUE\_52** *Queue Number 52.*
- #define **IX\_QMGR\_QUEUE\_53** *Queue Number 53*.
- #define **IX\_QMGR\_QUEUE\_54** *Queue Number 54.*

## #define IX\_QMGR\_QUEUE\_55

Queue Number 55.

## #define IX\_QMGR\_QUEUE\_56

Queue Number 56.

## #define IX\_QMGR\_QUEUE\_57

Queue Number 57.

## #define IX\_QMGR\_QUEUE\_58

Queue Number 58.

## #define IX\_QMGR\_QUEUE\_59

Queue Number 59.

## #define IX\_QMGR\_QUEUE\_60

Queue Number 60.

## #define IX QMGR QUEUE 61

Queue Number 61.

## #define IX\_QMGR\_QUEUE\_62

Queue Number 62.

## #define IX\_QMGR\_QUEUE\_63

Queue Number 63.

## #define IX\_QMGR\_QUEUE\_INVALID

AQM Queue Number Delimiter.

## **Typedefs**

## typedef int IxQMgrQId

Used in the API to identify the AQM queues.

## typedef UINT32 IxQMgrQStatus

Queue status.

## typedef unsigned IxQMgrCallbackId

Uniquely identifies a callback function.

## $typedef\ void (*\ \textbf{IxQMgrCallback}\ ) (\textbf{IxQMgrQId}\ qId,\ \textbf{IxQMgrCallbackId}\ cbId) \\ \textit{QMgr\ notification\ callback\ type}.$

typedef void(\* **IxQMgrDispatcherFuncPtr** )(**IxQMgrDispatchGroup** group)

\*\*QMgr Dispatcher Loop function pointer.

Typedefs 409

# **Enumerations**

```
enum IxQMgrQStatusMask {
     IX_QMGR_Q_STATUS_E_BIT_MASK,
     IX_QMGR_Q_STATUS_NE_BIT_MASK,
     IX_QMGR_Q_STATUS_NF_BIT_MASK,
     IX_QMGR_Q_STATUS_F_BIT_MASK,
     IX_QMGR_Q_STATUS_UF_BIT_MASK,
     IX_QMGR_Q_STATUS_OF_BIT_MASK
    Queue status mask.
enum IxQMgrSourceId {
     IX_QMGR_Q_SOURCE_ID_E,
     IX_QMGR_Q_SOURCE_ID_NE,
     IX_QMGR_Q_SOURCE_ID_NF,
     IX_QMGR_Q_SOURCE_ID_F,
     IX_QMGR_Q_SOURCE_ID_NOT_E,
     IX_QMGR_Q_SOURCE_ID_NOT_NE,
     IX_QMGR_Q_SOURCE_ID_NOT_NF,
     IX_QMGR_Q_SOURCE_ID_NOT_F
    Queue interrupt source select.
enum IxQMgrQEntrySizeInWords {
     IX_QMGR_Q_ENTRY_SIZE1,
     IX_QMGR_Q_ENTRY_SIZE2,
     IX_QMGR_Q_ENTRY_SIZE4
    QMgr queue entry sizes.
enum IxQMgrQSizeInWords {
     IX_QMGR_Q_SIZE16,
     IX_QMGR_Q_SIZE32,
     IX_QMGR_Q_SIZE64,
     IX_QMGR_Q_SIZE128,
     IX_QMGR_Q_SIZE_INVALID
    QMgr queue sizes.
enum IxQMgrWMLevel {
     IX_QMGR_Q_WM_LEVEL0,
     IX_QMGR_Q_WM_LEVEL1,
     IX_QMGR_Q_WM_LEVEL2,
     IX_QMGR_Q_WM_LEVEL4,
     IX_QMGR_Q_WM_LEVEL8,
     IX_QMGR_Q_WM_LEVEL16,
     IX_QMGR_Q_WM_LEVEL32,
     IX_QMGR_Q_WM_LEVEL64
```

Enumerations 410

*OMgr* watermark levels.

# **Functions**

PUBLIC IX\_STATUS ixQMgrInit (void)

Initialise the QMgr.

PUBLIC IX\_STATUS ixQMgrUnload (void)

Uninitialise the QMgr.

PUBLIC void ixQMgrShow (void)

Describe queue configuration and statistics for active queues.

PUBLIC IX\_STATUS ixQMgrQShow (IxQMgrQId qId)

Display aqueue configuration and statistics for a queue.

PUBLIC IX\_STATUS ixQMgrQConfig (char \*qName, IxQMgrQId qId,

IxQMgrQSizeInWords qSizeInWords, IxQMgrQEntrySizeInWords qEntrySizeInWords)

Configure an AQM queue.

PUBLIC IX\_STATUS ixQMgrQSizeInEntriesGet (IxQMgrQId qId, unsigned

\*qSizeInEntries)

Return the size of a queue in entries.

PUBLIC IX\_STATUS **ixQMgrWatermarkSet** (**IxQMgrQId** qId, **IxQMgrWMLevel** ne, **IxQMgrWMLevel** nf)

Functions 411

Set the Nearly Empty and Nearly Full Watermarks fo a queue.

PUBLIC IX\_STATUS **ixQMgrAvailableSramAddressGet** (UINT32 \*address, unsigned \*sizeOfFreeSram)

Return the address of available AQM SRAM.

PUBLIC IX\_STATUS **ixQMgrQReadWithChecks** (**IxQMgrQId** qId, UINT32 \*entry) *Read an entry from a queue.* 

 $PUBLIC\ IX\_STATUS\ \textbf{ixQMgrQReadMWordsMinus1}\ (\textbf{IxQMgrQId}\ qId,\ UINT32\ *entry)$ 

This function reads the remaining of the q entry for queues configured with many words. (the first word of the entry is already read in the inlined function and the entry pointer already incremented.

IX OMGR INLINE PUBLIC

IX\_STATUS ixQMgrQRead (IxQMgrQId qId, UINT32 \*entryPtr)

Fast read of an entry from a queue.

IX\_QMGR\_INLINE PUBLICixQMgrQBurstRead (IxQMgrQId qId, UINT32 numEntries, UINT32 IX STATUS \*entries)

Read a number of entries from an AQM queue.

PUBLIC IX\_STATUS **ixQMgrQPeek** (**IxQMgrQId** qId, unsigned int entryIndex, UINT32 \*entry)

Read an entry from a queue without moving the read pointer.

PUBLIC IX\_STATUS **ixQMgrQWriteWithChecks** (**IxQMgrQId** qId, UINT32 \*entry) Write an entry to an AQM queue.

IX\_QMGR\_INLINE PUBLIC

IX\_STATUS ixQMgrQWrite (IxQMgrQId qId, UINT32 \*entry)

Fast write of an entry to a queue.

IX\_QMGR\_INLINE PUBLICixQMgrQBurstWrite (IxQMgrQId qId, unsigned numEntries, UINT32 IX\_STATUS \*entries)

Write a number of entries to an AQM queue.

PUBLIC IX\_STATUS ixQMgrQPoke (IxQMgrQId qId, unsigned int entryIndex, UINT32

\*entry)

Write an entry to a queue without moving the write pointer.

PUBLIC IX\_STATUS ixQMgrQNumEntriesGet (IxQMgrQId qId, unsigned \*numEntries)

Get a snapshot of the number of entries in a queue.

PUBLIC IX\_STATUS ixQMgrQStatusGetWithChecks (IxQMgrQId qId, IxQMgrQStatus \*qStatus)

Get a queues status.

Ger a queues sum

IX QMGR INLINE PUBLIC

IX\_STATUS ixQMgrQStatusGet (IxQMgrQId qId, IxQMgrQStatus \*qStatus)

Functions 412

Fast get of a queue's status.

# PUBLIC IX\_STATUS ixQMgrDispatcherPrioritySet (IxQMgrQId qId, IxQMgrPriority priority)

Set the dispatch priority of a queue.

# PUBLIC IX\_STATUS **ixQMgrNotificationEnable** (**IxQMgrQId** qId, **IxQMgrSourceId** sourceId)

Enable notification on a queue for a specified queue source flag.

# PUBLIC IX\_STATUS ixQMgrNotificationDisable (IxQMgrQId qId)

Disable notifications on a queue.

# PUBLIC void **ixQMgrDispatcherLoopRunA0** (**IxQMgrDispatchGroup** group) *Run the callback dispatcher*.

PUBLIC void **ixQMgrDispatcherLoopRunB0** (**IxQMgrDispatchGroup** group) Run the callback dispatcher.

# PUBLIC void **ixQMgrDispatcherLoopRunB0LLP** (**IxQMgrDispatchGroup** group) *Run the callback dispatcher*.

# $PUBLIC\ IX\_STATUS\ \textbf{ixQMgrNotificationCallbackSet}\ (\textbf{IxQMgrQId}\ qId,\ \textbf{IxQMgrCallback}\ callback,\ \textbf{IxQMgrCallbackId}\ callbackId)$

Set the notification callback for a queue.

#### PUBLIC void ixQMgrDispatcherLoopGet (IxQMgrDispatcherFuncPtr

\*qDispatcherFuncPtr)

Get QMgr DispatcherLoopRun for respective silicon device.

#### PUBLIC void ixQMgrStickyInterruptRegEnable (void)

Enable AQM's sticky interrupt register behaviour only available on B0 Silicon.

# PUBLIC IX\_STATUS **ixQMgrCallbackTypeSet** (**IxQMgrQId** qId, **IxQMgrType** type) *Set the CallbackType of a queue.*

# PUBLIC IX\_STATUS **ixQMgrCallbackTypeGet** (**IxQMgrQId** qId, **IxQMgrType** \*type) *Get the CallbackType of a queue.*

#### PUBLIC void ixQMgrPeriodicDone (void)

Indicate that the Periodic task is completed for LLP.

#### PUBLIC void **ixQMgrLLPShow** (int resetStats)

Print out the live lock prevention statistics when in debug mode.

Functions 413

# **Variables**

IxQMgrQInlinedReadWriteInfo ixQMgrQInlinedReadWriteInfo []

UINT32 ixQMgrAqmIfQueLowStatRegAddr []

UINT32 ixQMgrAqmIfQueLowStatBitsOffset []

UINT32 ixQMgrAqmIfQueLowStatBitsMask

UINT32 ixQMgrAqmIfQueUppStat0RegAddr

UINT32 ixQMgrAqmIfQueUppStat1RegAddr

UINT32 ixQMgrAqmIfQueUppStat0BitMask []

UINT32 ixQMgrAqmIfQueUppStat1BitMask []

# **Detailed Description**

The public API for the IXP400 QMgr component.

IxQMgr is a low level interface to the AHB Queue Manager

# **Define Documentation**

# #define IX\_QMGR\_CB\_ALREADY\_SET

Callback set error return code.

The specified callback has already been for this queue

Definition at line **261** of file **IxQMgr.h**.

#### #define IX QMGR ENTRY INDEX OUT OF BOUNDS

Entry index out of bounds return code.

Entry index is greater than number of entries in queue.

Definition at line 388 of file IxQMgr.h.

#### #define IX\_QMGR\_INLINE

Inline definition, for inlining of Queue Access functions on API.

Please read the header information in this file for more details on the use of function inlining in this component.

Definition at line 102 of file IxQMgr.h.

# #define IX\_QMGR\_INVALID\_CB\_ID

Invalid callback identifier return code.

Invalid callback id

Definition at line 248 of file IxQMgr.h.

#### #define IX\_QMGR\_INVALID\_INT\_SOURCE\_ID

Invalid queue interrupt source identifier return code.

Invalid queue interrupt source given for notification enable

Definition at line **286** of file **IxQMgr.h**.

# #define IX\_QMGR\_INVALID\_Q\_ENTRY\_SIZE

Invalid entry size return code.

Invalid queue entry size for a queue read/write

Definition at line 223 of file IxQMgr.h.

# #define IX\_QMGR\_INVALID\_Q\_ID

Invalid queue identifier return code.

Invalid queue id, not in range 0-63

Definition at line **236** of file **IxQMgr.h**.

# #define IX\_QMGR\_INVALID\_Q\_WM

Invalid queue watermark return code.

Invalid queue watermark given for watermark set

Definition at line **312** of file **IxQMgr.h**.

#### #define IX\_QMGR\_INVALID\_QSIZE

Invalid queue size error code.

Invalid queue size not one of 16,32, 64, 128

Definition at line 300 of file IxQMgr.h.

# #define IX\_QMGR\_MAX\_NUM\_QUEUES

Number of queues supported by the AQM.

This constant is used to indicate the number of AQM queues

Definition at line 130 of file IxQMgr.h.

#### #define IX\_QMGR\_MAX\_QID

Maximum queue identifier.

This constant is used to indicate the largest queue identifier

Definition at line **156** of file **IxQMgr.h**.

#### #define IX\_QMGR\_MAX\_QNAME\_LEN

Maximum queue name length.

This constant is used to indicate the maximum null terminated string length (excluding ") for a queue name

Definition at line 184 of file IxQMgr.h.

# #define IX\_QMGR\_MIN\_QID

Minimum queue identifier.

This constant is used to indicate the smallest queue identifier

Definition at line 143 of file IxQMgr.h.

# #define IX\_QMGR\_MIN\_QUEUPP\_QID

Minimum queue identifier for reduced functionality queues.

This constant is used to indicate Minimum queue identifier for reduced functionality queues

Definition at line **170** of file **IxQMgr.h**.

Referenced by ixQMgrQBurstRead(), ixQMgrQBurstWrite(), ixQMgrQRead(), ixQMgrQStatusGet(), and ixQMgrQWrite().

# #define IX\_QMGR\_NO\_AVAILABLE\_SRAM

Sram consumed return code.

All AQM Sram is consumed by queue configuration

Definition at line **274** of file **IxQMgr.h**.

#### #define IX\_QMGR\_PARAMETER\_ERROR

Parameter error return code (NULL pointer etc..).

parameter error out of range/invalid

Definition at line 210 of file IxQMgr.h.

#### #define IX\_QMGR\_Q\_ALREADY\_CONFIGURED

Queue already configured return code.

Returned to client to indicate that a queue has already been configured

Definition at line **338** of file **IxQMgr.h**.

# #define IX\_QMGR\_Q\_INVALID\_PRIORITY

Invalid priority return code.

Invalid priority, not one of 0,1,2

Definition at line **376** of file **IxQMgr.h**.

#### #define IX\_QMGR\_Q\_NOT\_CONFIGURED

Queue not configured return code.

Returned to the client when a function has been called on an unconfigured queue

Definition at line **326** of file **IxQMgr.h**.

# #define IX\_QMGR\_Q\_OVERFLOW

Overflow return code.

Overflow on a queue write has occurred

Definition at line 364 of file IxQMgr.h.

Referenced by ixQMgrQBurstWrite(), and ixQMgrQWrite().

#### #define IX\_QMGR\_Q\_UNDERFLOW

Underflow return code.

Underflow on a queue read has occurred

Definition at line **351** of file **IxQMgr.h**.

Referenced by ixQMgrQBurstRead(), and ixQMgrQRead().

# #define IX\_QMGR\_QUEUE\_0

Queue Number 0.

Definition at line 415 of file IxQMgr.h.

# #define IX\_QMGR\_QUEUE\_1

Queue Number 1.

Definition at line **416** of file **IxQMgr.h**.

# #define IX\_QMGR\_QUEUE\_10

Queue Number 10.

Definition at line **425** of file **IxQMgr.h**.

# #define IX\_QMGR\_QUEUE\_11

Queue Number 11.

Definition at line **426** of file **IxQMgr.h**.

# #define IX\_QMGR\_QUEUE\_12 Queue Number 12. Definition at line 427 of file IxQMgr.h. #define IX\_QMGR\_QUEUE\_13 Queue Number 13. Definition at line **428** of file **IxQMgr.h**. #define IX\_QMGR\_QUEUE\_14 Queue Number 14. Definition at line 429 of file IxQMgr.h. #define IX\_QMGR\_QUEUE\_15 Queue Number 15. Definition at line 430 of file IxQMgr.h. #define IX\_QMGR\_QUEUE\_16 Queue Number 16. Definition at line **431** of file **IxQMgr.h**. #define IX\_QMGR\_QUEUE\_17 Queue Number 17. Definition at line 432 of file IxQMgr.h.

Variables 419

#define IX\_QMGR\_QUEUE\_18

Definition at line **433** of file **IxQMgr.h**.

Queue Number 18.

# #define IX\_QMGR\_QUEUE\_19 Queue Number 19. Definition at line **434** of file **IxQMgr.h**. #define IX\_QMGR\_QUEUE\_2 Queue Number 2. Definition at line **417** of file **IxQMgr.h**. #define IX\_QMGR\_QUEUE\_20 Queue Number 20. Definition at line **435** of file **IxQMgr.h**. #define IX\_QMGR\_QUEUE\_21 Queue Number 21. Definition at line 436 of file IxQMgr.h. #define IX\_QMGR\_QUEUE\_22 Queue Number 22. Definition at line **437** of file **IxQMgr.h**. #define IX\_QMGR\_QUEUE\_23 Queue Number 23. Definition at line 438 of file IxQMgr.h. #define IX\_QMGR\_QUEUE\_24

Variables 420

Queue Number 24.

Definition at line **439** of file **IxQMgr.h**.

# #define IX\_QMGR\_QUEUE\_25 Queue Number 25. Definition at line 440 of file IxQMgr.h. #define IX\_QMGR\_QUEUE\_26 Queue Number 26. Definition at line **441** of file **IxQMgr.h**. #define IX\_QMGR\_QUEUE\_27 Queue Number 27. Definition at line 442 of file IxQMgr.h. #define IX\_QMGR\_QUEUE\_28 Queue Number 28. Definition at line 443 of file IxQMgr.h. #define IX\_QMGR\_QUEUE\_29 Queue Number 29. Definition at line **444** of file **IxQMgr.h**. #define IX\_QMGR\_QUEUE\_3 Queue Number 3. Definition at line 418 of file IxQMgr.h.

Variables 421

#define IX\_QMGR\_QUEUE\_30

Definition at line **445** of file **IxQMgr.h**.

Queue Number 30.

# #define IX\_QMGR\_QUEUE\_31 Queue Number 31. Definition at line 446 of file IxQMgr.h. #define IX\_QMGR\_QUEUE\_32 Queue Number 32. Definition at line **447** of file **IxQMgr.h**. #define IX\_QMGR\_QUEUE\_33 Queue Number 33. Definition at line **448** of file **IxQMgr.h**. #define IX\_QMGR\_QUEUE\_34 Queue Number 34. Definition at line 449 of file IxQMgr.h. #define IX\_QMGR\_QUEUE\_35 Queue Number 35. Definition at line **450** of file **IxQMgr.h**. #define IX\_QMGR\_QUEUE\_36 Queue Number 36. Definition at line **451** of file **IxQMgr.h**.

Variables 422

#define IX\_QMGR\_QUEUE\_37

Definition at line **452** of file **IxQMgr.h**.

Queue Number 37.

# #define IX\_QMGR\_QUEUE\_38 Queue Number 38. Definition at line 453 of file IxQMgr.h. #define IX\_QMGR\_QUEUE\_39 Queue Number 39. Definition at line **454** of file **IxQMgr.h**. #define IX\_QMGR\_QUEUE\_4 Queue Number 4. Definition at line 419 of file IxQMgr.h. #define IX\_QMGR\_QUEUE\_40 Queue Number 40. Definition at line 455 of file IxQMgr.h. #define IX\_QMGR\_QUEUE\_41 Queue Number 41. Definition at line **456** of file **IxQMgr.h**. #define IX\_QMGR\_QUEUE\_42 Queue Number 42. Definition at line **457** of file **IxQMgr.h**.

Variables 423

#define IX\_QMGR\_QUEUE\_43

Definition at line **458** of file **IxQMgr.h**.

Queue Number 43.

# #define IX\_QMGR\_QUEUE\_44 Queue Number 44. Definition at line 459 of file IxQMgr.h. #define IX\_QMGR\_QUEUE\_45 Queue Number 45. Definition at line **460** of file **IxQMgr.h**. #define IX\_QMGR\_QUEUE\_46 Queue Number 46. Definition at line **461** of file **IxQMgr.h**. #define IX\_QMGR\_QUEUE\_47 Queue Number 47. Definition at line 462 of file IxQMgr.h. #define IX\_QMGR\_QUEUE\_48 Queue Number 48. Definition at line **463** of file **IxQMgr.h**. #define IX\_QMGR\_QUEUE\_49 Queue Number 49. Definition at line **464** of file **IxQMgr.h**. #define IX\_QMGR\_QUEUE\_5

Variables 424

Queue Number 5.

Definition at line **420** of file **IxQMgr.h**.

# #define IX\_QMGR\_QUEUE\_50 Queue Number 50. Definition at line **465** of file **IxQMgr.h**. #define IX\_QMGR\_QUEUE\_51 Queue Number 51. Definition at line **466** of file **IxQMgr.h**. #define IX\_QMGR\_QUEUE\_52 Queue Number 52. Definition at line **467** of file **IxQMgr.h**. #define IX\_QMGR\_QUEUE\_53 Queue Number 53. Definition at line 468 of file IxQMgr.h. #define IX\_QMGR\_QUEUE\_54 Queue Number 54. Definition at line **469** of file **IxQMgr.h**. #define IX\_QMGR\_QUEUE\_55 Queue Number 55.

# #define IX\_QMGR\_QUEUE\_56

Queue Number 56.

Definition at line **471** of file **IxQMgr.h**.

Definition at line 470 of file IxQMgr.h.

# #define IX\_QMGR\_QUEUE\_57 Queue Number 57. Definition at line 472 of file IxQMgr.h. #define IX\_QMGR\_QUEUE\_58 Queue Number 58. Definition at line **473** of file **IxQMgr.h**. #define IX\_QMGR\_QUEUE\_59 Queue Number 59. Definition at line **474** of file **IxQMgr.h**. #define IX\_QMGR\_QUEUE\_6 Queue Number 6. Definition at line 421 of file IxQMgr.h. #define IX\_QMGR\_QUEUE\_60 Queue Number 60. Definition at line **475** of file **IxQMgr.h**. #define IX\_QMGR\_QUEUE\_61 Queue Number 61. Definition at line 476 of file IxQMgr.h.

Definition at line **477** of file **IxQMgr.h**.

#define IX\_QMGR\_QUEUE\_62

Queue Number 62.

# #define IX\_QMGR\_QUEUE\_63

Queue Number 63.

Definition at line 478 of file IxQMgr.h.

# #define IX\_QMGR\_QUEUE\_7

Queue Number 7.

Definition at line 422 of file IxQMgr.h.

# #define IX\_QMGR\_QUEUE\_8

Queue Number 8.

Definition at line **423** of file **IxQMgr.h**.

# #define IX\_QMGR\_QUEUE\_9

Queue Number 9.

Definition at line 424 of file IxQMgr.h.

# #define IX\_QMGR\_QUEUE\_INVALID

AQM Queue Number Delimiter.

Definition at line **479** of file **IxQMgr.h**.

# #define IX\_QMGR\_WARNING

Warning return code.

Execution complete, but there is a special case to handle

Definition at line 197 of file IxQMgr.h.

# #define ixQMgrDispatcherLoopRun

Map old function name ixQMgrDispatcherLoopRun () to ixQMgrDispatcherLoopRunA0 ().

# Warning:

THIS #define HAS BEEN DEPRECATED AND SHOULD NOT BE USED. It will be removed in a future release.

Definition at line 403 of file IxQMgr.h.

# **Typedef Documentation**

# IxQMgrCallback

QMgr notification callback type.

This defines the interface to all client callback functions.

#### Parameters:

qId IxQMgrQId [in] – the queue identifiercbId IxQMgrCallbackId [in] – the callbackidentifier

Definition at line **716** of file **IxQMgr.h**.

#### IxQMgrCallbackId

Uniquely identifies a callback function.

A unique callback identifier associated with each callback registered by clients.

Definition at line **704** of file **IxQMgr.h**.

# IxQMgrDispatcherFuncPtr

QMgr Dispatcher Loop function pointer.

This defines the interface for QMgr Dispather functions.

#### Parameters:

*group* **IxQMgrDispatchGroup** [in] – the group of the queue of which the dispatcher will run

Definition at line 731 of file IxQMgr.h.

# IxQMgrQId

Used in the API to identify the AQM queues.

Definition at line 494 of file IxQMgr.h.

# IxQMgrQStatus

Queue status.

A queues status is defined by its relative fullness or relative emptiness. Each of the queues 0–31 have Nearly Empty, Nearly Full, Empty, Full, Underflow and Overflow status flags. Queues 32–63 have just Nearly Empty and Full status flags. The flags bit positions are outlined below:

OF - bit - 5

UF - bit-4

F - bit - 3

NF - bit - 2

NE - bit-1

E - bit - 0

Definition at line **517** of file **IxQMgr.h**.

# **Enumeration Type Documentation**

#### enum IxQMgrDispatchGroup

QMgr dispatch group select identifiers.

This enum defines the groups over which the dispatcher will process when called. One of the enum values must be used as a input to ixQMgrDispatcherLoopRunA0, ixQMgrDispatcherLoopRunB0 or ixQMgrDispatcherLoopRunB0LLP.

#### **Enumeration values:**

```
IX_QMGR_QUELOW_GROUP Queues 0–31. IX_QMGR_QUEUPP_GROUP Queues 32–63.
```

Definition at line **646** of file **IxQMgr.h**.

# enum IxQMgrPriority

Dispatcher priority levels.

This enum defines the different queue dispatch priority levels. The lowest priority number (0) is the highest priority level.

#### Enumeration values:

```
IX_QMGR_Q_PRIORITY_0 Priority level 0.

IX_QMGR_Q_PRIORITY_1 Priority level 1.

IX_QMGR_Q_PRIORITY_2 Priority level 2.
```

IX\_QMGR\_Q\_PRIORITY\_INVALID Invalid Priority level.

Definition at line **663** of file **IxQMgr.h**.

#### enum IxQMgrQEntrySizeInWords

QMgr queue entry sizes.

The entry size of a queue specifies the size of a queues entry in words.

#### **Enumeration values:**

```
IX_QMGR_Q_ENTRY_SIZE1 1 word entry IX_QMGR_Q_ENTRY_SIZE2 2 word entry IX_QMGR_Q_ENTRY_SIZE4 4 word entry
```

Definition at line **575** of file **IxQMgr.h**.

Referenced by ixQMgrQBurstRead(), and ixQMgrQBurstWrite().

# enum IxQMgrQSizeInWords

QMgr queue sizes.

These values define the allowed queue sizes for AQM queue. The sizes are specified in words.

#### **Enumeration values:**

```
    IX_QMGR_Q_SIZE16 16 word buffer
    IX_QMGR_Q_SIZE32 32 word buffer
    IX_QMGR_Q_SIZE64 64 word buffer
    IX_QMGR_Q_SIZE128 128 word buffer
    IX_QMGR_Q_SIZE_INVALID Insure that this is greater than largest queue size supported by the hardware.
```

Definition at line **593** of file **IxQMgr.h**.

# enum IxQMgrQStatusMask

Queue status mask.

Masks for extracting the individual status flags from the IxQMgrStatus word.

Definition at line **530** of file **IxQMgr.h**.

# enum IxQMgrSourceId

Queue interrupt source select.

This enum defines the different source conditions on a queue that result in an interupt being fired by the AQM. Interrupt source is configurable for queues 0–31 only. The interrupt source for queues 32–63 is hardwired to the NE(Nearly Empty) status flag.

# Enumeration values:

```
IX_QMGR_Q_SOURCE_ID_E
IX_QMGR_Q_SOURCE_ID_NE
IX_QMGR_Q_SOURCE_ID_NF
IX_QMGR_Q_SOURCE_ID_F
IX_QMGR_Q_SOURCE_ID_NOT_E
IX_QMGR_Q_SOURCE_ID_NOT_NE
IX_QMGR_Q_SOURCE_ID_NOT_NE
IX_QMGR_Q_SOURCE_ID_NOT_NE
Queue Not Nearly Empty due to last write.
IX_QMGR_Q_SOURCE_ID_NOT_NE
Queue Not Nearly Empty due to last write.
IX_QMGR_Q_SOURCE_ID_NOT_NF
Queue Not Nearly Full due to last read.
IX_OMGR_Q_SOURCE_ID_NOT_F
Queue Not Nearly Full due to last read.
```

Definition at line **553** of file **IxQMgr.h**.

#### enum IxQMgrType

Callback types as used with livelock prevention.

This enum defines the different callback types. These types are only used when Livelock prevention is enabled. The default is IX\_QMGR\_TYPE\_REALTIME\_OTHER.

#### Enumeration values:

```
    IX_QMGR_TYPE_REALTIME_OTHER Real time callbacks—always allowed run.
    IX_QMGR_TYPE_REALTIME_PERIODIC Periodic callbacks—always allowed run.
    IX_QMGR_TYPE_REALTIME_SPORADIC Sporadic callbacks—only run if no periodic callbacks are in progress.
```

Definition at line **684** of file **IxQMgr.h**.

#### enum IxQMgrWMLevel

OMgr watermark levels.

These values define the valid watermark levels(in ENTRIES) for queues. Each queue 0–63 have configurable Nearly full and Nearly empty watermarks. For queues 32–63 the Nearly full watermark has NO EFFECT. If the Nearly full watermark is set to IX\_QMGR\_Q\_WM\_LEVEL16 this means that the nearly full flag will be set by the hardware when there are >= 16 empty entries in the specified queue. If the Nearly empty watermark is set to IX\_QMGR\_Q\_WM\_LEVEL16 this means that the Nearly empty flag will be set by the hardware when there are <= 16 full entries in the specified queue.

#### Enumeration values:

```
IX_QMGR_Q_WM_LEVEL0 0 entry watermark IX_QMGR_Q_WM_LEVEL1 1 entry watermark
```

```
IX_QMGR_Q_WM_LEVEL2 2 entry watermark
IX_QMGR_Q_WM_LEVEL4 4 entry watermark
IX_QMGR_Q_WM_LEVEL8 8 entry watermark
IX_QMGR_Q_WM_LEVEL16 16 entry watermark
IX_QMGR_Q_WM_LEVEL32 32 entry watermark
IX_QMGR_Q_WM_LEVEL64 64 entry watermark
```

Definition at line **621** of file **IxQMgr.h**.

# **Function Documentation**

```
ixQMgrAvailableSramAddressGet ( UINT32 * address, unsigned * sizeOfFreeSram )
```

Return the address of available AQM SRAM.

This function returns the starting address in AQM SRAM not used by the current queue configuration and should only be called after all queues have been configured. Calling this function before all queues have been configured will will return the currently available SRAM. A call to configure another queue will use some of the available SRAM. The amount of SRAM available is specified in sizeOfFreeSram. The address is the address of the bottom of available SRAM. Available SRAM extends from address from address to address + sizeOfFreeSram.

#### Parameters:

```
**address UINT32 [out] – the address of the available SRAM, NULL if none available.
*sizeOfFreeSram unsigned [out] – the size in words of available SRAM
```

#### Returns:

♦ IX\_SUCCESS, there is available SRAM and is pointed to by address

```
♦ IX_QMGR_PARAMETER_ERROR, invalid parameter(s)
```

♦ IX\_QMGR\_NO\_AVAILABLE\_SRAM, all AQM SRAM is consumed by the queue configuration.

```
ixQMgrCallbackTypeGet ( IxQMgrQId qId, 
 IxQMgrType * type
```

Get the Callback Type of a queue.

This function allows the callback type of a queue to be got. As live lock prevention operates on lower queues, this function should be called for lower queues only. This function is re–entrant.

#### Parameters:

```
qId IxQMgrQId [in] – the queue identifier
```

```
*type IxQMgrType [out] – the type of callback
```

#### Returns:

```
    ♦ IX_SUCCESS, successfully set callback type for the queue entry
    ♦ IX_QMGR_Q_NOT_CONFIGURED, queue not configured for this QId
    ♦ IX_QMGR_PARAMETER_ERROR, invalid parameter(s)
```

```
ixQMgrCallbackTypeSet ( IxQMgrQId qId, IxQMgrType type )
```

Set the Callback Type of a queue.

This function is only used for live lock prevention. This function allows the callback type of a queue to be set. The default for all queues is IX\_QMGR\_TYPE\_REALTIME\_OTHER. Setting the type to IX\_QMGR\_TYPE\_REALTIME\_SPORADIC means that this queue will have it's notifications disabled while there is a task associated with a queue of type IX\_QMGR\_TYPE\_REALTIME\_PERIODIC running. As live lock prevention operates on lower queues, this function should be called for lower queues only. This function is not re—entrant.

#### Parameters:

```
qId IxQMgrQId [in] – the queue identifier type IxQMgrType [in] – the type of callback
```

#### Returns:

♦ IX\_SUCCESS, successfully set callback type for the queue entry
 ♦ IX\_QMGR\_Q\_NOT\_CONFIGURED, queue not configured for this QId
 ♦ IX\_QMGR\_PARAMETER\_ERROR, invalid parameter(s).

```
ixQMgrDispatcherLoopGet ( IxQMgrDispatcherFuncPtr * qDispatcherFuncPtr )
```

Get QMgr DispatcherLoopRun for respective silicon device.

This function gets a function pointer to **ixQMgrDispatcherLoopRunA0**() for IXP42X A0 Silicon. If the IXP42X B0 or 46X Silicon, the default is the **ixQMgrDispatcherLoopRunB0**() function, however if live lock prevention is enabled a function pointer to **ixQMgrDispatcherLoopRunB0LLP**() is given.

#### Parameters:

\*qDispatchFuncPtr IxQMgrDispatcherFuncPtr [out] – the function pointer of QMgr Dispatcher

```
ixQMgrDispatcherLoopRunA0 ( IxQMgrDispatchGroup group )
```

Run the callback dispatcher.

This function runs the dispatcher for a group of queues. Callbacks are made for interrupts that have occurred on queues within the group that have registered callbacks. The order in which queues are serviced depends on the queue priorities set by the client. This function may be called from interrupt or task context. For optimisations that were introduced in IXP42X B0 Silicon and supported IXP46X processor the <code>ixQMgrDispatcherLoopRunB0</code>, or <code>ixQMgrDispatcherLoopRunB0LLP</code> should be used.

This function is not re-entrant.

#### Parameters:

group **IxQMgrDispatchGroup** [in] – the group of queues over which the dispatcher will run

#### Returns:

♦ void

#### Note:

This function may be called from interrupt or task context. However, for optimal performance the choice of context depends also on the operating system used.

#### Warning:

THIS function HAS BEEN DEPRECATED AND SHOULD NOT BE USED. It will be removed in a future release. See ixQMgrDispatcherLoopRunB0 for more information

#### ixQMgrDispatcherLoopRunB0 ( **IxQMgrDispatchGroup** group )

Run the callback dispatcher.

The enhanced version of *ixQMgrDispatcherLoopRunA0* that is optimised for features introduced in IXP42X B0 silicon and supported on IXP46X processor. This is the default dispatcher for IXP42X B0 and IXP46X silicon. The function runs the dispatcher for a group of queues. Callbacks are made for interrupts that have occurred on queues within the group that have registered callbacks. The order in which queues are serviced depends on the queue priorities set by the client. This function may be called from interrupt or task context.

This function is not re-entrant.

#### Parameters:

group **IxQMgrDispatchGroup** [in] – the group of queues over which the dispatcher will run

### Returns:

♦ void

#### Note:

This function may be called from interrupt or task context. However, for optimal performance the choice of context depends also on the operating system used.

# ixQMgrDispatcherLoopRunB0LLP ( IxQMgrDispatchGroup group )

Run the callback dispatcher.

This is a version of the optimised dispatcher for IXP42X B0 and IXP46X silicon,

*ixQMgrDispatcherLoopRunB0*, with added support for livelock prevention. This dispatcher will only be used for the IXP42X B0 or IXP46X silicon if feature control indicates that

IX\_FEATURECTRL\_ORIGB0\_DISPATCHER is set to

IX\_FEATURE\_CTRL\_SWCONFIG\_DISABLED. Otherwise the *ixQMgrDispatcherLoopRunB0* dispatcher will be used (Default).

When this dispatcher notifies for a queue that is type IX\_QMGR\_TYPE\_REALTIME\_PERIODIC, notifications for queues that are set as type IX\_QMGR\_REALTIME\_SPORADIC are not processed and disabled. This helps prevent any tasks resulting from the notification of the

IX\_QMGR\_TYPE\_REALTIME\_PERIODIC type queue to being subject to livelock. The function runs the dispatcher for a group of queues. Callbacks are made for interrupts that have occurred on queues within the group that have registered callbacks. The order in which queues are serviced depends on their type along with the queue priorities set by the client. This function may be called from interrupt or task context.

This function is not re-entrant.

#### Parameters:

group **IxQMgrDispatchGroup** [in] – the group of queues over which the dispatcher will run

#### Returns:

◊ void

#### Note:

This function may be called from interrupt or task context. However, for optimal performance the choice of context depends also on the operating system used.

```
ixQMgrDispatcherPrioritySet ( IxQMgrQId qld, IxQMgrPriority priority )
```

Set the dispatch priority of a queue.

This function is called to set the dispatch priority of queue. The effect of this function is to add a priority change request to a queue. This queue is serviced by ixQMgrDispatcherLoopRunA0, ixQMgrDispatcherLoopRunB0 or ixQMgrDispatcherLoopRunB0LLP.

This function is re-entrant. and can be used from an interrupt context

#### Parameters:

```
qId IxQMgrQId [in] – the queue identifierpriority IxQMgrPriority [in] – the new queue dispatch priority
```

#### Returns:

♦ IX\_SUCCESS, priority change request is queued

♦ IX\_QMGR\_Q\_NOT\_CONFIGURED, the specified qId has not been configured

♦ IX QMGR Q INVALID PRIORITY, specified priority is invalid

```
ixQMgrInit (void)
```

Initialise the QMgr.

This function must be called before and other QMgr function. It sets up internal data structures.

#### Returns:

```
♦ IX_SUCCESS, the IxQMgr successfully initialised♦ IX_FAIL, failed to initialize the Qmgr
```

```
ixQMgrLLPShow (int resetStats)
```

Print out the live lock prevention statistics when in debug mode.

This function prints out statistics related to the livelock. These statistics are only collected in debug mode. This function is not re—entrant.

#### Parameters:

resetStats [in] – if set the stats are reset.

```
ixQMgrNotificationCallbackSet ( IxQMgrQId qId, IxQMgrCallback callback, IxQMgrCallbackId callbackId )
```

Set the notification callback for a queue.

This function sets the callback for the specified queue. This callback will be called by the dispatcher, and may be called in the context of a interrupt If callback has a value of NULL the previously registered callback, if one exists will be unregistered.

#### Parameters:

```
    qId IxQMgrQId [in] – the queue idenfifier
    callback IxQMgrCallback [in] – the callback registered for this queue
    callbackId IxQMgrCallbackId [in] – the callback identifier
```

#### Returns:

```
♦ IX_SUCCESS, the callback for the specified queue has been set
```

♦ IX\_QMGR\_Q\_NOT\_CONFIGURED, the specified qId has not been configured

```
ixQMgrNotificationDisable ( IxQMgrQId qld )
```

Disable notifications on a queue.

This function is called to disable notifications on a specified queue.

This function is re-entrant. and can be used from an interrupt context

#### Parameters:

```
qId IxQMgrQId [in] – the queue identifier
```

#### Returns:

- ♦ IX\_SUCCESS, the interrupt has been disabled
- ♦ IX\_QMGR\_Q\_NOT\_CONFIGURED, the specified qId has not been configured

```
ixQMgrNotificationEnable ( IxQMgrQId qld, IxQMgrSourceId sourceId
```

Enable notification on a queue for a specified queue source flag.

This function is called by a client of the QMgr to enable notifications on a specified condition. If the condition for the notification is set after the client has called this function but before the function has enabled the interrupt source, then the notification will not occur. For queues 32–63 the notification source is fixed to the NE(Nearly Empty) flag and cannot be changed so the sourceId parameter is ignored for these queues. The status register is read before the notofication is enabled and is read again after the notification has been enabled, if they differ then the warning status is returned.

This function is re-entrant. and can be used from an interrupt context

#### Parameters:

```
qId IxQMgrQId [in] – the queue identifiersourceId IxQMgrSourceId [in] – the interrupt src condition identifier
```

#### Returns:

- ♦ IX SUCCESS, the interrupt has been enabled for the specified source
- \$\delta \text{ IX QMGR Q NOT CONFIGURED, the specified qId has not been configured}
- ♦ IX\_QMGR\_INVALID\_INT\_SOURCE\_ID, interrupt source invalid for this queue
- ♦ IX\_QMGR\_WARNING, the status register may not be constistent

```
ixQMgrPeriodicDone (void)
```

Indicate that the Periodic task is completed for LLP.

This function is used as part of live lock prevention. A periodic task is a task that results from a queue that is set as type IX\_QMGR\_TYPE\_REALTIME\_PERIODIC. This function should be called to indicate to the dispatcher that the periodic task is completed. This ensures that the notifications for queues set as type

sporadic queues are re-enabled. This function is re-entrant.

```
IX_QMGR_INLINE PUBLIC IX_STATUS ixQMgrQBurstRead ( IxQMgrQId qId, UINT32 numEntries, UINT32 * entries )
```

Read a number of entries from an AQM queue.

This function will burst read a number of entries from the specified queue. The entry size of queue is auto-detected. The function will attempt to read as many entries as specified by the numEntries parameter and will return an UNDERFLOW if any one of the individual entry reads fail.

#### Warning:

IX\_QMGR\_Q\_UNDERFLOW is only returned for queues 0–31 as queues 32–63 do not have an underflow status maintained, hence there is a potential for silent failure here. This function must be used with caution.

#### Note:

This function is intended for fast draining of queues, so to make it as efficient as possible, it has the following features:

- ♦ This function is inlined, to reduce unnecessary function call overhead.
- ♦ It does not perform any parameter checks, or update any statistics.
- ♦ It does not check that the queue specified by qId has been configured.
- ♦ It does not check that the queue has the number of full entries that have been specified to be read. It will read until it finds a NULL entry or until the number of specified entries have been read. It always checks for underflow after all the reads have been performed. Therefore, the client should ensure before calling this function that there are enough entries in the queue to read. ixQMgrQNumEntriesGet() will provide the number of full entries in a queue. ixQMgrQRead() or ixQMgrQReadWithChecks(), which only reads a single queue entry per call, should be used instead if the user requires checks for UNDERFLOW after each entry read.

#### Parameters:

```
    qId IxQMgrQId [in] – the queue identifier.
    numEntries unsigned [in] – the number of entries to read. This number should be greater than 0
    *entries UINT32 [out] – the word(s) read.
```

#### Returns:

♦ IX\_SUCCESS, entries were successfully read.

♦ IX\_QMGR\_Q\_UNDERFLOW, attempt to read from an empty queue

Definition at line **1238** of file **IxQMgr.h**.

```
References IX_QMGR_MIN_QUEUPP_QID, IX_QMGR_Q_ENTRY_SIZE1, IX_QMGR_Q_UNDERFLOW, IxQMgrQEntrySizeInWords, IxQMgrQInlinedReadWriteInfo::qAccRegAddr, IxQMgrQInlinedReadWriteInfo::qEntrySizeInWords,
```

```
IxQMgrQInlinedReadWriteInfo::qReadCount, IxQMgrQInlinedReadWriteInfo::qUflowStatBitMask, and IxQMgrQInlinedReadWriteInfo::qUOStatRegAddr.
```

```
IX_QMGR_INLINE PUBLIC IX_STATUS ixQMgrQBurstWrite ( IxQMgrQId qId, unsigned numEntries, UINT32 * entries )
```

Write a number of entries to an AQM queue.

This function will burst write a number of entries to the specified queue. The entry size of queue is auto-detected. The function will attempt to write as many entries as specified by the numEntries parameter and will return an OVERFLOW if any one of the individual entry writes fail.

# Warning:

IX\_QMGR\_Q\_OVERFLOW is only returned for queues 0–31 as queues 32–63 do not have an overflow status maintained, hence there is a potential for silent failure here. This function must be used with caution.

#### Note:

This function is intended for fast population of queues, so to make it as efficient as possible, it has the following features:

- ♦ This function is inlined, to reduce unnecessary function call overhead.
- ♦ It does not perform any parameter checks, or update any statistics.
- ♦ It does not check that the queue specified by qId has been configured.
- ♦ It does not check that the queue has enough free space to hold the entries before writing, and only checks for overflow after all writes have been performed. Therefore, the client should ensure before calling this function that there is enough free space in the queue to hold the number of entries to be written. ixQMgrQWrite() or

**ixQMgrQWriteWithChecks()**, which only writes a single queue entry per call, should be used instead if the user requires checks for OVERFLOW after each entry written.

#### Parameters:

```
    qId IxQMgrQId [in] – the queue identifier.
    numEntries unsigned [in] – the number of entries to write.
    *entries UINT32 [in] – the word(s) to write.
```

#### Returns:

♦ IX\_SUCCESS, value was successfully written.

♦ IX\_QMGR\_Q\_OVERFLOW, attempt to write to a full queue

Definition at line **1580** of file **IxQMgr.h**.

References IX\_QMGR\_MIN\_QUEUPP\_QID, IX\_QMGR\_Q\_ENTRY\_SIZE1, IX\_QMGR\_Q\_OVERFLOW, IxQMgrQEntrySizeInWords, IxQMgrQInlinedReadWriteInfo::qAccRegAddr, IxQMgrQInlinedReadWriteInfo::qEntrySizeInWords,

```
IxQMgrQInlinedReadWriteInfo:: qOflowStatBitMask, \\ IxQMgrQInlinedReadWriteInfo:: qSizeInEntries, \\ IxQMgrQInlinedReadWriteInfo:: qUOStatRegAddr, and \\ IxQMgrQInlinedReadWriteInfo:: qWriteCount. \\
```

# Configure an AQM queue.

This function is called by a client to setup a queue. The size and entrySize qId and qName(NULL pointer) are checked for valid values. This function must be called for each queue, before any queue accesses are made and after **ixQMgrInit()** has been called. qName is assumed to be a "terminated array of 16 charachters or less.

#### Parameters:

\*qName char [in] – is the name provided by the client and is associated with a QId by

the QMgr.

qld IxQMgrQId [in] – the qld of this queue

*qSizeInWords* [in] – the size of the queue can be one of 16,32 64, 128 words.

qEntrySizeInWords IxQMgrQEntrySizeInWords [in] – the size of a queue entry can be one of

1,2,4 words.

# Returns:

```
♦ IX_SUCCESS, a specified queue has been successfully configured.
```

```
♦ IX_FAIL, IxQMgr has not been initialised.
```

```
♦ IX_QMGR_PARAMETER_ERROR, invalid parameter(s).
```

```
♦ IX_QMGR_INVALID_QSIZE, invalid queue size
```

```
♦ IX_QMGR_INVALID_Q_ID, invalid queue id
```

```
♦ IX_QMGR_INVALID_Q_ENTRY_SIZE, invalid queue entry size
```

♦ IX\_QMGR\_Q\_ALREADY\_CONFIGURED, queue already configured

```
ixQMgrQNumEntriesGet ( IxQMgrQId qId, unsigned * numEntries )
```

Get a snapshot of the number of entries in a queue.

This function gets the number of entries in a queue.

#### Parameters:

```
qId IxQMgrQId [in] qId – the queue idenfifier *numEntries unsigned [out] – the number of entries in a queue
```

#### Returns:

```
\Diamond IX_SUCCESS, got the number of entries for the queue
```

```
♦ IX_QMGR_PARAMETER_ERROR, invalid paramter(s).
```

- ♦ IX\_QMGR\_Q\_NOT\_CONFIGURED, the specified qId has not been configured
- ♦ IX\_QMGR\_WARNING, could not determine num entries at this time

```
ixQMgrQPeek ( IxQMgrQId qId, unsigned int entryIndex, UINT32 * entry
```

Read an entry from a queue without moving the read pointer.

This function inspects an entry in a queue. The entry is inspected directly in AQM SRAM and is not read from queue access registers. The entry is NOT removed from the queue and the read/write pointers are unchanged. N.B: The queue should not be accessed when this function is called.

#### Parameters:

```
    qId IxQMgrQId [in] – the queue identifier.
    entryIndex unsigned int [in] – index of entry in queue in the range [0]......[current number of entries in queue].
    *entry UINT32 [out] – pointer to the entry word(s).
```

#### Returns:

```
♦ IX_SUCCESS, entry was successfully inspected.
```

```
♦ IX_QMGR_PARAMETER_ERROR, invalid paramter(s).
```

- ♦ IX\_QMGR\_Q\_NOT\_CONFIGURED, queue not configured for this QId.
- ♦ IX\_QMGR\_ENTRY\_INDEX\_OUT\_OF\_BOUNDS, an entry does not exist at specified index.
- ♦ IX\_FAIL, failed to injected the queue entry.

```
ixQMgrQPoke ( IxQMgrQId qld, unsigned int entryIndex, UINT32 * entry
```

Write an entry to a queue without moving the write pointer.

This function modifies an entry in a queue. The entry is modified directly in AQM SRAM and not using the queue access registers. The entry is NOT added to the queue and the read/write pointers are unchanged. N.B: The queue should not be accessed when this function is called.

#### Parameters:

```
    qId IxQMgrQId [in] – the queue identifier.
    entryIndex unsigned int [in] – index of entry in queue in the range [0]......[current number of entries in queue].
    *entry UINT32 [in] – pointer to the entry word(s).
```

#### Returns:

- ♦ IX\_SUCCESS, entry was successfully modified.
- ♦ IX QMGR PARAMETER ERROR, invalid paramter(s).
- ♦ IX\_QMGR\_Q\_NOT\_CONFIGURED, queue not configured for this QId.
- ♦ IX\_QMGR\_ENTRY\_INDEX\_OUT\_OF\_BOUNDS, an entry does not exist at specified index.
- ♦ IX FAIL, failed to modify the queue entry.

```
IX_QMGR_INLINE PUBLIC IX_STATUS ixQMgrQRead ( IxQMgrQId qld, UINT32 * entryPtr )
```

Fast read of an entry from a queue.

This function is a heavily streamlined version of **ixQMgrQReadWithChecks**(), but performs essentially the same task. It reads an entire entry from a queue, returning it in entry which must be a pointer to a previously allocated array of sufficient size to hold an entry.

#### Note:

- This function is inlined, to reduce unnecessary function call overhead. It does not perform any parameter checks, or update any statistics. Also, it does not check that the queue specified by qId has been configured. or is in range. It simply reads an entry from the queue, and checks for underflow.
- IX\_QMGR\_Q\_UNDERFLOW is only returned for queues 0–31 as queues 32–63 do not have an underflow status maintained.

#### Parameters:

```
qId IxQMgrQId [in] – the queue identifier. *entry UINT32 [out] – pointer to the entry word(s).
```

#### Returns:

♦ IX SUCCESS, entry was successfully read.

```
♦ IX_QMGR_Q_UNDERFLOW, attempt to read from an empty queue
```

Definition at line **1087** of file **IxQMgr.h**.

References IX\_QMGR\_MIN\_QUEUPP\_QID, IX\_QMGR\_Q\_ENTRY\_SIZE1,

 $IX\_QMGR\_Q\_UNDERFLOW, ixQMgrQReadMWordsMinus1(),\\$ 

IxQMgrQInlinedReadWriteInfo:: qAccRegAddr,

IxQMgrQInlinedReadWriteInfo::qConfigRegAddr,

IxQMgrQInlinedReadWriteInfo:: qEntrySizeInWords,

IxQMgrQInlinedReadWriteInfo:: qReadCount, IxQMgrQInlinedReadWriteInfo:: qSizeInEntries, and the property of the property of

 $Ix QMgrQInlined Read Write Info:: qUflow Stat Bit Mask, \ and \$ 

IxQMgrQInlinedReadWriteInfo:: qUOStatRegAddr.

```
IX_STATUS ixQMgrQReadMWordsMinus1 ( IxQMgrQId qld, UINT32 * entry )
```

This function reads the remaining of the q entry for queues configured with many words. (the first word of the entry is already read in the inlined function and the entry pointer already incremented.

#### Parameters:

```
qId IxQMgrQId [in] – the queue identifier. *entry UINT32 [out] – pointer to the entry word(s).
```

#### Returns:

♦ IX\_SUCCESS, entry was successfully read.

♦ IX\_QMGR\_Q\_UNDERFLOW, attempt to read from an empty queue

Referenced by **ixQMgrQRead()**.

```
ixQMgrQReadWithChecks ( IxQMgrQId qId, UINT32 * entry )
```

Read an entry from a queue.

This function reads an entire entry from a queue returning it in entry. The queue configuration word is read to determine what entry size this queue is configured for and then the number of words specified by the entry size is read. entry must be a pointer to a previously allocated array of sufficient size to hold an entry.

### Note:

– IX\_QMGR\_Q\_UNDERFLOW is only returned for queues 0–31 as queues 32–63 do not have an underflow status maintained.

#### Parameters:

```
qId IxQMgrQId [in] – the queue identifier.*entry UINT32 [out] – pointer to the entry word(s).
```

```
Returns:
```

```
♦ IX_SUCCESS, entry was successfully read.
```

```
♦ IX QMGR PARAMETER ERROR, invalid paramter(s).
```

```
♦ IX_QMGR_Q_NOT_CONFIGURED, queue not configured for this QId
```

♦ IX\_QMGR\_Q\_UNDERFLOW, attempt to read from an empty queue

```
ixQMgrQShow ( IxQMgrQId qId )
```

Display aqueue configuration and statistics for a queue.

This function shows queue configuration and statistics for a queue.

#### Parameters:

```
qId IxQMgrQId [in] – the queue identifier.
```

#### Returns:

```
♦ IX_SUCCESS, success
```

♦ IX\_QMGR\_Q\_NOT\_CONFIGURED, queue not configured for this QId

```
ixQMgrQSizeInEntriesGet ( IxQMgrQId qId, unsigned * qSizeInEntries )
```

Return the size of a queue in entries.

This function returns the the size of the queue in entriese.

#### Parameters:

```
qId IxQMgrQId [in] – the queue identifier *qSizeInEntries [out] – queue size in entries
```

#### Returns:

- ♦ IX\_SUCCESS, successfully retrieved the number of full entrie
- ♦ IX\_QMGR\_Q\_NOT\_CONFIGURED, queue not configured for this QId
- ♦ IX\_QMGR\_PARAMETER\_ERROR, invalid parameter(s).

```
IX_QMGR_INLINE PUBLIC IX_STATUS ixQMgrQStatusGet ( IxQMgrQId qId, IxQMgrQStatus * qStatus )
```

Fast get of a queue's status.

This function is a streamlined version of **ixQMgrQStatusGetWithChecks**(), but performs essentially the same task. It reads the specified queue's status. A queues status is defined by its status flags. For queues 0–31 these flags are E,NE,NF,F. For queues 32–63 these flags are NE and F.

#### Note:

- This function is inlined, to reduce unnecessary function call overhead. It does not perform any parameter checks, or update any statistics. Also, it does not check that the queue specified by qId has been configured. It simply reads the specified queue's status.

#### Parameters:

```
qId IxQMgrQId [in] – the queue identifier.*qStatus IxQMgrQStatus [out] – the status of the specified queue.
```

#### Returns:

◊ void.

Definition at line **1775** of file **IxQMgr.h**.

References IX\_QMGR\_MIN\_QUEUPP\_QID.

```
ixQMgrQStatusGetWithChecks ( IxQMgrQId qId, IxQMgrQStatus * qStatus )
```

Get a queues status.

This function reads the specified queues status. A queues status is defined by its status flags. For queues 0–31 these flags are E,NE,NF,F. For queues 32–63 these flags are NE and F.

#### Parameters:

```
qId IxQMgrQId [in] – the queue identifier.&qStatus IxQMgrQStatus [out] – the status of the specified queue.
```

#### Returns:

♦ IX\_SUCCESS, queue status was successfully read.

♦ IX QMGR Q NOT CONFIGURED, the specified qId has not been configured

♦ IX\_QMGR\_PARAMETER\_ERROR, invalid paramter.

```
IX_QMGR_INLINE PUBLIC IX_STATUS ixQMgrQWrite ( IxQMgrQId qId, UINT32 * entry )
```

Fast write of an entry to a queue.

This function is a heavily streamlined version of **ixQMgrQWriteWithChecks**(), but performs essentially the same task. It will write the entry size number of words pointed to by entry to the queue specified by qId.

#### Note:

- This function is inlined, to reduce unnecessary function call overhead. It does not perform any parameter checks, or update any statistics. Also, it does not check that the queue specified by qId has been configured. It simply writes an entry to the queue, and checks for overflow.
- IX\_QMGR\_Q\_OVERFLOW is only returned for queues 0–31 as queues 32–63 do not have an overflow status maintained.

#### Parameters:

```
qId IxQMgrQId [in] – the queue identifier. *entry UINT32 [in] – pointer to the entry word(s).
```

#### Returns:

♦ IX\_SUCCESS, entry was successfully read.

♦ IX\_QMGR\_Q\_OVERFLOW, attempt to write to a full queue

Definition at line **1433** of file **IxQMgr.h**.

```
References \ IX\_QMGR\_MIN\_QUEUPP\_QID, \ IX\_QMGR\_Q\_ENTRY\_SIZE1,
```

 $IX\_QMGR\_Q\_OVERFLOW, IxQMgrQInlinedReadWriteInfo::qAccRegAddr,\\$ 

IxQMgrQInlinedReadWriteInfo::qConfigRegAddr,

Ix QMgr QIn lined Read Write Info:: qEntry Size In Words,

IxQMgrQInlinedReadWriteInfo:: qOflowStatBitMask,

IxQMgrQInlinedReadWriteInfo::qSizeInEntries,

IxQMgrQInlinedReadWriteInfo::qUOStatRegAddr, and

Ix QMgr QIn lined Read Write Info:: qWrite Count.

```
ixQMgrQWriteWithChecks ( IxQMgrQId qld, UINT32 * entry
```

Write an entry to an AQM queue.

This function will write the entry size number of words pointed to by entry to the queue specified by qId. The queue configuration word is read to determine the entry size of queue and the corresponding number of words is then written to the queue.

#### Note:

– IX\_QMGR\_Q\_OVERFLOW is only returned for queues 0–31 as queues 32–63 do not have an overflow status maintained.

#### Parameters:

```
qId IxQMgrQId [in] – the queue identifier. *entry UINT32 [in] – the word(s) to write.
```

#### Returns:

- ♦ IX\_SUCCESS, value was successfully written.
- ♦ IX QMGR PARAMETER ERROR, invalid paramter(s).
- ♦ IX\_QMGR\_Q\_NOT\_CONFIGURED, queue not configured for this QId
- ♦ IX\_QMGR\_Q\_OVERFLOW, attempt to write to a full queue

## ixQMgrShow (void)

Describe queue configuration and statistics for active queues.

This function shows active queues, their configurations and statistics.

#### Returns:

♦ void

#### ixQMgrStickyInterruptRegEnable (void)

Enable AQM's sticky interrupt register behaviour only available on B0 Silicon.

When AQM's sticky interrupt register is enabled, interrupt register bit will only be cleared when a '1' is written to interrupt register bit and the interrupting condition is satisfied, i.e.queue condition does not exist.

#### Note:

This function must be called before any queue is enabled. Calling this function after queue is enabled will cause undefined results.

#### Returns:

none

#### ixQMgrUnload (void)

Uninitialise the QMgr.

This function will perform the tasks required to unload the QMgr component cleanly. This includes unmapping kernel memory and unconfigures the access layer component's queue configuration.

This should be called before a soft reboot or unloading of a kernel module.

#### Precondition:

It should only be called if **ixQMgrInit** has already been called.

#### Postcondition:

No QMgr functions should be called until ixQMgrInit is called again.

#### Returns:

```
♦ IX_SUCCESS, the IxQMgr successfully uninitialised♦ IX_FAIL, failed to uninitialize the Qmgr
```

```
ixQMgrWatermarkSet ( IxQMgrQId qId, IxQMgrWMLevel ne, IxQMgrWMLevel nf )
```

Set the Nearly Empty and Nearly Full Watermarks fo a queue.

This function is called by a client to set the watermarks NE and NF for the queue specified by qId. The queue must be empty at the time this function is called, it is the clients responsibility to ensure that the queue is empty. This function will read the status of the queue before the watermarks are set and again after the watermarks are set. If the status register has changed, due to a queue access by an NPE for example, a warning is returned. Queues 32–63 only support the NE flag, therefore the value of nf will be ignored for these queues.

#### Parameters:

```
qId IxQMgrQId [in] – the QId of the queue.
```

- *ne* **IxQMgrWMLevel** [in] the NE(Nearly Empty) watermark for this queue. Valid values are 0,1,2,4,8,16,32 and 64 entries.
- *nf* **IxQMgrWMLevel** [in] the NF(Nearly Full) watermark for this queue. Valid values are 0,1,2,4,8,16,32 and 64 entries.

#### Returns:

```
♦ IX_SUCCESS, watermarks have been set for the queu
```

♦ IX\_QMGR\_Q\_NOT\_CONFIGURED, queue not configured for this QId

♦ IX\_QMGR\_INVALID\_Q\_WM, invalid watermark

♦ IX\_QMGR\_WARNING, the status register may not be constistent

# Intel (R) IXP400 Software SSP Serial Port Access (IxSspAcc) API

Intel (R) IXP400 Software SSP Serial Port Access Public API.

## **Data Structures**

#### struct IxSspAccStatsCounters

contains counters of the SSP statistics

#### struct IxSspAccStatsCounters

contains counters of the SSP statistics

#### struct IxSspInitVars

contains all the variables required to initialize the SSP serial port hardware.

#### struct IxSspInitVars

contains all the variables required to initialize the SSP serial port hardware.

# **Typedefs**

typedef void(\* RxFIFOOverrunHandler )(void)

SSP Rx FIFO Overrun handler.

typedef void(\* RxFIFOThresholdHandler )(void)

SSP Rx FIFO Threshold hit or above handler.

typedef void(\* TxFIFOThresholdHandler )(void)

SSP Tx FIFO Threshold hit or below handler.

# **Enumerations**

enum IxSspAccDataSize {

DATA SIZE TOO SMALL,

DATA\_SIZE\_4,

DATA\_SIZE\_5,

DATA SIZE 6,

DATA\_SIZE\_7,

DATA SIZE 8,

DATA\_SIZE\_9,

DATA\_SIZE\_10,

DATA\_SIZE\_11,

DATA\_SIZE\_12,

DATA SIZE 13,

```
DATA SIZE 14,
      DATA_SIZE_15,
      DATA SIZE 16,
      DATA SIZE TOO BIG
     The data sizes in bits that are supported by the protocol.
enum IxSspAccPortStatus {
      SSP PORT DISABLE,
      SSP_PORT_ENABLE,
      INVALID_SSP_PORT_STATUS
     The status of the SSP port to be set to enable/disable.
enum IxSspAccFrameFormat {
      SPI_FORMAT,
      SSP FORMAT.
      MICROWIRE FORMAT,
      INVALID FORMAT
     The frame format that is to be used – SPI, SSP, or Microwire.
enum IxSspAccClkSource {
      ON CHIP CLK,
      EXTERNAL CLK.
      INVALID_CLK_SOURCE
     The source to produce the SSP serial clock.
enum IxSspAccSpiSclkPhase {
      START_ONE_END_HALF,
      START HALF END ONE.
      INVALID_SPI_PHASE
     The SPI SCLK Phase: 0 – SCLK is inactive one cycle at the start of a frame and 1/2
     cycle at the end of a frame. 1 – SCLK is inactive 1/2 cycle at the start of a frame and
     one cycle at the end of a frame.
enum IxSspAccSpiSclkPolarity {
      SPI_POLARITY_LOW,
      SPI POLARITY HIGH,
      INVALID_SPI_POLARITY
     The SPI SCLK Polarity can be set to either low or high.
enum IxSspAccMicrowireCtlWord {
      MICROWIRE 8 BIT.
      MICROWIRE 16 BIT,
      INVALID MICROWIRE CTL WORD
     }
```

```
enum IxSspAccFifoThreshold {
     FIFO TSHLD 1,
     FIFO TSHLD 2.
     FIFO TSHLD 3,
     FIFO TSHLD 4.
     FIFO TSHLD 5,
     FIFO TSHLD 6,
     FIFO TSHLD 7.
     FIFO TSHLD 8,
     FIFO TSHLD 9.
     FIFO TSHLD 10,
     FIFO TSHLD 11,
     FIFO TSHLD 12.
     FIFO TSHLD 13,
     FIFO TSHLD 14.
     FIFO TSHLD 15,
     FIFO TSHLD 16,
     INVALID_FIFO_TSHLD
```

The threshold in frames (each frame is defined by IxSspAccDataSize) that can be set for the FIFO to trigger a threshold exceed when checking with the ExceedThresholdCheck functions or an interrupt when it is enabled.

```
enum IX SSP STATUS {
     IX SSP SUCCESS.
     IX SSP FAIL,
     IX SSP RX FIFO OVERRUN HANDLER MISSING,
     IX SSP RX FIFO HANDLER MISSING.
     IX SSP TX FIFO HANDLER MISSING,
     IX SSP FIFO NOT EMPTY FOR SETTING CTL CMD.
     IX SSP INVALID FRAME FORMAT ENUM VALUE,
     IX SSP INVALID DATA SIZE ENUM VALUE,
     IX SSP INVALID CLOCK SOURCE ENUM VALUE.
     IX SSP INVALID TX FIFO THRESHOLD ENUM VALUE,
     IX SSP INVALID RX FIFO THRESHOLD ENUM VALUE,
     IX SSP INVALID SPI PHASE ENUM VALUE,
     IX SSP INVALID SPI POLARITY ENUM VALUE,
     IX_SSP_INVALID_MICROWIRE_CTL_CMD_ENUM_VALUE,
     IX SSP INT UNBIND FAIL,
     IX SSP INT BIND FAIL.
     IX SSP RX FIFO NOT EMPTY,
     IX SSP TX FIFO NOT EMPTY.
     IX SSP POLL MODE BLOCKING.
     IX SSP TX FIFO HIT BELOW THRESHOLD,
     IX SSP TX FIFO EXCEED THRESHOLD.
     IX SSP RX FIFO HIT ABOVE THRESHOLD,
     IX SSP RX FIFO BELOW THRESHOLD,
     IX SSP BUSY.
     IX_SSP_IDLE,
```

```
IX_SSP_OVERRUN_OCCURRED,
IX_SSP_NO_OVERRUN,
IX_SSP_NOT_SUPORTED,
IX_SSP_NOT_INIT,
IX_SSP_NULL_POINTER
}
The statuses that can be returned in a SSP Serial Port Access.
```

# **Functions**

PUBLIC

IX\_SSP\_STATUS ixSspAccInit (IxSspInitVars \*initVarsSelected)

Initializes the SSP Access module.

**PUBLIC** 

IX\_SSP\_STATUS ixSspAccUninit (void)

*Un-initializes the SSP Serial Port Access component.* 

**PUBLIC** 

IX\_SSP\_STATUS ixSspAccFIFODataSubmit (UINT16 \*data, UINT32 amtOfData)

Inserts data into the SSP Serial Port's FIFO.

**PUBLIC** 

IX\_SSP\_STATUS ixSspAccFIFODataReceive (UINT16 \*data, UINT32 amtOfData)

Extract data from the SSP Serial Port's FIFO.

**PUBLIC** 

IX\_SSP\_STATUS ixSspAccTxFIFOHitOrBelowThresholdCheck (void)

Check if the Tx FIFO threshold has been hit or fallen below.

**PUBLIC** 

IX\_SSP\_STATUS ixSspAccRxFIFOHitOrAboveThresholdCheck (void)

Check if the Rx FIFO threshold has been hit or exceeded.

**PUBLIC** 

IX SSP STATUS ixSspAccSSPPortStatusSet (IxSspAccPortStatus portStatusSelected)

Enables/disables the SSP Serial Port hardware.

**PUBLIC** 

IX\_SSP\_STATUS ixSspAccFrameFormatSelect (IxSspAccFrameFormat frameFormatSelected)

Sets the frame format for the SSP Serial Port hardware.

**PUBLIC** 

IX\_SSP\_STATUS ixSspAccDataSizeSelect (IxSspAccDataSize dataSizeSelected)

Sets the data size for transfers.

**PUBLIC** 

IX\_SSP\_STATUS ixSspAccClockSourceSelect (IxSspAccClkSource clkSourceSelected)

Functions 452

Sets the clock source of the SSP Serial Port hardware.

**PUBLIC** 

 $\textbf{IX\_SSP\_STATUS} \ \textbf{ixSspAccSerialClockRateConfigure} \ (\textbf{UINT8} \ \textbf{serialClockRateSelected})$ 

Sets the on-chip Serial Clock Rate of the SSP Serial Port hardware.

**PUBLIC** 

IX\_SSP\_STATUS ixSspAccRxFIFOIntEnable (RxFIFOThresholdHandler rxFIFOIntrHandler)

Enables service request interrupt whenever the Rx FIFO hits its threshold.

**PUBLIC** 

IX\_SSP\_STATUS ixSspAccRxFIFOIntDisable (void)

Disables service request interrupt of the Rx FIFO.

**PUBLIC** 

IX SSP STATUS ixSspAccTxFIFOIntEnable (TxFIFOThresholdHandler txFIFOIntrHandler)

Enables service request interrupt of the Tx FIFO.

**PUBLIC** 

IX\_SSP\_STATUS ixSspAccTxFIFOIntDisable (void)

Disables service request interrupt of the Tx FIFO.

**PUBLIC** 

 $IX\_SSP\_STATUS\ ixSspAccLoopbackEnable\ (BOOL\ loopbackEnable)$ 

Enables/disables the loopback mode.

**PUBLIC** 

IX\_SSP\_STATUS ixSspAccSpiSclkPolaritySet (IxSspAccSpiSclkPolarity spiSclkPolaritySelected)

Sets the SPI SCLK Polarity to Low or High.

**PUBLIC** 

IX\_SSP\_STATUS ixSspAccSpiSclkPhaseSet (IxSspAccSpiSclkPhase spiSclkPhaseSelected)

Sets the SPI SCLK Phase.

 $PUBLIC \textbf{ix} \textbf{SspAccMicrowireControlWordSet} \ (\textbf{Ix} \textbf{SspAccMicrowireCtlWordSet}) \\$ 

IX\_SSP\_STATUS microwireCtlWordSelected)

Sets the Microwire control word to 8 or 16 bit format.

**PUBLIC** 

IX\_SSP\_STATUS ixSspAccTxFIFOThresholdSet (IxSspAccFifoThreshold txFIFOThresholdSelected)

Sets the Tx FIFO Threshold.

**PUBLIC** 

 $IX\_SSP\_STATUS\ ixSspAccRxFIFOThresholdSet\ (IxSspAccFifoThreshold\ rxFIFOThresholdSelected)$ 

Sets the Rx FIFO Threshold.

**PUBLIC** 

IX\_SSP\_STATUS ixSspAccStatsGet (IxSspAccStatsCounters \*sspStats)

Returns the SSP Statistics through the pointer passed in.

PUBLIC void ixSspAccStatsReset (void)

Functions 453

Resets the SSP Statistics.

#### **PUBLIC**

#### IX\_SSP\_STATUS ixSspAccShow (void)

Display SSP status registers and statistics counters.

#### **PUBLIC**

#### IX\_SSP\_STATUS ixSspAccSSPBusyCheck (void)

Determine the state of the SSP serial port hardware.

#### PUBLIC UINT8 ixSspAccTxFIFOLevelGet (void)

Obtain the Tx FIFO's level.

## PUBLIC UINT8 ixSspAccRxFIFOLevelGet (void)

Obtain the Rx FIFO's level.

#### **PUBLIC**

#### IX\_SSP\_STATUS ixSspAccRxFIFOOverrunCheck (void)

Check if the Rx FIFO has overrun its FIFOs.

# **Detailed Description**

Intel (R) IXP400 Software SSP Serial Port Access Public API.

# **Typedef Documentation**

typedef void(\* RxFIFOOverrunHandler)(void)

SSP Rx FIFO Overrun handler.

This function is called for the client to handle Rx FIFO Overrun that occurs in the SSP hardware

Definition at line **252** of file **IxSspAcc.h**.

typedef void(\* RxFIFOThresholdHandler)(void)

SSP Rx FIFO Threshold hit or above handler.

This function is called for the client to handle Rx FIFO threshold hit or or above that occurs in the SSP hardware

Definition at line **262** of file **IxSspAcc.h**.

Detailed Description 454

typedef void(\* TxFIFOThresholdHandler)(void)

SSP Tx FIFO Threshold hit or below handler.

This function is called for the client to handle Tx FIFO threshold hit or or below that occurs in the SSP hardware

Definition at line **272** of file **IxSspAcc.h**.

# **Enumeration Type Documentation**

enum IX SSP STATUS

The statuses that can be returned in a SSP Serial Port Access.

#### **Enumeration values:**

IX\_SSP\_SUCCESSSuccess status.IX\_SSP\_FAILFail status.

IX\_SSP\_RX\_FIFO\_OVERRUN\_HANDLER\_MISSING Rx FIFO Overrun handler is

NULL.

IX SSP RX FIFO HANDLER MISSING Rx FIFO threshold hit or above

handler is NULL.

IX\_SSP\_TX\_FIFO\_HANDLER\_MISSING Tx FIFO threshold hit or below

handler is NULL.

IX\_SSP\_FIFO\_NOT\_EMPTY\_FOR\_SETTING\_CTL\_CMD Tx FIFO not empty and therefore

microwire control command size

setting is not allowed.

IX\_SSP\_INVALID\_FRAME\_FORMAT\_ENUM\_VALUEframe format selected is invalidIX\_SSP\_INVALID\_DATA\_SIZE\_ENUM\_VALUEdata size selected is invalidIX\_SSP\_INVALID\_CLOCK\_SOURCE\_ENUM\_VALUEsource clock selected is invalid

IX\_SSP\_INVALID\_TX\_FIFO\_THRESHOLD\_ENUM\_VALUE Tx FIFO threshold selected is

invalid.

IX\_SSP\_INVALID\_RX\_FIFO\_THRESHOLD\_ENUM\_VALUE Rx FIFO threshold selected is

invalid.

IX\_SSP\_INVALID\_SPI\_PHASE\_ENUM\_VALUE SPI phase selected is invalid.

IX\_SSP\_INVALID\_SPI\_POLARITY\_ENUM\_VALUE SPI polarity selected is invalid.

IX\_SSP\_INVALID\_MICROWIRE\_CTL\_CMD\_ENUM\_VALUE Microwire control command

THE OTE ONE DEVONE VIEW HIS CONTROL COMMENT

selected is invalid.

IX\_SSP\_INT\_UNBIND\_FAIL Interrupt unbind fail to unbind SSP

interrupt.

IX\_SSP\_INT\_BIND\_FAIL Interrupt bind fail during init.

IX\_SSP\_RX\_FIFO\_NOT\_EMPTY Rx FIFO not empty while trying to

change data size.

IX\_SSP\_TX\_FIFO\_NOT\_EMPTY Rx FIFO not empty while trying to

change data size or microwire

control command size.

IX\_SSP\_POLL\_MODE\_BLOCKING

IX\_SSP\_TX\_FIFO\_HIT\_BELOW\_THRESHOLD

IX\_SSP\_TX\_FIFO\_EXCEED\_THRESHOLD IX\_SSP\_RX\_FIFO\_HIT\_ABOVE\_THRESHOLD

 $IX\_SSP\_RX\_FIFO\_BELOW\_THRESHOLD$ 

IX\_SSP\_BUSY IX\_SSP\_IDLE

IX\_SSP\_OVERRUN\_OCCURRED

IX\_SSP\_NO\_OVERRUN IX\_SSP\_NOT\_SUPORTED

 $IX\_SSP\_NOT\_INIT$ 

IX\_SSP\_NULL\_POINTER

Definition at line **181** of file **IxSspAcc.h**.

poll mode selected blocks interrupt

mode from being selected
Tx FIFO level hit or below

threshold.

Tx FIFO level exceeded threshold.

threshold.

Rx FIFO level below threshold.

Rx FIFO level hit or exceeded

SSP is busy. SSP is idle.

SSP has experienced an overrun. SSP did not experience an overrun. hardware does not support SSP SSP Access not intialized. parameter passed in is NULL

#### enum IxSspAccClkSource

The source to produce the SSP serial clock.

Definition at line **90** of file **IxSspAcc.h**.

#### enum IxSspAccDataSize

The data sizes in bits that are supported by the protocol.

Definition at line **35** of file **IxSspAcc.h**.

#### enum IxSspAccFifoThreshold

The threshold in frames (each frame is defined by IxSspAccDataSize) that can be set for the FIFO to trigger a threshold exceed when checking with the ExceedThresholdCheck functions or an interrupt when it is enabled.

Definition at line **153** of file **IxSspAcc.h**.

#### enum IxSspAccFrameFormat

The frame format that is to be used – SPI, SSP, or Microwire.

Definition at line **75** of file **IxSspAcc.h**.

#### enum IxSspAccMicrowireCtlWord

The Microwire control word can be either 8 or 16 bit.

Definition at line 136 of file IxSspAcc.h.

## enum IxSspAccPortStatus

The status of the SSP port to be set to enable/disable.

Definition at line **61** of file **IxSspAcc.h**.

#### enum IxSspAccSpiSclkPhase

The SPI SCLK Phase: 0 - SCLK is inactive one cycle at the start of a frame and 1/2 cycle at the end of a frame. 1 - SCLK is inactive 1/2 cycle at the start of a frame and one cycle at the end of a frame.

Definition at line 108 of file IxSspAcc.h.

#### enum IxSspAccSpiSclkPolarity

The SPI SCLK Polarity can be set to either low or high.

Definition at line **122** of file **IxSspAcc.h**.

# **Function Documentation**

ixSspAccClockSourceSelect ( IxSspAccClkSource clkSourceSelected )

Sets the clock source of the SSP Serial Port hardware.

#### Parameters:

IxSspAccClkSource [in] clkSourceSelected

- The clock source from either external source on on-chip can be selected as the source

Global Data:

• None.

This API will set the clock source for the transfers via user input.

#### Returns:

♦ IX\_SSP\_SUCCESS – clock source set with valid enum value ♦ IX\_SSP\_INVALID\_CLOCK\_SOURCE\_ENUM\_VALUE – invalid enum value

♦ IX\_SSP\_NOT\_INIT – SSP not initialized. SSP init needs to be called.

Reentrant : yesISR Callable : yes

#### ixSspAccDataSizeSelect ( **IxSspAccDataSize** dataSizeSelected )

Sets the data size for transfers.

#### Parameters:

*IxSspAccDataSize [in]* — The data size between 4 and 16 that can be selected for data dataSizeSelected transfers

#### Global Data:

• None.

This API will set the data size for the transfers via user input. It will disallow the change of the data size if either of the Rx/Tx FIFO is not empty to prevent data loss. \*NOTE\*: The SSP port will be disabled if the FIFOs are found to be empty and if between the check and disabling of the SSP (which clears the FIFOs) data is received into the FIFO, it might be lost. \*NOTE\*: The FIFOs can be cleared by disabling the SSP Port if necessary to force the data size change.

#### Returns:

- ♦ IX\_SSP\_SUCCESS data size set with valid enum value ♦ IX\_SSP\_RX\_FIFO\_NOT\_EMPTY – Rx FIFO not empty, data size change is not allowed.
- ♦ IX\_SSP\_TX\_FIFO\_NOT\_EMPTY Tx FIFO not empty, data size change is not allowed.
- ♦ IX\_SSP\_INVALID\_DATA\_SIZE\_ENUM\_VALUE invalid enum value
- ♦ IX SSP NOT INIT SSP not initialized. SSP init needs to be called.

Reentrant : yesISR Callable : yes

Extract data from the SSP Serial Port's FIFO.

#### Parameters:

```
UINT16 [in] – pointer to the location to receive the data into "UINT32 [in] amtOfData" – *data number of data to be received.
```

#### Global Data:

• None.

This API will extract the amount of data specified by "amtOfData" from the FIFO already received by the hardware into the buffer pointed to by "data".

#### Returns:

```
    ♦ IX_SSP_SUCCESS – Data extracted successfully from FIFO
    ♦ IX_SSP_FAIL – FIFO has no data
    ♦ IX_SSP_NULL_POINTER – data pointer passed by client is NULL
    ♦ IX_SSP_NOT_INIT – SSP not initialized. SSP init needs to be called.
```

Reentrant : yesISR Callable : yes

Inserts data into the SSP Serial Port's FIFO.

#### Parameters:

```
UINT16 [in] – pointer to the location to transmit the data from "UINT32 [in] amtOfData" – number of data to be transmitted.
```

#### Global Data:

• None.

This API will insert the amount of data specified by "amtOfData" from buffer pointed to by "data" into the FIFO to be transmitted by the hardware.

#### Returns:

```
    ◊ IX_SSP_SUCCESS – Data inserted successfully into FIFO
    ◊ IX_SSP_FAIL – FIFO insufficient space
    ◊ IX_SSP_NULL_POINTER – data pointer passed by client is NULL
    ◊ IX_SSP_NOT_INIT – SSP not initialized. SSP init needs to be called.
```

Reentrant : yesISR Callable : yes

#### ixSspAccFrameFormatSelect ( **IxSspAccFrameFormat** frameFormatSelected )

Sets the frame format for the SSP Serial Port hardware.

#### Parameters:

```
IxSspAccFrameFormat [in] — The frame format of SPI, SSP or Microwire can be frameFormatSelected selected as the format
```

Global Data:

• None.

This API will set the format for the transfers via user input. \*NOTE\*: The SSP hardware will be disabled to clear the FIFOs. Then its previous state (enabled/disabled) restored after changing the format.

#### Returns:

- ♦ IX\_SSP\_SUCCESS frame format set with valid enum value
- ♦ IX\_SSP\_INVALID\_FRAME\_FORMAT\_ENUM\_VALUE invalid frame format value
- ♦ IX SSP NOT INIT SSP not initialized. SSP init needs to be called.

Reentrant : yesISR Callable : yes

#### ixSspAccInit ( IxSspInitVars \* initVarsSelected )

Initializes the SSP Access module.

#### Parameters:

IxSspAccInitVars [in] \*initVarsSelected - struct containing required variables for initialization

#### Global Data:

• None.

This API will initialize the SSP Serial Port hardware to the user specified configuration. Then it will enable the SSP Serial Port. \*NOTE\*: Once interrupt or polling mode is selected, the mode cannot be changed via the interrupt enable/disable function but the init needs to be called again to change it.

#### Returns:

- ♦ IX\_SSP\_SUCCESS Successfully initialize and enable the SSP serial port.
- ♦ IX\_SSP\_RX\_FIFO\_HANDLER\_MISSING interrupt mode is selected but RX FIFO handler pointer is NULL
- ♦ IX\_SSP\_TX\_FIFO\_HANDLER\_MISSING interrupt mode is selected but TX FIFO handler pointer is NULL
- ♦ IX\_SSP\_RX\_FIFO\_OVERRUN\_HANDLER\_MISSING interrupt mode is selected but RX FIFO Overrun handler pointer is NULL
- ♦ IX SSP RX FIFO NOT EMPTY Rx FIFO not empty, data size change is not allowed.
- ♦ IX\_SSP\_TX\_FIFO\_NOT\_EMPTY Tx FIFO not empty, data size change is not allowed.
- ♦ IX\_SSP\_INVALID\_FRAME\_FORMAT\_ENUM\_VALUE frame format selected is invalid
- ♦ IX\_SSP\_INVALID\_DATA\_SIZE\_ENUM\_VALUE data size selected is invalid
- ♦ IX\_SSP\_INVALID\_CLOCK\_SOURCE\_ENUM\_VALUE clock source selected is invalid
- ♦ IX\_SSP\_INVALID\_TX\_FIFO\_THRESHOLD\_ENUM\_VALUE Tx FIFO threshold level selected is invalid
- ♦ IX\_SSP\_INVALID\_RX\_FIFO\_THRESHOLD\_ENUM\_VALUE Rx FIFO threshold level selected is invalid
- ♦ IX\_SSP\_INVALID\_SPI\_PHASE\_ENUM\_VALUE SPI phase selected is invalid
- ♦ IX\_SSP\_INVALID\_SPI\_POLARITY\_ENUM\_VALUE SPI polarity selected is invalid

- ♦ IX\_SSP\_INVALID\_MICROWIRE\_CTL\_CMD\_ENUM\_VALUE microwire control command size is invalid
- ♦ IX\_SSP\_INT\_UNBIND\_FAIL interrupt handler failed to unbind SSP interrupt
- $\Diamond$  IX\_SSP\_INT\_BIND\_FAIL interrupt handler failed to bind to SSP interrupt hardware trigger
- ♦ IX\_SSP\_NOT\_SUPORTED hardware does not support SSP
- ♦ IX\_SSP\_NULL\_POINTER parameter passed in is NULL

Reentrant : yesISR Callable : yes

#### ixSspAccLoopbackEnable ( BOOL loopbackEnable )

Enables/disables the loopback mode.

#### Parameters:

BOOL [in] loopbackEnable - True to enable and false to disable.

#### Global Data:

• None.

This API will set the mode of operation to either loopback or normal mode according to the user input.

#### Returns:

♦ IX\_SSP\_SUCCESS – Loopback enabled successfully ♦ IX\_SSP\_NOT\_INIT – SSP not initialized. SSP init needs to be called.

Reentrant : yesISR Callable : yes

#### ixSspAccMicrowireControlWordSet ( IxSspAccMicrowireCtlWord microwireCtlWordSelected )

Sets the Microwire control word to 8 or 16 bit format.

#### Parameters:

IxSspAccMicrowireCtlWord [in]– Microwire control word format can be either 8microwireCtlWordSelectedor 16 bit format

#### Global Data:

• None.

This API is only used for the Microwire frame format and will set the control word to 8 or 16 bit format

#### Returns:

- ♦ IX\_SSP\_SUCCESS Microwire Control Word set with valid enum value
- ♦ IX SSP TX FIFO NOT EMPTY Tx FIFO not empty, data size change is not allowed.

 $\Diamond$  IX\_SSP\_INVALID\_MICROWIRE\_CTL\_CMD\_ENUM\_VALUE – invalid enum value  $\Diamond$  IX\_SSP\_NOT\_INIT – SSP not initialized. SSP init needs to be called.

Reentrant : yesISR Callable : yes

## ixSspAccRxFIFOHitOrAboveThresholdCheck (void)

Check if the Rx FIFO threshold has been hit or exceeded.

#### Parameters:

- None

Global Data:

• None.

This API will return whether the Rx FIFO level is below threshold or not

#### Returns:

- ♦ IX\_SSP\_RX\_FIFO\_HIT\_ABOVE\_THRESHOLD Rx FIFO level hit or exceeded threshold
- ♦ IX\_SSP\_RX\_FIFO\_BELOW\_THRESHOLD Rx FIFO level below threshold
- $\Diamond$  IX\_SSP\_NOT\_INIT SSP not initialized. SSP init needs to be called.

Reentrant : yesISR Callable : yes

### ixSspAccRxFIFOIntDisable (void)

Disables service request interrupt of the Rx FIFO.

#### Parameters:

- None

Global Data:

• None.

This API will disable the service request interrupt of the Rx FIFO.

#### Returns:

- ♦ IX\_SSP\_SUCCESS Rx FIFO Interrupt disabled successfully
- ♦ IX\_SSP\_NOT\_INIT SSP not initialized. SSP init needs to be called.

Reentrant : yesISR Callable : yes

## $ix Ssp Acc RxFIFO Int Enable \ ( \ \textbf{RxFIFOThresholdHandler} \ rxFIFO Intr Handler \ )$

Enables service request interrupt whenever the Rx FIFO hits its threshold.

#### Parameters:

*void [in]* – function pointer to the interrupt handler for the Rx FIFO \*rxFIFOIntrHandler(UINT32) exceeded.

#### Global Data:

• None.

This API will enable the service request interrupt for the Rx FIFO

#### Returns:

- ♦ IX\_SSP\_SUCCESS Rx FIFO level interrupt enabled successfully
- ♦ IX\_SSP\_RX\_FIFO\_HANDLER\_MISSING missing handler for Rx FIFO level interrupt
- ♦ IX\_SSP\_POLL\_MODE\_BLOCKING poll mode is selected at init, interrupt not allowed to be enabled. Use init to enable interrupt mode.
- ♦ IX\_SSP\_NOT\_INIT SSP not initialized. SSP init needs to be called.

Reentrant : yesISR Callable : yes

#### ixSspAccRxFIFOLevelGet (void)

Obtain the Rx FIFO's level.

#### Parameters:

- None

#### Global Data:

• None.

This API will return the level of the Rx FIFO

#### Returns:

♦ 0..16; 0 can also mean SSP not initialized and will need to be init.

Reentrant : yesISR Callable : yes

#### ixSspAccRxFIFOOverrunCheck (void)

Check if the Rx FIFO has overrun its FIFOs.

#### Parameters:

None

Global Data:

• None.

This API will return whether the Rx FIFO has overrun its 16 FIFOs

#### Returns:

- ♦ IX\_SSP\_OVERRUN\_OCCURRED Rx FIFO overrun occurred
- ♦ IX\_SSP\_NO\_OVERRUN Rx FIFO did not overrun
- ♦ IX\_SSP\_NOT\_INIT SSP not initialized. SSP init needs to be called.

Reentrant : yesISR Callable : yes

## ixSspAccRxFIFOThresholdSet ( **IxSspAccFifoThreshold** rxFIFOThresholdSelected )

Sets the Rx FIFO Threshold.

#### Parameters:

IxSspAccFifoThreshold [in] rxFIFOThresholdSelected

- Threshold that is set for a Tx FIFO service request to be triggered

Global Data:

• None.

This API will will set the threshold for a Rx FIFO threshold to be triggered

#### Returns:

- $\Diamond$  IX\_SSP\_SUCCESS Rx FIFO Threshold set with valid enum value
- ♦ IX\_SSP\_INVALID\_RX\_FIFO\_THRESHOLD\_ENUM\_VALUE invalid enum value
- ♦ IX\_SSP\_NOT\_INIT SSP not initialized. SSP init needs to be called.

Reentrant : yesISR Callable : yes

#### ixSspAccSerialClockRateConfigure ( UINT8 serialClockRateSelected )

Sets the on-chip Serial Clock Rate of the SSP Serial Port hardware.

#### Parameters:

UINT8 [in] serialClockRateSelected

- The serial clock rate that can be set is between 7.2Kbps and 1.8432Mbps. The formula used is Bit rate =  $3.6864 \times 10^6 / (2 \times 10^8) \times 10^8 = 3.6864 \times 10^8 / (2 \times 10^8) \times 10^8 = 3.6864 \times 10^8 / (2 \times 10^8) \times 10^8 = 3.6864 \times 10^8 / (2 \times 10^8) \times 10^8 = 3.6864 \times 10^8 / (2 \times 10^8) \times 10^8 = 3.6864 \times 10^8 / (2 \times 10^8) \times 10^8 / (2 \times 10^8) \times 10^8 = 3.6864 \times 10^8 / (2 \times 10^8) \times 10^8 = 3.6864 \times 10^8 / (2 \times 10^8) \times 10^8 = 3.6864 \times 10^8 / (2 \times 10^8) \times 10^8 = 3.6864 \times 10^8 / (2 \times 10^8) \times 10^8 = 3.6864 \times 10^8 / (2 \times 10^8) \times 10^8 = 3.6864 \times 10^8 / (2 \times 10^8) \times 10^8 = 3.6864 \times 10^8 / (2 \times 10^8) \times 10^8 = 3.6864 \times 10^8 / (2 \times 10^8) \times 10^8 = 3.6864 \times 10^8 / (2 \times 10^8) \times 10^8 = 3.6864 \times 10^8 / (2 \times 10^8) \times 10^8 / (2 \times 10^8) \times 10^8 = 3.6864 \times 10^8 / (2 \times 10^8) \times 10^8 = 3.6864 \times 10^8 / (2 \times 10^8) \times 10^8 = 3.6864 \times 10^8 / (2 \times 10^8) \times 10^8 = 3.6864 \times 10^8 / (2 \times 10^8) \times 10^8 = 3.6864 \times 10^8 / (2 \times 10^8) \times 10^8 = 3.6864 \times 10^8 / (2 \times 10^8) \times 10^8 = 3.6864 \times 10^8 / (2 \times 10^8) \times 10^8 = 3.6864 \times 10^8 / (2 \times 10^8) \times 10^8 = 3.6864 \times 10^8 / (2 \times 10^8) \times 10^8 = 3.6864 \times 10^8 / (2 \times 10^8) \times 10^8 = 3.6864 \times 10^8 / (2 \times 10^8) \times 10^8 = 3.6864 \times 10^8 / (2 \times 10^8) \times 10^8 = 3.6864 \times 10^8 / (2 \times 10^8) \times 10^8 = 3.6864 \times 10^8 / (2 \times 10^8) \times 10^8 \times 10^8 = 3.6864 \times 10^8 / (2 \times 10^8) \times 10^8 = 3.6864 \times 10^8 / (2 \times 10^8) \times 10^8 = 3.6864 \times 10^8 / (2 \times 10^8) \times 10^8 \times 10^8 = 3.6864 \times 10^8 / (2 \times 10^8) \times 10^8 = 3.6864 \times 10^8 / (2 \times 10^8) \times 10^8 = 3.6864 \times 10^8 \times$ 

(SerialClockRateSelected + 1))

#### Global Data:

• None.

This API will set the serial clock rate for the transfers via user input.

#### Returns:

```
♦ IX_SSP_SUCCESS – Serial clock rate configured successfully 
♦ IX_SSP_NOT_INIT – SSP not initialized. SSP init needs to be called.
```

Reentrant : yesISR Callable : yes

#### ixSspAccShow (void)

Display SSP status registers and statistics counters.

#### Parameters:

- None

#### Global Data:

• None.

This API will display the status registers of the SSP and the statistics counters.

#### Returns:

```
    ♦ IX_SSP_SUCCESS – SSP show called successfully.
    ♦ IX_SSP_NOT_INIT – SSP not initialized. SSP init needs to be called.
```

Reentrant : yesISR Callable : yes

#### ixSspAccSpiSclkPhaseSet ( **IxSspAccSpiSclkPhase** spiSclkPhaseSelected )

Sets the SPI SCLK Phase.

#### Parameters:

IxSspAccSpiSclkPhase [in] spiSclkPhaseSelected

– Phase of either the SCLK is inactive one cycle at the start of a frame and 1/2 cycle at the end of a frame, OR the SCLK is inactive 1/2 cycle at the start of a frame and one cycle at the end of a frame.

#### Global Data:

- IX\_SSP\_SUCCESS SPI Sclk phase set with valid enum value
- IX\_SSP\_INVALID\_SPI\_PHASE\_ENUM\_VALUE invalid SPI phase value
- IX\_SSP\_NOT\_INIT SSP not initialized. SSP init needs to be called.

This API is only used for the SPI frame format and will set the SPI SCLK phase according to user input.

#### Returns:

♦ None

Reentrant : yesISR Callable : yes

## ixSspAccSpiSclkPolaritySet ( **IxSspAccSpiSclkPolarity** spiSclkPolaritySelected )

Sets the SPI SCLK Polarity to Low or High.

#### Parameters:

 "IxSspAccSpiSclkPolarity [in] spiSclkPolaritySelected" – SPI SCLK polarity that can be selected to either high or low

#### Global Data:

• None.

This API is only used for the SPI frame format and will set the SPI SCLK polarity to either low or high

#### Returns:

```
♦ IX_SSP_SUCCESS – SPI Sclk polarity set with valid enum value
```

♦ IX\_SSP\_INVALID\_SPI\_POLARITY\_ENUM\_VALUE – invalid SPI polarity value

♦ IX\_SSP\_NOT\_INIT – SSP not initialized. SSP init needs to be called.

Reentrant : yesISR Callable : yes

## ixSspAccSSPBusyCheck (void)

Determine the state of the SSP serial port hardware.

#### Parameters:

- None

#### Global Data:

• None.

This API will return the state of the SSP serial port hardware – busy or idle

#### Returns:

```
    ♦ IX_SSP_BUSY – SSP is busy
    ♦ IX_SSP_IDLE – SSP is idle.
    ♦ IX_SSP_NOT_INIT – SSP not initialized. SSP init needs to be called
```

Reentrant : yesISR Callable : yes

#### ixSspAccSSPPortStatusSet ( **IxSspAccPortStatus** portStatusSelected )

Enables/disables the SSP Serial Port hardware.

#### Parameters:

*IxSspAccPortStatus [in] portStatusSelected* — Set the SSP port to enable or disable

Global Data:

• None.

This API will enable/disable the SSP Serial Port hardware. NOTE: This function is called by init to enable the SSP after setting up the configurations and by uninit to disable the SSP.

#### Returns:

```
    ♦ IX_SSP_SUCCESS – Port status set with valid enum value
    ♦ IX_SSP_FAIL – invalid enum value
    ♦ IX_SSP_NOT_INIT – SSP not initialized. SSP init needs to be called.
```

Reentrant : yesISR Callable : yes

#### ixSspAccStatsGet ( **IxSspAccStatsCounters** \* *sspStats* )

Returns the SSP Statistics through the pointer passed in.

#### Parameters:

```
IxSspAccStatsCounters [in] - SSP statistics counter will be read and written to the location pointed by this pointer.
```

Global Data:

• None.

This API will return the statistics counters of the SSP transfers.

#### Returns:

♦ IX\_SSP\_SUCCESS – Stats obtained into the pointer provided successfully

#### ♦ IX\_SSP\_FAIL – client provided pointer is NULL

Reentrant : yesISR Callable : yes

#### ixSspAccStatsReset (void )

Resets the SSP Statistics.

#### Parameters:

- None

#### Global Data:

• None.

This API will reset the SSP statistics counters.

#### Returns:

◊ None

Reentrant : yesISR Callable : yes

#### ixSspAccTxFIFOHitOrBelowThresholdCheck (void)

Check if the Tx FIFO threshold has been hit or fallen below.

#### Parameters:

- None

Global Data:

• None.

This API will return whether the Tx FIFO threshold has been exceeded or not

#### Returns:

- $\Diamond$  IX\_SSP\_TX\_FIFO\_HIT\_BELOW\_THRESHOLD Tx FIFO level hit or below threshold .
- $\Diamond$  IX\_SSP\_TX\_FIFO\_EXCEED\_THRESHOLD Tx FIFO level exceeded threshold.
- ♦ IX\_SSP\_NOT\_INIT SSP not initialized. SSP init needs to be called.

Reentrant : yesISR Callable : yes

#### ixSspAccTxFIFOIntDisable (void)

Disables service request interrupt of the Tx FIFO.

#### Parameters:

None

Global Data:

• None.

This API will disable the service request interrupt of the Tx FIFO

#### Returns:

```
♦ IX_SSP_SUCCESS – Tx FIFO Interrupt disabled successfuly.
```

- ♦ IX\_SSP\_NOT\_INIT SSP not initialized. SSP init needs to be called.
- Reentrant : yesISR Callable : yes

## ixSspAccTxFIFOIntEnable ( **TxFIFOThresholdHandler** txFIFOIntrHandler )

Enables service request interrupt of the Tx FIFO.

#### Parameters:

```
void [in] – function pointer to the interrupt handler for the Tx FIFO *txFIFOIntrHandler(UINT32) exceeded.
```

#### Global Data:

• None.

This API will enable the service request interrupt of the Tx FIFO.

#### Returns:

```
♦ IX_SSP_SUCCESS – Tx FIFO level interrupt enabled successfully
```

- $\lozenge \ IX\_SSP\_TX\_FIFO\_HANDLER\_MISSING missing \ handler \ for \ Tx \ FIFO \ level \ interrupt$
- ♦ IX\_SSP\_POLL\_MODE\_BLOCKING poll mode is selected at init, interrupt not allowed to be enabled. Use init to enable interrupt mode.
- ♦ IX\_SSP\_NOT\_INIT SSP not initialized. SSP init needs to be called.

Reentrant : yesISR Callable : yes

```
ixSspAccTxFIFOLevelGet ( void )
```

Obtain the Tx FIFO's level. Parameters: - None Global Data: • None. This API will return the level of the Tx FIFO Returns: ♦ 0..16; 0 can also mean SSP not initialized and will need to be init. • Reentrant : yes • ISR Callable: yes ixSspAccTxFIFOThresholdSet ( **IxSspAccFifoThreshold** txFIFOThresholdSelected ) Sets the Tx FIFO Threshold. Parameters: IxSspAccFifoThreshold [in] - Threshold that is set for a Tx FIFO service request *txFIFOThresholdSelected* to be triggered Global Data: • None. This API will set the threshold for a Tx FIFO threshold to be triggered Returns: ♦ IX SSP SUCCESS – Tx FIFO Threshold set with valid enum value ♦ IX\_SSP\_INVALID\_TX\_FIFO\_THRESHOLD\_ENUM\_VALUE – invalid enum value ♦ IX\_SSP\_NOT\_INIT – SSP not initialized. SSP init needs to be called. • Reentrant : yes • ISR Callable: yes

ixSspAccUninit ( void )

Un-initializes the SSP Serial Port Access component.

#### Parameters:

- None

Global Data:

• None.

This API will disable the SSP Serial Port hardware. The client can call the init function again if they wish to enable the SSP.

#### Returns:

♦ IX\_SSP\_SUCCESS – successfully uninit SSP component
 ♦ IX\_SSP\_INT\_UNBIND\_FAIL – interrupt handler failed to unbind SSP interrupt

Reentrant : yesISR Callable : yes

# Intel (R) IXP400 Software Timer Control (IxTimerCtrl) API

The public API for the IXP400 Timer Control Component.

# **Defines**

#define IX TIMERCTRL NO FREE TIMERS

Timer schedule return code.

#define IX TIMERCTRL PARAM ERROR

Timer schedule return code.

# **Typedefs**

typedef void(\* IxTimerCtrlTimerCallback )(void \*userParam)

A typedef for a pointer to a timer callback function.

## **Enumerations**

# **Functions**

PUBLICixTimerCtrlSchedule (IxTimerCtrlTimerCallback func, void \*userParam,

IX STATUS **IxTimerCtrlPurpose** purpose, UINT32 relativeTime, unsigned \*timerId)

Schedules a callback function to be called after a period of "time". The callback function should not block or run for more than 100ms. This function.

PUBLICixTimerCtrlScheduleRepeating (IxTimerCtrlTimerCallback func, void \*param,

IX\_STATUS **IxTimerCtrlPurpose** purpose, UINT32 interval, unsigned \*timerId)

Schedules a callback function to be called after a period of "time". The callback function should not block or run for more than 100ms.

PUBLIC

IX STATUS ixTimerCtrlCancel (unsigned id)

Cancels a scheduled callback.

ixTimerCtrlInit (void)

# PUBLIC IX STATUS

*Initialise the Timer Control Component.* 

PUBLIC void ixTimerCtrlShow (void)

Display the status of the Timer Control Component.

# **Detailed Description**

The public API for the IXP400 Timer Control Component.

# **Define Documentation**

#### #define IX\_TIMERCTRL\_NO\_FREE\_TIMERS

Timer schedule return code.

Indicates that the request to start a timer failed because all available timer resources are used.

Definition at line 48 of file IxTimerCtrl.h.

#### #define IX\_TIMERCTRL\_PARAM\_ERROR

Timer schedule return code.

Indicates that the request to start a timer failed because the client has supplied invalid parameters.

Definition at line **61** of file **IxTimerCtrl.h**.

# **Typedef Documentation**

typedef void(\* IxTimerCtrlTimerCallback)(void \*userParam)

A typedef for a pointer to a timer callback function.

void \* – This parameter is supplied by the client when the timer is started and passed back to the client in the callback.

#### Note:

in general timer callback functions should not block or take longer than 100ms. This constraint is required to ensure that higher priority callbacks are not held up. All callbacks are called from the same thread. This thread is a shared resource. The parameter passed is provided when the timer is scheduled.

Detailed Description 473

# **Enumeration Type Documentation**

#### enum IxTimerCtrlPurpose

List used to identify the users of timers.

#### Note:

The order in this list indicates priority. Components appearing higher in the list will be given priority over components lower in the list. When adding components, please insert at an appropriate position for priority ( i.e values should be less than IxTimerCtrlMaxPurpose ).

Definition at line 93 of file IxTimerCtrl.h.

# **Function Documentation**

ixTimerCtrlCancel (unsigned id)

Cancels a scheduled callback.

#### Parameters:

id unsigned [in] – the id of the callback to be cancelled.

#### Returns:

- ♦ IX\_SUCCESS The timer was successfully stopped.
- ◊ IX\_FAIL The id parameter did not corrrespond to any running timer..

#### Note:

This function is re—entrant. The function accesses a list of running timers and may suspend the calling thread if this list is being accessed by another thread.

#### ixTimerCtrlInit (void)

Initialise the Timer Control Component.

#### Returns:

- ♦ IX\_SUCCESS The timer control component initialized successfully.
- ♦ IX\_FAIL The timer control component initialization failed, or the component was already initialized.

#### Note:

This must be done before any other API function is called. This function should be called once only and is not re-entrant.

```
ixTimerCtrlSchedule ( IxTimerCtrlTimerCallback func, void * userParam, IxTimerCtrlPurpose purpose, UINT32 relativeTime, unsigned * timerId
```

Schedules a callback function to be called after a period of "time". The callback function should not block or run for more than 100ms. This function.

#### Parameters:

*func* **IxTimerCtrlTimerCallback** [in] – the callback function to be called. *userParam* void [in] – a parameter to send to the callback function, can be NULL.

purpose IxTimerCtrlPurpose [in] – the purpose of the callback, internally this component

will decide the priority of callbacks with different purpose.

relativeTime UINT32 [in] – time relative to now in milliseconds after which the callback will be

called. The time must be greater than the duration of one OS tick.

\*timerId unsigned [out] – An id for the callback scheduled. This id can be used to cancel the

callback.

#### Returns:

- ♦ IX\_SUCCESS The timer was started successfully.
- ♦ IX\_TIMERCTRL\_NO\_FREE\_TIMERS The timer was not started because the maximum number of running timers has been exceeded.
- ♦ IX\_TIMERCTRL\_PARAM\_ERROR The timer was not started because the client has supplied a NULL callback func, or the requested timeout is less than one OS tick.

#### Note:

This function is re-entrant. The function accesses a list of running timers and may suspend the calling thread if this list is being accessed by another thread.

```
ixTimerCtrlScheduleRepeating ( IxTimerCtrlTimerCallback func, void * param, IxTimerCtrlPurpose purpose, UINT32 interval, unsigned * timerId
```

Schedules a callback function to be called after a period of "time". The callback function should not block or run for more than 100ms.

#### Parameters:

*func* **IxTimerCtrlTimerCallback** [in] – the callback function to be called. *userParam* void [in] – a parameter to send to the callback function, can be NULL.

purpose IxTimerCtrlPurpose [in] – the purpose of the callback, internally this component will

decide the priority of callbacks with different purpose.

interval UINT32 [in] – the interval in milliseconds between calls to func.

timerId unsigned [out] – An id for the callback scheduled. This id can be used to cancel the

callback.

#### Returns:

- ♦ IX\_SUCCESS The timer was started successfully.
- ♦ IX\_TIMERCTRL\_NO\_FREE\_TIMERS The timer was not started because the maximum number of running timers has been exceeded.
- ♦ IX\_TIMERCTRL\_PARAM\_ERROR The timer was not started because the client has supplied a NULL callback func, or the requested timeout is less than one OS tick.

#### Note:

This function is re-entrant. The function accesses a list of running timers and may suspend the calling thread if this list is being accessed by another thread.

#### ixTimerCtrlShow (void)

Display the status of the Timer Control Component.

#### Returns:

void

#### Note:

Displays a list of running timers. This function is not re-entrant. This function does not suspend the calling thread.

# Intel (R) IXP400 Software Time Sync Access Component API

Public API for IxTimeSyncAcc.

## **Data Structures**

#### struct IxTimeSyncAccPtpMsgData

Struct for data from the PTP message returned when TimeStamp available.

#### struct IxTimeSyncAccPtpMsgData

Struct for data from the PTP message returned when TimeStamp available.

#### struct IxTimeSyncAccPtpMsgData

Struct for data from the PTP message returned when TimeStamp available.

#### struct IxTimeSyncAccStats

Statistics for the PTP messages.

#### struct IxTimeSyncAccStats

Statistics for the PTP messages.

#### struct IxTimeSyncAccStats

Statistics for the PTP messages.

#### struct IxTimeSyncAccTimeValue

Struct to hold 64 bit SystemTime and TimeStamp values.

#### struct IxTimeSyncAccTimeValue

Struct to hold 64 bit SystemTime and TimeStamp values.

#### struct IxTimeSyncAccTimeValue

Struct to hold 64 bit SystemTime and TimeStamp values.

#### struct IxTimeSyncAccUuid

Struct to hold 48 bit UUID values captured in Sync or Delay\_Req messages.

#### struct IxTimeSyncAccUuid

Struct to hold 48 bit UUID values captured in Sync or Delay\_Req messages.

## struct IxTimeSyncAccUuid

Struct to hold 48 bit UUID values captured in Sync or Delay\_Req messages.

# **Typedefs**

typedef void(\* IxTimeSyncAccTargetTimeCallback )(IxTimeSyncAccTimeValue targetTime)

Callback for use by target time stamp interrupt.

 $typedef\ void (*\ IxTimeSyncAccAuxTimeCallback\ ) (IxTimeSyncAccAuxMode\ auxMode,\ IxTimeSyncAccTimeValue\ auxTime)$ 

Callback for use by auxiliary time interrupts.

# **Enumerations**

```
enum IxTimeSyncAccStatus {
     IX_TIMESYNCACC_SUCCESS,
     IX_TIMESYNCACC_INVALIDPARAM,
     IX_TIMESYNCACC_NOTIMESTAMP,
     IX_TIMESYNCACC_INTERRUPTMODEINUSE,
     IX_TIMESYNCACC_FAILED
    The status as returned from the API.
enum IxTimeSyncAccAuxMode {
     IX_TIMESYNCACC_AUXMODE_MASTER,
     IX_TIMESYNCACC_AUXMODE_SLAVE,
     IX_TIMESYNCACC_AUXMODE_INVALID
    Master or Slave Auxiliary Time Stamp (Snap Shot).
enum IxTimeSyncAcc1588PTPPort {
     IX_TIMESYNCACC_NPE_A_1588PTP_PORT,
     IX_TIMESYNCACC_NPE_B_1588PTP_PORT,
     IX_TIMESYNCACC_NPE_C_1588PTP_PORT,
     IX_TIMESYNCACC_NPE_1588PORT_INVALID
    IEEE 1588 PTP Communication Port(Channel).
enum IxTimeSyncAcc1588PTPPortMode {
     IX_TIMESYNCACC_1588PTP_PORT_MASTER,
     IX_TIMESYNCACC_1588PTP_PORT_SLAVE,
     IX_TIMESYNCACC_1588PTP_PORT_ANYMODE,
     IX_TIMESYNCACC_1588PTP_PORT_MODE_INVALID
    Master or Slave mode for IEEE 1588 PTP Communication Port.
enum IxTimeSyncAcc1588PTPMsgType {
     IX_TIMESYNCACC_1588PTP_MSGTYPE_SYNC,
     IX_TIMESYNCACC_1588PTP_MSGTYPE_DELAYREQ,
     IX_TIMESYNCACC_1588PTP_MSGTYPE_UNKNOWN
    1588 PTP Messages types that can be detected on communication port
```

Typedefs 478

# **Functions**

# PUBLICixTimeSyncAccPTPPortConfigSet (IxTimeSyncAcc1588PTPPort ptpPort,

IxTimeSyncAccStatus IxTimeSyncAcc1588PTPPortMode ptpPortMode)

Configures the IEEE 1588 message detect on particular PTP port.

# PUBLICixTimeSyncAccPTPPortConfigGet (IxTimeSyncAcc1588PTPPort ptpPort, IxTimeSyncAccStatus IxTimeSyncAcc1588PTPPortMode \*ptpPortMode)

Retrieves IEEE 1588 PTP operation mode on particular PTP port.

## PUBLICixTimeSyncAccPTPRxPoll (IxTimeSyncAcc1588PTPPort ptpPort,

#### IxTimeSyncAccStatus IxTimeSyncAccPtpMsgData \*ptpMsgData)

Polls the IEEE 1588 message/time stamp detect status on a particular PTP Port on the Receive side.

#### PUBLICixTimeSyncAccPTPTxPoll (IxTimeSyncAcc1588PTPPort ptpPort,

#### IxTimeSyncAccStatus IxTimeSyncAccPtpMsgData \*ptpMsgData)

Polls the IEEE 1588 message/time stamp detect status on a particular PTP Port on the Transmit side.

#### **PUBLIC**

#### IxTimeSyncAccStatus ixTimeSyncAccSystemTimeSet (IxTimeSyncAccTimeValue systemTime)

Sets the System Time in the IEEE 1588 hardware assist block.

#### **PUBLIC**

#### IxTimeSyncAccStatus ixTimeSyncAccSystemTimeGet (IxTimeSyncAccTimeValue \*systemTime)

Gets the System Time from the IEEE 1588 hardware assist block.

#### **PUBLIC**

## IxTimeSyncAccStatus ixTimeSyncAccTickRateSet (UINT32 tickRate)

Sets the Tick Rate (Frequency Scaling Value) in the IEEE 1588 hardware assist block.

#### **PUBLIC**

#### IxTimeSyncAccStatus ixTimeSyncAccTickRateGet (UINT32 \*tickRate)

Gets the Tick Rate (Frequency Scaling Value) from the IEEE 1588 hardware assist block.

#### PUBLIC ix Time Sync Acc Target Time Interrupt Enable

#### IxTimeSyncAccStatus (IxTimeSyncAccTargetTimeCallback targetTimeCallback)

Enables the interrupt to verify the condition where the System Time greater or equal to the Target Time in the IEEE 1588 hardware assist block. If the condition is true an interrupt will be sent to Intel XScale(R) Core.

#### **PUBLIC**

#### IxTimeSyncAccStatus ixTimeSyncAccTargetTimeInterruptDisable (void)

Disables the interrupt for the condition explained in the function description of ixTimeSyncAccTargetTimeInterruptEnable.

Functions 479

#### PUBLICixTimeSyncAccTargetTimePoll (BOOL \*ttmPollFlag,

#### IxTimeSyncAccStatus IxTimeSyncAccTimeValue \*targetTime)

Poll to verify the condition where the System Time greater or equal to the Target Time in the IEEE 1588 hardware assist block. If the condition is true an event flag is set in the hardware.

#### **PUBLIC**

#### IxTimeSyncAccStatus ixTimeSyncAccTargetTimeSet (IxTimeSyncAccTimeValue targetTime)

Sets the Target Time in the IEEE 1588 hardware assist block.

#### **PUBLIC**

#### IxTimeSyncAccStatus ixTimeSyncAccTargetTimeGet (IxTimeSyncAccTimeValue \*targetTime)

Gets the Target Time in the IEEE 1588 hardware assist block.

# PUBLICixTimeSyncAccAuxTimeInterruptEnable (IxTimeSyncAccAuxMode auxMode, IxTimeSyncAccStatus IxTimeSyncAccAuxTimeCallback auxTimeCallback)

Enables the interrupt notification for the given mode of Auxiliary Time Stamp in the IEEE 1588 hardware assist block.

#### **PUBLIC**

#### IxTimeSyncAccStatus ixTimeSyncAccAuxTimeInterruptDisable (IxTimeSyncAccAuxMode auxMode)

Disables the interrupt for the indicated mode of Auxiliary Time Stamp in the IEEE 1588 hardware assist block.

#### PUBLICixTimeSyncAccAuxTimePoll (IxTimeSyncAccAuxMode auxMode, BOOL

## IxTimeSyncAccStatus \*auxPollFlag, IxTimeSyncAccTimeValue \*auxTime)

Poll for the Auxiliary Time Stamp captured for the mode indicated (Master or Slave).

#### **PUBLIC**

#### IxTimeSyncAccStatus ixTimeSyncAccReset (void)

Resets the IEEE 1588 hardware assist block.

#### **PUBLIC**

#### IxTimeSyncAccStatus ixTimeSyncAccStatsGet (IxTimeSyncAccStats \*timeSyncStats)

Returns the IxTimeSyncAcc Statistics in the client supplied buffer.

#### PUBLIC void ixTimeSyncAccStatsReset (void)

Reset Time Sync statistics.

#### **PUBLIC**

## IxTimeSyncAccStatus ixTimeSyncAccShow (void)

Displays the Time Sync current status.

# **Detailed Description**

Public API for IxTimeSyncAcc.

Detailed Description 480

# **Typedef Documentation**

IxTimeSyncAccAuxTimeCallback

Callback for use by auxiliary time interrupts.

Definition at line **188** of file **IxTimeSyncAcc.h**.

IxTimeSyncAccTargetTimeCallback

Callback for use by target time stamp interrupt.

Definition at line 179 of file IxTimeSyncAcc.h.

# **Enumeration Type Documentation**

enum IxTimeSyncAcc1588PTPMsgType

1588 PTP Messages types that can be detected on communication port

Note that client code can determine this based on master/slave mode in which it is already operating in and this information is made available for the sake of convenience only.

#### Enumeration values:

IX\_TIMESYNCACC\_1588PTP\_MSGTYPE\_SYNC PTP Sync message sent by Master or received by Slave.

IX\_TIMESYNCACC\_1588PTP\_MSGTYPE\_DELAYREQ PTP Delay\_Req message sent by Slave or received by Master.

IX\_TIMESYNCACC\_1588PTP\_MSGTYPE\_UNKNOWN Other PTP and non-PTP message sent or received by both Master and/or Slave.

Definition at line **106** of file **IxTimeSyncAcc.h**.

#### enum IxTimeSyncAcc1588PTPPort

IEEE 1588 PTP Communication Port(Channel).

#### Enumeration values:

IX\_TIMESYNCACC\_NPE\_A\_1588PTP\_PORTPTP Communication<br/>Port on NPE-A.IX\_TIMESYNCACC\_NPE\_B\_1588PTP\_PORTPTP Communication<br/>Port on NPE-B.IX\_TIMESYNCACC\_NPE\_C\_1588PTP\_PORTPTP Communication<br/>Port on NPE-C.

IX\_TIMESYNCACC\_NPE\_1588PORT\_INVALID

Invalid PTP Communication Port.

Definition at line **70** of file **IxTimeSyncAcc.h**.

#### enum IxTimeSyncAcc1588PTPPortMode

Master or Slave mode for IEEE 1588 PTP Communication Port.

#### **Enumeration values:**

IX\_TIMESYNCACC\_1588PTP\_PORT\_MASTER PTP Communication Port in Master

Mode.

IX\_TIMESYNCACC\_1588PTP\_PORT\_SLAVE
IX\_TIMESYNCACC\_1588PTP\_PORT\_ANYMODE

PTP Communication Port in Slave Mode. PTP Communication Port in ANY Mode

allows time stamping of all messages

including non-1588 PTP.

IX\_TIMESYNCACC\_1588PTP\_PORT\_MODE\_INVALID Invalid PTP Port Mode.

Definition at line **85** of file **IxTimeSyncAcc.h**.

#### enum IxTimeSyncAccAuxMode

Master or Slave Auxiliary Time Stamp (Snap Shot).

#### **Enumeration values:**

IX\_TIMESYNCACC\_AUXMODE\_MASTER Auxiliary Master

Mode.

IX\_TIMESYNCACC\_AUXMODE\_SLAVE Auxiliary Slave

Mode.

IX\_TIMESYNCACC\_AUXMODE\_INVALID Invalid Auxiliary

Mode.

Definition at line **56** of file **IxTimeSyncAcc.h**.

#### enum IxTimeSyncAccStatus

The status as returned from the API.

#### Enumeration values:

IX\_TIMESYNCACC\_SUCCESSRequested operation successful.IX\_TIMESYNCACC\_INVALIDPARAMAn invalid parameter was passed.IX\_TIMESYNCACC\_NOTIMESTAMPWhile polling no time stamp available.

IX\_TIMESYNCACC\_INTERRUPTMODEINUSE Polling not allowed while operating in interrupt

mode.

IX\_TIMESYNCACC\_FAILED Internal error occurred.

### **Function Documentation**

**IxTimeSyncAccStatus** ixTimeSyncAccAuxTimeInterruptDisable ( **IxTimeSyncAccAuxMode** auxMode )

Disables the interrupt for the indicated mode of Auxiliary Time Stamp in the IEEE 1588 hardware assist block.

#### Parameters:

auxMode

[in] – Auxiliary time stamp mode (slave or master) using which the interrupt will be disabled.

This API will disable the Auxiliary Time Stamp Interrupt (Master or Slave)

Re-entrant : yesISR Callable : no

#### Returns:

 $\lozenge \ IX\_TIMESYNCACC\_SUCCESS - Operation \ is \ successful$ 

♦ IX\_TIMESYNCACC\_INVALIDPARAM – Invalid parameters passed

♦ IX\_TIMESYNCACC\_FAILED – Internal error occurred

```
      IxTimeSyncAccStatus
      ( IxTimeSyncAccAuxMode auxMode,

      ixTimeSyncAccAuxTimeInterruptEnable
      IxTimeSyncAccAuxTimeCallback auxTimeCallback
```

Enables the interrupt notification for the given mode of Auxiliary Time Stamp in the IEEE 1588 hardware assist block.

#### Parameters:

```
auxMode [in] – Auxiliary time stamp register (slave or master) to use auxTimeCallback [in] – Callback to be invoked when interrupt fires
```

This API will enable the Auxiliary Master/Slave Time stamp Interrupt.

NOTE: 1) An individual callback is to be registered for each Slave and Master Auxiliary Time Stamp registers. Thus to register for both Master and Slave time stamp interrupts either the same callback or two separate callbacks the API has to be invoked twice.

2) On the IXDP465 Development Platform, the Auxiliary Timestamp signal for slave mode is tied to GPIO 8 pin. This signal is software routed by default to PCI for backwards compatibility with the IXDP425 Development Platform. This routing must be disabled for the auxiliary slave time stamp register to work properly. The following commands may be used to accomplish this. However, refer to the IXDP465 Development Platform Users Guide or the BSP/LSP documentation for more specific information.

For Linux\* (at the Redboot prompt i.e., before loading zImage):

```
mfill -b 0x54100000 -1 -1 1 -p 8
    mfill -b 0x54100001 -1 -1 1 -p 0x7f
For vxWorks*, at the prompt:
    intDisable(25)
    ixdp400FpgaIODetach(8)
```

Re-entrant : noISR Callable : no

#### Returns:

- ♦ IX\_TIMESYNCACC\_SUCCESS Operation is successful
- ♦ IX\_TIMESYNCACC\_INVALIDPARAM Null parameter passed for callback or invalid auxiliary snapshot mode
- ♦ IX\_TIMESYNCACC\_FAILED Internal error occurred

Poll for the Auxiliary Time Stamp captured for the mode indicated (Master or Slave).

#### Parameters:

auxMode [in] – Auxiliary Snapshot Register (Slave or Master) to be checked
 auxPollFlag [out] – TRUE if the time stamp captured in auxiliary snapshot register FALSE if the time stamp not captured in auxiliary snapshot register
 auxTime [out] – Copy the current Auxiliary Snapshot Register value into the client provided buffer

Polls for the Time stamp in the appropriate Auxiliary Snapshot Registers based on the mode specified. Return true and the contents of the Auxiliary snapshot, if it is available else return false.

Please refer to the note #2 of the API **ixTimeSyncAccAuxTimeInterruptEnable** for more information for Auxiliary Slave mode.

Re-entrant : yesISR Callable : no

#### Returns:

- ♦ IX\_TIMESYNCACC\_SUCCESS Operation is successful
- ♦ IX\_TIMESYNCACC\_INVALIDPARAM Null parameter passed for auxPollFlag, callback or invalid auxiliary snapshot mode
- ♦ IX\_TIMESYNCACC\_FAILED Internal error occurred
- ◊ IX\_TIMESYNCACC\_INTERRUPTMODEINUSE Interrupt mode in use

#### 

```
IxTimeSyncAcc1588PTPPortMode

*
```

Retrieves IEEE 1588 PTP operation mode on particular PTP port.

#### Parameters:

```
ptpPort [in] - PTP port
ptpPortMode [in] - Mode of operation of PTP port (Master or Slave)
```

This API will identify the time stamping capability of a PTP port by means of obtaining its mode of operation.

Re–entrant : NoISR Callable : No

#### Returns:

```
♦ IX_TIMESYNCACC_SUCCESS – Operation is successful 
♦ IX_TIMESYNCACC_INVALIDPARAM – Invalid parameters passed
```

♦ IX\_TIMESYNCACC\_FAILED – Internal error occurred

Configures the IEEE 1588 message detect on particular PTP port.

#### Parameters:

```
ptpPort[in] – PTP port to configptpPortMode[in] – Port to operate in Master or Slave mode
```

This API will enable the time stamping on a particular PTP port.

Re-entrant : NoISR Callable : No

#### Returns:

```
    ♦ IX_TIMESYNCACC_SUCCESS – Operation is successful
    ♦ IX_TIMESYNCACC_INVALIDPARAM – Invalid parameters passed
    ♦ IX_TIMESYNCACC_FAILED – Internal error occurred
```

```
IxTimeSyncAccStatus ixTimeSyncAccPTPRxPoll ( IxTimeSyncAcc1588PTPPort ptpPort, IxTimeSyncAccPtpMsgData * ptpMsgData * ptpMsgData )
```

Polls the IEEE 1588 message/time stamp detect status on a particular PTP Port on the Receive side.

#### Parameters:

```
ptpPort [in] – PTP port to pollptpMsgData [out] – Current TimeStamp and other Data
```

This API will poll for the availability of a time stamp on the received Sync (Slave) or Delay\_Req (Master) messages. The client application will provide the buffer.

Re–entrant : NoISR Callable : No

#### Returns:

```
    ♦ IX_TIMESYNCACC_SUCCESS – Operation is successful
    ♦ IX_TIMESYNCACC_INVALIDPARAM – Invalid parameters passed
    ♦ IX_TIMESYNCACC_NOTIMESTAMP – No time stamp available
    ♦ IX_TIMESYNCACC_FAILED – Internal error occurred
```

```
IxTimeSyncAccStatus ixTimeSyncAccPTPTxPoll ( IxTimeSyncAcc1588PTPPort ptpPort, IxTimeSyncAccPtpMsgData * ptpMsgData * ptpMsgData )
```

Polls the IEEE 1588 message/time stamp detect status on a particular PTP Port on the Transmit side.

#### Parameters:

```
ptpPort [in] – PTP port to pollptpMsgData [out] – Current TimeStamp and other Data
```

This API will poll for the availability of a time stamp on the transmitted Sync (Master) or Delay\_Req (Slave) messages. The client application will provide the buffer.

Re–entrant : NoISR Callable : No

#### Returns:

```
♦ IX_TIMESYNCACC_SUCCESS – Operation is successful
```

- ♦ IX\_TIMESYNCACC\_INVALIDPARAM Invalid parameters passed
- ♦ IX\_TIMESYNCACC\_NOTIMESTAMP No time stamp available
- ♦ IX\_TIMESYNCACC\_FAILED Internal error occurred

#### IxTimeSyncAccStatus ixTimeSyncAccReset (void )

Resets the IEEE 1588 hardware assist block.

Sets the reset bit in the IEEE1588 silicon which fully resets the silicon block

Reentrant : yesISR Callable : no

#### Returns:

```
♦ IX_TIMESYNCACC_SUCCESS – Operation is successful 
♦ IX_TIMESYNCACC_FAILED – Internal error occurred
```

#### **IxTimeSyncAccStatus** ixTimeSyncAccShow (void )

Displays the Time Sync current status.

This API will display status on the current configuration of the IEEE 1588 hardware assist block, contents of the various time stamp registers, outstanding interrupts and/or events.

Note that this is intended for debug only, and in contrast to the other functions, it does not clear the any of the status bits associated with active timestamps and so is passive in its nature.

Reentrant : yesISR Callable : no

#### Returns:

```
♦ IX_TIMESYNCACC_SUCCESS – Operation is successful 
♦ IX_TIMESYNCACC_FAILED – Internal error occurred
```

#### **IxTimeSyncAccStatus** ixTimeSyncAccStatsGet ( **IxTimeSyncAccStats** \* timeSyncStats )

Returns the IxTimeSyncAcc Statistics in the client supplied buffer.

#### Parameters:

timeSyncStats [out] – TimeSync statistics counter values

This API will return the statistics of the received or transmitted messages.

NOTE: 1) These counters are updated only when the client polls for the time stamps or interrupt are enabled. This is because the IxTimeSyncAcc module does not either transmit or receive messages and does only run the code when explicit requests received by client application.

2) These statistics reflect the number of valid PTP messages exchanged in Master and Slave modes but includes all the messages (including valid non–PTP messages) while operating in the Any mode.

Reentrant : noISR Callable : no

#### Returns:

```
    ♦ IX_TIMESYNCACC_SUCCESS – Operation is successful
    ♦ IX_TIMESYNCACC_INVALIDPARAM – NULL parameter passed
    ♦ IX_TIMESYNCACC_FAILED – Internal error occurred
```

void ixTimeSyncAccStatsReset ( void )

Reset Time Sync statistics.

This API will reset the statistics counters of the TimeSync access layer.

```
Reentrant : yesISR Callable: no
```

#### Returns:

♦ None

#### **IxTimeSyncAccStatus** ixTimeSyncAccSystemTimeGet ( **IxTimeSyncAccTimeValue** \* systemTime )

Gets the System Time from the IEEE 1588 hardware assist block.

#### Parameters:

```
systemTime [out] – Copy the current System Time into the client application provided buffer
```

This API will get the SystemTime from IEEE1588 block and return to client

Re-entrant : noISR Callable : no

#### Returns:

- ♦ IX\_TIMESYNCACC\_SUCCESS Operation is successful
- ♦ IX\_TIMESYNCACC\_INVALIDPARAM Invalid parameters passed
- ♦ IX\_TIMESYNCACC\_FAILED Internal error occurred

#### **IxTimeSyncAccStatus** ixTimeSyncAccSystemTimeSet ( **IxTimeSyncAccTimeValue** systemTime )

Sets the System Time in the IEEE 1588 hardware assist block.

#### Parameters:

```
systemTime [in] – Value to set System Time
```

This API will set the SystemTime to given value.

Re-entrant : yesISR Callable : no

#### Returns:

```
    ◊ IX_TIMESYNCACC_SUCCESS – Operation is
successful
    ◊ IX_TIMESYNCACC_FAILED – Internal error
occurred
```

#### **IxTimeSyncAccStatus** ixTimeSyncAccTargetTimeGet ( **IxTimeSyncAccTimeValue** \* targetTime )

Gets the Target Time in the IEEE 1588 hardware assist block.

#### Parameters:

targetTime [out] - Copy current time to client provided buffer

This API will get the Target Time from IEEE 1588 block and return to the client application

Re-entrant : yesISR Callable : no

#### Returns:

- ♦ IX\_TIMESYNCACC\_SUCCESS Operation is successful
- ◊ IX TIMESYNCACC INVALIDPARAM Null parameter passed
- ♦ IX\_TIMESYNCACC\_FAILED Internal error occurred

#### **IxTimeSyncAccStatus** ixTimeSyncAccTargetTimeInterruptDisable (void )

Disables the interrupt for the condition explained in the function description of **ixTimeSyncAccTargetTimeInterruptEnable**.

This API will disable the Target Time interrupt.

NOTE: The client application needs to ensure that the APIs ixTimeSyncAccTargetTimeInterruptEnable, ixTimeSyncAccTargetTimeSet and ixTimeSyncAccTargetTimeInterruptDisable are accessed in mutual exclusive manner with respect to each other.

Re-entrant : noISR Callable : yes

#### Returns:

♦ IX\_TIMESYNCACC\_SUCCESS – Operation is successful ♦ IX\_TIMESYNCACC\_FAILED – Internal error occurred

#### **IxTimeSyncAccStatus**

( **IxTimeSyncAccTargetTimeCallback** targetTimeCallback )

ixTimeSyncAccTargetTimeInterruptEnable

Enables the interrupt to verify the condition where the System Time greater or equal to the Target Time in the IEEE 1588 hardware assist block. If the condition is true an interrupt will be sent to Intel XScale(R) Core .

#### Parameters:

targetTimeCallback [in] – Callback to be invoked when interrupt fires

This API will enable the Target Time reached/hit condition interrupt.

NOTE: The client application needs to ensure that the APIs ixTimeSyncAccTargetTimeInterruptEnable, ixTimeSyncAccTargetTimeSet and ixTimeSyncAccTargetTimeInterruptDisable are accessed in mutual exclusive manner with respect to each other.

Re–entrant : noISR Callable : yes

#### Returns:

```
    ♦ IX_TIMESYNCACC_SUCCESS – Operation is successful
    ♦ IX_TIMESYNCACC_INVALIDPARAM – Null parameter passed for callback
    ♦ IX_TIMESYNCACC_FAILED – Internal error occurred
```

```
IxTimeSyncAccStatus ixTimeSyncAccTargetTimePoll ( BOOL * ttmPollFlag, IxTimeSyncAccTimeValue * targetTime )
```

Poll to verify the condition where the System Time greater or equal to the Target Time in the IEEE 1588 hardware assist block. If the condition is true an event flag is set in the hardware.

#### Parameters:

```
    ttmPollFlag [out] – TRUE if the target time reached/hit condition event set FALSE if the target time reached/hit condition event is not set
    targetTime [out] – Capture current targetTime into client provided buffer
```

Poll the target time reached/hit condition status. Return true and the current target time value, if the condition is true else return false.

NOTE: The client application will need to clear the event flag that will be set as long as the condition that the System Time greater or equal to the Target Time is valid, in one of the following ways: 1) Invoke the API to change the target time 2) Change the system timer value

Re–entrant : yesISR Callable : no

#### Returns:

```
\lozenge \ IX\_TIMESYNCACC\_SUCCESS - Operation \ is \ successful
```

- ♦ IX\_TIMESYNCACC\_INVALIDPARAM Null parameter passed
- ♦ IX TIMESYNCACC FAILED Internal error occurred
- ♦ IX\_TIMESYNCACC\_INTERRUPTMODEINUSE Interrupt mode in use

#### **IxTimeSyncAccStatus** ixTimeSyncAccTargetTimeSet ( **IxTimeSyncAccTimeValue** targetTime )

Sets the Target Time in the IEEE 1588 hardware assist block.

#### Parameters:

```
targetTime [in] - Value to set Target Time
```

This API will set the Target Time to a given value.

NOTE: The client application needs to ensure that the APIs ixTimeSyncAccTargetTimeInterruptEnable, ixTimeSyncAccTargetTimeSet and ixTimeSyncAccTargetTimeInterruptDisable are accessed in mutual exclusive manner with respect to each other.

Reentrant : noISR Callable : yes

#### Returns:

```
♦ IX_TIMESYNCACC_SUCCESS – Operation is successful 
♦ IX_TIMESYNCACC_FAILED – Internal error occurred
```

#### **IxTimeSyncAccStatus** ixTimeSyncAccTickRateGet (UINT32 \* tickRate )

Gets the Tick Rate (Frequency Scaling Value) from the IEEE 1588 hardware assist block.

#### Parameters:

```
tickRate [out] - Current Tick Rate value in the IEEE 1588 block
```

This API will get the TickRate on IEE15588 block. Refer to **ixTimeSyncAccTickRateSet** for notes on usage of this value.

Reentrant : yesISR Callable : no

#### Returns:

- ♦ IX\_TIMESYNCACC\_SUCCESS Operation is successful
- ♦ IX\_TIMESYNCACC\_INVALIDPARAM Invalid parameters passed
- ♦ IX\_TIMESYNCACC\_FAILED Internal error occurred

#### **IxTimeSyncAccStatus** ixTimeSyncAccTickRateSet ( UINT32 tickRate )

Sets the Tick Rate (Frequency Scaling Value) in the IEEE 1588 hardware assist block.

#### Parameters:

```
tickRate [in] – Value to set Tick Rate
```

This API will set the Tick Rate (Frequency Scaling Value) in the IEEE 1588 block to the given value. The Accumulator register (not client visible) is incremented by this TickRate value every clock cycle. When the Accumulator overflows, the SystemTime is incremented by one. This TickValue can therefore be used to adjust the system timer.

Re-entrant : yesISR Callable : no

#### Returns:

```
♦ IX_TIMESYNCACC_SUCCESS – Operation is successful 
♦ IX_TIMESYNCACC_FAILED – Internal error occurred
```

# Intel (R) IXP400 Software Types (IxTypes)

Basic data types used by the IXP400 project.

# **Defines**

#define **OK** #define **ERROR** 

# **Typedefs**

typedef int(\* FUNCPTR )(void) typedef int STATUS

# **Detailed Description**

Basic data types used by the IXP400 project.

# Intel (R) IXP400 Software UART Access (IxUARTAcc) API

IXP400 UARTAcc Driver Public API.

### **Modules**

**Defines for Default Values** 

Default values which can be used for UART configuration.

**Defines for IOCTL Commands** 

IOCTL Commands (Request codes) which can be used with ixUARTIoctl.

**Defines for IOCTL** Arguments POSIX style IOCTL arguments which can be used with ixUARTIoctl.

### **Data Structures**

struct ixUARTDev Device descriptor for the UART.

struct **ixUARTDev** Device descriptor for the UART.

struct ixUARTStats Statistics for the UART.

struct ixUARTStats Statistics for the UART.

# **Enumerations**

# **Functions**

PUBLIC IX\_STATUS **ixUARTInit** (**ixUARTDev** \*pUART) Initialise the UART. This puts the chip in a quiescent state.

PUBLIC IX\_STATUS ixUARTPollOutput (ixUARTDev \*pUART, int outChar) Transmit a character in

PUBLIC IX\_STATUS **ixUARTPollInput** (**ixUARTDev** \*pUART, char \*inChar) *Receive a character in polled mode.* 

PUBLIC IX\_STATUS **ixUARTIoctl** (**ixUARTDev** \*pUART, int cmd, void \*arg) *Perform I/O control* routines on the device.

# **Detailed Description**

IXP400 UARTAcc Driver Public API.

# **Enumeration Type Documentation**

#### enum ixUARTMode

The mode to set to UART to.

#### **Enumeration values:**

INTERRUPT Interrupt mode – Not supported yet.POLLED Polled mode.LOOPBACK Loopback mode.

Definition at line 308 of file IxUART.h.

# **Function Documentation**

#### IX\_STATUS ixUARTInit ( ixUARTDev \* pUART )

Initialise the UART. This puts the chip in a quiescent state.

#### Parameters:

pUART ixUARTDev [in] – pointer to UART structure describing our device.

#### Precondition:

The base address for the UART must contain a valid value. Also the baud rate and hardware options must contain sensible values otherwise the defaults will be used as defined in ixUART.h

#### Postcondition:

UART is initialized and ready to send and receive data.

#### Note:

This function should only be called once per device.

#### Return values:

*IX\_SUCCESS* – UART device successfully

initialised.

*IX\_FAIL* – Critical error, device not

initialised.

```
IX_STATUS ixUARTIoctl ( ixUARTDev * pUART, int cmd, void * arg
```

Perform I/O control routines on the device.

#### Parameters:

pUART ixUARTDev [in] – pointer to UART structure describing our device.

*cmd* int [in] – an ioctl request code.

arg void\* [in] – optional argument used to set the device mode, baud rate, and hardware options.

#### Return values:

```
IX_SUCCESS – requested feature was set/read successfully.IX_FAIL – error setting/reading the requested feature.
```

#### See also:

#### **IoctlCommandDefines**

#### **IoctlArgDefines**

```
IX_STATUS ixUARTPollInput ( ixUARTDev * pUART, char * inChar
```

Receive a character in polled mode.

#### Parameters:

```
pUART ixUARTDev [in] – pointer to UART structure describing our device.*inChar char [in] – character read from the device.
```

#### Precondition:

UART device must be initialised.

#### Return values:

```
IX_SUCCESS – character was successfully read.IX_FAIL – input buffer empty (try again).
```

```
IX_STATUS ixUARTPollOutput ( ixUARTDev * pUART, int outChar )
```

Transmit a character in polled mode.

#### Parameters:

pUART ixUARTDev [out] – pointer to UART structure describing our device.outChar int [out] – character to transmit.

#### Precondition:

UART device must be initialised.

#### Return values:

*IX\_SUCCESS* – character was successfully

transmitted.

*IX\_FAIL* – output buffer is full (try again).

# **Defines for Default Values**

# [Intel (R) IXP400 Software UART Access (IxUARTAcc) API]

Default values which can be used for UART configuration.

### **Defines**

#### #define IX UART DEF OPTS

The default hardware options to set the UART to – no flow control, 8 bit word, 1 stop bit, no parity.

#### #define IX UART DEF XMIT

The default UART FIFO size – must be no bigger than 64.

#### #define IX UART DEF BAUD

*The default UART baud rate – 9600.* 

#### #define IX\_UART\_MIN\_BAUD

The minimum UART band rate - 9600.

#### #define IX\_UART\_MAX\_BAUD

*The maximum UART baud rate – 926100.* 

#### #define IX UART XTAL

The UART clock speed.

# **Detailed Description**

Default values which can be used for UART configuration.

See also:

ixUARTDev

# **Define Documentation**

#define IX\_UART\_DEF\_BAUD

The default UART band rate – 9600.

Definition at line 72 of file IxUART.h.

#define IX\_UART\_DEF\_OPTS

The default hardware options to set the UART to – no flow control, 8 bit word, 1 stop bit, no parity.

Definition at line **54** of file **IxUART.h**.

#### #define IX\_UART\_DEF\_XMIT

The default UART FIFO size – must be no bigger than 64.

Definition at line **63** of file **IxUART.h**.

#### #define IX\_UART\_MAX\_BAUD

The maximum UART baud rate – 926100.

Definition at line 90 of file IxUART.h.

#### #define IX\_UART\_MIN\_BAUD

The minimum UART baud rate – 9600.

Definition at line **81** of file **IxUART.h**.

#### #define IX\_UART\_XTAL

The UART clock speed.

Definition at line 99 of file IxUART.h.

# **Defines for IOCTL Commands**

### [Intel (R) IXP400 Software UART Access (IxUARTAcc) API]

IOCTL Commands (Request codes) which can be used with ixUARTIoctl.

### **Defines**

#define IX BAUD SET

Set the baud rate.

#define IX BAUD GET

Get the baud rate.

#define **IX\_MODE\_SET** 

*Set the UART mode of operation.* 

#define IX\_MODE\_GET

Get the current UART mode of operation.

#define IX OPTS SET

*Set the UART device options.* 

#define IX OPTS GET

Get the UART device options.

#define IX\_STATS\_GET

Get the UART statistics.

# **Detailed Description**

IOCTL Commands (Request codes) which can be used with **ixUARTIoctl**.

# **Define Documentation**

#define IX\_BAUD\_GET

Get the baud rate.

Definition at line 129 of file IxUART.h.

#define IX\_BAUD\_SET

Set the baud rate.

Definition at line 120 of file IxUART.h.

#### #define IX\_MODE\_GET

Get the current UART mode of operation.

Definition at line 145 of file IxUART.h.

#### #define IX\_MODE\_SET

Set the UART mode of operation.

Definition at line 136 of file IxUART.h.

#### #define IX\_OPTS\_GET

Get the UART device options.

Definition at line **163** of file **IxUART.h**.

#### #define IX\_OPTS\_SET

Set the UART device options.

Definition at line 154 of file IxUART.h.

#### #define IX\_STATS\_GET

Get the UART statistics.

Definition at line 172 of file IxUART.h.

# **Defines for IOCTL Arguments**

# [Intel (R) IXP400 Software UART Access (IxUARTAcc) API]

POSIX style IOCTL arguments which can be used with ixUARTIoctl.

### **Defines**

#define CLOCAL

Software flow control.

#define CREAD

Enable interrupt receiver.

#define CSIZE

Characters size.

#define CS5

5 bits

#define CS6

6 bits

#define CS7

7 bits

#define CS8

8 bits

#define STOPB

Send two stop bits (else one).

#define PARENB

Parity detection enabled (else disabled).

#define PARODD

Odd parity (else even).

# **Detailed Description**

POSIX style IOCTL arguments which can be used with **ixUARTIoctl**.

See also:

ixUARTMode

# **Define Documentation**

| #define CLOCAL                                          |
|---------------------------------------------------------|
| Software flow control.                                  |
| Definition at line 197 of file IxUART.h.                |
|                                                         |
| #define CREAD                                           |
| Enable interrupt receiver.                              |
| Definition at line <b>209</b> of file <b>IxUART.h</b> . |
| #define CS5                                             |
| 5 bits                                                  |
| Definition at line 233 of file IxUART.h.                |
| #define CS6                                             |
| 6 bits                                                  |
| Definition at line <b>245</b> of file <b>IxUART.h</b> . |
| #define CS7                                             |
| 7 bits                                                  |
| Definition at line <b>257</b> of file <b>IxUART.h</b> . |
| #define CS8                                             |
| 8 bits                                                  |
| Definition at line <b>269</b> of file <b>IxUART.h</b> . |
| #define CSIZE                                           |
| Characters size.                                        |

Define Documentation 502

Definition at line 221 of file IxUART.h.

#### #define PARENB

Parity detection enabled (else disabled).

Definition at line 290 of file IxUART.h.

### #define PARODD

Odd parity (else even).

Definition at line 302 of file IxUART.h.

#### #define STOPB

Send two stop bits (else one).

Definition at line 278 of file IxUART.h.

Define Documentation

503

# Intel (R) IXP400 Software Version ID (IxVersionId)

Version Identifiers.

### **Defines**

#### #define IX\_VERSION\_ID

Version Identifier String.

#### #define IX VERSION ADSL ID

This string will be updated with each customer release of the IXP400 ADSL driver package.

#### #define IX\_VERSION\_USBRNDIS\_ID

This string will be updated with each customer release of the IXP400 USB Client driver package.

#### #define IX\_VERSION\_I2C\_LINUX\_ID

This string will be updated with each customer release of the IXP400 I2C Linux\* driver package.

#### #define LINUX\_ETHERNET\_DRIVER\_PATCH\_ID

Linux\* Ethernet Driver Patch Version Identifier String.

#### #define LINUX\_INTEGRATION\_PATCH\_ID

Linux\* Integration Patch Version Identifier String.

#### #define LINUX\_ETHERNET\_README\_ID

*Linux\* Ethernet Readme version Identifier String.* 

#### #define LINUX\_INTEGRATION\_README\_ID

*Linux\* Integration Readme version Identifier String.* 

#### #define LINUX\_I2C\_DRIVER\_README\_ID

Linux\* I2C driver Readme version Identifier String.

#### #define IXP425\_ETH\_UPDATE\_NF\_BRIDGE\_ID

ixp400 eth update nf bridge.patch version Identifier String

#### #define IX\_VERSION\_INTERNAL\_ID

Internal Release Identifier String.

#### #define IX\_VERSION\_COMPATIBLE\_TORNADO

Compatible Tornado Version Identifier.

#### #define IX VERSION COMPATIBLE LINUX

Compatible Linux\* Version Identifier.

# **Detailed Description**

Version Identifiers.

# **Define Documentation**

#### #define IX VERSION ADSL ID

This string will be updated with each customer release of the IXP400 ADSL driver package.

Definition at line 36 of file IxVersionId.h.

#### #define IX\_VERSION\_COMPATIBLE\_LINUX

Compatible Linux\* Version Identifier.

Definition at line 113 of file IxVersionId.h.

#### #define IX\_VERSION\_COMPATIBLE\_TORNADO

Compatible Tornado Version Identifier.

Definition at line 108 of file IxVersionId.h.

#### #define IX\_VERSION\_I2C\_LINUX\_ID

This string will be updated with each customer release of the IXP400 I2C Linux\* driver package.

Definition at line **49** of file **IxVersionId.h**.

#### #define IX\_VERSION\_ID

Version Identifier String.

This string will be updated with each customer release of the IXP400 Software.

Definition at line **30** of file **IxVersionId.h**.

#### #define IX\_VERSION\_INTERNAL\_ID

Internal Release Identifier String.

This string will be updated with each internal release (SQA drop) of the IXP400 Software.

Definition at line 103 of file IxVersionId.h.

### #define IX\_VERSION\_USBRNDIS\_ID

This string will be updated with each customer release of the IXP400 USB Client driver package.

Definition at line **43** of file **IxVersionId.h**.

#### #define IXP425\_ETH\_UPDATE\_NF\_BRIDGE\_ID

ixp400\_eth\_update\_nf\_bridge.patch version Identifier String

This string will be updated with each release of ixp400\_eth\_update\_nf\_bridge. patch

Definition at line **95** of file **IxVersionId.h**.

#### #define LINUX ETHERNET DRIVER PATCH ID

Linux\* Ethernet Driver Patch Version Identifier String.

This string will be updated with each release of Linux\* Ethernet Patch

Definition at line **56** of file **IxVersionId.h**.

#### #define LINUX\_ETHERNET\_README\_ID

Linux\* Ethernet Readme version Identifier String.

This string will be updated with each release of Linux\* Ethernet Readme

Definition at line **70** of file **IxVersionId.h**.

#### #define LINUX\_I2C\_DRIVER\_README\_ID

Linux\* I2C driver Readme version Identifier String.

This string will be updated with each release of Linux\* I2C Driver Readme

Definition at line **85** of file **IxVersionId.h**.

#### #define LINUX\_INTEGRATION\_PATCH\_ID

Linux\* Integration Patch Version Identifier String.

This String will be updated with each release of Linux\* Integration Patch

Definition at line 63 of file IxVersionId.h.

### #define LINUX\_INTEGRATION\_README\_ID

Linux\* Integration Readme version Identifier String.

This string will be updated with each release of Linux\* Integration Readme

Definition at line 78 of file IxVersionId.h.

# Intel(R) IXP400 Software USB Driver Public API

Intel(R) IXP400 Software USB Driver Public API.

### **Data Structures**

struct USBDevice

USBDevice.

#### struct USBSetupPacket

Standard USB Setup packet components, see the USB Specification 1.1.

### **Defines**

#### #define IX\_USB\_MBLK

Memory buffer.

#### #define IX\_USB\_MBLK\_DATA(buf)

Return pointer to the data in the mbuf.

#### #define **IX\_USB\_MBLK\_LEN**(buf)

Return pointer to the data length.

#### #define IX\_USB\_MBLK\_FREE(buf)

#### #define **IX\_USB\_MBLK\_PKT\_LEN**(buf)

Return pointer to the total length of all the data in the mbuf chain for this packet.

#### #define IX\_USB\_HAS\_GET\_ERROR\_STRING

define to enable ixUSBErrorStringGet()

#### #define IX USB HAS ENDPOINT INFO SHOW

define to enable ixUSBEndpointInfoShow()

#### #define IX\_USB\_HAS\_STATISTICS\_SHOW

define to enable ixUSBStatisticsShow()

#### #define IX\_USB\_STATS\_SHOW\_PER\_ENDPOINT\_INFO

define to enable per-endpoint information in ixUSBStatisticsShow()

#### #define IX\_USB\_HAS\_VERBOSE\_WARN\_TRACE\_MACRO

define to enable verbose warning tracing

#### #define IX\_USB\_HAS\_CRITICAL\_DATA\_LOCKS

define to enable critical data sections locking

#define IX\_USB\_HAS\_ASSERT\_MACRO

#### define to enable assertion macro

#### #define IX\_USB\_HAS\_CT\_ASSERT\_MACRO

define to enable compile-time assertion macro

#### #define IX\_USB\_HAS\_INT\_BIND\_MACRO

define to enable interrupt handler binding for VxWorks

#### #define logMsg

#### #define UDC\_REGISTERS\_BASE

Base I/O address.

#### #define UDC IRQ

IRQ.

#### #define NUM ENDPOINTS

Number of endpoints.

#### #define **SETUP PACKET SIZE**

SETUP packet size.

#### #define CONTROL\_FIFO\_SIZE

CONTROL endpoint FIFO depth.

#### #define CONTROL PACKET SIZE

CONTROL endpoint packet size.

#### #define INTERRUPT FIFO SIZE

INTERRUPT endpoint FIFO depth.

#### #define INTERRUPT PACKET SIZE

INTERRUPT endpoint packet size.

#### #define BULK FIFO SIZE

BULK endpoint FIFO depth.

#### #define BULK\_PACKET\_SIZE

BULK endpoint packet size.

#### #define ISOCHRONOUS\_FIFO\_SIZE

ISOCHRONOUS endpoint FIFO depth.

#### #define ISOCHRONOUS\_PACKET\_SIZE

ISOCHRONOUS endpoint packet size.

#### #define MAX TRANSFER SIZE

Maximum data size for one transaction in bytes (bulk or control).

#### #define MAX QUEUE SIZE

Maximum outgoing queue size per endpoint, in elements Uses MAX\_QUEUE\_SIZE \* (sizeof(void \*)) bytes.

#### #define MEM POOL SIZE

Memory pool for data transactions.

#### #define TRANSACTION\_TIMEOUT\_RX

Maximum acceptable delay in transactions (timestamp ticks), Rx, 0 disables.

#### #define TRANSACTION TIMEOUT TX

Maximum acceptable delay in transactions (timestamp ticks), Tx, 0 disables.

#### #define IX\_USB\_ERROR\_BASE

USB error base.

#### #define IX USB ERROR

error due to unknown reasons

#### #define IX\_USB\_INVALID\_DEVICE

invalid USBDevice structure passed as parameter or no device present

#### #define IX USB NO PERMISSION

no permission for attempted operation

#### #define IX USB REDUNDANT

redundant operation

#### #define IX\_USB\_SEND\_QUEUE\_FULL

send queue full

#### #define IX\_USB\_NO\_ENDPOINT

invalid endpoint

#### #define IX\_USB\_NO\_IN\_CAPABILITY

no IN capability on endpoint

#### #define IX USB NO OUT CAPABILITY

no OUT capability on endpoint

#### #define IX USB NO TRANSFER CAPABILITY

transfer type incompatible with endpoint

#### #define IX\_USB\_ENDPOINT\_STALLED

endpoint stalled

#### #define IX\_USB\_INVALID\_PARMS

*invalid parameter(s)* 

### #define IX\_USB\_DEVICE\_DISABLED

device is disabled

#### #define IX\_USB\_NO\_STALL\_CAPABILITY

#### no STALL capability

#### #define **EP DIRECTION**(x)

*Macro used to extract the endpoint direction from an EPDescriptorTable[] entry.* 

#### #define **EP\_TYPE**(x)

*Macro used to extract the endpoint type from an EPDescriptorTable[] entry.* 

#### #define MIN(a, b)

Compares two values and returns the minimum.

#### #define MAX(a, b)

Compares two values and returns the maximum.

#### #define **QUEUE\_WRAP**(tail)

Ajusts the tail of a queue implemented in a circular buffer by wrapping at the buffer boundary.

#### #define **SWAP\_USB\_WORD**(wPtr)

USB byte swapping routine for a little endian platform.

#### #define **REG\_GET**(reg\_ptr)

read generic register access via register pointers

#### #define **REG\_SET**(reg\_ptr, val)

write generic register access via register pointers

#### #define **DREG GET**(reg ptr)

generic data register read access via register pointers

#### #define **DREG SET**(reg ptr, val)

generic data register write access via register pointers

#### #define **CONTEXT**(device)

get context from device pointer

#### #define **REGISTERS**(device)

get registers from device pointer

#### #define **EP0CONTROL**(device)

get endpoint 0 control data from device pointer

#### #define **EVENTS**(device)

get event processor from device pointer

#### #define **COUNTERS**(device)

get device counters

#### #define **OPERATION**(device)

get device operation

# #define **EPSTATUS**(device, endpointNumber) get endpoint status from device pointer and endpoint number

- #define **EPQUEUE**(device, endpointNumber)

  get endpoint queue from device pointer and endpoint number
- #define **EPCOUNTERS**(device, endpointNumber)
  get endpoint counters from device pointer and endpoint number
- #define **RETURN\_OK**(device)

  set IX\_SUCCESS on device and return IX\_SUCCESS
- #define **RETURN\_ERROR**(device)

  set IX\_USB\_ERROR on device and return IX\_FAIL
- #define **RETURN\_INVALID\_PARMS**(device)

  set IX\_USB\_INVALID\_PARAMS on device and return IX\_FAIL
- #define **RETURN\_REDUNDANT**(device)

  set IX\_USB\_REDUNDANT on device and return IX\_FAIL
- #define **RETURN\_INVALID\_DEVICE**(device)

  set IX\_USB\_INVALID\_PARAMS on device and return IX\_FAIL
- #define **RETURN\_NO\_ENDPOINT**(device)

  set IX\_USB\_INVALID\_PARAMS on device and return IX\_FAIL
- #define **RETURN\_ENDPOINT\_STALLED**(device)

  set IX\_USB\_ENDPOINT\_STALLED on device and return IX\_FAIL
- #define **RETURN\_SEND\_QUEUE\_FULL**(device)

  set IX\_USB\_SEND\_QUEUE\_FULL on device and return IX\_FAIL
- #define **RETURN\_NO\_IN\_CAPABILITY**(device)

  set IX\_USB\_NO\_IN\_CAPABILITY on device and return IX\_FAIL
- #define **RETURN\_NO\_STALL\_CAPABILITY**(device)

  set IX\_USB\_NO\_STALL\_CAPABILITY on device and return IX\_FAIL
- #define **RETURN\_NO\_PERMISSION**(device)

  set IX\_USB\_NO\_PERMISSION on device and return IX\_FAIL
- #define **CHECK\_DEVICE**(device)

  sanity checks for device existence
- #define **CHECK\_DEVICE\_ENABLED**(device) sanity checks for device enable status
- #define **CHECK\_ENDPOINT**(device, endpointNumber) sanity check for endpoint existence

```
#define CHECK_ENDPOINT_STALL(device, endpointNumber)
```

sanity check for endpoint stall

#### #define **CHECK EVENT MASK**(device, eventMask)

sanity check for event masks

#### #define CHECK\_ENDPOINT\_QUEUE(epData)

sanity check for endpoint queue size

#### #define CHECK\_ENDPOINT\_IN\_CAPABILITY(epData, device)

sanity check for endpoint IN capability

#### #define IX USB LOG DEVICE

#define IX USB TRACE(format, a, b, c, d, e, f)

no trace macro

#### #define IX USB LOCK

dummy critial data section lock

#### #define **IX\_USB\_UNLOCK**(state)

dummy critial data section unlock

#### #define IX\_USB\_IRQ\_LOCK

dummy irq lock

#### #define IX\_USB\_IRQ\_UNLOCK(state)

dummy irq unlock

#### #define **IX\_USB\_DRAIN\_FIFO**(registers)

#define USB\_CONTEXT\_SIZE

USB context size.

# **Typedefs**

```
typedef UINT16 USBEventSet
```

typedef void(\* USBEventCallback )(USBDevice \*device, USBEventSet events)

typedef void(\* USBSetupCallback )(USBDevice \*device, const char \*packet)

 $typedef\ void (*\ USBReceive Callback\ ) (USBDevice\ *device,\ UINT16\ source Endpoint,$ 

IX\_USB\_MBLK \*receiveBuffer)

# **Enumerations**

Typedefs 513

```
enum USBEndpointType {
      USB CONTROL,
      USB_BULK,
      USB_INTERRUPT,
      USB_ISOCHRONOUS
     Note: the values are set for compatibility with USBEndpointDirection.
enum USBEventMap {
      USB_NO_EVENT,
      USB_RESET,
      USB SUSPEND,
      USB_RESUME,
      USB_SOF,
      USB_DEVICE_EVENTS,
      USB_BUS_EVENTS,
      USB_ALL_EVENTS
     USB Event Map.
enum USBDeviceFlags {
     ENABLE RX SEQ.
      ENABLE_TX_SEQ,
      ENABLE_BULK_NAK_THROTTLE
     USB Device Flags.
enum USBEndpointNumber {
     ENDPOINT_0,
      ENDPOINT_1,
      ENDPOINT 2,
      ENDPOINT_3,
      ENDPOINT_4,
      ENDPOINT_5,
      ENDPOINT 6.
      ENDPOINT_7,
      ENDPOINT 8,
      ENDPOINT_9,
      ENDPOINT 10,
      ENDPOINT_11,
      ENDPOINT_12,
      ENDPOINT 13,
      ENDPOINT 14.
      ENDPOINT_15
     USB endpoint number.
enum USBStdRequestType {
      GET_STATUS_REQUEST,
```

Typedefs 514

```
CLEAR_FEATURE_REQUEST,
     SET_FEATURE_REQUEST,
     SET ADDRESS REQUEST,
     GET DESCRIPTOR REQUEST,
     SET DESCRIPTOR REQUEST.
     GET CONFIGURATION REQUEST,
     SET CONFIGURATION REQUEST.
     GET_INTERFACE_REQUEST,
     SET INTERFACE REQUEST,
     SYNCH_FRAME_REQUEST
    Standard USB request types.
enum USBStdDescriptorType {
     USB_DEVICE_DESCRIPTOR,
     USB_CONFIGURATION_DESCRIPTOR,
     USB STRING DESCRIPTOR,
     USB INTERFACE DESCRIPTOR,
     USB ENDPOINT DESCRIPTOR
    Standard USB descriptor types.
enum USBStdFeatureSelector {
     ENDPOINT STALL,
     DEVICE_REMOTE_WAKEUP
    Standard USB SET/CLEAR_FEATURE feature selector.
enum USBStdLanguageId { USB ENGLISH LANGUAGE }
    Standard language IDs used by USB.
enum USBStdEndpointType {
     USB CONTROL ENDPOINT,
     USB_ISOCHRONOUS_ENDPOINT,
     USB BULK ENDPOINT.
     USB_INTERRUPT_ENDPOINT
    Standard USB endpoint types.
enum USBStdEndpointDirection {
     USB ENDPOINT OUT,
     USB_ENDPOINT_IN
    Standard USB directions.
```

# **Functions**

PUBLIC void ixUSBDataSendAllow (USBDevice \*)

Functions 515

#### enable to send requests for USB\_IN endpoints

#### PUBLIC void ixUSBDataSendBlock (void)

#### PUBLIC IX STATUS ixUSBDriverInit (USBDevice \*device)

Initialize driver and USB Device Controller.

#### PUBLIC IX\_STATUS ixUSBDeviceEnable (USBDevice \*device, BOOL enableDevice)

Enable or disable the device.

## $PUBLIC\ IX\_STATUS\ \textbf{ixUSBEndpointStall}\ (\textbf{USBDevice}\ * device,\ UINT16\ endpointNumber,\ BOOL\ and\ an approximate the property of the p$

stallFlag)

Enable or disable endpoint stall (or halt feature).

### PUBLIC IX\_STATUS ixUSBEndpointClear (USBDevice \*device, UINT16 endpointNumber)

Free all Rx/Tx buffers associated with an endpoint.

#### PUBLIC IX\_STATUS ixUSBSignalResume (USBDevice \*device)

Trigger signal resuming on the bus.

#### PUBLIC IX\_STATUS ixUSBFrameCounterGet (USBDevice \*device, UINT16 \*counter)

Retrieve the 11-bit frame counter.

#### PUBLIC IX\_STATUS ixUSBReceiveCallbackRegister (USBDevice \*device, USBReceiveCallback

callbackFunction)

Register a data receive callback.

### $PUBLIC\ IX\_STATUS\ \textbf{ix} \textbf{USBSetupCallbackRegister}\ (\textbf{USBDevice}\ * \text{device},\ \textbf{USBSetupCallback}\$

callbackFunction)

Register a setup receive callback.

#### PUBLIC IX\_STATUS ixUSBBufferSubmit (USBDevice \*device, UINT16 destinationEndpoint,

IX USB MBLK \*sendBuffer)

Submit a buffer for transmit.

#### PUBLIC IX\_STATUS ixUSBBufferCancel (USBDevice \*device, UINT16 destinationEndpoint,

IX USB MBLK \*sendBuffer)

Cancel a buffer previously submitted for transmitting.

#### PUBLIC IX STATUS ixUSBEventCallbackRegister (USBDevice \*device, USBEventCallback

eventCallback, USBEventMap eventMap)

Register an event callback.

#### PUBLIC IX STATUS ixUSBIsEndpointStalled (USBDevice \*device, UINT16 endpointNumber, BOOL

\*stallState)

Retrieve an endpoint's stall status.

**PUBLIC** 

#### IX\_USB\_MBLK \* ixUSBBufferAlloc (size\_t size)

Allocates a buffer from the USB driver buffer pool.

### PUBLIC IX\_STATUS ixUSBStatisticsShow (USBDevice \*device)

Functions 516

Display device state and statistics.

#### PUBLIC const char \* ixUSBErrorStringGet (UINT32 errorCode)

Convert an error code into a human-readable string error message.

#### PUBLIC IX\_STATUS ixUSBEndpointInfoShow (USBDevice \*device)

Display endpoint information table.

#### void ixUSBMblkFree (IX USB MBLK \*)

Returns a buffer to the buffer pool.

# **Detailed Description**

Intel(R) IXP400 Software USB Driver Public API.

### **Define Documentation**

#### #define BULK\_FIFO\_SIZE

BULK endpoint FIFO depth.

Definition at line **61** of file **usbdeviceparam.h**.

#### #define BULK\_PACKET\_SIZE

BULK endpoint packet size.

Definition at line **64** of file **usbdeviceparam.h**.

#### #define CHECK\_DEVICE ( device )

sanity checks for device existence

Definition at line 237 of file usbmacros.h.

#### #define CHECK\_DEVICE\_ENABLED ( device )

sanity checks for device enable status

Definition at line 249 of file usbmacros.h.

```
#define CHECK_ENDPOINT ( device,
                              endpointNumber )
 sanity check for endpoint existence
 Definition at line 257 of file usbmacros.h.
#define CHECK_ENDPOINT_IN_CAPABILITY ( epData,
                                                device )
 sanity check for endpoint IN capability
 Definition at line 290 of file usbmacros.h.
#define CHECK_ENDPOINT_QUEUE ( epData )
 sanity check for endpoint queue size
 Definition at line 283 of file usbmacros.h.
#define CHECK_ENDPOINT_STALL ( device,
                                      endpointNumber )
 sanity check for endpoint stall
 Definition at line 264 of file usbmacros.h.
#define CHECK_EVENT_MASK ( device,
                                  eventMask )
 sanity check for event masks
 Definition at line 276 of file usbmacros.h.
#define CONTEXT ( device )
 get context from device pointer
 Definition at line 155 of file usbmacros.h.
#define CONTROL_FIFO_SIZE
```

```
CONTROL endpoint FIFO depth.
```

Definition at line **49** of file **usbdeviceparam.h**.

```
#define CONTROL_PACKET_SIZE
```

CONTROL endpoint packet size.

Definition at line **52** of file **usbdeviceparam.h**.

```
#define COUNTERS ( device )
```

get device counters

Definition at line 167 of file usbmacros.h.

```
#define DREG_GET ( reg_ptr )
```

generic data register read access via register pointers

Definition at line 128 of file usbmacros.h.

```
#define DREG_SET ( reg_ptr, val
```

generic data register write access via register pointers

Definition at line 130 of file usbmacros.h.

```
#define EP0CONTROL ( device )
```

get endpoint 0 control data from device pointer

Definition at line 161 of file usbmacros.h.

```
#define EP_DIRECTION (x)
```

Macro used to extract the endpoint direction from an EPDescriptorTable[] entry.

### Parameters:

x int (in) – the endpoint description entry

### Returns:

```
the endpoint direction (USB_IN, USB_OUT or USB_IN_OUT)
```

Definition at line 44 of file usbmacros.h.

```
#define EP_TYPE (x)
```

Macro used to extract the endpoint type from an EPDescriptorTable[] entry.

### Parameters:

```
x int (in) – the endpoint description entry
```

### Returns:

```
the endpoint type (USB_CONTROL, USB_BULK, USB_ISOCHRONOUS, USB_INTERRUPT)
```

Definition at line 56 of file usbmacros.h.

```
#define EPCOUNTERS ( device, endpointNumber )
```

get endpoint counters from device pointer and endpoint number

Definition at line 179 of file usbmacros.h.

```
#define EPQUEUE ( device, endpointNumber )
```

get endpoint queue from device pointer and endpoint number

Definition at line 176 of file usbmacros.h.

```
#define EPSTATUS ( device, endpointNumber )
```

get endpoint status from device pointer and endpoint number

Definition at line 173 of file usbmacros.h.

```
#define EVENTS ( device )
```

get event processor from device pointer

Definition at line **164** of file **usbmacros.h**.

### #define INTERRUPT\_FIFO\_SIZE

INTERRUPT endpoint FIFO depth.

Definition at line 55 of file usbdeviceparam.h.

### #define INTERRUPT\_PACKET\_SIZE

INTERRUPT endpoint packet size.

Definition at line **58** of file **usbdeviceparam.h**.

### #define ISOCHRONOUS\_FIFO\_SIZE

ISOCHRONOUS endpoint FIFO depth.

Definition at line **74** of file **usbdeviceparam.h**.

### #define ISOCHRONOUS\_PACKET\_SIZE

ISOCHRONOUS endpoint packet size.

Definition at line **77** of file **usbdeviceparam.h**.

### #define IX\_USB\_DEVICE\_DISABLED

device is disabled

Definition at line **69** of file **usberrors.h**.

### #define IX\_USB\_ENDPOINT\_STALLED

endpoint stalled

Definition at line **63** of file **usberrors.h**.

### #define IX\_USB\_ERROR

error due to unknown reasons

Definition at line **36** of file **usberrors.h**.

### #define IX\_USB\_ERROR\_BASE

USB error base.

Definition at line **32** of file **usberrors.h**.

### #define IX\_USB\_HAS\_ASSERT\_MACRO

define to enable assertion macro

Definition at line **99** of file **usbconfig.h**.

### #define IX\_USB\_HAS\_CRITICAL\_DATA\_LOCKS

define to enable critical data sections locking

Definition at line **94** of file **usbconfig.h**.

### #define IX\_USB\_HAS\_CT\_ASSERT\_MACRO

define to enable compile-time assertion macro

Definition at line 102 of file usbconfig.h.

### #define IX\_USB\_HAS\_ENDPOINT\_INFO\_SHOW

define to enable **ixUSBEndpointInfoShow**()

Definition at line **36** of file **usbconfig.h**.

### #define IX\_USB\_HAS\_GET\_ERROR\_STRING

define to enable ixUSBErrorStringGet()

Definition at line **33** of file **usbconfig.h**.

### #define IX\_USB\_HAS\_INT\_BIND\_MACRO

define to enable interrupt handler binding for VxWorks

Definition at line **105** of file **usbconfig.h**.

### #define IX\_USB\_HAS\_STATISTICS\_SHOW

define to enable ixUSBStatisticsShow()

Definition at line 42 of file usbconfig.h.

### #define IX\_USB\_HAS\_VERBOSE\_WARN\_TRACE\_MACRO

define to enable verbose warning tracing

Definition at line **88** of file **usbconfig.h**.

### #define IX\_USB\_INVALID\_DEVICE

invalid **USBDevice** structure passed as parameter or no device present

Definition at line **39** of file **usberrors.h**.

### #define IX\_USB\_INVALID\_PARMS

invalid parameter(s)

Definition at line **66** of file **usberrors.h**.

### #define IX\_USB\_IRQ\_LOCK

dummy irq lock

Definition at line 544 of file usbmacros.h.

### #define IX\_USB\_IRQ\_UNLOCK ( state )

dummy irq unlock

Definition at line **547** of file **usbmacros.h**.

### #define IX\_USB\_LOCK

dummy critial data section lock

Definition at line **538** of file **usbmacros.h**.

### #define IX USB MBLK

Memory buffer.

Definition at line 54 of file usbbasictypes.h.

### #define IX\_USB\_MBLK\_DATA (buf)

Return pointer to the data in the mbuf.

Definition at line **57** of file **usbbasictypes.h**.

### #define IX\_USB\_MBLK\_LEN ( buf )

Return pointer to the data length.

Definition at line **60** of file **usbbasictypes.h**.

### #define IX\_USB\_MBLK\_PKT\_LEN ( buf )

Return pointer to the total length of all the data in the mbuf chain for this packet.

Definition at line **67** of file **usbbasictypes.h**.

### #define IX\_USB\_NO\_ENDPOINT

invalid endpoint

Definition at line **51** of file **usberrors.h**.

### #define IX\_USB\_NO\_IN\_CAPABILITY

no IN capability on endpoint

Definition at line **54** of file **usberrors.h**.

### #define IX\_USB\_NO\_OUT\_CAPABILITY

no OUT capability on endpoint

Definition at line **57** of file **usberrors.h**.

### #define IX\_USB\_NO\_PERMISSION

no permission for attempted operation

Definition at line 42 of file usberrors.h.

### #define IX\_USB\_NO\_STALL\_CAPABILITY

no STALL capability

Definition at line **72** of file **usberrors.h**.

### #define IX\_USB\_NO\_TRANSFER\_CAPABILITY

transfer type incompatible with endpoint

Definition at line **60** of file **usberrors.h**.

### #define IX\_USB\_REDUNDANT

redundant operation

Definition at line **45** of file **usberrors.h**.

### #define IX\_USB\_SEND\_QUEUE\_FULL

send queue full

Definition at line **48** of file **usberrors.h**.

### #define IX\_USB\_STATS\_SHOW\_PER\_ENDPOINT\_INFO

 $\ define \ to \ enable \ per-endpoint \ in formation \ in \ ix USB Statistics Show ()$ 

Definition at line **64** of file **usbconfig.h**.

```
#define IX_USB_TRACE ( format,
```

a,

b,

c,

d,

e,

 $\mathbf{f}$ 

no trace macro

Definition at line 367 of file usbmacros.h.

```
#define IX_USB_UNLOCK ( state )
```

dummy critial data section unlock

Definition at line **541** of file **usbmacros.h**.

```
#define MAX ( a, b
```

Compares two values and returns the maximum.

### Parameters:

a – first value

b – second value

### Returns:

maximum of the two input values

Definition at line 85 of file usbmacros.h.

### #define MAX\_QUEUE\_SIZE

Maximum outgoing queue size per endpoint, in elements Uses MAX\_QUEUE\_SIZE \* (sizeof(void \*)) bytes.

Definition at line **39** of file **usbdriverparam.h**.

### #define MAX\_TRANSFER\_SIZE

Maximum data size for one transaction in bytes (bulk or control).

Definition at line 33 of file usbdriverparam.h.

### #define MEM\_POOL\_SIZE

Memory pool for data transactions.

Definition at line 42 of file usbdriverparam.h.

```
#define MIN (a, b)
```

Compares two values and returns the minimum.

### Parameters:

a – first value

b – second value

### Returns:

minimum of the two input values

Definition at line **70** of file **usbmacros.h**.

### #define NUM\_ENDPOINTS

Number of endpoints.

Definition at line 43 of file usbdeviceparam.h.

### #define OPERATION ( device )

get device operation

Definition at line 170 of file usbmacros.h.

### #define QUEUE\_WRAP ( tail )

Ajusts the tail of a queue implemented in a circular buffer by wrapping at the buffer boundary.

### Parameters:

tail int – virtual tail offset

### Returns:

the real adjusted tail offset

Definition at line 99 of file usbmacros.h.

### #define REG\_GET ( reg\_ptr )

read generic register access via register pointers

Definition at line 123 of file usbmacros.h.

```
#define REG_SET ( reg_ptr,
 write generic register access via register pointers
 Definition at line 125 of file usbmacros.h.
#define REGISTERS ( device )
 get registers from device pointer
 Definition at line 158 of file usbmacros.h.
#define RETURN_ENDPOINT_STALLED ( device )
 set IX_USB_ENDPOINT_STALLED on device and return IX_FAIL
 Definition at line 212 of file usbmacros.h.
#define RETURN_ERROR ( device )
 set IX_USB_ERROR on device and return IX_FAIL
 Definition at line 187 of file usbmacros.h.
#define RETURN_INVALID_DEVICE ( device )
 set IX_USB_INVALID_PARAMS on device and return IX_FAIL
 Definition at line 202 of file usbmacros.h.
#define RETURN_INVALID_PARMS ( device )
 set IX_USB_INVALID_PARAMS on device and return IX_FAIL
 Definition at line 192 of file usbmacros.h.
#define RETURN_NO_ENDPOINT ( device )
 set IX_USB_INVALID_PARAMS on device and return IX_FAIL
 Definition at line 207 of file usbmacros.h.
```

```
#define RETURN_NO_IN_CAPABILITY ( device )
 set IX_USB_NO_IN_CAPABILITY on device and return IX_FAIL
 Definition at line 222 of file usbmacros.h.
#define RETURN_NO_PERMISSION ( device )
 set IX_USB_NO_PERMISSION on device and return IX_FAIL
 Definition at line 232 of file usbmacros.h.
#define RETURN_NO_STALL_CAPABILITY ( device )
 set IX_USB_NO_STALL_CAPABILITY on device and return IX_FAIL
 Definition at line 227 of file usbmacros.h.
#define RETURN_OK ( device )
 set IX_SUCCESS on device and return IX_SUCCESS
 Definition at line 182 of file usbmacros.h.
#define RETURN_REDUNDANT ( device )
 set IX_USB_REDUNDANT on device and return IX_FAIL
 Definition at line 197 of file usbmacros.h.
#define RETURN_SEND_QUEUE_FULL ( device )
 set IX_USB_SEND_QUEUE_FULL on device and return IX_FAIL
 Definition at line 217 of file usbmacros.h.
#define SETUP_PACKET_SIZE
```

Detailed Description 529

SETUP packet size.

Definition at line **46** of file **usbdeviceparam.h**.

### #define SWAP\_USB\_WORD ( wPtr )

USB byte swapping routine for a little endian platform.

Definition at line 114 of file usbmacros.h.

### #define TRANSACTION\_TIMEOUT\_RX

Maximum acceptable delay in transactions (timestamp ticks), Rx, 0 disables.

Definition at line 45 of file usbdriverparam.h.

### #define TRANSACTION\_TIMEOUT\_TX

Maximum acceptable delay in transactions (timestamp ticks), Tx, 0 disables.

Definition at line **48** of file **usbdriverparam.h**.

### #define UDC\_IRQ

IRQ.

Definition at line 40 of file usbdeviceparam.h.

### #define UDC\_REGISTERS\_BASE

Base I/O address.

Definition at line **37** of file **usbdeviceparam.h**.

### #define USB\_CONTEXT\_SIZE

USB context size.

Definition at line **33** of file **usbtypes.h**.

# **Enumeration Type Documentation**

enum USBDeviceFlags

USB Device Flags.

Definition at line 72 of file usbconstants.h.

### enum USBEndpointDirection

USB endpoint direction.

Definition at line **33** of file **usbconstants.h**.

### enum USBEndpointNumber

USB endpoint number.

Definition at line **82** of file **usbconstants.h**.

### enum USBEndpointType

Note: the values are set for compatibility with USBEndpointDirection.

NB: THESE ARE NOT STANDARD USB ENDPOINT TYPES TO BE USED IN DESCRIPTORS, see usbstd.h

Definition at line 46 of file usbconstants.h.

### enum USBEventMap

USB Event Map.

### **Enumeration values:**

USB\_SOF Start Of Frame.

Definition at line **57** of file **usbconstants.h**.

### enum USBStdDescriptorType

Standard USB descriptor types.

Definition at line **54** of file **usbstd.h**.

### enum USBStdEndpointDirection

Standard USB directions.

Definition at line 94 of file usbstd.h.

```
enum USBStdEndpointType
```

Standard USB endpoint types.

Definition at line 83 of file usbstd.h.

### enum USBStdFeatureSelector

Standard USB SET/CLEAR\_FEATURE feature selector.

Definition at line **66** of file **usbstd.h**.

### enum USBStdLanguageId

Standard language IDs used by USB.

Definition at line **75** of file **usbstd.h**.

### enum USBStdRequestType

Standard USB request types.

Definition at line **36** of file **usbstd.h**.

# **Function Documentation**

```
PUBLIC IX_USB_MBLK * ixUSBBufferAlloc ( size_t size )
```

Allocates a buffer from the USB driver buffer pool.

### Parameters:

```
size size_t (in) - desired size, in bytes, of the buffer to be
allocated
```

### Returns:

a pointer to a newly allocated buffer or NULL if the allocation failed

```
PUBLIC IX_STATUS ixUSBBufferCancel ( USBDevice * device, UINT16 destinationEndpoint, IX_USB_MBLK * sendBuffer )
```

Cancel a buffer previously submitted for transmitting.

#### Parameters:

device USBDevice \* (in) – a structure identifying the device

destinationEndpoint UINT16 (in) - endpoint originally used for transmitting the data buffer

sendBuffer IX\_USB\_MBLK \* (in) – sumbitted data buffer

### Returns:

IX\_SUCCESS if the initialization was successful, IX\_FAIL otherwise, in which case a detailed error code will be set in the *lastError* field, unless the *device* parameter is NULL.

```
PUBLIC IX_STATUS ixUSBBufferSubmit ( USBDevice * device, UINT16 destinationEndpoint, IX_USB_MBLK * sendBuffer )
```

Submit a buffer for transmit.

### Parameters:

device USBDevice \* (in) – a structure identifying the device

destinationEndpoint UINT16 (in) - endpoint to be used for transmitting the data buffer

sendBuffer IX\_USB\_MBLK \* (in) – data buffer

### Returns:

IX\_SUCCESS if the initialization was successful, IX\_FAIL otherwise, in which case a detailed error code will be set in the *lastError* field, unless the *device* parameter is NULL.

```
PUBLIC void ixUSBDataSendAllow ( USBDevice * )
```

enable to send requests for USB\_IN endpoints

### Parameters:

*device* **USBDevice** \* (in) – a structure

identifying the device

### Returns:

none

```
PUBLIC IX_STATUS ixUSBDeviceEnable ( USBDevice * device, BOOL enableDevice )
```

Enable or disable the device.

### Parameters:

device USBDevice \* (in) – a structure identifying the device

enableDevice BOOL (in) - true to enable the device and false to disable it

This function enables or disables the device. A disabled device doesn't generate events and cannot send or receive data.

Disabling the device frees and discards all existent Rx/Tx buffers (received buffers that weren't dispatched yet and buffers waiting to be transmitted)

#### Returns:

IX\_SUCCESS if the initialization was successful, IX\_FAIL otherwise, in which case a detailed error code will be set in the *lastError* field, unless the *device* parameter is NULL.

### PUBLIC IX\_STATUS ixUSBDriverInit ( **USBDevice** \* device )

Initialize driver and USB Device Controller.

### Parameters:

device **USBDevice** \* (inout) – a structure identifying the device

This function initializes the UDC and all the data structures used to interact with the controller.

It is the responsibility of the caller to create the **USBDevice** structure and fill in the correct *baseIOAddress* and *interruptLevel* fields.

After successful initialization the device will be inactive – use **ixUSBDeviceEnable** to activate the device. Use the *flags* component of the *device* structure to pass in additional flags such as ENABLE\_RX\_SEQ or ENABLE\_TX\_SEQ. Changing these flags later will have no effect.

The driver will assign a device number which will be placed in the *deviceIndex* field.

The initialized *device* structure must be used for all interations with the USB controller. The same *device* pointer will be passed in to all the registered client callbacks.

The *deviceIndex* and *deviceContext* should be treated as read—only fields. A check to verify that the USB device is present is performed and a warning is issued if the device is not present.

### Warning:

This function is not reentrant.

### Returns:

IX\_SUCCESS if the initialization was successful; a warning is issued if the specified USB device is not present. IX\_FAIL otherwise,in which case a detailed error code will be set in the *lastError* field, unless the *device* parameter is NULL.

```
PUBLIC IX_STATUS ixUSBEndpointClear ( USBDevice * device, UINT16 endpointNumber )
```

Free all Rx/Tx buffers associated with an endpoint.

### Parameters:

```
device USBDevice * (in) – a structure identifying the device endpointNumber UINT16 (in) – endpoint number
```

This function discards and frees all Tx/Rx buffers associated with an endpoint. The corresponding endpoint dropped packet counters will also be incremented.

### Returns:

IX\_SUCCESS if the initialization was successful, IX\_FAIL otherwise, in which case a detailed error code will be set in the *lastError* field, unless the *device* parameter is NULL.

```
PUBLIC void ixUSBEndpointInfoShow ( USBDevice * device )
```

Display endpoint information table.

### Parameters:

*device* **USBDevice** \* (in) – a structure

identifying the device

### Returns:

none

```
PUBLIC IX_STATUS ixUSBEndpointStall ( USBDevice * device, UINT16 endpointNumber, BOOL stallFlag
```

Enable or disable endpoint stall (or *halt* feature).

### Parameters:

```
device USBDevice * (in) – a structure identifying the device
```

endpointNumber UINT16 (in) – endpoint number

stallFlag BOOL (in) – **true** to set endpoint stall and **false** to clear it

This function clears or sets the endpoint stall (or *halt*) feature.

Both IN and OUT endpoints can be stalled. A stalled endpoint will not send or receive data. Instead, it will send USB STALL packets in response to IN or OUT tokens.

Unstalling endpoints can be done only by using this function with the exception of endpoint 0 which unstalls itself automatically upon receiving a new SETUP packet, as required by the USB 1.1 Specification. Isochronous endpoints cannot be stalled and attempting to do so will return an IX USB NO STALL CAPABILITY failure.

### Returns:

IX\_SUCCESS if the initialization was successful, IX\_FAIL otherwise, in which case a detailed error code will be set in the *lastError* field, unless the *device* parameter is NULL.

```
PUBLIC const char * ixUSBErrorStringGet (UINT32 errorCode)
```

Convert an error code into a human–readable string error message.

#### Parameters:

# errorCode UINT32 (in) – erorr code as defined in **usberrors.h**

### Returns:

a const char \* pointer to the error message

```
PUBLIC IX_STATUS ixUSBEventCallbackRegister ( USBDevice * device, USBEventCallback eventCallback, USBEventMap eventMap )
```

Register an event callback.

### Parameters:

```
deviceUSBDevice * (in) – a structure identifying the deviceeventCallbackUSBEventCallback (in) – event callback functioneventMapUSBEventMap (in) – event map
```

### Returns:

IX\_SUCCESS if the initialization was successful, IX\_FAIL otherwise, in which case a detailed error code will be set in the *lastError* field, unless the *device* parameter is NULL.

```
PUBLIC IX_STATUS ixUSBFrameCounterGet ( USBDevice * device, UINT16 * counter )
```

Retrieve the 11-bit frame counter.

### Parameters:

```
device USBDevice * (in) – a structure identifying the device counter UINT16 * (out) – the 11–bit frame counter
```

This function returns the hardware USB frame counter.

Since the counter is 11-bit wide it rolls over after every 2048 frames.

### Returns:

IX\_SUCCESS if the initialization was successful, IX\_FAIL otherwise, in which case a detailed error code will be set in the *lastError* field, unless the *device* parameter is NULL.

```
PUBLIC IX_STATUS ixUSBIsEndpointStalled ( USBDevice * device, UINT16 endpointNumber, BOOL * stallState
```

Retrieve an endpoint's stall status.

### Parameters:

device USBDevice \* (in) – a structure identifying the device

endpointNumber UINT16 (in) - endpoint number

stallState BOOL \* (out) – stall state; **true** if the endpoint is stalled

(halted) or false otherwisetrue

### Returns:

IX\_SUCCESS or IX\_FAIL if the device pointer is invalid or the endpoint doesn't exist

```
void ixUSBMblkFree ( IX_USB_MBLK * )
```

Returns a buffer to the buffer pool.

```
PUBLIC IX_STATUS ixUSBReceiveCallbackRegister ( USBDevice * device, USBReceiveCallback callbackFunction )
```

Register a data receive callback.

#### Parameters:

device USBDevice \* (in) – a structure identifying the device callbackFunction USBReceiveCallback (in) – receive callback function

### Returns:

IX\_SUCCESS if the initialization was successful, IX\_FAIL otherwise, in which case a detailed error code will be set in the *lastError* field, unless the *device* parameter is NULL.

```
PUBLIC IX_STATUS ixUSBSetupCallbackRegister ( USBDevice * device, USBSetupCallback callbackFunction )
```

Register a setup receive callback.

### Parameters:

```
device USBDevice * (in) – a structure identifying the device callbackFunction USBSetupCallback (in) – setup callback function
```

### Returns:

IX\_SUCCESS if the initialization was successful, IX\_FAIL otherwise, in which case a detailed error code will be set in the *lastError* field, unless the *device* parameter is NULL.

```
PUBLIC IX_STATUS ixUSBSignalResume ( USBDevice * device )
```

Trigger signal resuming on the bus.

### Parameters:

device USBDevice \* (in) – a structure identifying the device

This function triggers signal resuming on the bus, waking up the USB host. Is should be used only if the host has enabled the device to do so using the standard SET\_FEATURE USB request, otherwise the function will return IX\_FAIL and set the *lastError* field to IX\_USB\_NO\_PERMISSION.

### Returns:

IX\_SUCCESS if the initialization was successful, IX\_FAIL otherwise, in which case a detailed error code will be set in the *lastError* field, unless the *device* parameter is NULL.

### PUBLIC IX\_STATUS ixUSBStatisticsShow ( **USBDevice** \* device )

Display device state and statistics.

### Parameters:

device USBDevice \* (in) – a structure identifying the device

### Returns:

IX\_SUCCESS if the initialization was successful, IX\_FAIL otherwise, in which case a detailed error code will be set in the *lastError* field, unless the *device* parameter is NULL.

# Intel (R) IXP400 Software Codelets

Intel (R) IXP400 Software Codelets.

### **Modules**

IXP400 ATM Codelet (IxAtmCodelet) API

This codelet demonstrates an example implementation of a working Atm driver that makes use of the AtmdAcc component, as well as demonstrating how the lower layer IxAtmdAcc component can be used for configuration and control.

# Intel (R) IXP400 Software DMA Access Codelet (IxDmaAccCodelet) API

Intel (R) IXP400 Software DMA Access component API.

Intel (R) IXP400 Software Ethenet Aal5 (IxEthAal5App) API Intel (R) IXP400 Software Ethernet Aal5 Codelet component API.

Intel (R) IXP400 Software Ethernet Access Codelet (IxEthAccCodelet) API Intel (R) IXP400 Software Ethernet Access Codelet API.

Intel (R) IXP400 Software HSS Access Codelet (IxHssAccCodelet) API Intel (R) IXP400 Software HSS Access Codelet API. The interface for the HSS Access Codelet.

Intel (R) IXP400 Software PerfProf Access Codelet (IxPerfProfAccCodelet) API Intel (R) IXP400 Software codelet PerfProf Access component API

Intel (R) IXP400 Software USB RNDIS Codelet (IxUSBRNDIS) API Intel (R) IXP400 Software codelet USB RNDIS API.

Intel (R) IXP400 Software Parity Error Notifier Access Codelet Intel (R) IXP400 Software Parity Error Notifier Access Codelet.

Intel (R) IXP400 Software Time Sync Access Codelet Intel (R) IXP400 Software Time Sync Access Codelet.

Intel (R) IXP400 Software Crypto Access Codelet (IxCryptoAccCodelet) API Intel (R) IXP400 Software Crypto Access Codelet API

# **Detailed Description**

Intel (R) IXP400 Software Codelets.

# IXP400 ATM Codelet (IxAtmCodelet) API

# [Intel (R) IXP400 Software Codelets]

This codelet demonstrates an example implementation of a working Atm driver that makes use of the AtmdAcc component, as well as demonstrating how the lower layer IxAtmdAcc component can be used for configuration and control.

# **Defines**

### #define IX\_ATM\_CODELET\_SWLOOPBACK\_PORT\_RATE

Port rate for Software Loopback.

### #define IX ATM CODELET REMOTELOOPBACK PORT RATE

Port rate for Remote Looopback.

### #define IX ATMCODELET START VPI

The first VPI value.

### #define IX\_ATMCODELET\_START\_VCI

*The first VCI value.* 

### #define IX\_ATMCODELET\_NUM\_AAL5\_CHANNELS

32 Channels for AAL5

### #define IX ATMCODELET NUM AALO 48 CHANNELS

32 Channels for AALO 48-bytes

### #define IX ATMCODELET NUM AALO 52 CHANNELS

32 Channels for AALO 52-bytes

### #define IX\_ATMCODELET\_QMGR\_DISPATCHER\_PRIORITY

Recommended priority of queue manager dispatch loop.

### #define IX\_ATMCODELET\_QMGR\_DISPATCHER\_THREAD\_STACK\_SIZE

Recommended stack size for queue manager dispatcher thread.

# **Functions**

PUBLIC IX\_STATUS ixAtmCodeletMain (IxAtmCodeletMode modeType, IxAtmCodeletAalType aalType)

*This function is used as a single point of execution for ATM codelet.* 

# **Detailed Description**

This codelet demonstrates an example implementation of a working Atm driver that makes use of the AtmdAcc component, as well as demonstrating how the lower layer IxAtmdAcc component can be used for configuration and control.

This codelet also demonstrates an example implementation of OAM F4 Segment, F4 End–To–End (ETE), F5 Segment and F5 ETE loopback that makes use of the AtmdAcc component, as well as demonstrating how the lower layer IxAtmdAcc component can be used for configuration and control.

### **Disclaimer Note:** For Linux\* Platform

- When 'insmod' the ATM codelet object, it will begin to send AAL packets and display the transmit and receive statistics every 15 second
- Unable to 'rmmod'. User will not be able to type anything in the command line due to: a) the return carriage indicating that the task is sending AAL packets, and b) the failure to kill the thread which is used to transmit AAL packets

### VxWorks\* User Guide

**ixAtmCodeletMain()** function is used as a single point of execution for Atm Codelet, which allows the user to enter selections for different type of modes and AAL type. The function also allows the user to execute OAM ping either in UTOPIA or Software Loopback mode. In all modes, the transmit and receive statistics will be displayed every 15secs.

### Linux\* User Guide

The idea of using the **ixAtmCodeletMain()** as a single point of execution for ATM codelet is similar in VxWorks\* User Guide. It also allows user to execute OAM ping. Similarly, all modes will display the transmit and receive statistics every 15secs. This function will be executed when user issue'insmod' in command prompt

 $2 = AAL0_48$  $3 = AAL0_52$ 

### Note for VxWorks\* and Unix\* Usage:

- IX\_ATM\_CODELET\_SWLOOPBACK\_PORT\_RATE and IX\_ATM\_CODELET\_REMOTELOOPBACK\_PORT\_RATE defined in this header file allows the user to change the port rate (in cells/sec) accordingly. The port rate works when using ADSL connection. The default port rate for both loopback is set to 1962cells/sec (~832kbps)
- IX\_ATMCODELET\_START\_VPI and IX\_ATMCODELET\_START\_VCI defined in this header file can be modified by the user. By default, VPI and VCI are set to 1 and 32 respectively
- IX\_ATMCODELET\_NUM\_AAL5\_CHANNELS, IX\_ATMCODELET\_NUM\_AAL0\_48\_CHANNELS, and IX\_ATMCODELET\_NUM\_AAL0\_52\_CHANNELS can be changed by the user. By default, they are set to 32 channels
- OAM Ping in UTOPIA Loopback mode will perform the following sequence in forever loop: i) Send AAL packets, ii) Display the transmit and receive statistics, and iii) Perform OAM Ping F4 and F5 (ETE and Segment) and display OAM statistics
- OAM Ping in Software Loopback will perform the following sequence in forever loop: i) Display the transmit and receive statistics, and ii) OAM Ping F4 and F5 (ETE and Segement) and display OAM Statistics

#### **ATM Features**

- An interface is provided to setup Aal5 or Aal0 (48 or 52 bytes) Transmit and Recieve VCs on one port. Only UBR VCs can be setup. When a channel is setup using this interface both a Transmit and a Recieve VC is created.
- An interface is provided to remove all registered Aal5/Aal0 VCs.
- Both remote and local loopback of Aal5 or Aal0 is provided by this codelet. Local loopback refers to loopback provided by the UTOPIA interface. In local loopback packets generated by the IXP400 are looped back to the Atm driver by the UTOPIA hardware. Software loopback refers to the software looping all packets received on the wire back out onto the wire. Remote loopback refers to where the far end is expected to performa a software loopback, i.e. any packets sent by the codelet are expected to be looped back by the far end into the codelet.
- Both interrupt and polled mode of operation is provided by this codelet.
- An interface is provided to send Aal5 SDUs specifying the sdu size and the number of Aal5 sdus to send.
- An interface is provided to send Aal0 packets specifying the packet size and the number of Aal0 packets to send.
- Both the Transmit port rate and the Recieve port rate can be modified. The Tx port rate is used by IxAtmSch in performing the shaping functions The Rx port rate is not used by any component.
- An interface is provided to allow the querying of the ATM ports and registered VCs.

### IXP400 ATM Components used by this codelet

• IxAtmdAcc. This component is the low level interface by which AAL packets get transmitted to, and received from the UTOPIA bus.

### IXP400 ATM Codelet components used by this codelet

- IxAtmSch. This component demonstrates an ATM Traffic Shaper implementation. IxAtmdAcc gets scheduling information from this component.
- IxAtmm. This component provides ATM port and VC management facilities. This component also manages the configuration of the UTOPIA co-processor

### **IxAtmCodelet modes of operation**

This codelet can be initialised to operate in one of three configurations.

• IX\_ATMCODELET\_UTOPIA\_LOOPBACK. In this mode the UTOPIA interface will loopback all traffic transmitted.

**Buffer management** In this mode a simple buffering mechanism is used; mbufs are allocated from the vxWorks pool as needed for RxFree replenishing/Tx and are returned to the vxWorks pool for TxDone/Rx

**Interrupt/Task based processing** In this mode of operation the IxQMgrDispatcher is hooked to interupts. This means that TxDone/RxLo will be perfored from a task level and IxAtmdAcc Tx processing/RxHi and RxFree will be precessed from an interrupt level.

**Sending Aal5 PDUs** In this mode of operation an interface is available to send Aal5 PDUs of specified size in bytes.

**Sending Aal0 Packets** In this mode of operation an interface is available to send Aal0 packets of specified size in cells.

- IX\_ATMCODELET\_REMOTE\_LOOPBACK. In this mode packets are sent and are expected to be looped back on the remote end.
- IX\_ATMCODELET\_SOFTWARE\_LOOPBACK. In this mode of operation all traffic sent are looped back to receive in the IXP400 device.

**Buffer management** In this mode a more complex buffering mechanism is used; mbufs are allocated from the vxWorks pool and stored in a software queue. These mbufs are fetched from this software queue as needed for RxFree replenishing/Tx and are returned to the software queue for TxDone/Rx.

**Interrupt/Task based processing** In this mode of operation the IxQMgrDispatcher is called form a task every 1 msec. This means that TxDone/RxLo/IxAtmdAcc Tx processing/RxHi and RxFree will be processed from a task level.

**Sending PDUs/Packets** This mode of operation does not provide an interface for sending Aal5 PDUs/Aal0 Packets.

### **IxAtmCodelet sub-components**



**AtmCodelet** This implements the API functions.

**RxTx** This sub–component implements the IX\_ATMCODELET\_UTOPIA\_LOOPBACK and IX\_ATMCODELET\_REMOTE\_LOOPBACK modes of operation.

**SwLoopback** This sub–component implements the IX\_ATMCODELET\_SOFTWARE\_LOOPBACK mode operation.

**BufMan** This sub–component implements the intefaces used internally for getting and returning vxWorks mbufs.

**UTOPIA Recieve and Transmit PHY addresses** In this codelet UTOPIA Phy Addresses are assigned numbers starting at UTOPIA\_PHY\_ADDR and are incremented for each port used. These addresses \_WILL\_ need to be changed depending on the hardware setup.

### **OAM Features**

- An interface is provided to configure the access layer to enable OAM traffic.
- OAM Loopback responses are sent automatically on receipt of OAM F4 and F5 parent Segment and ETE loopback cells, i.e. externally initiated OAM Loopbacks.
- Interfaces are provided to initiate an OAM F4/F5 Segment or ETE Loopback, see ITU-610. One loopback can be initiated at a time, this is to keep the codelet simple, this is independant of sending responses to parent loopback cells received.
- An interface is provided to query OAM traffic statistics.

### OAM uses the following IXP400 ATM Components

- IxAtmdAcc. This component is the low level interface by which OAM cells get transmitted to, and received from the UTOPIA bus.
- IxAtmm. This component provides ATM port and VC management facilities. This component also contains the configuration of the UTOPIA co-processor.
- AtmUtils. This codelet provides VC setup facilities using IxAtmdAcc.

### **IMPORTANT!!!**

If validation board is used (instead of using IXDP400 development board), then uncomment VALIDATION\_PLATFORM\_USED flag in component.mk

# **Define Documentation**

### #define IX\_ATM\_CODELET\_REMOTELOOPBACK\_PORT\_RATE

Port rate for Remote Looopback.

By default the port rate for remote loopback is set at PCR = 1962 cells/sec (832kbps)

Definition at line **305** of file **IxAtmCodelet.h**.

### #define IX\_ATM\_CODELET\_SWLOOPBACK\_PORT\_RATE

Port rate for Software Loopback.

By default the port rate for software loopback is set at PCR = 1962 cells/sec (832kbps)

Definition at line 292 of file IxAtmCodelet.h.

### #define IX\_ATMCODELET\_NUM\_AAL0\_48\_CHANNELS

32 Channels for AAL0 48-bytes

Definition at line **345** of file **IxAtmCodelet.h**.

### #define IX\_ATMCODELET\_NUM\_AAL0\_52\_CHANNELS

32 Channels for AAL0 52–bytes

Definition at line **354** of file **IxAtmCodelet.h**.

### #define IX\_ATMCODELET\_NUM\_AAL5\_CHANNELS

32 Channels for AAL5

Definition at line 336 of file IxAtmCodelet.h.

### #define IX\_ATMCODELET\_QMGR\_DISPATCHER\_PRIORITY

Recommended priority of queue manager dispatch loop.

Definition at line **364** of file **IxAtmCodelet.h**.

Define Documentation 546

### #define IX\_ATMCODELET\_QMGR\_DISPATCHER\_THREAD\_STACK\_SIZE

Recommended stack size for queue manager dispatcher thread.

Definition at line **374** of file **IxAtmCodelet.h**.

### #define IX\_ATMCODELET\_START\_VCI

The first VCI value.

By default the VCI is set to 2

Definition at line **327** of file **IxAtmCodelet.h**.

### #define IX\_ATMCODELET\_START\_VPI

The first VPI value.

By default the VPI is set to 1

Definition at line 316 of file IxAtmCodelet.h.

## **Function Documentation**

This function is used as a single point of execution for ATM codelet.

### Parameters:

IxAtmCodeletMode modeType The type of mode use, either Utopia, Software or Remote loopback mode. It also consists of OAM Ping in Utopia or Software loopback

mode.

*IxAtmCodeletAalType* 

aalType

The type of AAL: AAL5 or AAL0 with 48– or 52–bytes cell

### Returns:

IX\_SUCCESS Mode and AAL type successfully setup IX\_FAIL Invalid AAL or mode type, or error in setting up the modes

# Intel (R) IXP400 Software DMA Access Codelet (IxDmaAccCodelet) API

[Intel (R) IXP400 Software Codelets]

Intel (R) IXP400 Software DMA Access component API.

### **Defines**

#define IX DMA CODELET TRANSFER LENGTH

The length of the transfer size if 128 bytes.

# **Functions**

IX STATUS ixDmaAccCodeletMain (void)

This function is the entry point to the Dma Access codelet. It will initialise the Dma codelet which in turn initialises the necessary components.

# **Detailed Description**

Intel (R) IXP400 Software DMA Access component API.

This file contains a main interface of the Dma Access Codelet that initialises the DmaAcc codelet and execute Dma transfer using **ixDmaAccCodeletTestPerform()** function for various DMA transfer mode, addressing mode and transfer width. The block size used in this codelet are 8,1024,16384,32768,65528 bytes. For each Dma configuration, the performance will be measured and the average rate (in Mbps) will be displayed

### VxWorks\* User Guide

```
Usage :
    -> ixDmaAccCodeletMain()

Note:
1. Once the function is executed, the codelet will display the results

2. The formulae to calculate the rate is:

Rate (in Mbps) = ( (length * 8) / (ticks / 66) )
```

### Linux\* User Guide

Intel (R) IXP400 Software DMA Access Codelet (IxDmaAccCodelet) API [Intel (R) IXP400 Software DMA Access Codelet

```
Usage :
    # insmod ixp400_codelets_dmaAcc.o

Note:

1. Once the function is executed, the codelet will display the results

2. The formulae to calculate the rate is:

Rate (in Mbps) = ( (length * 8) / (ticks / 66) )
```

#### **DmaAcc Codelet Features**

The API **ixDmaAccCodeletTestPerform**() allows the user to perform a Dma transfer of block size 0 to 65535 bytes between two locations in the SRAM. The user can specify any combination of the following modes.

DMA Transfer Modes 1. Copy 2. Copy and Clear Source 3. Copy with Bytes Swap 4. Copy with Bytes Reversed

DMA Addressing Modes 1. Incremental Source to Incremental Destination Addressess 2. Fixed Source to Incremental Destination Addressess 3. Incremental Source to Fixed Destination Addressess

DMA Transfer Widths 1. 32-bit Transfer 2. 16-bit Transfer 3. 8-bit Transfer 4. Burst Transfer

NOTE: The user must initialise the system with ixDmaAccCodeletInit prior to calling the function ixDmaAccCodeletiTestPerform()

Performance will execute PERFORMANCE\_NUM\_LOOP (i.e. 100 runs) in order to calculate the average rate for each Dma transfer configuration

# **Define Documentation**

### #define IX\_DMA\_CODELET\_TRANSFER\_LENGTH

The length of the transfer size if 128 bytes.

It can be changed for Dma transfer. The range is between 1-65535 bytes

Definition at line 113 of file IxDmaAccCodelet.h.

Define Documentation 549

# **Function Documentation**

void ixDmaAccCodeletMain (void)

This function is the entry point to the Dma Access codelet. It will initialise the Dma codelet which in turn initialises the necessary components.

Once it has successfully initialise the Dma Codelet, this function will continue to perform valid DMA transfer using IxDmaAccCodeletTestPerform()

Parameters:

none

Returns:

none

# Intel (R) IXP400 Software Ethenet Aal5 (IxEthAal5App) API

# [Intel (R) IXP400 Software Codelets]

Intel (R) IXP400 Software Ethernet Aal5 Codelet component API.

### **Defines**

### #define IX\_EAA\_NUM\_BUFFERS\_PER\_ETH

This is the number of buffers, which can be stored in free buffer queue for each ethernet port.

### #define IX EAA NUM ATM PORTS

Define number of supported atm ports by this application.

### #define IX EAA NUM ATM VCS

Define number of supported atm VCs by this application.

### #define IX\_EAA\_NUM\_BUFFERS\_PER\_VC

This is the number of buffers per atm port.

### #define IX EAA VC1 VPI

Define default VPI for VC1.

### #define IX\_EAA\_VC2\_VPI

Define default VPI for VC2.

### #define IX EAA VC3 VPI

Define default VPI for VC3.

### #define IX EAA VC4 VPI

Define default VPI for VC4.

### #define IX EAA VC5 VPI

Define default VPI for VC5.

### #define IX\_EAA\_VC6\_VPI

Define default VPI for VC6.

### #define IX\_EAA\_VC7\_VPI

Define default VPI for VC7.

### #define IX EAA VC8 VPI

Define default VPI for VC8.

### #define IX\_EAA\_VC1\_VCI

Define default VCI for VC1.

### #define IX\_EAA\_VC2\_VCI

Define default VCI for VC2.

### #define IX\_EAA\_VC3\_VCI

Define default VCI for VC3.

### #define IX EAA VC4 VCI

Define default VCI for VC4.

### #define IX EAA VC5 VCI

Define default VCI for VC5.

### #define IX\_EAA\_VC6\_VCI

Define default VCI for VC6.

### #define IX EAA VC7 VCI

Define default VCI for VC7.

### #define IX\_EAA\_VC8\_VCI

Define default VCI for VC8.

### #define IX\_EAA\_MAC1

Define default for MAC1 address for ixEAAAddMac() function.

### #define IX EAA MAC2

Define default for MAC2 address for ixEAAAddMac() function.

### #define IX\_EAA\_MAC3

Define default for MAC3 address for ixEAAAddMac() function.

### #define IX EAA MAC4

Define default for MAC4 address for ixEAAAddMac() function.

### #define IX EAA MAC5

Define default for MAC5 address for ixEAAAddMac() function.

### #define IX EAA MAC6

Define default for MAC6 address for ixEAAAddMac() function.

### #define IX EAA PORTO

Define default for Port number for ixEAAAddMac() function.

### #define IX\_ETHAAL5APP\_THREAD\_PRI\_MEDIUM

Define medium thread priority for ixEAAPollTask() function.

## **Functions**

**PUBLIC** 

IX\_STATUS ixEthAal5AppCodeletMain (IxEAAModeType modeType)

This is the main function that executes the EthAal5App codelet.

# **Detailed Description**

Intel (R) IXP400 Software Ethernet Aal5 Codelet component API.

IxEthAal5App application is also called as IXP4XX Mini Bridge application which bridges traffic between Ethernet and Utopia ports or Ethernet and ADSL ports. It uses ixEthAcc,ixAtmdAcc, ixAtmm, ixAtmSch and ixQmgr software components.

### VxWorks User Guide

**ixEthAal5AppCodeletMain()** function is used as a single point of execution for EthAal5 Codelet, which allows the user to enter in 2 type of modes: Utopia or ADSL, in order to operate together with ethernet.

```
Usage :
    ixEthAal5AppCodeletMain (modeType)
        modeType:
        1 = Utopia
        2 = ADSL
```

### Linux\* User Guide

**ixEthAal5AppCodeletMain()** function is used as a single point of execution for EthAal5 Codelet, which allows the user to enter in 2 type of modes: Utopia or ADSL, in order to operate together with ethernet.

Note for VxWorks\* and Linux\* Usage: In order to observe the current traffic counters, the ixEAAShow() function is executed every 15seconds. This applys to both Utopia and ADSL mode.

### **Features**

This codelet currently supports 2 Ethernet ports and up to 8VCs per 8 Utopia phys (MPHY mode) or up to 8VCs per Utopia phy (SPHY mode), which will be initialized at the start of application. In SPHY mode, the codelet sets up 1 VC per UTOPIA phy by default. The codelet is also capable to configure up to 32VCs (see "How to Setup 32VCs" section)

Ethernet frames are transferred across ATM link (through Utopia interface) using AAL5 protocol and Ethernet frame encapsulation described by RFC 1483. MAC address learning is performed on Ethernet frames, received by Ethernet ports and ATM interface (encapsulated). Application filters packets base on destination MAC addresses – packets are forwarded to other port only if the port has ever received packet/frame with the same source MAC address. Forwarding is done only between Ethernet and Utopia port.

Functions 553

Several simplifications were made to keep code simple:

- Application doesn't allow packet forwarding between Ethernet ports (nor Utopia ports).
- flooding (forwarding frames/packets with unknown MAC addresses) is not supported. Two IxEthAal5App will never transfer any packets between each other, because initialy MAC data base is empty, so all packets will be filtered out. However there is function ixEAAAddMAC which can be used to add MAC address to the data base and assign it to one of available ports. To enable simplified flooding see comments in ixEAAEthRxCallback.
- This application can not be executed more than once. It doesn't deinitialize itself. If user wishes to change configuration and run application again the whole system (vxWorks\*) must be restarted.
- currently Mac Learning/Filtering database in ixEthAcc component supports only Ethernet ports. For that reason it couldn't be used in this application for learning Mac addresses from encapsulated Ethernet frames received from Utopia. In the near future ixEthAcc component will support all possible ports (including Utopia), but by this time a very simplified approach is used in this application: only one Mac address is stored per VC (and there is one VC per Phy). It means, that only one Mac address is supported simultaneously per Phy. This is done to keep code as simple as possible.
- This application provides two choices of connection: DSL or UTOPIA. DSL will be established (modeType = 2) if the DSL card is attached to the IXDP4XX board
- 2 protocols from RFC 1483 are recognized: The first packet received from ATM will decide the behaviour of the application (ether bridged or routed)

#### **How to Setup 32VC**

In order to setup 32VCs there are several steps involved: 1) Change the IX\_EAA\_NUM\_ATM\_VCS to 32 2) In ixEAASetupVc function,

- ♦ Change the configuration of each VC, i.e. which VC setup what what type of QoS and its parameters
- ♦ Add more VPI and VCI values to the atmVpi and atmVci variables respectively

#### **From RFC 1483**

VC Based Multiplexing of Routed Protocols

PDUs of routed protocols shall be carried as such in the Payload of the AAL5 CPCS-PDU. The format of the AAL5 CPCS-PDU Payload field thus becomes:



VC Based Multiplexing of Bridged Protocols

PDUs of bridged protocols shall be carried in the Payload of the AAL5 CPCS-PDU.



Functions 554

EthAal5App Codelet Data flow is illustrated in the diagram below:



Configuration Example 1: Using Smartbit and Adtech with UTOPIA connection

+----+ +-----+ +-----+

Functions 555

```
| Smartbits | <----> | (Eth) IXP4XX (Utopia) | <----> | Adtech |
```

On smartbits set: dst. mac = MAC1 and src mac = MAC2 On Adtech add AAL5 with eth. encapsulation, dst. mac = MAC2, src. mac = MAC1

Dependently which Phy is used Adtech must use same VPI/VCI address as assigned to Phy by ethAal5App. By default there are 8 pre–configured VCs with default VPI and VCI values: VPI/VCI = 10/63 VPI/VCI = 10/91 VPI/VCI = 10/92 VPI/VCI = 10/93 VPI/VCI = 10/94 VPI/VCI = 10/95 VPI/VCI = 10/96

Configuration Example 2: Using Smartbits/PCs with ADSL connection



The ADSL connection is enabled by the codelet when the modeType=2 and it is operating on SPHY mode.

```
On smartbits1 set: dst. mac = MAC1 and src mac = MAC2
On smartbits2 set: dst. mac = MAC2 and src mac = MAC1
```

Configuration Example 3: Using DSLAM and Adtech with ADSL connection



The VPI and VCI value is similar to Configuration Example 1. Ensure that either the DSLAM matches the EthAal5App codelet's VPI/VCI default values or the EthAal5App matches the DSLAM's VPI/VCI default values.

By default, the codelet is setup to 1VC per ATM port (SPHY). In order to setup 8VC, please change the following: #define IX\_EAA\_NUM\_ATM\_VCS 32

On the Adtech, setup Eth frame type II for the AX4000 Eth card and configure the destination and source MAC address accordingly. For example the frame contains: Dest MAC Address = 00:00:00:00:00:03:01 Src MAC Address: 00:00:00:00:02:01 Repeat this for all of the 8VCs Also specify the frame size

## **Define Documentation**

#define IX\_EAA\_MAC1

Define default for MAC1 address for ixEAAAddMac() function.

Definition at line 454 of file IxEthAal5App.h.

#### #define IX\_EAA\_MAC2

Define default for MAC2 address for ixEAAAddMac() function.

Definition at line 460 of file IxEthAal5App.h.

#### #define IX\_EAA\_MAC3

Define default for MAC3 address for ixEAAAddMac() function.

Definition at line 466 of file IxEthAal5App.h.

#### #define IX\_EAA\_MAC4

Define default for MAC4 address for ixEAAAddMac() function.

Definition at line **472** of file **IxEthAal5App.h**.

#### #define IX\_EAA\_MAC5

Define default for MAC5 address for ixEAAAddMac() function.

Definition at line 479 of file IxEthAal5App.h.

#### #define IX\_EAA\_MAC6

Define default for MAC6 address for ixEAAAddMac() function.

Definition at line **485** of file **IxEthAal5App.h**.

#### #define IX\_EAA\_NUM\_ATM\_PORTS

Define number of supported atm ports by this application.

User can define them in EthAal5User.h file to overwrite definitions below

Definition at line 320 of file IxEthAal5App.h.

#### #define IX\_EAA\_NUM\_ATM\_VCS

Define number of supported atm VCs by this application.

User can define them in EthAal5User.h file to overwrite definitions below

Definition at line 336 of file IxEthAal5App.h.

#### #define IX\_EAA\_NUM\_BUFFERS\_PER\_ETH

This is the number of buffers, which can be stored in free buffer queue for each ethernet port.

Definition at line **305** of file **IxEthAal5App.h**.

#### #define IX\_EAA\_NUM\_BUFFERS\_PER\_VC

This is the number of buffers per atm port.

User can define them in EthAal5User.h file to overwrite definitions below

Definition at line 349 of file IxEthAal5App.h.

#### #define IX\_EAA\_PORT0

Define default for Port number for ixEAAAddMac() function.

Definition at line **491** of file **IxEthAal5App.h**.

#### #define IX\_EAA\_VC1\_VCI

Define default VCI for VC1.

Definition at line **405** of file **IxEthAal5App.h**.

#### #define IX\_EAA\_VC1\_VPI

Define default VPI for VC1.

Definition at line **356** of file **IxEthAal5App.h**.

#### #define IX\_EAA\_VC2\_VCI

Define default VCI for VC2.

Definition at line 411 of file IxEthAal5App.h.

#define IX\_EAA\_VC2\_VPI

Define default VPI for VC2.

Definition at line 363 of file IxEthAal5App.h.

#define IX\_EAA\_VC3\_VCI

Define default VCI for VC3.

Definition at line 417 of file IxEthAal5App.h.

#define IX\_EAA\_VC3\_VPI

Define default VPI for VC3.

Definition at line **369** of file **IxEthAal5App.h**.

#define IX\_EAA\_VC4\_VCI

Define default VCI for VC4.

Definition at line 423 of file IxEthAal5App.h.

#define IX\_EAA\_VC4\_VPI

Define default VPI for VC4.

Definition at line **375** of file **IxEthAal5App.h**.

#define IX\_EAA\_VC5\_VCI

Define default VCI for VC5.

Definition at line 429 of file IxEthAal5App.h.

#define IX\_EAA\_VC5\_VPI

Define default VPI for VC5.

Definition at line **381** of file **IxEthAal5App.h**.

#### #define IX\_EAA\_VC6\_VCI

Define default VCI for VC6.

Definition at line 435 of file IxEthAal5App.h.

#### #define IX\_EAA\_VC6\_VPI

Define default VPI for VC6.

Definition at line 387 of file IxEthAal5App.h.

#### #define IX\_EAA\_VC7\_VCI

Define default VCI for VC7.

Definition at line **441** of file **IxEthAal5App.h**.

#### #define IX\_EAA\_VC7\_VPI

Define default VPI for VC7.

Definition at line 393 of file IxEthAal5App.h.

#### #define IX\_EAA\_VC8\_VCI

Define default VCI for VC8.

Definition at line **447** of file **IxEthAal5App.h**.

### #define IX\_EAA\_VC8\_VPI

Define default VPI for VC8.

Definition at line 399 of file IxEthAal5App.h.

#### #define IX\_ETHAAL5APP\_THREAD\_PRI\_MEDIUM

Define medium thread priority for ixEAAPollTask() function.

Definition at line 498 of file IxEthAal5App.h.

## **Function Documentation**

```
ixEthAal5AppCodeletMain ( IxEAAModeType modeType )
```

This is the main function that executes the EthAal5App codelet.

It first calls IxEAAMain() function which initialize the MAC database, to be an in valid Mac addresses (i.e. contain 0xffs), QMGR, NpeMh, Eth phys

• 100Mbit, FULL DUPLEX, NO AUTONEGOTIATION (User can change those settings accordingly to required configuration), ATM, and Utopia interface.

If Linux\* is used, use interrupt mode – much faster under Linux\* than polling

If vxWorks\* is used use poll mode – much faster under vxWorks\* than interrupts and start background QMgr queues poll

After which the main has been called, this **ixEthAal5AppCodeletMain**() function will add the MAC address using ixEAAAddMAC() function. For a single PHY utopia mode, only one port will be setup a single MAC address. However, if multiple phy is used, 8 ports will be setup and each port is assigned with a unique MAC addresses.

For single utopia phy. The following is setup using ixEAAAddMAC() function

For multi phy utopia the port number and MAC6 increments using a for-loop

Lastly, **ixEthAal5AppCodeletMain()** creates a thread which purposed to display the EthAal5App codelet counter every 15secs

Function Documentation 561

# Intel (R) IXP400 Software Ethernet Access Codelet (IxEthAccCodelet) API

[Intel (R) IXP400 Software Codelets]

Intel (R) IXP400 Software Ethernet Access Codelet API.

## **Defines**

#### #define IX\_ETHACC\_CODELET\_NPEB\_MAC

Hard-encoded MAC address for NPEB.

## #define IX\_ETHACC\_CODELET\_NPEA\_MAC

#define IX\_ETHACC\_CODELET\_NPEC\_MAC

Hard-encoded MAC address for NPEC.

#### #define IX\_ETHACC\_CODELET\_RX\_MBUF\_POOL\_SIZE

Size of receive MBuf pool.

#### #define IX ETHACC CODELET TX MBUF POOL SIZE

Size of transmit MBuf pool.

#### #define IX ETHACC CODELET MAX PORT

*Number of Ethernet Ports supported for this codelet.* 

#### #define IX ETHACC CODELET MBUF POOL SIZE

Size of MBuf pool.

#### #define IX ETHACC CODELET PCK SIZE

Size of MBuf packet (recommaended size for ethAcc component).

#### #define IX\_ETHACC\_CODELET\_PCK\_LEN

Length of MBuf payload (in bytes).

#### ${\tt \#define\ IX\_ETHACC\_CODELET\_MBUF\_DATA\_POOL\_SIZE}$

Size of MBuf data pool.

#### #define IX\_ETHACC\_CODELET\_TXGEN\_PCK\_LEN

Size of packets for TxGenRxSink Operation.

#### #define IX\_ETHACC\_CODELET\_TXGEN\_PCKS

Number of packets to generate for the TxGenRxSink Operation.

#### #define IX ETHACC CODELET RX FCS STRIP

Strip FCS from incoming frames. To undefine, change to #undef.

#define IX\_ETHACC\_CODELET\_FRAME\_SIZE

## **Enumerations**

```
enum IxEthAccCodeletOperation {
    IX_ETHACC_CODELET_RX_SINK,
    IX_ETHACC_CODELET_SW_LOOPBACK,
    IX_ETHACC_CODELET_TXGEN_RXSINK,
    IX_ETHACC_CODELET_PHY_LOOPBACK,
    IX_ETHACC_CODELET_BRIDGE,
    IX_ETHACC_CODELET_BRIDGE_QOS,
    IX_ETHACC_CODELET_BRIDGE_FIREWALL,
    IX_ETHACC_CODELET_ETH_LEARNING,
    IX_ETHACC_CODELET_BRIDGE_WIFI
}
```

## **Functions**

PUBLIC ixEthAccCodeletMain (IxEthAccCodeletOperation operationType, IxEthAccPortId IX\_STATUS inPort, IxEthAccPortId outPort)

# **Detailed Description**

Intel (R) IXP400 Software Ethernet Access Codelet API.

This codelet demonstrates both Ethernet Data and Control plane services and Ethernet Management services.

- A) Ethernet Data and Control plane services:
  - Configuring both ports as a receiver sink from an external source (such as Smartbits).
  - ♦ Configuring Port-1 to automatically transmit frames and receive frames on Port-2. Frames generated and transmitted in Port-1 are loopbacked into Port-2 by using cross cable.
  - Configuring and performing a software loopback on each of the two ethernet ports.
  - ♦ Configuring both ports to act as a bridge so that frames received on one port are retransmitted on the other.
- B) Ethernet Management services:
  - ♦ Adding and removing static/dynamic entries.
  - Calling the maintenance interface (shall be run as a separate background task)
  - ♦ Calling the show routine to display the MAC address filtering tables.

#### **Definition**

In the context of this codelet, the following definitions are applicable.

Port 1 = ixe0 = Ethernet port associated with NPE–B Ethernet Coprocessor.

Port 2 = ixe1 = Ethernet port associated with NPE-C Ethernet Coprocessor.

Port 3 = ixe2 = Ethernet port associated with NPE-A Ethernet Coprocessor.

Enumerations 563

#### **Design constraints**

This codelet assumes that the underlying Intel(R) IXP4XX Product Line of Network Processors have two Ethernet NPEs. For silicon with single Ethernet NPE, operation will be only functional in the particular Ethernet port that corresponds to the available Ethernet NPE. Particularly, bridge operation will not work as two Ethernet ports are needed in this operation.

#### **Assumptions**

This codelet illustrates the use EthAcc APIs. The operations provided may not be working on the best performance as the target of this codelet is just to show the functionality of APIs. In order to get better performance, #undef IX\_ETHACC\_CODELET\_TXGENRXSINK\_VERIFY to disable traffic verification.

Please note that this codelet is not optimized for production quality.

For performance testing, please use the operations below:

- Rx Sink Operation.
- TxGenRxSink Operation.
- Bridge Operation with Ethernet frames sent into either one of the Ethernet Ports.

The operations below need special tuning to optimize them. Tuning can be done by either using a lower traffic(frames/second), reducing the value of IX\_ETHACC\_CODELET\_TXGEN\_PCKS or #undef IX\_ETHACC\_CODELET\_TXGENRXSINK\_VERIFY.

• Software Loopback Operation.

MAC addresses

- PHY Loopback Operation.
- Bridge Operation with Ethernet frames sent into both Ethernet Ports.

#### **VxWorks\* User Guide**

**ixEthAccCodeletMain()** function is used as a single point of execution for EthAcc Codelet. It allows user to enter selection for different type of supported operations described below:

```
Usage :
   >ixEthAccCodeletMain (operationType,inPort,outPort)
  Where operationType:
        1 = To sink received frames as fast as possible for available ports.
        2 = To software loopback received frames to the same port for available ports.
        3 = To generate and transmit frames from outPort, remote loopback by using
            an external cross cable to inPort, and received on inPort (TxGenRxSink).
        4 = To generate frames and perform PHY loopback on the same port for available ports.
        5 = To transmit any frame received on inPort through outPort (Bridge).
        6 = To transmit any 802.1Q-tagged frame received on inPort through outPort,
            using QoS (QoS Bridge)
        7 = To transmit frames received on inPort through outPort, provided
            they meet the MAC address firewall criteria (Firewall Bridge)
        8 = To activate Ethernet MAC learning facility.
        9 = To transmit frames received on inPort through outPort, using
            802.3 <=> 802.11 frame header conversions for frames matching certain
```

#### Linux\* User Guide

The idea of using the **ixEthAccCodeletMain()** as a single point of execution for EthAcc codelet. The operation selected will be executed when user issue 'insmod' in command prompt.

Enumerations 564

```
Usage :
  >insmod ixp400_codelets_ethAcc.o operationType= inPort= outPort=
  Where x:
       1 = To sink received frames as fast as possible for available ports.
        2 = To software loopback received frames to the same port for available ports.
        3 = To generate and transmit frames from outPort (z), remote loopback by using
            an external cross cable to inPort (y), and received on inPort (y) (TxGenRxSink).
        4 = To generate frames and perform PHY loopback on the same port for available ports.
        5 = To transmit any frame received on inPort (y) through outPort (z) (Bridge).
        6 = To transmit any 802.10-tagged frame received on inPort (y) through outPort (z),
            using OoS (OoS Bridge)
        7 = To transmit frames received on inPort (y) through outPort (z), provided
            they meet the MAC address firewall criteria (Firewall Bridge)
        8 = To activate Ethernet MAC learning facility.
        9 = To transmit frames received on inPort (y) through outPort (z), using
            802.3 <=> 802.11 frame header conversions for frames matching certain
            MAC addresses
```

#### **WinCE User Guide**

The Ethernet Access Codelet uses serial console to print out menus and accept input from users. Users need to choose and enter which operation to be executed from the menus.

```
Usage :
  Menu: Choose type of test you want to execute.
  Options:
        1 = To sink received frames as fast as possible for available ports.
        2 = To software loopback received frames to the same port for available ports.
        3 = To generate and transmit frames from port 1, remote loopback by using
            an external cross cable to port 2, and received on port 2 (TxGenRxSink).
        4 = To generate frames and perform PHY loopback on the same port for available ports.
        5 = To transmit any frame received on one port through the other one (Bridge).
        6 = To transmit any 802.1Q-tagged frame received on one port through the other
            one, using QoS (QoS Bridge)
        7 = To transmit frames received on one port through the other port, provided
            they meet the MAC address firewall criteria (Firewall Bridge)
        8 = To activate Ethernet MAC learning facility.
        9 = To transmit frames received on one port through the other port, using
            802.3 <=> 802.11 frame header conversions for frames matching certain
           MAC addresses
      100 = Exit Ethernet Access codelet.
```

#### **MAC Setup**

The default MAC setup will be:

- Promiscuous mode enabled (for learning example)
- Frame Check Sequence appended for all frames generated on the XScale

#### **PHY Setup**

This codelet uses two PHYs as defined by IX\_ETHACC\_CODELET\_MAX\_PHY The default PHY setup will be:

Enumerations 565

- 100Mbits,
- full duplex,
- auto-negotiation on.

#### Jumbo frames

This codelet setup enable Jumbo frame reception The default setup will be:

• frames up to a msdu size of 9018 are supported.

#### **Test Equipment**

The test harness will consist of external test equipment capable of generating Ethernet packets (e.g. SmartBits).

The test equipment must be capable of performing at least the following actions to support the scenarios outlined for the Codelet:

- Send/receive an Ethernet data stream.
- Send/receive frames of different length.
- Detect CRC errors.
- Append FCS.
- Support 100Mbit full duplex mode.

## **Define Documentation**

#### #define IX\_ETHACC\_CODELET\_FRAME\_SIZE

Maximum size of a frame.

This maximum frame size includes different network settings:

- Ethernet frames (up to 1518 bytes),
- BabyJumbo frames (up to nearly 1600 bytes)
- Jumbo frames (9K bytes). Note that different encapsulation types may extend the MTU size of 9000. The NPE firmware compares onlu the overall ethernet frame size (MSDU), with may be stripped from the FCS at the time of comparrison. The frame size is affected by other operations which changes the frame size, like the addition or the removal of VLAN tags.

Definition at line **395** of file **IxEthAccCodelet.h**.

#### #define IX\_ETHACC\_CODELET\_MAX\_PORT

Number of Ethernet Ports supported for this codelet.

Definition at line 276 of file IxEthAccCodelet.h.

#### #define IX\_ETHACC\_CODELET\_MBUF\_DATA\_POOL\_SIZE

Size of MBuf data pool.

Definition at line 314 of file IxEthAccCodelet.h.

#### #define IX\_ETHACC\_CODELET\_MBUF\_POOL\_SIZE

Size of MBuf pool.

Definition at line **285** of file **IxEthAccCodelet.h**.

### #define IX\_ETHACC\_CODELET\_NPEB\_MAC

Hard-encoded MAC address for NPEB.

Definition at line **239** of file **IxEthAccCodelet.h**.

#### #define IX\_ETHACC\_CODELET\_NPEC\_MAC

Hard-encoded MAC address for NPEC.

Definition at line 248 of file IxEthAccCodelet.h.

#### #define IX\_ETHACC\_CODELET\_PCK\_LEN

Length of MBuf payload (in bytes).

Definition at line **305** of file **IxEthAccCodelet.h**.

#### #define IX\_ETHACC\_CODELET\_PCK\_SIZE

Size of MBuf packet (recommaended size for ethAcc component).

Definition at line 296 of file IxEthAccCodelet.h.

#### #define IX\_ETHACC\_CODELET\_RX\_FCS\_STRIP

Strip FCS from incoming frames. To undefine, change to #undef.

#### #define IX\_ETHACC\_CODELET\_RX\_MBUF\_POOL\_SIZE

Size of receive MBuf pool.

Definition at line **258** of file **IxEthAccCodelet.h**.

#### #define IX\_ETHACC\_CODELET\_TX\_MBUF\_POOL\_SIZE

Size of transmit MBuf pool.

Definition at line **267** of file **IxEthAccCodelet.h**.

#### #define IX\_ETHACC\_CODELET\_TXGEN\_PCK\_LEN

Size of packets for TxGenRxSink Operation.

Definition at line **324** of file **IxEthAccCodelet.h**.

#### #define IX\_ETHACC\_CODELET\_TXGEN\_PCKS

Number of packets to generate for the TxGenRxSink Operation.

Definition at line 333 of file IxEthAccCodelet.h.

## **Enumeration Type Documentation**

#### enum IxEthAccCodeletOperation

#### **Enumeration values:**

IX\_ETHACC\_CODELET\_RX\_SINK All frames received (from external device) will be

sinked for available ports.

IX\_ETHACC\_CODELET\_SW\_LOOPBACK All frames received are software loopbacked to

the same port for available ports.

IX\_ETHACC\_CODELET\_TXGEN\_RXSINK Frames generated and transmitted from port 1,

remote loopbacked to port 2 by using cross cable

and received on port 2.

IX\_ETHACC\_CODELET\_PHY\_LOOPBACK Frames generated and PHY loopbacked on the

same port for available ports.

IX\_ETHACC\_CODELET\_BRIDGE Frames received on one port will be transmitted

through the other port.

IX\_ETHACC\_CODELET\_BRIDGE\_QOS Frames received on one port will be transmitted

through the other port, with priority enabled.

IX\_ETHACC\_CODELET\_BRIDGE\_FIREWALL Frames received on one port will be transmitted

through the other port if the MAC address match

the firewall criteria.

IX\_ETHACC\_CODELET\_ETH\_LEARNING

IX\_ETHACC\_CODELET\_BRIDGE\_WIFI

Ethernet Learning Facility where it adds some

static and dynamic entries.

Dynamic entries are then aged and verified that

they no longer appear in the database.

Ethernet 802.3 <=> 802.11 header conversion

test.

Definition at line 408 of file IxEthAccCodelet.h.

# Intel (R) IXP400 Software HSS Access Codelet (IxHssAccCodelet) API

[Intel (R) IXP400 Software Codelets]

Intel (R) IXP400 Software HSS Access Codelet API. The interface for the HSS Access Codelet.

## **Defines**

#define IX\_HSSACC\_CODELET\_DURATION\_IN\_MS

## **Functions**

PUBLIC **ixHssAccCodeletMain** (IxHssAccCodeletOperation operationType, IX\_STATUS IxHssAccCodeletPortMode portMode, IxHssAccCodeletVerifyMode verifyMode)

# **Detailed Description**

Intel (R) IXP400 Software HSS Access Codelet API. The interface for the HSS Access Codelet.

This module contains the implementation of the HSS Access Codelet.

The following top-level operation is supported:

- Test Packetised and Channelised Services, with the Codelet acting as data source/sink and HSS as loopback. The Codelet will transmit data and verify that data received is the same as that transmitted. Codelet runs for IX\_HSS\_CODELET\_DURATION\_IN\_MS ms.
- There are four clients of Packetised service per HSS port 1 client per E1/T1 trunk. Client 0 and 2 are running in Packetised HDLC mode while client 1 and 3 in Packetised RAW mode.

#### Assumptions

In Channelised service, the codelet transmits traffic continuously. When the codelet runs up to IX\_HSS\_CODELET\_DURATION\_IN\_MS ms, Tx counter is bigger than Rx counter. This is due to the fact that traffics submitted to NPE (i.e. Tx counter has been increased) are not transmitted out by NPE when HSS service is disabled. These traffics will be dropped and not loopbacked at HSS (Hence, Rx counter not increased).

In Packetised—raw mode service (client 1 and 3), Rx counter will be bigger than Tx counter because in this service, idle packets are received by Intel XScale(R) Core and causes Rx counter to be bigger than Tx counter. As for packetised—HDLC service, idle packets are handled in HDLC coprocessor and not passed to Intel XScale(R) Core (Hence, Rx counter not increased).

#### Limitations

When executing Packetised service on both HSS ports of 266MHz Intel (R) IXP42X Processor simultaneously, receive traffic verification should fail on client 3 (i.e. Packetised–raw mode) of HSS port 1.

Intel (R) IXP400 Software HSS Access Codelet (IxHssAccCodelet) API [Intel (R) IXP400 Software Codelets

The reason why this issue occured is IXP421 processor does not have enough CPU resources to perform intensive packet verification tasks. However, this does not imply that the same issue will hit customer applications because actual applications will not do any packet verifications in the way that the codelet does. This issue is not seen on a 533MHz Intel (R) IXP42X processor.

#### **VxWorks\*** User Guide

ixHssAccCodeletMain() function is used as a single point of execution for HssAcc Codelet.

```
Usage :
    >ixHssAccCodeletMain (operationType, portMode, verifyMode)
Where operationType:
    1 = Packetised Service Only.
    2 = Channelised Service Only.
    3 = Packetised Service and Channelised Services.

Where portMode:
    1 = HSS Port 0 Only.
    2 = HSS Port 1 Only.
    3 = HSS Port 0 and 1.

Where verifyMode:
    1 = codelet verifies traffic received in hardware loopback mode.
    2 = codelet does not verify traffic received in hardware loopback mode.
```

#### Linux\* User Guide

The idea of using the **ixHssAccCodeletMain()** as a single point of execution for HssAcc codelet. The operation selected will be executed when user issue 'insmod' in command prompt.

```
Usage :
    >insmod ixp400_codelets_hssAcc.o operationType=(a) portMode=(b) verifyMode=(c)
Where a:
    1 = Packetised Service Only.
    2 = Channelised Service Only.
    3 = Packetised Service and Channelised Services.

Where b:
    1 = HSS Port 0 Only.
    2 = HSS Port 1 Only.
    3 = HSS Port 0 and 1.

Where c:
    1 = codelet verifies traffic received in hardware loopback mode.
    2 = codelet does not verify traffic received in hardware loopback mode.
```

#### **WinCE User Guide**

The HSS Access Codelet uses serial console to print out menus and accept input from users. Users need to choose and enter which operation to be executed from the menus.

```
Usage :
    Menu 1: Choose type of service you want to execute.
    Options:
```

Intel (R) IXP400 Software HSS Access Codelet (IxHssAccCodelet) API [Intel (R) IXP400 Software Codelets]

```
1 = Packetised Service Only.
2 = Channelised Service and Channelised Services.
3 = Packetised Service and Channelised Services.
100 = Exit HSS access codelet.

Menu 2: Choose which port(s) you want to execute.
Where b:
1 = HSS Port 0 Only.
2 = HSS Port 1 Only.
3 = HSS Port 0 and 1.
100 = Exit HSS access codelet.

Menu 3: Choose if codelet should or shouldn't verify traffic.
Where c:
1 = codelet verifies traffic received in hardware loopback mode.
2 = codelet does not verify traffic received in hardware loopback mode.
100 = Exit HSS access codelet.
```

#### **Buffer Management**

The packetised service uses mbuf buffers to store data, and chains mbufs together to form large packets. In the transmit direction, mbufs are allocated from a pool on transmit, and returned to the pool on transmit done. For receive, mbufs are allocated from a pool when supplying buffers to the free queue, and returned to the pool on receive.

The channelised service operates quite differently. As voice data is very sensitive to latency using mbufs for transferral of the data between Intel XScale(R) Core and NPE is not very appropriate. Instead, circular buffers are used whereby the NPE reads data from a block of SDRAM that the Intel XScale(R) Core writes to, and writes data to a block of SDRAM that Intel XScale(R) Core reads from. On receive, the NPE writes directly into a circular buffer that Intel XScale(R) Core subsequently reads the data from. Each channel has its own circular buffer, and all these buffers are stored contiguously. On transmit, the NPE takes a circular list of pointers from Intel XScale(R) Core and transmits the data referenced by these pointers. Each list of pointers contains a pointer for each channel, and the circular list of pointers contains multiple lists stored contiguously. This is to allow Intel XScale(R) Core to transmit voice samples without having to copy data, as only the pointer to the data blocks needs to be written to SDRAM. The NPE lets Intel XScale(R) Core know, in the form of Tx and Rx offsets, where in the blocks of SDRAM it is currently reading from and writing to. This enables Intel XScale(R) Core to co-ordinate its reading and writing activities to maintain the data flow. The Tx offset lets Intel XScale(R) Core know the list offset into the Tx circular pointer list that the NPE will next use to transmit. The Rx offset lets Intel XScale(R) Core know the byte offset into each channel's Rx circular buffer that the NPE will next receive data into.

#### **Caching**

To improve system performance, caching may be enabled for both the channelised and packetised buffers. To allow for this, buffers need to be flushed before transmit, and invalidated after receive. Flushing the buffers before transmit ensures the NPE reads and transmits the correct data. Invalidating the buffers after receive ensures Intel XScale(R) Core reads and processes the correct data. In the case of the Codelet, all data is flushed and invalidated as every byte is being written to on transmit and every byte is verified on receive. In a real application flushing or invalidating all the data may not be necessary, only the data that the application has written before transmit or will read after receive. Note, regarding the packetised service, the IxHssAcc component itself takes care of flushing and invalidating mbuf headers. The application needs only to concern

itself with the mbuf data.

#### **Data Verification Strategy**

For both the packetised and channelised service a changing pattern will be transmitted. When the HSS co-processor is performing a loopback the data received is expected to be the same as that transmitted. The data transmitted carries a byte pattern that begins at a known value and is incremented for each byte. An independent byte pattern is transmitted for each channel of the channelised service, and also for each port of the packetised service. When data is received it is expected to match the pattern that was transmitted. For the channelised service the first non-idle byte received is expected to be the beginning of the byte pattern. For the packetised service, RAW mode clients may receive idle data so this is detected and ignored. Only non-idle data is verified.

#### **56Kbps Packetised HDLC feature**

This feature is demonstrated in one of the packetised HDLC clients (i.e. client 2). The CAS bit is configured to be in the least signicant bit (LSB) position with bit polarity '1'. Bit inversion is also enabled on this client as well. The data verification strategy remains the same as other packetised clients.

# Intel (R) IXP400 Software PerfProf Access Codelet

## [Intel (R) IXP400 Software Codelets]

(IxPerfProfAccCodelet) API Intel (R) IXP400 Software codelet PerfProf Access component API

## **Defines**

#define PSS MASK

Masks out PSS portion of the PMSR register.

#define EXPANSION BUS

#define SDRAM\_CONTROLLER

#define PCI

#define QUEUE\_MANAGER #define AHB\_APB\_BRIDGE

## **Enumerations**

```
enum IxPerfProfAccCodeletMode {
    IX_PERFPROF_ACC_CODELET_MODE_HELP,
    IX_PERFPROF_ACC_CODELET_MODE_ALL,
    IX_PERFPROF_ACC_CODELET_MODE_BUS_PMU_NORTH_MODE,
    IX_PERFPROF_ACC_CODELET_MODE_BUS_PMU_SOUTH_MODE,
    IX_PERFPROF_ACC_CODELET_MODE_BUS_PMU_SDRAM_MODE,
    IX_PERFPROF_ACC_CODELET_MODE_XSCALE_PMU_EVENT_SAMPLING,
    IX_PERFPROF_ACC_CODELET_MODE_XSCALE_PMU_TIME_SAMPLING,
    IX_PERFPROF_ACC_CODELET_MODE_XSCALE_PMU_EVENT_COUNTING,
    IX_PERFPROF_ACC_CODELET_MODE_XCYCLE,
    IX_PERFPROF_ACC_CODELET_MODE_BUS_PMU_PMSR_GET
    }

Contains selection of mode to be used when calling the main API.
```

## **Functions**

PUBLIC **ixPerfProfAccCodeletMain** (**IxPerfProfAccCodeletMode** mode, UINT32 param1, UINT32 void param2, UINT32 param3, UINT32 param4, UINT32 param5, UINT32 param6, UINT32 param7, UINT32 param8, UINT32 param9)

## **Detailed Description**

(IxPerfProfAccCodelet) API Intel (R) IXP400 Software codelet PerfProf Access component API

Functionality of the PerfProf Access Codelet

The codelet shall demonstrate how the Performance Profiling utility can be used for profiling purposes.

- The different implementations are demonstrated.
  - ♦ Help Lists down how the codelet can be used.
  - ♦ Demo All A non user configurable demonstration on how to use the APIs
  - ♦ Bus Pmu North Mode Profiling of the north bus activities. Enables user to select events that they wish to monitor.
  - ♦ Bus Pmu South Mode Profiling of the south bus activities. Enables user to select events that they wish to monitor.
  - ♦ Bus Pmu Sdram Mode Profiling of the sdram bus activities. Enables user to select events that they wish to monitor.
  - ♦ Bus Pmu PMSR Get Mode Get the last slave or master to access the bus.
  - ♦ Xscale PMU Event Sampling Event Sampling of Xscale PMU. Enables user to select event and sampling rate that they wish to sample.
  - ◆ Xscale PMU Time Sampling Time Sampling of Xscale PMU. Enables user to select clock count mode and number of events and rate they wish to sample.
  - ♦ Xscale PMU Event Counting Event counting of Xscale PMU. Enables users to select events that they wish to count or monitor.
  - ◆ Xcycle Measurement Measurement of cycle idle time. i.e when the cycles are not being used to process anything.

#### User Guide

Users will be able to start the codelet by calling ixPerfProfAccCodeletMain and passing in up to 10 parameters. The parameters are represented in the following order:

```
Help Mode
  Mode - Select IX_PERFPROF_ACC_CODELET_MODE_HELP
   Set the rest of the parameters to 0.
All functionalities mode
   Mode - Select IX_PERFPROF_ACC_CODELET_MODE_ALL
   Set the rest of the parameters to 0.
Bus PMU north mode
   Mode - Select IX PERFPROF ACC CODELET MODE BUS PMU NORTH MODE
   param1 - Select proper PEC1 value from main header file.
   param2 - Select proper PEC2 value from main header file.
   param3 - Select proper PEC3 value from main header file.
   param4 - Select proper PEC4 value from main header file.
   param5 - Select proper PEC5 value from main header file.
   param6 - Select proper PEC6 value from main header file.
   param7 - Select proper PEC7 value from main header file.
   Set the rest of the parameters to 0.
Bus PMU south mode
   Mode - Select IX_PERFPROF_ACC_CODELET_MODE_BUS_PMU_SOUTH_MODE
   param1 - Select proper PEC1 value from main header file.
   param2 - Select proper PEC2 value from main header file.
   param3 - Select proper PEC3 value from main header file.
   param4 - Select proper PEC4 value from main header file.
   param5 - Select proper PEC5 value from main header file.
   param6 - Select proper PEC6 value from main header file.
   param7 - Select proper PEC7 value from main header file.
   Set the rest of the parameters to 0.
Bus PMU sdram mode
   Mode - Select IX_PERFPROF_ACC_CODELET_MODE_BUS_PMU_SDRAM_MODE
   param1 - Select proper PEC1 value from main header file.
   param2 - Select proper PEC2 value from main header file.
   param3 - Select proper PEC3 value from main header file.
```

```
param4 - Select proper PEC4 value from main header file.
   param5 - Select proper PEC5 value from main header file.
   param6 - Select proper PEC6 value from main header file.
   param7 - Select proper PEC7 value from main header file.
   Set the rest of the parameters to 0.
Bus PMU PMSR Get
  Mode - Select IX_PERFPROF_ACC_CODELET_MODE_BUS_PMU_PMSR_GET
   Set the rest of the parameters to 0.
XScale PMU Event Sampling
  Mode - Select IX PERFPROF ACC CODELET MODE DEMO XSCALE PMU EVENT SAMPLING
   param1 - Number of events
   param2 - Event 1
   param3 - Sampling rate of Event 1
  param4 - Event 2
   param5 - Sampling rate of Event 2
   param6 - Event 3
   param7 - Sampling rate of Event 3
   param8 - Event 4
   param9 - Sampling rate of Event 4
XScale PMU Time Sampling
   Mode - Select IX_PERFPROF_ACC_CODELET_MODE_DEMO_XSCALE_PMU_TIME_SAMPLING
   param1 - Sampling rate.
   param2 - Clock count divider.
   Set the rest of the parameters to 0.
XScale PMU Event Counting
   Mode - Select IX_PERFPROF_ACC_CODELET_MODE_DEMO_XSCALE_PMU_EVENT_COUNTING
   param1 - Clock count divider.
   param2 - Number of events.
   param3 - Event 1.
  param4 - Event 2.
  param5 - Event 3.
  param6 - Event 4.
  Set the rest of the parameters to 0.
Xcycle Measurement
  Mode - Select IX_PERFPROF_ACC_CODELET_MODE_XCYCLE
   param1 - Number of runs required.
   Set the rest of the parameters to 0.
```

#### **VxWorks User Guide**

**ixPerfProfAccCodeletMain()** function is used as a single point of execution for PerfProfAcc Codelet. It allows user to enter selection for different type of supported operations as described above.

#### **Linux User Guide**

**ixPerfProfAccCodeletMain()** function is used as a single point of execution for PerfProfAcc Codelet. It allows user to enter selection for different type of supported operations as described above.

```
Usage :
    >insmod ixp400_codelets_perfProfAcc.o \
    mode= \
    param1= \
    param2= \
```

```
param3= \
param4= \
param5= \
param6= \
param7= \
param8= \
param9= \
```

Where Parameter X are as described above.

## **Define Documentation**

#define PSS\_MASK

Masks out PSS portion of the PMSR register.

Definition at line 194 of file IxPerfProfAccCodelet.h.

# **Enumeration Type Documentation**

#### enum IxPerfProfAccCodeletMode

Contains selection of mode to be used when calling the main API.

#### Enumeration values:

| IX_PERFPROF_ACC_CODELET_MODE_HELP                      | Select help mode.                      |
|--------------------------------------------------------|----------------------------------------|
| IX_PERFPROF_ACC_CODELET_MODE_ALL                       | Select all mode.                       |
| IX_PERFPROF_ACC_CODELET_MODE_BUS_PMU_NORTH_MODE        | Select north bus pmu mode.             |
| IX_PERFPROF_ACC_CODELET_MODE_BUS_PMU_SOUTH_MODE        | Select south bus pmu mode.             |
| IX_PERFPROF_ACC_CODELET_MODE_BUS_PMU_SDRAM_MODE        | Select sdram mode.                     |
| IX_PERFPROF_ACC_CODELET_MODE_XSCALE_PMU_EVENT_SAMPLING | Select xscale pmu event sampling mode. |
| IX_PERFPROF_ACC_CODELET_MODE_XSCALE_PMU_TIME_SAMPLING  | Select xscale pmu time sampling mode.  |
| IX_PERFPROF_ACC_CODELET_MODE_XSCALE_PMU_EVENT_COUNTING | Select xscale pmu event counting mode. |
| IX_PERFPROF_ACC_CODELET_MODE_XCYCLE                    | Select xcycle mode.                    |
| IX_PERFPROF_ACC_CODELET_MODE_BUS_PMU_PMSR_GET          |                                        |

Select bus pmu pmsr get mode.

Definition at line 253 of file IxPerfProfAccCodelet.h.

# Intel (R) IXP400 Software USB RNDIS Codelet (IxUSBRNDIS) API

[Intel (R) IXP400 Software Codelets]

Intel (R) IXP400 Software codelet USB RNDIS API.

### **Modules**

Intel (R) IXP400 Software USB RNDIS End Driver Codelet (IxUSBRNDIS) API

Intel (R) IXP400 Software codelet for RNDIS End API.

Intel (R) IXP400 Software USB RNDIS Vendor Codelet (IxUSBRNDIS)

Intel (R) IXP400 Software codelet for RNDIS Vendor information.

## **Functions**

PUBLIC M BLK ID rndisBuffAlloc (size t size)PUBLIC

IX\_STATUS **ixUSBRNDISSignalEncapsulatedCommand** (void) Function prototype for signalling encapsulation command.

PUBLIC IX\_STATUS **ixUSBRNDISProcessEncapsulatedCommand** (IX\_USB\_MBLK \*) Function prototype for processing encapsulation command.

PUBLIC IX\_STATUS **ixUSBRNDISProcessDataPacket** (IX\_USB\_MBLK \*) Function prototype for processing data packet.

PUBLIC IX\_STATUS ixUSBRNDISLayerInit (void \*pDrvCtrl) Function prototype for layer initialization.

PUBLIC IX\_STATUS **ixUSBRNDISInit** (void) Function prototype for initializing RNDIS.

PUBLIC void **ixUSBRNDISUnload** (void) Function prototype for releasing the I/O memory and disconnecting the interrupt.

PUBLIC IX\_USB\_MBLK \* ixUSBRNDISCreateMBuf (UINT8 \*buffer, UINT32 len) Function prototype for creating MBufs.

PUBLIC IX\_STATUS **ixUSBRNDISSendDataPacket** (RNDIS\_BUF \*packet) Function prototype for sending data packet. It is the hook for the RNDIS END.

void ixUSBRNDISIpHdrDump (const char \*const mData) const char \* ixUSBRNDISIpProtoStrGet

Intel (R) IXP400 Software USB RNDIS Codelet (IxUSBRNDIS) API [Intel (R) IXP400 Software Codelets]

# **Detailed Description**

Intel (R) IXP400 Software codelet USB RNDIS API.

How to use the USB RNDIS codelet:

- build a loadable object and load it into vxWorks
- start the codelet by typing ixUSBRNDISStart

You should see the "usb" network interface in the output generated by the ifShow command.

Plug the board into the USB port of a Windows 98/ME/2000 machine and selected the driver provided with the codelet when queried for it.

#### Note:

- the IP and MAC addresses of the END driver (therefore the board side of the link) are defined in ixUSBRNDISEnd.h
- the MAC address of the RNDIS driver (which will be used by Windows as its own MAC address) is defined in ixUSBRNDIS.h

Currently the END MAC address is 00:00:00:00:00:00:00:00:00 and the RNDIS MAC address is 00:00:00:00:00:00:01. The IP address of the END is 192.168.1.1, therefore you should use a compatible address for the RNDIS controller on the Windows side (such as 192.168.1.2) and set the END IP address as gateway address for the RNDIS network device, or change them to suitable values.

The codelet was tested with Windows 2000 only, and telnet and ftp traffic was passed by routing the PC through the Intel (R) IXP400 Software into a network.

Warning: this codelet is for demonstration purposes only, it should not be considered a fully working application.

## **Function Documentation**

```
PUBLIC IX_USB_MBLK * ixUSBRNDISCreateMBuf ( UINT8 * buffer, UINT32 len )
```

Function prototype for creating MBufs.

#### Parameters:

```
UINT8 *buffer – Pointer to a bufferUINT32 len – Length of buffer
```

Detailed Description 580

#### Returns:

♦ IX\_USB\_MBLK – Successfully create MBUF

♦ NULL – Failed to create MBUF

#### PUBLIC IX\_STATUS ixUSBRNDISInit (void)

Function prototype for initializing RNDIS.

#### Parameters:

None

#### Returns:

♦ IX\_SUCCESS – Successfully initalized RNDIS

♦ IX\_FAIL – Failed to initialize RNDIS

#### PUBLIC IX\_STATUS ixUSBRNDISLayerInit (void \* pDrvCtrl )

Function prototype for layer initialization.

#### Parameters:

*pDrvCtrl* – Pointer to the device to be initialized

#### Returns:

♦ IX\_SUCCESS – Successfully initalized

♦ IX\_FAIL – Failed to initialize

#### PUBLIC IX\_STATUS ixUSBRNDISProcessDataPacket ( IX\_USB\_MBLK \* )

Function prototype for processing data packet.

#### Parameters:

*IX\_USB\_MBLK* – data packet to be processed

#### Returns:

♦ IX\_SUCCESS – Data packet successfully processed

Detailed Description 581

♦ IX\_FAIL – Failed to process data packet

#### PUBLIC IX\_STATUS ixUSBRNDISProcessEncapsulatedCommand ( IX\_USB\_MBLK \* )

Function prototype for processing encapsulation command.

#### Parameters:

*IX\_USB\_MBLK* – memory buffer to be encapsulated

#### Returns:

- ♦ IX\_SUCCESS Succesfully processing encapsulation command
- ♦ IX\_FAIL Failed to process encapsulation command for some internal reason

#### PUBLIC IX\_STATUS ixUSBRNDISSendDataPacket ( RNDIS\_BUF \* packet )

Function prototype for sending data packet. It is the hook for the RNDIS END.

#### Parameters:

RNDIS \*packet - Pointer to a data packet to be transmitted

#### Returns:

- ♦ IX\_SUCCESS Successfully send a data packet
- ♦ IX\_FAIL Failed to send a data packet

#### PUBLIC IX\_STATUS ixUSBRNDISSignalEncapsulatedCommand (void )

Function prototype for signalling encapsulation command.

#### Parameters:

None

#### Returns:

- ♦ IX\_SUCCESS Successfully signalling encapsulation command
- ♦ IX\_FAIL Failed to signal encapsulation command for some internal reason

#### PUBLIC void ixUSBRNDISUnload (void)

Detailed Description 582

Function prototype for releasing the I/O memory and disconnecting the interrupt.

#### Parameters:

None

#### Returns:

None

# Intel (R) IXP400 Software USB RNDIS End Driver Codelet (IxUSBRNDIS) API

# [Intel (R) IXP400 Software USB RNDIS Codelet (IxUSBRNDIS) API]

Intel (R) IXP400 Software codelet for RNDIS End API.

## **Defines**

#### #define RNDIS END INET ADDR

RNDIS END driver with inet address.

#### #define RNDIS\_END\_MAC\_ADDRESS

RNDIS END driver with MAC address.

## **Functions**

PUBLIC IX\_STATUS ixUSBRNDISStart (void)

Starts the RNDIS component.

PUBLIC void **rndisInt** (void \*pDrvCtrl, int packet)

RNDIS END hook for receiving packets.

## **Detailed Description**

Intel (R) IXP400 Software codelet for RNDIS End API.

Description of the RNDIS End driver

#### Running the codelet in Linux\*.

- insmod lib/linuxbe/ixp400.o
- insmod lib/linuxbe/ixp400\_codelets\_usb.o
- ifconfig usb0 x.x.x.x (Where x.x.x.x is the desired ip address of the interface)

#### Running the codelet in VxWorks\* big endian.

- Load module that was built
  - ♦ ld < lib/vxbe/codelets usbTest.out
- Run the codelet
  - ♦ ixUSBRNDISStart
  - ifAddrSet "usb0", "x.x.x.x" (Where x.x.x.x is the desired ip address of the interface)

#### Running the codelet in VxWorks\* little endian.

- Load module that was built
  - ♦ ld < lib/vxle/codelets usbTest.out
- Run the codelet
  - ♦ ixUSBRNDISStart
  - ♦ ifAddrSet "usb0", "x.x.x.x" (Where x.x.x.x is the desired ip address of the interface)

The codelet is executed by calling the ixUSBRNDISStart function. No parameters are needed to be passed in. The start function first loads and initializes the device driver. It then goes on to load the device driver into the MUX. The function then goes on to call muxDevStart() passing in the called earlier. muxDevStart start the device that has already been initialized and handles registering the driver's interrupt service routine and anything else necessary to handle receiving and transmitting. The function finally assigns an IP address to the RNDIS interface.

#### Overview of IxRNDISEnd.c

#### **Description of macros.**

In this example driver the macros RNDIS\_OUT\_SHORT and RNDIS\_IN\_SHORT are sample macros to read/write data to a mock device. If a device communicates through formatted control blocks in shared memory, the accesses to those control blocks should also be through redefinable macros.

The macros SYS\_INT\_CONNECT, SYS\_INT\_DISCONNECT, and SYS\_INT\_ENABLE allow the driver to be customized for BSPs that use special versions of these routines.

The macro SYS\_INT\_CONNECT is used to connect the interrupt handler to the appropriate vector. By default it is the routine intConnect().

The macro SYS\_INT\_DISCONNECT is used to disconnect the interrupt handler prior to unloading the module. By default this is a dummy routine that returns OK.

The macro SYS\_INT\_ENABLE is used to enable the interrupt level for the end device. It is called once during initialization. By default this is the routine sysLanIntEnable(), defined in the module sysLib.o.

The macro SYS\_ENET\_ADDR\_GET is used to get the ethernet address (MAC) for the device. The single argument to this routine is the END\_DEVICE pointer. By default this routine copies the ethernet address stored in the global variable sysTemplateEnetAddr into the END\_DEVICE structure.

#### **Brief overview of the APIs. ixUSBRNDISStart()**

• Initializes and starts the end driver. Called to run the codelet.

END\_OBJ\* rndisLoad ( char\* initString, void \*unused )

• This routine initializes the driver and the device to the operational state. All of the device specific parameters are passed in the initString.

rndisParse ( END DEVICE \* pDrvCtrl, char \* initString )

• Parse the input string. Fill in values in the driver control structure.

Intel (R) IXP400 Software USB RNDIS End Driver Codelet (IxUSBRNDIS) API [Intel (R) IXP400 5565ftware L

```
rndisMemInit ( END_DEVICE * pDrvCtrl )
      • Initialize memory for the chip.
rndisStart ( END_OBJ * pDrvCtrl )
     • Handle controller interrupt.
rndisRecv ( END_DEVICE *pDrvCtrl, M_BLK_ID packet )
      • Process the next incoming packet.
rndisHandleRcvInt ( END_DEVICE *pDrvCtrl, M_BLK_ID packet )
      • Task level interrupt service for input packets.
rndisSend ( END_DEVICE * pDrvCtrl, M_BLK_ID pMblk )
     • The driver send routine.
     • The driver I/O control routine.
rndisConfig ( END_DEVICE *pDrvCtrl )
      • Reconfigure the interface under us.
```

rndisIoctl ( END\_DEVICE \* pDrvCtrl, int cmd, caddr\_t data )

rndisAddrFilterSet ( END\_DEVICE \*pDrvCtrl )

• Set the address filter for multicast addresses.

rndisPollRcv ( END\_DEVICE \* pDrvCtrl, M\_BLK\_ID pMblk )

• Routine to receive a packet in polled mode.

rndisPollSend ( END\_DEVICE\* pDrvCtrl, M\_BLK\_ID pMblk )

• Routine to send a packet in polled mode.

rndisMCastAdd ( END\_DEVICE \*pDrvCtrl char\* pAddress )

• Add a multicast address for the device.

rndisMCastDel ( END\_DEVICE \*pDrvCtrl, char\* pAddress )

• Delete a multicast address for the device.

rndisMCastGet ( END DEVICE \*pDrvCtrl, MULTI TABLE\* pTable )

• Get the multicast address list for the device.

Intel (R) IXP400 Software USB RNDIS End Driver Codelet (IxUSBRNDIS) API [Intel (R) IXP400 5566ftware L

```
rndisStop ( END_DEVICE *pDrvCtrl )
```

• Stop the device.

rndisUnload ( END\_DEVICE\* pDrvCtrl )

• Unload a driver from the system.

rndisPollStart ( END\_DEVICE \* pDrvCtrl )

• Start polled mode operations.

rndisPollStop ( END\_DEVICE \* pDrvCtrl )

• Stop polled mode operations.

rndisReset ( END\_DEVICE \*pDrvCtrl )

• Reset device.

## **Define Documentation**

#define RNDIS\_END\_INET\_ADDR

RNDIS END driver with inet address.

Definition at line 224 of file IxUSBRNDISEnd.h.

#define RNDIS\_END\_MAC\_ADDRESS

RNDIS END driver with MAC address.

Definition at line 231 of file IxUSBRNDISEnd.h.

## **Function Documentation**

PUBLIC STATUS ixUSBRNDISStart (void)

Starts the RNDIS component.

Parameters:

None

Returns:

♦ OK – Successfully start

### RNDIS component

♦ ERROR – Failed to start RNDIS component

```
PUBLIC void rndisInt ( void * pDrvCtrl, int packet )
```

RNDIS END hook for receiving packets.

#### Parameters:

pDrvCtrl - pointer to END device
packet - received packet

#### Returns:

None

# Intel (R) IXP400 Software USB RNDIS Vendor Codelet (IxUSBRNDIS)

[Intel (R) IXP400 Software USB RNDIS Codelet (IxUSBRNDIS) API]

Intel (R) IXP400 Software codelet for RNDIS Vendor information.

## **Defines**

#define RNDIS VENDOR ID

RNDIS with static Intel Vendor ID.

#define RNDIS PRODUCT ID

RNDIS with static Product ID.

#define RNDIS VENDOR DESCRIPTION

RNDIS with vendor description.

#define RNDIS\_MAC\_ADDRESS

RNDIS with MAC address.

## **Detailed Description**

Intel (R) IXP400 Software codelet for RNDIS Vendor information.

## **Define Documentation**

#define RNDIS\_MAC\_ADDRESS

RNDIS with MAC address.

Definition at line 46 of file IxUSBRNDISVendor.h.

#define RNDIS\_PRODUCT\_ID

RNDIS with static Product ID.

Definition at line **32** of file **IxUSBRNDISVendor.h**.

#define RNDIS\_VENDOR\_DESCRIPTION

Intel (R) IXP400 Software USB RNDIS Vendor Codelet (IxUSBRNDIS) [Intel (R) IXP400 Software USB RNDIS RN

RNDIS with vendor description.

Definition at line 39 of file IxUSBRNDISVendor.h.

### #define RNDIS\_VENDOR\_ID

RNDIS with static Intel Vendor ID.

Definition at line 25 of file IxUSBRNDISVendor.h.

# Intel (R) IXP400 Software Parity Error Notifier Access Codelet

### [Intel (R) IXP400 Software Codelets]

Intel (R) IXP400 Software Parity Error Notifier Access Codelet.

### **Defines**

### #define IX PARITYENACC CODELET OWORD ALIGNED MASK

mask value that moves an address to its Q-word aligned location.

### #define IX PARITYENACC CODELET SCAN SEGMENT SIZE

segment size for memory scan. One segment is 256 Kb.

### #define IX\_PARITYENACC\_CODELET\_DISPLAY\_INTERVAL

display interval for memory scan. The progress of scanning will be shown after scanning 32 Mh

### #define IX PARITYENACC CODELET ECC TEST REG OFFSET

byte offset for Memory Controller's ECC Test Register from ECC Control Register. ECC Test Register is used to generate bad ECC for ECC testing.

# #define **IX\_PARITYENACC\_CODELET\_SINGLE\_BIT\_ERROR\_BIT\_0\_SYNDROME** single bit error syndrome value at bit 0.

#define IX\_PARITYENACC\_CODELET\_MULTI\_BIT\_ERROR\_SYNDROME multi bit error syndrome value.

### #define IX\_PARITYENACC\_CODELET\_EXTERNAL\_DATA\_ABORT

Fault Status Register's imprecise external data abort value.

### #define IX PARITYENACC CODELET DATA CACHE PARITY ERR

Fault Status Register's data cache parity error value.

### #define IX\_PARITYENACC\_CODELET\_BIT\_MASK\_CHECK(data, mask)

check if the result of bit mask operation on 'data' and 'mask' match the 'mask'.

#### #define IX PARITYENACC CODELET REBOOT()

map to reboot function. **reboot**() is not fully implemented, and it would cause the board to hang when it is executed. In the mean time, sysToMonitorColdReboot() which reboots the board using the watchdog timer reset functionality, will be used to reboot the board.

### ${\tt \#define}\; \textbf{IX\_PARITYENACC\_CODELET\_SDRAM\_BASE\_ADDR}$

SDRAM base address.

### #define IX\_PARITYENACC\_CODELET\_SDRAM\_SCAN\_START\_OFFSET

### **Functions**

**PUBLIC** 

IX\_STATUS ixParityENAccCodeletMain (BOOL multiBit, BOOL injectNow)

This is the main function for Parity Error Notifier Access Component (ParityENAcc) Codelet.

PUBLIC void ixParityENAccCodeletQuit (void)

ixParityENAccCodeletQuit function terminates SDRAM scan.

### **Detailed Description**

Intel (R) IXP400 Software Parity Error Notifier Access Codelet.

This codelet shows how to integrate Parity Error Notifier to client application. It demonstrates the followings:

#### **VxWorks\*** User Guide

### (1) ixParityENAccCodeletMain

This function is the main function for ParityENAcc codelet. This function will perform the followings:

- initialize ParityENACC
- register callback with ParityENAcc to handle parity error
- configure ParityENAcc
- spawn "shut down" task to reboot the board when reboot is requested
- register callback with VxWorks\* kernel to handle data abort
- generate bad ECC on allocated SDRAM memory
- spawn a task to start SDRAM memory scan

### (2) ixParityENAccCodeletQuit

This function terminates SDRAM memory scan.

```
Usage :
    -> ixParityENAccCodeletQuit
```

#### Linux\* User Guide

### (1) ixParityENAccCodeletMain

This function is the main function for ParityENAcc codelet. This function will perform the followings:

- initialize ParityENACC
- register callback with ParityENAcc to handle parity error
- configure ParityENAcc
- spawn "shut down" task to reboot the board when reboot is requested

- generate bad ECC on allocated SDRAM memory
- spawn a task to start SDRAM memory scan

This function will be invoked and executed when the user loads the ParityENACc codelet module using 'insmod' command.

### (2) ixParityENAccCodeletQuit

This function terminates SDRAM memory scan. This function will be executed when user terminates parityENAcc codelet execution using 'rmmod' command.

```
Usage :
    prompt> rmmod ixp400_codelets_parityENAcc
```

### **Define Documentation**

```
#define IX_PARITYENACC_CODELET_BIT_MASK_CHECK ( data, mask )
```

check if the result of bit mask operation on 'data' and 'mask' match the 'mask'.

#### Parameters:

```
data [in] – the data that will be masked and then compared with the mask.mask [in] – the mask value.
```

#### Returns:

### **BOOL**

```
    ♦ TRUE – bit mask operation result match the mask
    ♦ FALSE – bit mask operation result does not match the mask
```

Definition at line **250** of file **IxParityENAccCodelet.h**.

#define IX\_PARITYENACC\_CODELET\_DATA\_CACHE\_PARITY\_ERR

Fault Status Register's data cache parity error value.

Definition at line 233 of file IxParityENAccCodelet.h.

### #define IX\_PARITYENACC\_CODELET\_DISPLAY\_INTERVAL

display interval for memory scan. The progress of scanning will be shown after scanning 32 Mb.

Definition at line 196 of file IxParityENAccCodelet.h.

### #define IX\_PARITYENACC\_CODELET\_ECC\_TEST\_REG\_OFFSET

byte offset for Memory Controller's ECC Test Register from ECC Control Register. ECC Test Register is used to generate bad ECC for ECC testing.

Definition at line **205** of file **IxParityENAccCodelet.h**.

### #define IX\_PARITYENACC\_CODELET\_EXTERNAL\_DATA\_ABORT

Fault Status Register's imprecise external data abort value.

Definition at line 226 of file IxParityENAccCodelet.h.

### #define IX\_PARITYENACC\_CODELET\_MULTI\_BIT\_ERROR\_SYNDROME

multi bit error syndrome value.

Definition at line **219** of file **IxParityENAccCodelet.h**.

### #define IX\_PARITYENACC\_CODELET\_QWORD\_ALIGNED\_MASK

mask value that moves an address to its Q-word aligned location.

Definition at line **179** of file **IxParityENAccCodelet.h**.

### #define IX\_PARITYENACC\_CODELET\_REBOOT (

map to reboot function. **reboot**() is not fully implemented, and it would cause the board to hang when it is executed. In the mean time, sysToMonitorColdReboot() which reboots the board using the watchdog timer reset functionality, will be used to reboot the board.

Definition at line **277** of file **IxParityENAccCodelet.h**.

### #define IX PARITYENACC CODELET SCAN SEGMENT SIZE

segment size for memory scan. One segment is 256 Kb.

Definition at line 187 of file IxParityENAccCodelet.h.

### #define IX\_PARITYENACC\_CODELET\_SDRAM\_BASE\_ADDR

SDRAM base address.

Definition at line **291** of file **IxParityENAccCodelet.h**.

### #define IX\_PARITYENACC\_CODELET\_SDRAM\_SCAN\_START\_OFFSET

memory scan start address offset

Definition at line **284** of file **IxParityENAccCodelet.h**.

### #define IX\_PARITYENACC\_CODELET\_SINGLE\_BIT\_ERROR\_BIT\_0\_SYNDROME

single bit error syndrome value at bit 0.

Definition at line 212 of file IxParityENAccCodelet.h.

### **Function Documentation**

This is the main function for Parity Error Notifier Access Component (ParityENAcc) Codelet.

This function will first initialize ParityENAcc. Then, it registers the callback with ParityENAcc to notify the codelet whenever parity error is detected. Next, this function will configure ParityENAcc to enable parity error detection. By default, parity error detection will only enabled on MCU.

Next, this function will spawn "shut down" task. This task will sleep all the time. It will only be invoked when board reboot is requested. This task is mainly used to reboot the board.

In vxworks, a data abort handler is hooked up to DATA ABORT exception vector. This data abort handler will be called when data abort occurs. This data abort handler will determine whether the data abort is triggered by multi-bit ECC error. The board will be rebooted after data abort is processed. Linux\* does not have the hook up capability.

Function Documentation 596

After that, this function will generate bad ECC on allocated SDRAM memory. The user needs to provide two parameters to specify how the ECC error should be generated. First, the user has to specify the type of ECC error injection – single bit or multi bit. Second, the user has to tell this function when to cause ECC error after bad ECC generation. By default, bad single bit ECC will be injected, and the error will be discovered later when the memory is accessed by the memory scan.

Finally, this function will initiate SDRAM memory scan. Any single bit ECC error found during the scan will be scrubbed and corrected. If multi-bit ECC error is detected during the scan, the address of memory with bad ECC will be printed, then the board will be rebooted.

#### Parameters:

multiBit BOOL [in] – type of ECC error injection.

♦ FALSE : Single bit ECC error.♦ TRUE : Multi-bit ECC error.

*injectNow* BOOL [in] – preference for when to generate ECC error.

♦ FALSE : This function will only generate bad ECC on allocated memory.

ECC error will only occur when the memory is read later.

 $\Diamond$  TRUE : After generating bad ECC, this function will immediately read

the memory to cause ECC error.

#### Returns:

### ixParityENAccCodeletQuit (void )

ixParityENAccCodeletQuit function terminates SDRAM scan.

#### Returns:

void

Function Documentation 597

# Intel (R) IXP400 Software Time Sync Access Codelet

### [Intel (R) IXP400 Software Codelets]

Intel (R) IXP400 Software Time Sync Access Codelet.

### **Data Structures**

### struct IxTimeSyncAccCodeletTSChannelConfig

This struct is used to store all three Time Sync channels' operating mode: master or slave.

### struct IxTimeSyncAccCodeletTSChannelConfig

This struct is used to store all three Time Sync channels' operating mode: master or slave.

### struct IxTimeSyncAccCodeletUninitFuncMap

This struct is used to store each supporting module's unload function's pointer, function parameter, and the state whether the module is initialized.

### struct IxTimeSyncAccCodeletUninitFuncMap

This struct is used to store each supporting module's unload function's pointer, function parameter, and the state whether the module is initialized.

### **Defines**

### #define IX\_TIMESYNCACC\_CODELET\_ROLLOVER\_VALUE

rollover value

### #define IX\_TIMESYNCACC\_CODELET\_APB\_CLOCK\_FREQUENCY

APB clock frequency in MHz (66 MHz).

### #define IX\_TIMESYNCACC\_CODELET\_FSV\_DEFAULT

define default value for frequency scale value or tick rate. With this default tick rate, system time would tick approximately every milli-second.

### #define IX\_TIMESYNCACC\_CODELET\_TARGET\_TIME\_HIT\_INTERVAL

define default value for target time interval. With default tick rate, default interval is approximately 1 second.

#### #define IX\_TIMESYNCACC\_CODELET\_MAX\_TS\_CHANNELS

maximum number of time sync channels

### #define IX\_TIMESYNCACC\_CODELET\_MAX\_CONFIGURATIONS

maximum number of supported configurations

### #define IX\_TIMESYNCACC\_CODELET\_PTP\_MESSAGE\_LEN

PTP message length in byte.

### #define IX\_TIMESYNCACC\_CODELET\_UDP\_PAYLOAD\_LEN

*UDP* payload size in byte (offset: byte 38 and 39).

### $\hbox{\tt\#define IX\_TIMESYNCACC\_CODELET\_UDP\_HEADER\_LEN}$

*UDP* header size in byte.

### #define IX\_TIMESYNCACC\_CODELET\_UDP\_CHECKSUM\_LEN

UDP checksum length in byte.

### #define IX\_TIMESYNCACC\_CODELET\_UDP\_FRAME\_LEN

*UDP frame size in byte.* 

### #define IX\_TIMESYNCACC\_CODELET\_IP\_DATAGRAM

frame type field of UDP header (offset: byte 12 and 13) for PTP message. It is set to IP DATAGRAM.

### #define IX TIMESYNCACC CODELET IP HEADER LEN

IP\_HEADER\_LEN field of UDP header (offset: byte 14) for PTP message.

### #define IX TIMESYNCACC CODELET IP DATAGRAM LEN

IP\_DATAGRAM\_LEN field of UDP header (offset: byte 16 and 17) for PTP message.

### #define IX\_TIMESYNCACC\_CODELET\_TIME\_TO\_LIVE

TIME\_TO\_LIVE field of UDP header (offset: byte 22) for PTP message.

#### #define IX TIMESYNCACC CODELET UDP PROTOCOL

*UDP PROTOCOL field of UDP header (offset: byte 23) for PTP message.* 

### #define IX TIMESYNCACC CODELET PTP EVENT PORT

Destination port number field of UDP header (offset: byte 36 and 37) for PTP message. Event port (319) is used to communicates Sync and Delay Req messages.

#### #define IX TIMESYNCACC CODELET PTP MESSAGE TYPE

PTP\_MESSAGE\_TYPE field for PTP message (offset: byte 62).

#### #define IX TIMESYNCACC CODELET INVALID PARAM

value for invalid parameter

### #define IX\_TIMESYNCACC\_CODELET\_PTP\_MSG\_XMIT\_INTERVAL

time interval for PTP message transmission (2 seconds)

### #define IX\_TIMESYNCACC\_CODELET\_LSB\_VALUE(x)

*Get LSB value of x.* 

### #define IX\_TIMESYNCACC\_CODELET\_MSB\_VALUE(x)

Get MSB value of x (where x is a USHORT type).

### **Typedefs**

typedef void(\* IxTimeSyncAccCodeletUninitFuncPtr )(IxNpeDlNpeId)

Definition of void function pointer with one input parameter. The data type of input parameter is IxNpeDlNpeId.

### **Enumerations**

Module ID list. These modules are required to be initialized or setup for PTP message transmission from each NPE.

### **Functions**

**PUBLIC** 

IX\_STATUS ixTimeSyncAccCodeletMain (UINT32 configIndex)

ixTimeSyncAccCodeletMain is the main function for timeSyncAcc codelet.

PUBLIC void ixTimeSyncAccCodeletQuit (void)

ixTimeSyncAccCodeletQuit function unloads all initialized modules, free all resources, and nicely terminates timeSyncAcc codelet execution.

### **Detailed Description**

Intel (R) IXP400 Software Time Sync Access Codelet.

```
This codelet shows how to use some of Time Sync Access (timeSyncAcc)
API functions. It demonstrates the followings:

how to configure Time Sync channel to operate in master or slave mode
how to set frequency scale value (fsv)
```

Typedefs 600

how to set and get system time

how to set target time

how to setup target time in interrupt mode

how to enable and disable target time interrupt

Basically, Time Sync Access codelet supports three configurations as follow:

```
configuration 0: NPE A - Slave, NPE B - Slave, NPE C - Master (default) configuration 1: NPE A - Slave, NPE B - Master, NPE C - Slave configuration 2: NPE A - Master, NPE B - Slave, NPE C - Slave
```

User provides his/her choice of configuration when executing Time Sync Access codelet. Based on the selected user configuration, each NPE will be configured to operate in the desired operating mode - master or slave. In addition, all NPEs and ethernet ports will be setup to transmit one PTP message using UDP protocol every 2 seconds. PTP Sync message will be transmitted at port where NPE is configured to operate in master mode. Conversely, PTP Delay\_Req message will be transmitted from slave mode operating port. The transmission and reception of PTP Sync or Delay\_Req messages can be demonstrated if the user connects master operating port to slave operating port. The following table summarizes the activities between the two connecting master port and slave port:

master port slave port
transmit Sync message receive Delay\_Req message transmit Delay\_Req message

Time Sync Access codelet sets tick rate to 1000 ticks per second. In other word, the system time will tick every one millisecond. For demonstration purpose, the target time is configured to hit system time every one second. For example, target time is set to one second ahead of current system time. When system time reaches target time, interrupt will occur. Corresponding ISR will be invoked to be processed. Two main things will be performed during ISR. First, the codelet will check if any NPE channel has detected PTP's Sync or Delay\_Req message. If yes, the captured system time at RECV/XMIT snapshot registers will be read and printed along with the PTP message information. Then, the codelet will set new target time to a second later. This process will be repeated until the user terminates the Time Sync Access codelet execution.

#### VxWorks\* User Guide

#### (1) ixTimeSyncAccCodeletMain

This function is the main function for timeSyncAcc codelet. This function will perform the followings:

Typedefs 601

```
configure all Time Sync Channels to operate in the mode
          specified in the user selected configuration.
set tick rate to get system time to start ticking
setup target time to hit every one second (in interrupt mode)
setup and enable all NPEs and all ethernet components.
spawn a thread to transmit Sync message from master port
         and Delay_Req message from slave port every 2 seconds.
Usage :
        (a) connect slave port to any master port
        (b) run timeSyncAcc codelet:
            -> ixTimeSyncAccCodeletMain x
            where x =
               0 -> NPE A - Slave, NPE B - Slave, NPE C - Master (default)
                1 -> NPE A - Slave, NPE B - Master, NPE C - Slave
                2 -> NPE A - Master, NPE B - Slave, NPE C - Slave
 (2) ixTimeSyncAccCodeletQuit
This function gracefully terminates timeSyncAcc codelet execution.
Usage :
        -> ixTimeSyncAccCodeletQuit
Linux* User Guide
 (1) ixTimeSyncAccCodeletMain
This function is the main function for timeSyncAcc codelet.
This function will perform the followings:
configure all Time Sync Channels to operate in the mode
          specified in the user selected configuration.
set tick rate to get system time to start ticking
```

Typedefs 602

```
setup target time to hit every one second (in interrupt mode)
setup and enable all NPEs and all ethernet components.
spawn a thread to transmit Sync message from master port
          and Delay_Req message from slave port every 2 seconds.
This function will be invoked and executed when the user loads the
timeSyncAcc codelet module using 'insmod' command.
Usage :
        (a) connect slave port to any master port
        (b) run timeSyncAcc codelet:
           prompt> insmod ixp400_codelets_timeSyncAcc.o config=x
            where x =
               0 -> NPE A - Slave, NPE B - Slave, NPE C - Master (default)
                1 -> NPE A - Slave, NPE B - Master, NPE C - Slave
                2 -> NPE A - Master, NPE B - Slave, NPE C - Slave
 (2) ixTimeSyncAccCodeletQuit
This function terminates timeSyncAcc codelet execution.
It will be invoked when 'rmmod' command is executed.
Usage :
       prompt> rmmod ixp400_codelets_timeSyncAcc
```

### **Define Documentation**

### #define IX\_TIMESYNCACC\_CODELET\_APB\_CLOCK\_FREQUENCY

APB clock frequency in MHz (66 MHz).

Definition at line 199 of file IxTimeSyncAccCodelet.h.

#### #define IX\_TIMESYNCACC\_CODELET\_FSV\_DEFAULT

define default value for frequency scale value or tick rate. With this default tick rate, system time would tick approximately every milli–second.

Definition at line 208 of file IxTimeSyncAccCodelet.h.

### #define IX\_TIMESYNCACC\_CODELET\_INVALID\_PARAM

value for invalid parameter

Definition at line **324** of file **IxTimeSyncAccCodelet.h**.

### #define IX\_TIMESYNCACC\_CODELET\_IP\_DATAGRAM

frame type field of UDP header (offset: byte 12 and 13) for PTP message. It is set to IP\_DATAGRAM.

Definition at line **274** of file **IxTimeSyncAccCodelet.h**.

### #define IX\_TIMESYNCACC\_CODELET\_IP\_DATAGRAM\_LEN

IP\_DATAGRAM\_LEN field of UDP header (offset: byte 16 and 17) for PTP message.

Definition at line **288** of file **IxTimeSyncAccCodelet.h**.

### #define IX\_TIMESYNCACC\_CODELET\_IP\_HEADER\_LEN

IP\_HEADER\_LEN field of UDP header (offset: byte 14) for PTP message.

Definition at line 281 of file IxTimeSyncAccCodelet.h.

### #define IX\_TIMESYNCACC\_CODELET\_LSB\_VALUE ( x )

Get LSB value of x.

Definition at line **338** of file **IxTimeSyncAccCodelet.h**.

### #define IX\_TIMESYNCACC\_CODELET\_MAX\_CONFIGURATIONS

maximum number of supported configurations

Definition at line **230** of file **IxTimeSyncAccCodelet.h**.

### #define IX\_TIMESYNCACC\_CODELET\_MAX\_TS\_CHANNELS

maximum number of time sync channels

Definition at line 223 of file IxTimeSyncAccCodelet.h.

### #define IX\_TIMESYNCACC\_CODELET\_MSB\_VALUE ( x )

Get MSB value of x (where x is a USHORT type).

Definition at line **345** of file **IxTimeSyncAccCodelet.h**.

### #define IX\_TIMESYNCACC\_CODELET\_PTP\_EVENT\_PORT

Destination port number field of UDP header (offset: byte 36 and 37) for PTP message. Event port (319) is used to communicates Sync and Delay\_Req messages.

Definition at line **310** of file **IxTimeSyncAccCodelet.h**.

### #define IX\_TIMESYNCACC\_CODELET\_PTP\_MESSAGE\_LEN

PTP message length in byte.

Definition at line 237 of file IxTimeSyncAccCodelet.h.

### #define IX\_TIMESYNCACC\_CODELET\_PTP\_MESSAGE\_TYPE

PTP\_MESSAGE\_TYPE field for PTP message (offset: byte 62).

Definition at line **317** of file **IxTimeSyncAccCodelet.h**.

### #define IX\_TIMESYNCACC\_CODELET\_PTP\_MSG\_XMIT\_INTERVAL

time interval for PTP message transmission (2 seconds)

Definition at line 331 of file IxTimeSyncAccCodelet.h.

### #define IX\_TIMESYNCACC\_CODELET\_ROLLOVER\_VALUE

rollover value

Definition at line **192** of file **IxTimeSyncAccCodelet.h**.

### #define IX\_TIMESYNCACC\_CODELET\_TARGET\_TIME\_HIT\_INTERVAL

define default value for target time interval. With default tick rate, default interval is approximately 1 second.

Definition at line **216** of file **IxTimeSyncAccCodelet.h**.

### #define IX\_TIMESYNCACC\_CODELET\_TIME\_TO\_LIVE

TIME\_TO\_LIVE field of UDP header (offset: byte 22) for PTP message.

Definition at line **295** of file **IxTimeSyncAccCodelet.h**.

### #define IX\_TIMESYNCACC\_CODELET\_UDP\_CHECKSUM\_LEN

UDP checksum length in byte.

Definition at line **258** of file **IxTimeSyncAccCodelet.h**.

### #define IX\_TIMESYNCACC\_CODELET\_UDP\_FRAME\_LEN

UDP frame size in byte.

Definition at line 265 of file IxTimeSyncAccCodelet.h.

### #define IX\_TIMESYNCACC\_CODELET\_UDP\_HEADER\_LEN

UDP header size in byte.

Definition at line **251** of file **IxTimeSyncAccCodelet.h**.

### #define IX\_TIMESYNCACC\_CODELET\_UDP\_PAYLOAD\_LEN

UDP payload size in byte (offset: byte 38 and 39).

Definition at line 244 of file IxTimeSyncAccCodelet.h.

### #define IX\_TIMESYNCACC\_CODELET\_UDP\_PROTOCOL

UDP PROTOCOL field of UDP header (offset: byte 23) for PTP message.

Definition at line **302** of file **IxTimeSyncAccCodelet.h**.

### **Typedef Documentation**

Ix Time Sync Acc Code let Uninit Func Ptr

Definition of void function pointer with one input parameter. The data type of input parameter is IxNpeDlNpeId.

Definition at line 358 of file IxTimeSyncAccCodelet.h.

### **Enumeration Type Documentation**

enum IxTimeSyncAccCodeletModuleId

Module ID list. These modules are required to be initialized or setup for PTP message transmission from each NPE.

NPE Downloader

#### **Enumeration values:**

IX\_TIMESYNCACC\_CODELET\_MBUF\_ALLOCmBuf Memory AllocationIX\_TIMESYNCACC\_CODELET\_Q\_MGRQ MgrIX\_TIMESYNCACC\_CODELET\_DISPATCHERQ Mgr DispatcherIX\_TIMESYNCACC\_CODELET\_NPE\_MHNPE Message Handler

IX\_TIMESYNCACC\_CODELET\_NPE\_DLNPE DoIX\_TIMESYNCACC\_CODELET\_NPE\_ANPE AIX\_TIMESYNCACC\_CODELET\_NPE\_BNPE BIX\_TIMESYNCACC\_CODELET\_NPE\_CNPE C

IX\_TIMESYNCACC\_CODELET\_ETH\_ACC Ethernet Access Component

IX\_TIMESYNCACC\_CODELET\_ETH\_PORTS Ethernet Port

IX\_TIMESYNCACC\_CODELET\_TX\_PTP PTP Message Transmission Setup

Definition at line **396** of file **IxTimeSyncAccCodelet.h**.

### **Function Documentation**

ixTimeSyncAccCodeletMain (UINT32 configIndex )

ixTimeSyncAccCodeletMain is the main function for timeSyncAcc codelet.

This function will perform the followings:

- configure all Time Sync Channels to operate in the mode specified in the user selected configuration.
- set tick rate to get system time to start ticking

- setup target time to hit every one second (in interrupt mode)
- setup and enable all NPEs and all ethernet components.
- spawn a thread to transmit Sync message from master port and Delay\_Req message from slave port every 2 seconds.

#### Parameters:

```
configIndex UINT32 [in] – choice of configuration

◊ 0 –> NPE A – Slave, NPE B – Slave, NPE C – Master
(default)

◊ 1 –> NPE A – Slave, NPE B – Master, NPE C – Slave
◊ 2 –> NPE A – Master, NPE B – Slave, NPE C – Slave
```

#### Returns:

### ixTimeSyncAccCodeletQuit (void)

ixTimeSyncAccCodeletQuit function unloads all initialized modules, free all resources, and nicely terminates timeSyncAcc codelet execution.

#### Returns:

void

# Intel (R) IXP400 Software Crypto Access Codelet

### [Intel (R) IXP400 Software Codelets]

(IxCryptoAccCodelet) API Intel (R) IXP400 Software Crypto Access Codelet API

### **Defines**

#### #define INLINE

### #define IX\_CRYPTOACC\_CODELET\_CRYPTOACC\_CFG

Selects the interface's (to the NPE) to be initialized by the codelet. Use one of the values defined in IxCryptoAccCfg. IX\_CRYPTO\_ACC\_CFG\_CRYPTO\_WEP\_NPE\_ACC\_EN: Enable's access to the Crypto NPE and WEP NPE.

### #define IX CRYPTOACC CODELET NPEC IMAGE ID

The build ID for NPE C image, default is IX\_NPEDL\_NPEIMAGE\_NPEC\_CRYPTO\_AES\_CCM\_ETH.

### #define IX CRYPTOACC CODELET NPEA IMAGE ID

The build ID for NPE A image, default is IX\_NPEDL\_NPEIMAGE\_NPEA\_WEP.

### #define PERFORMANCE\_WINDOW\_SIZE

Number of crypto packets/requests need to be sent in for performance benchmarking (sampling size), 1 unit represents 1000 of requests (100 requests for EAU).

### #define IX\_CRYPTOACC\_CODELET\_CRYPTO\_MBUF\_POOL\_SIZE

Size of MBuf pool, ie number of buffers to circulate.

### #define IX CRYPTOACC CODELET BATCH LEN

Number of packets/requests per sampling for performance benchmarking.

### #define IX\_CRYPTOACC\_CODELET\_QMGR\_DISPATCHER\_PRIORITY

Recommended priority of queue manager dispatch loop.

### #define IX\_CRYPTOACC\_CODELET\_QMGR\_DISPATCHER\_THREAD\_STACK\_SIZE

Recommended stack size for queue manager dispatcher thread.

### #define IX\_CRYPTOACC\_CODELET\_XSCALE\_TICK

The XScale tick is 66 MHz. The ixOsalOsIxp400TimestampResolutionGet() function returns 66666666, thus need to divide by a million.

#### #define IX CRYPTOACC CODELET REGISTER WAIT TIME

The codelet register wait time (in ms) in a for loop.

### #define IX\_CRYPTOACC\_CODELET\_PERFORM\_WAIT\_TIME

The codelet perform wait time (in ms) in a for loop.

### #define IX\_CRYPTOACC\_CODELET\_MAX\_TIME\_WAIT

Maximum time (in ms) to wait before exiting the program.

### #define IX CRYPTO ACC CODELET PKE PERFORM WAIT TIME

Maximum time (in ms) to wait before exiting the program.

### #define IX\_CRYPTO\_ACC\_CODELET\_MAX\_COUNT

Maximum counter to wait before exiting the program.

### #define IX\_CRYPTO\_ACC\_CODELET\_PKE\_EAU\_TOTAL\_OP

Total Pke Eau operation for one window size.

### #define IX\_CRYPTO\_ACC\_CODELET\_PKE\_TOTAL\_OP

Total Pke RNG/SHA operation for one window size.

### #define IX\_CRYPTO\_ACC\_CODELET\_SLEEP\_WAIT

Delay time (in ms) for printf to avoid rpc error.

### #define IX\_CRYPTOACC\_CODELET\_MIN\_CRYPTO\_PKT\_SIZE

The minimum packet/data size.

### #define IX\_CRYPTOACC\_CODELET\_MAX\_CRYPTO\_PKT\_SIZE

The maximum packet/data size.

### #define IX CRYPTOACC\_CODELET\_QMGR\_DISPATCHER\_MODE

*QMgr Dispatcher Mode, whether in interrupt (TRUE) or poll (FALSE) mode.* 

#### #define IX CRYPTOACC PKE EAU EXP CONFIG FE MODE

Set the PKE EAU modular exponential configuration for fast exponent.

### #define IX\_CRYPTOACC\_PKE\_EAU\_EXP\_CONFIG\_SE\_MODE

Set the PKE EAU modular exponential configuration for short exponent.

### **Functions**

### IX\_STATUS ixCryptoAccCodeletMain (INT32 srvIndex, UINT32 dataBLenOrOprWLen)

This is the entry point function to the codelet to choose the service for the codelet and data/operand length to be used. This is the main function of the codelet where crypto contexts registration and crypto perform services are done. Based on the selected operation and length, data/operands are sent to cryptoAcc for processing.

### **Detailed Description**

(IxCryptoAccCodelet) API Intel (R) IXP400 Software Crypto Access Codelet API

The codelet demonstrates how the Security Hardware Accelerator API can be used for performing various cryptographic operations. For demonstration purposes, various cryptographic operations (called services in

this codelet) are preconfigured in an array. Users can specify a particular service with a "service index" from the list below. Various services shown are:

Encryption and decryption, using DES ECB
Authentication calculation and check, using MD5
Combined encryption and decryption, using DES CBC and SHA1
CCM for 802.11i
ARC4 with WEP CRC computations on XScale
ARC4 with WEP CRC computations on NPE
Pseudo-random number generator (RNG) on PKE Crypto Engine
Hashing (SHA1) on PKE Crypto Engine
Arithmetic operations (modular exponential, big number modular reduction, addition, subtraction, and multiplication) on PKE Crypto Engine.

The codelet shows how to initialize the required components (like Qmgr, NPE's) and the Security Hardware Acclerator. This initialization is done only once for the very first request. Every invocation of the codelet for a specific service results in the context registration followed by execution of the operation. Once the operation completes, the contexts are un-registered. If the operation completes successfully performance statistics are printed. If there is an error, statistics are not printed and an error message is displayed.

The codelet shows the following:

The codelet demonstrates how the Network Processor Engine (NPE) is initialised, how the NPE image is downloaded to the NPE, and and how the NPE is started.

The codelet demonstrates how the Queue Manager is initialised to polling or interrupt mode.

The codelet shows how to set up the callback functions and how to register crypto contexts with cryptoAcc access component.

The codelet demonstrates how the registration should be done for the different operations using the register API.

The codelet demonstrates how the perform API can be used after successful registration.

The codelet demonstrates how to use  ${\tt XScaleWepPerform}$  function and  ${\tt NpeWepPerform}$  function

The codelet demonstrates the use of the unregister API in the event of re-starting the above mentioned operation.

The codelet demonstrates how to use PKE API for RNG, SHA, and EAU and how to setup callback functions.

The codelet measures the performance of the Security Hardware Accelerator for each of the operations listed above.

Configuration parameters for Performance benchmarking are

#### Default Performance Sampling Size

Sampling rate : 1,000 (100 for EAU)

Number of Samples : 20

Total Samples : 20,000 (2,000 for EAU)

#### Default mbuf Pool Setting

Number of mbufs in pool : 20

Min of mbufs needed in pool : 2 (for crypto context registration

purpose)

User may choose to run different operation with different data/operand lengths. The performance rate of a selected operation with the selected length will be displayed after throughput rate has been captured for a predefined performance sampling size. If an error occurs any time in the codelet, the performance numbers will not be displayed and error message will be printed.

### Notes for Performance Benchmarking:

Data are generated in XScale with random payload. No explicit verification of payload will be carried out in the codelet.

Encrypted data are sent to NPE again for decryption and same applies to authentication operation. Data payload is verified implicitly through this feedback system.

Throughput rate is captured from the point where data is sent to NPE for processing to the point where NPE completes the encryption and/or authentication operation and notifies XScale through callback.

No external data generator or benchmarking devices involved in this codelet. Throughput rate is captured using XScale timestamp.

Performance of PKE functions are captured from the time the function is called until the PKE has finished the operations and callback is invoked.

Time taken for codelet to complete the operation depends on the length selected. Larger data will take more time to complete.

#### VxWorks\* User Guide

ixCryptoAccCodeletMain() function is used as the entry point of execution for cryptoAcc Codelet.

It allows user to enter selection for various operations described below with different data/operand length.

#### Usage :

>ixCryptoAccCodeletMain (serviceIndex, dataBLenOrOprWLen)
Where serviceIndex should be one of the following:

```
0 : Lists the set of services demonstrated.
1 : Encryption and Decryption using DES(ECB)
2 : Encryption and Decryption using DES(CBC)
3 : Encryption and Decryption using 3DES(ECB)
4 : Encryption and Decryption using 3DES(CBC)
5 : Encryption and Decryption using AES(ECB)
6 : Encryption and Decryption using AES(CBC)
7 : Encryption and Decryption using AES(CTR)
8 : Encryption and Decryption using AES-CCM
9 : Encryption and Decryption using ARC4 on XScale
10 : Encryption and Decryption using ARC4 on WAN-NPE
11 : Authentication calculation and verification using MD5
12 : Authentication calculation and verification using SHA1
13 : Authentication calculation and verification WEP CRC on XScale
14 : Authentication calculation and verification WEP CRC on WAN-NPE
15 : A combined mode of operation using DES(ECB) + MD5
16 : A combined mode of operation using DES(CBC) + MD5
17 : A combined mode of operation using DES(ECB) + SHA1
18 : A combined mode of operation using DES(CBC) + SHA1
19 : A combined mode of operation using 3DES(ECB) + MD5
20 : A combined mode of operation using 3DES(CBC) + MD5
21 : A combined mode of operation using 3DES(ECB) + SHA1
22 : A combined mode of operation using 3DES(CBC) + SHA1
23 : A combined mode of operation using AES(ECB) + MD5
24 : A combined mode of operation using AES(CBC) + MD5
25 : A combined mode of operation using AES(CTR) + MD5
26 : A combined mode of operation using AES(ECB) + SHA1
27 : A combined mode of operation using AES(CBC) + SHA1
28 : A combined mode of operation using AES(CTR) + SHA1
29 : A combined mode of operation using ARC4 + WEP CRC on XScale
30 : A combined mode of operation using ARC4 + WEP CRC on WAN-NPE
31 : PKE RNG pseudo-random number
32 : PKE SHA1 hashing operation
```

```
33 : PKE EAU modular exponential operation
34 : PKE EAU large number modular reduction operation
35 : PKE EAU large number addition operation
36 : PKE EAU large number subtraction operation
37 : PKE EAU large number multiplication operation
```

Where dataBLenOrOprWLen (data byte length or operand word length):

Data length ranges from 64 bytes to 65456 bytes, if cipher
algorithm is DES/3DES, data length must be multiple of 8-byte
(cipher block length); while AES algorithm must have data length
that is multiple of 16-byte in size. For ARC4 algorithm block length
there is no such restriction (because block size is 1 byte).

If cipher mode is CCM, there is no restriction on the data length
being a multiple of cipher block length.

For PKE EAU, RNG and SHA operands' range, please refer to the <code>IxCryptoAcc.h</code> file.

```
For EAU operation, each operand length allocates 8 bits. All others operations take the whole word of dataBLenOrOprWLen.

For example: WLen = 0x00ccbbaa.

modular exponential: aa is M, bb is N, and cc is e large number modular reduction: aa is A, bb is N large number add/sub/mul: aa is A, bb is B others: 0x00ccbbaa
```

### Linux\* User Guide

The ixCryptoAccCodeletMain() is the entry point of cryptoAcc codelet.

The selected operation will be executed when user issues 'insmod' at command prompt.

#### Usage :

>insmod ixp400\_codelets\_cryptoAcc.o serviceIndex= dataBLenOrOprWLen=
Where x should be one of the following numbers:

```
0 : Lists all set of services demonstrated.

1 : Encryption and Decryption using DES(ECB)

2 : Encryption and Decryption using DES(CBC)

3 : Encryption and Decryption using 3DES(ECB)

4 : Encryption and Decryption using 3DES(CBC)

5 : Encryption and Decryption using AES(ECB)

6 : Encryption and Decryption using AES(CBC)

7 : Encryption and Decryption using AES(CTR)

8 : Encryption and Decryption using AES-CCM

9 : Encryption and Decryption using ARC4 on XScale

10 : Encryption and Decryption using ARC4 on WAN-NPE

11 : Authentication calculation and verification using MD5
```

```
12 : Authentication calculation and verification using SHA1
13 : Authentication calculation and verification WEP CRC on XScale
14 : Authentication calculation and verification WEP CRC on WAN-NPE
15 : A combined mode of operation using DES(ECB) + MD5
16 : A combined mode of operation using DES(CBC) + MD5
17 : A combined mode of operation using DES(ECB) + SHA1
18 : A combined mode of operation using DES(CBC) + SHA1
19 : A combined mode of operation using 3DES(ECB) + MD5
20 : A combined mode of operation using 3DES(CBC) + MD5
21 : A combined mode of operation using 3DES(ECB) + SHA1
22 : A combined mode of operation using 3DES(CBC) + SHA1
23 : A combined mode of operation using AES(ECB) + MD5
24 : A combined mode of operation using AES(CBC) + MD5
25 : A combined mode of operation using AES(CTR) + MD5
26 : A combined mode of operation using AES(ECB) + SHA1
27 : A combined mode of operation using AES(CBC) + SHA1
28 : A combined mode of operation using AES(CTR) + SHA1
29 : A combined mode of operation using ARC4 + WEP CRC on XScale
30 : A combined mode of operation using ARC4 + WEP CRC on WAN-NPE
31 : PKE RNG pseudo-random number
32 : PKE SHA1 hashing operation
33 : PKE EAU modular exponential operation
34 : PKE EAU large number modular reduction operation
35 : PKE EAU large number addition operation
36 : PKE EAU large number subtraction operation
37 : PKE EAU large number multiplication operation
```

Where dataBLenOrOprWLen (data byte length or operand word length):

Data length ranges from 64 bytes to 65456 bytes, if cipher
algorithm is DES/3DES, data length must be multiple of 8-byte
(cipher block length); while AES algorithm must have data length
that is multiple of 16-byte in size. For ARC4 algorithm block length
there is no such restriction (because block size is 1 byte).

If cipher mode is CCM, there is no restriction on the data length
being a multiple of cipher block length.

For PKE EAU, RNG and SHA operands' range, please refer to the <code>IxCryptoAcc.h</code> file.

```
For EAU operation, each operand length allocates 8 bits. All other operations take the whole word of dataBLenOrOprWLen. For example: WLen = 0x00ccbbaa. modular exponential: aa is M, bb is N, and cc is e large number modular reduction: aa is A, bb is N large number add/sub/mul: aa is A, bb is B others: 0x00ccbbaa
```

### **Define Documentation**

### #define IX\_CRYPTO\_ACC\_CODELET\_MAX\_COUNT

Maximum counter to wait before exiting the program.

Definition at line 456 of file IxCryptoAccCodelet.h.

### #define IX\_CRYPTO\_ACC\_CODELET\_PKE\_EAU\_TOTAL\_OP

Total Pke Eau operation for one window size.

Definition at line **466** of file **IxCryptoAccCodelet.h**.

### #define IX\_CRYPTO\_ACC\_CODELET\_PKE\_PERFORM\_WAIT\_TIME

Maximum time (in ms) to wait before exiting the program.

Definition at line **446** of file **IxCryptoAccCodelet.h**.

### #define IX\_CRYPTO\_ACC\_CODELET\_PKE\_TOTAL\_OP

Total Pke RNG/SHA operation for one window size.

Definition at line **476** of file **IxCryptoAccCodelet.h**.

### #define IX\_CRYPTO\_ACC\_CODELET\_SLEEP\_WAIT

Delay time (in ms) for printf to avoid rpc error.

Definition at line **486** of file **IxCryptoAccCodelet.h**.

### #define IX\_CRYPTOACC\_CODELET\_BATCH\_LEN

Number of packets/requests per sampling for performance benchmarking.

Definition at line **374** of file **IxCryptoAccCodelet.h**.

### #define IX\_CRYPTOACC\_CODELET\_CRYPTO\_MBUF\_POOL\_SIZE

Size of MBuf pool, ie number of buffers to circulate.

Definition at line **359** of file **IxCryptoAccCodelet.h**.

### #define IX\_CRYPTOACC\_CODELET\_CRYPTOACC\_CFG

Selects the interface's (to the NPE) to be initialized by the codelet. Use one of the values defined in

IxCryptoAccCfg. IX\_CRYPTO\_ACC\_CFG\_CRYPTO\_WEP\_NPE\_ACC\_EN: Enable's access to the Crypto NPE and WEP NPE.

Definition at line **306** of file **IxCryptoAccCodelet.h**.

### #define IX\_CRYPTOACC\_CODELET\_MAX\_CRYPTO\_PKT\_SIZE

The maximum packet/data size.

Definition at line **506** of file **IxCryptoAccCodelet.h**.

### #define IX\_CRYPTOACC\_CODELET\_MAX\_TIME\_WAIT

Maximum time (in ms) to wait before exiting the program.

Definition at line **436** of file **IxCryptoAccCodelet.h**.

### #define IX\_CRYPTOACC\_CODELET\_MIN\_CRYPTO\_PKT\_SIZE

The minimum packet/data size.

Definition at line 496 of file IxCryptoAccCodelet.h.

### #define IX\_CRYPTOACC\_CODELET\_NPEA\_IMAGE\_ID

The build ID for NPE A image, default is IX\_NPEDL\_NPEIMAGE\_NPEA\_WEP.

Note:

Please refer to **IxNpeDl.h** for NPE image definition

Definition at line **333** of file **IxCryptoAccCodelet.h**.

#### #define IX CRYPTOACC CODELET NPEC IMAGE ID

The build ID for NPE C image, default is IX NPEDL NPEIMAGE NPEC CRYPTO AES CCM ETH.

Note:

Please refer to IxNpeDl.h for NPE image definition

Definition at line **320** of file **IxCryptoAccCodelet.h**.

### #define IX\_CRYPTOACC\_CODELET\_PERFORM\_WAIT\_TIME

The codelet perform wait time (in ms) in a for loop.

Definition at line 426 of file IxCryptoAccCodelet.h.

### #define IX\_CRYPTOACC\_CODELET\_QMGR\_DISPATCHER\_MODE

QMgr Dispatcher Mode, whether in interrupt (TRUE) or poll (FALSE) mode.

#### Note:

- 1. QMgr dispatcher can be run in both poll mode and interrupt mode in vxWorks platform.
- 2. In linux platform (with Linux\* kernel 2.4 and below), QMgr Dispatcher is NOT advisible to run in poll mode. Task scheduling in poll mode runs tasks sequentially (non-preemptive) that cause the performance rate to drop tremendously. Thus the performance rate displayed in Linux\* platform using poll mode is not accurate. Performance rate is more accurate when QMgr dispatcher is running in interrupt mode.

Definition at line **532** of file **IxCryptoAccCodelet.h**.

### #define IX\_CRYPTOACC\_CODELET\_QMGR\_DISPATCHER\_PRIORITY

Recommended priority of queue manager dispatch loop.

Definition at line **384** of file **IxCryptoAccCodelet.h**.

#### #define IX\_CRYPTOACC\_CODELET\_QMGR\_DISPATCHER\_THREAD\_STACK\_SIZE

Recommended stack size for queue manager dispatcher thread.

Definition at line **394** of file **IxCryptoAccCodelet.h**.

### #define IX\_CRYPTOACC\_CODELET\_REGISTER\_WAIT\_TIME

The codelet register wait time (in ms) in a for loop.

Definition at line 416 of file IxCryptoAccCodelet.h.

### #define IX\_CRYPTOACC\_CODELET\_XSCALE\_TICK

The XScale tick is 66 MHz. The ixOsalOsIxp400TimestampResolutionGet() function returns 66666666, thus need to divide by a million.

Definition at line **405** of file **IxCryptoAccCodelet.h**.

### #define IX CRYPTOACC PKE EAU EXP CONFIG FE MODE

Set the PKE EAU modular exponential configuration for fast exponent.

Definition at line **543** of file **IxCryptoAccCodelet.h**.

### #define IX\_CRYPTOACC\_PKE\_EAU\_EXP\_CONFIG\_SE\_MODE

Set the PKE EAU modular exponential configuration for short exponent.

Definition at line **553** of file **IxCryptoAccCodelet.h**.

### #define PERFORMANCE\_WINDOW\_SIZE

Number of crypto packets/requests need to be sent in for performance benchmarking (sampling size), 1 unit represents 1000 of requests (100 requests for EAU).

Definition at line **349** of file **IxCryptoAccCodelet.h**.

### **Function Documentation**

This is the entry point function to the codelet to choose the service for the codelet and data/operand length to be used. This is the main function of the codelet where crypto contexts registration and crypto perform services are done. Based on the selected operation and length, data/operands are sent to cryptoAcc for processing.

#### Parameters:

srvIndex

INT32 [in] – type of service to be invoked choose from one of the following pre–configured values.

```
0 : Lists all set of services demonstrated.
1 : Encryption and Decryption using DES(ECB)
2 : Encryption and Decryption using DES(CBC)
3 : Encryption and Decryption using 3DES(ECB)
4 : Encryption and Decryption using 3DES(CBC)
5 : Encryption and Decryption using AES(ECB)
6 : Encryption and Decryption using AES(CBC)
7 : Encryption and Decryption using AES(CTR)
8 : Encryption and Decryption using AES-CCM
9 : Encryption and Decryption using ARC4 on XScale
10 : Encryption and Decryption using ARC4 on WAN-NPE
11 : Authentication calculation and verification using MD5
12 : Authentication calculation and verification wEP CRC on XScale
13 : Authentication calculation and verification WEP CRC on WAN
14 : Authentication calculation and verification WEP CRC on WAN
```

Function Documentation 619

```
15 : A combined mode of operation using DES(ECB) + MD5
16 : A combined mode of operation using DES(CBC) + MD5
17 : A combined mode of operation using DES(ECB) + SHA1
18 : A combined mode of operation using DES(CBC) + SHA1
19: A combined mode of operation using 3DES(ECB) + MD5
20 : A combined mode of operation using 3DES(CBC) + MD5
21 : A combined mode of operation using 3DES(ECB) + SHA1
22 : A combined mode of operation using 3DES(CBC) + SHA1
23 : A combined mode of operation using AES(ECB) + MD5
24 : A combined mode of operation using AES(CBC) + MD5
25 : A combined mode of operation using AES(CTR) + MD5
26 : A combined mode of operation using AES(ECB) + SHA1
27 : A combined mode of operation using AES(CBC) + SHA1
28 : A combined mode of operation using AES(CTR) + SHA1
29 : A combined mode of operation using ARC4 + WEP CRC on XScal
30 : A combined mode of operation using ARC4 + WEP CRC on WAN-N
31 : PKE RNG pseudo-random number
32 : PKE SHA1 hashing operation
33 : PKE EAU modular exponential operation
34 : PKE EAU large number modular reduction operation
35 : PKE EAU large number addition operation
36 : PKE EAU large number subtraction operation
37 : PKE EAU large number multiplication operation
```

dataBLenOrOprWLenUINT32 [in] - data length in bytes or operand length in words

### Returns:

Function Documentation 620

### **ChannelisedStats Struct Reference**

ingroup IxHssAccCodeletCom

### **Data Fields**

UINT32 txSamples

UINT32 txBytes

UINT32 rxSamples

UINT32 rxBytes

UINT32 rxIdles

UINT32 rxVerifyFails

UINT32 connectFails

UINT32 portEnableFails

UINT32 portDisableFails

UINT32 disconnectFails

## **Detailed Description**

ingroup IxHssAccCodeletCom

brief Type definition structure for channelised statistics

Definition at line 93 of file IxHssAccCodeletCom.h.

The documentation for this struct was generated from the following file:

• IxHssAccCodeletCom.h

### **GeneralStats Struct Reference**

ingroup IxHssAccCodeletCom

### **Data Fields**

UINT32 portInitFails

UINT32 errorRetrievalFails

UINT32 txFrmSyncErrors

UINT32 rxFrmSyncErrors

UINT32 txOverRunErrors

UINT32 rxOverRunErrors

UINT32 chanSwTxErrors

UINT32 chanSwRxErrors

UINT32 pktSwTxErrors

UINT32 pktSwRxErrors

UINT32 unrecognisedErrors

## **Detailed Description**

ingroup IxHssAccCodeletCom

brief Type definition structure for general statistics

Definition at line **69** of file **IxHssAccCodeletCom.h**.

The documentation for this struct was generated from the following file:

• IxHssAccCodeletCom.h

### IxAtmCodeletStats Struct Reference

Codelet statistics.

### **Data Fields**

UINT32 txPdus

UINT32 txBytes

UINT32 rxPdus

UINT32 rxBytes

UINT32 txDonePdus

UINT32 rxFreeBuffers

UINT32 txPdusSubmitFail

UINT32 txPdusSubmitBusy

UINT32 rxPdusInvalid

# **Detailed Description**

Codelet statistics.

Definition at line 118 of file IxAtmCodelet\_p.h.

The documentation for this struct was generated from the following file:

• IxAtmCodelet\_p.h

# IxAtmdAccUtopiaConfig Struct Reference

# [Intel (R) IXP400 Software ATM Driver Access (IxAtmdAcc) Utopia Control API]

Utopia configuration.

### **Data Fields**

IxAtmdAccUtopiaConfig::UtTxConfig\_utTxConfig

Tx config Utopia register.

IxAtmdAccUtopiaConfig::UtTxStatsConfig\_utTxStatsConfig

Tx stats config Utopia register.

IxAtmdAccUtopiaConfig::UtTxDefineIdle\_utTxDefineIdle

Tx idle cell config Utopia register.

 $IxAtmdAccUtopia Config:: UtTxEnable Fields\_utTxEnable Fields$ 

Tx enable Utopia register.

IxAtmdAccUtopiaConfig::UtTxTransTable0 utTxTransTable0

Tx translation table.

IxAtmdAccUtopiaConfig::UtTxTransTable1\_utTxTransTable1

*Tx translation table.* 

IxAtmdAccUtopiaConfig::UtTxTransTable2\_utTxTransTable2

*Tx translation table.* 

IxAtmdAccUtopiaConfig::UtTxTransTable3\_utTxTransTable3

*Tx translation table.* 

 $IxAtmdAccUtopiaConfig:: UtTxTransTable 4\_utTxTransTable 4\\$ 

Tx translation table.

IxAtmdAccUtopiaConfig::UtTxTransTable5 utTxTransTable5

Tx translation table.

IxAtmdAccUtopiaConfig::UtRxConfig\_utRxConfig

Rx config Utopia register.

IxAtmdAccUtopiaConfig::UtRxStatsConfig\_utRxStatsConfig

Rx stats config Utopia register.

IxAtmdAccUtopiaConfig::UtRxDefineIdle\_utRxDefineIdle

Rx idle cell config Utopia register.

IxAtmdAccUtopiaConfig::UtRxEnableFields\_utRxEnableFields

Rx enable Utopia register.

 $IxAtmdAccUtopiaConfig:: UtRxTransTable 0\_utRxTransTable 0$ 

Rx translation table.

 $IxAtmdAccUtopiaConfig:: UtRxTransTable 1\_utRxTransTable 1\\$ 

Rx translation table.

 $IxAtmdAccUtopiaConfig:: UtRxTransTable 2\_utRxTransTable 2\\$ 

Rx translation table.

 $IxAtmdAccUtopiaConfig:: UtRxTransTable 3\_utRxTransTable 3$ 

Rx translation table.

IxAtmdAccUtopiaConfig::UtRxTransTable4\_utRxTransTable4

Rx translation table.

IxAtmdAccUtopiaConfig::UtRxTransTable5\_utRxTransTable5

Rx translation table.

 $IxAtmdAccUtopiaConfig:: UtSysConfig\_utSysConfig\_$ 

NPE debug config.

### **Detailed Description**

Utopia configuration.

This structure is used to set the Utopia parameters

- contains the values of Utopia registers, to be set during initialisation
- contains debug commands for NPE, to be used during development steps

Note:

– the exact description of all parameters is done in the Utopia reference documents.

Definition at line **979** of file **IxAtmdAccCtrl.h**.

### **Field Documentation**

struct IxAtmdAccUtopiaConfig::UtRxConfig\_ IxAtmdAccUtopiaConfig::utRxConfig

Rx config Utopia register.

struct IxAtmdAccUtopiaConfig::UtRxDefineIdle\_ IxAtmdAccUtopiaConfig::utRxDefineIdle

Detailed Description 625

Rx idle cell config Utopia register. struct IxAtmdAccUtopiaConfig::UtRxEnableFields\_IxAtmdAccUtopiaConfig::utRxEnableFields Rx enable Utopia register. struct IxAtmdAccUtopiaConfig::UtRxStatsConfig\_IxAtmdAccUtopiaConfig::utRxStatsConfig Rx stats config Utopia register. struct IxAtmdAccUtopiaConfig::UtRxTransTable0\_ IxAtmdAccUtopiaConfig::utRxTransTable0 Rx translation table. struct IxAtmdAccUtopiaConfig::UtRxTransTable1\_ IxAtmdAccUtopiaConfig::utRxTransTable1 Rx translation table. struct IxAtmdAccUtopiaConfig::UtRxTransTable2\_ IxAtmdAccUtopiaConfig::utRxTransTable2 Rx translation table. struct IxAtmdAccUtopiaConfig::UtRxTransTable3\_ IxAtmdAccUtopiaConfig::utRxTransTable3 Rx translation table. struct IxAtmdAccUtopiaConfig::UtRxTransTable4 IxAtmdAccUtopiaConfig::utRxTransTable4 Rx translation table. struct IxAtmdAccUtopiaConfig::UtRxTransTable5\_ IxAtmdAccUtopiaConfig::utRxTransTable5 Rx translation table. struct IxAtmdAccUtopiaConfig::UtSysConfig\_ IxAtmdAccUtopiaConfig::utSysConfig

Detailed Description 626

NPE debug config.

struct IxAtmdAccUtopiaConfig::UtTxConfig IxAtmdAccUtopiaConfig::utTxConfig Tx config Utopia register. struct IxAtmdAccUtopiaConfig::UtTxDefineIdle\_IxAtmdAccUtopiaConfig::utTxDefineIdle Tx idle cell config Utopia register. struct IxAtmdAccUtopiaConfig::UtTxEnableFields\_ IxAtmdAccUtopiaConfig::utTxEnableFields Tx enable Utopia register. struct IxAtmdAccUtopiaConfig::UtTxStatsConfig\_IxAtmdAccUtopiaConfig::utTxStatsConfig Tx stats config Utopia register. struct IxAtmdAccUtopiaConfig::UtTxTransTable0 IxAtmdAccUtopiaConfig::utTxTransTable0 Tx translation table. struct IxAtmdAccUtopiaConfig::UtTxTransTable1\_ IxAtmdAccUtopiaConfig::utTxTransTable1 Tx translation table. struct IxAtmdAccUtopiaConfig::UtTxTransTable2\_ IxAtmdAccUtopiaConfig::utTxTransTable2 Tx translation table. struct IxAtmdAccUtopiaConfig::UtTxTransTable3\_ IxAtmdAccUtopiaConfig::utTxTransTable3 Tx translation table. struct IxAtmdAccUtopiaConfig::UtTxTransTable4\_ IxAtmdAccUtopiaConfig::utTxTransTable4 Tx translation table. struct IxAtmdAccUtopiaConfig::UtTxTransTable5\_ IxAtmdAccUtopiaConfig::utTxTransTable5

The documentation for this struct was generated from the following file:

### • IxAtmdAccCtrl.h

# IxAtmdAccUtopiaConfig::UtRxConfig\_ Struct Reference

## [Intel (R) IXP400 Software ATM Driver Access (IxAtmdAcc) Utopia Control API]

Utopia Rx config Register.

### **Data Fields**

```
unsigned
     int rxInterface:1
        [31] Utopia Receive Interface
unsigned
     int rxMode:1
        [30] Utopia Receive Mode
unsigned
     int rxOctet:1
        [29] Utopia Receive cell transfer protocol
unsigned
     int rxParity:1
        [28] Utopia Receive Parity Checking enable
unsigned
     int rxEvenParity:1
        [27] Utopia Receive Parity Mode
              • 1 − Check for Even Parity
              • 0 – Check for Odd Parity.
unsigned
     int rxHEC:1
        [26] RxHEC Header Error Check Mode
unsigned
     int rxCOSET:1
        [25] If enabled the HEC is Exclusive-ORÆed with the value 0x55 before being tested with the
        received HEC
unsigned
     int rxHECpass:1
        [24] Specifies if the incoming cell HEC byte should be transferred after optional processing to the
```

#### unsigned

#### int reserved 1:1

[23] These bits are always 0

#### unsigned

#### int rxCellSize:7

[22:16] Receive cell size

#### unsigned

#### int rxHashEnbGFC:1

[15] Specifies if the VPI field [11:8]/GFC field should be included in the Hash data input or if the bits should be padded with 1Æb0

#### unsigned

#### int rxPreHash:1

[14] Enable Pre-hash value generation

#### unsigned

#### int reserved\_2:1

[13] These bits are always 0

#### unsigned

#### int **rxAddrRange**:5

[12:8] In ATM master, MPHY mode, this register specifies the upper limit of the PHY polling logical range

#### unsigned

#### int reserved\_3:3

[7–5] These bits are always 0.

#### unsigned

#### int rxPHYAddr:5

[4:0] When configured as a slave in an MPHY system this register specifies the physical address of the PHY

## **Detailed Description**

Utopia Rx config Register.

Definition at line 1316 of file IxAtmdAccCtrl.h.

## **Field Documentation**

unsigned int IxAtmdAccUtopiaConfig::UtRxConfig\_::reserved\_1

[23] These bits are always 0

Definition at line 1359 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtRxConfig\_::reserved\_2

[13] These bits are always 0

Definition at line 1376 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtRxConfig\_::reserved\_3

[7-5] These bits are always 0.

Definition at line **1383** of file **IxAtmdAccCtrl.h**.

unsigned int IxAtmdAccUtopiaConfig::UtRxConfig\_::rxAddrRange

[12:8] In ATM master, MPHY mode, this register specifies the upper limit of the PHY polling logical range

The number of active PHYs are RxAddrRange + 1.

Definition at line 1378 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtRxConfig\_::rxCellSize

[22:16] Receive cell size

Configures the receive cell size. Values between 52–64 are valid

Definition at line 1361 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtRxConfig\_::rxCOSET

[25] If enabled the HEC is Exclusive–ORÆed with the value 0x55 before being tested with the received HEC

- 1 Enable HEC ExOR with value 0x55.
- 0 Use generated HEC value.

Definition at line 1348 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtRxConfig\_::rxEvenParity

#### [27] Utopia Receive Parity Mode

- 1 Check for Even Parity
- 0 Check for Odd Parity.

Definition at line 1339 of file IxAtmdAccCtrl.h.

#### unsigned int IxAtmdAccUtopiaConfig::UtRxConfig\_::rxHashEnbGFC

[15] Specifies if the VPI field [11:8]/GFC field should be included in the Hash data input or if the bits should be padded with 1Æb0

- 1 VPI [11:8]/GFC field valid and used in Hash residue calculation.
- 0 VPI [11:8]/GFC field padded with 1Æb0

Definition at line 1364 of file IxAtmdAccCtrl.h.

#### unsigned int IxAtmdAccUtopiaConfig::UtRxConfig\_::rxHEC

[26] RxHEC Header Error Check Mode

Enables/disables cell header error checking on the received cell header.

- 1 HEC checking enabled
- 0 HEC checking disabled

Definition at line 1343 of file IxAtmdAccCtrl.h.

#### unsigned int IxAtmdAccUtopiaConfig::UtRxConfig ::rxHECpass

[24] Specifies if the incoming cell HEC byte should be transferred after optional processing to the NPE2 Coprocessor Bus Interface or if it should be discarded

- 1 HEC maintained 53-byte/UDC cell sent to NPE2.
- 0 HEC discarded 52–byte/UDC cell sent to NPE2 coprocessor.

Definition at line 1353 of file IxAtmdAccCtrl.h.

#### unsigned int IxAtmdAccUtopiaConfig::UtRxConfig\_::rxInterface

#### [31] Utopia Receive Interface

The following encoding is used to set the Utopia Receive interface as ATM master or PHY slave:

• 1 - PHY

 $\bullet 0 - ATM$ 

Definition at line 1319 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtRxConfig\_::rxMode

[30] Utopia Receive Mode

The following encoding is used to set the Utopia Receive mode to SPHY or MPHY:

- 1 − SPHY
- 0 MPHY

Definition at line 1324 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtRxConfig\_::rxOctet

[29] Utopia Receive cell transfer protocol

Used to set the Utopia cell transfer protocol to Octet-level handshaking. Note this is only applicable in SPHY mode.

- 1 Octet–handshaking enabled
- 0 Cell–handshaking enabled

Definition at line 1329 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtRxConfig\_::rxParity

[28] Utopia Receive Parity Checking enable

- 1 Parity checking enabled
- 0 Parity checking disabled

Definition at line 1335 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtRxConfig\_::rxPHYAddr

[4:0] When configured as a slave in an MPHY system this register specifies the physical address of the PHY

Definition at line 1384 of file IxAtmdAccCtrl.h.

 $unsigned\ int\ IxAtmdAccUtopiaConfig::UtRxConfig\_::rxPreHash$ 

#### [14] Enable Pre-hash value generation

Specifies if the incoming cell data should be pre-hashed to allow VPI/VCI header look-up in a hash table.

- 1 Pre–hashing enabled
- 0 Pre–hashing disabled

#### Definition at line 1370 of file IxAtmdAccCtrl.h.

The documentation for this struct was generated from the following file:

#### • IxAtmdAccCtrl.h

# IxAtmdAccUtopiaConfig::UtRxDefineIdle\_ Struct Reference

## [Intel (R) IXP400 Software ATM Driver Access (IxAtmdAcc) Utopia Control API]

Utopia Rx idle cells config Register.

### **Data Fields**

unsigned int **vpi**:12 [31:20] ATM VPI [11:0] OR GFC [3:0] and VPI [7:0]

• Note: if VCIdleRxGFC is set to 0 the GFC field is ignored in test

unsigned int **vci**:16 [19:4] ATM VCI [15:0]

unsigned int pti:3

[3:1] ATM PTI PTI [2:0]

• Note: if VCIdleRxPTI is set to 0 the PTI field is ignored in test.

unsigned int **clp**:1

[0] ATM CLP [0]

• Note: if VCIdleRxCLP is set to 0 the CLP field is ignored in test.

## **Detailed Description**

Utopia Rx idle cells config Register.

Definition at line 1418 of file IxAtmdAccCtrl.h.

## **Field Documentation**

unsigned int IxAtmdAccUtopiaConfig::UtRxDefineIdle\_::clp

[0] ATM CLP [0]

• Note: if VCIdleRxCLP is set to 0 the CLP field is ignored in test.

Definition at line 1429 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtRxDefineIdle\_::pti

[3:1] ATM PTI PTI [2:0]

• Note: if VCIdleRxPTI is set to 0 the PTI field is ignored in test.

Definition at line 1426 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtRxDefineIdle\_::vci

[19:4] ATM VCI [15:0]

Definition at line 1424 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtRxDefineIdle\_::vpi

[31:20] ATM VPI [11:0] OR GFC [3:0] and VPI [7:0]

• Note: if VCIdleRxGFC is set to 0 the GFC field is ignored in test

Definition at line 1421 of file IxAtmdAccCtrl.h.

The documentation for this struct was generated from the following file:

• IxAtmdAccCtrl.h

Field Documentation 636

## IxAtmdAccUtopiaConfig::UtRxEnableFields\_ Struct Reference

## [Intel (R) IXP400 Software ATM Driver Access (IxAtmdAcc) Utopia Control API]

Utopia Rx enable Register.

### **Data Fields**

#### unsigned

#### int defineRxIdleGFC:1

[31] This register is used to include or exclude the GFC field of the ATM header when testing for Idle cells

#### unsigned

#### int defineRxIdlePTI:1

[30] This register is used to include or exclude the PTI field of the ATM header when testing for Idle cells

#### unsigned

#### int defineRxIdleCLP:1

[29] This register is used to include or exclude the CLP field of the ATM header when testing for Idle cells

#### unsigned

#### int phyStatsRxEnb:1

[28] This register is used to enable or disable ATM statistics gathering based on the specified PHY address as defined in RxStatsConfig register

#### unsigned

#### int vcStatsRxEnb:1

[27] This register is used to enable or disable ATM statistics gathering based on a specific VPI/VCI address

#### unsigned

#### int vcStatsRxGFC:1

[26] This register is used to include or exclude the GFC field of the ATM header when ATM VPI/VCI statistics are enabled

#### unsigned

#### int vcStatsRxPTI:1

[25] This register is used to include or exclude the PTI field of the ATM header when ATM VPI/VCI statistics are enabled

#### unsigned

#### int vcStatsRxCLP:1

[24] This register is used to include or exclude the CLP field of the ATM header when ATM VPI/VCI statistics are enabled

#### unsigned

#### int discardHecErr:1

[23] Discard cells with an invalid HEC

#### unsigned

#### int discardParErr:1

[22] Discard cells containing parity errors

#### unsigned

#### int discardIdle:1

[21] Discard Idle Cells based on DefineIdle register values

- 1 Discard IDLE cells
- 0 IDLE cells passed

#### unsigned

#### int enbHecErrCnt:1

[20] Enable Receive HEC Error Count

#### unsigned

#### int enbParErrCnt:1

[19] Enable Parity Error Count

- 1 Enable count of received cells containing Parity errors
- 0 No count is maintained

#### unsigned

#### int enbIdleCellCnt:1

[18] Enable Receive Idle Cell Count

#### unsigned

#### int enbSizeErrCnt:1

[17] Enable Receive Size Error Count

#### unsigned

#### int enbRxCellCnt:1

[16] Enable Receive Valid Cell Count of non-idle/non-error cells

#### unsigned

#### int reserved\_1:3

[15:13] These bits are always 0

#### unsigned

#### int rxCellOvrInt:1

[12] Enable CBI Utopia Receive Status Condition if the RxCellCount register overflows

unsigned

#### int invalidHecOvrInt:1

[11] Enable CBI Receive Status Condition if the InvalidHecCount register overflows

unsigned

#### int invalidParOvrInt:1

[10] Enable CBI Receive Status Condition if the InvalidParCount register overflows

• 1 – CBI Receive Condition asserted

unsigned

#### int invalidSizeOvrInt:1

[9] Enable CBI Receive Status Condition if the InvalidSizeCount register overflows

unsigned

#### int rxIdleOvrInt:1

[8] Enable CBI Receive Status Condition if the RxIdleCount overflows

unsigned

#### int reserved\_2:3

[7:5] These bits are always 0

unsigned

#### int rxAddrMask:5

[4:0] This register is used as a mask to allow the user to increase the PHY receive address range

## **Detailed Description**

Utopia Rx enable Register.

Definition at line 1438 of file IxAtmdAccCtrl.h.

## **Field Documentation**

unsigned int IxAtmdAccUtopiaConfig::UtRxEnableFields\_::defineRxIdleCLP

[29] This register is used to include or exclude the CLP field of the ATM header when testing for Idle cells

- 1 CLP field is valid.
- 0 CLP field ignored.

Definition at line 1451 of file IxAtmdAccCtrl.h.

#### unsigned int IxAtmdAccUtopiaConfig::UtRxEnableFields ::defineRxIdleGFC

- [31] This register is used to include or exclude the GFC field of the ATM header when testing for Idle cells
  - 1 GFC field is valid.
  - 0 GFC field ignored.

Definition at line 1441 of file IxAtmdAccCtrl.h.

#### unsigned int IxAtmdAccUtopiaConfig::UtRxEnableFields\_::defineRxIdlePTI

- [30] This register is used to include or exclude the PTI field of the ATM header when testing for Idle cells
  - 1 PTI field is valid.
  - 0 PTI field ignored.

Definition at line 1446 of file IxAtmdAccCtrl.h.

#### unsigned int IxAtmdAccUtopiaConfig::UtRxEnableFields\_::discardHecErr

- [23] Discard cells with an invalid HEC
  - 1 Discard cells with HEC errors
  - 0 Cells with HEC errors are passed

Definition at line 1483 of file IxAtmdAccCtrl.h.

#### unsigned int IxAtmdAccUtopiaConfig::UtRxEnableFields\_::discardIdle

- [21] Discard Idle Cells based on DefineIdle register values
  - 1 Discard IDLE cells
  - 0 IDLE cells passed

Definition at line 1491 of file IxAtmdAccCtrl.h.

#### $unsigned\ int\ IxAtmdAccUtopiaConfig:: UtRxEnableFields\_:: discardParErr$

- [22] Discard cells containing parity errors
  - 1 Discard cells with parity errors
  - 0 Cells with parity errors are passed

Definition at line **1487** of file **IxAtmdAccCtrl.h**.

#### unsigned int IxAtmdAccUtopiaConfig::UtRxEnableFields ::enbHecErrCnt

- [20] Enable Receive HEC Error Count
  - 1 Enable count of received cells containing HEC errors
  - 0 No count is maintained.

Definition at line 1495 of file IxAtmdAccCtrl.h.

#### unsigned int IxAtmdAccUtopiaConfig::UtRxEnableFields\_::enbIdleCellCnt

- [18] Enable Receive Idle Cell Count
  - 1 Enable count of Idle cells received.
  - 0 No count is maintained.

Definition at line 1503 of file IxAtmdAccCtrl.h.

#### unsigned int IxAtmdAccUtopiaConfig::UtRxEnableFields\_::enbParErrCnt

- [19] Enable Parity Error Count
  - 1 Enable count of received cells containing Parity errors
  - 0 No count is maintained

Definition at line 1499 of file IxAtmdAccCtrl.h.

#### unsigned int IxAtmdAccUtopiaConfig::UtRxEnableFields\_::enbRxCellCnt

- [16] Enable Receive Valid Cell Count of non-idle/non-error cells
  - 1 Enable count of valid cells received non–idle/non–error
  - 0 No count is maintained.

Definition at line 1511 of file IxAtmdAccCtrl.h.

#### $unsigned\ int\ IxAtmdAccUtopiaConfig:: UtRxEnableFields\_::enbSizeErrCnt$

- [17] Enable Receive Size Error Count
  - 1 Enable count of received cells of incorrect size

• 0 – No count is maintained.

Definition at line 1507 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtRxEnableFields\_::invalidHecOvrInt

- [11] Enable CBI Receive Status Condition if the InvalidHecCount register overflows
  - 1 CBI Receive Condition asserted.
  - 0 No CBI Receive Condition asserted

Definition at line 1522 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtRxEnableFields\_::invalidParOvrInt

- [10] Enable CBI Receive Status Condition if the InvalidParCount register overflows
  - 1 CBI Receive Condition asserted
  - 0 No CBI Receive Condition asserted

Definition at line 1527 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtRxEnableFields\_::invalidSizeOvrInt

- [9] Enable CBI Receive Status Condition if the InvalidSizeCount register overflows
  - 1 CBI Receive Status Condition asserted.
  - 0 No CBI Receive Status asserted

Definition at line 1532 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtRxEnableFields\_::phyStatsRxEnb

- [28] This register is used to enable or disable ATM statistics gathering based on the specified PHY address as defined in RxStatsConfig register
  - 1 Enable statistics for specified receive PHY address.
  - 0 Disable statistics for specified receive PHY address.

Definition at line 1456 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtRxEnableFields\_::reserved\_1

[15:13] These bits are always 0

Definition at line 1515 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtRxEnableFields\_::reserved\_2

[7:5] These bits are always 0

Definition at line 1541 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtRxEnableFields\_::rxAddrMask

[4:0] This register is used as a mask to allow the user to increase the PHY receive address range

The register should be programmed with the address–range limit, i.e. if set to 0x3 the address range increases to a maximum of 4 addresses.

Definition at line 1543 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtRxEnableFields\_::rxCellOvrInt

- [12] Enable CBI Utopia Receive Status Condition if the RxCellCount register overflows
  - 1 CBI Receive Status asserted.
  - 0 No CBI Receive Status asserted.

Definition at line 1517 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtRxEnableFields\_::rxIdleOvrInt

- [8] Enable CBI Receive Status Condition if the RxIdleCount overflows
  - 1 CBI Receive Condition asserted.
  - 0 No CBI Receive Condition asserted

Definition at line 1537 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtRxEnableFields\_::vcStatsRxCLP

- [24] This register is used to include or exclude the CLP field of the ATM header when ATM VPI/VCI statistics are enabled
  - 1 CLP field is valid.
  - 0 CLP field ignored.

#### Definition at line 1478 of file IxAtmdAccCtrl.h.

#### unsigned int IxAtmdAccUtopiaConfig::UtRxEnableFields\_::vcStatsRxEnb

[27] This register is used to enable or disable ATM statistics gathering based on a specific VPI/VCI address

- 1 Enable statistics for specified VPI/VCI address.
- 0 Disable statistics for specified VPI/VCI address.

Definition at line 1462 of file IxAtmdAccCtrl.h.

#### unsigned int IxAtmdAccUtopiaConfig::UtRxEnableFields\_::vcStatsRxGFC

[26] This register is used to include or exclude the GFC field of the ATM header when ATM VPI/VCI statistics are enabled

GFC is only available at the UNI and uses the first 4–bits of the VPI field.

- 1 GFC field is valid.
- 0 GFC field ignored.

Definition at line 1467 of file IxAtmdAccCtrl.h.

#### unsigned int IxAtmdAccUtopiaConfig::UtRxEnableFields\_::vcStatsRxPTI

- [25] This register is used to include or exclude the PTI field of the ATM header when ATM VPI/VCI statistics are enabled
  - 1 PTI field is valid.
  - 0 PTI field ignored.

#### Definition at line 1473 of file IxAtmdAccCtrl.h.

The documentation for this struct was generated from the following file:

#### • IxAtmdAccCtrl.h

# IxAtmdAccUtopiaConfig::UtRxStatsConfig\_ Struct Reference

## [Intel (R) IXP400 Software ATM Driver Access (IxAtmdAcc) Utopia Control API]

Utopia Rx stats config Register.

## **Data Fields**

unsigned int **vpi**:12 [31:20] ATM VPI VPI [11:0] OR GFC [3:0] and VPI [7:0]

• Note: if VCStatsRxGFC is set to 0 the GFC field is ignored in test

unsigned int vci:16

[19:4] VCI [15:0] or PHY Address [4]

unsigned int pti:3

[3:1] PTI [2:0] or or PHY Address [3:1]

• Note: if VCStatsRxPTI is set to 0 the PTI field is ignored in test

unsigned int clp:1

[0] CLP [0] or PHY Address [0]

• Note: if VCStatsRxCLP is set to 0 the CLP field is ignored in test

## **Detailed Description**

Utopia Rx stats config Register.

Definition at line 1394 of file IxAtmdAccCtrl.h.

## **Field Documentation**

unsigned int IxAtmdAccUtopiaConfig::UtRxStatsConfig\_::clp

[0] CLP [0] or PHY Address [0]

- Note: if VCStatsRxCLP is set to 0 the CLP field is ignored in test
- Note: if VCStatsRxEnb is set to 0 only the PHY port address is used for statistics gathering..

Definition at line 1407 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtRxStatsConfig\_::pti

[3:1] PTI [2:0] or or PHY Address [3:1]

- Note: if VCStatsRxPTI is set to 0 the PTI field is ignored in test
- Note: if VCStatsRxEnb is set to 0 only the PHY port address is used for statistics gathering..

Definition at line 1402 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtRxStatsConfig\_::vci

[19:4] VCI [15:0] or PHY Address [4]

Definition at line 1400 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtRxStatsConfig\_::vpi

[31:20] ATM VPI VPI [11:0] OR GFC [3:0] and VPI [7:0]

• Note: if VCStatsRxGFC is set to 0 the GFC field is ignored in test

Definition at line **1397** of file **IxAtmdAccCtrl.h**.

The documentation for this struct was generated from the following file:

• IxAtmdAccCtrl.h

Field Documentation 646

# IxAtmdAccUtopiaConfig::UtRxTransTable0\_ Struct Reference

## [Intel (R) IXP400 Software ATM Driver Access (IxAtmdAcc) Utopia Control API]

Utopia Rx translation table Register.

### **Data Fields**

unsigned int phy0:5

[31–27] Rx Mapping value of logical phy 0

unsigned int phy1:5

[26–22] Rx Mapping value of logical phy 1

unsigned int phy2:5

[21–17] Rx Mapping value of logical phy 2

unsigned int reserved\_1:1

[16] These bits are always 0

unsigned int phy3:5

[15–11] Rx Mapping value of logical phy 3

unsigned int phy4:5

[10–6] Rx Mapping value of logical phy 4

unsigned int phy5:5

[5–1] Rx Mapping value of logical phy 5

unsigned int reserved 2:1

[0] These bits are always 0

## **Detailed Description**

Utopia Rx translation table Register.

Definition at line 1554 of file IxAtmdAccCtrl.h.

## **Field Documentation**

unsigned int IxAtmdAccUtopiaConfig::UtRxTransTableO\_::phy0

IxAtmdAccUtopiaConfig::UtRxTransTable0\_ Struct Reference [Intel (R) IXP400 Software ATM D64/er Acces

[31–27] Rx Mapping value of logical phy 0 Definition at line **1557** of file **IxAtmdAccCtrl.h**. unsigned int IxAtmdAccUtopiaConfig::UtRxTransTable0\_::phy1 [26–22] Rx Mapping value of logical phy 1 Definition at line 1559 of file IxAtmdAccCtrl.h. unsigned int IxAtmdAccUtopiaConfig::UtRxTransTable0\_::phy2 [21–17] Rx Mapping value of logical phy 2 Definition at line **1561** of file **IxAtmdAccCtrl.h**. unsigned int IxAtmdAccUtopiaConfig::UtRxTransTable0\_::phy3 [15–11] Rx Mapping value of logical phy 3 Definition at line 1565 of file IxAtmdAccCtrl.h. unsigned int IxAtmdAccUtopiaConfig::UtRxTransTable0\_::phy4 [10–6] Rx Mapping value of logical phy 4 Definition at line 1567 of file IxAtmdAccCtrl.h. unsigned int IxAtmdAccUtopiaConfig::UtRxTransTable0\_::phy5 [5–1] Rx Mapping value of logical phy 5 Definition at line **1569** of file **IxAtmdAccCtrl.h**. unsigned int IxAtmdAccUtopiaConfig::UtRxTransTable0\_::reserved\_1 [16] These bits are always 0 Definition at line 1563 of file IxAtmdAccCtrl.h. unsigned int IxAtmdAccUtopiaConfig::UtRxTransTable0\_::reserved\_2

IxAtmdAccUtopiaConfig::UtRxTransTable0\_ Struct Reference [Intel (R) IXP400 Software ATM D64&r Acces

| [0] These bits are alway |
|--------------------------|
|--------------------------|

#### Definition at line 1571 of file IxAtmdAccCtrl.h.

The documentation for this struct was generated from the following file:

• IxAtmdAccCtrl.h

# IxAtmdAccUtopiaConfig::UtRxTransTable1\_ Struct Reference

## [Intel (R) IXP400 Software ATM Driver Access (IxAtmdAcc) Utopia Control API]

Utopia Rx translation table Register.

### **Data Fields**

unsigned int phy6:5

[31–27] Rx Mapping value of logical phy 6

unsigned int phy7:5

[26–22] Rx Mapping value of logical phy 7

unsigned int phy8:5

[21–17] Rx Mapping value of logical phy 8

unsigned int reserved\_1:1

[16–0] These bits are always 0

unsigned int phy9:5

[15–11] Rx Mapping value of logical phy 3

unsigned int phy10:5

[10-6] Rx Mapping value of logical phy 4

unsigned int phy11:5

[5–1] Rx Mapping value of logical phy 5

unsigned int reserved 2:1

[0] These bits are always 0

## **Detailed Description**

Utopia Rx translation table Register.

Definition at line 1581 of file IxAtmdAccCtrl.h.

## **Field Documentation**

unsigned int IxAtmdAccUtopiaConfig::UtRxTransTable1\_::phy10

IxAtmdAccUtopiaConfig::UtRxTransTable1\_ Struct Reference [Intel (R) IXP400 Software ATM D65@r Acces

[10–6] Rx Mapping value of logical phy 4 Definition at line **1594** of file **IxAtmdAccCtrl.h**. unsigned int IxAtmdAccUtopiaConfig::UtRxTransTable1\_::phy11 [5–1] Rx Mapping value of logical phy 5 Definition at line 1596 of file IxAtmdAccCtrl.h. unsigned int IxAtmdAccUtopiaConfig::UtRxTransTable1\_::phy6 [31–27] Rx Mapping value of logical phy 6 Definition at line **1584** of file **IxAtmdAccCtrl.h**. unsigned int IxAtmdAccUtopiaConfig::UtRxTransTable1\_::phy7 [26–22] Rx Mapping value of logical phy 7 Definition at line **1586** of file **IxAtmdAccCtrl.h**. unsigned int IxAtmdAccUtopiaConfig::UtRxTransTable1\_::phy8 [21–17] Rx Mapping value of logical phy 8 Definition at line 1588 of file IxAtmdAccCtrl.h. unsigned int IxAtmdAccUtopiaConfig::UtRxTransTable1\_::phy9 [15–11] Rx Mapping value of logical phy 3 Definition at line **1592** of file **IxAtmdAccCtrl.h**. unsigned int IxAtmdAccUtopiaConfig::UtRxTransTable1\_::reserved\_1 [16–0] These bits are always 0 Definition at line 1590 of file IxAtmdAccCtrl.h.

IxAtmdAccUtopiaConfig::UtRxTransTable1\_ Struct Reference [Intel (R) IXP400 Software ATM D65/er Acces

unsigned int IxAtmdAccUtopiaConfig::UtRxTransTable1\_::reserved\_2

#### Definition at line 1598 of file IxAtmdAccCtrl.h.

The documentation for this struct was generated from the following file:

• IxAtmdAccCtrl.h

# IxAtmdAccUtopiaConfig::UtRxTransTable2\_ Struct Reference

## [Intel (R) IXP400 Software ATM Driver Access (IxAtmdAcc) Utopia Control API]

Utopia Rx translation table Register.

### **Data Fields**

unsigned int phy12:5

[31–27] Rx Mapping value of logical phy 6

unsigned int phy13:5

[26–22] Rx Mapping value of logical phy 7

unsigned int phy14:5

[21–17] Rx Mapping value of logical phy 8

unsigned int reserved\_1:1

[16–0] These bits are always 0

unsigned int **phy15**:5

[15–11] Rx Mapping value of logical phy 3

unsigned int phy16:5

[10-6] Rx Mapping value of logical phy 4

unsigned int phy17:5

[5–1] Rx Mapping value of logical phy 5

unsigned int reserved 2:1

[0] These bits are always 0

## **Detailed Description**

Utopia Rx translation table Register.

Definition at line 1608 of file IxAtmdAccCtrl.h.

## **Field Documentation**

unsigned int IxAtmdAccUtopiaConfig::UtRxTransTable2\_::phy12

IxAtmdAccUtopiaConfig::UtRxTransTable2\_ Struct Reference [Intel (R) IXP400 Software ATM D65@r Acces

[31–27] Rx Mapping value of logical phy 6 Definition at line **1611** of file **IxAtmdAccCtrl.h**. unsigned int IxAtmdAccUtopiaConfig::UtRxTransTable2\_::phy13 [26–22] Rx Mapping value of logical phy 7 Definition at line 1613 of file IxAtmdAccCtrl.h. unsigned int IxAtmdAccUtopiaConfig::UtRxTransTable2\_::phy14 [21–17] Rx Mapping value of logical phy 8 Definition at line **1615** of file **IxAtmdAccCtrl.h**. unsigned int IxAtmdAccUtopiaConfig::UtRxTransTable2\_::phy15 [15–11] Rx Mapping value of logical phy 3 Definition at line **1619** of file **IxAtmdAccCtrl.h**. unsigned int IxAtmdAccUtopiaConfig::UtRxTransTable2\_::phy16 [10-6] Rx Mapping value of logical phy 4 Definition at line 1621 of file IxAtmdAccCtrl.h. unsigned int IxAtmdAccUtopiaConfig::UtRxTransTable2\_::phy17 [5–1] Rx Mapping value of logical phy 5 Definition at line 1623 of file IxAtmdAccCtrl.h. unsigned int IxAtmdAccUtopiaConfig::UtRxTransTable2\_::reserved\_1 [16–0] These bits are always 0 Definition at line 1617 of file IxAtmdAccCtrl.h.

IxAtmdAccUtopiaConfig::UtRxTransTable2\_ Struct Reference [Intel (R) IXP400 Software ATM D65/er Acces

unsigned int IxAtmdAccUtopiaConfig::UtRxTransTable2\_::reserved\_2

#### Definition at line 1625 of file IxAtmdAccCtrl.h.

The documentation for this struct was generated from the following file:

• IxAtmdAccCtrl.h

# IxAtmdAccUtopiaConfig::UtRxTransTable3\_ Struct Reference

## [Intel (R) IXP400 Software ATM Driver Access (IxAtmdAcc) Utopia Control API]

Utopia Rx translation table Register.

### **Data Fields**

unsigned int phy18:5

[31–27] Rx Mapping value of logical phy 6

unsigned int phy19:5

[26–22] Rx Mapping value of logical phy 7

unsigned int phy20:5

[21–17] Rx Mapping value of logical phy 8

unsigned int reserved\_1:1

[16–0] These bits are always 0

unsigned int **phy21**:5

[15–11] Rx Mapping value of logical phy 3

unsigned int phy22:5

[10-6] Rx Mapping value of logical phy 4

unsigned int phy23:5

[5–1] Rx Mapping value of logical phy 5

unsigned int reserved 2:1

[0] These bits are always 0

## **Detailed Description**

Utopia Rx translation table Register.

Definition at line 1633 of file IxAtmdAccCtrl.h.

## **Field Documentation**

unsigned int IxAtmdAccUtopiaConfig::UtRxTransTable3\_::phy18

IxAtmdAccUtopiaConfig::UtRxTransTable3\_ Struct Reference [Intel (R) IXP400 Software ATM D656er Acces

[31–27] Rx Mapping value of logical phy 6 Definition at line **1636** of file **IxAtmdAccCtrl.h**. unsigned int IxAtmdAccUtopiaConfig::UtRxTransTable3\_::phy19 [26–22] Rx Mapping value of logical phy 7 Definition at line 1638 of file IxAtmdAccCtrl.h. unsigned int IxAtmdAccUtopiaConfig::UtRxTransTable3\_::phy20 [21–17] Rx Mapping value of logical phy 8 Definition at line **1640** of file **IxAtmdAccCtrl.h**. unsigned int IxAtmdAccUtopiaConfig::UtRxTransTable3\_::phy21 [15–11] Rx Mapping value of logical phy 3 Definition at line **1644** of file **IxAtmdAccCtrl.h**. unsigned int IxAtmdAccUtopiaConfig::UtRxTransTable3\_::phy22 [10-6] Rx Mapping value of logical phy 4 Definition at line 1646 of file IxAtmdAccCtrl.h. unsigned int IxAtmdAccUtopiaConfig::UtRxTransTable3\_::phy23 [5–1] Rx Mapping value of logical phy 5 Definition at line **1648** of file **IxAtmdAccCtrl.h**. unsigned int IxAtmdAccUtopiaConfig::UtRxTransTable3\_::reserved\_1

 $unsigned\ int\ IxAtmdAccUtopiaConfig:: UtRxTransTable 3\_:: reserved\_2$ 

[16–0] These bits are always 0

Definition at line 1642 of file IxAtmdAccCtrl.h.

IxAtmdAccUtopiaConfig::UtRxTransTable3\_ Struct Reference [Intel (R) IXP400 Software ATM D65/er Acces

#### Definition at line 1650 of file IxAtmdAccCtrl.h.

The documentation for this struct was generated from the following file:

• IxAtmdAccCtrl.h

# IxAtmdAccUtopiaConfig::UtRxTransTable4\_ Struct Reference

## [Intel (R) IXP400 Software ATM Driver Access (IxAtmdAcc) Utopia Control API]

Utopia Rx translation table Register.

### **Data Fields**

unsigned int phy24:5

[31–27] Rx Mapping value of logical phy 6

unsigned int phy25:5

[26–22] Rx Mapping value of logical phy 7

unsigned int phy26:5

[21–17] Rx Mapping value of logical phy 8

unsigned int reserved\_1:1

[16–0] These bits are always 0

unsigned int **phy27**:5

[15–11] Rx Mapping value of logical phy 3

unsigned int phy28:5

[10-6] Rx Mapping value of logical phy 4

unsigned int phy29:5

[5–1] Rx Mapping value of logical phy 5

unsigned int reserved 2:1

[0] These bits are always 0

## **Detailed Description**

Utopia Rx translation table Register.

Definition at line 1658 of file IxAtmdAccCtrl.h.

## **Field Documentation**

unsigned int IxAtmdAccUtopiaConfig::UtRxTransTable4\_::phy24

IxAtmdAccUtopiaConfig::UtRxTransTable4\_ Struct Reference [Intel (R) IXP400 Software ATM D65@r Acces

[31–27] Rx Mapping value of logical phy 6 Definition at line **1661** of file **IxAtmdAccCtrl.h**. unsigned int IxAtmdAccUtopiaConfig::UtRxTransTable4\_::phy25 [26–22] Rx Mapping value of logical phy 7 Definition at line 1663 of file IxAtmdAccCtrl.h. unsigned int IxAtmdAccUtopiaConfig::UtRxTransTable4\_::phy26 [21–17] Rx Mapping value of logical phy 8 Definition at line **1665** of file **IxAtmdAccCtrl.h**. unsigned int IxAtmdAccUtopiaConfig::UtRxTransTable4\_::phy27 [15–11] Rx Mapping value of logical phy 3 Definition at line **1669** of file **IxAtmdAccCtrl.h**. unsigned int IxAtmdAccUtopiaConfig::UtRxTransTable4\_::phy28 [10-6] Rx Mapping value of logical phy 4 Definition at line 1671 of file IxAtmdAccCtrl.h. unsigned int IxAtmdAccUtopiaConfig::UtRxTransTable4\_::phy29 [5–1] Rx Mapping value of logical phy 5 Definition at line 1673 of file IxAtmdAccCtrl.h. unsigned int IxAtmdAccUtopiaConfig::UtRxTransTable4\_::reserved\_1 [16–0] These bits are always 0

IxAtmdAccUtopiaConfig::UtRxTransTable4\_ Struct Reference [Intel (R) IXP400 Software ATM D66@r Access

Definition at line 1667 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtRxTransTable4\_::reserved\_2

#### Definition at line 1675 of file IxAtmdAccCtrl.h.

The documentation for this struct was generated from the following file:

• IxAtmdAccCtrl.h

# IxAtmdAccUtopiaConfig::UtRxTransTable5\_ Struct Reference

## [Intel (R) IXP400 Software ATM Driver Access (IxAtmdAcc) Utopia Control API]

Utopia Rx translation table Register.

#### **Data Fields**

unsigned int phy30:5

[31–27] Rx Mapping value of logical phy 6

unsigned int **reserved\_1**:27

[26–0] These bits are always 0

## **Detailed Description**

Utopia Rx translation table Register.

Definition at line 1683 of file IxAtmdAccCtrl.h.

### **Field Documentation**

unsigned int IxAtmdAccUtopiaConfig::UtRxTransTable5\_::phy30

[31–27] Rx Mapping value of logical phy 6

Definition at line 1686 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtRxTransTable5\_::reserved\_1

[26–0] These bits are always 0

Definition at line 1688 of file IxAtmdAccCtrl.h.

The documentation for this struct was generated from the following file:

• IxAtmdAccCtrl.h

# IxAtmdAccUtopiaConfig::UtSysConfig\_ Struct Reference

## [Intel (R) IXP400 Software ATM Driver Access (IxAtmdAcc) Utopia Control API]

NPE setup Register.

#### **Data Fields**

unsigned int **reserved\_1**:2

[31–30] These bits are always 0

#### unsigned int txEnbFSM:1

[29] Enables the operation of the Utopia Transmit FSM

- 1 FSM enabled
- 0 FSM inactive

#### unsigned int rxEnbFSM:1

[28] Enables the operation of the Utopia Revieve FSM

- 1 FSM enabled
- 0 − FSM inactive

#### unsigned int disablePins:1

[27] Disable Utopia interface I/O pins forcing the signals to an inactive state

#### unsigned int tstLoop:1

[26] Test Loop Back Enable

#### unsigned int txReset:1

[25] Resets the Utopia Coprocessor transmit module to a known state

#### unsigned int rxReset:1

[24] Resets the Utopia Coprocessor receive module to a known state

#### unsigned int reserved\_2:24

[23–0] These bits are always 0

## **Detailed Description**

NPE setup Register.

Definition at line **1697** of file **IxAtmdAccCtrl.h**.

## **Field Documentation**

unsigned int IxAtmdAccUtopiaConfig::UtSysConfig\_::disablePins

[27] Disable Utopia interface I/O pins forcing the signals to an inactive state

Note that this bit is set on reset and must be de-asserted

- 0 Normal data transfer
- 1 Utopia interface pins are forced inactive

Definition at line 1709 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtSysConfig\_::reserved\_1

[31–30] These bits are always 0

Definition at line 1700 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtSysConfig\_::reserved\_2

[23–0] These bits are always 0

Definition at line 1736 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtSysConfig\_::rxEnbFSM

- [28] Enables the operation of the Utopia Revieve FSM
  - 1 FSM enabled
  - 0 FSM inactive

Definition at line 1705 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtSysConfig\_::rxReset

[24] Resets the Utopia Coprocessor receive module to a known state

- Note: All receive configuration and status registers will be reset to their reset values.
- 0 Normal operating mode
- 1 Reset receive modules

Definition at line 1729 of file IxAtmdAccCtrl.h.

#### unsigned int IxAtmdAccUtopiaConfig::UtSysConfig\_::tstLoop

#### [26] Test Loop Back Enable

- Note: For loop back to function RxMode and Tx Mode must both be set to single PHY mode.
- 0 Loop back
- 1 Normal operating mode

Definition at line 1715 of file IxAtmdAccCtrl.h.

#### unsigned int IxAtmdAccUtopiaConfig::UtSysConfig\_::txEnbFSM

- [29] Enables the operation of the Utopia Transmit FSM
  - 1 FSM enabled
  - 0 FSM inactive

Definition at line 1701 of file IxAtmdAccCtrl.h.

#### unsigned int IxAtmdAccUtopiaConfig::UtSysConfig\_::txReset

- [25] Resets the Utopia Coprocessor transmit module to a known state
  - Note: All transmit configuration and status registers will be reset to their reset values.
  - 0 Normal operating mode
  - 1 Reset transmit modules

#### Definition at line 1722 of file IxAtmdAccCtrl.h.

The documentation for this struct was generated from the following file:

#### • IxAtmdAccCtrl.h

# IxAtmdAccUtopiaConfig::UtTxConfig\_ Struct Reference

## [Intel (R) IXP400 Software ATM Driver Access (IxAtmdAcc) Utopia Control API]

Utopia Tx Config Register.

### **Data Fields**

```
unsigned
     int reserved 1:1
        [31] These bits are always 0.
unsigned
     int txInterface:1
        [30] Utopia Transmit Interface
unsigned
     int txMode:1
        [29] Utopia Transmit Mode
unsigned
     int txOctet:1
        [28] Utopia Transmit cell transfer protocol
unsigned
     int txParity:1
        [27] Utopia Transmit parity enabled when set
unsigned
     int txEvenParity:1
        [26] Utopia Transmit Parity Mode
              • 1 − Even Parity Generated
unsigned
     int txHEC:1
        [25] Header Error Check Insertion Mode
unsigned
     int txCOSET:1
        [24] If enabled the HEC is Exclusive-ORÆed with the value 0x55 before being presented on the
        Utopia bus
```

```
unsigned
     int reserved_2:1
        [23] These bits are always 0
unsigned
     int txCellSize:7
        [22:16] Transmit expected cell size
unsigned
     int reserved_3:3
        [15:13] These bits are always 0
unsigned
     int txAddrRange:5
        [12:8] When configured as an ATM master in MPHY mode this register specifies the upper limit
        of the PHY polling logical range
unsigned
     int reserved 4:3
        [7:5] These bits are always 0
unsigned
     int txPHYAddr:5
        [4:0] When configured as a slave in an MPHY system this register specifies the physical address
        of the PHY
```

## **Detailed Description**

Utopia Tx Config Register.

Definition at line 986 of file IxAtmdAccCtrl.h.

## **Field Documentation**

```
unsigned int IxAtmdAccUtopiaConfig::UtTxConfig_::reserved_1

[31] These bits are always 0.

Definition at line 989 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtTxConfig_::reserved_2

[23] These bits are always 0

Definition at line 1027 of file IxAtmdAccCtrl.h.
```

unsigned int IxAtmdAccUtopiaConfig::UtTxConfig ::reserved 3

[15:13] These bits are always 0

Definition at line 1032 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtTxConfig\_::reserved\_4

[7:5] These bits are always 0

Definition at line 1037 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtTxConfig\_::txAddrRange

[12:8] When configured as an ATM master in MPHY mode this register specifies the upper limit of the PHY polling logical range

The number of active PHYs are TxAddrRange + 1.

Definition at line 1033 of file IxAtmdAccCtrl.h.

 $unsigned\ int\ IxAtmdAccUtopiaConfig::UtTxConfig\_::txCellSize$ 

[22:16] Transmit expected cell size

Configures the cell size for the transmit module: Values between 52–64 are valid.

Definition at line 1029 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtTxConfig\_::txCOSET

- [24] If enabled the HEC is Exclusive–ORÆed with the value 0x55 before being presented on the Utopia bus
  - 1 Enable HEC ExOR with value 0x55
  - 0 Use generated HEC value.

Definition at line 1021 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtTxConfig\_::txEvenParity

- [26] Utopia Transmit Parity Mode
  - 1 Even Parity Generated

• 0 – Odd Parity Generated.

Definition at line 1012 of file IxAtmdAccCtrl.h.

#### unsigned int IxAtmdAccUtopiaConfig::UtTxConfig\_::txHEC

[25] Header Error Check Insertion Mode

Specifies if the transmit cell header check byte is calculated and inserted when set.

- 1 Generate HEC.
- 0 Disable HEC generation.

Definition at line 1016 of file IxAtmdAccCtrl.h.

#### unsigned int IxAtmdAccUtopiaConfig::UtTxConfig\_::txInterface

[30] Utopia Transmit Interface

The following encoding is used to set the Utopia Transmit interface as ATM master or PHY slave:

- 1 PHY
- 0 ATM

Definition at line 990 of file IxAtmdAccCtrl.h.

#### unsigned int IxAtmdAccUtopiaConfig::UtTxConfig\_::txMode

[29] Utopia Transmit Mode

The following encoding is used to set the Utopia Transmit mode to SPHY or MPHY:

- 1 − SPHY
- 0 MPHY

Definition at line **996** of file **IxAtmdAccCtrl.h**.

#### unsigned int IxAtmdAccUtopiaConfig::UtTxConfig\_::txOctet

[28] Utopia Transmit cell transfer protocol

Used to set the Utopia cell transfer protocol to Octet-level handshaking. Note this is only applicable in SPHY mode.

• 1 – Octet–handshaking enabled

• 0 – Cell–handshaking enabled

Definition at line 1001 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtTxConfig\_::txParity

[27] Utopia Transmit parity enabled when set

TxEvenParity defines the parity format odd/even.

- 1 Enable Parity generation.
- 0 ut\_op\_prty held low.

Definition at line 1007 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtTxConfig\_::txPHYAddr

[4:0] When configured as a slave in an MPHY system this register specifies the physical address of the PHY

Definition at line 1038 of file IxAtmdAccCtrl.h.

The documentation for this struct was generated from the following file:

• IxAtmdAccCtrl.h

# IxAtmdAccUtopiaConfig::UtTxDefineIdle\_ Struct Reference

## [Intel (R) IXP400 Software ATM Driver Access (IxAtmdAcc) Utopia Control API]

Utopia Tx idle cells Register.

### **Data Fields**

unsigned int **vpi**:12 [31:20] ATM VPI [11:0] OR GFC [3:0] and VPI [7:0]

• Note: if VCIdleTxGFC is set to 0 the GFC field is ignored in test

unsigned int **vci**:16 [19:4] ATM VCI [15:0]

unsigned int pti:3

[3:1] ATM PTI PTI [2:0]

• Note: if VCIdleTxPTI is set to 0 the PTI field is ignored in test.

unsigned int **clp**:1

[0] ATM CLP [0]

• Note: if VCIdleTxCLP is set to 0 the CLP field is ignored in test.

## **Detailed Description**

Utopia Tx idle cells Register.

Definition at line 1076 of file IxAtmdAccCtrl.h.

### **Field Documentation**

unsigned int IxAtmdAccUtopiaConfig::UtTxDefineIdle\_::clp

[0] ATM CLP [0]

• Note: if VCIdleTxCLP is set to 0 the CLP field is ignored in test.

Definition at line 1087 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtTxDefineIdle\_::pti

[3:1] ATM PTI PTI [2:0]

• Note: if VCIdleTxPTI is set to 0 the PTI field is ignored in test.

Definition at line 1084 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtTxDefineIdle\_::vci

[19:4] ATM VCI [15:0]

Definition at line 1082 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtTxDefineIdle\_::vpi

[31:20] ATM VPI [11:0] OR GFC [3:0] and VPI [7:0]

• Note: if VCIdleTxGFC is set to 0 the GFC field is ignored in test

Definition at line 1079 of file IxAtmdAccCtrl.h.

The documentation for this struct was generated from the following file:

• IxAtmdAccCtrl.h

Field Documentation 672

# IxAtmdAccUtopiaConfig::UtTxEnableFields\_ Struct Reference

## [Intel (R) IXP400 Software ATM Driver Access (IxAtmdAcc) Utopia Control API]

Utopia Tx ienable fields Register.

#### **Data Fields**

#### unsigned int defineTxIdleGFC:1

[31] This register is used to include or exclude the GFC field of the ATM header when testing for Idle cells

#### unsigned int defineTxIdlePTI:1

[30] This register is used to include or exclude the PTI field of the ATM header when testing for Idle cells

#### unsigned int **defineTxIdleCLP**:1

[29] This register is used to include or exclude the CLP field of the ATM header when testing for Idle cells

#### unsigned int phyStatsTxEnb:1

[28] This register is used to enable or disable ATM statistics gathering based on the specified PHY address as defined in TxStatsConfig register

#### unsigned int vcStatsTxEnb:1

[27] This register is used to change the ATM statistics—gathering mode from the specified logical PHY address to a specific VPI/VCI address

#### unsigned int vcStatsTxGFC:1

[26] This register is used to include or exclude the GFC field of the ATM header when ATM VPI/VCI statistics are enabled

#### unsigned int vcStatsTxPTI:1

[25] This register is used to include or exclude the PTI field of the ATM header when ATM VPI/VCI statistics are enabled

#### unsigned int vcStatsTxCLP:1

[24] This register is used to include or exclude the CLP field of the ATM header when ATM VPI/VCI statistics are enabled

#### unsigned int **reserved 1**:3

[23-21] These bits are always 0

#### unsigned int txPollStsInt:1

[20] Enable the assertion of the ucp\_tx\_poll\_sts condition where there is a change in

polling status

#### unsigned int txCellOvrInt:1

[19] Enable TxCellCount overflow CBI Transmit Status condition assertion

#### unsigned int txIdleCellOvrInt:1

[18] Enable TxIdleCellCount overflow Transmit Status Condition

- 1 If TxIdleCellCountOvr is set assert the Transmit Status Condition
- 0 No CBI Transmit Status condition assertion..

#### unsigned int enbIdleCellCnt:1

[17] Enable Transmit Idle Cell Count

#### unsigned int enbTxCellCnt:1

[16] Enable Transmit Valid Cell Count of non-idle/non-error cells

- 1 Enable count of valid cells transmitted non-idle/non-error
- 0 No count is maintained.

unsigned int reserved\_2:16

[15:0] These bits are always 0

## **Detailed Description**

Utopia Tx ienable fields Register.

Definition at line 1098 of file IxAtmdAccCtrl.h.

## **Field Documentation**

unsigned int IxAtmdAccUtopiaConfig::UtTxEnableFields\_::defineTxIdleCLP

[29] This register is used to include or exclude the CLP field of the ATM header when testing for Idle cells

- 1 CLP field is valid.
- 0 CLP field ignored.

Definition at line 1111 of file IxAtmdAccCtrl.h.

 $unsigned\ int\ IxAtmdAccUtopiaConfig:: UtTxEnableFields\_:: defineTxIdleGFC$ 

[31] This register is used to include or exclude the GFC field of the ATM header when testing for Idle cells

- 1 GFC field is valid.
- 0 GFC field ignored.

Definition at line 1101 of file IxAtmdAccCtrl.h.

#### unsigned int IxAtmdAccUtopiaConfig::UtTxEnableFields\_::defineTxIdlePTI

[30] This register is used to include or exclude the PTI field of the ATM header when testing for Idle cells

- 1 PTI field is valid
- 0 PTI field ignored.

Definition at line 1106 of file IxAtmdAccCtrl.h.

#### unsigned int IxAtmdAccUtopiaConfig::UtTxEnableFields\_::enbIdleCellCnt

- [17] Enable Transmit Idle Cell Count
  - 1 Enable count of Idle cells transmitted.
  - 0 No count is maintained.

Definition at line 1161 of file IxAtmdAccCtrl.h.

#### unsigned int IxAtmdAccUtopiaConfig::UtTxEnableFields\_::enbTxCellCnt

- [16] Enable Transmit Valid Cell Count of non-idle/non-error cells
  - 1 Enable count of valid cells transmitted– non–idle/non–error
  - 0 No count is maintained.

Definition at line 1165 of file IxAtmdAccCtrl.h.

#### unsigned int IxAtmdAccUtopiaConfig::UtTxEnableFields\_::phyStatsTxEnb

[28] This register is used to enable or disable ATM statistics gathering based on the specified PHY address as defined in TxStatsConfig register

- 1 Enable statistics for specified transmit PHY address.
- 0 Disable statistics for specified transmit PHY address.

Definition at line 1116 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtTxEnableFields\_::reserved\_1

[23–21] These bits are always 0

Definition at line 1145 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtTxEnableFields\_::reserved\_2

[15:0] These bits are always 0

Definition at line **1169** of file **IxAtmdAccCtrl.h**.

unsigned int IxAtmdAccUtopiaConfig::UtTxEnableFields\_::txCellOvrInt

- [19] Enable TxCellCount overflow CBI Transmit Status condition assertion
  - 1 If TxCellCountOvr is set assert the Transmit Status Condition.
  - 0 No CBI Transmit Status condition assertion

Definition at line 1152 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtTxEnableFields\_::txIdleCellOvrInt

- [18] Enable TxIdleCellCount overflow Transmit Status Condition
  - 1 If TxIdleCellCountOvr is set assert the Transmit Status Condition
  - 0 No CBI Transmit Status condition assertion..

Definition at line 1157 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtTxEnableFields\_::txPollStsInt

- [20] Enable the assertion of the ucp\_tx\_poll\_sts condition where there is a change in polling status
  - 1 ucp tx poll sts asserted whenever there is a change in status
  - 0 ucp\_tx\_poll\_sts asserted if ANY transmit PHY is available

Definition at line 1147 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtTxEnableFields\_::vcStatsTxCLP

[24] This register is used to include or exclude the CLP field of the ATM header when ATM VPI/VCI statistics are enabled

- 1 CLP field is valid
- 0 CLP field ignored.

Definition at line 1140 of file IxAtmdAccCtrl.h.

#### unsigned int IxAtmdAccUtopiaConfig::UtTxEnableFields\_::vcStatsTxEnb

[27] This register is used to change the ATM statistics—gathering mode from the specified logical PHY address to a specific VPI/VCI address

- 1 Enable statistics for specified VPI/VCI address.
- 0 Disable statistics for specified VPI/VCI address

Definition at line 1122 of file IxAtmdAccCtrl.h.

#### unsigned int IxAtmdAccUtopiaConfig::UtTxEnableFields\_::vcStatsTxGFC

[26] This register is used to include or exclude the GFC field of the ATM header when ATM VPI/VCI statistics are enabled

GFC is only available at the UNI and uses the first 4-bits of the VPI field.

- 1 GFC field is valid
- 0 GFC field ignored.

Definition at line 1128 of file IxAtmdAccCtrl.h.

#### unsigned int IxAtmdAccUtopiaConfig::UtTxEnableFields\_::vcStatsTxPTI

[25] This register is used to include or exclude the PTI field of the ATM header when ATM VPI/VCI statistics are enabled

- 1 PTI field is valid
- 0 PTI field ignored.

#### Definition at line 1135 of file IxAtmdAccCtrl.h.

The documentation for this struct was generated from the following file:

#### • IxAtmdAccCtrl.h

# IxAtmdAccUtopiaConfig::UtTxStatsConfig\_ Struct Reference

## [Intel (R) IXP400 Software ATM Driver Access (IxAtmdAcc) Utopia Control API]

Utopia Tx stats Register.

### **Data Fields**

unsigned int **vpi**:12 [31:20] ATM VPI [11:0] OR GFC [3:0] and VPI [7:0]

• Note: if VCStatsTxGFC is set to 0 the GFC field is ignored in test

unsigned int vci:16

[19:4] ATM VCI [15:0] or PHY Address[4]

unsigned int pti:3

[3:1] ATM PTI [2:0] or PHY Address[3:1]

• Note: if VCStatsTxPTI is set to 0 the PTI field is ignored in test

unsigned int clp:1

[0] ATM CLP or PHY Address [0]

• Note: if VCStatsTxCLP is set to 0 the CLP field is ignored in test

## **Detailed Description**

Utopia Tx stats Register.

Definition at line 1050 of file IxAtmdAccCtrl.h.

#### **Field Documentation**

unsigned int IxAtmdAccUtopiaConfig::UtTxStatsConfig\_::clp

[0] ATM CLP or PHY Address [0]

- Note: if VCStatsTxCLP is set to 0 the CLP field is ignored in test
- Note: if VCStatsTxEnb is set to 0 only the transmit PHY port address as defined by this register is used for ATM statistics [4:0].

Definition at line 1063 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtTxStatsConfig\_::pti

[3:1] ATM PTI [2:0] or PHY Address[3:1]

- Note: if VCStatsTxPTI is set to 0 the PTI field is ignored in test
- Note: if VCStatsTxEnb is set to 0 only the transmit PHY port address as defined by this register is used for ATM statistics [4:0].

Definition at line 1058 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtTxStatsConfig\_::vci

[19:4] ATM VCI [15:0] or PHY Address[4]

Definition at line 1056 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtTxStatsConfig\_::vpi

[31:20] ATM VPI [11:0] OR GFC [3:0] and VPI [7:0]

• Note: if VCStatsTxGFC is set to 0 the GFC field is ignored in test

Definition at line **1053** of file **IxAtmdAccCtrl.h**.

The documentation for this struct was generated from the following file:

• IxAtmdAccCtrl.h

Field Documentation 679

# IxAtmdAccUtopiaConfig::UtTxTransTable0\_ Struct Reference

## [Intel (R) IXP400 Software ATM Driver Access (IxAtmdAcc) Utopia Control API]

Utopia Tx translation table Register.

### **Data Fields**

unsigned int phy0:5

[31–27] Tx Mapping value of logical phy 0

unsigned int phy1:5

[26–22] Tx Mapping value of logical phy 1

unsigned int phy2:5

[21–17] Tx Mapping value of logical phy 2

unsigned int reserved\_1:1

[16] These bits are always 0.

unsigned int phy3:5

[15–11] Tx Mapping value of logical phy 3

unsigned int phy4:5

[10–6] Tx Mapping value of logical phy 4

unsigned int phy5:5

[5–1] Tx Mapping value of logical phy 5

unsigned int reserved 2:1

[0] These bits are always 0

## **Detailed Description**

Utopia Tx translation table Register.

Definition at line 1177 of file IxAtmdAccCtrl.h.

## **Field Documentation**

unsigned int IxAtmdAccUtopiaConfig::UtTxTransTableO\_::phy0

Definition at line 1180 of file IxAtmdAccCtrl.h. unsigned int IxAtmdAccUtopiaConfig::UtTxTransTable0\_::phy1 [26–22] Tx Mapping value of logical phy 1 Definition at line 1182 of file IxAtmdAccCtrl.h. unsigned int IxAtmdAccUtopiaConfig::UtTxTransTableO\_::phy2 [21–17] Tx Mapping value of logical phy 2 Definition at line 1184 of file IxAtmdAccCtrl.h. unsigned int IxAtmdAccUtopiaConfig::UtTxTransTable0\_::phy3 [15–11] Tx Mapping value of logical phy 3 Definition at line 1188 of file IxAtmdAccCtrl.h. unsigned int IxAtmdAccUtopiaConfig::UtTxTransTableO\_::phy4 [10-6] Tx Mapping value of logical phy 4 Definition at line 1190 of file IxAtmdAccCtrl.h. unsigned int IxAtmdAccUtopiaConfig::UtTxTransTable0\_::phy5 [5–1] Tx Mapping value of logical phy 5 Definition at line 1192 of file IxAtmdAccCtrl.h. unsigned int IxAtmdAccUtopiaConfig::UtTxTransTable0\_::reserved\_1 [16] These bits are always 0. Definition at line 1186 of file IxAtmdAccCtrl.h. unsigned int IxAtmdAccUtopiaConfig::UtTxTransTable0\_::reserved\_2

IxAtmdAccUtopiaConfig::UtTxTransTable0\_ Struct Reference [Intel (R) IXP400 Software ATM D68/er Acces

[31–27] Tx Mapping value of logical phy 0

| [0] These bits are alway |
|--------------------------|
|--------------------------|

#### Definition at line 1194 of file IxAtmdAccCtrl.h.

The documentation for this struct was generated from the following file:

• IxAtmdAccCtrl.h

# IxAtmdAccUtopiaConfig::UtTxTransTable1\_ Struct Reference

## [Intel (R) IXP400 Software ATM Driver Access (IxAtmdAcc) Utopia Control API]

Utopia Tx translation table Register.

### **Data Fields**

unsigned int phy6:5

[31–27] Tx Mapping value of logical phy 6

unsigned int phy7:5

[26–22] Tx Mapping value of logical phy 7

unsigned int phy8:5

[21–17] Tx Mapping value of logical phy 8

unsigned int reserved\_1:1

[16–0] These bits are always 0

unsigned int phy9:5

[15–11] Tx Mapping value of logical phy 3

unsigned int phy10:5

[10–6] Tx Mapping value of logical phy 4

unsigned int phy11:5

[5–1] Tx Mapping value of logical phy 5

unsigned int reserved 2:1

[0] These bits are always 0

## **Detailed Description**

Utopia Tx translation table Register.

Definition at line 1202 of file IxAtmdAccCtrl.h.

## **Field Documentation**

unsigned int IxAtmdAccUtopiaConfig::UtTxTransTable1\_::phy10

[10–6] Tx Mapping value of logical phy 4 Definition at line **1215** of file **IxAtmdAccCtrl.h**. unsigned int IxAtmdAccUtopiaConfig::UtTxTransTable1\_::phy11 [5–1] Tx Mapping value of logical phy 5 Definition at line 1217 of file IxAtmdAccCtrl.h. unsigned int IxAtmdAccUtopiaConfig::UtTxTransTable1\_::phy6 [31–27] Tx Mapping value of logical phy 6 Definition at line **1205** of file **IxAtmdAccCtrl.h**. unsigned int IxAtmdAccUtopiaConfig::UtTxTransTable1\_::phy7 [26–22] Tx Mapping value of logical phy 7 Definition at line 1207 of file IxAtmdAccCtrl.h. unsigned int IxAtmdAccUtopiaConfig::UtTxTransTable1\_::phy8 [21–17] Tx Mapping value of logical phy 8 Definition at line 1209 of file IxAtmdAccCtrl.h. unsigned int IxAtmdAccUtopiaConfig::UtTxTransTable1\_::phy9 [15–11] Tx Mapping value of logical phy 3 Definition at line 1213 of file IxAtmdAccCtrl.h. unsigned int IxAtmdAccUtopiaConfig::UtTxTransTable1\_::reserved\_1 [16–0] These bits are always 0 Definition at line 1211 of file IxAtmdAccCtrl.h. unsigned int IxAtmdAccUtopiaConfig::UtTxTransTable1\_::reserved\_2

IxAtmdAccUtopiaConfig::UtTxTransTable1\_ Struct Reference [Intel (R) IXP400 Software ATM D68/4r Acces

| [0] These bits are alway |
|--------------------------|
|--------------------------|

#### Definition at line 1219 of file IxAtmdAccCtrl.h.

The documentation for this struct was generated from the following file:

• IxAtmdAccCtrl.h

# IxAtmdAccUtopiaConfig::UtTxTransTable2\_ Struct Reference

## [Intel (R) IXP400 Software ATM Driver Access (IxAtmdAcc) Utopia Control API]

Utopia Tx translation table Register.

### **Data Fields**

unsigned int phy12:5

[31–27] Tx Mapping value of logical phy 6

unsigned int phy13:5

[26–22] Tx Mapping value of logical phy 7

unsigned int phy14:5

[21–17] Tx Mapping value of logical phy 8

unsigned int reserved\_1:1

[16–0] These bits are always 0

unsigned int **phy15**:5

[15–11] Tx Mapping value of logical phy 3

unsigned int phy16:5

[10–6] Tx Mapping value of logical phy 4

unsigned int phy17:5

[5–1] Tx Mapping value of logical phy 5

unsigned int reserved\_2:1

[0] These bits are always 0

## **Detailed Description**

Utopia Tx translation table Register.

Definition at line 1227 of file IxAtmdAccCtrl.h.

### **Field Documentation**

unsigned int IxAtmdAccUtopiaConfig::UtTxTransTable2\_::phy12

[31–27] Tx Mapping value of logical phy 6 Definition at line **1230** of file **IxAtmdAccCtrl.h**. unsigned int IxAtmdAccUtopiaConfig::UtTxTransTable2\_::phy13 [26–22] Tx Mapping value of logical phy 7 Definition at line 1232 of file IxAtmdAccCtrl.h. unsigned int IxAtmdAccUtopiaConfig::UtTxTransTable2\_::phy14 [21–17] Tx Mapping value of logical phy 8 Definition at line **1234** of file **IxAtmdAccCtrl.h**. unsigned int IxAtmdAccUtopiaConfig::UtTxTransTable2\_::phy15 [15–11] Tx Mapping value of logical phy 3 Definition at line 1238 of file IxAtmdAccCtrl.h. unsigned int IxAtmdAccUtopiaConfig::UtTxTransTable2\_::phy16 [10-6] Tx Mapping value of logical phy 4 Definition at line 1240 of file IxAtmdAccCtrl.h. unsigned int IxAtmdAccUtopiaConfig::UtTxTransTable2\_::phy17 [5–1] Tx Mapping value of logical phy 5 Definition at line 1242 of file IxAtmdAccCtrl.h. unsigned int IxAtmdAccUtopiaConfig::UtTxTransTable2\_::reserved\_1 [16–0] These bits are always 0 Definition at line 1236 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtTxTransTable2\_::reserved\_2

| [0] These bits are alway |
|--------------------------|
|--------------------------|

#### Definition at line 1244 of file IxAtmdAccCtrl.h.

The documentation for this struct was generated from the following file:

• IxAtmdAccCtrl.h

# IxAtmdAccUtopiaConfig::UtTxTransTable3\_ Struct Reference

## [Intel (R) IXP400 Software ATM Driver Access (IxAtmdAcc) Utopia Control API]

Utopia Tx translation table Register.

### **Data Fields**

unsigned int phy18:5

[31–27] Tx Mapping value of logical phy 6

unsigned int phy19:5

[26–22] Tx Mapping value of logical phy 7

unsigned int phy20:5

[21–17] Tx Mapping value of logical phy 8

unsigned int reserved\_1:1

[16–0] These bits are always 0

unsigned int **phy21**:5

[15–11] Tx Mapping value of logical phy 3

unsigned int phy22:5

[10–6] Tx Mapping value of logical phy 4

unsigned int phy23:5

[5–1] Tx Mapping value of logical phy 5

unsigned int reserved 2:1

[0] These bits are always 0

## **Detailed Description**

Utopia Tx translation table Register.

Definition at line 1252 of file IxAtmdAccCtrl.h.

## **Field Documentation**

unsigned int IxAtmdAccUtopiaConfig::UtTxTransTable3\_::phy18

[31–27] Tx Mapping value of logical phy 6 Definition at line 1255 of file IxAtmdAccCtrl.h. unsigned int IxAtmdAccUtopiaConfig::UtTxTransTable3\_::phy19 [26–22] Tx Mapping value of logical phy 7 Definition at line 1257 of file IxAtmdAccCtrl.h. unsigned int IxAtmdAccUtopiaConfig::UtTxTransTable3\_::phy20 [21–17] Tx Mapping value of logical phy 8 Definition at line 1259 of file IxAtmdAccCtrl.h. unsigned int IxAtmdAccUtopiaConfig::UtTxTransTable3\_::phy21 [15–11] Tx Mapping value of logical phy 3 Definition at line **1263** of file **IxAtmdAccCtrl.h**. unsigned int IxAtmdAccUtopiaConfig::UtTxTransTable3\_::phy22 [10-6] Tx Mapping value of logical phy 4 Definition at line 1265 of file IxAtmdAccCtrl.h. unsigned int IxAtmdAccUtopiaConfig::UtTxTransTable3\_::phy23

[5–1] Tx Mapping value of logical phy 5

Definition at line **1267** of file **IxAtmdAccCtrl.h**.

unsigned int IxAtmdAccUtopiaConfig::UtTxTransTable3\_::reserved\_1

[16–0] These bits are always 0

Definition at line 1261 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtTxTransTable3\_::reserved\_2

IxAtmdAccUtopiaConfig::UtTxTransTable3\_ Struct Reference [Intel (R) IXP400 Software ATM D690 Access

| [0] These bits are alway |
|--------------------------|
|--------------------------|

#### Definition at line 1269 of file IxAtmdAccCtrl.h.

The documentation for this struct was generated from the following file:

• IxAtmdAccCtrl.h

# IxAtmdAccUtopiaConfig::UtTxTransTable4\_ Struct Reference

## [Intel (R) IXP400 Software ATM Driver Access (IxAtmdAcc) Utopia Control API]

Utopia Tx translation table Register.

### **Data Fields**

unsigned int phy24:5

[31–27] Tx Mapping value of logical phy 6

unsigned int phy25:5

[26–22] Tx Mapping value of logical phy 7

unsigned int phy26:5

[21–17] Tx Mapping value of logical phy 8

unsigned int reserved\_1:1

[16–0] These bits are always 0

unsigned int phy27:5

[15–11] Tx Mapping value of logical phy 3

unsigned int phy28:5

[10–6] Tx Mapping value of logical phy 4

unsigned int phy29:5

[5–1] Tx Mapping value of logical phy 5

unsigned int reserved\_2:1

[0] These bits are always 0

## **Detailed Description**

Utopia Tx translation table Register.

Definition at line 1277 of file IxAtmdAccCtrl.h.

## **Field Documentation**

unsigned int IxAtmdAccUtopiaConfig::UtTxTransTable4\_::phy24

IxAtmdAccUtopiaConfig::UtTxTransTable4\_ Struct Reference [Intel (R) IXP400 Software ATM D692r Acces

[31–27] Tx Mapping value of logical phy 6 Definition at line **1280** of file **IxAtmdAccCtrl.h**. unsigned int IxAtmdAccUtopiaConfig::UtTxTransTable4\_::phy25 [26–22] Tx Mapping value of logical phy 7 Definition at line 1282 of file IxAtmdAccCtrl.h. unsigned int IxAtmdAccUtopiaConfig::UtTxTransTable4\_::phy26 [21–17] Tx Mapping value of logical phy 8 Definition at line **1284** of file **IxAtmdAccCtrl.h**. unsigned int IxAtmdAccUtopiaConfig::UtTxTransTable4\_::phy27 [15–11] Tx Mapping value of logical phy 3 Definition at line **1288** of file **IxAtmdAccCtrl.h**. unsigned int IxAtmdAccUtopiaConfig::UtTxTransTable4\_::phy28 [10-6] Tx Mapping value of logical phy 4 Definition at line 1290 of file IxAtmdAccCtrl.h. unsigned int IxAtmdAccUtopiaConfig::UtTxTransTable4\_::phy29 [5–1] Tx Mapping value of logical phy 5 Definition at line **1292** of file **IxAtmdAccCtrl.h**. unsigned int IxAtmdAccUtopiaConfig::UtTxTransTable4\_::reserved\_1 [16–0] These bits are always 0

Definition at line 1286 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtTxTransTable4\_::reserved\_2

| [0] These bits are alway |
|--------------------------|
|--------------------------|

#### Definition at line 1294 of file IxAtmdAccCtrl.h.

The documentation for this struct was generated from the following file:

• IxAtmdAccCtrl.h

# IxAtmdAccUtopiaConfig::UtTxTransTable5\_ Struct Reference

## [Intel (R) IXP400 Software ATM Driver Access (IxAtmdAcc) Utopia Control API]

Utopia Tx translation table Register.

#### **Data Fields**

unsigned int phy30:5

[31–27] Tx Mapping value of logical phy 6

unsigned int **reserved\_1**:27

[26–0] These bits are always 0

## **Detailed Description**

Utopia Tx translation table Register.

Definition at line 1302 of file IxAtmdAccCtrl.h.

### **Field Documentation**

unsigned int IxAtmdAccUtopiaConfig::UtTxTransTable5\_::phy30

[31–27] Tx Mapping value of logical phy 6

Definition at line 1305 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaConfig::UtTxTransTable5\_::reserved\_1

[26–0] These bits are always 0

Definition at line 1307 of file IxAtmdAccCtrl.h.

The documentation for this struct was generated from the following file:

• IxAtmdAccCtrl.h

## IxAtmdAccUtopiaStatus Struct Reference

## [Intel (R) IXP400 Software ATM Driver Access (IxAtmdAcc) Utopia Control API]

Utopia status.

#### **Data Fields**

unsigned int utTxCellCount

count of cells transmitted

unsigned int utTxIdleCellCount

count of idle cells transmitted

 $IxAtmdAccUtopiaStatus:: UtTxCellConditionStatus\_utTxCellConditionStatus$ 

Tx cells condition status.

unsigned int utRxCellCount

count of cell received

unsigned int utRxIdleCellCount

count of idle cell received

unsigned int utRxInvalidHECount

count of invalid cell received because of HEC errors

unsigned int utRxInvalidParCount

count of invalid cell received because of parity errors

unsigned int utRxInvalidSizeCount

count of invalid cell received because of cell size errors

IxAtmdAccUtopiaStatus::UtRxCellConditionStatus\_utRxCellConditionStatus

Rx cells condition status.

## **Detailed Description**

Utopia status.

This structure is used to set/get the Utopia status parameters

• contains debug cell counters, to be accessed during a read operation

Note:

– the exact description of all parameters is done in the Utopia reference documents.

Definition at line 1753 of file IxAtmdAccCtrl.h.

### **Field Documentation**

struct IxAtmdAccUtopiaStatus::UtRxCellConditionStatus\_

IxAtmdAccUtopiaStatus::utRxCellConditionStatus

Rx cells condition status.

 $unsigned\ int\ IxAtmdAccUtopiaStatus::utRxCellCount$ 

count of cell received

Definition at line 1794 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaStatus::utRxIdleCellCount

count of idle cell received

Definition at line 1795 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaStatus::utRxInvalidHECount

count of invalid cell received because of HEC errors

Definition at line 1796 of file IxAtmdAccCtrl.h.

 $unsigned\ int\ IxAtmdAccUtopiaStatus::utRxInvalidParCount$ 

count of invalid cell received because of parity errors

Definition at line 1799 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaStatus::utRxInvalidSizeCount

count of invalid cell received because of cell size errors

Definition at line 1802 of file IxAtmdAccCtrl.h.

Field Documentation 697

#### struct IxAtmdAccUtopiaStatus::UtTxCellConditionStatus\_

IxAtmdAccUtopiaStatus:: utTxCellConditionStatus

Tx cells condition status.

unsigned int IxAtmdAccUtopiaStatus::utTxCellCount

count of cells transmitted

Definition at line 1756 of file IxAtmdAccCtrl.h.

 $unsigned\ int\ IxAtmdAccUtopiaStatus::utTxIdleCellCount$ 

count of idle cells transmitted

Definition at line 1758 of file IxAtmdAccCtrl.h.

The documentation for this struct was generated from the following file:

• IxAtmdAccCtrl.h

Field Documentation 698

# IxAtmdAccUtopiaStatus::UtRxCellConditionStatus\_ Struct Reference

# [Intel (R) IXP400 Software ATM Driver Access (IxAtmdAcc) Utopia Control API]

Utopia Rx Status Register.

## **Data Fields**

unsigned int reserved\_1:3

[31:29] These bits are always 0.

unsigned int rxCellCountOvr:1

[28] This bit is set if the RxCellCount register overflows

unsigned int invalidHecCountOvr:1

[27] This bit is set if the InvalidHecCount register overflows.

unsigned int invalidParCountOvr:1

[26] This bit is set if the InvalidParCount register overflows.

unsigned int invalidSizeCountOvr:1

[25] This bit is set if the InvalidSizeCount register overflows.

unsigned int rxIdleCountOvr:1

[24] This bit is set if the RxIdleCount register overflows.

unsigned int reserved\_2:4

[23:20] These bits are always 0

unsigned int rxFIFO2Underflow:1

[19] This bit is set if 64-byte Receive FIFO2 indicates a FIFO underflow error condition

unsigned int rxFIFO1Underflow:1

[18] This bit is set if 64-byte Receive FIFO1 indicates a FIFO underflow error condition

unsigned int rxFIFO2Overflow:1

[17] This bit is set if 64-byte Receive FIFO2 indicates a FIFO overflow error condition

unsigned int rxFIFO1Overflow:1

[16] This bit is set if 64-byte Receive FIFO1 indicates a FIFO overflow error condition

unsigned int reserved\_3:16

[15:0] These bits are always 0

# **Detailed Description**

Utopia Rx Status Register.

Definition at line 1812 of file IxAtmdAccCtrl.h.

# **Field Documentation**

unsigned int IxAtmdAccUtopiaStatus::UtRxCellConditionStatus\_::invalidHecCountOvr

[27] This bit is set if the InvalidHecCount register overflows.

Definition at line 1817 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaStatus::UtRxCellConditionStatus\_::invalidParCountOvr

[26] This bit is set if the InvalidParCount register overflows.

Definition at line 1818 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaStatus::UtRxCellConditionStatus\_::invalidSizeCountOvr

[25] This bit is set if the InvalidSizeCount register overflows.

Definition at line 1819 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaStatus::UtRxCellConditionStatus\_::reserved\_1

[31:29] These bits are always 0.

Definition at line 1815 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaStatus::UtRxCellConditionStatus\_::reserved\_2

[23:20] These bits are always 0

Definition at line 1821 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaStatus::UtRxCellConditionStatus\_::reserved\_3

[15:0] These bits are always 0

Detailed Description 700

Definition at line 1834 of file IxAtmdAccCtrl.h.

 $unsigned\ int\ IxAtmdAccUtopiaStatus:: UtRxCellConditionStatus\_:: rxCellCountOvr$ 

[28] This bit is set if the RxCellCount register overflows

Definition at line 1816 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaStatus::UtRxCellConditionStatus\_::rxFIFO1Overflow

[16] This bit is set if 64-byte Receive FIFO1 indicates a FIFO overflow error condition

Definition at line 1831 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaStatus::UtRxCellConditionStatus\_::rxFIFO1Underflow

[18] This bit is set if 64-byte Receive FIFO1 indicates a FIFO underflow error condition

Definition at line **1825** of file **IxAtmdAccCtrl.h**.

 $unsigned\ int\ IxAtmdAccUtopiaStatus:: UtRxCellConditionStatus\_:: rxFIFO2Overflow$ 

[17] This bit is set if 64-byte Receive FIFO2 indicates a FIFO overflow error condition

Definition at line 1828 of file IxAtmdAccCtrl.h.

 $unsigned\ int\ IxAtmdAccUtopiaStatus:: UtRxCellConditionStatus\_:: rxFIFO2Underflow$ 

[19] This bit is set if 64-byte Receive FIFO2 indicates a FIFO underflow error condition

Definition at line 1822 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaStatus::UtRxCellConditionStatus\_::rxIdleCountOvr

[24] This bit is set if the RxIdleCount register overflows.

Definition at line 1820 of file IxAtmdAccCtrl.h.

The documentation for this struct was generated from the following file:

#### • IxAtmdAccCtrl.h

Detailed Description 701

# IxAtmdAccUtopiaStatus::UtTxCellConditionStatus\_ Struct Reference

# [Intel (R) IXP400 Software ATM Driver Access (IxAtmdAcc) Utopia Control API]

Utopia Tx Status Register.

## **Data Fields**

unsigned int reserved\_1:2

[31:30] These bits are always 0

unsigned int txFIFO2Underflow:1

[29] This bit is set if 64-byte Transmit FIFO2 indicates a FIFO underflow error condition

unsigned int txFIFO1Underflow:1

[28] This bit is set if 64-byte Transmit FIFO1 indicates a FIFO underflow error condition

unsigned int txFIFO2Overflow:1

[27] This bit is set if 64-byte Transmit FIFO2 indicates a FIFO overflow error condition

unsigned int txFIFO1Overflow:1

[26] This bit is set if 64-byte Transmit FIFO1 indicates a FIFO overflow error condition

unsigned int txIdleCellCountOvr:1

[25] This bit is set if the TxIdleCellCount register overflows

unsigned int txCellCountOvr:1

[24] This bit is set if the TxCellCount register overflows

unsigned int reserved 2:24

[23:0] These bits are always 0

# **Detailed Description**

Utopia Tx Status Register.

Definition at line 1765 of file IxAtmdAccCtrl.h.

# **Field Documentation**

unsigned int IxAtmdAccUtopiaStatus::UtTxCellConditionStatus\_::reserved\_1

IxAtmdAccUtopiaStatus::UtTxCellConditionStatus\_ Struct Reference [Intel (R) IXP400 Software 702M Drive

[31:30] These bits are always 0

Definition at line **1768** of file **IxAtmdAccCtrl.h**.

unsigned int IxAtmdAccUtopiaStatus::UtTxCellConditionStatus\_::reserved\_2

[23:0] These bits are always 0

Definition at line 1791 of file IxAtmdAccCtrl.h.

 $unsigned\ int\ IxAtmdAccUtopiaStatus:: UtTxCellConditionStatus\_:: txCellCountOvr$ 

[24] This bit is set if the TxCellCount register overflows

Definition at line 1788 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaStatus::UtTxCellConditionStatus\_::txFIFO1Overflow

[26] This bit is set if 64-byte Transmit FIFO1 indicates a FIFO overflow error condition

Definition at line 1781 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaStatus::UtTxCellConditionStatus\_::txFIFO1Underflow

[28] This bit is set if 64-byte Transmit FIFO1 indicates a FIFO underflow error condition

Definition at line 1773 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaStatus::UtTxCellConditionStatus\_::txFIFO2Overflow

[27] This bit is set if 64-byte Transmit FIFO2 indicates a FIFO overflow error condition

Definition at line 1777 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaStatus::UtTxCellConditionStatus\_::txFIFO2Underflow

[29] This bit is set if 64-byte Transmit FIFO2 indicates a FIFO underflow error condition

Definition at line 1769 of file IxAtmdAccCtrl.h.

unsigned int IxAtmdAccUtopiaStatus::UtTxCellConditionStatus\_::txIdleCellCountOvr

IxAtmdAccUtopiaStatus::UtTxCellConditionStatus\_ Struct Reference [Intel (R) IXP400 Software 703M Drive

[25] This bit is set if the TxIdleCellCount register overflows

Definition at line 1785 of file IxAtmdAccCtrl.h.

The documentation for this struct was generated from the following file:

• IxAtmdAccCtrl.h

# IxAtmmPortCfg Struct Reference

## [Intel (R) IXP400 Software ATM Manager (IxAtmm) API]

Structure contains port–specific information required to initialize IxAtmm, and specifically, the IXP400 UTOPIA Level–2 device.

## **Data Fields**

unsigned reserved\_1:11

[31:21] Should be zero

unsigned UtopiaTxPhyAddr:5

[20:16] Address of the transmit (Tx) PHY for this port on the 5-bit UTOPIA Level-2 address bus

unsigned reserved\_2:11

[15:5] Should be zero

unsigned UtopiaRxPhyAddr:5

[4:0] Address of the receive (Rx) PHY for this port on the 5-bit UTOPIA Level-2 address bus

# **Detailed Description**

Structure contains port–specific information required to initialize IxAtmm, and specifically, the IXP400 UTOPIA Level–2 device.

Definition at line 161 of file IxAtmm.h.

# **Field Documentation**

unsigned IxAtmmPortCfg::reserved\_1

[31:21] Should be zero

Definition at line 162 of file IxAtmm.h.

unsigned IxAtmmPortCfg::reserved\_2

[15:5] Should be zero

Definition at line **167** of file **IxAtmm.h**.

unsigned IxAtmmPortCfg::UtopiaRxPhyAddr

[4:0] Address of the receive (Rx) PHY for this port on the 5-bit UTOPIA Level-2 address bus Definition at line **168** of file **IxAtmm.h**.

unsigned IxAtmmPortCfg::UtopiaTxPhyAddr

[20:16] Address of the transmit (Tx) PHY for this port on the 5-bit UTOPIA Level-2 address bus

Definition at line 163 of file IxAtmm.h.

The documentation for this struct was generated from the following file:

• IxAtmm.h

# IxAtmmVc Struct Reference

## [Intel (R) IXP400 Software ATM Manager (IxAtmm) API]

This structure describes the required attributes of a virtual connection.

## **Data Fields**

unsigned vpi

VPI value of this virtual connection.

unsigned vci

VCI value of this virtual connection.

IxAtmmVcDirection direction

VC direction.

IxAtmTrafficDescriptor trafficDesc

Traffic descriptor of this virtual connection.

# **Detailed Description**

This structure describes the required attributes of a virtual connection.

Definition at line **136** of file **IxAtmm.h**.

## **Field Documentation**

#### IxAtmmVcDirection IxAtmmVc::direction

VC direction.

Definition at line 139 of file IxAtmm.h.

#### IxAtmTrafficDescriptor IxAtmmVc::trafficDesc

Traffic descriptor of this virtual connection.

This structure is defined by the Intel (R) IXP400 Software ATM Transmit Scheduler (IxAtmSch) API component.

Definition at line 143 of file IxAtmm.h.

## unsigned IxAtmmVc::vci

VCI value of this virtual connection.

Definition at line 138 of file IxAtmm.h.

### unsigned IxAtmmVc::vpi

VPI value of this virtual connection.

Definition at line 137 of file IxAtmm.h.

The documentation for this struct was generated from the following file:

#### • IxAtmm.h

# IxAtmScheduleTable Struct Reference

## [Intel (R) IXP400 Software ATM Types (IxAtmTypes)]

This structure defines a schedule table which gives details on which data (from which VCs) should be transmitted for a forthcoming period of time for a particular port and the order in which that data should be transmitted.

#### **Data Fields**

unsigned tableSize

Number of entries.

unsigned totalCellSlots

Number of cells.

IxAtmScheduleTableEntry \* table

Pointer to schedule entries.

# **Detailed Description**

This structure defines a schedule table which gives details on which data (from which VCs) should be transmitted for a forthcoming period of time for a particular port and the order in which that data should be transmitted.

The schedule table consists of a series of entries each of which will schedule one or more cells from a particular registered VC. The total number of cells scheduled and the total number of entries in the table are also indicated.

Definition at line **348** of file **IxAtmTypes.h**.

# **Field Documentation**

#### IxAtmScheduleTableEntry\* IxAtmScheduleTable::table

Pointer to schedule entries.

Pointer to an array containing tableSize entries

Definition at line **361** of file **IxAtmTypes.h**.

unsigned IxAtmScheduleTable::tableSize

Number of entries.

Indicates the total number of entries in the table.

Definition at line 350 of file IxAtmTypes.h.

unsigned IxAtmScheduleTable::totalCellSlots

Number of cells.

Indicates the total number of ATM cells which are scheduled by all the entries in the table.

Definition at line **355** of file **IxAtmTypes.h**.

The documentation for this struct was generated from the following file:

• IxAtmTypes.h

# IxAtmScheduleTableEntry Struct Reference

# [Intel (R) IXP400 Software ATM Types (IxAtmTypes)]

ATM Schedule Table entry.

## **Data Fields**

IxAtmConnId connId

connection Id

unsigned int numberOfCells

number of cells to transmit

# **Detailed Description**

ATM Schedule Table entry.

This IxAtmScheduleTableEntry is used by an ATM scheduler to inform IxAtmdAcc about the data to transmit (in term of cells per VC)

This structure defines

- the number of cells to be transmitted (numberOfCells)
- the VC connection to be used for transmission (connId).

#### Note:

- When the connection Id value is IX\_ATM\_IDLE\_CELLS\_CONNID, the corresponding number of idle cells will be transmitted to the hardware.

Definition at line **316** of file **IxAtmTypes.h**.

# **Field Documentation**

#### IxAtmConnId IxAtmScheduleTableEntry::connId

connection Id

Identifier of VC from which cells are to be transmitted. When this valus is IX\_ATM\_IDLE\_CELLS\_CONNID, this indicates that the system should transmit the specified number of idle cells. Unknown connIds result in the transmission idle cells.

Definition at line 318 of file IxAtmTypes.h.

#### unsigned int IxAtmScheduleTableEntry::numberOfCells

number of cells to transmit

The number of contiguous cells to schedule from this VC at this point. The valid range is from 1 to *IX\_ATM\_SCHEDULETABLE\_MAXCELLS\_PER\_ENTRY*. This number can swap over mbufs and pdus. OverSchduling results in the transmission of idle cells.

Definition at line 326 of file IxAtmTypes.h.

The documentation for this struct was generated from the following file:

• IxAtmTypes.h

# IxAtmTrafficDescriptor Struct Reference

## [Intel (R) IXP400 Software ATM Types (IxAtmTypes)]

Structure describing an ATM traffic contract for a Virtual Connection (VC).

## **Data Fields**

IxAtmServiceCategory atmService

ATM service category.

unsigned pcr

Peak Cell Rate - cells per second.

unsigned cdvt

*Cell Delay Variation Tolerance – in nanoseconds.* 

unsigned scr

*Sustained Cell Rate – cells per second.* 

unsigned **mbs** 

*Max Burst Size – cells.* 

unsigned mcr

Minimum Cell Rate - cells per second.

unsigned mfs

*Max Frame Size - cells.* 

# **Detailed Description**

Structure describing an ATM traffic contract for a Virtual Connection (VC).

Structure is used to specify the requested traffic contract for a VC to the IxAtmSch component using the ixAtmSchVcModelSetup interface.

These parameters are defined by the ATM forum working group (http://www.atmforum.com).

Note:

Typical values for a voice channel 64 Kbit/s

♦ atmService *IX\_ATM\_RTVBR* 

♦ pcr 400 (include IP overhead, and AAL5 trailer)

♦ cdvt 5000000 (5 ms)

 $\Diamond$  scr = pcr

Typical values for a data channel 800 Kbit/s

♦ atmService *IX\_ATM\_UBR* 

♦ pcr 1962 (include IP overhead, and AAL5 trailer)

♦ cdvt 5000000 (5 ms)

Definition at line 255 of file IxAtmTypes.h.

## **Field Documentation**

#### IxAtmServiceCategory IxAtmTrafficDescriptor::atmService

ATM service category.

Definition at line **257** of file **IxAtmTypes.h**.

#### unsigned IxAtmTrafficDescriptor::cdvt

Cell Delay Variation Tolerance – in nanoseconds.

Definition at line **259** of file **IxAtmTypes.h**.

#### unsigned IxAtmTrafficDescriptor::mbs

Max Burst Size - cells.

Definition at line **261** of file **IxAtmTypes.h**.

#### unsigned IxAtmTrafficDescriptor::mcr

Minimum Cell Rate – cells per second.

Definition at line 262 of file IxAtmTypes.h.

#### unsigned IxAtmTrafficDescriptor::mfs

Max Frame Size – cells.

Definition at line 263 of file IxAtmTypes.h.

#### unsigned IxAtmTrafficDescriptor::pcr

Peak Cell Rate – cells per second.

Field Documentation 714

### Definition at line 258 of file IxAtmTypes.h.

unsigned IxAtmTrafficDescriptor::scr

Sustained Cell Rate – cells per second.

Definition at line 260 of file IxAtmTypes.h.

The documentation for this struct was generated from the following file:

• IxAtmTypes.h

Field Documentation 715

# IxCryptoAccAuthCtx Struct Reference

# [Intel (R) IXP400 Software Security (IxCryptoAcc) API]

Structure storing authentication configuration parameters required to perform security functionality.

## **Data Fields**

#### IxCryptoAccAuthAlgo authAlgo

authentication algorithm – MD5, SHA1, WEP\_CRC

#### UINT32 authDigestLen

Digest length in bytes.

#### UINT32 authKeyLen

Hash key length in bytes.

#### UINT32 aadLen

Additional Authentication Data (AAD) length in bytes.

```
union {
    UINT8 authKey

[IX_CRYPTO_ACC_MAX_AUTH_KEY_LENGTH]
    UINT8 sha1Key

[IX_CRYPTO_ACC_MAX_AUTH_KEY_LENGTH]
    UINT8 md5Key

[IX_CRYPTO_ACC_MAX_AUTH_KEY_LENGTH]
}
```

#### key

Hash key, key is not required for WEP\_CRC.

# **Detailed Description**

Structure storing authentication configuration parameters required to perform security functionality.

Structure is used to specify the authentication context required for using the **Intel** (**R**) **IXP400 Software Security** (**IxCryptoAcc**) **API** interface.

Definition at line 516 of file IxCryptoAcc.h.

## **Field Documentation**

#### UINT32 IxCryptoAccAuthCtx::aadLen

Additional Authentication Data (AAD) length in bytes.

This is the 16 bytes of initial block (called B0, in RFC 3610 and CCM Initial block in 802.11i spec), followed by additional authentication data (lengths– defined in respective standards).

Definition at line **523** of file **IxCryptoAcc.h**.

#### IxCryptoAccAuthAlgo IxCryptoAccAuthCtx::authAlgo

authentication algorithm - MD5, SHA1, WEP\_CRC

Definition at line 518 of file IxCryptoAcc.h.

#### UINT32 IxCryptoAccAuthCtx::authDigestLen

Digest length in bytes.

Definition at line **521** of file **IxCryptoAcc.h**.

#### UINT8 IxCryptoAccAuthCtx::authKey[IX\_CRYPTO\_ACC\_MAX\_AUTH\_KEY\_LENGTH]

default hash key array

Definition at line **532** of file **IxCryptoAcc.h**.

#### UINT32 IxCryptoAccAuthCtx::authKeyLen

Hash key length in bytes.

Definition at line **522** of file **IxCryptoAcc.h**.

#### union { ... } IxCryptoAccAuthCtx::key

Hash key, key is not required for WEP\_CRC.

#### UINT8 IxCryptoAccAuthCtx::md5Key[IX\_CRYPTO\_ACC\_MAX\_AUTH\_KEY\_LENGTH]

Field Documentation 717

MD5 key.

Definition at line 536 of file IxCryptoAcc.h.

UINT8 IxCryptoAccAuthCtx::sha1Key[IX\_CRYPTO\_ACC\_MAX\_AUTH\_KEY\_LENGTH]

SHA1 key.

Definition at line **535** of file **IxCryptoAcc.h**.

The documentation for this struct was generated from the following file:

• IxCryptoAcc.h

Field Documentation 718

# IxCryptoAccCipherCtx Struct Reference

# [Intel (R) IXP400 Software Security (IxCryptoAcc) API]

Structure storing cipher configuration parameters required to perform security functionality.

## **Data Fields**

#### IxCryptoAccCipherAlgo cipherAlgo

Cipher Algorithm – DES, 3DES, AES, ARC4.

#### IxCryptoAccCipherMode cipherMode

Cipher mode – ECB, CBC, CTR, CCM.

#### UINT32 cipherKeyLen

Cipher key length in bytes.

```
union {
    UINT8 cipherKey
[IX_CRYPTO_ACC_MAX_CIPHER_KEY_LENGTH]
    UINT8 desKey [IX_CRYPTO_ACC_DES_KEY_64]
    UINT8 tripleDesKey [IX_CRYPTO_ACC_3DES_KEY_192]
    UINT8 aesKey128 [IX_CRYPTO_ACC_AES_KEY_128]
    UINT8 aesKey192 [IX_CRYPTO_ACC_AES_KEY_192]
    UINT8 aesKey256 [IX_CRYPTO_ACC_AES_KEY_256]
```

#### kev

Cipher key, key is not required for ARC4 during registration.

#### UINT32 cipherBlockLen

Cipher block length in bytes.

#### UINT32 cipherInitialVectorLen

Length of IV in bytes.

# **Detailed Description**

Structure storing cipher configuration parameters required to perform security functionality.

Structure is used to specify the cipher context required for using the Intel (R) IXP400 Software Security (IxCryptoAcc) API interface.

#### Note:

SPI (Security Parameter Index) is not needed for crypto context registration as CTR counter block construction is client's responsibility

IxCryptoAccCipherCtx Struct Reference [Intel (R) IXP400 Software Security (IxCryptoAcc) API] 719

# **Field Documentation**

UINT8 IxCryptoAccCipherCtx::aesKey128[IX\_CRYPTO\_ACC\_AES\_KEY\_128]

AES-128 key.

Definition at line 493 of file IxCryptoAcc.h.

UINT8 IxCryptoAccCipherCtx::aesKey192[IX\_CRYPTO\_ACC\_AES\_KEY\_192]

AES-192 key.

Definition at line **494** of file **IxCryptoAcc.h**.

UINT8 IxCryptoAccCipherCtx::aesKey256[IX\_CRYPTO\_ACC\_AES\_KEY\_256]

AES-256 key.

Definition at line 495 of file IxCryptoAcc.h.

#### IxCryptoAccCipherAlgo IxCryptoAccCipherCtx::cipherAlgo

Cipher Algorithm – DES, 3DES, AES, ARC4.

Definition at line **481** of file **IxCryptoAcc.h**.

#### UINT32 IxCryptoAccCipherCtx::cipherBlockLen

Cipher block length in bytes.

(DES/3DES – 8 bytes, AES – 16 bytes) (ARC4 – 1 byte)

Definition at line 499 of file IxCryptoAcc.h.

#### UINT32 IxCryptoAccCipherCtx::cipherInitialVectorLen

Length of IV in bytes.

Definition at line **504** of file **IxCryptoAcc.h**.

Field Documentation 720

UINT8 IxCryptoAccCipherCtx::cipherKey[IX\_CRYPTO\_ACC\_MAX\_CIPHER\_KEY\_LENGTH]

default key array

Definition at line 488 of file IxCryptoAcc.h.

UINT32 IxCryptoAccCipherCtx::cipherKeyLen

Cipher key length in bytes.

Definition at line 485 of file IxCryptoAcc.h.

IxCryptoAccCipherMode IxCryptoAccCipherCtx::cipherMode

Cipher mode – ECB, CBC, CTR, CCM.

Definition at line **484** of file **IxCryptoAcc.h**.

UINT8 IxCryptoAccCipherCtx::desKey[IX\_CRYPTO\_ACC\_DES\_KEY\_64]

DES key.

Definition at line 491 of file IxCryptoAcc.h.

union { ... } IxCryptoAccCipherCtx::key

Cipher key, key is not required for ARC4 during registration.

UINT8 IxCryptoAccCipherCtx::tripleDesKey[IX\_CRYPTO\_ACC\_3DES\_KEY\_192]

3DES key

Definition at line **492** of file **IxCryptoAcc.h**.

The documentation for this struct was generated from the following file:

• IxCryptoAcc.h

Field Documentation 721

# IxCryptoAccCtx Struct Reference

## [Intel (R) IXP400 Software Security (IxCryptoAcc) API]

Structure storing configuration parameters required to perform security functionality.

## **Data Fields**

IxCryptoAccOperation operation

Types of operation.

IxCryptoAccCipherCtx cipherCtx

Cipher context.

IxCryptoAccAuthCtx authCtx

Authentication context.

#### BOOL useDifferentSrcAndDestMbufs

If TRUE, data is read from srcMbuf, result is written to destMbuf (non in-place operation).

# **Detailed Description**

Structure storing configuration parameters required to perform security functionality.

Structure is used to specify the crypto context (hardware accelerator context) required for using the Intel (R) IXP400 Software Security (IxCryptoAcc) API interface.

Definition at line **550** of file **IxCryptoAcc.h**.

# **Field Documentation**

#### IxCryptoAccAuthCtx IxCryptoAccCtx::authCtx

Authentication context.

Definition at line **554** of file **IxCryptoAcc.h**.

#### **IxCryptoAccCipherCtx** IxCryptoAccCtx::cipherCtx

Cipher context.

Definition at line 553 of file IxCryptoAcc.h.

#### IxCryptoAccOperation IxCryptoAccCtx::operation

Types of operation.

Definition at line 552 of file IxCryptoAcc.h.

#### BOOL IxCryptoAccCtx::useDifferentSrcAndDestMbufs

If TRUE, data is read from srcMbuf, result is written to destMbuf (non in-place operation).

If FALSE data is read from srcMbuf, and written back to srcMbuf (in–place operation). Default is FALSE. Note that only the crypted/authenticated data that is copied, not the entire source mbuf.

Definition at line **555** of file **IxCryptoAcc.h**.

The documentation for this struct was generated from the following file:

# IxCryptoAccPkeEauBnAddSubMulOperands Struct Reference

## [Intel (R) IXP400 Software Security (IxCryptoAcc) API]

Structure storing input operands for large number addition (Carry | R = A + B) or subtraction operation (Borrow | R = A - B) or multiplication (R = A \* B).

## **Data Fields**

IxCryptoAccPkeEauOperand A

A: 1st operand of addition/subtraction/multiplication.

IxCryptoAccPkeEauOperand B

*B* : 2nd operand of addition/subtraction multiplication.

# **Detailed Description**

Structure storing input operands for large number addition (Carry  $\mid R = A + B$ ) or subtraction operation (Borrow  $\mid R = A - B$ ) or multiplication (R = A \* B).

Definition at line 606 of file IxCryptoAcc.h.

# **Field Documentation**

#### IxCryptoAccPkeEauOperand IxCryptoAccPkeEauBnAddSubMulOperands::A

A: 1st operand of addition/subtraction/ multiplication.

Definition at line 608 of file IxCryptoAcc.h.

#### IxCryptoAccPkeEauOperand IxCryptoAccPkeEauBnAddSubMulOperands::B

B : 2nd operand of addition/subtraction multiplication.

Definition at line **610** of file **IxCryptoAcc.h**.

The documentation for this struct was generated from the following file:

# IxCryptoAccPkeEauBnModOperands Struct Reference

# [Intel (R) IXP400 Software Security (IxCryptoAcc) API]

Structure storing input operands for large number modular reduction operation ( $R = A \mod N$ ).

## **Data Fields**

IxCryptoAccPkeEauOperand A

A: Operand for modular reduction.

IxCryptoAccPkeEauOperand N

N: modulus.

# **Detailed Description**

Structure storing input operands for large number modular reduction operation ( $R = A \mod N$ ).

Definition at line 619 of file IxCryptoAcc.h.

## **Field Documentation**

#### IxCryptoAccPkeEauOperand IxCryptoAccPkeEauBnModOperands::A

A: Operand for modular reduction.

Definition at line **621** of file **IxCryptoAcc.h**.

#### IxCryptoAccPkeEauOperand IxCryptoAccPkeEauBnModOperands::N

N: modulus.

Definition at line **622** of file **IxCryptoAcc.h**.

The documentation for this struct was generated from the following file:

# IxCryptoAccPkeEauInOperands Union Reference

# [Intel (R) IXP400 Software Security (IxCryptoAcc) API]

Union storing input operands required for all EAU operations. These input operands will be supplied to **ixCryptoAccPkeEauPerform** interface to perform EAU functionalities.

## **Data Fields**

 $Ix Crypto Acc Pke Eau Mod Exp Operands\ mod Exp Opr$ 

Modular exponential input operands.

 $Ix Crypto Acc Pke Eau Bn Add Sub Mul Operands\ bn Add Sub Mul Operand$ 

Large number addition or subtraction or multiplication input operands.

IxCryptoAccPkeEauBnModOperands bnModOpr

Modular reduction input operands.

# **Detailed Description**

Union storing input operands required for all EAU operations. These input operands will be supplied to **ixCryptoAccPkeEauPerform** interface to perform EAU functionalities.

Definition at line **631** of file **IxCryptoAcc.h**.

## **Field Documentation**

IxCryptoAccPkeEauBnAddSubMulOperands IxCryptoAccPkeEauInOperands::bnAddSubMulOpr

Large number addition or subtraction or multiplication input operands.

Definition at line **637** of file **IxCryptoAcc.h**.

 $Ix Crypto Acc Pke Eau Bn Mod Operands \ Ix Crypto Acc Pke Eau In Operands :: bn Mod Oprands \ Ix Crypto Acc Pke Eau In Operands :: bn Mod Oprands \ Ix Crypto Acc Pke Eau In Operands :: bn Mod Oprands \ Ix Crypto Acc Pke Eau In Operands :: bn Mod Oprands \ Ix Crypto Acc Pke Eau In Operands :: bn Mod Oprands \ Ix Crypto Acc Pke Eau In Operands :: bn Mod Oprands \ Ix Crypto Acc Pke Eau In Operands :: bn Mod Oprands \ Ix Crypto Acc Pke Eau In Operands :: bn Mod Oprands \ Ix Crypto Acc Pke Eau In Operands :: bn Mod Oprands \ Ix Crypto Acc Pke Eau In Operands :: bn Mod Oprands \ Ix Crypto Acc Pke Eau In Operands \ Ix Crypto Acc Pke Eau In$ 

Modular reduction input operands.

Definition at line **641** of file **IxCryptoAcc.h**.

IxCryptoAccPkeEauModExpOperands IxCryptoAccPkeEauInOperands::modExpOpr

IxCryptoAccPkeEauInOperands Union Reference [Intel (R) IXP400 Software Security (IxCryptoAcc) API]

Modular exponential input operands.

Definition at line 633 of file IxCryptoAcc.h.

The documentation for this union was generated from the following file:

# IxCryptoAccPkeEauModExpOperands Struct Reference

# [Intel (R) IXP400 Software Security (IxCryptoAcc) API]

Structure storing input operands for large number modular exponential operation ( $C = M^e \mod N$ ).

## **Data Fields**

IxCryptoAccPkeEauOperand M

*M* : Base operand.

IxCryptoAccPkeEauOperand e

e: exponent

IxCryptoAccPkeEauOperand N

N: modulus.

# **Detailed Description**

Structure storing input operands for large number modular exponential operation ( $C = M^e \mod N$ ).

Definition at line **593** of file **IxCryptoAcc.h**.

## **Field Documentation**

 $\textbf{IxCryptoAccPkeEauOperand} \ IxCryptoAccPkeEauModExpOperands::e$ 

e: exponent

Definition at line **596** of file **IxCryptoAcc.h**.

IxCryptoAccPkeEauOperand IxCryptoAccPkeEauModExpOperands::M

M: Base operand.

Definition at line **595** of file **IxCryptoAcc.h**.

IxCryptoAccPkeEauOperand IxCryptoAccPkeEauModExpOperands::N

IxCryptoAccPkeEauModExpOperands Struct Reference [Intel (R) IXP400 Software Security (IxCryptoAcc).

N : modulus.

Definition at line **597** of file **IxCryptoAcc.h**.

The documentation for this struct was generated from the following file:

# IxCryptoAccPkeEauOperand Struct Reference

# [Intel (R) IXP400 Software Security (IxCryptoAcc) API]

Structure storing operand / result data pointer and length for EAU functionality performing through ixCryptoAccPkeEauPerform interface.

## **Data Fields**

UINT32 \* pData

Data pointer which contains EAU input operand or output result.

UINT32 dataLen

*data length in words (multiple of 32–bit)* 

# **Detailed Description**

Structure storing operand / result data pointer and length for EAU functionality performing through ixCryptoAccPkeEauPerform interface.

Definition at line **575** of file **IxCryptoAcc.h**.

## **Field Documentation**

UINT32 IxCryptoAccPkeEauOperand::dataLen

data length in words (multiple of 32-bit)

Definition at line **579** of file **IxCryptoAcc.h**.

UINT32\* IxCryptoAccPkeEauOperand::pData

Data pointer which contains EAU input operand or output result.

Definition at line **577** of file **IxCryptoAcc.h**.

The documentation for this struct was generated from the following file:

# IxCryptoCodeletServiceParam Struct Reference

Structure holding various configuration parameters for demonstration purposes.

## **Data Fields**

#### IxCryptoAccOperation frwdOperation

Opcode for forward operation.

#### IxCryptoAccOperation revOperation

*Opcode for reverse operation.* 

#### IxCryptoAccCipherAlgo cipherAlgo

Cipher Algorithm.

#### IxCryptoAccCipherMode cipherMode

Cipher Mode.

#### UINT32 cipherKeyLen

Cipher Key Length.

#### UINT32 cipherBlockLen

Cipher Algorithm's Block Length.

#### UINT32 cipherInitialVectorLen

Initial vector length.

#### IxCryptoAccAuthAlgo authAlgo

Authentication Algorithm.

#### UINT32 authKeyLen

Authentication Key Length.

#### UINT32 authDigestLen

Authentication Digest Length.

#### UINT32 aadLen

Additional Authentication Data Length (used in CCM mode of operation).

#### BOOL useDifferentSrcAndDestMbufs

*Use different source and destination buffers.* 

#### BOOL invokeXScaleWepPerform

Perform this request using XScaleWepPerform function (note only ARC4 and WEP CRC requests are valid.

#### UINT8 infoString [IX\_CRYPTOACC\_CODELET\_MAX\_STR\_SIZE]

*Information about the type of request.* 

# **Detailed Description**

Structure holding various configuration parameters for demonstration purposes.

This structure is only defined and used by this codelet. It holds various parameters that are required to register a context and invoke "perform" requests on the cryptoAcc component.

Definition at line 61 of file IxCryptoAccCodelet\_p.h.

## **Field Documentation**

UINT32 IxCryptoCodeletServiceParam::aadLen

Additional Authentication Data Length (used in CCM mode of operation).

Definition at line 73 of file IxCryptoAccCodelet\_p.h.

#### IxCryptoAccAuthAlgo IxCryptoCodeletServiceParam::authAlgo

Authentication Algorithm.

Definition at line **70** of file **IxCryptoAccCodelet\_p.h**.

#### UINT32 IxCryptoCodeletServiceParam::authDigestLen

Authentication Digest Length.

Definition at line **72** of file **IxCryptoAccCodelet\_p.h**.

#### UINT32 IxCryptoCodeletServiceParam::authKeyLen

Authentication Key Length.

Definition at line **71** of file **IxCryptoAccCodelet\_p.h**.

#### IxCryptoAccCipherAlgo IxCryptoCodeletServiceParam::cipherAlgo

Cipher Algorithm.

Definition at line 65 of file IxCryptoAccCodelet\_p.h.

Detailed Description 732

#### UINT32 IxCryptoCodeletServiceParam::cipherBlockLen

Cipher Algorithm's Block Length.

Definition at line 68 of file IxCryptoAccCodelet\_p.h.

#### UINT32 IxCryptoCodeletServiceParam::cipherInitialVectorLen

Initial vector length.

Definition at line **69** of file **IxCryptoAccCodelet\_p.h**.

#### UINT32 IxCryptoCodeletServiceParam::cipherKeyLen

Cipher Key Length.

Definition at line **67** of file **IxCryptoAccCodelet\_p.h**.

#### IxCryptoAccCipherMode IxCryptoCodeletServiceParam::cipherMode

Cipher Mode.

Definition at line 66 of file IxCryptoAccCodelet\_p.h.

#### IxCryptoAccOperation IxCryptoCodeletServiceParam::frwdOperation

Opcode for forward operation.

Definition at line 63 of file IxCryptoAccCodelet\_p.h.

#### UINT8 IxCryptoCodeletServiceParam::infoString[IX\_CRYPTOACC\_CODELET\_MAX\_STR\_SIZE]

Information about the type of request.

Definition at line **86** of file **IxCryptoAccCodelet\_p.h**.

#### $BOOL\ Ix Crypto Codelet Service Param:: invoke XS cale Wep Perform$

Perform this request using XScaleWepPerform function (note only ARC4 and WEP CRC requests are valid.

Definition at line **80** of file **IxCryptoAccCodelet\_p.h**.

Detailed Description 733

### IxCryptoAccOperation IxCryptoCodeletServiceParam::revOperation

Opcode for reverse operation.

Definition at line 64 of file IxCryptoAccCodelet\_p.h.

#### $BOOL\ Ix Crypto Code let Service Param:: use Different Src And Dest Mbufs$

Use different source and destination buffers.

Definition at line 77 of file IxCryptoAccCodelet\_p.h.

The documentation for this struct was generated from the following file:

• IxCryptoAccCodelet\_p.h

# IxEthAccMacAddr Struct Reference

### [Intel (R) IXP400 Software Ethernet Access (IxEthAcc) API]

Definition of the IEEE 802.3 Ethernet MAC address structure.

### **Data Fields**

UINT8 macAddress [IX\_IEEE803\_MAC\_ADDRESS\_SIZE] *MAC address*.

# **Detailed Description**

Definition of the IEEE 802.3 Ethernet MAC address structure.

The data should be packed with bytes xx:xx:xx:xx:xx

Note:

The data must be packed in network byte order.

Definition at line **99** of file **IxEthAcc.h**.

### **Field Documentation**

UINT8 IxEthAccMacAddr::macAddress[IX\_IEEE803\_MAC\_ADDRESS\_SIZE]

MAC address.

Definition at line 101 of file IxEthAcc.h.

The documentation for this struct was generated from the following file:

• IxEthAcc.h

# IxEthAccNe Struct Reference

[Intel (R) IXP400 Software Ethernet Access (IxEthAcc) API, Intel (R) IXP400 Software Ethernet Access (IxEthAcc) API, Intel (R) IXP400 Software Ethernet Access (IxEthAcc) API]

Definition of service-specific informations.

### **Data Fields**

UINT32 ixReserved\_next

reserved for chaining

UINT32 ixReserved\_lengths

reserved for buffer lengths

UINT32 ixReserved\_data

reserved for buffer pointer

**UINT8 ixDestinationPortId** 

Destination portId for this packet, if known by NPE.

UINT8 ixSourcePortId

Source portId for this packet.

UINT16 ixFlags

BitField of option for this frame.

UINT8 ixQoS

QoS class of the frame.

**UINT8** ixPadLength

Size of pad field in bytes (min 0 - max 16).

UINT16 ixVlanTCI

Vlan TCI.

UINT8 ixDestMac [IX\_IEEE803\_MAC\_ADDRESS\_SIZE]

Destination MAC address.

UINT8 ixSourceMac [IX\_IEEE803\_MAC\_ADDRESS\_SIZE]

Source MAC address.

# **Detailed Description**

Definition of service-specific informations.

This structure defines the Ethernet service–specific informations and enable QoS and VLAN features.

Definition at line 170 of file IxEthAcc.h.

### **Field Documentation**

UINT8 IxEthAccNe::ixDestinationPortId

Destination portId for this packet, if known by NPE.

Definition at line 175 of file IxEthAcc.h.

UINT8 IxEthAccNe::ixDestMac[IX\_IEEE803\_MAC\_ADDRESS\_SIZE]

Destination MAC address.

Definition at line 181 of file IxEthAcc.h.

UINT16 IxEthAccNe::ixFlags

BitField of option for this frame.

Definition at line 177 of file IxEthAcc.h.

UINT8 IxEthAccNe::ixPadLength

Size of pad field in bytes (min  $0 - \max 16$ ).

Definition at line 179 of file IxEthAcc.h.

UINT8 IxEthAccNe::ixQoS

QoS class of the frame.

Definition at line 178 of file IxEthAcc.h.

UINT32 IxEthAccNe::ixReserved\_data

reserved for buffer pointer

Definition at line 174 of file IxEthAcc.h.

UINT32 IxEthAccNe::ixReserved\_lengths

reserved for buffer lengths

Definition at line 173 of file IxEthAcc.h.

UINT32 IxEthAccNe::ixReserved\_next

reserved for chaining

Definition at line 172 of file IxEthAcc.h.

UINT8 IxEthAccNe::ixSourceMac[IX\_IEEE803\_MAC\_ADDRESS\_SIZE]

Source MAC address.

Definition at line 182 of file IxEthAcc.h.

UINT8 IxEthAccNe::ixSourcePortId

Source portId for this packet.

Definition at line 176 of file IxEthAcc.h.

UINT16 IxEthAccNe::ixVlanTCI

Vlan TCI.

Definition at line 180 of file IxEthAcc.h.

The documentation for this struct was generated from the following file:

• IxEthAcc.h

# IxEthDBMacAddr Struct Reference

### [Intel (R) IXP400 Software Ethernet Database (IxEthDB) API]

The IEEE 802.3 Ethernet MAC address structure.

### **Data Fields**

UINT8 macAddress [IX\_IEEE803\_MAC\_ADDRESS\_SIZE]

# **Detailed Description**

The IEEE 802.3 Ethernet MAC address structure.

The data should be packed with bytes xx:xx:xx:xx:xx

Note:

The data must be packed in network byte order.

Definition at line 236 of file IxEthDB.h.

The documentation for this struct was generated from the following file:

• IxEthDB.h

# IxEthDBPortDefinition Struct Reference

# [Intel (R) IXP400 Software Ethernet Database Port Definitions (IxEthDBPortDefs)]

Port Definition – a structure contains the Port type and capabilities.

### **Data Fields**

IxEthDBPortType type IxEthDBPortCapability capabilities

# **Detailed Description**

Port Definition – a structure contains the Port type and capabilities.

Definition at line 46 of file IxEthDBPortDefs.h.

The documentation for this struct was generated from the following file:

• IxEthDBPortDefs.h

# IxEthDBWiFiRecData Struct Reference

# [Intel (R) IXP400 Software Ethernet Database (IxEthDB) API]

The user wi-fi input parameters structure.

### **Data Fields**

IxEthDBWiFiRecordType
IxEthDBWiFiVlanTag vlanTagFlag
UINT32 logicalPortID
UINT8 padLength
UINT8 gatewayMacAddr [IX\_IEEE803\_MAC\_ADDRESS\_SIZE]
UINT8 bssid [IX\_IEEE803\_MAC\_ADDRESS\_SIZE]

# **Detailed Description**

The user wi-fi input parameters structure.

Note:

The data must be packed in network byte order.

Definition at line 275 of file IxEthDB.h.

The documentation for this struct was generated from the following file:

• IxEthDB.h

# IxEthEthObjStats Struct Reference

### [Intel (R) IXP400 Software Ethernet Access (IxEthAcc) API]

This struct defines the statistics returned by this component.

| <b>—</b> |     |      |
|----------|-----|------|
| Data     | Fie | Ide  |
| vala     |     | IU.5 |

#### UINT32 dot3StatsAlignmentErrors

*link error count (rx)* 

#### UINT32 dot3StatsFCSErrors

*link error count (rx)* 

#### UINT32 dot3StatsInternalMacReceiveErrors

*link error count (rx)* 

#### **UINT32 RxOverrunDiscards**

*NPE: discarded frames count (rx).* 

#### **UINT32 RxLearnedEntryDiscards**

NPE: discarded frames count(rx).

#### UINT32 RxLargeFramesDiscards

NPE: discarded frames count(rx).

#### **UINT32 RxSTPBlockedDiscards**

*NPE: discarded frames count(rx).* 

#### UINT32 RxVLANTypeFilterDiscards

*NPE: discarded frames count (rx).* 

#### UINT32 RxVLANIdFilterDiscards

*NPE: discarded frames count (rx).* 

#### UINT32 RxInvalidSourceDiscards

*NPE: discarded frames count (rx).* 

#### UINT32 RxBlackListDiscards

*NPE: discarded frames count (rx).* 

#### **UINT32 RxWhiteListDiscards**

*NPE: discarded frames count (rx).* 

#### UINT32 RxUnderflowEntryDiscards

*NPE: discarded frames count (rx).* 

#### UINT32 dot3StatsSingleCollisionFrames

*link error count (tx)* 

#### UINT32 dot3StatsMultipleCollisionFrames

*link error count (tx)* 

#### UINT32 dot3StatsDeferredTransmissions

*link error count (tx)* 

#### UINT32 dot3StatsLateCollisions

*link error count (tx)* 

#### UINT32 dot3StatsExcessiveCollsions

*link error count (tx)* 

#### UINT32 dot3StatsInternalMacTransmitErrors

*link error count (tx)* 

#### UINT32 dot3StatsCarrierSenseErrors

*link error count (tx)* 

#### UINT32 TxLargeFrameDiscards

*NPE: discarded frames count (tx).* 

#### UINT32 TxVLANIdFilterDiscards

*NPE: discarded frames count (tx).* 

- UINT32 RxValidFramesTotalOctets
- UINT32 RxUcastPkts
- UINT32 RxBcastPkts
- UINT32 RxMcastPkts
- UINT32 RxPkts64Octets
- UINT32 RxPkts65to127Octets
- UINT32 RxPkts128to255Octets
- UINT32 RxPkts256to511Octets
- UINT32 RxPkts512to1023Octets
- UINT32 RxPkts1024to1518Octets
- UINT32 RxInternalNPEReceiveErrors
- UINT32 TxInternalNPETransmitErrors

# **Detailed Description**

This struct defines the statistics returned by this component.

The component returns MIB2 EthObj variables which are obtained from the hardware or maintained by this component.

Definition at line 2297 of file IxEthAcc.h.

### **Field Documentation**

link error count (tx)

UINT32 IxEthEthObjStats::dot3StatsAlignmentErrors link error count (rx) Definition at line 2302 of file IxEthAcc.h. UINT32 IxEthEthObjStats::dot3StatsCarrierSenseErrors link error count (tx) Definition at line 2321 of file IxEthAcc.h.  $UINT32\ IxEthEthObjStats:: dot 3Stats Deferred Transmissions$ link error count (tx) Definition at line 2317 of file IxEthAcc.h. UINT32 IxEthEthObjStats::dot3StatsExcessiveCollsions link error count (tx) Definition at line 2319 of file IxEthAcc.h. UINT32 IxEthEthObjStats::dot3StatsFCSErrors link error count (rx) Definition at line 2303 of file IxEthAcc.h. UINT32 IxEthEthObjStats::dot3StatsInternalMacReceiveErrors link error count (rx) Definition at line **2304** of file **IxEthAcc.h**. UINT32 IxEthEthObjStats::dot3StatsInternalMacTransmitErrors

Definition at line 2320 of file IxEthAcc.h.

UINT32 IxEthEthObjStats::dot3StatsLateCollisions

link error count (tx)

Definition at line 2318 of file IxEthAcc.h.

UINT32 IxEthEthObjStats::dot3StatsMultipleCollisionFrames

link error count (tx)

Definition at line **2316** of file **IxEthAcc.h**.

UINT32 IxEthEthObjStats::dot3StatsSingleCollisionFrames

link error count (tx)

Definition at line 2315 of file IxEthAcc.h.

UINT32 IxEthEthObjStats::RxBlackListDiscards

NPE: discarded frames count (rx).

Definition at line 2312 of file IxEthAcc.h.

UINT32 IxEthEthObjStats::RxInvalidSourceDiscards

NPE: discarded frames count (rx).

Definition at line **2311** of file **IxEthAcc.h**.

UINT32 IxEthEthObjStats::RxLargeFramesDiscards

NPE: discarded frames count(rx).

Definition at line 2307 of file IxEthAcc.h.

UINT32 IxEthEthObjStats::RxLearnedEntryDiscards

NPE: discarded frames count(rx).

Definition at line 2306 of file IxEthAcc.h.

UINT32 IxEthEthObjStats::RxOverrunDiscards

NPE: discarded frames count (rx).

Definition at line 2305 of file IxEthAcc.h.

UINT32 IxEthEthObjStats::RxSTPBlockedDiscards

NPE: discarded frames count(rx).

Definition at line 2308 of file IxEthAcc.h.

UINT32 IxEthEthObjStats::RxUnderflowEntryDiscards

NPE: discarded frames count (rx).

Definition at line 2314 of file IxEthAcc.h.

UINT32 IxEthEthObjStats::RxVLANIdFilterDiscards

NPE: discarded frames count (rx).

Definition at line 2310 of file IxEthAcc.h.

UINT32 IxEthEthObjStats::RxVLANTypeFilterDiscards

NPE: discarded frames count (rx).

Definition at line 2309 of file IxEthAcc.h.

UINT32 IxEthEthObjStats::RxWhiteListDiscards

NPE: discarded frames count (rx).

Definition at line 2313 of file IxEthAcc.h.

 $UINT32\ IxEthEthObjStats:: TxLargeFrameDiscards$ 

NPE: discarded frames count (tx).

#### Definition at line 2322 of file IxEthAcc.h.

### UINT32 IxEthEthObjStats::TxVLANIdFilterDiscards

NPE: discarded frames count (tx).

Definition at line 2323 of file IxEthAcc.h.

The documentation for this struct was generated from the following file:

• IxEthAcc.h

# IxHssAccCodeletStats Struct Reference

ingroup IxHssAccCodeletCom

### **Data Fields**

GeneralStats gen
ChannelisedStats chan
PacketisedStats pkt [IX\_HSSACC\_HDLC\_PORT\_MAX]

# **Detailed Description**

ingroup IxHssAccCodeletCom

brief Type definition structure for HSS Access Codelet statistics

Definition at line 145 of file IxHssAccCodeletCom.h.

The documentation for this struct was generated from the following file:

• IxHssAccCodeletCom.h

# IxHssAccConfigParams Struct Reference

### [Intel (R) IXP400 Software HSS Access (IxHssAcc) API]

Structure containing HSS configuration parameters.

### **Data Fields**

### IxHssAccPortConfig txPortConfig

HSS tx port configuration.

#### IxHssAccPortConfig rxPortConfig

HSS rx port configuration.

#### unsigned numChannelised

*The number of channelised timeslots* (0-32).

#### unsigned hssPktChannelCount

The number of packetised clients (0-4).

#### **UINT8** channelisedIdlePattern

The byte to be transmitted on channelised service when there is no client data to tx.

#### **BOOL loopback**

The HSS loopback state.

#### unsigned packetizedIdlePattern

The data to be transmitted on packetised service when there is no client data to tx.

#### IxHssAccClkSpeed clkSpeed

The HSS clock speed.

# **Detailed Description**

Structure containing HSS configuration parameters.

Definition at line **563** of file **IxHssAcc.h**.

# **Field Documentation**

UINT8 IxHssAccConfigParams::channelisedIdlePattern

The byte to be transmitted on channelised service when there is no client data to tx.

IxHssAccConfigParams Struct Reference [Intel (R) IXP400 Software HSS Access (IxHssAcc) AP149

Definition at line **571** of file **IxHssAcc.h**.

#### IxHssAccClkSpeed IxHssAccConfigParams::clkSpeed

The HSS clock speed.

Definition at line **578** of file **IxHssAcc.h**.

#### unsigned IxHssAccConfigParams::hssPktChannelCount

The number of packetised clients (0-4).

Definition at line **569** of file **IxHssAcc.h**.

#### BOOL IxHssAccConfigParams::loopback

The HSS loopback state.

Definition at line **574** of file **IxHssAcc.h**.

#### unsigned IxHssAccConfigParams::numChannelised

The number of channelised timeslots (0-32).

Definition at line **567** of file **IxHssAcc.h**.

#### unsigned IxHssAccConfigParams::packetizedIdlePattern

The data to be transmitted on packetised service when there is no client data to tx.

Definition at line **575** of file **IxHssAcc.h**.

#### IxHssAccPortConfig IxHssAccConfigParams::rxPortConfig

HSS rx port configuration.

Definition at line **566** of file **IxHssAcc.h**.

#### IxHssAccPortConfig IxHssAccConfigParams::txPortConfig

HSS tx port configuration.

IxHssAccConfigParams Struct Reference [Intel (R) IXP400 Software HSS Access (IxHssAcc) API\$0

The documentation for this struct was generated from the following file:

• IxHssAcc.h

# IxHssAccHdlcMode Struct Reference

# [Intel (R) IXP400 Software HSS Access (IxHssAcc) API]

This structure contains 56Kbps, HDLC-mode configuration parameters.

### **Data Fields**

BOOL hdlc56kMode

56kbps(TRUE)/64kbps(FALSE) HDLC

#### IxHssAcc56kEndianness hdlc56kEndian

56kbps data endianness

• ignored if hdlc56kMode is FALSE

#### BOOL hdlc56kUnusedBitPolarity0

The polarity '0'(TRUE)/'1'(FALSE) of the unused bit while in 56kbps mode

• ignored if hdlc56kMode is FALSE.

# **Detailed Description**

This structure contains 56Kbps, HDLC-mode configuration parameters.

Definition at line **585** of file **IxHssAcc.h**.

# **Field Documentation**

IxHssAcc56kEndianness IxHssAccHdlcMode::hdlc56kEndian

56kbps data endianness

• ignored if hdlc56kMode is FALSE

Definition at line **588** of file **IxHssAcc.h**.

BOOL IxHssAccHdlcMode::hdlc56kMode

56kbps(TRUE)/64kbps(FALSE) HDLC

Definition at line **587** of file **IxHssAcc.h**.

### BOOL IxHssAccHdlcMode::hdlc56kUnusedBitPolarity0

The polarity '0'(TRUE)/'1'(FALSE) of the unused bit while in 56kbps mode

• ignored if hdlc56kMode is FALSE.

Definition at line **590** of file **IxHssAcc.h**.

The documentation for this struct was generated from the following file:

• IxHssAcc.h

# IxHssAccPktHdlcFraming Struct Reference

# [Intel (R) IXP400 Software HSS Access (IxHssAcc) API]

This structure contains information required by the NPE to configure the HDLC co-processor.

### **Data Fields**

IxHssAccPktHdlcIdleType hdlcIdleType

What to transmit when a HDLC port is idle.

IxHssAccBitEndian dataEndian

The HDLC data endianness.

IxHssAccPktCrcType crcType

The CRC type to be used for this HDLC port.

# **Detailed Description**

This structure contains information required by the NPE to configure the HDLC co-processor.

Definition at line 600 of file IxHssAcc.h.

# **Field Documentation**

#### IxHssAccPktCrcType IxHssAccPktHdlcFraming::crcType

The CRC type to be used for this HDLC port.

Definition at line **604** of file **IxHssAcc.h**.

#### IxHssAccBitEndian IxHssAccPktHdlcFraming::dataEndian

The HDLC data endianness.

Definition at line **603** of file **IxHssAcc.h**.

#### **IxHssAccPktHdlcIdleType** IxHssAccPktHdlcFraming::hdlcIdleType

What to transmit when a HDLC port is idle.

The documentation for this struct was generated from the following file:

• IxHssAcc.h

# IxHssAccPortConfig Struct Reference

### [Intel (R) IXP400 Software HSS Access (IxHssAcc) API]

Structure containing HSS port configuration parameters.

### **Data Fields**

#### IxHssAccFrmSyncType frmSyncType

frame sync pulse type (tx/rx)

#### IxHssAccFrmSyncEnable frmSyncIO

how the frame sync pulse is used (tx/rx)

#### IxHssAccClkEdge frmSyncClkEdge

frame sync clock edge type (tx/rx)

#### IxHssAccClkEdge dataClkEdge

data clock edge type (tx/rx)

#### IxHssAccClkDir clkDirection

clock direction (tx/rx)

#### IxHssAccFrmPulseUsage frmPulseUsage

whether to use the frame sync pulse or not (tx/rx)

#### IxHssAccDataRate dataRate

data rate in relation to the clock (tx/rx)

#### IxHssAccDataPolarity dataPolarity

data polarity type (tx/rx)

#### IxHssAccBitEndian dataEndianness

data endianness (tx/rx)

#### IxHssAccDrainMode drainMode

tx pin open drain mode (tx)

#### IxHssAccSOFType fBitUsage

start of frame types (tx/rx)

#### IxHssAccDataEnable dataEnable

whether or not to drive the data pins (tx)

#### IxHssAccTxSigType voice56kType

how to drive the data pins for voice56k type (tx)

#### IxHssAccTxSigType unassignedType

how to drive the data pins for unassigned type (tx)

#### IxHssAccFbType fBitType

*how to drive the Fbit (tx)* 

#### IxHssAcc56kEndianness voice56kEndian

56k data endianness when using the 56k type (tx)

#### IxHssAcc56kSel voice56kSel

56k data transmission type when using the 56k type (tx)

#### unsigned frmOffset

frame pulse offset in bits wrt the first timeslot (0-1023) (tx/rx)

#### unsigned maxFrmSize

frame size in bits (1-1024) (tx/rx)

# **Detailed Description**

Structure containing HSS port configuration parameters.

Note: All of these are used for TX. Only some are specific to RX.

Definition at line **525** of file **IxHssAcc.h**.

# **Field Documentation**

#### IxHssAccClkDir IxHssAccPortConfig::clkDirection

clock direction (tx/rx)

Definition at line **533** of file **IxHssAcc.h**.

#### IxHssAccClkEdge IxHssAccPortConfig::dataClkEdge

data clock edge type (tx/rx)

Definition at line 532 of file IxHssAcc.h.

#### IxHssAccDataEnable IxHssAccPortConfig::dataEnable

whether or not to drive the data pins (tx)

Definition at line **542** of file **IxHssAcc.h**.

#### IxHssAccBitEndian IxHssAccPortConfig::dataEndianness

data endianness (tx/rx)

Definition at line **539** of file **IxHssAcc.h**.

#### IxHssAccDataPolarity IxHssAccPortConfig::dataPolarity

data polarity type (tx/rx)

Definition at line **538** of file **IxHssAcc.h**.

#### IxHssAccDataRate IxHssAccPortConfig::dataRate

data rate in relation to the clock (tx/rx)

Definition at line **536** of file **IxHssAcc.h**.

#### IxHssAccDrainMode IxHssAccPortConfig::drainMode

tx pin open drain mode (tx)

Definition at line **540** of file **IxHssAcc.h**.

#### **IxHssAccFbType** IxHssAccPortConfig::fBitType

how to drive the Fbit (tx)

Definition at line **548** of file **IxHssAcc.h**.

#### IxHssAccSOFType IxHssAccPortConfig::fBitUsage

start of frame types (tx/rx)

Definition at line **541** of file **IxHssAcc.h**.

#### unsigned IxHssAccPortConfig::frmOffset

frame pulse offset in bits wrt the first timeslot (0–1023) (tx/rx)

Definition at line **553** of file **IxHssAcc.h**.

#### IxHssAccFrmPulseUsage IxHssAccPortConfig::frmPulseUsage

whether to use the frame sync pulse or not (tx/rx)

Definition at line **534** of file **IxHssAcc.h**.

#### IxHssAccClkEdge IxHssAccPortConfig::frmSyncClkEdge

frame sync clock edge type (tx/rx)

Definition at line **530** of file **IxHssAcc.h**.

#### IxHssAccFrmSyncEnable IxHssAccPortConfig::frmSyncIO

how the frame sync pulse is used (tx/rx)

Definition at line **528** of file **IxHssAcc.h**.

### IxHssAccFrmSyncType IxHssAccPortConfig::frmSyncType

frame sync pulse type (tx/rx)

Definition at line **527** of file **IxHssAcc.h**.

#### unsigned IxHssAccPortConfig::maxFrmSize

frame size in bits (1-1024) (tx/rx)

Definition at line **555** of file **IxHssAcc.h**.

#### **IxHssAccTxSigType** IxHssAccPortConfig::unassignedType

how to drive the data pins for unassigned type (tx)

Definition at line **546** of file **IxHssAcc.h**.

#### IxHssAcc56kEndianness IxHssAccPortConfig::voice56kEndian

56k data endianness when using the 56k type (tx)

Definition at line **549** of file **IxHssAcc.h**.

#### IxHssAcc56kSel IxHssAccPortConfig::voice56kSel

56k data transmission type when using the 56k type (tx)

Definition at line **551** of file **IxHssAcc.h**.

### **IxHssAccTxSigType** IxHssAccPortConfig::voice56kType

how to drive the data pins for voice56k type (tx)

Definition at line **544** of file **IxHssAcc.h**.

The documentation for this struct was generated from the following file:

• IxHssAcc.h

# IxI2cInitVars Struct Reference

# [Intel (R) IXP400 Software I2C Driver(IxI2cDrv) API]

contains all the variables required to initialize the I2C unit

### **Data Fields**

#### IxI2cSpeedMode I2cSpeedSelect

Select either normal (100kbps) or fast mode (400kbps).

#### IxI2cFlowMode I2cFlowSelect

Select interrupt or poll mode.

#### IxI2cMasterReadCallbackP MasterReadCBP

The master read callback pointer.

#### IxI2cMasterWriteCallbackP MasterWriteCBP

The master write callback pointer.

#### IxI2cSlaveReadCallbackP SlaveReadCBP

The slave read callback pointer.

#### IxI2cSlaveWriteCallbackP SlaveWriteCBP

The slave write callback pointer.

#### IxI2cGenCallCallbackP GenCallCBP

The general call callback pointer.

#### BOOL I2cGenCallResponseEnable

Enable/disable the unit to respond to generall calls.

#### BOOL I2cSlaveAddrResponseEnable

Enable/disable the unit to respond to the slave address set in ISAR.

#### **BOOL SCLEnable**

Enable/disable the unit from driving the SCL line during master mode operation.

#### UINT8 I2cHWAddr

The address the unit will response to as a slave device.

# **Detailed Description**

contains all the variables required to initialize the I2C unit

Structure to be filled and used for calling initialization

Definition at line **253** of file **IxI2cDrv.h**.

# **Field Documentation**

#### IxI2cGenCallCallbackP IxI2cInitVars::GenCallCBP

The general call callback pointer.

Definition at line **267** of file **IxI2cDrv.h**.

#### IxI2cFlowMode IxI2cInitVars::I2cFlowSelect

Select interrupt or poll mode.

Definition at line 257 of file IxI2cDrv.h.

#### BOOL IxI2cInitVars::I2cGenCallResponseEnable

Enable/disable the unit to respond to generall calls.

Definition at line 268 of file IxI2cDrv.h.

#### UINT8 IxI2cInitVars::I2cHWAddr

The address the unit will response to as a slave device.

Definition at line 276 of file IxI2cDrv.h.

#### BOOL IxI2cInitVars::I2cSlaveAddrResponseEnable

Enable/disable the unit to respond to the slave address set in ISAR.

Definition at line 270 of file IxI2cDrv.h.

#### IxI2cSpeedMode IxI2cInitVars::I2cSpeedSelect

Select either normal (100kbps) or fast mode (400kbps).

Definition at line 255 of file IxI2cDrv.h.

#### IxI2cMasterReadCallbackP IxI2cInitVars::MasterReadCBP

The master read callback pointer.

Definition at line 259 of file IxI2cDrv.h.

#### IxI2cMasterWriteCallbackP IxI2cInitVars::MasterWriteCBP

The master write callback pointer.

Definition at line 261 of file IxI2cDrv.h.

#### BOOL IxI2cInitVars::SCLEnable

Enable/disable the unit from driving the SCL line during master mode operation.

Definition at line 273 of file IxI2cDrv.h.

#### IxI2cSlaveReadCallbackP IxI2cInitVars::SlaveReadCBP

The slave read callback pointer.

Definition at line 263 of file IxI2cDrv.h.

#### IxI2cSlaveWriteCallbackP IxI2cInitVars::SlaveWriteCBP

The slave write callback pointer.

Definition at line 265 of file IxI2cDrv.h.

The documentation for this struct was generated from the following file:

#### • IxI2cDrv.h

# IxI2cStatsCounters Struct Reference

### [Intel (R) IXP400 Software I2C Driver(IxI2cDrv) API]

contains results of counters and their overflow

### **Data Fields**

#### UINT32 ixI2cMasterXmitCounter

Total bytes transmitted as master.

#### UINT32 ixI2cMasterFailedXmitCounter

Total bytes failed for transmission as master.

#### UINT32 ixI2cMasterRcvCounter

Total bytes received as master.

#### UINT32 ixI2cMasterFailedRcvCounter

Total bytes failed for receival as master.

#### UINT32 ixI2cSlaveXmitCounter

Total bytes transmitted as slave.

#### UINT32 ixI2cSlaveFailedXmitCounter

Total bytes failed for transmission as slave.

#### UINT32 ixI2cSlaveRcvCounter

Total bytes received as slave.

#### UINT32 ixI2cSlaveFailedRcvCounter

Total bytes failed for receival as slave.

#### UINT32 ixI2cGenAddrCallSucceedCounter

Total bytes successfully transmitted for general address.

#### UINT32 ixI2cGenAddrCallFailedCounter

Total bytes failed transmission for general address.

#### UINT32 ixI2cArbLossCounter

Total instances of arbitration loss has occured.

# **Detailed Description**

contains results of counters and their overflow

Structure contains all values of counters and associated overflows.

### **Field Documentation**

UINT32 IxI2cStatsCounters::ixI2cArbLossCounter

Total instances of arbitration loss has occured.

Definition at line 307 of file IxI2cDrv.h.

UINT32 IxI2cStatsCounters::ixI2cGenAddrCallFailedCounter

Total bytes failed transmission for general address.

Definition at line 305 of file IxI2cDrv.h.

UINT32 IxI2cStatsCounters::ixI2cGenAddrCallSucceedCounter

Total bytes successfully transmitted for general address.

Definition at line 303 of file IxI2cDrv.h.

UINT32 IxI2cStatsCounters::ixI2cMasterFailedRcvCounter

Total bytes failed for receival as master.

Definition at line 293 of file IxI2cDrv.h.

UINT32 IxI2cStatsCounters::ixI2cMasterFailedXmitCounter

Total bytes failed for transmission as master.

Definition at line 289 of file IxI2cDrv.h.

UINT32 IxI2cStatsCounters::ixI2cMasterRcvCounter

Total bytes received as master.

Definition at line **291** of file **IxI2cDrv.h**.

UINT32 IxI2cStatsCounters::ixI2cMasterXmitCounter

Total bytes transmitted as master.

Definition at line 287 of file IxI2cDrv.h.

#### UINT32 IxI2cStatsCounters::ixI2cSlaveFailedRcvCounter

Total bytes failed for receival as slave.

Definition at line 301 of file IxI2cDrv.h.

#### UINT32 IxI2cStatsCounters::ixI2cSlaveFailedXmitCounter

Total bytes failed for transmission as slave.

Definition at line **297** of file **IxI2cDrv.h**.

#### UINT32 IxI2cStatsCounters::ixI2cSlaveRcvCounter

Total bytes received as slave.

Definition at line 299 of file IxI2cDrv.h.

#### UINT32 IxI2cStatsCounters::ixI2cSlaveXmitCounter

Total bytes transmitted as slave.

Definition at line 295 of file IxI2cDrv.h.

The documentation for this struct was generated from the following file:

#### • IxI2cDrv.h

# IxNpeMhMessage Struct Reference

# [Intel (R) IXP400 Software NPE Message Handler (IxNpeMh) API]

The 2-word message structure to send to and receive from the NPEs.

### **Data Fields**

UINT32 data [2]

the actual data of the message

# **Detailed Description**

The 2-word message structure to send to and receive from the NPEs.

Definition at line **84** of file **IxNpeMh.h**.

### **Field Documentation**

UINT32 IxNpeMhMessage::data[2]

the actual data of the message

Definition at line **86** of file **IxNpeMh.h**.

The documentation for this struct was generated from the following file:

• IxNpeMh.h

# IxOamITU610Cell Struct Reference

OAM ITU610 Cell.

# **Data Fields**

atmCellHeader header IxOamITU610Payload payload

# **Detailed Description**

OAM ITU610 Cell.

Definition at line **221** of file **IxAtmCodelet\_p.h**.

The documentation for this struct was generated from the following file:

• IxAtmCodelet\_p.h

# IxOamITU610GenericPayload Struct Reference

Generic payload isn't a real payload but is used for checking which payload type a received OAM cell is.

### **Data Fields**

UINT8 oamTypeAndFunction

UINT8 reserved [IX\_OAM\_ITU610\_GENERIC\_PAYLOAD\_RESERVED\_BYTES\_LEN]

UINT8 reservedAndCrc10 [IX\_OAM\_ITU610\_RESERVED\_AND\_CRC10\_LEN]

# **Detailed Description**

Generic payload isn't a real payload but is used for checking which payload type a received OAM cell is.

Definition at line 201 of file IxAtmCodelet\_p.h.

The documentation for this struct was generated from the following file:

• IxAtmCodelet\_p.h

# IxOamITU610LbPayload Struct Reference

Oam cells payload typedefs.

### **Data Fields**

UINT8 oamTypeAndFunction

UINT8 loopbackIndication

UINT8 correlationTag [IX\_OAM\_ITU610\_LB\_CORRELATION\_TAG\_LEN]

UINT8 llid [IX\_OAM\_ITU610\_LOCATION\_ID\_LEN]

UINT8 sourceId [IX\_OAM\_ITU610\_LOCATION\_ID\_LEN]

UINT8 reserved [IX\_OAM\_ITU610\_LB\_RESERVED\_BYTES\_LEN]

UINT8 reservedAndCrc10 [IX\_OAM\_ITU610\_RESERVED\_AND\_CRC10\_LEN]

## **Detailed Description**

Oam cells payload typedefs.

Definition at line 186 of file IxAtmCodelet\_p.h.

The documentation for this struct was generated from the following file:

• IxAtmCodelet\_p.h

# IxOamITU610Payload Union Reference

OAM ITU610 Payload.

### **Data Fields**

IxOamITU610LbPayload lbPayload IxOamITU610GenericPayload genericPayload

## **Detailed Description**

OAM ITU610 Payload.

Definition at line **211** of file **IxAtmCodelet\_p.h**.

The documentation for this union was generated from the following file:

• IxAtmCodelet\_p.h

# IxParityENAccAHBErrorTransaction Struct Reference

[Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API, Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API, Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API]

The Master and Slave on the AHB bus interface whose transaction might have resulted in the parity error notification to Intel XScale(R) Core .

#### **Data Fields**

IxParityENAccAHBErrorMaster ahbErrorMaster

Master on AHB bus.

IxParityENAccAHBErrorSlave ahbErrorSlave
Slave on AHB bus.

## **Detailed Description**

The Master and Slave on the AHB bus interface whose transaction might have resulted in the parity error notification to Intel XScale(R) Core .

NOTE: This information may be used in the data abort exception handler to differentiate between the Intel XScale(R) Core and non–Intel XScale(R) Core access to the SDRAM memory.

Definition at line **368** of file **IxParityENAcc.h**.

## **Field Documentation**

IxParityENAccAHBErrorMaster IxParityENAccAHBErrorTransaction::ahbErrorMaster

Master on AHB bus.

Definition at line **370** of file **IxParityENAcc.h**.

IxParityENAccAHBErrorSlave IxParityENAccAHBErrorTransaction::ahbErrorSlave

Slave on AHB bus.

Definition at line **371** of file **IxParityENAcc.h**.

IxParityENAccAHBErrorTransaction Struct Reference [Intel (R) IXP400 Software Parity Error Notifier (IxParityEnacchemistry Enach Parity Error Notifier (IxParityEnacchemistry Enacchemistry Enachemistry Enachemistr

| documentation for this struct was generated from the following file: |  |  |  |  |  |
|----------------------------------------------------------------------|--|--|--|--|--|
| • IxParityENAcc.h                                                    |  |  |  |  |  |
|                                                                      |  |  |  |  |  |
|                                                                      |  |  |  |  |  |
|                                                                      |  |  |  |  |  |
|                                                                      |  |  |  |  |  |
|                                                                      |  |  |  |  |  |
|                                                                      |  |  |  |  |  |
|                                                                      |  |  |  |  |  |
|                                                                      |  |  |  |  |  |
|                                                                      |  |  |  |  |  |
|                                                                      |  |  |  |  |  |
|                                                                      |  |  |  |  |  |
|                                                                      |  |  |  |  |  |
|                                                                      |  |  |  |  |  |
|                                                                      |  |  |  |  |  |
|                                                                      |  |  |  |  |  |
|                                                                      |  |  |  |  |  |
|                                                                      |  |  |  |  |  |
|                                                                      |  |  |  |  |  |
|                                                                      |  |  |  |  |  |
|                                                                      |  |  |  |  |  |
|                                                                      |  |  |  |  |  |
|                                                                      |  |  |  |  |  |
|                                                                      |  |  |  |  |  |
|                                                                      |  |  |  |  |  |
|                                                                      |  |  |  |  |  |
|                                                                      |  |  |  |  |  |
|                                                                      |  |  |  |  |  |
|                                                                      |  |  |  |  |  |
|                                                                      |  |  |  |  |  |
|                                                                      |  |  |  |  |  |
|                                                                      |  |  |  |  |  |

# IxParityENAccEbcConfig Struct Reference

[Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API, Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API, Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API]

Expansion Bus Controller parity detection is to be enabled or disabled.

#### **Data Fields**

IxParityENAccConfigOption ebcCs0Enabled

Expansion Bus Controller - Chip Select 0.

IxParityENAccConfigOption ebcCs1Enabled

Expansion Bus Controller - Chip Select 1.

IxParityENAccConfigOption ebcCs2Enabled

Expansion Bus Controller - Chip Select 2.

IxParityENAccConfigOption ebcCs3Enabled

Expansion Bus Controller - Chip Select 3.

IxParityENAccConfigOption ebcCs4Enabled

Expansion Bus Controller – Chip Select 4.

IxParityENAccConfigOption ebcCs5Enabled

Expansion Bus Controller - Chip Select 5.

IxParityENAccConfigOption ebcCs6Enabled

Expansion Bus Controller - Chip Select 6.

IxParityENAccConfigOption ebcCs7Enabled

Expansion Bus Controller - Chip Select 7.

IxParityENAccConfigOption ebcExtMstEnabled

External Master on Expansion bus.

IxParityENAccParityType parityOddEven

Parity – Odd or Even.

## **Detailed Description**

Expansion Bus Controller parity detection is to be enabled or disabled.

Note: All the Chip Select(s) and External Masters will have the same parity

IxParityENAccEbcConfig Struct Reference [Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) A

## **Field Documentation**

#### IxParityENAccConfigOption IxParityENAccEbcConfig::ebcCs0Enabled

Expansion Bus Controller – Chip Select 0.

Definition at line 115 of file IxParityENAcc.h.

#### IxParityENAccConfigOption IxParityENAccEbcConfig::ebcCs1Enabled

Expansion Bus Controller – Chip Select 1.

Definition at line **116** of file **IxParityENAcc.h**.

#### IxParityENAccConfigOption IxParityENAccEbcConfig::ebcCs2Enabled

Expansion Bus Controller – Chip Select 2.

Definition at line 117 of file IxParityENAcc.h.

#### IxParityENAccConfigOption IxParityENAccEbcConfig::ebcCs3Enabled

Expansion Bus Controller – Chip Select 3.

Definition at line **118** of file **IxParityENAcc.h**.

#### IxParityENAccConfigOption IxParityENAccEbcConfig::ebcCs4Enabled

Expansion Bus Controller - Chip Select 4.

Definition at line 119 of file IxParityENAcc.h.

#### IxParityENAccConfigOption IxParityENAccEbcConfig::ebcCs5Enabled

Expansion Bus Controller – Chip Select 5.

Definition at line **120** of file **IxParityENAcc.h**.

#### IxParityENAccConfigOption IxParityENAccEbcConfig::ebcCs6Enabled

Field Documentation 775

Expansion Bus Controller – Chip Select 6.

Definition at line 121 of file IxParityENAcc.h.

#### IxParityENAccConfigOption IxParityENAccEbcConfig::ebcCs7Enabled

Expansion Bus Controller – Chip Select 7.

Definition at line 122 of file IxParityENAcc.h.

#### $\textbf{IxParityENAccConfigOption} \ IxParityENAccEbcConfig::ebcExtMstEnabled$

External Master on Expansion bus.

Definition at line 123 of file IxParityENAcc.h.

#### **IxParityENAccParityType** IxParityENAccEbcConfig::parityOddEven

Parity – Odd or Even.

Definition at line 124 of file IxParityENAcc.h.

The documentation for this struct was generated from the following file:

• IxParityENAcc.h

Field Documentation 776

# IxParityENAccEbcParityErrorStats Struct Reference

[Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API, Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API, Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API]

Expansion Bus Controller parity error statistics.

#### **Data Fields**

UINT32 parityErrorsInbound

Odd bit parity errors on inbound transfers.

UINT32 parityErrorsOutbound

Odd bit parity errors on outbound transfers.

## **Detailed Description**

Expansion Bus Controller parity error statistics.

Definition at line 216 of file IxParityENAcc.h.

## **Field Documentation**

UINT32 IxParityENAccEbcParityErrorStats::parityErrorsInbound

Odd bit parity errors on inbound transfers.

Definition at line **218** of file **IxParityENAcc.h**.

UINT32 IxParityENAccEbcParityErrorStats::parityErrorsOutbound

Odd bit parity errors on outbound transfers.

Definition at line 219 of file IxParityENAcc.h.

The documentation for this struct was generated from the following file:

# IxParityENAccHWParityConfig Struct Reference

[Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API, Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API, Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API]

Parity error configuration of the Hardware Blocks.

#### **Data Fields**

IxParityENAccNpeConfig npeAConfig

NPE A parity detection is to be enabled/disabled.

IxParityENAccNpeConfig npeBConfig

*NPE B parity detection is to be enabled/disabled.* 

IxParityENAccNpeConfig npeCConfig

*NPE C parity detection is to be enabled/disabled.* 

IxParityENAccMcuConfig mcuConfig

MCU pairty detection is to be enabled/disabled.

IxParityENAccConfigOption swcpEnabled

SWCP parity detection is to be enabled.

IxParityENAccConfigOption aqmEnabled

AQM parity detection is to be enabled.

IxParityENAccPbcConfig pbcConfig

PCI Bus Controller parity detection is to be enabled/disabled.

IxParityENAccEbcConfig ebcConfig

Expansion Bus Controller parity detection is to be enabled/disabled.

## **Detailed Description**

Parity error configuration of the Hardware Blocks.

Definition at line **149** of file **IxParityENAcc.h**.

## **Field Documentation**

IxParityENAccConfigOption IxParityENAccHWParityConfig::aqmEnabled

IxParityENAccHWParityConfig Struct Reference [Intel (R) IXP400 Software Parity Error Notifier (AXBarityEN

AQM parity detection is to be enabled.

Definition at line 156 of file IxParityENAcc.h.

#### IxParityENAccEbcConfig IxParityENAccHWParityConfig::ebcConfig

Expansion Bus Controller parity detection is to be enabled/disabled.

Definition at line **158** of file **IxParityENAcc.h**.

#### IxParityENAccMcuConfig IxParityENAccHWParityConfig::mcuConfig

MCU pairty detection is to be enabled/disabled.

Definition at line 154 of file IxParityENAcc.h.

#### IxParityENAccNpeConfig IxParityENAccHWParityConfig::npeAConfig

NPE A parity detection is to be enabled/disabled.

Definition at line **151** of file **IxParityENAcc.h**.

#### IxParityENAccNpeConfig IxParityENAccHWParityConfig::npeBConfig

NPE B parity detection is to be enabled/disabled.

Definition at line **152** of file **IxParityENAcc.h**.

#### IxParityENAccNpeConfig IxParityENAccHWParityConfig::npeCConfig

NPE C parity detection is to be enabled/disabled.

Definition at line **153** of file **IxParityENAcc.h**.

#### IxParityENAccPbcConfig IxParityENAccHWParityConfig::pbcConfig

PCI Bus Controller parity detection is to be enabled/disabled.

Definition at line **157** of file **IxParityENAcc.h**.

#### IxParityENAccConfigOption IxParityENAccHWParityConfig::swcpEnabled

IxParityENAccHWParityConfig Struct Reference [Intel (R) IXP400 Software Parity Error Notifier (IXP) arityEN

SWCP parity detection is to be enabled.

Definition at line **155** of file **IxParityENAcc.h**.

The documentation for this struct was generated from the following file:

# IxParityENAccMcuConfig Struct Reference

[Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API, Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API, Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API]

MCU pairty detection is to be enabled/disabled.

#### **Data Fields**

 $Ix Parity ENAcc Config Option\ single bit Detect Enabled$ 

Single-bit parity error detection.

 $Ix Parity ENAcc Config Option\ single bit Correction Enabled$ 

Single-bit parity error correction.

IxParityENAccConfigOption multibitDetectionEnabled

*Multi-bit parity error detection.* 

## **Detailed Description**

MCU pairty detection is to be enabled/disabled.

Definition at line **96** of file **IxParityENAcc.h**.

## **Field Documentation**

IxParityENAccConfigOption IxParityENAccMcuConfig::multibitDetectionEnabled

Multi-bit parity error detection.

Definition at line 100 of file IxParityENAcc.h.

IxParityENAccConfigOption IxParityENAccMcuConfig::singlebitCorrectionEnabled

Single-bit parity error correction.

Definition at line **99** of file **IxParityENAcc.h**.

IxParityENAccConfigOption IxParityENAccMcuConfig::singlebitDetectEnabled

IxParityENAccMcuConfig Struct Reference [Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc)

Single-bit parity error detection.

Definition at line 98 of file IxParityENAcc.h.

The documentation for this struct was generated from the following file:

# IxParityENAccMcuParityErrorStats Struct Reference

[Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API, Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API, Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API]

DDR Memory Control Unit parity error statistics.

#### **Data Fields**

UINT32 parityErrorsSingleBit

Parity errors of the type Single-Bit.

UINT32 parityErrorsMultiBit

Parity errors of the type Multi-Bit.

UINT32 parityErrorsOverflow

Parity errors when more than two parity errors occured.

## **Detailed Description**

DDR Memory Control Unit parity error statistics.

Note: There could be two outstanding parity errors at any given time whose address details captured. If there is no room for the new interrupt then it would be treated as overflow parity condition.

Definition at line **187** of file **IxParityENAcc.h**.

## **Field Documentation**

UINT32 IxParityENAccMcuParityErrorStats::parityErrorsMultiBit

Parity errors of the type Multi-Bit.

Definition at line **190** of file **IxParityENAcc.h**.

UINT32 IxParityENAccMcuParityErrorStats::parityErrorsOverflow

Parity errors when more than two parity errors occured.

IxParityENAccMcuParityErrorStats Struct Reference [Intel (R) IXP400 Software Parity Error Noti**76**8 (IxParit

Definition at line 191 of file IxParityENAcc.h.

UINT32 IxParityENAccMcuParityErrorStats::parityErrorsSingleBit

Parity errors of the type Single–Bit.

Definition at line 189 of file IxParityENAcc.h.

The documentation for this struct was generated from the following file:

# IxParityENAccNpeConfig Struct Reference

[Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API, Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API, Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API]

NPE parity detection is to be enabled/disabled.

#### **Data Fields**

IxParityENAccConfigOption ideEnabled

NPE IMem, DMem and External.

IxParityENAccParityType parityOddEven

Parity - Odd or Even.

## **Detailed Description**

NPE parity detection is to be enabled/disabled.

Definition at line 82 of file IxParityENAcc.h.

## **Field Documentation**

IxParityENAccConfigOption IxParityENAccNpeConfig::ideEnabled

NPE IMem, DMem and External.

Definition at line **84** of file **IxParityENAcc.h**.

**IxParityENAccParityType** IxParityENAccNpeConfig::parityOddEven

Parity – Odd or Even.

Definition at line **85** of file **IxParityENAcc.h**.

The documentation for this struct was generated from the following file:

# IxParityENAccNpeParityErrorStats Struct Reference

[Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API, Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API, Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API]

NPE parity error statistics.

#### **Data Fields**

UINT32 parityErrorsIMem

Parity errors in Instruction Memory.

UINT32 parityErrorsDMem

Parity errors in Data Memory.

UINT32 parityErrorsExternal

Parity errors in NPE External Entities.

## **Detailed Description**

NPE parity error statistics.

Definition at line **169** of file **IxParityENAcc.h**.

### **Field Documentation**

UINT32 IxParityENAccNpeParityErrorStats::parityErrorsDMem

Parity errors in Data Memory.

Definition at line 172 of file IxParityENAcc.h.

UINT32 IxParityENAccNpeParityErrorStats::parityErrorsExternal

Parity errors in NPE External Entities.

Definition at line 173 of file IxParityENAcc.h.

UINT32 IxParityENAccNpeParityErrorStats::parityErrorsIMem

Parity errors in Instruction Memory.

Definition at line 171 of file IxParityENAcc.h.

The documentation for this struct was generated from the following file:

# IxParityENAccParityErrorContextMessage Struct Reference

[Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API, Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API, Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API]

Parity Error Context Message.

#### **Data Fields**

#### IxParityENAccParityErrorSource pecParitySource

Source info of parity error.

#### IxParityENAccParityErrorAccess pecAccessType

Read or Write Access Read – NPE, SWCP, AQM, DDR MCU, PCI Bus Ctrlr, Exp Bus Ctrlr (Outbound) Write – DDR MCU, PCI Bus Ctrlr, Exp Bus Ctrlr (Inbound i.e., External Master).

#### IxParityENAccParityErrorAddress pecAddress

Address faulty location Valid only for AQM, DDR MCU, Exp Bus Ctrlr

#### IxParityENAccParityErrorData pecData

Data read from the faulty location Valid only for AQM and DDR MCU For DDR MCU it is the bit location of the Single-bit parity.

#### IxParityENAccParityErrorRequester pecRequester

Requester of SDRAM memory access Valid only for the DDR MCU.

#### IxParityENAccAHBErrorTransaction ahbErrorTran

Master and Slave information on the last AHB Error Transaction.

## **Detailed Description**

Parity Error Context Message.

Definition at line **381** of file **IxParityENAcc.h**.

## **Field Documentation**

IxParityENAccAHBErrorTransaction IxParityENAccParityErrorContextMessage::ahbErrorTran

Master and Slave information on the last AHB Error Transaction.

Definition at line 400 of file IxParityENAcc.h.

#### **IxParityENAccParityErrorAccess** IxParityENAccParityErrorContextMessage::pecAccessType

Read or Write Access Read – NPE, SWCP, AQM, DDR MCU, PCI Bus Ctrlr, Exp Bus Ctrlr (Outbound) Write – DDR MCU, PCI Bus Ctrlr, Exp Bus Ctrlr (Inbound i.e., External Master).

Definition at line **384** of file **IxParityENAcc.h**.

#### IxParityENAccParityErrorAddress IxParityENAccParityErrorContextMessage::pecAddress

Address faulty location Valid only for AQM, DDR MCU, Exp Bus Ctrlr.

Definition at line **391** of file **IxParityENAcc.h**.

#### IxParityENAccParityErrorData IxParityENAccParityErrorContextMessage::pecData

Data read from the faulty location Valid only for AQM and DDR MCU For DDR MCU it is the bit location of the Single-bit parity.

Definition at line **394** of file **IxParityENAcc.h**.

#### **IxParityENAccParityErrorSource** IxParityENAccParityErrorContextMessage::pecParitySource

Source info of parity error.

Definition at line **383** of file **IxParityENAcc.h**.

#### IxParityENAccParityErrorRequester IxParityENAccParityErrorContextMessage::pecRequester

Requester of SDRAM memory access Valid only for the DDR MCU.

Definition at line **398** of file **IxParityENAcc.h**.

The documentation for this struct was generated from the following file:

# IxParityENAccParityErrorStats Struct Reference

[Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API, Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API, Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API]

Parity Error Statistics for the all the hardware blocks.

## **Data Fields**

IxParityENAccNpeParityErrorStats npeStats

NPE parity error statistics.

IxParityENAccMcuParityErrorStats mcuStats

MCU parity error statistics.

IxParityENAccPbcParityErrorStats pbcStats

PBC parity error statistics.

IxParityENAccEbcParityErrorStats ebcStats

EBC parity error statistics.

UINT32 swcpStats

SWCP parity error statistics.

UINT32 aqmStats

AQM parity error statistics.

## **Detailed Description**

Parity Error Statistics for the all the hardware blocks.

Definition at line **230** of file **IxParityENAcc.h**.

## **Field Documentation**

UINT32 IxParityENAccParityErrorStats::aqmStats

AQM parity error statistics.

Definition at line **237** of file **IxParityENAcc.h**.

#### IxParityENAccEbcParityErrorStats IxParityENAccParityErrorStats::ebcStats

EBC parity error statistics.

Definition at line 235 of file IxParityENAcc.h.

#### IxParityENAccMcuParityErrorStats IxParityENAccParityErrorStats::mcuStats

MCU parity error statistics.

Definition at line **233** of file **IxParityENAcc.h**.

#### IxParityENAccNpeParityErrorStats IxParityENAccParityErrorStats::npeStats

NPE parity error statistics.

Definition at line 232 of file IxParityENAcc.h.

#### IxParityENAccPbcParityErrorStats IxParityENAccParityErrorStats::pbcStats

PBC parity error statistics.

Definition at line **234** of file **IxParityENAcc.h**.

#### UINT32 IxParityENAccParityErrorStats::swcpStats

SWCP parity error statistics.

Definition at line 236 of file IxParityENAcc.h.

The documentation for this struct was generated from the following file:

# IxParityENAccPbcConfig Struct Reference

[Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API, Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API, Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API]

PCI Bus Controller parity detection is to be enabled or disabled.

#### **Data Fields**

IxParityENAccConfigOption pbcInitiatorEnabled

PCI Bus Controller as PCI Initiator.

IxParityENAccConfigOption pbcTargetEnabled

PCI Bus Controller as PCI Target.

## **Detailed Description**

PCI Bus Controller parity detection is to be enabled or disabled.

Definition at line 135 of file IxParityENAcc.h.

## **Field Documentation**

IxParityENAccConfigOption IxParityENAccPbcConfig::pbcInitiatorEnabled

PCI Bus Controller as PCI Initiator.

Definition at line **137** of file **IxParityENAcc.h**.

**IxParityENAccConfigOption** IxParityENAccPbcConfig::pbcTargetEnabled

PCI Bus Controller as PCI Target.

Definition at line **138** of file **IxParityENAcc.h**.

The documentation for this struct was generated from the following file:

# IxParityENAccPbcParityErrorStats Struct Reference

[Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API, Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API, Intel (R) IXP400 Software Parity Error Notifier (IxParityENAcc) API]

PCI Bus Controller parity error statistics.

#### **Data Fields**

UINT32 parityErrorsPciInitiator

Parity errors received as a PCI Initiator.

UINT32 parityErrorsPciTarget

Parity errors received as a PCI Target.

## **Detailed Description**

PCI Bus Controller parity error statistics.

Definition at line 202 of file IxParityENAcc.h.

## **Field Documentation**

UINT32 IxParityENAccPbcParityErrorStats::parityErrorsPciInitiator

Parity errors received as a PCI Initiator.

Definition at line **204** of file **IxParityENAcc.h**.

UINT32 IxParityENAccPbcParityErrorStats::parityErrorsPciTarget

Parity errors received as a PCI Target.

Definition at line 205 of file IxParityENAcc.h.

The documentation for this struct was generated from the following file:

## IxPerfProfAccBusPmuResults Struct Reference

[Intel (R) IXP400 Software Performance Profiling (IxPerfProfAcc) API]

Results obtained from running the Bus Pmu component. The results are obtained when the get functions is called.

### **Data Fields**

UINT32 **statsToGetLower27Bit** [IX\_PERFPROF\_ACC\_BUS\_PMU\_MAX\_PECS] *Lower 27 Bit of counter value.* 

UINT32 **statsToGetUpper32Bit** [IX\_PERFPROF\_ACC\_BUS\_PMU\_MAX\_PECS] *Upper 32 Bit of counter value.* 

## **Detailed Description**

Results obtained from running the Bus Pmu component. The results are obtained when the get functions is called.

Definition at line **167** of file **IxPerfProfAcc.h**.

## **Field Documentation**

UINT32

IxPerfProfAccBusPmuResults::statsToGetLower27Bit[IX\_PERFPROF\_ACC\_BUS\_PMU\_MAX\_PECS]

Lower 27 Bit of counter value.

Definition at line **169** of file **IxPerfProfAcc.h**.

UINT32

IxPerfProfAccBusPmuResults::statsToGetUpper32Bit[IX\_PERFPROF\_ACC\_BUS\_PMU\_MAX\_PECS]

Upper 32 Bit of counter value.

Definition at line **170** of file **IxPerfProfAcc.h**.

The documentation for this struct was generated from the following file:

• IxPerfProfAcc.h

# IxPerfProfAccXcycleResults Struct Reference

[Intel (R) IXP400 Software Performance Profiling (IxPerfProfAcc) API]

Results obtained from Xcycle run.

#### **Data Fields**

float maxIdlePercentage

maximum percentage of Idle cycles

float minIdlePercentage

minimum percentage of Idle cycles

float aveIdlePercentage

average percentage of Idle cycles

**UINT32 totalMeasurements** 

total number of measurement made

## **Detailed Description**

Results obtained from Xcycle run.

Definition at line **153** of file **IxPerfProfAcc.h**.

## **Field Documentation**

 $float\ Ix Perf Prof Acc X cycle Results :: ave Idle Percentage$ 

average percentage of Idle cycles

Definition at line **157** of file **IxPerfProfAcc.h**.

float IxPerfProfAccXcycleResults::maxIdlePercentage

maximum percentage of Idle cycles

Definition at line **155** of file **IxPerfProfAcc.h**.

float IxPerfProfAccXcycleResults::minIdlePercentage

IxPerfProfAccXcycleResults Struct Reference [Intel (R) IXP400 Software Performance Profiling (1988) [Intel (R) IXP400 Software Performance Performance Profiling (1988) [Intel (R) IXP400 Software Performance Per

minimum percentage of Idle cycles

Definition at line **156** of file **IxPerfProfAcc.h**.

UINT32 IxPerfProfAccXcycleResults::totalMeasurements

total number of measurement made

Definition at line 158 of file IxPerfProfAcc.h.

The documentation for this struct was generated from the following file:

• IxPerfProfAcc.h

## IxPerfProfAccXscalePmuEvtCnt Struct Reference

[Intel (R) IXP400 Software Performance Profiling (IxPerfProfAcc) API]

contains results of a counter

#### **Data Fields**

UINT32 lower32BitsEventCount

lower 32bits value of the event counter

UINT32 upper32BitsEventCount

upper 32bits value of the event counter

## **Detailed Description**

contains results of a counter

Structure contains the results of a counter, which are split into the lower and upper 32 bits of the final count

Definition at line **123** of file **IxPerfProfAcc.h**.

## **Field Documentation**

UINT32 IxPerfProfAccXscalePmuEvtCnt::lower32BitsEventCount

lower 32bits value of the event counter

Definition at line 125 of file IxPerfProfAcc.h.

UINT32 IxPerfProfAccXscalePmuEvtCnt::upper32BitsEventCount

upper 32bits value of the event counter

Definition at line **126** of file **IxPerfProfAcc.h**.

The documentation for this struct was generated from the following file:

• IxPerfProfAcc.h

## IxPerfProfAccXscalePmuResults Struct Reference

## [Intel (R) IXP400 Software Performance Profiling (IxPerfProfAcc) API]

contains results of counters and their overflow

#### **Data Fields**

UINT32 clk value

current value of clock counter

UINT32 clk\_samples

number of clock counter overflows

UINT32 event1\_value

current value of event 1 counter

UINT32 event1\_samples

number of event 1 counter overflows

UINT32 event2\_value

current value of event 2 counter

UINT32 event2\_samples

number of event 2 counter overflows

UINT32 event3 value

*current value of event 3 counter* 

UINT32 event3 samples

number of event 3 counter overflows

UINT32 event4\_value

current value of event 4 counter

UINT32 event4\_samples

number of event 4 counter overflows

## **Detailed Description**

contains results of counters and their overflow

Structure contains all values of counters and associated overflows. The specific event and clock counters are determined by the user

Definition at line **135** of file **IxPerfProfAcc.h**.

IXPerfProfAccXscalePmuResults Struct Reference [Intel (R) IXP400 Software Performance Profiting (IXPerf

### **Field Documentation**

UINT32 IxPerfProfAccXscalePmuResults::clk\_samples

number of clock counter overflows

Definition at line 138 of file IxPerfProfAcc.h.

UINT32 IxPerfProfAccXscalePmuResults::clk\_value

current value of clock counter

Definition at line 137 of file IxPerfProfAcc.h.

UINT32 IxPerfProfAccXscalePmuResults::event1\_samples

number of event 1 counter overflows

Definition at line **140** of file **IxPerfProfAcc.h**.

 $UINT32\ Ix PerfProfAccX scale PmuRe sults:: event1\_value$ 

current value of event 1 counter

Definition at line 139 of file IxPerfProfAcc.h.

UINT32 IxPerfProfAccXscalePmuResults::event2\_samples

number of event 2 counter overflows

Definition at line 142 of file IxPerfProfAcc.h.

UINT32 IxPerfProfAccXscalePmuResults::event2\_value

current value of event 2 counter

Definition at line **141** of file **IxPerfProfAcc.h**.

UINT32 IxPerfProfAccXscalePmuResults::event3\_samples

Field Documentation 799

number of event 3 counter overflows

Definition at line **144** of file **IxPerfProfAcc.h**.

#### UINT32 IxPerfProfAccXscalePmuResults::event3\_value

current value of event 3 counter

Definition at line 143 of file IxPerfProfAcc.h.

#### $UINT32\ IxPerfProfAccX scalePmuResults:: event4\_samples$

number of event 4 counter overflows

Definition at line **146** of file **IxPerfProfAcc.h**.

#### UINT32 IxPerfProfAccXscalePmuResults::event4\_value

current value of event 4 counter

Definition at line 145 of file IxPerfProfAcc.h.

The documentation for this struct was generated from the following file:

#### • IxPerfProfAcc.h

Field Documentation 800

# IxPerfProfAccXscalePmuSamplePcProfile Struct Reference

[Intel (R) IXP400 Software Performance Profiling (IxPerfProfAcc) API]

contains summary of samples taken

#### **Data Fields**

UINT32 programCounter

the program counter value of the sample

UINT32 freq

the frequency of the occurence of the sample

## **Detailed Description**

contains summary of samples taken

Structure contains all details of each program counter value – frequency that PC occurs

Definition at line 111 of file IxPerfProfAcc.h.

## **Field Documentation**

UINT32 IxPerfProfAccXscalePmuSamplePcProfile::freq

the frequency of the occurence of the sample

Definition at line 114 of file IxPerfProfAcc.h.

UINT32 IxPerfProfAccXscalePmuSamplePcProfile::programCounter

the program counter value of the sample

Definition at line 113 of file IxPerfProfAcc.h.

The documentation for this struct was generated from the following file:

• IxPerfProfAcc.h

# IxQMgrQInlinedReadWriteInfo Struct Reference

## [Intel (R) IXP400 Software Queue Manager (IxQMgr) API]

Internal structure to facilitate inlining functions in **IxQMgr.h**.

#### **Data Fields**

UINT32 qOflowStatBitMask

overflow status mask

UINT32 qWriteCount

queue write count

volatile UINT32 \* qAccRegAddr

access register

volatile UINT32 \* qUOStatRegAddr

status register

volatile UINT32 \* qConfigRegAddr

config register

UINT32 qEntrySizeInWords

queue entry size in words

UINT32 qSizeInEntries

queue size in entries

UINT32 qUflowStatBitMask

underflow status mask

UINT32 qReadCount

queue read count

## **Detailed Description**

Internal structure to facilitate inlining functions in **IxQMgr.h**.

Definition at line 998 of file IxQMgr.h.

## **Field Documentation**

volatile UINT32\* IxQMgrQInlinedReadWriteInfo::qAccRegAddr

IxQMgrQInlinedReadWriteInfo Struct Reference [Intel (R) IXP400 Software Queue Manager (IxQMQr) API]

access register

Definition at line 1005 of file IxQMgr.h.

 $Referenced \ by \ \textbf{ixQMgrQBurstRead}(), \ \textbf{ixQMgrQBurstWrite}(), \ \textbf{ixQMgrQRead}(), \ and \ \textbf{ixQMgrQWrite}().$ 

volatile UINT32\* IxQMgrQInlinedReadWriteInfo::qConfigRegAddr

config register

Definition at line 1007 of file IxQMgr.h.

 $Referenced \ by \ \textbf{ixQMgrQRead}(), \ and \ \textbf{ixQMgrQWrite}().$ 

UINT32 IxQMgrQInlinedReadWriteInfo::qEntrySizeInWords

queue entry size in words

Definition at line 1008 of file IxQMgr.h.

Referenced by ixQMgrQBurstRead(), ixQMgrQBurstWrite(), ixQMgrQRead(), and ixQMgrQWrite().

 $UINT32\ IxQMgrQInlinedReadWriteInfo:: qOflowStatBitMask$ 

overflow status mask

Definition at line 1001 of file IxQMgr.h.

Referenced by ixQMgrQBurstWrite(), and ixQMgrQWrite().

UINT32 IxQMgrQInlinedReadWriteInfo::qReadCount

queue read count

Definition at line 1013 of file IxQMgr.h.

Referenced by ixQMgrQBurstRead(), and ixQMgrQRead().

UINT32 IxQMgrQInlinedReadWriteInfo::qSizeInEntries

queue size in entries

Definition at line **1009** of file **IxQMgr.h**.

IxQMgrQInlinedReadWriteInfo Struct Reference [Intel (R) IXP400 Software Queue Manager (IxQMQr) API]

Referenced by ixQMgrQBurstWrite(), ixQMgrQRead(), and ixQMgrQWrite().

#### $UINT32\ Ix QMgrQInlined Read WriteInfo:: qUflow Stat Bit Mask$

underflow status mask

Definition at line 1012 of file IxQMgr.h.

Referenced by ixQMgrQBurstRead(), and ixQMgrQRead().

#### volatile UINT32\* IxQMgrQInlinedReadWriteInfo::qUOStatRegAddr

status register

Definition at line 1006 of file IxQMgr.h.

Referenced by ixQMgrQBurstRead(), ixQMgrQBurstWrite(), ixQMgrQRead(), and ixQMgrQWrite().

#### UINT32 IxQMgrQInlinedReadWriteInfo::qWriteCount

queue write count

Definition at line 1002 of file IxQMgr.h.

Referenced by ixQMgrQBurstWrite(), and ixQMgrQWrite().

The documentation for this struct was generated from the following file:

• IxQMgr.h

# IxSspAccStatsCounters Struct Reference

[Intel (R) IXP400 Software SSP Serial Port Access (IxSspAcc) API, Intel (R) IXP400 Software SSP Serial Port Access (IxSspAcc) API]

contains counters of the SSP statistics

### **Data Fields**

UINT32 ixSspRcvCounter

Total frames received.

UINT32 ixSspXmitCounter

Total frames transmitted.

UINT32 ixSspOverflowCounter

Total occurrences of overflow.

## **Detailed Description**

contains counters of the SSP statistics

Structure contains all values of counters and associated overflows.

Definition at line **348** of file **IxSspAcc.h**.

## **Field Documentation**

UINT32 IxSspAccStatsCounters::ixSspOverflowCounter

Total occurrences of overflow.

Definition at line **352** of file **IxSspAcc.h**.

UINT32 IxSspAccStatsCounters::ixSspRcvCounter

Total frames received.

Definition at line **350** of file **IxSspAcc.h**.

UINT32 IxSspAccStatsCounters::ixSspXmitCounter

IxSspAccStatsCounters Struct Reference [Intel (R) IXP400 Software SSP Serial Port Access (Ix865Acc) Al

Total frames transmitted.

Definition at line **351** of file **IxSspAcc.h**.

The documentation for this struct was generated from the following file:

• IxSspAcc.h

# IxSspInitVars Struct Reference

# [Intel (R) IXP400 Software SSP Serial Port Access (IxSspAcc) API, Intel (R) IXP400 Software SSP Serial Port Access (IxSspAcc) API]

contains all the variables required to initialize the SSP serial port hardware.

## **Data Fields**

### Ix SspAcc Frame Format Frame Format Selected

Select between SPI, SSP and Microwire.

### IxSspAccDataSize DataSizeSelected

Select between 4 and 16.

#### IxSspAccClkSource ClkSourceSelected

*Select clock source to be on-chip or external.* 

#### IxSspAccFifoThreshold TxFIFOThresholdSelected

Select Tx FIFO threshold between 1 to 16.

#### IxSspAccFifoThreshold RxFIFOThresholdSelected

Select Rx FIFO threshold between 1 to 16.

#### **BOOL RxFIFOIntrEnable**

Enable/disable Rx FIFO threshold interrupt.

#### **BOOL TxFIFOIntrEnable**

Enable/disable Tx FIFO threshold interrupt.

#### RxFIFOThresholdHandler RxFIFOThsldHdlr

Pointer to function to handle a Rx FIFO interrupt.

#### TxFIFOThresholdHandler TxFIFOThsldHdlr

*Pointer to function to handle a Tx FIFO interrupt.* 

#### RxFIFOOverrunHandler RxFIFOOverrunHdlr

Pointer to function to handle a Rx FIFO overrun interrupt.

#### **BOOL LoopbackEnable**

Select operation mode to be normal or loopback mode.

#### IxSspAccSpiSclkPhaseSpiSclkPhaseSelected

Select SPI SCLK phase to start with one inactive cycle and end with 1/2 inactive cycle or start with 1/2 inactive cycle and end with one inactive cycle.

#### IxSspAccSpiSclkPolaritySpiSclkPolaritySelected

Select SPI SCLK idle state to be low or high.

#### IxSspAccMicrowireCtlWord MicrowireCtlWordSelected

Select Microwire control format to be 8 or 16-bit.

#### **UINT8 SerialClkRateSelected**

*Select between 0 (1.8432Mbps) and 255 (7.2Kbps).* 

# **Detailed Description**

contains all the variables required to initialize the SSP serial port hardware.

Structure to be filled and used for calling initialization

Definition at line 286 of file IxSspAcc.h.

## **Field Documentation**

#### IxSspAccClkSource IxSspInitVars::ClkSourceSelected

Select clock source to be on-chip or external.

Definition at line **291** of file **IxSspAcc.h**.

### IxSspAccDataSize IxSspInitVars::DataSizeSelected

Select between 4 and 16.

Definition at line **290** of file **IxSspAcc.h**.

#### IxSspAccFrameFormat IxSspInitVars::FrameFormatSelected

Select between SPI, SSP and Microwire.

Definition at line **288** of file **IxSspAcc.h**.

#### BOOL IxSspInitVars::LoopbackEnable

Select operation mode to be normal or loopback mode.

Definition at line **315** of file **IxSspAcc.h**.

Detailed Description 808

#### IxSspAccMicrowireCtlWord IxSspInitVars::MicrowireCtlWordSelected

Select Microwire control format to be 8 or 16-bit.

(Only used in Microwire format).

Definition at line **330** of file **IxSspAcc.h**.

#### BOOL IxSspInitVars::RxFIFOIntrEnable

Enable/disable Rx FIFO threshold interrupt.

Disabling this interrupt will require the use of the polling function RxFIFOExceedThresholdCheck.

Definition at line 299 of file IxSspAcc.h.

#### **RxFIFOOverrunHandler** IxSspInitVars::RxFIFOOverrunHdlr

Pointer to function to handle a Rx FIFO overrun interrupt.

Definition at line **313** of file **IxSspAcc.h**.

#### IxSspAccFifoThreshold IxSspInitVars::RxFIFOThresholdSelected

Select Rx FIFO threshold between 1 to 16.

Definition at line **297** of file **IxSspAcc.h**.

#### **RxFIFOThresholdHandler** IxSspInitVars::RxFIFOThsldHdlr

Pointer to function to handle a Rx FIFO interrupt.

Definition at line **309** of file **IxSspAcc.h**.

#### UINT8 IxSspInitVars::SerialClkRateSelected

Select between 0 (1.8432Mbps) and 255 (7.2Kbps).

The formula used is Bit rate =  $3.6864 \times 10^6 / (2 \times (SerialClkRateSelect + 1))$ 

Definition at line **333** of file **IxSspAcc.h**.

Detailed Description 809

#### IxSspAccSpiSclkPhase IxSspInitVars::SpiSclkPhaseSelected

Select SPI SCLK phase to start with one inactive cycle and end with 1/2 inactive cycle or start with 1/2 inactive cycle and end with one inactive cycle.

(Only used in SPI format).

Definition at line **318** of file **IxSspAcc.h**.

#### IxSspAccSpiSclkPolarity IxSspInitVars::SpiSclkPolaritySelected

Select SPI SCLK idle state to be low or high.

(Only used in SPI format).

Definition at line **326** of file **IxSspAcc.h**.

#### BOOL IxSspInitVars::TxFIFOIntrEnable

Enable/disable Tx FIFO threshold interrupt.

Disabling this interrupt will require the use of the polling function TxFIFOExceedThresholdCheck.

Definition at line **304** of file **IxSspAcc.h**.

#### IxSspAccFifoThreshold IxSspInitVars::TxFIFOThresholdSelected

Select Tx FIFO threshold between 1 to 16.

Definition at line **294** of file **IxSspAcc.h**.

#### $\textbf{TxFIFOThresholdHandler} \ IxSspInitVars::TxFIFOThsldHdlr$

Pointer to function to handle a Tx FIFO interrupt.

Definition at line **311** of file **IxSspAcc.h**.

The documentation for this struct was generated from the following file:

#### • IxSspAcc.h

Detailed Description 810

# IxTimeSyncAccCodeletTSChannelConfig Struct Reference

[Intel (R) IXP400 Software Time Sync Access Codelet, Intel (R) IXP400 Software Time Sync Access Codelet]

This struct is used to store all three Time Sync channels' operating mode: master or slave.

## **Data Fields**

IxTimeSyncAcc1588PTPPortMode tsChannelMode

[IX\_TIMESYNCACC\_CODELET\_MAX\_TS\_CHANNELS]

# **Detailed Description**

This struct is used to store all three Time Sync channels' operating mode: master or slave.

Definition at line 381 of file IxTimeSyncAccCodelet.h.

## **Field Documentation**

#### IxTimeSyncAcc1588PTPPortMode

 $Ix Time Sync Acc Code let TS Channel Config:: ts Channel Mode [IX\_TIME SYNC ACC\_CODE LET\_MAX\_TS\_CHANNEL CONFIGURATION AND ACCORDED LET LANGE AND ACCORDED LANGE A$ 

channel operating mode

Definition at line 383 of file IxTimeSyncAccCodelet.h.

The documentation for this struct was generated from the following file:

• IxTimeSyncAccCodelet.h

# IxTimeSyncAccCodeletUninitFuncMap Struct Reference

# [Intel (R) IXP400 Software Time Sync Access Codelet, Intel (R) IXP400 Software Time Sync Access Codelet]

This struct is used to store each supporting module's unload function's pointer, function parameter, and the state whether the module is initialized.

## **Data Fields**

IxOsalVoidFnPtr funcPtr
IxNpeDlNpeId funcParameter
BOOL initialized

## **Detailed Description**

This struct is used to store each supporting module's unload function's pointer, function parameter, and the state whether the module is initialized.

Definition at line **367** of file **IxTimeSyncAccCodelet.h**.

## **Field Documentation**

IxNpeDINpeId IxTimeSyncAccCodeletUninitFuncMap::funcParameter

function's input parameter

Definition at line **370** of file **IxTimeSyncAccCodelet.h**.

IxOsalVoidFnPtr IxTimeSyncAccCodeletUninitFuncMap::funcPtr

function pointer

Definition at line **369** of file **IxTimeSyncAccCodelet.h**.

 $BOOL\ Ix Time Sync Acc Code let Uninit Func Map:: initialized$ 

initialization state: TRUE - initialized, FALSE - not initialized

Definition at line **371** of file **IxTimeSyncAccCodelet.h**.

IxTimeSyncAccCodeletUninitFuncMap Struct Reference [Intel (R) IXP400 Software Time Sync A8d2ess Cod

| documentation for this struct was gene | rated from the | following fil | e: |  |
|----------------------------------------|----------------|---------------|----|--|
| • IxTimeSyncAccCodelet.h               |                |               |    |  |
|                                        |                |               |    |  |
|                                        |                |               |    |  |
|                                        |                |               |    |  |
|                                        |                |               |    |  |
|                                        |                |               |    |  |
|                                        |                |               |    |  |
|                                        |                |               |    |  |
|                                        |                |               |    |  |
|                                        |                |               |    |  |
|                                        |                |               |    |  |
|                                        |                |               |    |  |
|                                        |                |               |    |  |
|                                        |                |               |    |  |
|                                        |                |               |    |  |
|                                        |                |               |    |  |
|                                        |                |               |    |  |
|                                        |                |               |    |  |
|                                        |                |               |    |  |
|                                        |                |               |    |  |
|                                        |                |               |    |  |
|                                        |                |               |    |  |
|                                        |                |               |    |  |
|                                        |                |               |    |  |
|                                        |                |               |    |  |
|                                        |                |               |    |  |
|                                        |                |               |    |  |
|                                        |                |               |    |  |

# IxTimeSyncAccPtpMsgData Struct Reference

[Intel (R) IXP400 Software Time Sync Access Component API, Intel (R) IXP400 Software Time Sync Access Component API, Intel (R) IXP400 Software Time Sync Access Component API]

Struct for data from the PTP message returned when TimeStamp available.

## **Data Fields**

IxTimeSyncAcc1588PTPMsgType ptpMsgType

PTP Messages type.

IxTimeSyncAccTimeValue ptpTimeStamp

64 bit TimeStamp value from PTP Message

IxTimeSyncAccUuid ptpUuid

48 bit UUID value from the PTP Message

**UINT16** ptpSequenceNumber

16 bit Sequence Number from PTP Message

## **Detailed Description**

Struct for data from the PTP message returned when TimeStamp available.

Definition at line **151** of file **IxTimeSyncAcc.h**.

## **Field Documentation**

**IxTimeSyncAcc1588PTPMsgType** IxTimeSyncAccPtpMsgData::ptpMsgType

PTP Messages type.

Definition at line **153** of file **IxTimeSyncAcc.h**.

UINT16 IxTimeSyncAccPtpMsgData::ptpSequenceNumber

16 bit Sequence Number from PTP Message

Definition at line **156** of file **IxTimeSyncAcc.h**.

IxTimeSyncAccPtpMsgData Struct Reference [Intel (R) IXP400 Software Time Sync Access Cor®penent Al

## IxTimeSyncAccTimeValue IxTimeSyncAccPtpMsgData::ptpTimeStamp

64 bit TimeStamp value from PTP Message

Definition at line **154** of file **IxTimeSyncAcc.h**.

### IxTimeSyncAccUuid IxTimeSyncAccPtpMsgData::ptpUuid

48 bit UUID value from the PTP Message

Definition at line 155 of file IxTimeSyncAcc.h.

The documentation for this struct was generated from the following file:

# IxTimeSyncAccStats Struct Reference

[Intel (R) IXP400 Software Time Sync Access Component API, Intel (R) IXP400 Software Time Sync Access Component API, Intel (R) IXP400 Software Time Sync Access Component API]

Statistics for the PTP messages.

## **Data Fields**

UINT32 rxMsgs

Count of timestamps for received PTP Messages.

UINT32 txMsgs

Count of timestamps for transmitted PTP Messages.

# **Detailed Description**

Statistics for the PTP messages.

Definition at line 166 of file IxTimeSyncAcc.h.

## **Field Documentation**

UINT32 IxTimeSyncAccStats::rxMsgs

Count of timestamps for received PTP Messages.

Definition at line **168** of file **IxTimeSyncAcc.h**.

UINT32 IxTimeSyncAccStats::txMsgs

Count of timestamps for transmitted PTP Messages.

Definition at line **169** of file **IxTimeSyncAcc.h**.

The documentation for this struct was generated from the following file:

# IxTimeSyncAccTimeValue Struct Reference

[Intel (R) IXP400 Software Time Sync Access Component API, Intel (R) IXP400 Software Time Sync Access Component API, Intel (R) IXP400 Software Time Sync Access Component API]

Struct to hold 64 bit SystemTime and TimeStamp values.

## **Data Fields**

UINT32 timeValueLowWord

Lower 32 bits of the time value.

UINT32 timeValueHighWord

Upper 32 bits of the time value.

# **Detailed Description**

Struct to hold 64 bit SystemTime and TimeStamp values.

Definition at line 125 of file IxTimeSyncAcc.h.

## **Field Documentation**

UINT32 IxTimeSyncAccTimeValue::timeValueHighWord

Upper 32 bits of the time value.

Definition at line 128 of file IxTimeSyncAcc.h.

UINT32 IxTimeSyncAccTimeValue::timeValueLowWord

Lower 32 bits of the time value.

Definition at line **127** of file **IxTimeSyncAcc.h**.

The documentation for this struct was generated from the following file:

# IxTimeSyncAccUuid Struct Reference

[Intel (R) IXP400 Software Time Sync Access Component API, Intel (R) IXP400 Software Time Sync Access Component API, Intel (R) IXP400 Software Time Sync Access Component API]

Struct to hold 48 bit UUID values captured in Sync or Delay\_Req messages.

## **Data Fields**

UINT32 uuidValueLowWord

The lower 32 bits of the UUID.

UINT16 uuidValueHighHalfword

The upper 16 bits of the UUID.

# **Detailed Description**

Struct to hold 48 bit UUID values captured in Sync or Delay\_Req messages.

Definition at line 138 of file IxTimeSyncAcc.h.

## **Field Documentation**

UINT16 IxTimeSyncAccUuid::uuidValueHighHalfword

The upper 16 bits of the UUID.

Definition at line **141** of file **IxTimeSyncAcc.h**.

UINT32 IxTimeSyncAccUuid::uuidValueLowWord

The lower 32 bits of the UUID.

Definition at line **140** of file **IxTimeSyncAcc.h**.

The documentation for this struct was generated from the following file:

## ixUARTDev Struct Reference

# [Intel (R) IXP400 Software UART Access (IxUARTAcc) API, Intel (R) IXP400 Software UART Access (IxUARTAcc) API]

Device descriptor for the UART.

## **Data Fields**

UINT8 \* addr

device base address

#### ixUARTMode mode

interrupt, polled or loopback

int baudRate

baud rate

int freq

UART clock frequency.

int options

hardware options

int fifoSize

FIFO xmit size.

ixUARTStats stats

device statistics

# **Detailed Description**

Device descriptor for the UART.

Definition at line 333 of file IxUART.h.

## **Field Documentation**

UINT8\* ixUARTDev::addr

device base address

Definition at line 335 of file IxUART.h.

| int ixUARTDev::baudRate                                                  |  |
|--------------------------------------------------------------------------|--|
| baud rate                                                                |  |
| Definition at line <b>337</b> of file <b>IxUART.h</b> .                  |  |
| int ixUARTDev::fifoSize                                                  |  |
| FIFO xmit size.                                                          |  |
| Definition at line <b>340</b> of file <b>IxUART.h</b> .                  |  |
| int ixUARTDev::freq                                                      |  |
| UART clock frequency.                                                    |  |
| Definition at line 338 of file IxUART.h.                                 |  |
| ixUARTMode ixUARTDev::mode                                               |  |
| interrupt, polled or loopback                                            |  |
| Definition at line 336 of file IxUART.h.                                 |  |
| int ixUARTDev::options                                                   |  |
| hardware options                                                         |  |
| Definition at line <b>339</b> of file <b>IxUART.h</b> .                  |  |
| ixUARTStats ixUARTDev::stats                                             |  |
| device statistics                                                        |  |
| Definition at line <b>342</b> of file <b>IxUART.h</b> .                  |  |
| The documentation for this struct was generated from the following file: |  |

### • IxUART.h

## ixUARTStats Struct Reference

[Intel (R) IXP400 Software UART Access (IxUARTAcc) API, Intel (R) IXP400 Software UART Access (IxUARTAcc) API]

Statistics for the UART.

## **Data Fields**

UINT32 rxCount

UINT32 txCount

UINT32 overrunErr

UINT32 parityErr

UINT32 framingErr

UINT32 breakErr

# **Detailed Description**

Statistics for the UART.

Definition at line **319** of file **IxUART.h**.

The documentation for this struct was generated from the following file:

• IxUART.h

## PacketisedStats Struct Reference

ingroup IxHssAccCodeletCom

## **Data Fields**

- UINT32 txPackets
- UINT32 txBytes
- UINT32 txNoBuffers
- UINT32 rxPackets
- UINT32 rxBytes
- UINT32 rxNoBuffers
- UINT32 rxIdles
- UINT32 rxVerifyFails
- UINT32 connectFails
- UINT32 portEnableFails
- UINT32 txFails
- UINT32 replenishFails
- UINT32 portDisableFails
- UINT32 disconnectFails
- UINT32 txBufsInUse
- UINT32 rxBufsInUse
- UINT32 stopShutdownErrors
- **UINT32** hdlcAlignErrors
- UINT32 hdlcFcsErrors
- UINT32 rxQueueEmptyErrors
- UINT32 hdlcMaxSizeErrors
- UINT32 hdlcAbortErrors
- UINT32 disconnectErrors
- UINT32 unrecognisedErrors

# **Detailed Description**

ingroup IxHssAccCodeletCom

brief Type definition structure for Packetised statistics

Definition at line 112 of file IxHssAccCodeletCom.h.

The documentation for this struct was generated from the following file:

• IxHssAccCodeletCom.h

## **USBDevice Struct Reference**

## [Intel(R) IXP400 Software USB Driver Public API]

USBDevice.

## **Data Fields**

**UINT32 baseIOAddress** 

base I/O device address

UINT32 interruptLevel

device IRQ

UINT32 lastError

detailed error of last function call

**UINT32 deviceIndex** 

USB device index.

UINT32 flags

initialization flags

UINT8 deviceContext [USB CONTEXT SIZE]

used by the driver to identify the device

# **Detailed Description**

USBDevice.

Definition at line **38** of file **usbtypes.h**.

## **Field Documentation**

UINT32 USBDevice::baseIOAddress

base I/O device address

Definition at line 40 of file usbtypes.h.

UINT8 USBDevice::deviceContext[USB\_CONTEXT\_SIZE]

used by the driver to identify the device

Definition at line 45 of file usbtypes.h.

UINT32 USBDevice::deviceIndex

USB device index.

Definition at line 43 of file usbtypes.h.

UINT32 USBDevice::flags

initialization flags

Definition at line 44 of file usbtypes.h.

UINT32 USBDevice::interruptLevel

device IRQ

Definition at line 41 of file usbtypes.h.

UINT32 USBDevice::lastError

detailed error of last function call

Definition at line 42 of file usbtypes.h.

The documentation for this struct was generated from the following file:

• usbtypes.h

## **USBDeviceCounters Struct Reference**

file usbprivatetypes.h

## Data Fields

**UINT32 frames** 

UINT32 irqCount

UINT32 Rx

UINT32 Tx

UINT32 DRx

UINT32 DTx

UINT32 bytesRx

UINT32 bytesTx

UINT32 setup

# **Detailed Description**

file usbprivatetypes.h

author Intel Corporation date 30-OCT-2001

This file contains the private USB Driver data types

Definition at line 22 of file usbprivatetypes.h.

The documentation for this struct was generated from the following file:

• usbprivatetypes.h

# **USBSetupPacket Struct Reference**

## [Intel(R) IXP400 Software USB Driver Public API]

Standard USB Setup packet components, see the USB Specification 1.1.

## **Data Fields**

UCHAR bmRequestType
UCHAR bRequest
UINT16 wValue
UINT16 wIndex
UINT16 wLength

# **Detailed Description**

Standard USB Setup packet components, see the USB Specification 1.1.

Definition at line **24** of file **usbstd.h**.

The documentation for this struct was generated from the following file:

• usbstd.h