1 /* SPDX-License-Identifier: BSD-3-Clause
2 * Copyright(c) 2014-2020 Broadcom
6 #include <rte_malloc.h>
9 #include "bnxt_tf_common.h"
10 #include "ulp_port_db.h"
13 ulp_port_db_allocate_ifindex(struct bnxt_ulp_port_db *port_db)
17 while (idx < port_db->ulp_intf_list_size &&
18 port_db->ulp_intf_list[idx].type != BNXT_ULP_INTF_TYPE_INVALID)
21 if (idx >= port_db->ulp_intf_list_size) {
22 BNXT_TF_DBG(ERR, "Port DB interface list is full\n");
29 * Initialize the port database. Memory is allocated in this
30 * call and assigned to the port database.
32 * ulp_ctxt [in] Ptr to ulp context
34 * Returns 0 on success or negative number on failure.
36 int32_t ulp_port_db_init(struct bnxt_ulp_context *ulp_ctxt)
38 struct bnxt_ulp_port_db *port_db;
40 port_db = rte_zmalloc("bnxt_ulp_port_db",
41 sizeof(struct bnxt_ulp_port_db), 0);
44 "Failed to allocate memory for port db\n");
48 /* Attach the port database to the ulp context. */
49 bnxt_ulp_cntxt_ptr2_port_db_set(ulp_ctxt, port_db);
51 /* index 0 is not being used hence add 1 to size */
52 port_db->ulp_intf_list_size = BNXT_PORT_DB_MAX_INTF_LIST + 1;
53 /* Allocate the port tables */
54 port_db->ulp_intf_list = rte_zmalloc("bnxt_ulp_port_db_intf_list",
55 port_db->ulp_intf_list_size *
56 sizeof(struct ulp_interface_info),
58 if (!port_db->ulp_intf_list) {
60 "Failed to allocate mem for port interface list\n");
66 ulp_port_db_deinit(ulp_ctxt);
71 * Deinitialize the port database. Memory is deallocated in
74 * ulp_ctxt [in] Ptr to ulp context
76 * Returns 0 on success.
78 int32_t ulp_port_db_deinit(struct bnxt_ulp_context *ulp_ctxt)
80 struct bnxt_ulp_port_db *port_db;
82 port_db = bnxt_ulp_cntxt_ptr2_port_db_get(ulp_ctxt);
84 BNXT_TF_DBG(ERR, "Invalid Arguments\n");
88 /* Detach the flow database from the ulp context. */
89 bnxt_ulp_cntxt_ptr2_port_db_set(ulp_ctxt, NULL);
91 /* Free up all the memory. */
92 rte_free(port_db->ulp_intf_list);
98 * Update the port database.This api is called when the port
99 * details are available during the startup.
101 * ulp_ctxt [in] Ptr to ulp context
102 * bp [in]. ptr to the device function.
104 * Returns 0 on success or negative number on failure.
106 int32_t ulp_port_db_dev_port_intf_update(struct bnxt_ulp_context *ulp_ctxt,
109 struct bnxt_ulp_port_db *port_db;
110 uint32_t port_id = bp->eth_dev->data->port_id;
112 struct ulp_interface_info *intf;
114 struct bnxt_vnic_info *vnic;
116 port_db = bnxt_ulp_cntxt_ptr2_port_db_get(ulp_ctxt);
118 BNXT_TF_DBG(ERR, "Invalid Arguments\n");
122 rc = ulp_port_db_dev_port_to_ulp_index(ulp_ctxt, port_id, &ifindex);
124 /* port not found, allocate one */
125 ifindex = ulp_port_db_allocate_ifindex(port_db);
128 port_db->dev_port_list[port_id] = ifindex;
129 } else if (rc == -EINVAL) {
133 /* update the interface details */
134 intf = &port_db->ulp_intf_list[ifindex];
135 if (BNXT_PF(bp) || BNXT_VF(bp)) {
137 intf->type = BNXT_ULP_INTF_TYPE_PF;
138 intf->port_svif = bp->port_svif;
140 intf->type = BNXT_ULP_INTF_TYPE_VF;
142 intf->func_id = bp->fw_fid;
143 intf->func_svif = bp->func_svif;
144 vnic = BNXT_GET_DEFAULT_VNIC(bp);
146 intf->default_vnic = vnic->fw_vnic_id;
148 memcpy(intf->mac_addr, bp->mac_addr, sizeof(intf->mac_addr));
150 BNXT_TF_DBG(ERR, "Invalid interface type\n");
157 * Api to get the ulp ifindex for a given device port.
159 * ulp_ctxt [in] Ptr to ulp context
160 * port_id [in].device port id
161 * ifindex [out] ulp ifindex
163 * Returns 0 on success or negative number on failure.
166 ulp_port_db_dev_port_to_ulp_index(struct bnxt_ulp_context *ulp_ctxt,
170 struct bnxt_ulp_port_db *port_db;
173 port_db = bnxt_ulp_cntxt_ptr2_port_db_get(ulp_ctxt);
174 if (!port_db || port_id >= RTE_MAX_ETHPORTS) {
175 BNXT_TF_DBG(ERR, "Invalid Arguments\n");
178 if (!port_db->dev_port_list[port_id])
181 *ifindex = port_db->dev_port_list[port_id];
186 * Api to get the function id for a given ulp ifindex.
188 * ulp_ctxt [in] Ptr to ulp context
189 * ifindex [in] ulp ifindex
190 * func_id [out] the function id of the given ifindex.
192 * Returns 0 on success or negative number on failure.
195 ulp_port_db_function_id_get(struct bnxt_ulp_context *ulp_ctxt,
199 struct bnxt_ulp_port_db *port_db;
201 port_db = bnxt_ulp_cntxt_ptr2_port_db_get(ulp_ctxt);
202 if (!port_db || ifindex >= port_db->ulp_intf_list_size || !ifindex) {
203 BNXT_TF_DBG(ERR, "Invalid Arguments\n");
206 *func_id = port_db->ulp_intf_list[ifindex].func_id;
211 * Api to get the svid for a given ulp ifindex.
213 * ulp_ctxt [in] Ptr to ulp context
214 * ifindex [in] ulp ifindex
215 * dir [in] the direction for the flow.
216 * svif [out] the svif of the given ifindex.
218 * Returns 0 on success or negative number on failure.
221 ulp_port_db_svif_get(struct bnxt_ulp_context *ulp_ctxt,
226 struct bnxt_ulp_port_db *port_db;
228 port_db = bnxt_ulp_cntxt_ptr2_port_db_get(ulp_ctxt);
229 if (!port_db || ifindex >= port_db->ulp_intf_list_size || !ifindex) {
230 BNXT_TF_DBG(ERR, "Invalid Arguments\n");
233 if (dir == ULP_DIR_EGRESS)
234 *svif = port_db->ulp_intf_list[ifindex].func_svif;
236 *svif = port_db->ulp_intf_list[ifindex].port_svif;
241 * Api to get the vnic id for a given ulp ifindex.
243 * ulp_ctxt [in] Ptr to ulp context
244 * ifindex [in] ulp ifindex
245 * vnic [out] the vnic of the given ifindex.
247 * Returns 0 on success or negative number on failure.
250 ulp_port_db_default_vnic_get(struct bnxt_ulp_context *ulp_ctxt,
254 struct bnxt_ulp_port_db *port_db;
256 port_db = bnxt_ulp_cntxt_ptr2_port_db_get(ulp_ctxt);
257 if (!port_db || ifindex >= port_db->ulp_intf_list_size || !ifindex) {
258 BNXT_TF_DBG(ERR, "Invalid Arguments\n");
261 *vnic = port_db->ulp_intf_list[ifindex].default_vnic;