Fix clippy warnings

Seems clippy is not linting any of the benches.
This commit is contained in:
Greg Fitzgerald 2018-07-20 13:09:26 -04:00
parent 7193bf28b6
commit 69688a18c7
1 changed files with 17 additions and 20 deletions

View File

@ -4,20 +4,20 @@ use solana::packet::{Packet, PacketRecycler, BLOB_SIZE, PACKET_DATA_SIZE};
use solana::result::Result; use solana::result::Result;
use solana::streamer::{receiver, PacketReceiver}; use solana::streamer::{receiver, PacketReceiver};
use std::net::{SocketAddr, UdpSocket}; use std::net::{SocketAddr, UdpSocket};
use std::sync::atomic::{AtomicBool, Ordering}; use std::sync::atomic::{AtomicBool, AtomicUsize, Ordering};
use std::sync::mpsc::channel; use std::sync::mpsc::channel;
use std::sync::{Arc, Mutex}; use std::sync::Arc;
use std::thread::sleep; use std::thread::sleep;
use std::thread::{spawn, JoinHandle}; use std::thread::{spawn, JoinHandle};
use std::time::Duration; use std::time::Duration;
use std::time::SystemTime; use std::time::SystemTime;
fn producer(addr: &SocketAddr, recycler: PacketRecycler, exit: Arc<AtomicBool>) -> JoinHandle<()> { fn producer(addr: &SocketAddr, recycler: &PacketRecycler, exit: Arc<AtomicBool>) -> JoinHandle<()> {
let send = UdpSocket::bind("0.0.0.0:0").unwrap(); let send = UdpSocket::bind("0.0.0.0:0").unwrap();
let msgs = recycler.allocate(); let msgs = recycler.allocate();
let msgs_ = msgs.clone(); let msgs_ = msgs.clone();
msgs.write().unwrap().packets.resize(10, Packet::default()); msgs.write().unwrap().packets.resize(10, Packet::default());
for w in msgs.write().unwrap().packets.iter_mut() { for w in &mut msgs.write().unwrap().packets {
w.meta.size = PACKET_DATA_SIZE; w.meta.size = PACKET_DATA_SIZE;
w.meta.set_addr(&addr); w.meta.set_addr(&addr);
} }
@ -26,7 +26,7 @@ fn producer(addr: &SocketAddr, recycler: PacketRecycler, exit: Arc<AtomicBool>)
return; return;
} }
let mut num = 0; let mut num = 0;
for p in msgs_.read().unwrap().packets.iter() { for p in &msgs_.read().unwrap().packets {
let a = p.meta.addr(); let a = p.meta.addr();
assert!(p.meta.size < BLOB_SIZE); assert!(p.meta.size < BLOB_SIZE);
send.send_to(&p.data[..p.meta.size], &a).unwrap(); send.send_to(&p.data[..p.meta.size], &a).unwrap();
@ -39,7 +39,7 @@ fn producer(addr: &SocketAddr, recycler: PacketRecycler, exit: Arc<AtomicBool>)
fn sink( fn sink(
recycler: PacketRecycler, recycler: PacketRecycler,
exit: Arc<AtomicBool>, exit: Arc<AtomicBool>,
rvs: Arc<Mutex<usize>>, rvs: Arc<AtomicUsize>,
r: PacketReceiver, r: PacketReceiver,
) -> JoinHandle<()> { ) -> JoinHandle<()> {
spawn(move || loop { spawn(move || loop {
@ -47,13 +47,10 @@ fn sink(
return; return;
} }
let timer = Duration::new(1, 0); let timer = Duration::new(1, 0);
match r.recv_timeout(timer) { if let Ok(msgs) = r.recv_timeout(timer) {
Ok(msgs) => { rvs.fetch_add(msgs.read().unwrap().packets.len(), Ordering::Relaxed);
*rvs.lock().unwrap() += msgs.read().unwrap().packets.len();
recycler.recycle(msgs); recycler.recycle(msgs);
} }
_ => (),
}
}) })
} }
@ -67,20 +64,20 @@ fn main() -> Result<()> {
let (s_reader, r_reader) = channel(); let (s_reader, r_reader) = channel();
let t_reader = receiver(read, exit.clone(), pack_recycler.clone(), s_reader); let t_reader = receiver(read, exit.clone(), pack_recycler.clone(), s_reader);
let t_producer1 = producer(&addr, pack_recycler.clone(), exit.clone()); let t_producer1 = producer(&addr, &pack_recycler, exit.clone());
let t_producer2 = producer(&addr, pack_recycler.clone(), exit.clone()); let t_producer2 = producer(&addr, &pack_recycler, exit.clone());
let t_producer3 = producer(&addr, pack_recycler.clone(), exit.clone()); let t_producer3 = producer(&addr, &pack_recycler, exit.clone());
let rvs = Arc::new(Mutex::new(0)); let rvs = Arc::new(AtomicUsize::new(0));
let t_sink = sink(pack_recycler.clone(), exit.clone(), rvs.clone(), r_reader); let t_sink = sink(pack_recycler.clone(), exit.clone(), rvs.clone(), r_reader);
let start = SystemTime::now(); let start = SystemTime::now();
let start_val = *rvs.lock().unwrap(); let start_val = rvs.load(Ordering::Relaxed);
sleep(Duration::new(5, 0)); sleep(Duration::new(5, 0));
let elapsed = start.elapsed().unwrap(); let elapsed = start.elapsed().unwrap();
let end_val = *rvs.lock().unwrap(); let end_val = rvs.load(Ordering::Relaxed);
let time = elapsed.as_secs() * 10000000000 + elapsed.subsec_nanos() as u64; let time = elapsed.as_secs() * 10_000_000_000 + u64::from(elapsed.subsec_nanos());
let ftime = (time as f64) / 10000000000f64; let ftime = (time as f64) / 10_000_000_000_f64;
let fcount = (end_val - start_val) as f64; let fcount = (end_val - start_val) as f64;
println!("performance: {:?}", fcount / ftime); println!("performance: {:?}", fcount / ftime);
exit.store(true, Ordering::Relaxed); exit.store(true, Ordering::Relaxed);