123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548 |
- /*
- * Copyright (c) 2021, The Linux Foundation. All rights reserved.
- * Copyright (c) 2021-2023 Qualcomm Innovation Center, Inc. All rights reserved.
- *
- * Permission to use, copy, modify, and/or distribute this software for any
- * purpose with or without fee is hereby granted, provided that the above
- * copyright notice and this permission notice appear in all copies.
- * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
- * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
- * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
- * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
- * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
- * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
- * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
- */
- /**
- * DOC: contains interface prototypes for son api
- */
- #ifndef _SON_API_H_
- #define _SON_API_H_
- #include <qdf_types.h>
- #include <wlan_objmgr_peer_obj.h>
- #include <wlan_objmgr_pdev_obj.h>
- #include <reg_services_public_struct.h>
- #include <qdf_trace.h>
- #define son_alert(format, args...) \
- QDF_TRACE_FATAL(QDF_MODULE_ID_SON, format, ## args)
- #define son_err(format, args...) \
- QDF_TRACE_ERROR(QDF_MODULE_ID_SON, format, ## args)
- #define son_warn(format, args...) \
- QDF_TRACE_WARN(QDF_MODULE_ID_SON, format, ## args)
- #define son_info(format, args...) \
- QDF_TRACE_INFO(QDF_MODULE_ID_SON, format, ## args)
- #define son_debug(format, args...) \
- QDF_TRACE_DEBUG(QDF_MODULE_ID_SON, format, ## args)
- #define son_nofl_alert(format, args...) \
- QDF_TRACE_FATAL_NO_FL(QDF_MODULE_ID_SON, format, ## args)
- #define son_nofl_err(format, args...) \
- QDF_TRACE_ERROR_NO_FL(QDF_MODULE_ID_SON, format, ## args)
- #define son_nofl_warn(format, args...) \
- QDF_TRACE_WARN_NO_FL(QDF_MODULE_ID_SON, format, ## args)
- #define son_nofl_info(format, args...) \
- QDF_TRACE_INFO_NO_FL(QDF_MODULE_ID_SON, format, ## args)
- #define son_nofl_debug(format, args...) \
- QDF_TRACE_DEBUG_NO_FL(QDF_MODULE_ID_SON, format, ## args)
- #define son_alert_rl(format, args...) \
- QDF_TRACE_FATAL_RL(QDF_MODULE_ID_SON, format, ## args)
- #define son_err_rl(format, args...) \
- QDF_TRACE_ERROR_RL(QDF_MODULE_ID_SON, format, ## args)
- #define son_warn_rl(format, args...) \
- QDF_TRACE_WARN_RL(QDF_MODULE_ID_SON, format, ## args)
- #define son_info_rl(format, args...) \
- QDF_TRACE_INFO_RL(QDF_MODULE_ID_SON, format, ## args)
- #define son_debug_rl(format, args...) \
- QDF_TRACE_DEBUG_RL(QDF_MODULE_ID_SON, format, ## args)
- #define son_nofl_alert_rl(format, args...) \
- QDF_TRACE_FATAL_RL_NO_FL(QDF_MODULE_ID_SON, format, ## args)
- #define son_nofl_err_rl(format, args...) \
- QDF_TRACE_ERROR_RL_NO_FL(QDF_MODULE_ID_SON, format, ## args)
- #define son_nofl_warn_rl(format, args...) \
- QDF_TRACE_WARN_RL_NO_FL(QDF_MODULE_ID_SON, format, ## args)
- #define son_nofl_info_rl(format, args...) \
- QDF_TRACE_INFO_RL_NO_FL(QDF_MODULE_ID_SON, format, ## args)
- #define son_nofl_debug_rl(format, args...) \
- QDF_TRACE_DEBUG_RL_NO_FL(QDF_MODULE_ID_SON, format, ## args)
- #define TOTAL_DWELL_TIME 200
- #define CBS_DEFAULT_RESTTIME 500 /* msec */
- #define CBS_DEFAULT_DWELL_TIME 50 /* msec */
- #define CBS_DEFAULT_WAIT_TIME 1000 /* 1 sec */
- #define CBS_DEFAULT_DWELL_SPLIT_TIME 50 /* msec */
- #define CBS_DEFAULT_DWELL_REST_TIME 500 /* msec */
- #define CBS_DEFAULT_MIN_REST_TIME 50 /* msec */
- #define DEFAULT_BEACON_INTERVAL 100
- #define CBS_DWELL_TIME_10MS 10
- #define CBS_DWELL_TIME_25MS 25
- #define CBS_DWELL_TIME_50MS 50
- #define CBS_DWELL_TIME_75MS 75
- #define MIN_SCAN_OFFSET_ARRAY_SIZE 0
- #define MAX_SCAN_OFFSET_ARRAY_SIZE 9
- #define SCAN_START_OFFSET_MIN 26
- #define DEFAULT_SCAN_MAX_REST_TIME 500
- /**
- * enum son_cbs_state - son cbs state enumeration
- * @CBS_INIT: init state
- * @CBS_SCAN: scanning state
- * @CBS_REST: rest state
- * @CBS_RANK: rank state
- * @CBS_WAIT: wait state
- */
- enum son_cbs_state {
- CBS_INIT,
- CBS_SCAN,
- CBS_REST,
- CBS_RANK,
- CBS_WAIT,
- };
- /**
- * struct son_cbs - son cbs struction
- * @vdev: vdev
- * @cbs_lock: cbs spin lock
- * @cbs_timer: cbs timer
- * @cbs_state: cbs state
- * @cbs_scan_requestor: scan requestor
- * @cbs_scan_id: scan id
- * @dwell_time: dwell time configuration
- * @rest_time: rest time configuration
- * @wait_time: wait time configuration
- * @scan_intvl_time: interval time configuration
- * @scan_params: scan params
- * @max_dwell_split_cnt: max dwell split counter
- * @dwell_split_cnt: dwell split counter
- * @scan_offset: scan offset array
- * @scan_dwell_rest: scan dwell rest array
- * @min_dwell_rest_time: nub dwell rest time
- * @dwell_split_time: dwell split time
- * @max_arr_size_used: max array size used
- */
- struct son_cbs {
- struct wlan_objmgr_vdev *vdev;
- spinlock_t cbs_lock;
- qdf_timer_t cbs_timer;
- enum son_cbs_state cbs_state;
- wlan_scan_requester cbs_scan_requestor;
- wlan_scan_id cbs_scan_id;
- uint32_t dwell_time;
- uint32_t rest_time;
- uint32_t wait_time;
- int32_t scan_intvl_time;
- struct scan_start_request scan_params;
- uint8_t max_dwell_split_cnt;
- int8_t dwell_split_cnt;
- uint32_t scan_offset[10];
- uint32_t scan_dwell_rest[10];
- uint32_t min_dwell_rest_time;
- uint32_t dwell_split_time;
- uint8_t max_arr_size_used;
- };
- /**
- * typedef mlme_deliver_cb() - cb to deliver mlme event
- * @vdev: pointer to vdev
- * @event_len: event length
- * @event_buf: event buffer
- *
- * Return: 0 if event is sent successfully
- */
- typedef int (*mlme_deliver_cb)(struct wlan_objmgr_vdev *vdev,
- uint32_t event_len,
- const uint8_t *event_buf);
- /**
- * enum SON_MLME_DELIVER_CB_TYPE - mlme deliver cb type
- * @SON_MLME_DELIVER_CB_TYPE_OPMODE: cb to deliver opmode
- * @SON_MLME_DELIVER_CB_TYPE_SMPS: cb to deliver smps
- */
- enum SON_MLME_DELIVER_CB_TYPE {
- SON_MLME_DELIVER_CB_TYPE_OPMODE,
- SON_MLME_DELIVER_CB_TYPE_SMPS,
- };
- /**
- * wlan_son_register_mlme_deliver_cb - register mlme deliver cb
- * @psoc: pointer to psoc
- * @cb: mlme deliver cb
- * @type: mlme deliver cb type
- *
- * Return: QDF_STATUS
- */
- QDF_STATUS
- wlan_son_register_mlme_deliver_cb(struct wlan_objmgr_psoc *psoc,
- mlme_deliver_cb cb,
- enum SON_MLME_DELIVER_CB_TYPE type);
- /**
- * wlan_son_peer_ext_stat_enable() - sends EXT stats command to FW
- * @pdev: pointer to pdev
- * @mac_addr: MAC address of the target peer
- * @vdev: Pointer to vdev
- * @stats_count: Stats count
- * @enable: Enable / disable ext stats
- *
- * Return: QDF_STATUS_SUCCESS on success else failure
- */
- QDF_STATUS wlan_son_peer_ext_stat_enable(struct wlan_objmgr_pdev *pdev,
- uint8_t *mac_addr,
- struct wlan_objmgr_vdev *vdev,
- uint32_t stats_count,
- uint32_t enable);
- /**
- * wlan_son_peer_req_inst_stats() - Requests for instantaneous stats for
- * the target mac_addr from FW via
- * WMI_REQUEST_STATS_CMDID.
- * @pdev: pointer to pdev
- * @mac_addr: MAC address of the target peer
- * @vdev: Pointer to vdev
- *
- * Return: QDF_STATUS_SUCCESS on success else failure
- */
- QDF_STATUS wlan_son_peer_req_inst_stats(struct wlan_objmgr_pdev *pdev,
- uint8_t *mac_addr,
- struct wlan_objmgr_vdev *vdev);
- /**
- * wlan_son_get_chan_flag() - get chan flag
- * @pdev: pointer to pdev
- * @freq: qdf_freq_t
- * @flag_160: If true, 160 channel info will be obtained;
- * otherwise 80+80, 80 channel info will be obtained
- * @chan_params: chan parameters
- *
- * Return: combination of enum qca_wlan_vendor_channel_prop_flags and
- * enum qca_wlan_vendor_channel_prop_flags_2
- */
- uint32_t wlan_son_get_chan_flag(struct wlan_objmgr_pdev *pdev,
- qdf_freq_t freq, bool flag_160,
- struct ch_params *chan_params);
- /**
- * wlan_son_peer_set_kickout_allow() - set the peer is allowed to kickout
- * @vdev: pointer to vdev
- * @peer: pointer to peer
- * @kickout_allow: kickout_allow to set
- *
- * Return: QDF_STATUS_SUCCESS on Success else failure.
- */
- QDF_STATUS wlan_son_peer_set_kickout_allow(struct wlan_objmgr_vdev *vdev,
- struct wlan_objmgr_peer *peer,
- bool kickout_allow);
- /**
- * wlan_son_cbs_init() - son cbs init
- *
- * Return: 0 if succeed
- */
- int wlan_son_cbs_init(void);
- /* wlan_son_cbs_deinit - son cbs deinit
- *
- * Return: 0 if succeed
- */
- int wlan_son_cbs_deinit(void);
- /* wlan_son_cbs_enable() - son cbs enable
- * @vdev: pointer to vdev
- *
- * Return: 0 if succeed
- */
- int wlan_son_cbs_enable(struct wlan_objmgr_vdev *vdev);
- /* wlan_son_cbs_disable() - son cbs disable
- * @vdev: pointer to vdev
- *
- * Return: 0 if succeed
- */
- int wlan_son_cbs_disable(struct wlan_objmgr_vdev *vdev);
- /* wlan_son_set_cbs() - son cbs set
- * @vdev: pointer to vdev
- * @enable: enable or disable son cbs
- *
- * Return: 0 if succeed
- */
- int wlan_son_set_cbs(struct wlan_objmgr_vdev *vdev,
- bool enable);
- /* wlan_son_set_cbs_wait_time() - cbs wait time configure
- * @vdev: pointer to vdev
- * @val: wait time value
- *
- * Return: 0 if succeed
- */
- int wlan_son_set_cbs_wait_time(struct wlan_objmgr_vdev *vdev,
- uint32_t val);
- /* wlan_son_set_cbs_dwell_split_time() - cbs dwell spilt time configure
- * @vdev: pointer to vdev
- * @val: dwell spilt time value
- *
- * Return: 0 if succeed
- */
- int wlan_son_set_cbs_dwell_split_time(struct wlan_objmgr_vdev *vdev,
- uint32_t val);
- /**
- * wlan_son_vdev_get_supported_txrx_streams() - get supported spatial streams
- * @vdev: pointer to vdev
- * @num_tx_streams: pointer to number of tx streams
- * @num_rx_streams: pointer to number of rx streams
- *
- * Return: QDF_STATUS_SUCCESS on Success else failure.
- */
- QDF_STATUS
- wlan_son_vdev_get_supported_txrx_streams(struct wlan_objmgr_vdev *vdev,
- uint32_t *num_tx_streams,
- uint32_t *num_rx_streams);
- #ifdef WLAN_FEATURE_SON
- /**
- * wlan_son_peer_is_kickout_allow() - Is peer is allowed to kickout
- * @vdev: pointer to vdev
- * @macaddr: mac addr of the peer
- *
- * Return: True if it is allowed to kickout.
- */
- bool wlan_son_peer_is_kickout_allow(struct wlan_objmgr_vdev *vdev,
- uint8_t *macaddr);
- /**
- * wlan_son_ind_assoc_req_frm() - indicate assoc req frame to son
- * @vdev: pointer to vdev
- * @macaddr: MAC address
- * @is_reassoc: true if it is reassoc req
- * @frame: frame body
- * @frame_len: frame body length
- * @status: assoc req frame is handled successfully
- *
- * Return: Void
- */
- void wlan_son_ind_assoc_req_frm(struct wlan_objmgr_vdev *vdev,
- uint8_t *macaddr, bool is_reassoc,
- uint8_t *frame, uint16_t frame_len,
- QDF_STATUS status);
- /**
- * wlan_son_deliver_tx_power() - notify son module of tx power
- * @vdev: vdev
- * @max_pwr: max power in dBm unit
- *
- * Return: 0 if event is sent successfully
- */
- int wlan_son_deliver_tx_power(struct wlan_objmgr_vdev *vdev,
- int32_t max_pwr);
- /**
- * wlan_son_deliver_vdev_stop() - notify son module of vdev stop
- * @vdev: vdev
- *
- * Return: 0 if event is sent successfully
- */
- int wlan_son_deliver_vdev_stop(struct wlan_objmgr_vdev *vdev);
- /**
- * wlan_son_deliver_inst_rssi() - notify son module of inst rssi
- * @vdev: vdev
- * @peer: peer device
- * @irssi: inst rssi above the noise floor in dB unit
- *
- * Return: 0 if event is sent successfully
- */
- int wlan_son_deliver_inst_rssi(struct wlan_objmgr_vdev *vdev,
- struct wlan_objmgr_peer *peer,
- uint32_t irssi);
- /**
- * wlan_son_deliver_opmode() - notify user app of opmode
- * @vdev: vdev objmgr
- * @bw: channel width defined in enum eSirMacHTChannelWidth
- * @nss: supported rx nss
- * @addr: source addr
- *
- * Return: 0 if event is sent successfully
- */
- int wlan_son_deliver_opmode(struct wlan_objmgr_vdev *vdev,
- uint8_t bw,
- uint8_t nss,
- uint8_t *addr);
- /**
- * wlan_son_deliver_smps() - notify user app of smps
- * @vdev: vdev objmgr
- * @is_static: is_static
- * @addr: source addr
- *
- * Return: 0 if event is sent successfully
- */
- int wlan_son_deliver_smps(struct wlan_objmgr_vdev *vdev,
- uint8_t is_static,
- uint8_t *addr);
- /**
- * wlan_son_deliver_rrm_rpt() - notify son module of rrm rpt
- * @vdev: vdev objmgr
- * @addr: sender addr
- * @frm: points to measurement report
- * @flen: frame length
- *
- * Return: 0 if event is sent successfully
- */
- int wlan_son_deliver_rrm_rpt(struct wlan_objmgr_vdev *vdev,
- uint8_t *addr,
- uint8_t *frm,
- uint32_t flen);
- /**
- * wlan_son_anqp_frame() - notify son module of mgmt frames
- * @vdev: vdev
- * @subtype: frame subtype
- * @frame: the 802.11 frame
- * @frame_len: frame length
- * @action_hdr: Action header of the frame
- * @macaddr: source mac address
- *
- * Return: 0 if event is sent successfully
- */
- int wlan_son_anqp_frame(struct wlan_objmgr_vdev *vdev, int subtype,
- uint8_t *frame, uint16_t frame_len, void *action_hdr,
- uint8_t *macaddr);
- /**
- * wlan_son_get_node_tx_power() - Gets the max transmit power for peer
- * @assoc_req_ies: assoc req ies
- *
- * Return: Returns the max tx power
- */
- uint8_t wlan_son_get_node_tx_power(struct element_info assoc_req_ies);
- /**
- * wlan_son_get_peer_rrm_info() - Get RRM info for peer
- * @assoc_req_ies: assoc req ies
- * @rrmcaps: rrm capabilities
- * @is_beacon_meas_supported: if beacon meas is supported
- *
- * Return: Returns QDF_STATUS_SUCCESS if succeed
- */
- QDF_STATUS wlan_son_get_peer_rrm_info(struct element_info assoc_req_ies,
- uint8_t *rrmcaps,
- bool *is_beacon_meas_supported);
- #else
- static inline bool wlan_son_peer_is_kickout_allow(struct wlan_objmgr_vdev *vdev,
- uint8_t *macaddr)
- {
- return true;
- }
- static inline
- void wlan_son_ind_assoc_req_frm(struct wlan_objmgr_vdev *vdev,
- uint8_t *macaddr, bool is_reassoc,
- uint8_t *frame, uint16_t frame_len,
- QDF_STATUS status)
- {
- }
- static inline
- int wlan_son_deliver_tx_power(struct wlan_objmgr_vdev *vdev,
- int32_t max_pwr)
- {
- return -EINVAL;
- }
- static inline
- int wlan_son_deliver_vdev_stop(struct wlan_objmgr_vdev *vdev)
- {
- return -EINVAL;
- }
- static inline
- int wlan_son_deliver_inst_rssi(struct wlan_objmgr_vdev *vdev,
- struct wlan_objmgr_peer *peer,
- uint32_t irssi)
- {
- return -EINVAL;
- }
- static inline
- int wlan_son_deliver_opmode(struct wlan_objmgr_vdev *vdev,
- uint8_t bw,
- uint8_t nss,
- uint8_t *addr)
- {
- return -EINVAL;
- }
- static inline
- int wlan_son_deliver_smps(struct wlan_objmgr_vdev *vdev,
- uint8_t is_static,
- uint8_t *addr)
- {
- return -EINVAL;
- }
- static inline
- int wlan_son_deliver_rrm_rpt(struct wlan_objmgr_vdev *vdev,
- uint8_t *mac_addr,
- uint8_t *frm,
- uint32_t flen)
- {
- return -EINVAL;
- }
- static inline
- int wlan_son_anqp_frame(struct wlan_objmgr_vdev *vdev, int subtype,
- uint8_t *frame, uint16_t frame_len, void *action_hdr,
- uint8_t *macaddr)
- {
- return -EINVAL;
- }
- static inline
- uint8_t wlan_son_get_node_tx_power(struct element_info assoc_req_ies)
- {
- return 0;
- }
- static inline
- QDF_STATUS wlan_son_get_peer_rrm_info(struct element_info assoc_req_ies,
- uint8_t *rrmcaps,
- bool *is_beacon_meas_supported)
- {
- return QDF_STATUS_E_INVAL;
- }
- #endif /*WLAN_FEATURE_SON*/
- #endif
|