Home | History | Annotate | Download | only in ftdi
      1 /*
      2  *Copyright (C) 2015 The Android Open Source Project
      3  *
      4  *Licensed under the Apache License, Version 2.0 (the "License");
      5  *you may not use this file except in compliance with the License.
      6  *You may obtain a copy of the License at
      7  *
      8  *     http://www.apache.org/licenses/LICENSE-2.0
      9  *
     10  *Unless required by applicable law or agreed to in writing, software
     11  *distributed under the License is distributed on an "AS IS" BASIS,
     12  *WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
     13  *See the License for the specific language governing permissions and
     14  *limitations under the License.
     15  *
     16  * This file was copied from https://github.com/devttys0/libmpsse.git (sha1
     17  * f1a6744b), and modified to suite the Chromium OS project.
     18  *
     19  * Main libmpsse source file.
     20  *
     21  * Craig Heffner
     22  * 27 December 2011
     23  */
     24 
     25 #include <stdlib.h>
     26 #include <string.h>
     27 #include <stdint.h>
     28 #include <unistd.h>
     29 
     30 #include "trunks/ftdi/support.h"
     31 
     32 /* List of known FT2232-based devices */
     33 struct vid_pid supported_devices[] = {
     34     {0x0403, 0x6010, "FT2232 Future Technology Devices International, Ltd"},
     35     {0x0403, 0x6011, "FT4232 Future Technology Devices International, Ltd"},
     36     {0x0403, 0x6014, "FT232H Future Technology Devices International, Ltd"},
     37 
     38     /* These devices are based on FT2232 chips, but have not been tested. */
     39     {0x0403, 0x8878, "Bus Blaster v2 (channel A)"},
     40     {0x0403, 0x8879, "Bus Blaster v2 (channel B)"},
     41     {0x0403, 0xBDC8, "Turtelizer JTAG/RS232 Adapter A"},
     42     {0x0403, 0xCFF8, "Amontec JTAGkey"},
     43     {0x0403, 0x8A98, "TIAO Multi Protocol Adapter"},
     44     {0x15BA, 0x0003, "Olimex Ltd. OpenOCD JTAG"},
     45     {0x15BA, 0x0004, "Olimex Ltd. OpenOCD JTAG TINY"},
     46 
     47     {0, 0, NULL}};
     48 
     49 /*
     50  * Opens and initializes the first FTDI device found.
     51  *
     52  * @mode      - Mode to open the device in. One of enum modes.
     53  * @freq      - Clock frequency to use for the specified mode.
     54  * @endianess - Specifies how data is clocked in/out (MSB, LSB).
     55  *
     56  * Returns a pointer to an MPSSE context structure if succeeded, NULL otherwise.
     57  */
     58 struct mpsse_context* MPSSE(enum modes mode, int freq, int endianess) {
     59   int i = 0;
     60   struct mpsse_context* mpsse = NULL;
     61 
     62   for (i = 0; supported_devices[i].vid != 0; i++) {
     63     mpsse = Open(supported_devices[i].vid, supported_devices[i].pid, mode,
     64                  freq, endianess, IFACE_A, NULL, NULL);
     65     if (mpsse) {
     66       mpsse->description = supported_devices[i].description;
     67       return mpsse;
     68     }
     69   }
     70 
     71   return NULL;
     72 }
     73 
     74 /*
     75  * Open device by VID/PID
     76  *
     77  * @vid         - Device vendor ID.
     78  * @pid         - Device product ID.
     79  * @mode        - MPSSE mode, one of enum modes.
     80  * @freq        - Clock frequency to use for the specified mode.
     81  * @endianess   - Specifies how data is clocked in/out (MSB, LSB).
     82  * @interface   - FTDI interface to use (IFACE_A - IFACE_D).
     83  * @description - Device product description (set to NULL if not needed).
     84  * @serial      - Device serial number (set to NULL if not needed).
     85  *
     86  * Returns a pointer to an MPSSE context structure on success.
     87  */
     88 struct mpsse_context* Open(int vid,
     89                            int pid,
     90                            enum modes mode,
     91                            int freq,
     92                            int endianess,
     93                            int interface,
     94                            const char* description,
     95                            const char* serial) {
     96   return OpenIndex(vid, pid, mode, freq, endianess, interface, description,
     97                    serial, 0);
     98 }
     99 
    100 /*
    101  * Open device by VID/PID/index
    102  *
    103  * @vid         - Device vendor ID.
    104  * @pid         - Device product ID.
    105  * @mode        - MPSSE mode, one of enum modes.
    106  * @freq        - Clock frequency to use for the specified mode.
    107  * @endianess   - Specifies how data is clocked in/out (MSB, LSB).
    108  * @interface   - FTDI interface to use (IFACE_A - IFACE_D).
    109  * @description - Device product description (set to NULL if not needed).
    110  * @serial      - Device serial number (set to NULL if not needed).
    111  * @index       - Device index (set to 0 if not needed).
    112  *
    113  * Returns a pointer to an MPSSE context structure.
    114  * On success, mpsse->open will be set to 1.
    115  * On failure, mpsse->open will be set to 0.
    116  */
    117 struct mpsse_context* OpenIndex(int vid,
    118                                 int pid,
    119                                 enum modes mode,
    120                                 int freq,
    121                                 int endianess,
    122                                 int interface,
    123                                 const char* description,
    124                                 const char* serial,
    125                                 int index) {
    126   int status = 0;
    127   struct mpsse_context* mpsse = NULL;
    128 
    129   mpsse = malloc(sizeof(struct mpsse_context));
    130   if (!mpsse)
    131     return NULL;
    132 
    133   memset(mpsse, 0, sizeof(struct mpsse_context));
    134 
    135   /* Legacy; flushing is no longer needed, so disable it by default. */
    136   FlushAfterRead(mpsse, 0);
    137 
    138   /* ftdilib initialization */
    139   if (ftdi_init(&mpsse->ftdi)) {
    140     free(mpsse);
    141     return NULL;
    142   }
    143 
    144   /* Set the FTDI interface  */
    145   ftdi_set_interface(&mpsse->ftdi, interface);
    146 
    147   /* Open the specified device */
    148   if (!ftdi_usb_open_desc_index(&mpsse->ftdi, vid, pid, description, serial,
    149                                 index)) {
    150     mpsse->mode = mode;
    151     mpsse->vid = vid;
    152     mpsse->pid = pid;
    153     mpsse->status = STOPPED;
    154     mpsse->endianess = endianess;
    155 
    156     /* Set the appropriate transfer size for the requested protocol */
    157     if (mpsse->mode == I2C)
    158       mpsse->xsize = I2C_TRANSFER_SIZE;
    159     else
    160       mpsse->xsize = SPI_RW_SIZE;
    161 
    162     status |= ftdi_usb_reset(&mpsse->ftdi);
    163     status |= ftdi_set_latency_timer(&mpsse->ftdi, LATENCY_MS);
    164     status |= ftdi_write_data_set_chunksize(&mpsse->ftdi, CHUNK_SIZE);
    165     status |= ftdi_read_data_set_chunksize(&mpsse->ftdi, CHUNK_SIZE);
    166     status |= ftdi_set_bitmode(&mpsse->ftdi, 0, BITMODE_RESET);
    167 
    168     if (status == 0) {
    169       /* Set the read and write timeout periods */
    170       set_timeouts(mpsse, USB_TIMEOUT);
    171 
    172       if (mpsse->mode != BITBANG) {
    173         ftdi_set_bitmode(&mpsse->ftdi, 0, BITMODE_MPSSE);
    174 
    175         if (SetClock(mpsse, freq) == MPSSE_OK) {
    176           if (SetMode(mpsse, endianess) == MPSSE_OK) {
    177             mpsse->opened = 1;
    178 
    179             /* Give the chip a few mS to initialize */
    180             usleep(SETUP_DELAY);
    181 
    182             /*
    183              * Not all FTDI chips support all the commands that SetMode may
    184              * have sent.
    185              * This clears out any errors from unsupported commands that
    186              * might have been sent during set up.
    187              */
    188             ftdi_usb_purge_buffers(&mpsse->ftdi);
    189           }
    190         }
    191       } else {
    192         /* Skip the setup functions if we're just operating in BITBANG mode
    193          */
    194         if (!ftdi_set_bitmode(&mpsse->ftdi, 0xFF, BITMODE_BITBANG))
    195           mpsse->opened = 1;
    196       }
    197     }
    198   }
    199 
    200   if (mpsse && !mpsse->opened) {
    201     Close(mpsse);
    202     mpsse = NULL;
    203   }
    204 
    205   return mpsse;
    206 }
    207 
    208 /*
    209  * Closes the device, deinitializes libftdi, and frees the MPSSE context
    210  *pointer.
    211  *
    212  * @mpsse - MPSSE context pointer.
    213  *
    214  * Returns void.
    215  */
    216 void Close(struct mpsse_context* mpsse) {
    217   if (!mpsse)
    218     return;
    219 
    220   if (mpsse->opened) {
    221     /* Shut these down only if initialization succeeded before. */
    222     ftdi_set_bitmode(&mpsse->ftdi, 0, BITMODE_RESET);
    223     ftdi_usb_close(&mpsse->ftdi);
    224   }
    225   ftdi_deinit(&mpsse->ftdi);
    226   free(mpsse);
    227 }
    228 
    229 /* Enables bit-wise data transfers.
    230  * Must be called after MPSSE() / Open() / OpenIndex().
    231  *
    232  * Returns void.
    233  */
    234 void EnableBitmode(struct mpsse_context* mpsse, int tf) {
    235   if (is_valid_context(mpsse)) {
    236     if (tf) {
    237       mpsse->tx |= MPSSE_BITMODE;
    238       mpsse->rx |= MPSSE_BITMODE;
    239       mpsse->txrx |= MPSSE_BITMODE;
    240     } else {
    241       mpsse->tx &= ~MPSSE_BITMODE;
    242       mpsse->rx &= ~MPSSE_BITMODE;
    243       mpsse->txrx &= ~MPSSE_BITMODE;
    244     }
    245   }
    246 }
    247 
    248 /*
    249  * Sets the appropriate transmit and receive commands based on the requested
    250  *mode and byte order.
    251  *
    252  * @mpsse     - MPSSE context pointer.
    253  * @endianess - MPSSE_MSB or MPSSE_LSB.
    254  *
    255  * Returns MPSSE_OK on success.
    256  * Returns MPSSE_FAIL on failure.
    257  */
    258 int SetMode(struct mpsse_context* mpsse, int endianess) {
    259   int retval = MPSSE_OK, i = 0, setup_commands_size = 0;
    260   uint8_t buf[CMD_SIZE] = {0};
    261   uint8_t setup_commands[CMD_SIZE * MAX_SETUP_COMMANDS] = {0};
    262 
    263   /* Do not call is_valid_context() here, as the FTDI chip may not be completely
    264    * configured when SetMode is called */
    265   if (mpsse) {
    266     /* Read and write commands need to include endianess */
    267     mpsse->tx = MPSSE_DO_WRITE | endianess;
    268     mpsse->rx = MPSSE_DO_READ | endianess;
    269     mpsse->txrx = MPSSE_DO_WRITE | MPSSE_DO_READ | endianess;
    270 
    271     /* Clock, data out, chip select pins are outputs; all others are inputs. */
    272     mpsse->tris = DEFAULT_TRIS;
    273 
    274     /* Clock and chip select pins idle high; all others are low */
    275     mpsse->pidle = mpsse->pstart = mpsse->pstop = DEFAULT_PORT;
    276 
    277     /* During reads and writes the chip select pin is brought low */
    278     mpsse->pstart &= ~CS;
    279 
    280     /* Disable FTDI internal loopback */
    281     SetLoopback(mpsse, 0);
    282 
    283     /* Send ACKs by default */
    284     SetAck(mpsse, ACK);
    285 
    286     /* Ensure adaptive clock is disabled */
    287     setup_commands[setup_commands_size++] = DISABLE_ADAPTIVE_CLOCK;
    288 
    289     switch (mpsse->mode) {
    290       case SPI0:
    291         /* SPI mode 0 clock idles low */
    292         mpsse->pidle &= ~SK;
    293         mpsse->pstart &= ~SK;
    294         mpsse->pstop &= ~SK;
    295         /* SPI mode 0 propogates data on the falling edge and read data on the
    296          * rising edge of the clock */
    297         mpsse->tx |= MPSSE_WRITE_NEG;
    298         mpsse->rx &= ~MPSSE_READ_NEG;
    299         mpsse->txrx |= MPSSE_WRITE_NEG;
    300         mpsse->txrx &= ~MPSSE_READ_NEG;
    301         break;
    302       case SPI3:
    303         /* SPI mode 3 clock idles high */
    304         mpsse->pidle |= SK;
    305         mpsse->pstart |= SK;
    306         /* Keep the clock low while the CS pin is brought high to ensure we
    307          * don't accidentally clock out an extra bit */
    308         mpsse->pstop &= ~SK;
    309         /* SPI mode 3 propogates data on the falling edge and read data on the
    310          * rising edge of the clock */
    311         mpsse->tx |= MPSSE_WRITE_NEG;
    312         mpsse->rx &= ~MPSSE_READ_NEG;
    313         mpsse->txrx |= MPSSE_WRITE_NEG;
    314         mpsse->txrx &= ~MPSSE_READ_NEG;
    315         break;
    316       case SPI1:
    317         /* SPI mode 1 clock idles low */
    318         mpsse->pidle &= ~SK;
    319         /* Since this mode idles low, the start condition should ensure that the
    320          * clock is low */
    321         mpsse->pstart &= ~SK;
    322         /* Even though we idle low in this mode, we need to keep the clock line
    323          * high when we set the CS pin high to prevent
    324          * an unintended clock cycle from being sent by the FT2232. This way,
    325          * the clock goes high, but does not go low until
    326          * after the CS pin goes high.
    327          */
    328         mpsse->pstop |= SK;
    329         /* Data read on falling clock edge */
    330         mpsse->rx |= MPSSE_READ_NEG;
    331         mpsse->tx &= ~MPSSE_WRITE_NEG;
    332         mpsse->txrx |= MPSSE_READ_NEG;
    333         mpsse->txrx &= ~MPSSE_WRITE_NEG;
    334         break;
    335       case SPI2:
    336         /* SPI 2 clock idles high */
    337         mpsse->pidle |= SK;
    338         mpsse->pstart |= SK;
    339         mpsse->pstop |= SK;
    340         /* Data read on falling clock edge */
    341         mpsse->rx |= MPSSE_READ_NEG;
    342         mpsse->tx &= ~MPSSE_WRITE_NEG;
    343         mpsse->txrx |= MPSSE_READ_NEG;
    344         mpsse->txrx &= ~MPSSE_WRITE_NEG;
    345         break;
    346       case I2C:
    347         /* I2C propogates data on the falling clock edge and reads data on the
    348          * falling (or rising) clock edge */
    349         mpsse->tx |= MPSSE_WRITE_NEG;
    350         mpsse->rx &= ~MPSSE_READ_NEG;
    351         /* In I2C, both the clock and the data lines idle high */
    352         mpsse->pidle |= DO | DI;
    353         /* I2C start bit == data line goes from high to low while clock line is
    354          * high */
    355         mpsse->pstart &= ~DO & ~DI;
    356         /* I2C stop bit == data line goes from low to high while clock line is
    357          * high - set data line low here, so the transition to the idle state
    358          * triggers the stop condition. */
    359         mpsse->pstop &= ~DO & ~DI;
    360         /* Enable three phase clock to ensure that I2C data is available on both
    361          * the rising and falling clock edges */
    362         setup_commands[setup_commands_size++] = ENABLE_3_PHASE_CLOCK;
    363         break;
    364       case GPIO:
    365         break;
    366       default:
    367         retval = MPSSE_FAIL;
    368     }
    369 
    370     /* Send any setup commands to the chip */
    371     if (retval == MPSSE_OK && setup_commands_size > 0) {
    372       retval = raw_write(mpsse, setup_commands, setup_commands_size);
    373     }
    374 
    375     if (retval == MPSSE_OK) {
    376       /* Set the idle pin states */
    377       set_bits_low(mpsse, mpsse->pidle);
    378 
    379       /* All GPIO pins are outputs, set low */
    380       mpsse->trish = 0xFF;
    381       mpsse->gpioh = 0x00;
    382 
    383       buf[i++] = SET_BITS_HIGH;
    384       buf[i++] = mpsse->gpioh;
    385       buf[i++] = mpsse->trish;
    386 
    387       retval = raw_write(mpsse, buf, i);
    388     }
    389   } else {
    390     retval = MPSSE_FAIL;
    391   }
    392 
    393   return retval;
    394 }
    395 
    396 /*
    397  * Sets the appropriate divisor for the desired clock frequency.
    398  *
    399  * @mpsse - MPSSE context pointer.
    400  * @freq  - Desired clock frequency in hertz.
    401  *
    402  * Returns MPSSE_OK on success.
    403  * Returns MPSSE_FAIL on failure.
    404  */
    405 int SetClock(struct mpsse_context* mpsse, uint32_t freq) {
    406   int retval = MPSSE_FAIL;
    407   uint32_t system_clock = 0;
    408   uint16_t divisor = 0;
    409   uint8_t buf[CMD_SIZE] = {0};
    410 
    411   /* Do not call is_valid_context() here, as the FTDI chip may not be completely
    412    * configured when SetClock is called */
    413   if (mpsse) {
    414     if (freq > SIX_MHZ) {
    415       buf[0] = TCK_X5;
    416       system_clock = SIXTY_MHZ;
    417     } else {
    418       buf[0] = TCK_D5;
    419       system_clock = TWELVE_MHZ;
    420     }
    421 
    422     if (raw_write(mpsse, buf, 1) == MPSSE_OK) {
    423       if (freq <= 0) {
    424         divisor = 0xFFFF;
    425       } else {
    426         divisor = freq2div(system_clock, freq);
    427       }
    428 
    429       buf[0] = TCK_DIVISOR;
    430       buf[1] = (divisor & 0xFF);
    431       buf[2] = ((divisor >> 8) & 0xFF);
    432 
    433       if (raw_write(mpsse, buf, 3) == MPSSE_OK) {
    434         mpsse->clock = div2freq(system_clock, divisor);
    435         retval = MPSSE_OK;
    436       }
    437     }
    438   }
    439 
    440   return retval;
    441 }
    442 
    443 /*
    444  * Retrieves the last error string from libftdi.
    445  *
    446  * @mpsse - MPSSE context pointer.
    447  *
    448  * Returns a pointer to the last error string.
    449  */
    450 const char* ErrorString(struct mpsse_context* mpsse) {
    451   if (mpsse != NULL) {
    452     return ftdi_get_error_string(&mpsse->ftdi);
    453   }
    454 
    455   return NULL_CONTEXT_ERROR_MSG;
    456 }
    457 
    458 /*
    459  * Gets the currently configured clock rate.
    460  *
    461  * @mpsse - MPSSE context pointer.
    462  *
    463  * Returns the existing clock rate in hertz.
    464  */
    465 int GetClock(struct mpsse_context* mpsse) {
    466   int clock = 0;
    467 
    468   if (is_valid_context(mpsse)) {
    469     clock = mpsse->clock;
    470   }
    471 
    472   return clock;
    473 }
    474 
    475 /*
    476  * Returns the vendor ID of the FTDI chip.
    477  *
    478  * @mpsse - MPSSE context pointer.
    479  *
    480  * Returns the integer value of the vendor ID.
    481  */
    482 int GetVid(struct mpsse_context* mpsse) {
    483   int vid = 0;
    484 
    485   if (is_valid_context(mpsse)) {
    486     vid = mpsse->vid;
    487   }
    488 
    489   return vid;
    490 }
    491 
    492 /*
    493  * Returns the product ID of the FTDI chip.
    494  *
    495  * @mpsse - MPSSE context pointer.
    496  *
    497  * Returns the integer value of the product ID.
    498  */
    499 int GetPid(struct mpsse_context* mpsse) {
    500   int pid = 0;
    501 
    502   if (is_valid_context(mpsse)) {
    503     pid = mpsse->pid;
    504   }
    505 
    506   return pid;
    507 }
    508 
    509 /*
    510  * Returns the description of the FTDI chip, if any.
    511  *
    512  * @mpsse - MPSSE context pointer.
    513  *
    514  * Returns the description of the FTDI chip.
    515  */
    516 const char* GetDescription(struct mpsse_context* mpsse) {
    517   char* description = NULL;
    518 
    519   if (is_valid_context(mpsse)) {
    520     description = mpsse->description;
    521   }
    522 
    523   return description;
    524 }
    525 
    526 /*
    527  * Enable / disable internal loopback.
    528  *
    529  * @mpsse  - MPSSE context pointer.
    530  * @enable - Zero to disable loopback, 1 to enable loopback.
    531  *
    532  * Returns MPSSE_OK on success.
    533  * Returns MPSSE_FAIL on failure.
    534  */
    535 int SetLoopback(struct mpsse_context* mpsse, int enable) {
    536   uint8_t buf[1] = {0};
    537   int retval = MPSSE_FAIL;
    538 
    539   if (is_valid_context(mpsse)) {
    540     if (enable) {
    541       buf[0] = LOOPBACK_START;
    542     } else {
    543       buf[0] = LOOPBACK_END;
    544     }
    545 
    546     retval = raw_write(mpsse, buf, 1);
    547   }
    548 
    549   return retval;
    550 }
    551 
    552 /*
    553  * Sets the idle state of the chip select pin. CS idles high by default.
    554  *
    555  * @mpsse - MPSSE context pointer.
    556  * @idle  - Set to 1 to idle high, 0 to idle low.
    557  *
    558  * Returns void.
    559  */
    560 void SetCSIdle(struct mpsse_context* mpsse, int idle) {
    561   if (is_valid_context(mpsse)) {
    562     if (idle > 0) {
    563       /* Chip select idles high, active low */
    564       mpsse->pidle |= CS;
    565       mpsse->pstop |= CS;
    566       mpsse->pstart &= ~CS;
    567     } else {
    568       /* Chip select idles low, active high */
    569       mpsse->pidle &= ~CS;
    570       mpsse->pstop &= ~CS;
    571       mpsse->pstart |= CS;
    572     }
    573   }
    574 
    575   return;
    576 }
    577 
    578 /*
    579  * Enables or disables flushing of the FTDI chip's RX buffers after each read
    580  *operation.
    581  * Flushing is disable by default.
    582  *
    583  * @mpsse - MPSSE context pointer.
    584  * @tf    - Set to 1 to enable flushing, or 0 to disable flushing.
    585  *
    586  * Returns void.
    587  */
    588 void FlushAfterRead(struct mpsse_context* mpsse, int tf) {
    589   mpsse->flush_after_read = tf;
    590   return;
    591 }
    592 
    593 /*
    594  * Send data start condition.
    595  *
    596  * @mpsse - MPSSE context pointer.
    597  *
    598  * Returns MPSSE_OK on success.
    599  * Returns MPSSE_FAIL on failure.
    600  */
    601 int Start(struct mpsse_context* mpsse) {
    602   int status = MPSSE_OK;
    603 
    604   if (is_valid_context(mpsse)) {
    605     if (mpsse->mode == I2C && mpsse->status == STARTED) {
    606       /* Set the default pin states while the clock is low since this is an I2C
    607        * repeated start condition */
    608       status |= set_bits_low(mpsse, (mpsse->pidle & ~SK));
    609 
    610       /* Make sure the pins are in their default idle state */
    611       status |= set_bits_low(mpsse, mpsse->pidle);
    612     }
    613 
    614     /* Set the start condition */
    615     status |= set_bits_low(mpsse, mpsse->pstart);
    616 
    617     /*
    618      * Hackish work around to properly support SPI mode 3.
    619      * SPI3 clock idles high, but needs to be set low before sending out
    620      * data to prevent unintenteded clock glitches from the FT2232.
    621      */
    622     if (mpsse->mode == SPI3) {
    623       status |= set_bits_low(mpsse, (mpsse->pstart & ~SK));
    624     }
    625     /*
    626      * Hackish work around to properly support SPI mode 1.
    627      * SPI1 clock idles low, but needs to be set high before sending out
    628      * data to preven unintended clock glitches from the FT2232.
    629      */
    630     else if (mpsse->mode == SPI1) {
    631       status |= set_bits_low(mpsse, (mpsse->pstart | SK));
    632     }
    633 
    634     mpsse->status = STARTED;
    635   } else {
    636     status = MPSSE_FAIL;
    637     mpsse->status = STOPPED;
    638   }
    639 
    640   return status;
    641 }
    642 
    643 /*
    644  * Performs a bit-wise write of up to 8 bits at a time.
    645  *
    646  * @mpsse - MPSSE context pointer.
    647  * @bits  - A byte containing the desired bits to write.
    648  * @size  - The number of bits from the 'bits' byte to write.
    649  *
    650  * Returns MPSSE_OK on success, MPSSE_FAIL on failure.
    651  */
    652 int WriteBits(struct mpsse_context* mpsse, char bits, size_t size) {
    653   uint8_t data[8] = {0};
    654   size_t i = 0;
    655   int retval = MPSSE_OK;
    656 
    657   if (size > sizeof(data)) {
    658     size = sizeof(data);
    659   }
    660 
    661   /* Convert each bit in bits to an array of bytes */
    662   for (i = 0; i < size; i++) {
    663     if (bits & (1 << i)) {
    664       /* Be sure to honor endianess */
    665       if (mpsse->endianess == LSB) {
    666         data[i] = '\xFF';
    667       } else {
    668         data[size - i - 1] = '\xFF';
    669       }
    670     }
    671   }
    672 
    673   /* Enable bit mode before writing, then disable it afterwards. */
    674   EnableBitmode(mpsse, 1);
    675   retval = Write(mpsse, data, size);
    676   EnableBitmode(mpsse, 0);
    677 
    678   return retval;
    679 }
    680 
    681 /*
    682  * Send data out via the selected serial protocol.
    683  *
    684  * @mpsse - MPSSE context pointer.
    685  * @data  - Buffer of data to send.
    686  * @size  - Size of data.
    687  *
    688  * Returns MPSSE_OK on success.
    689  * Returns MPSSE_FAIL on failure.
    690  */
    691 int Write(struct mpsse_context* mpsse, const void* vdata, int size) {
    692   const uint8_t* data = vdata;
    693   uint8_t* buf = NULL;
    694   int retval = MPSSE_FAIL, buf_size = 0, txsize = 0, n = 0;
    695 
    696   if (is_valid_context(mpsse)) {
    697     if (mpsse->mode) {
    698       while (n < size) {
    699         txsize = size - n;
    700         if (txsize > mpsse->xsize) {
    701           txsize = mpsse->xsize;
    702         }
    703 
    704         /*
    705          * For I2C we need to send each byte individually so that we can
    706          * read back each individual ACK bit, so set the transmit size to 1.
    707          */
    708         if (mpsse->mode == I2C) {
    709           txsize = 1;
    710         }
    711 
    712         buf = build_block_buffer(mpsse, mpsse->tx, data + n, txsize, &buf_size);
    713         if (buf) {
    714           retval = raw_write(mpsse, buf, buf_size);
    715           n += txsize;
    716           free(buf);
    717 
    718           if (retval == MPSSE_FAIL) {
    719             break;
    720           }
    721 
    722           /* Read in the ACK bit and store it in mpsse->rack */
    723           if (mpsse->mode == I2C) {
    724             raw_read(mpsse, (uint8_t*)&mpsse->rack, 1);
    725           }
    726         } else {
    727           break;
    728         }
    729       }
    730     }
    731 
    732     if (retval == MPSSE_OK && n == size) {
    733       retval = MPSSE_OK;
    734     }
    735   }
    736 
    737   return retval;
    738 }
    739 
    740 /* Performs a read. For internal use only; see Read() and ReadBits(). */
    741 static uint8_t* InternalRead(struct mpsse_context* mpsse, int size) {
    742   uint8_t *data = NULL, *buf = NULL;
    743   uint8_t sbuf[SPI_RW_SIZE] = {0};
    744   int n = 0, rxsize = 0, data_size = 0, retval = 0;
    745 
    746   if (is_valid_context(mpsse)) {
    747     if (mpsse->mode) {
    748       buf = malloc(size);
    749       if (buf) {
    750         memset(buf, 0, size);
    751 
    752         while (n < size) {
    753           rxsize = size - n;
    754           if (rxsize > mpsse->xsize) {
    755             rxsize = mpsse->xsize;
    756           }
    757 
    758           data = build_block_buffer(mpsse, mpsse->rx, sbuf, rxsize, &data_size);
    759           if (data) {
    760             retval = raw_write(mpsse, data, data_size);
    761             free(data);
    762 
    763             if (retval == MPSSE_OK) {
    764               n += raw_read(mpsse, buf + n, rxsize);
    765             } else {
    766               break;
    767             }
    768           } else {
    769             break;
    770           }
    771         }
    772       }
    773     }
    774   }
    775 
    776   return buf;
    777 }
    778 
    779 /*
    780  * Reads data over the selected serial protocol.
    781  *
    782  * @mpsse - MPSSE context pointer.
    783  * @size  - Number of bytes to read.
    784  *
    785  * Returns a pointer to the read data on success.
    786  * Returns NULL on failure.
    787  */
    788 #ifdef SWIGPYTHON
    789 swig_string_data Read(struct mpsse_context* mpsse, int size)
    790 #else
    791 uint8_t* Read(struct mpsse_context* mpsse, int size)
    792 #endif
    793 {
    794   uint8_t* buf = NULL;
    795 
    796   buf = InternalRead(mpsse, size);
    797 
    798 #ifdef SWIGPYTHON
    799   swig_string_data sdata = {0};
    800   sdata.size = size;
    801   sdata.data = buf;
    802   return sdata;
    803 #else
    804   return buf;
    805 #endif
    806 }
    807 
    808 /*
    809  * Performs a bit-wise read of up to 8 bits.
    810  *
    811  * @mpsse - MPSSE context pointer.
    812  * @size  - Number of bits to read.
    813  *
    814  * Returns an 8-bit byte containing the read bits.
    815  */
    816 char ReadBits(struct mpsse_context* mpsse, int size) {
    817   char bits = 0;
    818   uint8_t* rdata = NULL;
    819 
    820   if (size > 8) {
    821     size = 8;
    822   }
    823 
    824   EnableBitmode(mpsse, 1);
    825   rdata = InternalRead(mpsse, size);
    826   EnableBitmode(mpsse, 0);
    827 
    828   if (rdata) {
    829     /* The last byte in rdata will have all the read bits set or unset as
    830      * needed. */
    831     bits = rdata[size - 1];
    832 
    833     if (mpsse->endianess == MSB) {
    834       /*
    835        * In MSB mode, bits are sifted in from the left. If less than 8 bits were
    836        * read, we need to shift them left accordingly.
    837        */
    838       bits = bits << (8 - size);
    839     } else if (mpsse->endianess == LSB) {
    840       /*
    841        * In LSB mode, bits are shifted in from the right. If less than 8 bits
    842        * were
    843        * read, we need to shift them right accordingly.
    844        */
    845       bits = bits >> (8 - size);
    846     }
    847 
    848     free(rdata);
    849   }
    850 
    851   return bits;
    852 }
    853 
    854 /*
    855  * Reads and writes data over the selected serial protocol (SPI only).
    856  *
    857  * @mpsse - MPSSE context pointer.
    858  * @data  - Buffer containing bytes to write.
    859  * @size  - Number of bytes to transfer.
    860  *
    861  * Returns a pointer to the read data on success.
    862  * Returns NULL on failure.
    863  */
    864 #ifdef SWIGPYTHON
    865 swig_string_data Transfer(struct mpsse_context* mpsse, char* data, int size)
    866 #else
    867 uint8_t* Transfer(struct mpsse_context* mpsse, uint8_t* data, int size)
    868 #endif
    869 {
    870   uint8_t *txdata = NULL, *buf = NULL;
    871   int n = 0, data_size = 0, rxsize = 0, retval = 0;
    872 
    873   if (is_valid_context(mpsse)) {
    874     /* Make sure we're configured for one of the SPI modes */
    875     if (mpsse->mode >= SPI0 && mpsse->mode <= SPI3) {
    876       buf = malloc(size);
    877       if (buf) {
    878         memset(buf, 0, size);
    879 
    880         while (n < size) {
    881           /* When sending and recieving, FTDI chips don't seem to like large
    882            * data blocks. Limit the size of each block to SPI_TRANSFER_SIZE */
    883           rxsize = size - n;
    884           if (rxsize > SPI_TRANSFER_SIZE) {
    885             rxsize = SPI_TRANSFER_SIZE;
    886           }
    887 
    888           txdata =
    889               build_block_buffer(mpsse, mpsse->txrx, data + n,
    890                                  rxsize, &data_size);
    891           if (txdata) {
    892             retval = raw_write(mpsse, txdata, data_size);
    893             free(txdata);
    894 
    895             if (retval == MPSSE_OK) {
    896               n += raw_read(mpsse, (buf + n), rxsize);
    897             } else {
    898               break;
    899             }
    900           } else {
    901             break;
    902           }
    903         }
    904       }
    905     }
    906   }
    907 
    908 #ifdef SWIGPYTHON
    909   swig_string_data sdata = {0};
    910   sdata.size = n;
    911   sdata.data = (char*)buf;
    912   return sdata;
    913 #else
    914   return buf;
    915 #endif
    916 }
    917 
    918 /*
    919  * Returns the last received ACK bit.
    920  *
    921  * @mpsse - MPSSE context pointer.
    922  *
    923  * Returns either an ACK (0) or a NACK (1).
    924  */
    925 int GetAck(struct mpsse_context* mpsse) {
    926   int ack = 0;
    927 
    928   if (is_valid_context(mpsse)) {
    929     ack = (mpsse->rack & 0x01);
    930   }
    931 
    932   return ack;
    933 }
    934 
    935 /*
    936  * Sets the transmitted ACK bit.
    937  *
    938  * @mpsse - MPSSE context pointer.
    939  * @ack   - 0 to send ACKs, 1 to send NACKs.
    940  *
    941  * Returns void.
    942  */
    943 void SetAck(struct mpsse_context* mpsse, int ack) {
    944   if (is_valid_context(mpsse)) {
    945     if (ack == NACK) {
    946       mpsse->tack = 0xFF;
    947     } else {
    948       mpsse->tack = 0x00;
    949     }
    950   }
    951 
    952   return;
    953 }
    954 
    955 /*
    956  * Causes libmpsse to send ACKs after each read byte in I2C mode.
    957  *
    958  * @mpsse - MPSSE context pointer.
    959  *
    960  * Returns void.
    961  */
    962 void SendAcks(struct mpsse_context* mpsse) {
    963   return SetAck(mpsse, ACK);
    964 }
    965 
    966 /*
    967  * Causes libmpsse to send NACKs after each read byte in I2C mode.
    968  *
    969  * @mpsse - MPSSE context pointer.
    970  *
    971  * Returns void.
    972  */
    973 void SendNacks(struct mpsse_context* mpsse) {
    974   return SetAck(mpsse, NACK);
    975 }
    976 
    977 /*
    978  * Send data stop condition.
    979  *
    980  * @mpsse - MPSSE context pointer.
    981  *
    982  * Returns MPSSE_OK on success.
    983  * Returns MPSSE_FAIL on failure.
    984  */
    985 int Stop(struct mpsse_context* mpsse) {
    986   int retval = MPSSE_OK;
    987 
    988   if (is_valid_context(mpsse)) {
    989     /* In I2C mode, we need to ensure that the data line goes low while the
    990      * clock line is low to avoid sending an inadvertent start condition */
    991     if (mpsse->mode == I2C) {
    992       retval |= set_bits_low(mpsse, (mpsse->pidle & ~DO & ~SK));
    993     }
    994 
    995     /* Send the stop condition */
    996     retval |= set_bits_low(mpsse, mpsse->pstop);
    997 
    998     if (retval == MPSSE_OK) {
    999       /* Restore the pins to their idle states */
   1000       retval |= set_bits_low(mpsse, mpsse->pidle);
   1001     }
   1002 
   1003     mpsse->status = STOPPED;
   1004   } else {
   1005     retval = MPSSE_FAIL;
   1006     mpsse->status = STOPPED;
   1007   }
   1008 
   1009   return retval;
   1010 }
   1011 
   1012 /*
   1013  * Sets the specified pin high.
   1014  *
   1015  * @mpsse - MPSSE context pointer.
   1016  * @pin   - Pin number to set high.
   1017  *
   1018  * Returns MPSSE_OK on success.
   1019  * Returns MPSSE_FAIL on failure.
   1020  */
   1021 int PinHigh(struct mpsse_context* mpsse, int pin) {
   1022   int retval = MPSSE_FAIL;
   1023 
   1024   if (is_valid_context(mpsse)) {
   1025     retval = gpio_write(mpsse, pin, HIGH);
   1026   }
   1027 
   1028   return retval;
   1029 }
   1030 
   1031 /*
   1032  * Sets the specified pin low.
   1033  *
   1034  * @mpsse - MPSSE context pointer.
   1035  * @pin   - Pin number to set low.
   1036  *
   1037  * Returns MPSSE_OK on success.
   1038  * Returns MPSSE_FAIL on failure.
   1039  */
   1040 int PinLow(struct mpsse_context* mpsse, int pin) {
   1041   int retval = MPSSE_FAIL;
   1042 
   1043   if (is_valid_context(mpsse)) {
   1044     retval = gpio_write(mpsse, pin, LOW);
   1045   }
   1046 
   1047   return retval;
   1048 }
   1049 
   1050 /*
   1051  * Sets the input/output direction of all pins. For use in BITBANG mode only.
   1052  *
   1053  * @mpsse     - MPSSE context pointer.
   1054  * @direction - Byte indicating input/output direction of each bit.  1 is out.
   1055  *
   1056  * Returns MPSSE_OK if direction could be set, MPSSE_FAIL otherwise.
   1057  */
   1058 int SetDirection(struct mpsse_context* mpsse, uint8_t direction) {
   1059   int retval = MPSSE_FAIL;
   1060 
   1061   if (is_valid_context(mpsse)) {
   1062     if (mpsse->mode == BITBANG) {
   1063       if (ftdi_set_bitmode(&mpsse->ftdi, direction, BITMODE_BITBANG) == 0) {
   1064         retval = MPSSE_OK;
   1065       }
   1066     }
   1067   }
   1068 
   1069   return retval;
   1070 }
   1071 
   1072 /*
   1073  * Sets the input/output value of all pins. For use in BITBANG mode only.
   1074  *
   1075  * @mpsse - MPSSE context pointer.
   1076  * @data  - Byte indicating bit hi/low value of each bit.
   1077  *
   1078  * Returns MPSSE_OK if direction could be set, MPSSE_FAIL otherwise.
   1079  */
   1080 int WritePins(struct mpsse_context* mpsse, uint8_t data) {
   1081   int retval = MPSSE_FAIL;
   1082 
   1083   if (is_valid_context(mpsse)) {
   1084     if (mpsse->mode == BITBANG) {
   1085       if (ftdi_write_data(&mpsse->ftdi, &data, 1) == 0) {
   1086         retval = MPSSE_OK;
   1087       }
   1088     }
   1089   }
   1090 
   1091   return retval;
   1092 }
   1093 
   1094 /*
   1095  * Reads the state of the chip's pins. For use in BITBANG mode only.
   1096  *
   1097  * @mpsse - MPSSE context pointer.
   1098  *
   1099  * Returns a byte with the corresponding pin's bits set to 1 or 0.
   1100  */
   1101 int ReadPins(struct mpsse_context* mpsse) {
   1102   uint8_t val = 0;
   1103 
   1104   if (is_valid_context(mpsse)) {
   1105     ftdi_read_pins((struct ftdi_context*)&mpsse->ftdi, (uint8_t*)&val);
   1106   }
   1107 
   1108   return (int)val;
   1109 }
   1110 
   1111 /*
   1112  * Checks if a specific pin is high or low. For use in BITBANG mode only.
   1113  *
   1114  * @mpsse - MPSSE context pointer.
   1115  * @pin   - The pin number.
   1116  * @state - The state of the pins, as returned by ReadPins.
   1117  *          If set to -1, ReadPins will automatically be called.
   1118  *
   1119  * Returns a 1 if the pin is high, 0 if the pin is low.
   1120  */
   1121 int PinState(struct mpsse_context* mpsse, int pin, int state) {
   1122   if (state == -1) {
   1123     state = ReadPins(mpsse);
   1124   }
   1125 
   1126   /* If not in bitbang mode, the specified pin should be one of GPIOLx. Convert
   1127    * these defines into an absolute pin number. */
   1128   if (mpsse->mode != BITBANG) {
   1129     pin += NUM_GPIOL_PINS;
   1130   }
   1131 
   1132   return ((state & (1 << pin)) >> pin);
   1133 }
   1134 
   1135 /*
   1136  * Places all I/O pins into a tristate mode.
   1137  *
   1138  * @mpsse - MPSSE context pointer.
   1139  *
   1140  * Returns MPSSE_OK on success, MPSSE_FAIL on failure.
   1141  */
   1142 int Tristate(struct mpsse_context* mpsse) {
   1143   uint8_t cmd[CMD_SIZE] = {0};
   1144 
   1145   /* Tristate the all I/O pins (FT232H only) */
   1146   cmd[0] = TRISTATE_IO;
   1147   cmd[1] = 0xFF;
   1148   cmd[2] = 0xFF;
   1149 
   1150   return raw_write(mpsse, cmd, sizeof(cmd));
   1151 }
   1152