virtio-devices: net: Avoid using vector and direct indexing

With known number of queues and queue events, we can make each of them
more explicit and avoid using vector/direct indexing, which is cleaner
and slightly more efficient.

Signed-off-by: Bo Chen <chen.bo@intel.com>
This commit is contained in:
Bo Chen 2022-10-19 15:09:19 -07:00 committed by Bo Chen
parent a388d76228
commit 38620eaea8

View File

@ -173,8 +173,8 @@ struct NetEpollHandler {
kill_evt: EventFd, kill_evt: EventFd,
pause_evt: EventFd, pause_evt: EventFd,
queue_index_base: u16, queue_index_base: u16,
queue_pair: Vec<Queue>, queue_pair: (Queue, Queue),
queue_evt_pair: Vec<EventFd>, queue_evt_pair: (EventFd, EventFd),
// Always generate interrupts until the driver has signalled to the device. // Always generate interrupts until the driver has signalled to the device.
// This mitigates a problem with interrupts from tap events being "lost" upon // This mitigates a problem with interrupts from tap events being "lost" upon
// a restore as the vCPU thread isn't ready to handle the interrupt. This causes // a restore as the vCPU thread isn't ready to handle the interrupt. This causes
@ -193,7 +193,7 @@ impl NetEpollHandler {
} }
fn handle_rx_event(&mut self) -> result::Result<(), DeviceError> { fn handle_rx_event(&mut self) -> result::Result<(), DeviceError> {
let queue_evt = &self.queue_evt_pair[0]; let queue_evt = &self.queue_evt_pair.0;
if let Err(e) = queue_evt.read() { if let Err(e) = queue_evt.read() {
error!("Failed to get rx queue event: {:?}", e); error!("Failed to get rx queue event: {:?}", e);
} }
@ -224,7 +224,7 @@ impl NetEpollHandler {
fn process_tx(&mut self) -> result::Result<(), DeviceError> { fn process_tx(&mut self) -> result::Result<(), DeviceError> {
if self if self
.net .net
.process_tx(&self.mem.memory(), &mut self.queue_pair[1]) .process_tx(&self.mem.memory(), &mut self.queue_pair.1)
.map_err(DeviceError::NetQueuePair)? .map_err(DeviceError::NetQueuePair)?
|| !self.driver_awake || !self.driver_awake
{ {
@ -253,7 +253,7 @@ impl NetEpollHandler {
fn handle_rx_tap_event(&mut self) -> result::Result<(), DeviceError> { fn handle_rx_tap_event(&mut self) -> result::Result<(), DeviceError> {
if self if self
.net .net
.process_rx(&self.mem.memory(), &mut self.queue_pair[0]) .process_rx(&self.mem.memory(), &mut self.queue_pair.0)
.map_err(DeviceError::NetQueuePair)? .map_err(DeviceError::NetQueuePair)?
|| !self.driver_awake || !self.driver_awake
{ {
@ -271,8 +271,8 @@ impl NetEpollHandler {
paused_sync: Arc<Barrier>, paused_sync: Arc<Barrier>,
) -> result::Result<(), EpollHelperError> { ) -> result::Result<(), EpollHelperError> {
let mut helper = EpollHelper::new(&self.kill_evt, &self.pause_evt)?; let mut helper = EpollHelper::new(&self.kill_evt, &self.pause_evt)?;
helper.add_event(self.queue_evt_pair[0].as_raw_fd(), RX_QUEUE_EVENT)?; helper.add_event(self.queue_evt_pair.0.as_raw_fd(), RX_QUEUE_EVENT)?;
helper.add_event(self.queue_evt_pair[1].as_raw_fd(), TX_QUEUE_EVENT)?; helper.add_event(self.queue_evt_pair.1.as_raw_fd(), TX_QUEUE_EVENT)?;
if let Some(rate_limiter) = &self.net.rx_rate_limiter { if let Some(rate_limiter) = &self.net.rx_rate_limiter {
helper.add_event(rate_limiter.as_raw_fd(), RX_RATE_LIMITER_EVENT)?; helper.add_event(rate_limiter.as_raw_fd(), RX_RATE_LIMITER_EVENT)?;
} }
@ -283,10 +283,14 @@ impl NetEpollHandler {
let mem = self.mem.memory(); let mem = self.mem.memory();
// If there are some already available descriptors on the RX queue, // If there are some already available descriptors on the RX queue,
// then we can start the thread while listening onto the TAP. // then we can start the thread while listening onto the TAP.
if self.queue_pair[0] if self
.queue_pair
.0
.used_idx(mem.deref(), Ordering::Acquire) .used_idx(mem.deref(), Ordering::Acquire)
.map_err(EpollHelperError::QueueRingIndex)? .map_err(EpollHelperError::QueueRingIndex)?
< self.queue_pair[0] < self
.queue_pair
.0
.avail_idx(mem.deref(), Ordering::Acquire) .avail_idx(mem.deref(), Ordering::Acquire)
.map_err(EpollHelperError::QueueRingIndex)? .map_err(EpollHelperError::QueueRingIndex)?
{ {
@ -319,7 +323,7 @@ impl EpollHelperHandler for NetEpollHandler {
})?; })?;
} }
TX_QUEUE_EVENT => { TX_QUEUE_EVENT => {
let queue_evt = &self.queue_evt_pair[1]; let queue_evt = &self.queue_evt_pair.1;
if let Err(e) = queue_evt.read() { if let Err(e) = queue_evt.read() {
error!("Failed to get tx queue event: {:?}", e); error!("Failed to get tx queue event: {:?}", e);
} }
@ -686,11 +690,11 @@ impl VirtioDevice for Net {
let (_, queue_0, queue_evt_0) = queues.remove(0); let (_, queue_0, queue_evt_0) = queues.remove(0);
let (_, queue_1, queue_evt_1) = queues.remove(0); let (_, queue_1, queue_evt_1) = queues.remove(0);
let mut queue_pair = vec![queue_0, queue_1]; let mut queue_pair = (queue_0, queue_1);
queue_pair[0].set_event_idx(event_idx); queue_pair.0.set_event_idx(event_idx);
queue_pair[1].set_event_idx(event_idx); queue_pair.1.set_event_idx(event_idx);
let queue_evt_pair = vec![queue_evt_0, queue_evt_1]; let queue_evt_pair = (queue_evt_0, queue_evt_1);
let (kill_evt, pause_evt) = self.common.dup_eventfds(); let (kill_evt, pause_evt) = self.common.dup_eventfds();