net/tap: fix to populate FDs in secondary process
[dpdk.git] / drivers / net / bnxt / tf_core / tf_core.h
1 /* SPDX-License-Identifier: BSD-3-Clause
2  * Copyright(c) 2019-2021 Broadcom
3  * All rights reserved.
4  */
5
6 #ifndef _TF_CORE_H_
7 #define _TF_CORE_H_
8
9 #include <stdint.h>
10 #include <stdlib.h>
11 #include <stdbool.h>
12 #include <stdio.h>
13 #include "hcapi_cfa_defs.h"
14 #include "tf_project.h"
15
16 /**
17  * @file
18  *
19  * Truflow Core API Header File
20  */
21
22 /********** BEGIN Truflow Core DEFINITIONS **********/
23
24 #define TF_KILOBYTE  1024
25 #define TF_MEGABYTE  (1024 * 1024)
26
27 /**
28  * direction
29  */
30 enum tf_dir {
31         TF_DIR_RX,  /**< Receive */
32         TF_DIR_TX,  /**< Transmit */
33         TF_DIR_MAX
34 };
35
36 /**
37  * memory choice
38  */
39 enum tf_mem {
40         TF_MEM_INTERNAL, /**< Internal */
41         TF_MEM_EXTERNAL, /**< External */
42         TF_MEM_MAX
43 };
44
45 /**
46  * External memory control channel type
47  */
48 enum tf_ext_mem_chan_type {
49         /**
50          * Direct memory write(Wh+/SR)
51          */
52         TF_EXT_MEM_CHAN_TYPE_DIRECT = 0,
53         /**
54          * Ring interface MPC
55          */
56         TF_EXT_MEM_CHAN_TYPE_RING_IF,
57         /**
58          * Use HWRM message to firmware
59          */
60         TF_EXT_MEM_CHAN_TYPE_FW,
61         /**
62          * Use ring_if message to firmware
63          */
64         TF_EXT_MEM_CHAN_TYPE_RING_IF_FW,
65         TF_EXT_MEM_CHAN_TYPE_MAX
66 };
67
68 /**
69  * WC TCAM number of slice per row that devices supported
70  */
71 enum tf_wc_num_slice {
72         TF_WC_TCAM_1_SLICE_PER_ROW = 1,
73         TF_WC_TCAM_2_SLICE_PER_ROW = 2,
74         TF_WC_TCAM_4_SLICE_PER_ROW = 4,
75         TF_WC_TCAM_8_SLICE_PER_ROW = 8,
76 };
77
78 /**
79  * Bank identifier
80  */
81 enum tf_sram_bank_id {
82         TF_SRAM_BANK_ID_0,              /**< SRAM Bank 0 id */
83         TF_SRAM_BANK_ID_1,              /**< SRAM Bank 1 id */
84         TF_SRAM_BANK_ID_2,              /**< SRAM Bank 2 id */
85         TF_SRAM_BANK_ID_3,              /**< SRAM Bank 3 id */
86         TF_SRAM_BANK_ID_MAX             /**< SRAM Bank index limit */
87 };
88
89 /**
90  * EEM record AR helper
91  *
92  * Helper to handle the Action Record Pointer in the EEM Record Entry.
93  *
94  * Convert absolute offset to action record pointer in EEM record entry
95  * Convert action record pointer in EEM record entry to absolute offset
96  */
97 #define TF_ACT_REC_OFFSET_2_PTR(offset) ((offset) >> 4)
98 #define TF_ACT_REC_PTR_2_OFFSET(offset) ((offset) << 4)
99
100 /*
101  * Helper Macros
102  */
103 #define TF_BITS_2_BYTES(num_bits) (((num_bits) + 7) / 8)
104
105 /********** BEGIN API FUNCTION PROTOTYPES/PARAMETERS **********/
106
107 /**
108  * @page general General
109  *
110  * @ref tf_open_session
111  *
112  * @ref tf_attach_session
113  *
114  * @ref tf_close_session
115  */
116
117 /**
118  * Session Version defines
119  *
120  * The version controls the format of the tf_session and
121  * tf_session_info structure. This is to assure upgrade between
122  * versions can be supported.
123  */
124 #define TF_SESSION_VER_MAJOR  1   /**< Major Version */
125 #define TF_SESSION_VER_MINOR  0   /**< Minor Version */
126 #define TF_SESSION_VER_UPDATE 0   /**< Update Version */
127
128 /**
129  * Session Name
130  *
131  * Name of the TruFlow control channel interface.  Expects
132  * format to be RTE Name specific, i.e. rte_eth_dev_get_name_by_port()
133  */
134 #define TF_SESSION_NAME_MAX       64
135
136 #define TF_FW_SESSION_ID_INVALID  0xFF  /**< Invalid FW Session ID define */
137
138 /**
139  * Session Identifier
140  *
141  * Unique session identifier which includes PCIe bus info to
142  * distinguish the PF and session info to identify the associated
143  * TruFlow session. Session ID is constructed from the passed in
144  * ctrl_chan_name in tf_open_session() together with an allocated
145  * fw_session_id. Done by TruFlow on tf_open_session().
146  */
147 union tf_session_id {
148         uint32_t id;
149         struct {
150                 uint8_t domain;
151                 uint8_t bus;
152                 uint8_t device;
153                 uint8_t fw_session_id;
154         } internal;
155 };
156
157 /**
158  * Session Client Identifier
159  *
160  * Unique identifier for a client within a session. Session Client ID
161  * is constructed from the passed in session and a firmware allocated
162  * fw_session_client_id. Done by TruFlow on tf_open_session().
163  */
164 union tf_session_client_id {
165         uint16_t id;
166         struct {
167                 uint8_t fw_session_id;
168                 uint8_t fw_session_client_id;
169         } internal;
170 };
171
172 /**
173  * Session Version
174  *
175  * The version controls the format of the tf_session and
176  * tf_session_info structure. This is to assure upgrade between
177  * versions can be supported.
178  *
179  * Please see the TF_VER_MAJOR/MINOR and UPDATE defines.
180  */
181 struct tf_session_version {
182         uint8_t major;
183         uint8_t minor;
184         uint8_t update;
185 };
186
187 /**
188  * Session supported device types
189  */
190 enum tf_device_type {
191         TF_DEVICE_TYPE_WH = 0, /**< Whitney+  */
192         TF_DEVICE_TYPE_SR,     /**< Stingray  */
193         TF_DEVICE_TYPE_THOR,   /**< Thor      */
194         TF_DEVICE_TYPE_MAX     /**< Maximum   */
195 };
196
197 /**
198  * Module types
199  */
200 enum tf_module_type {
201         /**
202          * Identifier module
203          */
204         TF_MODULE_TYPE_IDENTIFIER,
205         /**
206          * Table type module
207          */
208         TF_MODULE_TYPE_TABLE,
209         /**
210          * TCAM module
211          */
212         TF_MODULE_TYPE_TCAM,
213         /**
214          * EM module
215          */
216         TF_MODULE_TYPE_EM,
217         TF_MODULE_TYPE_MAX
218 };
219
220 /**
221  * Identifier resource types
222  */
223 enum tf_identifier_type {
224         /**
225          *  WH/SR/TH
226          *  The L2 Context is returned from the L2 Ctxt TCAM lookup
227          *  and can be used in WC TCAM or EM keys to virtualize further
228          *  lookups.
229          */
230         TF_IDENT_TYPE_L2_CTXT_HIGH,
231         /**
232          *  WH/SR/TH
233          *  The L2 Context is returned from the L2 Ctxt TCAM lookup
234          *  and can be used in WC TCAM or EM keys to virtualize further
235          *  lookups.
236          */
237         TF_IDENT_TYPE_L2_CTXT_LOW,
238         /**
239          *  WH/SR/TH
240          *  The WC profile func is returned from the L2 Ctxt TCAM lookup
241          *  to enable virtualization of the profile TCAM.
242          */
243         TF_IDENT_TYPE_PROF_FUNC,
244         /**
245          *  WH/SR/TH
246          *  The WC profile ID is included in the WC lookup key
247          *  to enable virtualization of the WC TCAM hardware.
248          */
249         TF_IDENT_TYPE_WC_PROF,
250         /**
251          *  WH/SR/TH
252          *  The EM profile ID is included in the EM lookup key
253          *  to enable virtualization of the EM hardware.
254          */
255         TF_IDENT_TYPE_EM_PROF,
256         /**
257          *  (Future)
258          *  The L2 func is included in the ILT result and from recycling to
259          *  enable virtualization of further lookups.
260          */
261         TF_IDENT_TYPE_L2_FUNC,
262         TF_IDENT_TYPE_MAX
263 };
264
265 /**
266  * Enumeration of TruFlow table types. A table type is used to identify a
267  * resource object.
268  *
269  * NOTE: The table type TF_TBL_TYPE_EXT is unique in that it is
270  * the only table type that is connected with a table scope.
271  */
272 enum tf_tbl_type {
273         /* Internal */
274
275         /** Wh+/SR/TH Action Record */
276         TF_TBL_TYPE_FULL_ACT_RECORD,
277         /** TH Compact Action Record */
278         TF_TBL_TYPE_COMPACT_ACT_RECORD,
279         /** (Future) Multicast Groups */
280         TF_TBL_TYPE_MCAST_GROUPS,
281         /** Wh+/SR/TH Action Encap 8 Bytes */
282         TF_TBL_TYPE_ACT_ENCAP_8B,
283         /** Wh+/SR/TH Action Encap 16 Bytes */
284         TF_TBL_TYPE_ACT_ENCAP_16B,
285         /** WH+/SR/TH Action Encap 32 Bytes */
286         TF_TBL_TYPE_ACT_ENCAP_32B,
287         /** Wh+/SR/TH Action Encap 64 Bytes */
288         TF_TBL_TYPE_ACT_ENCAP_64B,
289         /** WH+/SR/TH Action Source Properties SMAC */
290         TF_TBL_TYPE_ACT_SP_SMAC,
291         /** Wh+/SR/TH Action Source Properties SMAC IPv4 */
292         TF_TBL_TYPE_ACT_SP_SMAC_IPV4,
293         /** WH+/SR/TH Action Source Properties SMAC IPv6 */
294         TF_TBL_TYPE_ACT_SP_SMAC_IPV6,
295         /** Wh+/SR/TH Action Statistics 64 Bits */
296         TF_TBL_TYPE_ACT_STATS_64,
297         /** Wh+/SR Action Modify IPv4 Source */
298         TF_TBL_TYPE_ACT_MODIFY_IPV4,
299         /** TH 8B Modify Record */
300         TF_TBL_TYPE_ACT_MODIFY_8B,
301         /** TH 16B Modify Record */
302         TF_TBL_TYPE_ACT_MODIFY_16B,
303         /** TH 32B Modify Record */
304         TF_TBL_TYPE_ACT_MODIFY_32B,
305         /** TH 64B Modify Record */
306         TF_TBL_TYPE_ACT_MODIFY_64B,
307         /** Meter Profiles */
308         TF_TBL_TYPE_METER_PROF,
309         /** Meter Instance */
310         TF_TBL_TYPE_METER_INST,
311         /** Wh+/SR/Th Mirror Config */
312         TF_TBL_TYPE_MIRROR_CONFIG,
313         /** (Future) UPAR */
314         TF_TBL_TYPE_UPAR,
315         /** (Future) TH Metadata  */
316         TF_TBL_TYPE_METADATA,
317         /** (Future) TH CT State  */
318         TF_TBL_TYPE_CT_STATE,
319         /** (Future) TH Range Profile  */
320         TF_TBL_TYPE_RANGE_PROF,
321         /** TH EM Flexible Key builder */
322         TF_TBL_TYPE_EM_FKB,
323         /** TH WC Flexible Key builder */
324         TF_TBL_TYPE_WC_FKB,
325         /** Meter Drop Counter */
326         TF_TBL_TYPE_METER_DROP_CNT,
327
328         /* External */
329
330         /**
331          * External table type - initially 1 poolsize entries.
332          * All External table types are associated with a table
333          * scope. Internal types are not.  Currently this is
334          * a pool of 64B entries.
335          */
336         TF_TBL_TYPE_EXT,
337         TF_TBL_TYPE_MAX
338 };
339
340 /** Enable Shared TCAM Management
341  *
342  *  This feature allows for management of high and low pools within
343  *  the WC TCAM.  These pools are only valid when this feature is enabled.
344  *
345  *  For normal OVS-DPDK operation, this feature is not required and can
346  *  be disabled by commenting out TF_TCAM_SHARED in this header file.
347  *
348  *  Operation:
349  *
350  *  When a shared session is created with WC TCAM entries allocated during
351  *  tf_open_session(), the TF_TCAM_TBL_TYPE_WC_TCAM pool entries will be divided
352  *  into 2 equal pools - TF_TCAM_TBL_TYPE_WC_TCAM_HIGH and
353  *  TF_TCAM_TBL_TYPE_WC_TCAM_LOW.
354  *
355  *  The user will allocate and free entries from either of these pools to obtain
356  *  WC_TCAM entry offsets.  For the WC_TCAM_HI/LO management, alloc/free is done
357  *  using the tf_alloc_tcam_entry()/tf_free_tcam_entry() APIs for the shared
358  *  session.
359  *
360  *  The use case for this feature is so that applications can have a shared
361  *  session and use the TF core to allocate/set/free entries within a given
362  *  region of the WC_TCAM within the shared session.  Application A only writes
363  *  to the LOW region for example and Application B only writes to the HIGH
364  *  region during normal operation.  After Application A goes down, Application
365  *  B may decide to overwrite the LOW region with the HIGH region's entries
366  *  and switch to the low region.
367  *
368  *  For other TCAM types in the  shared session, no alloc/free operations are
369  *  permitted. Only set should be used for other TCAM table types after getting
370  *  the range as provided by the tf_get_resource_info() API.
371  *
372  */
373 #define TF_TCAM_SHARED 1
374
375 /**
376  * TCAM table type
377  */
378 enum tf_tcam_tbl_type {
379         /** L2 Context TCAM */
380         TF_TCAM_TBL_TYPE_L2_CTXT_TCAM_HIGH,
381         /** L2 Context TCAM */
382         TF_TCAM_TBL_TYPE_L2_CTXT_TCAM_LOW,
383         /** Profile TCAM */
384         TF_TCAM_TBL_TYPE_PROF_TCAM,
385         /** Wildcard TCAM */
386         TF_TCAM_TBL_TYPE_WC_TCAM,
387         /** Source Properties TCAM */
388         TF_TCAM_TBL_TYPE_SP_TCAM,
389         /** Connection Tracking Rule TCAM */
390         TF_TCAM_TBL_TYPE_CT_RULE_TCAM,
391         /** Virtual Edge Bridge TCAM */
392         TF_TCAM_TBL_TYPE_VEB_TCAM,
393 #ifdef TF_TCAM_SHARED
394         /** Wildcard TCAM HI Priority */
395         TF_TCAM_TBL_TYPE_WC_TCAM_HIGH,
396         /** Wildcard TCAM Low Priority */
397         TF_TCAM_TBL_TYPE_WC_TCAM_LOW,
398 #endif /* TF_TCAM_SHARED */
399         TF_TCAM_TBL_TYPE_MAX
400 };
401
402 /**
403  * SEARCH STATUS
404  */
405 enum tf_search_status {
406         /** The entry was not found, but an idx was allocated if requested. */
407         MISS,
408         /** The entry was found, and the result/idx are valid */
409         HIT,
410         /** The entry was not found and the table is full */
411         REJECT
412 };
413
414 /**
415  * EM Resources
416  * These defines are provisioned during
417  * tf_open_session()
418  */
419 enum tf_em_tbl_type {
420         /** The number of internal EM records for the session */
421         TF_EM_TBL_TYPE_EM_RECORD,
422         /** The number of table scopes requested */
423         TF_EM_TBL_TYPE_TBL_SCOPE,
424         TF_EM_TBL_TYPE_MAX
425 };
426
427 /**
428  * TruFlow Session Information
429  *
430  * Structure defining a TruFlow Session, also known as a Management
431  * session. This structure is initialized at time of
432  * tf_open_session(). It is passed to all of the TruFlow APIs as way
433  * to prescribe and isolate resources between different TruFlow ULP
434  * Applications.
435  *
436  * Ownership of the elements is split between ULP and TruFlow. Please
437  * see the individual elements.
438  */
439 struct tf_session_info {
440         /**
441          * TruFlow Version. Used to control the structure layout when
442          * sharing sessions. No guarantee that a secondary process
443          * would come from the same version of an executable.
444          * TruFlow initializes this variable on tf_open_session().
445          *
446          * Owner:  TruFlow
447          * Access: TruFlow
448          */
449         struct tf_session_version ver;
450         /**
451          * will be STAILQ_ENTRY(tf_session_info) next
452          *
453          * Owner:  ULP
454          * Access: ULP
455          */
456         void                 *next;
457         /**
458          * Session ID is a unique identifier for the session. TruFlow
459          * initializes this variable during tf_open_session()
460          * processing.
461          *
462          * Owner:  TruFlow
463          * Access: Truflow & ULP
464          */
465         union tf_session_id   session_id;
466         /**
467          * Protects access to core_data. Lock is initialized and owned
468          * by ULP. TruFlow can access the core_data without checking
469          * the lock.
470          *
471          * Owner:  ULP
472          * Access: ULP
473          */
474         uint8_t               spin_lock;
475         /**
476          * The core_data holds the TruFlow tf_session data
477          * structure. This memory is allocated and owned by TruFlow on
478          * tf_open_session().
479          *
480          * TruFlow uses this memory for session management control
481          * until the session is closed by ULP. Access control is done
482          * by the spin_lock which ULP controls ahead of TruFlow API
483          * calls.
484          *
485          * Please see tf_open_session_parms for specification details
486          * on this variable.
487          *
488          * Owner:  TruFlow
489          * Access: TruFlow
490          */
491         void                 *core_data;
492         /**
493          * The core_data_sz_bytes specifies the size of core_data in
494          * bytes.
495          *
496          * The size is set by TruFlow on tf_open_session().
497          *
498          * Please see tf_open_session_parms for specification details
499          * on this variable.
500          *
501          * Owner:  TruFlow
502          * Access: TruFlow
503          */
504         uint32_t              core_data_sz_bytes;
505 };
506
507 /**
508  * TruFlow handle
509  *
510  * Contains a pointer to the session info. Allocated by ULP and passed
511  * to TruFlow using tf_open_session(). TruFlow will populate the
512  * session info at that time. A TruFlow Session can be used by more
513  * than one PF/VF by using the tf_open_session().
514  *
515  * It is expected that ULP allocates this memory as shared memory.
516  *
517  * NOTE: This struct must be within the BNXT PMD struct bnxt
518  *       (bp). This allows use of container_of() to get access to the PMD.
519  */
520 struct tf {
521         struct tf_session_info *session;
522         /**
523          * the pointer to the parent bp struct
524          */
525         void *bp;
526 };
527
528 /**
529  * Identifier resource definition
530  */
531 struct tf_identifier_resources {
532         /**
533          * Array of TF Identifiers where each entry is expected to be
534          * set to the requested resource number of that specific type.
535          * The index used is tf_identifier_type.
536          */
537         uint16_t cnt[TF_IDENT_TYPE_MAX];
538 };
539
540 /**
541  * Table type resource definition
542  */
543 struct tf_tbl_resources {
544         /**
545          * Array of TF Table types where each entry is expected to be
546          * set to the requested resource number of that specific
547          * type. The index used is tf_tbl_type.
548          */
549         uint16_t cnt[TF_TBL_TYPE_MAX];
550 };
551
552 /**
553  * TCAM type resource definition
554  */
555 struct tf_tcam_resources {
556         /**
557          * Array of TF TCAM types where each entry is expected to be
558          * set to the requested resource number of that specific
559          * type. The index used is tf_tcam_tbl_type.
560          */
561         uint16_t cnt[TF_TCAM_TBL_TYPE_MAX];
562 };
563
564 /**
565  * EM type resource definition
566  */
567 struct tf_em_resources {
568         /**
569          * Array of TF EM table types where each entry is expected to
570          * be set to the requested resource number of that specific
571          * type. The index used is tf_em_tbl_type.
572          */
573         uint16_t cnt[TF_EM_TBL_TYPE_MAX];
574 };
575
576 /**
577  * tf_session_resources parameter definition.
578  */
579 struct tf_session_resources {
580         /**
581          * [in] Requested Identifier Resources
582          *
583          * Number of identifier resources requested for the
584          * session.
585          */
586         struct tf_identifier_resources ident_cnt[TF_DIR_MAX];
587         /**
588          * [in] Requested Index Table resource counts
589          *
590          * The number of index table resources requested for the
591          * session.
592          */
593         struct tf_tbl_resources tbl_cnt[TF_DIR_MAX];
594         /**
595          * [in] Requested TCAM Table resource counts
596          *
597          * The number of TCAM table resources requested for the
598          * session.
599          */
600
601         struct tf_tcam_resources tcam_cnt[TF_DIR_MAX];
602         /**
603          * [in] Requested EM resource counts
604          *
605          * The number of internal EM table resources requested for the
606          * session.
607          */
608         struct tf_em_resources em_cnt[TF_DIR_MAX];
609 };
610
611 /**
612  * tf_open_session parameters definition.
613  */
614 struct tf_open_session_parms {
615         /**
616          * [in] ctrl_chan_name
617          *
618          * String containing name of control channel interface to be
619          * used for this session to communicate with firmware.
620          *
621          * The ctrl_chan_name can be looked up by using
622          * rte_eth_dev_get_name_by_port() within the ULP.
623          *
624          * ctrl_chan_name will be used as part of a name for any
625          * shared memory allocation. The ctrl_chan_name is usually in format
626          * 0000:02:00.0. The name for shared session is 0000:02:00.0-tf_shared.
627          */
628         char ctrl_chan_name[TF_SESSION_NAME_MAX];
629         /**
630          * [in] shadow_copy
631          *
632          * Boolean controlling the use and availability of shadow
633          * copy. Shadow copy will allow the TruFlow to keep track of
634          * resource content on the firmware side without having to
635          * query firmware. Additional private session core_data will
636          * be allocated if this boolean is set to 'true', default
637          * 'false'.
638          *
639          * Size of memory depends on the NVM Resource settings for the
640          * control channel.
641          */
642         bool shadow_copy;
643         /**
644          * [in/out] session_id
645          *
646          * Session_id is unique per session.
647          *
648          * Session_id is composed of domain, bus, device and
649          * fw_session_id. The construction is done by parsing the
650          * ctrl_chan_name together with allocation of a fw_session_id.
651          *
652          * The session_id allows a session to be shared between devices.
653          */
654         union tf_session_id session_id;
655         /**
656          * [in/out] session_client_id
657          *
658          * Session_client_id is unique per client.
659          *
660          * Session_client_id is composed of session_id and the
661          * fw_session_client_id fw_session_id. The construction is
662          * done by parsing the ctrl_chan_name together with allocation
663          * of a fw_session_client_id during tf_open_session().
664          *
665          * A reference count will be incremented in the session on
666          * which a client is created.
667          *
668          * A session can first be closed if there is one Session
669          * Client left. Session Clients should closed using
670          * tf_close_session().
671          */
672         union tf_session_client_id session_client_id;
673         /**
674          * [in] device type
675          *
676          * Device type for the session.
677          */
678         enum tf_device_type device_type;
679         /**
680          * [in] resources
681          *
682          * Resource allocation for the session.
683          */
684         struct tf_session_resources resources;
685
686         /**
687          * [in] bp
688          * The pointer to the parent bp struct. This is only used for HWRM
689          * message passing within the portability layer. The type is struct
690          * bnxt.
691          */
692         void *bp;
693
694         /**
695          * [in]
696          *
697          * The number of slices per row for WC TCAM entry.
698          */
699         enum tf_wc_num_slice wc_num_slices;
700
701         /**
702          * [out] shared_session_creator
703          *
704          * Indicates whether the application created the session if set.
705          * Otherwise the shared session already existed.  Just for information
706          * purposes.
707          */
708         int shared_session_creator;
709 };
710
711 /**
712  * Opens a new TruFlow Session or session client.
713  *
714  * What gets created depends on the passed in tfp content. If the tfp does not
715  * have prior session data a new session with associated session client. If tfp
716  * has a session already a session client will be created. In both cases the
717  * session client is created using the provided ctrl_chan_name.
718  *
719  * In case of session creation TruFlow will allocate session specific memory to
720  * hold its session data. This data is private to TruFlow.
721  *
722  * No other TruFlow APIs will succeed unless this API is first called
723  * and succeeds.
724  *
725  * tf_open_session() returns a session id and session client id.  These are
726  * also stored within the tfp structure passed in to all other APIs.
727  *
728  * A Session or session client can be closed using tf_close_session().
729  *
730  * There are 2 types of sessions - shared and not.  For non-shared all
731  * the allocated resources are owned and managed by a single session instance.
732  * No other applications have access to the resources owned by the non-shared
733  * session.  For a shared session, resources are shared between 2 applications.
734  *
735  * When the caller of tf_open_session() sets the ctrl_chan_name[] to a name
736  * like "0000:02:00.0-tf_shared", it is a request to create a new "shared"
737  * session in the firmware or access the existing shared session. There is
738  * only 1 shared session that can be created. If the shared session has
739  * already been created in the firmware, this API will return this indication
740  * by clearing the shared_session_creator flag. Only the first shared session
741  * create will have the shared_session_creator flag set.
742  *
743  * The shared session should always be the first session to be created by
744  * application and the last session closed due to RM management preference.
745  *
746  * Sessions remain open in the firmware until the last client of the session
747  * closes the session (tf_close_session()).
748  *
749  * [in] tfp
750  *   Pointer to TF handle
751  *
752  * [in] parms
753  *   Pointer to open parameters
754  *
755  * Returns
756  *   - (0) if successful.
757  *   - (-EINVAL) on failure.
758  */
759 int tf_open_session(struct tf *tfp,
760                     struct tf_open_session_parms *parms);
761
762 /**
763  * General internal resource info
764  *
765  */
766 struct tf_resource_info {
767         uint16_t start;
768         uint16_t stride;
769 };
770
771 /**
772  * Identifier resource definition
773  */
774 struct tf_identifier_resource_info {
775         /**
776          * Array of TF Identifiers. The index used is tf_identifier_type.
777          */
778         struct tf_resource_info info[TF_IDENT_TYPE_MAX];
779 };
780
781 /**
782  * Table type resource info definition
783  */
784 struct tf_tbl_resource_info {
785         /**
786          * Array of TF Table types. The index used is tf_tbl_type.
787          */
788         struct tf_resource_info info[TF_TBL_TYPE_MAX];
789 };
790
791 /**
792  * TCAM type resource definition
793  */
794 struct tf_tcam_resource_info {
795         /**
796          * Array of TF TCAM types. The index used is tf_tcam_tbl_type.
797          */
798         struct tf_resource_info info[TF_TCAM_TBL_TYPE_MAX];
799 };
800
801 /**
802  * EM type resource definition
803  */
804 struct tf_em_resource_info {
805         /**
806          * Array of TF EM table types. The index used is tf_em_tbl_type.
807          */
808         struct tf_resource_info info[TF_EM_TBL_TYPE_MAX];
809 };
810
811 /**
812  * tf_session_resources parameter definition.
813  */
814 struct tf_session_resource_info {
815         /**
816          * [in] Requested Identifier Resources
817          *
818          * Number of identifier resources requested for the
819          * session.
820          */
821         struct tf_identifier_resource_info ident[TF_DIR_MAX];
822         /**
823          * [in] Requested Index Table resource counts
824          *
825          * The number of index table resources requested for the
826          * session.
827          */
828         struct tf_tbl_resource_info tbl[TF_DIR_MAX];
829         /**
830          * [in] Requested TCAM Table resource counts
831          *
832          * The number of TCAM table resources requested for the
833          * session.
834          */
835
836         struct tf_tcam_resource_info tcam[TF_DIR_MAX];
837         /**
838          * [in] Requested EM resource counts
839          *
840          * The number of internal EM table resources requested for the
841          * session.
842          */
843         struct tf_em_resource_info em[TF_DIR_MAX];
844 };
845
846 /**
847  * tf_get_session_resources parameter definition.
848  */
849 struct tf_get_session_info_parms {
850         /**
851          * [out] the structure is used to return the information of
852          * allocated resources.
853          *
854          */
855         struct tf_session_resource_info session_info;
856 };
857
858 /** (experimental)
859  * Gets info about a TruFlow Session
860  *
861  * Get info about the session which has been created.  Whether it exists and
862  * what resource start and stride offsets are in use.  This API is primarily
863  * intended to be used by an application which has created a shared session
864  * This application needs to obtain the resources which have already been
865  * allocated for the shared session.
866  *
867  * [in] tfp
868  *   Pointer to TF handle
869  *
870  * [in] parms
871  *   Pointer to get parameters
872  *
873  * Returns
874  *   - (0) if successful.
875  *   - (-EINVAL) on failure.
876  */
877 int tf_get_session_info(struct tf *tfp,
878                         struct tf_get_session_info_parms *parms);
879 /**
880  * Experimental
881  *
882  * tf_attach_session parameters definition.
883  */
884 struct tf_attach_session_parms {
885         /**
886          * [in] ctrl_chan_name
887          *
888          * String containing name of control channel interface to be
889          * used for this session to communicate with firmware.
890          *
891          * The ctrl_chan_name can be looked up by using
892          * rte_eth_dev_get_name_by_port() within the ULP.
893          *
894          * ctrl_chan_name will be used as part of a name for any
895          * shared memory allocation.
896          */
897         char ctrl_chan_name[TF_SESSION_NAME_MAX];
898
899         /**
900          * [in] attach_chan_name
901          *
902          * String containing name of attach channel interface to be
903          * used for this session.
904          *
905          * The attach_chan_name must be given to a 2nd process after
906          * the primary process has been created. This is the
907          * ctrl_chan_name of the primary process and is used to find
908          * the shared memory for the session that the attach is going
909          * to use.
910          */
911         char attach_chan_name[TF_SESSION_NAME_MAX];
912
913         /**
914          * [in] session_id
915          *
916          * Session_id is unique per session. For Attach the session_id
917          * should be the session_id that was returned on the first
918          * open.
919          *
920          * Session_id is composed of domain, bus, device and
921          * fw_session_id. The construction is done by parsing the
922          * ctrl_chan_name together with allocation of a fw_session_id
923          * during tf_open_session().
924          *
925          * A reference count will be incremented on attach. A session
926          * is first fully closed when reference count is zero by
927          * calling tf_close_session().
928          */
929         union tf_session_id session_id;
930 };
931
932 /**
933  * Experimental
934  *
935  * Allows a 2nd application instance to attach to an existing
936  * session. Used when a session is to be shared between two processes.
937  *
938  * Attach will increment a ref count as to manage the shared session data.
939  *
940  * [in] tfp
941  *   Pointer to TF handle
942  *
943  * [in] parms
944  *   Pointer to attach parameters
945  *
946  * Returns
947  *   - (0) if successful.
948  *   - (-EINVAL) on failure.
949  */
950 int tf_attach_session(struct tf *tfp,
951                       struct tf_attach_session_parms *parms);
952
953 /**
954  * Closes an existing session client or the session it self. The
955  * session client is default closed and if the session reference count
956  * is 0 then the session is closed as well.
957  *
958  * On session close all hardware and firmware state associated with
959  * the TruFlow application is cleaned up.
960  *
961  * The session client is extracted from the tfp. Thus tf_close_session()
962  * cannot close a session client on behalf of another function.
963  *
964  * Returns success or failure code.
965  */
966 int tf_close_session(struct tf *tfp);
967
968 /**
969  * @page  ident Identity Management
970  *
971  * @ref tf_alloc_identifier
972  *
973  * @ref tf_free_identifier
974  */
975 /**
976  * tf_alloc_identifier parameter definition
977  */
978 struct tf_alloc_identifier_parms {
979         /**
980          * [in]  receive or transmit direction
981          */
982         enum tf_dir dir;
983         /**
984          * [in] Identifier type
985          */
986         enum tf_identifier_type ident_type;
987         /**
988          * [out] Allocated identifier
989          */
990         uint32_t id;
991 };
992
993 /**
994  * tf_free_identifier parameter definition
995  */
996 struct tf_free_identifier_parms {
997         /**
998          * [in]  receive or transmit direction
999          */
1000         enum tf_dir dir;
1001         /**
1002          * [in] Identifier type
1003          */
1004         enum tf_identifier_type ident_type;
1005         /**
1006          * [in] ID to free
1007          */
1008         uint32_t id;
1009         /**
1010          * (experimental)
1011          * [out] Current refcnt after free
1012          */
1013         uint32_t ref_cnt;
1014 };
1015
1016 /**
1017  * tf_search_identifier parameter definition (experimental)
1018  */
1019 struct tf_search_identifier_parms {
1020         /**
1021          * [in]  receive or transmit direction
1022          */
1023         enum tf_dir dir;
1024         /**
1025          * [in] Identifier type
1026          */
1027         enum tf_identifier_type ident_type;
1028         /**
1029          * [in] Identifier data to search for
1030          */
1031         uint32_t search_id;
1032         /**
1033          * [out] Set if matching identifier found
1034          */
1035         bool hit;
1036         /**
1037          * [out] Current ref count after allocation
1038          */
1039         uint32_t ref_cnt;
1040 };
1041
1042 /**
1043  * allocate identifier resource
1044  *
1045  * TruFlow core will allocate a free id from the per identifier resource type
1046  * pool reserved for the session during tf_open().  No firmware is involved.
1047  *
1048  * If shadow copy is enabled, the internal ref_cnt is set to 1 in the
1049  * shadow table for a newly allocated resource.
1050  *
1051  * Returns success or failure code.
1052  */
1053 int tf_alloc_identifier(struct tf *tfp,
1054                         struct tf_alloc_identifier_parms *parms);
1055
1056 /**
1057  * free identifier resource
1058  *
1059  * TruFlow core will return an id back to the per identifier resource type pool
1060  * reserved for the session.  No firmware is involved.  During tf_close, the
1061  * complete pool is returned to the firmware.
1062  *
1063  * additional operation (experimental)
1064  * Decrement reference count.  Only release resource once refcnt goes to 0 if
1065  * shadow copy is enabled.
1066  *
1067  * Returns success or failure code.
1068  */
1069 int tf_free_identifier(struct tf *tfp,
1070                        struct tf_free_identifier_parms *parms);
1071
1072 /**
1073  * Search identifier resource (experimental)
1074  *
1075  * If the shadow copy is enabled search_id is used to search for a matching
1076  * entry in the shadow table.  The shadow table consists of an array of
1077  * reference counts indexed by identifier.  If a matching entry is found hit is
1078  * set to TRUE, refcnt is increased by 1 and returned.  Otherwise, hit is
1079  * set to false and refcnt is set to 0.
1080  *
1081  * TODO: we may need a per table internal shadow copy enable flag to stage
1082  * the shadow table implementation.  We do not need the shadow table for other
1083  * tables at this time so we may only want to enable the identifier shadow.
1084  *
1085  * TODO: remove this pseudocode below added to show that if search fails
1086  * we shouldn't allocate a new entry but return.
1087  *
1088  * identifier alloc (search_en=1)
1089  * if (ident is allocated and ref_cnt >=1)
1090  *      return ident - hit is set, incr refcnt
1091  * else (not found)
1092  *      return
1093  *
1094  */
1095 int tf_search_identifier(struct tf *tfp,
1096                          struct tf_search_identifier_parms *parms);
1097
1098 /**
1099  * @page dram_table DRAM Table Scope Interface
1100  *
1101  * @ref tf_alloc_tbl_scope
1102  *
1103  * @ref tf_free_tbl_scope
1104  *
1105  * If we allocate the EEM memory from the core, we need to store it in
1106  * the shared session data structure to make sure it can be freed later.
1107  * (for example if the PF goes away)
1108  *
1109  * Current thought is that memory is allocated within core.
1110  */
1111
1112 /**
1113  * tf_alloc_tbl_scope_parms definition
1114  */
1115 struct tf_alloc_tbl_scope_parms {
1116         /**
1117          * [in] All Maximum key size required.
1118          */
1119         uint16_t rx_max_key_sz_in_bits;
1120         /**
1121          * [in] Maximum Action size required (includes inlined items)
1122          */
1123         uint16_t rx_max_action_entry_sz_in_bits;
1124         /**
1125          * [in] Memory size in Megabytes
1126          * Total memory size allocated by user to be divided
1127          * up for actions, hash, counters.  Only inline external actions.
1128          * Use this variable or the number of flows, do not set both.
1129          */
1130         uint32_t rx_mem_size_in_mb;
1131         /**
1132          * [in] Number of flows * 1000. If set, rx_mem_size_in_mb must equal 0.
1133          */
1134         uint32_t rx_num_flows_in_k;
1135         /**
1136          * [in] All Maximum key size required.
1137          */
1138         uint16_t tx_max_key_sz_in_bits;
1139         /**
1140          * [in] Maximum Action size required (includes inlined items)
1141          */
1142         uint16_t tx_max_action_entry_sz_in_bits;
1143         /**
1144          * [in] Memory size in Megabytes
1145          * Total memory size allocated by user to be divided
1146          * up for actions, hash, counters.  Only inline external actions.
1147          */
1148         uint32_t tx_mem_size_in_mb;
1149         /**
1150          * [in] Number of flows * 1000
1151          */
1152         uint32_t tx_num_flows_in_k;
1153         /**
1154          * [in] Flush pending HW cached flows every 1/10th of value
1155          * set in seconds, both idle and active flows are flushed
1156          * from the HW cache. If set to 0, this feature will be disabled.
1157          */
1158         uint8_t hw_flow_cache_flush_timer;
1159         /**
1160          * [out] table scope identifier
1161          */
1162         uint32_t tbl_scope_id;
1163 };
1164 /**
1165  * tf_free_tbl_scope_parms definition
1166  */
1167 struct tf_free_tbl_scope_parms {
1168         /**
1169          * [in] table scope identifier
1170          */
1171         uint32_t tbl_scope_id;
1172 };
1173
1174 /**
1175  * tf_map_tbl_scope_parms definition
1176  */
1177 struct tf_map_tbl_scope_parms {
1178         /**
1179          * [in] table scope identifier
1180          */
1181         uint32_t tbl_scope_id;
1182         /**
1183          * [in] Which parifs are associated with this table scope.  Bit 0
1184          *      indicates parif 0.
1185          */
1186         uint16_t parif_bitmask;
1187 };
1188
1189 /**
1190  * allocate a table scope
1191  *
1192  * The scope is a software construct to identify an EEM table.  This function will
1193  * divide the hash memory/buckets and records according to the device
1194  * device constraints based upon calculations using either the number of flows
1195  * requested or the size of memory indicated.  Other parameters passed in
1196  * determine the configuration (maximum key size, maximum external action record
1197  * size).
1198  *
1199  * A single API is used to allocate a common table scope identifier in both
1200  * receive and transmit CFA. The scope identifier is common due to nature of
1201  * connection tracking sending notifications between RX and TX direction.
1202  *
1203  * The receive and transmit table access identifiers specify which rings will
1204  * be used to initialize table DRAM.  The application must ensure mutual
1205  * exclusivity of ring usage for table scope allocation and any table update
1206  * operations.
1207  *
1208  * The hash table buckets, EM keys, and EM lookup results are stored in the
1209  * memory allocated based on the rx_em_hash_mb/tx_em_hash_mb parameters.  The
1210  * hash table buckets are stored at the beginning of that memory.
1211  *
1212  * NOTE:  No EM internal setup is done here. On chip EM records are managed
1213  * internally by TruFlow core.
1214  *
1215  * Returns success or failure code.
1216  */
1217 int tf_alloc_tbl_scope(struct tf *tfp,
1218                        struct tf_alloc_tbl_scope_parms *parms);
1219
1220 /**
1221  * map a table scope (legacy device only Wh+/SR)
1222  *
1223  * Map a table scope to one or more partition interfaces (parifs).
1224  * The parif can be remapped in the L2 context lookup for legacy devices.  This
1225  * API allows a number of parifs to be mapped to the same table scope.  On
1226  * legacy devices a table scope identifies one of 16 sets of EEM table base
1227  * addresses and is associated with a PF communication channel.  The associated
1228  * PF must be configured for the table scope to operate.
1229  *
1230  * An L2 context TCAM lookup returns a remapped parif value used to
1231  * index into the set of 16 parif_to_pf registers which are used to map to one
1232  * of the 16 table scopes.  This API allows the user to map the parifs in the
1233  * mask to the previously allocated table scope (EEM table).
1234
1235  * Returns success or failure code.
1236  */
1237 int tf_map_tbl_scope(struct tf *tfp,
1238                       struct tf_map_tbl_scope_parms *parms);
1239 /**
1240  * free a table scope
1241  *
1242  * Firmware checks that the table scope ID is owned by the TruFlow
1243  * session, verifies that no references to this table scope remains
1244  * or Profile TCAM entries for either CFA (RX/TX) direction,
1245  * then frees the table scope ID.
1246  *
1247  * Returns success or failure code.
1248  */
1249 int tf_free_tbl_scope(struct tf *tfp,
1250                       struct tf_free_tbl_scope_parms *parms);
1251
1252 /**
1253  * @page tcam TCAM Access
1254  *
1255  * @ref tf_search_tcam_entry
1256  *
1257  * @ref tf_alloc_tcam_entry
1258  *
1259  * @ref tf_set_tcam_entry
1260  *
1261  * @ref tf_get_tcam_entry
1262  *
1263  * @ref tf_free_tcam_entry
1264  *
1265 #ifdef TF_TCAM_SHARED
1266  * @ref tf_move_tcam_shared_entries
1267  *
1268  * @ref tf_clear_tcam_shared_entries
1269 #endif
1270  */
1271
1272 /**
1273  * tf_search_tcam_entry parameter definition (experimental)
1274  */
1275 struct tf_search_tcam_entry_parms {
1276         /**
1277          * [in] receive or transmit direction
1278          */
1279         enum tf_dir dir;
1280         /**
1281          * [in] TCAM table type
1282          */
1283         enum tf_tcam_tbl_type tcam_tbl_type;
1284         /**
1285          * [in] Key data to match on
1286          */
1287         uint8_t *key;
1288         /**
1289          * [in] key size in bits
1290          */
1291         uint16_t key_sz_in_bits;
1292         /**
1293          * [in] Mask data to match on
1294          */
1295         uint8_t *mask;
1296         /**
1297          * [in] Priority of entry requested (definition TBD)
1298          */
1299         uint32_t priority;
1300         /**
1301          * [in] Allocate on miss.
1302          */
1303         uint8_t alloc;
1304         /**
1305          * [out] Set if matching entry found
1306          */
1307         uint8_t hit;
1308         /**
1309          * [out] Search result status (hit, miss, reject)
1310          */
1311         enum tf_search_status search_status;
1312         /**
1313          * [out] Current refcnt after allocation
1314          */
1315         uint16_t ref_cnt;
1316         /**
1317          * [in out] The result data from the search is copied here
1318          */
1319         uint8_t *result;
1320         /**
1321          * [in out] result size in bits for the result data
1322          */
1323         uint16_t result_sz_in_bits;
1324         /**
1325          * [out] Index found
1326          */
1327         uint16_t idx;
1328 };
1329
1330 /**
1331  * search TCAM entry (experimental)
1332  *
1333  * Search for a TCAM entry
1334  *
1335  * This function searches the shadow copy of the TCAM table for a matching
1336  * entry.  Key and mask must match for hit to be set.  Only TruFlow core data
1337  * is accessed.  If shadow_copy is not enabled, an error is returned.
1338  *
1339  * Implementation:
1340  *
1341  * A hash is performed on the key/mask data and mapped to a shadow copy entry
1342  * where the full key/mask is populated.  If the full key/mask matches the
1343  * entry, hit is set, ref_cnt is incremented, and search_status indicates what
1344  * action the caller can take regarding setting the entry.
1345  *
1346  * search_status should be used as follows:
1347  * - On Miss, the caller should create a result and call tf_set_tcam_entry with
1348  * returned index.
1349  *
1350  * - On Reject, the hash table is full and the entry cannot be added.
1351  *
1352  * - On Hit, the result data is returned to the caller.  Additionally, the
1353  * ref_cnt is updated.
1354  *
1355  * Also returns success or failure code.
1356  */
1357 int tf_search_tcam_entry(struct tf *tfp,
1358                          struct tf_search_tcam_entry_parms *parms);
1359
1360 /**
1361  * tf_alloc_tcam_entry parameter definition
1362  */
1363 struct tf_alloc_tcam_entry_parms {
1364         /**
1365          * [in] receive or transmit direction
1366          */
1367         enum tf_dir dir;
1368         /**
1369          * [in] TCAM table type
1370          */
1371         enum tf_tcam_tbl_type tcam_tbl_type;
1372         /**
1373          * [in] Enable search for matching entry
1374          */
1375         uint8_t search_enable;
1376         /**
1377          * [in] Key data to match on (if search)
1378          */
1379         uint8_t *key;
1380         /**
1381          * [in] key size in bits (if search)
1382          */
1383         uint16_t key_sz_in_bits;
1384         /**
1385          * [in] Mask data to match on (if search)
1386          */
1387         uint8_t *mask;
1388         /**
1389          * [in] Priority of entry requested (definition TBD)
1390          */
1391         uint32_t priority;
1392         /**
1393          * [out] If search, set if matching entry found
1394          */
1395         uint8_t hit;
1396         /**
1397          * [out] Current refcnt after allocation
1398          */
1399         uint16_t ref_cnt;
1400         /**
1401          * [out] Idx allocated
1402          *
1403          */
1404         uint16_t idx;
1405 };
1406
1407 /**
1408  * allocate TCAM entry
1409  *
1410  * Allocate a TCAM entry - one of these types:
1411  *
1412  * L2 Context
1413  * Profile TCAM
1414  * WC TCAM
1415  * VEB TCAM
1416  *
1417  * This function allocates a TCAM table record.  This function
1418  * will attempt to allocate a TCAM table entry from the session
1419  * owned TCAM entries or search a shadow copy of the TCAM table for a
1420  * matching entry if search is enabled.  Key, mask and result must match for
1421  * hit to be set.  Only TruFlow core data is accessed.
1422  * A hash table to entry mapping is maintained for search purposes.  If
1423  * search is not enabled, the first available free entry is returned based
1424  * on priority and alloc_cnt is set to 1.  If search is enabled and a matching
1425  * entry to entry_data is found, hit is set to TRUE and alloc_cnt is set to 1.
1426  * RefCnt is also returned.
1427  *
1428  * Also returns success or failure code.
1429  */
1430 int tf_alloc_tcam_entry(struct tf *tfp,
1431                         struct tf_alloc_tcam_entry_parms *parms);
1432
1433 /**
1434  * tf_set_tcam_entry parameter definition
1435  */
1436 struct  tf_set_tcam_entry_parms {
1437         /**
1438          * [in] receive or transmit direction
1439          */
1440         enum tf_dir dir;
1441         /**
1442          * [in] TCAM table type
1443          */
1444         enum tf_tcam_tbl_type tcam_tbl_type;
1445         /**
1446          * [in] base index of the entry to program
1447          */
1448         uint16_t idx;
1449         /**
1450          * [in] struct containing key
1451          */
1452         uint8_t *key;
1453         /**
1454          * [in] struct containing mask fields
1455          */
1456         uint8_t *mask;
1457         /**
1458          * [in] key size in bits (if search)
1459          */
1460         uint16_t key_sz_in_bits;
1461         /**
1462          * [in] struct containing result
1463          */
1464         uint8_t *result;
1465         /**
1466          * [in] struct containing result size in bits
1467          */
1468         uint16_t result_sz_in_bits;
1469 };
1470
1471 /**
1472  * set TCAM entry
1473  *
1474  * Program a TCAM table entry for a TruFlow session.
1475  *
1476  * If the entry has not been allocated, an error will be returned.
1477  *
1478  * Returns success or failure code.
1479  */
1480 int tf_set_tcam_entry(struct tf *tfp,
1481                       struct tf_set_tcam_entry_parms *parms);
1482
1483 /**
1484  * tf_get_tcam_entry parameter definition
1485  */
1486 struct tf_get_tcam_entry_parms {
1487         /**
1488          * [in] receive or transmit direction
1489          */
1490         enum tf_dir dir;
1491         /**
1492          * [in] TCAM table type
1493          */
1494         enum tf_tcam_tbl_type  tcam_tbl_type;
1495         /**
1496          * [in] index of the entry to get
1497          */
1498         uint16_t idx;
1499         /**
1500          * [out] struct containing key
1501          */
1502         uint8_t *key;
1503         /**
1504          * [out] struct containing mask fields
1505          */
1506         uint8_t *mask;
1507         /**
1508          * [in/out] key size in bits
1509          */
1510         uint16_t key_sz_in_bits;
1511         /**
1512          * [out] struct containing result
1513          */
1514         uint8_t *result;
1515         /**
1516          * [in/out] struct containing result size in bits
1517          */
1518         uint16_t result_sz_in_bits;
1519 };
1520
1521 /**
1522  * get TCAM entry
1523  *
1524  * Program a TCAM table entry for a TruFlow session.
1525  *
1526  * If the entry has not been allocated, an error will be returned.
1527  *
1528  * Returns success or failure code.
1529  */
1530 int tf_get_tcam_entry(struct tf *tfp,
1531                       struct tf_get_tcam_entry_parms *parms);
1532
1533 /**
1534  * tf_free_tcam_entry parameter definition
1535  */
1536 struct tf_free_tcam_entry_parms {
1537         /**
1538          * [in] receive or transmit direction
1539          */
1540         enum tf_dir dir;
1541         /**
1542          * [in] TCAM table type
1543          */
1544         enum tf_tcam_tbl_type tcam_tbl_type;
1545         /**
1546          * [in] Index to free
1547          */
1548         uint16_t idx;
1549         /**
1550          * [out] reference count after free
1551          */
1552         uint16_t ref_cnt;
1553 };
1554
1555 /**
1556  * free TCAM entry
1557  *
1558  * Free TCAM entry.
1559  *
1560  * Firmware checks to ensure the TCAM entries are owned by the TruFlow
1561  * session.  TCAM entry will be invalidated.  All-ones mask.
1562  * writes to hw.
1563  *
1564  * WCTCAM profile id of 0 must be used to invalidate an entry.
1565  *
1566  * Returns success or failure code.
1567  */
1568 int tf_free_tcam_entry(struct tf *tfp,
1569                        struct tf_free_tcam_entry_parms *parms);
1570
1571 #ifdef TF_TCAM_SHARED
1572 /**
1573  * tf_move_tcam_shared_entries parameter definition
1574  */
1575 struct tf_move_tcam_shared_entries_parms {
1576         /**
1577          * [in] receive or transmit direction
1578          */
1579         enum tf_dir dir;
1580         /**
1581          * [in] TCAM table type
1582          */
1583         enum tf_tcam_tbl_type tcam_tbl_type;
1584 };
1585
1586 /**
1587  * Move TCAM entries
1588  *
1589  * This API only affects the following TCAM pools within a shared session:
1590  *
1591  * TF_TCAM_TBL_TYPE_WC_TCAM_HIGH
1592  * TF_TCAM_TBL_TYPE_WC_TCAM_LOW
1593  *
1594  * When called, all allocated entries from the high pool will be moved to
1595  * the low pool.  Then the allocated entries in the high pool will be
1596  * cleared and freed.
1597  *
1598  * This API is not supported on a non-shared session.
1599  *
1600  * Returns success or failure code.
1601  */
1602 int tf_move_tcam_shared_entries(struct tf *tfp,
1603                                 struct tf_move_tcam_shared_entries_parms *parms);
1604
1605 /**
1606  * tf_clear_tcam_shared_entries parameter definition
1607  */
1608 struct tf_clear_tcam_shared_entries_parms {
1609         /**
1610          * [in] receive or transmit direction
1611          */
1612         enum tf_dir dir;
1613         /**
1614          * [in] TCAM table type
1615          */
1616         enum tf_tcam_tbl_type tcam_tbl_type;
1617 };
1618
1619 /**
1620  * Clear TCAM shared entries pool
1621  *
1622  * This API only affects the following TCAM pools within a shared session:
1623  *
1624  * TF_TCAM_TBL_TYPE_WC_TCAM_HIGH
1625  * TF_TCAM_TBL_TYPE_WC_TCAM_LOW
1626  *
1627  * When called, the indicated WC TCAM high or low pool will be cleared.
1628  *
1629  * This API is not supported on a non-shared session.
1630  *
1631  * Returns success or failure code.
1632  */
1633 int tf_clear_tcam_shared_entries(struct tf *tfp,
1634                               struct tf_clear_tcam_shared_entries_parms *parms);
1635
1636 #endif /* TF_TCAM_SHARED */
1637 /**
1638  * @page table Table Access
1639  *
1640  * @ref tf_alloc_tbl_entry
1641  *
1642  * @ref tf_free_tbl_entry
1643  *
1644  * @ref tf_set_tbl_entry
1645  *
1646  * @ref tf_get_tbl_entry
1647  *
1648  * @ref tf_bulk_get_tbl_entry
1649  *
1650  * @ref tf_get_shared_tbl_increment
1651  */
1652
1653 /**
1654  * tf_alloc_tbl_entry parameter definition
1655  */
1656 struct tf_alloc_tbl_entry_parms {
1657         /**
1658          * [in] Receive or transmit direction
1659          */
1660         enum tf_dir dir;
1661         /**
1662          * [in] Type of the allocation
1663          */
1664         enum tf_tbl_type type;
1665         /**
1666          * [in] Table scope identifier (ignored unless TF_TBL_TYPE_EXT)
1667          */
1668         uint32_t tbl_scope_id;
1669
1670         /**
1671          * [out] Idx of allocated entry
1672          */
1673         uint32_t idx;
1674 };
1675
1676 /**
1677  * allocate index table entries
1678  *
1679  * Internal types:
1680  *
1681  * Allocate an on chip index table entry or search for a matching
1682  * entry of the indicated type for this TruFlow session.
1683  *
1684  * Allocates an index table record. This function will attempt to
1685  * allocate an index table entry.
1686  *
1687  * External types:
1688  *
1689  * These are used to allocate inlined action record memory.
1690  *
1691  * Allocates an external index table action record.
1692  *
1693  * NOTE:
1694  * Implementation of the internals of the external function will be a stack with
1695  * push and pop.
1696  *
1697  * Returns success or failure code.
1698  */
1699 int tf_alloc_tbl_entry(struct tf *tfp,
1700                        struct tf_alloc_tbl_entry_parms *parms);
1701
1702 /**
1703  * tf_free_tbl_entry parameter definition
1704  */
1705 struct tf_free_tbl_entry_parms {
1706         /**
1707          * [in] Receive or transmit direction
1708          */
1709         enum tf_dir dir;
1710         /**
1711          * [in] Type of the allocation type
1712          */
1713         enum tf_tbl_type type;
1714         /**
1715          * [in] Table scope identifier (ignored unless TF_TBL_TYPE_EXT)
1716          */
1717         uint32_t tbl_scope_id;
1718         /**
1719          * [in] Index to free
1720          */
1721         uint32_t idx;
1722 };
1723
1724 /**
1725  * free index table entry
1726  *
1727  * Used to free a previously allocated table entry.
1728  *
1729  * Internal types:
1730  *
1731  * The element is freed and given back to the session pool.
1732  *
1733  * External types:
1734  *
1735  * Frees an external index table action record.
1736  *
1737  * NOTE:
1738  * Implementation of the internals of the external table will be a stack with
1739  * push and pop.
1740  *
1741  * Returns success or failure code.
1742  */
1743 int tf_free_tbl_entry(struct tf *tfp,
1744                       struct tf_free_tbl_entry_parms *parms);
1745
1746 /**
1747  * tf_set_tbl_entry parameter definition
1748  */
1749 struct tf_set_tbl_entry_parms {
1750         /**
1751          * [in] Table scope identifier
1752          */
1753         uint32_t tbl_scope_id;
1754         /**
1755          * [in] Receive or transmit direction
1756          */
1757         enum tf_dir dir;
1758         /**
1759          * [in] Type of object to set
1760          */
1761         enum tf_tbl_type type;
1762         /**
1763          * [in] Entry data
1764          */
1765         uint8_t *data;
1766         /**
1767          * [in] Entry size
1768          */
1769         uint16_t data_sz_in_bytes;
1770         /**
1771          * [in] External memory channel type to use
1772          */
1773         enum tf_ext_mem_chan_type chan_type;
1774         /**
1775          * [in] Entry index to write to
1776          */
1777         uint32_t idx;
1778 };
1779
1780 /**
1781  * set index table entry
1782  *
1783  * Used to set an application programmed index table entry into a
1784  * previous allocated table location.
1785  *
1786  * Returns success or failure code.
1787  */
1788 int tf_set_tbl_entry(struct tf *tfp,
1789                      struct tf_set_tbl_entry_parms *parms);
1790
1791 /**
1792  * tf_get_shared_tbl_increment parameter definition
1793  */
1794 struct tf_get_shared_tbl_increment_parms {
1795         /**
1796          * [in] Receive or transmit direction
1797          */
1798         enum tf_dir dir;
1799         /**
1800          * [in] Type of object to set
1801          */
1802         enum tf_tbl_type type;
1803         /**
1804          * [out] Value to increment by for resource type
1805          */
1806         uint32_t increment_cnt;
1807 };
1808
1809 /**
1810  * tf_get_shared_tbl_increment
1811  *
1812  * This API is currently only required for use in the shared
1813  * session for Thor (p58) actions.  An increment count is returned per
1814  * type to indicate how much to increment the start by for each
1815  * entry (see tf_resource_info)
1816  *
1817  * Returns success or failure code.
1818  */
1819 int tf_get_shared_tbl_increment(struct tf *tfp,
1820                                 struct tf_get_shared_tbl_increment_parms *parms);
1821
1822 /**
1823  * tf_get_tbl_entry parameter definition
1824  */
1825 struct tf_get_tbl_entry_parms {
1826         /**
1827          * [in] Receive or transmit direction
1828          */
1829         enum tf_dir dir;
1830         /**
1831          * [in] Type of object to get
1832          */
1833         enum tf_tbl_type type;
1834         /**
1835          * [out] Entry data
1836          */
1837         uint8_t *data;
1838         /**
1839          * [in] Entry size
1840          */
1841         uint16_t data_sz_in_bytes;
1842         /**
1843          * [in] External memory channel type to use
1844          */
1845         enum tf_ext_mem_chan_type chan_type;
1846         /**
1847          * [in] Entry index to read
1848          */
1849         uint32_t idx;
1850 };
1851
1852 /**
1853  * get index table entry
1854  *
1855  * Used to retrieve a previous set index table entry.
1856  *
1857  * Reads and compares with the shadow table copy (if enabled) (only
1858  * for internal objects).
1859  *
1860  * Returns success or failure code. Failure will be returned if the
1861  * provided data buffer is too small for the data type requested.
1862  */
1863 int tf_get_tbl_entry(struct tf *tfp,
1864                      struct tf_get_tbl_entry_parms *parms);
1865
1866 /**
1867  * tf_bulk_get_tbl_entry parameter definition
1868  */
1869 struct tf_bulk_get_tbl_entry_parms {
1870         /**
1871          * [in] Receive or transmit direction
1872          */
1873         enum tf_dir dir;
1874         /**
1875          * [in] Type of object to get
1876          */
1877         enum tf_tbl_type type;
1878         /**
1879          * [in] Starting index to read from
1880          */
1881         uint32_t starting_idx;
1882         /**
1883          * [in] Number of sequential entries
1884          */
1885         uint16_t num_entries;
1886         /**
1887          * [in] Size of the single entry
1888          */
1889         uint16_t entry_sz_in_bytes;
1890         /**
1891          * [out] Host physical address, where the data
1892          * will be copied to by the firmware.
1893          * Use tfp_calloc() API and mem_pa
1894          * variable of the tfp_calloc_parms
1895          * structure for the physical address.
1896          */
1897         uint64_t physical_mem_addr;
1898         /**
1899          * [in] External memory channel type to use
1900          */
1901         enum tf_ext_mem_chan_type chan_type;
1902 };
1903
1904 /**
1905  * Bulk get index table entry
1906  *
1907  * Used to retrieve a set of index table entries.
1908  *
1909  * Entries within the range may not have been allocated using
1910  * tf_alloc_tbl_entry() at the time of access. But the range must
1911  * be within the bounds determined from tf_open_session() for the
1912  * given table type.  Currently, this is only used for collecting statistics.
1913  *
1914  * Returns success or failure code. Failure will be returned if the
1915  * provided data buffer is too small for the data type requested.
1916  */
1917 int tf_bulk_get_tbl_entry(struct tf *tfp,
1918                           struct tf_bulk_get_tbl_entry_parms *parms);
1919
1920 /**
1921  * @page exact_match Exact Match Table
1922  *
1923  * @ref tf_insert_em_entry
1924  *
1925  * @ref tf_delete_em_entry
1926  *
1927  * @ref tf_search_em_entry
1928  *
1929  */
1930 /**
1931  * tf_insert_em_entry parameter definition
1932  */
1933 struct tf_insert_em_entry_parms {
1934         /**
1935          * [in] receive or transmit direction
1936          */
1937         enum tf_dir dir;
1938         /**
1939          * [in] internal or external
1940          */
1941         enum tf_mem mem;
1942         /**
1943          * [in] ID of table scope to use (external only)
1944          */
1945         uint32_t tbl_scope_id;
1946         /**
1947          * [in] ptr to structure containing key fields
1948          */
1949         uint8_t *key;
1950         /**
1951          * [in] key bit length
1952          */
1953         uint16_t key_sz_in_bits;
1954         /**
1955          * [in] ptr to structure containing result field
1956          */
1957         uint8_t *em_record;
1958         /**
1959          * [out] result size in bits
1960          */
1961         uint16_t em_record_sz_in_bits;
1962         /**
1963          * [in] duplicate check flag
1964          */
1965         uint8_t dup_check;
1966         /**
1967          * [in] External memory channel type to use
1968          */
1969         enum tf_ext_mem_chan_type chan_type;
1970         /**
1971          * [out] Flow handle value for the inserted entry.  This is encoded
1972          * as the entries[4]:bucket[2]:hashId[1]:hash[14]
1973          */
1974         uint64_t flow_handle;
1975         /**
1976          * [out] Flow id is returned as null (internal)
1977          * Flow id is the GFID value for the inserted entry (external)
1978          * This is the value written to the BD and useful information for mark.
1979          */
1980         uint64_t flow_id;
1981 };
1982 /**
1983  * tf_delete_em_entry parameter definition
1984  */
1985 struct tf_delete_em_entry_parms {
1986         /**
1987          * [in] receive or transmit direction
1988          */
1989         enum tf_dir dir;
1990         /**
1991          * [in] internal or external
1992          */
1993         enum tf_mem mem;
1994         /**
1995          * [in] ID of table scope to use (external only)
1996          */
1997         uint32_t tbl_scope_id;
1998         /**
1999          * [out] The index of the entry
2000          */
2001         uint16_t index;
2002         /**
2003          * [in] External memory channel type to use
2004          */
2005         enum tf_ext_mem_chan_type chan_type;
2006         /**
2007          * [in] structure containing flow delete handle information
2008          */
2009         uint64_t flow_handle;
2010 };
2011 /**
2012  * tf_move_em_entry parameter definition
2013  */
2014 struct tf_move_em_entry_parms {
2015         /**
2016          * [in] receive or transmit direction
2017          */
2018         enum tf_dir dir;
2019         /**
2020          * [in] internal or external
2021          */
2022         enum tf_mem mem;
2023         /**
2024          * [in] ID of table scope to use (external only)
2025          */
2026         uint32_t tbl_scope_id;
2027         /**
2028          * [in] ID of table interface to use (SR2 only)
2029          */
2030         uint32_t tbl_if_id;
2031         /**
2032          * [in] epoch group IDs of entry to delete
2033          * 2 element array with 2 ids. (SR2 only)
2034          */
2035         uint16_t *epochs;
2036         /**
2037          * [out] The index of the entry
2038          */
2039         uint16_t index;
2040         /**
2041          * [in] External memory channel type to use
2042          */
2043         enum tf_ext_mem_chan_type chan_type;
2044         /**
2045          * [in] The index of the new EM record
2046          */
2047         uint32_t new_index;
2048         /**
2049          * [in] structure containing flow delete handle information
2050          */
2051         uint64_t flow_handle;
2052 };
2053 /**
2054  * tf_search_em_entry parameter definition (Future)
2055  */
2056 struct tf_search_em_entry_parms {
2057         /**
2058          * [in] receive or transmit direction
2059          */
2060         enum tf_dir dir;
2061         /**
2062          * [in] internal or external
2063          */
2064         enum tf_mem mem;
2065         /**
2066          * [in] ID of table scope to use (external only)
2067          */
2068         uint32_t tbl_scope_id;
2069         /**
2070          * [in] ptr to structure containing key fields
2071          */
2072         uint8_t *key;
2073         /**
2074          * [in] key bit length
2075          */
2076         uint16_t key_sz_in_bits;
2077         /**
2078          * [in/out] ptr to structure containing EM record fields
2079          */
2080         uint8_t *em_record;
2081         /**
2082          * [out] result size in bits
2083          */
2084         uint16_t em_record_sz_in_bits;
2085         /**
2086          * [in] External memory channel type to use
2087          */
2088         enum tf_ext_mem_chan_type chan_type;
2089         /**
2090          * [in] ptr to structure containing flow delete handle
2091          */
2092         uint64_t flow_handle;
2093 };
2094
2095 /**
2096  * insert em hash entry in internal table memory
2097  *
2098  * Internal:
2099  *
2100  * This API inserts an exact match entry into internal EM table memory
2101  * of the specified direction.
2102  *
2103  * Note: The EM record is managed within the TruFlow core and not the
2104  * application.
2105  *
2106  * Shadow copy of internal record table an association with hash and 1,2, or 4
2107  * associated buckets
2108  *
2109  * External:
2110  * This API inserts an exact match entry into DRAM EM table memory of the
2111  * specified direction and table scope.
2112  *
2113  * The insertion of duplicate entries in an EM table is not permitted.  If a
2114  * TruFlow application can guarantee that it will never insert duplicates, it
2115  * can disable duplicate checking by passing a zero value in the  dup_check
2116  * parameter to this API.  This will optimize performance. Otherwise, the
2117  * TruFlow library will enforce protection against inserting duplicate entries.
2118  *
2119  * Flow handle is defined in this document:
2120  *
2121  * https://docs.google.com
2122  * /document/d/1NESu7RpTN3jwxbokaPfYORQyChYRmJgs40wMIRe8_-Q/edit
2123  *
2124  * Returns success or busy code.
2125  *
2126  */
2127 int tf_insert_em_entry(struct tf *tfp,
2128                        struct tf_insert_em_entry_parms *parms);
2129
2130 /**
2131  * delete em hash entry table memory
2132  *
2133  * Internal:
2134  *
2135  * This API deletes an exact match entry from internal EM table memory of the
2136  * specified direction. If a valid flow ptr is passed in then that takes
2137  * precedence over the pointer to the complete key passed in.
2138  *
2139  *
2140  * External:
2141  *
2142  * This API deletes an exact match entry from EM table memory of the specified
2143  * direction and table scope. If a valid flow handle is passed in then that
2144  * takes precedence over the pointer to the complete key passed in.
2145  *
2146  * The TruFlow library may release a dynamic bucket when an entry is deleted.
2147  *
2148  *
2149  * Returns success or not found code
2150  *
2151  *
2152  */
2153 int tf_delete_em_entry(struct tf *tfp,
2154                        struct tf_delete_em_entry_parms *parms);
2155
2156 /**
2157  * search em hash entry table memory (Future)
2158  *
2159  * Internal:
2160
2161  * This API looks up an EM entry in table memory with the specified EM
2162  * key or flow (flow takes precedence) and direction.
2163  *
2164  * The status will be one of: success or entry not found.  If the lookup
2165  * succeeds, a pointer to the matching entry and the result record associated
2166  * with the matching entry will be provided.
2167  *
2168  * If flow_handle is set, search shadow copy.
2169  *
2170  * Otherwise, query the fw with key to get result.
2171  *
2172  * External:
2173  *
2174  * This API looks up an EM entry in table memory with the specified EM
2175  * key or flow_handle (flow takes precedence), direction and table scope.
2176  *
2177  * The status will be one of: success or entry not found.  If the lookup
2178  * succeeds, a pointer to the matching entry and the result record associated
2179  * with the matching entry will be provided.
2180  *
2181  * Returns success or not found code
2182  *
2183  */
2184 int tf_search_em_entry(struct tf *tfp,
2185                        struct tf_search_em_entry_parms *parms);
2186
2187 /**
2188  * @page global Global Configuration
2189  *
2190  * @ref tf_set_global_cfg
2191  *
2192  * @ref tf_get_global_cfg
2193  */
2194 /**
2195  * Tunnel Encapsulation Offsets
2196  */
2197 enum tf_tunnel_encap_offsets {
2198         TF_TUNNEL_ENCAP_L2,
2199         TF_TUNNEL_ENCAP_NAT,
2200         TF_TUNNEL_ENCAP_MPLS,
2201         TF_TUNNEL_ENCAP_VXLAN,
2202         TF_TUNNEL_ENCAP_GENEVE,
2203         TF_TUNNEL_ENCAP_NVGRE,
2204         TF_TUNNEL_ENCAP_GRE,
2205         TF_TUNNEL_ENCAP_FULL_GENERIC
2206 };
2207 /**
2208  * Global Configuration Table Types
2209  */
2210 enum tf_global_config_type {
2211         TF_TUNNEL_ENCAP,  /**< Tunnel Encap Config(TECT) */
2212         TF_ACTION_BLOCK,  /**< Action Block Config(ABCR) */
2213         TF_COUNTER_CFG,   /**< Counter Configuration (CNTRS_CTRL) */
2214         TF_METER_CFG,     /**< Meter Config(ACTP4_FMTCR) */
2215         TF_METER_INTERVAL_CFG, /**< Meter Interval Config(FMTCR_INTERVAL)  */
2216         TF_GLOBAL_CFG_TYPE_MAX
2217 };
2218
2219 /**
2220  * tf_global_cfg parameter definition
2221  */
2222 struct tf_global_cfg_parms {
2223         /**
2224          * [in] receive or transmit direction
2225          */
2226         enum tf_dir dir;
2227         /**
2228          * [in] Global config type
2229          */
2230         enum tf_global_config_type type;
2231         /**
2232          * [in] Offset @ the type
2233          */
2234         uint32_t offset;
2235         /**
2236          * [in/out] Value of the configuration
2237          * set - Read, Modify and Write
2238          * get - Read the full configuration
2239          */
2240         uint8_t *config;
2241         /**
2242          * [in] Configuration mask
2243          * set - Read, Modify with mask and Write
2244          * get - unused
2245          */
2246         uint8_t *config_mask;
2247         /**
2248          * [in] struct containing size
2249          */
2250         uint16_t config_sz_in_bytes;
2251 };
2252
2253 /**
2254  * Get global configuration
2255  *
2256  * Retrieve the configuration
2257  *
2258  * Returns success or failure code.
2259  */
2260 int tf_get_global_cfg(struct tf *tfp,
2261                       struct tf_global_cfg_parms *parms);
2262
2263 /**
2264  * Update the global configuration table
2265  *
2266  * Read, modify write the value.
2267  *
2268  * Returns success or failure code.
2269  */
2270 int tf_set_global_cfg(struct tf *tfp,
2271                       struct tf_global_cfg_parms *parms);
2272
2273 /**
2274  * @page if_tbl Interface Table Access
2275  *
2276  * @ref tf_set_if_tbl_entry
2277  *
2278  * @ref tf_get_if_tbl_entry
2279  *
2280  * @ref tf_restore_if_tbl_entry
2281  */
2282 /**
2283  * Enumeration of TruFlow interface table types.
2284  */
2285 enum tf_if_tbl_type {
2286         /** Default Profile L2 Context Entry */
2287         TF_IF_TBL_TYPE_PROF_SPIF_DFLT_L2_CTXT,
2288         /** Default Profile TCAM/Lookup Action Record Pointer Table */
2289         TF_IF_TBL_TYPE_PROF_PARIF_DFLT_ACT_REC_PTR,
2290         /** Error Profile TCAM Miss Action Record Pointer Table */
2291         TF_IF_TBL_TYPE_PROF_PARIF_ERR_ACT_REC_PTR,
2292         /** Default Error Profile TCAM Miss Action Record Pointer Table */
2293         TF_IF_TBL_TYPE_LKUP_PARIF_DFLT_ACT_REC_PTR,
2294         /** Ingress lookup table */
2295         TF_IF_TBL_TYPE_ILT,
2296         /** VNIC/SVIF Properties Table */
2297         TF_IF_TBL_TYPE_VSPT,
2298         TF_IF_TBL_TYPE_MAX
2299 };
2300
2301 /**
2302  * tf_set_if_tbl_entry parameter definition
2303  */
2304 struct tf_set_if_tbl_entry_parms {
2305         /**
2306          * [in] Receive or transmit direction
2307          */
2308         enum tf_dir dir;
2309         /**
2310          * [in] Type of object to set
2311          */
2312         enum tf_if_tbl_type type;
2313         /**
2314          * [in] Entry data
2315          */
2316         uint8_t *data;
2317         /**
2318          * [in] Entry size
2319          */
2320         uint16_t data_sz_in_bytes;
2321         /**
2322          * [in] Interface to write
2323          */
2324         uint32_t idx;
2325 };
2326
2327 /**
2328  * set interface table entry
2329  *
2330  * Used to set an interface table. This API is used for managing tables indexed
2331  * by SVIF/SPIF/PARIF interfaces. In current implementation only the value is
2332  * set.
2333  * Returns success or failure code.
2334  */
2335 int tf_set_if_tbl_entry(struct tf *tfp,
2336                         struct tf_set_if_tbl_entry_parms *parms);
2337
2338 /**
2339  * tf_get_if_tbl_entry parameter definition
2340  */
2341 struct tf_get_if_tbl_entry_parms {
2342         /**
2343          * [in] Receive or transmit direction
2344          */
2345         enum tf_dir dir;
2346         /**
2347          * [in] Type of table to get
2348          */
2349         enum tf_if_tbl_type type;
2350         /**
2351          * [out] Entry data
2352          */
2353         uint8_t *data;
2354         /**
2355          * [in] Entry size
2356          */
2357         uint16_t data_sz_in_bytes;
2358         /**
2359          * [in] Entry index to read
2360          */
2361         uint32_t idx;
2362 };
2363
2364 /**
2365  * get interface table entry
2366  *
2367  * Used to retrieve an interface table entry.
2368  *
2369  * Reads the interface table entry value
2370  *
2371  * Returns success or failure code. Failure will be returned if the
2372  * provided data buffer is too small for the data type requested.
2373  */
2374 int tf_get_if_tbl_entry(struct tf *tfp,
2375                         struct tf_get_if_tbl_entry_parms *parms);
2376
2377 /**
2378  * tf_get_version parameters definition.
2379  */
2380 struct tf_get_version_parms {
2381         /**
2382          * [in] device type
2383          *
2384          * Device type for the session.
2385          */
2386         enum tf_device_type device_type;
2387
2388         /**
2389          * [in] bp
2390          * The pointer to the parent bp struct. This is only used for HWRM
2391          * message passing within the portability layer. The type is struct
2392          * bnxt.
2393          */
2394         void *bp;
2395
2396         /* [out] major
2397          *
2398          * Version Major number.
2399          */
2400         uint8_t major;
2401
2402         /* [out] minor
2403          *
2404          * Version Minor number.
2405          */
2406         uint8_t minor;
2407
2408         /* [out] update
2409          *
2410          * Version Update number.
2411          */
2412         uint8_t update;
2413
2414         /**
2415          * [out] dev_ident_caps
2416          *
2417          * fw available identifier resource list
2418          */
2419         uint32_t dev_ident_caps;
2420
2421         /**
2422          * [out] dev_tbl_caps
2423          *
2424          * fw available table resource list
2425          */
2426         uint32_t dev_tbl_caps;
2427
2428         /**
2429          * [out] dev_tcam_caps
2430          *
2431          * fw available tcam resource list
2432          */
2433         uint32_t dev_tcam_caps;
2434
2435         /**
2436          * [out] dev_em_caps
2437          *
2438          * fw available em resource list
2439          */
2440         uint32_t dev_em_caps;
2441 };
2442
2443 /**
2444  * Get tf fw version
2445  *
2446  * Used to retrieve Truflow fw version information.
2447  *
2448  * Returns success or failure code.
2449  */
2450 int tf_get_version(struct tf *tfp,
2451                    struct tf_get_version_parms *parms);
2452
2453 /**
2454  * tf_query_sram_resources parameter definition
2455  */
2456 struct tf_query_sram_resources_parms {
2457         /**
2458          * [in] Device type
2459          *
2460          * Device type for the session.
2461          */
2462         enum tf_device_type device_type;
2463
2464         /**
2465          * [in] bp
2466          * The pointer to the parent bp struct. This is only used for HWRM
2467          * message passing within the portability layer. The type is struct
2468          * bnxt.
2469          */
2470         void *bp;
2471
2472         /**
2473          * [in] Receive or transmit direction
2474          */
2475         enum tf_dir dir;
2476
2477         /**
2478          * [out] Bank resource count in 8 bytes entry
2479          */
2480
2481         uint32_t bank_resc_count[TF_SRAM_BANK_ID_MAX];
2482
2483         /**
2484          * [out] Dynamic SRAM Enable
2485          */
2486         bool dynamic_sram_capable;
2487
2488         /**
2489          * [out] SRAM profile
2490          */
2491         uint8_t sram_profile;
2492 };
2493
2494 /**
2495  * Get SRAM resources information
2496  *
2497  * Used to retrieve sram bank partition information
2498  *
2499  * Returns success or failure code.
2500  */
2501 int tf_query_sram_resources(struct tf *tfp,
2502                             struct tf_query_sram_resources_parms *parms);
2503
2504 /**
2505  * tf_set_sram_policy parameter definition
2506  */
2507 struct tf_set_sram_policy_parms {
2508         /**
2509          * [in] Device type
2510          *
2511          * Device type for the session.
2512          */
2513         enum tf_device_type device_type;
2514
2515         /**
2516          * [in] Receive or transmit direction
2517          */
2518         enum tf_dir dir;
2519
2520         /**
2521          * [in] Array of Bank id for each truflow tbl type
2522          */
2523         enum tf_sram_bank_id bank_id[TF_TBL_TYPE_ACT_MODIFY_64B + 1];
2524 };
2525
2526 /**
2527  * Set SRAM policy
2528  *
2529  * Used to assign SRAM bank index to all truflow table type.
2530  *
2531  * Returns success or failure code.
2532  */
2533 int tf_set_sram_policy(struct tf *tfp,
2534                        struct tf_set_sram_policy_parms *parms);
2535
2536 /**
2537  * tf_get_sram_policy parameter definition
2538  */
2539 struct tf_get_sram_policy_parms {
2540         /**
2541          * [in] Device type
2542          *
2543          * Device type for the session.
2544          */
2545         enum tf_device_type device_type;
2546
2547         /**
2548          * [in] Receive or transmit direction
2549          */
2550         enum tf_dir dir;
2551
2552         /**
2553          * [out] Array of Bank id for each truflow tbl type
2554          */
2555         enum tf_sram_bank_id bank_id[TF_TBL_TYPE_ACT_MODIFY_64B + 1];
2556 };
2557
2558 /**
2559  * Get SRAM policy
2560  *
2561  * Used to get the assigned bank of table types.
2562  *
2563  * Returns success or failure code.
2564  */
2565 int tf_get_sram_policy(struct tf *tfp,
2566                        struct tf_get_sram_policy_parms *parms);
2567
2568 #endif /* _TF_CORE_H_ */