kopia lustrzana https://github.com/Hamlib/Hamlib
freq, mode, func, some levels, get_info, still untested
git-svn-id: https://hamlib.svn.sourceforge.net/svnroot/hamlib/trunk@2715 7ae35d74-ebe9-4afe-98af-79ac388436b8Hamlib-1.2.10
rodzic
0fd0883095
commit
80676140ff
24
rs/esmc.c
24
rs/esmc.c
|
@ -2,7 +2,7 @@
|
||||||
* Hamlib R&S backend - ESMC description
|
* Hamlib R&S backend - ESMC description
|
||||||
* Copyright (c) 2009 by Stephane Fillod
|
* Copyright (c) 2009 by Stephane Fillod
|
||||||
*
|
*
|
||||||
* $Id: ekd500.c,v 1.5 2009/02/20 12:23:46 fillods Exp $
|
* $Id: esmc.c,v 1.5 2009/08/02 12:23:46 fillods Exp $
|
||||||
*
|
*
|
||||||
* This library is free software; you can redistribute it and/or modify
|
* This library is free software; you can redistribute it and/or modify
|
||||||
* it under the terms of the GNU Library General Public License as
|
* it under the terms of the GNU Library General Public License as
|
||||||
|
@ -31,11 +31,11 @@
|
||||||
|
|
||||||
|
|
||||||
/* TODO: LOG and PULSE ? */
|
/* TODO: LOG and PULSE ? */
|
||||||
#define ESMC_MODES (RIG_MODE_SSB|RIG_MODE_CW|RIG_MODE_AM|RIG_MODE_FM)
|
#define ESMC_MODES (RIG_MODE_SSB|RIG_MODE_CW|RIG_MODE_AM|RIG_MODE_FM|RIG_MODE_WFM)
|
||||||
|
|
||||||
#define ESMC_FUNC (RIG_FUNC_SQL)
|
#define ESMC_FUNC (RIG_FUNC_SQL|RIG_FUNC_AFC)
|
||||||
|
|
||||||
#define ESMC_LEVEL_ALL (RIG_LEVEL_ATT|RIG_LEVEL_SQL|RIG_LEVEL_AGC|RIG_LEVEL_RF)
|
#define ESMC_LEVEL_ALL (RIG_LEVEL_ATT|RIG_LEVEL_SQL|RIG_LEVEL_AGC|RIG_LEVEL_RF|RIG_LEVEL_STRENGTH)
|
||||||
|
|
||||||
#define ESMC_PARM_ALL (RIG_PARM_NONE)
|
#define ESMC_PARM_ALL (RIG_PARM_NONE)
|
||||||
|
|
||||||
|
@ -50,8 +50,8 @@
|
||||||
.ant = 1, \
|
.ant = 1, \
|
||||||
.funcs = ESMC_FUNC, \
|
.funcs = ESMC_FUNC, \
|
||||||
.levels = RIG_LEVEL_SET(ESMC_LEVEL_ALL), \
|
.levels = RIG_LEVEL_SET(ESMC_LEVEL_ALL), \
|
||||||
.channel_desc=1, \
|
.channel_desc=1, \
|
||||||
.flags = RIG_CHFLAG_SKIP, \
|
.flags = RIG_CHFLAG_SKIP, \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -107,7 +107,7 @@ const struct rig_caps esmc_caps = {
|
||||||
.vfo_ops = ESMC_VFO_OPS,
|
.vfo_ops = ESMC_VFO_OPS,
|
||||||
|
|
||||||
.chan_list = {
|
.chan_list = {
|
||||||
//{ 0, 999, RIG_MTYPE_MEM, ESMC_MEM_CAP },
|
{ 0, 999, RIG_MTYPE_MEM, ESMC_MEM_CAP },
|
||||||
RIG_CHAN_END,
|
RIG_CHAN_END,
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -138,6 +138,8 @@ const struct rig_caps esmc_caps = {
|
||||||
|
|
||||||
/* mode/filter list, remember: order matters! */
|
/* mode/filter list, remember: order matters! */
|
||||||
.filters = {
|
.filters = {
|
||||||
|
{RIG_MODE_WFM, kHz(200)},
|
||||||
|
{RIG_MODE_FM|RIG_MODE_AM, kHz(15)},
|
||||||
{ESMC_MODES, kHz(2.5)},
|
{ESMC_MODES, kHz(2.5)},
|
||||||
{ESMC_MODES, kHz(0.5)},
|
{ESMC_MODES, kHz(0.5)},
|
||||||
{ESMC_MODES, kHz(8)},
|
{ESMC_MODES, kHz(8)},
|
||||||
|
@ -156,9 +158,6 @@ const struct rig_caps esmc_caps = {
|
||||||
.priv = NULL,
|
.priv = NULL,
|
||||||
|
|
||||||
.set_freq = rs_set_freq,
|
.set_freq = rs_set_freq,
|
||||||
|
|
||||||
#if 0
|
|
||||||
.rig_open = rs_rig_open,
|
|
||||||
.get_freq = rs_get_freq,
|
.get_freq = rs_get_freq,
|
||||||
.set_mode = rs_set_mode,
|
.set_mode = rs_set_mode,
|
||||||
.get_mode = rs_get_mode,
|
.get_mode = rs_get_mode,
|
||||||
|
@ -166,6 +165,11 @@ const struct rig_caps esmc_caps = {
|
||||||
.get_level = rs_get_level,
|
.get_level = rs_get_level,
|
||||||
.set_func = rs_set_func,
|
.set_func = rs_set_func,
|
||||||
.get_func = rs_get_func,
|
.get_func = rs_get_func,
|
||||||
|
.get_info = rs_get_info,
|
||||||
|
|
||||||
|
#if 0
|
||||||
|
/* TODO */
|
||||||
|
.rig_open = rs_rig_open,
|
||||||
.set_channel = rs_set_channel,
|
.set_channel = rs_set_channel,
|
||||||
.get_channel = rs_get_channel,
|
.get_channel = rs_get_channel,
|
||||||
#endif
|
#endif
|
||||||
|
|
215
rs/rs.c
215
rs/rs.c
|
@ -2,7 +2,7 @@
|
||||||
* Hamlib R&S backend - main file
|
* Hamlib R&S backend - main file
|
||||||
* Copyright (c) 2009 by Stéphane Fillod
|
* Copyright (c) 2009 by Stéphane Fillod
|
||||||
*
|
*
|
||||||
* $Id: rft.c,v 1.3 2006/10/07 18:48:34 csete Exp $
|
* $Id: rs.c,v 1.2 2009/08/07 18:48:34 fillods Exp $
|
||||||
*
|
*
|
||||||
* This library is free software; you can redistribute it and/or modify
|
* This library is free software; you can redistribute it and/or modify
|
||||||
* it under the terms of the GNU Library General Public License as
|
* it under the terms of the GNU Library General Public License as
|
||||||
|
@ -39,6 +39,7 @@
|
||||||
|
|
||||||
|
|
||||||
#define BUFSZ 64
|
#define BUFSZ 64
|
||||||
|
#define RESPSZ 64
|
||||||
|
|
||||||
#define LF "\x0a"
|
#define LF "\x0a"
|
||||||
#define CR "\x0d"
|
#define CR "\x0d"
|
||||||
|
@ -68,13 +69,11 @@ int rs_transaction(RIG *rig, const char *cmd, int cmd_len, char *data, int *data
|
||||||
return retval;
|
return retval;
|
||||||
|
|
||||||
|
|
||||||
/* no data expected, TODO: flush input? */
|
/* no data expected */
|
||||||
if (!data || !data_len)
|
if (!data || !data_len)
|
||||||
return 0;
|
return RIG_OK;
|
||||||
|
|
||||||
retval = read_string(&rs->rigport, data, BUFSZ, CR, 1);
|
retval = read_string(&rs->rigport, data, BUFSZ, CR, 1);
|
||||||
if (retval == -RIG_ETIMEOUT)
|
|
||||||
retval = 0;
|
|
||||||
if (retval < 0)
|
if (retval < 0)
|
||||||
return retval;
|
return retval;
|
||||||
*data_len = retval;
|
*data_len = retval;
|
||||||
|
@ -88,17 +87,211 @@ int rs_transaction(RIG *rig, const char *cmd, int cmd_len, char *data, int *data
|
||||||
*/
|
*/
|
||||||
int rs_set_freq(RIG *rig, vfo_t vfo, freq_t freq)
|
int rs_set_freq(RIG *rig, vfo_t vfo, freq_t freq)
|
||||||
{
|
{
|
||||||
char freqbuf[16], ackbuf[16];
|
char freqbuf[32];
|
||||||
int freq_len, ack_len, retval;
|
int freq_len, retval;
|
||||||
|
|
||||||
/*
|
freq_len = sprintf(freqbuf, BOM "FREQ %"PRIll EOM, (long long)freq);
|
||||||
*/
|
retval = rs_transaction(rig, freqbuf, freq_len, NULL, NULL);
|
||||||
freq_len = sprintf(freqbuf, BOM "FREQ %f MHz" EOM, freq/1e6);
|
|
||||||
retval = rs_transaction(rig, freqbuf, freq_len, ackbuf, &ack_len);
|
|
||||||
|
|
||||||
return retval;
|
return retval;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* rs_get_freq
|
||||||
|
* Assumes rig!=NULL
|
||||||
|
*/
|
||||||
|
int rs_get_freq(RIG *rig, vfo_t vfo, freq_t *freq)
|
||||||
|
{
|
||||||
|
char buf[RESPSZ];
|
||||||
|
int len, retval;
|
||||||
|
|
||||||
|
#define FREQ_QUERY BOM "FREQ?" EOM
|
||||||
|
|
||||||
|
retval = rs_transaction(rig, FREQ_QUERY, strlen(FREQ_QUERY), buf, &len);
|
||||||
|
if (retval < 0)
|
||||||
|
return retval;
|
||||||
|
|
||||||
|
retval = (sscanf(buf, "%"SCNfreq, freq)==1) ? RIG_OK : -RIG_EPROTO;
|
||||||
|
|
||||||
|
return retval;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* rs_set_mode
|
||||||
|
* Assumes rig!=NULL
|
||||||
|
*/
|
||||||
|
int rs_set_mode(RIG *rig, vfo_t vfo, rmode_t mode, pbwidth_t width)
|
||||||
|
{
|
||||||
|
char buf[32], *smode;
|
||||||
|
int len, retval;
|
||||||
|
|
||||||
|
switch (mode) {
|
||||||
|
case RIG_MODE_AM: smode = "AM"; break;
|
||||||
|
case RIG_MODE_WFM:
|
||||||
|
case RIG_MODE_FM: smode = "FM"; break;
|
||||||
|
case RIG_MODE_CW: smode = "CW"; break;
|
||||||
|
case RIG_MODE_USB: smode = "USB"; break;
|
||||||
|
case RIG_MODE_LSB: smode = "LSB"; break;
|
||||||
|
default:
|
||||||
|
return -RIG_EINVAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
len = sprintf(buf, BOM "DEM %s" EOM, smode);
|
||||||
|
retval = rs_transaction(rig, buf, len, NULL, NULL);
|
||||||
|
|
||||||
|
if (width == RIG_PASSBAND_NORMAL)
|
||||||
|
width = rig_passband_normal(rig, mode);
|
||||||
|
|
||||||
|
if (width > 0) {
|
||||||
|
len = sprintf(buf, BOM "BAND %d" EOM, (int) width);
|
||||||
|
retval = rs_transaction(rig, buf, len, NULL, NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
return retval;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* rs_get_mode
|
||||||
|
* Assumes rig!=NULL
|
||||||
|
*/
|
||||||
|
int rs_get_mode(RIG *rig, vfo_t vfo, rmode_t *mode, pbwidth_t *width)
|
||||||
|
{
|
||||||
|
char buf[RESPSZ];
|
||||||
|
int buf_len, retval;
|
||||||
|
|
||||||
|
#define DEM_QUERY BOM "DEM?" EOM
|
||||||
|
|
||||||
|
retval = rs_transaction(rig, DEM_QUERY, strlen(DEM_QUERY), buf, &buf_len);
|
||||||
|
if (retval < 0)
|
||||||
|
return retval;
|
||||||
|
|
||||||
|
*mode = rig_parse_mode(buf);
|
||||||
|
|
||||||
|
#define BAND_QUERY BOM "BAND?" EOM
|
||||||
|
retval = rs_transaction(rig, BAND_QUERY, strlen(BAND_QUERY), buf, &buf_len);
|
||||||
|
if (retval < 0)
|
||||||
|
return retval;
|
||||||
|
|
||||||
|
*width = atoi(buf);
|
||||||
|
|
||||||
|
return retval;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int rs_set_func(RIG *rig, vfo_t vfo, setting_t func, int status)
|
||||||
|
{
|
||||||
|
char buf[32], *sfunc;
|
||||||
|
int len, retval;
|
||||||
|
|
||||||
|
switch (func) {
|
||||||
|
case RIG_FUNC_AFC: sfunc = "FREQ:AFC"; break;
|
||||||
|
case RIG_FUNC_SQL: sfunc = "OUTP:SQU"; break;
|
||||||
|
default:
|
||||||
|
return -RIG_EINVAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
len = sprintf(buf, BOM "%s %s" EOM, sfunc, status ? "ON" : "OFF");
|
||||||
|
retval = rs_transaction(rig, buf, len, NULL, NULL);
|
||||||
|
|
||||||
|
return retval;
|
||||||
|
}
|
||||||
|
|
||||||
|
int rs_get_func(RIG *rig, vfo_t vfo, setting_t func, int *status)
|
||||||
|
{
|
||||||
|
char buf[RESPSZ], *sfunc;
|
||||||
|
int buf_len, retval;
|
||||||
|
|
||||||
|
switch (func) {
|
||||||
|
case RIG_FUNC_AFC: sfunc = "FREQ:AFC?"; break;
|
||||||
|
case RIG_FUNC_SQL: sfunc = "OUTP:SQU?"; break;
|
||||||
|
default:
|
||||||
|
return -RIG_EINVAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
retval = rs_transaction(rig, sfunc, strlen(sfunc), buf, &buf_len);
|
||||||
|
if (retval < 0)
|
||||||
|
return retval;
|
||||||
|
|
||||||
|
*status = (memcmp(buf, "ON", 2) == 0) ? 1 : 0;
|
||||||
|
|
||||||
|
return retval;
|
||||||
|
}
|
||||||
|
|
||||||
|
int rs_set_level(RIG *rig, vfo_t vfo, setting_t level, value_t val)
|
||||||
|
{
|
||||||
|
char buf[32];
|
||||||
|
int len, retval;
|
||||||
|
|
||||||
|
switch (level) {
|
||||||
|
case RIG_LEVEL_ATT:
|
||||||
|
len = sprintf(buf, BOM "INP:ATT:STAT %s" EOM, val.i ? "ON" : "OFF");
|
||||||
|
break;
|
||||||
|
case RIG_LEVEL_SQL:
|
||||||
|
case RIG_LEVEL_AGC:
|
||||||
|
case RIG_LEVEL_RF:
|
||||||
|
return -RIG_ENIMPL;
|
||||||
|
default:
|
||||||
|
return -RIG_EINVAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
retval = rs_transaction(rig, buf, len, NULL, NULL);
|
||||||
|
|
||||||
|
return retval;
|
||||||
|
}
|
||||||
|
|
||||||
|
int rs_get_level(RIG *rig, vfo_t vfo, setting_t level, value_t *val)
|
||||||
|
{
|
||||||
|
char buf[RESPSZ], *slevel;
|
||||||
|
int buf_len, retval;
|
||||||
|
|
||||||
|
switch (level) {
|
||||||
|
case RIG_LEVEL_STRENGTH: slevel = BOM "SENS:DATA? \"VOLT:AC\"" EOM; break;
|
||||||
|
case RIG_LEVEL_ATT: slevel = BOM "INP:ATT:STAT?" EOM; break;
|
||||||
|
break;
|
||||||
|
case RIG_LEVEL_SQL:
|
||||||
|
case RIG_LEVEL_AGC:
|
||||||
|
case RIG_LEVEL_RF:
|
||||||
|
return -RIG_ENIMPL;
|
||||||
|
default:
|
||||||
|
return -RIG_EINVAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
retval = rs_transaction(rig, slevel, strlen(slevel), buf, &buf_len);
|
||||||
|
if (retval < 0)
|
||||||
|
return retval;
|
||||||
|
|
||||||
|
switch (level) {
|
||||||
|
case RIG_LEVEL_STRENGTH:
|
||||||
|
/* assumes FORMAat:DATA ASCii
|
||||||
|
* result in dBuV, keep only integer part
|
||||||
|
*/
|
||||||
|
sscanf(buf, "%d", &val->i);
|
||||||
|
val->i -= 34;
|
||||||
|
break;
|
||||||
|
case RIG_LEVEL_ATT:
|
||||||
|
val->i = (memcmp(buf, "ON", 2) == 0) ? rig->state.attenuator[0] : 0;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return -RIG_EINVAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
return retval;
|
||||||
|
}
|
||||||
|
|
||||||
|
const char * rs_get_info(RIG *rig)
|
||||||
|
{
|
||||||
|
static char infobuf[128];
|
||||||
|
int info_len, retval;
|
||||||
|
|
||||||
|
#define ID_QUERY BOM "*IDN?" EOM
|
||||||
|
|
||||||
|
retval = rs_transaction(rig, ID_QUERY, strlen(ID_QUERY), infobuf, &info_len);
|
||||||
|
if (retval < 0)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
return infobuf;
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* initrigs_rs is called by rig_backend_load
|
* initrigs_rs is called by rig_backend_load
|
||||||
*/
|
*/
|
||||||
|
|
10
rs/rs.h
10
rs/rs.h
|
@ -2,7 +2,7 @@
|
||||||
* Hamlib R&S backend - main header
|
* Hamlib R&S backend - main header
|
||||||
* Copyright (c) 2009 by Stephane Fillod
|
* Copyright (c) 2009 by Stephane Fillod
|
||||||
*
|
*
|
||||||
* $Id: rft.h,v 1.1 2003/10/07 22:15:49 fillods Exp $
|
* $Id: rs.h,v 1.1 2009/08/07 22:15:49 fillods Exp $
|
||||||
*
|
*
|
||||||
* This library is free software; you can redistribute it and/or modify
|
* This library is free software; you can redistribute it and/or modify
|
||||||
* it under the terms of the GNU Library General Public License as
|
* it under the terms of the GNU Library General Public License as
|
||||||
|
@ -27,6 +27,14 @@
|
||||||
|
|
||||||
|
|
||||||
int rs_set_freq(RIG *rig, vfo_t vfo, freq_t freq);
|
int rs_set_freq(RIG *rig, vfo_t vfo, freq_t freq);
|
||||||
|
int rs_get_freq(RIG *rig, vfo_t vfo, freq_t *freq);
|
||||||
|
int rs_set_mode(RIG *rig, vfo_t vfo, rmode_t mode, pbwidth_t width);
|
||||||
|
int rs_get_mode(RIG *rig, vfo_t vfo, rmode_t *mode, pbwidth_t *width);
|
||||||
|
int rs_set_func(RIG *rig, vfo_t vfo, setting_t func, int status);
|
||||||
|
int rs_get_func(RIG *rig, vfo_t vfo, setting_t func, int *status);
|
||||||
|
int rs_set_level(RIG *rig, vfo_t vfo, setting_t level, value_t val);
|
||||||
|
int rs_get_level(RIG *rig, vfo_t vfo, setting_t level, value_t *val);
|
||||||
|
const char * rs_get_info(RIG *rig);
|
||||||
|
|
||||||
extern const struct rig_caps esmc_caps;
|
extern const struct rig_caps esmc_caps;
|
||||||
|
|
||||||
|
|
Ładowanie…
Reference in New Issue