net/hns3: refactor multi-process initialization
[dpdk.git] / drivers / raw / cnxk_bphy / cnxk_bphy_cgx.c
index 3da2244..0b694e1 100644 (file)
@@ -28,7 +28,7 @@ static void
 cnxk_bphy_cgx_format_name(char *name, unsigned int len,
                          struct rte_pci_device *pci_dev)
 {
-       snprintf(name, len, "BPHY_CGX:%x:%02x.%x", pci_dev->addr.bus,
+       snprintf(name, len, "BPHY_CGX:%02x:%02x.%x", pci_dev->addr.bus,
                 pci_dev->addr.devid, pci_dev->addr.function);
 }
 
@@ -62,6 +62,7 @@ cnxk_bphy_cgx_process_buf(struct cnxk_bphy_cgx *cgx, unsigned int queue,
        struct cnxk_bphy_cgx_msg_link_info *link_info;
        struct roc_bphy_cgx_link_info rlink_info;
        struct roc_bphy_cgx_link_mode rlink_mode;
+       enum roc_bphy_cgx_eth_link_fec *fec;
        unsigned int lmac = qp->lmac;
        void *rsp = NULL;
        int ret;
@@ -122,6 +123,18 @@ cnxk_bphy_cgx_process_buf(struct cnxk_bphy_cgx *cgx, unsigned int queue,
        case CNXK_BPHY_CGX_MSG_TYPE_STOP_RXTX:
                ret = roc_bphy_cgx_stop_rxtx(cgx->rcgx, lmac);
                break;
+       case CNXK_BPHY_CGX_MSG_TYPE_GET_SUPPORTED_FEC:
+               fec = rte_zmalloc(NULL, sizeof(*fec), 0);
+               if (!fec)
+                       return -ENOMEM;
+
+               ret = roc_bphy_cgx_fec_supported_get(cgx->rcgx, lmac, fec);
+               rsp = fec;
+               break;
+       case CNXK_BPHY_CGX_MSG_TYPE_SET_FEC:
+               fec = msg->data;
+               ret = roc_bphy_cgx_fec_set(cgx->rcgx, lmac, *fec);
+               break;
        default:
                return -EINVAL;
        }