*/
int _read = 0, _erase = 0, _flash = 0;
- const int my_eeprom_size = 128; /* TODO: Kill this. Check with Uwe how we can determine the eeprom size properly
- because it's initialized with -1. Maybe assume 128 bytes per default? */
- unsigned char eeprom_buf[my_eeprom_size];
+ int my_eeprom_size = 0;
+ unsigned char eeprom_buf[FTDI_MAX_EEPROM_SIZE];
char *filename;
int size_check;
int i, argc_filename;
return EXIT_FAILURE;
}
- ftdi_eeprom_initdefaults (ftdi, "Acme Inc.", "FTDI Chip", NULL);
+ ftdi_eeprom_initdefaults (ftdi, cfg_getstr(cfg, "manufacturer"),
+ cfg_getstr(cfg, "product"),
+ cfg_getstr(cfg, "serial"));
eeprom_set_value(ftdi, VENDOR_ID, cfg_getint(cfg, "vendor_id"));
eeprom_set_value(ftdi, PRODUCT_ID, cfg_getint(cfg, "product_id"));
eeprom_set_value(ftdi, USB_VERSION, cfg_getint(cfg, "usb_version"));
- ftdi->eeprom->manufacturer = cfg_getstr(cfg, "manufacturer");
- ftdi->eeprom->product = cfg_getstr(cfg, "product");
- ftdi->eeprom->serial = cfg_getstr(cfg, "serial");
eeprom_set_value(ftdi, HIGH_CURRENT, cfg_getbool(cfg, "high_current"));
eeprom_set_value(ftdi, CBUS_FUNCTION_0, str_to_cbus(cfg_getstr(cfg, "cbus0"), 13));
eeprom_set_value(ftdi, CBUS_FUNCTION_1, str_to_cbus(cfg_getstr(cfg, "cbus1"), 13));
if (i == 0)
{
+ printf("FTDI read eeprom: %d\n", ftdi_read_eeprom(ftdi));
+ eeprom_get_value(ftdi, CHIP_SIZE, &my_eeprom_size);
// TODO: Do we know the eeprom size already?
- printf("EEPROM size: %d\n", ftdi->eeprom->size);
+ printf("EEPROM size: %d\n", my_eeprom_size);
}
else
{
if (_read > 0)
{
- printf("FTDI read eeprom: %d\n", ftdi_read_eeprom(ftdi));
ftdi_eeprom_decode(ftdi, 0);
/* Debug output */
fread(eeprom_buf, 1, my_eeprom_size, fp);
fclose(fp);
- /* TODO: Dirty hack. Create an API for this. How about ftdi_set_eeprom_buf()? */
- memcpy(ftdi->eeprom->buf, eeprom_buf, my_eeprom_size);
+ ftdi_set_eeprom_buf(ftdi, eeprom_buf, my_eeprom_size);
}
}
printf ("FTDI write eeprom: %d\n", ftdi_write_eeprom(ftdi));