Fix Teensy 3.5/3.6 ADC access for ADC1 (#12258)
This commit is contained in:
		
							parent
							
								
									6fbc87301f
								
							
						
					
					
						commit
						63ce8baa55
					
				| @ -18,7 +18,6 @@ | |||||||
|  along with this program.  If not, see <http://www.gnu.org/licenses/>.
 |  along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | ||||||
| ****************************************************************************/ | ****************************************************************************/ | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| /**
 | /**
 | ||||||
|  * Description: HAL for Teensy35 (MK64FX512) |  * Description: HAL for Teensy35 (MK64FX512) | ||||||
|  */ |  */ | ||||||
| @ -30,7 +29,7 @@ | |||||||
| 
 | 
 | ||||||
| #include <Wire.h> | #include <Wire.h> | ||||||
| 
 | 
 | ||||||
| uint16_t HAL_adc_result; | uint16_t HAL_adc_result, HAL_adc_select; | ||||||
| 
 | 
 | ||||||
| static const uint8_t pin2sc1a[] = { | static const uint8_t pin2sc1a[] = { | ||||||
|   5, 14, 8, 9, 13, 12, 6, 7, 15, 4, 3, 19+128, 14+128, 15+128, // 0-13 -> A0-A13
 |   5, 14, 8, 9, 13, 12, 6, 7, 15, 4, 3, 19+128, 14+128, 15+128, // 0-13 -> A0-A13
 | ||||||
| @ -59,6 +58,7 @@ static const uint8_t pin2sc1a[] = { | |||||||
| void HAL_adc_init() { | void HAL_adc_init() { | ||||||
|   analog_init(); |   analog_init(); | ||||||
|   while (ADC0_SC3 & ADC_SC3_CAL) {}; // Wait for calibration to finish
 |   while (ADC0_SC3 & ADC_SC3_CAL) {}; // Wait for calibration to finish
 | ||||||
|  |   while (ADC1_SC3 & ADC_SC3_CAL) {}; // Wait for calibration to finish
 | ||||||
|   NVIC_ENABLE_IRQ(IRQ_FTM1); |   NVIC_ENABLE_IRQ(IRQ_FTM1); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -91,8 +91,28 @@ extern "C" { | |||||||
|   } |   } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void HAL_adc_start_conversion(const uint8_t adc_pin) { ADC0_SC1A = pin2sc1a[adc_pin]; } | void HAL_adc_start_conversion(const uint8_t adc_pin) { | ||||||
|  |   uint16_t pin = pin2sc1a[adc_pin]; | ||||||
|  |   if (pin == 0xFF) { | ||||||
|  |     // Digital only
 | ||||||
|  |     HAL_adc_select = -1; | ||||||
|  |   } | ||||||
|  |   else if (pin & 0x80) { | ||||||
|  |     HAL_adc_select = 1; | ||||||
|  |     ADC1_SC1A = pin & 0x7F; | ||||||
|  |   } | ||||||
|  |   else { | ||||||
|  |     HAL_adc_select = 0; | ||||||
|  |     ADC0_SC1A = pin; | ||||||
|  |   } | ||||||
|  | } | ||||||
| 
 | 
 | ||||||
| uint16_t HAL_adc_get_result(void) { return ADC0_RA; } | uint16_t HAL_adc_get_result(void) { | ||||||
|  |   switch (HAL_adc_select) { | ||||||
|  |     case 0: return ADC0_RA; | ||||||
|  |     case 1: return ADC1_RA; | ||||||
|  |   } | ||||||
|  |   return 0; | ||||||
|  | } | ||||||
| 
 | 
 | ||||||
| #endif // __MK64FX512__ || __MK66FX1M0__
 | #endif // __MK64FX512__ || __MK66FX1M0__
 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user