Fixing docs and tests
This commit is contained in:
parent
b9ba375ca2
commit
d2dea7a42c
3 changed files with 43 additions and 118 deletions
103
README.md
103
README.md
|
|
@ -33,95 +33,40 @@ of the SPI implementation. It must be set up to work as the W5500 chip requires
|
|||
use embedded_nal::{IpAddr, Ipv4Addr, SocketAddr};
|
||||
#
|
||||
# struct Mock;
|
||||
#
|
||||
# impl embedded_hal::blocking::spi::Transfer<u8> for Mock {
|
||||
# type Error = ();
|
||||
#
|
||||
# fn transfer<'w>(&mut self, words: &'w mut [u8]) -> Result<&'w [u8], Self::Error> {
|
||||
# words[0] = 0x04;
|
||||
# Ok(words)
|
||||
# }
|
||||
#
|
||||
# impl embedded_hal::spi::ErrorType for Mock {
|
||||
# type Error = core::convert::Infallible;
|
||||
# }
|
||||
#
|
||||
# impl embedded_hal::spi::FullDuplex<u8> for Mock {
|
||||
# type Error = ();
|
||||
#
|
||||
# fn read(&mut self) -> nb::Result<u8, Self::Error> {
|
||||
# Ok(0)
|
||||
# }
|
||||
#
|
||||
# fn send(&mut self, word: u8) -> nb::Result<(), Self::Error> {
|
||||
# Ok(())
|
||||
# }
|
||||
# }
|
||||
#
|
||||
# impl embedded_hal::blocking::spi::Write<u8> for Mock {
|
||||
# type Error = ();
|
||||
#
|
||||
# fn write(&mut self, words: &[u8]) -> Result<(), Self::Error> {
|
||||
# Ok(())
|
||||
# }
|
||||
# }
|
||||
#
|
||||
# impl embedded_hal::digital::v2::OutputPin for Mock {
|
||||
# type Error = ();
|
||||
#
|
||||
# fn set_low(&mut self) -> Result<(), Self::Error> {
|
||||
# Ok(())
|
||||
# }
|
||||
#
|
||||
# fn set_high(&mut self) -> Result<(), Self::Error> {
|
||||
#
|
||||
# impl embedded_hal::spi::SpiDevice for Mock {
|
||||
# fn transaction(&mut self, operations: &mut [embedded_hal::spi::Operation<'_, u8>]) -> Result<(), Self::Error> {
|
||||
# Ok(())
|
||||
# }
|
||||
# }
|
||||
use embedded_nal::UdpClientStack;
|
||||
|
||||
{
|
||||
use embedded_nal::UdpClientStack;
|
||||
let mut spi = Mock;
|
||||
|
||||
let mut spi = Mock;
|
||||
let mut cs = Mock;
|
||||
let mut device = w5500::UninitializedDevice::new(w5500::bus::FourWire::new(spi))
|
||||
.initialize_manual(
|
||||
w5500::MacAddress::new(0, 1, 2, 3, 4, 5),
|
||||
Ipv4Addr::new(192, 168, 86, 79),
|
||||
w5500::Mode::default()
|
||||
).unwrap();
|
||||
|
||||
let mut device = w5500::UninitializedDevice::new(w5500::bus::FourWire::new(spi, cs))
|
||||
.initialize_manual(
|
||||
w5500::MacAddress::new(0, 1, 2, 3, 4, 5),
|
||||
Ipv4Addr::new(192, 168, 86, 79),
|
||||
w5500::Mode::default()
|
||||
).unwrap();
|
||||
// Allocate a UDP socket to send data with
|
||||
let mut socket = device.socket().unwrap();
|
||||
|
||||
// Allocate a UDP socket to send data with
|
||||
let mut socket = device.socket().unwrap();
|
||||
// Connect the socket to the IP address and port we want to send to.
|
||||
device.connect(&mut socket,
|
||||
SocketAddr::new(IpAddr::V4(Ipv4Addr::new(192, 168, 86, 38)), 8000),
|
||||
).unwrap();
|
||||
|
||||
// Connect the socket to the IP address and port we want to send to.
|
||||
device.connect(&mut socket,
|
||||
SocketAddr::new(IpAddr::V4(Ipv4Addr::new(192, 168, 86, 38)), 8000),
|
||||
).unwrap();
|
||||
// Send the data
|
||||
nb::block!(device.send(&mut socket, &[104, 101, 108, 108, 111, 10]));
|
||||
|
||||
// Send the data
|
||||
nb::block!(device.send(&mut socket, &[104, 101, 108, 108, 111, 10]));
|
||||
|
||||
// Optionally close the socket and deactivate the device
|
||||
device.close(socket);
|
||||
let (spi_bus, inactive_device) = device.deactivate();
|
||||
}
|
||||
|
||||
// Alternatively, you can use the W5500 where a SPI bus is shared between drivers:
|
||||
{
|
||||
use embedded_nal::TcpClientStack;
|
||||
|
||||
let mut spi = Mock;
|
||||
let mut cs = Mock;
|
||||
|
||||
let mut device: Option<w5500::InactiveDevice<w5500::Manual>> = None; // maybe: previously initialized device
|
||||
let mut socket: Option<w5500::tcp::TcpSocket> = None; // maybe: previously opened socket
|
||||
|
||||
if let (Some(socket), Some(device)) = (socket.as_mut(), device.as_mut()) {
|
||||
let mut buffer = [0u8; 1024];
|
||||
let mut active = device.activate_ref(w5500::bus::FourWireRef::new(&mut spi, &mut cs));
|
||||
|
||||
// Read from the device.
|
||||
active.receive(socket, &mut buffer).unwrap();
|
||||
}
|
||||
}
|
||||
// Optionally close the socket
|
||||
device.close(socket);
|
||||
```
|
||||
## Todo
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue