X-Git-Url: http://developer.intra2net.com/git/?p=libftdi;a=blobdiff_plain;f=examples%2Feeprom.c;h=247589a2b4caefbae41501634485cf5e79d0f8a5;hp=3b8d3a6f094e72cebcd6b238b79fc3ea734b65d7;hb=1b1bf7e481bc29ffac3b4c6a6da9eeff36beb1d0;hpb=fa457b38eb116eb3804de37170df70803accc4ff diff --git a/examples/eeprom.c b/examples/eeprom.c index 3b8d3a6..247589a 100644 --- a/examples/eeprom.c +++ b/examples/eeprom.c @@ -11,20 +11,76 @@ #include #include +int read_decode_eeprom(struct ftdi_context *ftdi) +{ + int i, j, f; + int value; + int size; + unsigned char buf[256]; + + f = ftdi_read_eeprom(ftdi); + if (f < 0) + { + fprintf(stderr, "ftdi_read_eeprom: %d (%s)\n", + f, ftdi_get_error_string(ftdi)); + return -1; + } + + + ftdi_get_eeprom_value(ftdi, CHIP_SIZE, & value); + if (value <0) + { + fprintf(stderr, "No EEPROM found or EEPROM empty\n"); + fprintf(stderr, "On empty EEPROM, use -w option to write default values\n"); + return -1; + } + fprintf(stderr, "Chip type %d ftdi_eeprom_size: %d\n", ftdi->type, value); + if (ftdi->type == TYPE_R) + size = 0xa0; + else + size = value; + ftdi_get_eeprom_buf(ftdi, buf, size); + for (i=0; i < size; i += 16) + { + fprintf(stdout,"0x%03x:", i); + + for (j = 0; j< 8; j++) + fprintf(stdout," %02x", buf[i+j]); + fprintf(stdout," "); + for (; j< 16; j++) + fprintf(stdout," %02x", buf[i+j]); + fprintf(stdout," "); + for (j = 0; j< 8; j++) + fprintf(stdout,"%c", isprint(buf[i+j])?buf[i+j]:'.'); + fprintf(stdout," "); + for (; j< 16; j++) + fprintf(stdout,"%c", isprint(buf[i+j])?buf[i+j]:'.'); + fprintf(stdout,"\n"); + } + + f = ftdi_eeprom_decode(ftdi, 1); + if (f < 0) + { + fprintf(stderr, "ftdi_eeprom_decode: %d (%s)\n", + f, ftdi_get_error_string(ftdi)); + return -1; + } + return 0; +} + int main(int argc, char **argv) { struct ftdi_context *ftdi; - unsigned char buf[256]; - int f, i, j; - int vid = 0x0403; - int pid = 0x6010; + int f, i; + int vid = 0; + int pid = 0; char const *desc = 0; char const *serial = 0; int erase = 0; int use_defaults = 0; int large_chip = 0; int do_write = 0; - int size; + int retval = 0; int value; if ((ftdi = ftdi_new()) == 0) @@ -74,29 +130,81 @@ int main(int argc, char **argv) "product description\n"); fprintf(stderr, "\t-S 1) + { + int i = 1; + fprintf(stderr, "%d FTDI devices found: Only Readout on EEPROM done. ",res); + fprintf(stderr, "Use VID/PID/desc/serial to select device\n"); + for (curdev = devlist; curdev != NULL; curdev= curdev->next, i++) + { + f = ftdi_usb_open_dev(ftdi, curdev->dev); + if (f<0) + { + fprintf(stderr, "Unable to open device %d: (%s)", + i, ftdi_get_error_string(ftdi)); + continue; + } + fprintf(stderr, "Decoded values of device %d:\n", i); + read_decode_eeprom(ftdi); + ftdi_usb_close(ftdi); + } + ftdi_list_free(&devlist); + retval = EXIT_SUCCESS; + goto do_deinit; + } + else if (res == 1) + { + f = ftdi_usb_open_dev(ftdi, devlist[0].dev); + if (f<0) + { + fprintf(stderr, "Unable to open device %d: (%s)", + i, ftdi_get_error_string(ftdi)); + } + } + else + { + fprintf(stderr, "No devices found\n"); + f = 0; + } + ftdi_list_free(&devlist); + } + else + { + // Open device + f = ftdi_usb_open_desc(ftdi, vid, pid, desc, serial); + if (f < 0) + { + fprintf(stderr, "Device VID 0x%04x PID 0x%04x", vid, pid); + if (desc) + fprintf(stderr, " Desc %s", desc); + if (serial) + fprintf(stderr, " Serial %s", serial); + fprintf(stderr, "\n"); + fprintf(stderr, "unable to open ftdi device: %d (%s)\n", + f, ftdi_get_error_string(ftdi)); + + retval = -1; + goto done; + } } - if (erase) { f = ftdi_erase_eeprom(ftdi); /* needed to determine EEPROM chip type */ @@ -104,7 +212,8 @@ int main(int argc, char **argv) { fprintf(stderr, "Erase failed: %s", ftdi_get_error_string(ftdi)); - return -2; + retval = -2; + goto done; } if (ftdi_get_eeprom_value(ftdi, CHIP_TYPE, & value) <0) { @@ -117,13 +226,13 @@ int main(int argc, char **argv) fprintf(stderr, "Internal EEPROM\n"); else fprintf(stderr, "Found 93x%02x\n", value); - return 0; + retval = 0; + goto done; } if (use_defaults) { - ftdi_eeprom_initdefaults(ftdi, "IKDA", "FTDIJTAG", "0001"); - ftdi_eeprom_initdefaults(ftdi, "IKDA", "FTDIJTAG", "0001"); + ftdi_eeprom_initdefaults(ftdi, NULL, NULL, NULL); if (ftdi_set_eeprom_value(ftdi, MAX_POWER, 500) <0) { fprintf(stderr, "ftdi_set_eeprom_value: %d (%s)\n", @@ -140,12 +249,13 @@ int main(int argc, char **argv) { fprintf(stderr, "ftdi_eeprom_build: %d (%s)\n", f, ftdi_get_error_string(ftdi)); - exit(-1); + retval = -1; + goto done; } } else if (do_write) { - ftdi_eeprom_initdefaults(ftdi, "IKDA", "FTDIJTAG", "0001"); + ftdi_eeprom_initdefaults(ftdi, NULL, NULL, NULL); f = ftdi_erase_eeprom(ftdi); if (ftdi_set_eeprom_value(ftdi, MAX_POWER, 500) <0) { @@ -169,64 +279,21 @@ int main(int argc, char **argv) { fprintf(stderr, "Erase failed: %s", ftdi_get_error_string(ftdi)); - return -2; + retval = -2; + goto done; } f = ftdi_write_eeprom(ftdi); { fprintf(stderr, "ftdi_eeprom_decode: %d (%s)\n", f, ftdi_get_error_string(ftdi)); - exit(-1); + retval = 1; + goto done; } } - f = ftdi_read_eeprom(ftdi); - if (f < 0) - { - fprintf(stderr, "ftdi_read_eeprom: %d (%s)\n", - f, ftdi_get_error_string(ftdi)); - exit(-1); - } - - - ftdi_get_eeprom_value(ftdi, CHIP_SIZE, & value); - if (value <0) - { - fprintf(stderr, "No EEPROM found\n"); - return -1; - - } - fprintf(stderr, "Chip type %d ftdi_eeprom_size: %d\n", ftdi->type, value); - if (ftdi->type == TYPE_R) - size = 0xa0; - else - size = value; - ftdi_get_eeprom_buf(ftdi, buf, size); - for (i=0; i < size; i += 16) - { - fprintf(stdout,"0x%03x:", i); - - for (j = 0; j< 8; j++) - fprintf(stdout," %02x", buf[i+j]); - fprintf(stdout," "); - for (; j< 16; j++) - fprintf(stdout," %02x", buf[i+j]); - fprintf(stdout," "); - for (j = 0; j< 8; j++) - fprintf(stdout,"%c", isprint(buf[i+j])?buf[i+j]:'.'); - fprintf(stdout," "); - for (; j< 16; j++) - fprintf(stdout,"%c", isprint(buf[i+j])?buf[i+j]:'.'); - fprintf(stdout,"\n"); - } - - f = ftdi_eeprom_decode(ftdi, 1); - if (f < 0) - { - fprintf(stderr, "ftdi_eeprom_decode: %d (%s)\n", - f, ftdi_get_error_string(ftdi)); - exit(-1); - } - + retval = read_decode_eeprom(ftdi); +done: ftdi_usb_close(ftdi); +do_deinit: ftdi_free(ftdi); - return 0; + return retval; }