| /* |
| * TWDriverRate.h |
| * |
| * Copyright(c) 1998 - 2009 Texas Instruments. All rights reserved. |
| * All rights reserved. |
| * |
| * Redistribution and use in source and binary forms, with or without |
| * modification, are permitted provided that the following conditions |
| * are met: |
| * |
| * * Redistributions of source code must retain the above copyright |
| * notice, this list of conditions and the following disclaimer. |
| * * Redistributions in binary form must reproduce the above copyright |
| * notice, this list of conditions and the following disclaimer in |
| * the documentation and/or other materials provided with the |
| * distribution. |
| * * Neither the name Texas Instruments nor the names of its |
| * contributors may be used to endorse or promote products derived |
| * from this software without specific prior written permission. |
| * |
| * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
| * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
| * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |
| * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT |
| * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
| * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
| * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
| * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
| * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
| * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
| * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
| */ |
| |
| #ifndef TWDRIVERRATE_H |
| #define TWDRIVERRATE_H |
| |
| /** \file TWDriverRate.h |
| * \brief TWDriver Rate APIs |
| * |
| * \see |
| */ |
| |
| /** \enum ERate |
| * \brief Rate Types |
| * |
| * \par Description |
| * Driver's TX Control Frame Rate Format Type |
| * |
| * \sa |
| */ |
| typedef enum |
| { |
| DRV_RATE_AUTO = 0, /**< Auto */ |
| DRV_RATE_1M = 1, /**< 1M */ |
| DRV_RATE_2M = 2, /**< 2M */ |
| DRV_RATE_5_5M = 3, /**< 5.5M */ |
| DRV_RATE_11M = 4, /**< 11M */ |
| DRV_RATE_22M = 5, /**< 22M */ |
| DRV_RATE_6M = 6, /**< 6M */ |
| DRV_RATE_9M = 7, /**< 9M */ |
| DRV_RATE_12M = 8, /**< 12M */ |
| DRV_RATE_18M = 9, /**< 18M */ |
| DRV_RATE_24M = 10, /**< 24M */ |
| DRV_RATE_36M = 11, /**< 36M */ |
| DRV_RATE_48M = 12, /**< 48M */ |
| DRV_RATE_54M = 13, /**< 54M */ |
| DRV_RATE_MCS_0 = 14, /**< 6.5M or 7.2 */ |
| DRV_RATE_MCS_1 = 15, /**< 13.0M or 14.4 */ |
| DRV_RATE_MCS_2 = 16, /**< 19.5M or 21.7 */ |
| DRV_RATE_MCS_3 = 17, /**< 26.0M or 28.9 */ |
| DRV_RATE_MCS_4 = 18, /**< 39.0M or 43.3 */ |
| DRV_RATE_MCS_5 = 19, /**< 52.0M or 57.8 */ |
| DRV_RATE_MCS_6 = 20, /**< 58.5M or 65.0 */ |
| DRV_RATE_MCS_7 = 21, /**< 65.0M or 72.2 */ |
| DRV_RATE_MAX = DRV_RATE_MCS_7, /**< Maximum Driver's Rate Type */ |
| DRV_RATE_INVALID = 0xFF /**< Invalid Driver's Rate Type */ |
| |
| } ERate; |
| |
| #define RATE_TO_MASK(R) (1 << ((R) - 1)) |
| |
| /** \enum ERateMask |
| * \brief Driver rate mask |
| * |
| * \par Description |
| * |
| * \sa |
| */ |
| typedef enum |
| { |
| DRV_RATE_MASK_AUTO = DRV_RATE_AUTO, /**< 0x000000 */ |
| DRV_RATE_MASK_1_BARKER = RATE_TO_MASK(DRV_RATE_1M), /**< 0x000001 */ |
| DRV_RATE_MASK_2_BARKER = RATE_TO_MASK(DRV_RATE_2M), /**< 0x000002 */ |
| DRV_RATE_MASK_5_5_CCK = RATE_TO_MASK(DRV_RATE_5_5M), /**< 0x000004 */ |
| DRV_RATE_MASK_11_CCK = RATE_TO_MASK(DRV_RATE_11M), /**< 0x000008 */ |
| DRV_RATE_MASK_22_PBCC = RATE_TO_MASK(DRV_RATE_22M), /**< 0x000010 */ |
| DRV_RATE_MASK_6_OFDM = RATE_TO_MASK(DRV_RATE_6M), /**< 0x000020 */ |
| DRV_RATE_MASK_9_OFDM = RATE_TO_MASK(DRV_RATE_9M), /**< 0x000040 */ |
| DRV_RATE_MASK_12_OFDM = RATE_TO_MASK(DRV_RATE_12M), /**< 0x000080 */ |
| DRV_RATE_MASK_18_OFDM = RATE_TO_MASK(DRV_RATE_18M), /**< 0x000100 */ |
| DRV_RATE_MASK_24_OFDM = RATE_TO_MASK(DRV_RATE_24M), /**< 0x000200 */ |
| DRV_RATE_MASK_36_OFDM = RATE_TO_MASK(DRV_RATE_36M), /**< 0x000400 */ |
| DRV_RATE_MASK_48_OFDM = RATE_TO_MASK(DRV_RATE_48M), /**< 0x000800 */ |
| DRV_RATE_MASK_54_OFDM = RATE_TO_MASK(DRV_RATE_54M), /**< 0x001000 */ |
| DRV_RATE_MASK_MCS_0_OFDM = RATE_TO_MASK(DRV_RATE_MCS_0), /**< 0x002000 */ |
| DRV_RATE_MASK_MCS_1_OFDM = RATE_TO_MASK(DRV_RATE_MCS_1), /**< 0x004000 */ |
| DRV_RATE_MASK_MCS_2_OFDM = RATE_TO_MASK(DRV_RATE_MCS_2), /**< 0x008000 */ |
| DRV_RATE_MASK_MCS_3_OFDM = RATE_TO_MASK(DRV_RATE_MCS_3), /**< 0x010000 */ |
| DRV_RATE_MASK_MCS_4_OFDM = RATE_TO_MASK(DRV_RATE_MCS_4), /**< 0x020000 */ |
| DRV_RATE_MASK_MCS_5_OFDM = RATE_TO_MASK(DRV_RATE_MCS_5), /**< 0x040000 */ |
| DRV_RATE_MASK_MCS_6_OFDM = RATE_TO_MASK(DRV_RATE_MCS_6), /**< 0x080000 */ |
| DRV_RATE_MASK_MCS_7_OFDM = RATE_TO_MASK(DRV_RATE_MCS_7) /**< 0x100000 */ |
| |
| } ERateMask; |
| |
| #define PBCC_BIT 0x00000080 /* BIT_7 */ |
| |
| #endif /* #define TWDRIVERRATE_H */ |