flex6xxx add rfpower level

pull/1495/head
Warren Volz 2024-01-29 16:37:58 -07:00
rodzic 8d59c9302f
commit 9f6ca84572
1 zmienionych plików z 69 dodań i 3 usunięć

Wyświetl plik

@ -37,7 +37,7 @@
#define F6K_FUNC_ALL (RIG_FUNC_VOX|RIG_FUNC_TUNER)
#define F6K_LEVEL_ALL (RIG_LEVEL_SLOPE_HIGH|RIG_LEVEL_SLOPE_LOW|RIG_LEVEL_KEYSPD)
#define F6K_LEVEL_ALL (RIG_LEVEL_SLOPE_HIGH|RIG_LEVEL_SLOPE_LOW|RIG_LEVEL_KEYSPD|RIG_LEVEL_RFPOWER)
#define F6K_VFO (RIG_VFO_A|RIG_VFO_B)
#define POWERSDR_VFO_OP (RIG_OP_BAND_UP|RIG_OP_BAND_DOWN|RIG_OP_UP|RIG_OP_DOWN)
@ -738,6 +738,72 @@ int powersdr_set_level(RIG *rig, vfo_t vfo, setting_t level, value_t val)
return RIG_OK;
}
/*
* flex6k_get_level
*/
int flex6k_get_level(RIG *rig, vfo_t vfo, setting_t level, value_t *val)
{
char lvlbuf[KENWOOD_MAX_BUF_LEN];
char *cmd;
int retval;
int len, ans;
rmode_t mode;
pbwidth_t width;
ptt_t ptt;
double dval;
rig_debug(RIG_DEBUG_VERBOSE, "%s called\n", __func__);
if (!val)
{
return -RIG_EINVAL;
}
switch (level)
{
case RIG_LEVEL_RFPOWER:
cmd = "ZZPC";
len = 4;
ans = 3;
break;
default:
return kenwood_get_level(rig, vfo, level, val);
}
retval = kenwood_safe_transaction(rig, cmd, lvlbuf, sizeof(lvlbuf), len + ans);
if (retval != RIG_OK)
{
return retval;
}
int n;
switch (level)
{
case RIG_LEVEL_RFPOWER:
n = sscanf(lvlbuf, "ZZPC%f", &val->f);
if (n != 1)
{
rig_debug(RIG_DEBUG_ERR, "%s: Error parsing value from lvlbuf='%s'\n",
__func__, lvlbuf);
val->f = 0;
return -RIG_EPROTO;
}
val->f /= 100;
break;
default:
rig_debug(RIG_DEBUG_ERR, "%s: should never get here\n", __func__);
}
return RIG_OK;
}
/*
* powersdr_get_level
*/
@ -1241,7 +1307,7 @@ struct rig_caps f6k_caps =
RIG_MODEL(RIG_MODEL_F6K),
.model_name = "6xxx",
.mfg_name = "FlexRadio",
.version = "20230606.0",
.version = "20240129.0",
.copyright = "LGPL",
.status = RIG_STATUS_STABLE,
.rig_type = RIG_TYPE_TRANSCEIVER,
@ -1360,7 +1426,7 @@ struct rig_caps f6k_caps =
// TODO copy over kenwood_[set|get]_level and modify to handle DSP filter values
// correctly - use actual values instead of indices
.set_level = kenwood_set_level,
.get_level = kenwood_get_level,
.get_level = flex6k_get_level,
//.set_ant = kenwood_set_ant_no_ack,
//.get_ant = kenwood_get_ant,
.hamlib_check_rig_caps = HAMLIB_CHECK_RIG_CAPS