>From 8f36c47d427ec073bbb6ccde02a584061a9a9406 Mon Sep 17 00:00:00 2001 From: Marc Schink <d...@zapb.de> Date: Wed, 12 Apr 2023 07:13:55 +0200 Subject: [PATCH] scpi-pps: Add support for R&S HMC8042
Signed-off-by: Marc Schink <d...@zapb.de> --- src/hardware/scpi-pps/profiles.c | 33 ++++++++++++++++++++++++++------ 1 file changed, 27 insertions(+), 6 deletions(-) diff --git a/src/hardware/scpi-pps/profiles.c b/src/hardware/scpi- pps/profiles.c index e947f744..b8101520 100644 --- a/src/hardware/scpi-pps/profiles.c +++ b/src/hardware/scpi-pps/profiles.c @@ -1206,13 +1206,13 @@ static const struct scpi_command philips_pm2800_cmd[] = { ALL_ZERO }; -static const uint32_t rs_hmc8043_devopts[] = { +static const uint32_t rs_hmc804x_devopts[] = { SR_CONF_CONTINUOUS, SR_CONF_LIMIT_SAMPLES | SR_CONF_GET | SR_CONF_SET, SR_CONF_LIMIT_MSEC | SR_CONF_GET | SR_CONF_SET, }; -static const uint32_t rs_hmc8043_devopts_cg[] = { +static const uint32_t rs_hmc804x_devopts_cg[] = { 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_THRESHOLD | SR_CONF_GET | SR_CONF_SET, @@ -1223,6 +1223,15 @@ static const uint32_t rs_hmc8043_devopts_cg[] = { SR_CONF_ENABLED | SR_CONF_GET | SR_CONF_SET, }; +static const struct channel_spec rs_hmc8042_ch[] = { + { "1", { 0, 32.050, 0.001, 3, 4 }, { 0.001, 5, 0.001, 3, 4 }, { 0, 0, 0, 0, 4 }, FREQ_DC_ONLY, NO_OVP_LIMITS, NO_OCP_LIMITS }, + { "2", { 0, 32.050, 0.001, 3, 4 }, { 0.001, 5, 0.001, 3, 4 }, { 0, 0, 0, 0, 4 }, FREQ_DC_ONLY, NO_OVP_LIMITS, NO_OCP_LIMITS }, +}; + +static const struct channel_group_spec rs_hmc8042_cg[] = { + { "1", CH_IDX(0), PPS_OVP, SR_MQFLAG_DC }, + { "2", CH_IDX(1), PPS_OVP, SR_MQFLAG_DC }, +}; static const struct channel_spec rs_hmc8043_ch[] = { { "1", { 0, 32.050, 0.001, 3, 4 }, { 0.001, 3, 0.001, 3, 4 }, { 0, 0, 0, 0, 4 }, FREQ_DC_ONLY, NO_OVP_LIMITS, NO_OCP_LIMITS }, { "2", { 0, 32.050, 0.001, 3, 4 }, { 0.001, 3, 0.001, 3, 4 }, { 0, 0, 0, 0, 4 }, FREQ_DC_ONLY, NO_OVP_LIMITS, NO_OCP_LIMITS }, @@ -1235,7 +1244,7 @@ static const struct channel_group_spec rs_hmc8043_cg[] = { { "3", CH_IDX(2), PPS_OVP, SR_MQFLAG_DC }, }; -static const struct scpi_command rs_hmc8043_cmd[] = { +static const struct scpi_command rs_hmc804x_cmd[] = { { SCPI_CMD_SELECT_CHANNEL, "INST:NSEL %s" }, { SCPI_CMD_GET_MEAS_VOLTAGE, "MEAS:VOLT?" }, { SCPI_CMD_GET_MEAS_CURRENT, "MEAS:CURR?" }, @@ -1695,13 +1704,25 @@ SR_PRIV const struct scpi_pps pps_profiles[] = { .update_status = NULL, }, + /* Rohde & Schwarz HMC8042 */ + { "Rohde&Schwarz", "HMC8042", SCPI_DIALECT_UNKNOWN, 0, + ARRAY_AND_SIZE(rs_hmc804x_devopts), + ARRAY_AND_SIZE(rs_hmc804x_devopts_cg), + ARRAY_AND_SIZE(rs_hmc8042_ch), + ARRAY_AND_SIZE(rs_hmc8042_cg), + rs_hmc804x_cmd, + .probe_channels = NULL, + .init_acquisition = NULL, + .update_status = NULL, + }, + /* Rohde & Schwarz HMC8043 */ { "Rohde&Schwarz", "HMC8043", SCPI_DIALECT_UNKNOWN, 0, - ARRAY_AND_SIZE(rs_hmc8043_devopts), - ARRAY_AND_SIZE(rs_hmc8043_devopts_cg), + ARRAY_AND_SIZE(rs_hmc804x_devopts), + ARRAY_AND_SIZE(rs_hmc804x_devopts_cg), ARRAY_AND_SIZE(rs_hmc8043_ch), ARRAY_AND_SIZE(rs_hmc8043_cg), - rs_hmc8043_cmd, + rs_hmc804x_cmd, .probe_channels = NULL, .init_acquisition = NULL, .update_status = NULL, -- 2.34.1 _______________________________________________ sigrok-devel mailing list sigrok-devel@lists.sourceforge.net https://lists.sourceforge.net/lists/listinfo/sigrok-devel