1 /* zd_rf_uw2453.c: Functions for the UW2453 RF controller
 
   3  * This program is free software; you can redistribute it and/or modify
 
   4  * it under the terms of the GNU General Public License as published by
 
   5  * the Free Software Foundation; either version 2 of the License, or
 
   6  * (at your option) any later version.
 
   8  * This program is distributed in the hope that it will be useful,
 
   9  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 
  10  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
  11  * GNU General Public License for more details.
 
  13  * You should have received a copy of the GNU General Public License
 
  14  * along with this program; if not, write to the Free Software
 
  15  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
 
  18 #include <linux/kernel.h>
 
  24 /* This RF programming code is based upon the code found in v2.16.0.0 of the
 
  25  * ZyDAS vendor driver. Unlike other RF's, Ubec publish full technical specs
 
  26  * for this RF on their website, so we're able to understand more than
 
  27  * usual as to what is going on. Thumbs up for Ubec for doing that. */
 
  29 /* The 3-wire serial interface provides access to 8 write-only registers.
 
  30  * The data format is a 4 bit register address followed by a 20 bit value. */
 
  31 #define UW2453_REGWRITE(reg, val) ((((reg) & 0xf) << 20) | ((val) & 0xfffff))
 
  33 /* For channel tuning, we have to configure registers 1 (synthesizer), 2 (synth
 
  34  * fractional divide ratio) and 3 (VCO config).
 
  36  * We configure the RF to produce an interrupt when the PLL is locked onto
 
  37  * the configured frequency. During initialization, we run through a variety
 
  38  * of different VCO configurations on channel 1 until we detect a PLL lock.
 
  39  * When this happens, we remember which VCO configuration produced the lock
 
  40  * and use it later. Actually, we use the configuration *after* the one that
 
  41  * produced the lock, which seems odd, but it works.
 
  43  * If we do not see a PLL lock on any standard VCO config, we fall back on an
 
  44  * autocal configuration, which has a fixed (as opposed to per-channel) VCO
 
  45  * config and different synth values from the standard set (divide ratio
 
  46  * is still shared with the standard set). */
 
  48 /* The per-channel synth values for all standard VCO configurations. These get
 
  49  * written to register 1. */
 
  50 static const u8 uw2453_std_synth[] = {
 
  51         RF_CHANNEL( 1) = 0x47,
 
  52         RF_CHANNEL( 2) = 0x47,
 
  53         RF_CHANNEL( 3) = 0x67,
 
  54         RF_CHANNEL( 4) = 0x67,
 
  55         RF_CHANNEL( 5) = 0x67,
 
  56         RF_CHANNEL( 6) = 0x67,
 
  57         RF_CHANNEL( 7) = 0x57,
 
  58         RF_CHANNEL( 8) = 0x57,
 
  59         RF_CHANNEL( 9) = 0x57,
 
  60         RF_CHANNEL(10) = 0x57,
 
  61         RF_CHANNEL(11) = 0x77,
 
  62         RF_CHANNEL(12) = 0x77,
 
  63         RF_CHANNEL(13) = 0x77,
 
  64         RF_CHANNEL(14) = 0x4f,
 
  67 /* This table stores the synthesizer fractional divide ratio for *all* VCO
 
  68  * configurations (both standard and autocal). These get written to register 2.
 
  70 static const u16 uw2453_synth_divide[] = {
 
  71         RF_CHANNEL( 1) = 0x999,
 
  72         RF_CHANNEL( 2) = 0x99b,
 
  73         RF_CHANNEL( 3) = 0x998,
 
  74         RF_CHANNEL( 4) = 0x99a,
 
  75         RF_CHANNEL( 5) = 0x999,
 
  76         RF_CHANNEL( 6) = 0x99b,
 
  77         RF_CHANNEL( 7) = 0x998,
 
  78         RF_CHANNEL( 8) = 0x99a,
 
  79         RF_CHANNEL( 9) = 0x999,
 
  80         RF_CHANNEL(10) = 0x99b,
 
  81         RF_CHANNEL(11) = 0x998,
 
  82         RF_CHANNEL(12) = 0x99a,
 
  83         RF_CHANNEL(13) = 0x999,
 
  84         RF_CHANNEL(14) = 0xccc,
 
  87 /* Here is the data for all the standard VCO configurations. We shrink our
 
  88  * table a little by observing that both channels in a consecutive pair share
 
  89  * the same value. We also observe that the high 4 bits ([0:3] in the specs)
 
  90  * are all 'Reserved' and are always set to 0x4 - we chop them off in the data
 
  92 #define CHAN_TO_PAIRIDX(a) ((a - 1) / 2)
 
  93 #define RF_CHANPAIR(a,b) [CHAN_TO_PAIRIDX(a)]
 
  94 static const u16 uw2453_std_vco_cfg[][7] = {
 
  96                 RF_CHANPAIR( 1,  2) = 0x664d,
 
  97                 RF_CHANPAIR( 3,  4) = 0x604d,
 
  98                 RF_CHANPAIR( 5,  6) = 0x6675,
 
  99                 RF_CHANPAIR( 7,  8) = 0x6475,
 
 100                 RF_CHANPAIR( 9, 10) = 0x6655,
 
 101                 RF_CHANPAIR(11, 12) = 0x6455,
 
 102                 RF_CHANPAIR(13, 14) = 0x6665,
 
 105                 RF_CHANPAIR( 1,  2) = 0x666d,
 
 106                 RF_CHANPAIR( 3,  4) = 0x606d,
 
 107                 RF_CHANPAIR( 5,  6) = 0x664d,
 
 108                 RF_CHANPAIR( 7,  8) = 0x644d,
 
 109                 RF_CHANPAIR( 9, 10) = 0x6675,
 
 110                 RF_CHANPAIR(11, 12) = 0x6475,
 
 111                 RF_CHANPAIR(13, 14) = 0x6655,
 
 114                 RF_CHANPAIR( 1,  2) = 0x665d,
 
 115                 RF_CHANPAIR( 3,  4) = 0x605d,
 
 116                 RF_CHANPAIR( 5,  6) = 0x666d,
 
 117                 RF_CHANPAIR( 7,  8) = 0x646d,
 
 118                 RF_CHANPAIR( 9, 10) = 0x664d,
 
 119                 RF_CHANPAIR(11, 12) = 0x644d,
 
 120                 RF_CHANPAIR(13, 14) = 0x6675,
 
 123                 RF_CHANPAIR( 1,  2) = 0x667d,
 
 124                 RF_CHANPAIR( 3,  4) = 0x607d,
 
 125                 RF_CHANPAIR( 5,  6) = 0x665d,
 
 126                 RF_CHANPAIR( 7,  8) = 0x645d,
 
 127                 RF_CHANPAIR( 9, 10) = 0x666d,
 
 128                 RF_CHANPAIR(11, 12) = 0x646d,
 
 129                 RF_CHANPAIR(13, 14) = 0x664d,
 
 132                 RF_CHANPAIR( 1,  2) = 0x6643,
 
 133                 RF_CHANPAIR( 3,  4) = 0x6043,
 
 134                 RF_CHANPAIR( 5,  6) = 0x667d,
 
 135                 RF_CHANPAIR( 7,  8) = 0x647d,
 
 136                 RF_CHANPAIR( 9, 10) = 0x665d,
 
 137                 RF_CHANPAIR(11, 12) = 0x645d,
 
 138                 RF_CHANPAIR(13, 14) = 0x666d,
 
 141                 RF_CHANPAIR( 1,  2) = 0x6663,
 
 142                 RF_CHANPAIR( 3,  4) = 0x6063,
 
 143                 RF_CHANPAIR( 5,  6) = 0x6643,
 
 144                 RF_CHANPAIR( 7,  8) = 0x6443,
 
 145                 RF_CHANPAIR( 9, 10) = 0x667d,
 
 146                 RF_CHANPAIR(11, 12) = 0x647d,
 
 147                 RF_CHANPAIR(13, 14) = 0x665d,
 
 150                 RF_CHANPAIR( 1,  2) = 0x6653,
 
 151                 RF_CHANPAIR( 3,  4) = 0x6053,
 
 152                 RF_CHANPAIR( 5,  6) = 0x6663,
 
 153                 RF_CHANPAIR( 7,  8) = 0x6463,
 
 154                 RF_CHANPAIR( 9, 10) = 0x6643,
 
 155                 RF_CHANPAIR(11, 12) = 0x6443,
 
 156                 RF_CHANPAIR(13, 14) = 0x667d,
 
 159                 RF_CHANPAIR( 1,  2) = 0x6673,
 
 160                 RF_CHANPAIR( 3,  4) = 0x6073,
 
 161                 RF_CHANPAIR( 5,  6) = 0x6653,
 
 162                 RF_CHANPAIR( 7,  8) = 0x6453,
 
 163                 RF_CHANPAIR( 9, 10) = 0x6663,
 
 164                 RF_CHANPAIR(11, 12) = 0x6463,
 
 165                 RF_CHANPAIR(13, 14) = 0x6643,
 
 168                 RF_CHANPAIR( 1,  2) = 0x664b,
 
 169                 RF_CHANPAIR( 3,  4) = 0x604b,
 
 170                 RF_CHANPAIR( 5,  6) = 0x6673,
 
 171                 RF_CHANPAIR( 7,  8) = 0x6473,
 
 172                 RF_CHANPAIR( 9, 10) = 0x6653,
 
 173                 RF_CHANPAIR(11, 12) = 0x6453,
 
 174                 RF_CHANPAIR(13, 14) = 0x6663,
 
 177                 RF_CHANPAIR( 1,  2) = 0x666b,
 
 178                 RF_CHANPAIR( 3,  4) = 0x606b,
 
 179                 RF_CHANPAIR( 5,  6) = 0x664b,
 
 180                 RF_CHANPAIR( 7,  8) = 0x644b,
 
 181                 RF_CHANPAIR( 9, 10) = 0x6673,
 
 182                 RF_CHANPAIR(11, 12) = 0x6473,
 
 183                 RF_CHANPAIR(13, 14) = 0x6653,
 
 186                 RF_CHANPAIR( 1,  2) = 0x665b,
 
 187                 RF_CHANPAIR( 3,  4) = 0x605b,
 
 188                 RF_CHANPAIR( 5,  6) = 0x666b,
 
 189                 RF_CHANPAIR( 7,  8) = 0x646b,
 
 190                 RF_CHANPAIR( 9, 10) = 0x664b,
 
 191                 RF_CHANPAIR(11, 12) = 0x644b,
 
 192                 RF_CHANPAIR(13, 14) = 0x6673,
 
 197 /* The per-channel synth values for autocal. These get written to register 1. */
 
 198 static const u16 uw2453_autocal_synth[] = {
 
 199         RF_CHANNEL( 1) = 0x6847,
 
 200         RF_CHANNEL( 2) = 0x6847,
 
 201         RF_CHANNEL( 3) = 0x6867,
 
 202         RF_CHANNEL( 4) = 0x6867,
 
 203         RF_CHANNEL( 5) = 0x6867,
 
 204         RF_CHANNEL( 6) = 0x6867,
 
 205         RF_CHANNEL( 7) = 0x6857,
 
 206         RF_CHANNEL( 8) = 0x6857,
 
 207         RF_CHANNEL( 9) = 0x6857,
 
 208         RF_CHANNEL(10) = 0x6857,
 
 209         RF_CHANNEL(11) = 0x6877,
 
 210         RF_CHANNEL(12) = 0x6877,
 
 211         RF_CHANNEL(13) = 0x6877,
 
 212         RF_CHANNEL(14) = 0x684f,
 
 215 /* The VCO configuration for autocal (all channels) */
 
 216 static const u16 UW2453_AUTOCAL_VCO_CFG = 0x6662;
 
 218 /* TX gain settings. The array index corresponds to the TX power integration
 
 219  * values found in the EEPROM. The values get written to register 7. */
 
 220 static u32 uw2453_txgain[] = {
 
 242 /* RF-specific structure */
 
 244         /* index into synth/VCO config tables where PLL lock was found
 
 245          * -1 means autocal */
 
 249 #define UW2453_PRIV(rf) ((struct uw2453_priv *) (rf)->priv)
 
 251 static int uw2453_synth_set_channel(struct zd_chip *chip, int channel,
 
 255         int idx = channel - 1;
 
 259                 val = UW2453_REGWRITE(1, uw2453_autocal_synth[idx]);
 
 261                 val = UW2453_REGWRITE(1, uw2453_std_synth[idx]);
 
 263         r = zd_rfwrite_locked(chip, val, RF_RV_BITS);
 
 267         return zd_rfwrite_locked(chip,
 
 268                 UW2453_REGWRITE(2, uw2453_synth_divide[idx]), RF_RV_BITS);
 
 271 static int uw2453_write_vco_cfg(struct zd_chip *chip, u16 value)
 
 273         /* vendor driver always sets these upper bits even though the specs say
 
 274          * they are reserved */
 
 275         u32 val = 0x40000 | value;
 
 276         return zd_rfwrite_locked(chip, UW2453_REGWRITE(3, val), RF_RV_BITS);
 
 279 static int uw2453_init_mode(struct zd_chip *chip)
 
 281         static const u32 rv[] = {
 
 282                 UW2453_REGWRITE(0, 0x25f98), /* enter IDLE mode */
 
 283                 UW2453_REGWRITE(0, 0x25f9a), /* enter CAL_VCO mode */
 
 284                 UW2453_REGWRITE(0, 0x25f94), /* enter RX/TX mode */
 
 285                 UW2453_REGWRITE(0, 0x27fd4), /* power down RSSI circuit */
 
 288         return zd_rfwritev_locked(chip, rv, ARRAY_SIZE(rv), RF_RV_BITS);
 
 291 static int uw2453_set_tx_gain_level(struct zd_chip *chip, int channel)
 
 293         u8 int_value = chip->pwr_int_values[channel - 1];
 
 295         if (int_value >= ARRAY_SIZE(uw2453_txgain)) {
 
 296                 dev_dbg_f(zd_chip_dev(chip), "can't configure TX gain for "
 
 297                           "int value %x on channel %d\n", int_value, channel);
 
 301         return zd_rfwrite_locked(chip,
 
 302                 UW2453_REGWRITE(7, uw2453_txgain[int_value]), RF_RV_BITS);
 
 305 static int uw2453_init_hw(struct zd_rf *rf)
 
 308         int found_config = -1;
 
 310         struct zd_chip *chip = zd_rf_to_chip(rf);
 
 312         static const struct zd_ioreq16 ioreqs[] = {
 
 313                 { CR10,  0x89 }, { CR15,  0x20 },
 
 314                 { CR17,  0x28 }, /* 6112 no change */
 
 315                 { CR23,  0x38 }, { CR24,  0x20 }, { CR26,  0x93 },
 
 316                 { CR27,  0x15 }, { CR28,  0x3e }, { CR29,  0x00 },
 
 317                 { CR33,  0x28 }, { CR34,  0x30 },
 
 318                 { CR35,  0x43 }, /* 6112 3e->43 */
 
 319                 { CR41,  0x24 }, { CR44,  0x32 },
 
 320                 { CR46,  0x92 }, /* 6112 96->92 */
 
 322                 { CR48,  0x04 }, /* 5602 Roger */
 
 323                 { CR49,  0xfa }, { CR79,  0x58 }, { CR80,  0x30 },
 
 324                 { CR81,  0x30 }, { CR87,  0x0a }, { CR89,  0x04 },
 
 325                 { CR91,  0x00 }, { CR92,  0x0a }, { CR98,  0x8d },
 
 326                 { CR99,  0x28 }, { CR100, 0x02 },
 
 327                 { CR101, 0x09 }, /* 6112 13->1f 6220 1f->13 6407 13->9 */
 
 329                 { CR106, 0x1c }, /* 5d07 5112 1f->1c 6220 1c->1f 6221 1f->1c */
 
 330                 { CR107, 0x1c }, /* 6220 1c->1a 5221 1a->1c */
 
 332                 { CR110, 0x1f }, /* 6112 13->1f 6221 1f->13 6407 13->0x09 */
 
 333                 { CR111, 0x13 }, { CR112, 0x1f }, { CR113, 0x27 },
 
 334                 { CR114, 0x23 }, /* 6221 27->23 */
 
 335                 { CR115, 0x24 }, /* 6112 24->1c 6220 1c->24 */
 
 336                 { CR116, 0x24 }, /* 6220 1c->24 */
 
 337                 { CR117, 0xfa }, /* 6112 fa->f8 6220 f8->f4 6220 f4->fa */
 
 338                 { CR118, 0xf0 }, /* 5d07 6112 f0->f2 6220 f2->f0 */
 
 339                 { CR119, 0x1a }, /* 6112 1a->10 6220 10->14 6220 14->1a */
 
 341                 { CR121, 0x1f }, /* 6220 4f->1f */
 
 342                 { CR122, 0xf0 }, { CR123, 0x57 }, { CR125, 0xad },
 
 343                 { CR126, 0x6c }, { CR127, 0x03 },
 
 344                 { CR128, 0x14 }, /* 6302 12->11 */
 
 345                 { CR129, 0x12 }, /* 6301 10->0f */
 
 346                 { CR130, 0x10 }, { CR137, 0x50 }, { CR138, 0xa8 },
 
 347                 { CR144, 0xac }, { CR146, 0x20 }, { CR252, 0xff },
 
 351         static const u32 rv[] = {
 
 352                 UW2453_REGWRITE(4, 0x2b),    /* configure reciever gain */
 
 353                 UW2453_REGWRITE(5, 0x19e4f), /* configure transmitter gain */
 
 354                 UW2453_REGWRITE(6, 0xf81ad), /* enable RX/TX filter tuning */
 
 355                 UW2453_REGWRITE(7, 0x3fffe), /* disable TX gain in test mode */
 
 357                 /* enter CAL_FIL mode, TX gain set by registers, RX gain set by pins,
 
 358                  * RSSI circuit powered down, reduced RSSI range */
 
 359                 UW2453_REGWRITE(0, 0x25f9c), /* 5d01 cal_fil */
 
 361                 /* synthesizer configuration for channel 1 */
 
 362                 UW2453_REGWRITE(1, 0x47),
 
 363                 UW2453_REGWRITE(2, 0x999),
 
 365                 /* disable manual VCO band selection */
 
 366                 UW2453_REGWRITE(3, 0x7602),
 
 368                 /* enable manual VCO band selection, configure current level */
 
 369                 UW2453_REGWRITE(3, 0x46063),
 
 372         r = zd_iowrite16a_locked(chip, ioreqs, ARRAY_SIZE(ioreqs));
 
 376         r = zd_rfwritev_locked(chip, rv, ARRAY_SIZE(rv), RF_RV_BITS);
 
 380         r = uw2453_init_mode(chip);
 
 384         /* Try all standard VCO configuration settings on channel 1 */
 
 385         for (i = 0; i < ARRAY_SIZE(uw2453_std_vco_cfg) - 1; i++) {
 
 386                 /* Configure synthesizer for channel 1 */
 
 387                 r = uw2453_synth_set_channel(chip, 1, false);
 
 391                 /* Write VCO config */
 
 392                 r = uw2453_write_vco_cfg(chip, uw2453_std_vco_cfg[i][0]);
 
 396                 /* ack interrupt event */
 
 397                 r = zd_iowrite16_locked(chip, 0x0f, UW2453_INTR_REG);
 
 401                 /* check interrupt status */
 
 402                 r = zd_ioread16_locked(chip, &intr_status, UW2453_INTR_REG);
 
 406                 if (!intr_status & 0xf) {
 
 407                         dev_dbg_f(zd_chip_dev(chip),
 
 408                                 "PLL locked on configuration %d\n", i);
 
 414         if (found_config == -1) {
 
 416                 dev_dbg_f(zd_chip_dev(chip),
 
 417                         "PLL did not lock, using autocal\n");
 
 419                 r = uw2453_synth_set_channel(chip, 1, true);
 
 423                 r = uw2453_write_vco_cfg(chip, UW2453_AUTOCAL_VCO_CFG);
 
 428         /* To match the vendor driver behaviour, we use the configuration after
 
 429          * the one that produced a lock. */
 
 430         UW2453_PRIV(rf)->config = found_config + 1;
 
 432         return zd_iowrite16_locked(chip, 0x06, CR203);
 
 435 static int uw2453_set_channel(struct zd_rf *rf, u8 channel)
 
 439         int config = UW2453_PRIV(rf)->config;
 
 440         bool autocal = (config == -1);
 
 441         struct zd_chip *chip = zd_rf_to_chip(rf);
 
 443         static const struct zd_ioreq16 ioreqs[] = {
 
 444                 { CR80,  0x30 }, { CR81,  0x30 }, { CR79,  0x58 },
 
 445                 { CR12,  0xf0 }, { CR77,  0x1b }, { CR78,  0x58 },
 
 448         r = uw2453_synth_set_channel(chip, channel, autocal);
 
 453                 vco_cfg = UW2453_AUTOCAL_VCO_CFG;
 
 455                 vco_cfg = uw2453_std_vco_cfg[config][CHAN_TO_PAIRIDX(channel)];
 
 457         r = uw2453_write_vco_cfg(chip, vco_cfg);
 
 461         r = uw2453_init_mode(chip);
 
 465         r = zd_iowrite16a_locked(chip, ioreqs, ARRAY_SIZE(ioreqs));
 
 469         r = uw2453_set_tx_gain_level(chip, channel);
 
 473         return zd_iowrite16_locked(chip, 0x06, CR203);
 
 476 static int uw2453_switch_radio_on(struct zd_rf *rf)
 
 479         struct zd_chip *chip = zd_rf_to_chip(rf);
 
 480         struct zd_ioreq16 ioreqs[] = {
 
 481                 { CR11,  0x00 }, { CR251, 0x3f },
 
 484         /* enter RXTX mode */
 
 485         r = zd_rfwrite_locked(chip, UW2453_REGWRITE(0, 0x25f94), RF_RV_BITS);
 
 489         if (zd_chip_is_zd1211b(chip))
 
 490                 ioreqs[1].value = 0x7f;
 
 492         return zd_iowrite16a_locked(chip, ioreqs, ARRAY_SIZE(ioreqs));
 
 495 static int uw2453_switch_radio_off(struct zd_rf *rf)
 
 498         struct zd_chip *chip = zd_rf_to_chip(rf);
 
 499         static const struct zd_ioreq16 ioreqs[] = {
 
 500                 { CR11,  0x04 }, { CR251, 0x2f },
 
 503         /* enter IDLE mode */
 
 504         /* FIXME: shouldn't we go to SLEEP? sent email to zydas */
 
 505         r = zd_rfwrite_locked(chip, UW2453_REGWRITE(0, 0x25f90), RF_RV_BITS);
 
 509         return zd_iowrite16a_locked(chip, ioreqs, ARRAY_SIZE(ioreqs));
 
 512 static void uw2453_clear(struct zd_rf *rf)
 
 517 int zd_rf_init_uw2453(struct zd_rf *rf)
 
 519         rf->init_hw = uw2453_init_hw;
 
 520         rf->set_channel = uw2453_set_channel;
 
 521         rf->switch_radio_on = uw2453_switch_radio_on;
 
 522         rf->switch_radio_off = uw2453_switch_radio_off;
 
 523         rf->patch_6m_band_edge = zd_rf_generic_patch_6m;
 
 524         rf->clear = uw2453_clear;
 
 525         /* we have our own TX integration code */
 
 526         rf->update_channel_int = 0;
 
 528         rf->priv = kmalloc(sizeof(struct uw2453_priv), GFP_KERNEL);
 
 529         if (rf->priv == NULL)