kopia lustrzana https://github.com/Hamlib/Hamlib
				
				
				
			
		
			
				
	
	
		
			542 wiersze
		
	
	
		
			18 KiB
		
	
	
	
		
			C
		
	
	
			
		
		
	
	
			542 wiersze
		
	
	
		
			18 KiB
		
	
	
	
		
			C
		
	
	
/*
 | 
						||
 *  Hamlib Kenwood backend - TS570 description
 | 
						||
 *  Copyright (c) 2001-2003 by Stephane Fillod
 | 
						||
 *
 | 
						||
 *	$Id: ts570.c,v 1.20 2003-10-01 19:31:59 fillods Exp $
 | 
						||
 *
 | 
						||
 *   This library is free software; you can redistribute it and/or modify
 | 
						||
 *   it under the terms of the GNU Library General Public License as
 | 
						||
 *   published by the Free Software Foundation; either version 2 of
 | 
						||
 *   the License, or (at your option) any later version.
 | 
						||
 *
 | 
						||
 *   This program 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 Library General Public License for more details.
 | 
						||
 *
 | 
						||
 *   You should have received a copy of the GNU Library General Public
 | 
						||
 *   License along with this library; if not, write to the Free Software
 | 
						||
 *   Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
 | 
						||
 *
 | 
						||
 */
 | 
						||
 | 
						||
#ifdef HAVE_CONFIG_H
 | 
						||
#include "config.h"
 | 
						||
#endif
 | 
						||
 | 
						||
#include <stdio.h>
 | 
						||
#include <stdlib.h>
 | 
						||
 | 
						||
#include <hamlib/rig.h>
 | 
						||
#include "kenwood.h"
 | 
						||
 | 
						||
 | 
						||
#define TS570_ALL_MODES (RIG_MODE_AM|RIG_MODE_CW|RIG_MODE_SSB|RIG_MODE_FM|RIG_MODE_RTTY)
 | 
						||
#define TS570_OTHER_TX_MODES (RIG_MODE_CW|RIG_MODE_SSB|RIG_MODE_FM|RIG_MODE_RTTY)
 | 
						||
#define TS570_AM_TX_MODES RIG_MODE_AM
 | 
						||
 | 
						||
#define TS570_FUNC_ALL (RIG_FUNC_FAGC|RIG_FUNC_TSQL|RIG_FUNC_TONE|RIG_FUNC_NB|RIG_FUNC_COMP|RIG_FUNC_VOX|RIG_FUNC_NR|RIG_FUNC_LOCK|RIG_FUNC_BC)
 | 
						||
 | 
						||
#define TS570_LEVEL_ALL (RIG_LEVEL_ATT|RIG_LEVEL_AGC|RIG_LEVEL_SQL|RIG_LEVEL_SQLSTAT|RIG_LEVEL_STRENGTH|RIG_LEVEL_AF|RIG_LEVEL_RF|RIG_LEVEL_RFPOWER|RIG_LEVEL_MICGAIN)
 | 
						||
 | 
						||
#define TS570_VFO (RIG_VFO_A|RIG_VFO_B)
 | 
						||
#define TS570_VFO_OP (RIG_OP_UP|RIG_OP_DOWN)
 | 
						||
 | 
						||
/*
 | 
						||
 * modes in use by the "MD" command
 | 
						||
 */
 | 
						||
#define MD_NONE	'0'
 | 
						||
#define MD_LSB	'1'
 | 
						||
#define MD_USB	'2'
 | 
						||
#define MD_CW	'3'
 | 
						||
#define MD_FM	'4'
 | 
						||
#define MD_AM	'5'
 | 
						||
#define MD_FSK	'6'
 | 
						||
#define MD_CWR	'7'
 | 
						||
#define MD_FSKR	'9'
 | 
						||
 | 
						||
static const struct kenwood_priv_caps  ts570_priv_caps  = {
 | 
						||
		.cmdtrm =  EOM_KEN,
 | 
						||
};
 | 
						||
 | 
						||
