uint32_t rte_net_get_ptype(const struct rte_mbuf *m,
struct rte_net_hdr_lens *hdr_lens, uint32_t layers);
此函数解析dpdk收到的报文,因此第一个参数是 struct rte_mbuf,当然也可以把其他方式收取的报文放入 struct rte_mbuf 内,设置好与报文有关的字段(此方式未用过)。
第二个参数用来保存解析过程中2-4层网络包头的长度。如果不需要,可以传入NULL。
第三个参数用来设置解析网络包头的层级,若要解析所有,为RTE_PTYPE_ALL_MASK,若只需要2-3层,为 RTE_PTYPE_L2_MASK | RTE_PTYPE_L3_MASK。因为是逐级解析的,所以此参数能取值的只有 RTE_PTYPE_ALL_MASK、RTE_PTYPE_L2_MASK、RTE_PTYPE_L2_MASK | RTE_PTYPE_L3_MASK、RTE_PTYPE_L2_MASK | RTE_PTYPE_L3_MASK | RTE_PTYPE_L4_MASK 这4种。
函数返回2-4层具体协议包头信息,目前支持的包头类型有:
* L2: Ether, Vlan, QinQ
* L3: IPv4, IPv6
* L4: TCP, UDP, SCTP
* Tunnels: IPv4, IPv6, Gre, Nvgre