return;
}
- n->has_vnet_hdr = qemu_peer_has_vnet_hdr(nc);
+ n->has_vnet_hdr = qemu_has_vnet_hdr(nc->peer);
}
static int peer_has_vnet_hdr(VirtIONet *n)
if (!peer_has_vnet_hdr(n))
return 0;
- n->has_ufo = qemu_peer_has_ufo(qemu_get_queue(n->nic));
+ n->has_ufo = qemu_has_ufo(qemu_get_queue(n->nic)->peer);
return n->has_ufo;
}
nc = qemu_get_subqueue(n->nic, i);
if (peer_has_vnet_hdr(n) &&
- qemu_peer_has_vnet_hdr_len(nc, n->guest_hdr_len)) {
- qemu_peer_set_vnet_hdr_len(nc, n->guest_hdr_len);
+ qemu_has_vnet_hdr_len(nc->peer, n->guest_hdr_len)) {
+ qemu_set_vnet_hdr_len(nc->peer, n->guest_hdr_len);
n->host_hdr_len = n->guest_hdr_len;
}
}
static void virtio_net_apply_guest_offloads(VirtIONet *n)
{
- qemu_peer_set_offload(qemu_get_subqueue(n->nic, 0),
+ qemu_set_offload(qemu_get_subqueue(n->nic, 0)->peer,
!!(n->curr_guest_offloads & (1ULL << VIRTIO_NET_F_GUEST_CSUM)),
!!(n->curr_guest_offloads & (1ULL << VIRTIO_NET_F_GUEST_TSO4)),
!!(n->curr_guest_offloads & (1ULL << VIRTIO_NET_F_GUEST_TSO6)),
peer_test_vnet_hdr(n);
if (peer_has_vnet_hdr(n)) {
for (i = 0; i < n->max_queues; i++) {
- qemu_peer_using_vnet_hdr(qemu_get_subqueue(n->nic, i), true);
+ qemu_using_vnet_hdr(qemu_get_subqueue(n->nic, i)->peer, true);
}
n->host_hdr_len = sizeof(struct virtio_net_hdr);
} else {
s->lro_supported, rxcso_supported,
s->rx_vlan_stripping);
if (s->peer_has_vhdr) {
- qemu_peer_set_offload(qemu_get_queue(s->nic),
- rxcso_supported,
- s->lro_supported,
- s->lro_supported,
- 0,
- 0);
+ qemu_set_offload(qemu_get_queue(s->nic)->peer,
+ rxcso_supported,
+ s->lro_supported,
+ s->lro_supported,
+ 0,
+ 0);
}
}
{
NetClientState *nc = qemu_get_queue(s->nic);
- if (qemu_peer_has_vnet_hdr(nc)) {
+ if (qemu_has_vnet_hdr(nc->peer)) {
return true;
}
s->lro_supported = false;
if (s->peer_has_vhdr) {
- qemu_peer_set_vnet_hdr_len(qemu_get_queue(s->nic),
+ qemu_set_vnet_hdr_len(qemu_get_queue(s->nic)->peer,
sizeof(struct virtio_net_hdr));
- qemu_peer_using_vnet_hdr(qemu_get_queue(s->nic), 1);
+ qemu_using_vnet_hdr(qemu_get_queue(s->nic)->peer, 1);
}
qemu_format_nic_info_str(qemu_get_queue(s->nic), s->conf.macaddr.a);
void qemu_purge_queued_packets(NetClientState *nc);
void qemu_flush_queued_packets(NetClientState *nc);
void qemu_format_nic_info_str(NetClientState *nc, uint8_t macaddr[6]);
-bool qemu_peer_has_ufo(NetClientState *nc);
-bool qemu_peer_has_vnet_hdr(NetClientState *nc);
-bool qemu_peer_has_vnet_hdr_len(NetClientState *nc, int len);
-void qemu_peer_using_vnet_hdr(NetClientState *nc, bool enable);
-void qemu_peer_set_offload(NetClientState *nc, int csum, int tso4, int tso6,
- int ecn, int ufo);
-void qemu_peer_set_vnet_hdr_len(NetClientState *nc, int len);
+bool qemu_has_ufo(NetClientState *nc);
+bool qemu_has_vnet_hdr(NetClientState *nc);
+bool qemu_has_vnet_hdr_len(NetClientState *nc, int len);
+void qemu_using_vnet_hdr(NetClientState *nc, bool enable);
+void qemu_set_offload(NetClientState *nc, int csum, int tso4, int tso6,
+ int ecn, int ufo);
+void qemu_set_vnet_hdr_len(NetClientState *nc, int len);
void qemu_macaddr_default_if_unset(MACAddr *macaddr);
int qemu_show_nic_models(const char *arg, const char *const *models);
void qemu_check_nic_model(NICInfo *nd, const char *model);
}
}
-bool qemu_peer_has_ufo(NetClientState *nc)
+bool qemu_has_ufo(NetClientState *nc)
{
- if (!nc->peer || !nc->peer->info->has_ufo) {
+ if (!nc || !nc->info->has_ufo) {
return false;
}
- return nc->peer->info->has_ufo(nc->peer);
+ return nc->info->has_ufo(nc);
}
-bool qemu_peer_has_vnet_hdr(NetClientState *nc)
+bool qemu_has_vnet_hdr(NetClientState *nc)
{
- if (!nc->peer || !nc->peer->info->has_vnet_hdr) {
+ if (!nc || !nc->info->has_vnet_hdr) {
return false;
}
- return nc->peer->info->has_vnet_hdr(nc->peer);
+ return nc->info->has_vnet_hdr(nc);
}
-bool qemu_peer_has_vnet_hdr_len(NetClientState *nc, int len)
+bool qemu_has_vnet_hdr_len(NetClientState *nc, int len)
{
- if (!nc->peer || !nc->peer->info->has_vnet_hdr_len) {
+ if (!nc || !nc->info->has_vnet_hdr_len) {
return false;
}
- return nc->peer->info->has_vnet_hdr_len(nc->peer, len);
+ return nc->info->has_vnet_hdr_len(nc, len);
}
-void qemu_peer_using_vnet_hdr(NetClientState *nc, bool enable)
+void qemu_using_vnet_hdr(NetClientState *nc, bool enable)
{
- if (!nc->peer || !nc->peer->info->using_vnet_hdr) {
+ if (!nc || !nc->info->using_vnet_hdr) {
return;
}
- nc->peer->info->using_vnet_hdr(nc->peer, enable);
+ nc->info->using_vnet_hdr(nc, enable);
}
-void qemu_peer_set_offload(NetClientState *nc, int csum, int tso4, int tso6,
+void qemu_set_offload(NetClientState *nc, int csum, int tso4, int tso6,
int ecn, int ufo)
{
- if (!nc->peer || !nc->peer->info->set_offload) {
+ if (!nc || !nc->info->set_offload) {
return;
}
- nc->peer->info->set_offload(nc->peer, csum, tso4, tso6, ecn, ufo);
+ nc->info->set_offload(nc, csum, tso4, tso6, ecn, ufo);
}
-void qemu_peer_set_vnet_hdr_len(NetClientState *nc, int len)
+void qemu_set_vnet_hdr_len(NetClientState *nc, int len)
{
- if (!nc->peer || !nc->peer->info->set_vnet_hdr_len) {
+ if (!nc || !nc->info->set_vnet_hdr_len) {
return;
}
- nc->peer->info->set_vnet_hdr_len(nc->peer, len);
+ nc->info->set_vnet_hdr_len(nc, len);
}
int qemu_can_send_packet(NetClientState *sender)