int ts570_get_mode(RIG *rig, vfo_t vfo, rmode_t *mode, pbwidth_t *width)
 | 
						||
{
 | 
						||
  unsigned char buf[50];
 | 
						||
  int buf_len, retval;
 | 
						||
 | 
						||
 | 
						||
  buf_len = 50;
 | 
						||
  retval = kenwood_transaction (rig, "MD;", 3, buf, &buf_len);
 | 
						||
  if (retval != RIG_OK)
 | 
						||
    return retval;
 | 
						||
 | 
						||
  if (buf_len != 4 || buf[1] != 'D')
 | 
						||
  {
 | 
						||
    rig_debug(RIG_DEBUG_ERR,"ts570_get_mode: unexpected MD answer, len=%d\n",
 | 
						||
      buf_len);
 | 
						||
    return -RIG_ERJCTED;
 | 
						||
  }
 | 
						||
 | 
						||
  switch (buf[2]) 
 | 
						||
  {
 | 
						||
    case MD_CW:         *mode = RIG_MODE_CW; break;
 | 
						||
    case MD_CWR:	*mode = RIG_MODE_CWR; break;
 | 
						||
    case MD_USB:	*mode = RIG_MODE_USB; break;
 | 
						||
    case MD_LSB:	*mode = RIG_MODE_LSB; break;
 | 
						||
    case MD_FM:	        *mode = RIG_MODE_FM; break;
 | 
						||
    case MD_AM:	        *mode = RIG_MODE_AM; break;
 | 
						||
    case MD_FSK:	*mode = RIG_MODE_RTTY; break;
 | 
						||
    case MD_FSKR:	*mode = RIG_MODE_RTTYR; break;
 | 
						||
    case MD_NONE:	*mode = RIG_MODE_NONE; break;
 | 
						||
    default:
 | 
						||
      rig_debug(RIG_DEBUG_ERR,"ts570_get_mode: "
 | 
						||
        "unsupported mode '%c'\n", buf[2]);
 | 
						||
      return -RIG_EINVAL;
 | 
						||
  }
 | 
						||
 | 
						||
/* 
 | 
						||
 * Use FW (Filter Width) for CW and RTTY, 
 | 
						||
 * SL (dsp Slope Low cut-off)  for all the other modes.
 | 
						||
 * This is how it works on the TS870S, which does not have SL/SH commands.
 | 
						||
 * TODO: combine SL and SH to set/read bandwidth....
 | 
						||
 */
 | 
						||
  switch (*mode) 
 | 
						||
  {
 | 
						||
    case RIG_MODE_CW:
 | 
						||
    case RIG_MODE_CWR:
 | 
						||
    case RIG_MODE_RTTY:
 | 
						||
    case RIG_MODE_RTTYR:
 | 
						||
      buf_len = 50;
 | 
						||
      retval = kenwood_transaction (rig, "FW;", 3, buf, &buf_len);
 | 
						||
      if (retval != RIG_OK) return retval;
 | 
						||
      if (buf_len != 7 || buf[1] != 'W')
 | 
						||
      {
 | 
						||
        rig_debug(RIG_DEBUG_ERR,
 | 
						||
          "ts570_get_mode: unexpected FW answer, len=%d\n", buf_len);
 | 
						||
        return -RIG_ERJCTED;
 | 
						||
      }
 | 
						||
      *width = atoi(&buf[2]);
 | 
						||
      break;
 | 
						||
    case RIG_MODE_USB:
 | 
						||
    case RIG_MODE_LSB:
 | 
						||
    case RIG_MODE_FM:
 | 
						||
    case RIG_MODE_AM:
 | 
						||
      buf_len = 50;
 | 
						||
      retval = kenwood_transaction (rig, "SL;", 3, buf, &buf_len);
 | 
						||
      if (retval != RIG_OK) return retval;
 | 
						||
      if (buf_len != 5 || buf[1] != 'L')
 | 
						||
      {
 | 
						||
        rig_debug(RIG_DEBUG_ERR,
 | 
						||
          "ts570_get_mode: unexpected SL answer, len=%d\n", buf_len);
 | 
						||
        return -RIG_ERJCTED;
 | 
						||
      }
 | 
						||
      *width = 50 * atoi(&buf[2]);
 | 
						||
      break;
 | 
						||
    default:
 | 
						||
      return -RIG_EINVAL;
 | 
						||
  }
 | 
						||
 | 
						||
  return RIG_OK;
 | 
						||
}
 | 
						||
 | 
						||
 | 
						||
