Merge pull request #3812 from noracarmig/sai_v3_dma
Allow stm32 H7 and L5 families to use external SAI sync & allow recovering after dropping a DMA channel
This commit is contained in:
		
						commit
						7e0c70b1aa
					
				| @ -359,11 +359,13 @@ impl AnyChannel { | |||||||
|         match self.info().dma { |         match self.info().dma { | ||||||
|             #[cfg(dma)] |             #[cfg(dma)] | ||||||
|             DmaInfo::Dma(r) => { |             DmaInfo::Dma(r) => { | ||||||
|  |                 let state: &ChannelState = &STATE[self.id as usize]; | ||||||
|                 let ch = r.st(info.num); |                 let ch = r.st(info.num); | ||||||
| 
 | 
 | ||||||
|                 // "Preceding reads and writes cannot be moved past subsequent writes."
 |                 // "Preceding reads and writes cannot be moved past subsequent writes."
 | ||||||
|                 fence(Ordering::SeqCst); |                 fence(Ordering::SeqCst); | ||||||
| 
 | 
 | ||||||
|  |                 state.complete_count.store(0, Ordering::Release); | ||||||
|                 self.clear_irqs(); |                 self.clear_irqs(); | ||||||
| 
 | 
 | ||||||
|                 ch.par().write_value(peri_addr as u32); |                 ch.par().write_value(peri_addr as u32); | ||||||
|  | |||||||
| @ -190,7 +190,7 @@ pub enum SyncInput { | |||||||
|     /// Syncs with the other A/B sub-block within the SAI unit
 |     /// Syncs with the other A/B sub-block within the SAI unit
 | ||||||
|     Internal, |     Internal, | ||||||
|     /// Syncs with a sub-block in the other SAI unit
 |     /// Syncs with a sub-block in the other SAI unit
 | ||||||
|     #[cfg(any(sai_v4_2pdm, sai_v4_4pdm))] |     #[cfg(any(sai_v3_2pdm, sai_v3_4pdm, sai_v4_2pdm, sai_v4_4pdm))] | ||||||
|     External(SyncInputInstance), |     External(SyncInputInstance), | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -199,14 +199,14 @@ impl SyncInput { | |||||||
|         match self { |         match self { | ||||||
|             SyncInput::None => vals::Syncen::ASYNCHRONOUS, |             SyncInput::None => vals::Syncen::ASYNCHRONOUS, | ||||||
|             SyncInput::Internal => vals::Syncen::INTERNAL, |             SyncInput::Internal => vals::Syncen::INTERNAL, | ||||||
|             #[cfg(any(sai_v4_2pdm, sai_v4_4pdm))] |             #[cfg(any(sai_v3_2pdm, sai_v3_4pdm, sai_v4_2pdm, sai_v4_4pdm))] | ||||||
|             SyncInput::External(_) => vals::Syncen::EXTERNAL, |             SyncInput::External(_) => vals::Syncen::EXTERNAL, | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| /// SAI instance to sync from.
 | /// SAI instance to sync from.
 | ||||||
| #[cfg(any(sai_v4_2pdm, sai_v4_4pdm))] | #[cfg(any(sai_v3_2pdm, sai_v3_4pdm, sai_v4_2pdm, sai_v4_4pdm))] | ||||||
| #[derive(Copy, Clone, PartialEq)] | #[derive(Copy, Clone, PartialEq)] | ||||||
| #[allow(missing_docs)] | #[allow(missing_docs)] | ||||||
| pub enum SyncInputInstance { | pub enum SyncInputInstance { | ||||||
| @ -704,12 +704,12 @@ fn update_synchronous_config(config: &mut Config) { | |||||||
|     config.mode = Mode::Slave; |     config.mode = Mode::Slave; | ||||||
|     config.sync_output = false; |     config.sync_output = false; | ||||||
| 
 | 
 | ||||||
|     #[cfg(any(sai_v1, sai_v2, sai_v3_2pdm, sai_v3_4pdm))] |     #[cfg(any(sai_v1, sai_v2))] | ||||||
|     { |     { | ||||||
|         config.sync_input = SyncInput::Internal; |         config.sync_input = SyncInput::Internal; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     #[cfg(any(sai_v4_2pdm, sai_v4_4pdm))] |     #[cfg(any(sai_v3_2pdm, sai_v3_4pdm, sai_v4_2pdm, sai_v4_4pdm))] | ||||||
|     { |     { | ||||||
|         //this must either be Internal or External
 |         //this must either be Internal or External
 | ||||||
|         //The asynchronous sub-block on the same SAI needs to enable sync_output
 |         //The asynchronous sub-block on the same SAI needs to enable sync_output
 | ||||||
| @ -870,7 +870,7 @@ impl<'d, T: Instance, W: word::Word> Sai<'d, T, W> { | |||||||
| 
 | 
 | ||||||
|         ch.cr2().modify(|w| w.set_fflush(true)); |         ch.cr2().modify(|w| w.set_fflush(true)); | ||||||
| 
 | 
 | ||||||
|         #[cfg(any(sai_v4_2pdm, sai_v4_4pdm))] |         #[cfg(any(sai_v3_2pdm, sai_v3_4pdm, sai_v4_2pdm, sai_v4_4pdm))] | ||||||
|         { |         { | ||||||
|             if let SyncInput::External(i) = config.sync_input { |             if let SyncInput::External(i) = config.sync_input { | ||||||
|                 T::REGS.gcr().modify(|w| { |                 T::REGS.gcr().modify(|w| { | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user