net-wiznet: rename from embassy-net-w5500.
This commit is contained in:
		
							parent
							
								
									1d4b941d52
								
							
						
					
					
						commit
						11b66a73b4
					
				
							
								
								
									
										2
									
								
								.github/ci/doc.sh
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/ci/doc.sh
									
									
									
									
										vendored
									
									
								
							| @ -35,7 +35,7 @@ docserver-builder -i ./embassy-usb-driver -o webroot/crates/embassy-usb-driver/g | |||||||
| docserver-builder -i ./embassy-usb-logger -o webroot/crates/embassy-usb-logger/git.zup | docserver-builder -i ./embassy-usb-logger -o webroot/crates/embassy-usb-logger/git.zup | ||||||
| docserver-builder -i ./cyw43 -o webroot/crates/cyw43/git.zup | docserver-builder -i ./cyw43 -o webroot/crates/cyw43/git.zup | ||||||
| docserver-builder -i ./cyw43-pio -o webroot/crates/cyw43-pio/git.zup | docserver-builder -i ./cyw43-pio -o webroot/crates/cyw43-pio/git.zup | ||||||
| docserver-builder -i ./embassy-net-w5500 -o webroot/crates/embassy-net-w5500/git.zup | docserver-builder -i ./embassy-net-wiznet -o webroot/crates/embassy-net-wiznet/git.zup | ||||||
| docserver-builder -i ./embassy-net-enc28j60 -o webroot/crates/embassy-net-enc28j60/git.zup | docserver-builder -i ./embassy-net-enc28j60 -o webroot/crates/embassy-net-enc28j60/git.zup | ||||||
| docserver-builder -i ./embassy-net-esp-hosted -o webroot/crates/embassy-net-esp-hosted/git.zup | docserver-builder -i ./embassy-net-esp-hosted -o webroot/crates/embassy-net-esp-hosted/git.zup | ||||||
| docserver-builder -i ./embassy-stm32-wpan -o webroot/crates/embassy-stm32-wpan/git.zup --output-static webroot/static | docserver-builder -i ./embassy-stm32-wpan -o webroot/crates/embassy-stm32-wpan/git.zup --output-static webroot/static | ||||||
|  | |||||||
| @ -76,7 +76,7 @@ These `embassy-net` drivers are implemented using this crate. You can look at th | |||||||
| 
 | 
 | ||||||