int ts570_set_mode(RIG *rig, vfo_t vfo, rmode_t mode, pbwidth_t width)
 | 
						||
{
 | 
						||
  unsigned char buf[16],ackbuf[16];
 | 
						||
  int buf_len, ack_len, kmode, retval;
 | 
						||
 | 
						||
  switch (mode) 
 | 
						||
  {
 | 
						||
    case RIG_MODE_CW:       kmode = MD_CW; break;
 | 
						||
    case RIG_MODE_CWR:      kmode = MD_CWR; break;
 | 
						||
    case RIG_MODE_USB:      kmode = MD_USB; break;
 | 
						||
    case RIG_MODE_LSB:      kmode = MD_LSB; break;
 | 
						||
    case RIG_MODE_FM:       kmode = MD_FM; break;
 | 
						||
    case RIG_MODE_AM:       kmode = MD_AM; break;
 | 
						||
    case RIG_MODE_RTTY:     kmode = MD_FSK; break;
 | 
						||
    case RIG_MODE_RTTYR:    kmode = MD_FSKR; break;
 | 
						||
    default:
 | 
						||
      rig_debug(RIG_DEBUG_ERR,"ts570_set_mode: "
 | 
						||
	"unsupported mode %d\n", mode);
 | 
						||
      return -RIG_EINVAL;
 | 
						||
  }
 | 
						||
 | 
						||
  buf_len = sprintf(buf, "MD%c;", kmode);
 | 
						||
  ack_len = 0;
 | 
						||
  retval = kenwood_transaction (rig, buf, buf_len, ackbuf, &ack_len);
 | 
						||
  if (retval != RIG_OK) return retval;
 | 
						||
 | 
						||
  switch (mode) 
 | 
						||
  {
 | 
						||
    case RIG_MODE_CW:
 | 
						||
    case RIG_MODE_CWR:
 | 
						||
    case RIG_MODE_RTTY:
 | 
						||
    case RIG_MODE_RTTYR:
 | 
						||
      buf_len = sprintf(buf, "FW%04d;", (int)width);
 | 
						||
      ack_len = 0;
 | 
						||
      retval = kenwood_transaction (rig, buf, buf_len, ackbuf, &ack_len);
 | 
						||
      if (retval != RIG_OK) return retval;
 | 
						||
      break;
 | 
						||
    case RIG_MODE_USB:
 | 
						||
    case RIG_MODE_LSB:
 | 
						||
    case RIG_MODE_FM:
 | 
						||
    case RIG_MODE_AM:
 | 
						||
      buf_len = sprintf(buf, "SL%02d;", (int)width/50);
 | 
						||
      ack_len = 0;
 | 
						||
      retval = kenwood_transaction (rig, buf, buf_len, ackbuf, &ack_len);
 | 
						||
      if (retval != RIG_OK) return retval;
 | 
						||
      break;
 | 
						||
    default:
 | 
						||
      return -RIG_EINVAL;
 | 
						||
  }
 | 
						||
 | 
						||
  return RIG_OK;
 | 
						||
}
 | 
						||
 | 
						||
/*
 | 
						||
 * ts570 rig capabilities.
 | 
						||
 * Notice that some rigs share the same functions.
 | 
						||
 * Also this struct is READONLY!
 | 
						||
 * RIT: Variable Range <20>9.99 kHz
 | 
						||
 *
 | 
						||
 * part of infos comes from .http = //www.kenwood.net/
 | 
						||
 */
 | 
						||
