Fix FT-710, FTDX10, FTDX101D/MP 60M operations

https://github.com/Hamlib/Hamlib/issues/1211
Hamlib-4.5.4
Mike Black W9MDB 2023-01-09 10:42:57 -06:00
rodzic eea9901502
commit 2570c273ab
2 zmienionych plików z 76 dodań i 22 usunięć

Wyświetl plik

@ -799,21 +799,35 @@ int newcat_get_conf2(RIG *rig, token_t token, char *val, int val_len)
RETURNFUNC(ret);
}
static int freq_60m[] = { 5332000, 5348000, 5358500, 5373000, 5405000 };
/* returns 0 if no exeption or 1 if rig needs special handling */
int newcat_60m_exception(RIG *rig, freq_t freq)
int newcat_60m_exception(RIG *rig, freq_t freq, mode_t mode)
{
struct newcat_priv_data *priv = (struct newcat_priv_data *)rig->state.priv;
int err;
int is_exception = 0;
int channel = -1;
int i;
rmode_t tmode;
pbwidth_t twidth;
if (!(freq > 5.2 && freq < 5.5)) // we're not on 60M
{
return 0;
}
if (is_ftdx10) { is_exception = 1; }
else if (is_ft710)
if (mode != RIG_MODE_CW && mode != RIG_MODE_USB && mode != RIG_MODE_PKTUSB
&& mode != RIG_MODE_RTTYR)
{
rig_debug(RIG_DEBUG_ERR,
"%s: only USB, PKTUSB, RTTYR, and CW allowed for 60M operations\n", __func__);
return -RIG_EINVAL;
}
if (!is_ftdx10 && !is_ft710 && !is_ftdx101d && !is_ftdx101mp) { return 0; }
rig_debug(RIG_DEBUG_VERBOSE, "%s: 60M exception ignoring freq/mode commands\n",
__func__);
// If US mode we need to use memory channels
SNPRINTF(priv->cmd_str, sizeof(priv->cmd_str), "EX0301%c", cat_term);
@ -825,17 +839,48 @@ int newcat_60m_exception(RIG *rig, freq_t freq)
// 01 is the only exception so far -- others may be like UK and have full control too
if (strncmp(&priv->ret_data[6], "01", 2) != 0) { return 0; } // no exception
is_exception = 1;
}
// so now we should have a rig that has fixed memory channels 501-510 in USB/CW-U mode
// toggle vfo mode if we need to
if (is_exception)
{
rig_debug(RIG_DEBUG_VERBOSE, "%s: 60M exception ignoring freq/mode commands\n",
__func__);
return 1;
rig_get_mode(rig, RIG_VFO_A, &tmode, &twidth);
if (tmode != RIG_VFO_MEM)
{
err = newcat_vfomem_toggle(rig);
if (err != RIG_OK)
{
rig_debug(RIG_DEBUG_ERR, "%s: Error toggling VFO_MEM\n", __func__);
return -err;
}
}
// find the nearest slot below what is requested
for (i = 0; i < 5; ++i)
{
if ((long)freq == freq_60m[i]) { channel = i; }
}
return 0;
if (channel < 0)
{
rig_debug(RIG_DEBUG_ERR,
"%s: 60M allowed frequencies are 5.332, 5.348, 5.3585, 5.373,5.405, got %g\n",
__func__, freq / 1000);
return -RIG_EINVAL;
}
if (mode == RIG_MODE_CW) { channel += 5; }
SNPRINTF(priv->cmd_str, sizeof(priv->cmd_str), "MC%3d%c", channel + 501,
cat_term);
if ((err = newcat_set_cmd(rig)) != RIG_OK)
{
RETURNFUNC2(err);
}
return 1;
}
/*
@ -854,10 +899,12 @@ int newcat_set_freq(RIG *rig, vfo_t vfo, freq_t freq)
const struct rig_caps *caps;
struct newcat_priv_data *priv;
int special_60m = 0;
rmode_t tmode;
pbwidth_t twidth;
ENTERFUNC;
if (newcat_60m_exception(rig, freq))
if (newcat_60m_exception(rig, freq, rig->state.cache.modeMainA))
{
// we don't try to set freq on 60m for some rigs since we must be in memory mode
// and we can't run split mode on 60M memory mode either
@ -882,6 +929,13 @@ int newcat_set_freq(RIG *rig, vfo_t vfo, freq_t freq)
priv = (struct newcat_priv_data *)rig->state.priv;
caps = rig->caps;
rig_get_mode(rig, RIG_VFO_A, &tmode, &twidth);
if (tmode == RIG_VFO_MEM)
{
// then we need to toggle back to VFO mode
newcat_vfomem_toggle(rig);
}
rig_debug(RIG_DEBUG_TRACE, "%s: passed vfo = %s\n", __func__, rig_strvfo(vfo));
// rig_debug(RIG_DEBUG_TRACE, "%s: translated vfo = %s\n", __func__, rig_strvfo(tvfo));
rig_debug(RIG_DEBUG_TRACE, "%s: passed freq = %"PRIfreq" Hz\n", __func__, freq);
@ -1386,7 +1440,7 @@ int newcat_set_mode(RIG *rig, vfo_t vfo, rmode_t mode, pbwidth_t width)
ENTERFUNC;
if (newcat_60m_exception(rig, rig->state.cache.freqMainA)) { RETURNFUNC(RIG_OK); } // we don't set mode in this case
if (newcat_60m_exception(rig, rig->state.cache.freqMainA, mode)) { RETURNFUNC(RIG_OK); } // we don't set mode in this case
if (!newcat_valid_command(rig, "MD"))
{

Wyświetl plik

@ -50,7 +50,7 @@
typedef char ncboolean;
/* shared function version */
#define NEWCAT_VER "20230108"
#define NEWCAT_VER "20230109"
/* Hopefully large enough for future use, 128 chars plus '\0' */
#define NEWCAT_DATA_LEN 129