applied astyle on thd74.c

pull/19/head
Sebastian Denz 2018-05-01 13:56:30 +02:00
rodzic c907a512c8
commit d06e4c306f
1 zmienionych plików z 401 dodań i 286 usunięć

Wyświetl plik

@ -35,7 +35,7 @@
#include "serial.h" #include "serial.h"
#define THD74_MODES (RIG_MODE_FM|RIG_MODE_AM) #define THD74_MODES (RIG_MODE_FM|RIG_MODE_AM)
#define THD74_MODES_TX (RIG_MODE_FM) #define THD74_MODES_TX (RIG_MODE_FM)
#define THD74_FUNC_ALL (RIG_FUNC_TSQL| \ #define THD74_FUNC_ALL (RIG_FUNC_TSQL| \
@ -53,7 +53,7 @@
RIG_LEVEL_RF|\ RIG_LEVEL_RF|\
RIG_LEVEL_MICGAIN) RIG_LEVEL_MICGAIN)
#define THD74_PARMS (RIG_PARM_BACKLIGHT) #define THD74_PARMS (RIG_PARM_BACKLIGHT)
#define THD74_VFO_OP (RIG_OP_NONE) #define THD74_VFO_OP (RIG_OP_NONE)
@ -62,26 +62,28 @@
*/ */
#define THD74_VFO (RIG_VFO_A|RIG_VFO_B) #define THD74_VFO (RIG_VFO_A|RIG_VFO_B)
static rmode_t td74_mode_table[KENWOOD_MODE_TABLE_MAX] = { static rmode_t td74_mode_table[KENWOOD_MODE_TABLE_MAX] =
[0] = RIG_MODE_FM, {
[1] = RIG_MODE_DR, [0] = RIG_MODE_FM,
[2] = RIG_MODE_AM, [1] = RIG_MODE_DR,
[3] = RIG_MODE_LSB, [2] = RIG_MODE_AM,
[4] = RIG_MODE_USB, [3] = RIG_MODE_LSB,
[5] = RIG_MODE_CW, [4] = RIG_MODE_USB,
[6] = RIG_MODE_FMN, [5] = RIG_MODE_CW,
[7] = RIG_MODE_DR, [6] = RIG_MODE_FMN,
[8] = RIG_MODE_WFM, [7] = RIG_MODE_DR,
[9] = RIG_MODE_CWR, [8] = RIG_MODE_WFM,
[9] = RIG_MODE_CWR,
}; };
static struct kenwood_priv_caps thd74_priv_caps = { static struct kenwood_priv_caps thd74_priv_caps =
{
.cmdtrm = EOM_TH, /* Command termination character */ .cmdtrm = EOM_TH, /* Command termination character */
.mode_table = td74_mode_table, .mode_table = td74_mode_table,
}; };
//static int thd74_open(RIG *rig); //static int thd74_open(RIG *rig);
static int thd74_get_chan_all_cb (RIG * rig, chan_cb_t chan_cb, rig_ptr_t arg); static int thd74_get_chan_all_cb(RIG *rig, chan_cb_t chan_cb, rig_ptr_t arg);
static int thd74_get_freq(RIG *rig, vfo_t vfo, freq_t *freq); static int thd74_get_freq(RIG *rig, vfo_t vfo, freq_t *freq);
static int thd74_set_freq(RIG *rig, vfo_t vfo, freq_t freq); static int thd74_set_freq(RIG *rig, vfo_t vfo, freq_t freq);
@ -93,121 +95,122 @@ static int thd74_set_ptt(RIG *rig, vfo_t vfo, ptt_t ptt);
/* /*
* th-d72a rig capabilities. * th-d72a rig capabilities.
*/ */
const struct rig_caps thd74_caps = { const struct rig_caps thd74_caps =
.rig_model = RIG_MODEL_THD74, {
.model_name = "TH-D74", .rig_model = RIG_MODEL_THD74,
.mfg_name = "Kenwood", .model_name = "TH-D74",
.version = TH_VER ".1", .mfg_name = "Kenwood",
.copyright = "LGPL", .version = TH_VER ".1",
.status = RIG_STATUS_ALPHA, .copyright = "LGPL",
.rig_type = RIG_TYPE_HANDHELD|RIG_FLAG_APRS|RIG_FLAG_TNC|RIG_FLAG_DXCLUSTER, .status = RIG_STATUS_ALPHA,
.ptt_type = RIG_PTT_RIG, .rig_type = RIG_TYPE_HANDHELD | RIG_FLAG_APRS | RIG_FLAG_TNC | RIG_FLAG_DXCLUSTER,
.dcd_type = RIG_DCD_RIG, .ptt_type = RIG_PTT_RIG,
.port_type = RIG_PORT_SERIAL, .dcd_type = RIG_DCD_RIG,
.serial_rate_min = 9600, .port_type = RIG_PORT_SERIAL,
.serial_rate_max = 9600, .serial_rate_min = 9600,
.serial_data_bits = 8, .serial_rate_max = 9600,
.serial_stop_bits = 1, .serial_data_bits = 8,
.serial_parity = RIG_PARITY_NONE, .serial_stop_bits = 1,
.serial_handshake = RIG_HANDSHAKE_XONXOFF, .serial_parity = RIG_PARITY_NONE,
.write_delay = 100, .serial_handshake = RIG_HANDSHAKE_XONXOFF,
.post_write_delay = 100, .write_delay = 100,
.timeout = 250, .post_write_delay = 100,
.retry = 3, .timeout = 250,
.retry = 3,
.has_get_func = THD74_FUNC_ALL, .has_get_func = THD74_FUNC_ALL,
.has_set_func = THD74_FUNC_ALL, .has_set_func = THD74_FUNC_ALL,
.has_get_level = THD74_LEVEL_ALL, .has_get_level = THD74_LEVEL_ALL,
.has_set_level = RIG_LEVEL_SET(THD74_LEVEL_ALL), .has_set_level = RIG_LEVEL_SET(THD74_LEVEL_ALL),
.has_get_parm = THD74_PARMS, .has_get_parm = THD74_PARMS,
.has_set_parm = THD74_PARMS, /* FIXME: parms */ .has_set_parm = THD74_PARMS, /* FIXME: parms */
.level_gran = { .level_gran = {
[LVL_RAWSTR] = { .min = { .i = 0 }, .max = { .i = 5 } }, [LVL_RAWSTR] = { .min = { .i = 0 }, .max = { .i = 5 } },
[LVL_SQL] = { .min = { .i = 0 }, .max = { .i = 5 } }, [LVL_SQL] = { .min = { .i = 0 }, .max = { .i = 5 } },
[LVL_RFPOWER] = { .min = { .i = 3 }, .max = { .i = 0 } }, [LVL_RFPOWER] = { .min = { .i = 3 }, .max = { .i = 0 } },
}, },
.parm_gran = {}, .parm_gran = {},
.ctcss_list = kenwood38_ctcss_list, .ctcss_list = kenwood38_ctcss_list,
.dcs_list = NULL, .dcs_list = NULL,
.preamp = { RIG_DBLST_END, }, .preamp = { RIG_DBLST_END, },
.attenuator = { RIG_DBLST_END, }, .attenuator = { RIG_DBLST_END, },
.max_rit = Hz(0), .max_rit = Hz(0),
.max_xit = Hz(0), .max_xit = Hz(0),
.max_ifshift = Hz(0), .max_ifshift = Hz(0),
.vfo_ops = THD74_VFO_OP, .vfo_ops = THD74_VFO_OP,
.targetable_vfo = RIG_TARGETABLE_FREQ, .targetable_vfo = RIG_TARGETABLE_FREQ,
.transceive = RIG_TRN_RIG, .transceive = RIG_TRN_RIG,
.bank_qty = 0, .bank_qty = 0,
.chan_desc_sz = 6, /* TBC */ .chan_desc_sz = 6, /* TBC */
.chan_list = { .chan_list = {
{ 0, 999, RIG_MTYPE_MEM , {TH_CHANNEL_CAPS}}, /* TBC MEM */ { 0, 999, RIG_MTYPE_MEM, {TH_CHANNEL_CAPS}}, /* TBC MEM */
RIG_CHAN_END, RIG_CHAN_END,
}, },
.rx_range_list1 = { RIG_FRNG_END, }, /* FIXME: enter region 1 setting */ .rx_range_list1 = { RIG_FRNG_END, }, /* FIXME: enter region 1 setting */
.tx_range_list1 = { RIG_FRNG_END, }, .tx_range_list1 = { RIG_FRNG_END, },
.rx_range_list2 = { .rx_range_list2 = {
{MHz(118),MHz(174),THD74_MODES,-1,-1,THD74_VFO}, {MHz(118), MHz(174), THD74_MODES, -1, -1, THD74_VFO},
{MHz(320),MHz(524),THD74_MODES,-1,-1,THD74_VFO}, {MHz(320), MHz(524), THD74_MODES, -1, -1, THD74_VFO},
RIG_FRNG_END, RIG_FRNG_END,
}, /* rx range */ }, /* rx range */
.tx_range_list2 = { .tx_range_list2 = {
{MHz(144),MHz(148),THD74_MODES_TX,W(0.05),W(5),THD74_VFO}, {MHz(144), MHz(148), THD74_MODES_TX, W(0.05), W(5), THD74_VFO},
{MHz(430),MHz(440),THD74_MODES_TX,W(0.05),W(5),THD74_VFO}, {MHz(430), MHz(440), THD74_MODES_TX, W(0.05), W(5), THD74_VFO},
RIG_FRNG_END, RIG_FRNG_END,
}, /* tx range */ }, /* tx range */
.tuning_steps = { .tuning_steps = {
{THD74_MODES,kHz(5)}, {THD74_MODES, kHz(5)},
{THD74_MODES,kHz(6.25)}, {THD74_MODES, kHz(6.25)},
/* kHz(8.33) ?? */ /* kHz(8.33) ?? */
{THD74_MODES,kHz(10)}, {THD74_MODES, kHz(10)},
{THD74_MODES,kHz(12.5)}, {THD74_MODES, kHz(12.5)},
{THD74_MODES,kHz(15)}, {THD74_MODES, kHz(15)},
{THD74_MODES,kHz(20)}, {THD74_MODES, kHz(20)},
{THD74_MODES,kHz(25)}, {THD74_MODES, kHz(25)},
{THD74_MODES,kHz(30)}, {THD74_MODES, kHz(30)},
{THD74_MODES,kHz(50)}, {THD74_MODES, kHz(50)},
{THD74_MODES,kHz(100)}, {THD74_MODES, kHz(100)},
RIG_TS_END, RIG_TS_END,
}, },
/* mode/filter list, remember: order matters! */ /* mode/filter list, remember: order matters! */
.filters = { .filters = {
{RIG_MODE_FM, kHz(14)}, {RIG_MODE_FM, kHz(14)},
{RIG_MODE_AM, kHz(9)}, {RIG_MODE_AM, kHz(9)},
RIG_FLT_END, RIG_FLT_END,
}, },
.priv = (void *)&thd74_priv_caps, .priv = (void *)& thd74_priv_caps,
.rig_init = kenwood_init, .rig_init = kenwood_init,
.rig_cleanup = kenwood_cleanup, .rig_cleanup = kenwood_cleanup,
.rig_open = kenwood_open, .rig_open = kenwood_open,
.set_vfo = th_set_vfo, .set_vfo = th_set_vfo,
.get_vfo = th_get_vfo, .get_vfo = th_get_vfo,
// need to understand // need to understand
//.get_chan_all_cb = thd74_get_chan_all_cb, //.get_chan_all_cb = thd74_get_chan_all_cb,
.get_info = th_get_info, .get_info = th_get_info,
// add functions step by step... // add functions step by step...
.set_freq = thd74_set_freq, .set_freq = thd74_set_freq,
.get_freq = thd74_get_freq, .get_freq = thd74_get_freq,
.set_trn = kenwood_set_trn, .set_trn = kenwood_set_trn,
.get_trn = kenwood_get_trn, .get_trn = kenwood_get_trn,
//.set_rit = kenwood_set_rit, //.set_rit = kenwood_set_rit,
//.get_rit = kenwood_get_rit, //.get_rit = kenwood_get_rit,
//.set_xit = kenwood_set_xit, //.set_xit = kenwood_set_xit,
//.get_xit = kenwood_get_xit, //.get_xit = kenwood_get_xit,
.set_mode = thd74_set_mode, .set_mode = thd74_set_mode,
.get_mode = thd74_get_mode, .get_mode = thd74_get_mode,
//.set_split_vfo = kenwood_set_split_vfo, //.set_split_vfo = kenwood_set_split_vfo,
//.get_split_vfo = kenwood_get_split_vfo_if, //.get_split_vfo = kenwood_get_split_vfo_if,
.get_ptt = kenwood_get_ptt, .get_ptt = kenwood_get_ptt,
.set_ptt = thd74_set_ptt, .set_ptt = thd74_set_ptt,
.get_dcd = th_get_dcd, .get_dcd = th_get_dcd,
}; };
@ -216,30 +219,38 @@ const struct rig_caps thd74_caps = {
#define BLOCK_SZ 256 #define BLOCK_SZ 256
#define BLOCK_COUNT 256 #define BLOCK_COUNT 256
static char thd74_get_vfo_letter(RIG *rig, vfo_t vfo){ static char thd74_get_vfo_letter(RIG *rig, vfo_t vfo)
unsigned char vfo_letter; {
vfo_t tvfo; unsigned char vfo_letter;
vfo_t tvfo;
rig_debug(RIG_DEBUG_TRACE, "%s: called\n", __func__); rig_debug(RIG_DEBUG_TRACE, "%s: called\n", __func__);
tvfo = (vfo==RIG_VFO_CURR || vfo==RIG_VFO_VFO) ? rig->state.current_vfo : vfo; tvfo = (vfo == RIG_VFO_CURR
switch (tvfo) { || vfo == RIG_VFO_VFO) ? rig->state.current_vfo : vfo;
case RIG_VFO_A:
case RIG_VFO_MAIN: switch (tvfo)
vfo_letter = '0'; {
break; case RIG_VFO_A:
case RIG_VFO_B: case RIG_VFO_MAIN:
case RIG_VFO_SUB: vfo_letter = '0';
vfo_letter = '1'; break;
break;
default: case RIG_VFO_B:
rig_debug(RIG_DEBUG_ERR, "%s: unsupported VFO %d\n", __func__, vfo); case RIG_VFO_SUB:
return -RIG_EINVAL; vfo_letter = '1';
} break;
return vfo_letter;
default:
rig_debug(RIG_DEBUG_ERR, "%s: unsupported VFO %d\n", __func__, vfo);
return -RIG_EINVAL;
}
return vfo_letter;
} }
static int thd74_get_block (RIG *rig, int block_num, char *block) { static int thd74_get_block(RIG *rig, int block_num, char *block)
{
hamlib_port_t *rp = &rig->state.rigport; hamlib_port_t *rp = &rig->state.rigport;
char cmd[CMD_SZ] = "R\0\0\0\0"; char cmd[CMD_SZ] = "R\0\0\0\0";
char resp[CMD_SZ]; char resp[CMD_SZ];
@ -249,102 +260,142 @@ static int thd74_get_block (RIG *rig, int block_num, char *block) {
cmd[2] = block_num & 0xff; cmd[2] = block_num & 0xff;
ret = write_block(rp, cmd, CMD_SZ); ret = write_block(rp, cmd, CMD_SZ);
if (ret != RIG_OK) if (ret != RIG_OK)
{
return ret; return ret;
}
/* read response first */ /* read response first */
ret = read_block(rp, resp, CMD_SZ); ret = read_block(rp, resp, CMD_SZ);
if (ret != RIG_OK)
return ret;
if (resp[0] != 'W' || memcmp(cmd+1, resp+1, CMD_SZ-1)) if (ret != RIG_OK)
{
return ret;
}
if (resp[0] != 'W' || memcmp(cmd + 1, resp + 1, CMD_SZ - 1))
{
return -RIG_EPROTO; return -RIG_EPROTO;
}
/* read block */ /* read block */
ret = read_block(rp, block, BLOCK_SZ); ret = read_block(rp, block, BLOCK_SZ);
if (ret != BLOCK_SZ) if (ret != BLOCK_SZ)
{
return ret; return ret;
}
ret = write_block(rp, "\006", 1); ret = write_block(rp, "\006", 1);
if (ret != RIG_OK) if (ret != RIG_OK)
{
return ret; return ret;
}
ret = read_block(rp, resp, 1); ret = read_block(rp, resp, 1);
if (ret != 1) if (ret != 1)
{
return ret; return ret;
}
if (resp[0] != 0x06) if (resp[0] != 0x06)
{
return -RIG_EPROTO; return -RIG_EPROTO;
}
return RIG_OK; return RIG_OK;
} }
int thd74_get_chan_all_cb (RIG * rig, chan_cb_t chan_cb, rig_ptr_t arg) { int thd74_get_chan_all_cb(RIG *rig, chan_cb_t chan_cb, rig_ptr_t arg)
{
int i, j, ret; int i, j, ret;
hamlib_port_t *rp = &rig->state.rigport; hamlib_port_t *rp = &rig->state.rigport;
channel_t *chan; channel_t *chan;
chan_t *chan_list = rig->state.chan_list; chan_t *chan_list = rig->state.chan_list;
int chan_next = chan_list[0].start; int chan_next = chan_list[0].start;
char block[BLOCK_SZ]; char block[BLOCK_SZ];
char resp[CMD_SZ]; char resp[CMD_SZ];
ret = kenwood_transaction(rig, "0M PROGRAM", NULL, 0); ret = kenwood_transaction(rig, "0M PROGRAM", NULL, 0);
if (ret != RIG_OK) if (ret != RIG_OK)
{
return ret; return ret;
}
rp->parm.serial.rate = 57600; rp->parm.serial.rate = 57600;
serial_setup(rp); serial_setup(rp);
/* let the pcr settle and flush any remaining data*/ /* let the pcr settle and flush any remaining data*/
usleep(100*1000); usleep(100 * 1000);
serial_flush(rp); serial_flush(rp);
/* setRTS or Hardware flow control? */ /* setRTS or Hardware flow control? */
ret = ser_set_rts(rp, 1); ret = ser_set_rts(rp, 1);
if (ret != RIG_OK)
return ret;
/* if (ret != RIG_OK)
* setting chan to NULL means the application {
* has to provide a struct where to store data return ret;
* future data for channel channel_num }
*/
/*
* setting chan to NULL means the application
* has to provide a struct where to store data
* future data for channel channel_num
*/
chan = NULL; chan = NULL;
ret = chan_cb(rig, &chan, chan_next, chan_list, arg); ret = chan_cb(rig, &chan, chan_next, chan_list, arg);
if (ret != RIG_OK) if (ret != RIG_OK)
{
return ret; return ret;
}
if (chan == NULL) if (chan == NULL)
{
return -RIG_ENOMEM; return -RIG_ENOMEM;
}
for (i=0; i<BLOCK_COUNT; i++) { for (i = 0; i < BLOCK_COUNT; i++)
{
ret = thd74_get_block(rig, i, block);
ret = thd74_get_block (rig, i, block);
if (ret != RIG_OK) if (ret != RIG_OK)
{
return ret; return ret;
}
/* /*
* Most probably, there's 64 bytes per channel (256*256 / 1000+) * Most probably, there's 64 bytes per channel (256*256 / 1000+)
*/ */
#define CHAN_PER_BLOCK 4 #define CHAN_PER_BLOCK 4
for (j=0; j<CHAN_PER_BLOCK; j++) { for (j = 0; j < CHAN_PER_BLOCK; j++)
{
char *block_chan = block + j*(BLOCK_SZ/CHAN_PER_BLOCK); char *block_chan = block + j * (BLOCK_SZ / CHAN_PER_BLOCK);
memset(chan, 0, sizeof(channel_t)); memset(chan, 0, sizeof(channel_t));
chan->vfo = RIG_VFO_MEM; chan->vfo = RIG_VFO_MEM;
chan->channel_num = i*CHAN_PER_BLOCK + j; chan->channel_num = i * CHAN_PER_BLOCK + j;
/* What are the extra 64 channels ? */ /* What are the extra 64 channels ? */
if (chan->channel_num >= 1000) if (chan->channel_num >= 1000)
{
break; break;
}
/* non-empty channel ? */ /* non-empty channel ? */
// if (block_chan[0] != 0xff) { // if (block_chan[0] != 0xff) {
// since block_chan is *signed* char, this maps to -1 // since block_chan is *signed* char, this maps to -1
if (block_chan[0] != -1) { if (block_chan[0] != -1)
{
memcpy(chan->channel_desc, block_chan, 8); memcpy(chan->channel_desc, block_chan, 8);
/* TODO: chop off trailing chars */ /* TODO: chop off trailing chars */
@ -353,33 +404,43 @@ int thd74_get_chan_all_cb (RIG * rig, chan_cb_t chan_cb, rig_ptr_t arg) {
/* TODO: parse block and fill in chan */ /* TODO: parse block and fill in chan */
} }
/* notify the end? */ /* notify the end? */
chan_next = chan_next < chan_list[i].end ? chan_next+1 : chan_next; chan_next = chan_next < chan_list[i].end ? chan_next + 1 : chan_next;
/* /*
* provide application with channel data, * provide application with channel data,
* and ask for a new channel structure * and ask for a new channel structure
*/ */
chan_cb(rig, &chan, chan_next, chan_list, arg); chan_cb(rig, &chan, chan_next, chan_list, arg);
} }
} }
ret = write_block(rp, "E", 1); ret = write_block(rp, "E", 1);
if (ret != RIG_OK) if (ret != RIG_OK)
{
return ret; return ret;
}
ret = read_block(rp, resp, 1); ret = read_block(rp, resp, 1);
if (ret != 1)
return ret;
if (resp[0] != 0x06) { if (ret != 1)
{
return ret;
}
if (resp[0] != 0x06)
{
return -RIG_EPROTO; return -RIG_EPROTO;
} }
/* setRTS?? getCTS needed? */ /* setRTS?? getCTS needed? */
ret = ser_set_rts(rp, 1); ret = ser_set_rts(rp, 1);
if (ret != RIG_OK) if (ret != RIG_OK)
{
return ret; return ret;
}
return RIG_OK; return RIG_OK;
} }
@ -390,75 +451,90 @@ int thd74_get_chan_all_cb (RIG * rig, chan_cb_t chan_cb, rig_ptr_t arg) {
*/ */
int thd74_get_freq(RIG *rig, vfo_t vfo, freq_t *freq) int thd74_get_freq(RIG *rig, vfo_t vfo, freq_t *freq)
{ {
rig_debug(RIG_DEBUG_VERBOSE, "%s called\n", __func__); rig_debug(RIG_DEBUG_VERBOSE, "%s called\n", __func__);
if (!rig || !freq) if (!rig || !freq)
return -RIG_EINVAL; {
return -RIG_EINVAL;
}
char freqbuf[50]; char freqbuf[50];
char cmdbuf[5]; char cmdbuf[5];
int retval; int retval;
unsigned char vfo_letter; unsigned char vfo_letter;
vfo_t tvfo; vfo_t tvfo;
tvfo = (vfo == RIG_VFO_CURR || vfo==RIG_VFO_VFO) ? rig->state.current_vfo : vfo; tvfo = (vfo == RIG_VFO_CURR
|| vfo == RIG_VFO_VFO) ? rig->state.current_vfo : vfo;
if (RIG_VFO_CURR == tvfo) { if (RIG_VFO_CURR == tvfo)
/* fetch from rig */ {
retval = rig_get_vfo (rig, &tvfo); /* fetch from rig */
if (RIG_OK != retval) return retval; retval = rig_get_vfo(rig, &tvfo);
}
/* memory frequency cannot be read with an Fx command, use IF */ if (RIG_OK != retval) { return retval; }
if (tvfo == RIG_VFO_MEM) { }
return kenwood_get_freq_if(rig, vfo, freq); /* memory frequency cannot be read with an Fx command, use IF */
} if (tvfo == RIG_VFO_MEM)
{
vfo_letter = thd74_get_vfo_letter(rig, vfo); return kenwood_get_freq_if(rig, vfo, freq);
}
snprintf(cmdbuf, sizeof (cmdbuf), "FQ %c", vfo_letter); vfo_letter = thd74_get_vfo_letter(rig, vfo);
rig_debug(RIG_DEBUG_ERR, "%s: cmd: %s\n", __func__, cmdbuf);
retval = kenwood_safe_transaction(rig, cmdbuf, freqbuf, 50, 15); snprintf(cmdbuf, sizeof(cmdbuf), "FQ %c", vfo_letter);
if (retval != RIG_OK) rig_debug(RIG_DEBUG_ERR, "%s: cmd: %s\n", __func__, cmdbuf);
return retval;
rig_debug(RIG_DEBUG_ERR, "%s: response is %s\n", __func__, freqbuf); retval = kenwood_safe_transaction(rig, cmdbuf, freqbuf, 50, 15);
sscanf(freqbuf,"FQ %d,%10"SCNfreq, &retval, freq);
return RIG_OK; if (retval != RIG_OK)
{
return retval;
}
rig_debug(RIG_DEBUG_ERR, "%s: response is %s\n", __func__, freqbuf);
sscanf(freqbuf, "FQ %d,%10"SCNfreq, &retval, freq);
return RIG_OK;
} }
/* /*
* thd74_set_freq * thd74_set_freq
*/ */
int thd74_set_freq(RIG *rig, vfo_t vfo, freq_t freq) { int thd74_set_freq(RIG *rig, vfo_t vfo, freq_t freq)
rig_debug(RIG_DEBUG_VERBOSE, "%s called\n", __func__); {
rig_debug(RIG_DEBUG_VERBOSE, "%s called\n", __func__);
if (!rig) if (!rig)
return -RIG_EINVAL; {
return -RIG_EINVAL;
}
char freqbuf[16],replybuf[16]; char freqbuf[16], replybuf[16];
unsigned char vfo_letter; unsigned char vfo_letter;
int err; int err;
vfo_t tvfo; vfo_t tvfo;
tvfo = (vfo == RIG_VFO_CURR || vfo==RIG_VFO_VFO) ? rig->state.current_vfo : vfo; tvfo = (vfo == RIG_VFO_CURR
|| vfo == RIG_VFO_VFO) ? rig->state.current_vfo : vfo;
if (RIG_VFO_CURR == tvfo) { if (RIG_VFO_CURR == tvfo)
/* fetch from rig */ {
err = rig_get_vfo (rig, &tvfo); /* fetch from rig */
if (RIG_OK != err) return err; err = rig_get_vfo(rig, &tvfo);
}
vfo_letter = thd74_get_vfo_letter(rig, vfo); if (RIG_OK != err) { return err; }
}
snprintf(freqbuf, sizeof (freqbuf), "FQ %c,%010ld", vfo_letter, (int64_t)freq); vfo_letter = thd74_get_vfo_letter(rig, vfo);
rig_debug(RIG_DEBUG_ERR, "%s: freqbuf: %s\n", __func__, freqbuf);
err = kenwood_transaction(rig, freqbuf, replybuf, 16); snprintf(freqbuf, sizeof(freqbuf), "FQ %c,%010ld", vfo_letter, (int64_t)freq);
return err; rig_debug(RIG_DEBUG_ERR, "%s: freqbuf: %s\n", __func__, freqbuf);
err = kenwood_transaction(rig, freqbuf, replybuf, 16);
return err;
} }
@ -466,105 +542,144 @@ int thd74_set_freq(RIG *rig, vfo_t vfo, freq_t freq) {
* thd74_get_mode * thd74_get_mode
* Assumes rig!=NULL, mode!=NULL * Assumes rig!=NULL, mode!=NULL
*/ */
int thd74_get_mode(RIG *rig, vfo_t vfo, rmode_t *mode, pbwidth_t *width) { int thd74_get_mode(RIG *rig, vfo_t vfo, rmode_t *mode, pbwidth_t *width)
char buf[64]; {
char modebuf[8]; char buf[64];
int retval; char modebuf[8];
const struct kenwood_priv_caps *priv=(const struct kenwood_priv_caps *)rig->caps->priv; int retval;
unsigned char vfo_letter; const struct kenwood_priv_caps *priv = (const struct kenwood_priv_caps *)
rig->caps->priv;
unsigned char vfo_letter;
rig_debug(RIG_DEBUG_TRACE, "%s: called\n", __func__); rig_debug(RIG_DEBUG_TRACE, "%s: called\n", __func__);
if (vfo != RIG_VFO_CURR && vfo != rig->state.current_vfo) if (vfo != RIG_VFO_CURR && vfo != rig->state.current_vfo)
return kenwood_wrong_vfo(__func__, vfo); {
return kenwood_wrong_vfo(__func__, vfo);
}
vfo_letter = thd74_get_vfo_letter(rig, vfo); vfo_letter = thd74_get_vfo_letter(rig, vfo);
snprintf(modebuf, sizeof (modebuf), "MD %c", vfo_letter); snprintf(modebuf, sizeof(modebuf), "MD %c", vfo_letter);
retval = kenwood_safe_transaction(rig, modebuf, buf, sizeof(buf), 6); retval = kenwood_safe_transaction(rig, modebuf, buf, sizeof(buf), 6);
//retval = kenwood_safe_transaction(rig, modebuf, buf, sizeof(buf), 0);
if (retval != RIG_OK)
return retval;
rig_debug(RIG_DEBUG_ERR, "%s: buf%s\n", __func__, buf); //retval = kenwood_safe_transaction(rig, modebuf, buf, sizeof(buf), 0);
if (buf[5] < '0' || buf[5] > '9') { if (retval != RIG_OK)
rig_debug(RIG_DEBUG_ERR, "%s: Unexpected reply '%s'\n", __func__, buf); {
return -RIG_ERJCTED; return retval;
} }
if (priv->mode_table) { rig_debug(RIG_DEBUG_ERR, "%s: buf%s\n", __func__, buf);
*mode = kenwood2rmode(buf[5]-'0', priv->mode_table);
if (*mode == RIG_MODE_NONE) {
rig_debug(RIG_DEBUG_ERR, "%s: Unsupported Mode (table)value '%c'\n",
__func__, buf[5]);
return -RIG_EINVAL;
}
}
else {
return -RIG_EINVAL;
}
if (width) if (buf[5] < '0' || buf[5] > '9')
*width = RIG_PASSBAND_NORMAL; {
rig_debug(RIG_DEBUG_ERR, "%s: Unexpected reply '%s'\n", __func__, buf);
return -RIG_ERJCTED;
}
return RIG_OK; if (priv->mode_table)
{
*mode = kenwood2rmode(buf[5] - '0', priv->mode_table);
if (*mode == RIG_MODE_NONE)
{
rig_debug(RIG_DEBUG_ERR, "%s: Unsupported Mode (table)value '%c'\n",
__func__, buf[5]);
return -RIG_EINVAL;
}
}
else
{
return -RIG_EINVAL;
}
if (width)
{
*width = RIG_PASSBAND_NORMAL;
}
return RIG_OK;
} }
/* /*
* th_set_mode * th_set_mode
* Assumes rig!=NULL * Assumes rig!=NULL
*/ */
int thd74_set_mode(RIG *rig, vfo_t vfo, rmode_t mode, pbwidth_t width) { int thd74_set_mode(RIG *rig, vfo_t vfo, rmode_t mode, pbwidth_t width)
char kmode, mdbuf[8], replybuf[8]; {
int retval; char kmode, mdbuf[8], replybuf[8];
const struct kenwood_priv_caps *priv=(const struct kenwood_priv_caps *)rig->caps->priv; int retval;
unsigned char vfo_letter; const struct kenwood_priv_caps *priv = (const struct kenwood_priv_caps *)
rig->caps->priv;
unsigned char vfo_letter;
rig_debug(RIG_DEBUG_TRACE, "%s: called\n", __func__); rig_debug(RIG_DEBUG_TRACE, "%s: called\n", __func__);
if (vfo != RIG_VFO_CURR && vfo != rig->state.current_vfo) // FIXME thinkabout if (vfo != RIG_VFO_CURR && vfo != rig->state.current_vfo) // FIXME thinkabout
return kenwood_wrong_vfo(__func__, vfo); {
return kenwood_wrong_vfo(__func__, vfo);
}
vfo_letter = thd74_get_vfo_letter(rig, vfo); vfo_letter = thd74_get_vfo_letter(rig, vfo);
if (priv->mode_table) { if (priv->mode_table)
kmode = rmode2kenwood(mode, priv->mode_table); {
if (kmode == -1) { kmode = rmode2kenwood(mode, priv->mode_table);
rig_debug(RIG_DEBUG_WARN, "%s: Unsupported Mode value '%s'\n",
__func__, rig_strrmode(mode)); if (kmode == -1)
return -RIG_EINVAL; {
} rig_debug(RIG_DEBUG_WARN, "%s: Unsupported Mode value '%s'\n",
kmode += '0'; __func__, rig_strrmode(mode));
} else { return -RIG_EINVAL;
switch (mode) {
case RIG_MODE_FM: kmode = '0'; break;
case RIG_MODE_AM: kmode = '1'; break;
// case RIG_MODE_AM: kmode = '2'; break; // FIXME
case RIG_MODE_LSB: kmode = '3'; break;
case RIG_MODE_USB: kmode = '4'; break;
case RIG_MODE_CW: kmode = '5'; break;
case RIG_MODE_FMN: kmode = '6'; break;
case RIG_MODE_DR: kmode = '7'; break;
case RIG_MODE_WFM: kmode = '8'; break;
case RIG_MODE_CWR: kmode = '9'; break;
default:
rig_debug(RIG_DEBUG_ERR, "%s: Unsupported Mode %d\n", __func__, mode);
return -RIG_EINVAL;
}
} }
sprintf(mdbuf, "MD %c,%c", vfo_letter, kmode); kmode += '0';
rig_debug(RIG_DEBUG_ERR, "%s: mdbuf: %s\n", __func__, mdbuf); }
else
{
switch (mode)
{
case RIG_MODE_FM: kmode = '0'; break;
retval = kenwood_transaction(rig, mdbuf, replybuf, 7); case RIG_MODE_AM: kmode = '1'; break;
rig_debug(RIG_DEBUG_ERR, "%s: retval: %d\n", __func__, retval);
if (retval != RIG_OK)
return retval;
return RIG_OK; // case RIG_MODE_AM: kmode = '2'; break; // FIXME
case RIG_MODE_LSB: kmode = '3'; break;
case RIG_MODE_USB: kmode = '4'; break;
case RIG_MODE_CW: kmode = '5'; break;
case RIG_MODE_FMN: kmode = '6'; break;
case RIG_MODE_DR: kmode = '7'; break;
case RIG_MODE_WFM: kmode = '8'; break;
case RIG_MODE_CWR: kmode = '9'; break;
default:
rig_debug(RIG_DEBUG_ERR, "%s: Unsupported Mode %d\n", __func__, mode);
return -RIG_EINVAL;
}
}
sprintf(mdbuf, "MD %c,%c", vfo_letter, kmode);
rig_debug(RIG_DEBUG_ERR, "%s: mdbuf: %s\n", __func__, mdbuf);
retval = kenwood_transaction(rig, mdbuf, replybuf, 7);
rig_debug(RIG_DEBUG_ERR, "%s: retval: %d\n", __func__, retval);
if (retval != RIG_OK)
{
return retval;
}
return RIG_OK;
} }
static int thd74_set_ptt(RIG *rig, vfo_t vfo, ptt_t ptt) { static int thd74_set_ptt(RIG *rig, vfo_t vfo, ptt_t ptt)
char buf[6]; {
rig_debug(RIG_DEBUG_TRACE, "%s: called\n", __func__); char buf[6];
return kenwood_transaction(rig, (ptt == RIG_PTT_ON) ? "TX" : "RX", buf, 5); rig_debug(RIG_DEBUG_TRACE, "%s: called\n", __func__);
return kenwood_transaction(rig, (ptt == RIG_PTT_ON) ? "TX" : "RX", buf, 5);
} }