Hamlib/amplifiers/elecraft/kpa.c

596 wiersze
14 KiB
C
Czysty Zwykły widok Historia

2019-06-12 20:52:35 +00:00
/*
* Hamlib Elecraft amplifier backend - low level communication routines
* Copyright (c) 2019 by Michael Black W9MDB
*
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*
*/
#include <stdlib.h>
#include <string.h>
#include "kpa.h"
struct fault_list
{
2019-11-30 16:19:08 +00:00
int code;
char *errmsg;
2019-06-12 20:52:35 +00:00
};
const struct fault_list kpa_fault_list [] =
{
2019-11-30 16:19:08 +00:00
{0, "No fault condition"},
{0x10, "Watchdog Timer was reset"},
{0x20, "PA Current is too high"},
{0x40, "Temperature is too high"},
{0x60, "Input power is too high"},
{0x61, "Gain is too low"},
{0x70, "Invalid frequency"},
{0x80, "50V supply voltage too low or too high"},
{0x81, "5V supply voltage too low or too high"},
{0x82, "10V supply voltage too low or too high"},
{0x83, "12V supply voltage too low or too high"},
{0x84, "-12V supply voltage too low or too high"},
{0x85, "5V or 400V LPF board supply voltages not detected"},
{0x90, "Reflected power is too high"},
{0x91, "SWR very high"},
{0x92, "ATU no match"},
{0xB0, "Dissipated power too high"},
{0xC0, "Forward power too high"},
{0xE0, "Forward power too high for current setting"},
{0xF0, "Gain is too high"},
{0, NULL}
2019-06-12 20:52:35 +00:00
};
/*
* Initialize data structures
*/
int kpa_init(AMP *amp)
{
2019-11-30 16:19:08 +00:00
struct kpa_priv_data *priv;
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
rig_debug(RIG_DEBUG_VERBOSE, "%s called\n", __func__);
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
if (!amp)
{
return -RIG_EINVAL;
}
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
priv = (struct kpa_priv_data *)
malloc(sizeof(struct kpa_priv_data));
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
if (!priv)
{
return -RIG_ENOMEM;
}
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
amp->state.priv = (void *)priv;
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
amp->state.ampport.type.rig = RIG_PORT_SERIAL;
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
return RIG_OK;
2019-06-12 20:52:35 +00:00
}
int kpa_flushbuffer(AMP *amp)
{
2019-11-30 16:19:08 +00:00
struct amp_state *rs;
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
rig_debug(RIG_DEBUG_VERBOSE, "%s called\n", __func__);
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
rs = &amp->state;
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
return serial_flush(&rs->ampport);
2019-06-12 20:52:35 +00:00
}
int kpa_transaction(AMP *amp, const char *cmd, char *response, int response_len)
{
2019-11-30 16:19:08 +00:00
struct amp_state *rs;
int err;
int len = 0;
char responsebuf[KPABUFSZ];
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
rig_debug(RIG_DEBUG_VERBOSE, "%s called, cmd=%s\n", __func__, cmd);
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
if (!amp) { return -RIG_EINVAL; }
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
kpa_flushbuffer(amp);
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
rs = &amp->state;
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
int loop = 3;
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
do // wake up the amp by sending ; until we receive ;
{
rig_debug(RIG_DEBUG_VERBOSE, "%s waiting for ;\n", __func__);
char c = ';';
err = write_block(&rs->ampport, &c, 1);
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
if (err != RIG_OK) { return err; }
2019-06-12 20:52:35 +00:00
len = read_string(&rs->ampport, responsebuf, KPABUFSZ, ";", 1);
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
if (len < 0) { return len; }
}
while (--loop > 0 && (len != 1 || responsebuf[0] != ';'));
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
// Now send our command
err = write_block(&rs->ampport, cmd, strlen(cmd));
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
if (err != RIG_OK) { return err; }
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
if (response) // if response expected get it
2019-06-12 20:52:35 +00:00
{
2019-11-30 16:19:08 +00:00
responsebuf[0] = 0;
int len = read_string(&rs->ampport, responsebuf, KPABUFSZ, ";", 1);
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
if (len < 0)
{
rig_debug(RIG_DEBUG_VERBOSE, "%s called, error=%s\n", __func__,
rigerror(len));
return len;
}
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
rig_debug(RIG_DEBUG_VERBOSE, "%s called, response='%s'\n", __func__,
responsebuf);
}
else // if no response expected try to get one
2019-06-12 20:52:35 +00:00
{
2019-11-30 16:19:08 +00:00
loop = 3;
do
{
rig_debug(RIG_DEBUG_VERBOSE, "%s waiting for ;\n", __func__);
char c = ';';
err = write_block(&rs->ampport, &c, 1);
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
if (err != RIG_OK) { return err; }
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
int len = read_string(&rs->ampport, responsebuf, KPABUFSZ, ";", 1);
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
if (len < 0) { return len; }
}
while (--loop > 0 && (len != 1 || responsebuf[0] != ';'));
2019-06-12 20:52:35 +00:00
}
2019-11-30 16:19:08 +00:00
return RIG_OK;
2019-06-12 20:52:35 +00:00
}
/*
* Get Info
* returns the model name string
*/
const char *kpa_get_info(AMP *amp)
{
2019-11-30 16:19:08 +00:00
const struct amp_caps *rc;
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
rig_debug(RIG_DEBUG_VERBOSE, "%s called\n", __func__);
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
if (!amp) { return (const char *) - RIG_EINVAL; }
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
rc = amp->caps;
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
return rc->model_name;
2019-06-12 20:52:35 +00:00
}
int kpa_get_freq(AMP *amp, freq_t *freq)
{
2019-11-30 16:19:08 +00:00
char responsebuf[KPABUFSZ];
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
rig_debug(RIG_DEBUG_VERBOSE, "%s called\n", __func__);
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
if (!amp) { return -RIG_EINVAL; }
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
int retval = kpa_transaction(amp, "^FR;", responsebuf, sizeof(responsebuf));
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
if (retval != RIG_OK) { return retval; }
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
unsigned long tfreq;
int nargs = sscanf(responsebuf, "^FR%lu", &tfreq);
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
if (nargs != 1)
{
rig_debug(RIG_DEBUG_VERBOSE, "%s Error: ^FR response='%s'\n", __func__,
responsebuf);
return -RIG_EPROTO;
}
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
*freq = tfreq * 1000;
return RIG_OK;
2019-06-12 20:52:35 +00:00
}
int kpa_set_freq(AMP *amp, freq_t freq)
{
2019-11-30 16:19:08 +00:00
char responsebuf[KPABUFSZ];
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
rig_debug(RIG_DEBUG_VERBOSE, "%s called, freq=%"PRIfreq"\n", __func__, freq);
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
if (!amp) { return -RIG_EINVAL; }
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
char cmd[KPABUFSZ];
sprintf(cmd, "^FR%05ld;", (long)freq / 1000);
int retval = kpa_transaction(amp, cmd, NULL, 0);
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
if (retval != RIG_OK) { return retval; }
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
unsigned long tfreq;
int nargs = sscanf(responsebuf, "^FR%lu", &tfreq);
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
if (nargs != 1)
{
rig_debug(RIG_DEBUG_ERR, "%s Error: ^FR response='%s'\n", __func__,
responsebuf);
return -RIG_EPROTO;
}
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
if (tfreq * 1000 != freq)
{
rig_debug(RIG_DEBUG_ERR,
"%s Error setting freq: ^FR freq!=freq2, %f=%ld '%s'\n", __func__,
freq, tfreq * 1000, responsebuf);
return -RIG_EPROTO;
}
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
return RIG_OK;
2019-06-12 20:52:35 +00:00
}
int kpa_get_level(AMP *amp, setting_t level, value_t *val)
{
2019-11-30 16:19:08 +00:00
char responsebuf[KPABUFSZ];
char *cmd;
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
rig_debug(RIG_DEBUG_VERBOSE, "%s called\n", __func__);
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
if (!amp) { return -RIG_EINVAL; }
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
// get the current antenna selected
cmd = "^AE;";
int retval = kpa_transaction(amp, cmd, responsebuf, sizeof(responsebuf));
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
if (retval != RIG_OK) { return retval; }
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
int antenna = 0;
int nargs = sscanf(responsebuf, "^AE%d", &antenna);
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
if (nargs != 1)
{
rig_debug(RIG_DEBUG_ERR, "%s: invalid value %s='%s'\n", __func__, cmd,
responsebuf);
return -RIG_EPROTO;
}
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
rig_debug(RIG_DEBUG_VERBOSE, "%s: cmd=%s, antenna=%d\n", __func__, cmd,
antenna);
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
switch (level)
{
case AMP_LEVEL_SWR:
cmd = "^SW;";
break;
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
case AMP_LEVEL_NH:
cmd = "^DF;";
break;
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
case AMP_LEVEL_PF:
cmd = "^DF;";
break;
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
case AMP_LEVEL_PWR_INPUT:
cmd = "^PWI;";
break;
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
case AMP_LEVEL_PWR_FWD:
cmd = "^PWF;";
break;
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
case AMP_LEVEL_PWR_REFLECTED:
cmd = "^PWR;";
break;
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
case AMP_LEVEL_PWR_PEAK:
cmd = "^PWK;";
break;
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
case AMP_LEVEL_FAULT:
cmd = "^SF;";
break;
}
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
retval = kpa_transaction(amp, cmd, responsebuf, sizeof(responsebuf));
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
if (retval != RIG_OK) { return retval; }
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
float float_value = 0;
int int_value = 0, int_value2 = 0;
struct amp_state *rs = &amp->state;
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
switch (level)
2019-06-12 20:52:35 +00:00
{
2019-11-30 16:19:08 +00:00
case AMP_LEVEL_SWR:
nargs = sscanf(responsebuf, "^SW%f", &float_value);
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
if (nargs != 1)
{
rig_debug(RIG_DEBUG_ERR, "%s invalid value %s='%s'\n", __func__, cmd,
responsebuf);
return -RIG_EPROTO;
}
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
val->f = float_value / 10.0f;
return RIG_OK;
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
case AMP_LEVEL_NH:
case AMP_LEVEL_PF:
nargs = sscanf(responsebuf, "^DF%d,%d", &int_value, &int_value2);
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
if (nargs != 2)
{
rig_debug(RIG_DEBUG_ERR, "%s invalid value %s='%s'\n", __func__, cmd,
responsebuf);
return -RIG_EPROTO;
}
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
rig_debug(RIG_DEBUG_VERBOSE, "%s freq range=%dKHz,%dKHz\n", __func__,
int_value, int_value2);
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
//
do
2019-06-12 20:52:35 +00:00
{
2019-11-30 16:19:08 +00:00
retval = read_string(&rs->ampport, responsebuf, sizeof(responsebuf), ";", 1);
if (retval != RIG_OK) { return retval; }
if (strstr(responsebuf, "BYPASS") != 0)
{
int antenna2 = 0;
nargs = sscanf(responsebuf, "AN%d Side TX %d %*s %*s %d", &antenna2, &int_value,
&int_value2);
rig_debug(RIG_DEBUG_VERBOSE, "%s response='%s'\n", __func__, responsebuf);
if (nargs != 3)
{
rig_debug(RIG_DEBUG_ERR, "%s invalid value %s='%s'\n", __func__, cmd,
responsebuf);
return -RIG_EPROTO;
}
rig_debug(RIG_DEBUG_VERBOSE, "%s antenna=%d,nH=%d\n", __func__, antenna2,
int_value);
val->i = level == AMP_LEVEL_NH ? int_value : int_value2;
return RIG_OK;
}
2019-06-12 20:52:35 +00:00
}
2019-11-30 16:19:08 +00:00
while (strstr(responsebuf, "BYPASS"));
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
break;
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
case AMP_LEVEL_PWR_INPUT:
cmd = "^PWI;";
int pwrinput;
nargs = sscanf(responsebuf, "^SW%d", &pwrinput);
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
if (nargs != 1)
{
rig_debug(RIG_DEBUG_ERR, "%s invalid value %s='%s'\n", __func__, cmd,
responsebuf);
return -RIG_EPROTO;
}
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
val->i = pwrinput;
return RIG_OK;
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
break;
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
case AMP_LEVEL_PWR_FWD:
cmd = "^PWF;";
int pwrfwd;
nargs = sscanf(responsebuf, "^SW%d", &pwrfwd);
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
if (nargs != 1)
{
rig_debug(RIG_DEBUG_ERR, "%s invalid value %s='%s'\n", __func__, cmd,
responsebuf);
return -RIG_EPROTO;
}
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
val->i = pwrfwd;
return RIG_OK;
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
break;
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
case AMP_LEVEL_PWR_REFLECTED:
cmd = "^PWR;";
int pwrref;
nargs = sscanf(responsebuf, "^SW%d", &pwrref);
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
if (nargs != 1)
{
rig_debug(RIG_DEBUG_ERR, "%s invalid value %s='%s'\n", __func__, cmd,
responsebuf);
return -RIG_EPROTO;
}
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
val->i = pwrref;
return RIG_OK;
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
break;
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
case AMP_LEVEL_PWR_PEAK:
cmd = "^PWK;";
int pwrpeak;
nargs = sscanf(responsebuf, "^SW%d", &pwrpeak);
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
if (nargs != 1)
{
rig_debug(RIG_DEBUG_ERR, "%s invalid value %s='%s'\n", __func__, cmd,
responsebuf);
return -RIG_EPROTO;
}
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
val->i = pwrpeak;
return RIG_OK;
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
break;
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
case AMP_LEVEL_FAULT:
cmd = "^SF;";
int fault;
nargs = sscanf(responsebuf, "^SW%d", &fault);
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
if (nargs != 1)
{
rig_debug(RIG_DEBUG_ERR, "%s invalid value %s='%s'\n", __func__, cmd,
responsebuf);
return -RIG_EPROTO;
}
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
int i;
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
for (i = 0; kpa_fault_list[i].errmsg != NULL; ++i)
{
if (kpa_fault_list[i].code == fault)
{
val->s = kpa_fault_list[i].errmsg;
return RIG_OK;
}
}
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
rig_debug(RIG_DEBUG_ERR, "%s unknown fault from %s\n", __func__, responsebuf);
struct kpa_priv_data *priv = amp->state.priv;
sprintf(priv->tmpbuf, "Unknown fault code=0x%02x", fault);
val->s = priv->tmpbuf;
2019-06-12 20:52:35 +00:00
return RIG_OK;
2019-11-30 16:19:08 +00:00
break;
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
default:
rig_debug(RIG_DEBUG_ERR, "%s unknown level=%s\n", __func__,
rig_strlevel(level));
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
}
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
return -RIG_EINVAL;
2019-06-12 20:52:35 +00:00
}
int kpa_get_powerstat(AMP *amp, powerstat_t *status)
{
2019-11-30 16:19:08 +00:00
char responsebuf[KPABUFSZ];
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
rig_debug(RIG_DEBUG_VERBOSE, "%s called\n", __func__);
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
*status = RIG_POWER_UNKNOWN;
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
if (!amp) { return -RIG_EINVAL; }
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
int retval = kpa_transaction(amp, "^ON;", responsebuf, sizeof(responsebuf));
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
if (retval != RIG_OK) { return retval; }
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
int ampon;
int nargs = sscanf(responsebuf, "^ON%d", &ampon);
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
if (nargs != 1)
{
rig_debug(RIG_DEBUG_VERBOSE, "%s Error: ^ON response='%s'\n", __func__,
responsebuf);
return -RIG_EPROTO;
}
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
switch (ampon)
{
case 0: *status = RIG_POWER_OFF; return RIG_OK;
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
case 1: *status = RIG_POWER_ON; break;
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
default:
rig_debug(RIG_DEBUG_VERBOSE, "%s Error: ^ON unknown response='%s'\n", __func__,
responsebuf);
return -RIG_EPROTO;
}
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
retval = kpa_transaction(amp, "^OP;", responsebuf, sizeof(responsebuf));
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
if (retval != RIG_OK) { return retval; }
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
int operate;
nargs = sscanf(responsebuf, "^ON%d", &operate);
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
if (nargs != 1)
{
rig_debug(RIG_DEBUG_VERBOSE, "%s Error: ^ON response='%s'\n", __func__,
responsebuf);
return -RIG_EPROTO;
}
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
*status = operate == 1 ? RIG_POWER_OPERATE : RIG_POWER_STANDBY;
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
return RIG_OK;
2019-06-12 20:52:35 +00:00
}
int kpa_set_powerstat(AMP *amp, powerstat_t status)
{
2019-11-30 16:19:08 +00:00
rig_debug(RIG_DEBUG_VERBOSE, "%s called\n", __func__);
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
if (!amp) { return -RIG_EINVAL; }
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
char *cmd = NULL;
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
switch (status)
{
case RIG_POWER_UNKNOWN: break;
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
case RIG_POWER_OFF: cmd = "^ON0;"; break;
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
case RIG_POWER_ON: cmd = "^ON1;"; break;
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
case RIG_POWER_OPERATE: cmd = "^OS1;"; break;
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
case RIG_POWER_STANDBY: cmd = "^OS0;"; break;
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
default:
rig_debug(RIG_DEBUG_ERR, "%s invalid status=%d\n", __func__, status);
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
}
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
int retval = kpa_transaction(amp, cmd, NULL, 0);
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
if (retval != RIG_OK) { return retval; }
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
return RIG_OK;
2019-06-12 20:52:35 +00:00
}
int kpa_reset(AMP *amp, amp_reset_t reset)
{
2019-11-30 16:19:08 +00:00
rig_debug(RIG_DEBUG_VERBOSE, "%s called\n", __func__);
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
// toggling from standby to operate supposed to reset
int retval = kpa_set_powerstat(amp, RIG_POWER_STANDBY);
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
if (retval != RIG_OK)
{
rig_debug(RIG_DEBUG_ERR, "%s: error setting RIG_POWER_STANDBY '%s'\n", __func__,
strerror(retval));
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
}
2019-06-12 20:52:35 +00:00
2019-11-30 16:19:08 +00:00
return kpa_set_powerstat(amp, RIG_POWER_OPERATE);
2019-06-12 20:52:35 +00:00
}