kopia lustrzana https://github.com/Hamlib/Hamlib
rodzic
9415fc3446
commit
d50ff331ee
|
@ -32,21 +32,12 @@
|
||||||
|
|
||||||
#define BARRETT4050_MODES (RIG_MODE_AM | RIG_MODE_CW | RIG_MODE_RTTY | RIG_MODE_SSB)
|
#define BARRETT4050_MODES (RIG_MODE_AM | RIG_MODE_CW | RIG_MODE_RTTY | RIG_MODE_SSB)
|
||||||
|
|
||||||
#define BARRETT4050_LEVELS (RIG_LEVEL_NONE)
|
#define BARRETT4050_LEVELS (RIG_LEVEL_AGC|RIG_LEVEL_STRENGTH)
|
||||||
|
|
||||||
#define BARRETT4050_FUNCTIONS (RIG_FUNC_TUNER)
|
#define BARRETT4050_FUNCTIONS (RIG_FUNC_TUNER)
|
||||||
|
|
||||||
extern int barret950_get_freq(RIG *rig, vfo_t vfo, freq_t freq);
|
extern int barret950_get_freq(RIG *rig, vfo_t vfo, freq_t freq);
|
||||||
|
|
||||||
/*
|
|
||||||
* barrett4050_get_level
|
|
||||||
*/
|
|
||||||
static int barrett4050_get_level(RIG *rig, vfo_t vfo, setting_t level,
|
|
||||||
value_t *val)
|
|
||||||
{
|
|
||||||
return -RIG_ENIMPL;
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* barrett4050_get_info
|
* barrett4050_get_info
|
||||||
*/
|
*/
|
||||||
|
@ -130,7 +121,7 @@ const struct rig_caps barrett4050_caps =
|
||||||
.has_get_func = BARRETT4050_FUNCTIONS,
|
.has_get_func = BARRETT4050_FUNCTIONS,
|
||||||
.has_set_func = BARRETT4050_FUNCTIONS,
|
.has_set_func = BARRETT4050_FUNCTIONS,
|
||||||
.has_get_level = BARRETT4050_LEVELS,
|
.has_get_level = BARRETT4050_LEVELS,
|
||||||
.has_set_level = RIG_LEVEL_NONE,
|
.has_set_level = RIG_LEVEL_AGC,
|
||||||
.has_get_parm = RIG_PARM_NONE,
|
.has_get_parm = RIG_PARM_NONE,
|
||||||
.has_set_parm = RIG_PARM_NONE,
|
.has_set_parm = RIG_PARM_NONE,
|
||||||
.transceive = RIG_TRN_RIG,
|
.transceive = RIG_TRN_RIG,
|
||||||
|
@ -164,7 +155,8 @@ const struct rig_caps barrett4050_caps =
|
||||||
.set_mode = barrett_set_mode,
|
.set_mode = barrett_set_mode,
|
||||||
.get_mode = barrett_get_mode,
|
.get_mode = barrett_get_mode,
|
||||||
|
|
||||||
.get_level = barrett4050_get_level,
|
.set_level = barrett_set_level,
|
||||||
|
.get_level = barrett_get_level,
|
||||||
|
|
||||||
.get_info = barrett4050_get_info,
|
.get_info = barrett4050_get_info,
|
||||||
.set_ptt = barrett_set_ptt,
|
.set_ptt = barrett_set_ptt,
|
||||||
|
|
|
@ -642,6 +642,27 @@ int barrett_get_level(RIG *rig, vfo_t vfo, setting_t level, value_t *val)
|
||||||
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case RIG_LEVEL_AGC:
|
||||||
|
retval = barrett_transaction(rig, "IGA", 0, &response);
|
||||||
|
|
||||||
|
if (retval < 0)
|
||||||
|
{
|
||||||
|
rig_debug(RIG_DEBUG_ERR, "%s: invalid response=%s\n", __func__,
|
||||||
|
response);
|
||||||
|
return retval;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (response[0] == 'H') // then AGC hang is on
|
||||||
|
{
|
||||||
|
val->i = 1;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
val->i = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
rig_debug(RIG_DEBUG_ERR, "%s: unsupported level %s\n", __func__,
|
rig_debug(RIG_DEBUG_ERR, "%s: unsupported level %s\n", __func__,
|
||||||
rig_strlevel(level));
|
rig_strlevel(level));
|
||||||
|
@ -654,6 +675,29 @@ int barrett_get_level(RIG *rig, vfo_t vfo, setting_t level, value_t *val)
|
||||||
return RIG_OK;
|
return RIG_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int barrett_set_level(RIG *rig, vfo_t vfo, setting_t level, value_t val)
|
||||||
|
{
|
||||||
|
char cmd_buf[MAXCMDLEN];
|
||||||
|
struct rig_state *rs = &rig->state;
|
||||||
|
int retval;
|
||||||
|
|
||||||
|
switch (level)
|
||||||
|
{
|
||||||
|
case RIG_LEVEL_AGC:
|
||||||
|
sprintf(cmd_buf,"EG%c%s", val.i==0?'N':'H' , EOM);
|
||||||
|
break;
|
||||||
|
default: return -RIG_ENIMPL;
|
||||||
|
}
|
||||||
|
rig_flush(&rs->rigport);
|
||||||
|
retval = write_block(&rs->rigport, (unsigned char *) cmd_buf, strlen(cmd_buf));
|
||||||
|
|
||||||
|
if (retval < 0)
|
||||||
|
{
|
||||||
|
return retval;
|
||||||
|
}
|
||||||
|
return RIG_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* barrett_get_info
|
* barrett_get_info
|
||||||
|
|
|
@ -66,6 +66,9 @@ extern int barrett_set_split_vfo(RIG *rig, vfo_t rxvfo, split_t split,
|
||||||
extern int barrett_get_split_vfo(RIG *rig, vfo_t rxvfo, split_t *split,
|
extern int barrett_get_split_vfo(RIG *rig, vfo_t rxvfo, split_t *split,
|
||||||
vfo_t *txvfo);
|
vfo_t *txvfo);
|
||||||
|
|
||||||
|
extern int barrett_get_level(RIG *rig, vfo_t vfo, setting_t level, value_t *val);
|
||||||
|
extern int barrett_set_level(RIG *rig, vfo_t vfo, setting_t level, value_t val);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
Ładowanie…
Reference in New Issue