mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-22 08:38:36 -04:00
eedfe13f9c
the rgb value was never being set meaning the led was always off external bus is checked first
94 lines
2.9 KiB
C++
94 lines
2.9 KiB
C++
/*
|
|
ToshibaLED I2C driver
|
|
*/
|
|
/*
|
|
This program is free software: you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
(at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
/* LED driver for TCA62724FMG */
|
|
|
|
#include "ToshibaLED_I2C.h"
|
|
|
|
#include <utility>
|
|
|
|
#include <AP_HAL/AP_HAL.h>
|
|
|
|
extern const AP_HAL::HAL& hal;
|
|
|
|
#define TOSHIBA_LED_I2C_ADDR 0x55 // default I2C bus address
|
|
#define TOSHIBA_LED_I2C_BUS_INTERNAL 0
|
|
#define TOSHIBA_LED_I2C_BUS_EXTERNAL 1
|
|
|
|
#define TOSHIBA_LED_PWM0 0x01 // pwm0 register
|
|
#define TOSHIBA_LED_PWM1 0x02 // pwm1 register
|
|
#define TOSHIBA_LED_PWM2 0x03 // pwm2 register
|
|
#define TOSHIBA_LED_ENABLE 0x04 // enable register
|
|
|
|
bool ToshibaLED_I2C::hw_init()
|
|
{
|
|
// first look for led on external bus
|
|
_dev = std::move(hal.i2c_mgr->get_device(TOSHIBA_LED_I2C_BUS_EXTERNAL, TOSHIBA_LED_I2C_ADDR));
|
|
if (!_dev || !_dev->get_semaphore()->take(HAL_SEMAPHORE_BLOCK_FOREVER)) {
|
|
return false;
|
|
}
|
|
|
|
// enable the led
|
|
bool ret = _dev->write_register(TOSHIBA_LED_ENABLE, 0x03);
|
|
|
|
// on failure try the internal bus
|
|
if (!ret) {
|
|
// give back external bus semaphore
|
|
_dev->get_semaphore()->give();
|
|
// get internal I2C bus driver
|
|
_dev = std::move(hal.i2c_mgr->get_device(TOSHIBA_LED_I2C_BUS_INTERNAL, TOSHIBA_LED_I2C_ADDR));
|
|
if (!_dev || !_dev->get_semaphore()->take(HAL_SEMAPHORE_BLOCK_FOREVER)) {
|
|
return false;
|
|
}
|
|
ret = _dev->write_register(TOSHIBA_LED_ENABLE, 0x03);
|
|
}
|
|
|
|
// update the red, green and blue values to zero
|
|
uint8_t val[4] = { TOSHIBA_LED_PWM0, _led_off, _led_off, _led_off };
|
|
ret &= _dev->transfer(val, sizeof(val), nullptr, 0);
|
|
|
|
// give back i2c semaphore
|
|
_dev->get_semaphore()->give();
|
|
|
|
_dev->register_periodic_callback(20000, FUNCTOR_BIND_MEMBER(&ToshibaLED_I2C::_timer, void));
|
|
|
|
return ret;
|
|
}
|
|
|
|
// set_rgb - set color as a combination of red, green and blue values
|
|
bool ToshibaLED_I2C::hw_set_rgb(uint8_t red, uint8_t green, uint8_t blue)
|
|
{
|
|
rgb = {red, green, blue};
|
|
_need_update = true;
|
|
return true;
|
|
}
|
|
|
|
void ToshibaLED_I2C::_timer(void)
|
|
{
|
|
if (!_need_update) {
|
|
return;
|
|
}
|
|
_need_update = false;
|
|
|
|
/* 4-bit for each color */
|
|
uint8_t val[4] = { TOSHIBA_LED_PWM0, (uint8_t)(rgb.b >> 4),
|
|
(uint8_t)(rgb.g / 16), (uint8_t)(rgb.r / 16) };
|
|
|
|
_dev->transfer(val, sizeof(val), nullptr, 0);
|
|
}
|