Convert to cargo workspace with lib/ and cli/ crates. Add Nix flake for building and development. Extract handle_urb_loop and add read_urb_command to the library for CLI consumption. Implement the usbip-rs CLI binary with clap subcommands: - client listen: accept incoming connections via vhci_hcd sysfs - host connect: passthrough real USB devices via nusb - test_hid connect: export a simulated HID keyboard for testing Add vsock transport layer and vhci_hcd sysfs interaction module. Apply rustfmt formatting project-wide and add rustfmt/clippy to devShell. Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
36 lines
1.1 KiB
Rust
36 lines
1.1 KiB
Rust
use log::*;
|
|
use std::net::*;
|
|
use std::sync::{Arc, Mutex};
|
|
use std::time::Duration;
|
|
|
|
#[tokio::main]
|
|
async fn main() {
|
|
env_logger::init();
|
|
let handler = Arc::new(Mutex::new(Box::new(usbip_rs::cdc::UsbCdcAcmHandler::new())
|
|
as Box<dyn usbip_rs::UsbInterfaceHandler + Send>));
|
|
let server = Arc::new(usbip_rs::UsbIpServer::new_simulated(vec![
|
|
usbip_rs::UsbDevice::new(0).with_interface(
|
|
usbip_rs::ClassCode::CDC as u8,
|
|
usbip_rs::cdc::CDC_ACM_SUBCLASS,
|
|
0x00,
|
|
Some("Test CDC ACM"),
|
|
usbip_rs::cdc::UsbCdcAcmHandler::endpoints(),
|
|
handler.clone(),
|
|
),
|
|
]));
|
|
let addr = SocketAddr::new(IpAddr::V4(Ipv4Addr::new(0, 0, 0, 0)), 3240);
|
|
tokio::spawn(usbip_rs::server(addr, server));
|
|
|
|
loop {
|
|
// sleep 1s
|
|
tokio::time::sleep(Duration::new(1, 0)).await;
|
|
let mut handler = handler.lock().unwrap();
|
|
if let Some(acm) = handler
|
|
.as_any()
|
|
.downcast_mut::<usbip_rs::cdc::UsbCdcAcmHandler>()
|
|
{
|
|
acm.tx_buffer.push(b'a');
|
|
info!("Simulate a char input");
|
|
}
|
|
}
|
|
}
|