1 /* 2 * Hamlib Kenwood backend - TM-D700 description 3 * Copyright (c) 2000-2010 by Stephane Fillod 4 * 5 * 6 * This library is free software; you can redistribute it and/or 7 * modify it under the terms of the GNU Lesser General Public 8 * License as published by the Free Software Foundation; either 9 * version 2.1 of the License, or (at your option) any later version. 10 * 11 * This library is distributed in the hope that it will be useful, 12 * but WITHOUT ANY WARRANTY; without even the implied warranty of 13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 14 * Lesser General Public License for more details. 15 * 16 * You should have received a copy of the GNU Lesser General Public 17 * License along with this library; if not, write to the Free Software 18 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA 19 * 20 */ 21 22 #ifdef HAVE_CONFIG_H 23 #include "config.h" 24 #endif 25 26 #include <stdlib.h> 27 #include <math.h> 28 29 #include "hamlib/rig.h" 30 #include "kenwood.h" 31 #include "th.h" 32 #include "tones.h" 33 34 35 #define TMD700_MODES (RIG_MODE_FM|RIG_MODE_AM) 36 #define TMD700_MODES_TX (RIG_MODE_FM) 37 38 /* TBC */ 39 #define TMD700_FUNC_ALL (RIG_FUNC_TSQL| \ 40 RIG_FUNC_AIP| \ 41 RIG_FUNC_MON| \ 42 RIG_FUNC_MUTE| \ 43 RIG_FUNC_SQL| \ 44 RIG_FUNC_TONE| \ 45 RIG_FUNC_TBURST| \ 46 RIG_FUNC_REV| \ 47 RIG_FUNC_LOCK| \ 48 RIG_FUNC_ARO) 49 50 #define TMD700_LEVEL_ALL (RIG_LEVEL_STRENGTH| \ 51 RIG_LEVEL_SQL| \ 52 RIG_LEVEL_AF| \ 53 RIG_LEVEL_RF|\ 54 RIG_LEVEL_MICGAIN) 55 56 #define TMD700_PARMS (RIG_PARM_BACKLIGHT|\ 57 RIG_PARM_BEEP|\ 58 RIG_PARM_APO) 59 60 #define TMD700_VFO_OP (RIG_OP_UP|RIG_OP_DOWN) 61 62 #define TMD700_CHANNEL_CAPS \ 63 TH_CHANNEL_CAPS,\ 64 .flags=1, \ 65 .dcs_code=1, \ 66 .dcs_sql=1, 67 68 #define TMD700_CHANNEL_CAPS_WO_LO \ 69 TH_CHANNEL_CAPS,\ 70 .dcs_code=1, \ 71 .dcs_sql=1, 72 73 /* 74 * TODO: Band A & B 75 */ 76 #define TMD700_VFO (RIG_VFO_A|RIG_VFO_B) 77 78 static rmode_t tmd700_mode_table[KENWOOD_MODE_TABLE_MAX] = 79 { 80 [0] = RIG_MODE_FM, 81 [1] = RIG_MODE_AM, 82 }; 83 84 static struct kenwood_priv_caps tmd700_priv_caps = 85 { 86 .cmdtrm = EOM_TH, /* Command termination character */ 87 .mode_table = tmd700_mode_table, 88 }; 89 90 91 92 /* 93 * TM-D700 rig capabilities. 94 * 95 * specs: http://www.geocities.jp/hkwatarin/TM-D700/English/spec.htm 96 * protocol: http://www.qsl.net/k/k7jar//pages/D700Cmds.html 97 */ 98 const struct rig_caps tmd700_caps = 99 { 100 RIG_MODEL(RIG_MODEL_TMD700), 101 .model_name = "TM-D700", 102 .mfg_name = "Kenwood", 103 .version = TH_VER ".0", 104 .copyright = "LGPL", 105 .status = RIG_STATUS_BETA, 106 .rig_type = RIG_TYPE_MOBILE | RIG_FLAG_APRS | RIG_FLAG_TNC, 107 .ptt_type = RIG_PTT_RIG, 108 .dcd_type = RIG_DCD_RIG, 109 .port_type = RIG_PORT_SERIAL, 110 .serial_rate_min = 9600, 111 .serial_rate_max = 57600, 112 .serial_data_bits = 8, 113 .serial_stop_bits = 1, 114 .serial_parity = RIG_PARITY_NONE, 115 .serial_handshake = RIG_HANDSHAKE_NONE, 116 .write_delay = 0, 117 .post_write_delay = 0, 118 .timeout = 1000, 119 .retry = 3, 120 121 .has_get_func = TMD700_FUNC_ALL, 122 .has_set_func = TMD700_FUNC_ALL, 123 .has_get_level = TMD700_LEVEL_ALL, 124 .has_set_level = RIG_LEVEL_SET(TMD700_LEVEL_ALL), 125 .has_get_parm = TMD700_PARMS, 126 .has_set_parm = TMD700_PARMS, /* FIXME: parms */ 127 .level_gran = { 128 // cppcheck-suppress * 129 [LVL_RAWSTR] = { .min = { .i = 0 }, .max = { .i = 7 } }, 130 [LVL_SQL] = { .min = { .i = 0 }, .max = { .i = 0x1f }, .step = { .f = 1. / 0x1f } }, 131 [LVL_RFPOWER] = { .min = { .i = 2 }, .max = { .i = 0 }, .step = { .f = 1. / 3. } }, 132 [LVL_AF] = { .min = { .i = 0 }, .max = { .i = 0x3f }, .step = { .f = 1. / 0x3f } }, 133 }, 134 .parm_gran = {}, 135 .ctcss_list = kenwood38_ctcss_list, 136 .dcs_list = common_dcs_list, 137 .preamp = { RIG_DBLST_END, }, 138 .attenuator = { RIG_DBLST_END, }, 139 .max_rit = Hz(0), 140 .max_xit = Hz(0), 141 .max_ifshift = Hz(0), 142 .vfo_ops = TMD700_VFO_OP, 143 .scan_ops = RIG_SCAN_VFO, 144 .targetable_vfo = RIG_TARGETABLE_NONE, 145 .transceive = RIG_TRN_RIG, 146 .bank_qty = 0, 147 .chan_desc_sz = 8, 148 149 .chan_list = { 150 { 1, 199, RIG_MTYPE_MEM, {TMD700_CHANNEL_CAPS}}, /* normal MEM */ 151 { 200, 219, RIG_MTYPE_EDGE, {TMD700_CHANNEL_CAPS}}, /* U/L MEM */ 152 { 221, 222, RIG_MTYPE_CALL, {TMD700_CHANNEL_CAPS_WO_LO}}, /* Call 0/1 */ 153 RIG_CHAN_END, 154 }, 155 /* 156 * TODO: Japan & TM-D700S, and Taiwan models 157 */ 158 .rx_range_list1 = { 159 {MHz(118), MHz(470), TMD700_MODES, -1, -1, RIG_VFO_A}, 160 {MHz(136), MHz(174), RIG_MODE_FM, -1, -1, RIG_VFO_B}, 161 {MHz(300), MHz(524), RIG_MODE_FM, -1, -1, RIG_VFO_B}, 162 {MHz(800), MHz(1300), RIG_MODE_FM, -1, -1, RIG_VFO_B}, 163 RIG_FRNG_END, 164 }, /* rx range */ 165 .tx_range_list1 = { 166 {MHz(144), MHz(146), TMD700_MODES_TX, W(5), W(50), RIG_VFO_A}, 167 {MHz(430), MHz(440), TMD700_MODES_TX, W(5), W(35), RIG_VFO_A}, 168 RIG_FRNG_END, 169 }, /* tx range */ 170 171 .rx_range_list2 = { 172 {MHz(118), MHz(470), TMD700_MODES, -1, -1, RIG_VFO_A}, 173 {MHz(136), MHz(174), RIG_MODE_FM, -1, -1, RIG_VFO_B}, 174 {MHz(300), MHz(524), RIG_MODE_FM, -1, -1, RIG_VFO_B}, 175 {MHz(800), MHz(1300), RIG_MODE_FM, -1, -1, RIG_VFO_B}, /* TODO: cellular blocked */ 176 RIG_FRNG_END, 177 }, /* rx range */ 178 .tx_range_list2 = { 179 {MHz(144), MHz(148), TMD700_MODES_TX, W(5), W(50), RIG_VFO_A}, 180 {MHz(430), MHz(450), TMD700_MODES_TX, W(5), W(35), RIG_VFO_A}, 181 RIG_FRNG_END, 182 }, /* tx range */ 183 184 .tuning_steps = { 185 {TMD700_MODES, kHz(5)}, 186 {TMD700_MODES, kHz(6.25)}, 187 {TMD700_MODES, kHz(10)}, 188 {TMD700_MODES, kHz(12.5)}, 189 {TMD700_MODES, kHz(15)}, 190 {TMD700_MODES, kHz(20)}, 191 {TMD700_MODES, kHz(25)}, 192 {TMD700_MODES, kHz(30)}, 193 {TMD700_MODES, kHz(50)}, 194 {TMD700_MODES, kHz(100)}, 195 RIG_TS_END, 196 }, 197 /* mode/filter list, remember: order matters! */ 198 .filters = { 199 {RIG_MODE_FM, kHz(12)}, 200 {RIG_MODE_AM, kHz(9)}, /* TBC */ 201 RIG_FLT_END, 202 }, 203 .priv = (void *)& tmd700_priv_caps, 204 205 .rig_init = kenwood_init, 206 .rig_open = kenwood_open, 207 .rig_close = kenwood_close, 208 .rig_cleanup = kenwood_cleanup, 209 .set_freq = th_set_freq, 210 .get_freq = th_get_freq, 211 .set_mode = th_set_mode, 212 .get_mode = th_get_mode, 213 .set_vfo = tm_set_vfo_bc2, 214 .get_vfo = th_get_vfo, 215 .set_split_vfo = th_set_split_vfo, 216 .get_split_vfo = th_get_split_vfo, 217 .set_ctcss_tone = th_set_ctcss_tone, 218 .get_ctcss_tone = th_get_ctcss_tone, 219 .set_ctcss_sql = th_set_ctcss_sql, 220 .get_ctcss_sql = th_get_ctcss_sql, 221 .set_dcs_sql = th_set_dcs_sql, 222 .get_dcs_sql = th_get_dcs_sql, 223 .set_mem = th_set_mem, 224 .get_mem = th_get_mem, 225 .set_channel = th_set_channel, 226 .get_channel = th_get_channel, 227 .set_trn = th_set_trn, 228 .get_trn = th_get_trn, 229 230 .set_func = th_set_func, 231 .get_func = th_get_func, 232 .set_level = th_set_level, 233 .get_level = th_get_level, 234 .set_parm = th_set_parm, 235 .get_parm = th_get_parm, 236 .get_info = th_get_info, 237 .get_dcd = th_get_dcd, 238 .set_ptt = th_set_ptt, 239 .vfo_op = th_vfo_op, 240 .scan = th_scan, 241 242 .decode_event = th_decode_event, 243 }; 244 245 246 /* end of file */ 247