common/idpf: refine get packet type

Message ID 20231222165128.2899806-1-beilei.xing@intel.com (mailing list archive)
State Accepted, archived
Delegated to: Bruce Richardson
Headers
Series common/idpf: refine get packet type |

Checks

Context Check Description
ci/checkpatch success coding style OK
ci/loongarch-compilation success Compilation OK
ci/loongarch-unit-testing success Unit Testing PASS
ci/Intel-compilation success Compilation OK
ci/github-robot: build success github build: passed
ci/intel-Testing success Testing PASS
ci/intel-Functional success Functional PASS
ci/iol-broadcom-Functional success Functional Testing PASS
ci/iol-intel-Performance success Performance Testing PASS
ci/iol-intel-Functional success Functional Testing PASS
ci/iol-sample-apps-testing success Testing PASS
ci/iol-broadcom-Performance success Performance Testing PASS
ci/iol-abi-testing success Testing PASS
ci/iol-unit-amd64-testing success Testing PASS
ci/iol-compile-amd64-testing success Testing PASS
ci/iol-mellanox-Performance success Performance Testing PASS
ci/iol-unit-arm64-testing success Testing PASS
ci/iol-compile-arm64-testing success Testing PASS

Commit Message

Xing, Beilei Dec. 22, 2023, 4:51 p.m. UTC
  From: Beilei Xing <beilei.xing@intel.com>

Since the response of virtual channel virtchnl2_get_ptype_info is
changed on IMC side, driver needs to be updated when requiring
the virtual channel.

Signed-off-by: Beilei Xing <beilei.xing@intel.com>
---
 drivers/common/idpf/idpf_common_device.c   | 64 ++++++++++++++--------
 drivers/common/idpf/idpf_common_device.h   |  9 +++
 drivers/common/idpf/idpf_common_virtchnl.c | 28 ++++------
 drivers/common/idpf/idpf_common_virtchnl.h |  4 +-
 4 files changed, 63 insertions(+), 42 deletions(-)
  

Comments

Vladimir Medvedkin Feb. 27, 2024, 7:35 p.m. UTC | #1
Hi Beilei,

Just a one nit below, besides that LGTM

Acked-by: Vladimir Medvedkin <vladimir.medvedkin@intel.com>

