blob: cfb2ce1dca127e2ba156c5b9ceab762f41b36c39 [file] [log] [blame]
Debashis Duttc4c52dc2016-10-04 17:12:23 -07001/*
Tallapragada Kalyan57b6bb32018-01-02 12:58:33 +05302 * Copyright (c) 2016-2018 The Linux Foundation. All rights reserved.
Debashis Duttc4c52dc2016-10-04 17:12:23 -07003 *
4 * Permission to use, copy, modify, and/or distribute this software for
5 * any purpose with or without fee is hereby granted, provided that the
6 * above copyright notice and this permission notice appear in all
7 * copies.
8 *
9 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
10 * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
11 * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
12 * AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
13 * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
14 * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
15 * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
16 * PERFORMANCE OF THIS SOFTWARE.
17 */
Jeff Johnson2cb8fc72016-12-17 10:45:08 -080018#ifndef _DP_PEER_H_
19#define _DP_PEER_H_
Debashis Duttc4c52dc2016-10-04 17:12:23 -070020
21#include <qdf_types.h>
22#include <qdf_lock.h>
23#include "dp_types.h"
24
25#define DP_INVALID_PEER_ID 0xffff
Debashis Duttc4c52dc2016-10-04 17:12:23 -070026/**
Chaithanya Garrepalli974da262018-02-22 20:32:19 +053027 * __dp_peer_find_by_id() - Returns peer object given the peer id
Debashis Duttc4c52dc2016-10-04 17:12:23 -070028 *
29 * @soc : core DP soc context
30 * @peer_id : peer id from peer object can be retrieved
31 *
32 * Return: struct dp_peer*: Pointer to DP peer object
33 */
34static inline struct dp_peer *
Chaithanya Garrepalli974da262018-02-22 20:32:19 +053035__dp_peer_find_by_id(struct dp_soc *soc,
Debashis Duttc4c52dc2016-10-04 17:12:23 -070036 uint16_t peer_id)
37{
38 struct dp_peer *peer;
39
40 /* TODO: Hold lock */
41 peer = (peer_id >= soc->max_peers) ? NULL :
42 soc->peer_id_to_obj_map[peer_id];
43
Anish Nataraj0dae6762018-03-02 22:31:45 +053044 /**
45 * For bss peer, peer is not really deleted
46 * but reference count is decremented in firmware
47 * and hence ignore delete in progress for bss peer
48 */
49 if (peer && !peer->bss_peer && peer->delete_in_progress)
50 return NULL;
51
Debashis Duttc4c52dc2016-10-04 17:12:23 -070052 return peer;
53}
Jeff Johnson2cb8fc72016-12-17 10:45:08 -080054
Chaithanya Garrepalli974da262018-02-22 20:32:19 +053055/**
56 * dp_peer_find_by_id() - Returns peer object given the peer id
57 * if delete_in_progress in not set for peer
58 *
59 * @soc : core DP soc context
60 * @peer_id : peer id from peer object can be retrieved
61 *
62 * Return: struct dp_peer*: Pointer to DP peer object
63 */
64static inline struct dp_peer *
65dp_peer_find_by_id(struct dp_soc *soc,
66 uint16_t peer_id)
67{
68 struct dp_peer *peer;
69
70 peer = __dp_peer_find_by_id (soc, peer_id);
71
72 if (peer && peer->delete_in_progress) {
73 return NULL;
74 }
75
76 return peer;
77}
78
Jeff Johnson2cb8fc72016-12-17 10:45:08 -080079void dp_rx_peer_map_handler(void *soc_handle, uint16_t peer_id,
Tallapragada Kalyan6f6166e2017-02-17 17:00:23 +053080 uint16_t hw_peer_id, uint8_t vdev_id, uint8_t *peer_mac_addr);
Jeff Johnson2cb8fc72016-12-17 10:45:08 -080081void dp_rx_peer_unmap_handler(void *soc_handle, uint16_t peer_id);
82void dp_rx_sec_ind_handler(void *soc_handle, uint16_t peer_id,
83 enum htt_sec_type sec_type, int is_unicast,
84 u_int32_t *michael_key, u_int32_t *rx_pn);
Ishank Jain1e7401c2017-02-17 15:38:39 +053085uint8_t dp_get_peer_mac_addr_frm_id(struct cdp_soc_t *soc_handle,
86 uint16_t peer_id, uint8_t *peer_mac);
Jeff Johnson2cb8fc72016-12-17 10:45:08 -080087
Pamidipati, Vijayb8bbf162017-06-26 23:47:39 +053088int dp_peer_add_ast(struct dp_soc *soc, struct dp_peer *peer,
Tallapragada Kalyan57b6bb32018-01-02 12:58:33 +053089 uint8_t *mac_addr, enum cdp_txrx_ast_entry_type type,
90 uint32_t flags);
91
92void dp_peer_del_ast(struct dp_soc *soc, struct dp_ast_entry *ast_entry);
93
94int dp_peer_update_ast(struct dp_soc *soc, struct dp_peer *peer,
95 struct dp_ast_entry *ast_entry, uint32_t flags);
96
Tallapragada Kalyan1c14d5d2017-07-26 00:31:35 +053097struct dp_ast_entry *dp_peer_ast_hash_find(struct dp_soc *soc,
Tallapragada Kalyan57b6bb32018-01-02 12:58:33 +053098 uint8_t *ast_mac_addr);
99
100uint8_t dp_peer_ast_get_pdev_id(struct dp_soc *soc,
101 struct dp_ast_entry *ast_entry);
102
103
104uint8_t dp_peer_ast_get_next_hop(struct dp_soc *soc,
105 struct dp_ast_entry *ast_entry);
106
107void dp_peer_ast_set_type(struct dp_soc *soc,
108 struct dp_ast_entry *ast_entry,
109 enum cdp_txrx_ast_entry_type type);
Pamidipati, Vijayb8bbf162017-06-26 23:47:39 +0530110
Pramod Simhab17d0672017-03-06 17:20:13 -0800111/*
112 * dp_get_vdev_from_soc_vdev_id_wifi3() -
113 * Returns vdev object given the vdev id
114 * vdev id is unique across pdev's
115 *
116 * @soc : core DP soc context
117 * @vdev_id : vdev id from vdev object can be retrieved
118 *
119 * Return: struct dp_vdev*: Pointer to DP vdev object
120 */
121static inline struct dp_vdev *
122dp_get_vdev_from_soc_vdev_id_wifi3(struct dp_soc *soc,
123 uint8_t vdev_id)
124{
125 struct dp_pdev *pdev = NULL;
126 struct dp_vdev *vdev = NULL;
127 int i;
128
129 for (i = 0; i < MAX_PDEV_CNT && soc->pdev_list[i]; i++) {
130 pdev = soc->pdev_list[i];
131 TAILQ_FOREACH(vdev, &pdev->vdev_list, vdev_list_elem) {
132 if (vdev->vdev_id == vdev_id) {
133 QDF_TRACE(QDF_MODULE_ID_DP,
134 QDF_TRACE_LEVEL_INFO,
Jeff Johnson3f217e22017-09-18 10:13:35 -0700135 FL("Found vdev 0x%pK on pdev %d\n"),
Pramod Simhab17d0672017-03-06 17:20:13 -0800136 vdev, i);
137 return vdev;
138 }
139 }
140 }
141 return NULL;
142
143}
Jeff Johnson2cb8fc72016-12-17 10:45:08 -0800144#endif /* _DP_PEER_H_ */