/** * @file kinetis_common.cpp * @brief Low level common Kinetis code * * @date Mar 28, 2019 * @author andreika */ #include "global.h" #include "engine.h" #include "pin_repository.h" #if HAL_USE_ADC || defined(__DOXYGEN__) // ADC_CHANNEL_IN0 // PA2 (def=VIGN) // ADC_CHANNEL_IN1 // PA3 (def=MAP4) // ADC_CHANNEL_IN2 // x // ADC_CHANNEL_IN3 // PD3 (def=MAP3) // ADC_CHANNEL_IN4 // x // ADC_CHANNEL_IN5 // x // ADC_CHANNEL_IN6 // x // ADC_CHANNEL_IN7 // PB12 (def=MAP2) // ADC_CHANNEL_IN8 // PB13 (def=MAP1) // ADC_CHANNEL_IN9 // x // ADC_CHANNEL_IN10 // PE2 (def=O2S2) // ADC_CHANNEL_IN11 // x // ADC_CHANNEL_IN12 // PC14 (def=O2S) // ADC_CHANNEL_IN13 // PC15 (def=TPS) // ADC_CHANNEL_IN14 // PC16 (def=CLT) // ADC_CHANNEL_IN15 // PC17 (def=IAT) brain_pin_e getAdcChannelBrainPin(const char *msg, adc_channel_e hwChannel) { static_assert(EFI_ADC_NONE == ADC_CHANNEL_NONE); // todo: replace this with an array :) switch (hwChannel) { case EFI_ADC_0: return GPIOA_2; case EFI_ADC_1: return GPIOA_3; case EFI_ADC_2: return GPIO_INVALID; case EFI_ADC_3: return GPIOD_3; case EFI_ADC_4: return GPIO_INVALID; case EFI_ADC_5: return GPIO_INVALID; case EFI_ADC_6: return GPIO_INVALID; case EFI_ADC_7: return GPIOB_12; case EFI_ADC_8: return GPIOB_13; case EFI_ADC_9: return GPIO_INVALID; case EFI_ADC_10: return GPIOE_2; case EFI_ADC_11: return GPIO_INVALID; case EFI_ADC_12: return GPIOC_14; case EFI_ADC_13: return GPIOC_15; case EFI_ADC_14: return GPIOC_16; case EFI_ADC_15: return GPIOC_17; default: firmwareError(CUSTOM_ERR_ADC_UNKNOWN_CHANNEL, "Unknown hw channel %d [%s]", hwChannel, msg); return GPIO_INVALID; } } adc_channel_e getAdcChannel(brain_pin_e pin) { switch (pin) { case GPIOA_2: return EFI_ADC_0; case GPIOA_3: return EFI_ADC_1; //case GPIOA_2: // return EFI_ADC_2; case GPIOD_3: return EFI_ADC_3; //case GPIOA_4: // return EFI_ADC_4; //case GPIOA_5: // return EFI_ADC_5; //case GPIOA_6: // return EFI_ADC_6; case GPIOB_12: return EFI_ADC_7; case GPIOB_13: return EFI_ADC_8; //case GPIOB_1: // return EFI_ADC_9; case GPIOE_2: return EFI_ADC_10; //case GPIOC_1: // return EFI_ADC_11; case GPIOC_14: return EFI_ADC_12; case GPIOC_15: return EFI_ADC_13; case GPIOC_16: return EFI_ADC_14; case GPIOC_17: return EFI_ADC_15; default: return EFI_ADC_ERROR; } } // deprecated - migrate to 'getAdcChannelBrainPin' ioportid_t getAdcChannelPort(const char *msg, adc_channel_e hwChannel) { return getHwPort(msg, getAdcChannelBrainPin(msg, hwChannel)); } // deprecated - migrate to 'getAdcChannelBrainPin' int getAdcChannelPin(adc_channel_e hwChannel) { return getHwPin("get_pin", getAdcChannelBrainPin("get_pin", hwChannel)); } #endif /* HAL_USE_ADC */ #if EFI_PROD_CODE #define BOOTLOADER_LOCATION 0x1C00001CUL void jump_to_bootloader() { typedef void (*bootloader_start_t)(void * arg); // Read the function address from the ROM API tree and turn it into a function pointer bootloader_start_t bootloaderStart = (bootloader_start_t)(**(uint32_t **)BOOTLOADER_LOCATION); // Call the function! bootloaderStart(NULL); // Will not return from here NVIC_SystemReset(); } #endif /* EFI_PROD_CODE */