1*4882a593Smuzhiyun /****************************************************************************** 2*4882a593Smuzhiyun * 3*4882a593Smuzhiyun * Copyright(c) 2020 Realtek Corporation. 4*4882a593Smuzhiyun * 5*4882a593Smuzhiyun * This program is free software; you can redistribute it and/or modify it 6*4882a593Smuzhiyun * under the terms of version 2 of the GNU General Public License as 7*4882a593Smuzhiyun * published by the Free Software Foundation. 8*4882a593Smuzhiyun * 9*4882a593Smuzhiyun * This program is distributed in the hope that it will be useful, but WITHOUT 10*4882a593Smuzhiyun * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 11*4882a593Smuzhiyun * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for 12*4882a593Smuzhiyun * more details. 13*4882a593Smuzhiyun * 14*4882a593Smuzhiyun *****************************************************************************/ 15*4882a593Smuzhiyun #ifndef _PHL_SCAN_INSTANCE_H_ 16*4882a593Smuzhiyun #define _PHL_SCAN_INSTANCE_H_ 17*4882a593Smuzhiyun 18*4882a593Smuzhiyun #define MAX_SCAN_INSTANCE 160 19*4882a593Smuzhiyun 20*4882a593Smuzhiyun enum order_strategy { 21*4882a593Smuzhiyun ORDER_5GHZ_PRIOR = BIT(0), 22*4882a593Smuzhiyun ORDER_ACTIVE_PRIOR = BIT(1) 23*4882a593Smuzhiyun }; 24*4882a593Smuzhiyun 25*4882a593Smuzhiyun enum skip_strategy { 26*4882a593Smuzhiyun SKIP_2GHZ = BIT(0), 27*4882a593Smuzhiyun SKIP_5GHZ = BIT(1), 28*4882a593Smuzhiyun SKIP_PASSIVE = BIT(2), 29*4882a593Smuzhiyun SKIP_DFS = BIT(3), 30*4882a593Smuzhiyun SKIP_6GHZ = BIT(4), 31*4882a593Smuzhiyun }; 32*4882a593Smuzhiyun 33*4882a593Smuzhiyun enum period_strategy { 34*4882a593Smuzhiyun PERIOD_ALL_MAX = BIT(0), 35*4882a593Smuzhiyun PERIOD_ALL_MIN = BIT(1), 36*4882a593Smuzhiyun PERIOD_MIN_DFS = BIT(2) 37*4882a593Smuzhiyun }; 38*4882a593Smuzhiyun 39*4882a593Smuzhiyun struct instance_strategy { 40*4882a593Smuzhiyun u8 order; 41*4882a593Smuzhiyun u8 skip; 42*4882a593Smuzhiyun u8 period; 43*4882a593Smuzhiyun }; 44*4882a593Smuzhiyun 45*4882a593Smuzhiyun struct instance_channel { 46*4882a593Smuzhiyun enum band_type band; 47*4882a593Smuzhiyun u8 channel; 48*4882a593Smuzhiyun u8 property; 49*4882a593Smuzhiyun u8 active; 50*4882a593Smuzhiyun u8 period; 51*4882a593Smuzhiyun u8 mode; 52*4882a593Smuzhiyun u8 bw; 53*4882a593Smuzhiyun u8 offset; 54*4882a593Smuzhiyun }; 55*4882a593Smuzhiyun 56*4882a593Smuzhiyun struct instance { 57*4882a593Smuzhiyun u32 cnt; /* channel cnt */ 58*4882a593Smuzhiyun struct instance_channel ch[MAX_SCAN_INSTANCE]; 59*4882a593Smuzhiyun }; 60*4882a593Smuzhiyun 61*4882a593Smuzhiyun 62*4882a593Smuzhiyun #endif /* _PHL_SCAN_INSTANCE_H_ */ 63