2018-05-29 10:18:12 -07:00
|
|
|
//! The `fetch_stage` batches input from a UDP socket and sends it to a channel.
|
|
|
|
|
2018-06-27 11:33:56 -07:00
|
|
|
use packet::PacketRecycler;
|
2018-07-03 21:14:08 -07:00
|
|
|
use service::Service;
|
2018-05-29 10:18:12 -07:00
|
|
|
use std::net::UdpSocket;
|
2018-07-09 13:53:18 -07:00
|
|
|
use std::sync::atomic::{AtomicBool, Ordering};
|
2018-05-29 10:18:12 -07:00
|
|
|
use std::sync::mpsc::channel;
|
2018-05-29 20:20:28 -07:00
|
|
|
use std::sync::Arc;
|
2018-07-03 21:14:08 -07:00
|
|
|
use std::thread::{self, JoinHandle};
|
2018-06-27 11:33:56 -07:00
|
|
|
use streamer::{self, PacketReceiver};
|
2018-05-29 10:18:12 -07:00
|
|
|
|
|
|
|
pub struct FetchStage {
|
2018-07-09 13:53:18 -07:00
|
|
|
exit: Arc<AtomicBool>,
|
2018-07-03 21:14:08 -07:00
|
|
|
thread_hdls: Vec<JoinHandle<()>>,
|
2018-05-29 10:18:12 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
impl FetchStage {
|
2018-07-02 14:45:16 -07:00
|
|
|
pub fn new(
|
2018-08-28 16:32:40 -07:00
|
|
|
socket: Arc<UdpSocket>,
|
2018-07-02 14:45:16 -07:00
|
|
|
exit: Arc<AtomicBool>,
|
2018-08-28 16:32:40 -07:00
|
|
|
recycler: &PacketRecycler,
|
2018-07-02 14:45:16 -07:00
|
|
|
) -> (Self, PacketReceiver) {
|
2018-08-28 16:32:40 -07:00
|
|
|
Self::new_multi_socket(vec![socket], exit, recycler)
|
2018-06-13 21:52:23 -07:00
|
|
|
}
|
|
|
|
pub fn new_multi_socket(
|
2018-08-28 16:32:40 -07:00
|
|
|
sockets: Vec<Arc<UdpSocket>>,
|
2018-06-13 21:52:23 -07:00
|
|
|
exit: Arc<AtomicBool>,
|
2018-08-28 16:32:40 -07:00
|
|
|
recycler: &PacketRecycler,
|
2018-07-02 14:45:16 -07:00
|
|
|
) -> (Self, PacketReceiver) {
|
2018-08-28 16:32:40 -07:00
|
|
|
let (sender, receiver) = channel();
|
2018-06-13 21:52:23 -07:00
|
|
|
let thread_hdls: Vec<_> = sockets
|
|
|
|
.into_iter()
|
|
|
|
.map(|socket| {
|
2018-08-28 16:32:40 -07:00
|
|
|
streamer::receiver(socket, exit.clone(), recycler.clone(), sender.clone())
|
2018-06-13 21:52:23 -07:00
|
|
|
})
|
|
|
|
.collect();
|
2018-05-29 10:18:12 -07:00
|
|
|
|
2018-08-28 16:32:40 -07:00
|
|
|
(FetchStage { exit, thread_hdls }, receiver)
|
2018-07-09 13:53:18 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
pub fn close(&self) {
|
|
|
|
self.exit.store(true, Ordering::Relaxed);
|
2018-05-29 10:18:12 -07:00
|
|
|
}
|
|
|
|
}
|
2018-07-03 21:14:08 -07:00
|
|
|
|
|
|
|
impl Service for FetchStage {
|
|
|
|
fn thread_hdls(self) -> Vec<JoinHandle<()>> {
|
|
|
|
self.thread_hdls
|
|
|
|
}
|
|
|
|
|
|
|
|
fn join(self) -> thread::Result<()> {
|
|
|
|
for thread_hdl in self.thread_hdls() {
|
|
|
|
thread_hdl.join()?;
|
|
|
|
}
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
}
|