/****************************************************************************** Copyright 2008, Freie Universitaet Berlin (FUB). All rights reserved. These sources were developed at the Freie Universitaet Berlin, Computer Systems and Telematics group (http://cst.mi.fu-berlin.de). ------------------------------------------------------------------------------- This file is part of FeuerWare. This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. FeuerWare 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 General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see http://www.gnu.org/licenses/ . -------------------------------------------------------------------------------- For further information and questions please use the web site http://scatterweb.mi.fu-berlin.de and the mailinglist (subscription via web site) scatterweb@lists.spline.inf.fu-berlin.de *******************************************************************************/ /** * @ingroup dev_cc110x * @{ */ /** * @file * @brief TI Chipcon CC110x default settings * * @author Freie Universität Berlin, Computer Systems & Telematics, FeuerWhere project * @author Thomas Hillebrandt * @author Heiko Will * @version $Revision: 2058 $ * * @note $Id: cc1100-defaultSettings.c 2058 2010-03-31 08:59:31Z hillebra $ */ #include /** * Usable, non overlapping channels and corresponding frequencies * for use with CC1100. CHANNR is the register for selecting a channel. * * channel number | CHANNR | frequency [MHz] * ----------------------------------------- * 0 | 0 | 869.525 * 1 | 10 | 871.61 * 2 | 20 | 873.58 ~ seems to be bad (hang-ups with this channel) * 3 | 30 | 875.61 * 4 | 40 | 877.58 * 5 | 50 | 879.61 * 6 | 60 | 881.58 * 7 | 70 | 883.61 * 8 | 80 | 885.58 * 9 | 90 | 887.61 * 10 | 100 | 889.58 * 11 | 110 | 891.57 * 12 | 120 | 893.58 * 13 | 130 | 895.61 * 14 | 140 | 897.58 * 15 | 150 | 899.57 * 16 | 160 | 901.57 * 17 | 170 | 903.61 * 18 | 180 | 905.57 * 19 | 190 | 907.57 * 20 | 200 | 909.57 * 21 | 210 | 911.57 * 22 | 220 | 913.57 * 23 | 230 | 915.61 * 24 | 240 | 917.61 */ // 400 kbps, MSK, X-tal: 26 MHz (Chip Revision F) char cc1100_conf[] = { 0x06, // IOCFG2 0x2E, // IOCFG1 0x0E, // IOCFG0 0x0F, // FIFOTHR 0x9B, // SYNC1 0xAD, // SYNC0 0x3D, // PKTLEN (maximum value of packet length byte = 61) 0x06, // PKTCTRL1 0x45, // PKTCTRL0 (variable packet length) 0xFF, // ADDR CC1100_DEFAULT_CHANNR*10, // CHANNR 0x0B, // FSCTRL1 0x00, // FSCTRL0 0x21, // FREQ2 0x71, // FREQ1 0x7A, // FREQ0 0x2D, // MDMCFG4 0xF8, // MDMCFG3 0x73, // MDMCFG2 0x42, // MDMCFG1 0xF8, // MDMCFG0 0x00, // DEVIATN 0x07, // MCSM2 0x03, // MCSM1 0x18, // MCSM0 0x1D, // FOCCFG 0x1C, // BSCFG 0xC0, // AGCCTRL2 0x49, // AGCCTRL1, (old value was 0x49 -> made carrier sense less sensitive!) // 0x47 - 7 dB above MAGN_TARGET setting 0xB2, // AGCCTRL0 0x87, // WOREVT1 0x6B, // WOREVT0 0xF8, // WORCTRL 0xB6, // FREND1 0x10, // FREND0 0xEA, // FSCAL3 0x2A, // FSCAL2 0x00, // FSCAL1 0x1F, // FSCAL0 0x00 // padding to 4 bytes }; static uint8_t pa_table_index = PATABLE; ///< Current PATABLE Index static uint8_t pa_table[] = { ///< PATABLE with available output powers 0x00, ///< -52 dBm 0x03, ///< -30 dBm 0x0D, ///< -20 dBm 0x1C, ///< -15 dBm 0x34, ///< -10 dBm 0x57, ///< - 5 dBm 0x3F, ///< - 1 dBm 0x8E, ///< 0 dBm 0x85, ///< + 5 dBm 0xCC, ///< + 7 dBm 0xC6, ///< + 9 dBm 0xC3 ///< +10 dBm }; // If PATABLE is changed in size, adjust MAX_OUTPUT_POWER definition in CC1100 interface! static int8_t pa_table_dBm[] = { ///< Values of the PATABLE in dBm -52, -30, -20, -15, -10, -5, -1, 0, 5, 7, 9, 10 }; /** @} */