const struct rig_caps ts570s_caps = {
 | 
						||
.rig_model =  RIG_MODEL_TS570S,
 | 
						||
.model_name = "TS-570S",
 | 
						||
.mfg_name =  "Kenwood",
 | 
						||
.version =  "0.2.1",
 | 
						||
.copyright =  "LGPL",
 | 
						||
.status =  RIG_STATUS_UNTESTED,
 | 
						||
.rig_type =  RIG_TYPE_TRANSCEIVER,
 | 
						||
.ptt_type =  RIG_PTT_RIG,
 | 
						||
.dcd_type =  RIG_DCD_RIG,
 | 
						||
.port_type =  RIG_PORT_SERIAL,
 | 
						||
.serial_rate_min =  1200,
 | 
						||
.serial_rate_max =  57600,
 | 
						||
.serial_data_bits =  8,
 | 
						||
.serial_stop_bits =  1,
 | 
						||
.serial_parity =  RIG_PARITY_NONE,
 | 
						||
.serial_handshake =  RIG_HANDSHAKE_NONE,
 | 
						||
.write_delay =  0,
 | 
						||
.post_write_delay =  0,
 | 
						||
.timeout =  200,
 | 
						||
.retry =  3,
 | 
						||
 | 
						||
.has_get_func =  TS570_FUNC_ALL,
 | 
						||
.has_set_func =  TS570_FUNC_ALL,
 | 
						||
.has_get_level =  TS570_LEVEL_ALL,
 | 
						||
.has_set_level =  RIG_LEVEL_SET(TS570_LEVEL_ALL),
 | 
						||
.has_get_parm =  RIG_PARM_NONE,
 | 
						||
.has_set_parm =  RIG_PARM_NONE,    /* FIXME: parms */
 | 
						||
.level_gran =  {},                 /* FIXME: granularity */
 | 
						||
.parm_gran =  {},
 | 
						||
.ctcss_list =  kenwood38_ctcss_list,
 | 
						||
.dcs_list =  NULL,
 | 
						||
.preamp =   { RIG_DBLST_END, },	/* FIXME: preamp list */
 | 
						||
.attenuator =   { 18, RIG_DBLST_END, },
 | 
						||
.max_rit =  Hz(9990),
 | 
						||
.max_xit =  Hz(9990),
 | 
						||
.max_ifshift =  Hz(0),
 | 
						||
.vfo_ops =  TS570_VFO_OP,
 | 
						||
.targetable_vfo =  RIG_TARGETABLE_FREQ,
 | 
						||
.transceive =  RIG_TRN_RIG,
 | 
						||
.bank_qty =   0,
 | 
						||
.chan_desc_sz =  0,
 | 
						||
 | 
						||
 | 
						||
.chan_list =  {
 | 
						||
			{  0, 89, RIG_MTYPE_MEM  },
 | 
						||
			{ 90, 99, RIG_MTYPE_EDGE },
 | 
						||
		  	RIG_CHAN_END,
 | 
						||
		   },
 | 
						||
.rx_range_list1 =  { 
 | 
						||
	{kHz(500),MHz(60),TS570_ALL_MODES,-1,-1,TS570_VFO},
 | 
						||
	RIG_FRNG_END,
 | 
						||
  }, /* rx range */
 | 
						||
.tx_range_list1 =  {
 | 
						||
    {kHz(1810),kHz(1850)-1,TS570_OTHER_TX_MODES,5000,100000,TS570_VFO},	/* 100W class */
 | 
						||
    {kHz(1800),MHz(2)-1,TS570_AM_TX_MODES,5000,25000,TS570_VFO},		/* 25W class */
 | 
						||
    {kHz(3500),kHz(3800)-1,TS570_OTHER_TX_MODES,5000,100000,TS570_VFO},
 | 
						||
    {kHz(3500),kHz(3800)-1,TS570_AM_TX_MODES,5000,25000,TS570_VFO},
 | 
						||
    {MHz(7),kHz(7100),TS570_OTHER_TX_MODES,5000,100000,TS570_VFO},
 | 
						||
    {MHz(7),kHz(7100),TS570_AM_TX_MODES,5000,25000,TS570_VFO},
 | 
						||
    {kHz(10100),kHz(10150),TS570_OTHER_TX_MODES,5000,100000,TS570_VFO},
 | 
						||
    {kHz(10100),kHz(10150),TS570_AM_TX_MODES,5000,25000,TS570_VFO},
 | 
						||
    {MHz(14),kHz(14350),TS570_OTHER_TX_MODES,5000,100000,TS570_VFO},
 | 
						||
    {MHz(14),kHz(14350),TS570_AM_TX_MODES,5000,25000,TS570_VFO},
 | 
						||
    {kHz(18068),kHz(18168),TS570_OTHER_TX_MODES,5000,100000,TS570_VFO},
 | 
						||
    {kHz(18068),kHz(18168),TS570_AM_TX_MODES,5000,25000,TS570_VFO},
 | 
						||
    {MHz(21),kHz(21450),TS570_OTHER_TX_MODES,5000,100000,TS570_VFO},
 | 
						||
    {MHz(21),kHz(21450),TS570_AM_TX_MODES,5000,25000,TS570_VFO},
 | 
						||
    {kHz(24890),kHz(24990),TS570_OTHER_TX_MODES,5000,100000,TS570_VFO},
 | 
						||
    {kHz(24890),kHz(24990),TS570_AM_TX_MODES,5000,25000,TS570_VFO},
 | 
						||
    {MHz(28),kHz(29700),TS570_OTHER_TX_MODES,5000,100000,TS570_VFO},
 | 
						||
    {MHz(28),kHz(29700),TS570_AM_TX_MODES,5000,25000,TS570_VFO},
 | 
						||
    {MHz(50),MHz(54),TS570_OTHER_TX_MODES,5000,100000,TS570_VFO},
 | 
						||
    {MHz(50),MHz(54),TS570_AM_TX_MODES,5000,25000,TS570_VFO},
 | 
						||
	RIG_FRNG_END,
 | 
						||
  }, /* tx range */
 | 
						||
 | 
						||
.rx_range_list2 =  {
 | 
						||
	{kHz(500),MHz(60),TS570_ALL_MODES,-1,-1,TS570_VFO},
 | 
						||
	RIG_FRNG_END,
 | 
						||
  }, /* rx range */
 | 
						||
.tx_range_list2 =  {
 | 
						||
    {kHz(1800),MHz(2)-1,TS570_OTHER_TX_MODES,5000,100000,TS570_VFO},	/* 100W class */
 | 
						||
    {kHz(1800),MHz(2)-1,TS570_AM_TX_MODES,5000,25000,TS570_VFO},		/* 25W class */
 | 
						||
    {kHz(3500),MHz(4)-1,TS570_OTHER_TX_MODES,5000,100000,TS570_VFO},
 | 
						||
    {kHz(3500),MHz(4)-1,TS570_AM_TX_MODES,5000,25000,TS570_VFO},
 | 
						||
    {MHz(7),kHz(7300),TS570_OTHER_TX_MODES,5000,100000,TS570_VFO},
 | 
						||
    {MHz(7),kHz(7300),TS570_AM_TX_MODES,5000,25000,TS570_VFO},
 | 
						||
    {kHz(10100),kHz(10150),TS570_OTHER_TX_MODES,5000,100000,TS570_VFO},
 | 
						||
    {kHz(10100),kHz(10150),TS570_AM_TX_MODES,5000,25000,TS570_VFO},
 | 
						||
    {MHz(14),kHz(14350),TS570_OTHER_TX_MODES,5000,100000,TS570_VFO},
 | 
						||
    {MHz(14),kHz(14350),TS570_AM_TX_MODES,5000,25000,TS570_VFO},
 | 
						||
    {kHz(18068),kHz(18168),TS570_OTHER_TX_MODES,5000,100000,TS570_VFO},
 | 
						||
    {kHz(18068),kHz(18168),TS570_AM_TX_MODES,5000,25000,TS570_VFO},
 | 
						||
    {MHz(21),kHz(21450),TS570_OTHER_TX_MODES,5000,100000,TS570_VFO},
 | 
						||
    {MHz(21),kHz(21450),TS570_AM_TX_MODES,5000,25000,TS570_VFO},
 | 
						||
    {kHz(24890),kHz(24990),TS570_OTHER_TX_MODES,5000,100000,TS570_VFO},
 | 
						||
    {kHz(24890),kHz(24990),TS570_AM_TX_MODES,5000,25000,TS570_VFO},
 | 
						||
    {MHz(28),kHz(29700),TS570_OTHER_TX_MODES,5000,100000,TS570_VFO},
 | 
						||
    {MHz(28),kHz(29700),TS570_AM_TX_MODES,5000,25000,TS570_VFO},
 | 
						||
    {MHz(50),MHz(54),TS570_OTHER_TX_MODES,5000,100000,TS570_VFO},
 | 
						||
    {MHz(50),MHz(54),TS570_AM_TX_MODES,5000,25000,TS570_VFO},
 | 
						||
	RIG_FRNG_END,
 | 
						||
  }, /* tx range */
 | 
						||
.tuning_steps =  {
 | 
						||
	 {TS570_ALL_MODES,50},
 | 
						||
	 {TS570_ALL_MODES,100},
 | 
						||
	 {TS570_ALL_MODES,kHz(1)},
 | 
						||
	 {TS570_ALL_MODES,kHz(5)},
 | 
						||
	 {TS570_ALL_MODES,kHz(9)},
 | 
						||
	 {TS570_ALL_MODES,kHz(10)},
 | 
						||
	 {TS570_ALL_MODES,12500},
 | 
						||
	 {TS570_ALL_MODES,kHz(20)},
 | 
						||
	 {TS570_ALL_MODES,kHz(25)},
 | 
						||
	 {TS570_ALL_MODES,kHz(100)},
 | 
						||
	 {TS570_ALL_MODES,MHz(1)},
 | 
						||
	 {TS570_ALL_MODES,0},	/* any tuning step */
 | 
						||
	 RIG_TS_END,
 | 
						||
	},
 | 
						||
        /* mode/filter list, remember: order matters! */
 | 
						||
.filters =  {
 | 
						||
		{RIG_MODE_SSB, kHz(2.4)},
 | 
						||
		{RIG_MODE_CW, Hz(200)},
 | 
						||
		{RIG_MODE_RTTY, Hz(500)},
 | 
						||
		{RIG_MODE_AM, kHz(9)},
 | 
						||
		{RIG_MODE_FM, kHz(14)},
 | 
						||
		RIG_FLT_END,
 | 
						||
	},
 | 
						||
.priv =  (void *)&ts570_priv_caps,
 | 
						||
 | 
						||
.set_freq =  kenwood_set_freq,
 | 
						||
.get_freq =  kenwood_get_freq,
 | 
						||
.set_rit =  kenwood_set_rit,
 | 
						||
.get_rit =  kenwood_get_rit,
 | 
						||
.set_xit =  kenwood_set_xit,
 | 
						||
.get_xit =  kenwood_get_xit,
 | 
						||
.set_mode =  ts570_set_mode,
 | 
						||
.get_mode =  ts570_get_mode,
 | 
						||
.set_vfo =  kenwood_set_vfo,
 | 
						||
.get_vfo =  kenwood_get_vfo,
 | 
						||
.set_ctcss_tone =  kenwood_set_ctcss_tone,
 | 
						||
.get_ctcss_tone =  kenwood_get_ctcss_tone,
 | 
						||
.get_ptt =  kenwood_get_ptt,
 | 
						||
.set_ptt =  kenwood_set_ptt,
 | 
						||
.get_dcd =  kenwood_get_dcd,
 | 
						||
.set_func =  kenwood_set_func,
 | 
						||
.get_func =  kenwood_get_func,
 | 
						||
.set_level =  kenwood_set_level,
 | 
						||
.get_level =  kenwood_get_level,
 | 
						||
.vfo_op =  kenwood_vfo_op,
 | 
						||
.set_mem =  kenwood_set_mem,
 | 
						||
.get_mem =  kenwood_get_mem,
 | 
						||
.set_trn =  kenwood_set_trn,
 | 
						||
.get_trn =  kenwood_get_trn,
 | 
						||
.set_powerstat =  kenwood_set_powerstat,
 | 
						||
.get_powerstat =  kenwood_get_powerstat,
 | 
						||
.reset =  kenwood_reset,
 | 
						||
 | 
						||
};
 | 
						||
 | 
						||
