Rename SR_CONF_OUTPUT_* to SR_CONF_*.
All those options are currently applied only to power-supplies but they could apply as well to electronic loads, except for the fact that electronic loads channels are called inputs and not outputs. Also when you think about an SMU (or any kind of 4-quadrants power-supply), their channels can both source and sink current, so they can be considered as input as much as output. Those SR_CONF_* are thus renamed so that they can be used in all those situations.
This commit is contained in:
parent
c1603f4574
commit
7a0b98b544
|
@ -758,51 +758,51 @@ enum sr_configkey {
|
||||||
SR_CONF_NUM_ANALOG_CHANNELS,
|
SR_CONF_NUM_ANALOG_CHANNELS,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Output voltage.
|
* Current voltage.
|
||||||
* @arg type: double
|
* @arg type: double
|
||||||
* @arg get: get measured output voltage
|
* @arg get: get measured voltage
|
||||||
*/
|
*/
|
||||||
SR_CONF_OUTPUT_VOLTAGE,
|
SR_CONF_VOLTAGE,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Maximum output voltage target.
|
* Maximum target voltage.
|
||||||
* @arg type: double
|
* @arg type: double
|
||||||
* @arg get: get output voltage target
|
* @arg get: get target voltage
|
||||||
* @arg set: change output voltage target
|
* @arg set: change target voltage
|
||||||
*/
|
*/
|
||||||
SR_CONF_OUTPUT_VOLTAGE_TARGET,
|
SR_CONF_VOLTAGE_TARGET,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Output current.
|
* Current current.
|
||||||
* @arg type: double
|
* @arg type: double
|
||||||
* @arg get: get measured output current
|
* @arg get: get measured current
|
||||||
*/
|
*/
|
||||||
SR_CONF_OUTPUT_CURRENT,
|
SR_CONF_CURRENT,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Output current limit.
|
* Current limit.
|
||||||
* @arg type: double
|
* @arg type: double
|
||||||
* @arg get: get output current limit
|
* @arg get: get current limit
|
||||||
* @arg set: change output current limit
|
* @arg set: change current limit
|
||||||
*/
|
*/
|
||||||
SR_CONF_OUTPUT_CURRENT_LIMIT,
|
SR_CONF_CURRENT_LIMIT,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Enabling/disabling output.
|
* Enabling/disabling channel.
|
||||||
* @arg type: boolean
|
* @arg type: boolean
|
||||||
* @arg get: @b true if currently enabled
|
* @arg get: @b true if currently enabled
|
||||||
* @arg set: enable/disable
|
* @arg set: enable/disable
|
||||||
*/
|
*/
|
||||||
SR_CONF_OUTPUT_ENABLED,
|
SR_CONF_ENABLED,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Output channel configuration.
|
* Channel configuration.
|
||||||
* @arg type: string
|
* @arg type: string
|
||||||
* @arg get: get current setting
|
* @arg get: get current setting
|
||||||
* @arg set: change current setting
|
* @arg set: change current setting
|
||||||
* @arg list: array of possible values
|
* @arg list: array of possible values
|
||||||
*/
|
*/
|
||||||
SR_CONF_OUTPUT_CHANNEL_CONFIG,
|
SR_CONF_CHANNEL_CONFIG,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Over-voltage protection (OVP) feature
|
* Over-voltage protection (OVP) feature
|
||||||
|
@ -839,7 +839,7 @@ enum sr_configkey {
|
||||||
/**
|
/**
|
||||||
* Over-current protection (OCP) active
|
* Over-current protection (OCP) active
|
||||||
* @arg type: boolean
|
* @arg type: boolean
|
||||||
* @arg get: @b true if device has activated OCP, i.e. the output current
|
* @arg get: @b true if device has activated OCP, i.e. the current current
|
||||||
* exceeds the over-current protection threshold.
|
* exceeds the over-current protection threshold.
|
||||||
*/
|
*/
|
||||||
SR_CONF_OVER_CURRENT_PROTECTION_ACTIVE,
|
SR_CONF_OVER_CURRENT_PROTECTION_ACTIVE,
|
||||||
|
@ -859,11 +859,11 @@ enum sr_configkey {
|
||||||
SR_CONF_AMPLITUDE,
|
SR_CONF_AMPLITUDE,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Output channel regulation
|
* Channel regulation
|
||||||
* get: "CV", "CC" or "UR", denoting constant voltage, constant current
|
* get: "CV", "CC" or "UR", denoting constant voltage, constant current
|
||||||
* or unregulated.
|
* or unregulated.
|
||||||
*/
|
*/
|
||||||
SR_CONF_OUTPUT_REGULATION,
|
SR_CONF_REGULATION,
|
||||||
|
|
||||||
/** Over-temperature protection (OTP) */
|
/** Over-temperature protection (OTP) */
|
||||||
SR_CONF_OVER_TEMPERATURE_PROTECTION,
|
SR_CONF_OVER_TEMPERATURE_PROTECTION,
|
||||||
|
|
|
@ -42,16 +42,16 @@ static const uint32_t drvopts[] = {
|
||||||
|
|
||||||
static const uint32_t devopts[] = {
|
static const uint32_t devopts[] = {
|
||||||
SR_CONF_CONTINUOUS | SR_CONF_SET,
|
SR_CONF_CONTINUOUS | SR_CONF_SET,
|
||||||
SR_CONF_OUTPUT_CHANNEL_CONFIG | SR_CONF_GET | SR_CONF_SET | SR_CONF_LIST,
|
SR_CONF_CHANNEL_CONFIG | SR_CONF_GET | SR_CONF_SET | SR_CONF_LIST,
|
||||||
SR_CONF_OVER_CURRENT_PROTECTION_ENABLED | SR_CONF_GET | SR_CONF_SET,
|
SR_CONF_OVER_CURRENT_PROTECTION_ENABLED | SR_CONF_GET | SR_CONF_SET,
|
||||||
};
|
};
|
||||||
|
|
||||||
static const uint32_t devopts_cg[] = {
|
static const uint32_t devopts_cg[] = {
|
||||||
SR_CONF_OUTPUT_VOLTAGE | SR_CONF_GET,
|
SR_CONF_VOLTAGE | SR_CONF_GET,
|
||||||
SR_CONF_OUTPUT_VOLTAGE_TARGET | SR_CONF_GET | SR_CONF_SET | SR_CONF_LIST,
|
SR_CONF_VOLTAGE_TARGET | SR_CONF_GET | SR_CONF_SET | SR_CONF_LIST,
|
||||||
SR_CONF_OUTPUT_CURRENT | SR_CONF_GET,
|
SR_CONF_CURRENT | SR_CONF_GET,
|
||||||
SR_CONF_OUTPUT_CURRENT_LIMIT | SR_CONF_GET | SR_CONF_SET | SR_CONF_LIST,
|
SR_CONF_CURRENT_LIMIT | SR_CONF_GET | SR_CONF_SET | SR_CONF_LIST,
|
||||||
SR_CONF_OUTPUT_ENABLED | SR_CONF_GET | SR_CONF_SET,
|
SR_CONF_ENABLED | SR_CONF_GET | SR_CONF_SET,
|
||||||
};
|
};
|
||||||
|
|
||||||
static const char *channel_modes[] = {
|
static const char *channel_modes[] = {
|
||||||
|
@ -225,7 +225,7 @@ static int config_get(uint32_t key, GVariant **data, const struct sr_dev_inst *s
|
||||||
if (!cg) {
|
if (!cg) {
|
||||||
/* No channel group: global options. */
|
/* No channel group: global options. */
|
||||||
switch (key) {
|
switch (key) {
|
||||||
case SR_CONF_OUTPUT_CHANNEL_CONFIG:
|
case SR_CONF_CHANNEL_CONFIG:
|
||||||
*data = g_variant_new_string(channel_modes[devc->channel_mode]);
|
*data = g_variant_new_string(channel_modes[devc->channel_mode]);
|
||||||
break;
|
break;
|
||||||
case SR_CONF_OVER_CURRENT_PROTECTION_ENABLED:
|
case SR_CONF_OVER_CURRENT_PROTECTION_ENABLED:
|
||||||
|
@ -240,19 +240,19 @@ static int config_get(uint32_t key, GVariant **data, const struct sr_dev_inst *s
|
||||||
channel = ch->index;
|
channel = ch->index;
|
||||||
|
|
||||||
switch (key) {
|
switch (key) {
|
||||||
case SR_CONF_OUTPUT_VOLTAGE:
|
case SR_CONF_VOLTAGE:
|
||||||
*data = g_variant_new_double(devc->config[channel].output_voltage_last);
|
*data = g_variant_new_double(devc->config[channel].output_voltage_last);
|
||||||
break;
|
break;
|
||||||
case SR_CONF_OUTPUT_VOLTAGE_TARGET:
|
case SR_CONF_VOLTAGE_TARGET:
|
||||||
*data = g_variant_new_double(devc->config[channel].output_voltage_max);
|
*data = g_variant_new_double(devc->config[channel].output_voltage_max);
|
||||||
break;
|
break;
|
||||||
case SR_CONF_OUTPUT_CURRENT:
|
case SR_CONF_CURRENT:
|
||||||
*data = g_variant_new_double(devc->config[channel].output_current_last);
|
*data = g_variant_new_double(devc->config[channel].output_current_last);
|
||||||
break;
|
break;
|
||||||
case SR_CONF_OUTPUT_CURRENT_LIMIT:
|
case SR_CONF_CURRENT_LIMIT:
|
||||||
*data = g_variant_new_double(devc->config[channel].output_current_max);
|
*data = g_variant_new_double(devc->config[channel].output_current_max);
|
||||||
break;
|
break;
|
||||||
case SR_CONF_OUTPUT_ENABLED:
|
case SR_CONF_ENABLED:
|
||||||
*data = g_variant_new_boolean(devc->config[channel].output_enabled);
|
*data = g_variant_new_boolean(devc->config[channel].output_enabled);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
@ -296,7 +296,7 @@ static int config_set(uint32_t key, GVariant *data, const struct sr_dev_inst *sd
|
||||||
if (!cg) {
|
if (!cg) {
|
||||||
/* No channel group: global options. */
|
/* No channel group: global options. */
|
||||||
switch (key) {
|
switch (key) {
|
||||||
case SR_CONF_OUTPUT_CHANNEL_CONFIG:
|
case SR_CONF_CHANNEL_CONFIG:
|
||||||
sval = g_variant_get_string(data, NULL);
|
sval = g_variant_get_string(data, NULL);
|
||||||
if ((ival = find_str(sval, channel_modes,
|
if ((ival = find_str(sval, channel_modes,
|
||||||
ARRAY_SIZE(channel_modes))) == -1) {
|
ARRAY_SIZE(channel_modes))) == -1) {
|
||||||
|
@ -331,21 +331,21 @@ static int config_set(uint32_t key, GVariant *data, const struct sr_dev_inst *sd
|
||||||
channel = ch->index;
|
channel = ch->index;
|
||||||
|
|
||||||
switch (key) {
|
switch (key) {
|
||||||
case SR_CONF_OUTPUT_VOLTAGE_TARGET:
|
case SR_CONF_VOLTAGE_TARGET:
|
||||||
dval = g_variant_get_double(data);
|
dval = g_variant_get_double(data);
|
||||||
if (dval < 0 || dval > devc->model->channels[channel].voltage[1])
|
if (dval < 0 || dval > devc->model->channels[channel].voltage[1])
|
||||||
ret = SR_ERR_ARG;
|
ret = SR_ERR_ARG;
|
||||||
devc->config[channel].output_voltage_max = dval;
|
devc->config[channel].output_voltage_max = dval;
|
||||||
devc->config_dirty = TRUE;
|
devc->config_dirty = TRUE;
|
||||||
break;
|
break;
|
||||||
case SR_CONF_OUTPUT_CURRENT_LIMIT:
|
case SR_CONF_CURRENT_LIMIT:
|
||||||
dval = g_variant_get_double(data);
|
dval = g_variant_get_double(data);
|
||||||
if (dval < 0 || dval > devc->model->channels[channel].current[1])
|
if (dval < 0 || dval > devc->model->channels[channel].current[1])
|
||||||
ret = SR_ERR_ARG;
|
ret = SR_ERR_ARG;
|
||||||
devc->config[channel].output_current_max = dval;
|
devc->config[channel].output_current_max = dval;
|
||||||
devc->config_dirty = TRUE;
|
devc->config_dirty = TRUE;
|
||||||
break;
|
break;
|
||||||
case SR_CONF_OUTPUT_ENABLED:
|
case SR_CONF_ENABLED:
|
||||||
bval = g_variant_get_boolean(data);
|
bval = g_variant_get_boolean(data);
|
||||||
if (bval == devc->config[channel].output_enabled_set)
|
if (bval == devc->config[channel].output_enabled_set)
|
||||||
/* Nothing to do. */
|
/* Nothing to do. */
|
||||||
|
@ -395,7 +395,7 @@ static int config_list(uint32_t key, GVariant **data, const struct sr_dev_inst *
|
||||||
*data = g_variant_new_fixed_array(G_VARIANT_TYPE_UINT32,
|
*data = g_variant_new_fixed_array(G_VARIANT_TYPE_UINT32,
|
||||||
devopts, ARRAY_SIZE(devopts), sizeof(uint32_t));
|
devopts, ARRAY_SIZE(devopts), sizeof(uint32_t));
|
||||||
break;
|
break;
|
||||||
case SR_CONF_OUTPUT_CHANNEL_CONFIG:
|
case SR_CONF_CHANNEL_CONFIG:
|
||||||
if (devc->model->channel_modes == CHANMODE_INDEPENDENT) {
|
if (devc->model->channel_modes == CHANMODE_INDEPENDENT) {
|
||||||
/* The 1-channel models. */
|
/* The 1-channel models. */
|
||||||
*data = g_variant_new_strv(channel_modes, 1);
|
*data = g_variant_new_strv(channel_modes, 1);
|
||||||
|
@ -420,7 +420,7 @@ static int config_list(uint32_t key, GVariant **data, const struct sr_dev_inst *
|
||||||
*data = g_variant_new_fixed_array(G_VARIANT_TYPE_UINT32,
|
*data = g_variant_new_fixed_array(G_VARIANT_TYPE_UINT32,
|
||||||
devopts_cg, ARRAY_SIZE(devopts_cg), sizeof(uint32_t));
|
devopts_cg, ARRAY_SIZE(devopts_cg), sizeof(uint32_t));
|
||||||
break;
|
break;
|
||||||
case SR_CONF_OUTPUT_VOLTAGE_TARGET:
|
case SR_CONF_VOLTAGE_TARGET:
|
||||||
g_variant_builder_init(&gvb, G_VARIANT_TYPE_ARRAY);
|
g_variant_builder_init(&gvb, G_VARIANT_TYPE_ARRAY);
|
||||||
/* Min, max, step. */
|
/* Min, max, step. */
|
||||||
for (i = 0; i < 3; i++) {
|
for (i = 0; i < 3; i++) {
|
||||||
|
@ -429,7 +429,7 @@ static int config_list(uint32_t key, GVariant **data, const struct sr_dev_inst *
|
||||||
}
|
}
|
||||||
*data = g_variant_builder_end(&gvb);
|
*data = g_variant_builder_end(&gvb);
|
||||||
break;
|
break;
|
||||||
case SR_CONF_OUTPUT_CURRENT_LIMIT:
|
case SR_CONF_CURRENT_LIMIT:
|
||||||
g_variant_builder_init(&gvb, G_VARIANT_TYPE_ARRAY);
|
g_variant_builder_init(&gvb, G_VARIANT_TYPE_ARRAY);
|
||||||
/* Min, max, step. */
|
/* Min, max, step. */
|
||||||
for (i = 0; i < 3; i++) {
|
for (i = 0; i < 3; i++) {
|
||||||
|
|
|
@ -33,8 +33,8 @@ static const uint32_t scanopts[] = {
|
||||||
|
|
||||||
static const uint32_t devopts[] = {
|
static const uint32_t devopts[] = {
|
||||||
SR_CONF_POWER_SUPPLY,
|
SR_CONF_POWER_SUPPLY,
|
||||||
SR_CONF_OUTPUT_VOLTAGE | SR_CONF_SET,
|
SR_CONF_VOLTAGE | SR_CONF_SET,
|
||||||
SR_CONF_OUTPUT_CURRENT | SR_CONF_SET,
|
SR_CONF_CURRENT | SR_CONF_SET,
|
||||||
SR_CONF_OVER_CURRENT_PROTECTION_ENABLED | SR_CONF_SET,
|
SR_CONF_OVER_CURRENT_PROTECTION_ENABLED | SR_CONF_SET,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -128,7 +128,7 @@ static int config_set(uint32_t key, GVariant *data, const struct sr_dev_inst *sd
|
||||||
|
|
||||||
ret = SR_OK;
|
ret = SR_OK;
|
||||||
switch (key) {
|
switch (key) {
|
||||||
case SR_CONF_OUTPUT_VOLTAGE:
|
case SR_CONF_VOLTAGE:
|
||||||
dblval = g_variant_get_double(data);
|
dblval = g_variant_get_double(data);
|
||||||
if ((dblval < 0.0) || (dblval > 35.0)) {
|
if ((dblval < 0.0) || (dblval > 35.0)) {
|
||||||
sr_err("Voltage out of range (0 - 35.0)!");
|
sr_err("Voltage out of range (0 - 35.0)!");
|
||||||
|
@ -136,7 +136,7 @@ static int config_set(uint32_t key, GVariant *data, const struct sr_dev_inst *sd
|
||||||
}
|
}
|
||||||
ret = send_msg1(sdi, 'V', (int) (dblval * 10 + 0.5));
|
ret = send_msg1(sdi, 'V', (int) (dblval * 10 + 0.5));
|
||||||
break;
|
break;
|
||||||
case SR_CONF_OUTPUT_CURRENT:
|
case SR_CONF_CURRENT:
|
||||||
dblval = g_variant_get_double(data);
|
dblval = g_variant_get_double(data);
|
||||||
if ((dblval < 0.01) || (dblval > 2.55)) {
|
if ((dblval < 0.01) || (dblval > 2.55)) {
|
||||||
sr_err("Current out of range (0 - 2.55)!");
|
sr_err("Current out of range (0 - 2.55)!");
|
||||||
|
|
|
@ -44,11 +44,11 @@ static const uint32_t devopts[] = {
|
||||||
SR_CONF_LIMIT_SAMPLES | SR_CONF_GET | SR_CONF_SET,
|
SR_CONF_LIMIT_SAMPLES | SR_CONF_GET | SR_CONF_SET,
|
||||||
SR_CONF_LIMIT_MSEC | SR_CONF_GET | SR_CONF_SET,
|
SR_CONF_LIMIT_MSEC | SR_CONF_GET | SR_CONF_SET,
|
||||||
/* Device configuration */
|
/* Device configuration */
|
||||||
SR_CONF_OUTPUT_VOLTAGE | SR_CONF_GET,
|
SR_CONF_VOLTAGE | SR_CONF_GET,
|
||||||
SR_CONF_OUTPUT_VOLTAGE_TARGET | SR_CONF_GET | SR_CONF_SET | SR_CONF_LIST,
|
SR_CONF_VOLTAGE_TARGET | SR_CONF_GET | SR_CONF_SET | SR_CONF_LIST,
|
||||||
SR_CONF_OUTPUT_CURRENT | SR_CONF_GET,
|
SR_CONF_CURRENT | SR_CONF_GET,
|
||||||
SR_CONF_OUTPUT_CURRENT_LIMIT | SR_CONF_GET | SR_CONF_SET | SR_CONF_LIST,
|
SR_CONF_CURRENT_LIMIT | SR_CONF_GET | SR_CONF_SET | SR_CONF_LIST,
|
||||||
SR_CONF_OUTPUT_ENABLED | SR_CONF_GET | SR_CONF_SET,
|
SR_CONF_ENABLED | SR_CONF_GET | SR_CONF_SET,
|
||||||
};
|
};
|
||||||
|
|
||||||
/* Note: All models have one power supply output only. */
|
/* Note: All models have one power supply output only. */
|
||||||
|
@ -231,19 +231,19 @@ static int config_get(uint32_t key, GVariant **data, const struct sr_dev_inst *s
|
||||||
case SR_CONF_LIMIT_MSEC:
|
case SR_CONF_LIMIT_MSEC:
|
||||||
*data = g_variant_new_uint64(devc->limit_msec);
|
*data = g_variant_new_uint64(devc->limit_msec);
|
||||||
break;
|
break;
|
||||||
case SR_CONF_OUTPUT_VOLTAGE:
|
case SR_CONF_VOLTAGE:
|
||||||
*data = g_variant_new_double(devc->voltage);
|
*data = g_variant_new_double(devc->voltage);
|
||||||
break;
|
break;
|
||||||
case SR_CONF_OUTPUT_VOLTAGE_TARGET:
|
case SR_CONF_VOLTAGE_TARGET:
|
||||||
*data = g_variant_new_double(devc->voltage_max);
|
*data = g_variant_new_double(devc->voltage_max);
|
||||||
break;
|
break;
|
||||||
case SR_CONF_OUTPUT_CURRENT:
|
case SR_CONF_CURRENT:
|
||||||
*data = g_variant_new_double(devc->current);
|
*data = g_variant_new_double(devc->current);
|
||||||
break;
|
break;
|
||||||
case SR_CONF_OUTPUT_CURRENT_LIMIT:
|
case SR_CONF_CURRENT_LIMIT:
|
||||||
*data = g_variant_new_double(devc->current_max);
|
*data = g_variant_new_double(devc->current_max);
|
||||||
break;
|
break;
|
||||||
case SR_CONF_OUTPUT_ENABLED:
|
case SR_CONF_ENABLED:
|
||||||
*data = g_variant_new_boolean(devc->output_enabled);
|
*data = g_variant_new_boolean(devc->output_enabled);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
@ -278,7 +278,7 @@ static int config_set(uint32_t key, GVariant *data, const struct sr_dev_inst *sd
|
||||||
return SR_ERR_ARG;
|
return SR_ERR_ARG;
|
||||||
devc->limit_samples = g_variant_get_uint64(data);
|
devc->limit_samples = g_variant_get_uint64(data);
|
||||||
break;
|
break;
|
||||||
case SR_CONF_OUTPUT_VOLTAGE_TARGET:
|
case SR_CONF_VOLTAGE_TARGET:
|
||||||
dval = g_variant_get_double(data);
|
dval = g_variant_get_double(data);
|
||||||
if (dval < devc->model->voltage[0] || dval > devc->voltage_max_device)
|
if (dval < devc->model->voltage[0] || dval > devc->voltage_max_device)
|
||||||
return SR_ERR_ARG;
|
return SR_ERR_ARG;
|
||||||
|
@ -289,7 +289,7 @@ static int config_set(uint32_t key, GVariant *data, const struct sr_dev_inst *sd
|
||||||
return SR_ERR;
|
return SR_ERR;
|
||||||
devc->voltage_max = dval;
|
devc->voltage_max = dval;
|
||||||
break;
|
break;
|
||||||
case SR_CONF_OUTPUT_CURRENT_LIMIT:
|
case SR_CONF_CURRENT_LIMIT:
|
||||||
dval = g_variant_get_double(data);
|
dval = g_variant_get_double(data);
|
||||||
if (dval < devc->model->current[0] || dval > devc->current_max_device)
|
if (dval < devc->model->current[0] || dval > devc->current_max_device)
|
||||||
return SR_ERR_ARG;
|
return SR_ERR_ARG;
|
||||||
|
@ -300,7 +300,7 @@ static int config_set(uint32_t key, GVariant *data, const struct sr_dev_inst *sd
|
||||||
return SR_ERR;
|
return SR_ERR;
|
||||||
devc->current_max = dval;
|
devc->current_max = dval;
|
||||||
break;
|
break;
|
||||||
case SR_CONF_OUTPUT_ENABLED:
|
case SR_CONF_ENABLED:
|
||||||
bval = g_variant_get_boolean(data);
|
bval = g_variant_get_boolean(data);
|
||||||
if (bval == devc->output_enabled) /* Nothing to do. */
|
if (bval == devc->output_enabled) /* Nothing to do. */
|
||||||
break;
|
break;
|
||||||
|
@ -351,7 +351,7 @@ static int config_list(uint32_t key, GVariant **data, const struct sr_dev_inst *
|
||||||
*data = g_variant_new_fixed_array(G_VARIANT_TYPE_UINT32,
|
*data = g_variant_new_fixed_array(G_VARIANT_TYPE_UINT32,
|
||||||
devopts, ARRAY_SIZE(devopts), sizeof(uint32_t));
|
devopts, ARRAY_SIZE(devopts), sizeof(uint32_t));
|
||||||
break;
|
break;
|
||||||
case SR_CONF_OUTPUT_VOLTAGE_TARGET:
|
case SR_CONF_VOLTAGE_TARGET:
|
||||||
g_variant_builder_init(&gvb, G_VARIANT_TYPE_ARRAY);
|
g_variant_builder_init(&gvb, G_VARIANT_TYPE_ARRAY);
|
||||||
/* Min, max, step. */
|
/* Min, max, step. */
|
||||||
for (idx = 0; idx < 3; idx++) {
|
for (idx = 0; idx < 3; idx++) {
|
||||||
|
@ -364,7 +364,7 @@ static int config_list(uint32_t key, GVariant **data, const struct sr_dev_inst *
|
||||||
}
|
}
|
||||||
*data = g_variant_builder_end(&gvb);
|
*data = g_variant_builder_end(&gvb);
|
||||||
break;
|
break;
|
||||||
case SR_CONF_OUTPUT_CURRENT_LIMIT:
|
case SR_CONF_CURRENT_LIMIT:
|
||||||
g_variant_builder_init(&gvb, G_VARIANT_TYPE_ARRAY);
|
g_variant_builder_init(&gvb, G_VARIANT_TYPE_ARRAY);
|
||||||
/* Min, max, step. */
|
/* Min, max, step. */
|
||||||
for (idx = 0; idx < 3; idx++) {
|
for (idx = 0; idx < 3; idx++) {
|
||||||
|
|
|
@ -63,22 +63,22 @@ static const uint32_t devopts[] = {
|
||||||
SR_CONF_LIMIT_SAMPLES | SR_CONF_GET | SR_CONF_SET,
|
SR_CONF_LIMIT_SAMPLES | SR_CONF_GET | SR_CONF_SET,
|
||||||
SR_CONF_LIMIT_MSEC | SR_CONF_GET | SR_CONF_SET,
|
SR_CONF_LIMIT_MSEC | SR_CONF_GET | SR_CONF_SET,
|
||||||
/* Device configuration */
|
/* Device configuration */
|
||||||
SR_CONF_OUTPUT_CHANNEL_CONFIG | SR_CONF_GET | SR_CONF_SET | SR_CONF_LIST,
|
SR_CONF_CHANNEL_CONFIG | SR_CONF_GET | SR_CONF_SET | SR_CONF_LIST,
|
||||||
};
|
};
|
||||||
|
|
||||||
/** Hardware capabilities channel 1, 2. */
|
/** Hardware capabilities channel 1, 2. */
|
||||||
static const uint32_t devopts_ch12[] = {
|
static const uint32_t devopts_ch12[] = {
|
||||||
SR_CONF_OUTPUT_VOLTAGE | SR_CONF_GET,
|
SR_CONF_VOLTAGE | SR_CONF_GET,
|
||||||
SR_CONF_OUTPUT_VOLTAGE_TARGET | SR_CONF_GET | SR_CONF_SET | SR_CONF_LIST,
|
SR_CONF_VOLTAGE_TARGET | SR_CONF_GET | SR_CONF_SET | SR_CONF_LIST,
|
||||||
SR_CONF_OUTPUT_CURRENT | SR_CONF_GET,
|
SR_CONF_CURRENT | SR_CONF_GET,
|
||||||
SR_CONF_OUTPUT_CURRENT_LIMIT | SR_CONF_GET | SR_CONF_SET | SR_CONF_LIST,
|
SR_CONF_CURRENT_LIMIT | SR_CONF_GET | SR_CONF_SET | SR_CONF_LIST,
|
||||||
SR_CONF_OUTPUT_ENABLED | SR_CONF_GET | SR_CONF_SET,
|
SR_CONF_ENABLED | SR_CONF_GET | SR_CONF_SET,
|
||||||
};
|
};
|
||||||
|
|
||||||
/** Hardware capabilities channel 3. (LPS-304/305 only). */
|
/** Hardware capabilities channel 3. (LPS-304/305 only). */
|
||||||
static const uint32_t devopts_ch3[] = {
|
static const uint32_t devopts_ch3[] = {
|
||||||
SR_CONF_OUTPUT_VOLTAGE | SR_CONF_GET,
|
SR_CONF_VOLTAGE | SR_CONF_GET,
|
||||||
SR_CONF_OUTPUT_ENABLED | SR_CONF_GET | SR_CONF_SET,
|
SR_CONF_ENABLED | SR_CONF_GET | SR_CONF_SET,
|
||||||
};
|
};
|
||||||
|
|
||||||
static const char *channel_modes[] = {
|
static const char *channel_modes[] = {
|
||||||
|
@ -561,7 +561,7 @@ static int config_get(uint32_t key, GVariant **data, const struct sr_dev_inst *s
|
||||||
case SR_CONF_LIMIT_MSEC:
|
case SR_CONF_LIMIT_MSEC:
|
||||||
*data = g_variant_new_uint64(devc->limit_msec);
|
*data = g_variant_new_uint64(devc->limit_msec);
|
||||||
break;
|
break;
|
||||||
case SR_CONF_OUTPUT_CHANNEL_CONFIG:
|
case SR_CONF_CHANNEL_CONFIG:
|
||||||
*data = g_variant_new_string(channel_modes[devc->tracking_mode]);
|
*data = g_variant_new_string(channel_modes[devc->tracking_mode]);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
@ -572,19 +572,19 @@ static int config_get(uint32_t key, GVariant **data, const struct sr_dev_inst *s
|
||||||
ch = cg->channels->data;
|
ch = cg->channels->data;
|
||||||
ch_idx = ch->index;
|
ch_idx = ch->index;
|
||||||
switch (key) {
|
switch (key) {
|
||||||
case SR_CONF_OUTPUT_VOLTAGE:
|
case SR_CONF_VOLTAGE:
|
||||||
*data = g_variant_new_double(devc->channel_status[ch_idx].output_voltage_last);
|
*data = g_variant_new_double(devc->channel_status[ch_idx].output_voltage_last);
|
||||||
break;
|
break;
|
||||||
case SR_CONF_OUTPUT_VOLTAGE_TARGET:
|
case SR_CONF_VOLTAGE_TARGET:
|
||||||
*data = g_variant_new_double(devc->channel_status[ch_idx].output_voltage_max);
|
*data = g_variant_new_double(devc->channel_status[ch_idx].output_voltage_max);
|
||||||
break;
|
break;
|
||||||
case SR_CONF_OUTPUT_CURRENT:
|
case SR_CONF_CURRENT:
|
||||||
*data = g_variant_new_double(devc->channel_status[ch_idx].output_current_last);
|
*data = g_variant_new_double(devc->channel_status[ch_idx].output_current_last);
|
||||||
break;
|
break;
|
||||||
case SR_CONF_OUTPUT_CURRENT_LIMIT:
|
case SR_CONF_CURRENT_LIMIT:
|
||||||
*data = g_variant_new_double(devc->channel_status[ch_idx].output_current_max);
|
*data = g_variant_new_double(devc->channel_status[ch_idx].output_current_max);
|
||||||
break;
|
break;
|
||||||
case SR_CONF_OUTPUT_ENABLED:
|
case SR_CONF_ENABLED:
|
||||||
*data = g_variant_new_boolean(devc->channel_status[ch_idx].output_enabled);
|
*data = g_variant_new_boolean(devc->channel_status[ch_idx].output_enabled);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
@ -626,7 +626,7 @@ static int config_set(uint32_t key, GVariant *data, const struct sr_dev_inst *sd
|
||||||
case SR_CONF_LIMIT_SAMPLES:
|
case SR_CONF_LIMIT_SAMPLES:
|
||||||
devc->limit_samples = g_variant_get_uint64(data);
|
devc->limit_samples = g_variant_get_uint64(data);
|
||||||
break;
|
break;
|
||||||
case SR_CONF_OUTPUT_CHANNEL_CONFIG:
|
case SR_CONF_CHANNEL_CONFIG:
|
||||||
sval = g_variant_get_string(data, NULL);
|
sval = g_variant_get_string(data, NULL);
|
||||||
found = FALSE;
|
found = FALSE;
|
||||||
for (idx = 0; idx < (int)ARRAY_SIZE(channel_modes); idx++) {
|
for (idx = 0; idx < (int)ARRAY_SIZE(channel_modes); idx++) {
|
||||||
|
@ -654,7 +654,7 @@ static int config_set(uint32_t key, GVariant *data, const struct sr_dev_inst *sd
|
||||||
ch_idx = ch->index;
|
ch_idx = ch->index;
|
||||||
|
|
||||||
switch (key) {
|
switch (key) {
|
||||||
case SR_CONF_OUTPUT_VOLTAGE_TARGET:
|
case SR_CONF_VOLTAGE_TARGET:
|
||||||
dval = g_variant_get_double(data);
|
dval = g_variant_get_double(data);
|
||||||
if (dval < 0 || dval > devc->model->channels[ch_idx].voltage[1])
|
if (dval < 0 || dval > devc->model->channels[ch_idx].voltage[1])
|
||||||
return SR_ERR_ARG;
|
return SR_ERR_ARG;
|
||||||
|
@ -675,7 +675,7 @@ static int config_set(uint32_t key, GVariant *data, const struct sr_dev_inst *sd
|
||||||
else
|
else
|
||||||
return lps_cmd_ok(sdi->conn, "VSET%d %05.3f", ch_idx+1, dval);
|
return lps_cmd_ok(sdi->conn, "VSET%d %05.3f", ch_idx+1, dval);
|
||||||
break;
|
break;
|
||||||
case SR_CONF_OUTPUT_CURRENT_LIMIT:
|
case SR_CONF_CURRENT_LIMIT:
|
||||||
dval = g_variant_get_double(data);
|
dval = g_variant_get_double(data);
|
||||||
if (dval < 0 || dval > devc->model->channels[ch_idx].current[1])
|
if (dval < 0 || dval > devc->model->channels[ch_idx].current[1])
|
||||||
return SR_ERR_ARG;
|
return SR_ERR_ARG;
|
||||||
|
@ -684,7 +684,7 @@ static int config_set(uint32_t key, GVariant *data, const struct sr_dev_inst *sd
|
||||||
devc->channel_status[ch_idx].output_current_max = dval;
|
devc->channel_status[ch_idx].output_current_max = dval;
|
||||||
return lps_cmd_ok(sdi->conn, "ISET%d %05.4f", ch_idx+1, dval);
|
return lps_cmd_ok(sdi->conn, "ISET%d %05.4f", ch_idx+1, dval);
|
||||||
break;
|
break;
|
||||||
case SR_CONF_OUTPUT_ENABLED:
|
case SR_CONF_ENABLED:
|
||||||
bval = g_variant_get_boolean(data);
|
bval = g_variant_get_boolean(data);
|
||||||
if (bval == devc->channel_status[ch_idx].output_enabled) /* Nothing to do. */
|
if (bval == devc->channel_status[ch_idx].output_enabled) /* Nothing to do. */
|
||||||
break;
|
break;
|
||||||
|
@ -742,7 +742,7 @@ static int config_list(uint32_t key, GVariant **data, const struct sr_dev_inst *
|
||||||
*data = g_variant_new_fixed_array(G_VARIANT_TYPE_UINT32,
|
*data = g_variant_new_fixed_array(G_VARIANT_TYPE_UINT32,
|
||||||
devopts, ARRAY_SIZE(devopts), sizeof(uint32_t));
|
devopts, ARRAY_SIZE(devopts), sizeof(uint32_t));
|
||||||
return SR_OK;
|
return SR_OK;
|
||||||
case SR_CONF_OUTPUT_CHANNEL_CONFIG:
|
case SR_CONF_CHANNEL_CONFIG:
|
||||||
if (devc->model->modelid <= LPS_303) {
|
if (devc->model->modelid <= LPS_303) {
|
||||||
/* The 1-channel models. */
|
/* The 1-channel models. */
|
||||||
*data = g_variant_new_strv(channel_modes, 1);
|
*data = g_variant_new_strv(channel_modes, 1);
|
||||||
|
@ -768,7 +768,7 @@ static int config_list(uint32_t key, GVariant **data, const struct sr_dev_inst *
|
||||||
*data = g_variant_new_fixed_array(G_VARIANT_TYPE_UINT32,
|
*data = g_variant_new_fixed_array(G_VARIANT_TYPE_UINT32,
|
||||||
devopts_ch3, ARRAY_SIZE(devopts_ch3), sizeof(uint32_t));
|
devopts_ch3, ARRAY_SIZE(devopts_ch3), sizeof(uint32_t));
|
||||||
break;
|
break;
|
||||||
case SR_CONF_OUTPUT_VOLTAGE_TARGET:
|
case SR_CONF_VOLTAGE_TARGET:
|
||||||
g_variant_builder_init(&gvb, G_VARIANT_TYPE_ARRAY);
|
g_variant_builder_init(&gvb, G_VARIANT_TYPE_ARRAY);
|
||||||
/* Min, max, step. */
|
/* Min, max, step. */
|
||||||
for (i = 0; i < 3; i++) {
|
for (i = 0; i < 3; i++) {
|
||||||
|
@ -777,7 +777,7 @@ static int config_list(uint32_t key, GVariant **data, const struct sr_dev_inst *
|
||||||
}
|
}
|
||||||
*data = g_variant_builder_end(&gvb);
|
*data = g_variant_builder_end(&gvb);
|
||||||
break;
|
break;
|
||||||
case SR_CONF_OUTPUT_CURRENT_LIMIT:
|
case SR_CONF_CURRENT_LIMIT:
|
||||||
g_variant_builder_init(&gvb, G_VARIANT_TYPE_ARRAY);
|
g_variant_builder_init(&gvb, G_VARIANT_TYPE_ARRAY);
|
||||||
/* Min, max, step. */
|
/* Min, max, step. */
|
||||||
for (i = 0; i < 3; i++) {
|
for (i = 0; i < 3; i++) {
|
||||||
|
|
|
@ -287,15 +287,15 @@ static int config_get(uint32_t key, GVariant **data, const struct sr_dev_inst *s
|
||||||
gvtype = NULL;
|
gvtype = NULL;
|
||||||
cmd = -1;
|
cmd = -1;
|
||||||
switch (key) {
|
switch (key) {
|
||||||
case SR_CONF_OUTPUT_ENABLED:
|
case SR_CONF_ENABLED:
|
||||||
gvtype = G_VARIANT_TYPE_BOOLEAN;
|
gvtype = G_VARIANT_TYPE_BOOLEAN;
|
||||||
cmd = SCPI_CMD_GET_OUTPUT_ENABLED;
|
cmd = SCPI_CMD_GET_OUTPUT_ENABLED;
|
||||||
break;
|
break;
|
||||||
case SR_CONF_OUTPUT_VOLTAGE:
|
case SR_CONF_VOLTAGE:
|
||||||
gvtype = G_VARIANT_TYPE_DOUBLE;
|
gvtype = G_VARIANT_TYPE_DOUBLE;
|
||||||
cmd = SCPI_CMD_GET_MEAS_VOLTAGE;
|
cmd = SCPI_CMD_GET_MEAS_VOLTAGE;
|
||||||
break;
|
break;
|
||||||
case SR_CONF_OUTPUT_VOLTAGE_TARGET:
|
case SR_CONF_VOLTAGE_TARGET:
|
||||||
gvtype = G_VARIANT_TYPE_DOUBLE;
|
gvtype = G_VARIANT_TYPE_DOUBLE;
|
||||||
cmd = SCPI_CMD_GET_VOLTAGE_TARGET;
|
cmd = SCPI_CMD_GET_VOLTAGE_TARGET;
|
||||||
break;
|
break;
|
||||||
|
@ -307,11 +307,11 @@ static int config_get(uint32_t key, GVariant **data, const struct sr_dev_inst *s
|
||||||
gvtype = G_VARIANT_TYPE_DOUBLE;
|
gvtype = G_VARIANT_TYPE_DOUBLE;
|
||||||
cmd = SCPI_CMD_GET_FREQUENCY_TARGET;
|
cmd = SCPI_CMD_GET_FREQUENCY_TARGET;
|
||||||
break;
|
break;
|
||||||
case SR_CONF_OUTPUT_CURRENT:
|
case SR_CONF_CURRENT:
|
||||||
gvtype = G_VARIANT_TYPE_DOUBLE;
|
gvtype = G_VARIANT_TYPE_DOUBLE;
|
||||||
cmd = SCPI_CMD_GET_MEAS_CURRENT;
|
cmd = SCPI_CMD_GET_MEAS_CURRENT;
|
||||||
break;
|
break;
|
||||||
case SR_CONF_OUTPUT_CURRENT_LIMIT:
|
case SR_CONF_CURRENT_LIMIT:
|
||||||
gvtype = G_VARIANT_TYPE_DOUBLE;
|
gvtype = G_VARIANT_TYPE_DOUBLE;
|
||||||
cmd = SCPI_CMD_GET_CURRENT_LIMIT;
|
cmd = SCPI_CMD_GET_CURRENT_LIMIT;
|
||||||
break;
|
break;
|
||||||
|
@ -343,7 +343,7 @@ static int config_get(uint32_t key, GVariant **data, const struct sr_dev_inst *s
|
||||||
gvtype = G_VARIANT_TYPE_BOOLEAN;
|
gvtype = G_VARIANT_TYPE_BOOLEAN;
|
||||||
cmd = SCPI_CMD_GET_OVER_TEMPERATURE_PROTECTION;
|
cmd = SCPI_CMD_GET_OVER_TEMPERATURE_PROTECTION;
|
||||||
break;
|
break;
|
||||||
case SR_CONF_OUTPUT_REGULATION:
|
case SR_CONF_REGULATION:
|
||||||
gvtype = G_VARIANT_TYPE_STRING;
|
gvtype = G_VARIANT_TYPE_STRING;
|
||||||
cmd = SCPI_CMD_GET_OUTPUT_REGULATION;
|
cmd = SCPI_CMD_GET_OUTPUT_REGULATION;
|
||||||
}
|
}
|
||||||
|
@ -375,13 +375,13 @@ static int config_set(uint32_t key, GVariant *data, const struct sr_dev_inst *sd
|
||||||
|
|
||||||
ret = SR_OK;
|
ret = SR_OK;
|
||||||
switch (key) {
|
switch (key) {
|
||||||
case SR_CONF_OUTPUT_ENABLED:
|
case SR_CONF_ENABLED:
|
||||||
if (g_variant_get_boolean(data))
|
if (g_variant_get_boolean(data))
|
||||||
ret = scpi_cmd(sdi, SCPI_CMD_SET_OUTPUT_ENABLE);
|
ret = scpi_cmd(sdi, SCPI_CMD_SET_OUTPUT_ENABLE);
|
||||||
else
|
else
|
||||||
ret = scpi_cmd(sdi, SCPI_CMD_SET_OUTPUT_DISABLE);
|
ret = scpi_cmd(sdi, SCPI_CMD_SET_OUTPUT_DISABLE);
|
||||||
break;
|
break;
|
||||||
case SR_CONF_OUTPUT_VOLTAGE_TARGET:
|
case SR_CONF_VOLTAGE_TARGET:
|
||||||
d = g_variant_get_double(data);
|
d = g_variant_get_double(data);
|
||||||
ret = scpi_cmd(sdi, SCPI_CMD_SET_VOLTAGE_TARGET, d);
|
ret = scpi_cmd(sdi, SCPI_CMD_SET_VOLTAGE_TARGET, d);
|
||||||
break;
|
break;
|
||||||
|
@ -389,7 +389,7 @@ static int config_set(uint32_t key, GVariant *data, const struct sr_dev_inst *sd
|
||||||
d = g_variant_get_double(data);
|
d = g_variant_get_double(data);
|
||||||
ret = scpi_cmd(sdi, SCPI_CMD_SET_FREQUENCY_TARGET, d);
|
ret = scpi_cmd(sdi, SCPI_CMD_SET_FREQUENCY_TARGET, d);
|
||||||
break;
|
break;
|
||||||
case SR_CONF_OUTPUT_CURRENT_LIMIT:
|
case SR_CONF_CURRENT_LIMIT:
|
||||||
d = g_variant_get_double(data);
|
d = g_variant_get_double(data);
|
||||||
ret = scpi_cmd(sdi, SCPI_CMD_SET_CURRENT_LIMIT, d);
|
ret = scpi_cmd(sdi, SCPI_CMD_SET_CURRENT_LIMIT, d);
|
||||||
break;
|
break;
|
||||||
|
@ -461,7 +461,7 @@ static int config_list(uint32_t key, GVariant **data, const struct sr_dev_inst *
|
||||||
devc->device->devopts, devc->device->num_devopts,
|
devc->device->devopts, devc->device->num_devopts,
|
||||||
sizeof(uint32_t));
|
sizeof(uint32_t));
|
||||||
break;
|
break;
|
||||||
case SR_CONF_OUTPUT_CHANNEL_CONFIG:
|
case SR_CONF_CHANNEL_CONFIG:
|
||||||
/* Not used. */
|
/* Not used. */
|
||||||
i = 0;
|
i = 0;
|
||||||
if (devc->device->features & PPS_INDEPENDENT)
|
if (devc->device->features & PPS_INDEPENDENT)
|
||||||
|
@ -498,7 +498,7 @@ static int config_list(uint32_t key, GVariant **data, const struct sr_dev_inst *
|
||||||
devc->device->devopts_cg, devc->device->num_devopts_cg,
|
devc->device->devopts_cg, devc->device->num_devopts_cg,
|
||||||
sizeof(uint32_t));
|
sizeof(uint32_t));
|
||||||
break;
|
break;
|
||||||
case SR_CONF_OUTPUT_VOLTAGE_TARGET:
|
case SR_CONF_VOLTAGE_TARGET:
|
||||||
ch_spec = &(devc->device->channels[ch->index]);
|
ch_spec = &(devc->device->channels[ch->index]);
|
||||||
g_variant_builder_init(&gvb, G_VARIANT_TYPE_ARRAY);
|
g_variant_builder_init(&gvb, G_VARIANT_TYPE_ARRAY);
|
||||||
/* Min, max, write resolution. */
|
/* Min, max, write resolution. */
|
||||||
|
@ -518,7 +518,7 @@ static int config_list(uint32_t key, GVariant **data, const struct sr_dev_inst *
|
||||||
}
|
}
|
||||||
*data = g_variant_builder_end(&gvb);
|
*data = g_variant_builder_end(&gvb);
|
||||||
break;
|
break;
|
||||||
case SR_CONF_OUTPUT_CURRENT_LIMIT:
|
case SR_CONF_CURRENT_LIMIT:
|
||||||
g_variant_builder_init(&gvb, G_VARIANT_TYPE_ARRAY);
|
g_variant_builder_init(&gvb, G_VARIANT_TYPE_ARRAY);
|
||||||
/* Min, max, step. */
|
/* Min, max, step. */
|
||||||
for (i = 0; i < 3; i++) {
|
for (i = 0; i < 3; i++) {
|
||||||
|
|
|
@ -149,18 +149,18 @@ static const uint32_t rigol_dp800_devopts[] = {
|
||||||
};
|
};
|
||||||
|
|
||||||
static const uint32_t rigol_dp800_devopts_cg[] = {
|
static const uint32_t rigol_dp800_devopts_cg[] = {
|
||||||
SR_CONF_OUTPUT_REGULATION | SR_CONF_GET,
|
SR_CONF_REGULATION | SR_CONF_GET,
|
||||||
SR_CONF_OVER_VOLTAGE_PROTECTION_ENABLED | SR_CONF_GET | SR_CONF_SET,
|
SR_CONF_OVER_VOLTAGE_PROTECTION_ENABLED | SR_CONF_GET | SR_CONF_SET,
|
||||||
SR_CONF_OVER_VOLTAGE_PROTECTION_ACTIVE | SR_CONF_GET,
|
SR_CONF_OVER_VOLTAGE_PROTECTION_ACTIVE | SR_CONF_GET,
|
||||||
SR_CONF_OVER_VOLTAGE_PROTECTION_THRESHOLD | SR_CONF_GET | SR_CONF_SET,
|
SR_CONF_OVER_VOLTAGE_PROTECTION_THRESHOLD | SR_CONF_GET | SR_CONF_SET,
|
||||||
SR_CONF_OVER_CURRENT_PROTECTION_ENABLED | SR_CONF_GET | SR_CONF_SET,
|
SR_CONF_OVER_CURRENT_PROTECTION_ENABLED | SR_CONF_GET | SR_CONF_SET,
|
||||||
SR_CONF_OVER_CURRENT_PROTECTION_ACTIVE | SR_CONF_GET,
|
SR_CONF_OVER_CURRENT_PROTECTION_ACTIVE | SR_CONF_GET,
|
||||||
SR_CONF_OVER_CURRENT_PROTECTION_THRESHOLD | SR_CONF_GET | SR_CONF_SET,
|
SR_CONF_OVER_CURRENT_PROTECTION_THRESHOLD | SR_CONF_GET | SR_CONF_SET,
|
||||||
SR_CONF_OUTPUT_VOLTAGE | SR_CONF_GET,
|
SR_CONF_VOLTAGE | SR_CONF_GET,
|
||||||
SR_CONF_OUTPUT_VOLTAGE_TARGET | SR_CONF_GET | SR_CONF_SET | SR_CONF_LIST,
|
SR_CONF_VOLTAGE_TARGET | SR_CONF_GET | SR_CONF_SET | SR_CONF_LIST,
|
||||||
SR_CONF_OUTPUT_CURRENT | SR_CONF_GET,
|
SR_CONF_CURRENT | SR_CONF_GET,
|
||||||
SR_CONF_OUTPUT_CURRENT_LIMIT | SR_CONF_GET | SR_CONF_SET | SR_CONF_LIST,
|
SR_CONF_CURRENT_LIMIT | SR_CONF_GET | SR_CONF_SET | SR_CONF_LIST,
|
||||||
SR_CONF_OUTPUT_ENABLED | SR_CONF_GET | SR_CONF_SET,
|
SR_CONF_ENABLED | SR_CONF_GET | SR_CONF_SET,
|
||||||
};
|
};
|
||||||
|
|
||||||
static const struct channel_spec rigol_dp821a_ch[] = {
|
static const struct channel_spec rigol_dp821a_ch[] = {
|
||||||
|
@ -229,11 +229,11 @@ static const struct scpi_command rigol_dp800_cmd[] = {
|
||||||
/* HP 663xx series */
|
/* HP 663xx series */
|
||||||
static const uint32_t hp_6632b_devopts[] = {
|
static const uint32_t hp_6632b_devopts[] = {
|
||||||
SR_CONF_CONTINUOUS | SR_CONF_SET,
|
SR_CONF_CONTINUOUS | SR_CONF_SET,
|
||||||
SR_CONF_OUTPUT_ENABLED | SR_CONF_GET | SR_CONF_SET,
|
SR_CONF_ENABLED | SR_CONF_GET | SR_CONF_SET,
|
||||||
SR_CONF_OUTPUT_VOLTAGE | SR_CONF_GET,
|
SR_CONF_VOLTAGE | SR_CONF_GET,
|
||||||
SR_CONF_OUTPUT_CURRENT | SR_CONF_GET,
|
SR_CONF_CURRENT | SR_CONF_GET,
|
||||||
SR_CONF_OUTPUT_VOLTAGE_TARGET | SR_CONF_GET | SR_CONF_SET | SR_CONF_LIST,
|
SR_CONF_VOLTAGE_TARGET | SR_CONF_GET | SR_CONF_SET | SR_CONF_LIST,
|
||||||
SR_CONF_OUTPUT_CURRENT_LIMIT | SR_CONF_GET | SR_CONF_SET | SR_CONF_LIST,
|
SR_CONF_CURRENT_LIMIT | SR_CONF_GET | SR_CONF_SET | SR_CONF_LIST,
|
||||||
};
|
};
|
||||||
|
|
||||||
static const struct channel_spec hp_6632b_ch[] = {
|
static const struct channel_spec hp_6632b_ch[] = {
|
||||||
|
@ -262,16 +262,16 @@ static const uint32_t philips_pm2800_devopts[] = {
|
||||||
};
|
};
|
||||||
|
|
||||||
static const uint32_t philips_pm2800_devopts_cg[] = {
|
static const uint32_t philips_pm2800_devopts_cg[] = {
|
||||||
SR_CONF_OUTPUT_ENABLED | SR_CONF_GET | SR_CONF_SET,
|
SR_CONF_ENABLED | SR_CONF_GET | SR_CONF_SET,
|
||||||
SR_CONF_OUTPUT_VOLTAGE | SR_CONF_GET,
|
SR_CONF_VOLTAGE | SR_CONF_GET,
|
||||||
SR_CONF_OUTPUT_VOLTAGE_TARGET | SR_CONF_GET | SR_CONF_SET | SR_CONF_LIST,
|
SR_CONF_VOLTAGE_TARGET | SR_CONF_GET | SR_CONF_SET | SR_CONF_LIST,
|
||||||
SR_CONF_OUTPUT_CURRENT | SR_CONF_GET,
|
SR_CONF_CURRENT | SR_CONF_GET,
|
||||||
SR_CONF_OUTPUT_CURRENT_LIMIT | SR_CONF_GET | SR_CONF_SET | SR_CONF_LIST,
|
SR_CONF_CURRENT_LIMIT | SR_CONF_GET | SR_CONF_SET | SR_CONF_LIST,
|
||||||
SR_CONF_OVER_VOLTAGE_PROTECTION_ACTIVE | SR_CONF_GET,
|
SR_CONF_OVER_VOLTAGE_PROTECTION_ACTIVE | SR_CONF_GET,
|
||||||
SR_CONF_OVER_VOLTAGE_PROTECTION_THRESHOLD | SR_CONF_GET | SR_CONF_SET,
|
SR_CONF_OVER_VOLTAGE_PROTECTION_THRESHOLD | SR_CONF_GET | SR_CONF_SET,
|
||||||
SR_CONF_OVER_CURRENT_PROTECTION_ENABLED | SR_CONF_GET | SR_CONF_SET,
|
SR_CONF_OVER_CURRENT_PROTECTION_ENABLED | SR_CONF_GET | SR_CONF_SET,
|
||||||
SR_CONF_OVER_CURRENT_PROTECTION_ACTIVE | SR_CONF_GET,
|
SR_CONF_OVER_CURRENT_PROTECTION_ACTIVE | SR_CONF_GET,
|
||||||
SR_CONF_OUTPUT_REGULATION | SR_CONF_GET,
|
SR_CONF_REGULATION | SR_CONF_GET,
|
||||||
};
|
};
|
||||||
|
|
||||||
enum philips_pm2800_modules {
|
enum philips_pm2800_modules {
|
||||||
|
|
|
@ -125,18 +125,18 @@ static struct sr_config_info sr_config_info_data[] = {
|
||||||
"Number of logic channels", NULL},
|
"Number of logic channels", NULL},
|
||||||
{SR_CONF_NUM_ANALOG_CHANNELS, SR_T_INT32, "analog_channels",
|
{SR_CONF_NUM_ANALOG_CHANNELS, SR_T_INT32, "analog_channels",
|
||||||
"Number of analog channels", NULL},
|
"Number of analog channels", NULL},
|
||||||
{SR_CONF_OUTPUT_VOLTAGE, SR_T_FLOAT, "output_voltage",
|
{SR_CONF_VOLTAGE, SR_T_FLOAT, "voltage",
|
||||||
"Current output voltage", NULL},
|
"Current voltage", NULL},
|
||||||
{SR_CONF_OUTPUT_VOLTAGE_TARGET, SR_T_FLOAT, "output_voltage_target",
|
{SR_CONF_VOLTAGE_TARGET, SR_T_FLOAT, "voltage_target",
|
||||||
"Output voltage target", NULL},
|
"Voltage target", NULL},
|
||||||
{SR_CONF_OUTPUT_CURRENT, SR_T_FLOAT, "output_current",
|
{SR_CONF_CURRENT, SR_T_FLOAT, "current",
|
||||||
"Current output current", NULL},
|
"Current current", NULL},
|
||||||
{SR_CONF_OUTPUT_CURRENT_LIMIT, SR_T_FLOAT, "output_current_limit",
|
{SR_CONF_CURRENT_LIMIT, SR_T_FLOAT, "current_limit",
|
||||||
"Output current limit", NULL},
|
"Current limit", NULL},
|
||||||
{SR_CONF_OUTPUT_ENABLED, SR_T_BOOL, "output_enabled",
|
{SR_CONF_ENABLED, SR_T_BOOL, "enabled",
|
||||||
"Output enabled", NULL},
|
"Channel enabled", NULL},
|
||||||
{SR_CONF_OUTPUT_CHANNEL_CONFIG, SR_T_STRING, "output_channel_config",
|
{SR_CONF_CHANNEL_CONFIG, SR_T_STRING, "channel_config",
|
||||||
"Output channel modes", NULL},
|
"Channel modes", NULL},
|
||||||
{SR_CONF_OVER_VOLTAGE_PROTECTION_ENABLED, SR_T_BOOL, "ovp_enabled",
|
{SR_CONF_OVER_VOLTAGE_PROTECTION_ENABLED, SR_T_BOOL, "ovp_enabled",
|
||||||
"Over-voltage protection enabled", NULL},
|
"Over-voltage protection enabled", NULL},
|
||||||
{SR_CONF_OVER_VOLTAGE_PROTECTION_ACTIVE, SR_T_BOOL, "ovp_active",
|
{SR_CONF_OVER_VOLTAGE_PROTECTION_ACTIVE, SR_T_BOOL, "ovp_active",
|
||||||
|
@ -153,8 +153,8 @@ static struct sr_config_info sr_config_info_data[] = {
|
||||||
"Clock edge", NULL},
|
"Clock edge", NULL},
|
||||||
{SR_CONF_AMPLITUDE, SR_T_FLOAT, "amplitude",
|
{SR_CONF_AMPLITUDE, SR_T_FLOAT, "amplitude",
|
||||||
"Amplitude", NULL},
|
"Amplitude", NULL},
|
||||||
{SR_CONF_OUTPUT_REGULATION, SR_T_STRING, "output_regulation",
|
{SR_CONF_REGULATION, SR_T_STRING, "regulation",
|
||||||
"Output channel regulation", NULL},
|
"Channel regulation", NULL},
|
||||||
{SR_CONF_OVER_TEMPERATURE_PROTECTION, SR_T_BOOL, "otp",
|
{SR_CONF_OVER_TEMPERATURE_PROTECTION, SR_T_BOOL, "otp",
|
||||||
"Over-temperature protection", NULL},
|
"Over-temperature protection", NULL},
|
||||||
{SR_CONF_OUTPUT_FREQUENCY, SR_T_FLOAT, "output_frequency",
|
{SR_CONF_OUTPUT_FREQUENCY, SR_T_FLOAT, "output_frequency",
|
||||||
|
|
Loading…
Reference in New Issue