Merge pull request #954 from rn3kk/master

Kenwood TS-590. Work get_level for ATT/Preamp state
pull/955/head
Michael Black 2022-02-05 08:16:22 -06:00 zatwierdzone przez GitHub
commit 9c60d1b9a0
Nie znaleziono w bazie danych klucza dla tego podpisu
ID klucza GPG: 4AEE18F83AFDEB23
1 zmienionych plików z 51 dodań i 0 usunięć

Wyświetl plik

@ -469,6 +469,7 @@ int ts590_get_level(RIG *rig, vfo_t vfo, setting_t level, value_t *val)
int retval;
char lvlbuf[50];
rig_debug(RIG_DEBUG_VERBOSE, "%s called\n", __func__);
switch (level)
@ -568,6 +569,56 @@ int ts590_get_level(RIG *rig, vfo_t vfo, setting_t level, value_t *val)
sscanf(lvlbuf + 3, "%d", &val->i);
return retval;
case RIG_LEVEL_PREAMP:
retval = kenwood_transaction(rig, "PA", lvlbuf, sizeof(lvlbuf));
if (retval != RIG_OK)
{
RETURNFUNC(retval);
}
if (lvlbuf[2] == '0')
{
val->i = 0;
}
else if (lvlbuf[2] == '1')
{
val->i = rig->state.preamp[0];
}
else
{
rig_debug(RIG_DEBUG_ERR, "%s: "
"unexpected preamp char '%c'\n",
__func__, lvlbuf[2]);
RETURNFUNC(-RIG_EPROTO);
}
return retval;
case RIG_LEVEL_ATT:
retval = kenwood_transaction(rig, "RA", lvlbuf, sizeof(lvlbuf));
if (retval != RIG_OK)
{
RETURNFUNC(retval);
}
if (lvlbuf[3] == '0')
{
val->i = 0;
}
else if (lvlbuf[3] == '1')
{
val->i = rig->state.attenuator[0];
}
else
{
rig_debug(RIG_DEBUG_ERR, "%s: "
"unexpected att char '%c'\n",
__func__, lvlbuf[2]);
RETURNFUNC(-RIG_EPROTO);
}
return retval;
case RIG_LEVEL_RAWSTR:
case RIG_LEVEL_STRENGTH:
retval = kenwood_transaction(rig, "SM0", lvlbuf, sizeof(lvlbuf));