ftdipp_mpsse: update direction method

This commit is contained in:
Gwenhael Goavec-Merou 2020-10-31 07:38:06 +01:00
parent b2abafa76d
commit deefcd2d38
2 changed files with 34 additions and 4 deletions

View File

@ -484,7 +484,7 @@ void FTDIpp_MPSSE::gpio_set_dir(uint16_t dir)
* @param[in] gpio: pins bitmask
* @param[int] low_pins: select between CBUS or DBUS
*/
void FTDIpp_MPSSE::gpio_set_input(uint16_t gpio, bool low_pins)
void FTDIpp_MPSSE::gpio_set_input(uint8_t gpio, bool low_pins)
{
if (low_pins)
_cable.bit_low_dir &= ~gpio;
@ -492,12 +492,24 @@ void FTDIpp_MPSSE::gpio_set_input(uint16_t gpio, bool low_pins)
_cable.bit_high_dir &= ~gpio;
}
/**
* configure pins as input
* @param[in] gpio: pins bitmask
*/
void FTDIpp_MPSSE::gpio_set_input(uint16_t gpio)
{
if (gpio & 0x00ff)
_cable.bit_low_dir &= ~(gpio & 0x00ff);
if (gpio & 0xff00)
_cable.bit_high_dir &= ~((gpio >> 8) & 0x00ff);
}
/**
* configure low or high pins as output
* @param[in] gpio: pins bitmask
* @param[int] low_pins: select between CBUS or DBUS
*/
void FTDIpp_MPSSE::gpio_set_output(uint16_t gpio, bool low_pins)
void FTDIpp_MPSSE::gpio_set_output(uint8_t gpio, bool low_pins)
{
if (low_pins)
_cable.bit_low_dir |= gpio;
@ -505,6 +517,18 @@ void FTDIpp_MPSSE::gpio_set_output(uint16_t gpio, bool low_pins)
_cable.bit_high_dir |= gpio;
}
/**
* configure pins as output
* @param[in] gpio: pins bitmask
*/
void FTDIpp_MPSSE::gpio_set_output(uint16_t gpio)
{
if (gpio & 0x00ff)
_cable.bit_low_dir |= (gpio & 0x00ff);
if (gpio & 0xff00)
_cable.bit_high_dir |= ((gpio >> 8) & 0x00ff);
}
/**
* private method to write ftdi half bank GPIOs (pins state are in _cable)
* @param[in] low or high half bank

View File

@ -42,8 +42,14 @@ class FTDIpp_MPSSE {
/* gpio direction */
void gpio_set_dir(uint8_t dir, bool low_pins);
void gpio_set_dir(uint16_t dir);
void gpio_set_input(uint16_t gpio, bool low_pins);
void gpio_set_output(uint16_t gpio, bool low_pins);
/* configure as input low/high pins */
void gpio_set_input(uint8_t gpio, bool low_pins);
/* configure as input pins */
void gpio_set_input(uint16_t gpio);
/* configure as output low/high pins */
void gpio_set_output(uint8_t gpio, bool low_pins);
/* configure as output pins */
void gpio_set_output(uint16_t gpio);
protected:
void open_device(const std::string &serial, unsigned int baudrate);