/* * QEMU VMWARE VMXNET* paravirtual NICs - TX packets abstraction * * Copyright (c) 2012 Ravello Systems LTD (http://ravellosystems.com) * * Developed by Daynix Computing LTD (http://www.daynix.com) * * Authors: * Dmitry Fleytman * Tamir Shomer * Yan Vugenfirer * * This work is licensed under the terms of the GNU GPL, version 2 or later. * See the COPYING file in the top-level directory. * */ #ifndef VMXNET_TX_PKT_H #define VMXNET_TX_PKT_H #include "stdint.h" #include "stdbool.h" #include "net/eth.h" #include "exec/hwaddr.h" /* define to enable packet dump functions */ /*#define VMXNET_TX_PKT_DEBUG*/ struct VmxnetTxPkt; /** * Init function for tx packet functionality * * @pkt: packet pointer * @max_frags: max tx ip fragments * @has_virt_hdr: device uses virtio header. */ void vmxnet_tx_pkt_init(struct VmxnetTxPkt **pkt, uint32_t max_frags, bool has_virt_hdr); /** * Clean all tx packet resources. * * @pkt: packet. */ void vmxnet_tx_pkt_uninit(struct VmxnetTxPkt *pkt); /** * get virtio header * * @pkt: packet * @ret: virtio header */ struct virtio_net_hdr *vmxnet_tx_pkt_get_vhdr(struct VmxnetTxPkt *pkt); /** * build virtio header (will be stored in module context) * * @pkt: packet * @tso_enable: TSO enabled * @csum_enable: CSO enabled * @gso_size: MSS size for TSO * */ void vmxnet_tx_pkt_build_vheader(struct VmxnetTxPkt *pkt, bool tso_enable, bool csum_enable, uint32_t gso_size); /** * updates vlan tag, and adds vlan header in case it is missing * * @pkt: packet * @vlan: VLAN tag * */ void vmxnet_tx_pkt_setup_vlan_header(struct VmxnetTxPkt *pkt, uint16_t vlan); /** * populate data fragment into pkt context. * * @pkt: packet * @pa: physical address of fragment * @len: length of fragment * */ bool vmxnet_tx_pkt_add_raw_fragment(struct VmxnetTxPkt *pkt, hwaddr pa, size_t len); /** * fix ip header fields and calculate checksums needed. * * @pkt: packet * */ void vmxnet_tx_pkt_update_ip_checksums(struct VmxnetTxPkt *pkt); /** * get length of all populated data. * * @pkt: packet * @ret: total data length * */ size_t vmxnet_tx_pkt_get_total_len(struct VmxnetTxPkt *pkt); /** * get packet type * * @pkt: packet * @ret: packet type * */ eth_pkt_types_e vmxnet_tx_pkt_get_packet_type(struct VmxnetTxPkt *pkt); /** * prints packet data if debug is enabled * * @pkt: packet * */ void vmxnet_tx_pkt_dump(struct VmxnetTxPkt *pkt); /** * reset tx packet private context (needed to be called between packets) * * @pkt: packet * */ void vmxnet_tx_pkt_reset(struct VmxnetTxPkt *pkt); /** * Send packet to qemu. handles sw offloads if vhdr is not supported. * * @pkt: packet * @nc: NetClientState * @ret: operation result * */ bool vmxnet_tx_pkt_send(struct VmxnetTxPkt *pkt, NetClientState *nc); /** * parse raw packet data and analyze offload requirements. * * @pkt: packet * */ bool vmxnet_tx_pkt_parse(struct VmxnetTxPkt *pkt); #endif