mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-10 18:08:30 -04:00
HAL_ChibiOS: fixed reconfig of group after serial_end()
This commit is contained in:
parent
46c76c3d5d
commit
d258eac88d
@ -82,6 +82,11 @@ void RCOutput::init()
|
|||||||
*/
|
*/
|
||||||
void RCOutput::set_freq_group(pwm_group &group)
|
void RCOutput::set_freq_group(pwm_group &group)
|
||||||
{
|
{
|
||||||
|
if (mode_requires_dma(group.current_mode)) {
|
||||||
|
// speed setup in DMA handler
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
uint16_t freq_set = group.rc_frequency;
|
uint16_t freq_set = group.rc_frequency;
|
||||||
uint32_t old_clock = group.pwm_cfg.frequency;
|
uint32_t old_clock = group.pwm_cfg.frequency;
|
||||||
|
|
||||||
@ -105,7 +110,16 @@ void RCOutput::set_freq_group(pwm_group &group)
|
|||||||
psc = (pwmp->clock / pwmp->config->frequency) - 1;
|
psc = (pwmp->clock / pwmp->config->frequency) - 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (old_clock != group.pwm_cfg.frequency || !group.pwm_started) {
|
bool force_reconfig = false;
|
||||||
|
for (uint8_t j=0; j<4; j++) {
|
||||||
|
if (group.pwm_cfg.channels[j].mode != PWM_OUTPUT_DISABLED &&
|
||||||
|
group.pwm_cfg.channels[j].mode == PWM_OUTPUT_ACTIVE_LOW) {
|
||||||
|
group.pwm_cfg.channels[j].mode = PWM_OUTPUT_ACTIVE_HIGH;
|
||||||
|
force_reconfig = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (old_clock != group.pwm_cfg.frequency || !group.pwm_started || force_reconfig) {
|
||||||
// we need to stop and start to setup the new clock
|
// we need to stop and start to setup the new clock
|
||||||
if (group.pwm_started) {
|
if (group.pwm_started) {
|
||||||
pwmStop(group.pwm_drv);
|
pwmStop(group.pwm_drv);
|
||||||
@ -892,6 +906,10 @@ bool RCOutput::serial_setup_output(uint8_t chan, uint32_t baudrate)
|
|||||||
// find the channel group
|
// find the channel group
|
||||||
for (uint8_t i = 0; i < NUM_GROUPS; i++ ) {
|
for (uint8_t i = 0; i < NUM_GROUPS; i++ ) {
|
||||||
pwm_group &group = pwm_group_list[i];
|
pwm_group &group = pwm_group_list[i];
|
||||||
|
if (group.current_mode == MODE_PWM_BRUSHED) {
|
||||||
|
// can't do serial output with brushed motors
|
||||||
|
continue;
|
||||||
|
}
|
||||||
if (group.ch_mask & (1U<<chan)) {
|
if (group.ch_mask & (1U<<chan)) {
|
||||||
if (serial_group && serial_group != &group) {
|
if (serial_group && serial_group != &group) {
|
||||||
// we're changing to a new group, end the previous output
|
// we're changing to a new group, end the previous output
|
||||||
@ -1084,6 +1102,9 @@ bool RCOutput::serial_read_byte(uint8_t &b)
|
|||||||
*/
|
*/
|
||||||
uint16_t RCOutput::serial_read_bytes(uint8_t *buf, uint16_t len)
|
uint16_t RCOutput::serial_read_bytes(uint8_t *buf, uint16_t len)
|
||||||
{
|
{
|
||||||
|
if (serial_group == nullptr) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
pwm_group &group = *serial_group;
|
pwm_group &group = *serial_group;
|
||||||
uint8_t chan = group.chan[group.serial.chan];
|
uint8_t chan = group.chan[group.serial.chan];
|
||||||
uint32_t gpio_mode = PAL_MODE_INPUT | PAL_STM32_OSPEED_LOWEST | PAL_STM32_OTYPE_PUSHPULL | PAL_STM32_PUPDR_PULLUP;
|
uint32_t gpio_mode = PAL_MODE_INPUT | PAL_STM32_OSPEED_LOWEST | PAL_STM32_OTYPE_PUSHPULL | PAL_STM32_PUPDR_PULLUP;
|
||||||
@ -1136,9 +1157,14 @@ uint16_t RCOutput::serial_read_bytes(uint8_t *buf, uint16_t len)
|
|||||||
void RCOutput::serial_end(void)
|
void RCOutput::serial_end(void)
|
||||||
{
|
{
|
||||||
if (serial_group) {
|
if (serial_group) {
|
||||||
|
pwm_group &group = *serial_group;
|
||||||
// restore normal output
|
// restore normal output
|
||||||
set_group_mode(*serial_group);
|
if (group.pwm_started) {
|
||||||
set_freq_group(*serial_group);
|
pwmStop(group.pwm_drv);
|
||||||
|
group.pwm_started = false;
|
||||||
|
}
|
||||||
|
set_group_mode(group);
|
||||||
|
set_freq_group(group);
|
||||||
irq.waiter = nullptr;
|
irq.waiter = nullptr;
|
||||||
}
|
}
|
||||||
serial_group = nullptr;
|
serial_group = nullptr;
|
||||||
|
Loading…
Reference in New Issue
Block a user