rigol-ds: fix set_cfg() calls with float parameters to avoid locale issues
This commit is contained in:
parent
f76c24f6fd
commit
889ef4a01c
|
@ -552,6 +552,7 @@ static int config_set(int id, GVariant *data, const struct sr_dev_inst *sdi,
|
||||||
unsigned int i, j;
|
unsigned int i, j;
|
||||||
int ret;
|
int ret;
|
||||||
const char *tmp_str;
|
const char *tmp_str;
|
||||||
|
char buffer[16];
|
||||||
|
|
||||||
if (!(devc = sdi->priv))
|
if (!(devc = sdi->priv))
|
||||||
return SR_ERR_ARG;
|
return SR_ERR_ARG;
|
||||||
|
@ -586,14 +587,17 @@ static int config_set(int id, GVariant *data, const struct sr_dev_inst *sdi,
|
||||||
/* We have the trigger offset as a percentage of the frame, but
|
/* We have the trigger offset as a percentage of the frame, but
|
||||||
* need to express this in seconds. */
|
* need to express this in seconds. */
|
||||||
t_dbl = -(devc->horiz_triggerpos - 0.5) * devc->timebase * devc->num_timebases;
|
t_dbl = -(devc->horiz_triggerpos - 0.5) * devc->timebase * devc->num_timebases;
|
||||||
ret = set_cfg(sdi, ":TIM:OFFS %.6f", t_dbl);
|
g_ascii_formatd(buffer, sizeof(buffer), "%.6f", t_dbl);
|
||||||
|
ret = set_cfg(sdi, ":TIM:OFFS %s", buffer);
|
||||||
break;
|
break;
|
||||||
case SR_CONF_TIMEBASE:
|
case SR_CONF_TIMEBASE:
|
||||||
g_variant_get(data, "(tt)", &p, &q);
|
g_variant_get(data, "(tt)", &p, &q);
|
||||||
for (i = 0; i < devc->num_timebases; i++) {
|
for (i = 0; i < devc->num_timebases; i++) {
|
||||||
if (devc->timebases[i][0] == p && devc->timebases[i][1] == q) {
|
if (devc->timebases[i][0] == p && devc->timebases[i][1] == q) {
|
||||||
devc->timebase = (float)p / q;
|
devc->timebase = (float)p / q;
|
||||||
ret = set_cfg(sdi, ":TIM:SCAL %.9f", devc->timebase);
|
g_ascii_formatd(buffer, sizeof(buffer), "%.9f",
|
||||||
|
devc->timebase);
|
||||||
|
ret = set_cfg(sdi, ":TIM:SCAL %s", buffer);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -637,8 +641,10 @@ static int config_set(int id, GVariant *data, const struct sr_dev_inst *sdi,
|
||||||
if (vdivs[j][0] != p || vdivs[j][1] != q)
|
if (vdivs[j][0] != p || vdivs[j][1] != q)
|
||||||
continue;
|
continue;
|
||||||
devc->vdiv[i] = (float)p / q;
|
devc->vdiv[i] = (float)p / q;
|
||||||
return set_cfg(sdi, ":CHAN%d:SCAL %.3f", i + 1,
|
g_ascii_formatd(buffer, sizeof(buffer), "%.3f",
|
||||||
devc->vdiv[i]);
|
devc->vdiv[i]);
|
||||||
|
return set_cfg(sdi, ":CHAN%d:SCAL %s", i + 1,
|
||||||
|
buffer);
|
||||||
}
|
}
|
||||||
return SR_ERR_ARG;
|
return SR_ERR_ARG;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue