scpi-pps: Add SR_CONF_REGULATION for HP 66xxA power supplies.

This commit is contained in:
Frank Stettner 2019-04-10 11:39:55 +02:00 committed by Uwe Hermann
parent dbc519f720
commit 0ad7074c9e
2 changed files with 20 additions and 2 deletions

View File

@ -459,6 +459,22 @@ static int config_get(uint32_t key, GVariant **data,
*data = g_variant_new_string("CC");
}
}
if (devc->device->dialect == SCPI_DIALECT_HP_COMP) {
/* Evaluate Status Register from a HP 66xx in COMP mode. */
s = g_variant_get_string(*data, NULL);
sr_atoi(s, &reg);
g_variant_unref(*data);
if (reg & (1 << 0))
*data = g_variant_new_string("CV");
else if (reg & (1 << 1))
*data = g_variant_new_string("CC");
else if (reg & (1 << 2))
*data = g_variant_new_string("UR");
else if (reg & (1 << 9))
*data = g_variant_new_string("CC-");
else
*data = g_variant_new_string("");
}
if (devc->device->dialect == SCPI_DIALECT_HP_66XXB) {
/* Evaluate Operational Status Register from a HP 66xxB. */
s = g_variant_get_string(*data, NULL);
@ -475,8 +491,8 @@ static int config_get(uint32_t key, GVariant **data,
}
s = g_variant_get_string(*data, NULL);
if (g_strcmp0(s, "CV") && g_strcmp0(s, "CC") &&
g_strcmp0(s, "CC-") && g_strcmp0(s, "UR")) {
if (g_strcmp0(s, "CV") && g_strcmp0(s, "CC") && g_strcmp0(s, "CC-") &&
g_strcmp0(s, "UR") && g_strcmp0(s, "")) {
sr_err("Unknown response to SCPI_CMD_GET_OUTPUT_REGULATION: %s", s);
ret = SR_ERR_DATA;

View File

@ -444,6 +444,7 @@ static const uint32_t hp_6630a_devopts_cg[] = {
SR_CONF_CURRENT_LIMIT | SR_CONF_SET | SR_CONF_LIST,
SR_CONF_OVER_VOLTAGE_PROTECTION_THRESHOLD | SR_CONF_SET | SR_CONF_LIST,
SR_CONF_OVER_CURRENT_PROTECTION_ENABLED | SR_CONF_SET,
SR_CONF_REGULATION | SR_CONF_GET,
};
static const struct channel_spec hp_6633a_ch[] = {
@ -464,6 +465,7 @@ static const struct scpi_command hp_6630a_cmd[] = {
{ SCPI_CMD_SET_OVER_CURRENT_PROTECTION_ENABLE, "OCP 1" },
{ SCPI_CMD_SET_OVER_CURRENT_PROTECTION_DISABLE, "OCP 0" },
{ SCPI_CMD_SET_OVER_VOLTAGE_PROTECTION_THRESHOLD, "OVSET %.4f" },
{ SCPI_CMD_GET_OUTPUT_REGULATION, "STS?" },
ALL_ZERO
};