asix-sigma: Pull out the logic-mode switching
Pull out the code which switches Sigma from the FPGA programming mode into Logic-Analyzer mode into separate function. Also, given the reply is only ever 3-byte long, do not allocate 32 byte big buffer, but only a 3-byte long one. Signed-off-by: Marek Vasut <marex@denx.de>
This commit is contained in:
parent
29b66a2eb0
commit
64fe661b87
|
@ -80,12 +80,6 @@ static const int32_t hwcaps[] = {
|
||||||
SR_CONF_LIMIT_SAMPLES,
|
SR_CONF_LIMIT_SAMPLES,
|
||||||
};
|
};
|
||||||
|
|
||||||
/* Initialize the logic analyzer mode. */
|
|
||||||
static uint8_t logic_mode_start[] = {
|
|
||||||
0x00, 0x40, 0x0f, 0x25, 0x35, 0x40,
|
|
||||||
0x2a, 0x3a, 0x40, 0x03, 0x20, 0x38,
|
|
||||||
};
|
|
||||||
|
|
||||||
static const char *sigma_firmware_files[] = {
|
static const char *sigma_firmware_files[] = {
|
||||||
/* 50 MHz, supports 8 bit fractions */
|
/* 50 MHz, supports 8 bit fractions */
|
||||||
FIRMWARE_DIR "/asix-sigma-50.fw",
|
FIRMWARE_DIR "/asix-sigma-50.fw",
|
||||||
|
@ -454,6 +448,37 @@ static int sigma_fpga_init_bitbang(struct dev_context *devc)
|
||||||
return SR_ERR_TIMEOUT;
|
return SR_ERR_TIMEOUT;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Configure the FPGA for logic-analyzer mode.
|
||||||
|
*/
|
||||||
|
static int sigma_fpga_init_la(struct dev_context *devc)
|
||||||
|
{
|
||||||
|
/* Initialize the logic analyzer mode. */
|
||||||
|
uint8_t logic_mode_start[] = {
|
||||||
|
0x00, 0x40, 0x0f, 0x25, 0x35, 0x40,
|
||||||
|
0x2a, 0x3a, 0x40, 0x03, 0x20, 0x38,
|
||||||
|
};
|
||||||
|
|
||||||
|
uint8_t result[3];
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
/* Initialize the logic analyzer mode. */
|
||||||
|
sigma_write(logic_mode_start, sizeof(logic_mode_start), devc);
|
||||||
|
|
||||||
|
/* Expect a 3 byte reply. */
|
||||||
|
ret = sigma_read(result, 3, devc);
|
||||||
|
if (ret != 3)
|
||||||
|
goto err;
|
||||||
|
|
||||||
|
if (result[0] != 0xa6 || result[1] != 0x55 || result[2] != 0xaa)
|
||||||
|
goto err;
|
||||||
|
|
||||||
|
return SR_OK;
|
||||||
|
err:
|
||||||
|
sr_err("Configuration failed. Invalid reply received.");
|
||||||
|
return SR_ERR;
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Read the firmware from a file and transform it into a series of bitbang
|
* Read the firmware from a file and transform it into a series of bitbang
|
||||||
* pulses used to program the FPGA. Note that the *bb_cmd must be free()'d
|
* pulses used to program the FPGA. Note that the *bb_cmd must be free()'d
|
||||||
|
@ -532,7 +557,6 @@ static int upload_firmware(int firmware_idx, struct dev_context *devc)
|
||||||
unsigned char *buf;
|
unsigned char *buf;
|
||||||
unsigned char pins;
|
unsigned char pins;
|
||||||
size_t buf_size;
|
size_t buf_size;
|
||||||
unsigned char result[32];
|
|
||||||
const char *firmware = sigma_firmware_files[firmware_idx];
|
const char *firmware = sigma_firmware_files[firmware_idx];
|
||||||
struct ftdi_context *ftdic = &devc->ftdic;
|
struct ftdi_context *ftdic = &devc->ftdic;
|
||||||
|
|
||||||
|
@ -592,16 +616,10 @@ static int upload_firmware(int firmware_idx, struct dev_context *devc)
|
||||||
while (sigma_read(&pins, 1, devc) == 1)
|
while (sigma_read(&pins, 1, devc) == 1)
|
||||||
;
|
;
|
||||||
|
|
||||||
/* Initialize the logic analyzer mode. */
|
/* Initialize the FPGA for logic-analyzer mode. */
|
||||||
sigma_write(logic_mode_start, sizeof(logic_mode_start), devc);
|
ret = sigma_fpga_init_la(devc);
|
||||||
|
if (ret != SR_OK)
|
||||||
/* Expect a 3 byte reply. */
|
return ret;
|
||||||
ret = sigma_read(result, 3, devc);
|
|
||||||
if (ret != 3 ||
|
|
||||||
result[0] != 0xa6 || result[1] != 0x55 || result[2] != 0xaa) {
|
|
||||||
sr_err("Configuration failed. Invalid reply received.");
|
|
||||||
return SR_ERR;
|
|
||||||
}
|
|
||||||
|
|
||||||
devc->cur_firmware = firmware_idx;
|
devc->cur_firmware = firmware_idx;
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue