Commit fb4dae4c authored by Junfeng Guo's avatar Junfeng Guo Committed by Tony Nguyen

virtchnl: support raw packet in protocol header

The patch extends existing virtchnl_proto_hdrs structure to allow VF
to pass a pair of buffers as packet data and mask that describe
a match pattern of a filter rule. Then the kernel PF driver is requested
to parse the pair of buffer and figure out low level hardware metadata
(ptype, profile, field vector.. ) to program the expected FDIR or RSS
rules.
Reviewed-by: default avatarSimon Horman <horms@kernel.org>
Reviewed-by: default avatarMarcin Szycik <marcin.szycik@linux.intel.com>
Signed-off-by: default avatarQi Zhang <qi.z.zhang@intel.com>
Signed-off-by: default avatarJunfeng Guo <junfeng.guo@intel.com>
Signed-off-by: default avatarAhmed Zaki <ahmed.zaki@intel.com>
Tested-by: default avatarRafal Romanowski <rafal.romanowski@intel.com>
Signed-off-by: default avatarTony Nguyen <anthony.l.nguyen@intel.com>
parent e312b3a1
...@@ -1121,6 +1121,7 @@ enum virtchnl_vfr_states { ...@@ -1121,6 +1121,7 @@ enum virtchnl_vfr_states {
}; };
#define VIRTCHNL_MAX_NUM_PROTO_HDRS 32 #define VIRTCHNL_MAX_NUM_PROTO_HDRS 32
#define VIRTCHNL_MAX_SIZE_RAW_PACKET 1024
#define PROTO_HDR_SHIFT 5 #define PROTO_HDR_SHIFT 5
#define PROTO_HDR_FIELD_START(proto_hdr_type) ((proto_hdr_type) << PROTO_HDR_SHIFT) #define PROTO_HDR_FIELD_START(proto_hdr_type) ((proto_hdr_type) << PROTO_HDR_SHIFT)
#define PROTO_HDR_FIELD_MASK ((1UL << PROTO_HDR_SHIFT) - 1) #define PROTO_HDR_FIELD_MASK ((1UL << PROTO_HDR_SHIFT) - 1)
...@@ -1266,13 +1267,22 @@ struct virtchnl_proto_hdrs { ...@@ -1266,13 +1267,22 @@ struct virtchnl_proto_hdrs {
u8 pad[3]; u8 pad[3];
/** /**
* specify where protocol header start from. * specify where protocol header start from.
* must be 0 when sending a raw packet request.
* 0 - from the outer layer * 0 - from the outer layer
* 1 - from the first inner layer * 1 - from the first inner layer
* 2 - from the second inner layer * 2 - from the second inner layer
* .... * ....
**/ **/
int count; /* the proto layers must < VIRTCHNL_MAX_NUM_PROTO_HDRS */ int count; /* the proto layers must < VIRTCHNL_MAX_NUM_PROTO_HDRS */
struct virtchnl_proto_hdr proto_hdr[VIRTCHNL_MAX_NUM_PROTO_HDRS]; union {
struct virtchnl_proto_hdr
proto_hdr[VIRTCHNL_MAX_NUM_PROTO_HDRS];
struct {
u16 pkt_len;
u8 spec[VIRTCHNL_MAX_SIZE_RAW_PACKET];
u8 mask[VIRTCHNL_MAX_SIZE_RAW_PACKET];
} raw;
};
}; };
VIRTCHNL_CHECK_STRUCT_LEN(2312, virtchnl_proto_hdrs); VIRTCHNL_CHECK_STRUCT_LEN(2312, virtchnl_proto_hdrs);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment