ftdi: incorrectly using output register for direction
[fw/openocd] / src / jtag / drivers / ftdi.c
index a038a232af6d15e0779eafcd3b6d593c72492245..f04b390c1717b1c541c2e3e81fa9daa1cbda8ff3 100644 (file)
@@ -175,7 +175,7 @@ static int ftdi_set_signal(const struct signal *s, char value)
 
        output = data ? output | s->data_mask : output & ~s->data_mask;
        if (s->oe_mask == s->data_mask)
-               direction = oe ? output | s->oe_mask : output & ~s->oe_mask;
+               direction = oe ? direction | s->oe_mask : direction & ~s->oe_mask;
        else
                output = oe ? output | s->oe_mask : output & ~s->oe_mask;