rusefi-full/firmware/hw_layer/ports/kinetis/kinetis_common.cpp

138 lines
3.2 KiB
C++

/**
* @file kinetis_common.cpp
* @brief Low level common Kinetis code
*
* @date Mar 28, 2019
* @author andreika <prometheus.pcb@gmail.com>
*/
#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 */