| - [`cyw43`](https://github.com/embassy-rs/embassy/tree/main/cyw43) for WiFi on CYW43xx chips, used in the Raspberry Pi Pico W | - [`cyw43`](https://github.com/embassy-rs/embassy/tree/main/cyw43) for WiFi on CYW43xx chips, used in the Raspberry Pi Pico W | ||||||
| - [`embassy-usb`](https://github.com/embassy-rs/embassy/tree/main/embassy-usb) for Ethernet-over-USB (CDC NCM) support. | - [`embassy-usb`](https://github.com/embassy-rs/embassy/tree/main/embassy-usb) for Ethernet-over-USB (CDC NCM) support. | ||||||
| - [`embassy-net-w5500`](https://github.com/embassy-rs/embassy/tree/main/embassy-net-w5500) for Wiznet W5500 SPI Ethernet MAC+PHY chip. | - [`embassy-net-wiznet`](https://github.com/embassy-rs/embassy/tree/main/embassy-net-wiznet) for Wiznet SPI Ethernet MAC+PHY chips. | ||||||
| - [`embassy-net-esp-hosted`](https://github.com/embassy-rs/embassy/tree/main/embassy-net-esp-hosted) for using ESP32 chips with the [`esp-hosted`](https://github.com/espressif/esp-hosted) firmware as WiFi adapters for another non-ESP32 MCU. | - [`embassy-net-esp-hosted`](https://github.com/embassy-rs/embassy/tree/main/embassy-net-esp-hosted) for using ESP32 chips with the [`esp-hosted`](https://github.com/espressif/esp-hosted) firmware as WiFi adapters for another non-ESP32 MCU. | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -1,7 +0,0 @@ | |||||||
| # WIZnet W5500 `embassy-net` integration |  | ||||||
| 
 |  | ||||||
| [`embassy-net`](https://crates.io/crates/embassy-net) integration for the WIZnet W5500 SPI ethernet chip, operating in MACRAW mode. |  | ||||||
| 
 |  | ||||||
| Supports any SPI driver implementing [`embedded-hal-async`](https://crates.io/crates/embedded-hal-async) |  | ||||||
| 
 |  | ||||||
| See [`examples`](https://github.com/kalkyl/embassy-net-w5500/tree/main/examples) directory for usage examples with the rp2040 [`WIZnet W5500-EVB-Pico`](https://www.wiznet.io/product-item/w5500-evb-pico/) module. |  | ||||||
| @ -1,8 +1,8 @@ | |||||||
| [package] | [package] | ||||||
| name = "embassy-net-w5500" | name = "embassy-net-wiznet" | ||||||
| version = "0.1.0" | version = "0.1.0" | ||||||
| description = "embassy-net driver for the W5500 ethernet chip" | description = "embassy-net driver for WIZnet SPI Ethernet chips" | ||||||
| keywords = ["embedded", "w5500", "embassy-net", "embedded-hal-async", "ethernet", "async"] | keywords = ["embedded", "wiznet", "embassy-net", "embedded-hal-async", "ethernet", "async"] | ||||||
| categories = ["embedded", "hardware-support", "no-std", "network-programming", "async"] | categories = ["embedded", "hardware-support", "no-std", "network-programming", "async"] | ||||||
| license = "MIT OR Apache-2.0" | license = "MIT OR Apache-2.0" | ||||||
| edition = "2021" | edition = "2021" | ||||||
| @ -16,7 +16,7 @@ embassy-futures = { version = "0.1.0", path = "../embassy-futures" } | |||||||
| defmt = { version = "0.3", optional = true } | defmt = { version = "0.3", optional = true } | ||||||
| 
 | 
 | ||||||
| [package.metadata.embassy_docs] | [package.metadata.embassy_docs] | ||||||
| src_base = "https://github.com/embassy-rs/embassy/blob/embassy-net-w5500-v$VERSION/embassy-net-w5500/src/" | src_base = "https://github.com/embassy-rs/embassy/blob/embassy-net-wiznet-v$VERSION/embassy-net-wiznet/src/" | ||||||
| src_base_git = "https://github.com/embassy-rs/embassy/blob/$COMMIT/embassy-net-w5500/src/" | src_base_git = "https://github.com/embassy-rs/embassy/blob/$COMMIT/embassy-net-wiznet/src/" | ||||||
| target = "thumbv7em-none-eabi" | target = "thumbv7em-none-eabi" | ||||||
| features = ["defmt"] | features = ["defmt"] | ||||||
							
								
								
									
										27
									
								
								embassy-net-wiznet/README.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										27
									
								
								embassy-net-wiznet/README.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,27 @@ | |||||||
|  | # WIZnet `embassy-net` integration | ||||||
|  | 
 | ||||||
|  | [`embassy-net`](https://crates.io/crates/embassy-net) integration for the WIZnet SPI ethernet chips, operating in MACRAW mode. | ||||||
|  | 
 | ||||||
|  | See [`examples`](https://github.com/embassy-rs/embassy/tree/main/examples/rp) directory for usage examples with the rp2040 [`WIZnet W5500-EVB-Pico`](https://www.wiznet.io/product-item/w5500-evb-pico/) module. | ||||||
|  | 
 | ||||||
|  | ## Supported chips | ||||||
|  | 
 | ||||||
|  | - W5500 | ||||||
|  | - W5100S | ||||||
|  | 
 | ||||||
|  | ## Interoperability | ||||||
|  | 
 | ||||||
|  | This crate can run on any executor. | ||||||
|  | 
 | ||||||
|  | It supports any SPI driver implementing [`embedded-hal-async`](https://crates.io/crates/embedded-hal-async). | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | ## License | ||||||
|  | 
 | ||||||
|  | This work is licensed under either of | ||||||
|  | 
 | ||||||
|  | - Apache License, Version 2.0 ([LICENSE-APACHE](LICENSE-APACHE) or | ||||||
|  |   http://www.apache.org/licenses/LICENSE-2.0) | ||||||
|  | - MIT license ([LICENSE-MIT](LICENSE-MIT) or http://opensource.org/licenses/MIT) | ||||||
|  | 
 | ||||||
|  | at your option. | ||||||
| @ -16,7 +16,7 @@ enum Interrupt { | |||||||
|     Receive = 0b00100_u8, |     Receive = 0b00100_u8, | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| /// W5500 in MACRAW mode
 | /// Wiznet chip in MACRAW mode
 | ||||||
| #[derive(Debug)] | #[derive(Debug)] | ||||||
| #[cfg_attr(feature = "defmt", derive(defmt::Format))] | #[cfg_attr(feature = "defmt", derive(defmt::Format))] | ||||||
| pub(crate) struct WiznetDevice<C, SPI> { | pub(crate) struct WiznetDevice<C, SPI> { | ||||||
| @ -25,7 +25,7 @@ pub(crate) struct WiznetDevice<C, SPI> { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| impl<C: Chip, SPI: SpiDevice> WiznetDevice<C, SPI> { | impl<C: Chip, SPI: SpiDevice> WiznetDevice<C, SPI> { | ||||||
|     /// Create and initialize the W5500 driver
 |     /// Create and initialize the driver
 | ||||||
|     pub async fn new(spi: SPI, mac_addr: [u8; 6]) -> Result<Self, SPI::Error> { |     pub async fn new(spi: SPI, mac_addr: [u8; 6]) -> Result<Self, SPI::Error> { | ||||||
|         let mut this = Self { |         let mut this = Self { | ||||||
|             spi, |             spi, | ||||||
| @ -22,7 +22,7 @@ unimplemented features of the network protocols. | |||||||
| - [`cyw43`](https://github.com/embassy-rs/embassy/tree/main/cyw43) for WiFi on CYW43xx chips, used in the Raspberry Pi Pico W | - [`cyw43`](https://github.com/embassy-rs/embassy/tree/main/cyw43) for WiFi on CYW43xx chips, used in the Raspberry Pi Pico W | ||||||
| - [`embassy-usb`](https://github.com/embassy-rs/embassy/tree/main/embassy-usb) for Ethernet-over-USB (CDC NCM) support. | - [`embassy-usb`](https://github.com/embassy-rs/embassy/tree/main/embassy-usb) for Ethernet-over-USB (CDC NCM) support. | ||||||
| - [`embassy-stm32`](https://github.com/embassy-rs/embassy/tree/main/embassy-stm32) for the builtin Ethernet MAC in all STM32 chips (STM32F1, STM32F2, STM32F4, STM32F7, STM32H7, STM32H5). | - [`embassy-stm32`](https://github.com/embassy-rs/embassy/tree/main/embassy-stm32) for the builtin Ethernet MAC in all STM32 chips (STM32F1, STM32F2, STM32F4, STM32F7, STM32H7, STM32H5). | ||||||
| - [`embassy-net-w5500`](https://github.com/embassy-rs/embassy/tree/main/embassy-net-w5500) for Wiznet W5500 SPI Ethernet MAC+PHY chip. | - [`embassy-net-wiznet`](https://github.com/embassy-rs/embassy/tree/main/embassy-net-wiznet) for Wiznet SPI Ethernet MAC+PHY chips (W5100S, W5500) | ||||||
| - [`embassy-net-esp-hosted`](https://github.com/embassy-rs/embassy/tree/main/embassy-net-esp-hosted) for using ESP32 chips with the [`esp-hosted`](https://github.com/espressif/esp-hosted) firmware as WiFi adapters for another non-ESP32 MCU. | - [`embassy-net-esp-hosted`](https://github.com/embassy-rs/embassy/tree/main/embassy-net-esp-hosted) for using ESP32 chips with the [`esp-hosted`](https://github.com/espressif/esp-hosted) firmware as WiFi adapters for another non-ESP32 MCU. | ||||||
| 
 | 
 | ||||||
| ## Examples | ## Examples | ||||||
|  | |||||||
| @ -13,7 +13,7 @@ embassy-time = { version = "0.1.2", path = "../../embassy-time", features = ["ni | |||||||
| embassy-rp = { version = "0.1.0", path = "../../embassy-rp", features = ["defmt", "unstable-traits", "nightly", "unstable-pac", "time-driver", "critical-section-impl"] } | embassy-rp = { version = "0.1.0", path = "../../embassy-rp", features = ["defmt", "unstable-traits", "nightly", "unstable-pac", "time-driver", "critical-section-impl"] } | ||||||
| embassy-usb = { version = "0.1.0", path = "../../embassy-usb", features = ["defmt"] } | embassy-usb = { version = "0.1.0", path = "../../embassy-usb", features = ["defmt"] } | ||||||
| embassy-net = { version = "0.1.0", path = "../../embassy-net", features = ["defmt", "nightly", "tcp", "udp", "dhcpv4", "medium-ethernet"] } | embassy-net = { version = "0.1.0", path = "../../embassy-net", features = ["defmt", "nightly", "tcp", "udp", "dhcpv4", "medium-ethernet"] } | ||||||
| embassy-net-w5500 = { version = "0.1.0", path = "../../embassy-net-w5500", features = ["defmt"] } | embassy-net-wiznet = { version = "0.1.0", path = "../../embassy-net-wiznet", features = ["defmt"] } | ||||||
| embassy-futures = { version = "0.1.0", path = "../../embassy-futures" } | embassy-futures = { version = "0.1.0", path = "../../embassy-futures" } | ||||||
| embassy-usb-logger = { version = "0.1.0", path = "../../embassy-usb-logger" } | embassy-usb-logger = { version = "0.1.0", path = "../../embassy-usb-logger" } | ||||||
| embassy-lora = { version = "0.1.0", path = "../../embassy-lora", features = ["time", "defmt"] } | embassy-lora = { version = "0.1.0", path = "../../embassy-lora", features = ["time", "defmt"] } | ||||||
|  | |||||||
| @ -10,8 +10,8 @@ use defmt::*; | |||||||
| use embassy_executor::Spawner; | use embassy_executor::Spawner; | ||||||
| use embassy_futures::yield_now; | use embassy_futures::yield_now; | ||||||
| use embassy_net::{Stack, StackResources}; | use embassy_net::{Stack, StackResources}; | ||||||
| use embassy_net_w5500::chip::W5500; | use embassy_net_wiznet::chip::W5500; | ||||||
| use embassy_net_w5500::*; | use embassy_net_wiznet::*; | ||||||
| use embassy_rp::clocks::RoscRng; | use embassy_rp::clocks::RoscRng; | ||||||
| use embassy_rp::gpio::{Input, Level, Output, Pull}; | use embassy_rp::gpio::{Input, Level, Output, Pull}; | ||||||
| use embassy_rp::peripherals::{PIN_17, PIN_20, PIN_21, SPI0}; | use embassy_rp::peripherals::{PIN_17, PIN_20, PIN_21, SPI0}; | ||||||
| @ -56,7 +56,7 @@ async fn main(spawner: Spawner) { | |||||||
| 
 | 
 | ||||||
|     let mac_addr = [0x02, 0x00, 0x00, 0x00, 0x00, 0x00]; |     let mac_addr = [0x02, 0x00, 0x00, 0x00, 0x00, 0x00]; | ||||||
|     let state = make_static!(State::<8, 8>::new()); |     let state = make_static!(State::<8, 8>::new()); | ||||||
|     let (device, runner) = embassy_net_w5500::new( |     let (device, runner) = embassy_net_wiznet::new( | ||||||
|         mac_addr, |         mac_addr, | ||||||
|         state, |         state, | ||||||
|         ExclusiveDevice::new(spi, cs, Delay), |         ExclusiveDevice::new(spi, cs, Delay), | ||||||
|  | |||||||
| @ -12,8 +12,8 @@ use defmt::*; | |||||||
| use embassy_executor::Spawner; | use embassy_executor::Spawner; | ||||||
| use embassy_futures::yield_now; | use embassy_futures::yield_now; | ||||||
| use embassy_net::{Stack, StackResources}; | use embassy_net::{Stack, StackResources}; | ||||||
| use embassy_net_w5500::chip::W5500; | use embassy_net_wiznet::chip::W5500; | ||||||
| use embassy_net_w5500::*; | use embassy_net_wiznet::*; | ||||||
| use embassy_rp::clocks::RoscRng; | use embassy_rp::clocks::RoscRng; | ||||||
| use embassy_rp::gpio::{Input, Level, Output, Pull}; | use embassy_rp::gpio::{Input, Level, Output, Pull}; | ||||||
| use embassy_rp::peripherals::{PIN_17, PIN_20, PIN_21, SPI0}; | use embassy_rp::peripherals::{PIN_17, PIN_20, PIN_21, SPI0}; | ||||||
| @ -59,7 +59,7 @@ async fn main(spawner: Spawner) { | |||||||
| 
 | 
 | ||||||
|     let mac_addr = [0x02, 0x00, 0x00, 0x00, 0x00, 0x00]; |     let mac_addr = [0x02, 0x00, 0x00, 0x00, 0x00, 0x00]; | ||||||
|     let state = make_static!(State::<8, 8>::new()); |     let state = make_static!(State::<8, 8>::new()); | ||||||
|     let (device, runner) = embassy_net_w5500::new( |     let (device, runner) = embassy_net_wiznet::new( | ||||||
|         mac_addr, |         mac_addr, | ||||||
|         state, |         state, | ||||||
|         ExclusiveDevice::new(spi, cs, Delay), |         ExclusiveDevice::new(spi, cs, Delay), | ||||||
|  | |||||||
| @ -11,8 +11,8 @@ use defmt::*; | |||||||
| use embassy_executor::Spawner; | use embassy_executor::Spawner; | ||||||
| use embassy_futures::yield_now; | use embassy_futures::yield_now; | ||||||
| use embassy_net::{Stack, StackResources}; | use embassy_net::{Stack, StackResources}; | ||||||
| use embassy_net_w5500::chip::W5500; | use embassy_net_wiznet::chip::W5500; | ||||||
| use embassy_net_w5500::*; | use embassy_net_wiznet::*; | ||||||
| use embassy_rp::clocks::RoscRng; | use embassy_rp::clocks::RoscRng; | ||||||
| use embassy_rp::gpio::{Input, Level, Output, Pull}; | use embassy_rp::gpio::{Input, Level, Output, Pull}; | ||||||
| use embassy_rp::peripherals::{PIN_17, PIN_20, PIN_21, SPI0}; | use embassy_rp::peripherals::{PIN_17, PIN_20, PIN_21, SPI0}; | ||||||
| @ -23,6 +23,7 @@ use embedded_io_async::Write; | |||||||
| use rand::RngCore; | use rand::RngCore; | ||||||
| use static_cell::make_static; | use static_cell::make_static; | ||||||
| use {defmt_rtt as _, panic_probe as _}; | use {defmt_rtt as _, panic_probe as _}; | ||||||
|  | 
 | ||||||
| #[embassy_executor::task] | #[embassy_executor::task] | ||||||
| async fn ethernet_task( | async fn ethernet_task( | ||||||
|     runner: Runner< |     runner: Runner< | ||||||
| @ -57,7 +58,7 @@ async fn main(spawner: Spawner) { | |||||||
| 
 | 
 | ||||||
|     let mac_addr = [0x02, 0x00, 0x00, 0x00, 0x00, 0x00]; |     let mac_addr = [0x02, 0x00, 0x00, 0x00, 0x00, 0x00]; | ||||||
|     let state = make_static!(State::<8, 8>::new()); |     let state = make_static!(State::<8, 8>::new()); | ||||||
|     let (device, runner) = embassy_net_w5500::new( |     let (device, runner) = embassy_net_wiznet::new( | ||||||
|         mac_addr, |         mac_addr, | ||||||
|         state, |         state, | ||||||
|         ExclusiveDevice::new(spi, cs, Delay), |         ExclusiveDevice::new(spi, cs, Delay), | ||||||
|  | |||||||
| @ -11,8 +11,8 @@ use embassy_executor::Spawner; | |||||||
| use embassy_futures::yield_now; | use embassy_futures::yield_now; | ||||||
| use embassy_net::udp::{PacketMetadata, UdpSocket}; | use embassy_net::udp::{PacketMetadata, UdpSocket}; | ||||||
| use embassy_net::{Stack, StackResources}; | use embassy_net::{Stack, StackResources}; | ||||||
| use embassy_net_w5500::chip::W5500; | use embassy_net_wiznet::chip::W5500; | ||||||
| use embassy_net_w5500::*; | use embassy_net_wiznet::*; | ||||||
| use embassy_rp::clocks::RoscRng; | use embassy_rp::clocks::RoscRng; | ||||||
| use embassy_rp::gpio::{Input, Level, Output, Pull}; | use embassy_rp::gpio::{Input, Level, Output, Pull}; | ||||||
| use embassy_rp::peripherals::{PIN_17, PIN_20, PIN_21, SPI0}; | use embassy_rp::peripherals::{PIN_17, PIN_20, PIN_21, SPI0}; | ||||||
| @ -22,6 +22,7 @@ use embedded_hal_async::spi::ExclusiveDevice; | |||||||
| use rand::RngCore; | use rand::RngCore; | ||||||
| use static_cell::make_static; | use static_cell::make_static; | ||||||
| use {defmt_rtt as _, panic_probe as _}; | use {defmt_rtt as _, panic_probe as _}; | ||||||
|  | 
 | ||||||
| #[embassy_executor::task] | #[embassy_executor::task] | ||||||
| async fn ethernet_task( | async fn ethernet_task( | ||||||
|     runner: Runner< |     runner: Runner< | ||||||
| @ -55,7 +56,7 @@ async fn main(spawner: Spawner) { | |||||||
| 
 | 
 | ||||||
|     let mac_addr = [0x02, 0x00, 0x00, 0x00, 0x00, 0x00]; |     let mac_addr = [0x02, 0x00, 0x00, 0x00, 0x00, 0x00]; | ||||||
|     let state = make_static!(State::<8, 8>::new()); |     let state = make_static!(State::<8, 8>::new()); | ||||||
|     let (device, runner) = embassy_net_w5500::new( |     let (device, runner) = embassy_net_wiznet::new( | ||||||
|         mac_addr, |         mac_addr, | ||||||
|         state, |         state, | ||||||
|         ExclusiveDevice::new(spi, cs, Delay), |         ExclusiveDevice::new(spi, cs, Delay), | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user