Made Linux jtagtap_init() more verbose on errors.

This commit is contained in:
Gareth McMullin 2011-02-07 13:08:45 +13:00
parent bb0981b22f
commit 5cc8ff5404
1 changed files with 39 additions and 8 deletions

View File

@ -83,8 +83,18 @@ static int buffer_read(uint8_t *data, int size)
int jtagtap_init(void) int jtagtap_init(void)
{ {
ftdi_init(&ftdic); int err;
ftdi_set_interface(&ftdic, INTERFACE_A);
if((err = ftdi_init(&ftdic)) != 0) {
fprintf(stderr, "ftdi_init: %d: %s\n",
err, ftdi_get_error_string(&ftdic));
abort();
}
if((err = ftdi_set_interface(&ftdic, INTERFACE_A)) != 0) {
fprintf(stderr, "ftdi_set_interface: %d: %s\n",
err, ftdi_get_error_string(&ftdic));
abort();
}
f = ftdi_usb_open(&ftdic, FT2232_VID, FT2232_PID); f = ftdi_usb_open(&ftdic, FT2232_VID, FT2232_PID);
if(f < 0 && f != -5) { if(f < 0 && f != -5) {
fprintf(stderr, "unable to open ftdi device: %d (%s)\n", fprintf(stderr, "unable to open ftdi device: %d (%s)\n",
@ -93,14 +103,35 @@ int jtagtap_init(void)
} }
fprintf(stderr, "ftdi open succeeded(channel 1): %d\n",f); fprintf(stderr, "ftdi open succeeded(channel 1): %d\n",f);
ftdi_set_latency_timer(&ftdic, 1); if((err = ftdi_set_latency_timer(&ftdic, 1)) != 0) {
ftdi_set_baudrate(&ftdic, 480000000); fprintf(stderr, "ftdi_set_latency_timer: %d: %s\n",
ftdi_usb_purge_buffers(&ftdic); err, ftdi_get_error_string(&ftdic));
abort();
}
if((err = ftdi_set_baudrate(&ftdic, 1000000)) != 0) {
fprintf(stderr, "ftdi_set_baudrate: %d: %s\n",
err, ftdi_get_error_string(&ftdic));
abort();
}
if((err = ftdi_usb_purge_buffers(&ftdic)) != 0) {
fprintf(stderr, "ftdi_set_baudrate: %d: %s\n",
err, ftdi_get_error_string(&ftdic));
abort();
}
if((err = ftdi_set_bitmode(&ftdic, 0xAB, BITMODE_MPSSE)) != 0) {
fprintf(stderr, "ftdi_set_bitmode: %d: %s\n",
err, ftdi_get_error_string(&ftdic));
abort();
}
fprintf(stderr, "enabling bitbang mode(channel 1)\n");
assert(ftdi_set_bitmode(&ftdic, 0xAB, BITMODE_MPSSE) == 0);
assert(ftdi_write_data(&ftdic, "\x86\x00\x00\x80\xA8\xAB", 6) == 6); assert(ftdi_write_data(&ftdic, "\x86\x00\x00\x80\xA8\xAB", 6) == 6);
ftdi_write_data_set_chunksize(&ftdic, BUF_SIZE);
if((err = ftdi_write_data_set_chunksize(&ftdic, BUF_SIZE)) != 0) {
fprintf(stderr, "ftdi_write_data_set_chunksize: %d: %s\n",
err, ftdi_get_error_string(&ftdic));
abort();
}
return 0; return 0;
} }