asterinas/kernel/comps/network/src/driver.rs

63 lines
1.4 KiB
Rust
Raw Normal View History

2024-01-03 03:22:36 +00:00
// SPDX-License-Identifier: MPL-2.0
2023-05-30 08:34:28 +00:00
use alloc::vec;
2023-08-28 07:03:28 +00:00
use smoltcp::{phy, time::Instant};
2023-05-30 08:34:28 +00:00
2023-08-28 07:03:28 +00:00
use crate::{
2023-05-30 08:34:28 +00:00
buffer::{RxBuffer, TxBuffer},
2023-11-20 12:37:51 +00:00
AnyNetworkDevice,
2023-05-30 08:34:28 +00:00
};
2023-11-20 12:37:51 +00:00
impl phy::Device for dyn AnyNetworkDevice {
2023-05-30 08:34:28 +00:00
type RxToken<'a> = RxToken;
type TxToken<'a> = TxToken<'a>;
2023-08-28 07:03:28 +00:00
fn receive(&mut self, _timestamp: Instant) -> Option<(Self::RxToken<'_>, Self::TxToken<'_>)> {
2023-05-30 08:34:28 +00:00
if self.can_receive() {
2023-08-28 07:03:28 +00:00
let rx_buffer = self.receive().unwrap();
Some((RxToken(rx_buffer), TxToken(self)))
2023-05-30 08:34:28 +00:00
} else {
None
}
}
2023-08-28 07:03:28 +00:00
fn transmit(&mut self, _timestamp: Instant) -> Option<Self::TxToken<'_>> {
2023-05-30 08:34:28 +00:00
if self.can_send() {
2023-08-28 07:03:28 +00:00
Some(TxToken(self))
2023-05-30 08:34:28 +00:00
} else {
None
}
}
fn capabilities(&self) -> phy::DeviceCapabilities {
2023-08-28 07:03:28 +00:00
self.capabilities()
2023-05-30 08:34:28 +00:00
}
}
pub struct RxToken(RxBuffer);
impl phy::RxToken for RxToken {
fn consume<R, F>(mut self, f: F) -> R
where
F: FnOnce(&mut [u8]) -> R,
{
let packet_but = self.0.packet_mut();
2023-09-04 03:04:42 +00:00
f(packet_but)
2023-05-30 08:34:28 +00:00
}
}
2023-11-20 12:37:51 +00:00
pub struct TxToken<'a>(&'a mut dyn AnyNetworkDevice);
2023-05-30 08:34:28 +00:00
impl<'a> phy::TxToken for TxToken<'a> {
fn consume<R, F>(self, len: usize, f: F) -> R
where
F: FnOnce(&mut [u8]) -> R,
{
let mut buffer = vec![0u8; len];
let res = f(&mut buffer);
let tx_buffer = TxBuffer::new(&buffer);
self.0.send(tx_buffer).expect("Send packet failed");
res
}
}