Merge pull request #3444 from dnbln/main
feat: allow `bind_interrupts!` to accept conditional compilation attrs
This commit is contained in:
		
						commit
						8eb80c6816
					
				| @ -177,22 +177,31 @@ mod chip; | |||||||
| // developer note: this macro can't be in `embassy-hal-internal` due to the use of `$crate`.
 | // developer note: this macro can't be in `embassy-hal-internal` due to the use of `$crate`.
 | ||||||
| #[macro_export] | #[macro_export] | ||||||
| macro_rules! bind_interrupts { | macro_rules! bind_interrupts { | ||||||
|         ($vis:vis struct $name:ident { $($irq:ident => $($handler:ty),*;)* }) => { |         ($vis:vis struct $name:ident { | ||||||
|  |             $( | ||||||
|  |                 $(#[cfg($cond_irq:meta)])? | ||||||
|  |                 $irq:ident => $( | ||||||
|  |                     $(#[cfg($cond_handler:meta)])? | ||||||
|  |                     $handler:ty | ||||||
|  |                 ),*; | ||||||
|  |             )* | ||||||
|  |         }) => { | ||||||
|             #[derive(Copy, Clone)] |             #[derive(Copy, Clone)] | ||||||
|             $vis struct $name; |             $vis struct $name; | ||||||
| 
 | 
 | ||||||
|             $( |             $( | ||||||
|                 #[allow(non_snake_case)] |                 #[allow(non_snake_case)] | ||||||
|                 #[no_mangle] |                 #[no_mangle] | ||||||
|  |                 $(#[cfg($cond_irq)])? | ||||||
|                 unsafe extern "C" fn $irq() { |                 unsafe extern "C" fn $irq() { | ||||||
|                     $( |                     $( | ||||||
|  |                         $(#[cfg($cond_handler)])? | ||||||
|                         <$handler as $crate::interrupt::typelevel::Handler<$crate::interrupt::typelevel::$irq>>::on_interrupt(); |                         <$handler as $crate::interrupt::typelevel::Handler<$crate::interrupt::typelevel::$irq>>::on_interrupt(); | ||||||
|                     )* |  | ||||||
|                 } |  | ||||||
| 
 | 
 | ||||||
|                 $( |                         $(#[cfg($cond_handler)])? | ||||||
|                         unsafe impl $crate::interrupt::typelevel::Binding<$crate::interrupt::typelevel::$irq, $handler> for $name {} |                         unsafe impl $crate::interrupt::typelevel::Binding<$crate::interrupt::typelevel::$irq, $handler> for $name {} | ||||||
|                     )* |                     )* | ||||||
|  |                 } | ||||||
|             )* |             )* | ||||||
|         }; |         }; | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -166,22 +166,31 @@ embassy_hal_internal::interrupt_mod!( | |||||||
| // developer note: this macro can't be in `embassy-hal-internal` due to the use of `$crate`.
 | // developer note: this macro can't be in `embassy-hal-internal` due to the use of `$crate`.
 | ||||||
| #[macro_export] | #[macro_export] | ||||||
| macro_rules! bind_interrupts { | macro_rules! bind_interrupts { | ||||||
|     ($vis:vis struct $name:ident { $($irq:ident => $($handler:ty),*;)* }) => { |     ($vis:vis struct $name:ident { | ||||||
|  |         $( | ||||||
|  |             $(#[cfg($cond_irq:meta)])? | ||||||
|  |             $irq:ident => $( | ||||||
|  |                 $(#[cfg($cond_handler:meta)])? | ||||||
|  |                 $handler:ty | ||||||
|  |             ),*; | ||||||
|  |         )* | ||||||
|  |     }) => { | ||||||
|             #[derive(Copy, Clone)] |             #[derive(Copy, Clone)] | ||||||
|             $vis struct $name; |             $vis struct $name; | ||||||
| 
 | 
 | ||||||
|         $( |         $( | ||||||
|             #[allow(non_snake_case)] |             #[allow(non_snake_case)] | ||||||
|             #[no_mangle] |             #[no_mangle] | ||||||
|  |             $(#[cfg($cond_irq)])? | ||||||
|             unsafe extern "C" fn $irq() { |             unsafe extern "C" fn $irq() { | ||||||
|                 $( |                 $( | ||||||
|  |                     $(#[cfg($cond_handler)])? | ||||||
|                     <$handler as $crate::interrupt::typelevel::Handler<$crate::interrupt::typelevel::$irq>>::on_interrupt(); |                     <$handler as $crate::interrupt::typelevel::Handler<$crate::interrupt::typelevel::$irq>>::on_interrupt(); | ||||||
|                 )* |  | ||||||
|             } |  | ||||||
| 
 | 
 | ||||||
|             $( |                     $(#[cfg($cond_handler)])? | ||||||
|                     unsafe impl $crate::interrupt::typelevel::Binding<$crate::interrupt::typelevel::$irq, $handler> for $name {} |                     unsafe impl $crate::interrupt::typelevel::Binding<$crate::interrupt::typelevel::$irq, $handler> for $name {} | ||||||
|                 )* |                 )* | ||||||
|  |             } | ||||||
|         )* |         )* | ||||||
|     }; |     }; | ||||||
| } | } | ||||||
|  | |||||||
| @ -165,22 +165,31 @@ pub use crate::_generated::interrupt; | |||||||
| // developer note: this macro can't be in `embassy-hal-internal` due to the use of `$crate`.
 | // developer note: this macro can't be in `embassy-hal-internal` due to the use of `$crate`.
 | ||||||
| #[macro_export] | #[macro_export] | ||||||
| macro_rules! bind_interrupts { | macro_rules! bind_interrupts { | ||||||
|     ($vis:vis struct $name:ident { $($irq:ident => $($handler:ty),*;)* }) => { |     ($vis:vis struct $name:ident { | ||||||
|  |         $( | ||||||
|  |             $(#[cfg($cond_irq:meta)])? | ||||||
|  |             $irq:ident => $( | ||||||
|  |                 $(#[cfg($cond_handler:meta)])? | ||||||
|  |                 $handler:ty | ||||||
|  |             ),*; | ||||||
|  |         )* | ||||||
|  |     }) => { | ||||||
|         #[derive(Copy, Clone)] |         #[derive(Copy, Clone)] | ||||||
|         $vis struct $name; |         $vis struct $name; | ||||||
| 
 | 
 | ||||||
|         $( |         $( | ||||||
|             #[allow(non_snake_case)] |             #[allow(non_snake_case)] | ||||||
|             #[no_mangle] |             #[no_mangle] | ||||||
|  |             $(#[cfg($cond_irq)])? | ||||||
|             unsafe extern "C" fn $irq() { |             unsafe extern "C" fn $irq() { | ||||||
|                 $( |                 $( | ||||||
|  |                     $(#[cfg($cond_handler)])? | ||||||
|                     <$handler as $crate::interrupt::typelevel::Handler<$crate::interrupt::typelevel::$irq>>::on_interrupt(); |                     <$handler as $crate::interrupt::typelevel::Handler<$crate::interrupt::typelevel::$irq>>::on_interrupt(); | ||||||
|                 )* |  | ||||||
|             } |  | ||||||
| 
 | 
 | ||||||
|             $( |                     $(#[cfg($cond_handler)])? | ||||||
|                     unsafe impl $crate::interrupt::typelevel::Binding<$crate::interrupt::typelevel::$irq, $handler> for $name {} |                     unsafe impl $crate::interrupt::typelevel::Binding<$crate::interrupt::typelevel::$irq, $handler> for $name {} | ||||||
|                 )* |                 )* | ||||||
|  |             } | ||||||
|         )* |         )* | ||||||
|     }; |     }; | ||||||
| } | } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user