use private_bounds for sealed traits.
This commit is contained in:
		
							parent
							
								
									cb1e4e684e
								
							
						
					
					
						commit
						4aa4ea99c2
					
				| @ -30,14 +30,12 @@ macro_rules! interrupt_mod { | |||||||
|             pub mod typelevel { |             pub mod typelevel { | ||||||
|                 use super::InterruptExt; |                 use super::InterruptExt; | ||||||
| 
 | 
 | ||||||
|                 mod sealed { |                 trait SealedInterrupt {} | ||||||
|                     pub trait Interrupt {} |  | ||||||
|                 } |  | ||||||
| 
 | 
 | ||||||
|                 /// Type-level interrupt.
 |                 /// Type-level interrupt.
 | ||||||
|                 ///
 |                 ///
 | ||||||
|                 /// This trait is implemented for all typelevel interrupt types in this module.
 |                 /// This trait is implemented for all typelevel interrupt types in this module.
 | ||||||
|                 pub trait Interrupt: sealed::Interrupt { |                 pub trait Interrupt: SealedInterrupt { | ||||||
| 
 | 
 | ||||||
|                     /// Interrupt enum variant.
 |                     /// Interrupt enum variant.
 | ||||||
|                     ///
 |                     ///
 | ||||||
| @ -105,7 +103,7 @@ macro_rules! interrupt_mod { | |||||||
|                     #[doc=stringify!($irqs)] |                     #[doc=stringify!($irqs)] | ||||||
|                     #[doc=" typelevel interrupt."] |                     #[doc=" typelevel interrupt."] | ||||||
|                     pub enum $irqs {} |                     pub enum $irqs {} | ||||||
|                     impl sealed::Interrupt for $irqs{} |                     impl SealedInterrupt for $irqs{} | ||||||
|                     impl Interrupt for $irqs { |                     impl Interrupt for $irqs { | ||||||
|                         const IRQ: super::Interrupt = super::Interrupt::$irqs; |                         const IRQ: super::Interrupt = super::Interrupt::$irqs; | ||||||
|                     } |                     } | ||||||
|  | |||||||
| @ -2,12 +2,10 @@ | |||||||
| mod w5500; | mod w5500; | ||||||
| pub use w5500::W5500; | pub use w5500::W5500; | ||||||
| mod w5100s; | mod w5100s; | ||||||
|  | use embedded_hal_async::spi::SpiDevice; | ||||||
| pub use w5100s::W5100S; | pub use w5100s::W5100S; | ||||||
| 
 | 
 | ||||||
| pub(crate) mod sealed { | pub(crate) trait SealedChip { | ||||||
|     use embedded_hal_async::spi::SpiDevice; |  | ||||||
| 
 |  | ||||||
|     pub trait Chip { |  | ||||||
|     type Address; |     type Address; | ||||||
| 
 | 
 | ||||||
|     const COMMON_MODE: Self::Address; |     const COMMON_MODE: Self::Address; | ||||||
| @ -33,18 +31,11 @@ pub(crate) mod sealed { | |||||||
|     fn rx_addr(addr: u16) -> Self::Address; |     fn rx_addr(addr: u16) -> Self::Address; | ||||||
|     fn tx_addr(addr: u16) -> Self::Address; |     fn tx_addr(addr: u16) -> Self::Address; | ||||||
| 
 | 
 | ||||||
|         async fn bus_read<SPI: SpiDevice>( |     async fn bus_read<SPI: SpiDevice>(spi: &mut SPI, address: Self::Address, data: &mut [u8]) | ||||||
|             spi: &mut SPI, |         -> Result<(), SPI::Error>; | ||||||
|             address: Self::Address, |     async fn bus_write<SPI: SpiDevice>(spi: &mut SPI, address: Self::Address, data: &[u8]) -> Result<(), SPI::Error>; | ||||||
|             data: &mut [u8], |  | ||||||
|         ) -> Result<(), SPI::Error>; |  | ||||||
|         async fn bus_write<SPI: SpiDevice>( |  | ||||||
|             spi: &mut SPI, |  | ||||||
|             address: Self::Address, |  | ||||||
|             data: &[u8], |  | ||||||
|         ) -> Result<(), SPI::Error>; |  | ||||||
|     } |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| /// Trait for Wiznet chips.
 | /// Trait for Wiznet chips.
 | ||||||
| pub trait Chip: sealed::Chip {} | #[allow(private_bounds)] | ||||||
|  | pub trait Chip: SealedChip {} | ||||||
|  | |||||||
| @ -8,7 +8,7 @@ const RX_BASE: u16 = 0x6000; | |||||||
| pub enum W5100S {} | pub enum W5100S {} | ||||||
| 
 | 
 | ||||||
| impl super::Chip for W5100S {} | impl super::Chip for W5100S {} | ||||||
| impl super::sealed::Chip for W5100S { | impl super::SealedChip for W5100S { | ||||||
|     type Address = u16; |     type Address = u16; | ||||||
| 
 | 
 | ||||||
|     const COMMON_MODE: Self::Address = 0x00; |     const COMMON_MODE: Self::Address = 0x00; | ||||||
|  | |||||||
| @ -12,7 +12,7 @@ pub enum RegisterBlock { | |||||||
| pub enum W5500 {} | pub enum W5500 {} | ||||||
| 
 | 
 | ||||||
| impl super::Chip for W5500 {} | impl super::Chip for W5500 {} | ||||||
| impl super::sealed::Chip for W5500 { | impl super::SealedChip for W5500 { | ||||||
|     type Address = (RegisterBlock, u16); |     type Address = (RegisterBlock, u16); | ||||||
| 
 | 
 | ||||||
|     const COMMON_MODE: Self::Address = (RegisterBlock::Common, 0x00); |     const COMMON_MODE: Self::Address = (RegisterBlock::Common, 0x00); | ||||||
|  | |||||||
| @ -226,12 +226,9 @@ pub mod windows_version { | |||||||
|     pub const WIN10: u32 = 0x0A000000; |     pub const WIN10: u32 = 0x0A000000; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| mod sealed { |  | ||||||
|     use core::mem::size_of; |  | ||||||
| 
 |  | ||||||
| /// A trait for descriptors
 | /// A trait for descriptors
 | ||||||
|     pub trait Descriptor: Sized { | trait Descriptor: Sized { | ||||||
|         const TYPE: super::DescriptorType; |     const TYPE: DescriptorType; | ||||||
| 
 | 
 | ||||||
|     /// The size of the descriptor's header.
 |     /// The size of the descriptor's header.
 | ||||||
|     fn size(&self) -> usize { |     fn size(&self) -> usize { | ||||||
| @ -241,12 +238,9 @@ mod sealed { | |||||||
|     fn write_to(&self, buf: &mut [u8]); |     fn write_to(&self, buf: &mut [u8]); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|     pub trait DescriptorSet: Descriptor { | trait DescriptorSet: Descriptor { | ||||||
|     const LENGTH_OFFSET: usize; |     const LENGTH_OFFSET: usize; | ||||||
| } | } | ||||||
| } |  | ||||||
| 
 |  | ||||||
| use sealed::*; |  | ||||||
| 
 | 
 | ||||||
| /// Copies the data of `t` into `buf`.
 | /// Copies the data of `t` into `buf`.
 | ||||||
| ///
 | ///
 | ||||||
| @ -412,9 +406,11 @@ impl DescriptorSet for FunctionSubsetHeader { | |||||||
| // Feature Descriptors
 | // Feature Descriptors
 | ||||||
| 
 | 
 | ||||||
| /// A marker trait for feature descriptors that are valid at the device level.
 | /// A marker trait for feature descriptors that are valid at the device level.
 | ||||||
|  | #[allow(private_bounds)] | ||||||
| pub trait DeviceLevelDescriptor: Descriptor {} | pub trait DeviceLevelDescriptor: Descriptor {} | ||||||
| 
 | 
 | ||||||
| /// A marker trait for feature descriptors that are valid at the function level.
 | /// A marker trait for feature descriptors that are valid at the function level.
 | ||||||
|  | #[allow(private_bounds)] | ||||||
| pub trait FunctionLevelDescriptor: Descriptor {} | pub trait FunctionLevelDescriptor: Descriptor {} | ||||||
| 
 | 
 | ||||||
| /// Table 13. Microsoft OS 2.0 compatible ID descriptor.
 | /// Table 13. Microsoft OS 2.0 compatible ID descriptor.
 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user