From 900ff8e82884a1df757fa6f83189ffe2c157ca89 Mon Sep 17 00:00:00 2001 From: Alexander Gall Date: Mon, 4 Jul 2016 17:36:19 +0200 Subject: [PATCH 1/2] Fix interface speed The counter value for the interface speed should be in units of bps. The ifSpeed SNMP object must obey RFC3635 sec. 3.2.8. --- src/apps/intel/intel_app.lua | 2 +- src/lib/ipc/shmem/iftable_mib.lua | 9 +++++++-- 2 files changed, 8 insertions(+), 3 deletions(-) diff --git a/src/apps/intel/intel_app.lua b/src/apps/intel/intel_app.lua index 92f97d00fd..c85c2e5530 100644 --- a/src/apps/intel/intel_app.lua +++ b/src/apps/intel/intel_app.lua @@ -73,7 +73,7 @@ function Intel82599:new (arg) counter.set(self.stats.counters.type, 0x1000) -- Hardware interface counter.set(self.stats.counters.dtime, C.get_unix_time()) counter.set(self.stats.counters.mtu, self.dev.mtu) - counter.set(self.stats.counters.speed, 10000000) -- 10 Gbits + counter.set(self.stats.counters.speed, 10000000000) -- 10 Gbits counter.set(self.stats.counters.status, 2) -- down if not conf.vmdq and conf.macaddr then counter.set(self.stats.counters.macaddr, diff --git a/src/lib/ipc/shmem/iftable_mib.lua b/src/lib/ipc/shmem/iftable_mib.lua index 8d96d29e67..c03f98c29a 100644 --- a/src/lib/ipc/shmem/iftable_mib.lua +++ b/src/lib/ipc/shmem/iftable_mib.lua @@ -30,8 +30,13 @@ function init_snmp (name, counters, directory, interval) ifTable:register('ifSpeed', 'Gauge32') ifTable:register('ifHighSpeed', 'Gauge32') if counters.speed then - ifTable:set('ifSpeed', counter.read(counters.speed)) - ifTable:set('ifHighSpeed', counter.read(counters.speed) / 1000) + speed = counters.read(counters.speed) + if speed > 1000000000 then + ifTable:set('ifSpeed', 4294967295) -- RFC3635 sec. 3.2.8 + else + ifTable:set('ifSpeed', speed) + end + ifTable:set('ifHighSpeed', speed / 1000000) end ifTable:register('ifPhysAddress', { type = 'OctetStr', length = 6 }) if counters.macaddr then From 905bf8dd6b12f2347780664c9ea5a83fff7a69c1 Mon Sep 17 00:00:00 2001 From: Max Rottenkolber Date: Fri, 8 Jul 2016 16:23:24 +0200 Subject: [PATCH 2/2] vhost/vhost_user: avoid callbacks. --- src/apps/vhost/vhost_user.lua | 21 --------------------- src/lib/virtio/net_device.lua | 25 +++++++++++++++++++++---- 2 files changed, 21 insertions(+), 25 deletions(-) diff --git a/src/apps/vhost/vhost_user.lua b/src/apps/vhost/vhost_user.lua index 0bc822bcae..b81a974404 100644 --- a/src/apps/vhost/vhost_user.lua +++ b/src/apps/vhost/vhost_user.lua @@ -15,7 +15,6 @@ local main = require("core.main") local memory = require("core.memory") local counter = require("core.counter") local pci = require("lib.hardware.pci") -local ethernet = require("lib.protocol.ethernet") local net_device= require("lib.virtio.net_device") local timer = require("core.timer") local ffi = require("ffi") @@ -104,26 +103,6 @@ function VhostUser:push () end end -function VhostUser:tx_callback (p) - counter.add(self.counters.txbytes, packet.length(p)) - counter.add(self.counters.txpackets) - if ethernet:is_mcast(packet.data(p)) then - counter.add(self.counters.txmcast) - end -end - -function VhostUser:rx_callback (p) - counter.add(self.counters.rxbytes, packet.length(p)) - counter.add(self.counters.rxpackets) - if ethernet:is_mcast(packet.data(p)) then - counter.add(self.counters.rxmcast) - end -end - -function VhostUser:rxdrop_callback (p) - counter.add(self.counters.rxdrop) -end - -- Try to connect to QEMU. function VhostUser:client_connect () return C.vhost_user_connect(self.socket_path) diff --git a/src/lib/virtio/net_device.lua b/src/lib/virtio/net_device.lua index e01ac7f86b..cb9fca2863 100644 --- a/src/lib/virtio/net_device.lua +++ b/src/lib/virtio/net_device.lua @@ -10,6 +10,8 @@ local link = require("core.link") local memory = require("core.memory") local packet = require("core.packet") local timer = require("core.timer") +local counter = require("core.counter") +local ethernet = require("lib.protocol.ethernet") local vq = require("lib.virtio.virtq_device") local checksum = require("lib.checksum") local ffi = require("ffi") @@ -151,6 +153,7 @@ end function VirtioNetDevice:rx_packet_end(header_id, total_size, rx_p) local l = self.owner.output.tx + local counters = self.owner.counters if l then if band(self.rx_hdr_flags, C.VIO_NET_HDR_F_NEEDS_CSUM) ~= 0 and -- Bounds-check the checksum area @@ -162,11 +165,15 @@ function VirtioNetDevice:rx_packet_end(header_id, total_size, rx_p) rx_p.length - self.rx_hdr_csum_start, self.rx_hdr_csum_offset) end - self.owner:rx_callback(rx_p) + counter.add(counters.rxbytes, rx_p.length) + counter.add(counters.rxpackets) + if ethernet:is_mcast(rx_p.data) then + counter.add(counters.rxmcast) + end link.transmit(l, rx_p) else debug("droprx", "len", rx_p.length) - self.owner:rxdrop_callback(rx_p) + counter.add(counters.rxdrop) packet.free(rx_p) end self.virtq[self.ring_id]:put_buffer(header_id, total_size) @@ -254,7 +261,12 @@ function VirtioNetDevice:tx_buffer_add(tx_p, addr, len) end function VirtioNetDevice:tx_packet_end(header_id, total_size, tx_p) - self.owner:tx_callback(tx_p) + local counters = self.owner.counters + counter.add(counters.txbytes, tx_p.length) + counter.add(counters.txpackets) + if ethernet:is_mcast(tx_p.data) then + counter.add(counters.txmcast) + end packet.free(tx_p) self.virtq[self.ring_id]:put_buffer(header_id, total_size) end @@ -313,9 +325,14 @@ function VirtioNetDevice:tx_buffer_add_mrg_rxbuf(tx_p, addr, len) end function VirtioNetDevice:tx_packet_end_mrg_rxbuf(header_id, total_size, tx_p) + local counters = self.owner.counters -- free the packet only when all its data is processed if self.tx.finished then - self.owner:tx_callback(tx_p) + counter.add(counters.txbytes, tx_p.length) + counter.add(counters.txpackets) + if ethernet:is_mcast(tx_p.data) then + counter.add(counters.txmcast) + end packet.free(tx_p) self.tx.p = nil self.tx.data_sent = nil