

## **Netronome Network Flow Processor 6xxx**

NFP SDK version 6.1 Preview

# Microcode Standard Library Reference Manual

- Proprietary and Confidential - b3285.dr7086

## Netronome Network Flow Processor 6xxx: Microcode Standard Library Reference Manual

Copyright © 2008-2014 Netronome

#### COPYRIGHT

No part of this publication or documentation accompanying this Product may be reproduced in any form or by any means or used to make any derivative work by any means including but not limited to by translation, transformation or adaptation without permission from Netronome Systems, Inc., as stipulated by the United States Copyright Act of 1976. Contents are subject to change without prior notice.

#### WARRANTY

Netronome warrants that any media on which this documentation is provided will be free from defects in materials and workmanship under normal use for a period of ninety (90) days from the date of shipment. If a defect in any such media should occur during this 90-day period, the media may be returned to Netronome for a replacement.

NETRONOME DOES NOT WARRANT THAT THE DOCUMENTATION SHALL BE ERROR-FREE. THIS LIMITED WARRANTY SHALL NOT APPLY IF THE DOCUMENTATION OR MEDIA HAS BEEN (I) ALTERED OR MODIFIED; (II) SUBJECTED TO NEGLIGENCE, COMPUTER OR ELECTRICAL MALFUNCTION; OR (III) USED, ADJUSTED, OR INSTALLED OTHER THAN IN ACCORDANCE WITH INSTRUCTIONS FURNISHED BY NETRONOME OR IN AN ENVIRONMENT OTHER THAN THAT INTENDED OR RECOMMENDED BY NETRONOME.

EXCEPT FOR WARRANTIES SPECIFICALLY STATED IN THIS SECTION, NETRONOME HEREBY DISCLAIMS ALL EXPRESS OR IMPLIED WARRANTIES OF ANY KIND, INCLUDING, WITHOUT LIMITATION, ANY IMPLIED WARRANTIES OF MERCHANTABILITY, NON-INFRINGEMENT AND FITNESS FOR A PARTICULAR PURPOSE.

Some jurisdictions do not allow the exclusion of implied warranties, so the above exclusion may not apply to some users of this documentation. This limited warranty gives users of this documentation specific legal rights, and users of this documentation may also have other rights which vary from jurisdiction to jurisdiction.

#### LIABILITY

Regardless of the form of any claim or action, Netronome's total liability to any user of this documentation for all occurrences combined, for claims, costs, damages or liability based on any cause whatsoever and arising from or in connection with this documentation shall not exceed the purchase price (without interest) paid by such user.

IN NO EVENT SHALL NETRONOME OR ANYONE ELSE WHO HAS BEEN INVOLVED IN THE CREATION, PRODUCTION, OR DELIVERY OF THE DOCUMENTATION BE LIABLE FOR ANY LOSS OF DATA, LOSS OF PROFITS OR LOSS OF USE OF THE DOCUMENTATION OR FOR ANY SPECIAL, INCIDENTAL, CONSEQUENTIAL, EXEMPLARY, PUNITIVE, MULTIPLE OR OTHER DAMAGES, ARISING FROM OR IN CONNECTION WITH THE DOCUMENTATION EVEN IF NETRONOME HAS BEEN MADE AWARE OF THE POSSIBILITY OF SUCH DAMAGES. IN NO EVENT SHALL NETRONOME OR ANYONE ELSE WHO HAS BEEN INVOLVED IN THE CREATION, PRODUCTION, OR DELIVERY OF THE DOCUMENTATION BE LIABLE TO ANYONE FOR ANY CLAIMS, COSTS, DAMAGES OR LIABILITIES CAUSED BY IMPROPER USE OF THE DOCUMENTATION OR USE WHERE ANY PARTY HAS SUBSTITUTED PROCEDURES NOT SPECIFIED BY NETRONOME.

© 2008-2014 Netronome 2 of 256

## **Revision History**

| Date           | Revision | Description                    |
|----------------|----------|--------------------------------|
| April 2016     | 004      | Updated for NFP SDK 6.0 Beta 1 |
| September 2014 | 003      | Updated for NFP SDK 5.1        |
| January 2014   | 002      | Updated for NFP SDK 5.0 Beta   |
| August 2013    | 001      | Initial release                |

© 2008-2014 Netronome 3 of 256

## **Table of Contents**

| 1. Introduction                                                         | 13  |
|-------------------------------------------------------------------------|-----|
| 1.1. About This Guide                                                   | 13  |
| 1.2. Related Documentation                                              | 13  |
|                                                                         |     |
| 2. Microcode Library                                                    |     |
| 2.1. Aggregate Operations                                               | 14  |
| 2.1.1. Aggregate Operation Macros                                       |     |
| 2.1.2.                                                                  |     |
| 2.2. Big-Little-endian                                                  |     |
| 2.2.1. Big-Little-endian Related Macros                                 |     |
| 2.2.2.                                                                  |     |
| 2.2.3.                                                                  |     |
| 2.3. Bitfield Operations                                                |     |
| 2.3.1. Bitfield Operation Macros                                        |     |
| 2.3.2.                                                                  |     |
| 2.3.3.                                                                  |     |
| 2.4. Byte Field Manipulation                                            |     |
| 2.4.1. Big / Little-endian Byte Field Extract / Compare / Branch Macros |     |
| 2.4.2                                                                   |     |
| 2.5. Cluster Local Scratch                                              |     |
| 2.5.1. Cluster Local Scratch Operation Macros                           |     |
| 2.5.2                                                                   |     |
| 2.5.3.                                                                  |     |
|                                                                         |     |
| 2.6. Common and Global Constants                                        |     |
| 2.6.1                                                                   |     |
| 2.7. CRYPTO IPSec Operation                                             |     |
| 2.7.1. CRYPTO IPSec Operation Macros                                    |     |
| 2.7.2.                                                                  |     |
| 2.7.3.                                                                  |     |
| 2.8. CRYPTO Operation                                                   |     |
| 2.8.1. CRYPTO Operation Macros                                          |     |
| 2.8.2.                                                                  |     |
| 2.8.3.                                                                  |     |
| 2.9. CRYPTO Threads Operation                                           |     |
| 2.9.1. CRYPTO Threads Operation Macros                                  |     |
| 2.9.2.                                                                  |     |
| 2.9.3                                                                   | 111 |
| 2.10. DRAM Access                                                       | 113 |
| 2.10.1. DRAM Access Macros                                              | 113 |
| 2.10.2                                                                  |     |
| 2.11. Event filters and autopush API                                    | 124 |
| 2.11.1. CLS Filters and Autopush Macros                                 |     |
| 2.11.2                                                                  |     |
| 2.12. Fletcher Hash Operations                                          |     |
| 2.12.1. Fletcher Hash Operation Macros                                  |     |
| 2.12.2.                                                                 |     |
| 2.13. HASH operation                                                    |     |
| 2.13.1. HASH operation macros                                           |     |
| 2.13.2.                                                                 |     |

|       | 2.13.3.                                          |   |
|-------|--------------------------------------------------|---|
| 2.14. | Limit Operations                                 |   |
|       | 2.14.1. Limit Operation Macros                   |   |
|       | 2.14.2.                                          |   |
|       | Math Operations                                  |   |
|       | 2.15.1. Math Operation Macros General            |   |
|       | 2.15.2                                           |   |
|       | Memory Allocation                                |   |
|       | 2.16.1. Memory Allocation Macros general info    |   |
|       | 2.16.2                                           |   |
|       | Memory Queue Operations                          |   |
|       | 2.17.1. Local Memory Queue Operation Macros      |   |
|       | 2.17.2.                                          |   |
|       | 2.17.3.                                          |   |
|       |                                                  |   |
|       | Microengine CAM Operation                        |   |
|       | 2.18.1. Microengine CAM Operation Macros         |   |
|       | 2.18.2                                           |   |
|       | Microengine CAM Sharing Operation                |   |
|       | 2.19.1. Microengine CAM Sharing Operation Macros |   |
|       | 2.19.2.                                          |   |
|       | 2.19.3.                                          |   |
|       | Microengine CRC                                  |   |
|       | 2.20.1. Microengine CRC Macros                   |   |
|       | 2.20.2.                                          |   |
|       | Microengine Standard Macros                      |   |
|       | 2.21.1. Microengine Standard Macros              |   |
|       | 2.21.2.                                          |   |
| 2.22. | Override Macros                                  |   |
|       | 2.22.1. Override flags                           |   |
|       | 2.22.2.                                          |   |
| 2.23. | Ring Utility                                     |   |
|       | 2.23.1. Ring Utility Macros                      |   |
|       | 2.23.2.                                          |   |
| 2.24. | SRAM Operation                                   |   |
|       | 2.24.1. SRAM Operation Macros                    |   |
|       | 2.24.2.                                          |   |
|       | Thread Synchronization                           |   |
|       | 2.25.1. Thread Synchronization Macros            |   |
|       | 2.25.2                                           |   |
|       | XBUF Operation                                   |   |
| 0.    | 2.26.1. XBUF Operation Macros                    | • |
|       | 2.26.2.                                          |   |

## **List of Tables**

| 1.1. Contents of this Guide           |      |
|---------------------------------------|------|
| 2.1. aggregate_zero parameters        |      |
| 2.2. aggregate_zero parameters        |      |
| 2.3. aggregate_set parameters         |      |
| 2.4. aggregate_set parameters         |      |
| 2.5. aggregate_copy parameters        |      |
| 2.6. aggregate_copy parameters        |      |
| 2.7. aggregate_directive parameters   |      |
| 2.8. aggregate_directive parameters   | . 18 |
| 2.9. Big-Little-endian and Defines    | . 18 |
| 2.10. swap parameters                 | . 19 |
| 2.11. swap01 parameters               | . 20 |
| 2.12. swap12 parameters               | . 20 |
| 2.13. swap23 parameters               | . 21 |
| 2.14. extract0 parameters             | . 21 |
| 2.15. extract1 parameters             | . 22 |
| 2.16. extract2 parameters             | . 23 |
| 2.17. extract3 parameters             | . 23 |
| 2.18. extract01 parameters            | . 24 |
| 2.19. extract12 parameters            | . 25 |
| 2.20. extract23 parameters            |      |
| 2.21. extract02 parameters            |      |
| 2.22. extract13 parameters            | . 27 |
| 2.23. extract03 parameters            | . 27 |
| 2.24. merge_extract0 parameters       | . 28 |
| 2.25. merge_extract1 parameters       |      |
| 2.26. merge_extract2 parameters       |      |
| 2.27. merge_extract3 parameters       |      |
| 2.28. merge_extract01 parameters      |      |
| 2.29. merge_extract12 parameters      |      |
| 2.30. merge_extract23 parameters      |      |
| 2.31. merge_extract02 parameters      |      |
| 2.32. merge_extract13 parameters      |      |
| 2.33. comp parameters                 |      |
| 2.34. comp_ea_eb parameters           |      |
| 2.35. comp_ea parameters              |      |
| 2.36. comp_ea01 parameters            |      |
| 2.37. comp_ea12 parameters            |      |
| 2.38. comp ea23 parameters            |      |
| 2.39. Bitfield Operations and Defines | . 43 |
| 2.40. alu_shf_leftsz1 parameters      |      |
| 2.41. alu_shf_rightsz1 parameters     |      |
| 2.42. bits_clrsz1 parameters          |      |
| 2.43. bits_setsz1 parameters          |      |
| 2.44. bitfield_extractsz1 parameters  |      |
| 2.45. bitfield clear sz1 parameters   |      |
| 2.46. bitfield_insertsz2 parameters   |      |
| 2.47. bitfield_orsz1 parameters       |      |
| 2.48. bitfield_copysz2 parameters     |      |
| 2.49. bytefield_decr parameters       |      |
| 2.50. bytefield_incr parameters       |      |

| 2.51. bytefield_extract parameters              |      |
|-------------------------------------------------|------|
| 2.52. bytefield_dbl_extract parameters          | . 52 |
| 2.53. bytefield_insert parameters               | . 53 |
| 2.54. bytefield_select parameters               | . 54 |
| 2.55. bytefield_br_eq parameters                |      |
| 2.56. bytefield_br_gtr parameters               | . 55 |
| 2.57. bytefield_br_gtreq parameters             | . 55 |
| 2.58. bytefield_br_less parameters              | . 56 |
| 2.59. bytefield_br_lesseq parameters            | . 56 |
| 2.60. bytefield_comp parameters                 |      |
| 2.61. bytefield_shf_left_insert parameters      | . 57 |
| 2.62. bytefield_shf_right_insert parameters     | . 58 |
| 2.63. bytefield_clr_insert parameters           |      |
| 2.64. bytefield_clr_shf_left_insert parameters  | . 60 |
| 2.65. bytefield_clr_shf_right_insert parameters | . 60 |
| 2.66. Cluster Local Scratch and Defines         | . 61 |
| 2.67. cls_read parameters                       |      |
| 2.68. cls_read_le parameters                    | . 62 |
| 2.69. cls_write parameters                      |      |
| 2.70. cls_write_le parameters                   |      |
| 2.71. cls_write_byte parameters                 |      |
| 2.72. cls_write_byte_le parameters              | . 66 |
| 2.73. cls_bits_clr parameters                   | . 66 |
| 2.74. cls_bits_set parameters                   |      |
| 2.75. cls_bits_test_and_clr parameters          | . 67 |
| 2.76. cls_bits_test_and_set parameters          |      |
| 2.77. cls_incr parameters                       | . 69 |
| 2.78. cls_decr parameters                       | . 69 |
| 2.79. cls_add parameters                        | . 69 |
| 2.80. cls_sub parameters                        | . 70 |
| 2.81. cls_swap parameters                       | . 71 |
| 2.82. cls_test_and_add parameters               | . 72 |
| 2.83. cls_test_and_decr parameters              | . 73 |
| 2.84. cls_test_and_incr parameters              | . 73 |
| 2.85. cls_add64_immed_init parameters           | . 74 |
| 2.86. cls_add64_immed parameters                | . 75 |
| 2.87. cls_memset parameters                     | . 75 |
| 2.88. Common and Global Constants and Defines   | . 75 |
| 2.89. CRYPTO IPSec Operation and Defines        |      |
| 2.90. crypto_load_ipsec_enc parameters          | . 80 |
| 2.91. crypto_gen_ipsec_enc parameters           | . 81 |
| 2.92. crypto_load_ipsec_enc_esn parameters      | . 81 |
| 2.93. crypto_gen_ipsec_enc_esn parameters       | . 82 |
| 2.94. crypto_load_ipsec_enc_strt parameters     | . 83 |
| 2.95. crypto_gen_ipsec_enc_strt parameters      |      |
| 2.96. crypto_load_ipsec_enc_cont parameters     | . 84 |
| 2.97. crypto_gen_ipsec_enc_cont parameters      | . 84 |
| 2.98. crypto_load_ipsec_enc_end parameters      | . 85 |
| 2.99. crypto_gen_ipsec_enc_end parameters       | . 86 |
| 2.100. crypto_load_ipsec_enc_end_esn parameters | . 86 |
| 2.101. crypto_gen_ipsec_enc_end_esn parameters  | . 87 |
| 2.102. crypto_load_ipsec_enc_aesgcm parameters  |      |
| 2.103. crypto_gen_ipsec_enc_aesgcm parameters   |      |

| 2.104.  | crypto_load_lpsec_enc_aesgcm_strt parameters        | . 89 |
|---------|-----------------------------------------------------|------|
| 2.105.  | crypto_gen_ipsec_enc_aesgcm_strt parameters         | . 90 |
| 2.106.  | crypto_load_ipsec_enc_aesgcm_strt_save parameters   | . 90 |
|         | crypto_gen_ipsec_enc_aesgcm_strt_save parameters    |      |
| 2.108.  | crypto_load_ipsec_enc_aesgcm_end parameters         | . 92 |
| 2.109.  | crypto_gen_ipsec_enc_aesgcm_end parameters          | . 92 |
|         | crypto_load_ipsec_enc_aesgcm_end_restore parameters |      |
|         | crypto_gen_ipsec_enc_aesgcm_end_restore parameters  |      |
|         | crypto_load_ipsec_dec parameters                    |      |
|         | crypto_gen_ipsec_dec parameters                     |      |
|         | crypto_load_ipsec_dec_esn parameters                |      |
|         | crypto_gen_ipsec_dec_esn parameters                 |      |
|         | crypto_load_ipsec_dec_strt parameters               |      |
|         | crypto_gen_ipsec_dec_strt parameters                |      |
|         | crypto_load_ipsec_dec_strt_nw parameters            |      |
|         | crypto_gen_ipsec_dec_strt_nw parameters             |      |
|         | crypto_load_ipsec_dec_cont parameters               |      |
|         | crypto_gen_ipsec_dec_cont parameters                |      |
|         | crypto_load_ipsec_dec_cont_nw parameters            |      |
|         | crypto_gen_ipsec_dec_cont_nw parameters             |      |
|         | crypto_load_ipsec_dec_end parameters                |      |
|         | crypto_gen_ipsec_dec_end parameters                 |      |
|         | crypto_load_ipsec_dec_end_esn parameters            |      |
|         | crypto_gen_ipsec_dec_end_esn parameters             |      |
|         | crypto_load_ipsec_dec_aesgcm parameters             |      |
|         | crypto_gen_ipsec_dec_aesgcm parameters              |      |
|         | crypto_load_ipsec_dec_aesgcm_strt parameters        |      |
|         | crypto_gen_ipsec_dec_aesgcm_strt parameters         |      |
|         | crypto_load_ipsec_dec_aesgcm_end parameters         |      |
|         | crypto_gen_ipsec_dec_aesgcm_end parameters          |      |
|         | CRYPTO Operation and Defines                        |      |
|         | CRYPTO Threads Operation and Defines                |      |
|         | crypto_threads_input parameters                     |      |
|         | crypto_threads_output parameters                    |      |
|         | dram_mask_write parameters                          |      |
|         | ·                                                   | 114  |
|         | dram_rbuf_read parameters                           |      |
|         | ·                                                   | 116  |
|         | dram_read parameters                                |      |
|         | dram_read parameters                                |      |
|         | dram_tbuf_write parameters                          |      |
|         | dram write parameters                               |      |
|         | dram_write parameters                               |      |
|         | ddr_add64_immed_init parameters                     |      |
|         | ddr_add64_immed_init parameters                     |      |
|         | ddr_add64_immed parameters                          |      |
|         | ddr_add64_immed_sat parameters                      |      |
|         | dram_memcmp parametersdram_memcmp parameters        |      |
|         | dram_memcmp parameters                              |      |
|         | · ·                                                 |      |
|         | dram_memset parameters                              |      |
|         | dram_memset parameters                              |      |
|         | dram_memset parameters                              | 124  |
| - 13363 | EVIDO GA EVED DIEL COMO DALAMETERA                  | 1/:1 |

| 2.157. | evntm_cls_autopush_monitor_config parameters  | 125 |
|--------|-----------------------------------------------|-----|
| 2.158. | evntm_cls_autopush_monitor_config parameters  | 126 |
| 2.159. | evntm_cls_autopush_monitor_engage parameters  | 126 |
| 2.160. | evntm_cls_autopush_user_event parameters      | 126 |
| 2.161. | fletcher_hash parameters                      | 127 |
| 2.162. | jenkins_hash parameters                       | 128 |
|        | jenkins_byte_hash parameters                  |     |
|        | hardware_hash parameters                      |     |
|        | HASH operation and Defines                    |     |
|        | hash_init parameters                          |     |
|        | hash_init_cls parameters                      |     |
|        | hash_translate parameters                     |     |
|        | hash_lookup parameters                        |     |
|        | hash_dual_lookup parameters                   |     |
|        | limit_min parameters                          |     |
|        | limit_min parameters                          |     |
|        | limit_min_cc parameters                       |     |
|        | limit_max parameters                          |     |
|        | limit_max parameters                          |     |
|        | limit_max_cc parameters                       |     |
|        | limit_min_unsigned parameters                 |     |
| 2.178. | limit_min_unsigned parameters                 | 139 |
| 2.179. | limit_min_unsigned_cc parameters              | 140 |
| 2.180. | limit_max_unsigned parameters                 | 141 |
| 2.181. | limit_max_unsigned parameters                 | 141 |
| 2.182. | limit_max_unsigned_cc parameters              | 142 |
| 2.183. | limit_align_first_chunk parameters            | 142 |
| 2.184. | math_int_div parameters                       | 143 |
| 2.185. | math_int_div_64 parameters                    | 144 |
| 2.186. | math_log2 parameters                          | 144 |
| 2.187. | math_find_highest_set parameters              | 145 |
| 2.188. | buf_dram_addr_from_index parameters           | 146 |
| 2.189. | buf_dram_addr_from_sram_addr parameters       | 146 |
| 2.190. | buf_index_from_dram_addr parameters           | 147 |
| 2.191. | buf_index_from_sram_addr parameters           | 147 |
| 2.192. | buf_sram_addr_from_index parameters           | 148 |
| 2.193. | buf_sram_addr_from_dram_addr parameters       | 149 |
| 2.194. | buf_freelist_create parameters                | 149 |
| 2.195. | buf_alloc parameters                          | 150 |
| 2.196. | buf_free parameters                           | 150 |
| 2.197. | Memory Queue Operations and Defines           | 151 |
| 2.198. | Im_handle_alloc parameters                    | 152 |
| 2.199. | Im_handle_free parameters                     | 152 |
| 2.200. | Im_handle_verify parameters                   | 153 |
| 2.201. | incr_lm_base parameters                       | 153 |
| 2.202. | cam_read_entry parameters                     | 154 |
| 2.203. | cam_write_entry parameters                    | 154 |
| 2.204. | cam_read_data parameters                      | 155 |
|        | cam_match parameters                          |     |
| 2.206. | Microengine CAM Sharing Operation and Defines | 156 |
| 2.207. | cam_entry_read_state parameters               | 156 |
|        | cam_entry_write_state parameters              |     |
| 2.209. | cam_entry_read_tag parameters                 | 157 |

| 2.210. | cam_clearall parameters               | 158  |
|--------|---------------------------------------|------|
| 2.211. | cam_entry_write parameters            | 158  |
|        | cam_exit_using_entry parameters       |      |
| 2.213. | cam_entry_lookup parameters           | 160  |
|        | cam_entry_lookup_with_lm parameters   |      |
|        | crc_load_crc10_table parameters       |      |
|        | crc_10 parameters                     |      |
|        | crc_32 parameters                     |      |
|        | crc_ccitt parameters                  |      |
|        | crc_read parameters                   |      |
|        | crc_write parameters                  |      |
|        | immed32 parameters                    |      |
|        | immed40 parameters                    |      |
|        | balr parameters                       |      |
|        | move parameters                       |      |
|        | alu_op parameters                     |      |
|        | add parameters                        |      |
|        | add_c parameters                      |      |
|        | sub parameters                        |      |
|        | shf_right parameters                  |      |
|        | shf_left parameters                   |      |
|        | rot_right parameters                  |      |
|        | rot_left parameters                   |      |
|        | alu_shf_right parameters              |      |
|        | add_shf_right parameters              |      |
|        | sub_shf_right parameters              |      |
|        | and_shf_right parameters              |      |
|        | or_shf_right parameters               |      |
|        | alu_shf_left parameters               |      |
|        | add_shf_left parameters               |      |
|        | sub_shf_left parameters               |      |
|        | and_shf_left parameters               |      |
|        | or_shf_left parameters                |      |
|        | alu_rot_right parameters              |      |
|        | alu_rot_left parameters               |      |
|        | bitfield_extract parameters           |      |
|        | bitfield_insert parameters            |      |
|        | bits_clr parameters                   |      |
|        | bits_set parameters                   |      |
|        | multiply parameters                   |      |
|        | divide parameters                     |      |
|        | array_index_from_elem_addr parameters |      |
|        | elem_addr_from_array_index parameters |      |
|        | arith_shf_right parameters            |      |
|        | multiply32 parameters                 |      |
|        | multiply64 parameters                 |      |
|        | rand parameters                       |      |
|        | srand parameters                      |      |
|        | ov_global_flags parameters            |      |
|        | ov_global_nags parameters             |      |
|        | ov_set_bits parameters                |      |
|        | ov_set_bits parameters                |      |
|        | ·                                     | 190  |
|        | uv asi ugiginsista                    | 1.71 |

| 2.263. ov_set para  | meters                       | 92 |
|---------------------|------------------------------|----|
| 2.264. ov_set_bm_   | and parameters1              | 93 |
| 2.265. ov_set_bm_   | and parameters19             | 94 |
| 2.266. ov_set_extr  | act parameters1              | 95 |
| 2.267. ov_set_extr  | act parameters1              | 96 |
| 2.268. ov_set_bm_   | and_extract parameters19     | 97 |
|                     | and_extract parameters19     |    |
|                     | parameters                   |    |
|                     | parameters 2                 |    |
|                     | and_use parameters20         |    |
|                     | and_use parameters20         |    |
|                     | act_use parameters20         |    |
| 2.275. ov_set_extr  | act_use parameters20         | 04 |
| 2.276. ov_set_bm_   | and_extract_use parameters20 | 06 |
|                     | and_extract_use parameters20 |    |
| 2.278. ov_use para  | meters20                     | 08 |
| 2.279. ov_single pa | rameters20                   | 09 |
| 2.280. ov_recall pa | rameters                     | 10 |
|                     | parameters 2                 |    |
|                     | parameters 2                 |    |
|                     | ng_setup parameters 2        |    |
|                     | ng_setup parameters          |    |
|                     | ng_put parameters            |    |
|                     | ng_get parameters 2          |    |
|                     | init parameters              |    |
|                     | g_setup parameters 2         |    |
|                     | g_setup parameters 2         |    |
|                     | g_setup parameters 2         |    |
|                     | setup parameters             |    |
|                     | _setup parameters2           |    |
|                     | parameters 2                 |    |
|                     | g_put parameters 2           |    |
|                     | g_put parameters             |    |
|                     | o_ring parameters2           |    |
|                     | n_ring parameters2           |    |
|                     | put parameters               |    |
|                     | _put parameters2             |    |
| 2.300. ru_ctm_ring  |                              | 27 |
|                     | ing parameters2              | 28 |
| -                   | ing parameters2              |    |
| -                   | parameters                   |    |
| -                   | parameters2                  |    |
|                     | Ir parameters2               |    |
|                     | et parameters                |    |
|                     | est_and_clr parameters2      |    |
|                     | est_and_set parameters       |    |
|                     | arameters                    |    |
|                     | parameters                   |    |
|                     | arameters                    |    |
| -                   | arameters                    |    |
| -                   | parameters                   |    |
| -                   | nd_add parameters            |    |
|                     | nd decr parameters           |    |

## Netronome Network Flow Processor 6xxx NFP SDK version 6.1 Preview - Microcode Standard Library Reference Manual

| 2.316. sram_test_and_incr parameters           | 238 |
|------------------------------------------------|-----|
| 2.317. sram_fast_journal parameters            | 239 |
| 2.318. sram_wr_qdesc parameters                | 239 |
| 2.319. sram_memset parameters                  | 239 |
| 2.320. threads_reorder_once parameters         | 240 |
| 2.321. threads_br_ctx parameters               | 241 |
| 2.322. threads_kill parameters                 | 241 |
| 2.323. threads_order parameters                | 242 |
| 2.324. xbuf_bind_address parameters            |     |
| 2.325. xbuf_deactivate parameters              | 244 |
| 2.326. xbuf_activate parameters                | 245 |
| 2.327. xbuf_alloc parameters                   | 246 |
| 2.328. xbuf_free parameters                    | 247 |
| 2.329. xbuf_link parameters                    |     |
| 2.330. xbuf_find parameters                    | 249 |
| 2.331. xbuf_param_set parameters               | 249 |
| 2.332. xbuf_xfer_set parameters                | 250 |
| 2.333. xbuf_extract parameters                 |     |
| 2.334. xbuf_extract_frm_linked_bufs parameters | 252 |
| 2.335. xbuf_type_extract parameters            | 253 |
| 2.336. xbuf_insert parameters                  | 254 |
| 2.337. xbuf_copy parameters                    | 254 |

## 1. Introduction

## 1.1 About This Guide

This document provides a reference to the Microcode Standard Library functions that supports the Netronome Network Flow Processor NFP-6xxx product line.



#### Note

For simplicity throughout this document, the compiler will be referred to as the *C compiler*, or in some cases simply *the compiler*. Also, the Netronome NFP-6xxx network processor may be referred to as *the network processor*.

Table 1.1. Contents of this Guide

| Chapter   | Description                                                                      |
|-----------|----------------------------------------------------------------------------------|
| Chapter 1 | Description of this guide, related documentation, and table of conventions used. |
| Chapter 2 | Microcode Standard Library functions.                                            |

## 1.2 Related Documentation

Further information related to the Netronome Systems NFP-32XX product line is located in:

- Netronome Network Flow Processor 6xxx: Datasheet
- Netronome Network Flow Processor 6xxx: Development Tools User's Guide
- Netronome Network Flow Processor 6xxx: Network Flow Assembler System User's Guide
- Netronome Network Flow Processor 6xxx: Databook
- Netronome Network Flow Processor 6xxx: Network Flow C Compiler User's Guide
- Netronome Network Flow Processor 6xxx: Microengine Programmer's Reference Manual
- Netronome Network Flow Processor 6xxx: Micro-C Standard Library Reference Manual

© 2008-2014 Netronome 13 of 256

## 2. Microcode Library

## 2.1 Aggregate Operations

## 2.1.1 Aggregate Operation Macros

These macros perform operations on groups of registers

## 2.1.2.1 aggregate\_zero

#### **Prototype:**

aggregate\_zero(dst, COUNT)

#### **Description**:

Zero Aggregate.

#### **Example:**

```
.reg write $stat_wr[16]
aggregate_zero($stat_wr, 16)
```

#### Table 2.1. aggregate\_zero parameters

| Name  | Description                                          |
|-------|------------------------------------------------------|
| dst   | Destination GPRs or write transfer registers to zero |
| COUNT | CONSTANT number of registers to set to zero          |

## 2.1.2.2 aggregate\_zero

#### **Prototype:**

```
aggregate_zero(dst, DST_IDX, COUNT)
```

#### **Description**:

Zero Aggregate using Index.

#### **Example:**

```
.reg write $stat_wr[16]
aggregate_zero($stat_wr, 8, 2)
```

© 2008-2014 Netronome 14 of 256

#### Table 2.2. aggregate\_zero parameters

| Name    | Description                                          |
|---------|------------------------------------------------------|
| dst     | Destination GPRs or write transfer registers to zero |
| DST_IDX | Index of 1st register to zero                        |
| COUNT   | CONSTANT number of registers to set to zero          |

## 2.1.2.3 aggregate\_set

#### **Prototype:**

aggregate\_set(dst, scalar\_src, COUNT)

#### **Description:**

Set value to Aggregate.

#### **Example:**

```
.reg write $stat_wr[16]
aggregate_set($stat_wr, 0x55, 16)
```

#### Table 2.3. aggregate\_set parameters

| Name       | Description                                                  |
|------------|--------------------------------------------------------------|
| dst        | Destination GPRs or write transfer registers to set to value |
| scalar_src | value to set to registers                                    |
| COUNT      | CONSTANT number of registers to set to value                 |

## 2.1.2.4 aggregate\_set

#### **Prototype:**

aggregate\_set(dst, DST\_IDX, scalar\_src, COUNT)

#### **Description**:

Set value to Aggregate using Index.

#### **Example:**

```
.reg write $stat_wr[16]
aggregate_set($stat_wr, 0x55, 16)
```

#### Table 2.4. aggregate\_set parameters

| Name | Description                                                  |
|------|--------------------------------------------------------------|
| dst  | Destination GPRs or write transfer registers to set to value |

© 2008-2014 Netronome 15 of 256

| Name       | Description                                  |
|------------|----------------------------------------------|
| DST_IDX    | Index of 1st register to set value to        |
| scalar_src | value to set to registers                    |
| COUNT      | CONSTANT number of registers to set to value |

## 2.1.2.5 aggregate\_copy

#### **Prototype:**

```
aggregate_copy(dst, src, COUNT)
```

#### **Description**:

Copy from Aggregate source to Aggregate destination.

#### **Example:**

```
.reg $src[8]
.reg $dst[8]
aggregate_copy($dst, $src, 8)
```

#### Table 2.5. aggregate\_copy parameters

| Name  | Description                                           |
|-------|-------------------------------------------------------|
| dst   | Destination GPRs or write transfer registers for copy |
| src   | Source GPRs or read transfer registers for copy       |
| COUNT | CONSTANT number of registers to copy                  |

## 2.1.2.6 aggregate\_copy

#### **Prototype:**

```
aggregate_copy(dst, DST_IDX, src, SRC_IDX, COUNT)
```

#### **Description**:

Copy from Aggregate source to Aggregate destination using indeces.

#### **Example:**

```
.reg $src[8]
.reg $dst[8]
aggregate_copy($dst, 2, $src, 4, 2)
```

#### Table 2.6. aggregate\_copy parameters

| Name | Description                                           |
|------|-------------------------------------------------------|
| dst  | Destination GPRs or write transfer registers for copy |

© 2008-2014 Netronome 16 of 256

| Name    | Description                                     |
|---------|-------------------------------------------------|
| DST_IDX | Index of 1st destination register to copy to    |
| src     | Source GPRs or read transfer registers for copy |
| SRC_IDX | Index of 1st source register to copy from       |
| COUNT   | CONSTANT number of registers to copy            |

## 2.1.2.7 aggregate\_directive

#### **Prototype:**

aggregate\_directive(DIRECTIVE, xfer, COUNT)

#### **Description**:

Generate Assembler Directive for a Register Aggregate.

#### **Example:**

```
.reg $xfr[8]
aggregate_directive(.set, $xfr, 8)
```

#### Table 2.7. aggregate\_directive parameters

| Name      | Description                                                                                                     |
|-----------|-----------------------------------------------------------------------------------------------------------------|
| DIRECTIVE | directive string to generate on transfer registers one of .set, .set_wr, .set_rd, .use, .use_wr, .use_rd, .init |
| xfer      | Transfer registers on which to generate directive                                                               |
| COUNT     | CONSTANT number of registers to generate directive on                                                           |

## 2.1.2.8 aggregate\_directive

#### **Prototype:**

```
aggregate_directive(DIRECTIVE, xfer, START, COUNT)
```

#### **Description**:

Generate Assembler Directive for a Register Aggregate using index.

#### **Example:**

```
.reg $xfr[8]
aggregate_directive(.set, $xfr, 4, 2)
```

© 2008-2014 Netronome 17 of 256

Table 2.8. aggregate\_directive parameters

| Name      | Description                                                                                                     |
|-----------|-----------------------------------------------------------------------------------------------------------------|
| DIRECTIVE | directive string to generate on transfer registers one of .set, .set_wr, .set_rd, .use, .use_wr, .use_rd, .init |
| xfer      | Transfer registers on which to generate directive                                                               |
| START     | START index of 1st transfer register to generate directive on                                                   |
| COUNT     | CONSTANT number of registers to generate directive on                                                           |

## 2.2 Big-Little-endian

## 2.2.1 Big-Little-endian Related Macros

Endian independent internal macros supporting bytefield.uc.Default is BIG\_ENDIAN. LITTLE\_ENDIAN is not yet supported. These macros perform swaps on operators and stores the result according to the following naming convention: swap :== e no\_character :== result\_op :== e | <no\_character> all\_bytes :== <no\_character> left\_to\_right\_bytes :== 01 | 12 | 23 | <all\_bytes> function :== add | comp appearand :== \_ea<left\_to\_right\_bytes> | <no\_character> prev\_carry :== \_c | <no\_character> unary operator = <result\_op><function><left\_to\_right\_bytes> operator = <result\_op><function><appearand><br/><prev\_carry>

Table 2.9. Big-Little-endian and Defines

| Defined   | Definition           |
|-----------|----------------------|
| swap32    | swap01               |
|           | Alias for swap01.    |
| swap21    | swap12               |
|           | Alias for swap12.    |
| swap10    | swap23               |
|           | Alias for swap23.    |
| comp_ea32 | comp_ea01            |
|           | Alias for comp_ea01. |
| comp_ea21 | comp_ea12            |
|           | Alias for comp_ea12. |
| comp_ea10 | comp_ea23            |
|           | Alias for comp_ea23. |

© 2008-2014 Netronome 18 of 256

| Defined     | Definition             |
|-------------|------------------------|
| add_ea32_eb | add_ea01_eb            |
|             | Alias for add_ea01_eb. |
| add_ea10_eb | add_ea23_eb            |
|             | Alias for add_ea23_eb. |
| add_ea10_c  | add_ea23_c             |
|             | Alias for add_ea23_c.  |
| add_ea32_c  | add_ea01_c             |
|             | Alias for add_ea01_c.  |

## 2.2.3.1 swap

#### **Prototype**:

swap(res, aop, in\_load\_cc)

#### **Description**:

Four byte endian swap.

#### **Example:**

aop = 0xAABBCCDD
res = 0xDDCCBBAA

#### Table 2.10. swap parameters

| Name       | Description                                                                                                             |
|------------|-------------------------------------------------------------------------------------------------------------------------|
| res        | Result register                                                                                                         |
| aop        | Input value                                                                                                             |
| in_load_cc | CONSTANT to specify whether user wants the load ALU condition codes based on the result performed Possible values are:  |
|            | • NO_LOAD_CC: Do not load condition code - suggested value if users only want to select byte(s) without any side effect |
|            | • DO_LOAD_CC: Load condition code                                                                                       |

## 2.2.3.2 swap01

#### **Prototype**:

swap01(res, aop, in\_load\_cc)

© 2008-2014 Netronome 19 of 256

## **Description**:

Two byte endian swap of two left-most bytes.

#### **Example:**

```
aop = 0xAABBCCDD
res = 0x0000BBAA
```

#### Table 2.11. swap01 parameters

| Name       | Description                                                                                                             |
|------------|-------------------------------------------------------------------------------------------------------------------------|
| res        | Result register                                                                                                         |
| аор        | Input value                                                                                                             |
| in_load_cc | CONSTANT to specify whether user wants the load ALU condition codes based on the result performed Possible values are:  |
|            | • NO_LOAD_CC: Do not load condition code - suggested value if users only want to select byte(s) without any side effect |
|            | • DO_LOAD_CC: Load condition code                                                                                       |

## 2.2.3.3 swap12

#### **Prototype:**

```
swap12(res, aop, in_load_cc)
```

#### **Description**:

Two byte endian swap of two middle bytes.

#### **Example:**

```
aop = 0xAABBCCDD
res = 0x0000CCBB
```

#### Table 2.12. swap12 parameters

| Name       | Description                                                                                                             |
|------------|-------------------------------------------------------------------------------------------------------------------------|
| res        | Result register                                                                                                         |
| aop        | Input value                                                                                                             |
| in_load_cc | CONSTANT to specify whether user wants the load ALU condition codes based on the result performed Possible values are:  |
|            | • NO_LOAD_CC: Do not load condition code - suggested value if users only want to select byte(s) without any side effect |
|            | DO_LOAD_CC: Load condition code                                                                                         |

© 2008-2014 Netronome 20 of 256

## 2.2.3.4 swap23

#### **Prototype:**

```
swap23(res, aop, in_load_cc)
```

#### **Description**:

Two byte endian swap of two right-most bytes.

#### **Example:**

```
aop = 0xAABBCCDD
res = 0x0000DDCC
```

#### Table 2.13. swap23 parameters

| Name       | Description                                                                                                             |
|------------|-------------------------------------------------------------------------------------------------------------------------|
| res        | Result register                                                                                                         |
| aop        | Input value                                                                                                             |
| in_load_cc | CONSTANT to specify whether user wants the load ALU condition codes based on the result performed Possible values are:  |
|            | • NO_LOAD_CC: Do not load condition code - suggested value if users only want to select byte(s) without any side effect |
|            | • DO_LOAD_CC: Load condition code                                                                                       |

## 2.2.3.5 extract0

#### **Prototype:**

```
extract0(dest, source, shift_amt, in_load_cc)
```

#### **Description**:

Extract byte 0 from source, store in cleared dest at bit shift\_amt.

#### **Example:**

#### **Table 2.14. extract0 parameters**

| Name   | Description          |
|--------|----------------------|
| dest   | Destination register |
| source | Input value          |

© 2008-2014 Netronome 21 of 256

| Name       | Description                                                                                                             |
|------------|-------------------------------------------------------------------------------------------------------------------------|
| shift_amt  | Left shift count of the extracted byte. Must be 0, 8, 16 or 24                                                          |
| in_load_cc | CONSTANT to specify whether user wants the load ALU condition codes based on the result performed Possible values are:  |
|            | • NO_LOAD_CC: Do not load condition code - suggested value if users only want to select byte(s) without any side effect |
|            | • DO_LOAD_CC: Load condition code                                                                                       |

#### 2.2.3.6 extract1

#### **Prototype:**

```
extract1(dest, source, shift_amt, in_load_cc)
```

#### **Description**:

Extract byte 1 from source, store in cleared dest at bit shift\_amt.

#### **Example:**

#### Table 2.15. extract1 parameters

| Name       | Description                                                                                                                                                                        |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| dest       | Destination register                                                                                                                                                               |
| source     | Input value                                                                                                                                                                        |
| shift_amt  | Left shift count of the extracted byte. Must be 0, 8, 16 or 24                                                                                                                     |
| in_load_cc | CONSTANT to specify whether user wants the load ALU condition codes based on the result performed Possible values are:                                                             |
|            | <ul> <li>NO_LOAD_CC: Do not load condition code - suggested value if users only want to select byte(s) without any side effect</li> <li>DO_LOAD_CC: Load condition code</li> </ul> |

#### 2.2.3.7 extract2

#### **Prototype:**

```
extract2(dest, source, shift_amt, in_load_cc)
```

#### **Description**:

© 2008-2014 Netronome 22 of 256

Extract byte 2 from source, store in cleared dest at bit shift\_amt.

#### **Example:**

```
src = 0xAABBCCDD

extract2(out, src, 24, NO_LOAD_CC)  // out == 0xCC000000
extract2(out, src, 8, NO_LOAD_CC)  // out == 0x0000CC00
```

#### Table 2.16. extract2 parameters

| Name       | Description                                                                                                                                                                        |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| dest       | Destination register                                                                                                                                                               |
| source     | Input value                                                                                                                                                                        |
| shift_amt  | Left shift count of the extracted byte. Must be 0, 8, 16 or 24                                                                                                                     |
| in_load_cc | CONSTANT to specify whether user wants the load ALU condition codes based on the result performed Possible values are:                                                             |
|            | <ul> <li>NO_LOAD_CC: Do not load condition code - suggested value if users only want to select byte(s) without any side effect</li> <li>DO_LOAD_CC: Load condition code</li> </ul> |

#### 2.2.3.8 extract3

#### **Prototype:**

```
extract3(dest, source, shift_amt, in_load_cc)
```

#### **Description**:

Extract byte 3 from source, store in cleared dest at bit shift\_amt.

#### **Example:**

#### Table 2.17. extract3 parameters

| Name      | Description                                                    |
|-----------|----------------------------------------------------------------|
| dest      | Destination register                                           |
| source    | Input value                                                    |
| shift_amt | Left shift count of the extracted byte. Must be 0, 8, 16 or 24 |

© 2008-2014 Netronome 23 of 256

| Name | Description                                                                                                             |
|------|-------------------------------------------------------------------------------------------------------------------------|
|      | CONSTANT to specify whether user wants the load ALU condition codes based on the result performed Possible values are:  |
|      | • NO_LOAD_CC: Do not load condition code - suggested value if users only want to select byte(s) without any side effect |
|      | • DO_LOAD_CC: Load condition code                                                                                       |

#### 2.2.3.9 extract01

#### **Prototype:**

```
extract01(dest, source, shift_amt, in_load_cc)
```

#### **Description**:

Extract bytes 0 and 1 from source, store in cleared dest at bit shift\_amt.

#### **Example:**

```
src = 0xAABBCCDD

extract01(out, src, 16, NO_LOAD_CC)  // out == 0xAABB0000
extract01(out, src, 8, NO_LOAD_CC)  // out == 0x00AABB00
extract01(out, src, 0, NO_LOAD_CC)  // out == 0x0000AABB
```

#### Table 2.18. extract01 parameters

| Name       | Description                                                                                                                                                                        |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| dest       | Destination register                                                                                                                                                               |
| source     | Input value                                                                                                                                                                        |
| shift_amt  | Left shift count of the extracted byte. Must be 0, 8 or 16                                                                                                                         |
| in_load_cc | CONSTANT to specify whether user wants the load ALU condition codes based on the result performed Possible values are:                                                             |
|            | <ul> <li>NO_LOAD_CC: Do not load condition code - suggested value if users only want to select byte(s) without any side effect</li> <li>DO_LOAD_CC: Load condition code</li> </ul> |

#### 2.2.3.10 extract12

#### **Prototype:**

```
extract12(dest, source, shift_amt, in_load_cc)
```

#### **Description**:

© 2008-2014 Netronome 24 of 256

Extract bytes 1 and 2 from source, store in cleared dest at bit shift\_amt.

#### **Example:**

```
src = 0xAABBCCDD

extract12(out, src, 16, NO_LOAD_CC)  // out == 0xBBCC0000
extract12(out, src, 8, NO_LOAD_CC)  // out == 0x00BBCC00
extract12(out, src, 0, NO_LOAD_CC)  // out == 0x0000BBCC
```

#### Table 2.19. extract12 parameters

| Name       | Description                                                                                                            |
|------------|------------------------------------------------------------------------------------------------------------------------|
| dest       | Destination register                                                                                                   |
| source     | Input value                                                                                                            |
| shift_amt  | Left shift count of the extracted byte. Must be 0, 8 or 16                                                             |
| in_load_cc | CONSTANT to specify whether user wants the load ALU condition codes based on the result performed Possible values are: |
|            | NO_LOAD_CC: Do not load condition code - suggested value if users only want to select byte(s) without any side effect  |
|            | • DO_LOAD_CC: Load condition code                                                                                      |

#### 2.2.3.11 extract23

#### **Prototype:**

```
extract23(dest, source, shift_amt, in_load_cc)
```

#### **Description**:

Extract bytes 2 and 3 from source, store in cleared dest at bit shift\_amt.

#### **Example:**

```
src = 0xAABBCCDD

extract23(out, src, 16, NO_LOAD_CC)  // out == 0xCCDD0000
extract23(out, src, 8, NO_LOAD_CC)  // out == 0x00CCDD00
extract23(out, src, 0, NO_LOAD_CC)  // out == 0x0000CCDD
```

#### Table 2.20. extract23 parameters

| Name      | Description                                                |
|-----------|------------------------------------------------------------|
| dest      | Destination register                                       |
| source    | Input value                                                |
| shift_amt | Left shift count of the extracted byte. Must be 0, 8 or 16 |

© 2008-2014 Netronome 25 of 256

| Name | Description                                                                                                             |
|------|-------------------------------------------------------------------------------------------------------------------------|
|      | CONSTANT to specify whether user wants the load ALU condition codes based on the result performed Possible values are:  |
|      | • NO_LOAD_CC: Do not load condition code - suggested value if users only want to select byte(s) without any side effect |
|      | • DO_LOAD_CC: Load condition code                                                                                       |

## 2.2.3.12 extract02

#### **Prototype:**

```
extract02(dest, source, shift_amt, in_load_cc)
```

#### **Description**:

Extract bytes 0 to 2 from source, store in cleared dest at bit shift\_amt.

#### **Example:**

#### Table 2.21. extract02 parameters

| Name       | Description                                                                                                            |
|------------|------------------------------------------------------------------------------------------------------------------------|
| dest       | Destination register                                                                                                   |
| source     | Input value                                                                                                            |
| shift_amt  | Left shift count of the extracted byte. Must be 0 or 8                                                                 |
| in_load_cc | CONSTANT to specify whether user wants the load ALU condition codes based on the result performed Possible values are: |
|            | NO_LOAD_CC: Do not load condition code - suggested value if users only want to select byte(s) without any side effect  |
|            | DO_LOAD_CC: Load condition code                                                                                        |

#### 2.2.3.13 extract13

#### **Prototype:**

```
extract13(dest, source, shift_amt, in_load_cc)
```

#### **Description**:

Extract bytes 1 to 3 from source, store in cleared dest at bit shift\_amt.

© 2008-2014 Netronome 26 of 256

#### **Example:**

#### Table 2.22. extract13 parameters

| Name       | Description                                                                                                            |
|------------|------------------------------------------------------------------------------------------------------------------------|
| dest       | Destination register                                                                                                   |
| source     | Input value                                                                                                            |
| shift_amt  | Left shift count of the extracted byte. Must be 0 or 8                                                                 |
| in_load_cc | CONSTANT to specify whether user wants the load ALU condition codes based on the result performed Possible values are: |
|            | NO_LOAD_CC: Do not load condition code - suggested value if users only want to select byte(s) without any side effect  |
|            | DO_LOAD_CC: Load condition code                                                                                        |

#### 2.2.3.14 extract03

#### **Prototype:**

```
extract03(dest, source, dummySHIFT, in_load_cc)
```

#### **Description**:

Extract bytes 0 to 3 from source, store in cleared dest at bit shift\_amt.

This function is mainly provided for generic coding in other modules.

#### Table 2.23. extract03 parameters

| Name       | Description                                     |
|------------|-------------------------------------------------|
| dest       | Destination register                            |
| source     | Input value                                     |
| dummySHIFT | Ignored                                         |
| in_load_cc | Ignored, macro behaves as if DO_LOAD_CC is used |

## 2.2.3.15 merge\_extract0

#### **Prototype:**

```
merge_extract0(dest, source, in_load_cc)
```

#### **Description**:

© 2008-2014 Netronome 27 of 256

Extract byte 0 from source, store in dest at bit 0.

#### **Example:**

```
src = 0xAABBCCDD
out = 0x11223344

merge_extract0(out, src, NO_LOAD_CC) // out == 0x112233AA
```

#### Table 2.24. merge\_extract0 parameters

| Name       | Description                                                                                                            |
|------------|------------------------------------------------------------------------------------------------------------------------|
| dest       | Destination register                                                                                                   |
| source     | Input value                                                                                                            |
| in_load_cc | CONSTANT to specify whether user wants the load ALU condition codes based on the result performed Possible values are: |
|            | NO_LOAD_CC: Do not load condition code - suggested value if users only want to select byte(s) without any side effect  |
|            | DO_LOAD_CC: Load condition code                                                                                        |

## 2.2.3.16 merge\_extract1

#### **Prototype:**

merge\_extract1(dest, source, in\_load\_cc)

#### **Description**:

Extract byte 1 from source, store in dest at bit 0.

#### **Example:**

```
src = 0xAABBCCDD
out = 0x11223344

merge_extractl(out, src, NO_LOAD_CC) // out == 0x112233BB
```

#### Table 2.25. merge\_extract1 parameters

| Name       | Description                                                                                                            |
|------------|------------------------------------------------------------------------------------------------------------------------|
| dest       | Destination register                                                                                                   |
| source     | Input value                                                                                                            |
| in_load_cc | CONSTANT to specify whether user wants the load ALU condition codes based on the result performed Possible values are: |
|            | NO_LOAD_CC: Do not load condition code - suggested value if users only want to select byte(s) without any side effect  |
|            | DO_LOAD_CC: Load condition code                                                                                        |

© 2008-2014 Netronome 28 of 256

## 2.2.3.17 merge\_extract2

#### **Prototype:**

merge\_extract2(dest, source, in\_load\_cc)

#### **Description**:

Extract byte 2 from source, store in dest at bit 0.

#### **Example:**

```
src = 0xAABBCCDD
out = 0x11223344

merge_extract2(out, src, NO_LOAD_CC) // out == 0x112233CC
```

#### Table 2.26. merge\_extract2 parameters

| Name       | Description                                                                                                             |
|------------|-------------------------------------------------------------------------------------------------------------------------|
| dest       | Destination register                                                                                                    |
| source     | Input value                                                                                                             |
| in_load_cc | CONSTANT to specify whether user wants the load ALU condition codes based on the result performed Possible values are:  |
|            | • NO_LOAD_CC: Do not load condition code - suggested value if users only want to select byte(s) without any side effect |
|            | • DO_LOAD_CC: Load condition code                                                                                       |

## 2.2.3.18 merge\_extract3

#### **Prototype:**

```
merge_extract3(dest, source, in_load_cc)
```

#### **Description:**

Extract byte 3 from source, store in dest at bit 0.

#### **Example:**

```
src = 0xAABBCCDD
out = 0x11223344

merge_extract3(out, src, NO_LOAD_CC) // out == 0x112233DD
```

#### Table 2.27. merge\_extract3 parameters

| Name | Description          |
|------|----------------------|
| dest | Destination register |

© 2008-2014 Netronome 29 of 256

| Name       | Description                                                                                                            |
|------------|------------------------------------------------------------------------------------------------------------------------|
| source     | Input value                                                                                                            |
| in_load_cc | CONSTANT to specify whether user wants the load ALU condition codes based on the result performed Possible values are: |
|            | NO_LOAD_CC: Do not load condition code - suggested value if users only want to select byte(s) without any side effect  |
|            | DO_LOAD_CC: Load condition code                                                                                        |

## 2.2.3.19 merge\_extract01

#### **Prototype:**

merge\_extract01(dest, source, in\_load\_cc)

#### **Description**:

Extract byte 0 and 1 from source, store in dest at bit 0.

#### **Example:**

```
src = 0xAABBCCDD
out = 0x11223344

merge_extract01(out, src, NO_LOAD_CC) // out == 0x1122AABB
```

#### Table 2.28. merge\_extract01 parameters

| Name       | Description                                                                                                            |
|------------|------------------------------------------------------------------------------------------------------------------------|
| dest       | Destination register                                                                                                   |
| source     | Input value                                                                                                            |
| in_load_cc | CONSTANT to specify whether user wants the load ALU condition codes based on the result performed Possible values are: |
|            | NO_LOAD_CC: Do not load condition code - suggested value if users only want to select byte(s) without any side effect  |
|            | • DO_LOAD_CC: Load condition code                                                                                      |

## 2.2.3.20 merge\_extract12

#### **Prototype:**

merge\_extract12(dest, source, in\_load\_cc)

#### **Description**:

Extract byte 1 and 2 from source, store in dest at bit 0.

© 2008-2014 Netronome 30 of 256

#### **Example:**

```
src = 0xAABBCCDD
out = 0x11223344

merge_extract12(out, src, NO_LOAD_CC) // out == 0x1122BBCC
```

#### Table 2.29. merge\_extract12 parameters

| Name       | Description                                                                                                             |
|------------|-------------------------------------------------------------------------------------------------------------------------|
| dest       | Destination register                                                                                                    |
| source     | Input value                                                                                                             |
| in_load_cc | CONSTANT to specify whether user wants the load ALU condition codes based on the result performed Possible values are:  |
|            | • NO_LOAD_CC: Do not load condition code - suggested value if users only want to select byte(s) without any side effect |
|            | • DO_LOAD_CC: Load condition code                                                                                       |

## 2.2.3.21 merge\_extract23

#### **Prototype:**

merge\_extract23(dest, source, in\_load\_cc)

#### **Description**:

Extract byte 2 and 3 from source, store in dest at bit 0.

#### **Example:**

```
src = 0xAABBCCDD
out = 0x11223344

merge_extract23(out, src, NO_LOAD_CC) // out == 0x1122CCDD
```

#### Table 2.30. merge\_extract23 parameters

| Name       | Description                                                                                                             |
|------------|-------------------------------------------------------------------------------------------------------------------------|
| dest       | Destination register                                                                                                    |
| source     | Input value                                                                                                             |
| in_load_cc | CONSTANT to specify whether user wants the load ALU condition codes based on the result performed Possible values are:  |
|            | • NO_LOAD_CC: Do not load condition code - suggested value if users only want to select byte(s) without any side effect |
|            | • DO_LOAD_CC: Load condition code                                                                                       |

© 2008-2014 Netronome 31 of 256

## 2.2.3.22 merge\_extract02

#### **Prototype:**

merge\_extract02(dest, source, in\_load\_cc)

#### **Description**:

Extract byte 0 to 2 from source, store in dest at bit 0.

#### **Example:**

```
src = 0xAABBCCDD
out = 0x11223344

merge_extract02(out, src, NO_LOAD_CC) // out == 0x11AABBCC
```

#### Table 2.31. merge\_extract02 parameters

| Name       | Description                                                                                                            |
|------------|------------------------------------------------------------------------------------------------------------------------|
| dest       | Destination register                                                                                                   |
| source     | Input value                                                                                                            |
| in_load_cc | CONSTANT to specify whether user wants the load ALU condition codes based on the result performed Possible values are: |
|            | NO_LOAD_CC: Do not load condition code - suggested value if users only want to select byte(s) without any side effect  |
|            | • DO_LOAD_CC: Load condition code                                                                                      |

## 2.2.3.23 merge\_extract13

#### **Prototype:**

```
merge_extract13(dest, source, in_load_cc)
```

#### **Description:**

Extract byte 1 to 3 from source, store in dest at bit 0.

#### **Example:**

```
src = 0xAABBCCDD
out = 0x11223344

merge_extract13(out, src, NO_LOAD_CC) // out == 0x11BBCCDD
```

#### Table 2.32. merge\_extract13 parameters

| Name | Description          |
|------|----------------------|
| dest | Destination register |

© 2008-2014 Netronome 32 of 256

| Name       | Description                                                                                                                                                                        |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| source     | Input value                                                                                                                                                                        |
| in_load_cc | CONSTANT to specify whether user wants the load ALU condition codes based on the result performed Possible values are:                                                             |
|            | <ul> <li>NO_LOAD_CC: Do not load condition code - suggested value if users only want to select byte(s) without any side effect</li> <li>DO_LOAD_CC: Load condition code</li> </ul> |
|            |                                                                                                                                                                                    |

## 2.2.3.24 comp

#### **Prototype**:

comp(aop, bop)

#### **Description**:

Compare aop to bop.

#### Table 2.33. comp parameters

| Name | Description |
|------|-------------|
| aop  | Operand A   |
| bop  | Operand B   |

## 2.2.3.25 comp\_ea\_eb

#### **Prototype:**

comp\_ea\_eb(aop, bop)

#### **Description**:

Compare 4 byte endian swapped aop to 4 byte endian swapped bop.

#### Table 2.34. comp\_ea\_eb parameters

| Name | Description |
|------|-------------|
| aop  | Operand A   |
| bop  | Operand B   |

## 2.2.3.26 comp\_ea

#### **Prototype**:

comp\_ea(aop, bop)

© 2008-2014 Netronome 33 of 256

#### **Description**:

Compare 4 byte endian swapped aop to bop.

#### Table 2.35. comp\_ea parameters

| Name | Description |
|------|-------------|
| aop  | Operand A   |
| bop  | Operand B   |

## 2.2.3.27 comp\_ea01

#### **Prototype:**

comp\_ea01(aop, bop)

#### **Description**:

16 bit big-endian compare aop to big-endian bop, compare left 2 bytes of aop to bop.

#### Table 2.36. comp\_ea01 parameters

| Name | Description |
|------|-------------|
| aop  | Operand A   |
| bop  | Operand B   |

## 2.2.3.28 comp\_ea12

#### **Prototype:**

comp\_ea12(aop, bop)

#### **Description**:

16 bit big-endian compare aop to big-endian bop, compare middle 2 bytes of aop to bop.

#### Table 2.37. comp\_ea12 parameters

| Name | Description |
|------|-------------|
| аор  | Operand A   |
| bop  | Operand B   |

## 2.2.3.29 comp\_ea23

#### **Prototype**:

comp\_ea23(aop, bop)

© 2008-2014 Netronome 34 of 256

#### **Description**:

16 bit big-endian compare aop to big-endian bop, compare right 2 bytes of aop to bop.

#### Table 2.38. comp\_ea23 parameters

| Name | Description |
|------|-------------|
| aop  | Operand A   |
| bop  | Operand B   |

## 2.2.3.30 eadd\_ea\_eb

#### **Prototype:**

```
eadd_ea_eb(res, aop, bop)
```

#### **Description**:

4 byte endian add of swapped aop and swapped bop, swapped result.

#### **Executes:**

```
res = swap( swap(aop) + swap(bop) )
```

## 2.2.3.31 add ea eb

#### **Prototype**:

```
add_ea_eb(res, aop, bop)
```

#### **Description**:

4 byte endian add of swapped aop and swapped bop.

#### **Executes:**

```
res = swap(aop) + swap(bop)
```

## 2.2.3.32 eadd\_ea

#### **Prototype:**

```
eadd_ea(res, aop, bop)
```

#### **Description**:

4 byte endian add of swapped aop and bop, swapped result.

#### **Executes:**

© 2008-2014 Netronome 35 of 256

res = swap( swap(aop) + bop )



#### Note

bop can be the same register as res.

## 2.2.3.33 add\_ea

#### **Prototype:**

```
add_ea(res, aop, bop)
```

#### **Description**:

4 byte endian add of swapped aop and bop.

#### **Executes:**

```
res = swap(aop) + bop
```



#### **Note**

bop can be the same register as res.

## 2.2.3.34 add\_ea01\_eb

#### **Prototype:**

```
add_ea01_eb(res, aop, bop)
```

#### **Description**:

Swap(left 2 bytes of aop) + swap(bop).

#### **Executes:**

```
res = swap01(aop) + swap(bop)
```

## 2.2.3.35 add\_ea23\_eb

#### **Prototype:**

```
add_ea23_eb(res, aop, bop)
```

#### **Description**:

Swap(right 2 bytes aop) + swap(bop).

#### **Executes:**

© 2008-2014 Netronome 36 of 256

res = swap23(aop) + swap(bop)

## 2.2.3.36 add\_ea\_c

### **Prototype:**

add\_ea\_c(res, aop, bop)

### **Description**:

4 byte endian carry add of swapped aop and bop.

#### **Executes:**

res = swap(aop) + bop + previous carry



## **Note**

bop can be the same register as res.

## 2.2.3.37 add\_ea23\_c

#### **Prototype:**

add\_ea23\_c(res, aop, bop)

#### **Description**:

4 byte endian carry add of swap(right 2 bytes aop) and bop.

#### **Executes:**

res = swap23(aop) + bop + previous carry



### Note

bop can be the same register as res.

# 2.2.3.38 add\_ea01\_c

### **Prototype:**

add\_ea01\_c(res, aop, bop)

### **Description**:

4 byte endian carry add of swap(left 2 bytes aop) and bop.

#### **Executes:**

© 2008-2014 Netronome 37 of 256

res = swap01(aop) + bop + previous carry



#### **Note**

bop can be the same register as res.

## 2.2.3.39 incr0

## **Prototype:**

incr0(dest, source)

### **Description**:

Increment byte 0, other bytes are unaffected.

Source can be a read transfer register. Destination can be a write transfer register.

## 2.2.3.40 incr1

### **Prototype:**

incr1(dest, source)

#### **Description**:

Increment byte 1, other bytes are unaffected.

Source can be a read transfer register. Destination can be a write transfer register.

### 2.2.3.41 incr2

### **Prototype:**

incr2(dest, source)

#### **Description**:

Increment byte 2, other bytes are unaffected.

Source can be a read transfer register. Destination can be a write transfer register.

## 2.2.3.42 incr3

#### **Prototype:**

incr3(dest, source)

© 2008-2014 Netronome 38 of 256

### **Description**:

Increment byte 3, other bytes are unaffected.

Source can be a read transfer register. Destination can be a write transfer register.

### 2.2.3.43 incr01

### **Prototype:**

```
incr01(dest, source)
```

#### **Description**:

Increment bytes 0-1.

Source can be a read transfer register. Destination can be a write transfer register.

## 2.2.3.44 incr12

#### **Prototype:**

```
incr12(dest, source)
```

#### **Description**:

Increment bytes 1-2, other bytes are unaffected.

Source can be a read transfer register. Destination can be a write transfer register.

## 2.2.3.45 incr23

#### **Prototype:**

```
incr23(dest, source)
```

#### **Description:**

Increment bytes 2-3, other bytes are unaffected.

Source can be a read transfer register. Destination can be a write transfer register.

## 2.2.3.46 incr02

### **Prototype**:

```
incr02(dest, source)
```

#### **Description**:

© 2008-2014 Netronome 39 of 256

Increment bytes 0-2.

Source can be a read transfer register. Destination can be a write transfer register.

## 2.2.3.47 incr13

## **Prototype**:

```
incr13(dest, source)
```

#### **Description**:

Increment bytes 1-3, other bytes are unaffected.

Source can be a read transfer register. Destination can be a write transfer register.

## 2.2.3.48 incr03

#### **Prototype:**

```
incr03(dest, source)
```

### **Description**:

Increment bytes 0-3.

Source can be a read transfer register. Destination can be a write transfer register.

#### 2.2.3.49 decr0

#### **Prototype:**

```
decr0(dest, source)
```

#### **Description**:

Decrement byte 0, other bytes are unaffected.

Source can be a read transfer register. Destination can be a write transfer register.

## 2.2.3.50 decr1

#### **Prototype:**

```
decr1(dest, source)
```

### **Description**:

Decrement byte 1, other bytes are unaffected.

© 2008-2014 Netronome 40 of 256

Source can be a read transfer register. Destination can be a write transfer register.

### 2.2.3.51 decr2

### **Prototype:**

```
decr2(dest, source)
```

#### **Description**:

Decrement byte 2, other bytes are unaffected.

Source can be a read transfer register. Destination can be a write transfer register.

## 2.2.3.52 decr3

#### **Prototype:**

```
decr3(dest, source)
```

#### **Description**:

Decrement byte 3, other bytes are unaffected.

Source can be a read transfer register. Destination can be a write transfer register.

### 2.2.3.53 decr01

### **Prototype:**

```
decr01(dest, source)
```

#### **Description**:

Decrement byte 0-1, other bytes are unaffected.

Source can be a read transfer register. Destination can be a write transfer register.

## 2.2.3.54 decr12

### **Prototype:**

```
decr12(dest, source)
```

### **Description**:

Decrement byte 1-2, other bytes are unaffected.

Source can be a read transfer register. Destination can be a write transfer register.

© 2008-2014 Netronome 41 of 256

## 2.2.3.55 decr23

## **Prototype:**

```
decr23(dest, source)
```

### **Description**:

Decrement byte 2-3, other bytes are unaffected.

Source can be a read transfer register. Destination can be a write transfer register.

## 2.2.3.56 decr02

### **Prototype:**

```
decr02(dest, source)
```

#### **Description**:

Decrement byte 0-2, other bytes are unaffected.

Source can be a read transfer register. Destination can be a write transfer register.

## 2.2.3.57 decr13

#### **Prototype:**

```
decr13(dest, source)
```

#### **Description**:

Decrement byte 1-3, other bytes are unaffected.

Source can be a read transfer register. Destination can be a write transfer register.

## 2.2.3.58 decr03

## **Prototype**:

```
decr03(dest, source)
```

#### **Description**:

Decrement byte 0-3.

Source can be a read transfer register. Destination can be a write transfer register.

© 2008-2014 Netronome 42 of 256

# 2.3 Bitfield Operations

# 2.3.1 Bitfield Operation Macros

These macros perform bitfield operations using minimum number of instructions

**Table 2.39. Bitfield Operations and Defines** 

| Defined          | Definition         |
|------------------|--------------------|
| BF_AML(a,w,m,l)  | a[w], m, l         |
| BF_AL(a,w,m,1)   | a[w], 1            |
| BF_A(a,w,m,1)    | a[w]               |
| BF_ML(w,m,1)     | m, 1               |
| BF_W(w,m,1)      | w                  |
| BF_M(w,m,1)      | m                  |
| BF_L(w,m,1)      | 1                  |
| BF_WIDTH(w,m,1)  | (m + 1 - 1)        |
| _bitfield_insert | bitfield_insertsz2 |
| _bitfield_clear  | bitfield_clearsz1  |
| _bitfield_or     | bitfield_orsz1     |
| _bitfield_copy   | bitfield_copysz2   |
| F_AML            | BF_AML             |
| F_AL             | BF_AL              |
| F_A              | BF_A               |
| F_ML             | BF_ML              |
| F_W              | BF_W               |
| F_M              | BF_M               |
| F_L              | BF_L               |

# 2.3.3.1 alu\_shf\_left\_\_sz1

#### **Prototype:**

alu\_shf\_left\_\_sz1(out\_result, in\_a, op\_spec, in\_b, in\_shift\_amt)

## **Description**:

Shift left in\_b by in\_shift\_amt bit positions, then perform operation op\_spec on in\_a.

© 2008-2014 Netronome 43 of 256

### **Example:**

```
.reg output, input
immed[input, 0x05]
alu_shf_left__sz1(output, 0x02, OR, input, 4)
```

Limited to restricted operands and single 8 bit constant parameter or 2 GPRs Use alu\_shf\_left() instead for reduced limitations

**Instruction Count:** 1

## Table 2.40. alu\_shf\_left\_\_sz1 parameters

| Name         | Description                        |
|--------------|------------------------------------|
| out_result   | Destination                        |
| in_a         | Register or constant               |
| op_spec      | ALU operation Legal operators are: |
|              | • B                                |
|              | • ~B                               |
|              | • AND                              |
|              | • ~AND                             |
|              | • AND~                             |
|              | • OR                               |
| in_b         | Register or constant               |
| in_shift_amt | Constant (0 to 31)                 |

# 2.3.3.2 alu\_shf\_right\_\_sz1

#### **Prototype:**

```
alu_shf_right__sz1(out_result, in_a, op_spec, in_b, in_shift_amt)
```

#### **Description:**

Shift right in\_b by in\_shift\_amt bit positions, then perform operation op\_spec on in\_a.

## **Example:**

```
.reg output, input
immed[input, 0x50]
alu_shf_right__sz1(output, 0x20, OR, input, 4)
```

Limited to restricted operands and single 8 bit constant parameter or 2 GPRs Use  $alu\_shf\_left()$  instead for more flexibility

#### **Instruction Count:** 1

© 2008-2014 Netronome 44 of 256

Table 2.41. alu\_shf\_right\_\_sz1 parameters

| Name         | Description                        |
|--------------|------------------------------------|
| out_result   | Destination                        |
| in_a         | Register or constant               |
| op_spec      | ALU operation Legal operators are: |
|              | • B                                |
|              | • ~B                               |
|              | • AND                              |
|              | • ~AND                             |
|              | • AND~                             |
|              | • OR                               |
| in_b         | Register or constant               |
| in_shift_amt | Constant (0 to 31)                 |

## 2.3.3.3 bits\_clr\_\_sz1

## **Prototype:**

bits\_clr\_\_sz1(io\_data, in\_start\_bit\_pos, in\_mask)

### **Description**:

Clear bits indicated by mask at starting position in\_start\_bit\_pos.

### **Example:**

```
.reg reg2, bitpos
bits_clr__sz1(reg2, bitpos, 0x3)
```

Limited to restricted operands, use bits\_clr() instead for more flexibility

## **Instruction Count:** 1

Table 2.42. bits\_clr\_\_sz1 parameters

| Name             | Description                                                                         |
|------------------|-------------------------------------------------------------------------------------|
| io_data          | Register to modify                                                                  |
| in_start_bit_pos | Constant less than 32, starting bit position in_mask is shifted left by this amount |
| in_mask          | Register or constant, mask of bits to clear                                         |

## 2.3.3.4 bits\_set\_\_sz1

### **Prototype:**

© 2008-2014 Netronome 45 of 256

```
bits_set__szl(io_data, in_start_bit_pos, in_mask)
```

#### **Description:**

Set bits indicated by mask at starting position in\_start\_bit\_pos.

#### **Example:**

```
.reg reg2, bitpos
bits_set__sz1(reg2, bitpos, 0x3)
```

Limited to restricted operands, use bits\_set() instead for more flexibility

#### **Instruction Count:** 1

#### Table 2.43. bits\_set\_\_sz1 parameters

| Name             | Description                                                                         |
|------------------|-------------------------------------------------------------------------------------|
| io_data          | Register to modify                                                                  |
| in_start_bit_pos | Constant less than 32, starting bit position in_mask is shifted left by this amount |
| in_mask          | Register or constant, mask of bits to set                                           |

## 2.3.3.5 bitfield\_extract\_\_sz1

#### **Prototype:**

bitfield\_extract\_\_sz1(out\_result, in\_src, MSB, LSB)

#### **Description:**

Extract a bit field from a register.

#### **Example:**

```
.reg r_out, r_in
bitfield_extract__sz1(r_out, r_in, 15, 8)
```



#### **Note**

Bits are numbered 31-0, left to right.

Limited to restricted operands in some cases, as well as certain combinations of MSB/LSB. Use bitfield\_extract() instead for more flexibility

#### **Instruction Count:** 1

© 2008-2014 Netronome 46 of 256

Table 2.44. bitfield\_extract\_\_sz1 parameters

| Name       | Description                                 |
|------------|---------------------------------------------|
| out_result | Extracted field                             |
| in_src     | Source register with multiple fields        |
| MSB        | Most significant, left bit defining field   |
| LSB        | Least significant, right bit defining field |

# 2.3.3.6 bitfield\_clear\_\_sz1

## **Prototype:**

bitfield\_clear\_\_sz1(io\_data, MSB, LSB)

#### **Description**:

Clear a bit field in a register.

#### **Example:**

```
.reg r_val
bitfield_clear__sz1(r_val, 15, 8)
```



### Note

Bits are numbered 31-0, left to right.

Limited to restricted operands. Use bits\_clr instead for more flexibility

#### **Instruction Count:** 1

Table 2.45. bitfield\_clear\_\_sz1 parameters

| Name    | Description                                           |
|---------|-------------------------------------------------------|
| io_data | Register to clear                                     |
| MSB     | Constant, most significant, left bit defining field   |
| LSB     | Constant, least significant, right bit defining field |

# 2.3.3.7 bitfield\_insert\_\_sz2

#### **Prototype:**

bitfield\_insert\_\_sz2(io\_data, MSB, LSB, in\_mask)

### **Description**:

Clear a bit field in a register, then inserts in\_mask.

© 2008-2014 Netronome 47 of 256

### **Example:**

```
.reg r_val
bitfield_insert__sz2(r_val, 15, 8, 0x23)
```



### **Note**

Bits are numbered 31-0, left to right.

Limited to restricted operands. Use bitfield\_insert instead for more flexibility If in\_mask is a run-time constant, ensures that the value of in\_mask is not wider than (MSB - LSB + 1) bits

#### **Instruction Count: 2**

## Table 2.46. bitfield\_insert\_\_sz2 parameters

| Name    | Description                                           |
|---------|-------------------------------------------------------|
| io_data | Register to insert value                              |
| MSB     | Constant, most significant, left bit defining field   |
| LSB     | Constant, least significant, right bit defining field |
| in_mask | Register or constant, bit mask to insert              |

# 2.3.3.8 bitfield\_insert\_\_sz1

#### **Prototype:**

bitfield\_insert\_\_szl(io\_data, MSB, LSB, in\_mask)

#### **Description:**

Retain deprecated aliases for backwards compatibility, but with compiler warnings.

## 2.3.3.9 bitfield or sz1

#### **Prototype:**

```
bitfield_or__sz1(io_data, LSB, in_mask)
```

#### **Description**:

Logical Or bits in an input field into a register.

#### **Example:**

```
.reg r_val
bitfield_or__sz1(r_val, 8, 0x23)
```

© 2008-2014 Netronome 48 of 256



### Note

Bits are numbered 31-0, left to right.

Limited to restricted operands. Use bitfield\_insert instead for more flexibility

#### **Instruction Count:** 1

Table 2.47. bitfield\_or\_\_sz1 parameters

| Name    | Description                                               |
|---------|-----------------------------------------------------------|
| io_data | Register in which to logical or in_mask                   |
| LSB     | Constant, least significant, right bit defining field     |
| in_mask | Register or constant, bit mask to logical or into io_data |

## 2.3.3.10 bitfield\_copy\_\_sz2

### **Prototype:**

bitfield\_copy\_\_sz2(out\_reg, OUT\_LSB, in\_reg, IN\_MSB, IN\_LSB)

#### **Description**:

Logical Or a bitfield from one register into another register.

#### **Example:**

```
.reg r_val
bitfield_copy__sz2(r_val, 8, 0x23, 15, 0)
```



## **Note**

Bits are numbered 31-0, left to right.

Limited to restricted operands.

## **Instruction Count: 2**

Table 2.48. bitfield\_copy\_\_sz2 parameters

| Name    | Description                                                      |
|---------|------------------------------------------------------------------|
| out_reg | Register in which to logical or the bitfield from in_reg         |
| OUT_LSB | Constant, least significant, right bit defining field in out_reg |
| in_reg  | Register containing bit field to extract and insert into out_reg |
| IN_MSB  | Constant, most significant, left bit defining field in in_reg    |
| IN_LSB  | Constant, least significant, right bit defining field in in_reg  |

© 2008-2014 Netronome 49 of 256

## 2.3.3.11 bitfield\_copy\_\_sz1

## **Prototype:**

bitfield\_copy\_\_sz1(out\_reg, OUT\_LSB, in\_reg, IN\_MSB, IN\_LSB)

### **Description**:

Retain deprecated aliases for backwards compatibility, but with compiler warnings.

# 2.4 Byte Field Manipulation

# 2.4.1 Big / Little-endian Byte Field Extract / Compare / Branch Macros

Default is BIG-ENDIAN.By defining LITTLE\_ENDIAN, the appropriate underlying swaps will be inserted. This will allow users to write code that runs big- or little-endian.

## 2.4.2.1 bytefield\_decr

#### **Prototype:**

bytefield\_decr(out\_result, in\_src, in\_start\_byte, in\_end\_byte)

#### **Description**:

Decrement byte field from in\_src and place the result into out\_result.

#### **Example:**

bytefield\_decr(reg, \$xfer[0], 1, 2) // decrement 2 byte fields

**Instruction Count:** 2 to 4

### Table 2.49. bytefield\_decr parameters

| Name          | Description                                                                                            |
|---------------|--------------------------------------------------------------------------------------------------------|
| out_result    | GPR or write transfer register                                                                         |
| in_src        | GPR or read transfer reg containing byte field. If GPR, it must be on the opposite bank as out_result. |
| in_start_byte | Starting byte position 0-3 based on endian mode                                                        |
| in_end_byte   | Ending byte position 0-3 based on endian mode. Can be equal to or greater than in_start_byte.          |

© 2008-2014 Netronome 50 of 256

## 2.4.2.2 bytefield\_incr

## **Prototype:**

bytefield\_incr(out\_result, in\_src, in\_start\_byte, in\_end\_byte)

## **Description**:

Increment byte field from in\_src and place the result into out\_result.

#### **Example:**

bytefield\_incr(reg, \$xfer[0], 1, 3) // increment 3 byte fields

**Instruction Count:** 2 to 4

## Table 2.50. bytefield\_incr parameters

| Name          | Description                                                                                            |
|---------------|--------------------------------------------------------------------------------------------------------|
| out_result    | GPR or write transfer register                                                                         |
|               | GPR or read transfer reg containing byte field. If GPR, it must be on the opposite bank as out_result. |
| in_start_byte | Starting byte position 0-3 based on endian mode                                                        |
| in_end_byte   | Ending byte position 0-3 based on endian mode. Can be equal to or greater than in_start_byte.          |

# 2.4.2.3 bytefield\_extract

### **Prototype:**

bytefield\_extract(out\_result, in\_src, in\_start\_byte, in\_end\_byte, in\_load\_cc)

## **Description**:

Extract byte field from in\_src and place the result into out\_result.

### **Example:**

bytefield\_extract(reg, \$xfer[0], 1, 3, DO\_LOAD\_CC) // extract 3 byte fields

**Instruction Count:** 1 to 3

## Table 2.51. bytefield\_extract parameters

| Name          | Description                                                                                            |
|---------------|--------------------------------------------------------------------------------------------------------|
| out_result    | GPR                                                                                                    |
|               | GPR or read transfer reg containing byte field. If GPR, it must be on the opposite bank as out_result. |
| in_start_byte | Starting byte position 0-3 based on endian mode                                                        |

© 2008-2014 Netronome 51 of 256

| Name        | Description                                                                                                            |
|-------------|------------------------------------------------------------------------------------------------------------------------|
| in_end_byte | Ending byte position 0-3 based on endian mode. Must be greater than in_start_byte.                                     |
| in_load_cc  | CONSTANT to specify whether user wants the load ALU condition codes based on the result performed Possible values are: |
|             | NO_LOAD_CC: Do not load condition code - suggested value if users only want to select byte(s) without any side effect  |
|             | DO_LOAD_CC: Load condition code                                                                                        |

# 2.4.2.4 bytefield\_dbl\_extract

### **Prototype:**

bytefield\_dbl\_extract(out\_result, in\_a, in\_start\_byte, in\_b, in\_end\_byte, in\_load\_cc)

## **Description**:

Extract a field that spans two input registers.

## **Example:**

bytefield\_dbl\_extract(reg, \$xfer[0], 3, \$xfer[1], 1, DO\_LOAD\_CC) // extract 3 byte fields

**Instruction Count:** 2 to 4

Table 2.52. bytefield\_dbl\_extract parameters

| Name          | Description                                                                                                             |
|---------------|-------------------------------------------------------------------------------------------------------------------------|
| out_result    | GPR                                                                                                                     |
| in_a          | GPR or read transfer reg, left source longword. If GPR, it must be on the opposite bank as out_result.                  |
| in_start_byte | Starting byte position 0-3 of in_a based on endian mode                                                                 |
| in_b          | GPR or read transfer register, right source longword. If GPR, it must be on the opposite bank as out_result.            |
| in_end_byte   | Ending byte position 0-3 of in_b based on endian mode. Must be less than in_start_byte.                                 |
| in_load_cc    | CONSTANT to specify whether user wants the load ALU condition codes based on the result performed. Possible values are: |
|               | NO_LOAD_CC: Do not load condition code - suggested value if users only want to select byte(s) without any side effect   |
|               | DO_LOAD_CC: Load condition code                                                                                         |

# 2.4.2.5 bytefield\_insert

## **Prototype:**

© 2008-2014 Netronome 52 of 256

bytefield\_insert(io\_a, in\_byte\_mask, in\_b, in\_load\_cc)

#### **Description**:

Insert bytes from in\_b specified by in\_byte\_mask into io\_a.

The source and destination registers must have the same endianness.

#### **Example:**

```
bytefield_insert(x, 0110, y, DO_LOAD_CC) // insert y bytes 1,2 into x bytes 1,2
```

**Instruction Count:** 1 to 3

## Table 2.53. bytefield\_insert parameters

| Name         | Description                                                                                                             |
|--------------|-------------------------------------------------------------------------------------------------------------------------|
| io_a         | GPR                                                                                                                     |
| in_byte_mask | xxxx, where $x = 0$ or 1. If 1, insert byte.                                                                            |
| in_b         | GPR or read transfer register. If GPR, it must be on the opposite bank as io_a.                                         |
| in_load_cc   | CONSTANT to specify whether user wants the load ALU condition codes based on the result performed. Possible values are: |
|              | NO_LOAD_CC: Do not load condition code - suggested value if users only want to select byte(s) without any side effect   |
|              | • DO_LOAD_CC: Load condition code                                                                                       |

# 2.4.2.6 bytefield\_select

#### **Prototype:**

bytefield\_select(out\_result, in\_byte\_mask, in\_src, in\_load\_cc)

#### **Description**:

Insert bytes from in\_src specified by in\_byte\_mask into out\_result.

The output register out\_result is cleared prior to the insert.

The source and destination registers must have the same endianness.

#### **Example:**

```
bytefield_select(x, 0110, y, DO_LOAD_CC) // output bytes 1-2
```

**Instruction Count:** 1 to 3

© 2008-2014 Netronome 53 of 256

Table 2.54. bytefield\_select parameters

| Name         | Description                                                                                                                                                                                                                                                                        |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| out_result   | GPR or write transfer register                                                                                                                                                                                                                                                     |
| in_byte_mask | xxxx, where $x = 0$ or 1. If 1, insert byte.                                                                                                                                                                                                                                       |
| in_src       | GPR or read transfer register. If both out_result and in_src are GPR, in_src must be on the opposite bank as out_result.                                                                                                                                                           |
| in_load_cc   | CONSTANT to specify whether user wants the load ALU condition codes based on the result performed Possible values are:  • NO_LOAD_CC: Do not load condition code - suggested value if users only want to select byte(s) without any side effect  • DO_LOAD_CC: Load condition code |

# 2.4.2.7 bytefield\_br\_eq

## **Prototype:**

bytefield\_br\_eq(in\_src, in\_start\_byte, in\_end\_byte, COMPARE\_VAL, target\_label)

## **Description**:

Compare byte field to a constant and branch if equal.

### **Example:**

bytefield\_br\_eq(test\_reg, 0, 2, 0xff, exception\_handler#)

**Instruction Count:** 2 to 4

## Table 2.55. bytefield\_br\_eq parameters

| Name          | Description                                                                        |
|---------------|------------------------------------------------------------------------------------|
| in_src        | GPR or read transfer reg containing byte field                                     |
| in_start_byte | Starting byte position 0-3 based on endian mode                                    |
| in_end_byte   | Ending byte position 0-3 based on endian mode. Must be greater than in_start byte. |
| COMPARE_VAL   | Constant value to compare field with                                               |
| target_label  | Label to branch to                                                                 |

# 2.4.2.8 bytefield\_br\_gtr

### **Prototype**:

bytefield\_br\_gtr(in\_src, in\_start\_byte, in\_end\_byte, COMPARE\_VAL, target\_label)

### **Description**:

© 2008-2014 Netronome 54 of 256

Compare byte field to a constant and branch if field is greater.

### **Example:**

```
bytefield_br_gtr(test_reg, 0, 2, 0xff, exception_handler#)
```

**Instruction Count:** 2 to 4

### Table 2.56. bytefield\_br\_gtr parameters

| Name          | Description                                                                        |
|---------------|------------------------------------------------------------------------------------|
| in_src        | GPR or read transfer reg containing byte field                                     |
| in_start_byte | Starting byte position 0-3 based on endian mode                                    |
| in_end_byte   | Ending byte position 0-3 based on endian mode. Must be greater than in_start byte. |
| COMPARE_VAL   | Constant value to compare field with                                               |
| target_label  | Label to branch to                                                                 |

# 2.4.2.9 bytefield\_br\_gtreq

### **Prototype:**

bytefield\_br\_gtreq(in\_src, in\_start\_byte, in\_end\_byte, COMPARE\_VAL, target\_label)

## **Description**:

Compare byte field to a constant and branch if field is greater or equal.

#### **Example:**

```
bytefield_br_gtreq(test_reg, 0, 2, 0xff, exception_handler#)
```

**Instruction Count:** 2 to 4

## Table 2.57. bytefield\_br\_gtreq parameters

| Name          | Description                                                                        |
|---------------|------------------------------------------------------------------------------------|
| in_src        | GPR or read transfer reg containing byte field                                     |
| in_start_byte | Starting byte position 0-3 based on endian mode                                    |
| in_end_byte   | Ending byte position 0-3 based on endian mode. Must be greater than in_start byte. |
| COMPARE_VAL   | Constant value to compare field with                                               |
| target_label  | Label to branch to                                                                 |

# 2.4.2.10 bytefield\_br\_less

## **Prototype:**

bytefield\_br\_less(in\_src, in\_start\_byte, in\_end\_byte, COMPARE\_VAL, target\_label)

© 2008-2014 Netronome 55 of 256

### **Description**:

Compare byte field to a constant and branch if field is less.

#### **Example:**

```
bytefield_br_less(test_reg, 0, 2, 0xff, exception_handler#)
```

**Instruction Count:** 2 to 4

## Table 2.58. bytefield\_br\_less parameters

| Name          | Description                                                                        |
|---------------|------------------------------------------------------------------------------------|
| in_src        | GPR or read transfer reg containing byte field                                     |
| in_start_byte | Starting byte position 0-3 based on endian mode                                    |
| in_end_byte   | Ending byte position 0-3 based on endian mode. Must be greater than in_start byte. |
| COMPARE_VAL   | Constant value to compare field with                                               |
| target_label  | Label to branch to                                                                 |

# 2.4.2.11 bytefield\_br\_lesseq

### **Prototype:**

bytefield\_br\_lesseq(in\_src, in\_start\_byte, in\_end\_byte, COMPARE\_VAL, target\_label)

## **Description**:

Compare byte field to a constant and branch if field is less or equal.

#### **Example:**

```
bytefield_br_lesseq(test_reg, 0, 2, 0xff, exception_handler#)
```

**Instruction Count:** 2 to 4

### Table 2.59. bytefield\_br\_lesseq parameters

| Name          | Description                                                                        |
|---------------|------------------------------------------------------------------------------------|
| in_src        | GPR or read transfer reg containing byte field                                     |
| in_start_byte | Starting byte position 0-3 based on endian mode                                    |
| in_end_byte   | Ending byte position 0-3 based on endian mode. Must be greater than in_start byte. |
| COMPARE_VAL   | Constant value to compare field with                                               |
| target_label  | Label to branch to                                                                 |

# 2.4.2.12 bytefield\_comp

### **Prototype:**

© 2008-2014 Netronome 56 of 256

bytefield\_comp(in\_src, in\_start\_byte, in\_end\_byte, COMPARE\_VAL)

#### **Description**:

Extract byte field based on endian mode.

Compare byte field to COMPARE\_VAL.

Condition code is set as result of compare.

#### **Example:**

```
bytefield_comp(test_reg, 0, 2, 0xff)
```

**Instruction Count:** 2 to 4

#### Table 2.60. bytefield\_comp parameters

| Name          | Description                                                                        |
|---------------|------------------------------------------------------------------------------------|
| in_src        | GPR or read transfer reg containing byte field                                     |
| in_start_byte | Starting byte position 0-3 based on endian mode                                    |
| in_end_byte   | Ending byte position 0-3 based on endian mode. Must be greater than in_start byte. |
| COMPARE_VAL   | Constant value to compare field with                                               |

# 2.4.2.13 bytefield\_shf\_left\_insert

## **Prototype:**

bytefield\_shf\_left\_insert(io\_a, in\_byte\_mask, in\_b, in\_shift\_amt, in\_load\_cc)

#### **Description**:

Insert bytes from in\_b specified by in\_byte\_mask into io\_a.

The source and destination registers must have the same endianness.

## **Example:**

```
bytefield_shf_left_insert(x, 0110, y, 8, DO_LOAD_CC) // insert y bytes 2,3 into x bytes 1,2
```

**Instruction Count:** 1 to 3

#### Table 2.61. bytefield\_shf\_left\_insert parameters

| Name         | Description                                                                     |
|--------------|---------------------------------------------------------------------------------|
| io_a         | GPR                                                                             |
| in_byte_mask | xxxx, where $x = 0$ or 1. If 1, insert byte.                                    |
| in_b         | GPR or read transfer register. If GPR, it must be on the opposite bank as io_a. |
| in_shift_amt | Shift amount 0-31                                                               |

© 2008-2014 Netronome 57 of 256

| Description                                                                                                                                            |
|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| CONSTANT to specify whether user wants the load ALU condition codes based on the result performed. Possible values are:                                |
| NO_LOAD_CC: Do not load condition code - suggested value if users only want to select byte(s) without any side effect  DO_LOAD_CC: Load condition code |
| )(                                                                                                                                                     |

## 2.4.2.14 bytefield\_shf\_right\_insert

#### **Prototype:**

bytefield\_shf\_right\_insert(io\_a, in\_byte\_mask, in\_b, in\_shift\_amt, in\_load\_cc)

## **Description**:

Insert bytes from in\_b specified by in\_byte\_mask into io\_a after shifting in\_b left by in\_shift\_amt.

The source and destination registers must have the same endianness.

## **Example:**

bytefield\_shf\_right\_insert(x, 0110, y, 8, DO\_LOAD\_CC) // insert y bytes 0,1 into x bytes 1,2

**Instruction Count:** 1 to 3

## Table 2.62. bytefield\_shf\_right\_insert parameters

| Name         | Description                                                                                                            |
|--------------|------------------------------------------------------------------------------------------------------------------------|
| io_a         | GPR                                                                                                                    |
| in_byte_mask | xxxx, where $x = 0$ or 1. If 1, insert byte.                                                                           |
| in_b         | GPR or read transfer register. If GPR, it must be on the opposite bank as io_a.                                        |
| in_shift_amt | Shift amount 0-31                                                                                                      |
| in_load_cc   | CONSTANT to specify whether user wants the load ALU condition codes based on the result performed Possible values are: |
|              | NO_LOAD_CC: Do not load condition code - suggested value if users only want to select byte(s) without any side effect  |
|              | DO_LOAD_CC: Load condition code                                                                                        |

# 2.4.2.15 bytefield\_clr\_insert

### **Prototype:**

bytefield\_clr\_insert(out\_result, in\_byte\_mask, in\_b, in\_load\_cc)

## **Description**:

© 2008-2014 Netronome 58 of 256

Insert bytes from in\_b specified by in\_byte\_mask into out\_result.

The output register out\_result is cleared prior to the insert.

The source and destination registers must have the same endianness.

#### **Example:**

```
bytefield_clr_insert(x, 0110, y, DO_LOAD_CC) // insert y bytes 1,2 into x bytes 1,2
```

**Instruction Count:** 1 to 3

### Table 2.63. bytefield\_clr\_insert parameters

| Name         | Description                                                                                                             |
|--------------|-------------------------------------------------------------------------------------------------------------------------|
| out_result   | GPR or write transfer register                                                                                          |
| in_byte_mask | xxxx, where $x = 0$ or 1. If 1, insert byte.                                                                            |
| in_b         | GPR or read transfer register. If both out_result and in_b are GPR, in_b must be on the opposite bank as out_result.    |
| in_load_cc   | CONSTANT to specify whether user wants the load ALU condition codes based on the result performed. Possible values are: |
|              | NO_LOAD_CC: Do not load condition code - suggested value if users only want to select byte(s) without any side effect   |
|              | • DO_LOAD_CC: Load condition code                                                                                       |

## 2.4.2.16 bytefield\_clr\_shf\_left\_insert

#### **Prototype:**

bytefield\_clr\_shf\_left\_insert(out\_result, in\_byte\_mask, in\_b, in\_shift\_amt, in\_load\_cc)

#### **Description:**

Insert bytes from in\_b specified by in\_byte\_mask into out\_result after shifting in\_b left by in\_shift\_amt.

The output register out\_result is cleared prior to the insert.

The source and destination registers must have the same endianness.

## **Example:**

bytefield\_clr\_shf\_left\_insert(x, 0110, y, 8, DO\_LOAD\_CC) // insert y bytes 2,3 into x bytes 1,2

**Instruction Count:** 1 to 3

© 2008-2014 Netronome 59 of 256

Table 2.64. bytefield\_clr\_shf\_left\_insert parameters

| Name         | Description                                                                                                             |
|--------------|-------------------------------------------------------------------------------------------------------------------------|
| out_result   | GPR or write transfer register                                                                                          |
| in_byte_mask | xxxx, where $x = 0$ or 1. If 1, insert byte.                                                                            |
| in_b         | GPR or read transfer register. If both out_result and in_b are GPR, in_b must be on the opposite bank as out_result.    |
| in_shift_amt | Shift amount 0-31                                                                                                       |
| in_load_cc   | CONSTANT to specify whether user wants the load ALU condition codes based on the result performed. Possible values are: |
|              | • NO_LOAD_CC: Do not load condition code - suggested value if users only want to select byte(s) without any side effect |
|              | • DO_LOAD_CC: Load condition code                                                                                       |

# 2.4.2.17 bytefield\_clr\_shf\_right\_insert

## **Prototype:**

bytefield\_clr\_shf\_right\_insert(out\_result, in\_byte\_mask, in\_b, in\_shift\_amt, in\_load\_cc)

#### **Description**:

Insert bytes from in\_b specified by in\_byte\_mask into out\_result after shifting in\_b left by in\_shift\_amt.

The output register out\_result is cleared prior to the insert.

The source and destination registers must have the same endianness.

## **Example:**

bytefield\_clr\_shf\_right\_insert(x, 0110, y, 8, DO\_LOAD\_CC) // insert y bytes 0,1 into x bytes 1,2

**Instruction Count:** 1 to 3

Table 2.65. bytefield\_clr\_shf\_right\_insert parameters

| Name         | Description                                                                                                          |
|--------------|----------------------------------------------------------------------------------------------------------------------|
| out_result   | GPR or write transfer register                                                                                       |
| in_byte_mask | xxxx, where $x = 0$ or 1. If 1, insert byte.                                                                         |
| in_b         | GPR or read transfer register. If both out_result and in_b are GPR, in_b must be on the opposite bank as out_result. |
| in_shift_amt | Shift amount 0-31                                                                                                    |

© 2008-2014 Netronome 60 of 256

| Name       | Description                                                                                                             |
|------------|-------------------------------------------------------------------------------------------------------------------------|
| in_load_cc | CONSTANT to specify whether user wants the load ALU condition codes based on the result performed. Possible values are: |
|            | NO_LOAD_CC: Do not load condition code - suggested value if users only want to select byte(s) without any side effect   |
|            | • DO_LOAD_CC: Load condition code                                                                                       |

## 2.5 Cluster Local Scratch

# 2.5.1 Cluster Local Scratch Operation Macros

Default: all memory operation word counts are actual word counts.MEM\_WD\_COUNT\_MIN\_1

### **Table 2.66. Cluster Local Scratch and Defines**

| Defined         | Definition        |
|-----------------|-------------------|
| lscratch_memset | cls_memset        |
|                 | Deprecated alias. |

## 2.5.3.1 cls\_read

## **Prototype:**

cls\_read(out\_data, in\_cls\_addr, in\_addr\_offset, in\_lw\_count, REQ\_SIG, in\_wakeup\_sigs,
Q\_OPTION)

### **Description**:

Read from Cluster Local Scratch starting at address of first longword.

### **Example:**

cls\_read(\$packet[2], addr, 0, LWCOUNT3, SIG\_CS, SIG\_CS, \_\_\_\_)



#### **Note**

Temporary register usage: Uses 0 to 2 registers if constant addr args > MAX\_IMMEDIATE, or register length.

© 2008-2014 Netronome 61 of 256

## Table 2.67. cls\_read parameters

| Name           | Description                                                                                    |
|----------------|------------------------------------------------------------------------------------------------|
| out_data       | First transfer register of sequence to read to, array notation must be in xbuf array notation, |
|                | index range 0-15 for NFP-32xx                                                                  |
| in_cls_addr    | Register or constant base longword address                                                     |
| in_addr_offset | Register or constant longword address offset                                                   |
| in_lw_count    | Register or constant longword count                                                            |
| REQ_SIG        | Signal associated with this request                                                            |
| in_wakeup_sigs | Signal or signals to wake up on                                                                |
| Q_OPTION       | Queue options:                                                                                 |
|                | • no_option or: Default. Order queue                                                           |
|                | optimize_mem: Mem controller selects cycle to issue                                            |
|                | • priority: High priority                                                                      |

# 2.5.3.2 cls\_read\_le

## **Prototype:**

cls\_read\_le(out\_data, in\_cls\_addr, in\_addr\_offset, in\_lw\_count, REQ\_SIG, in\_wakeup\_sigs,
Q\_OPTION)

### **Description**:

Read from Cluster Local Scratch starting at address of first longword in little endian.

### **Example:**

cls\_read\_le(\$packet[2], addr, 0, LWCOUNT3, SIG\_CS, SIG\_CS, \_\_\_\_)



### **Note**

Temporary register usage: uses 0 to 2 registers if constant addr args > MAX\_IMMEDIATE, or register length.

## Table 2.68. cls\_read\_le parameters

| Name           | Description                                                                                                                  |
|----------------|------------------------------------------------------------------------------------------------------------------------------|
| out_data       | First transfer register of sequence to read to, array notation must be in xbuf array notation, index range 0-15 for NFP-32xx |
| in_cls_addr    | Register or constant base longword address                                                                                   |
| in_addr_offset | Register or constant longword address offset                                                                                 |
| in_lw_count    | Register or constant longword count                                                                                          |

© 2008-2014 Netronome 62 of 256

| Name           | Description                                         |
|----------------|-----------------------------------------------------|
| REQ_SIG        | Signal associated with this request                 |
| in_wakeup_sigs | Signal or signals to wake up on                     |
| Q_OPTION       | Queue options:                                      |
|                | • no_option or: Default. Order queue                |
|                | optimize_mem: Mem controller selects cycle to issue |
|                | • priority: High priority                           |

## 2.5.3.3 cls\_write

## **Prototype:**

cls\_write(in\_data, in\_cls\_addr, in\_addr\_offset, in\_lw\_count, REQ\_SIG, in\_wakeup\_sigs,
Q\_OPTION)

## **Description**:

Write to Cluster Local Scratch.

## **Example:**

cls\_write(\$packet[2], addr, 0, LWCOUNT3, SIG\_CS, SIG\_CS, \_\_\_)



### **Note**

Temporary register usage: Uses 0 to 2 registers if constant addr args > MAX\_IMMEDIATE, or register length.

### Table 2.69. cls\_write parameters

| Name           | Description                                                                                                                     |
|----------------|---------------------------------------------------------------------------------------------------------------------------------|
| in_data        | First transfer register of sequence to write from, array notation must be in xbuf array notation, index range 0-15 for NFP-32xx |
| in_cls_addr    | Register or constant base longword address                                                                                      |
| in_addr_offset | Register or constant longword address offset                                                                                    |
| in_lw_count    | Register or constant longword count                                                                                             |
| REQ_SIG        | Signal associated with this request                                                                                             |
| in_wakeup_sigs | Signal or signals to wake up on                                                                                                 |
| Q_OPTION       | Queue options:                                                                                                                  |
|                | no_option or: Default. Order queue                                                                                              |
|                | optimize_mem: Mem controller selects cycle to issue                                                                             |
|                | • priority: High priority                                                                                                       |

© 2008-2014 Netronome 63 of 256

# 2.5.3.4 cls\_write\_le

## **Prototype:**

cls\_write\_le(in\_data, in\_cls\_addr, in\_addr\_offset, in\_lw\_count, REQ\_SIG, in\_wakeup\_sigs,
Q\_OPTION)

#### **Description:**

Write to Cluster Local Scratch (Little Endian).

#### **Example:**

cls\_write\_le(\$packet[2], addr, 0, LWCOUNT3, SIG\_CS, SIG\_CS, \_\_\_)



#### Note

Temporary register usage: Uses 0 to 2 registers if constant addr args > MAX\_IMMEDIATE, or register length.

### Table 2.70. cls\_write\_le parameters

| Name           | Description                                                                                                                     |
|----------------|---------------------------------------------------------------------------------------------------------------------------------|
| in_data        | First transfer register of sequence to write from, array notation must be in xbuf array notation, index range 0-15 for NFP-32xx |
| in_cls_addr    | Register or constant base longword address                                                                                      |
| in_addr_offset | Register or constant longword address offset                                                                                    |
| in_lw_count    | Register or constant longword count                                                                                             |
| REQ_SIG        | Signal associated with this request                                                                                             |
| in_wakeup_sigs | Signal or signals to wake up on                                                                                                 |
| Q_OPTION       | Queue options:                                                                                                                  |
|                | • no_option or: Default. Order queue                                                                                            |
|                | optimize_mem: Mem controller selects cycle to issue                                                                             |
|                | • priority: High priority                                                                                                       |

# 2.5.3.5 cls\_write\_byte

#### **Prototype:**

cls\_write\_byte(in\_data, in\_cls\_addr, in\_addr\_offset, in\_lw\_count, REQ\_SIG, in\_wakeup\_sigs,
Q\_OPTION)

### **Description**:

Write bytes to Cluster Local Scratch.

© 2008-2014 Netronome 64 of 256

### **Example:**

cls\_write\_byte(\$packet, addr, 0, BYTE\_CNT, SIG\_CS, SIG\_CS, \_\_\_)



#### Note

Temporary register usage: Uses 0 to 2 registers if constant addr args > MAX\_IMMEDIATE, or register length.

### Table 2.71. cls\_write\_byte parameters

| Name           | Description                                                                                                                     |
|----------------|---------------------------------------------------------------------------------------------------------------------------------|
| in_data        | First transfer register of sequence to write from, array notation must be in xbuf array notation, index range 0-15 for NFP-32xx |
| in_cls_addr    | Register or constant base longword address                                                                                      |
| in_addr_offset | Register or constant longword address offset                                                                                    |
| in_lw_count    | Register or constant longword count                                                                                             |
| REQ_SIG        | Signal associated with this request                                                                                             |
| in_wakeup_sigs | Signal or signals to wake up on                                                                                                 |
| Q_OPTION       | Queue options:                                                                                                                  |
|                | • no_option or: Default. Order queue                                                                                            |
|                | optimize_mem: Mem controller selects cycle to issue                                                                             |
|                | • priority: High priority                                                                                                       |

# 2.5.3.6 cls\_write\_byte\_le

### **Prototype:**

cls\_write\_byte\_le(in\_data, in\_cls\_addr, in\_addr\_offset, in\_lw\_count, REQ\_SIG, in\_wakeup\_sigs, Q\_OPTION)

#### **Description:**

Write bytes to Cluster Local Scratch (Little Endian).

#### **Example:**

cls\_write\_byte\_le(\$packet, addr, 0, BYTE\_CNT, SIG\_CS, SIG\_CS, \_\_\_)



#### Note

Temporary register usage: Uses 0 to 2 registers if constant addr args > MAX\_IMMEDIATE, or register length.

© 2008-2014 Netronome 65 of 256

Table 2.72. cls\_write\_byte\_le parameters

| Name           | Description                                                                                                                     |
|----------------|---------------------------------------------------------------------------------------------------------------------------------|
| in_data        | First transfer register of sequence to write from, array notation must be in xbuf array notation, index range 0-15 for NFP-32xx |
| in_cls_addr    | Register or constant base longword address                                                                                      |
| in_addr_offset | Register or constant longword address offset                                                                                    |
| in_lw_count    | Register or constant longword count                                                                                             |
| REQ_SIG        | Signal associated with this request                                                                                             |
| in_wakeup_sigs | Signal or signals to wake up on                                                                                                 |
| Q_OPTION       | Queue options:                                                                                                                  |
|                | • no_option or: Default. Order queue                                                                                            |
|                | optimize_mem: Mem controller selects cycle to issue                                                                             |
|                | • priority: High priority                                                                                                       |

# 2.5.3.7 cls\_bits\_clr

## **Prototype**:

cls\_bits\_clr(in\_mask, in\_cls\_addr, in\_addr\_offset, REQ\_SIG, in\_wakeup\_sigs, Q\_OPTION)

### **Description**:

Clear in\_mask bits at Cluster Local Scratch longword location.

Table 2.73. cls\_bits\_clr parameters

| Name           | Description                                         |
|----------------|-----------------------------------------------------|
| in_mask        | Register or constant, mask of bits to set           |
| in_cls_addr    | Register or constant base longword address          |
| in_addr_offset | Register or constant longword address offset        |
| REQ_SIG        | Signal associated with this request                 |
| in_wakeup_sigs | Signal or signals to wake up on                     |
| Q_OPTION       | Queue options:                                      |
|                | • no_option or: Default. Order queue                |
|                | optimize_mem: Mem controller selects cycle to issue |
|                | • priority: High priority                           |

# 2.5.3.8 cls\_bits\_set

## **Prototype:**

© 2008-2014 Netronome 66 of 256

cls\_bits\_set(in\_mask, in\_cls\_addr, in\_addr\_offset, REQ\_SIG, in\_wakeup\_sigs, length,
Q\_OPTION)

#### **Description**:

Set in\_mask bits at Cluster Local Scratch longword location.

#### **Example:**

```
cls_bits_set(0x111, 0, bit_position, SIG_CS, SIG_CS, ___)
```

**Instruction Count:** 2 to 6

## Table 2.74. cls\_bits\_set parameters

| Name           | Description                                                |
|----------------|------------------------------------------------------------|
| in_mask        | Register or constant, mask of bits to set                  |
| in_cls_addr    | Register or constant base longword address                 |
| in_addr_offset | Register or constant longword address offset               |
| REQ_SIG        | Signal associated with this request                        |
| in_wakeup_sigs | Signal or signals to wake up on                            |
| length         | Word count, dual_sig_op (for 2-signal ops), or no_wd_count |
| Q_OPTION       | Queue options:                                             |
|                | • no_option or: Default. Order queue                       |
|                | optimize_mem: Mem controller selects cycle to issue        |
|                | • priority: High priority                                  |

# 2.5.3.9 cls\_bits\_test\_and\_clr

#### **Prototype:**

```
cls_bits_test_and_clr(out_data, in_mask, in_cls_addr, in_addr_offset, REQ_SIG, in_wakeup_sigs, length, Q_OPTION)
```

### **Description**:

Clear in\_mask bits at Cluster Local Scratch longword location.

Read contents of Cluster Local Scratch address prior to the write.

### Table 2.75. cls\_bits\_test\_and\_clr parameters

| Name     | Description                               |
|----------|-------------------------------------------|
| out_data | Read transfer register result             |
| in_mask  | Register or constant, mask of bits to set |

© 2008-2014 Netronome 67 of 256

| Name           | Description                                                |
|----------------|------------------------------------------------------------|
| in_cls_addr    | Register or constant base longword address                 |
| in_addr_offset | Register or constant longword address offset               |
| REQ_SIG        | Signal associated with this request                        |
| in_wakeup_sigs | Signal or signals to wake up on                            |
| length         | Word count, dual_sig_op (for 2-signal ops), or no_wd_count |
| Q_OPTION       | Queue options:                                             |
|                | • no_option or: Default. Order queue                       |
|                | optimize_mem: Mem controller selects cycle to issue        |
|                | • priority: High priority                                  |

# 2.5.3.10 cls\_bits\_test\_and\_set

## **Prototype:**

cls\_bits\_test\_and\_set(out\_data, in\_mask, in\_cls\_addr, in\_addr\_offset, REQ\_SIG, in\_wakeup\_sigs, length, Q\_OPTION)

## **Description**:

Set in\_mask bits at Cluster Local Scratch longword location.

Read contents of Cluster Local Scratch address prior to the write.

#### **Example:**

cls\_bits\_test\_and\_set(prev\_value, 0x1000, addr0, addr1, SIG\_CS, SIG\_CS, \_\_\_) // test/set bit 3

## Table 2.76. cls\_bits\_test\_and\_set parameters

| Name           | Description                                                |
|----------------|------------------------------------------------------------|
| out_data       | Read transfer register result                              |
| in_mask        | Register or constant, mask of bits to set                  |
| in_cls_addr    | Register or constant base longword address                 |
| in_addr_offset | Register or constant longword address offset               |
| REQ_SIG        | Signal associated with this request                        |
| in_wakeup_sigs | Signal or signals to wake up on                            |
| length         | Word count, dual_sig_op (for 2-signal ops), or no_wd_count |
| Q_OPTION       | Queue options:                                             |
|                | • no_option or: Default. Order queue                       |
|                | optimize_mem: Mem controller selects cycle to issue        |
|                | • priority: High priority                                  |

© 2008-2014 Netronome 68 of 256

## 2.5.3.11 cls\_incr

## **Prototype:**

cls\_incr(in\_cls\_addr, in\_addr\_offset)

### **Description**:

Increment 32-bit longword at Cluster Local Scratch location.

## Table 2.77. cls\_incr parameters

| Name           | Description                                  |
|----------------|----------------------------------------------|
| in_cls_addr    | Register or constant base longword address   |
| in_addr_offset | Register or constant longword address offset |

## 2.5.3.12 cls\_decr

#### **Prototype:**

cls\_decr(in\_cls\_addr, in\_addr\_offset)

## **Description**:

Decrement 32-bit longword at Cluster Local Scratch location.

#### Table 2.78. cls\_decr parameters

| Name           | Description                                  |
|----------------|----------------------------------------------|
| in_cls_addr    | Register or constant base longword address   |
| in_addr_offset | Register or constant longword address offset |

## 2.5.3.13 cls add

## **Prototype:**

cls\_add(in\_data, in\_cls\_addr, in\_addr\_offset, REQ\_SIG, in\_wakeup\_sigs, Q\_OPTION)

## **Description**:

Add in\_data to Cluster Local Scratch location.

#### Table 2.79. cls\_add parameters

| Name    | Description                                                                           |
|---------|---------------------------------------------------------------------------------------|
| in_data | Data to be added to Cluster Local Scratch location specified by in_cls_addr and       |
|         | in_addr_offset. in_data must be a write transfer register i.e. out transfer register. |

© 2008-2014 Netronome 69 of 256

| Name           | Description                                         |
|----------------|-----------------------------------------------------|
| in_cls_addr    | Register or constant base longword address          |
| in_addr_offset | Register or constant longword address offset        |
| REQ_SIG        | Signal associated with this request                 |
| in_wakeup_sigs | Signal or signals to wake up on                     |
| Q_OPTION       | Queue options:                                      |
|                | • no_option or: Default. Order queue                |
|                | optimize_mem: Mem controller selects cycle to issue |
|                | • priority: High priority                           |

# 2.5.3.14 cls\_sub

## **Prototype**:

cls\_sub(in\_data, in\_cls\_addr, in\_addr\_offset, REQ\_SIG, in\_wakeup\_sigs, Q\_OPTION)

## **Description**:

Subtract in\_data from Cluster Local Scratch location.



## **Note**

The sub instruction is not supported in HW, so subtract from 0 and add that number. in\_data can be GPR or a read transfer register.

### Table 2.80. cls\_sub parameters

| Name           | Description                                                                     |
|----------------|---------------------------------------------------------------------------------|
| in_data        | Data to be added to Cluster Local Scratch location specified by in_cls_addr and |
|                | in_addr_offset                                                                  |
| in_cls_addr    | Register or constant base longword address                                      |
| in_addr_offset | Register or constant longword address offset                                    |
| REQ_SIG        | Signal associated with this request                                             |
| in_wakeup_sigs | Signal or signals to wake up on                                                 |
| Q_OPTION       | Queue options:                                                                  |
|                | no_option or: Default. Order queue                                              |
|                | optimize_mem: Mem controller selects cycle to issue                             |
|                | • priority: High priority                                                       |

© 2008-2014 Netronome 70 of 256

## 2.5.3.15 cls\_swap

## **Prototype:**

cls\_swap(out\_data, in\_data, in\_cls\_addr, in\_addr\_offset, REQ\_SIG, in\_wakeup\_sigs, Q\_OPTION)

### **Description**:

Write in\_data to Cluster Local Scratch location.

Read contents of Cluster Local Scratch location prior to the operation to out\_data.

## **Example:**

cls\_swap(prev\_value, new\_value, addr0, addr1, SIG\_CS, SIG\_CS, \_\_\_) // test/set bit 3



## **Note**

If in\_data and out\_data is a pair of read/write transfer registers with the same name, eg. \$buffer0, the data from the \$buffer0.write will be written to (in\_cls\_addr + in\_addr\_offset). The data from (in\_cls\_addr + in\_addr\_offset) will be returned in \$buffer0.read.

### Table 2.81. cls\_swap parameters

| Name           | Description                                                                                                          |
|----------------|----------------------------------------------------------------------------------------------------------------------|
| out_data       | A read/write transfer registers pair. Result is returned in the read part of the read/write transfer registers pair. |
| in_data        | Can be constant, GPR, read transfer register                                                                         |
| in_cls_addr    | Register or constant base longword address                                                                           |
| in_addr_offset | Register or constant longword address offset                                                                         |
| REQ_SIG        | Signal associated with this request                                                                                  |
| in_wakeup_sigs | Signal or signals to wake up on                                                                                      |
| Q_OPTION       | Queue options:                                                                                                       |
|                | • no_option or: Default. Order queue                                                                                 |
|                | optimize_mem: Mem controller selects cycle to issue                                                                  |
|                | • priority: High priority                                                                                            |

# 2.5.3.16 cls\_test\_and\_add

### **Prototype:**

cls\_test\_and\_add(out\_data, in\_data, in\_cls\_addr, in\_addr\_offset, REQ\_SIG, in\_wakeup\_sigs,
Q\_OPTION)

© 2008-2014 Netronome 71 of 256

#### **Description:**

Read contents of Cluster Local Scratch location to out\_data then add in\_data to Cluster Local Scratch location contents.

## **Example:**

cls\_test\_and\_add(prev\_value, addend, addr0, addr1, SIG\_CS, SIG\_CS, \_\_\_) // test/set bit 3



#### Note

If in\_data and out\_data is a pair of read/write transfer registers with the same name, eg. \$buffer0, the data from the \$buffer0.write will be written to (in\_cls\_addr + in\_addr\_offset). The data from (in\_cls\_addr + in\_addr\_offset) will be returned in \$buffer0.read.

#### Table 2.82. cls\_test\_and\_add parameters

| Name           | Description                                                                                                          |
|----------------|----------------------------------------------------------------------------------------------------------------------|
| out_data       | A read/write transfer registers pair. Result is returned in the read part of the read/write transfer registers pair. |
| in_data        | Can be constant, GPR, read transfer register                                                                         |
| in_cls_addr    | Register or constant base longword address                                                                           |
| in_addr_offset | Register or constant longword address offset                                                                         |
| REQ_SIG        | Signal associated with this request                                                                                  |
| in_wakeup_sigs | Signal or signals to wake up on                                                                                      |
| Q_OPTION       | Queue options:                                                                                                       |
|                | • no_option or: Default. Order queue                                                                                 |
|                | optimize_mem: Mem controller selects cycle to issue                                                                  |
|                | • priority: High priority                                                                                            |

## 2.5.3.17 cls\_test\_and\_decr

#### **Prototype:**

 $\verb|cls_test_and_decr(out_data, in_cls_addr, in_addr_offset, REQ_SIG, in_wakeup\_sigs, Q_OPTION)| \\$ 

#### **Description**:

Read contents of Cluster Local Scratch location to out\_data then decrement Cluster Local Scratch location contents.

#### **Example:**

cls\_test\_and\_decr(prev\_value, addr0, addr1, SIG\_CS, SIG\_CS, \_\_\_\_) // test/set bit 3

© 2008-2014 Netronome 72 of 256



### Note

out\_data must be a transfer register.

### Table 2.83. cls\_test\_and\_decr parameters

| Name           | Description                                                                                                          |
|----------------|----------------------------------------------------------------------------------------------------------------------|
| out_data       | A read/write transfer registers pair. Result is returned in the read part of the read/write transfer registers pair. |
| in_cls_addr    | Register or constant base longword address                                                                           |
| in_addr_offset | Register or constant longword address offset                                                                         |
| REQ_SIG        | Signal associated with this request                                                                                  |
| in_wakeup_sigs | Signal or signals to wake up on                                                                                      |
| Q_OPTION       | Queue options:                                                                                                       |
|                | • no_option or: Default. Order queue                                                                                 |
|                | optimize_mem: Mem controller selects cycle to issue                                                                  |
|                | • priority: High priority                                                                                            |

## 2.5.3.18 cls\_test\_and\_incr

### **Prototype:**

cls\_test\_and\_incr(out\_data, in\_cls\_addr, in\_addr\_offset, REQ\_SIG, in\_wakeup\_sigs, Q\_OPTION)

### **Description**:

Read contents of Cluster Local Scratch location to out\_data then increment Cluster Local Scratch location contents.

#### **Example:**

cls\_test\_and\_incr(prev\_value, addr0, addr1, SIG\_CS, SIG\_CS, \_\_\_) // test/set bit 3



### Note

out\_data must be a transfer register.

### Table 2.84. cls\_test\_and\_incr parameters

| Name           | Description                                                                                                          |
|----------------|----------------------------------------------------------------------------------------------------------------------|
|                | A read/write transfer registers pair. Result is returned in the read part of the read/write transfer registers pair. |
| in_cls_addr    | Register or constant base longword address                                                                           |
| in_addr_offset | Register or constant longword address offset                                                                         |

© 2008-2014 Netronome 73 of 256

| Name           | Description                                         |
|----------------|-----------------------------------------------------|
| REQ_SIG        | Signal associated with this request                 |
| in_wakeup_sigs | Signal or signals to wake up on                     |
| Q_OPTION       | Queue options:                                      |
|                | • no_option or: Default. Order queue                |
|                | optimize_mem: Mem controller selects cycle to issue |
|                | • priority: High priority                           |

## 2.5.3.19 cls\_add64\_immed\_init

#### **Prototype:**

cls\_add64\_immed\_init(indirect\_ref\_reg)

### **Description**:

Initialize indirect reference register for use in IXP or NFP indirect reference format mode.

### Table 2.85. cls\_add64\_immed\_init parameters

| Name             | Description                             |
|------------------|-----------------------------------------|
| indirect_ref_reg | Indirect GPR register to be initialized |

# 2.5.3.20 cls\_add64\_immed

#### **Prototype:**

cls add64 immed(indirect ref reg, val, addr, offset)

#### **Description:**

Perform immediate add (64-bit) operation in Cluster Local Scratch.

Can add up to a 16-bit value in NFP indirect reference mode and up to 255 in IXP indirect reference format mode. For a 16-bit value, the two most significant bits control sign extension (bits 15 and 14). This means only 14-bits are used for an actual value.

Bits 15 and 14 of a 16-bit value, as from the *Netronome Network Flow Processor* 6000 *Programmers Reference*, CLS (Atomic Operations):

- 00 indicates no sign extension
- 01 indicates sign extend to 32-bit/64-bit value for 32/64-bit operation respectively
- 10 indicates no sign extension, but duplicate immediate in both high and low 32-bit words (applicable to 64-bit operations only)

© 2008-2014 Netronome 74 of 256

• 11 means sign extend to 32-bit word and duplicate value in both high and low 32-bit words (applicable to 64-bit operations only).

Using val in the range from 1 to 7 (atomic increment/add), saves one instruction.

Table 2.86. cls\_add64\_immed parameters

| Name             | Description                                                                                                                                                                                                        |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| indirect_ref_reg | Indirect GPR register initialized with cls_add64_immed_init. Not needed when val is a constant from 0 to 7.                                                                                                        |
| val              | Value to be added. Can be constant or GPR. If constant: Values in range 1-7, no indirect and save 1 instruction. Values in range 8-255, indirect reference. Values > 255 must be in GPR and use indrect reference. |
| addr             | Base Address in cluster scratch where immed add operation is done. Byte address. Constant or GPR.                                                                                                                  |
| offset           | Offset from base. Add is done at (addr + offset). Byte address.                                                                                                                                                    |

## 2.5.3.21 cls\_memset

### **Prototype:**

cls\_memset(in\_cls\_addr, in\_len, lw\_pattern, CHUNK\_SIZE)

### **Description**:

Fill a region of Cluster Local Scratch memory with a specified pattern.

Table 2.87. cls\_memset parameters

| Name        | Description                                                                                                                      |
|-------------|----------------------------------------------------------------------------------------------------------------------------------|
| in_cls_addr | Address to start memory fill from                                                                                                |
| in_len      | Number of bytes to set. Must be a multiple of CHUNK_SIZE.                                                                        |
| lw_pattern  | 32-bit pattern to fill memory region with                                                                                        |
| CHUNK_SIZE  | Chunk size, a multiple of 4 bytes from 4 to 128 in NFP indirect reference format mode and 4 to 64 otherwise. Must be a constant. |

# 2.6 Common and Global Constants

**Table 2.88. Common and Global Constants and Defines** 

| Defined            | Definition                                         |
|--------------------|----------------------------------------------------|
| MEM_WD_COUNT_MIN_1 | FALSE                                              |
|                    | Control word count passed to memory access macros. |

© 2008-2014 Netronome 75 of 256

| Defined            | Definition                                                                                                                |
|--------------------|---------------------------------------------------------------------------------------------------------------------------|
|                    | Values:                                                                                                                   |
|                    | • TRUE: All memory access macros must be called with word count = actual number of word - 1. This will help save 1 cycle. |
|                    | • FALSE: All memory access macros are called with word count = actual number of word                                      |
|                    | Note  Default is FALSE.                                                                                                   |
| MAY TMMEDIATE      | 0                                                                                                                         |
| MAX_IMMEDIATE      | 0xff                                                                                                                      |
| MAX_IMMEDIATE_ADDR | 0x7f                                                                                                                      |
|                    | Only 7 bits available in memory operations.                                                                               |
| SIG_NONE           | 0                                                                                                                         |
|                    | 0                                                                                                                         |
| optimize_mem       | unordered                                                                                                                 |
| FALSE              | 0                                                                                                                         |
| TRUE               | 1                                                                                                                         |
| UNALLOCATED        | 0                                                                                                                         |
| FREELISTO          | 0                                                                                                                         |
| FREELIST1          | 1                                                                                                                         |
| FREELIST2          | 2                                                                                                                         |
| FREELIST3          | 3                                                                                                                         |
| FREELIST4          | 4                                                                                                                         |
| FREELIST5          | 5                                                                                                                         |
| FREELIST6          | 6                                                                                                                         |
| FREELIST7          | 7                                                                                                                         |
| XFRINDEX0          | 0                                                                                                                         |
| XFRINDEX1          | 1                                                                                                                         |
| XFRINDEX2          | 2                                                                                                                         |
| XFRINDEX3          | 3                                                                                                                         |
| XFRINDEX4          | 4                                                                                                                         |
| XFRINDEX5          | 5                                                                                                                         |
| XFRINDEX6          | 6                                                                                                                         |
| XFRINDEX7          | 7                                                                                                                         |
| QWCOUNT1           | 1                                                                                                                         |

© 2008-2014 Netronome 76 of 256

| Defined     | Definition |
|-------------|------------|
| QWCOUNT2    | 2          |
| QWCOUNT3    | 3          |
| QWCOUNT4    | 4          |
| QWCOUNT5    | 5          |
| QWCOUNT6    | 6          |
| QWCOUNT7    | 7          |
| QWCOUNT8    | 8          |
| QWOFFSET0   | 0          |
| QWOFFSET1   | 1          |
| QWOFFSET2   | 2          |
| QWOFFSET3   | 3          |
| QWOFFSET4   | 4          |
| QWOFFSET5   | 5          |
| QWOFFSET6   | 6          |
| QWOFFSET7   | 7          |
| LWCOUNT1    | 1          |
| LWCOUNT2    | 2          |
| LWCOUNT3    | 3          |
| LWCOUNT4    | 4          |
| LWCOUNT5    | 5          |
| LWCOUNT6    | 6          |
| LWCOUNT7    | 7          |
| LWCOUNT8    | 8          |
| LWOFFSET0   | 0          |
| LWOFFSET1   | 1          |
| LWOFFSET2   | 2          |
| LWOFFSET3   | 3          |
| LWOFFSET4   | 4          |
| LWOFFSET5   | 5          |
| LWOFFSET6   | 6          |
| LWOFFSET7   | 7          |
| BYTEOFFSET0 | 0          |
| BYTEOFFSET1 | 1          |
| BYTEOFFSET2 | 2          |
| BYTEOFFSET3 | 3          |

© 2008-2014 Netronome 77 of 256

| Defined           | Definition |
|-------------------|------------|
| BYTEOFFSET4       | 4          |
| BYTEOFFSET5       | 5          |
| BYTEOFFSET6       | 6          |
| BYTEOFFSET7       | 7          |
| BYTEOFFSET8       | 8          |
| BYTEOFFSET9       | 9          |
| BYTEOFFSET10      | 10         |
| BYTEOFFSET11      | 11         |
| BYTEOFFSET12      | 12         |
| BYTEOFFSET13      | 13         |
| BYTEOFFSET14      | 14         |
| BYTEOFFSET15      | 15         |
| BYTEOFFSET16      | 16         |
| BYTEOFFSET17      | 17         |
| BYTEOFFSET18      | 18         |
| BYTEOFFSET19      | 19         |
| BYTEOFFSET20      | 20         |
| BYTEOFFSET21      | 21         |
| BYTEOFFSET22      | 22         |
| BYTEOFFSET23      | 23         |
| BYTEOFFSET24      | 24         |
| BYTEOFFSET25      | 25         |
| BYTEOFFSET26      | 26         |
| BYTEOFFSET27      | 27         |
| BYTEOFFSET28      | 28         |
| BYTEOFFSET29      | 29         |
| BYTEOFFSET30      | 30         |
| BYTEOFFSET31      | 31         |
| PKT_DENY          | 0x00       |
| PKT_PERMIT        | 0x01       |
| PKT_QUEUE_TO_CORE | 0x02       |
| OP_SIZE_8X24      | 1          |
| OP_SIZE_16X16     | 2          |
| OP_SIZE_16X32     | 3          |
| OP_SIZE_32X32     | 4          |

© 2008-2014 Netronome 78 of 256

| Defined                        | Definition |
|--------------------------------|------------|
| BYTES_PER_LW                   | 4          |
| BYTES_PER_QW                   | 8          |
| MU_LOCALITY_HIGH               | 0          |
| MU_LOCALITY_LOW                | 1          |
| MU_LOCALITY_DIRECT_ACCESS      | 2          |
| MU_LOCALITY_DISCARD_AFTER_READ | 3          |

# 2.7 CRYPTO IPSec Operation

# 2.7.1 CRYPTO IPSec Operation Macros

This file contains a set of crypto-library sequences. The sequences are designed to be compatible with Netronome's crypto\_support facility. They are implemented as 'compressed' sequences, which can be preloaded to the CIB memory space of the bulk core units at initialization time, and then invoked at run-time on a per-packet basis quickly and efficiently. These sequences implement encryption, decryption, and authentication that is intended to be usable on IPSec-formatted packets encapsulated with ESP or AH. The intention is for the ME to issue a single get\_core() at initialization time for a specific Crypto Dispatcher context, then keep that core 'pinned' to that context for the life of the program. The selection of which bulk core unit works on a particular packet is thus pushed to earlier in the process, when the packet is assigned to an ME. This technique has the advantage that it avoids the processing delay associated with executing the get\_core() and free\_core() instructions for every packet. It also eliminates some of the variables that need to be passed to the CIB code sequences, because each core can use a fixed set of pre-allocated buffers that are statically assigned to the ME's. The source file for these sequences is crypto\_lib\_ipsec.crypt The source file is processed by the Netronome utility ca2.py to generate the file crypto\_lib\_ipsec.uc, which is included in the microcode. The macros defined in crypto\_lib\_ipsec.uc are used by the macros in crypto\_lib.uc

Table 2.89. CRYPTO IPSec Operation and Defines

| Defined         | Definition                                                                          |
|-----------------|-------------------------------------------------------------------------------------|
| CRYPTO_NFP_MODE | 1                                                                                   |
|                 | SA layout for IPSec-oriented crypto instruction sequences.                          |
|                 | byte offset description                                                             |
|                 | 0x20-0x3F cipher key (up to 32 bytes) 0x40-0x7F authentication key (up to 64 bytes) |
|                 | Based constants: temp0 and temp1 - used for scratch space                           |

© 2008-2014 Netronome 79 of 256

## 2.7.3.1 crypto\_load\_ipsec\_enc

## **Prototype:**

crypto\_load\_ipsec\_enc(cr\_xfr, cr\_ctx, packet\_in, packet\_out, in\_len, seq\_ua,
auth\_only\_data, iv, auth\_length, hmac\_keylen, crypt\_select, crypt\_modes, sa\_cik, sa\_hmk,
sa\_hmr)

#### **Description:**

ipsec\_enc

Sequence to do IPSec-compatible encryption of a packet, using bulk cores that stay 'pinned'to a Dispatcher context. This allows operation without per-packet get\_core()/free\_core() ops. One context will do a get\_core() at init time and will hold onto that core for the life of the program.

In most cases, the 'output' (ciphertext) data is at the same address as the 'input' (plaintext) data. Only in the case of the 'aes-gcm null' ciphers the output is sent to a different buffer than the input.

Supports AES, DES, and NO encryption with MD5 or SHA-x HMAC auth.

#### Calling the sequence:

crypto\_load\_ipsec\_enc (packet\_in, packet\_out, in\_len, seq\_ua, auth\_only\_data, iv, auth\_length, hmac\_keylen, crypt\_select, crypt\_modes, sa\_cik, sa\_hmk, sa\_hmr)

Table 2.90. crypto\_load\_ipsec\_enc parameters

| Name           | Description                                        |
|----------------|----------------------------------------------------|
| cr_xfr         |                                                    |
| cr_ctx         |                                                    |
| packet_in      | crypto SRAM address of the start of plaintext      |
| packet_out     | crypto SRAM address of the start of ciphertext     |
| in_len         | length of data to be encrypted                     |
| seq_ua         | crypto SRAM addr of seq number 63:32 (unused)      |
| auth_only_data | crypto SRAM addr of auth-only data SPI/Seq         |
| iv             | crypto SRAM address of the Initialization Vector   |
| auth_length    | byte length of (SPI/Seq                            |
| hmac_keylen    | byte length of HMAC key, minus 1 (MD5-15, SHA1-19) |
| crypt_select   | config word 1, produced by crypto_setup_configs    |
| crypt_modes    | config word 2, produced by crypto_setup_configs    |
| sa_cik         | crypto SRAM address of start of cipher key         |
| sa_hmk         | crypto SRAM address of start of hash key           |

© 2008-2014 Netronome 80 of 256

| Name | Description                                                                                                |
|------|------------------------------------------------------------------------------------------------------------|
|      | crypto SRAM address of hash result Prepare transfer regs to load static (aka 'pinned') encryption sequence |

## 2.7.3.2 crypto\_gen\_ipsec\_enc

### **Prototype:**

crypto\_gen\_ipsec\_enc(core, desc)

#### **Description:**

Generate cmd sequence as constant data.

used in \_crypto\_library\_load\_dynamic in crypto\_lib.uc

### Table 2.91. crypto\_gen\_ipsec\_enc parameters

| Name | Description                                              |
|------|----------------------------------------------------------|
| core | crypto bulk core, 0 - 3 for NFP3XXX or 0 - 5 for NFP6XXX |
| desc | sequence 'descriptor', contains sram location address    |

## 2.7.3.3 crypto\_load\_ipsec\_enc\_esn

### **Prototype:**

crypto\_load\_ipsec\_enc\_esn(cr\_xfr, cr\_ctx, packet\_in, packet\_out, in\_len, seq\_ua,
auth\_only\_data, iv, auth\_length, hmac\_keylen, crypt\_select, crypt\_modes, sa\_cik, sa\_hmk,
sa\_hmr)

### **Description**:

ipsec\_enc\_esn

Similiar to ipsec\_enc, but works for a 64 bit sequence number (ESN)

Calling the sequence:

crypto\_load\_ipsec\_enc\_esn (packet\_in, packet\_out, in\_len, seq\_ua, auth\_only\_data, iv, auth\_length, hmac\_keylen, crypt\_select, crypt\_modes, sa\_cik, sa\_hmk, sa\_hmr)

### Table 2.92. crypto\_load\_ipsec\_enc\_esn parameters

| Name      | Description                                   |
|-----------|-----------------------------------------------|
| cr_xfr    |                                               |
| cr_ctx    |                                               |
| packet_in | crypto SRAM address of the start of plaintext |

© 2008-2014 Netronome 81 of 256

| Name           | Description                                                                                       |
|----------------|---------------------------------------------------------------------------------------------------|
| packet_out     | crypto SRAM address of the start of ciphertext                                                    |
| in_len         | length of data to be encrypted                                                                    |
| seq_ua         | crypto SRAM addr of seq number 63:32                                                              |
| auth_only_data | crypto SRAM addr of auth-only data SPI/Seq                                                        |
| iv             | crypto SRAM addr of the Initialization Vector                                                     |
| auth_length    | byte length of (SPI/Seq                                                                           |
| hmac_keylen    | byte length of HMAC key, minus 1 (MD5-15, SHA1-19)                                                |
| crypt_select   | config word 1, produced by crypto_setup_configs                                                   |
| crypt_modes    | config word 2, produced by crypto_setup_configs                                                   |
| sa_cik         | crypto SRAM address of start of cipher key                                                        |
| sa_hmk         | crypto SRAM address of start of hash key                                                          |
| sa_hmr         | crypto SRAM address of hash result Prepare transfer regs to load static (aka 'pinned') encryption |
|                | sequence                                                                                          |

# 2.7.3.4 crypto\_gen\_ipsec\_enc\_esn

## **Prototype:**

crypto\_gen\_ipsec\_enc\_esn(core, desc)

### **Description**:

Generate cmd sequence as constant data.

used in \_crypto\_library\_load\_dynamic in crypto\_lib.uc

## Table 2.93. crypto\_gen\_ipsec\_enc\_esn parameters

| Name | Description                                              |
|------|----------------------------------------------------------|
| core | crypto bulk core, 0 - 3 for NFP3XXX or 0 - 5 for NFP6XXX |
| desc | sequence 'descriptor', contains sram location address    |

# 2.7.3.5 crypto\_load\_ipsec\_enc\_strt

### **Prototype:**

crypto\_load\_ipsec\_enc\_strt(cr\_xfr, cr\_ctx, packet\_in, packet\_out, in\_len, seq\_ua,
auth\_only\_data, iv, auth\_length, hmac\_keylen, crypt\_select, crypt\_modes, sa\_cik, sa\_hmk,
sa\_hmr)

### **Description**:

ipsec\_enc\_strt

© 2008-2014 Netronome 82 of 256

Similar to ipsec\_enc but used to begin an encryption sequence that will span multiple buffers, needed to handle jumbo packets.

### Calling the sequence:

load\_ipsec\_enc\_strt (packet\_in, packet\_out, in\_len, seq\_ua auth\_only\_data, iv, auth\_length, hmac\_keylen, crypt\_select, crypt\_modes, sa\_cik, sa\_hmk, sa\_hmr)

Table 2.94. crypto\_load\_ipsec\_enc\_strt parameters

| Name           | Description                                                                                                |
|----------------|------------------------------------------------------------------------------------------------------------|
| cr_xfr         |                                                                                                            |
| cr_ctx         |                                                                                                            |
| packet_in      | crypto SRAM address of the start of plaintext                                                              |
| packet_out     | crypto SRAM address of the start of ciphertext                                                             |
| in_len         | length of data to be encrypted                                                                             |
| seq_ua         | crypto SRAM addr of seq number 63:32 (unused)                                                              |
| auth_only_data | crypto SRAM addr of auth-only data SPI/Seq                                                                 |
| iv             | crypto SRAM address of the Initialization Vector                                                           |
| auth_length    | byte length of (SPI/Seq                                                                                    |
| hmac_keylen    | byte length of HMAC key, minus 1                                                                           |
| crypt_select   | config word 1, produced by crypto_setup_configs                                                            |
| crypt_modes    | config word 2, produced by crypto_setup_configs                                                            |
| sa_cik         | crypto SRAM address of start of cipher key                                                                 |
| sa_hmk         | crypto SRAM address of start of hash key                                                                   |
| sa_hmr         | crypto SRAM address of hash result Prepare transfer regs to load static (aka 'pinned') encryption sequence |

# 2.7.3.6 crypto\_gen\_ipsec\_enc\_strt

### **Prototype:**

crypto\_gen\_ipsec\_enc\_strt(core, desc)

### **Description**:

Generate cmd sequence as constant data.

used in \_crypto\_library\_load\_dynamic in crypto\_lib.uc

Table 2.95. crypto\_gen\_ipsec\_enc\_strt parameters

| Name | Description                                              |
|------|----------------------------------------------------------|
| core | crypto bulk core, 0 - 3 for NFP3XXX or 0 - 5 for NFP6XXX |

© 2008-2014 Netronome 83 of 256

| Name | Description                                           |
|------|-------------------------------------------------------|
| desc | sequence 'descriptor', contains sram location address |

# 2.7.3.7 crypto\_load\_ipsec\_enc\_cont

### **Prototype:**

crypto\_load\_ipsec\_enc\_cont(cr\_xfr, cr\_ctx, packet\_in, packet\_out, in\_len)

### **Description**:

ipsec\_enc\_cont

Used after ipsec\_enc\_strt to continue encrypting a packet on a buffer of data following the first part of the packet. Needed to handle jumbo packets. Setup and ending condition from prior use of ipsec\_enc\_strt is required prior to invoking this sequence. In particular, the keys, config registers, hash address, etc. must remain intact when this sequence is started.

Calling the sequence:

load\_ipsec\_enc\_cont (packet\_in, packet\_out, in\_len)

Table 2.96. crypto\_load\_ipsec\_enc\_cont parameters

| Name       | Description                                                                                       |
|------------|---------------------------------------------------------------------------------------------------|
| cr_xfr     |                                                                                                   |
| cr_ctx     |                                                                                                   |
| packet_in  | crypto SRAM address of the start of plaintext                                                     |
| packet_out | crypto SRAM address of the start of ciphertext                                                    |
| in_len     | length of data to encrypt Prepare transfer regs to load static (aka 'pinned') encryption sequence |

# 2.7.3.8 crypto\_gen\_ipsec\_enc\_cont

#### **Prototype:**

crypto\_gen\_ipsec\_enc\_cont(core, desc)

#### **Description:**

Generate cmd sequence as constant data.

used in \_crypto\_library\_load\_dynamic in crypto\_lib.uc

Table 2.97. crypto\_gen\_ipsec\_enc\_cont parameters

| Name | Description                                              |
|------|----------------------------------------------------------|
| core | crypto bulk core, 0 - 3 for NFP3XXX or 0 - 5 for NFP6XXX |

© 2008-2014 Netronome 84 of 256

| Name | Description                                           |
|------|-------------------------------------------------------|
| desc | sequence 'descriptor', contains sram location address |

# 2.7.3.9 crypto\_load\_ipsec\_enc\_end

#### **Prototype:**

```
crypto_load_ipsec_enc_end(cr_xfr, cr_ctx, packet_in, packet_out, in_len, seq_ua,
hmac_keyadr, hmac_keylen, hmac_resadr)
```

#### **Description:**

ipsec\_enc\_end

Used after ipsec\_enc\_strt and possibly ipsec\_enc\_cont, to complete encrypting a packet on the last buffer of data of the packet. Needed to handle jumbo packets. Setup and ending condition from prior use of ipsec\_enc\_strt is required prior to invoking this sequence. In particular, the keys, config registers, etc. must remain intact when this sequence is started.

The hash key address and result address for the packet must be specified as parameters to this sequence.

The key address should be equal to the sram location for the hash key corresponding to the buffer (A,B,C or D) used for the 1st part of the packet. For e.g., if the 1st part of the packet was loaded using buffer A, the hash key address would be the same as provided in the variable sa\_hmk provided with ipsec\_enc\_strt since that is where the key was loaded.

The hash key result address should be the sram address corresponding to the hash result for the buffer being used when this macro ( ipsec\_enc\_end ) is invoked. For example, if using buffer B, the hash result address would be equal to location of the hash for buffer B.

Calling the sequence:

crypto\_load\_ipsec\_enc\_end (packet\_in, packet\_out, in\_len, seq\_ua, hmac\_resadr, hmac\_keyadr, hmac\_keylen)

Table 2.98. crypto\_load\_ipsec\_enc\_end parameters

| Name        | Description                                      |
|-------------|--------------------------------------------------|
| cr_xfr      |                                                  |
| cr_ctx      |                                                  |
| packet_in   | crypto SRAM address of the start of plaintext    |
| packet_out  | crypto SRAM address of the start of ciphertext   |
| in_len      | length of data to be encrypted                   |
| seq_ua      | crypto SRAM addr of seq number 63:32 (unused)    |
| hmac_keyadr | crypto SRAM address of the start of the HMAC key |
| hmac_keylen | byte length of HMAC key, minus 1                 |

© 2008-2014 Netronome 85 of 256

| Name        | Description                                                                                 |
|-------------|---------------------------------------------------------------------------------------------|
| hmac_resadr | crypto SRAM address of the HMAC key calculation result Prepare transfer regs to load static |
|             | (aka 'pinned') encryption sequence                                                          |

## 2.7.3.10 crypto\_gen\_ipsec\_enc\_end

### **Prototype:**

crypto\_gen\_ipsec\_enc\_end(core, desc)

#### **Description**:

Generate cmd sequence as constant data.

used in \_crypto\_library\_load\_dynamic in crypto\_lib.uc

## Table 2.99. crypto\_gen\_ipsec\_enc\_end parameters

| Name | Description                                              |
|------|----------------------------------------------------------|
| core | crypto bulk core, 0 - 3 for NFP3XXX or 0 - 5 for NFP6XXX |
| desc | sequence 'descriptor', contains sram location address    |

# 2.7.3.11 crypto\_load\_ipsec\_enc\_end\_esn

### **Prototype:**

crypto\_load\_ipsec\_enc\_end\_esn(cr\_xfr, cr\_ctx, packet\_in, packet\_out, in\_len, seq\_ua,
hmac\_keyadr, hmac\_keylen, hmac\_resadr)

#### **Description:**

ipsec\_enc\_end\_esn

Similiar to ipsec\_enc\_end, but works for a 64 bit sequence number (ESN)

Calling the sequence:

crypto\_load\_ipsec\_enc\_end\_esn (packet\_in, packet\_out, in\_len, seq\_ua, hmac\_keyadr, hmac\_keylen, hmac\_resadr)

#### Table 2.100. crypto\_load\_ipsec\_enc\_end\_esn parameters

| Name       | Description                                    |
|------------|------------------------------------------------|
| cr_xfr     |                                                |
| cr_ctx     |                                                |
| packet_in  | crypto SRAM address of the start of plaintext  |
| packet_out | crypto SRAM address of the start of ciphertext |
| in_len     | length of data to be encrypted                 |

© 2008-2014 Netronome 86 of 256

| Name        | Description                                                                                                                    |
|-------------|--------------------------------------------------------------------------------------------------------------------------------|
| seq_ua      | crypto SRAM addr of seq number 63:32                                                                                           |
| hmac_keyadr | crypto SRAM address of the start of the HMAC key                                                                               |
| hmac_keylen | byte length of HMAC key, minus 1                                                                                               |
|             | crypto SRAM address of the HMAC key calculation result Prepare transfer regs to load static (aka 'pinned') encryption sequence |

## 2.7.3.12 crypto\_gen\_ipsec\_enc\_end\_esn

#### **Prototype:**

crypto\_gen\_ipsec\_enc\_end\_esn(core, desc)

#### **Description:**

Generate cmd sequence as constant data.

used in \_crypto\_library\_load\_dynamic in crypto\_lib.uc

Table 2.101. crypto\_gen\_ipsec\_enc\_end\_esn parameters

| Name | Description                                              |  |
|------|----------------------------------------------------------|--|
| core | crypto bulk core, 0 - 3 for NFP3XXX or 0 - 5 for NFP6XXX |  |
| desc | sequence 'descriptor', contains sram location address    |  |

# 2.7.3.13 crypto\_load\_ipsec\_enc\_aesgcm

#### **Prototype:**

crypto\_load\_ipsec\_enc\_aesgcm(cr\_xfr, cr\_ctx, packet\_in, packet\_out, in\_len, length\_vector,
auth\_only\_data, iv\_constr, auth\_length, zero, crypt\_select, crypt\_modes, sa\_cik, sa\_hmk,
sa\_hmr)

#### **Description:**

ipsec\_enc\_aesgcm

Similar to ipsec\_enc, but used for gcm (galois counter mode) for aes-gcm-esp, esn or non-esn and either regular or 'null' (rfc4543) encrypt. In the normal case, the ciphertext is written to the same location as the plaintext. In the 'null' case, the ciphertext is written to another buffer instead; this buffer is used as a temp area and is not transmitted.

N.B. this 'encrypt' sequence should actually not be used for 'null' (rfc4543) because we have to do crypt\_hash parallel ( not serial ) because the hash is to be generated using the original plaintext. Use the 'decrypt' sequence instead for encrypt; it is the same except for serial/parallel

This sequence is used for encrypt. Decrypt is the same except for the use of crypt serial for encrypt and crypt parallel for decrypt

© 2008-2014 Netronome 87 of 256

### Calling the sequence:

load\_ipsec\_enc\_aesgcm (packet\_in, packet\_out, in\_len, length\_vector, auth\_only\_data, iv\_constr, auth\_length, zero, crypt\_select, crypt\_modes, sa\_cik, sa\_hmk, sa\_hmr)

Table 2.102. crypto\_load\_ipsec\_enc\_aesgcm parameters

| Name           | Description                                                                                                |
|----------------|------------------------------------------------------------------------------------------------------------|
| cr_xfr         |                                                                                                            |
| cr_ctx         |                                                                                                            |
| packet_in      | crypto SRAM address of the start of plaintext                                                              |
| packet_out     | crypto SRAM address of the start of ciphertext                                                             |
| in_len         | length of data to be encrypted                                                                             |
| length_vector  | crypto SRAM address of the len(A)  len(C) vector                                                           |
| auth_only_data | crypto SRAM addr of SPI + SeqLo + SeqHi(esn)                                                               |
| iv_constr      | crypto SRAM address of constructed Initialization Vector / Counter initialization                          |
| auth_length    | byte length of (SPI + SeqLo + seqHi(esn)), minus 1                                                         |
| zero           | crypto SRAM address of a 16B block of zeros                                                                |
| crypt_select   | config word 1, produced by crypto_setup_configs                                                            |
| crypt_modes    | config word 2, produced by crypto_setup_configs                                                            |
| sa_cik         | crypto SRAM address of start of cipher key                                                                 |
| sa_hmk         | crypto SRAM address of start of hash key(unused)                                                           |
| sa_hmr         | crypto SRAM address of hash result Prepare transfer regs to load static (aka 'pinned') encryption sequence |

# 2.7.3.14 crypto\_gen\_ipsec\_enc\_aesgcm

### **Prototype:**

crypto\_gen\_ipsec\_enc\_aesgcm(core, desc)

### **Description**:

Generate cmd sequence as constant data.

used in \_crypto\_library\_load\_dynamic in crypto\_lib.uc

Table 2.103. crypto\_gen\_ipsec\_enc\_aesgcm parameters

| Name | Description                                              |  |
|------|----------------------------------------------------------|--|
| core | crypto bulk core, 0 - 3 for NFP3XXX or 0 - 5 for NFP6XXX |  |
| desc | sequence 'descriptor', contains sram location address    |  |

© 2008-2014 Netronome 88 of 256

## 2.7.3.15 crypto\_load\_ipsec\_enc\_aesgcm\_strt

## **Prototype:**

crypto\_load\_ipsec\_enc\_aesgcm\_strt(cr\_xfr, cr\_ctx, packet\_in, packet\_out, in\_len,
length\_vector, auth\_only\_data, iv\_constr, auth\_length, zero, crypt\_select, crypt\_modes,
sa\_cik, sa\_hmk, sa\_hmr)

#### **Description:**

ipsec\_enc\_aesgcm\_strt

Similar to ipsec\_enc\_aesgcm, but used to begin an encryption sequence that will span multiple buffers, needed to handle jumbo packets. Calling the sequence:

load\_ipsec\_enc\_aesgcm\_strt (packet\_in, packet\_out, in\_len, length\_vector, auth\_only\_data, iv\_constr, auth\_length, zero, crypt\_select, crypt\_modes, sa\_cik, sa\_hmk, sa\_hmr)

Table 2.104. crypto\_load\_ipsec\_enc\_aesgcm\_strt parameters

| Name           | Description                                                                                                |
|----------------|------------------------------------------------------------------------------------------------------------|
| cr_xfr         |                                                                                                            |
| cr_ctx         |                                                                                                            |
| packet_in      | crypto SRAM address of the start of plaintext                                                              |
| packet_out     | crypto SRAM address of the start of ciphertext                                                             |
| in_len         | length of data to be encrypted                                                                             |
| length_vector  | crypto SRAM address of the len(A)  len(C) vector                                                           |
| auth_only_data | crypto SRAM addr of SPI + SeqLo + SeqHi(esn)                                                               |
| iv_constr      | crypto SRAM address of constructed Initialization Vector / Counter initialization                          |
| auth_length    | byte length of (SPI + SeqLo + seqHi(esn)), minus 1                                                         |
| zero           | crypto SRAM address of a 16B block of zeros                                                                |
| crypt_select   | config word 1, produced by crypto_setup_configs                                                            |
| crypt_modes    | config word 2, produced by crypto_setup_configs                                                            |
| sa_cik         | crypto SRAM address of start of cipher key                                                                 |
| sa_hmk         | crypto SRAM address of start of hash key                                                                   |
| sa_hmr         | crypto SRAM address of hash result Prepare transfer regs to load static (aka 'pinned') encryption sequence |

# 2.7.3.16 crypto\_gen\_ipsec\_enc\_aesgcm\_strt

### **Prototype:**

crypto\_gen\_ipsec\_enc\_aesgcm\_strt(core, desc)

© 2008-2014 Netronome 89 of 256

#### **Description:**

Generate cmd sequence as constant data.

used in \_crypto\_library\_load\_dynamic in crypto\_lib.uc

Table 2.105. crypto\_gen\_ipsec\_enc\_aesgcm\_strt parameters

| Name | Description                                              |  |
|------|----------------------------------------------------------|--|
| core | crypto bulk core, 0 - 3 for NFP3XXX or 0 - 5 for NFP6XXX |  |
| desc | sequence 'descriptor', contains sram location address    |  |

# 2.7.3.17 crypto\_load\_ipsec\_enc\_aesgcm\_strt\_save

### **Prototype:**

crypto\_load\_ipsec\_enc\_aesgcm\_strt\_save(cr\_xfr, cr\_ctx, packet\_in, packet\_out, in\_len,
length\_vector, auth\_only\_data, iv\_constr, auth\_length, zero, crypt\_select, crypt\_modes,
sa\_cik, sa\_hmk, sa\_hmr)

#### **Description:**

ipsec\_enc\_aesgcm\_strt\_save

Similiar to ipsec\_enc\_aesgcm\_strt, but saves the hash state at the end. Used when need to restart crypt operation on next buffer in packet, when the crypt engine is interrupted between buffers

load\_ipsec\_enc\_aesgcm\_strt\_save (packet\_in, packet\_out, in\_len, length\_vector, auth\_only\_data, iv\_constr, auth\_length, zero, crypt\_select, crypt\_modes, sa\_cik, sa\_hmk, sa\_hmr)

Table 2.106. crypto\_load\_ipsec\_enc\_aesgcm\_strt\_save parameters

| Name           | Description                                                                       |
|----------------|-----------------------------------------------------------------------------------|
| cr_xfr         |                                                                                   |
| cr_ctx         |                                                                                   |
| packet_in      | crypto SRAM address of the start of plaintext                                     |
| packet_out     | crypto SRAM address of the start of ciphertext                                    |
| in_len         | length of data to be encrypted                                                    |
| length_vector  | crypto SRAM address of the len(A)  len(C) vector                                  |
| auth_only_data | crypto SRAM addr of SPI + SeqLo + SeqHi(esn)                                      |
| iv_constr      | crypto SRAM address of constructed Initialization Vector / Counter initialization |
| auth_length    | byte length of (SPI + SeqLo + seqHi(esn)), minus 1                                |
| zero           | crypto SRAM address of a 16B block of zeros                                       |
| crypt_select   | config word 1, produced by crypto_setup_configs                                   |
| crypt_modes    | config word 2, produced by crypto_setup_configs                                   |

© 2008-2014 Netronome 90 of 256

| Name   | Description                                                                                                |
|--------|------------------------------------------------------------------------------------------------------------|
| sa_cik | crypto SRAM address of start of cipher key                                                                 |
| sa_hmk | crypto SRAM address of start of hash key                                                                   |
|        | crypto SRAM address of hash result Prepare transfer regs to load static (aka 'pinned') encryption sequence |

## 2.7.3.18 crypto\_gen\_ipsec\_enc\_aesgcm\_strt\_save

#### **Prototype:**

crypto\_gen\_ipsec\_enc\_aesgcm\_strt\_save(core, desc)

#### **Description:**

Generate cmd sequence as constant data.

used in \_crypto\_library\_load\_dynamic in crypto\_lib.uc

Table 2.107. crypto\_gen\_ipsec\_enc\_aesgcm\_strt\_save parameters

| Name | Description                                              |
|------|----------------------------------------------------------|
| core | crypto bulk core, 0 - 3 for NFP3XXX or 0 - 5 for NFP6XXX |
| desc | sequence 'descriptor', contains sram location address    |

# 2.7.3.19 crypto\_load\_ipsec\_enc\_aesgcm\_end

#### **Prototype:**

crypto\_load\_ipsec\_enc\_aesgcm\_end(cr\_xfr, cr\_ctx, packet\_in, packet\_out, in\_len,
length\_vector, unused1, unused2, hash\_resadr)

#### **Description:**

ipsec enc aesgcm end

Used after ipsec\_enc\_aesgcm\_strt and possibly ipsec\_enc\_cont, to complete encrypting a packet on the last buffer of data of the packet. Needed to handle jumbo packets. Setup and ending condition from prior use of ipsec\_enc\_aesgcm\_strt is required prior to invoking this sequence. In particular, the keys, config registers, etc. must remain intact when this sequence is started.

The hash result address should be the sram address corresponding to the hash result for the buffer being used when this macro ( <code>ipsec\_enc\_aesgcm\_end</code> ) is invoked. For example, if using buffer B, the hash result address would be equal to the hash result address for buffer B

#### Calling the sequence:

crypto\_load\_ipsec\_enc\_aesgcm\_end (packet\_in, packet\_out, in\_len, length\_vector, unused, unused, hash\_resadr)

© 2008-2014 Netronome 91 of 256

Table 2.108. crypto\_load\_ipsec\_enc\_aesgcm\_end parameters

| Name          | Description                                                                                                                |
|---------------|----------------------------------------------------------------------------------------------------------------------------|
| cr_xfr        |                                                                                                                            |
| cr_ctx        |                                                                                                                            |
| packet_in     | crypto SRAM address of the start of plaintext                                                                              |
| packet_out    | crypto SRAM address of the start of ciphertext                                                                             |
| in_len        | length of data to be encrypted                                                                                             |
| length_vector | crypto SRAM address of the len(A)  len(C) vector                                                                           |
| unused1       |                                                                                                                            |
| unused2       |                                                                                                                            |
| hash_resadr   | crypto SRAM address of the hash calculation result Prepare transfer regs to load static (aka 'pinned') encryption sequence |

## 2.7.3.20 crypto\_gen\_ipsec\_enc\_aesgcm\_end

### **Prototype:**

crypto\_gen\_ipsec\_enc\_aesgcm\_end(core, desc)

### **Description**:

Generate cmd sequence as constant data.

used in \_crypto\_library\_load\_dynamic in crypto\_lib.uc

Table 2.109. crypto\_gen\_ipsec\_enc\_aesgcm\_end parameters

| Name | Description                                              |
|------|----------------------------------------------------------|
| core | crypto bulk core, 0 - 3 for NFP3XXX or 0 - 5 for NFP6XXX |
| desc | sequence 'descriptor', contains sram location address    |

# 2.7.3.21 crypto\_load\_ipsec\_enc\_aesgcm\_end\_restore

#### **Prototype:**

crypto\_load\_ipsec\_enc\_aesgcm\_end\_restore(cr\_xfr, cr\_ctx, packet\_in, packet\_out, in\_len,
length\_vector, crypt\_modes, iv\_constr\_prv, sa\_cik, sa\_hmr\_prev, sa\_hmr)

#### **Description**:

ipsec\_enc\_aesgcm\_end\_restore

Similar to ipsec\_enc\_aesgcm\_end, but restores the crypto state before doing the crypt operation. This sequence would be used when the processing of a packet was split across different crypto engines, or if a single crypto engine that is processing a packet using multiple buffers was interrupted in between the multiple buffers.

© 2008-2014 Netronome 92 of 256

### Calling the sequence:

load\_ipsec\_enc\_aesgcm\_end\_restore (packet\_in, packet\_out, in\_len, length\_vector, crypt\_modes, iv\_constr\_prev, sa\_cik, sa\_hmr\_prev, sa\_hmr)

Table 2.110. crypto\_load\_ipsec\_enc\_aesgcm\_end\_restore parameters

| Name          | Description                                                                                                |
|---------------|------------------------------------------------------------------------------------------------------------|
| cr_xfr        |                                                                                                            |
| cr_ctx        |                                                                                                            |
| packet_in     | crypto SRAM address of the start of plaintext                                                              |
| packet_out    | crypto SRAM address of the start of ciphertext                                                             |
| in_len        | length of data to be encrypted                                                                             |
| length_vector | crypto SRAM address of the len(A)  len(C) vector                                                           |
| crypt_modes   | config word 2, produced by crypto_setup_configs                                                            |
| iv_constr_prv | iv constr with counter value at end of previous buffer                                                     |
| sa_cik        | crypto SRAM address of start of cipher key                                                                 |
| sa_hmr_prev   | crypto SRAM address of hash result from previous buffer                                                    |
| sa_hmr        | crypto SRAM address of hash result Prepare transfer regs to load static (aka 'pinned') encryption sequence |

# 2.7.3.22 crypto\_gen\_ipsec\_enc\_aesgcm\_end\_restore

### **Prototype:**

crypto\_gen\_ipsec\_enc\_aesgcm\_end\_restore(core, desc)

### **Description**:

Generate cmd sequence as constant data.

used in \_crypto\_library\_load\_dynamic in crypto\_lib.uc

Table 2.111. crypto\_gen\_ipsec\_enc\_aesgcm\_end\_restore parameters

| Name | Description                                              |  |
|------|----------------------------------------------------------|--|
| core | crypto bulk core, 0 - 3 for NFP3XXX or 0 - 5 for NFP6XXX |  |
| desc | sequence 'descriptor', contains sram location address    |  |

# 2.7.3.23 crypto\_load\_ipsec\_dec

### **Prototype**:

© 2008-2014 Netronome 93 of 256

crypto\_load\_ipsec\_dec(cr\_xfr, cr\_ctx, packet\_in, packet\_out, in\_len, seq\_ua,
auth\_only\_data, iv, auth\_length, hmac\_keylen, crypt\_select, crypt\_modes, sa\_cik, sa\_hmk,
sa\_hmr)

#### **Description**:

ipsec\_dec

Sequence to do IPSec-compatible decryption of a packet, using bulk cores that stay 'pinned'to a Dispatcher context. This allows operation without per-packet get\_core()/free\_core() ops. One context will do a get\_core() at init time and will hold onto that core for the life of the program.

In most cases, the 'output' (plaintext) data is at the same address as the 'input' (ciphertext) data. Only in the case of the 'aes-gcm null' ciphers the output is sent to a different buffer than the input.

Supports AES, DES, and NO encryption with MD5 or SHA-x HMAC auth.

#### Calling the sequence:

crypto\_load\_ipsec\_dec (packet\_in, packet\_out, in\_len, seq\_ua, auth\_only\_data, iv, auth\_length, hmac\_keylen, crypt\_select, crypt\_modes, sa\_cik, sa\_hmk, sa\_hmr)

Table 2.112. crypto\_load\_ipsec\_dec parameters

| Name           | Description                                                                                                |
|----------------|------------------------------------------------------------------------------------------------------------|
| cr_xfr         |                                                                                                            |
| cr_ctx         |                                                                                                            |
| packet_in      | crypto SRAM address of the start of ciphertext                                                             |
| packet_out     | crypto SRAM address of the start of plaintext                                                              |
| in_len         | length of data to be decrypted                                                                             |
| seq_ua         | crypto SRAM addr of seq number 63:32 (unused)                                                              |
| auth_only_data | crypto SRAM addr of auth-only data SPI/Seq                                                                 |
| iv             | crypto SRAM address of the Initialization Vector                                                           |
| auth_length    | byte length of (SPI/Seq                                                                                    |
| hmac_keylen    | byte length of HMAC key, minus 1 (MD5-15, SHA1-19)                                                         |
| crypt_select   | config word 1, produced by crypto_setup_configs                                                            |
| crypt_modes    | config word 2, produced by crypto_setup_configs                                                            |
| sa_cik         | crypto SRAM address of start of cipher key                                                                 |
| sa_hmk         | crypto SRAM address of start of hash key                                                                   |
| sa_hmr         | crypto SRAM address of hash result Prepare transfer regs to load static (aka 'pinned') encryption sequence |

© 2008-2014 Netronome 94 of 256

# 2.7.3.24 crypto\_gen\_ipsec\_dec

### **Prototype:**

crypto\_gen\_ipsec\_dec(core, desc)

## **Description**:

Generate cmd sequence as constant data.

used in \_crypto\_library\_load\_dynamic in crypto\_lib.uc

Table 2.113. crypto\_gen\_ipsec\_dec parameters

| Name | Description                                              |
|------|----------------------------------------------------------|
| core | crypto bulk core, 0 - 3 for NFP3XXX or 0 - 5 for NFP6XXX |
| desc | sequence 'descriptor', contains sram location address    |

# 2.7.3.25 crypto\_load\_ipsec\_dec\_esn

### **Prototype:**

crypto\_load\_ipsec\_dec\_esn(cr\_xfr, cr\_ctx, packet\_in, packet\_out, in\_len, seq\_ua,
auth\_only\_data, iv, auth\_length, hmac\_keylen, crypt\_select, crypt\_modes, sa\_cik, sa\_hmk,
sa\_hmr)

#### **Description:**

ipsec\_dec\_esn

Similiar to ipsec\_dec, but works for a 64 bit sequence number (ESN)

Calling the sequence:

crypto\_load\_ipsec\_dec\_esn (packet\_in, packet\_out, in\_len, seq\_ua, auth\_only\_data, iv, auth\_length, hmac\_keylen, crypt\_select, crypt\_modes, sa\_cik, sa\_hmk, sa\_hmr)

Table 2.114. crypto\_load\_ipsec\_dec\_esn parameters

| Name           | Description                                    |
|----------------|------------------------------------------------|
| cr_xfr         |                                                |
| cr_ctx         |                                                |
| packet_in      | crypto SRAM address of the start of ciphertext |
| packet_out     | crypto SRAM address of the start of plaintext  |
| in_len         | length of data to be decrypted                 |
| seq_ua         | crypto SRAM addr of seq number 63:32           |
| auth_only_data | crypto SRAM addr of auth-only data SPI/Seq     |

© 2008-2014 Netronome 95 of 256

| Name         | Description                                                                                                |
|--------------|------------------------------------------------------------------------------------------------------------|
| iv           | crypto SRAM addr of the Initialization Vector                                                              |
| auth_length  | byte length of (SPI/Seq                                                                                    |
| hmac_keylen  | byte length of HMAC key, minus 1 (MD5-15, SHA1-19)                                                         |
| crypt_select | config word 1, produced by crypto_setup_configs                                                            |
| crypt_modes  | config word 2, produced by crypto_setup_configs                                                            |
| sa_cik       | crypto SRAM address of start of cipher key                                                                 |
| sa_hmk       | crypto SRAM address of start of hash key                                                                   |
| sa_hmr       | crypto SRAM address of hash result Prepare transfer regs to load static (aka 'pinned') encryption sequence |

## 2.7.3.26 crypto\_gen\_ipsec\_dec\_esn

#### **Prototype:**

crypto\_gen\_ipsec\_dec\_esn(core, desc)

### **Description**:

Generate cmd sequence as constant data.

used in \_crypto\_library\_load\_dynamic in crypto\_lib.uc

## Table 2.115. crypto\_gen\_ipsec\_dec\_esn parameters

| Name | Description                                              |  |
|------|----------------------------------------------------------|--|
| core | crypto bulk core, 0 - 3 for NFP3XXX or 0 - 5 for NFP6XXX |  |
| desc | sequence 'descriptor', contains sram location address    |  |

# 2.7.3.27 crypto\_load\_ipsec\_dec\_strt

#### **Prototype:**

crypto\_load\_ipsec\_dec\_strt(cr\_xfr, cr\_ctx, packet\_in, packet\_out, in\_len, seq\_ua,
auth\_only\_data, iv, auth\_length, hmac\_keylen, crypt\_select, crypt\_modes, sa\_cik, sa\_hmk,
sa\_hmr)

#### **Description:**

ipsec\_dec\_strt

Similar to ipsec\_dec but used to begin a decryption sequence that will span multiple buffers, needed to handle jumbo packets.

Calling the sequence:

© 2008-2014 Netronome 96 of 256

crypto\_load\_ipsec\_dec\_strt (packet\_in, packet\_out, in\_len, seq\_ua, auth\_only\_data, iv, auth\_length, hmac\_keylen, crypt\_select, crypt\_modes, sa\_cik, sa\_hmk, sa\_hmr)

Table 2.116. crypto\_load\_ipsec\_dec\_strt parameters

| Name           | Description                                                                                                |
|----------------|------------------------------------------------------------------------------------------------------------|
| cr_xfr         |                                                                                                            |
| cr_ctx         |                                                                                                            |
| packet_in      | crypto SRAM address of the start of plaintext                                                              |
| packet_out     | crypto SRAM address of the start of ciphertext                                                             |
| in_len         | length of data to be decrypted                                                                             |
| seq_ua         | crypto SRAM addr of seq number 63:32 (unused)                                                              |
| auth_only_data | crypto SRAM addr of auth-only data SPI/Seq                                                                 |
| iv             | crypto SRAM address of the Initialization Vector                                                           |
| auth_length    | byte length of (SPI/Seq                                                                                    |
| hmac_keylen    | byte length of HMAC key, minus 1                                                                           |
| crypt_select   | config word 1, produced by crypto_setup_configs                                                            |
| crypt_modes    | config word 2, produced by crypto_setup_configs                                                            |
| sa_cik         | crypto SRAM address of start of cipher key                                                                 |
| sa_hmk         | crypto SRAM address of start of hash key                                                                   |
| sa_hmr         | crypto SRAM address of hash result Prepare transfer regs to load static (aka 'pinned') encryption sequence |

# 2.7.3.28 crypto\_gen\_ipsec\_dec\_strt

### **Prototype**:

crypto\_gen\_ipsec\_dec\_strt(core, desc)

### **Description**:

Generate cmd sequence as constant data.

used in \_crypto\_library\_load\_dynamic in crypto\_lib.uc

Table 2.117. crypto\_gen\_ipsec\_dec\_strt parameters

| Name | Description                                              |  |
|------|----------------------------------------------------------|--|
| core | crypto bulk core, 0 - 3 for NFP3XXX or 0 - 5 for NFP6XXX |  |
| desc | sequence 'descriptor', contains sram location address    |  |

© 2008-2014 Netronome 97 of 256

## 2.7.3.29 crypto\_load\_ipsec\_dec\_strt\_nw

## **Prototype:**

crypto\_load\_ipsec\_dec\_strt\_nw(cr\_xfr, cr\_ctx, packet\_in, packet\_out, in\_len, seq\_ua,
auth\_only\_data, iv, auth\_length, hmac\_keylen, crypt\_select, crypt\_modes, sa\_cik, sa\_hmk,
sa\_hmr)

#### **Description:**

ipsec\_dec\_strt\_nw

Similar to ipsec\_dec\_strt, used to begin a decryption sequence that will span multiple buffers, when no cipher is selected, so the sequence does not have a wait for the cipher to complete. used to handle jumbo packets.

Calling the sequence:

crypto\_load\_ipsec\_dec\_strt\_nw (packet\_in, packet\_out, in\_len, seq\_ua, auth\_only\_data, iv, auth\_length, hmac\_keylen, crypt\_select, crypt\_modes, sa\_cik, sa\_hmk, sa\_hmr)

Table 2.118. crypto\_load\_ipsec\_dec\_strt\_nw parameters

| Name           | Description                                                                                                |
|----------------|------------------------------------------------------------------------------------------------------------|
| cr_xfr         |                                                                                                            |
| cr_ctx         |                                                                                                            |
| packet_in      | crypto SRAM address of the start of plaintext                                                              |
| packet_out     | crypto SRAM address of the start of ciphertext                                                             |
| in_len         | length of data to be decrypted                                                                             |
| seq_ua         | crypto SRAM addr of seq number 63:32 (unused)                                                              |
| auth_only_data | crypto SRAM addr of auth-only data SPI/Seq                                                                 |
| iv             | crypto SRAM address of the Initialization Vector                                                           |
| auth_length    | byte length of (SPI/Seq                                                                                    |
| hmac_keylen    | byte length of HMAC key, minus 1                                                                           |
| crypt_select   | config word 1, produced by crypto_setup_configs                                                            |
| crypt_modes    | config word 2, produced by crypto_setup_configs                                                            |
| sa_cik         | crypto SRAM address of start of cipher key                                                                 |
| sa_hmk         | crypto SRAM address of start of hash key                                                                   |
| sa_hmr         | crypto SRAM address of hash result Prepare transfer regs to load static (aka 'pinned') encryption sequence |

# 2.7.3.30 crypto\_gen\_ipsec\_dec\_strt\_nw

#### **Prototype:**

© 2008-2014 Netronome 98 of 256

crypto\_gen\_ipsec\_dec\_strt\_nw(core, desc)

#### **Description:**

Generate cmd sequence as constant data.

used in \_crypto\_library\_load\_dynamic in crypto\_lib.uc

Table 2.119. crypto\_gen\_ipsec\_dec\_strt\_nw parameters

| Name | Description                                              |
|------|----------------------------------------------------------|
| core | crypto bulk core, 0 - 3 for NFP3XXX or 0 - 5 for NFP6XXX |
| desc | sequence 'descriptor', contains sram location address    |

## 2.7.3.31 crypto\_load\_ipsec\_dec\_cont

## **Prototype:**

crypto\_load\_ipsec\_dec\_cont(cr\_xfr, cr\_ctx, packet\_in, packet\_out, in\_len)

#### **Description**:

ipsec\_dec\_cont

Used after ipsec\_dec\_strt to continue decrypting a packet on a buffer of data following the first part of the packet. Needed to handle jumbo packets. Setup and ending condition from prior use of ipsec\_dec\_strt is required prior to invoking this sequence. In particular, the keys, config registers, hash address, etc. must remain intact when this sequence is started.

Calling the sequence:

load\_ipsec\_dec\_cont (packet\_in, packet\_out, in\_len)

Table 2.120. crypto\_load\_ipsec\_dec\_cont parameters

| Name       | Description                                                                                       |
|------------|---------------------------------------------------------------------------------------------------|
| cr_xfr     |                                                                                                   |
| cr_ctx     |                                                                                                   |
| packet_in  | crypto SRAM address of the start of ciphertext                                                    |
| packet_out | crypto SRAM address of the start of plaintext                                                     |
| in_len     | length of data to decrypt Prepare transfer regs to load static (aka 'pinned') encryption sequence |

# 2.7.3.32 crypto\_gen\_ipsec\_dec\_cont

### **Prototype:**

crypto\_gen\_ipsec\_dec\_cont(core, desc)

© 2008-2014 Netronome 99 of 256

### **Description**:

Generate cmd sequence as constant data.

used in \_crypto\_library\_load\_dynamic in crypto\_lib.uc

Table 2.121. crypto\_gen\_ipsec\_dec\_cont parameters

| Name | Description                                              |
|------|----------------------------------------------------------|
| core | crypto bulk core, 0 - 3 for NFP3XXX or 0 - 5 for NFP6XXX |
| desc | sequence 'descriptor', contains sram location address    |

# 2.7.3.33 crypto\_load\_ipsec\_dec\_cont\_nw

### **Prototype:**

crypto\_load\_ipsec\_dec\_cont\_nw(cr\_xfr, cr\_ctx, packet\_in, packet\_out, in\_len)

### **Description**:

ipsec\_dec\_cont\_nw

Similar to ipsec\_dec\_cont, but used on no cipher selection, so it does not have a wait for cipher. used for jumbo packets

Calling the sequence:

load\_ipsec\_dec\_cont\_nw (packet\_in, packet\_out, in\_len)

Table 2.122. crypto\_load\_ipsec\_dec\_cont\_nw parameters

| Name       | Description                                                                                       |
|------------|---------------------------------------------------------------------------------------------------|
| cr_xfr     |                                                                                                   |
| cr_ctx     |                                                                                                   |
| packet_in  | crypto SRAM address of the start of ciphertext                                                    |
| packet_out | crypto SRAM address of the start of plaintext                                                     |
| in_len     | length of data to decrypt Prepare transfer regs to load static (aka 'pinned') encryption sequence |

# 2.7.3.34 crypto\_gen\_ipsec\_dec\_cont\_nw

#### **Prototype:**

crypto\_gen\_ipsec\_dec\_cont\_nw(core, desc)

#### **Description:**

Generate cmd sequence as constant data.

© 2008-2014 Netronome 100 of 256

used in \_crypto\_library\_load\_dynamic in crypto\_lib.uc

Table 2.123. crypto\_gen\_ipsec\_dec\_cont\_nw parameters

| Name | Description                                              |
|------|----------------------------------------------------------|
| core | crypto bulk core, 0 - 3 for NFP3XXX or 0 - 5 for NFP6XXX |
| desc | sequence 'descriptor', contains sram location address    |

# 2.7.3.35 crypto\_load\_ipsec\_dec\_end

#### **Prototype:**

```
crypto_load_ipsec_dec_end(cr_xfr, cr_ctx, packet_in, packet_out, in_len, seq_ua,
hmac_keyadr, hmac_keylen, hmac_resadr)
```

#### **Description:**

ipsec\_dec\_end

Used after ipsec\_dec\_strt and possibly ipsec\_dec\_cont, to complete decrypting a packet on the last buffer of data of the packet. Needed to handle jumbo packets. Setup and ending condition from prior use of ipsec\_dec\_strt is required prior to invoking this sequence. In particular, the keys, config registers, etc. must remain intact when this sequence is started.

The hash key address and result address for the packet must be specified as parameters to this sequence.

The key address should be equal to the sram location for the hash key corresponding to the buffer (A,B,C or D) used for the 1st part of the packet. For e.g., if the 1st part of the packet was loaded using buffer A, the hash key address would be the same as provided in the variable sa\_hmk provided with ipsec\_dec\_strt since that is where the key was loaded.

The hash key result address should be the sram address corresponding to the hash result for the buffer being used when this macro ( ipsec\_dec\_end ) is invoked. For example, if using buffer B, the hash result address would be equal to location of the hash for buffer B.

Calling the sequence:

crypto\_load\_ipsec\_dec\_end (packet\_in, packet\_out, in\_len, seq\_ua, hmac\_keyadr, hmac\_keylen, hmac\_resadr)

Table 2.124. crypto\_load\_ipsec\_dec\_end parameters

| Name       | Description                                    |
|------------|------------------------------------------------|
| cr_xfr     |                                                |
| cr_ctx     |                                                |
| packet_in  | crypto SRAM address of the start of ciphertext |
| packet_out | crypto SRAM address of the start of plaintext  |
| in_len     | length of data to be decrypted                 |

© 2008-2014 Netronome 101 of 256

| Name        | Description                                                                                                                    |
|-------------|--------------------------------------------------------------------------------------------------------------------------------|
| seq_ua      | crypto SRAM addr of seq number 63:32 (unused)                                                                                  |
| hmac_keyadr | crypto SRAM address of the start of the HMAC key                                                                               |
| hmac_keylen | byte length of HMAC key, minus 1                                                                                               |
| hmac_resadr | crypto SRAM address of the HMAC key calculation result Prepare transfer regs to load static (aka 'pinned') encryption sequence |

# 2.7.3.36 crypto\_gen\_ipsec\_dec\_end

### **Prototype:**

crypto\_gen\_ipsec\_dec\_end(core, desc)

#### **Description**:

Generate cmd sequence as constant data.

used in \_crypto\_library\_load\_dynamic in crypto\_lib.uc

### Table 2.125. crypto\_gen\_ipsec\_dec\_end parameters

| Name | Description                                              |
|------|----------------------------------------------------------|
| core | crypto bulk core, 0 - 3 for NFP3XXX or 0 - 5 for NFP6XXX |
| desc | sequence 'descriptor', contains sram location address    |

# 2.7.3.37 crypto\_load\_ipsec\_dec\_end\_esn

### **Prototype:**

crypto\_load\_ipsec\_dec\_end\_esn(cr\_xfr, cr\_ctx, packet\_in, packet\_out, in\_len, seq\_ua,
hmac\_keyadr, hmac\_keylen, hmac\_resadr)

### **Description**:

ipsec\_dec\_end\_esn

Similiar to ipsec\_dec\_end, but works for a 64 bit sequence number (ESN)

Calling the sequence:

crypto\_load\_ipsec\_dec\_end\_esn (packet\_in, packet\_out, in\_len, seq\_ua, hmac\_keyadr, hmac\_keylen, hmac\_resadr)

#### Table 2.126. crypto\_load\_ipsec\_dec\_end\_esn parameters

| Name   | Description |
|--------|-------------|
| cr_xfr |             |
| cr_ctx |             |

© 2008-2014 Netronome 102 of 256

| Name        | Description                                                                                                                    |
|-------------|--------------------------------------------------------------------------------------------------------------------------------|
| packet_in   | crypto SRAM address of the start of cipherext                                                                                  |
| packet_out  | crypto SRAM address of the start of plaintext                                                                                  |
| in_len      | length of data to be decrypted                                                                                                 |
| seq_ua      | crypto SRAM addr of seq number 63:32                                                                                           |
| hmac_keyadr | crypto SRAM address of the start of the HMAC key                                                                               |
| hmac_keylen | byte length of HMAC key, minus 1                                                                                               |
| hmac_resadr | crypto SRAM address of the HMAC key calculation result Prepare transfer regs to load static (aka 'pinned') encryption sequence |

# 2.7.3.38 crypto\_gen\_ipsec\_dec\_end\_esn

### **Prototype:**

crypto\_gen\_ipsec\_dec\_end\_esn(core, desc)

#### **Description**:

Generate cmd sequence as constant data.

used in \_crypto\_library\_load\_dynamic in crypto\_lib.uc

Table 2.127. crypto\_gen\_ipsec\_dec\_end\_esn parameters

| Name | Description                                              |
|------|----------------------------------------------------------|
| core | crypto bulk core, 0 - 3 for NFP3XXX or 0 - 5 for NFP6XXX |
| desc | sequence 'descriptor', contains sram location address    |

# 2.7.3.39 crypto\_load\_ipsec\_dec\_aesgcm

#### **Prototype:**

crypto\_load\_ipsec\_dec\_aesgcm(cr\_xfr, cr\_ctx, packet\_in, packet\_out, in\_len, length\_vector, auth\_only\_data, iv\_constr, auth\_length, zero, crypt\_select, crypt\_modes, sa\_cik, sa\_hmk, sa\_hmr)

#### **Description:**

ipsec\_dec\_aesgcm

Similar to ipsec\_dec, but used for gcm (galois counter mode) for aes-gcm-esp, esn or non-esn and either regular or 'null' (rfc4543) decrypt. In the normal case, the plaintext is written to the same location as the ciphertext. In the 'null' case, the plaintext is written to another buffer instead; this buffer is used as a temp area and is not transmitted.

Calling the sequence:

© 2008-2014 Netronome 103 of 256

load\_ipsec\_dec\_aesgcm (packet\_in, packet\_out, in\_len, length\_vector, auth\_only\_data, iv\_constr, auth\_length, zero, crypt\_select, crypt\_modes, sa\_cik, sa\_hmr)

Table 2.128. crypto\_load\_ipsec\_dec\_aesgcm parameters

| Name           | Description                                                                                                |
|----------------|------------------------------------------------------------------------------------------------------------|
| cr_xfr         |                                                                                                            |
| cr_ctx         |                                                                                                            |
| packet_in      | crypto SRAM address of the start of ciphertext                                                             |
| packet_out     | crypto SRAM address of the start of plaintext                                                              |
| in_len         | length of data to be decrypted                                                                             |
| length_vector  | crypto SRAM address of the len(A)  len(C) vector                                                           |
| auth_only_data | crypto SRAM addr of SPI + SeqLo + SeqHi(esn)                                                               |
| iv_constr      | crypto SRAM address of constructed Initialization Vector / Counter initialization                          |
| auth_length    | byte length of (SPI + SeqLo + seqHi(esn)), minus 1                                                         |
| zero           | crypto SRAM address of a 16B block of zeros                                                                |
| crypt_select   | config word 1, produced by crypto_setup_configs                                                            |
| crypt_modes    | config word 2, produced by crypto_setup_configs                                                            |
| sa_cik         | crypto SRAM address of start of cipher key                                                                 |
| sa_hmk         | crypto SRAM address of start of hash key (unused)                                                          |
| sa_hmr         | crypto SRAM address of hash result Prepare transfer regs to load static (aka 'pinned') encryption sequence |

# 2.7.3.40 crypto\_gen\_ipsec\_dec\_aesgcm

### **Prototype:**

crypto\_gen\_ipsec\_dec\_aesgcm(core, desc)

### **Description**:

Generate cmd sequence as constant data.

used in \_crypto\_library\_load\_dynamic in crypto\_lib.uc

Table 2.129. crypto\_gen\_ipsec\_dec\_aesgcm parameters

| Name | Description                                              |
|------|----------------------------------------------------------|
| core | crypto bulk core, 0 - 3 for NFP3XXX or 0 - 5 for NFP6XXX |
| desc | sequence 'descriptor', contains sram location address    |

© 2008-2014 Netronome 104 of 256

## 2.7.3.41 crypto\_load\_ipsec\_dec\_aesgcm\_strt

## **Prototype:**

crypto\_load\_ipsec\_dec\_aesgcm\_strt(cr\_xfr, cr\_ctx, packet\_in, packet\_out, in\_len,
length\_vector, auth\_only\_data, iv\_constr, auth\_length, zero, crypt\_select, crypt\_modes,
sa\_cik, sa\_hmk, sa\_hmr)

#### **Description:**

ipsec\_dec\_aesgcm\_strt

Similar to ipsec\_dec\_aesgcm, but used to begin an encryption sequence that will span multiple buffers, needed to handle jumbo packets.

Calling the sequence:

load\_ipsec\_dec\_aesgcm\_strt (packet\_in, packet\_out, in\_len, length\_vector, auth\_only\_data, iv\_constr, auth\_length, zero, crypt\_select, crypt\_modes, sa\_cik, sa\_hmr)

Table 2.130. crypto\_load\_ipsec\_dec\_aesgcm\_strt parameters

| Name           | Description                                                                                       |
|----------------|---------------------------------------------------------------------------------------------------|
| cr_xfr         |                                                                                                   |
| cr_ctx         |                                                                                                   |
| packet_in      | crypto SRAM address of the start of ciphertext                                                    |
| packet_out     | crypto SRAM address of the start of plaintext                                                     |
| in_len         | length of data to be decrypted                                                                    |
| length_vector  | crypto SRAM address of the len(A)  len(C) vector                                                  |
| auth_only_data | crypto SRAM addr of data SPI + SeqLo + SeqHi(esn)                                                 |
| iv_constr      | crypto SRAM address of constructed Initialization Vector / Counter initialization                 |
| auth_length    | byte length of (SPI + SeqLo + seqHi(esn)), minus 1                                                |
| zero           | crypto SRAM address of a 16B block of zeros                                                       |
| crypt_select   | config word 1, produced by crypto_setup_configs                                                   |
| crypt_modes    | config word 2, produced by crypto_setup_configs                                                   |
| sa_cik         | crypto SRAM address of start of cipher key                                                        |
| sa_hmk         | crypto SRAM address of start of hash key (unused)                                                 |
| sa_hmr         | crypto SRAM address of hash result Prepare transfer regs to load static (aka 'pinned') encryption |
|                | sequence                                                                                          |

# 2.7.3.42 crypto\_gen\_ipsec\_dec\_aesgcm\_strt

#### **Prototype:**

© 2008-2014 Netronome 105 of 256

crypto\_gen\_ipsec\_dec\_aesgcm\_strt(core, desc)

#### **Description**:

Generate cmd sequence as constant data.

used in \_crypto\_library\_load\_dynamic in crypto\_lib.uc

Table 2.131. crypto\_gen\_ipsec\_dec\_aesgcm\_strt parameters

| Name | Description                                              |
|------|----------------------------------------------------------|
| core | crypto bulk core, 0 - 3 for NFP3XXX or 0 - 5 for NFP6XXX |
| desc | sequence 'descriptor', contains sram location address    |

## 2.7.3.43 crypto\_load\_ipsec\_dec\_aesgcm\_end

### **Prototype:**

crypto\_load\_ipsec\_dec\_aesgcm\_end(cr\_xfr, cr\_ctx, packet\_in, packet\_out, in\_len,
length\_vector, unused1, unused2, hash\_resadr)

#### **Description**:

ipsec\_dec\_aesgcm\_end

Used after ipsec\_dec\_aesgcm\_strt and possibly ipsec\_dec\_cont, to complete decrypting a packet on the last buffer of data of the packet. Needed to handle jumbo packets. Setup and ending condition from prior use of ipsec\_dec\_aesgcm\_strt is required prior to invoking this sequence. In particular, the keys, config registers, etc. must remain intact when this sequence is started.

The hash result address should be the sram address corresponding to the hash result for the buffer being used when this macro ( <code>ipsec\_dec\_aesgcm\_end</code> ) is invoked. For example, if using buffer B, the hash result address would be equal to the hash result address for buffer B

Calling the sequence:

crypto\_load\_ipsec\_dec\_aesgcm\_end (packet\_in, packet\_out, in\_len, seq\_ua, unused, length\_vector, hash\_resadr)

Table 2.132. crypto\_load\_ipsec\_dec\_aesgcm\_end parameters

| Name          | Description                                      |
|---------------|--------------------------------------------------|
| cr_xfr        |                                                  |
| cr_ctx        |                                                  |
| packet_in     | crypto SRAM address of the start of plaintext    |
| packet_out    | crypto SRAM address of the start of ciphertext   |
| in_len        | length of data to be decrypted                   |
| length_vector | crypto SRAM address of the len(A)  len(C) vector |

© 2008-2014 Netronome 106 of 256

| Name        | Description                                                                                                                |
|-------------|----------------------------------------------------------------------------------------------------------------------------|
| unused1     | unused                                                                                                                     |
| unused2     | unused                                                                                                                     |
| hash_resadr | crypto SRAM address of the hash calculation result Prepare transfer regs to load static (aka 'pinned') encryption sequence |

# 2.7.3.44 crypto\_gen\_ipsec\_dec\_aesgcm\_end

#### **Prototype:**

crypto\_gen\_ipsec\_dec\_aesgcm\_end(core, desc)

#### **Description:**

Generate cmd sequence as constant data.

used in \_crypto\_library\_load\_dynamic in crypto\_lib.uc

Table 2.133. crypto\_gen\_ipsec\_dec\_aesgcm\_end parameters

| Name | Description                                              |
|------|----------------------------------------------------------|
| core | crypto bulk core, 0 - 3 for NFP3XXX or 0 - 5 for NFP6XXX |
| desc | sequence 'descriptor', contains sram location address    |

# 2.7.3.45 crypto\_gen\_compr\_constants

#### **Prototype:**

crypto\_gen\_compr\_constants(base0)



#### Note

No description!

# 2.8 CRYPTO Operation

# 2.8.1 CRYPTO Operation Macros

This file contains a set of crypto-library sequences. The sequences are designed to be compatible with Netronome's crypto\_support facility. They are implemented as 'compressed' sequences, which can be preloaded to the CIB memory space of the bulk core units at initialization time, and then invoked at run-time on a per-packet basis quickly and efficiently. The source file for these sequences is crypto\_lib\_kestrel.crypt. The source file is processed by the

© 2008-2014 Netronome 107 of 256

Netronome utility ca2.py to generate the file crypto\_lib\_kestrel.uc, which is included in the microcode. The macros defined in crypto\_lib\_kestrel.uc are used by the macros in crypto\_lib.uc.

### **Table 2.134. CRYPTO Operation and Defines**

| Defined         | Definition |
|-----------------|------------|
| CRYPTO_NFP_MODE | 1          |

## 2.8.3.1 crypto\_load\_generic\_chacha20

### **Prototype:**

crypto\_load\_generic\_chacha20(cr\_xfr, cr\_ctx, payload, in\_len, iv\_constr)



#### **Note**

No description!

## 2.8.3.2 crypto\_gen\_generic\_chacha20

#### **Prototype:**

crypto\_gen\_generic\_chacha20(core, desc)



#### **Note**

No description!

# 2.8.3.3 crypto\_load\_generic\_poly1305

### **Prototype:**

crypto\_load\_generic\_poly1305(cr\_xfr, cr\_ctx, payload, in\_len)



### **Note**

No description!

# 2.8.3.4 crypto\_gen\_generic\_poly1305

### **Prototype:**

crypto\_gen\_generic\_poly1305(core, desc)

© 2008-2014 Netronome 108 of 256



## **Note**

No description!

# 2.8.3.5 crypto\_gen\_compr\_constants

### **Prototype:**

crypto\_gen\_compr\_constants(base0, base1)



# **Note**

No description!

# 2.9 CRYPTO Threads Operation

# 2.9.1 CRYPTO Threads Operation Macros

Crypto logic support macros facilitating encryption, decryption, and authentication of ip packets. Utilizes multiple crypto cores, packet buffers, and threads in a pipeline in order to maximize utilization of crypto hardware and maximize packet processing performance. Intended to be run on one or more microengines in the crypto island of NFP6000

**Table 2.135. CRYPTO Threads Operation and Defines** 

| Defined              | Definition |
|----------------------|------------|
| CRYPTO_NUM_THREADS   | 6          |
| CRYPTO_START_CTX     | 0          |
| CRYPTO_RING_CTM      | 0          |
| CRYPTO_RING_EMU0     | 1          |
| CRYPTO_RING_EMU1     | 2          |
| CRYPTO_RING_EMU2     | 3          |
| CRYPTO_RING_WQ       | 4          |
| CRYPTO_RING_SIZE_128 | 128        |
| CRYPTO_RING_SIZE_256 | 256        |
| CRYPTO_RING_SIZE_512 | 512        |
| CRYPTO_RING_SIZE_1K  | 1024       |
| CRYPTO_RING_SIZE_2K  | 2048       |

© 2008-2014 Netronome 109 of 256

| Defined                    | Definition                                    |
|----------------------------|-----------------------------------------------|
| CRYPTO_RING_SIZE_4K        | 4096                                          |
| CRYPTO_RING_SIZE_8K        | 8192                                          |
| CRYPTO_RING_SIZE_16K       | 16384                                         |
| CRYPTO_RING_SIZE_32K       | 32768                                         |
| CRYPTO_RING_SIZE_64K       | 64536                                         |
| OVERRIDE_RESPONSE_RING     | 0                                             |
| RESPONSE_RING_TYPE         | CRYPTO_RING_CTM                               |
| BUF_RING_TYPE              | CRYPTO_RING_CTM                               |
| BUF_RING_NUM               | 0                                             |
| BUF_RING_ISLAND_ID         | 0x00                                          |
| INIT_FLAG_USE_ALLOC_MEM    | 1                                             |
| INIT_FLAG_ALLOCATION_FIXED | 0                                             |
| INIT_FLAG_ADDR             | 0x00000020                                    |
| INIT_FLAG_ISLAND           | 12                                            |
| INIT_FLAG_ISLAND_TXT       | i12                                           |
| ENABLE_SA_FLUSH            | 0                                             |
| REQ_RING_TYPE              | CRYPTO_RING_CTM                               |
| REQ_RING_USE_ONE_EMU_RING  | 0                                             |
| REQ_RING_SIZE              | CRYPTO_RING_SIZE_2K                           |
| REQ_RING_NUM               | 0                                             |
| REQ_RING_USE_ALLOC_MEM     | 1                                             |
| REQ_RING_ALLOCATION_FIXED  | 0                                             |
| REQ_RING_ADDR              | 0x0000000                                     |
| REQ_RING_DESC_ADDR         | (REQ_RING_ADDR + (REQ_RING_SIZE << 2))        |
| _SIZE                      | (REQ_RING_SIZE << 2)                          |
| OVERRIDE_UPDATE_COUNTER    | 0                                             |
| COUNTER_MEMORY_TYPE_CLS    | 0                                             |
| COUNTER_MEMORY_TYPE_CTM    | 1                                             |
| COUNTER_MEMORY_TYPE        | COUNTER_MEMORY_TYPE_CLS                       |
| COUNTER_USE_ALLOC_MEM      | 1                                             |
| COUNTER_ALLOCATION_FIXED   | 0                                             |
| COUNTER_BASE_ADDR          | 0x1000                                        |
| COUNTER_MEM_SIZE           | ((CRYPTO_COUNTER_LENGTH/8) * CRYPTO_CNTR_MAX) |
| ENABLE_CLEAR_SRAM          | 1                                             |
| ENABLE_JUMBO_PKTS          | 1                                             |

© 2008-2014 Netronome 110 of 256

| Defined                          | Definition |
|----------------------------------|------------|
| ENABLE_ERROR_CHECKS              | 0          |
| ENABLE_ANTI_REPLAY               | 1          |
| ENABLE_CRYPTO_STATE_SAVE_RESTORE | 0          |
| ENABLE_DETAILED_COUNTERS         | 0          |
| ENABLE_DEBUG_COUNTERS            | 0          |
| HALT_ON_ERROR                    | 0          |

# 2.9.3.1 crypto\_threads\_input

#### **Prototype:**

crypto\_threads\_input(\_me\_ctx, \_crypto\_ctx, \_in\_ring\_type, \_in\_ring\_num)

#### **Description:**

Crypto input thread.

Input thread dedicated to a single crypto context / core. Typically run on even #'d thread, i.e. me threads 0,2,4,6 while corresponding output thread is run on odd #'d threads, i.e. me threads 1,3,5,7

Utilizes 1/6 of crypto sram buffer; each crypto core/ctx is allocated 1/6 of the sram buffer. Within each 1/6 of the sram buffer, space is allocated for 4x (2KB packet buffer, SA struct, and temp area)

The 4 packet buffers are used to create a pipeline to keep the crypto core active. The 4 buffers are in one of the following states:

- data being dma'd from system memory into crypto sram buffer
- ready to be operated on by crypto core when current crypto operation done
- being operated on by crypto core
- being dma'd from crypto sram to system memory

Source packet data may be stored contiguously in one buffer, or split into two or three buffers. One, two, or three dma transfers will be performed to move the buffers into crypt sram for encryption/decryption. The buffers will be placed in crypto sram contiguously, starting with data at Start of Packet Address, followed by Continuation of Packet Address, followed by End of Packet Address. If a length field is 0, no dma will occur for the corresponding buffer. ( addresses and length are part of the request ring entry, refer to request ring entry in code file for format)

Table 2.136. crypto\_threads\_input parameters

| Name    | Description                                                                                                                                    |
|---------|------------------------------------------------------------------------------------------------------------------------------------------------|
| _me_ctx | GPR, me context of this thread                                                                                                                 |
|         | GPR, crypto core context to be used by this thread. One context is used per core, so context will be equal to the core # in use by this thread |

© 2008-2014 Netronome 111 of 256

| Name          | Description                                                                |
|---------------|----------------------------------------------------------------------------|
| _in_ring_type | CONST, ring type. one of CRYTPO_RING_CTM, CRYPTO_RING_IMU, CRYPTO_RING_EMU |
| _in_ring_num  | CONST or GPR, ring number of input request ring.                           |

# 2.9.3.2 crypto threads output

#### **Prototype:**

crypto\_threads\_output(\_me\_ctx, \_crypto\_ctx)

# **Description**:

Crypto output thread.

Output thread dedicated to a single crypto context / core. Typically run on odd #'d thread, i.e. me threads 1,3,5,7, while corresponding input thread is run on even #'d threads, i.e. me threads 0,2,4,6.

See above re crypto\_threads\_input for buffer utilization description

Table 2.137. crypto\_threads\_output parameters

| Name    | Description                                                                                                                                    |
|---------|------------------------------------------------------------------------------------------------------------------------------------------------|
| _me_ctx | GPR, me context of this thread                                                                                                                 |
|         | GPR, crypto core context to be used by this thread. One context is used per core, so context will be equal to the core # in use by this thread |

# 2.9.3.3 crypto\_threads\_init

#### **Prototype:**

crypto\_threads init()

#### **Description**:

Initialize crypto threads.

## **Example:**

```
crypto_threads_init()
```

Initializes input request ring, initializes crypto cores, and initializes and starts crypto input and output threads. CRYPTO\_NUM\_THREADS, CRYPTO\_START\_CTX determine how many threads are started and what contexts they are started on.

The Request Ring params are defined as REQ\_RING\_xyz, above.

Typically used via a wrapper microcode file that may override some of the parameters defined above, invokes this macro, and does nothing else.

© 2008-2014 Netronome 112 of 256

Threads that wish to send requests to the request ring may use macro: crypto\_threads\_wait\_init\_flag() which loops waiting for crypto\_threads\_init to complete.

# 2.10 DRAM Access

# 2.10.1 DRAM Access Macros

DRAM memory specific Access Macros

# 2.10.2.1 dram mask write

# **Prototype:**

dram\_mask\_write(in\_data, in\_dram\_addr, in\_addr\_offset, in\_byte\_mask, REQ\_SIG, in\_wakeup\_sigs, in\_reserved)

#### **Description:**

Write bytes selected by in\_byte\_mask to a DRAM quadword.



#### Note

**Limitations:** Input data must be in transfer registers.

**Condition Codes:** Data dependent: assume they are clobbered.

**Instruction Count:** 3 to 8

#### Table 2.138. dram\_mask\_write parameters

| Name           | Description                                                                                                                                                                                                                      |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| in_data        | Transfer register containing data to be written to DRAM                                                                                                                                                                          |
| in_dram_addr   | DRAM address. Register or constant. Added to in_addr_offset to form DRAM address used in transfer.                                                                                                                               |
| in_addr_offset | DRAM address. Register or constant. Added to in_dram_addr to form DRAM address used in transfer.                                                                                                                                 |
| in_byte_mask   | Register or constant containing an 8 bit mask that indicates which bytes to write. The bits in the mask correspond to bytes, left to right. For example, 0x80 specifies the leftmost byte, and 0x1 specifies the rightmost byte. |
| REQ_SIG        | Requested signal.                                                                                                                                                                                                                |
| in_wakeup_sigs | List of signals causing thread to swap/wakeup.                                                                                                                                                                                   |
| in_reserved    | Reserved for future use. Pass: as the value of this parameter.                                                                                                                                                                   |

© 2008-2014 Netronome 113 of 256

# 2.10.2.2 dram mask write

# **Prototype:**

dram\_mask\_write(in\_data, in\_addr\_1, in\_addr\_2, in\_addr\_3, in\_byte\_mask, REQ\_SIG, in\_wakeup\_sigs, in\_reserved)

### **Description:**

Write bytes selected by in\_byte\_mask to a DRAM quadword - 40-bit addressing version.



# **Note**

**Limitations:** Input data must be in transfer registers. **Address specification** takes the form "reg\_or\_const1, <<8, reg\_or\_const2" or "reg\_or\_const1, reg\_or\_const2, <<8".

**Condition Codes:** Data dependent: assume they are clobbered.

**Instruction Count:** 3 to 8

Table 2.139. dram\_mask\_write parameters

| Name           | Description                                                                                                                                                                                                                      |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| in_data        | Transfer register containing data to be written to DRAM                                                                                                                                                                          |
| in_addr_1      | Address specification - see note.                                                                                                                                                                                                |
| in_addr_2      | Address specification - see note.                                                                                                                                                                                                |
| in_addr_3      | Address specification - see note.                                                                                                                                                                                                |
| in_byte_mask   | Register or constant containing an 8 bit mask that indicates which bytes to write. The bits in the mask correspond to bytes, left to right. For example, 0x80 specifies the leftmost byte, and 0x1 specifies the rightmost byte. |
| REQ_SIG        | Requested signal.                                                                                                                                                                                                                |
| in_wakeup_sigs | List of signals causing thread to swap/wakeup.                                                                                                                                                                                   |
| in_reserved    | Reserved for future use. Pass: as the value of this parameter.                                                                                                                                                                   |

# 2.10.2.3 dram\_rbuf\_read

## **Prototype:**

dram\_rbuf\_read(in\_dram\_addr, in\_dram\_addr\_offset, in\_rbuf\_addr, in\_rbuf\_addr\_offset, in\_qw\_count, REQ\_SIG, in\_wakeup\_sigs, in\_reserved)

# **Description**:

Copy in\_qw\_count quadwords from RBUF to DRAM.

RBUF is the interface buffer for data received from the network.

© 2008-2014 Netronome 114 of 256



# Note

**Limitations:** Granularity of transfer count is quadwords.

**Condition Codes:** Data dependent: assume they are clobbered.

**Instruction Count:** 2 to 10

## Table 2.140. dram\_rbuf\_read parameters

| Name                | Description                                                                                             |
|---------------------|---------------------------------------------------------------------------------------------------------|
| in_dram_addr        | DRAM address. Register or constant. Added to in_dram_addr_offset to form DRAM address used in transfer. |
| in_dram_addr_offset | DRAM address. Register or constant. Added to in_dram_addr to form DRAM address used in transfer.        |
| in_rbuf_addr        | RBUF address. Register or constant. Added to in_rbuf_addr_offset to form RBUF address used in transfer. |
| in_rbuf_addr_offset | RBUF address. Register or constant. Added to in_rbuf_addr to form RBUF address used in transfer.        |
| in_qw_count         | Register or constant. Number of quadwords to transfer from RBUF to DRAM                                 |
| REQ_SIG             | Requested signal.                                                                                       |
| in_wakeup_sigs      | List of signals causing thread to swap/wakeup.                                                          |
| in_reserved         | Reserved for future use. Pass: as the value of this parameter.                                          |

# Availability:

IXP Indirect Reference Mode

# 2.10.2.4 dram\_read

# **Prototype:**

dram\_read(out\_data, in\_dram\_addr, in\_addr\_offset, in\_qw\_count, REQ\_SIG, in\_wakeup\_sigs,
in\_reserved)

#### **Description:**

Read in\_qw\_count quadwords from DRAM.



## **Note**

**Limitations:** Granularity of transfer count is quadwords.

**Condition Codes:** Data dependent: assume they are clobbered.

© 2008-2014 Netronome 115 of 256

**Instruction Count:** 1 to 7 (indirect read (count in GPR) and 8<=count<=15)

Table 2.141. dram\_read parameters

| Name           | Description                                                                                        |
|----------------|----------------------------------------------------------------------------------------------------|
| out_data       | Transfer register that will contain read data                                                      |
| in_dram_addr   | DRAM address. Register or constant. Added to in_addr_offset to form DRAM address used in transfer. |
| in_addr_offset | DRAM address. Register or constant. Added to in_dram_addr to form DRAM address used in transfer.   |
| in_qw_count    | Register or constant. Number of quadwords to read. The maximum quadword count is 16.               |
| REQ_SIG        | Requested signal.                                                                                  |
| in_wakeup_sigs | List of signals causing thread to swap/wakeup.                                                     |
| in_reserved    | Reserved for future use. Pass: as the value of this parameter.                                     |

# 2.10.2.5 dram\_read

# **Prototype:**

dram\_read(out\_data, in\_dram\_addr, in\_addr\_offset, in\_qw\_count, REQ\_SIG, in\_wakeup\_sigs)

# **Description**:

Read in\_qw\_count quadwords from DRAM.



# **Note**

**Limitations:** Granularity of transfer count is quadwords.

**Condition Codes:** Data dependent: assume they are clobbered.

**Instruction Count:** 1 to 7 (indirect read (count in GPR) and 8<=count<=15)

Table 2.142. dram\_read parameters

| Name           | Description                                                                                        |
|----------------|----------------------------------------------------------------------------------------------------|
| out_data       | Transfer register that will contain read data                                                      |
| in_dram_addr   | DRAM address. Register or constant. Added to in_addr_offset to form DRAM address used in transfer. |
| in_addr_offset | DRAM address. Register or constant. Added to in_dram_addr to form DRAM address used in transfer.   |
| in_qw_count    | Register or constant. Number of quadwords to read. The maximum quadword count is 16.               |
| REQ_SIG        | Requested signal.                                                                                  |
| in_wakeup_sigs | List of signals causing thread to swap/wakeup.                                                     |

© 2008-2014 Netronome 116 of 256

# 2.10.2.6 dram\_read

# **Prototype:**

dram\_read(out\_data, in\_addr\_1, in\_addr\_2, in\_addr\_3, in\_qw\_count, REQ\_SIG, in\_wakeup\_sigs,
in\_reserved)

### **Description:**

Read in\_qw\_count quadwords from DRAM - 40-bit addressing version.



## **Note**

**Limitations:** Granularity of transfer count is quadwords. **Address specification** takes the form "reg\_or\_const1, <<8, reg\_or\_const2" or "reg\_or\_const1, reg\_or\_const2, <<8".

**Condition Codes:** Data dependent: assume they are clobbered.

**Instruction Count:** 1 to 7 (indirect read (count in GPR) and 8<=count<=15)

# Table 2.143. dram\_read parameters

| Name           | Description                                                                          |
|----------------|--------------------------------------------------------------------------------------|
| out_data       | Transfer register that will contain read data                                        |
| in_addr_1      | Address specification - see note.                                                    |
| in_addr_2      | Address specification - see note.                                                    |
| in_addr_3      | Address specification - see note.                                                    |
| in_qw_count    | Register or constant. Number of quadwords to read. The maximum quadword count is 16. |
| REQ_SIG        | Requested signal.                                                                    |
| in_wakeup_sigs | List of signals causing thread to swap/wakeup.                                       |
| in_reserved    | Reserved for future use. Pass: as the value of this parameter.                       |

# 2.10.2.7 dram\_tbuf\_write

#### **Prototype:**

dram\_tbuf\_write(in\_dram\_addr, in\_dram\_addr\_offset, in\_tbuf\_addr, in\_tbuf\_addr\_offset, in\_qw\_count, REQ\_SIG, in\_wakeup\_sigs, in\_reserved)

#### **Description:**

Copy in\_qw\_count quadwords from DRAM address to TBUF.

 $(in\_dram\_addr + in\_dram\_addr\_offset)$  to the TBUF address.  $(in\_tbuf\_addr + in\_tbuf\_addr\_offset)$ .

© 2008-2014 Netronome 117 of 256



## Note

**Limitations:** Granularity of transfer count is quadwords.

**Condition Codes:** Data dependent: assume they are clobbered.

**Instruction Count:** 2 to 10

## Table 2.144. dram\_tbuf\_write parameters

| Name                | Description                                                                                             |
|---------------------|---------------------------------------------------------------------------------------------------------|
| in_dram_addr        | DRAM address. Register or constant. Added to in_dram_addr_offset to form DRAM address used in transfer. |
| in_dram_addr_offset | DRAM address. Register or constant. Added to in_dram_addr to form DRAM address used in transfer.        |
| in_tbuf_addr        | TBUF address. Register or constant. Added to in_tbuf_addr_offset to form TBUF address used in transfer. |
| in_tbuf_addr_offset | TBUF address. Register or constant. Added to in_tbuf_addr to form TBUF address used in transfer.        |
| in_qw_count         | Register or constant. Number of quadwords to write.                                                     |
| REQ_SIG             | Requested signal.                                                                                       |
| in_wakeup_sigs      | List of signals causing thread to swap/wakeup.                                                          |
| in_reserved         | Reserved for future use. Pass: as the value of this parameter.                                          |

# Availability:

IXP Indirect Reference Mode

# 2.10.2.8 dram\_write

## **Prototype:**

dram\_write(in\_data, in\_addr\_1, in\_addr\_2, in\_addr\_3, in\_qw\_count, REQ\_SIG, in\_wakeup\_sigs)

#### **Description**:

Write in\_qw\_count quadwords to DRAM memory - 40-bit addressing version.



# Note

**Limitations:** Granularity of transfer count is quadwords. **Address specification** takes the form "reg\_or\_const1, <<8, reg\_or\_const2" or "reg\_or\_const1, reg\_or\_const2, <<8".

**Condition Codes:** Data dependent: assume they are clobbered.

© 2008-2014 Netronome 118 of 256

**Instruction Count:** 1 to 7 (indirect write (count in GPR) and 8<=count<=15)

Table 2.145. dram\_write parameters

| Name           | Description                                                                           |
|----------------|---------------------------------------------------------------------------------------|
| in_data        | Transfer register containing data to write                                            |
| in_addr_1      | Address specification - see note.                                                     |
| in_addr_2      | Address specification - see note.                                                     |
| in_addr_3      | Address specification - see note.                                                     |
| in_qw_count    | Register or constant. Number of quadwords to write. The maximum quadword count is 16. |
| REQ_SIG        | Requested signal.                                                                     |
| in_wakeup_sigs | List of signals causing thread to swap/wakeup.                                        |

# 2.10.2.9 dram\_write

# **Prototype:**

dram\_write(in\_data, in\_dram\_addr, in\_addr\_offset, in\_qw\_count, REQ\_SIG, in\_wakeup\_sigs)

# **Description**:

Write in\_qw\_count quadwords to DRAM memory.



## Note

Limitations: Granularity of transfer count is quadwords.

**Condition Codes:** Data dependent: assume they are clobbered.

**Instruction Count:** 1 to 7 (indirect write (count in GPR) and 8<=count<=15)

Table 2.146. dram\_write parameters

| Name           | Description                                                                                        |
|----------------|----------------------------------------------------------------------------------------------------|
| in_data        | Transfer register containing data to write                                                         |
| in_dram_addr   | DRAM address. Register or constant. Added to in_addr_offset to form DRAM address used in transfer. |
| in_addr_offset | DRAM address. Register or constant. Added to in_dram_addr to form DRAM address used in transfer.   |
| in_qw_count    | Register or constant. Number of quadwords to write. The maximum quadword count is 16.              |
| REQ_SIG        | Requested signal.                                                                                  |
| in_wakeup_sigs | List of signals causing thread to swap/wakeup.                                                     |

© 2008-2014 Netronome 119 of 256

# 2.10.2.10 ddr\_add64\_immed\_init

# **Prototype:**

ddr\_add64\_immed\_init(indirect\_ref\_reg, en\_64\_bit, ref\_cnt, byte\_mask\_dm\_dr)

# **Description**:

Alias to ddr\_add64\_immed\_init.



# Warning

This function is deprecated and may be removed in the future.

# Table 2.147. ddr\_add64\_immed\_init parameters

| Name             | Description                                          |
|------------------|------------------------------------------------------|
| indirect_ref_reg | GPR to be initialized                                |
| en_64_bit        | Constant Boolean value.                              |
|                  | • 0: Perform 32-bit Add operations                   |
|                  | • 1: Perform 64-bit Add operations                   |
| ref_cnt          | Reference count. Constant. Valid values: 0, 1, 2, 3. |
| byte_mask_dm_dr  | Not used, must be 1.                                 |

# ${\bf 2.10.2.11~ddr\_add64\_immed\_init}$

## **Prototype:**

ddr\_add64\_immed\_init(indirect\_ref\_reg, en\_64\_bit, ref\_cnt)

## **Description**:

Initialize the indirect reference register for ddr\_add64\_immed.

Using a static register for indirect reference, saves few instructions for every immed add operation.

## Table 2.148. ddr\_add64\_immed\_init parameters

| Name             | Description                        |
|------------------|------------------------------------|
| indirect_ref_reg | GPR to be initialized              |
| en_64_bit        | Constant Boolean value.            |
|                  | 0: Perform 32-bit Add operations   |
|                  | • 1: Perform 64-bit Add operations |

© 2008-2014 Netronome 120 of 256

| Name    | Description                                          |
|---------|------------------------------------------------------|
| ref_cnt | Reference count. Constant. Valid values: 0, 1, 2, 3. |

# 2.10.2.12 ddr\_add64\_immed

#### **Prototype:**

ddr\_add64\_immed(indirect\_ref\_reg, val, addr, offset)

## **Description**:

Given indirect reference register, value, address and offset, do immed add.

In NFP indirect reference mode, 14-bit values are supported. In IXP indirect reference mode, only 7-bit values are supported.

Table 2.149. ddr\_add64\_immed parameters

| Name             | Description                                                               |
|------------------|---------------------------------------------------------------------------|
| indirect_ref_reg | Indirect reference register initialized using ddr_add64_immed_init macro  |
| val              | Value to be added - constant or GPR                                       |
| addr             | DRAM address where add to be performed                                    |
| offset           | Offset from 'addr', where add is to be performed. must by 8-byte aligned. |

# 2.10.2.13 ddr\_add64\_immed\_sat

# **Prototype:**

ddr\_add64\_immed\_sat(indirect\_ref\_reg, val, addr, offset)

## **Description**:

Given indirect reference register, value, address and offset, do immed add (saturates at max value).

In NFP indirect reference mode, 14-bit values are supported. In IXP indirect reference mode, only 7-bit values are supported.

Table 2.150. ddr\_add64\_immed\_sat parameters

| Name             | Description                                                              |
|------------------|--------------------------------------------------------------------------|
| indirect_ref_reg | Indirect reference register initialized using ddr_add64_immed_init macro |
| val              | Value to be added - constant or GPR                                      |
| addr             | DRAM address where add to be performed                                   |
| offset           | Offset from 'addr', where add to be performed. must by 8-byte aligned.   |

© 2008-2014 Netronome 121 of 256

# 2.10.2.14 dram\_memcmp

# **Prototype:**

dram\_memcmp(in\_cur\_addr\_1, in\_cur\_addr\_2, in\_cur\_addr\_3, in\_src\_addr\_1, in\_src\_addr\_2, in\_src\_addr\_3, in\_cur\_len, ret\_val)

### **Description**:

Compare a region of DRAM memory with a specified pattern.

Comparison is done on data from in cur dram addr (labelled A) to data at in src dram addr (labelled B).



### **Note**

**Address specification** takes the form "reg\_or\_const1, <<8, reg\_or\_const2" or "reg\_or\_const1, reg\_or\_const2, <<8".

# Table 2.151. dram\_memcmp parameters

| Name          | Description                                                                   |
|---------------|-------------------------------------------------------------------------------|
| in_cur_addr_1 | Address specification - see note.                                             |
| in_cur_addr_2 | Address specification - see note.                                             |
| in_cur_addr_3 | Address specification - see note.                                             |
| in_src_addr_1 | Address specification - see note.                                             |
| in_src_addr_2 | Address specification - see note.                                             |
| in_src_addr_3 | Address specification - see note.                                             |
| in_cur_len    | Number of bytes to compare                                                    |
| ret_val       | Set to the first address in A where a mismatch was found otherwise unmodified |

# 2.10.2.15 dram\_memcmp

#### **Prototype:**

dram\_memcmp(in\_cur\_dram\_addr, in\_cur\_dram\_offset, in\_src\_dram\_addr, in\_src\_dram\_offset, in\_cur\_len, ret\_val)

#### **Description:**

Compare a region of DRAM memory with a specified pattern.

Comparison is done on data from in\_cur\_dram\_addr (labelled A) to data at in\_src\_dram\_addr (labelled B).

© 2008-2014 Netronome 122 of 256

Table 2.152. dram\_memcmp parameters

| Name               | Description                                                            |
|--------------------|------------------------------------------------------------------------|
| in_cur_dram_addr   | Byte address to start comparing from (A)                               |
| in_cur_dram_offset | Offset added to in_cur_dram_addr to determine start address            |
| in_src_dram_addr   | Byte address to start comparing against (B)                            |
| in_src_dram_offset | Offset added to in_src_dram_addr to determine start address            |
| in_cur_len         | Number of bytes to compare                                             |
| ret_val            | Set to the first address in A where a mismatch was found or unmodified |

# 2.10.2.16 dram\_memset

# **Prototype:**

dram\_memset(in\_dram\_addr, in\_len, lw\_pattern, CHUNK\_SIZE)

## **Description**:

Fill a region of DRAM memory with a specified pattern.

Compatibility version, which does not use an offset parameter

Table 2.153. dram\_memset parameters

| Name         | Description                                                         |
|--------------|---------------------------------------------------------------------|
| in_dram_addr | Address to start memory fill from                                   |
| in_len       | Number of bytes to set. Must be a multiple of CHUNK_SIZE.           |
| lw_pattern   | 32-bit pattern to fill memory region with                           |
| CHUNK_SIZE   | Chunk size, a multiple of 8 bytes from 8 to 64. Must be a constant. |

# 2.10.2.17 dram\_memset

#### **Prototype:**

dram\_memset(in\_dram\_addr, in\_addr\_offset, in\_len, lw\_pattern, CHUNK\_SIZE)

# **Description**:

Fill a region of DRAM memory with a specified pattern.

Compatibility version, which does not use an offset parameter

Table 2.154. dram\_memset parameters

| Name         | Description                       |
|--------------|-----------------------------------|
| in_dram_addr | Address to start memory fill from |

© 2008-2014 Netronome 123 of 256

| Name           | Description                                                         |  |
|----------------|---------------------------------------------------------------------|--|
| in_addr_offset | Added to in_dram_addr to form the DRAM address used in transfer     |  |
| in_len         | Number of bytes to set. Must be a multiple of CHUNK_SIZE.           |  |
| lw_pattern     | 32-bit pattern to fill memory region with                           |  |
| CHUNK_SIZE     | Chunk size, a multiple of 8 bytes from 8 to 64. Must be a constant. |  |

# 2.10.2.18 dram\_memset

## **Prototype:**

dram\_memset(in\_addr\_1, in\_addr\_2, in\_addr\_3, in\_len, lw\_pattern, CHUNK\_SIZE)

# **Description**:

Fill a region of DRAM memory with a specified pattern.



## **Note**

**Address specification** takes the form "reg\_or\_const1, <<8, reg\_or\_const2" or "reg\_or\_const1, reg\_or\_const2, <<8".

# Table 2.155. dram\_memset parameters

| Name       | Description                                                         |  |
|------------|---------------------------------------------------------------------|--|
| in_addr_1  | Address specification - see note.                                   |  |
| in_addr_2  | Address specification - see note.                                   |  |
| in_addr_3  | Address specification - see note.                                   |  |
| in_len     | Number of bytes to set. Must be a multiple of CHUNK_SIZE.           |  |
| lw_pattern | 32-bit pattern to fill memory region with                           |  |
| CHUNK_SIZE | Chunk size, a multiple of 8 bytes from 8 to 64. Must be a constant. |  |

# 2.11 Event filters and autopush API

# 2.11.1 CLS Filters and Autopush Macros

Cluster Scratch Event Filters & Autopush config Macros

# 2.11.2.1 evntm\_cls\_event\_filter\_config

# **Prototype:**

© 2008-2014 Netronome 124 of 256

evntm\_cls\_event\_filter\_config(filter, mask, match, filter\_type)

#### **Description:**

This macro configures an event filter to a provided mask/match and filter type.

Table 2.156. evntm\_cls\_event\_filter\_config parameters

| Name        | Description |
|-------------|-------------|
| filter      |             |
| mask        |             |
| match       |             |
| filter_type |             |

# 2.11.2.2 evntm\_cls\_autopush\_monitor\_config

## **Prototype:**

evntm\_cls\_autopush\_monitor\_config(filter, me\_num, ctxt\_num, auto\_push\_xfer\_reg, signal)

#### **Description:**

This macro configures an autopush monitor for a filter with ME number, transfer register and signal.

Table 2.157. evntm\_cls\_autopush\_monitor\_config parameters

| Name               | Description                                                                                  |
|--------------------|----------------------------------------------------------------------------------------------|
| filter             | Filter number to be monitored                                                                |
| me_num             | Microengine number to signal and push data to when a FilterStatusMonitor fires.  Range[4-15] |
| ctxt_num           | Context to be signaled on event. Range[0-7] ME Transfer register to push event status        |
| auto_push_xfer_reg |                                                                                              |
| signal             | Signal reference to use on auto push.                                                        |

# 2.11.2.3 evntm\_cls\_autopush\_monitor\_config

#### **Prototype:**

evntm cls autopush monitor config(filter, auto push xfer req, signal)

#### **Description**:

This macro configures an autopush monitor for a filter.transfer register and signal ME number and Context number are taken from ACTIVE\_CTX\_STS i.e.

which ever ME & Context is calling this macro.

© 2008-2014 Netronome 125 of 256

Table 2.158. evntm\_cls\_autopush\_monitor\_config parameters

| Name               | Description                                                             |
|--------------------|-------------------------------------------------------------------------|
| filter             | Filter number to be monitored ME Transfer register to push event status |
| auto_push_xfer_reg |                                                                         |
| signal             | Signal reference to use on auto push                                    |

# 2.11.2.4 evntm\_cls\_autopush\_monitor\_engage

#### **Prototype:**

evntm\_cls\_autopush\_monitor\_engage(filter, in\_xfer, signal, sig\_action)

#### **Description**:

This macro should be called to start monitoring an event filter, after evntm\_cls\_autopush\_monitor\_config has been called once.

This macro uses 'one shot acknowledge'

Table 2.159. evntm\_cls\_autopush\_monitor\_engage parameters

| Name       | Description                      |  |
|------------|----------------------------------|--|
| filter     | Filter number to be monitored    |  |
| in_xfer    | Xfer register to be used for I/O |  |
| signal     | I/O Signal to use                |  |
| sig_action | THD_SWAP/THD_SPIN/NONE           |  |

# 2.11.2.5 evntm\_cls\_autopush\_user\_event

#### **Prototype:**

evntm\_cls\_autopush\_user\_event(event, in\_xfer, signal, sig\_action)

#### **Description**:

This macro pushes an event into UserEvent in the CLS event manager.

Table 2.160. evntm\_cls\_autopush\_user\_event parameters

| Name       | Description            |  |
|------------|------------------------|--|
| event      | Event to push          |  |
| in_xfer    |                        |  |
| signal     | I/O Signal to use      |  |
| sig_action | THD_SWAP/THD_SPIN/NONE |  |

© 2008-2014 Netronome 126 of 256

# 2.12 Fletcher Hash Operations

# 2.12.1 Fletcher Hash Operation Macros

These macros calculate Fletcher, Jenkins, and Hardware based Hash of data in local memory

# 2.12.2.1 fletcher\_hash

### **Prototype:**

```
fletcher_hash(out_f_hash, in_lm_base_addr, in_data_size_lw, in_lm_handle, in_calc_upper)
```

# **Description**:

Calculate 32 bit Fletcher Hash of data in local memory.

## **Example:**

refer http://en.wikipedia.org/wiki/Fletcher's\_checksum for more information

Table 2.161. fletcher hash parameters

| Name            | Description                                                                                                      |  |
|-----------------|------------------------------------------------------------------------------------------------------------------|--|
| out_f_hash      | Register receives hash calculation result                                                                        |  |
| in_lm_base_addr | Register or Constant, start address of data in local memory                                                      |  |
| in_data_size_lw | Register or Constant, size of data in lwords                                                                     |  |
| in_lm_handle    | Constant, lm handle, either 0 or 1                                                                               |  |
| in_calc_upper   | Constant, enable calculation of upper 16 bits if 1 can be set to 0 to save instructions if upper bits not needed |  |

© 2008-2014 Netronome 127 of 256

# 2.12.2.2 jenkins\_hash

# **Prototype:**

```
jenkins_hash(out_j_hash, in_lm_base_addr, in_data_size_lw, in_lm_handle)
```

## **Description**:

Calculate Jenkins Hash of data in local memory.

# **Example:**

refer to http://en.wikipedia.org/wiki/Jenkins\_hash\_function for more information

Table 2.162. jenkins\_hash parameters

| Name            | Description                                                 |  |
|-----------------|-------------------------------------------------------------|--|
| out_j_hash      | Register receives hash calculation result                   |  |
| in_lm_base_addr | Register or Constant, start address of data in local memory |  |
| in_data_size_lw | Register or Constant, size of data in lwords                |  |
| in_lm_handle    | Constant, lm handle, either 0 or 1                          |  |

# 2.12.2.3 jenkins\_byte\_hash

#### **Prototype:**

```
jenkins_byte_hash(out_j_hash, in_lm_base_addr, in_data_size_lw, in_lm_handle)
```

### **Description:**

Calculate Jenkins Hash of data in local memory, byte wise.

#### **Example:**

```
localmem_set_address(0, 0, LM_HANDLE_0)
localmem_write8( 0x12345678, \
```

© 2008-2014 Netronome 128 of 256

```
0x11111111, \
0x22222222, \
0x333333333, \
0x444444444, \
0x55555555, \
0x666666666, \
0x77777777, \
0,0)

#define_eval LM_BASE_ADDR 0

#define_eval LM_SIZE_LWORDS 8
.reg r_hash_val
jenkins_byte_hash(r_hash_val, LM_BASE_ADDR, LM_SIZE_LWORDS, 0)
```

refer to http://en.wikipedia.org/wiki/Jenkins\_hash\_function for more information

# Table 2.163. jenkins\_byte\_hash parameters

| Name            | Description                                                 |  |
|-----------------|-------------------------------------------------------------|--|
| out_j_hash      | Register receives hash calculation result                   |  |
| in_lm_base_addr | Register or Constant, start address of data in local memory |  |
| in_data_size_lw | Register or Constant, size of data in lwords                |  |
| in_lm_handle    | Constant, lm handle, either 0 or 1                          |  |

# 2.12.2.4 hardware\_hash

#### **Prototype:**

hardware hash(out hw hash, in lm base addr, in data size lw, in lm handle)

#### **Description**:

Calculate Hash using IXP/NFP32XX hash hardware.

Returns result LSW

### **Example:**



#### **Note**

Not available for NFP6000. Use hash\_init\_cls() and hash\_translate() instead.

© 2008-2014 Netronome 129 of 256

Table 2.164. hardware\_hash parameters

| Name            | Description                                                        |
|-----------------|--------------------------------------------------------------------|
| out_hw_hash     | Register receives hash calculation result                          |
| in_lm_base_addr | Register or Constant, start address of data in local memory        |
| in_data_size_lw | Register or Constant, size of data in lwords (only 4 is supported) |
| in_lm_handle    | Constant, lm handle, either 0 or 1                                 |

# 2.13 HASH operation

# 2.13.1 HASH operation macros

**Table 2.165. HASH operation and Defines** 

| Defined                     | Definition                            |
|-----------------------------|---------------------------------------|
| HW_HASH_48                  | 1                                     |
|                             | API identifier for 48 bit hash keys.  |
| HW_HASH_64                  | 2                                     |
|                             | API identifier for 64 bit hash keys.  |
| HW_HASH_128                 | 3                                     |
|                             | API identifier for 128 bit hash keys. |
| CLS_HASH_M4                 | (1<<0)                                |
| CLS_HASH_M36                | (1<<1)                                |
| CLS_HASH_M53                | (1<<2)                                |
| CLS_HASH_M63                | (1<<3)                                |
| CLS_HASH_BASE_ADDR          | 0x40000                               |
| CLS_HASH_MUL_REG_OFFSET     | 0x000                                 |
| CLS_HASH_IDX0_64_REG_OFFSET | 0x800                                 |

© 2008-2014 Netronome 130 of 256

# 2.13.3.1 hash\_init

# **Prototype:**

hash\_init(in\_multiplier, MULTIPLIER\_SIZE)

## **Description**:

Initialize the hash multiplier of the hardware hash translation unit.

#### **Example:**

```
xbuf_alloc($multiplier, 2, read_write)
move($multiplier[0], 0)
move($multiplier[1], 1)
hash_init($multiplier, HW_HASH_64)
xbuf_free($multiplier)
```



#### **Note**

Not available for NFP6000. Use hash\_init\_cls instead.

**Instruction Count:** 2 to 4

# Table 2.166. hash\_init parameters

| Name            | Description                                                                                                                                                                                                                                                                                    |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | Buffer of write transfer registers with the multiplier. For more description of the multiplier, please refer to the Hash Unit section of the <i>Netronome Network Flow Processor 6000 Databook</i> . Note that this parameter must be supplied using the xbuf_alloc macro. (See Example Usage) |
| MULTIPLIER_SIZE | Size of multiplier: hw_hash_48, hw_hash_64 or hw_hash_128                                                                                                                                                                                                                                      |

# 2.13.3.2 hash\_init\_cls

#### **Prototype:**

```
hash_init_cls(INDEX, in_mask, MUL_SEL, SB_ENA, NUM_SB)
```

#### **Description:**

Initialize the cls hash logic.

# **Example:**

```
#define CLS_HASH_IDX 1
#define CLS_MUL_SEL (CLS_HASH_M4 | CLS_HASH_M36 | CLS_HASH_M53 | CLS_HASH_M63 )
#define CLS_SB_ENA 0
#define CLS_NUM_SB 0
.global_mem hashmask cls 16 8
```

© 2008-2014 Netronome 131 of 256

.init hashmask 0xffffffff, 0x0000fffff, 0x00000000, 0x00000000 hash\_init\_cls(CLS\_HASH\_IDX, hashmask, CLS\_MUL\_SEL, CLS\_SB\_ENA, CLS\_NUM\_SB)



# **Note**

Must be invoked on NFP6000 prior to using other hash macros.

**Instruction Count:** 2 to 3

## Table 2.167. hash\_init\_cls parameters

| Name    | Description                                                                                                                                                                                    |
|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| INDEX   | Cls Hash Index to use, valid values 0-7                                                                                                                                                        |
| in_mask | Cls global mem with initialized 128 bit mask value. For more description of the mask, please refer to the CLS Hash Unit section of the <i>Netronome Network Flow Processor 6000 Databook</i> . |
| MUL_SEL | Multiplier selects, logical or of CLS_HASH_M4, CLS_HASH_M36, CLS_HASH_M53, CLS_HASH_M63 as required by user. Refer to <i>Netronome Network Flow Processor 6000 Databook</i> for description    |
| SB_ENA  | SBOX Enable, valied values 1 or 0, refer to <i>Netronome Network Flow Processor 6000 Databook</i> for description                                                                              |
| NUM_SB  | Number of SBOX's to use, value values 0 through 15, refer to <i>Netronome Network Flow Processor</i> 6000 Databook for description.                                                            |

# 2.13.3.3 hash\_translate

#### **Prototype:**

hash\_translate(io\_index, INDEX\_SIZE, REQ\_SIG, in\_wakeup\_sigs)

# **Description**:

Translate a big index, up to 128 bits, using the hardware hash translation unit.

## **Example:**

```
.sig sig1
hash_translate($big_index, HW_HASH_128, sig1, sig1)
```

**Instruction Count:** 1 to 2

#### Table 2.168. hash\_translate parameters

| Name     | Description                                                                 |
|----------|-----------------------------------------------------------------------------|
| io_index | Buffer of read/write transfer registers:                                    |
|          | Output: buffer of read transfer registers with the translated index         |
|          | • Input: buffer of write transfer registers with the index to be translated |

© 2008-2014 Netronome 132 of 256

| Name           | Description                                                                         |
|----------------|-------------------------------------------------------------------------------------|
| INDEX_SIZE     | Size of index: hw_hash_48, hw_hash_64 or hw_hash_128                                |
| REQ_SIG        | Requested signal. See common section Signal Arguments.                              |
| in_wakeup_sigs | List of signals causing thread to swap/wakeup. See common section Signal Arguments. |

# 2.13.3.4 hash\_lookup

## **Prototype:**

hash\_lookup(out\_index, in\_key, KEY\_SIZE, trie\_base\_addr, TRIE\_TYPE, KEY\_DATA\_SD\_BASE)

#### **Description:**

Lookup a table entry using up to 128 bit index.

Uses tables written by core Hash Table Database Manager.

## **Example:**

hash\_lookup(table\_entry\_index, \$wide\_index[0], 102, trie\_addr, HASH16\_4, 0x100)



## **Note**

If HASH\_DONT\_TRANSLATE\_KEYS is defined, the macro will skip hash translation.

**Instruction Count:** 14 to 16 for TRIE\_TYPE = HASH\_16\_4 ((1 dram access, 1 dram access) + 11\*No of iterations (1 sram access/iteration)), 12 to 19 for TRIE\_TYPE = HASH\_FOLD\_16 ((1 sram access) + 14\*No of iteration (1 dram access/Iteration))

Table 2.169. hash\_lookup parameters

| Name             | Description                                                                                                                                                                         |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| out_index        | Index of hash table entry if success. 0 if fail (no entry)                                                                                                                          |
| in_key           | Buffer of write transfer registers with the starting index, up to 128 bits                                                                                                          |
| KEY_SIZE         | Size of in_key in bits                                                                                                                                                              |
| trie_base_addr   | Address of trie table, which is the sram primary base table                                                                                                                         |
| TRIE_TYPE        | Index bits used to address the hash trie: HASH_16_4, HASH_FOLD_16                                                                                                                   |
|                  | • HASH_16_4: First lookup uses 16 bits of index, subsequent lookups use 4 bits of index                                                                                             |
|                  | • HASH_FOLD_16: First lookup XORs the initial index to reduce it by half, then performs a table lookup using 16 bits of half-index, with subsequent chain search until no collision |
| KEY_DATA_SD_BASE | GPR or CONST, list of available SDRAM space to be used for key/data storage                                                                                                         |

© 2008-2014 Netronome 133 of 256

# 2.13.3.5 hash\_dual\_lookup

# **Prototype:**

hash\_dual\_lookup(out\_index1, out\_index2, in\_key1, in\_key2, KEY\_SIZE, trie\_base\_addr,
TRIE\_TYPE, KEY\_DATA\_SD\_BASE)

### **Description:**

Lookup two table entries in parallel using up to 128 bit index each.

The reads of the trie structure are done in parallel. This utilizes trie structure and tables written by core Hash Table Database Manager.

# **Example:**



#### Note

If HASH\_DONT\_TRANSLATE\_KEYS is defined the macro will skip hash translation.

**Instruction Count:** 32 to 37 for TRIE\_TYPE = HASH\_16\_4 ((2 sram access, 2 dram access) + 22\*No of iterations (2 sram access/iteration)), 32 to 40 for TRIE\_TYPE = HASH\_FOLD\_16 ((2 sram access) + 28\*No of iteration (1 dram access/Iteration))

Table 2.170. hash\_dual\_lookup parameters

| Name             | Description                                                                                                                                                                         |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| out_index1       | Corresponding index of hash table entry if success. 0 if fail (no entry).                                                                                                           |
| out_index2       | Corresponding index of hash table entry if success. 0 if fail (no entry).                                                                                                           |
| in_key1          | Corresponding buffer of write transfer registers with the starting index, up to 128 bits                                                                                            |
| in_key2          | Corresponding buffer of write transfer registers with the starting index, up to 128 bits                                                                                            |
| KEY_SIZE         | Size of in_key1 in bits, in_key2 must be the same size                                                                                                                              |
| trie_base_addr   | Address of trie table, which is the sram primary base table                                                                                                                         |
| TRIE_TYPE        | Index bits used to address the hash trie: HASH_16_4, HASH_FOLD_16                                                                                                                   |
|                  | • HASH_16_4: First lookup uses 16 bits of index, subsequent lookups use 4 bits of index                                                                                             |
|                  | • HASH_FOLD_16: First lookup XORs the initial index to reduce it by half, then performs a table lookup using 16 bits of half-index, with subsequent chain search until no collision |
| KEY_DATA_SD_BASE | GPR or CONST, list of available SDRAM space to be used for key/data storage                                                                                                         |

© 2008-2014 Netronome 134 of 256

# 2.14 Limit Operations

# 2.14.1 Limit Operation Macros

These macros perform limit operations

# 2.14.2.1 limit\_min

#### **Prototype:**

```
limit_min(out_c, in_a, in_b)
```

## **Description**:

Calculate minimum of two values using signed arithmetic.

## **Example:**

```
.reg minimum, ina, inb
immed[ina,5]
immed[inb,6]
limit_min(minimum, ina, inb)
beq[result_is_zero#]
```

Use in\_a for the parameter most likely to be the smallest.

Condition Codes: N,Z set based on result in out\_c

#### **Instruction Count:** 4

Cycles: For 3 different parameters: 4 if in\_a <= in\_b, else 5 Where in\_a or in\_b is the same as out\_c: 5 if out\_c already lowest, else 4

## Table 2.171. limit\_min parameters

| Name  | Description                               |
|-------|-------------------------------------------|
| out_c | Register written with lower of ina or inb |
| in_a  | Register, value to compare to in_b        |
| in_b  | Register, value to compare to in_a        |

# 2.14.2.2 limit\_min

### **Prototype:**

```
limit_min(io_a, in_b)
```

© 2008-2014 Netronome 135 of 256

## **Description**:

Calculate minimum of two values using signed arithmetic.

### **Example:**

```
.reg ioa, inb
immed[ioa,5]
immed[inb,6]
limit_min(ioa, inb)
```

Condition Codes: Data dependent: assume they are clobbered

**Instruction Count:** 3

# Table 2.172. limit\_min parameters

| Name | Description                                                 |
|------|-------------------------------------------------------------|
| io_a | Register, value to compare to in_b, and resultant min value |
| in_b | Register, value to compare to io_a                          |

# 2.14.2.3 limit\_min\_cc

# **Prototype:**

```
limit_min_cc(io_a, in_b)
```

# **Description**:

Calculate minimum of two values using signed arithmetic.

## **Example:**

```
.reg ioa, inb
immed[ioa,0]
immed[inb,6]
limit_min_cc(ioa, inb)
beq[result_is_zero#]
```

Condition Codes: N,Z set based on result in io\_a

**Instruction Count:** 4

#### Table 2.173. limit\_min\_cc parameters

| Name | Description                                                 |
|------|-------------------------------------------------------------|
| io_a | Register, value to compare to in_b, and resultant min value |
| in_b | Register, value to compare to io_a                          |

© 2008-2014 Netronome 136 of 256

# 2.14.2.4 limit\_max

# **Prototype:**

```
limit_max(out_c, in_a, in_b)
```

## **Description**:

Calculate maximum of two values using signed arithmetic.

#### **Example:**

```
.reg maximum, ina, inb
immed[ina,5]
immed[inb,6]
limit_max(maximum, ina, inb)
beq[result_is_zero#]
```

Use in\_b for the parameter most likely to be the highest.

Condition Codes: N,Z set based on result in out\_c

#### **Instruction Count:** 4

Cycles: For 3 different parameters: 4 if in\_a <= in\_b, else 5 Where in\_a or in\_b is the same as out\_c: 5 if out\_c already lowest, else 4

# Table 2.174. limit\_max parameters

| Name  | Description                                |  |
|-------|--------------------------------------------|--|
| out_c | Register written with higher of ina or inb |  |
| in_a  | Register, value to compare to in_b         |  |
| in_b  | Register, value to compare to in_a         |  |

# 2.14.2.5 limit\_max

#### **Prototype:**

```
limit_max(io_a, in_b)
```

#### **Description:**

Calculate maximum of two values using signed arithmetic.

# **Example:**

```
.reg ioa, inb
immed[ioa,5]
immed[inb,6]
limit_max(ioa, inb)
```

Condition Codes: Data dependent: assume they are clobbered

© 2008-2014 Netronome 137 of 256

#### **Instruction Count:** 3

# Table 2.175. limit\_max parameters

| Name | Description                                                 |
|------|-------------------------------------------------------------|
| io_a | Register, value to compare to in_b, and resultant max value |
| in_b | Register, value to compare to io_a                          |

# 2.14.2.6 limit\_max\_cc

## **Prototype:**

```
limit_max_cc(io_a, in_b)
```

#### **Description:**

Calculate maximum of two values using signed arithmetic.

## **Example:**

```
.reg ioa, inb
immed[ioa,5]
immed[inb,6]
limit_max(ioa, inb)
beq[result_is_zero#]
```

Condition Codes: N,Z set based on result in io\_a

**Instruction Count:** 4

## Table 2.176. limit\_max\_cc parameters

| Name | Description                                                 |
|------|-------------------------------------------------------------|
| io_a | Register, value to compare to in_b, and resultant max value |
| in_b | Register, value to compare to io_a                          |

# 2.14.2.7 limit\_min\_unsigned

#### **Prototype:**

```
limit_min_unsigned(out_c, in_a, in_b)
```

### **Description:**

Calculate minimum of two values using unsigned arithmetic.

## **Example:**

```
.reg minimum, ina, inb
immed[ina,5]
```

© 2008-2014 Netronome 138 of 256

```
immed[inb,6]
limit_min_unsigned(minimum, ina, inb)
beq[result_is_zero#]
```

Use in\_a for the parameter most likely to be the smallest.

Condition Codes: N,Z set based on result in out\_c

#### **Instruction Count:** 4

Cycles: For 3 different parameters: 4 if in\_a <= in\_b, else 5 Where in\_a or in\_b is the same as out\_c: 5 if out\_c already lowest, else 4

Table 2.177. limit\_min\_unsigned parameters

| Name  | Description                               |  |
|-------|-------------------------------------------|--|
| out_c | Register written with lower of ina or inb |  |
| in_a  | Register, value to compare to in_b        |  |
| in_b  | Register, value to compare to in_a        |  |

# 2.14.2.8 limit\_min\_unsigned

## **Prototype:**

limit\_min\_unsigned(io\_a, in\_b)

#### **Description**:

Calculate minimum of two values using unsigned arithmetic.

#### **Example:**

```
.reg ioa, inb
immed[ioa,5]
immed[inb,6]
limit_min_unsigned(ioa, inb)
```

Condition Codes: Data dependent: assume they are clobbered

**Instruction Count: 3** 

## Table 2.178. limit\_min\_unsigned parameters

| Name | Description                                                 |
|------|-------------------------------------------------------------|
| io_a | Register, value to compare to in_b, and resultant min value |
| in_b | Register, value to compare to io_a                          |

# 2.14.2.9 limit\_min\_unsigned\_cc

### **Prototype:**

© 2008-2014 Netronome 139 of 256

```
limit_min_unsigned_cc(io_a, in_b)
```

#### **Description:**

Calculate minimum of two values using unsigned arithmetic.

# **Example:**

```
.reg ioa, inb
immed[ioa,5]
immed[inb,6]
limit_min_unsigned_cc(ioa, inb)
beq[result_is_zero#]
```

Condition Codes: N,Z set based on result in io\_a

**Instruction Count:** 4

# Table 2.179. limit\_min\_unsigned\_cc parameters

| Name | Description                                                 |
|------|-------------------------------------------------------------|
| io_a | Register, value to compare to in_b, and resultant min value |
| in_b | Register, value to compare to io_a                          |

# 2.14.2.10 limit\_max\_unsigned

#### **Prototype:**

```
limit_max_unsigned(out_c, in_a, in_b)
```

#### **Description:**

Calculate maximum of two values using unsigned arithmetic.

# **Example:**

```
.reg maximum, ina, inb
immed[ina,5]
immed[inb,6]
limit_max_unsigned(maximum, ina, inb)
beq[result_is_zero#]
```

Use in\_b for the parameter most likely to be the highest.

**Condition Codes:** N,Z set based on result in out\_c

#### **Instruction Count:** 4

Cycles: For 3 different parameters: 4 if in\_a <= in\_b, else 5 Where in\_a or in\_b is the same as out\_c: 5 if out\_c already lowest, else 4

© 2008-2014 Netronome 140 of 256

## Table 2.180. limit\_max\_unsigned parameters

| Name  | Description                                |  |
|-------|--------------------------------------------|--|
| out_c | Register written with higher of ina or inb |  |
| in_a  | Register, value to compare to in_b         |  |
| in_b  | Register, value to compare to in_a         |  |

# 2.14.2.11 limit\_max\_unsigned

#### **Prototype:**

limit\_max\_unsigned(io\_a, in\_b)

#### **Description**:

Calculate maximum of two values using unsigned arithmetic.

#### Example:

```
.reg ioa, inb
immed[ioa,5]
immed[inb,6]
limit_max_unsigned(ioa, inb)
```

Condition Codes: Data dependent: assume they are clobbered

**Instruction Count:** 3

# Table 2.181. limit\_max\_unsigned parameters

| Name | Description                                                 |
|------|-------------------------------------------------------------|
| io_a | Register, value to compare to in_b, and resultant max value |
| in_b | Register, value to compare to io_a                          |

# 2.14.2.12 limit\_max\_unsigned\_cc

## **Prototype:**

limit\_max\_unsigned\_cc(io\_a, in\_b)

#### **Description**:

Calculate maximum of two values using unsigned arithmetic.

# **Example:**

```
.reg ioa, inb
immed[ioa,5]
immed[inb,6]
```

© 2008-2014 Netronome 141 of 256

```
limit_max_unsigned_cc(ioa, inb)
beq[result_is_zero#]
```

Condition Codes: N,Z set based on result in io\_a

**Instruction Count:** 4

Table 2.182. limit\_max\_unsigned\_cc parameters

| Name | Description                                                 |
|------|-------------------------------------------------------------|
| io_a | Register, value to compare to in_b, and resultant max value |
| in_b | Register, value to compare to io_a                          |

# 2.14.2.13 limit\_align\_first\_chunk

#### **Prototype:**

limit\_align\_first\_chunk(out\_chunk, in\_size, in\_align, in\_address)

# **Description**:

Calculate size of first chunk of work.

#### **Example:**

```
#define_eval BOUNDARY 8
.reg chunk_size, size, address
move(size,200)
move(address,0x12340004)
limit_align_first_chunk(chunk_size, size, BOUNDARY, addr)
```

Returned size (out\_chunk ) will not cross alignment boundary even if total size is less than the alignment size

Works with unsigned values

Cycles: 6/7 if in\_align constant, else 7/8

# Table 2.183. limit\_align\_first\_chunk parameters

| Name       | Description                                                                                       |
|------------|---------------------------------------------------------------------------------------------------|
| out_chunk  | Returned size of first chunk of work, so that it will not cross a boundary (mulitple of in_align) |
| in_size    | Total work size                                                                                   |
| in_align   | Alignment boundary, must be power of 2                                                            |
| in_address | Start address of work                                                                             |

© 2008-2014 Netronome 142 of 256

# 2.15 Math Operations

# 2.15.1 Math Operation Macros General

These macros perform math functions which are not provided by microcode instructions

# 2.15.2.1 math\_int\_div

#### **Prototype:**

math\_int\_div(out\_q, in\_numerator, in\_denominator)

#### **Description**:

32 bit unsigned integer divide.

## **Example:**

```
.reg dividend, divisor, quotient
immed[dividend,20]
immed[divisor,4]
math_int_div(quotient, dividend, divisor) // quotient will equal 5
```

if in\_numerator and in\_denominator are constants, division is done using assembler rather than at runtime out\_q is set to -1 if in\_denominator is 0

#### Table 2.184. math\_int\_div parameters

| Name           | Description                                                 |
|----------------|-------------------------------------------------------------|
| out_q          | GPR written with quotient ( in_numerator / in_denominator ) |
| in_numerator   | GPR or CONSTANT, dividend                                   |
| in_denominator | GPR or CONSTANT, divisor                                    |

# 2.15.2.2 math\_int\_div\_64

#### **Prototype:**

```
math_int_div_64(out_q, in_numerator_hi, in_numerator_lo, in_denominator)
```

#### **Description:**

64 bit unsigned integer divide (supports 64 bit dividend).

#### **Example:**

© 2008-2014 Netronome 143 of 256

```
.reg dividend_hi, dividend_lo, divisor, quotient
immed[dividend_hi,20]
immed[dividend_lo,10]
immed[divisor,5723]
math_int_div_64(quotient, dividend_hi, dividend_lo, divisor)
```

out\_q is set to -1 if in\_denominator is 0

Caution: This macro uses the basic subtract method of division and execution time will be proportionate to the magnitude of the resulting quotient.

Table 2.185. math\_int\_div\_64 parameters

| Name            | Description                                                 |
|-----------------|-------------------------------------------------------------|
| out_q           | GPR written with quotient ( in_numerator / in_denominator ) |
| in_numerator_hi | GPR upper 32 bits of dividend                               |
| in_numerator_lo | GPR lower 32 bits of dividend                               |
| in_denominator  | GPR divisor                                                 |

# 2.15.2.3 math\_log2

# **Prototype:**

math\_log2(out\_result, in\_arg, IN\_ROUND)

#### **Description:**

calculate base 2 logarithm on unsigned input value.

## **Example:**

```
.reg log2, value
immed[value, 32]
math_log2(log2, value, 0)
```

similar to LOG2 assembler function

## Table 2.186. math\_log2 parameters

| Name       | Description                                                                                                                                                                                                 |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| out_result | GPR written with log base 2 of in_arg                                                                                                                                                                       |
| in_arg     | GPR 32 bit unsigned int                                                                                                                                                                                     |
|            | Constant, used when result is not a power of 2: round $<$ 0: round result down to next smaller integer round $=$ 0: generate an error (negative output) round $>$ 0: round result up to next larger integer |

# 2.15.2.4 math\_find\_highest\_set

## **Prototype:**

© 2008-2014 Netronome 144 of 256

```
math_find_highest_set(out_result, in_arg)
```

#### **Description:**

calculate highest set bit in a 32 bit unsigned value.

#### **Example:**

```
.reg bit, value
move(value, 0x01234567]
math_find_highest_set(bit, value) // bit should equal 24
```

if no bit is set, out\_result is set to -1

### Table 2.187. math\_find\_highest\_set parameters

| Name       | Description                                |
|------------|--------------------------------------------|
| out_result | GPR written with highest bit set of in_arg |
| in_arg     | GPR 32 bit unsigned int                    |

# 2.16 Memory Allocation

# 2.16.1 Memory Allocation Macros general info

For some macros a virtual parameter, called the freelisthandle, is used to refer to a specific group of macro parameters. It is composed of: POOL\_ID Which freelist: POOL0, POOL1, POOL2 ... D\_BASE Base byte address of DRAM buffers. Must be aligned to 32 byte boundary. D\_SIZE Byte size of DRAM buffers. Must be power of 2. S\_BASE Base byte address of SRAM buffers. Must be aligned to 4 byte boundary. S\_SIZE Byte size of SRAM buffers. Must be power of 2. For example:

#defineBUF\_FHBUF\_FREE\_LISTO,BUF\_DRAM\_BASE,BUFFER\_SIZE,BUF\_SRAM\_BASE,META\_DATA\_SIZE All of these addresses are byte addresses, and all of these sizes refer to the number of bytes.

## 2.16.2.1 buf dram addr from index

#### **Prototype:**

```
buf_dram_addr_from_index(out_address, in_index, POOL_ID, D_BASE, D_SIZE, S_BASE, S_SIZE)
```

#### **Description**:

Calculate DRAM Buffer Address from Index.

This macro calculates:

```
out_address = (in_index * D_SIZE) + D_BASE
```

© 2008-2014 Netronome 145 of 256

**Instruction Count:** 3 to 4

Table 2.188. buf\_dram\_addr\_from\_index parameters

| Name        | Description                                                                     |
|-------------|---------------------------------------------------------------------------------|
| out_address | A DRAM buffer address                                                           |
| in_index    | A relative index that identifies DRAM buffer and SRAM buffer descriptor address |
| POOL_ID     | Which freelist: POOL0, POOL1, POOL2                                             |
| D_BASE      | Base byte address of DRAM buffers. Must be aligned to 32 byte boundary.         |
| D_SIZE      | Byte size of DRAM buffers. Must be power of 2.                                  |
| S_BASE      | Base byte address of SRAM buffers. Must be aligned to 4 byte boundary.          |
| S_SIZE      | Byte size of SRAM buffers. Must be power of 2.                                  |

## 2.16.2.2 buf\_dram\_addr\_from\_sram\_addr

#### **Prototype:**

buf\_dram\_addr\_from\_sram\_addr(out\_dram\_addr, in\_sram\_addr, POOL\_ID, D\_BASE, D\_SIZE, S\_BASE,
S\_SIZE)

#### **Description:**

Given a freelist handle and SRAM address, calculate DRAM buffer address.

This macro calculates:

**Instruction Count:** 5 to 6

Table 2.189. buf\_dram\_addr\_from\_sram\_addr parameters

| Name          | Description                                                             |
|---------------|-------------------------------------------------------------------------|
| out_dram_addr | A DRAM buffer address                                                   |
| in_sram_addr  | An SRAM buffer descriptor address                                       |
| POOL_ID       | Which freelist: POOL0, POOL1, POOL2                                     |
| D_BASE        | Base byte address of DRAM buffers. Must be aligned to 32 byte boundary. |
| D_SIZE        | Byte size of DRAM buffers. Must be power of 2.                          |
| S_BASE        | Base byte address of SRAM buffers. Must be aligned to 4 byte boundary.  |
| S_SIZE        | Byte size of SRAM buffers. Must be power of 2.                          |

© 2008-2014 Netronome 146 of 256

# 2.16.2.3 buf\_index\_from\_dram\_addr

#### **Prototype:**

buf\_index\_from\_dram\_addr(out\_index, in\_address, POOL\_ID, D\_BASE, D\_SIZE, S\_BASE, S\_SIZE)

#### **Description**:

Calculate array index from DRAM buffer address.

This macro calculates:

```
out_index = (in_address - D_BASE) / D_SIZE
```

**Instruction Count:** 2 to 4

#### Table 2.190. buf\_index\_from\_dram\_addr parameters

| Name       | Description                                                                       |
|------------|-----------------------------------------------------------------------------------|
| out_index  | A relative index that identifies DRAM buffer and SRAM buffer descriptor addresses |
| in_address | A DRAM buffer address                                                             |
| POOL_ID    | Which freelist: POOL0, POOL1, POOL2                                               |
| D_BASE     | Base byte address of DRAM buffers. Must be aligned to 32 byte boundary.           |
| D_SIZE     | Byte size of DRAM buffers. Must be power of 2.                                    |
| S_BASE     | Base byte address of SRAM buffers. Must be aligned to 4 byte boundary.            |
| S_SIZE     | Byte size of SRAM buffers. Must be power of 2.                                    |

## 2.16.2.4 buf\_index\_from\_sram\_addr

#### **Prototype:**

buf\_index\_from\_sram\_addr(out\_index, in\_address, POOL\_ID, D\_BASE, D\_SIZE, S\_BASE, S\_SIZE)

#### **Description**:

Calculate Array Index from Buffer Descriptor Address.

This macro calculates:

```
out_index = (in_address - S_BASE) / S_SIZE
```

**Instruction Count:** 2 to 4

#### Table 2.191. buf\_index\_from\_sram\_addr parameters

| Name       | Description                                                                       |
|------------|-----------------------------------------------------------------------------------|
| out_index  | A relative index that identifies DRAM buffer and SRAM buffer descriptor addresses |
| in_address | An SRAM buffer address                                                            |

© 2008-2014 Netronome 147 of 256

| Name    | Description                                                             |
|---------|-------------------------------------------------------------------------|
| POOL_ID | Which freelist: POOL0, POOL1, POOL2                                     |
| D_BASE  | Base byte address of DRAM buffers. Must be aligned to 32 byte boundary. |
| D_SIZE  | Byte size of DRAM buffers. Must be power of 2.                          |
| S_BASE  | Base byte address of SRAM buffers. Must be aligned to 4 byte boundary.  |
| S_SIZE  | Byte size of SRAM buffers. Must be power of 2.                          |

## 2.16.2.5 buf\_sram\_addr\_from\_index

#### **Prototype:**

buf\_sram\_addr\_from\_index(out\_address, in\_index, POOL\_ID, D\_BASE, D\_SIZE, S\_BASE, S\_SIZE)

#### **Description**:

Calculate SRAM Buffer Address from Index.

This macro calculates:

out\_address = (in\_index \* S\_SIZE) + S\_BASE

**Instruction Count:** 3 to 4

Table 2.192. buf\_sram\_addr\_from\_index parameters

| Name        | Description                                                                     |
|-------------|---------------------------------------------------------------------------------|
| out_address | An SRAM buffer address                                                          |
| in_index    | A relative index that identifies DRAM buffer and SRAM buffer descriptor address |
| POOL_ID     | Which freelist: POOL0, POOL1, POOL2                                             |
| D_BASE      | Base byte address of DRAM buffers. Must be aligned to 32 byte boundary.         |
| D_SIZE      | Byte size of DRAM buffers. Must be power of 2.                                  |
| S_BASE      | Base byte address of SRAM buffers. Must be aligned to 4 byte boundary.          |
| S_SIZE      | Byte size of SRAM buffers. Must be power of 2.                                  |

## 2.16.2.6 buf\_sram\_addr\_from\_dram\_addr

#### **Prototype:**

buf\_sram\_addr\_from\_dram\_addr(out\_sram\_addr, in\_dram\_addr, POOL\_ID, D\_BASE, D\_SIZE, S\_BASE,
S\_SIZE)

#### **Description:**

Given a freelist handle and DRAM address, calculate SRAM buffer address.

© 2008-2014 Netronome 148 of 256

#### This macro calculates:

**Instruction Count:** 5 to 6

Table 2.193. buf sram addr from dram addr parameters

| Name          | Description                                                             |
|---------------|-------------------------------------------------------------------------|
| out_sram_addr | An SRAM buffer address                                                  |
| in_dram_addr  | A DRAM buffer descriptor address                                        |
| POOL_ID       | Which freelist: POOL0, POOL1, POOL2                                     |
| D_BASE        | Base byte address of DRAM buffers. Must be aligned to 32 byte boundary. |
| D_SIZE        | Byte size of DRAM buffers. Must be power of 2.                          |
| S_BASE        | Base byte address of SRAM buffers. Must be aligned to 4 byte boundary.  |
| S_SIZE        | Byte size of SRAM buffers. Must be power of 2.                          |

## 2.16.2.7 buf freelist create

#### **Prototype:**

```
buf_freelist_create(in_num_buffers, POOL_ID, D_BASE, D_SIZE, S_BASE, S_SIZE)
```

#### **Description**:

Create SRAM buffer (descriptor) freelist using sram queues.

The freelist termination is indicated by a return value of 0 from buf\_alloc(). The freelist is permanent. This library does not make provision for destroying the freelist. Freelist creation should be performed at initialization time only, so as not to interfere with runtime performance.

**Instruction Count:** (11 to 14) + 7\*in\_num\_buffers

Table 2.194. buf\_freelist\_create parameters

| Name    | Description                                                                                                                                                                                                             |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         | Number of buffers put on the freelist. The minimum value is 1. The maximum value is arbitrary, chosen based on the amount of memory available for buffer space (in_num_buffers x D_SIZE) and (in_num_buffers x S_SIZE). |
| POOL_ID | Which freelist: POOL0, POOL1, POOL2                                                                                                                                                                                     |
| D_BASE  | Base byte address of DRAM buffers. Must be aligned to 32 byte boundary.                                                                                                                                                 |

© 2008-2014 Netronome 149 of 256

| Name   | Description                                                            |
|--------|------------------------------------------------------------------------|
| D_SIZE | Byte size of DRAM buffers. Must be power of 2.                         |
| S_BASE | Base byte address of SRAM buffers. Must be aligned to 4 byte boundary. |
| S_SIZE | Byte size of SRAM buffers. Must be power of 2.                         |

## 2.16.2.8 buf\_alloc

#### **Prototype:**

buf\_alloc(out\_sram\_addr, POOL\_ID, D\_BASE, D\_SIZE, S\_BASE, S\_SIZE, REQ\_SIG, in\_wakeup\_sigs,
Q\_OPTIONS)

#### **Description**:

Allocate SRAM/DRAM buffers from a buffer freelist identified by the freelist handle.

#### Table 2.195. buf\_alloc parameters

| Name           | Description                                                                                 |
|----------------|---------------------------------------------------------------------------------------------|
| out_sram_addr  | Allocated SRAM address.                                                                     |
| POOL_ID        | Which freelist: POOL0, POOL1, POOL2                                                         |
| D_BASE         | Base byte address of DRAM buffers. Must be aligned to 32 byte boundary.                     |
| D_SIZE         | Byte size of DRAM buffers. Must be power of 2.                                              |
| S_BASE         | Base byte address of SRAM buffers. Must be aligned to 4 byte boundary.                      |
| S_SIZE         | Byte size of SRAM buffers. Must be power of 2.                                              |
| REQ_SIG        | Requested signal                                                                            |
| in_wakeup_sigs | List of signals causing thread to swap/wakeup                                               |
| Q_OPTIONS      | Directive for memory controller queue selection. (Currently not applicable: pass the value) |

## 2.16.2.9 buf\_free

### **Prototype:**

buf\_free(in\_sram\_addr, POOL\_ID, D\_BASE, D\_SIZE, S\_BASE, S\_SIZE)

#### **Description**:

Return the specified SRAM address to the buffer pool identified by the freelist handle.

#### Table 2.196. buf\_free parameters

| Name         | Description     |
|--------------|-----------------|
| in_sram_addr | An SRAM address |

© 2008-2014 Netronome 150 of 256

| Name    | Description                                                             |
|---------|-------------------------------------------------------------------------|
| POOL_ID | Which freelist: POOL0, POOL1, POOL2                                     |
| D_BASE  | Base byte address of DRAM buffers. Must be aligned to 32 byte boundary. |
| D_SIZE  | Byte size of DRAM buffers. Must be power of 2.                          |
| S_BASE  | Base byte address of SRAM buffers. Must be aligned to 4 byte boundary.  |
| S_SIZE  | Byte size of SRAM buffers. Must be power of 2.                          |

# 2.17 Memory Queue Operations

## 2.17.1 Local Memory Queue Operation Macros

These macros implement queues using local memory Three different mechanisms are used to implement the LM queues. The most appropriate approach is automatically selected depending on the sizes. The most efficient is if the queue size (number of items \* size of item [bytes]) is 256. The worst is if the queue size is not a power-of-2, as conditional branches have to be used. No assumption is made about the alignment of the buffer in local memory. The programmer must ensure that the queue do not overflow. The \*\_enqueue macros enqueues the new item without checking for overflow. General use: The enqueue/dequeue macros do not directly put/get data. They adjust the head/tail/count variables and initialize the specified LM index to point to the relevant slot. The caller can then read/write the data using the specified LM index. Example use: //Parameters: \_NAME\_PREFIX, FLAGS, NUM\_ITEMS, ITEM\_SIZE define SOME\_QUEUE \_SOME\_QUEUE, 0, 16, 4Imqueue\_init(SOME\_QUEUE)Imqueue\_enqueue(SOME\_QUEUE, ACTIVE\_LM\_ADDR\_0) move(\*1\$index0[0], 0) move(\*1\$index0[1], 100) ... Imqueue\_dequeue(SOME\_QUEUE, ACTIVE\_LM\_ADDR\_0) move(tmp1, \*1\$index0[0]) move(tmp2, \*1\$index0[1])

**Table 2.197. Memory Queue Operations and Defines** 

| Defined            | Definition |
|--------------------|------------|
| _LM_HANDLES_IN_USE | 0          |

## 2.17.3.1 Im\_handle\_alloc

## **Prototype:**

lm\_handle\_alloc(HANDLE)

#### **Description:**

Allocate Handle to local memory control logic.

#### **Example:**

© 2008-2014 Netronome 151 of 256

#### **Instruction Count:** 0

#### Table 2.198. Im\_handle\_alloc parameters

| Name   | Description          |
|--------|----------------------|
| HANDLE | Constant handle name |

## 2.17.3.2 lm\_handle\_free

#### **Prototype:**

lm\_handle\_free(HANDLE)

#### **Description**:

Free Handle allocated with lm\_handle\_alloc.

#### **Example:**

```
lm_handle_free(SOME_LM_HANDLE)
#undef SOME_LM_HANDLE
#undef SOME_LM_INDEX
```

#### **Instruction Count:** 0

## Table 2.199. Im\_handle\_free parameters

| Name   | Description          |
|--------|----------------------|
| HANDLE | Constant handle name |

## 2.17.3.3 Im\_handle\_verify

#### **Prototype:**

lm\_handle\_verify(NUM\_IN\_USE)

#### **Description:**

Verifies the number of LM handles in use.

#### **Example:**

lm\_handle\_verify(1)

#### **Instruction Count:** 0

© 2008-2014 Netronome 152 of 256

#### Table 2.200. Im\_handle\_verify parameters

| Name       | Description                                 |
|------------|---------------------------------------------|
| NUM_IN_USE | Constant, expected number of handles in use |

## 2.17.3.4 incr\_lm\_base

#### **Prototype:**

incr\_lm\_base(NAME)

### **Description**:

Increment base address of lm block used for queue data.

LM must be manually assigned as parts of the addresses may be used in preprocessor macros.

The Imqueue macros require LM NAME BASE and LM NAME SIZE.

Note that the blocks must be naturally aligned for some of the uses.

Each LM block can be specified by the triplet:

#### **Example:**

```
#define_eval LM_SOMENAME_BASE (_LM_BASE)
#define_eval LM_SOMENAME_SIZE 256
incr_lm_base(LM_SOMENAME)
```

#### **Instruction Count:** 0

The BASE and the SIZE is specified in bytes.

#### Table 2.201. incr\_lm\_base parameters

| Name | Description             |
|------|-------------------------|
| NAME | Constant, Name of queue |

# 2.18 Microengine CAM Operation

# 2.18.1 Microengine CAM Operation Macros

Microengine CAM Operation Macros

© 2008-2014 Netronome 153 of 256

## 2.18.2.1 cam\_clear\_all

#### **Prototype:**

cam\_clear\_all()

#### **Description**:

Clear all the CAM entries.

## 2.18.2.2 cam\_read\_entry

### **Prototype:**

cam\_read\_entry(out\_data, out\_state, in\_entry\_num)

#### **Description:**

Read the data and state for the specified CAM entry.

#### Table 2.202. cam\_read\_entry parameters

| Name         | Description                                     |
|--------------|-------------------------------------------------|
| out_data     | 32-bit data read from entry                     |
| out_state    | 4-bit state data associated with this CAM entry |
| in_entry_num | CAM entry number                                |

## 2.18.2.3 cam\_write\_entry

#### **Prototype:**

cam\_write\_entry(in\_entry\_num, in\_data, in\_state)

#### **Description**:

Write the data and state for the specified CAM entry.

#### Table 2.203. cam\_write\_entry parameters

| Name         | Description                                           |
|--------------|-------------------------------------------------------|
| in_entry_num | CAM entry number                                      |
| in_data      | 32-bit data to be written to specified CAM entry      |
| in_state     | 4-bit state data to be associated with this CAM entry |

## 2.18.2.4 cam\_read\_data

### **Prototype**:

© 2008-2014 Netronome 154 of 256

cam\_read\_data(out\_data, in\_entry\_num)

#### **Description**:

Read the data for the specified CAM entry.

Table 2.204. cam\_read\_data parameters

| Name         | Description                 |
|--------------|-----------------------------|
| out_data     | 32-bit data read from entry |
| in_entry_num | CAM entry number            |

## 2.18.2.5 cam\_match

### **Prototype:**

cam\_match(out\_state, out\_status, out\_entry\_num, in\_data)

#### **Description**:

Perform content match to get a CAM entry.

Table 2.205. cam match parameters

| Name          | Description                                                                                                                                                                                                                      |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| out_state     | If out_status is 1 (hit), this contains the appropriate state value. If out_status is 0 (miss), this contains 0.                                                                                                                 |
| out_status    | Match status. A value of 1 means Hit, 0 means Miss.                                                                                                                                                                              |
| out_entry_num | If out_status is 1 (hit), this contains the matched entry number. If out_status is 0 (miss), this contains the least recently used (LRU) entry number. The LRU entry number can be used as a hint for writing new data into CAM. |
| in_data       | 32-bit data to match                                                                                                                                                                                                             |

# 2.19 Microengine CAM Sharing Operation

# 2.19.1 Microengine CAM Sharing Operation Macros

This API supports: CAM sharing across different microblocks running on same ME. The original LRU CAM implementation (without CAM sharing). To enable CAM sharing support, define CAM\_SHARED before including this file. For most macros a virtual parameter, called the CAM handle, is used to refer to a specific group of macro parameters. It is composed of: BID Unique Microblock Block ID. 4 bits by default. BID\_BIT\_SZ COUNT Number of CAM entries. 4 bits. FIRST Number of first CAM entry. 4 bits. For example: #defineRX\_CAM\_HANDLE1,8,0 However, the CAM handle is not used if CAM sharing is not enabled. The relevant macro parameters must still be

© 2008-2014 Netronome 155 of 256

passed though. This section creates the following global absolute registers: @camsharing\_bit\_vector @camsharing\_ref\_cnt1 @camsharing\_ref\_cnt2

**Table 2.206. Microengine CAM Sharing Operation and Defines** 

| Defined        | Definition                                        |
|----------------|---------------------------------------------------|
| SRC_KEY_BIT_SZ | 28                                                |
|                | Bit size of the key part of the CAM tag.          |
|                | This plus BID_BIT_SZ must not exceed 32 bits.     |
| BID_BIT_SZ     | 4                                                 |
|                | Bit size of the block ID part of the CAM tag.     |
|                | This plus SRC_KEY_BIT_SZ must not exceed 32 bits. |

## 2.19.3.1 cam\_init

#### **Prototype:**

cam\_init()

#### **Description**:

Initializes CAM variables and clears all CAM entries, must be called before using any other macros of this API.

It is assumed that after calling this macro all CAM entries will be initialized to unique values prior to doing CAM lookups.

## 2.19.3.2 cam\_entry\_read\_state

#### **Prototype:**

cam\_entry\_read\_state(out\_state\_val, in\_entry\_num, in\_bid, in\_num\_entries, in\_first\_entry)

#### **Description**:

Reads the state value for the CAM entry (the block specific entry if CAM is shared).

#### **Example:**

cam\_entry\_read\_state(cam\_state, cam\_entry, RX\_CAM\_HANDLE)

### Table 2.207. cam\_entry\_read\_state parameters

| Name          | Description                                                                                |
|---------------|--------------------------------------------------------------------------------------------|
| out_state_val | The state value of the CAM entry is placed in bits 11 to 8, other bits are set to 0.       |
| in_entry_num  | CAM entry number. May not exceed the total number of CAM entries. It is not range checked. |

© 2008-2014 Netronome 156 of 256

| Name           | Description                                |
|----------------|--------------------------------------------|
| in_bid         | Microblock Block ID.                       |
| in_num_entries | Number of CAM entries for this microblock. |
| in_first_entry | First CAM entry number of this microblock. |

## 2.19.3.3 cam\_entry\_write\_state

#### **Prototype:**

cam\_entry\_write\_state(in\_entry\_num, in\_state\_val, in\_bid, in\_num\_entries, in\_first\_entry)

#### **Description**:

Writes the state value for the CAM entry (the block specific entry if CAM is shared).

#### **Example:**

cam\_entry\_write\_state(cam\_entry, CAM\_STATE\_VALID, RX\_CAM\_HANDLE)

### Table 2.208. cam\_entry\_write\_state parameters

| Name           | Description                                                                                |
|----------------|--------------------------------------------------------------------------------------------|
| in_entry_num   | CAM entry number. May not exceed the total number of CAM entries. It is not range checked. |
| in_state_val   | The state value to write to the CAM entry.                                                 |
| in_bid         | Microblock Block ID.                                                                       |
| in_num_entries | Number of CAM entries for this microblock.                                                 |
| in_first_entry | First CAM entry number of this microblock.                                                 |

# 2.19.3.4 cam\_entry\_read\_tag

#### **Prototype:**

cam\_entry\_read\_tag(out\_tag, in\_entry\_num, in\_bid, in\_num\_entries, in\_first\_entry)

### **Description**:

Reads the tag for the CAM entry (the block specific entry if CAM is shared).

#### **Example:**

cam\_entry\_read\_tag(cam\_tag, cam\_entry, RX\_CAM\_HANDLE)

#### Table 2.209. cam\_entry\_read\_tag parameters

| Name         | Description                                                                                |
|--------------|--------------------------------------------------------------------------------------------|
| out_tag      | The tag of the CAM entry is returned here.                                                 |
| in_entry_num | CAM entry number. May not exceed the total number of CAM entries. It is not range checked. |

© 2008-2014 Netronome 157 of 256

| Name           | Description                                |
|----------------|--------------------------------------------|
| in_bid         | Microblock Block ID.                       |
| in_num_entries | Number of CAM entries for this microblock. |
| in_first_entry | First CAM entry number of this microblock. |

## 2.19.3.5 cam\_clearall

#### **Prototype:**

cam\_clearall(in\_bid, in\_num\_entries, in\_first\_entry)

#### **Description:**

In CAM sharing mode, clear CAM entries for the specified microblock, otherwise clear all CAM entries.



#### **Note**

In CAM sharing mode the CAM tags and state bits of entries are not cleared.

## Table 2.210. cam\_clearall parameters

| Name           | Description                                |
|----------------|--------------------------------------------|
| in_bid         | Microblock Block ID.                       |
| in_num_entries | Number of CAM entries for this microblock. |
| in_first_entry | First CAM entry number of this microblock. |

## 2.19.3.6 cam\_entry\_write

#### **Prototype:**

cam\_entry\_write(in\_entry\_num, in\_key, in\_state\_val, in\_bid, in\_num\_entries, in\_first\_entry)

#### **Description**:

Write the tag for the specified CAM entry of the specific microblock.

#### **Example:**

cam\_entry\_write(cam\_entry, src\_key, CAM\_STATE\_VALID, RX\_CAM\_HANDLE)

#### Table 2.211. cam\_entry\_write parameters

| Name         | Description                                                                                |
|--------------|--------------------------------------------------------------------------------------------|
| in_entry_num | CAM entry number. May not exceed the total number of CAM entries. It is not range checked. |
| in_key       | Source key with which CAM lookup was done.                                                 |
| in_state_val | State value of CAM entry.                                                                  |

© 2008-2014 Netronome 158 of 256

| Name           | Description                                |
|----------------|--------------------------------------------|
| in_bid         | Microblock Block ID.                       |
| in_num_entries | Number of CAM entries for this microblock. |
| in_first_entry | First CAM entry number of this microblock. |

## 2.19.3.7 cam\_exit\_using\_entry

#### **Prototype:**

cam\_exit\_using\_entry(in\_entry\_num, in\_bid, in\_num\_entries, in\_first\_entry)

#### **Description:**

Decrement the reference count for the specified CAM entry to indicate that a thread is done with the entry.

When the reference count is zero, the entry is marked as free.

### Table 2.212. cam\_exit\_using\_entry parameters

| Name           | Description                                                                                |
|----------------|--------------------------------------------------------------------------------------------|
| in_entry_num   | CAM entry number. May not exceed the total number of CAM entries. It is not range checked. |
| in_bid         | Microblock Block ID.                                                                       |
| in_num_entries | Number of CAM entries for this microblock.                                                 |
| in_first_entry | First CAM entry number of this microblock.                                                 |

# 2.19.3.8 cam\_entry\_lookup

### **Prototype:**

cam\_entry\_lookup(out\_lookup\_result, in\_key, in\_bid, in\_num\_entries, in\_first\_entry)

#### **Description**:

Perform a CAM lookup and increment the reference count in CAM sharing mode.

The following algorithm is used to increment the reference count:

<verbatim> Say the @camsharing\_ref\_cnt1 has: 0011 ... 0100 0011 0011 0001 To increment ref\_cnt for entry 1,
add: 0000 ... 0000 0000 0001 0000 Result: 0011 ... 0100 0011 0100 0001 /verbatim>

#### **Example:**

cam\_entry\_lookup(lookup\_result, src\_key, RX\_CAM\_HANDLE)

© 2008-2014 Netronome 159 of 256

Table 2.213. cam\_entry\_lookup parameters

| Name              | Description                                                                                              |
|-------------------|----------------------------------------------------------------------------------------------------------|
| out_lookup_result | The lookup result is returned here. For CAM sharing mode the result has tje block specific entry number. |
| in_key            | Source key with which CAM lookup should be done.                                                         |
| in_bid            | Microblock Block ID.                                                                                     |
| in_num_entries    | Number of CAM entries for this microblock.                                                               |
| in_first_entry    | First CAM entry number of this microblock.                                                               |

## 2.19.3.9 cam\_entry\_lookup\_with\_lm

#### **Prototype:**

cam\_entry\_lookup\_with\_lm(out\_lookup\_result, in\_key, in\_lm\_handle, in\_lm\_start\_addr, in\_bid, in\_num\_entries, in\_first\_entry)

#### **Description:**

Perform a CAM lookup, increment the reference count in CAM sharing mode and set the given LM handle to point to corresponding data in Local Memory.

The following algorithm is used to increment the reference count:

<verbatim> Say the @camsharing\_ref\_cnt1 has: 0011 ... 0100 0011 0011 0001 To increment ref\_cnt for entry 1,
add: 0000 ... 0000 0000 0001 0000 Result: 0011 ... 0100 0011 0100 0001 /verbatim>

#### **Example:**

cam\_entry\_lookup\_with\_lm(lookup\_result, src\_key, RXC\_LM\_HANDLE, RXC\_INFO\_LM\_BASE, \
 RX\_CAM\_HANDLE)

Table 2.214. cam\_entry\_lookup\_with\_lm parameters

| Name              | Description                                                                                                   |
|-------------------|---------------------------------------------------------------------------------------------------------------|
| out_lookup_result | The lookup result is returned here. For CAM sharing mode the result has tje block specific entry number.      |
| in_key            | Source key with which CAM lookup should be done.                                                              |
| in_lm_handle      | LM handle 0 or 1 which will be set to point to the data structure in LM according to the lookup result.       |
| in_lm_start_addr  | 2-bit LM address where the data structure is located. (0, 1, 2, 3 represents 0, 1024, 2048, 3072 bytes in LM) |
| in_bid            | Microblock Block ID.                                                                                          |
| in_num_entries    | Number of CAM entries for this microblock.                                                                    |
| in_first_entry    | First CAM entry number of this microblock.                                                                    |

© 2008-2014 Netronome 160 of 256

# 2.20 Microengine CRC

## 2.20.1 Microengine CRC Macros

This section creates a global absolute register:@crc10\_table\_base\_addr

## 2.20.2.1 crc load crc10 table

#### **Prototype:**

crc\_load\_crc10\_table(lm\_crc10\_base\_addr)

#### **Description**:

Load crc\_10 lookup table.



#### **Note**

The user needs to make sure this area is not currupted later.

**Instruction Count:** 130

### Table 2.215. crc\_load\_crc10\_table parameters

| Name               | Description                                                           |
|--------------------|-----------------------------------------------------------------------|
| lm_crc10_base_addr | Base address from where CRC lookup table should start in local memory |

## 2.20.2.2 crc\_10

#### **Prototype:**

crc\_10(out\_remainder, in\_data, ENDIAN, in\_start\_byte, in\_end\_byte)

#### **Description**:

Perform a crc 10 computation.

The CRC Remainder CSR must contain the remainder intended to be used in this CRC 10 operation (usually it is the remainder of the previous CRC operation).

© 2008-2014 Netronome 161 of 256



#### **Note**

If in\_start\_byte = in\_end\_byte, only values 0 or 3 are legal. This means only the byte at either end of in\_data can be used in the CRC operation.

in\_start\_byte and in\_end\_byte should be consistent with the byte order specified in ENDIAN. Example: If you want to use only the least significant byte:

- ENDIAN = big\_endian ---> in\_start\_byte = in\_end\_byte = 3
- ENDIAN = little\_endian ---> in\_start\_byte = in\_end\_byte = 0

Each time this operation is performed, the new remainder is put in the CRC Remainder CSR.

**Instruction Count:** 27 for 1 byte, 40 for 2 bytes, 54 for 3 bytes, 68 for 4 bytes

#### Table 2.216. crc\_10 parameters

| Name          | Description                                                                                                                   |
|---------------|-------------------------------------------------------------------------------------------------------------------------------|
| out_remainder | Value of remainder. Can be GPR or sram/dram transfer out register (a.k.a. write transfer register).                           |
| in_data       | Source data on which CRC operation will be performed.                                                                         |
| ENDIAN        | String with two possible values:                                                                                              |
|               | • little_endian: use crc_le operation (the data will be swaped before being used to calculate CRC remainder)                  |
|               | • big_endian: use crc_be operation (no data swapping)                                                                         |
| in_start_byte | Byte position where data starts. Must be an immediate value (a number). in_start_byte must be less than or equal in_end_byte. |
| in_end_byte   | Byte position where data ends. Must be an immediate value (a number).                                                         |

## 2.20.2.3 crc\_32

#### **Prototype:**

crc\_32(out\_remainder, in\_data, ENDIAN, in\_start\_byte, in\_end\_byte)

#### **Description:**

Perform a crc 32 computation.

The CRC Remainder CSR must contain the remainder intended to be used in this CRC 32 operation (usually it is the remainder of the previous CRC operation).



#### **Note**

If in\_start\_byte == in\_end\_byte, only values 0 or 3 are legal. This means only the byte at either end of in\_data can be used in the CRC operation.

© 2008-2014 Netronome 162 of 256

in\_start\_byte and in\_end\_byte should be consistent with the byte order specified in ENDIAN. Example: If you want to use only the least significant byte:

- ENDIAN = big\_endian ---> in\_start\_byte = in\_end\_byte = 3
- ENDIAN = little\_endian ---> in\_start\_byte = in\_end\_byte = 0

Each time this operation is performed, the new remainder is put in the CRC Remainder CSR.

#### **Instruction Count:** 1

#### Table 2.217. crc\_32 parameters

| Name          | Description                                                                                                                                                                                            |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| out_remainder | The value of remainder. Can be a GPR or a sram/dram transfer out register (a.k.a. write transfer register).                                                                                            |
| in_data       | Source data on which CRC operation will be performed                                                                                                                                                   |
| ENDIAN        | String with two possible values:  • little_endian: use crc_le operation (the data will be swapped before being used to calculate CRC remainder)  • big_endian: use crc_be operation (no data swapping) |
| in_start_byte | Byte position where data starts. Must be a immediate value (a number). in_start_byte must be less than or equal in_end_byte                                                                            |
| in_end_byte   | Byte position where data ends. Must be an immediate value (a number).                                                                                                                                  |

## 2.20.2.4 crc\_ccitt

### **Prototype:**

crc\_ccitt(out\_remainder, in\_data, ENDIAN, in\_start\_byte, in\_end\_byte)

#### **Description:**

Perform a crc ccitt computation.

The CRC Remainder CSR must contain the remainder intended to be used in this CRC operation (usually it is the remainder of the previous CRC operation).



#### **Note**

If  $in\_start\_byte == in\_end\_byte$ , only value 0 or 3 are legal. This means only the byte at either end of  $in\_data$  can be used in the CRC operation.

in\_start\_byte and in\_end\_byte should be consistent with the byte order specified in ENDIAN. Example: If you want to use only the least significant byte:

• ENDIAN = big\_endian ---> in\_start\_byte = in\_end\_byte = 3

© 2008-2014 Netronome 163 of 256

• ENDIAN = little\_endian ---> in\_start\_byte = in\_end\_byte = 0

Each time this operation is performed, the new remainder is put in the CRC Remainder CSR.

NFP-32xx can perform CRC operation on big or little endian data.

#### **Instruction Count:** 1

#### Table 2.218. crc\_ccitt parameters

| Name          | Description                                                                                                                                                                                            |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| out_remainder | Value of remainder. Can be a GPR or a sram/dram transfer out register (a.k.a. write transfer register).                                                                                                |
| in_data       | Source data on which CRC operation will be performed                                                                                                                                                   |
| ENDIAN        | String with two possible values:  • little_endian: use crc_le operation (the data will be swapped before being used to calculate CRC remainder)  • big_endian: use crc_be operation (no data swapping) |
| in_start_byte | Byte position where data starts. Must be a immediate value (a number). in_start_byte must be less than or equal in_end_byte.                                                                           |
| in_end_byte   | Byte position where data ends. Must be an immediate value (a number).                                                                                                                                  |

## 2.20.2.5 crc\_read

#### **Prototype:**

crc\_read(out\_remainder)

## **Description**:

Read the data that is currently in the CSR CRC\_Remainder.

### Table 2.219. crc\_read parameters

| Name          | Description                                                                                  |
|---------------|----------------------------------------------------------------------------------------------|
| out_remainder | Value of remainder. Can be a GPR or a sram/dram transfer out register (a.k.a. write transfer |
|               | register).                                                                                   |

## 2.20.2.6 crc\_write

#### **Prototype:**

crc\_write(in\_remainder)

#### **Description**:

© 2008-2014 Netronome 164 of 256

Write the input data into the CRC unit.



### **Note**

This operation needs 3 cycles for data to be updated. Therefore, there must be at least 3 instructions between calling this macro and reading the CRC Remainder or using the remainder via crc\_ccitt or CRC\_32 operation.

#### **Instruction Count:** 1

#### Table 2.220. crc\_write parameters

| Name | Description                                                                                                         |
|------|---------------------------------------------------------------------------------------------------------------------|
|      | Value of remainder to be written. Can be a GPR or a sram/dram transfer in register (a.k.a. read transfer register). |

# 2.21 Microengine Standard Macros

# 2.21.1 Microengine Standard Macros

This paragraph provides a list of generic macros

### 2.21.2.1 immed32

#### **Prototype:**

immed32(out\_result, VAL)

#### **Description:**

Load out\_result with 32 bit constant.

If constant fits in 16 bits, expand to a single immed, if not, expand into an immed\_w0 and an immed\_w1. If it is a name (not a number), assume that it is being imported (an import variable).

#### **Example:**

immed32(output, 0x12345678)

**Instruction Count:** 1 to 2 (3 if output is transfer register)

© 2008-2014 Netronome 165 of 256

Table 2.221. immed32 parameters

| Name       | Description                                |
|------------|--------------------------------------------|
| out_result | Destination GPR or write transfer register |
| VAL        | Constant                                   |

### 2.21.2.2 immed40

#### **Prototype:**

immed40(out\_result\_hi, out\_result\_lo, VAL)

#### **Description:**

Load the upper byte of the 40-bit immediate value in the upper byte of out\_result\_hi and load the lower 4 bytes into out\_result\_lo Can be used with immediate constant or import variable.

This macro is specifically for defining a 40-bit addresses

**Example:** .reg addr\_hi, addr\_lo .reg write \$wr\_buf .sig s

define TEST\_BASE\_ADDR\_SIZE 0x100 define TEST\_BASE\_ADDR\_ALIGN 0x4 .alloc\_mem TEST\_BASE\_ADDR i26.emem island TEST\_BASE\_ADDR\_SIZE TEST\_BASE\_ADDR\_ALIGN

immed40(addr\_hi, addr\_lo, TEST\_BASE\_ADDR) move(\$wr\_buf, 0x12345678) mem[write8\_be, \$wr\_buf, addr\_hi, <<8, addr\_lo, 4], sig\_done[s] ctx\_arb[s], all

Table 2.222. immed40 parameters

| Name          | Description                      |
|---------------|----------------------------------|
| out_result_hi | Destination GPR or xfer register |
| out_result_lo | Destination GPR or xfer register |
| VAL           | 40-bit Constant                  |

#### 2.21.2.3 balr

#### **Prototype:**

balr(in\_link\_pc, target\_label)

### **Description**:

Save the current program counter in GPR in\_link\_pc and branch to target\_label.

Program control can be returned to the current PC (the current location) using the rtn[in\_link\_pc] instruction.

#### **Example:**

balr(next, target)

© 2008-2014 Netronome 166 of 256

#### **Instruction Count: 2**

#### Table 2.223. balr parameters

| Name         | Description                                    |
|--------------|------------------------------------------------|
| in_link_pc   | GPR to hold next PC for use by rtn instruction |
| target_label | Subroutine start                               |

### 2.21.2.4 move

#### **Prototype:**

move(out\_result, in\_src)

#### **Description:**

Move the source value into the destination register.

### **Example:**

move(output, input)

**Instruction Count:** 1 to 3 (2 if output is GPR, 3 if output is transfer register)

#### Table 2.224. move parameters

| Name       | Description                                    |
|------------|------------------------------------------------|
| out_result | Destination GPR or write transfer register     |
| in_src     | Source GPR, read transfer register or constant |

## 2.21.2.5 alu\_op

#### **Prototype:**

alu\_op(out\_result, in\_a, op\_spec, in\_b)

#### **Description**:

Perform ALU operation in\_aop\_specin\_b.

#### **Example:**

alu\_op(output, 0x12345678, +, 10)

**Instruction Count:** 1 to 5 (6 if op\_spec = +4)

© 2008-2014 Netronome 167 of 256

Table 2.225. alu\_op parameters

| Name       | Description                                |
|------------|--------------------------------------------|
| out_result | Destination GPR or write transfer register |
| in_a       | Register or constant                       |
| op_spec    | ALU operation Legal operators are:         |
|            | • B                                        |
|            | • ~B                                       |
|            | • +                                        |
|            | • +carry                                   |
|            | • +4                                       |
|            | • +8                                       |
|            | • +16                                      |
|            | • -                                        |
|            | • B-A                                      |
|            | • AND                                      |
|            | • ~AND                                     |
|            | • AND~                                     |
|            | • OR                                       |
|            | • XOR                                      |
| in_b       | Register or constant                       |

## 2.21.2.6 add

## **Prototype**:

add(out\_result, in\_a, in\_b)

### **Description**:

Perform 32 bit add.

This macro calculates:

out\_result = in\_a + in\_b

#### **Example:**

add(output, 0x1234, 0x12345678)

**Instruction Count:** 1 to 5

© 2008-2014 Netronome 168 of 256

### Table 2.226. add parameters

| Name       | Description                                |
|------------|--------------------------------------------|
| out_result | Destination GPR or write transfer register |
| in_a       | Register or constant                       |
| in_b       | Register or constant                       |

## 2.21.2.7 add\_c

### **Prototype:**

add\_c(out\_result, in\_a, in\_b)

#### **Description**:

Perform 32 bit add.

This macro calculates:

out\_result = in\_a + in\_b + previous carry

#### **Example:**

add\_c(output, source\_a, 0x12345678)

**Instruction Count:** 1 to 5

#### Table 2.227. add\_c parameters

| Name       | Description                                |
|------------|--------------------------------------------|
| out_result | Destination GPR or write transfer register |
| in_a       | Register or constant                       |
| in_b       | Register or constant                       |

### 2.21.2.8 sub

#### **Prototype:**

sub(out\_result, in\_a, in\_b)

### **Description**:

Perform 32 bit subtract.

This macro calculates:

out\_result = in\_a - in\_b

#### **Example:**

© 2008-2014 Netronome 169 of 256

sub(output, 0x12345678, source)

**Instruction Count:** 1 to 5

#### Table 2.228. sub parameters

| Name       | Description                                |
|------------|--------------------------------------------|
| out_result | Destination GPR or write transfer register |
| in_a       | Register or constant                       |
| in_b       | Register or constant                       |

## 2.21.2.9 shf\_right

### **Prototype:**

shf\_right(out\_result, in\_src, in\_shift\_amt)

#### **Description**:

Shift right in\_src by in\_shift\_amt bit positions.

#### **Example:**

shf\_right(output, input, 3)

**Instruction Count:** 1 to 2

#### Table 2.229. shf\_right parameters

| Name         | Description                    |
|--------------|--------------------------------|
| out_result   | Destination                    |
| in_src       | Source                         |
| in_shift_amt | Register or constant (0 to 31) |

## 2.21.2.10 shf\_left

#### **Prototype:**

shf\_left(out\_result, in\_src, in\_shift\_amt)

#### **Description**:

Shift left in\_src by in\_shift\_amt bit positions.

#### **Example:**

shf\_left(output, input, reg)

**Instruction Count:** 1 to 4

© 2008-2014 Netronome 170 of 256

### Table 2.230. shf\_left parameters

| Name         | Description                    |
|--------------|--------------------------------|
| out_result   | Destination                    |
| in_src       | Source                         |
| in_shift_amt | Register or constant (0 to 31) |

## 2.21.2.11 rot\_right

### **Prototype:**

rot\_right(out\_result, in\_src, in\_shift\_amt)

#### **Description**:

Rotate right in\_src by in\_shift\_amt bit positions.

#### **Example:**

rot\_right(output, input, 3)

#### **Instruction Count:** 1

### Table 2.231. rot\_right parameters

| Name         | Description                    |
|--------------|--------------------------------|
| out_result   | Destination GPR                |
| in_src       | Source GPR                     |
| in_shift_amt | Register or constant (0 to 31) |

# 2.21.2.12 rot\_left

### **Prototype:**

rot\_left(out\_result, in\_src, in\_shift\_amt)

### **Description**:

Rotate left in\_src by in\_shift\_amt bit positions.

#### **Example:**

rot\_left(output, input, 3)

#### **Instruction Count:** 1

© 2008-2014 Netronome 171 of 256

Table 2.232. rot\_left parameters

| Name         | Description                    |
|--------------|--------------------------------|
| out_result   | Destination GPR                |
| in_src       | Source GPR                     |
| in_shift_amt | Register or constant (0 to 31) |

## 2.21.2.13 alu\_shf\_right

### **Prototype**:

alu\_shf\_right(out\_result, in\_a, op\_spec, in\_b, in\_shift\_amt)

### **Description**:

Shift right in\_b by in\_shift\_amt bit positions, then perform operation op\_spec on in\_a.

## **Example:**

alu\_shf\_right(output, 0xABCD1234, +, input, 3)

**Instruction Count:** 1 to 4

Table 2.233. alu\_shf\_right parameters

| Name       | Description                        |
|------------|------------------------------------|
| out_result | Destination                        |
| in_a       | Register or constant               |
| op_spec    | ALU operation Legal operators are: |
|            | • B                                |
|            | • ~B                               |
|            | • +                                |
|            | • +carry                           |
|            | • +4                               |
|            | • +8                               |
|            | • +16                              |
|            | • -                                |
|            | • -carry                           |
|            | • B-A                              |
|            | • AND                              |
|            | • ~AND                             |
|            | • AND~                             |

© 2008-2014 Netronome 172 of 256

| Name         | Description                    |
|--------------|--------------------------------|
|              | • OR                           |
|              | • XOR                          |
| in_b         | Register or constant           |
| in_shift_amt | Register or constant (0 to 31) |

## 2.21.2.14 add\_shf\_right

#### **Prototype:**

add\_shf\_right(out\_result, in\_a, in\_b, in\_shift\_amt)

### **Description**:

Shift right in\_b by in\_shift\_amt bit positions, then ADD in\_a.

#### **Example:**

add\_shf\_right(output, 0xABCD1234, input, 3)

**Instruction Count:** 1 to 4

### Table 2.234. add\_shf\_right parameters

| Name         | Description                    |
|--------------|--------------------------------|
| out_result   | Destination GPR                |
| in_a         | Register or constant           |
| in_b         | Register or constant           |
| in_shift_amt | Register or constant (0 to 31) |

# 2.21.2.15 sub\_shf\_right

### **Prototype:**

sub\_shf\_right(out\_result, in\_a, in\_b, in\_shift\_amt)

### **Description**:

Shift right in\_b by in\_shift\_amt bit positions, then SUBTRACT in\_a.

#### **Example:**

sub\_shf\_right(output, 0xABCD1234, input, 3)

**Instruction Count:** 1 to 4

© 2008-2014 Netronome 173 of 256

### Table 2.235. sub\_shf\_right parameters

| Name         | Description                    |
|--------------|--------------------------------|
| out_result   | Destination GPR                |
| in_a         | Register or constant           |
| in_b         | Register or constant           |
| in_shift_amt | Register or constant (0 to 31) |

## 2.21.2.16 and\_shf\_right

#### **Prototype:**

and\_shf\_right(out\_result, in\_a, in\_b, in\_shift\_amt)

#### **Description**:

Shift right in\_b by in\_shift\_amt bit positions, then AND in\_a.

#### **Example:**

and\_shf\_right(output, 0xABCD1234, input, 3)

**Instruction Count:** 1 to 4

### Table 2.236. and\_shf\_right parameters

| Name         | Description                    |
|--------------|--------------------------------|
| out_result   | Destination GPR                |
| in_a         | Register or constant           |
| in_b         | Register or constant           |
| in_shift_amt | Register or constant (0 to 31) |

# 2.21.2.17 or\_shf\_right

#### **Prototype:**

or\_shf\_right(out\_result, in\_a, in\_b, in\_shift\_amt)

### **Description**:

Shift right in\_b by in\_shift\_amt bit positions, then OR in\_a.

#### **Example:**

or\_shf\_right(output, 0xABCD1234, input, 3)

**Instruction Count:** 1 to 4

© 2008-2014 Netronome 174 of 256

Table 2.237. or\_shf\_right parameters

| Name         | Description                    |
|--------------|--------------------------------|
| out_result   | Destination GPR                |
| in_a         | Register or constant           |
| in_b         | Register or constant           |
| in_shift_amt | Register or constant (0 to 31) |

# 2.21.2.18 alu\_shf\_left

### **Prototype**:

alu\_shf\_left(out\_result, in\_a, op\_spec, in\_b, in\_shift\_amt)

## **Description**:

Shift left in\_b by in\_shift\_amt bit positions, then perform operation op\_spec on in\_a.

### **Example:**

alu\_shf\_left(output, 0xABCD1234, +, input, 3)

**Instruction Count:** 1 to 4

Table 2.238. alu\_shf\_left parameters

| Name       | Description                        |
|------------|------------------------------------|
| out_result | Destination                        |
| in_a       | Register or constant               |
| op_spec    | ALU operation Legal operators are: |
|            | • B                                |
|            | • ~B                               |
|            | • +                                |
|            | • +carry                           |
|            | • +4                               |
|            | • +8                               |
|            | • +16                              |
|            | • -                                |
|            | • -carry                           |
|            | • B-A                              |
|            | • AND                              |
|            | • ~AND                             |

© 2008-2014 Netronome 175 of 256

| Name         | Description                    |
|--------------|--------------------------------|
|              | • AND~                         |
|              | • OR                           |
|              | • XOR                          |
| in_b         | Register or constant           |
| in_shift_amt | Register or constant (0 to 31) |

## 2.21.2.19 add\_shf\_left

#### **Prototype:**

add\_shf\_left(out\_result, in\_a, in\_b, in\_shift\_amt)

#### **Description**:

Shift left in\_b by in\_shift\_amt bit positions, then ADD in\_a.

#### **Example:**

add\_shf\_left(output, 0xABCD1234, input, 3)

**Instruction Count:** 1 to 4

### Table 2.239. add\_shf\_left parameters

| Name         | Description                    |
|--------------|--------------------------------|
| out_result   | Destination GPR                |
| in_a         | Register or constant           |
| in_b         | Register or constant           |
| in_shift_amt | Register or constant (0 to 31) |

## 2.21.2.20 sub\_shf\_left

#### **Prototype:**

sub\_shf\_left(out\_result, in\_a, in\_b, in\_shift\_amt)

#### **Description**:

Shift left in\_b by in\_shift\_amt bit positions, then SUBTRACT in\_a.

#### **Example:**

```
sub_shf_left(output, 0xABCD1234, input, 3)
```

**Instruction Count:** 1 to 4

© 2008-2014 Netronome 176 of 256

### Table 2.240. sub\_shf\_left parameters

| Name         | Description                    |
|--------------|--------------------------------|
| out_result   | Destination GPR                |
| in_a         | Register or constant           |
| in_b         | Register or constant           |
| in_shift_amt | Register or constant (0 to 31) |

## 2.21.2.21 and\_shf\_left

#### **Prototype:**

and\_shf\_left(out\_result, in\_a, in\_b, in\_shift\_amt)

#### **Description**:

Shift left in\_b by in\_shift\_amt bit positions, then AND in\_a.

#### **Example:**

and\_shf\_left(output, 0xABCD1234, input, 3)

**Instruction Count:** 1 to 4

## Table 2.241. and\_shf\_left parameters

| Name         | Description                    |
|--------------|--------------------------------|
| out_result   | Destination GPR                |
| in_a         | Register or constant           |
| in_b         | Register or constant           |
| in_shift_amt | Register or constant (0 to 31) |

## 2.21.2.22 or\_shf\_left

#### **Prototype:**

or\_shf\_left(out\_result, in\_a, in\_b, in\_shift\_amt)

### **Description**:

Shift left in\_b by in\_shift\_amt bit positions, then OR in\_a.

#### **Example:**

or\_shf\_left(output, 0xABCD1234, input, 3)

**Instruction Count:** 1 to 4

© 2008-2014 Netronome 177 of 256

Table 2.242. or\_shf\_left parameters

| Name         | Description                    |
|--------------|--------------------------------|
| out_result   | Destination GPR                |
| in_a         | Register or constant           |
| in_b         | Register or constant           |
| in_shift_amt | Register or constant (0 to 31) |

# 2.21.2.23 alu\_rot\_right

#### **Prototype**:

alu\_rot\_right(out\_result, in\_a, op\_spec, in\_b, in\_shift\_amt)

#### **Description**:

Rotate right in\_b by in\_shift\_amt bit positions, then perform operation op\_spec on in\_a.

### **Example:**

```
alu_rot_right(output, input2, +, input, 4)
```

When: input2 = 5 and input = 0x12345678 results in out\_result = 0x8123456c

**Instruction Count:** 1 to 3 (4 if op\_spec = +4)

Table 2.243. alu\_rot\_right parameters

| Name       | Description                        |
|------------|------------------------------------|
| out_result | Destination GPR                    |
| in_a       | Register or constant               |
| op_spec    | ALU operation Legal operators are: |
|            | • B                                |
|            | • ~B                               |
|            | • +                                |
|            | • +carry                           |
|            | • +4                               |
|            | • +8                               |
|            | • +16                              |
|            | • -                                |
|            | • B-A                              |
|            | • AND                              |
|            | • ~AND                             |

© 2008-2014 Netronome 178 of 256

| Name         | Description                    |
|--------------|--------------------------------|
|              | • AND~                         |
|              | • OR                           |
|              | • XOR                          |
| in_b         | Register or constant           |
| in_shift_amt | Register or constant (0 to 31) |

## 2.21.2.24 alu\_rot\_left

#### **Prototype:**

alu\_rot\_left(out\_result, in\_a, op\_spec, in\_b, in\_shift\_amt)

### **Description**:

Rotate left in\_b by in\_shift\_amt bit positions, then perform operation op\_spec on in\_a.

#### **Example:**

alu\_rot\_left(output, input2, +, input, 3)

**Instruction Count:** 1 to 3 (4 if op\_spec = +4)

Table 2.244. alu\_rot\_left parameters

| Name       | Description                        |
|------------|------------------------------------|
| out_result | Destination GPR                    |
| in_a       | Register or constant               |
| op_spec    | ALU operation Legal operators are: |
|            | • B                                |
|            | • ~B                               |
|            | • +                                |
|            | • +carry                           |
|            | • +4                               |
|            | • +8                               |
|            | • +16                              |
|            | • -                                |
|            | • B-A                              |
|            | • AND                              |
|            | • ~AND                             |
|            | • AND~                             |

© 2008-2014 Netronome 179 of 256

| Name         | Description                    |
|--------------|--------------------------------|
|              | • OR                           |
|              | • XOR                          |
| in_b         | Register or constant           |
| in_shift_amt | Register or constant (0 to 31) |

## 2.21.2.25 bitfield\_extract

## **Prototype:**

bitfield\_extract(out\_result, in\_src, MSB, LSB)

### **Description**:

Extract a bit field from a register.



#### **Note**

Bits are numbered 31-0, left to right.

**Instruction Count:** 1 to 6

#### Table 2.245. bitfield\_extract parameters

| Name       | Description                                 |
|------------|---------------------------------------------|
| out_result | Extracted field                             |
| in_src     | Source register with multiple fields        |
| MSB        | Most significant, left bit defining field   |
| LSB        | Least significant, right bit defining field |

## 2.21.2.26 bitfield\_insert

### **Prototype:**

bitfield\_insert(out\_result, in\_a, in\_b, MSB, LSB)

### **Description**:

Insert bitfield in\_b into copy of in\_a.



#### **Note**

Bits are numbered 31-0, left to right.

© 2008-2014 Netronome 180 of 256

**Instruction Count:** 2 to 4 (depending on size of bitfield, 2 if mask fits in immediate)

## Table 2.246. bitfield\_insert parameters

| Name       | Description                                                                                          |
|------------|------------------------------------------------------------------------------------------------------|
| out_result | Merged result                                                                                        |
| in_a       | Register with multiple fields                                                                        |
| in_b       | Bits to be inserted (This field always start at bit 0. Do not shift to the position to be inserted.) |
| MSB        | Most significant, left bit (bits left to right are 31-0)                                             |
| LSB        | Least significant, right bit                                                                         |

## 2.21.2.27 bits\_clr

## **Prototype:**

bits\_clr(io\_data, in\_start\_bit\_pos, in\_mask)

#### **Description:**

Clear bits indicated by mask at starting position in\_start\_bit\_pos.

## **Example:**

bits\_clr(reg2, bitpos, 0x3)

**Instruction Count:** 4 to 7

## Table 2.247. bits\_clr parameters

| Name             | Description                                                                                     |
|------------------|-------------------------------------------------------------------------------------------------|
| io_data          | Register to modify                                                                              |
| in_start_bit_pos | Register or constant less than 32, starting bit position in_mask is shifted left by this amount |
| in_mask          | Register or constant, mask of bits to clear                                                     |

# 2.21.2.28 bits\_set

## **Prototype:**

bits\_set(io\_data, in\_start\_bit\_pos, in\_mask)

## **Description**:

Set bits indicated by mask at starting position in\_start\_bit\_pos.

#### **Example:**

bits\_set(reg2, 5, 0xff)

© 2008-2014 Netronome 181 of 256

**Instruction Count:** 3 to 5

#### Table 2.248. bits\_set parameters

| Name             | Description                                                                                     |
|------------------|-------------------------------------------------------------------------------------------------|
| io_data          | Register to modify                                                                              |
| in_start_bit_pos | Register or constant less than 32, starting bit position in_mask is shifted left by this amount |
| in_mask          | Register or constant, mask of bits to set                                                       |

## 2.21.2.29 multiply

## **Prototype:**

multiply(out\_result, in\_a, in\_b)

#### **Description**:

32-bit multiplication with 16x16 operand size.

This macro calculates:

out\_result = in\_a \* in\_b



#### Note

in\_b is known at compile time, so the pre-processor uses its bit value to construct an optimal multiply via ALU/shift operations. A simple implementation would take every 1-bit position n in in\_b, and shift and add mpy\_in by n to accumulate the out\_result. So if there were B 1-bits in in\_b, this would take B instructions -- up to 32. This implementation also uses subtraction, reducing the maximum number of instructions to 16. For example given in\_b = 123 = 1111011b 123x = 64x + 32x + 16x + 8x + 2x + 1x but also: 123x = 128x - 4x - 1x

**Performance:** n cycles: 1 to 16 Worst case performance is the number of 1 bits in in\_b. 0xxAAAAAAAA and 0x55555555 take the maximum 16 cycles. Actual performance depends on in\_b like so:

- 1. Spans of two or more 1's cost 2 cycles. 1a) The exception is if there is only 1 span of 1's and it is adjacent to bit 31 -- this costs 1 cycle.
- 2. Isolated 0's or 1's cost 1 cycle each.

#### **Resources:**

- Memory: no accesses, none consumed
- Registers: no additional registers, just out\_result & input parameters.
- Instructions = n: (n <= 16), as described Performance.

**Limitations:**mpy\_in and out\_result typically cannot be the same GPR. This is because add\_shf\_left and sub\_shf\_left macros will operate on both out\_result and mpy\_in in

© 2008-2014 Netronome 182 of 256

the same cycle and would result in a compile-time error. However, mpy\_in and out\_result can be the same GPR in cases where the macro expands to just a single instruction. For example, if in\_b is zero or a positive or negative even power of two.

**Algorithm:** Start scanning the in\_b from one end looking for the first 1-bit. If it is a single 1-bit, emit an add\_shift and continue. Otherwise, start counting 1-bits until you find two or more 0-bits in a row. Then add the first of the two zero bits, subtract the first 1-bit, and subtract any single 0-bits along the way.

**Condition Codes:** Data dependent: assume they are clobbered.

**Instruction Count:** 3 to 4

#### Table 2.249. multiply parameters

| Name       | Description                           |
|------------|---------------------------------------|
| out_result | Destination GPR                       |
| in_a       | Multiplicand, GPR                     |
| in_b       | Multiplier, any 32-bit input constant |

## 2.21.2.30 divide

## **Prototype:**

divide(out\_result, dividend, DIVISOR)

#### **Description:**

Divide.

This macro calculates:

out\_result = dividend / DIVISOR



#### Note

**Performance:** Variable/CONSTANT: 1 cycle CONSTANT/CONSTANT: 1 - 2 cycles

**Resources:** Memory: no accesses, none consumed. Registers: no additional registers, just out\_result and input parameters. Instructions: 1 or 2

**Limitations:** Power of 2 constant DIVISOR

**Algorithm:** Determine what DIV\_SHIFT yields (2^DIV\_SHIFT == DIVISOR). Right shift divisor by DIV\_SHIFT.

**Condition Codes:** Data dependent: assume they are clobbered.

© 2008-2014 Netronome 183 of 256

**Instruction Count:** 1 to 2

## Table 2.250. divide parameters

| Name       | Description                                                                                                                 |
|------------|-----------------------------------------------------------------------------------------------------------------------------|
| out_result | Destination GPR                                                                                                             |
| dividend   | GPR or CONSTANT                                                                                                             |
|            | GPR or CONSTANT For variable dividend DIVISOR must be constant power of 2 For CONSTANT dividend DIVISOR can be any CONSTANT |

# 2.21.2.31 array\_index\_from\_elem\_addr

## **Prototype:**

array\_index\_from\_elem\_addr(out\_index, in\_address, BASE\_ADDRESS, ELEMENT\_SIZE)

#### **Description:**

Convert an address into an array index.

This macro calculates:

out\_index = (in\_address / ELEMENT\_SIZE) - (BASE\_ADDRESS / ELEMENT\_SIZE)



## **Note**

**Limitations:** Attempts to compile for non power of 2 ELEMENT\_SIZE will fail because divide does not currently support non power of 2 divisors.

**Instruction Count:** 3 (Depends on ELEMENT\_SIZE and BASE\_ADDRESS)

Table 2.251. array\_index\_from\_elem\_addr parameters

| Name         | Description                                |
|--------------|--------------------------------------------|
| out_index    | Index of the array element                 |
| in_address   | Array element's address                    |
| BASE_ADDRESS | Memory Address of 1st element in the array |
| ELEMENT_SIZE | Size of Array Element in address units     |

# 2.21.2.32 elem\_addr\_from\_array\_index

#### **Prototype:**

elem\_addr\_from\_array\_index(out\_address, in\_index, BASE\_ADDRESS, ELEMENT\_SIZE)

#### **Description:**

© 2008-2014 Netronome 184 of 256

Convert an array element address to an array index.

This macro calculates:

```
if (ELEMENT_SIZE is power of 2)
  out_address = (in_index << BUF_DAFI_SHIFT) + BASE_ADDRESS
else
  out_address = (in_index * ELEMENT_SIZE) + BASE_ADDRESS</pre>
```

**Instruction Count:** 1 to 21 (Depends on ELEMENT\_SIZE and BASE\_ADDRESS). Best: 1 = 1 ALU. Typical: 3 = 2 immeds + 1 ALU. Worst: 21 = 4 immeds + 17 ALU

Table 2.252. elem\_addr\_from\_array\_index parameters

| Name         | Description                                |
|--------------|--------------------------------------------|
| out_address  | Address of the array element               |
| in_index     | Index of the array element                 |
| BASE_ADDRESS | Memory Address of 1st element in the array |
| ELEMENT_SIZE | Size of Array Element in address units     |

## 2.21.2.33 arith\_shf\_right

## **Prototype:**

```
arith_shf_right(out_result, in_src, in_shift_amt, SIGN_BIT_POS)
```

#### **Description**:

Shift right depend on the following cases:

1. If SIGN\_BIT\_POS is set to 31, no sign extend will occur, just arithmetic shift right.

#### Table 2.253. arith\_shf\_right parameters

| Name         | Description                                                                                             |
|--------------|---------------------------------------------------------------------------------------------------------|
| out_result   | Sign-extended shifted-right result                                                                      |
| in_src       | Source operand.                                                                                         |
| in_shift_amt | Register of constant right shift amount, values from 0-31 but cannot be greater than SIGN_BIT_POS value |
| SIGN_BIT_POS | Constant position of sign bit. 31 if in_src is already sign-extended.                                   |

# 2.21.2.34 multiply32

## **Prototype:**

```
multiply32(out_result, in_a, in_b, OPERAND_SIZE)
```

#### **Description:**

© 2008-2014 Netronome 185 of 256

32 bit multiply optimized for OPERAND\_SIZE specifications.

This macro calculates:

```
out_result = in_a * in_b
```

**Instruction Count:** 3 to 4 (3 for OP\_SIZE\_8x24 and 4 for OP\_SIZE\_16x16)

## Table 2.254. multiply32 parameters

| Name         | Description                                                          |
|--------------|----------------------------------------------------------------------|
| out_result   | 32 bit multiply result                                               |
| in_a         | Multiplicand                                                         |
| in_b         | Multiplier                                                           |
| OPERAND_SIZE | Operand size Valid sizes:                                            |
|              | • OP_SIZE_8x24: Multiplier is 8 bits, multiplicand is 24 bits (8x24) |
|              | • OP_SIZE_16X16: Multiplier and multiplicand are 16 bits (16x16)     |

# 2.21.2.35 multiply64

## **Prototype:**

multiply64(out\_result\_hi, out\_result\_lo, in\_a, in\_b, OPERAND\_SIZE)

## **Description**:

64 bit multiply optimized for OPERAND\_SIZE specifications.

This macro calculates:

```
out_result = in_a * in_b
```

**Instruction Count:** 5 to 7 (5 for OP\_SIZE\_16x32 and 7 for OP\_SIZE\_32x32)

## Table 2.255. multiply64 parameters

| Name          | Description                                                     |
|---------------|-----------------------------------------------------------------|
| out_result_hi | Most significant 32 bits of multiply result                     |
| out_result_lo | Least significant 32 bits of multiply result                    |
| in_a          | Multiplicand                                                    |
| in_b          | Multiplier                                                      |
| OPERAND_SIZE  | Operand size Valid sizes:                                       |
|               | • OP_SIZE_16X32: Multiplier is 16 bits, multiplicand is 32 bits |
|               | • OP_SIZE_32X32: Multiplier and multiplicand are 32 bits        |

© 2008-2014 Netronome 186 of 256

## 2.21.2.36 rand

**Prototype:** 

rand(out\_result)

**Description**:

Generate a pseudo-random number.

## Table 2.256. rand parameters

| Name       | Description   |
|------------|---------------|
| out_result | Random number |

## 2.21.2.37 srand

**Prototype:** 

srand(in\_src)

**Description**:

Set pseudo-random number seed.

#### Table 2.257. srand parameters

| Name   | Description                              |
|--------|------------------------------------------|
| in_src | Random number seed, constant or register |

# 2.22 Override Macros

# 2.22.1 Override flags

Names of flags that can be provided to fields that can be provided to ov\_global(), ov\_start(), ov\_set\*() and ov\_\*use() to fine-tune the functionality provided by these macros.Flags provided to ov\_global() are the default flags used every time ov\_start() is called. ov\_global() can be called at any time, but the value is only used during a call to ov\_start().Flags provided to ov\_start() override the current global flags, and are used for the entire indirect reference, even if it is stored and later recalled or resumed.Flags provided to ov\_set\*() and ov\_\*use() override the current indirect reference's flags, and are used for only that specific macro.

## 2.22.2.1 ov\_global\_flags

#### **Prototype:**

© 2008-2014 Netronome 187 of 256

ov\_global\_flags(FLAGS)

#### **Description:**

Set the values of the global flags, from this point forward.

This macro can be called at any time. A copy of these flags is used as a starting point when ov\_start() is called.

#### **Example:**

```
ov_global_flags((OVF_NO_CTX_SWAP_OFF | OVF_RELAXED_ORDER_ON))
```

Condition Codes: Unchanged

**Instruction Count:** None - only preprocessor

## Table 2.258. ov\_global\_flags parameters

| Name  | Description                                                                                      |
|-------|--------------------------------------------------------------------------------------------------|
| FLAGS | Zero or more flags from Override flags, ORd together. Flags not specified are assumed to be _OFF |

## 2.22.2.2 ov\_start

## **Prototype:**

ov\_start(OVERRIDE\_TYPES, FLAGS)

#### **Description**:

Start an indirect reference.

This macro creates the context within which the indirect reference is determined. It is always the first step of an indirect reference, and may only be called if an indirect reference is not already in progress.

#### **Example:**

ov\_start((OV\_LENGTH | OV\_DATA\_REF), OVF\_REUSE\_ON)



#### Note

The validity of the provided parameters are checked against the indirect reference environment currently being compiled for.



## **Note**

Constants ORd together must be enclosed within round brackets.

**Condition Codes:** Unchanged

© 2008-2014 Netronome 188 of 256

**Instruction Count:** None - only preprocessor

#### Table 2.259. ov\_start parameters

| Name           | Description                                                                                                                                                                                                                        |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OVERRIDE_TYPES | One or more override fields from Override fields, ORd together.                                                                                                                                                                    |
| FLAGS          | Optional: Zero or more flags from Override flags, ORd together, which are used for the entire duration of this indirect reference. Flags specified here override the global flags most recently specified using ov_global_flags(). |

## 2.22.2.3 ov\_set\_bits

#### **Prototype:**

```
ov_set_bits(OVERRIDE_TYPE, BIT_MASK, BIT_CONSTANT)
```

## **Description**:

Set bits within the mask of the indicated field to the provided value.

This macro is typically useful to specify constant bits that indicate which subcommand is required.

#### **Example:**

```
ov_start(OV_LENGTH)
ov_set_bits(OV_LENGTH, 0b11000, 0b01000) // Clear bit 4 and set bit 3
ov_set(OV_LENGTH, 2, 0, 3)
ov_use()
command[...], indirect_ref
ov_clean()
```



## **Note**

BIT\_MASK and BIT\_CONSTANT must be constant values.

Condition Codes: Unchanged

**Instruction Count:** None - only preprocessor

## Table 2.260. ov\_set\_bits parameters

| Name          | Description                                                                                                                                    |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| OVERRIDE_TYPE | One override field from Override fields that was specified in ov_start().                                                                      |
|               | Mask indicating which bits must be set. Valid formats are decimal, hexadecimal and binary (prefixed with "0b").                                |
|               | Constant indicating value of bit for each bit set in <i>BIT_MASK</i> . Valid formats are decimal, hexadecimal and binary (prefixed with "0b"). |

© 2008-2014 Netronome 189 of 256

## 2.22.2.4 ov set bits

## **Prototype:**

```
ov_set_bits(OVERRIDE_TYPE, DST_MSB, DST_LSB, BIT_CONSTANT)
```

## **Description**:

Set the specific range of bits in the indicated field to the provided value.

This macro is typically useful to specify a range of constant bits that are not used in the instruction that this indirect reference is going to be used with.

#### **Example:**

```
ov_start(OV_LENGTH)
ov_set_bits(OV_LENGTH, 4, 3, 0) // Clear bits 4 and 3
ov_set(OV_LENGTH, 2, 0, 3)
ov_use()
command[...], indirect_ref
ov_clean()
```



#### Note

BIT\_CONSTANT is relative to DST\_LSB, i.e. BIT\_CONSTANT will be shifted to the left by DST\_LSB before being used.

Condition Codes: Unchanged

**Instruction Count:** None - only preprocessor

## Table 2.261. ov\_set\_bits parameters

| Name          | Description                                                               |
|---------------|---------------------------------------------------------------------------|
| OVERRIDE_TYPE | One override field from Override fields that was specified in ov_start(). |
| DST_MSB       | Most significant bit within field <i>OVERRIDE_TYPE</i> to set.            |
| DST_LSB       | Least significant bit within field <i>OVERRIDE_TYPE</i> to set.           |
| BIT_CONSTANT  | Constant to set the bits DST_MSB:DST_LSB to.                              |

## 2.22.2.5 ov\_set

## **Prototype:**

```
ov_set(OVERRIDE_TYPE, DST_MSB, DST_LSB, in_value, FLAGS)
```

#### **Description**:

Set the specific range of bits in the indicated field to the provided value, taking the provided flags into account.

© 2008-2014 Netronome 190 of 256

#### **Example:**

```
ov_start(OV_LENGTH)
ov_set(OV_LENGTH, 4, 4, 0)
ov_set(OV_LENGTH, 3, 0, 1, OVF_RELAXED_ORDER_ON)
ov_use()
command[...], indirect_ref
ov_clean()
```



#### **Note**

*in\_value* is relative to *DST\_LSB*, i.e. in\_value will be shifted to the left by *DST\_LSB* before being used.

Condition Codes: Clobbered (in\_value a register value) or unchanged (in\_value a constant).

**Instruction Count:** One or more (in\_value a register value) or zero (in\_value a constant).

#### Table 2.262. ov\_set parameters

| Name          | Description                                                                                                                                |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| OVERRIDE_TYPE | One override field from Override fields that was specified in ov_start().                                                                  |
| DST_MSB       | Most significant bit within field <i>OVERRIDE_TYPE</i> to set.                                                                             |
| DST_LSB       | Least significant bit within field <i>OVERRIDE_TYPE</i> to set.                                                                            |
| in_value      | Value to set the bits DST_MSB:DST_LSB to. May be a constant or a register value.                                                           |
| FLAGS         | Optional: Zero or more flags from Override flags, ORd together, which, for just this macro call, overrides the indirect reference's flags. |

## 2.22.2.6 ov\_set

## **Prototype:**

```
ov_set(OVERRIDE_TYPE, in_value, FLAGS)
```

#### **Description:**

Set the indicated field to the provided value, taking the provided flags into account.

#### **Example:**

```
ov_start(OV_LENGTH)
ov_set(OV_LENGTH, 12, OVF_SUBTRACT_ONE)
ov_use()
command[...], indirect_ref
ov_clean()
```

Condition Codes: Clobbered (in\_value a register value) or unchanged (in\_value a constant).

**Instruction Count:** One or more (in value a register value) or zero (in value a constant).

© 2008-2014 Netronome 191 of 256

#### Table 2.263. ov\_set parameters

| Name          | Description                                                                                                                                |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| OVERRIDE_TYPE | One override field from Override fields that was specified in ov_start().                                                                  |
| in_value      | Value to set field <i>OVERRIDE_TYPE</i> to. May be a constant or a register value.                                                         |
|               | Optional: Zero or more flags from Override flags, ORd together, which, for just this macro call, overrides the indirect reference's flags. |

## 2.22.2.7 ov set bm and

## **Prototype:**

```
ov_set_bm_and(in_byte_mask, OVERRIDE_TYPE, DST_MSB, DST_LSB, in_value, FLAGS)
```

#### **Description**:

Set the OV\_BYTE\_MASK field to the provided value and also set the specific range of bits in the indicated field to the provided value, taking the provided flags into account.



## **Note**

This macro is functionally equivalent to the following, except that it produces more efficient code:

```
ov_set(OV_BYTE_MASK, in_byte_mask)
ov_set(OVERRIDE_TYPE, DST_MSB, DST_LSB, in_value, FLAGS)
```

## **Example:**



## **Note**

The parameter *in\_byte\_mask* is used in its entirety as is. No provided parameters are applicable to it.

*in\_value* is relative to *DST\_LSB*, i.e. in\_value will be shifted to the left by *DST\_LSB* before being used.

© 2008-2014 Netronome 192 of 256

Condition Codes: Clobbered

**Instruction Count:** One or more

## Table 2.264. ov\_set\_bm\_and parameters

| Name          | Description                                                                                                                                |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| in_byte_mask  | Value to be used for override field OV_BYTE_MASK.                                                                                          |
| OVERRIDE_TYPE | One override field from Override fields that was specified in ov_start().                                                                  |
| DST_MSB       | Most significant bit within field <i>OVERRIDE_TYPE</i> to set.                                                                             |
| DST_LSB       | Least significant bit within field <i>OVERRIDE_TYPE</i> to set.                                                                            |
| in_value      | Value to set the bits <i>DST_MSB</i> :DST_LSB <i>inOVERRIDE_TYPE</i> to. May be a constant or a register value.                            |
| FLAGS         | Optional: Zero or more flags from Override flags, ORd together, which, for just this macro call, overrides the indirect reference's flags. |

## 2.22.2.8 ov\_set\_bm\_and

## **Prototype:**

```
ov_set_bm_and(in_byte_mask, OVERRIDE_TYPE, in_value, FLAGS)
```

#### **Description:**

Set the OV\_BYTE\_MASK field to the provided value and also set the indicated field to the provided value, taking the provided flags into account.



#### Note

This macro is functionally equivalent to the following, except that it produces more efficient code:

```
ov_set(OV_BYTE_MASK, in_byte_mask)
ov_set(OVERRIDE_TYPE, in_value, FLAGS)
```

## **Example:**

© 2008-2014 Netronome 193 of 256



The parameter *in\_byte\_mask* is used in its entirety as is. No provided parameters are applicable to it.

Condition Codes: Clobbered

**Instruction Count:** One or more

#### Table 2.265. ov set bm and parameters

| Name          | Description                                                                                                                                |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| in_byte_mask  | Value to be used for override field OV_BYTE_MASK.                                                                                          |
| OVERRIDE_TYPE | One override field from Override fields that was specified in ov_start().                                                                  |
| in_value      | Value to set the field <i>OVERRIDE_TYPE</i> to. May be a constant or a register value.                                                     |
| FLAGS         | Optional: Zero or more flags from Override flags, ORd together, which, for just this macro call, overrides the indirect reference's flags. |

## 2.22.2.9 ov\_set\_extract

#### **Prototype:**

```
ov_set_extract(OVERRIDE_TYPE, DST_MSB, DST_LSB, in_value, SRC_MSB, SRC_LSB, FLAGS)
```

#### **Description:**

Set the specific range of bits in the indicated field to the extracted range of bits in the provided value, taking the provided flags into account.

The data is extracted from *in\_value*, meaning that bits set in *in\_value* outside the range *SRC\_MSB*:SRC\_LSB *have* no effect on the indirect reference.

#### **Example:**

```
ov_start(OV_LENGTH)
ov_set(OV_LENGTH, 4, 4, 0)
ov_set_extract(OV_LENGTH, 3, 0, value, 12, 9, OVF_RELAXED_ORDER_ON)
ov_use()
command[...], indirect_ref
ov_clean()
```



#### **Note**

Bits in the range *SRC\_MSB:*SRC\_LSB *are* extracted from in\_value, and are placed in the indicated field relative to *DST\_LSB* and , i.e. in\_value will be masked and effectively shifted to the left by (*DST\_LSB - SRC\_LSB*) bit positions before being used.

Condition Codes: Clobbered (in\_value a register value) or unchanged (in\_value a constant).

© 2008-2014 Netronome 194 of 256

**Instruction Count:** Two or more (in\_value a register value) or zero (in\_value a constant).

Table 2.266. ov\_set\_extract parameters

| Name          | Description                                                                                                                                |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| OVERRIDE_TYPE | One override field from Override fields that was specified in ov_start().                                                                  |
| DST_MSB       | Most significant bit within field <i>OVERRIDE_TYPE</i> to set.                                                                             |
| DST_LSB       | Least significant bit within field OVERRIDE_TYPE to set.                                                                                   |
| in_value      | Value to set the bits DST_MSB:DST_LSB to. May be a constant or a register value.                                                           |
| SRC_MSB       | Most significant bit within field <i>in_value</i> to use.                                                                                  |
| SRC_LSB       | Least significant bit within field <i>in_value</i> to use.                                                                                 |
| FLAGS         | Optional: Zero or more flags from Override flags, ORd together, which, for just this macro call, overrides the indirect reference's flags. |

## 2.22.2.10 ov\_set\_extract

#### **Prototype:**

```
ov_set_extract(OVERRIDE_TYPE, in_value, SRC_MSB, SRC_LSB, FLAGS)
```

#### **Description:**

Set the value of the indicated field to the extracted range of bits in the provided value, taking the provided flags into account.

The data is extracted from *in\_value*, meaning that bits set in *in\_value* outside the range *SRC\_MSB*:SRC\_LSB *have* no effect on the indirect reference.

#### **Example:**

```
ov_start(OV_LENGTH)
ov_set_extract(OV_LENGTH, value, 13, 9)
ov_use()
command[...], indirect_ref
ov_clean()
```



## **Note**

Bits in the range *SRC\_MSB*:SRC\_LSB *are* extracted from in\_value, and are placed in the indicated field, i.e. in\_value will be masked and effectively shifted to the right by *SRC\_LSB* bit positions before being used.

Condition Codes: Clobbered (in\_value a register value) or unchanged (in\_value a constant).

**Instruction Count:** Two or more (in\_value a register value) or zero (in\_value a constant).

© 2008-2014 Netronome 195 of 256

Table 2.267. ov\_set\_extract parameters

| Name          | Description                                                                                                                                |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| OVERRIDE_TYPE | One override field from Override fields that was specified in ov_start().                                                                  |
| in_value      | Value to set the bits DST_MSB:DST_LSB to. May be a constant or a register value.                                                           |
| SRC_MSB       | Most significant bit within field <i>in_value</i> to use.                                                                                  |
| SRC_LSB       | Least significant bit within field <i>in_value</i> to use.                                                                                 |
| FLAGS         | Optional: Zero or more flags from Override flags, ORd together, which, for just this macro call, overrides the indirect reference's flags. |

## 2.22.2.11 ov\_set\_bm\_and\_extract

#### **Prototype:**

```
ov_set_bm_and_extract(in_byte_mask, OVERRIDE_TYPE, DST_MSB, DST_LSB, in_value, SRC_MSB,
SRC_LSB, FLAGS)
```

#### **Description**:

Set the OV\_BYTE\_MASK field to the provided value and also set the specific range of bits in the indicated field to the extracted range of bits in the provided value, taking the provided flags into account.



#### Note

This macro is functionally equivalent to the following, except that it produces more efficient code:

The data for the indicated field is extracted from *in\_value*, meaning that bits set in *in\_value* outside the range *SRC\_MSB*:SRC\_LSB *have* no effect on the indirect reference.

#### **Example:**

© 2008-2014 Netronome 196 of 256



Bits in the range *SRC\_MSB*:SRC\_LSB *are* extracted from in\_value, and are placed in the indicated field relative to *DST\_LSB* and , i.e. in\_value will be masked and effectively shifted to the left by (*DST\_LSB* - *SRC\_LSB*) bit positions before being used.

**Condition Codes:** Clobbered (in\_value a register value) or unchanged (in\_value a constant).

**Instruction Count:** Two or more (in\_value a register value) or zero (in\_value a constant).

Table 2.268. ov\_set\_bm\_and\_extract parameters

| Name          | Description                                                                                                                                |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| in_byte_mask  | Value to be used for override field OV_BYTE_MASK.                                                                                          |
| OVERRIDE_TYPE | One override field from Override fields that was specified in ov_start().                                                                  |
| DST_MSB       | Most significant bit within field <i>OVERRIDE_TYPE</i> to set.                                                                             |
| DST_LSB       | Least significant bit within field <i>OVERRIDE_TYPE</i> to set.                                                                            |
| in_value      | Value to set the bits DST_MSB:DST_LSB to. May be a constant or a register value.                                                           |
| SRC_MSB       | Most significant bit within field <i>in_value</i> to use.                                                                                  |
| SRC_LSB       | Least significant bit within field <i>in_value</i> to use.                                                                                 |
| FLAGS         | Optional: Zero or more flags from Override flags, ORd together, which, for just this macro call, overrides the indirect reference's flags. |

## 2.22.2.12 ov\_set\_bm\_and\_extract

#### **Prototype:**

ov\_set\_bm\_and\_extract(in\_byte\_mask, OVERRIDE\_TYPE, in\_value, SRC\_MSB, SRC\_LSB, FLAGS)

#### **Description**:

Set the OV\_BYTE\_MASK field to the provided value and also set the value of the indicated field to the extracted range of bits in the provided value, taking the provided flags into account.



#### Note

This macro is functionally equivalent to the following, except that it produces more efficient code:

```
ov_set(OV_BYTE_MASK, in_byte_mask)
ov_set_extract(OVERRIDE_TYPE, in_value, SRC_MSB, SRC_LSB, FLAGS)
```

The data for the indicated field is extracted from *in\_value*, meaning that bits set in *in\_value* outside the range *SRC MSB*:SRC LSB *have* no effect on the indirect reference.

© 2008-2014 Netronome 197 of 256

#### **Example:**



#### **Note**

Bits in the range *SRC\_MSB*:SRC\_LSB *are* extracted from in\_value, and are placed in the indicated field, i.e. in\_value will be masked and effectively shifted to the right by *SRC\_LSB* bit positions before being used.

**Condition Codes:** Clobbered (in\_value a register value) or unchanged (in\_value a constant).

**Instruction Count:** Two or more (in\_value a register value) or zero (in\_value a constant).

Table 2.269. ov\_set\_bm\_and\_extract parameters

| Name          | Description                                                                                                                                |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| in_byte_mask  | Value to be used for override field OV_BYTE_MASK.                                                                                          |
| OVERRIDE_TYPE | One override field from Override fields that was specified in ov_start().                                                                  |
| in_value      | Value to set the bits DST_MSB:DST_LSB to. May be a constant or a register value.                                                           |
| SRC_MSB       | Most significant bit within field <i>in_value</i> to use.                                                                                  |
| SRC_LSB       | Least significant bit within field <i>in_value</i> to use.                                                                                 |
| FLAGS         | Optional: Zero or more flags from Override flags, ORd together, which, for just this macro call, overrides the indirect reference's flags. |

## 2.22.2.13 ov\_set\_use

## **Prototype:**

```
ov_set_use(OVERRIDE_TYPE, DST_MSB, DST_LSB, in_value, FLAGS)
```

## **Description**:

Set the specific range of bits in the indicated field to the provided value, taking the provided flags into account, and then populates CMD\_INDIRECT\_REF\_0, if appropriate, and sets the value of previous ALU output.

© 2008-2014 Netronome 198 of 256



This macro is functionally equivalent to the following, except that it produces more efficient code:

```
ov_set(OVERRIDE_TYPE, DST_MSB, DST_LSB, in_value, FLAGS)
ov_use()
```

## **Example:**

```
ov_start(OV_LENGTH)
ov_set(OV_LENGTH, 4, 4, 0)
ov_set_use(OV_LENGTH, 3, 0, 1, OVF_RELAXED_ORDER_ON)
command[...], indirect_ref
ov_clean()
```



## **Note**

*in\_value* is relative to *DST\_LSB*, i.e. in\_value will be shifted to the left by *DST\_LSB* before being used.

Condition Codes: Clobbered

**Instruction Count:** One to six

#### Table 2.270. ov\_set\_use parameters

| Name          | Description                                                                                                                                |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| OVERRIDE_TYPE | One override field from Override fields that was specified in ov_start().                                                                  |
| DST_MSB       | Most significant bit within field <i>OVERRIDE_TYPE</i> to set.                                                                             |
| DST_LSB       | Least significant bit within field OVERRIDE_TYPE to set.                                                                                   |
| in_value      | Value to set the bits DST_MSB:DST_LSB to. May be a constant or a register value.                                                           |
| FLAGS         | Optional: Zero or more flags from Override flags, ORd together, which, for just this macro call, overrides the indirect reference's flags. |

## 2.22.2.14 ov\_set\_use

## **Prototype:**

```
ov_set_use(OVERRIDE_TYPE, in_value, FLAGS)
```

#### **Description**:

Set the indicated field to the provided value, taking the provided flags into account, and then populates CMD\_INDIRECT\_REF\_0, if appropriate, and sets the value of previous ALU output.

© 2008-2014 Netronome 199 of 256



This macro is functionally equivalent to the following, except that it produces more efficient code:

```
ov_set(OVERRIDE_TYPE, in_value, FLAGS)
ov_use()
```

#### **Example:**

```
ov_start(OV_LENGTH)
ov_set_use(OV_LENGTH, 12, OVF_SUBTRACT_ONE)
command[...], indirect_ref
ov_clean()
```

Condition Codes: Clobbered

**Instruction Count:** One to six

#### Table 2.271. ov\_set\_use parameters

| Name          | Description                                                                                                                                |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| OVERRIDE_TYPE | One override field from Override fields that was specified in ov_start().                                                                  |
| in_value      | Value to set field <i>OVERRIDE_TYPE</i> to. May be a constant or a register value.                                                         |
|               | Optional: Zero or more flags from Override flags, ORd together, which, for just this macro call, overrides the indirect reference's flags. |

# 2.22.2.15 ov\_set\_bm\_and\_use

## **Prototype:**

```
ov_set_bm_and_use(in_byte_mask, OVERRIDE_TYPE, DST_MSB, DST_LSB, in_value, FLAGS)
```

#### **Description**:

Set the OV\_BYTE\_MASK field to the provided value and also set the specific range of bits in the indicated field to the provided value, taking the provided flags into account, and then populates CMD\_INDIRECT\_REF\_0, if appropriate, and sets the value of previous ALU output.



## **Note**

This macro is functionally equivalent to the following, except that it produces more efficient code:

```
ov_set(OV_BYTE_MASK, in_byte_mask)
ov_set(OVERRIDE_TYPE, DST_MSB, DST_LSB, in_value, FLAGS)
ov_use()
```

© 2008-2014 Netronome 200 of 256

#### **Example:**

```
ov_start((OV_LENGTH | OV_BYTE_MASK | OV_DATA_REF | OV_DATA_MASTER))
ov_set(OV_DATA_REF, data_ref)
ov_set(OV_LENGTH, len, OVF_SUBTRACT_ONE)
ov_set(OV_DATA_MASTER, 3, 2, 0)
ov_set_bm_and_use(byte_mask, OV_DATA_MASTER, 1, 0, data_master, OVF_PARANOID_ON)
command[...], indirect_ref
ov_clean()
```



#### **Note**

The parameter *in\_byte\_mask* is used in its entirety as is. No provided parameters are applicable to it.

*in\_value* is relative to *DST\_LSB*, i.e. in\_value will be shifted to the left by *DST\_LSB* before being used.

**Condition Codes:** Clobbered

**Instruction Count:** One to six

Table 2.272. ov\_set\_bm\_and\_use parameters

| Name          | Description                                                                                                                                |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| in_byte_mask  | Value to be used for override field OV_BYTE_MASK.                                                                                          |
| OVERRIDE_TYPE | One override field from Override fields that was specified in ov_start().                                                                  |
| DST_MSB       | Most significant bit within field <i>OVERRIDE_TYPE</i> to set.                                                                             |
| DST_LSB       | Least significant bit within field <i>OVERRIDE_TYPE</i> to set.                                                                            |
| in_value      | Value to set the bits <i>DST_MSB</i> :DST_LSB <i>inOVERRIDE_TYPE</i> to. May be a constant or a register value.                            |
| FLAGS         | Optional: Zero or more flags from Override flags, ORd together, which, for just this macro call, overrides the indirect reference's flags. |

## 2.22.2.16 ov\_set\_bm\_and\_use

#### **Prototype:**

```
\verb|ov_set_bm_and_use(in\_byte_mask, OVERRIDE_TYPE, in\_value, FLAGS)|\\
```

#### **Description:**

Set the OV\_BYTE\_MASK field to the provided value and also set the indicated field to the provided value, taking the provided flags into account, and then populates CMD\_INDIRECT\_REF\_0, if appropriate, and sets the value of previous ALU output.

© 2008-2014 Netronome 201 of 256



This macro is functionally equivalent to the following, except that it produces more efficient code:

```
ov_set(OV_BYTE_MASK, in_byte_mask)
ov_set(OVERRIDE_TYPE, in_value, FLAGS)
ov_use()
```

#### **Example:**

```
ov_start((OV_LENGTH | OV_BYTE_MASK | OV_DATA_REF | OV_DATA_MASTER))
ov_set(OV_LENGTH, len, OVF_SUBTRACT_ONE)
ov_set(OV_DATA_REF, data_ref)
ov_set_bm_and_use(byte_mask, OV_DATA_MASTER, data_master, OVF_PARANOID_ON)
command[...], indirect_ref
ov_clean()
```



## **Note**

The parameter *in\_byte\_mask* is used in its entirety as is. No provided parameters are applicable to it.

Condition Codes: Clobbered

**Instruction Count:** Two to six, or more, depending on flags

Table 2.273. ov\_set\_bm\_and\_use parameters

| Name          | Description                                                                                                                                |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| in_byte_mask  | Value to be used for override field OV_BYTE_MASK.                                                                                          |
| OVERRIDE_TYPE | One override field from Override fields that was specified in ov_start().                                                                  |
| in_value      | Value to set the field <i>OVERRIDE_TYPE</i> to. May be a constant or a register value.                                                     |
| FLAGS         | Optional: Zero or more flags from Override flags, ORd together, which, for just this macro call, overrides the indirect reference's flags. |

## 2.22.2.17 ov\_set\_extract\_use

## **Prototype:**

```
ov_set_extract_use(OVERRIDE_TYPE, DST_MSB, DST_LSB, in_value, SRC_MSB, SRC_LSB, FLAGS)
```

## **Description**:

Set the specific range of bits in the indicated field to the extracted range of bits in the provided value, taking the provided flags into account, and then populates CMD\_INDIRECT\_REF\_0, if appropriate, and sets the value of previous ALU output.

© 2008-2014 Netronome 202 of 256



This macro is functionally equivalent to the following, except that it produces more efficient code:

The data is extracted from *in\_value*, meaning that bits set in *in\_value* outside the range *SRC\_MSB*:SRC\_LSB *have* no effect on the indirect reference.

## **Example:**

```
ov_start(OV_LENGTH)
ov_set(OV_LENGTH, 4, 4, 0)
ov_set_extract_use(OV_LENGTH, 3, 0, value, 12, 9, OVF_RELAXED_ORDER_ON)
command[...], indirect_ref
ov_clean()
```



#### Note

Bits in the range *SRC\_MSB*:SRC\_LSB *are* extracted from in\_value, and are placed in the indicated field relative to *DST\_LSB* and , i.e. in\_value will be masked and effectively shifted to the left by (*DST\_LSB* - *SRC\_LSB*) bit positions before being used.

Condition Codes: Clobbered

**Instruction Count:** Two to six, or more, depending on flags

Table 2.274. ov\_set\_extract\_use parameters

| Name          | Description                                                                                                                                |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| OVERRIDE_TYPE | One override field from Override fields that was specified in ov_start().                                                                  |
| DST_MSB       | Most significant bit within field <i>OVERRIDE_TYPE</i> to set.                                                                             |
| DST_LSB       | Least significant bit within field <i>OVERRIDE_TYPE</i> to set.                                                                            |
| in_value      | Value to set the bits DST_MSB:DST_LSB to. May be a constant or a register value.                                                           |
| SRC_MSB       | Most significant bit within field <i>in_value</i> to use.                                                                                  |
| SRC_LSB       | Least significant bit within field <i>in_value</i> to use.                                                                                 |
| FLAGS         | Optional: Zero or more flags from Override flags, ORd together, which, for just this macro call, overrides the indirect reference's flags. |

## 2.22.2.18 ov\_set\_extract\_use

## **Prototype:**

© 2008-2014 Netronome 203 of 256

ov\_set\_extract\_use(OVERRIDE\_TYPE, in\_value, SRC\_MSB, SRC\_LSB, FLAGS)

#### **Description:**

Set the value of the indicated field to the extracted range of bits in the provided value, taking the provided flags into account, and then populates CMD\_INDIRECT\_REF\_0, if appropriate, and sets the value of previous ALU output.



## **Note**

This macro is functionally equivalent to the following, except that it produces more efficient code:

```
ov_set_extract(OVERRIDE_TYPE, in_value, SRC_MSB, SRC_LSB, FLAGS)
ov_use()
```

The data is extracted from *in\_value*, meaning that bits set in *in\_value* outside the range *SRC\_MSB*:SRC\_LSB *have* no effect on the indirect reference.

#### **Example:**

```
ov_start(OV_LENGTH)
ov_set_extract_use(OV_LENGTH, value, 13, 9)
command[...], indirect_ref
ov_clean()
```



## **Note**

Bits in the range *SRC\_MSB*:SRC\_LSB *are* extracted from in\_value, and are placed in the indicated field, i.e. in\_value will be masked and effectively shifted to the right by *SRC\_LSB* bit positions before being used.

Condition Codes: Clobbered

**Instruction Count:** Two to six, or more, depending on flags

Table 2.275. ov\_set\_extract\_use parameters

| Name          | Description                                                                                                                                |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| OVERRIDE_TYPE | One override field from Override fields that was specified in ov_start().                                                                  |
| in_value      | Value to set the bits DST_MSB:DST_LSB to. May be a constant or a register value.                                                           |
| SRC_MSB       | Most significant bit within field <i>in_value</i> to use.                                                                                  |
| SRC_LSB       | Least significant bit within field <i>in_value</i> to use.                                                                                 |
| FLAGS         | Optional: Zero or more flags from Override flags, ORd together, which, for just this macro call, overrides the indirect reference's flags. |

© 2008-2014 Netronome 204 of 256

## 2.22.2.19 ov set bm and extract use

#### **Prototype:**

ov\_set\_bm\_and\_extract\_use(in\_byte\_mask, OVERRIDE\_TYPE, DST\_MSB, DST\_LSB, in\_value, SRC\_MSB,
SRC\_LSB, FLAGS)

#### **Description**:

Set the OV\_BYTE\_MASK field to the provided value and also set the specific range of bits in the indicated field to the extracted range of bits in the provided value, taking the provided flags into account, and then populates CMD\_INDIRECT\_REF\_0, if appropriate, and sets the value of previous ALU output.



#### **Note**

This macro is functionally equivalent to the following, except that it produces more efficient code:

The data for the indicated field is extracted from *in\_value*, meaning that bits set in *in\_value* outside the range *SRC\_MSB*:SRC\_LSB *have* no effect on the indirect reference.

## **Example:**

```
ov_start((OV_LENGTH | OV_BYTE_MASK | OV_DATA_REF | OV_DATA_MASTER))
ov_set(OV_DATA_MASTER, 3, 2, 0)
ov_set(OV_DATA_REF, data_ref)
ov_set(OV_LENGTH, len, OVF_SUBTRACT_ONE)
ov_set_bm_and_extract_use(byte_mask, OV_DATA_MASTER, 1, 0, data_master, 5, 4)
command[...], indirect_ref
ov_clean()
```



#### **Note**

Bits in the range *SRC\_MSB*:SRC\_LSB *are* extracted from in\_value, and are placed in the indicated field relative to *DST\_LSB* and , i.e. in\_value will be masked and effectively shifted to the left by (*DST\_LSB* - *SRC\_LSB*) bit positions before being used.

Condition Codes: Clobbered

**Instruction Count:** Two to six, or more, depending on flags

© 2008-2014 Netronome 205 of 256

Table 2.276. ov\_set\_bm\_and\_extract\_use parameters

| Name          | Description                                                                                                                                |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| in_byte_mask  | Value to be used for override field OV_BYTE_MASK.                                                                                          |
| OVERRIDE_TYPE | One override field from Override fields that was specified in ov_start().                                                                  |
| DST_MSB       | Most significant bit within field <i>OVERRIDE_TYPE</i> to set.                                                                             |
| DST_LSB       | Least significant bit within field <i>OVERRIDE_TYPE</i> to set.                                                                            |
| in_value      | Value to set the bits DST_MSB:DST_LSB to. May be a constant or a register value.                                                           |
| SRC_MSB       | Most significant bit within field <i>in_value</i> to use.                                                                                  |
| SRC_LSB       | Least significant bit within field <i>in_value</i> to use.                                                                                 |
| FLAGS         | Optional: Zero or more flags from Override flags, ORd together, which, for just this macro call, overrides the indirect reference's flags. |

## 2.22.2.20 ov\_set\_bm\_and\_extract\_use

#### **Prototype:**

```
ov_set_bm_and_extract_use(in_byte_mask, OVERRIDE_TYPE, in_value, SRC_MSB, SRC_LSB, FLAGS)
```

#### **Description:**

Set the OV\_BYTE\_MASK field to the provided value and also set the value of the indicated field to the extracted range of bits in the provided value, taking the provided flags into account, and then populates CMD\_INDIRECT\_REF\_0, if appropriate, and sets the value of previous ALU output.



## Note

This macro is functionally equivalent to the following, except that it produces more efficient code:

```
ov_set(OV_BYTE_MASK, in_byte_mask)
ov_set_extract(OVERRIDE_TYPE, in_value, SRC_MSB, SRC_LSB, FLAGS)
ov_use()
```

The data for the indicated field is extracted from *in\_value*, meaning that bits set in *in\_value* outside the range *SRC\_MSB*:SRC\_LSB *have* no effect on the indirect reference.

#### **Example:**

```
ov_start((OV_LENGTH | OV_BYTE_MASK | OV_DATA_REF | OV_DATA_MASTER))
ov_set(OV_DATA_REF, data_ref)
ov_set(OV_LENGTH, len, OVF_SUBTRACT_ONE)
ov_set_bm_and_extract_use(byte_mask, OV_DATA_MASTER, data_master, 7, 4)
command[...], indirect_ref
ov_clean()
```

© 2008-2014 Netronome 206 of 256



Bits in the range *SRC\_MSB*:SRC\_LSB *are* extracted from in\_value, and are placed in the indicated field, i.e. in\_value will be masked and effectively shifted to the right by *SRC\_LSB* bit positions before being used.

Condition Codes: Clobbered

**Instruction Count:** Two to six, or more, depending on flags

Table 2.277. ov\_set\_bm\_and\_extract\_use parameters

| Name          | Description                                                                                                                                |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| in_byte_mask  | Value to be used for override field OV_BYTE_MASK.                                                                                          |
| OVERRIDE_TYPE | One override field from Override fields that was specified in ov_start().                                                                  |
| in_value      | Value to set the bits DST_MSB:DST_LSB to. May be a constant or a register value.                                                           |
| SRC_MSB       | Most significant bit within field <i>in_value</i> to use.                                                                                  |
| SRC_LSB       | Least significant bit within field <i>in_value</i> to use.                                                                                 |
| FLAGS         | Optional: Zero or more flags from Override flags, ORd together, which, for just this macro call, overrides the indirect reference's flags. |

## 2.22.2.21 ov\_use

#### **Prototype:**

ov\_use(FLAGS)

## **Description**:

Use the current indirect reference, in accordance with the provided flags.

This macro populates CMD\_INDIRECT\_REF\_0, if appropriate, and then sets the value of previous ALU output.



#### Note

The next instruction after calling this macro must be the instruction that requires the indirect reference.

## **Example:**

```
ov_start(OV_LENGTH, OVF_REUSE_ON)
ov_set(OV_LENGTH, 12, OVF_SUBTRACT_ONE)
ov_use()
command[...], indirect_ref
ov_use(OVF_NO_SWAP_SINCE_USE)
command[...], indirect_ref
ov_clean()
```

© 2008-2014 Netronome 207 of 256

Condition Codes: Clobbered

**Instruction Count:** One to six

## Table 2.278. ov\_use parameters

| Name  | Description                                                                                   |
|-------|-----------------------------------------------------------------------------------------------|
| FLAGS | Optional: The only flag that may be specified is OVF_NO_SWAP_SINCE_USE. This flag may only be |
|       | specified on the second or subsequent use of the current indirect reference.                  |

## 2.22.2.22 ov\_clean

## **Prototype:**

ov\_clean()

#### **Description**:

Release resources used by the current indirect reference.

After calling this macro, the indirect reference no longer exists.

#### **Example:**

```
ov_start(OV_LENGTH)
ov_set(OV_LENGTH, 12, OVF_SUBTRACT_ONE)
ov_use()
command[...], indirect_ref
ov_clean()
```

Condition Codes: Unchanged

**Instruction Count:** None - only preprocessor

# 2.22.2.23 ov\_single

## **Prototype:**

```
ov_single(OVERRIDE_TYPE, in_value, FLAGS)
```

#### **Description:**

Shorthand for an indirect reference containing a single field.

The following shorthand:

```
ov_single(OV_LENGTH, 12, OVF_SUBTRACT_ONE)
command[...], indirect_ref
```

is equivalent to

© 2008-2014 Netronome 208 of 256

```
ov_start(OV_LENGTH)
ov_set_use(OV_LENGTH, 12, OVF_SUBTRACT_ONE)
ov_clean()
command[...], indirect_ref
```

#### Table 2.279. ov\_single parameters

| Name          | Description                                                                                                                                |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| OVERRIDE_TYPE | One override field from Override fields.                                                                                                   |
| in_value      | Value to set field <i>OVERRIDE_TYPE</i> to. May be a constant or a register value.                                                         |
|               | Optional: Zero or more flags from Override flags, ORd together, which, for just this macro call, overrides the indirect reference's flags. |

## 2.22.2.24 ov store

## **Prototype:**

ov\_store()

## **Description**:

Store the current indirect reference for later use.

After calling this macro, the indirect reference no longer exists.



## **Note**

After calling this macro, the number of the slot in which the indirect reference has been stored is available in the preprocessor define OV\_SLOT. This must be stored to be able to recall / resume the indirect reference later.

After calling this macro, a new indirect reference may be started using ov\_start(), or a previously stored macro may be resumed using ov\_resume() or recalled using ov\_recall().

## **Example:**

```
ov_start(OV_LENGTH)
ov_set(OV_LENGTH, 12, OVF_SUBTRACT_ONE)
ov_store()
#define_eval IND_REF_ONE OV_SLOT
// ...
ov_resume(IND_REF_ONE)
ov_use()
command[...], indirect_ref
ov_clean()
```

Condition Codes: Unchanged

Instruction Count: Zero to two, depending on whether registers have been been implicitly copied or not

© 2008-2014 Netronome 209 of 256

#### See Also:

• Resuming and recalling

## 2.22.2.25 ov\_recall

## **Prototype:**

ov\_recall(SLOT)

## **Description**:

Recall a previously-stored indirect reference for use now.

Recalling makes the previously-stored indirect reference the currently active indirect reference, **but without influencing the stored indirect reference**.



#### Note

There may be more than one ov\_recall() corresponding to ov\_store() for a specific slot.

When the stored indirect reference is no longer required, ov\_destroy() must be called.

## **Example:**

```
ov_start((OV_LENGTH | OV_SEQ_NUM))
ov_set(OV_LENGTH, 16, OVF_SUBTRACT_ONE)
ov_store()
#define_eval REF_LENGTH_SEQ_NUM OV_SLOT

#define COUNT 0
#while (COUNT < 4)

    ov_recall(REF_LENGTH_SEQ_NUM)
    ov_set_use(OV_SEQ_NUM, COUNT)
    command[...], indirect_ref
    ov_clean()

#define_eval COUNT (COUNT + 1)
#endloop

ov_dispose(REF_LENGTH_SEQ_NUM)</pre>
```

Condition Codes: Unchanged

**Instruction Count:** None - only preprocessor

## Table 2.280. ov\_recall parameters

| Name | Description                                                 |
|------|-------------------------------------------------------------|
| SLOT | The slot number that was returned in OV_SLOT by ov_store(). |

© 2008-2014 Netronome 210 of 256

#### See Also:

• Resuming and recalling

## 2.22.2.26 ov\_resume

## **Prototype:**

```
ov_resume(SLOT)
```

## **Description**:

Resume a previously-stored indirect reference.

Resuming carries on with the previously-stored indirect reference, as though nothing had occurred in the interim.



## **Note**

There may be exactly one ov\_resume() corresponding to ov\_store() for a specific slot.

ov\_resume() implicitly destroys the stored indirect reference.

#### **Example:**

```
// First indirect reference starts
ov_start((OV_BYTE_MASK | OV_LENGTH))
ov_set(OV_BYTE_MASK, byte_mask)
ov_store()
#define_eval REF_BYTE_MASK_AND_LENGTH OV_SLOT // Store slot number for later
// Second indirect reference starts
ov_start((OV_DATA_REF | OV_BYTE_MASK))
ov_set(OV_BYTE_MASK, byte_mask)
#define_eval REF_DATA_REF_AND_BYTE_MASK OV_SLOT // Store slot number for later
// First indirect reference resumed
ov_resume(REF_BYTE_MASK_AND_LENGTH)
ov_set_use(OV_LENGTH, len, OVF_SUBTRACT_ONE)
command[...], indirect_ref
ov_clean()
// Second indirect reference resumed
ov_resume(REF_DATA_REF_AND_BYTE_MASK)
ov_set_use(OV_DATA_REF, data)
command[...], indirect_ref
ov_clean()
```

**Condition Codes:** Unchanged

**Instruction Count:** None - only preprocessor

© 2008-2014 Netronome 211 of 256

## Table 2.281. ov\_resume parameters

| Name | Description                                                 |
|------|-------------------------------------------------------------|
| SLOT | The slot number that was returned in OV_SLOT by ov_store(). |

#### See Also:

• Resuming and recalling

## 2.22.2.27 ov\_dispose

## **Prototype:**

ov\_dispose(SLOT)

#### **Description**:

Destroy the indirect reference previously stored at the indicated slot.

After a previously-stored indirect reference has been destroyed, it can no longer be referred to.



## **Note**

If an indirect reference is recalled using ov\_recall(), the only way to release the resource is via ov\_dipose().

Condition Codes: Unchanged

**Instruction Count:** None - only preprocessor

#### Table 2.282. ov\_dispose parameters

| Name | Description                                                 |
|------|-------------------------------------------------------------|
| SLOT | The slot number that was returned in OV_SLOT by ov_store(). |

#### See Also:

• Resuming and recalling

## 2.22.2.28 ov\_sanity

## **Prototype:**

ov\_sanity()

#### **Description:**

Performs sanity checks to ensure correct usage of the indirect reference macros.

Checks that:

© 2008-2014 Netronome 212 of 256

- The most recent indirect reference must have been completed with ov\_clean().
- Every indirect reference that was stored using ov\_store() must have been cleared via either ov\_resume() or ov\_destroy().



It is recommended that ov\_sanity is called at the end of the top-level microcode file. It may be called at any convenient time when there should be no current indirect reference and there should be no stored indirect references.

Condition Codes: Unchanged

**Instruction Count:** None - only preprocessor

# 2.23 Ring Utility

# 2.23.1 Ring Utility Macros

List of macros specific to memory ring utilities

# 2.23.2.1 ru\_emem\_ring\_setup

## **Prototype:**

ru\_emem\_ring\_setup(\_in\_addr\_hi, \_in\_q\_desc\_addr\_lo, \_in\_ring\_base\_addr\_lo, \_in\_ring\_num,
\_IN\_SIZE\_LW, \_IN\_Q\_LOC)

## **Description**:

Set up a type 2 ring with variable q-descriptor and ring bases addresses.

## Table 2.283. ru\_emem\_ring\_setup parameters

| Name                  | Description                                                                                                                               |
|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------|
|                       | Upper byte of the 40-bit address of the ring descriptor in emem0, emem1 or emem2 Note that it is located in the lower byte of _in_addr_hi |
| _in_q_desc_addr_lo    | 32-bit address identifying the location of the descriptor                                                                                 |
| _in_ring_base_addr_lo | 32-bit address identifying the location of the rings in emem0, emem1 or emem2                                                             |
| _in_ring_num          | Number of emem rings to configure, valid values 0-1023, GPR or constant value                                                             |
| _IN_SIZE_LW           | size of ring in long words, must be between 512 and 16M and a power of 2                                                                  |

© 2008-2014 Netronome 213 of 256

| Name      | Description                                                                            |
|-----------|----------------------------------------------------------------------------------------|
| _IN_Q_LOC | Queue locality mode:                                                                   |
|           | • MU_LOCALITY_HIGH                                                                     |
|           | • MU_LOCALITY_LOW                                                                      |
|           | • MU_LOCALITY_DIRECT_ACCESS                                                            |
|           | • MU_LOCALITY_DISCARD_AFTER_READ                                                       |
|           | This macro is also available with fixed q-descriptor and ring addresses (5 parameters) |

# 2.23.2.2 ru\_emem\_ring\_setup

## **Prototype:**

```
ru_emem_ring_setup(_IN_Q_DESC_ADDR, _IN_RING_BASE_ADDR, _in_ring_num, _IN_SIZE_LW,
_IN_Q_LOC)
```

## **Description**:

Set up a type 2 ring with constant q-descriptor and ring bases addresses.

This macro is also available with dynamic q-descriptor and ring addresses (6 parameters)

Table 2.284. ru\_emem\_ring\_setup parameters

| Name              | Des                                                                                     | scription                                                  |
|-------------------|-----------------------------------------------------------------------------------------|------------------------------------------------------------|
| _IN_Q_DESC_ADDR   | 40-bit address identifying the location of the ring descriptor in emem0, emem1 or emem2 |                                                            |
| _IN_RING_BASE_ADD | 40-bit address identifying the location of the rings in emem0, emem1 or emem2           |                                                            |
| _in_ring_num      | Number of emem rings to configure, vali                                                 | d values 0-1023, GPR or constant value                     |
| _IN_SIZE_LW       | size of ring in long words, must be between 512 and 16M and a power of 2                |                                                            |
| _IN_Q_LOC         | Queue locality mode:                                                                    |                                                            |
|                   | • MU_LOCALITY_HIGH                                                                      |                                                            |
|                   | • MU_LOCALITY_LOW                                                                       |                                                            |
|                   | • MU_LOCALITY_DIRECT_ACCESS                                                             |                                                            |
|                   | • MU_LOCALITY_DISCARD_AFTER_REAL                                                        |                                                            |
|                   | <b>Example:</b> Create ring in emem island 26                                           | 5                                                          |
|                   | <pre>#define EMEM_RING_NUM #define EMEM_RING_SIZE</pre>                                 | 12<br>512                                                  |
|                   | .alloc_mem RING_BASE_ADDR .alloc_mem Q_DESC_BASE_ADDR                                   | i26.emem island EMEM_RING_SIZE EMEM_RIN i26.emem island 16 |
|                   | <pre>.reg \$xdout[2], \$xdin[2] .xfer_order \$xdout, \$xdin .sig g1, g2</pre>           |                                                            |

© 2008-2014 Netronome 214 of 256

| Name | Description                                                                                                                                                                                                           |             |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
|      | <pre>ru_emem_ring_setup(Q_DESC_BASE_ADDR, RING_BASE_ADDR, EMEM_RING_NUM, E ru_emem_ring_put(RING_BASE_ADDR, \$xdout[0], EMEM_RING_NUM, 2, g1] ru_emem_ring_get(RING_BASE_ADDR, \$xdin[0], EMEM_RING_NUM, 2, g2]</pre> | MEM_RING_SI |

## 2.23.2.3 ru\_emem\_ring\_put

## **Prototype:**

ru\_emem\_ring\_put(\_in\_ring\_base\_addr, \_in\_xfer\_reg, \_in\_ring\_num, \_IN\_REF\_CNT, \_in\_sig\_name)

#### **Description**:

Add entries to the tail of the circular buffer in emem based on parameters passed to the macro.

See ru\_emem\_ring\_setup() macro for implementation details Some compile time error checking is done.

Table 2.285. ru\_emem\_ring\_put parameters

| Name               | Description                                                                   |
|--------------------|-------------------------------------------------------------------------------|
| _in_ring_base_addr | 40-bit address identifying the location of the rings in emem0, emem1 or emem2 |
| _in_xfer_reg       | Entries to add to the circular buffer                                         |
| _in_ring_num       | Select the ring number to add to, between 0-1023                              |
| _IN_REF_CNT        | Number of 32-bit words to add to the circular buffer, must be between 1-16    |
| _in_sig_name       | Signal to use for ring operation                                              |

# 2.23.2.4 ru\_emem\_ring\_get

## **Prototype:**

ru\_emem\_ring\_get(\_in\_ring\_base\_addr, \_out\_xfer\_reg, \_in\_ring\_num, \_IN\_REF\_CNT,
\_in\_sig\_name)

#### **Description**:

Remove entries from the head of the circular buffer in emem based on parameters passed to the macro.

See ru\_emem\_ring\_setup() macro for implementation details Some compile time error checking is done.

#### Table 2.286. ru\_emem\_ring\_get parameters

| Name               | Description                                                                   |
|--------------------|-------------------------------------------------------------------------------|
| _in_ring_base_addr | 40-bit address identifying the location of the rings in emem0, emem1 or emem2 |
| _out_xfer_reg      | Entries to remove from the circular buffer                                    |
| _in_ring_num       | Select the ring number to remove from, between 0-1023                         |

© 2008-2014 Netronome 215 of 256

| Name         | Description                                                                 |
|--------------|-----------------------------------------------------------------------------|
| _IN_REF_CNT  | Number of 32-bit words to remove from the circular buffer must between 1-16 |
| _in_sig_name | Signal to use for ring operation                                            |

## 2.23.2.5 ru\_nn\_ring\_init

## **Prototype:**

ru\_nn\_ring\_init(NN\_EMPTY\_THRESHOLD)

## **Description**:

Next-neighbor ring initialization.

## Table 2.287. ru\_nn\_ring\_init parameters

| Name               | Description                                            |
|--------------------|--------------------------------------------------------|
| NN_EMPTY_THRESHOLD | Threshold when NN_Empty asserts. Valid values are 0-3. |

## 2.23.2.6 ru\_dram\_ring\_setup

## **Prototype**:

ru\_dram\_ring\_setup(\_IN\_RING\_NUM\_, \_IN\_BASE\_ADDR\_, \_IN\_SIZE\_LW\_, \_IN\_Q\_LOC\_, \_IN\_Q\_PAGE\_)

#### **Description**:

Set up a type 2 DRAM ring based on parameters passed to the macro.

Some compile time error checking is done.

## Table 2.288. ru\_dram\_ring\_setup parameters

| Name           | Description                                                   |
|----------------|---------------------------------------------------------------|
| _IN_RING_NUM_  | Number of DRAM ring to configure                              |
| _IN_BASE_ADDR_ | DRAM address where ring starts                                |
| _IN_SIZE_LW_   | LW size of ring, must be between 512 and 16M and a power of 2 |
| _IN_Q_LOC_     | Queue locality mode:                                          |
|                | • MU_LOCALITY_HIGH                                            |
|                | • MU_LOCALITY_LOW                                             |
|                | • MU_LOCALITY_DIRECT_ACCESS                                   |
|                | • MU_LOCALITY_DISCARD_AFTER_READ                              |
| _IN_Q_PAGE_    | Top two bits of the queue entry addresses.                    |

© 2008-2014 Netronome 216 of 256

# 2.23.2.7 ru\_dram\_ring\_setup

# **Prototype:**

ru\_dram\_ring\_setup(\_IN\_RING\_NUM\_, \_IN\_BASE\_ADDR\_, \_IN\_SIZE\_LW\_)

# **Description**:

Set up a type 2 DRAM ring based on parameters passed to the macro.

This is an overloaded macro which uses MU\_LOCALITY\_HIGH for \_IN\_Q\_LOC\_ and 0 for \_IN\_Q\_PAGE\_.

# Table 2.289. ru\_dram\_ring\_setup parameters

| Name           | Description                                                   |
|----------------|---------------------------------------------------------------|
| _IN_RING_NUM_  | Number of DRAM ring to configure                              |
| _IN_BASE_ADDR_ | DRAM address where ring starts                                |
| _IN_SIZE_LW_   | LW size of ring, must be between 512 and 16M and a power of 2 |

# 2.23.2.8 ru\_sram\_ring\_setup

# **Prototype:**

ru\_sram\_ring\_setup(\_IN\_RING\_NUM\_, \_IN\_BASE\_ADDR\_, \_IN\_SIZE\_LW\_)

### **Description:**

Set up a SRAM ring Based on parameters passed into the macro.

Some compile time error checking is done.

#### Table 2.290. ru\_sram\_ring\_setup parameters

| Name           | Description                                                      |
|----------------|------------------------------------------------------------------|
| _IN_RING_NUM_  | Number of SRAM ring to configure                                 |
| _IN_BASE_ADDR_ | SRAM address where ring starts (channel value will be extracted) |
| _IN_SIZE_LW_   | LW size of ring, must be between 512 and 64K and a power of 2    |

# 2.23.2.9 ru\_cls\_ring\_setup

# **Prototype:**

ru\_cls\_ring\_setup(\_IN\_RING\_NUM\_, \_IN\_BASE\_ADDR\_, \_IN\_SIZE\_LW\_)

# **Description**:

Set up a single CLS ring based on parameters passed into the macro.

© 2008-2014 Netronome 217 of 256

Some compile time error checking is done.

Table 2.291. ru\_cls\_ring\_setup parameters

| Name           | Description                                                   |
|----------------|---------------------------------------------------------------|
| _IN_RING_NUM_  | Number of CLS ring to configure                               |
| _IN_BASE_ADDR_ | CLS address where ring starts                                 |
| _IN_SIZE_LW_   | LW size of ring, must be between 32 and 1024 and a power of 2 |

# 2.23.2.10 ru\_ctm\_ring\_setup

# **Prototype:**

ru\_ctm\_ring\_setup(\_IN\_RING\_NUM\_, \_IN\_BASE\_ADDR\_, \_IN\_SIZE\_LW\_, \_IN\_STATUS\_)

# **Description**:

Set up a single CTM ring based on parameters passed into the macro.

Some compile time error checking is done.

Table 2.292. ru\_ctm\_ring\_setup parameters

| Name           | Description                                                              |
|----------------|--------------------------------------------------------------------------|
| _IN_RING_NUM_  | CONST, Number of CTM ring to configure, must be between 0 and 14         |
| _IN_BASE_ADDR_ | CONST, CTM address where ring starts, must be aligned to ring size       |
| _IN_SIZE_LW_   | CONST, LW size of ring, must be between 128 and 16*1024 and a power of 2 |
| _IN_STATUS_    | CONST, status generation control, either "FULL" or "EMPTY"               |

# 2.23.2.11 ru\_ring\_op

# **Prototype:**

ru\_ring\_op(\_\_MEM\_TYPE\_\_, \_IN\_CMD\_, in\_xfer\_reg, \_IN\_RING\_NUM\_, \_IN\_REF\_CNT\_, in\_sig)

# **Description**:

Wrapper for CLS/GS/CTM ring commands.

This macro is used to hide some of the internal details such as encoding the ring address.



### Note

No swapping on the signal is done, the calling code needs to do this.

© 2008-2014 Netronome 218 of 256

Table 2.293. ru\_ring\_op parameters

| Name          | Description                                                                         |
|---------------|-------------------------------------------------------------------------------------|
| MEM_TYPE      | One of CLS,GS, or CTM. GS not supported for NFP6000. CTM only supported for NFP6000 |
| _IN_CMD_      | Ring command to perform (put/get for CLS,GS or ring_put/get for CTM)                |
| in_xfer_reg   | Xfer register name to use in command                                                |
| _IN_RING_NUM_ | Ring number where data is to be placed, must be between 0-15                        |
| _IN_REF_CNT_  | Reference count, must be between 1-16                                               |
| in_sig        | Signal to use for ring operation                                                    |

# 2.23.2.12 ru\_sram\_ring\_put

# **Prototype:**

ru\_sram\_ring\_put(in\_xfer\_reg, in\_src\_op1, in\_src\_op2, \_RING\_CHAN\_NUM\_, \_IN\_REF\_CNT\_,
in\_sig\_name, sig\_action)

# **Description**:

Put \_IN\_REF\_CNT\_ words on sram ring.



# Note

• If there are no sufficient words in the ring for get and put commands, two signals will be pushed where sig\_name[1] signals error.

# Table 2.294. ru\_sram\_ring\_put parameters

| Name            | Description                                                                |
|-----------------|----------------------------------------------------------------------------|
| in_xfer_reg     | Xfer register name to use in command                                       |
| in_src_op1      | Restricted operands are added (src_op1 + src_op2) to define the following: |
|                 | • [31:30]: SRAM channel.                                                   |
|                 | • [29:8]: Ignored.                                                         |
|                 | • [7:2]: Ring number.                                                      |
|                 | • [1:0]: Ignored.                                                          |
| in_src_op2      | As per above                                                               |
| _RING_CHAN_NUM_ | SRAM channel/bank to use                                                   |
| _IN_REF_CNT_    | Reference count in increments of 4 byte words. Valid values are 1 to 8.    |
| in_sig_name     | Signal to use for ring operation                                           |
| sig_action      | SIG_NONE or SIG_WAIT                                                       |

© 2008-2014 Netronome 219 of 256

# 2.23.2.13 ru\_sram\_ring\_get

# **Prototype:**

ru\_sram\_ring\_get(out\_xfer\_reg, in\_src\_op1, in\_src\_op2, \_RING\_CHAN\_NUM\_, IN\_REF\_CNT\_,
in\_sig\_name)

### **Description:**

Refer to description for ru\_sram\_ring\_put macro.

# 2.23.2.14 ru\_sram\_ring\_get

# **Prototype:**

ru\_sram\_ring\_get(out\_xfer\_reg, in\_src\_op1, in\_src\_op2, \_RING\_CHAN\_NUM\_, \_IN\_REF\_CNT\_,
in\_sig\_name, sig\_action)

### **Description:**

Refer to description for ru\_sram\_ring\_put macro.

# 2.23.2.15 ru\_sram\_ring\_journal

### **Prototype:**

ru\_sram\_ring\_journal(in\_xfer\_reg, in\_src\_op1, in\_src\_op2, \_RING\_CHAN\_NUM\_, \_IN\_REF\_CNT\_,
in\_sig\_name, sig\_action)

### **Description**:

Refer to description for ru\_sram\_ring\_put macro.

# 2.23.2.16 ru\_dram\_ring\_put

### **Prototype:**

ru\_dram\_ring\_put(in\_xfer\_reg, in\_src\_op1, in\_src\_op2, \_IN\_REF\_CNT\_, in\_sig\_name,
sig\_action)

### **Description:**

Put \_IN\_REF\_CNT\_ words on dram ring.



### **Note**

• If there are not sufficient words in the ring for get, pop, and put commands, two signals will be pushed where sig\_name[1] signals error.

© 2008-2014 Netronome 220 of 256

- If the EOP bit is set for get\_eop and pop\_eop commands, two signals will be pushed, where sig\_name[1] signals error.
- If the tag is not matched for get\_safe\_tag, pop\_tag\_safe, and journal\_tag, two signals will be pushed, where sig\_name[1] signals error.

# Table 2.295. ru\_dram\_ring\_put parameters

| Name         | Description                                                                                                                             |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| in_xfer_reg  | Xfer register name to use in command                                                                                                    |
| in_src_op1   | Restricted operands are added (src_op1 + src_op2) to define the following:                                                              |
|              | • [23:16]: Memory tag number for XX_tag_XX commands.                                                                                    |
|              | • [9:0]: Queue array entry number.                                                                                                      |
| in_src_op2   | As per above                                                                                                                            |
| _IN_REF_CNT_ | Reference count in increments of 4 byte words. Valid values are 1 to 16 for NFP6000 or 1 to 8 otherwise. Specified as actual count - 1. |
| in_sig_name  | Signal to use for ring operation                                                                                                        |
| sig_action   | SIG_NONE or SIG_WAIT                                                                                                                    |

# 2.23.2.17 ru\_dram\_ring\_put\_tag

# **Prototype:**

ru\_dram\_ring\_put\_tag(in\_xfer\_reg, in\_src\_op1, in\_src\_op2, \_IN\_REF\_CNT\_, in\_sig\_name,
sig\_action)

# **Description**:

Refer to description for ru\_dram\_ring\_put macro.

# 2.23.2.18 ru\_dram\_ring\_qadd\_work

# **Prototype:**

ru\_dram\_ring\_qadd\_work(in\_xfer\_reg, in\_src\_op1, in\_src\_op2, \_IN\_REF\_CNT\_, in\_sig\_name,
sig\_action)

# **Description**:

Refer to description for ru\_dram\_ring\_put macro.

# 2.23.2.19 ru\_dram\_ring\_qadd\_thread

### **Prototype:**

© 2008-2014 Netronome 221 of 256

ru\_dram\_ring\_qadd\_thread(in\_xfer\_reg, in\_src\_op1, in\_src\_op2, \_IN\_REF\_CNT\_, in\_sig\_name,
sig\_action)

#### **Description:**

Refer to description for ru\_dram\_ring\_put macro.

# 2.23.2.20 ru\_dram\_ring\_get

### **Prototype:**

ru\_dram\_ring\_get(out\_xfer\_reg, in\_src\_op1, in\_src\_op2, \_IN\_REF\_CNT\_, in\_sig\_name)

#### **Description:**

Refer to description for ru\_dram\_ring\_put macro.

# 2.23.2.21 ru\_dram\_ring\_get

### **Prototype:**

ru\_dram\_ring\_get(out\_xfer\_reg, in\_src\_op1, in\_src\_op2, \_IN\_REF\_CNT\_, in\_sig\_name,
sig\_action)

# **Description**:

Refer to description for ru\_dram\_ring\_put macro.

# 2.23.2.22 ru\_dram\_ring\_get\_eop

#### **Prototype:**

ru\_dram\_ring\_get\_eop(out\_xfer\_reg, in\_src\_op1, in\_src\_op2, \_IN\_REF\_CNT\_, in\_sig\_name,
sig\_action)

### **Description:**

Refer to description for ru\_dram\_ring\_put macro.

# 2.23.2.23 ru\_dram\_ring\_get\_safe

# **Prototype:**

ru\_dram\_ring\_get\_safe(out\_xfer\_reg, in\_src\_op1, in\_src\_op2, \_IN\_REF\_CNT\_, in\_sig\_name,
sig\_action)

#### **Description:**

Refer to description for ru\_dram\_ring\_put macro.

© 2008-2014 Netronome 222 of 256

# 2.23.2.24 ru\_dram\_ring\_get\_tag\_safe

# **Prototype:**

ru\_dram\_ring\_get\_tag\_safe(out\_xfer\_reg, in\_src\_op1, in\_src\_op2, \_IN\_REF\_CNT\_, in\_sig\_name,
sig\_action)

### **Description:**

Refer to description for ru\_dram\_ring\_put macro.

# 2.23.2.25 ru\_dram\_ring\_pop

### **Prototype:**

ru\_dram\_ring\_pop(in\_xfer\_reg, in\_src\_op1, in\_src\_op2, \_IN\_REF\_CNT\_, in\_sig\_name)

### **Description:**

Refer to description for ru\_dram\_ring\_put macro.

# 2.23.2.26 ru\_dram\_ring\_pop

### **Prototype:**

ru\_dram\_ring\_pop(out\_xfer\_reg, in\_src\_op1, in\_src\_op2, \_IN\_REF\_CNT\_, in\_sig\_name,
sig\_action)

### **Description**:

Refer to description for ru\_dram\_ring\_put macro.

# 2.23.2.27 ru\_dram\_ring\_pop\_eop

#### **Prototype:**

ru\_dram\_ring\_pop\_eop(out\_xfer\_reg, in\_src\_op1, in\_src\_op2, \_IN\_REF\_CNT\_, in\_sig\_name,
sig\_action)

#### **Description**:

Refer to description for ru\_dram\_ring\_put macro.

# 2.23.2.28 ru\_dram\_ring\_pop\_safe

# **Prototype:**

© 2008-2014 Netronome 223 of 256

ru\_dram\_ring\_pop\_safe(out\_xfer\_reg, in\_src\_op1, in\_src\_op2, \_IN\_REF\_CNT\_, in\_sig\_name,
sig\_action)

### **Description**:

Refer to description for ru\_dram\_ring\_put macro.

# 2.23.2.29 ru\_dram\_ring\_pop\_tag\_safe

### **Prototype:**

ru\_dram\_ring\_pop\_tag\_safe(out\_xfer\_reg, in\_src\_op1, in\_src\_op2, \_IN\_REF\_CNT\_, in\_sig\_name,
sig\_action)

# **Description**:

Refer to description for ru\_dram\_ring\_put macro.

# 2.23.2.30 ru\_dram\_ring\_journal

# **Prototype:**

ru\_dram\_ring\_journal(in\_xfer\_reg, in\_src\_op1, in\_src\_op2, \_IN\_REF\_CNT\_, in\_sig\_name,
sig\_action)

### **Description**:

Refer to description for ru\_dram\_ring\_put macro.

# 2.23.2.31 ru\_dram\_ring\_journal\_tag

### **Prototype:**

ru\_dram\_ring\_journal\_tag(in\_xfer\_reg, in\_src\_op1, in\_src\_op2, \_IN\_REF\_CNT\_, in\_sig\_name,
sig\_action)

#### **Description**:

Refer to description for ru\_dram\_ring\_put macro.

# 2.23.2.32 ru\_deq\_from\_ring

### **Prototype:**

ru\_deq\_from\_ring(out\_req, RING\_TYPE, ref\_cnt, ring\_num, sig, sig\_action, \_\_NULL\_LABEL\_\_)

#### **Description:**

Generic ring dequeue operation.

© 2008-2014 Netronome 224 of 256

Table 2.296. ru\_deq\_from\_ring parameters

| Name       | Description                                                   |
|------------|---------------------------------------------------------------|
| out_req    | Register aggregate                                            |
| RING_TYPE  | Ring type, One of NN_RING,CLS_RING,GS_RING,DDR_RING,QDR_RING  |
| ref_cnt    | Number of operations to perform                               |
| ring_num   | Ring number                                                   |
| sig        | Signal to generate                                            |
| sig_action | If SIG_WAIT, waits for operation to complete                  |
| NULL_LABEL | label to branch to on NN_RING empty, or to wait for not empty |

# 2.23.2.33 ru\_deq\_from\_ring

# **Prototype:**

ru\_deq\_from\_ring(out\_req, RING\_TYPE, ref\_cnt, ring\_num, ring\_chan, sig, sig\_action,
\_\_NULL\_LABEL\_\_)

# **Description**:

Generic ring dequeue operation.

Table 2.297. ru\_deq\_from\_ring parameters

| Name       | Description                                                   |
|------------|---------------------------------------------------------------|
| out_req    | Register aggregate                                            |
| RING_TYPE  | Ring type, One of NN_RING,CLS_RING,GS_RING,DDR_RING,QDR_RING  |
| ref_cnt    | Number of operations to perform                               |
| ring_num   | Ring number                                                   |
| ring_chan  | Ring channel, only applicable to the QDR_RING                 |
| sig        | Signal to generate                                            |
| sig_action | If SIG_WAIT, waits for operation to complete                  |
| NULL_LABEL | label to branch to on NN_RING empty, or to wait for not empty |

# 2.23.2.34 ru\_cls\_ring\_put

# **Prototype:**

ru\_cls\_ring\_put(in\_xfer\_reg, in\_src\_op1, in\_src\_op2, \_IN\_REF\_CNT\_, in\_sig\_name, sig\_action)

# **Description**:

Add n 32-bit words to the tail of the ring.

© 2008-2014 Netronome 225 of 256

Table 2.298. ru\_cls\_ring\_put parameters

| Name         | Description                              |
|--------------|------------------------------------------|
| in_xfer_reg  | xfer registers                           |
| in_src_op1   | Ring number (contant/GPR)                |
| in_src_op2   | Not used and ignored. Can be "".         |
| _IN_REF_CNT_ | Number of 32-bit words to put on to ring |
| in_sig_name  | Signal to wait on                        |
| sig_action   | SIG_WAIT or SIG_NONE                     |

# 2.23.2.35 ru\_cls\_ring\_pop

# **Prototype:**

ru\_cls\_ring\_pop(in\_xfer\_reg, in\_src\_op1, in\_src\_op2, \_IN\_REF\_CNT\_, in\_sig\_name, sig\_action)

# **Description**:

Pop n 32-bit words from tail of the ring (LIFO).

# 2.23.2.36 ru\_cls\_ring\_pop\_safe

# **Prototype:**

ru\_cls\_ring\_pop\_safe(in\_xfer\_reg, in\_src\_op1, in\_src\_op2, \_IN\_REF\_CNT\_, in\_sig\_name,
sig\_action)

# **Description**:

Pop n 32-bit words from tail of the ring (LIFO).

If less than n in the ring, return zero for extra words.

# 2.23.2.37 ru\_cls\_ring\_get\_safe

### **Prototype:**

ru\_cls\_ring\_get\_safe(in\_xfer\_reg, in\_src\_op1, in\_src\_op2, \_IN\_REF\_CNT\_, in\_sig\_name,
sig\_action)

### **Description**:

Get n 32-bit words from head of the ring (FIFO).

If less than n in the ring, return zero for extra words.

© 2008-2014 Netronome 226 of 256

# 2.23.2.38 ru\_cls\_ring\_get

# **Prototype:**

ru\_cls\_ring\_get(in\_xfer\_reg, in\_src\_op1, in\_src\_op2, \_IN\_REF\_CNT\_, in\_sig\_name, sig\_action)

# **Description**:

Get n 32-bit words from head of the ring (FIFO).

# 2.23.2.39 ru\_ctm\_ring\_put

# **Prototype:**

ru\_ctm\_ring\_put(in\_xfer\_reg, in\_src\_op1, in\_src\_op2, \_IN\_REF\_CNT\_, in\_sig\_name, sig\_action)

### **Description:**

Add n 32-bit words to the tail of the ring.

Table 2.299. ru\_ctm\_ring\_put parameters

| Name         | Description                              |
|--------------|------------------------------------------|
| in_xfer_reg  | xfer registers                           |
| in_src_op1   | Ring number (contant/GPR)                |
| in_src_op2   | Not used and ignored. Can be "".         |
| _IN_REF_CNT_ | Number of 32-bit words to put on to ring |
| in_sig_name  | Signal to wait on                        |
| sig_action   | SIG_WAIT or SIG_NONE                     |

# 2.23.2.40 ru\_ctm\_ring\_get

# **Prototype**:

ru\_ctm\_ring\_get(in\_xfer\_reg, in\_src\_op1, in\_src\_op2, \_IN\_REF\_CNT\_, in\_sig\_name, sig\_action)

### **Description**:

Get n 32-bit words from head of the ring.

### Table 2.300. ru\_ctm\_ring\_get parameters

| Name        | Description                      |
|-------------|----------------------------------|
| in_xfer_reg | xfer registers                   |
| in_src_op1  | Ring number (contant/GPR)        |
| in_src_op2  | Not used and ignored. Can be "". |

© 2008-2014 Netronome 227 of 256

| Name         | Description                             |
|--------------|-----------------------------------------|
| _IN_REF_CNT_ | Number of 32-bit words to get from ring |
| in_sig_name  | Signal to wait on                       |
| sig_action   | SIG_WAIT or SIG_NONE                    |

# 2.23.2.41 ru\_enq\_to\_ring

# **Prototype:**

ru\_enq\_to\_ring(in\_req, RING\_TYPE, ref\_cnt, ring\_num, sig, sig\_action, \_\_FULL\_LABEL\_\_)

### **Description**:

Generic ring enqueue operation, with optional ring channel.

# Table 2.301. ru\_enq\_to\_ring parameters

| Name       | Description                                                                             |
|------------|-----------------------------------------------------------------------------------------|
| in_req     | Register aggregate                                                                      |
| RING_TYPE  | Ring type, One of NN_RING,CLS_RING,GS_RING(not supported for NFP6000),DDR_RING,QDR_RING |
| ref_cnt    | Number of operations to perform                                                         |
| ring_num   | Ring number                                                                             |
| sig        | Signal to generate                                                                      |
| sig_action | If SIG_WAIT, waits for operation to complete                                            |
| FULL_LABEL | label to branch to on NN_RING full, or to wait for not full                             |

# 2.23.2.42 ru\_enq\_to\_ring

# **Prototype:**

ru\_enq\_to\_ring(in\_req, RING\_TYPE, ref\_cnt, ring\_num, ring\_chan, sig, sig\_action,
\_\_FULL\_LABEL\_\_)

### **Description**:

Generic ring enqueue operation, with optional ring channel.

# Table 2.302. ru\_enq\_to\_ring parameters

| Name      | Description                                                  |
|-----------|--------------------------------------------------------------|
| in_req    | Register aggregate                                           |
| RING_TYPE | Ring type, One of NN_RING,CLS_RING,GS_RING,DDR_RING,QDR_RING |
| ref_cnt   | Number of operations to perform                              |

© 2008-2014 Netronome 228 of 256

| Name       | Description                                                 |
|------------|-------------------------------------------------------------|
| ring_num   | Ring number                                                 |
| ring_chan  | Ring channel, only applicable to the QDR_RING               |
| sig        | Signal to generate                                          |
| sig_action | If SIG_WAIT, waits for operation to complete                |
| FULL_LABEL | label to branch to on NN_RING full, or to wait for not full |

# 2.24 SRAM Operation

# 2.24.1 SRAM Operation Macros

Operations macros specific for SRAM memory (deprecated)

# 2.24.2.1 sram\_read

# **Prototype:**

sram\_read(out\_data, in\_sram\_addr, in\_addr\_offset, in\_lw\_count, REQ\_SIG, in\_wakeup\_sigs,
Q\_OPTION)

# **Description**:

Read from sram starting at address of first longword.

**Instruction Count:** 1-5 (1 read SRAM access)

**Example:** 

sram\_read(\$packet[2], addr, 0, LWCOUNT3, SIG\_SRAM. SIG\_SRAM, \_\_\_\_)

# Table 2.303. sram\_read parameters

| Name           | Description                                                                                                 |
|----------------|-------------------------------------------------------------------------------------------------------------|
| out_data       | First sram xfer reg of sequence to read to, array notation must be in xbuf array notation, index range 0-15 |
| in_sram_addr   | Register or constant base longword address                                                                  |
| in_addr_offset | Register or constant longword address offset                                                                |
| in_lw_count    | Register or constant longword count                                                                         |
| REQ_SIG        | Signal associated with this request                                                                         |
| in_wakeup_sigs | Signal or signals to wake up on                                                                             |

© 2008-2014 Netronome 229 of 256

| Name     | Description                                                                                        |
|----------|----------------------------------------------------------------------------------------------------|
| Q_OPTION | Queue option                                                                                       |
|          | no_option or : default. Order queue                                                                |
|          | optimize_mem: mem controller selects cycle to issue                                                |
|          | priority: high priority                                                                            |
|          | Temp register usage: 0-2, uses registers if constant addr args > MAX_IMMEDIATE, or register length |

# 2.24.2.2 sram\_write

# **Prototype:**

sram\_write(in\_data, in\_sram\_addr, in\_addr\_offset, in\_lw\_count, REQ\_SIG, in\_wakeup\_sigs,
Q\_OPTION)

# **Description**:

Write to sram.

**Instruction Count:** 1-5 (1 write SRAM access)

**Example:** 

sram\_write(\$packet[2], addr, 0, LWCOUNT3, SIG\_SRAM, SIG\_SRAM, \_\_\_)

# Table 2.304. sram\_write parameters

| Name           | Description                                                                                                         |
|----------------|---------------------------------------------------------------------------------------------------------------------|
| in_data        | First sram xfer register of sequence to write from, array notation must be in xbuf array notation, index range 0-15 |
| in_sram_addr   | Register or constant base longword address                                                                          |
| in_addr_offset | Register or constant longword address offset                                                                        |
| in_lw_count    | Register or constant longword count                                                                                 |
| REQ_SIG        | Signal associated with this request                                                                                 |
| in_wakeup_sigs | Signal or signals to wake up on                                                                                     |
| Q_OPTION       | Queue option                                                                                                        |
|                | no_option or : default. Order queue                                                                                 |
|                | optimize_mem: mem controller selects cycle to issue                                                                 |
|                | priority: high priority                                                                                             |
|                | Temp register usage: 0-2, uses registers if constant addr args > MAX_IMMEDIATE, or register or length               |

© 2008-2014 Netronome 230 of 256

# 2.24.2.3 sram\_bits\_clr

# **Prototype:**

sram\_bits\_clr(in\_mask, in\_sram\_addr, in\_addr\_offset, REQ\_SIG, in\_wakeup\_sigs, Q\_OPTION)

# **Description**:

Clear in\_mask bits at sram longword location.

# Table 2.305. sram\_bits\_clr parameters

| Name           | Description                                         |
|----------------|-----------------------------------------------------|
| in_mask        | Register or constant, mask of bits to set           |
| in_sram_addr   | Register or constant base longword address          |
| in_addr_offset | Register or constant longword address offset        |
| REQ_SIG        | Signal associated with this request                 |
| in_wakeup_sigs | Signal or signals to wake up on                     |
| Q_OPTION       | Queue option                                        |
|                | no_option or : default. Order queue                 |
|                | optimize_mem: mem controller selects cycle to issue |
|                | priority: high priority                             |

# 2.24.2.4 sram bits set

# **Prototype:**

sram\_bits\_set(in\_mask, in\_sram\_addr, in\_addr\_offset, REQ\_SIG, in\_wakeup\_sigs, Q\_OPTION)

### **Description**:

Set in\_mask bits at sram longword location.

**Instruction Count:** 1-8 (1 sram read-modify-write memory access)

**Example:** 

sram\_bits\_set(0x111, 0, bit\_position, SIG\_SRAM. SIG\_SRAM, \_\_\_)

# Table 2.306. sram\_bits\_set parameters

| Name           | Description                                  |
|----------------|----------------------------------------------|
| in_mask        | Register or constant, mask of bits to set    |
| in_sram_addr   | Register or constant base longword address   |
| in_addr_offset | Register or constant longword address offset |
| REQ_SIG        | Signal associated with this request          |

© 2008-2014 Netronome 231 of 256

| Name           | Description                                         |
|----------------|-----------------------------------------------------|
| in_wakeup_sigs | Signal or signals to wake up on                     |
| Q_OPTION       | Queue option                                        |
|                | no_option or : default. Order queue                 |
|                | optimize_mem: mem controller selects cycle to issue |
|                | priority: high priority                             |

# 2.24.2.5 sram\_bits\_test\_and\_clr

# **Prototype:**

sram\_bits\_test\_and\_clr(out\_data, in\_mask, in\_sram\_addr, in\_addr\_offset, REQ\_SIG, in\_wakeup\_sigs, Q\_OPTION)

# **Description**:

Clear in\_mask bits at sram longword location.

Read contents of sram address prior to the write.

**Instruction Count:** 1-8 (1 sram read-modify-write memory access)

Table 2.307. sram\_bits\_test\_and\_clr parameters

| Name           | Description                                         |
|----------------|-----------------------------------------------------|
| out_data       | Read xfer register result                           |
| in_mask        | Register or constant, mask of bits to set           |
| in_sram_addr   | Register or constant base longword address          |
| in_addr_offset | Register or constant longword address offset        |
| REQ_SIG        | Signal associated with this request                 |
| in_wakeup_sigs | Signal or signals to wake up on                     |
| Q_OPTION       | Queue option                                        |
|                | no_option or : default. Order queue                 |
|                | optimize_mem: mem controller selects cycle to issue |
|                | priority: high priority                             |

# 2.24.2.6 sram\_bits\_test\_and\_set

# **Prototype:**

sram\_bits\_test\_and\_set(out\_data, in\_mask, in\_sram\_addr, in\_addr\_offset, REQ\_SIG,
in\_wakeup\_sigs, Q\_OPTION)

© 2008-2014 Netronome 232 of 256

# **Description**:

Set in\_mask bits at sram longword location.

Read contents of sram address prior to the write.

**Instruction Count:** 1-8 (1 sram read-modify-write memory access)

**Example:** 

sram\_bits\_test\_and\_set(prev\_value, 0x1000, addr0, addr1, SIG\_SRAM, SIG\_SRAM, \_\_\_) // test/set bit 3

Table 2.308. sram\_bits\_test\_and\_set parameters

| Name           | Description                                         |
|----------------|-----------------------------------------------------|
| out_data       | Read xfer register result                           |
| in_mask        | Register or constant, mask of bits to set           |
| in_sram_addr   | Register or constant base longword address          |
| in_addr_offset | Register or constant longword address offset        |
| REQ_SIG        | Signal associated with this request                 |
| in_wakeup_sigs | Signal or signals to wake up on                     |
| Q_OPTION       | Queue option                                        |
|                | no_option or : default. Order queue                 |
|                | optimize_mem: mem controller selects cycle to issue |
|                | priority: high priority                             |

# 2.24.2.7 sram\_add

# **Prototype:**

sram\_add(in\_data, in\_sram\_addr, in\_addr\_offset, REQ\_SIG, in\_wakeup\_sigs, Q\_OPTION)

# **Description**:

Add in\_data to sram location.

# Table 2.309. sram\_add parameters

| Name           | Description                                  |  |
|----------------|----------------------------------------------|--|
| in_data        | Register or constant, data to add            |  |
| in_sram_addr   | Register or constant base longword address   |  |
| in_addr_offset | Register or constant longword address offset |  |
| REQ_SIG        | Signal associated with this request          |  |
| in_wakeup_sigs | Signal or signals to wake up on              |  |

© 2008-2014 Netronome 233 of 256

| Name     | Description                                         |
|----------|-----------------------------------------------------|
| Q_OPTION | Queue option                                        |
|          | no_option or : default. Order queue                 |
|          | optimize_mem: mem controller selects cycle to issue |
|          | priority: high priority                             |

# 2.24.2.8 sram\_decr

# **Prototype:**

sram\_decr(in\_sram\_addr, in\_addr\_offset)

### **Description**:

Decrement 32-bit longword at sram location.

# Table 2.310. sram\_decr parameters

| Name           | Description                                  |  |
|----------------|----------------------------------------------|--|
| in_sram_addr   | Register or constant base longword address   |  |
| in_addr_offset | Register or constant longword address offset |  |

# 2.24.2.9 sram\_incr

### **Prototype:**

sram\_incr(in\_sram\_addr, in\_addr\_offset)

# **Description**:

Increment 32-bit longword at to sram location.

# Table 2.311. sram\_incr parameters

| Name           | Description                                  |  |
|----------------|----------------------------------------------|--|
| in_sram_addr   | Register or constant base longword address   |  |
| in_addr_offset | Register or constant longword address offset |  |

# 2.24.2.10 sram\_sub

# **Prototype**:

sram\_sub(in\_data, in\_sram\_addr, in\_addr\_offset, REQ\_SIG, in\_wakeup\_sigs, Q\_OPTION)

# **Description**:

© 2008-2014 Netronome 234 of 256

Sub in\_data from sram location.



# **Note**

sub instr is not supported in HW, so we subtract from 0 and add that number. in\_data must not be a write transfer register.

**Instruction Count:** 2-6 (1 SRAM read-modify-write access)

# Table 2.312. sram\_sub parameters

| Name           | Description                                         |  |
|----------------|-----------------------------------------------------|--|
| in_data        | Register or constant, data to subtract              |  |
| in_sram_addr   | Register or constant base longword address          |  |
| in_addr_offset | Register or constant longword address offset        |  |
| REQ_SIG        | Signal associated with this request                 |  |
| in_wakeup_sigs | Signal or signals to wake up on                     |  |
| Q_OPTION       | Queue option                                        |  |
|                | no_option or : default. Order queue                 |  |
|                | optimize_mem: mem controller selects cycle to issue |  |
|                | priority: high priority                             |  |

# 2.24.2.11 sram\_swap

# **Prototype:**

sram\_swap(out\_data, in\_data, in\_sram\_addr, in\_addr\_offset, REQ\_SIG, in\_wakeup\_sigs,
Q\_OPTION)

# **Description**:

Write in data to sram location.

Read contents of sram location prior to the operation to out\_data.



### **Note**

out\_data must be a transfer register.

**Instruction Count:** 1-8 (1 SRAM read-modify-write access)

**Example:** code sram\_swap(prev\_value, new\_value, addr0, addr1, SIG\_SRAM. SIG\_SRAM, \_\_\_\_) // test/set bit 3

© 2008-2014 Netronome 235 of 256

Table 2.313. sram\_swap parameters

| Name           | Description                                         |  |
|----------------|-----------------------------------------------------|--|
| out_data       | Transfer Register, returned previous data value     |  |
| in_data        | Register or constant, data to write                 |  |
| in_sram_addr   | Register or constant base longword address          |  |
| in_addr_offset | Register or constant longword address offset        |  |
| REQ_SIG        | Signal associated with this request                 |  |
| in_wakeup_sigs | Signal or signals to wake up on                     |  |
| Q_OPTION       | Queue option                                        |  |
|                | no_option or : default. Order queue                 |  |
|                | optimize_mem: mem controller selects cycle to issue |  |
|                | priority: high priority                             |  |

# 2.24.2.12 sram\_test\_and\_add

# **Prototype:**

sram\_test\_and\_add(out\_data, in\_data, in\_sram\_addr, in\_addr\_offset, REQ\_SIG, in\_wakeup\_sigs,
Q\_OPTION)

# **Description**:

Read contents of sram location to out\_data.

Then add in\_data to sram location contents.



# Note

out\_data must be a transfer register.

# **Example:**

sram\_test\_and\_add(prev\_value, addend, addr0, addr1, SIG\_SRAM. SIG\_SRAM, \_\_\_) // test/set bit 3

**Instruction Count:** 1-8 (1 SRAM read-modify-write access)

### Table 2.314. sram\_test\_and\_add parameters

| Name           | Description                                     |  |
|----------------|-------------------------------------------------|--|
| out_data       | Transfer Register, returned previous data value |  |
| in_data        | Register or constant, data to add               |  |
| in_sram_addr   | Register or constant base longword address      |  |
| in_addr_offset | Register or constant longword address offset    |  |

© 2008-2014 Netronome 236 of 256

| Name           | Description                                         |
|----------------|-----------------------------------------------------|
| REQ_SIG        | Signal associated with this request                 |
| in_wakeup_sigs | Signal or signals to wake up on                     |
| Q_OPTION       | Queue option                                        |
|                | no_option or: default. Order queue                  |
|                | optimize_mem: mem controller selects cycle to issue |
|                | priority: high priority                             |

# 2.24.2.13 sram\_test\_and\_decr

# **Prototype:**

sram\_test\_and\_decr(out\_data, in\_sram\_addr, in\_addr\_offset, REQ\_SIG, in\_wakeup\_sigs,
Q\_OPTION)

# **Description**:

Read contents of sram location to out\_data.

Then decrement sram location contents.



### Note

out\_data must be a transfer register.

**Instruction Count:** 1-5 (1 SRAM read-modify-write access)

**Example:** 

sram\_test\_and\_decr(prev\_value, addr0, addr1, SIG\_SRAM. SIG\_SRAM, \_\_\_) // test/set bit 3

# Table 2.315. sram\_test\_and\_decr parameters

| Name           | Description                                         |  |
|----------------|-----------------------------------------------------|--|
| out_data       | Transfer Register, returned previous data value     |  |
| in_sram_addr   | Register or constant base longword address          |  |
| in_addr_offset | Register or constant longword address offset        |  |
| REQ_SIG        | Signal associated with this request                 |  |
| in_wakeup_sigs | Signal or signals to wake up on                     |  |
| Q_OPTION       | Queue option                                        |  |
|                | no_option or : default. Order queue                 |  |
|                | optimize_mem: mem controller selects cycle to issue |  |
|                | priority: high priority                             |  |

© 2008-2014 Netronome 237 of 256

# 2.24.2.14 sram test and incr

# **Prototype:**

sram\_test\_and\_incr(out\_data, in\_sram\_addr, in\_addr\_offset, REQ\_SIG, in\_wakeup\_sigs,
Q\_OPTION)

### **Description:**

Read contents of sram location to out\_data.

Then increment sram location contents.



### Note

out\_data must be a transfer register.

**Instruction Count:** 1-5 (1 SRAM read-modify-write access)

**Example:** 

sram\_test\_and\_incr(prev\_value, addr0, addr1, SIG\_SRAM. SIG\_SRAM, \_\_\_) // test/set bit 3

# Table 2.316. sram\_test\_and\_incr parameters

| Name           | Description                                         |  |
|----------------|-----------------------------------------------------|--|
| out_data       | Transfer Register, returned previous data value     |  |
| in_sram_addr   | Register or constant base longword address          |  |
| in_addr_offset | Register or constant longword address offset        |  |
| REQ_SIG        | Signal associated with this request                 |  |
| in_wakeup_sigs | Signal or signals to wake up on                     |  |
| Q_OPTION       | Queue option                                        |  |
|                | no_option or : default. Order queue                 |  |
|                | optimize_mem: mem controller selects cycle to issue |  |
|                | priority: high priority                             |  |

# 2.24.2.15 sram\_fast\_journal

### **Prototype:**

sram\_fast\_journal(in\_journal\_reg\_orig, ring\_num)

### **Description**:

Macro to do sram ring fast journal logging.

© 2008-2014 Netronome 238 of 256

# Table 2.317. sram\_fast\_journal parameters

| Name                | Description                                             |
|---------------------|---------------------------------------------------------|
| in_journal_reg_orig | Register with data in lower 24 bits, upper 8 bits clear |
| ring_num            | SRAM journal ring number - must be constant             |

# 2.24.2.16 sram\_wr\_qdesc

# **Prototype:**

sram\_wr\_qdesc(\_QID\_, \_DEBUG\_QDESC\_SRAM\_BASE\_)

# **Description**:

Given freelist ID and sram address, dump the current sram queue descriptor state to specified sram address.

# Table 2.318. sram\_wr\_qdesc parameters

| Name                    | Description                                     |
|-------------------------|-------------------------------------------------|
| _QID_                   | Qdescriptor number to dump                      |
| _DEBUG_QDESC_SRAM_BASE_ | SRAM address where q-descriptor will be written |

# 2.24.2.17 sram\_memset

# **Prototype:**

sram\_memset(in\_sram\_addr, in\_len, lw\_pattern, \_CHUNK\_SIZE\_)

### **Description:**

Initialize SRAM memory with given pattern for 'len' bytes.

# Table 2.319. sram\_memset parameters

| Name         | Description                                                                  |
|--------------|------------------------------------------------------------------------------|
| in_sram_addr | SRAM start address (constant or mutable GPR)                                 |
| in_len       | Number of bytes to initialize (blocks of 32 bytes) (constant or mutable GPR) |
| lw_pattern   | Pattern to fill (constant)                                                   |
| _CHUNK_SIZE_ |                                                                              |

© 2008-2014 Netronome 239 of 256

# 2.25 Thread Synchronization

# 2.25.1 Thread Synchronization Macros

Thread Synchronization Macros

# 2.25.2.1 threads\_reorder\_once

#### **Prototype:**

threads\_reorder\_once(in\_sig)

### **Description**:

Reorder threads.

Threads enabled to run in order 0->7

### **Example:**

```
.sig s
threads_reorder_once(s)
[work to do before next thread runs]
ctx_arb[voluntary] // let next thread run
```

#### Table 2.320. threads\_reorder\_once parameters

| Name   | Description |
|--------|-------------|
| in_sig | signal      |

# 2.25.2.2 threads\_br\_ctx

# **Prototype:**

threads\_br\_ctx(CTX\_MASK, LABEL)

### **Description**:

Take a branch if running on thread indicated in bit mask.

### **Example:**

```
.reg r_thd_3_0, r_thd_7_4
#define THD_MASK 0xF0
threads_br_ctx(THD_MASK, thd_7_4_running#)
thd_3_0_running#:
immed[r_thd3_0, 1]
```

© 2008-2014 Netronome 240 of 256

```
br[done#]
thd_7_4_running#:
immed[r_thd7_4, 1]
done#:
```

# Table 2.321. threads\_br\_ctx parameters

| Name     | Description                   |
|----------|-------------------------------|
| CTX_MASK |                               |
| LABEL    | Constant, branch target label |

# 2.25.2.3 threads\_kill

### **Prototype:**

threads\_kill(KILL\_MASK)

# **Description**:

Kill threads indicated in bit mask.

### **Example:**

```
#define THD_MASK 0xAA
threads_kill(THD_MASK) // kill threads 7,5,3,1
```

# Table 2.322. threads\_kill parameters

| Name      | Description |
|-----------|-------------|
| KILL_MASK |             |

# 2.25.2.4 threads\_order

### **Prototype:**

threads\_order(out\_next, in\_sig, ORDERED\_MASK)

# **Description**:

Order threads enabled in bit mask.

### **Example:**

```
.sig s
.reg next_val
#define THD_MASK 0xAA
threads_order(next_val, s, THD_MASK) // order threads 1,3,5,7
```

© 2008-2014 Netronome 241 of 256

# Table 2.323. threads\_order parameters

| Name         | Description                                                     |
|--------------|-----------------------------------------------------------------|
| out_next     | GPR, written with                                               |
| in_sig       | signal                                                          |
| ORDERED_MASK | Constant, bit mask, one bit per thread of threads to be ordered |

# 2.26 XBUF Operation

# 2.26.1 XBUF Operation Macros

XBUF macros

# 2.26.2.1 xbuf\_bind\_address

# **Prototype:**

```
xbuf_bind_address(str_xbuf_name, POOLS_BASE, POOL_SIZE, BUFFER_OFFSET)
```

### **Description**:

This macro is used to bind a buffer name with an address in a pool of buffers inside local memory.

Common designs have local memory divided into several blocks of pools. In each block, the pools are contiguous, and the number of pools is equal to the number of active threads so that each thread has one pool. Inside a pool, there can be several buffers.

This call is applicable to LMEM buffers only. It is transparent to other types.

# **Example:**

```
xbuf_alloc(lmem_buf0, 8, READ_WRITE)
xbuf_bind_address(lmem_buf0, 0x100, 0x20, 0x0)
xbuf_activate(lmem_buf0, 0, 0, 1)

Start using lmem_buf0....
ipv4_cksum_verify(lmem_buf0, 0xb)
```

#### **Instruction Count:** 0



# Note

lmem\_buf0, lmem\_buf1, ..., lmem\_buf15 must be used for local memory buffers.

© 2008-2014 Netronome 242 of 256

Table 2.324. xbuf\_bind\_address parameters

| Name          | Description                                                                                                                                                                                   |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| str_xbuf_name | Name of buffer. Name has to start with "lmem". For example, lmem_buf1. If name does not start with "lmem", the macro will assume that buffer is not in local memory and nothing will be done. |
| POOLS_BASE    | Base of all pools in bytes (must be multiple of POOL_SIZE)                                                                                                                                    |
| POOL_SIZE     | Size of each pool in bytes (must be power of 2)                                                                                                                                               |
| BUFFER_OFFSET | Offset in bytes of the buffer inside its pool. The offset should be aligned on a long-word boundary which is calculated as the next higher power of 2 of the buffer-size.                     |

#### **Macro Defines:**

- Set internal constants.
- \_xbuf[i]\_lmem\_pools\_base
- \_xbuf[i]\_lmem\_pool\_size
- \_xbuf[i]\_lmem\_offset (where i = 0..15 since 16 buffers are supported)

# 2.26.2.2 xbuf deactivate

### **Prototype:**

xbuf\_deactivate(str\_xbuf\_name)

### **Description:**

Undefine the binding (set by xbuf\_activate) between the buffer name and its current Local Memory handle.

This macro is called at the end of a block that defines the scope of the binding. Users have to call <code>xbuf\_activate</code> again to associate the buffer name with LMEM handle before the buffer can be used.

This call is applicable to Local Memory buffers only. It is transparent to other types.



### Note

lmem\_buf0, lmem\_buf1, ..., lmem\_buf15 must be used for local memory buffers.

### Example 1:

```
#define_eval ipv4_hdr lmem_buf0
xbuf_alloc(ipv4_hdr, 8, read_write)
xbuf_bind_address(ipv4_hdr, 0x280, 0x20, 0)
xbuf_activate(ipv4_hdr, 0, 3, 1)
// uses of ipv4_hdr
xbuf_deactivate(ipv4_hdr)
xbuf_activate(ipv4_hdr, 1, 3, 1)
// uses of ipv4_hdr
```

© 2008-2014 Netronome 243 of 256

```
xbuf_deactivate(ipv4_hdr)
xbuf_free(ipv4_hdr)
```

### Example 2:

```
#define_eval ipv4_hdr
                       lmem_buf1
xbuf_alloc(ipv4_hdr, 8, read_write)
xbuf_bind_address(ipv4_hdr, pools_base, pool_size, buf_offset)
#macro first_block(name)
   xbuf_activate(name, 1, 2, 1)
                                   // select handle1
   xbuf_extract(..., name, ...)
   xbuf_deactivate(name)
#endm
#macro second_block(name)
   xbuf_activate(name, 0, 2, 1)
                                    // switch to handle0
   xbuf_extract(..., name, ...)
   xbuf_deactivate(name)
#endm
first_block(ipv4_hdr)
second_block(ipv4_hdr)
```

#### **Instruction Count:** 0

#### Table 2.325. xbuf deactivate parameters

| Name | Description                                                                                                                                                                                   |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | Name of buffer. Name has to start with "lmem". For example, lmem_buf1. If name does not start with "lmem", the macro will assume that buffer is not in local memory and nothing will be done. |

### **Macro Defines:**

• str\_xbuf\_name is no longer associated with any Local Memory handle.

# 2.26.2.3 xbuf\_activate

#### **Prototype:**

```
xbuf_activate(str_xbuf_name, INDEX, thread_id, WAIT_ACTION)
```

# **Description**:

To map the specified ACTIVE\_LM\_ADDRESS CSR to the specified buffer.

The absolute address of the buffer will be put in the ACTIVE\_LM\_ADDR local CSR. The absolute address is calculated from the parameters supplied from the xbuf\_bind\_address call. After this macro is called, the specified buffer can be accessed via\* 1\$index0/1.

This call is applicable to LMEM buffers only. It is transparent to other buffer types.

© 2008-2014 Netronome 244 of 256



# **Note**

lmem\_buf0, lmem\_buf1, ..., lmem\_buf15 must be used for Local Memory buffers.

Applications that run with 4 context mode have to explicitly define it:

```
#define CONTEXT_MODE_4
```

It is 8 context mode by default.

Buffer absolute address = (thread\_id  $<< [log(2) of (\_xbuf[i]\_lmem\_pool\_size)]) + _xbuf[i]\_lmem\_pools\_base + _xbuf[i]\_lmem\_offset, where _xbuf[i]\_lmem is the buffer with the specified name.$ 

### **Example:**

```
#define_eval ipv6_hdr lmem_buf0

xbuf_alloc(ipv6_hdr, 8, read_write)
xbuf_bind_address(ipv6_hdr, pools_base, pool_size, buf_offset)
xbuf_activate(ipv6_hdr, 0, 3, 1)

Now for thread 3, ipv6_hdr[0], ipv6_hdr[1], ... ipv6_hdr[7]
are associated with *l$index0[0], *l$index0[1], ... *l$index0[7]
```

**Instruction Count:** 3 - 4 Without wait cycle, 6 - 7 With 3 wait cycles

# Table 2.326. xbuf\_activate parameters

| Name          | Description                                                                                           |
|---------------|-------------------------------------------------------------------------------------------------------|
| str_xbuf_name | Name of buffer. Name has to start with "lmem". For example, lmem_buf1. If name does not               |
|               | start with "lmem", the macro will assume that buffer is not in local memory and nothing will be done. |
| INDEX         | • 0 to map* 1\$index0 to the specified buffer                                                         |
|               | • 1 to map* l\$index1 to the specified buffer                                                         |
| thread_id     | Run-time value thread ID. Can be either a GPR or a constant.                                          |
| WAIT_ACTION   | • 1 wait 3 cycles after setting up local CSR (3 NOPs)                                                 |
|               | • 0 do not wait (0 NOP)                                                                               |

#### **Macro Defines**:

- Set ACTIVE\_LM\_ADDR\_0 or ACTIVE\_LM\_ADDR\_1
- Set \_xbuf[i]\_lmem\_index = INDEX

# 2.26.2.4 xbuf\_alloc

### **Prototype:**

© 2008-2014 Netronome 245 of 256

```
xbuf_alloc(str_xbuf_name, NUMBER_OF_REGS, RW_INDICATOR)
```

#### **Description:**

Locally declares contiguous 'NUMBER\_OF\_REGS' sram xfer registers and sets an appropriate .xfer\_order.

Registers may be referenced as an array. This macro allows transfer registers to be divided into to a maximum of 4 buffers in IXP compatible indirect reference mode and 8 buffers in NFP indirect reference mode.

### Example 1:

### **Example 2:** [Using localmem]

```
xbuf_alloc(lmem_buf0, 8, READ_WRITE)
xbuf_bind_address(lmem_buf0, 0x100, 0x20, 0x0)
xbuf_activate(lmem_buf0, 0, 0, 1)

ipv4_cksum_verify(lmem_buf0, 0xb)
...
xbuf_deactivate(lmem_buf0)
xbuf_free(lmem_buf0)
```

#### **Instruction Count:** 0



# **Note**

For local memory buffers: lmem\_buf0, lmem\_buf1, ..., lmem\_buf15 must be used.

### Table 2.327. xbuf\_alloc parameters

| Name           | Description                                                                                                                                     |
|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| str_xbuf_name  | String uniquely identifying transfer register buffer                                                                                            |
| NUMBER_OF_REGS | Number of transfer registers to allocate                                                                                                        |
|                | String = read, write, or read_write, which which will specify the transfer registers as read only, write only, or read/write transfer registers |

# 2.26.2.5 xbuf\_free

# **Prototype:**

```
xbuf_free(str_xbuf_name)
```

# **Description**:

Used to deallocate transfer registers.

© 2008-2014 Netronome 246 of 256

### **Example:**

### **Example 2:** [Using Localmem]

```
xbuf_alloc(lmem_buf0, 8, READ_WRITE)
xbuf_bind_address(lmem_buf0, 0x100, 0x20, 0x0)
xbuf_activate(lmem_buf0, 0, 0, 1)

ipv4_cksum_verify(lmem_buf0, 0xb)
...
xbuf_deactivate(lmem_buf0)
xbuf_free(lmem_buf0)
```

#### **Instruction Count:** 0



### **Note**

For local memory buffers: lmem\_buf0, lmem\_buf1, ..., lmem\_buf15 must be used.

# Table 2.328. xbuf\_free parameters

| Name          | Description                      |
|---------------|----------------------------------|
| str_xbuf_name | Name of transfer register buffer |

# 2.26.2.6 xbuf\_link

#### **Prototype:**

```
xbuf_link(str_xbuf_name, str_nextxbuf_name)
```

### **Description:**

Link one transfer register buffer to another.

The purpose is to allow processing streams of bytes by continually loading buffers and providing macros that can traverse the buffers.

### Example 1:

© 2008-2014 Netronome 247 of 256

# Example 2: [Using Localmem]

```
xbuf_alloc(lmem_buf0, 8, READ_WRITE)
xbuf_bind_address(lmem_buf0, 0x100, 0x20, 0x0)
xbuf_activate(lmem_buf0, 0, 0, 1)

xbuf_alloc(lmem_buf1, 8, READ_WRITE)
xbuf_bind_address(lmem_buf1, 0x100, 0x20, 32)
xbuf_activate(lmem_buf1, 1, 0, 1)
xbuf_link(lmem_buf0, lmem_buf1)
ipv4_cksum_verify(lmem_buf0, 0xb)
...
xbuf_deactivate(lmem_buf0)
xbuf_free(lmem_buf0)
```

#### **Instruction Count:** 0



# **Note**

For local memory buffers: lmem\_buf0, lmem\_buf1, ..., lmem\_buf15 must be used.

### Table 2.329. xbuf\_link parameters

| Name              | Description                                                                             |
|-------------------|-----------------------------------------------------------------------------------------|
| str_xbuf_name     | Transfer buffer allocated by xbuf_alloc                                                 |
| str_nextxbuf_name | Another transfer buffer allocated by xbuf_alloc. Next buffer continues stream of bytes. |

# 2.26.2.7 xbuf\_find

### **Prototype:**

```
xbuf_find(xfer_name)
```

#### **Description:**

Given a transfer register name, removes special characters and array notation and then checks if the XBUF token name is an allocated XBUF.

This macro makes this XBUF the current XBUF.

### **Example:**

#### **Instruction Count:** 0

© 2008-2014 Netronome 248 of 256



# **Note**

For local memory buffers: lmem\_buf0, lmem\_buf1, ..., lmem\_buf15 must be used.

### Table 2.330. xbuf\_find parameters

| Name      | Description                             |
|-----------|-----------------------------------------|
| xfer_name | Transfer buffer allocated by xbuf_alloc |

# 2.26.2.8 xbuf\_param\_set

#### **Prototype:**

```
xbuf_param_set(str_xbuf_name)
```

#### **Description:**

Set global internal \_cur\_xbuf\_name, \_cur\_xbuf\_size and \_cur\_xbuf\_next parameters.

This macro is used for following a chain of xbufs. The side-effect of this macro is to modify <code>\_cur\_xbuf\_name</code>, <code>\_cur\_xbuf\_size</code> and <code>\_cur\_xbuf\_next</code>.

# **Example:**

```
xbuf_alloc(a_reg, 4, read_write)
xbuf_alloc(b_reg, 4, read_write)

immed32(a_reg[0], 0x01000CCC)
immed32(a_reg[1], 0xCCCC0030)
immed32(a_reg[2], 0x788D43B7)
immed32(a_reg[3], 0x0032AAAA)

xbuf_param_set(a_reg)
xbuf_xfer_set(_BUF0, a_reg, 0)
//_BUF0_REG0 should be equal to 0x01000CCC
//_BUF0_REG1 should be equal to 0xCCCC0030
//_BUF0_REG2 should be equal to 0x788D43B7
//_BUF0_REG3 should be equal to 0x0032AAAA
```

#### **Instruction Count:** 0



### **Note**

For local memory buffers: lmem\_buf0, lmem\_buf1, ..., lmem\_buf15 must be used.

### Table 2.331. xbuf\_param\_set parameters

| Name          | Description                  |
|---------------|------------------------------|
| str_xbuf_name | Name of sram transfer buffer |

© 2008-2014 Netronome 249 of 256

# 2.26.2.9 xbuf\_xfer\_set

# **Prototype:**

```
xbuf_xfer_set(XFER_TOKEN, str_xbuf_name, BYTE_OFFSET)
```

# **Description**:

Define the register token sequence from the xbufs, starting at the longword indicated by BYTE\_OFFSET.

These tokens can then be used as individual identification of transfer registers. The search for transfers can span multiple linked xbufs. The side-effect of this macro is to modify global accessible tokens \_XFER0, \_XFER1, ..., \_XFER7.

### **Example:**

```
xbuf_alloc(a_reg, 4, read_write)
xbuf_alloc(b_reg, 4, read_write)

immed32(a_reg[0], 0x01000CCC)
immed32(a_reg[1], 0xCCCC0030)
immed32(a_reg[2], 0x788D43B7)
immed32(a_reg[3], 0x0032AAAA)

xbuf_param_set(a_reg)
xbuf_xfer_set(_BUF0, a_reg, 0)
//_BUF0_REGO should be equal to 0x01000CCC
//_BUF0_REG1 should be equal to 0xCCCC0030
//_BUF0_REG2 should be equal to 0x788D43B7
//_BUF0_REG3 should be equal to 0x0032AAAA
```

#### **Instruction Count:** 0

#### Table 2.332. xbuf\_xfer\_set parameters

| Name          | Description                                                                                                                                                                                                                                 |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| XFER_TOKEN    | _S_XFER define tokens _XFER0 through _XFER15/_XFER31 _SRD_XFER define tokens _SRD_XFER0 through _SRD_XFER15/_SRD_XFER31 _SWR_XFER define tokens _SWR_XFER0 through _SWR_XFER15/_SWR_XFER31 _D_XFER define tokens _D_XFER0 through _D_XFER15 |
|               | _BUF2 define tokens _BUF2_REG0 through _BUF2_REG7 _BUF3 define tokens _BUF3_REG0 through _BUF3_REG7                                                                                                                                         |
| str_xbuf_name | Name of first sram transfer buffer                                                                                                                                                                                                          |
| BYTE_OFFSET   | Byte offset where _XFER0 is                                                                                                                                                                                                                 |

© 2008-2014 Netronome 250 of 256

# **2.26.2.10** xbuf extract

# **Prototype:**

xbuf\_extract(out\_byte\_field, str\_xbuf\_name, window\_start, field\_start, number\_of\_bytes)

# **Description**:

Extract a numeric byte field from a register buffer.



### Note

- 1. No error checking in order to minimize the number of instructions. If users try to extract more than 4 bytes or pass in an field-offset that is bigger than the buffer size, the result will be undefined.
- 2. If the source buffer is GPRs, users can define a compile option \_EXTRACT\_FROM\_BANK\_B\_GPR if they know for sure that the source is in bank B. When defined, this option makes this macro skip moving the source register to bank B, hence saving 1 to 2 instructions.

# **Example:**

```
xbuf_alloc(wbuf, 2, read_write)
immed32(wbuf[0], 0x01020304)
immed32(wbuf[1], 0x50607080)

xbuf_alloc(wbuf_next1, 2, read_write)
immed32(wbuf_next1[0], 0x13459851)
immed32(wbuf_next1[1], 0x198428e5)

xbuf_alloc(wbuf_next2, 2, read_write)
immed32(wbuf_next2[0], 0x11111111)
immed32(wbuf_next2[1], 0x22222222)

xbuf_link(wbuf, wbuf_next1)
xbuf_link(wbuf, wbuf_next1)
xbuf_link(wbuf_next1, wbuf_next2)

alu[win_start, --, B, 3]
alu[field_start, --, B, 4]

xbuf_extract(out_byte_field, wbuf, win_start, field_start, num_of_bytes)
```

#### **Instruction Count:** 1-12

### Table 2.333. xbuf\_extract parameters

| Name           | Description                       |
|----------------|-----------------------------------|
| out_byte_field | GPR output field, right justified |

© 2008-2014 Netronome 251 of 256

| Name            | Description                                                                                                                                     |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| str_xbuf_name   | Name of source to extract from. It can be a buffer of transfer registers, local memory, or GPRs.                                                |
| window_start    | Start byte position of window to extract from. Offset from the beginning of the buffer to the location of the window to extract from.           |
| field_start     | Byte offset of the field to be extracted starting from window_start. window_start + field_start -> exact byte location of first byte to extract |
| number_of_bytes | Number of bytes to extract. Because out_byte_field is a 32-bit GPR, maximum number of bytes to extract is 4.                                    |

# 2.26.2.11 xbuf\_extract\_frm\_linked\_bufs

# **Prototype:**

xbuf\_extract\_frm\_linked\_bufs(out\_byte\_field, str\_xbuf\_name, window\_start, field\_start,
number\_of\_bytes, DATA\_SPREAD)

# **Description**:

Extract a numeric byte field from a register buffer.

The source of data may be spread in 2 buffers: str\_xbuf\_name and the buffer that is linked to it. DATA\_SPREAD indicates whether or not the data spreads 2 buffers. If DATA\_SPREAD = 0, this macro functions the same way as xbuf\_extract.

**Instruction Count:** 1-15

Table 2.334. xbuf\_extract\_frm\_linked\_bufs parameters

| Name            | Description                                                                                                        |
|-----------------|--------------------------------------------------------------------------------------------------------------------|
| out_byte_field  | GPR output field, right justified                                                                                  |
| str_xbuf_name   | Name of sram read transfer register                                                                                |
| window_start    | Start byte position of window or header                                                                            |
| field_start     | Start byte offset of field from window start                                                                       |
| number_of_bytes | Number of bytes to extract. Because the out_byte_field is a GPR (32-bit), maximum number of bytes to extract is 4. |
| DATA_SPREAD     | CONSTANT to indicate whether source data spreads 2 buffers                                                         |
|                 | • 1: If part of data to be extracted spreads into buffer linked to in_src_xbuf                                     |
|                 | • 0: All data to be extracted resides in str_xbuf_name.                                                            |

# 2.26.2.12 xbuf\_type\_extract

# **Prototype:**

© 2008-2014 Netronome 252 of 256

xbuf\_type\_extract(out\_field, str\_xbuf\_name, WINDOW\_START, FIELD\_START, SIZE, DATATYPE)

#### **Description:**

Extract a specified number of bytes from xbuf.

Perform endian swap if global define LITTLE\_ENDIAN.

### **Example:**

**Instruction Count:** 8-10

### Table 2.335. xbuf\_type\_extract parameters

| Name          | Description                                                      |
|---------------|------------------------------------------------------------------|
| out_field     | GPR containing field, right justified                            |
| str_xbuf_name | Name of sram transfer register buffer                            |
| WINDOW_START  | Start position (in datatype increments) of window or header      |
| FIELD_START   | Start offset (in datatype increments) of field from window start |
| SIZE          | Size of field                                                    |
| DATATYPE      | Datatype of field                                                |

# 2.26.2.13 xbuf\_insert

### **Prototype:**

xbuf\_insert(io\_str\_xbuf\_name, in\_byte\_field, window\_start, field\_start, number\_of\_bytes)

# **Description**:

Insert specified bytes of a numeric byte field into xbuf buffer at the specified start byte offset.



### Note

1. No error checking in order to minimize the number of instruction. If users try to insert more than 4 bytes or pass in an field-offset that is bigger than the buffer size, the result will be undefined.

© 2008-2014 Netronome 253 of 256

2. If the source register is GPRs, users can define a compile option \_INSERT\_BYTE\_FROM\_BANK\_B\_GPR if they know for sure that the source is in bank B. When defined, this option makes this macro skip moving the source register to bank B, hence save 1 instruction.

# **Example usage:**

```
xbuf_alloc($$io_xbuf_dest, 8, read_write)
...
move(in_byte_field, 0x12345678)
//Insert in_byte_field into io_xbuf_dest starting at byte offset 12
xbuf_insert($io_xbuf_dest, in_byte_field, 0, 12, 4)
...
```

**Instruction Count:** (1 \* number of words to insert) for constant offsets and size

# Table 2.336. xbuf\_insert parameters

| Name             | Description                                                                                                                                   |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| io_str_xbuf_name | Name of xbuf register where byte field is to be inserted                                                                                      |
| in_byte_field    | GPR, read transfer register or local memory register that contains byte field to be inserted.                                                 |
| window_start     | Start byte position of window to insert to. This is offset from beginning of output buffer to location of window to insert into.              |
| field_start      | Byte offset of field to be inserted starting from window_start. window_start + field_start -> exact byte location of the first byte to insert |
| number_of_bytes  | Number of bytes to insert. Because in_byte_field is a 32-bit register, maximum number of bytes is 4.                                          |

# 2.26.2.14 xbuf\_copy

### **Prototype:**

xbuf\_copy(out\_dest\_xbuf, out\_last\_element, dest\_start\_byte, in\_src\_xbuf, src\_start\_byte, in\_prepend, total\_bytes\_to\_copy, DATA\_SPREAD)

### **Description:**

XBUF Copy.

### Table 2.337. xbuf\_copy parameters

| Name | Description                                                                                                                                                                                                                                                    |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | Name of output buffer. Can be SRAM write registers, DRAM write registers, local memory, or GPR.                                                                                                                                                                |
|      | GPR to contain last element of destination buffer. This output is very useful when the destination buffer elements are write transfer register and the copy results in an incompleted last element (not all 4 bytes are filled). The need for out_last_element |

© 2008-2014 Netronome 254 of 256

| Name                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                     | arises when users want to copy another buffer into a paritally-filled destination buffer. Users may find that the last long-word element in the destination is incompleted as the result of the previous copy. In that case, they will need to pass the out_last_element of the previous copy as the in_prepend to the current xbuf_copy. Otherwise, the bytes in the partially-filled write register element will be cleared. If users are sure that they do not need this value, they can pass the constant 0 to save one instruction. |
| dest_start_byte     | Absolute offset in bytes from beginning of output buffer to location where copied data will reside. Can be longword aligned or not (dest_start_byte $\%$ 4 = 0, 1, 2, or 3). Can be constant or GPR.                                                                                                                                                                                                                                                                                                                                     |
| in_src_xbuf         | Name of input buffer. Can be SRAM read registers, DRAM read registers, local memory, or GPR. Data to be copied can not spread in several buffers. In other words, all data has to be in in_src_xbuf. In order to have most efficient copy (ie. done with least number of instructions), in_src_xbuf should be buffer that actually contains the data. It is fine if the data spreads beyond in_src_xbuf, but it will take several more instructions if ALL the data does not reside in some buffers that are linked to in_src_xbuf.      |
| src_start_byte      | Absolute offset in bytes from beginning of input buffer. Can be longword aligned or not (src_start_byte $\%$ 4 = 0, 1, 2, or 3) Can be constant or GPR.                                                                                                                                                                                                                                                                                                                                                                                  |
| in_prepend          | GPR or constant containing bytes to be merged with first word in destination, prepended, if byte alignment of destination is not 0. Bytes to be merged must be at exact byte locations that they will occupy in first word of destination. All other bytes must be 0. In cases in_prepend is not needed, just pass constant 0.                                                                                                                                                                                                           |
| total_bytes_to_copy | Total number of bytes to copy. Can be constant or GPR. Maximum number of bytes is dependent on maximum size of output buffer.                                                                                                                                                                                                                                                                                                                                                                                                            |
|                     | <ul> <li>If out_dest_xbuf is xfer registers or GPRs buffer: maximum size is 64 bytes.</li> <li>If out_dest_xbuf is local memory buffer: maximum size is 32 bytes.</li> </ul>                                                                                                                                                                                                                                                                                                                                                             |
| DATA_SPREAD         | • 1: If part of data to be copied spreads into buffer(s) linked to in_src_xbuf                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                     | • 0: All data to be copied resides in in_src_xbuf. DATA_SPREAD = 0 or 1 are allowed for copy with constant offsets and size. In other words, if ALL offsets and size are constants, data to be copied can completely reside in in_src_xbuf, or be spread between in_src_buf and buffer that is linked to in_src_buf. For copy with run-time offsets and/or run-time size DATA_SPREAD must be 0. In other words, data spreading is not allowed for xbuf_copy with any run-time parameters.                                                |

© 2008-2014 Netronome 255 of 256

# 3. Technical Support

To obtain additional information, or to provide feedback, please email support@netronome.com> or contact
the nearest Netronome technical support representative.

© 2008-2014 Netronome 256 of 256