asix-sigma: Only change number of channels after successful firmware upload
The asix-sigma driver supports different samplerates, which will involve different firmware images and will affect the number of available logic channels as well as their memory layout in downloaded sample data. Make sure to only store the configuration's parameters after the setup of that configuration has successfully completed, and make sure to store a consistent set of parameters. Specifically don't change the number of channels when the firmware upload failed. This fixes part of bug #471. Suggested-By: Marian Cingel <cingel.marian@gmail.com>
This commit is contained in:
parent
7bcf21683e
commit
ac9534f48a
|
@ -554,6 +554,7 @@ SR_PRIV int sigma_set_samplerate(const struct sr_dev_inst *sdi, uint64_t sampler
|
||||||
struct drv_context *drvc;
|
struct drv_context *drvc;
|
||||||
size_t i;
|
size_t i;
|
||||||
int ret;
|
int ret;
|
||||||
|
int num_channels;
|
||||||
|
|
||||||
devc = sdi->priv;
|
devc = sdi->priv;
|
||||||
drvc = sdi->driver->context;
|
drvc = sdi->driver->context;
|
||||||
|
@ -572,15 +573,16 @@ SR_PRIV int sigma_set_samplerate(const struct sr_dev_inst *sdi, uint64_t sampler
|
||||||
* firmware is required and higher rates might limit the set
|
* firmware is required and higher rates might limit the set
|
||||||
* of available channels.
|
* of available channels.
|
||||||
*/
|
*/
|
||||||
|
num_channels = devc->num_channels;
|
||||||
if (samplerate <= SR_MHZ(50)) {
|
if (samplerate <= SR_MHZ(50)) {
|
||||||
ret = upload_firmware(drvc->sr_ctx, 0, devc);
|
ret = upload_firmware(drvc->sr_ctx, 0, devc);
|
||||||
devc->num_channels = 16;
|
num_channels = 16;
|
||||||
} else if (samplerate == SR_MHZ(100)) {
|
} else if (samplerate == SR_MHZ(100)) {
|
||||||
ret = upload_firmware(drvc->sr_ctx, 1, devc);
|
ret = upload_firmware(drvc->sr_ctx, 1, devc);
|
||||||
devc->num_channels = 8;
|
num_channels = 8;
|
||||||
} else if (samplerate == SR_MHZ(200)) {
|
} else if (samplerate == SR_MHZ(200)) {
|
||||||
ret = upload_firmware(drvc->sr_ctx, 2, devc);
|
ret = upload_firmware(drvc->sr_ctx, 2, devc);
|
||||||
devc->num_channels = 4;
|
num_channels = 4;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -589,6 +591,7 @@ SR_PRIV int sigma_set_samplerate(const struct sr_dev_inst *sdi, uint64_t sampler
|
||||||
* an "event" (memory organization internal to the device).
|
* an "event" (memory organization internal to the device).
|
||||||
*/
|
*/
|
||||||
if (ret == SR_OK) {
|
if (ret == SR_OK) {
|
||||||
|
devc->num_channels = num_channels;
|
||||||
devc->cur_samplerate = samplerate;
|
devc->cur_samplerate = samplerate;
|
||||||
devc->samples_per_event = 16 / devc->num_channels;
|
devc->samples_per_event = 16 / devc->num_channels;
|
||||||
devc->state.state = SIGMA_IDLE;
|
devc->state.state = SIGMA_IDLE;
|
||||||
|
|
Loading…
Reference in New Issue