aboutsummaryrefslogtreecommitdiff
path: root/examples
diff options
context:
space:
mode:
Diffstat (limited to 'examples')
-rw-r--r--examples/stm32u5/src/bin/adc.rs102
1 files changed, 73 insertions, 29 deletions
diff --git a/examples/stm32u5/src/bin/adc.rs b/examples/stm32u5/src/bin/adc.rs
index 049b985cf..4632f2cd1 100644
--- a/examples/stm32u5/src/bin/adc.rs
+++ b/examples/stm32u5/src/bin/adc.rs
@@ -36,55 +36,99 @@ async fn main(spawner: embassy_executor::Spawner) {
36 36
37 let mut p = embassy_stm32::init(config); 37 let mut p = embassy_stm32::init(config);
38 38
39 let mut adc = adc::Adc::new(p.ADC1); 39 // **** ADC1 init ****
40 let mut adc_pin1 = p.PA3; // A0 on nucleo u5a5 40 let mut adc1 = adc::Adc::new(p.ADC1);
41 let mut adc_pin2 = p.PA2; // A1 on nucleo u5a5 41 let mut adc1_pin1 = p.PA3; // A0 on nucleo u5a5
42 adc.set_resolution(adc::Resolution::BITS14); 42 let mut adc1_pin2 = p.PA2; // A1
43 adc.set_averaging(adc::Averaging::Samples1024); 43 adc1.set_resolution(adc::Resolution::BITS14);
44 adc.set_sample_time(adc::SampleTime::CYCLES160_5); 44 adc1.set_averaging(adc::Averaging::Samples1024);
45 let max = adc::resolution_to_max_count(adc::Resolution::BITS14); 45 adc1.set_sample_time(adc::SampleTime::CYCLES160_5);
46 46 let max1 = adc::resolution_to_max_count(adc::Resolution::BITS14);
47
48 // **** ADC2 init ****
49 let mut adc2 = adc::Adc::new(p.ADC2);
50 let mut adc2_pin1 = p.PC3; // A2
51 let mut adc2_pin2 = p.PB0; // A3
52 adc2.set_resolution(adc::Resolution::BITS14);
53 adc2.set_averaging(adc::Averaging::Samples1024);
54 adc2.set_sample_time(adc::SampleTime::CYCLES160_5);
55 let max2 = adc::resolution_to_max_count(adc::Resolution::BITS14);
56
57 // **** ADC4 init ****
47 let mut adc4 = adc4::Adc4::new(p.ADC4); 58 let mut adc4 = adc4::Adc4::new(p.ADC4);
48 let mut adc4_pin1 = p.PD11; 59 let mut adc4_pin1 = p.PC1; // A4
49 let mut adc4_pin2 = p.PC0; 60 let mut adc4_pin2 = p.PC0; // A5
50 adc4.set_resolution(adc4::Resolution::BITS12); 61 adc4.set_resolution(adc4::Resolution::BITS12);
51 adc4.set_averaging(adc4::Averaging::Samples256); 62 adc4.set_averaging(adc4::Averaging::Samples256);
52 adc4.set_sample_time(adc4::SampleTime::CYCLES1_5); 63 adc4.set_sample_time(adc4::SampleTime::CYCLES1_5);
53 let max4 = adc4::resolution_to_max_count(adc4::Resolution::BITS12); 64 let max4 = adc4::resolution_to_max_count(adc4::Resolution::BITS12);
54 65
55 let raw: u16 = adc.blocking_read(&mut adc_pin1); 66 // **** ADC1 blocking read ****
56 let volt: f32 = 3.3 * raw as f32 / max as f32; 67 let raw: u16 = adc1.blocking_read(&mut adc1_pin1);
57 info!("Read 1 pin 1 {}", volt); 68 let volt: f32 = 3.3 * raw as f32 / max1 as f32;
69 info!("Read adc1 pin 1 {}", volt);
70
71 let raw: u16 = adc1.blocking_read(&mut adc1_pin2);
72 let volt: f32 = 3.3 * raw as f32 / max1 as f32;
73 info!("Read adc1 pin 2 {}", volt);
74
75 // **** ADC2 blocking read ****
76 let raw: u16 = adc2.blocking_read(&mut adc2_pin1);
77 let volt: f32 = 3.3 * raw as f32 / max2 as f32;
78 info!("Read adc2 pin 1 {}", volt);
58 79
59 let raw: u16 = adc.blocking_read(&mut adc_pin2); 80 let raw: u16 = adc2.blocking_read(&mut adc2_pin2);
60 let volt: f32 = 3.3 * raw as f32 / max as f32; 81 let volt: f32 = 3.3 * raw as f32 / max2 as f32;
61 info!("Read 1 pin 2 {}", volt); 82 info!("Read adc2 pin 2 {}", volt);
62 83
63 let raw4: u16 = adc4.blocking_read(&mut adc4_pin1); 84 // **** ADC4 blocking read ****
64 let volt4: f32 = 3.3 * raw4 as f32 / max4 as f32; 85 let raw: u16 = adc4.blocking_read(&mut adc4_pin1);
65 info!("Read 4 pin 1 {}", volt4); 86 let volt: f32 = 3.3 * raw as f32 / max4 as f32;
87 info!("Read adc4 pin 1 {}", volt);
66 88
67 let raw4: u16 = adc4.blocking_read(&mut adc4_pin2); 89 let raw: u16 = adc4.blocking_read(&mut adc4_pin2);
68 let volt4: f32 = 3.3 * raw4 as f32 / max4 as f32; 90 let volt: f32 = 3.3 * raw as f32 / max4 as f32;
69 info!("Read 4 pin 2 {}", volt4); 91 info!("Read adc4 pin 2 {}", volt);
70 92
71 let mut degraded1 = adc_pin1.degrade_adc(); 93 // **** ADC1 async read ****
72 let mut degraded2 = adc_pin2.degrade_adc(); 94 let mut degraded11 = adc1_pin1.degrade_adc();
95 let mut degraded12 = adc1_pin2.degrade_adc();
73 let mut measurements = [0u16; 2]; 96 let mut measurements = [0u16; 2];
74 97
75 adc.read( 98 adc1.read(
76 &mut p.GPDMA1_CH0, 99 &mut p.GPDMA1_CH0,
77 [ 100 [
78 (&mut degraded2, adc::SampleTime::CYCLES160_5), 101 (&mut degraded11, adc::SampleTime::CYCLES160_5),
79 (&mut degraded1, adc::SampleTime::CYCLES160_5), 102 (&mut degraded12, adc::SampleTime::CYCLES160_5),
80 ] 103 ]
81 .into_iter(), 104 .into_iter(),
82 &mut measurements, 105 &mut measurements,
83 ).await; 106 ).await;
84 let volt1: f32 = 3.3 * measurements[1] as f32 / max as f32; 107 let volt1: f32 = 3.3 * measurements[0] as f32 / max1 as f32;
85 let volt2: f32 = 3.3 * measurements[0] as f32 / max as f32; 108 let volt2: f32 = 3.3 * measurements[1] as f32 / max1 as f32;
86 109
87 info!("Async read 1 pin 1 {}", volt1); 110 info!("Async read 1 pin 1 {}", volt1);
88 info!("Async read 1 pin 2 {}", volt2); 111 info!("Async read 1 pin 2 {}", volt2);
89 112
113 // **** ADC2 does not support async read ****
114
115 // **** ADC4 async read ****
116 let mut degraded41 = adc4_pin1.degrade_adc();
117 let mut degraded42 = adc4_pin2.degrade_adc();
118 let mut measurements = [0u16; 2];
119
120 // The channels must be in ascending order and can't repeat for ADC4
121 adc4.read(
122 &mut p.GPDMA1_CH1,
123 [
124 &mut degraded42,
125 &mut degraded41,
126 ]
127 .into_iter(),
128 &mut measurements,
129 ).await.unwrap();
130 let volt2: f32 = 3.3 * measurements[0] as f32 / max4 as f32;
131 let volt1: f32 = 3.3 * measurements[1] as f32 / max4 as f32;
132 info!("Async read 4 pin 1 {}", volt1);
133 info!("Async read 4 pin 2 {}", volt2);
90} \ No newline at end of file 134} \ No newline at end of file