Updates sonar so that it can be used together with ADC current meter
Check if ADC current meter is enabled in sonarInit() and change sonar pins to pwm 5 and 6 if it is. Same as when RX_PARALLEL is enabled.
This commit is contained in:
parent
6e8d081c45
commit
b83b9040f9
|
@ -15,8 +15,8 @@ Currently the only supported sensor is the HCSR04 sensor.
|
||||||
### Naze/Flip32+
|
### Naze/Flip32+
|
||||||
|
|
||||||
| Mode | Trigger | Echo | Inline 1k resistors |
|
| Mode | Trigger | Echo | Inline 1k resistors |
|
||||||
| ------------- | ------------- | ------------- | ------------------- |
|
| ------------------------------- | ------------- | ------------- | ------------------- |
|
||||||
| Parallel PWM | PB8 / Motor 5 | PB9 / Motor 6 | NO (5v tolerant) |
|
| Parallel PWM/ADC current sensor | PB8 / Motor 5 | PB9 / Motor 6 | NO (5v tolerant) |
|
||||||
| PPM/Serial RX | PB0 / RC7 | PB1 / RC8 | YES (3.3v input) |
|
| PPM/Serial RX | PB0 / RC7 | PB1 / RC8 | YES (3.3v input) |
|
||||||
|
|
||||||
Current meter cannot be used in conjunction with Parallel PWM and Sonar.
|
Current meter cannot be used in conjunction with Parallel PWM and Sonar.
|
||||||
|
|
|
@ -367,7 +367,7 @@ void init(void)
|
||||||
|
|
||||||
#ifdef SONAR
|
#ifdef SONAR
|
||||||
if (feature(FEATURE_SONAR)) {
|
if (feature(FEATURE_SONAR)) {
|
||||||
sonarInit();
|
sonarInit(&masterConfig.batteryConfig);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
|
@ -37,7 +37,7 @@
|
||||||
|
|
||||||
static int32_t calculatedAltitude;
|
static int32_t calculatedAltitude;
|
||||||
|
|
||||||
void sonarInit(void)
|
void sonarInit(batteryConfig_t *batteryConfig)
|
||||||
{
|
{
|
||||||
#if defined(NAZE) || defined(EUSTM32F103RC) || defined(PORT103R)
|
#if defined(NAZE) || defined(EUSTM32F103RC) || defined(PORT103R)
|
||||||
static const sonarHardware_t const sonarPWM56 = {
|
static const sonarHardware_t const sonarPWM56 = {
|
||||||
|
@ -54,8 +54,8 @@ void sonarInit(void)
|
||||||
.exti_pin_source = GPIO_PinSource1,
|
.exti_pin_source = GPIO_PinSource1,
|
||||||
.exti_irqn = EXTI1_IRQn
|
.exti_irqn = EXTI1_IRQn
|
||||||
};
|
};
|
||||||
// If we are using parallel PWM for our receiver, then use motor pins 5 and 6 for sonar, otherwise use rc pins 7 and 8
|
// If we are using parallel PWM for our receiver or ADC current sensor, then use motor pins 5 and 6 for sonar, otherwise use rc pins 7 and 8
|
||||||
if (feature(FEATURE_RX_PARALLEL_PWM)) {
|
if (feature(FEATURE_RX_PARALLEL_PWM ) || (feature(FEATURE_CURRENT_METER) && batteryConfig->currentMeterType == CURRENT_SENSOR_ADC) ) {
|
||||||
hcsr04_init(&sonarPWM56);
|
hcsr04_init(&sonarPWM56);
|
||||||
} else {
|
} else {
|
||||||
hcsr04_init(&sonarRC78);
|
hcsr04_init(&sonarRC78);
|
||||||
|
|
|
@ -16,8 +16,9 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
#include "sensors/battery.h"
|
||||||
|
|
||||||
void sonarInit(void);
|
void sonarInit(batteryConfig_t *batteryConfig);
|
||||||
void sonarUpdate(void);
|
void sonarUpdate(void);
|
||||||
|
|
||||||
int32_t sonarRead(void);
|
int32_t sonarRead(void);
|
||||||
|
|
Loading…
Reference in New Issue