1*ebacd801SBjoern A. Zeeb /* 2*ebacd801SBjoern A. Zeeb * Copyright (c) 2012 Neratec Solutions AG 3*ebacd801SBjoern A. Zeeb * 4*ebacd801SBjoern A. Zeeb * Permission to use, copy, modify, and/or distribute this software for any 5*ebacd801SBjoern A. Zeeb * purpose with or without fee is hereby granted, provided that the above 6*ebacd801SBjoern A. Zeeb * copyright notice and this permission notice appear in all copies. 7*ebacd801SBjoern A. Zeeb * 8*ebacd801SBjoern A. Zeeb * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES 9*ebacd801SBjoern A. Zeeb * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF 10*ebacd801SBjoern A. Zeeb * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR 11*ebacd801SBjoern A. Zeeb * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES 12*ebacd801SBjoern A. Zeeb * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN 13*ebacd801SBjoern A. Zeeb * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF 14*ebacd801SBjoern A. Zeeb * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. 15*ebacd801SBjoern A. Zeeb */ 16*ebacd801SBjoern A. Zeeb 17*ebacd801SBjoern A. Zeeb #ifndef DFS_PRI_DETECTOR_H 18*ebacd801SBjoern A. Zeeb #define DFS_PRI_DETECTOR_H 19*ebacd801SBjoern A. Zeeb 20*ebacd801SBjoern A. Zeeb #include <linux/list.h> 21*ebacd801SBjoern A. Zeeb 22*ebacd801SBjoern A. Zeeb extern struct ath_dfs_pool_stats global_dfs_pool_stats; 23*ebacd801SBjoern A. Zeeb 24*ebacd801SBjoern A. Zeeb /** 25*ebacd801SBjoern A. Zeeb * struct pri_sequence - sequence of pulses matching one PRI 26*ebacd801SBjoern A. Zeeb * @head: list_head 27*ebacd801SBjoern A. Zeeb * @pri: pulse repetition interval (PRI) in usecs 28*ebacd801SBjoern A. Zeeb * @dur: duration of sequence in usecs 29*ebacd801SBjoern A. Zeeb * @count: number of pulses in this sequence 30*ebacd801SBjoern A. Zeeb * @count_falses: number of not matching pulses in this sequence 31*ebacd801SBjoern A. Zeeb * @first_ts: time stamp of first pulse in usecs 32*ebacd801SBjoern A. Zeeb * @last_ts: time stamp of last pulse in usecs 33*ebacd801SBjoern A. Zeeb * @deadline_ts: deadline when this sequence becomes invalid (first_ts + dur) 34*ebacd801SBjoern A. Zeeb */ 35*ebacd801SBjoern A. Zeeb struct pri_sequence { 36*ebacd801SBjoern A. Zeeb struct list_head head; 37*ebacd801SBjoern A. Zeeb u32 pri; 38*ebacd801SBjoern A. Zeeb u32 dur; 39*ebacd801SBjoern A. Zeeb u32 count; 40*ebacd801SBjoern A. Zeeb u32 count_falses; 41*ebacd801SBjoern A. Zeeb u64 first_ts; 42*ebacd801SBjoern A. Zeeb u64 last_ts; 43*ebacd801SBjoern A. Zeeb u64 deadline_ts; 44*ebacd801SBjoern A. Zeeb }; 45*ebacd801SBjoern A. Zeeb 46*ebacd801SBjoern A. Zeeb /** 47*ebacd801SBjoern A. Zeeb * struct pri_detector - PRI detector element for a dedicated radar type 48*ebacd801SBjoern A. Zeeb * @exit(): destructor 49*ebacd801SBjoern A. Zeeb * @add_pulse(): add pulse event, returns pri_sequence if pattern was detected 50*ebacd801SBjoern A. Zeeb * @reset(): clear states and reset to given time stamp 51*ebacd801SBjoern A. Zeeb * @rs: detector specs for this detector element 52*ebacd801SBjoern A. Zeeb * @last_ts: last pulse time stamp considered for this element in usecs 53*ebacd801SBjoern A. Zeeb * @sequences: list_head holding potential pulse sequences 54*ebacd801SBjoern A. Zeeb * @pulses: list connecting pulse_elem objects 55*ebacd801SBjoern A. Zeeb * @count: number of pulses in queue 56*ebacd801SBjoern A. Zeeb * @max_count: maximum number of pulses to be queued 57*ebacd801SBjoern A. Zeeb * @window_size: window size back from newest pulse time stamp in usecs 58*ebacd801SBjoern A. Zeeb */ 59*ebacd801SBjoern A. Zeeb struct pri_detector { 60*ebacd801SBjoern A. Zeeb void (*exit) (struct pri_detector *de); 61*ebacd801SBjoern A. Zeeb struct pri_sequence * 62*ebacd801SBjoern A. Zeeb (*add_pulse)(struct pri_detector *de, struct pulse_event *e); 63*ebacd801SBjoern A. Zeeb void (*reset) (struct pri_detector *de, u64 ts); 64*ebacd801SBjoern A. Zeeb 65*ebacd801SBjoern A. Zeeb const struct radar_detector_specs *rs; 66*ebacd801SBjoern A. Zeeb 67*ebacd801SBjoern A. Zeeb /* private: internal use only */ 68*ebacd801SBjoern A. Zeeb u64 last_ts; 69*ebacd801SBjoern A. Zeeb struct list_head sequences; 70*ebacd801SBjoern A. Zeeb struct list_head pulses; 71*ebacd801SBjoern A. Zeeb u32 count; 72*ebacd801SBjoern A. Zeeb u32 max_count; 73*ebacd801SBjoern A. Zeeb u32 window_size; 74*ebacd801SBjoern A. Zeeb }; 75*ebacd801SBjoern A. Zeeb 76*ebacd801SBjoern A. Zeeb struct pri_detector *pri_detector_init(const struct radar_detector_specs *rs); 77*ebacd801SBjoern A. Zeeb 78*ebacd801SBjoern A. Zeeb #endif /* DFS_PRI_DETECTOR_H */ 79