On 22/12/2023 16:51, beilei.xing@intel.com wrote:
> From: Beilei Xing <beilei.xing@intel.com>
>
> Since the response of virtual channel virtchnl2_get_ptype_info is
> changed on IMC side, driver needs to be updated when requiring
> the virtual channel.
>
> Signed-off-by: Beilei Xing <beilei.xing@intel.com>
> ---
>   drivers/common/idpf/idpf_common_device.c   | 64 ++++++++++++++--------
>   drivers/common/idpf/idpf_common_device.h   |  9 +++
>   drivers/common/idpf/idpf_common_virtchnl.c | 28 ++++------
>   drivers/common/idpf/idpf_common_virtchnl.h |  4 +-
>   4 files changed, 63 insertions(+), 42 deletions(-)
>
> diff --git a/drivers/common/idpf/idpf_common_device.c b/drivers/common/idpf/idpf_common_device.c
> index cc4207a46e..1380cc462c 100644
> --- a/drivers/common/idpf/idpf_common_device.c
> +++ b/drivers/common/idpf/idpf_common_device.c
> @@ -157,49 +157,65 @@ idpf_init_mbx(struct idpf_hw *hw)
>   static int
>   idpf_get_pkt_type(struct idpf_adapter *adapter)
>   {
> -	struct virtchnl2_get_ptype_info *ptype_info;
> +	struct virtchnl2_get_ptype_info *req_ptype_info;
> +	struct virtchnl2_get_ptype_info *recv_ptype_info;
> +	uint16_t recv_num_ptypes = 0;
>   	uint16_t ptype_offset, i, j;
> -	uint16_t ptype_recvd = 0;
> +	uint16_t start_ptype_id = 0;
>   	int ret;
>   
> -	ret = idpf_vc_ptype_info_query(adapter);
> -	if (ret != 0) {
> -		DRV_LOG(ERR, "Fail to query packet type information");
> -		return ret;
> +	req_ptype_info = rte_zmalloc("req_ptype_info", IDPF_DFLT_MBX_BUF_SIZE, 0);
> +	if (req_ptype_info == NULL)
> +		return -ENOMEM;
> +
> +	recv_ptype_info = rte_zmalloc("recv_ptype_info", IDPF_DFLT_MBX_BUF_SIZE, 0);
> +	if (recv_ptype_info == NULL) {
> +		ret = -ENOMEM;
> +		goto free_req_ptype_info;
>   	}
>   
> -	ptype_info = rte_zmalloc("ptype_info", IDPF_DFLT_MBX_BUF_SIZE, 0);
> -		if (ptype_info == NULL)
> -			return -ENOMEM;
> +	while (start_ptype_id < IDPF_MAX_PKT_TYPE) {
> +		memset(req_ptype_info, 0, sizeof(*req_ptype_info));
> +		memset(recv_ptype_info, 0, sizeof(*recv_ptype_info));
> +
> +		if ((start_ptype_id + IDPF_RX_MAX_PTYPES_PER_BUF) > IDPF_MAX_PKT_TYPE)
> +			req_ptype_info->num_ptypes =
> +				rte_cpu_to_le_16(IDPF_MAX_PKT_TYPE - start_ptype_id);
> +		else
> +			req_ptype_info->num_ptypes = rte_cpu_to_le_16(IDPF_RX_MAX_PTYPES_PER_BUF);
> +		req_ptype_info->start_ptype_id = start_ptype_id;
>   
> -	while (ptype_recvd < IDPF_MAX_PKT_TYPE) {
> -		ret = idpf_vc_one_msg_read(adapter, VIRTCHNL2_OP_GET_PTYPE_INFO,
> -					   IDPF_DFLT_MBX_BUF_SIZE, (uint8_t *)ptype_info);
> +		ret = idpf_vc_ptype_info_query(adapter, req_ptype_info, recv_ptype_info);
>   		if (ret != 0) {
> -			DRV_LOG(ERR, "Fail to get packet type information");
> -			goto free_ptype_info;
> +			DRV_LOG(ERR, "Fail to query packet type information");
> +			goto free_recv_ptype_info;
>   		}
>   
> -		ptype_recvd += ptype_info->num_ptypes;
> +		recv_num_ptypes += rte_cpu_to_le_16(recv_ptype_info->num_ptypes);
I understand that rte_cpu_to_le and rte_le_to_cpu are the same thing, 
however here and in several places below it would be better to use 
rte_le_to_cpu_16() because it is semantically correct.
> +		if (recv_num_ptypes > IDPF_MAX_PKT_TYPE) {
> +			ret = -EINVAL;
> +			goto free_recv_ptype_info;
> +		}
> +
> +		start_ptype_id = rte_cpu_to_le_16(req_ptype_info->start_ptype_id) +
> +			rte_cpu_to_le_16(req_ptype_info->num_ptypes);
> +
>   		ptype_offset = sizeof(struct virtchnl2_get_ptype_info) -
>   						sizeof(struct virtchnl2_ptype);
>   
> -		for (i = 0; i < rte_cpu_to_le_16(ptype_info->num_ptypes); i++) {
> +		for (i = 0; i < rte_cpu_to_le_16(recv_ptype_info->num_ptypes); i++) {
>   			bool is_inner = false, is_ip = false;
>   			struct virtchnl2_ptype *ptype;
>   			uint32_t proto_hdr = 0;
>   
>   			ptype = (struct virtchnl2_ptype *)
> -					((uint8_t *)ptype_info + ptype_offset);
> +					((uint8_t *)recv_ptype_info + ptype_offset);
>   			ptype_offset += IDPF_GET_PTYPE_SIZE(ptype);
>   			if (ptype_offset > IDPF_DFLT_MBX_BUF_SIZE) {
>   				ret = -EINVAL;
> -				goto free_ptype_info;
> +				goto free_recv_ptype_info;
>   			}
>   
> -			if (rte_cpu_to_le_16(ptype->ptype_id_10) == 0xFFFF)
> -				goto free_ptype_info;
> -
>   			for (j = 0; j < ptype->proto_id_count; j++) {
>   				switch (rte_cpu_to_le_16(ptype->proto_id[j])) {
>   				case VIRTCHNL2_PROTO_HDR_GRE:
> @@ -358,8 +374,10 @@ idpf_get_pkt_type(struct idpf_adapter *adapter)
>   		}
>   	}
>   
> -free_ptype_info:
> -	rte_free(ptype_info);
> +free_recv_ptype_info:
> +	rte_free(recv_ptype_info);
> +free_req_ptype_info:
> +	rte_free(req_ptype_info);
>   	clear_cmd(adapter);
>   	return ret;
>   }
> diff --git a/drivers/common/idpf/idpf_common_device.h b/drivers/common/idpf/idpf_common_device.h
> index f767ea7cec..2b94f0331a 100644
> --- a/drivers/common/idpf/idpf_common_device.h
> +++ b/drivers/common/idpf/idpf_common_device.h
> @@ -31,6 +31,15 @@
>   
>   #define IDPF_DFLT_INTERVAL	16
>   
> +#define IDPF_RX_MAX_PTYPE_PROTO_IDS	32
> +#define IDPF_RX_MAX_PTYPE_SZ	(sizeof(struct virtchnl2_ptype) +	\
> +				 (sizeof(uint16_t) *			\
> +				  (IDPF_RX_MAX_PTYPE_PROTO_IDS - 1)))
> +#define IDPF_RX_PTYPE_HDR_SZ	(sizeof(struct virtchnl2_get_ptype_info) - \
> +				 sizeof(struct virtchnl2_ptype))
> +#define IDPF_RX_MAX_PTYPES_PER_BUF				\
> +	((IDPF_DFLT_MBX_BUF_SIZE - IDPF_RX_PTYPE_HDR_SZ)/	\
> +	 IDPF_RX_MAX_PTYPE_SZ)
>   #define IDPF_GET_PTYPE_SIZE(p)						\
>   	(sizeof(struct virtchnl2_ptype) +				\
>   	 (((p)->proto_id_count ? ((p)->proto_id_count - 1) : 0) * sizeof((p)->proto_id[0])))
> diff --git a/drivers/common/idpf/idpf_common_virtchnl.c b/drivers/common/idpf/idpf_common_virtchnl.c
> index 6455f640da..c46ed50eb5 100644
> --- a/drivers/common/idpf/idpf_common_virtchnl.c
> +++ b/drivers/common/idpf/idpf_common_virtchnl.c
> @@ -202,15 +202,11 @@ idpf_vc_cmd_execute(struct idpf_adapter *adapter, struct idpf_cmd_info *args)
>   	switch (args->ops) {
>   	case VIRTCHNL_OP_VERSION:
>   	case VIRTCHNL2_OP_GET_CAPS:
> +	case VIRTCHNL2_OP_GET_PTYPE_INFO:
>   		/* for init virtchnl ops, need to poll the response */
>   		err = idpf_vc_one_msg_read(adapter, args->ops, args->out_size, args->out_buffer);
>   		clear_cmd(adapter);
>   		break;
> -	case VIRTCHNL2_OP_GET_PTYPE_INFO:
> -		/* for multuple response message,
> -		 * do not handle the response here.
> -		 */
> -		break;
>   	default:
>   		/* For other virtchnl ops in running time,
>   		 * wait for the cmd done flag.
> @@ -909,28 +905,24 @@ idpf_vc_vport_ena_dis(struct idpf_vport *vport, bool enable)
>   }
>   
>   int
> -idpf_vc_ptype_info_query(struct idpf_adapter *adapter)
> +idpf_vc_ptype_info_query(struct idpf_adapter *adapter,
> +			 struct virtchnl2_get_ptype_info *req_ptype_info,
> +			 struct virtchnl2_get_ptype_info *recv_ptype_info)
>   {
> -	struct virtchnl2_get_ptype_info *ptype_info;
>   	struct idpf_cmd_info args;
> -	int len, err;
> -
> -	len = sizeof(struct virtchnl2_get_ptype_info);
> -	ptype_info = rte_zmalloc("ptype_info", len, 0);
> -	if (ptype_info == NULL)
> -		return -ENOMEM;
> +	int err;
>   
> -	ptype_info->start_ptype_id = 0;
> -	ptype_info->num_ptypes = IDPF_MAX_PKT_TYPE;
>   	args.ops = VIRTCHNL2_OP_GET_PTYPE_INFO;
> -	args.in_args = (uint8_t *)ptype_info;
> -	args.in_args_size = len;
> +	args.in_args = (uint8_t *)req_ptype_info;
> +	args.in_args_size = sizeof(struct virtchnl2_get_ptype_info);
> +	args.out_buffer = adapter->mbx_resp;
> +	args.out_size = IDPF_DFLT_MBX_BUF_SIZE;
>   
>   	err = idpf_vc_cmd_execute(adapter, &args);
>   	if (err != 0)
>   		DRV_LOG(ERR, "Failed to execute command of VIRTCHNL2_OP_GET_PTYPE_INFO");
>   
> -	rte_free(ptype_info);
> +	rte_memcpy(recv_ptype_info, args.out_buffer, IDPF_DFLT_MBX_BUF_SIZE);
>   	return err;
>   }
>   
> diff --git a/drivers/common/idpf/idpf_common_virtchnl.h b/drivers/common/idpf/idpf_common_virtchnl.h
> index 9ff5c38c26..73446ded86 100644
> --- a/drivers/common/idpf/idpf_common_virtchnl.h
> +++ b/drivers/common/idpf/idpf_common_virtchnl.h
> @@ -41,7 +41,9 @@ int idpf_vc_vectors_alloc(struct idpf_vport *vport, uint16_t num_vectors);
>   __rte_internal
>   int idpf_vc_vectors_dealloc(struct idpf_vport *vport);
>   __rte_internal
> -int idpf_vc_ptype_info_query(struct idpf_adapter *adapter);
> +int idpf_vc_ptype_info_query(struct idpf_adapter *adapter,
> +			     struct virtchnl2_get_ptype_info *req_ptype_info,
> +			     struct virtchnl2_get_ptype_info *recv_ptype_info);
>   __rte_internal
>   int idpf_vc_one_msg_read(struct idpf_adapter *adapter, uint32_t ops,
>   			 uint16_t buf_len, uint8_t *buf);
  
Bruce Richardson Feb. 29, 2024, 5:09 p.m. UTC | #2
On Tue, Feb 27, 2024 at 07:35:37PM +0000, Medvedkin, Vladimir wrote:
> Hi Beilei,
> 
> Just a one nit below, besides that LGTM
> 
> Acked-by: Vladimir Medvedkin <vladimir.medvedkin@intel.com>
> 
> On 22/12/2023 16:51, beilei.xing@intel.com wrote:
> > From: Beilei Xing <beilei.xing@intel.com>
> > 
> > Since the response of virtual channel virtchnl2_get_ptype_info is
> > changed on IMC side, driver needs to be updated when requiring
> > the virtual channel.
> > 
> > Signed-off-by: Beilei Xing <beilei.xing@intel.com>
> > ---
Applied to next-net-intel, with changes suggested by Vladimir, and some
rewording of commit message.

Thanks,
/Bruce
  

Patch

diff --git a/drivers/common/idpf/idpf_common_device.c b/drivers/common/idpf/idpf_common_device.c
index cc4207a46e..1380cc462c 100644
--- a/drivers/common/idpf/idpf_common_device.c
+++ b/drivers/common/idpf/idpf_common_device.c
@@ -157,49 +157,65 @@  idpf_init_mbx(struct idpf_hw *hw)
 static int
 idpf_get_pkt_type(struct idpf_adapter *adapter)
 {
-	struct virtchnl2_get_ptype_info *ptype_info;
+	struct virtchnl2_get_ptype_info *req_ptype_info;
+	struct virtchnl2_get_ptype_info *recv_ptype_info;
+	uint16_t recv_num_ptypes = 0;
 	uint16_t ptype_offset, i, j;
-	uint16_t ptype_recvd = 0;
+	uint16_t start_ptype_id = 0;
 	int ret;
 
-	ret = idpf_vc_ptype_info_query(adapter);
-	if (ret != 0) {
-		DRV_LOG(ERR, "Fail to query packet type information");
-		return ret;
+	req_ptype_info = rte_zmalloc("req_ptype_info", IDPF_DFLT_MBX_BUF_SIZE, 0);
+	if (req_ptype_info == NULL)
+		return -ENOMEM;
+
+	recv_ptype_info = rte_zmalloc("recv_ptype_info", IDPF_DFLT_MBX_BUF_SIZE, 0);
+	if (recv_ptype_info == NULL) {
+		ret = -ENOMEM;
+		goto free_req_ptype_info;
 	}
 
-	ptype_info = rte_zmalloc("ptype_info", IDPF_DFLT_MBX_BUF_SIZE, 0);
-		if (ptype_info == NULL)
-			return -ENOMEM;
+	while (start_ptype_id < IDPF_MAX_PKT_TYPE) {
+		memset(req_ptype_info, 0, sizeof(*req_ptype_info));
+		memset(recv_ptype_info, 0, sizeof(*recv_ptype_info));
+
+		if ((start_ptype_id + IDPF_RX_MAX_PTYPES_PER_BUF) > IDPF_MAX_PKT_TYPE)
+			req_ptype_info->num_ptypes =
+				rte_cpu_to_le_16(IDPF_MAX_PKT_TYPE - start_ptype_id);
+		else
+			req_ptype_info->num_ptypes = rte_cpu_to_le_16(IDPF_RX_MAX_PTYPES_PER_BUF);
+		req_ptype_info->start_ptype_id = start_ptype_id;
 
-	while (ptype_recvd < IDPF_MAX_PKT_TYPE) {
-		ret = idpf_vc_one_msg_read(adapter, VIRTCHNL2_OP_GET_PTYPE_INFO,
-					   IDPF_DFLT_MBX_BUF_SIZE, (uint8_t *)ptype_info);
+		ret = idpf_vc_ptype_info_query(adapter, req_ptype_info, recv_ptype_info);
 		if (ret != 0) {
-			DRV_LOG(ERR, "Fail to get packet type information");
-			goto free_ptype_info;
+			DRV_LOG(ERR, "Fail to query packet type information");
+			goto free_recv_ptype_info;
 		}
 
-		ptype_recvd += ptype_info->num_ptypes;
+		recv_num_ptypes += rte_cpu_to_le_16(recv_ptype_info->num_ptypes);
+		if (recv_num_ptypes > IDPF_MAX_PKT_TYPE) {
+			ret = -EINVAL;
+			goto free_recv_ptype_info;
+		}
+
+		start_ptype_id = rte_cpu_to_le_16(req_ptype_info->start_ptype_id) +
+			rte_cpu_to_le_16(req_ptype_info->num_ptypes);
+
 		ptype_offset = sizeof(struct virtchnl2_get_ptype_info) -
 						sizeof(struct virtchnl2_ptype);
 
-		for (i = 0; i < rte_cpu_to_le_16(ptype_info->num_ptypes); i++) {
+		for (i = 0; i < rte_cpu_to_le_16(recv_ptype_info->num_ptypes); i++) {
 			bool is_inner = false, is_ip = false;
 			struct virtchnl2_ptype *ptype;
 			uint32_t proto_hdr = 0;
 
 			ptype = (struct virtchnl2_ptype *)
-					((uint8_t *)ptype_info + ptype_offset);
+					((uint8_t *)recv_ptype_info + ptype_offset);
 			ptype_offset += IDPF_GET_PTYPE_SIZE(ptype);
 			if (ptype_offset > IDPF_DFLT_MBX_BUF_SIZE) {
 				ret = -EINVAL;
-				goto free_ptype_info;
+				goto free_recv_ptype_info;
 			}
 
-			if (rte_cpu_to_le_16(ptype->ptype_id_10) == 0xFFFF)
-				goto free_ptype_info;
-
 			for (j = 0; j < ptype->proto_id_count; j++) {
 				switch (rte_cpu_to_le_16(ptype->proto_id[j])) {
 				case VIRTCHNL2_PROTO_HDR_GRE:
@@ -358,8 +374,10 @@  idpf_get_pkt_type(struct idpf_adapter *adapter)
 		}
 	}
 
-free_ptype_info:
-	rte_free(ptype_info);
+free_recv_ptype_info:
+	rte_free(recv_ptype_info);
+free_req_ptype_info:
+	rte_free(req_ptype_info);
 	clear_cmd(adapter);
 	return ret;
 }
diff --git a/drivers/common/idpf/idpf_common_device.h b/drivers/common/idpf/idpf_common_device.h
index f767ea7cec..2b94f0331a 100644
--- a/drivers/common/idpf/idpf_common_device.h
+++ b/drivers/common/idpf/idpf_common_device.h
@@ -31,6 +31,15 @@ 
 
 #define IDPF_DFLT_INTERVAL	16
 
+#define IDPF_RX_MAX_PTYPE_PROTO_IDS	32
+#define IDPF_RX_MAX_PTYPE_SZ	(sizeof(struct virtchnl2_ptype) +	\
+				 (sizeof(uint16_t) *			\
+				  (IDPF_RX_MAX_PTYPE_PROTO_IDS - 1)))
+#define IDPF_RX_PTYPE_HDR_SZ	(sizeof(struct virtchnl2_get_ptype_info) - \
+				 sizeof(struct virtchnl2_ptype))
+#define IDPF_RX_MAX_PTYPES_PER_BUF				\
+	((IDPF_DFLT_MBX_BUF_SIZE - IDPF_RX_PTYPE_HDR_SZ)/	\
+	 IDPF_RX_MAX_PTYPE_SZ)
 #define IDPF_GET_PTYPE_SIZE(p)						\
 	(sizeof(struct virtchnl2_ptype) +				\
 	 (((p)->proto_id_count ? ((p)->proto_id_count - 1) : 0) * sizeof((p)->proto_id[0])))
diff --git a/drivers/common/idpf/idpf_common_virtchnl.c b/drivers/common/idpf/idpf_common_virtchnl.c
index 6455f640da..c46ed50eb5 100644
--- a/drivers/common/idpf/idpf_common_virtchnl.c
+++ b/drivers/common/idpf/idpf_common_virtchnl.c
@@ -202,15 +202,11 @@  idpf_vc_cmd_execute(struct idpf_adapter *adapter, struct idpf_cmd_info *args)
 	switch (args->ops) {
 	case VIRTCHNL_OP_VERSION:
 	case VIRTCHNL2_OP_GET_CAPS:
+	case VIRTCHNL2_OP_GET_PTYPE_INFO:
 		/* for init virtchnl ops, need to poll the response */
 		err = idpf_vc_one_msg_read(adapter, args->ops, args->out_size, args->out_buffer);
 		clear_cmd(adapter);
 		break;
-	case VIRTCHNL2_OP_GET_PTYPE_INFO:
-		/* for multuple response message,
-		 * do not handle the response here.
-		 */
-		break;
 	default:
 		/* For other virtchnl ops in running time,
 		 * wait for the cmd done flag.
@@ -909,28 +905,24 @@  idpf_vc_vport_ena_dis(struct idpf_vport *vport, bool enable)
 }
 
 int
-idpf_vc_ptype_info_query(struct idpf_adapter *adapter)
+idpf_vc_ptype_info_query(struct idpf_adapter *adapter,
+			 struct virtchnl2_get_ptype_info *req_ptype_info,
+			 struct virtchnl2_get_ptype_info *recv_ptype_info)
 {
-	struct virtchnl2_get_ptype_info *ptype_info;
 	struct idpf_cmd_info args;
-	int len, err;
-
-	len = sizeof(struct virtchnl2_get_ptype_info);
-	ptype_info = rte_zmalloc("ptype_info", len, 0);
-	if (ptype_info == NULL)
-		return -ENOMEM;
+	int err;
 
-	ptype_info->start_ptype_id = 0;
-	ptype_info->num_ptypes = IDPF_MAX_PKT_TYPE;
 	args.ops = VIRTCHNL2_OP_GET_PTYPE_INFO;
-	args.in_args = (uint8_t *)ptype_info;
-	args.in_args_size = len;
+	args.in_args = (uint8_t *)req_ptype_info;
+	args.in_args_size = sizeof(struct virtchnl2_get_ptype_info);
+	args.out_buffer = adapter->mbx_resp;
+	args.out_size = IDPF_DFLT_MBX_BUF_SIZE;
 
 	err = idpf_vc_cmd_execute(adapter, &args);
 	if (err != 0)
 		DRV_LOG(ERR, "Failed to execute command of VIRTCHNL2_OP_GET_PTYPE_INFO");
 
-	rte_free(ptype_info);
+	rte_memcpy(recv_ptype_info, args.out_buffer, IDPF_DFLT_MBX_BUF_SIZE);
 	return err;
 }
 
diff --git a/drivers/common/idpf/idpf_common_virtchnl.h b/drivers/common/idpf/idpf_common_virtchnl.h
index 9ff5c38c26..73446ded86 100644
--- a/drivers/common/idpf/idpf_common_virtchnl.h
+++ b/drivers/common/idpf/idpf_common_virtchnl.h
@@ -41,7 +41,9 @@  int idpf_vc_vectors_alloc(struct idpf_vport *vport, uint16_t num_vectors);
 __rte_internal
 int idpf_vc_vectors_dealloc(struct idpf_vport *vport);
 __rte_internal
-int idpf_vc_ptype_info_query(struct idpf_adapter *adapter);
+int idpf_vc_ptype_info_query(struct idpf_adapter *adapter,
+			     struct virtchnl2_get_ptype_info *req_ptype_info,
+			     struct virtchnl2_get_ptype_info *recv_ptype_info);
 __rte_internal
 int idpf_vc_one_msg_read(struct idpf_adapter *adapter, uint32_t ops,
 			 uint16_t buf_len, uint8_t *buf);