1e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin/* 2e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin * Copyright (c) 2010 Broadcom Corporation 3e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin * 4e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin * Permission to use, copy, modify, and/or distribute this software for any 5e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin * purpose with or without fee is hereby granted, provided that the above 6e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin * copyright notice and this permission notice appear in all copies. 7e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin * 8e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES 9e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF 10e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY 11e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin * SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES 12e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION 13e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin * OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN 14e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin * CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. 15e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin */ 16e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin 17e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#ifndef _BRCMU_D11_H_ 18e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define _BRCMU_D11_H_ 19e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin 20e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin/* d11 io type */ 21e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_D11N_IOTYPE 1 22e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_D11AC_IOTYPE 2 23e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin 24e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin/* A chanspec (channel specification) holds the channel number, band, 25e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin * bandwidth and control sideband 26e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin */ 27e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin 28e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin/* chanspec binary format */ 29e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin 30e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_INVALID 255 31e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin/* bit 0~7 channel number 32e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin * for 80+80 channels: bit 0~3 low channel id, bit 4~7 high channel id 33e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin */ 34e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_CH_MASK 0x00ff 35e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_CH_SHIFT 0 36e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_CHL_MASK 0x000f 37e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_CHL_SHIFT 0 38e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_CHH_MASK 0x00f0 39e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_CHH_SHIFT 4 40e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin 41e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin/* bit 8~16 for dot 11n IO types 42e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin * bit 8~9 sideband 43e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin * bit 10~11 bandwidth 44e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin * bit 12~13 spectral band 45e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin * bit 14~15 not used 46e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin */ 47e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_D11N_SB_MASK 0x0300 48e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_D11N_SB_SHIFT 8 49e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_D11N_SB_L 0x0100 /* control lower */ 50e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_D11N_SB_U 0x0200 /* control upper */ 51e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_D11N_SB_N 0x0300 /* none */ 52e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_D11N_BW_MASK 0x0c00 53e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_D11N_BW_SHIFT 10 54e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_D11N_BW_10 0x0400 55e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_D11N_BW_20 0x0800 56e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_D11N_BW_40 0x0c00 57e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_D11N_BND_MASK 0x3000 58e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_D11N_BND_SHIFT 12 59e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_D11N_BND_5G 0x1000 60e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_D11N_BND_2G 0x2000 61e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin 62e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin/* bit 8~16 for dot 11ac IO types 63e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin * bit 8~10 sideband 64e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin * bit 11~13 bandwidth 65e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin * bit 14~15 spectral band 66e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin */ 67e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_D11AC_SB_MASK 0x0700 68e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_D11AC_SB_SHIFT 8 69e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_D11AC_SB_LLL 0x0000 70e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_D11AC_SB_LLU 0x0100 71e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_D11AC_SB_LUL 0x0200 72e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_D11AC_SB_LUU 0x0300 73e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_D11AC_SB_ULL 0x0400 74e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_D11AC_SB_ULU 0x0500 75e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_D11AC_SB_UUL 0x0600 76e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_D11AC_SB_UUU 0x0700 77e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_D11AC_SB_LL BRCMU_CHSPEC_D11AC_SB_LLL 78e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_D11AC_SB_LU BRCMU_CHSPEC_D11AC_SB_LLU 79e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_D11AC_SB_UL BRCMU_CHSPEC_D11AC_SB_LUL 80e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_D11AC_SB_UU BRCMU_CHSPEC_D11AC_SB_LUU 81e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_D11AC_SB_L BRCMU_CHSPEC_D11AC_SB_LLL 82e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_D11AC_SB_U BRCMU_CHSPEC_D11AC_SB_LLU 83e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_D11AC_BW_MASK 0x3800 84e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_D11AC_BW_SHIFT 11 85e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_D11AC_BW_5 0x0000 86e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_D11AC_BW_10 0x0800 87e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_D11AC_BW_20 0x1000 88e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_D11AC_BW_40 0x1800 89e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_D11AC_BW_80 0x2000 90e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_D11AC_BW_160 0x2800 91e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_D11AC_BW_8080 0x3000 92e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_D11AC_BND_MASK 0xc000 93e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_D11AC_BND_SHIFT 14 94e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_D11AC_BND_2G 0x0000 95e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_D11AC_BND_3G 0x4000 96e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_D11AC_BND_4G 0x8000 97e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHSPEC_D11AC_BND_5G 0xc000 98e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin 99e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHAN_BAND_2G 0 100e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#define BRCMU_CHAN_BAND_5G 1 101e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin 102e3b919d8b3db014af848af64ead8da4475d4ab60Franky Linenum brcmu_chan_bw { 103e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin BRCMU_CHAN_BW_20, 104e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin BRCMU_CHAN_BW_40, 105e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin BRCMU_CHAN_BW_80, 106e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin BRCMU_CHAN_BW_80P80, 107e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin BRCMU_CHAN_BW_160, 108e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin}; 109e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin 110e3b919d8b3db014af848af64ead8da4475d4ab60Franky Linenum brcmu_chan_sb { 1114439cbcd37a9dc2c4e976259cd2962956985d58dArend van Spriel BRCMU_CHAN_SB_NONE = -1, 112e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin BRCMU_CHAN_SB_LLL, 113e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin BRCMU_CHAN_SB_LLU, 114e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin BRCMU_CHAN_SB_LUL, 115e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin BRCMU_CHAN_SB_LUU, 116e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin BRCMU_CHAN_SB_ULL, 117e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin BRCMU_CHAN_SB_ULU, 118e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin BRCMU_CHAN_SB_UUL, 119e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin BRCMU_CHAN_SB_UUU, 1204439cbcd37a9dc2c4e976259cd2962956985d58dArend van Spriel BRCMU_CHAN_SB_L = BRCMU_CHAN_SB_LLL, 1214439cbcd37a9dc2c4e976259cd2962956985d58dArend van Spriel BRCMU_CHAN_SB_U = BRCMU_CHAN_SB_LLU, 1224439cbcd37a9dc2c4e976259cd2962956985d58dArend van Spriel BRCMU_CHAN_SB_LL = BRCMU_CHAN_SB_LLL, 1234439cbcd37a9dc2c4e976259cd2962956985d58dArend van Spriel BRCMU_CHAN_SB_LU = BRCMU_CHAN_SB_LLU, 1244439cbcd37a9dc2c4e976259cd2962956985d58dArend van Spriel BRCMU_CHAN_SB_UL = BRCMU_CHAN_SB_LUL, 1254439cbcd37a9dc2c4e976259cd2962956985d58dArend van Spriel BRCMU_CHAN_SB_UU = BRCMU_CHAN_SB_LUU, 126e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin}; 127e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin 128e3b919d8b3db014af848af64ead8da4475d4ab60Franky Linstruct brcmu_chan { 129e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin u16 chspec; 130e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin u8 chnum; 131e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin u8 band; 132e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin enum brcmu_chan_bw bw; 133e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin enum brcmu_chan_sb sb; 134e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin}; 135e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin 136e3b919d8b3db014af848af64ead8da4475d4ab60Franky Linstruct brcmu_d11inf { 137e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin u8 io_type; 138e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin 139e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin void (*encchspec)(struct brcmu_chan *ch); 140e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin void (*decchspec)(struct brcmu_chan *ch); 141e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin}; 142e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin 1439bd91f3c00bd8dd54339499a9253b31c6bac7c7bJoe Perchesvoid brcmu_d11_attach(struct brcmu_d11inf *d11inf); 144e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin 145e3b919d8b3db014af848af64ead8da4475d4ab60Franky Lin#endif /* _BRCMU_CHANNELS_H_ */ 146