/*
 | 
						||
 * ts570d rig capabilities, which is basically the ts570s without 6m.
 | 
						||
 * Notice that some rigs share the same functions.
 | 
						||
 * Also this struct is READONLY!
 | 
						||
 * RIT: Variable Range <20>9.99 kHz
 | 
						||
 *
 | 
						||
 * part of infos comes from .http = //www.kenwood.net/
 | 
						||
 */
 | 
						||
const struct rig_caps ts570d_caps = {
 | 
						||
.rig_model =  RIG_MODEL_TS570D,
 | 
						||
.model_name = "TS-570D",
 | 
						||
.mfg_name =  "Kenwood",
 | 
						||
.version =  "0.2.1",
 | 
						||
.copyright =  "LGPL",
 | 
						||
.status =  RIG_STATUS_UNTESTED,
 | 
						||
.rig_type =  RIG_TYPE_TRANSCEIVER,
 | 
						||
.ptt_type =  RIG_PTT_RIG,
 | 
						||
.dcd_type =  RIG_DCD_RIG,
 | 
						||
.port_type =  RIG_PORT_SERIAL,
 | 
						||
.serial_rate_min =  1200,
 | 
						||
.serial_rate_max =  57600,
 | 
						||
.serial_data_bits =  8,
 | 
						||
.serial_stop_bits =  1,
 | 
						||
.serial_parity =  RIG_PARITY_NONE,
 | 
						||
.serial_handshake =  RIG_HANDSHAKE_NONE,
 | 
						||
.write_delay =  0,
 | 
						||
.post_write_delay =  0,
 | 
						||
.timeout =  200,
 | 
						||
.retry =  3,
 | 
						||
 | 
						||
.has_get_func =  TS570_FUNC_ALL,
 | 
						||
.has_set_func =  TS570_FUNC_ALL,
 | 
						||
.has_get_level =  TS570_LEVEL_ALL,
 | 
						||
.has_set_level =  RIG_LEVEL_SET(TS570_LEVEL_ALL),
 | 
						||
.has_get_parm =  RIG_PARM_NONE,
 | 
						||
.has_set_parm =  RIG_PARM_NONE,    /* FIXME: parms */
 | 
						||
.level_gran =  {},                 /* FIXME: granularity */
 | 
						||
.parm_gran =  {},
 | 
						||
.ctcss_list =  kenwood38_ctcss_list,
 | 
						||
.dcs_list =  NULL,
 | 
						||
.preamp =   { RIG_DBLST_END, },	/* FIXME: preamp list */
 | 
						||
.attenuator =   { 18, RIG_DBLST_END, },
 | 
						||
.max_rit =  Hz(9990),
 | 
						||
.max_xit =  Hz(9990),
 | 
						||
.max_ifshift =  Hz(0),
 | 
						||
.vfo_ops =  TS570_VFO_OP,
 | 
						||
.targetable_vfo =  RIG_TARGETABLE_FREQ,
 | 
						||
.transceive =  RIG_TRN_RIG,
 | 
						||
.bank_qty =   0,
 | 
						||
.chan_desc_sz =  0,
 | 
						||
 | 
						||
.chan_list =  {
 | 
						||
			{  0, 89, RIG_MTYPE_MEM  },
 | 
						||
			{ 90, 99, RIG_MTYPE_EDGE },
 | 
						||
		  	RIG_CHAN_END,
 | 
						||
		   },
 | 
						||
.rx_range_list1 =  { 
 | 
						||
	{kHz(500),MHz(30),TS570_ALL_MODES,-1,-1,TS570_VFO},
 | 
						||
	RIG_FRNG_END,
 | 
						||
  }, /* rx range */
 | 
						||
.tx_range_list1 =  {
 | 
						||
    {kHz(1810),kHz(1850)-1,TS570_OTHER_TX_MODES,5000,100000,TS570_VFO},	/* 100W class */
 | 
						||
    {kHz(1800),MHz(2)-1,TS570_AM_TX_MODES,5000,25000,TS570_VFO},		/* 25W class */
 | 
						||
    {kHz(3500),kHz(3800)-1,TS570_OTHER_TX_MODES,5000,100000,TS570_VFO},
 | 
						||
    {kHz(3500),kHz(3800)-1,TS570_AM_TX_MODES,5000,25000,TS570_VFO},
 | 
						||
    {MHz(7),kHz(7100),TS570_OTHER_TX_MODES,5000,100000,TS570_VFO},
 | 
						||
    {MHz(7),kHz(7100),TS570_AM_TX_MODES,5000,25000,TS570_VFO},
 | 
						||
    {kHz(10100),kHz(10150),TS570_OTHER_TX_MODES,5000,100000,TS570_VFO},
 | 
						||
    {kHz(10100),kHz(10150),TS570_AM_TX_MODES,5000,25000,TS570_VFO},
 | 
						||
    {MHz(14),kHz(14350),TS570_OTHER_TX_MODES,5000,100000,TS570_VFO},
 | 
						||
    {MHz(14),kHz(14350),TS570_AM_TX_MODES,5000,25000,TS570_VFO},
 | 
						||
    {kHz(18068),kHz(18168),TS570_OTHER_TX_MODES,5000,100000,TS570_VFO},
 | 
						||
    {kHz(18068),kHz(18168),TS570_AM_TX_MODES,5000,25000,TS570_VFO},
 | 
						||
    {MHz(21),kHz(21450),TS570_OTHER_TX_MODES,5000,100000,TS570_VFO},
 | 
						||
    {MHz(21),kHz(21450),TS570_AM_TX_MODES,5000,25000,TS570_VFO},
 | 
						||
    {kHz(24890),kHz(24990),TS570_OTHER_TX_MODES,5000,100000,TS570_VFO},
 | 
						||
    {kHz(24890),kHz(24990),TS570_AM_TX_MODES,5000,25000,TS570_VFO},
 | 
						||
    {MHz(28),kHz(29700),TS570_OTHER_TX_MODES,5000,100000,TS570_VFO},
 | 
						||
    {MHz(28),kHz(29700),TS570_AM_TX_MODES,5000,25000,TS570_VFO},
 | 
						||
	RIG_FRNG_END,
 | 
						||
  }, /* tx range */
 | 
						||
 | 
						||
.rx_range_list2 =  {
 | 
						||
	{kHz(500),MHz(30),TS570_ALL_MODES,-1,-1,TS570_VFO},
 | 
						||
	RIG_FRNG_END,
 | 
						||
  }, /* rx range */
 | 
						||
.tx_range_list2 =  {
 | 
						||
    {kHz(1800),MHz(2)-1,TS570_OTHER_TX_MODES,5000,100000,TS570_VFO},	/* 100W class */
 | 
						||
    {kHz(1800),MHz(2)-1,TS570_AM_TX_MODES,5000,25000,TS570_VFO},		/* 25W class */
 | 
						||
    {kHz(3500),MHz(4)-1,TS570_OTHER_TX_MODES,5000,100000,TS570_VFO},
 | 
						||
    {kHz(3500),MHz(4)-1,TS570_AM_TX_MODES,5000,25000,TS570_VFO},
 | 
						||
    {MHz(7),kHz(7300),TS570_OTHER_TX_MODES,5000,100000,TS570_VFO},
 | 
						||
    {MHz(7),kHz(7300),TS570_AM_TX_MODES,5000,25000,TS570_VFO},
 | 
						||
    {kHz(10100),kHz(10150),TS570_OTHER_TX_MODES,5000,100000,TS570_VFO},
 | 
						||
    {kHz(10100),kHz(10150),TS570_AM_TX_MODES,5000,25000,TS570_VFO},
 | 
						||
    {MHz(14),kHz(14350),TS570_OTHER_TX_MODES,5000,100000,TS570_VFO},
 | 
						||
    {MHz(14),kHz(14350),TS570_AM_TX_MODES,5000,25000,TS570_VFO},
 | 
						||
    {kHz(18068),kHz(18168),TS570_OTHER_TX_MODES,5000,100000,TS570_VFO},
 | 
						||
    {kHz(18068),kHz(18168),TS570_AM_TX_MODES,5000,25000,TS570_VFO},
 | 
						||
    {MHz(21),kHz(21450),TS570_OTHER_TX_MODES,5000,100000,TS570_VFO},
 | 
						||
    {MHz(21),kHz(21450),TS570_AM_TX_MODES,5000,25000,TS570_VFO},
 | 
						||
    {kHz(24890),kHz(24990),TS570_OTHER_TX_MODES,5000,100000,TS570_VFO},
 | 
						||
    {kHz(24890),kHz(24990),TS570_AM_TX_MODES,5000,25000,TS570_VFO},
 | 
						||
    {MHz(28),kHz(29700),TS570_OTHER_TX_MODES,5000,100000,TS570_VFO},
 | 
						||
    {MHz(28),kHz(29700),TS570_AM_TX_MODES,5000,25000,TS570_VFO},
 | 
						||
	RIG_FRNG_END,
 | 
						||
  }, /* tx range */
 | 
						||
.tuning_steps =  {
 | 
						||
	 {TS570_ALL_MODES,50},
 | 
						||
	 {TS570_ALL_MODES,100},
 | 
						||
	 {TS570_ALL_MODES,kHz(1)},
 | 
						||
	 {TS570_ALL_MODES,kHz(5)},
 | 
						||
	 {TS570_ALL_MODES,kHz(9)},
 | 
						||
	 {TS570_ALL_MODES,kHz(10)},
 | 
						||
	 {TS570_ALL_MODES,12500},
 | 
						||
	 {TS570_ALL_MODES,kHz(20)},
 | 
						||
	 {TS570_ALL_MODES,kHz(25)},
 | 
						||
	 {TS570_ALL_MODES,kHz(100)},
 | 
						||
	 {TS570_ALL_MODES,MHz(1)},
 | 
						||
	 {TS570_ALL_MODES,0},	/* any tuning step */
 | 
						||
	 RIG_TS_END,
 | 
						||
	},
 | 
						||
        /* mode/filter list, remember: order matters! */
 | 
						||
.filters =  {
 | 
						||
		{RIG_MODE_SSB, Hz(500)},
 | 
						||
		{RIG_MODE_SSB, Hz(0)},
 | 
						||
		{RIG_MODE_SSB, kHz(1)},
 | 
						||
		{RIG_MODE_CW, Hz(400)},
 | 
						||
		{RIG_MODE_CW, Hz(100)},
 | 
						||
		{RIG_MODE_CW, Hz(1000)},
 | 
						||
		{RIG_MODE_RTTY, Hz(1000)},
 | 
						||
		{RIG_MODE_RTTY, Hz(500)},
 | 
						||
		{RIG_MODE_RTTY, Hz(1500)},
 | 
						||
		{RIG_MODE_AM, Hz(500)},
 | 
						||
		{RIG_MODE_AM, Hz(0)},
 | 
						||
		{RIG_MODE_AM, kHz(1)},
 | 
						||
		{RIG_MODE_FM, Hz(500)},
 | 
						||
		{RIG_MODE_FM, Hz(0)},
 | 
						||
		{RIG_MODE_FM, kHz(1)},
 | 
						||
		RIG_FLT_END,
 | 
						||
	},
 | 
						||
.priv =  (void *)&ts570_priv_caps,
 | 
						||
 | 
						||
.set_freq =  kenwood_set_freq,
 | 
						||
.get_freq =  kenwood_get_freq,
 | 
						||
.set_rit =  kenwood_set_rit,
 | 
						||
.get_rit =  kenwood_get_rit,
 | 
						||
.set_xit =  kenwood_set_xit,
 | 
						||
.get_xit =  kenwood_get_xit,
 | 
						||
.set_mode =  kenwood_set_mode,
 | 
						||
.get_mode =  kenwood_get_mode,
 | 
						||
.set_vfo =  kenwood_set_vfo,
 | 
						||
.get_vfo =  kenwood_get_vfo,
 | 
						||
.set_ctcss_tone =  kenwood_set_ctcss_tone,
 | 
						||
.get_ctcss_tone =  kenwood_get_ctcss_tone,
 | 
						||
.get_ptt =  kenwood_get_ptt,
 | 
						||
.set_ptt =  kenwood_set_ptt,
 | 
						||
.get_dcd =  kenwood_get_dcd,
 | 
						||
.set_func =  kenwood_set_func,
 | 
						||
.get_func =  kenwood_get_func,
 | 
						||
.set_level =  kenwood_set_level,
 | 
						||
.get_level =  kenwood_get_level,
 | 
						||
.vfo_op =  kenwood_vfo_op,
 | 
						||
.set_mem =  kenwood_set_mem,
 | 
						||
.get_mem =  kenwood_get_mem,
 | 
						||
.set_trn =  kenwood_set_trn,
 | 
						||
.get_trn =  kenwood_get_trn,
 | 
						||
.set_powerstat =  kenwood_set_powerstat,
 | 
						||
.get_powerstat =  kenwood_get_powerstat,
 | 
						||
.reset =  kenwood_reset,
 | 
						||
 | 
						||
};
 | 
						||
 | 
						||
 | 
						||
/*
 | 
						||
 * Function definitions below
 | 
						||
 */
 | 
						||
 |