]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
wifi: ath12k: Move DP related functions from peer.c to dp_peer.c file
authorHarsh Kumar Bijlani <quic_hbijlani@quicinc.com>
Fri, 24 Oct 2025 18:15:40 +0000 (23:45 +0530)
committerJeff Johnson <jeff.johnson@oss.qualcomm.com>
Mon, 27 Oct 2025 14:01:59 +0000 (07:01 -0700)
Refactor the structures and APIs defined in files peer.h and peer.c in such a
way that the APIs making use of ath12k_peer are moved to newly introduced files
dp_peer.h and dp_peer.c.

Have this new file dp_peer.c compiled as part of kernel module ath12k.ko.

Move these APIs from peer.h and peer.c to dp_peer.h and dp_peer.c:
  ath12k_peer_find()
  ath12k_peer_find_by_pdev_idx()
  ath12k_peer_find_by_addr()
  ath12k_peer_find_by_ml_id()
  ath12k_peer_find_by_id()
  ath12k_peer_exist_by_vdev_id()
  ath12k_peer_find_by_ast()
  ath12k_peer_unmap_event()
  ath12k_peer_map_event()
  ath12k_peer_get_link_sta()

Background:

In current ath12k architecture, connected station is represented by struct
ath12k_sta.

struct ath12k_sta has an array of struct ath12k_link_sta wherein each index
represents one link of the connected station.

For each ath12k_link_sta, there is a corresponding data path peer which is
represented by struct ath12k_peer.

Diagrammatic view of the station is as below:

        ath12k_sta
            |
            |-> ath12k_link_sta <--> ath12k_peer
            |
            |-> ath12k_link_sta <--> ath12k_peer
            |
            |-> ath12k_link_sta <--> ath12k_peer

Currently, in control path, ath12k_link_sta and ath12k_peer are used
interchangeably, while the data path makes use of ath12k_peer only.

For ath12k next-generation driver framework, in order to have a clean
segregation between control and data path, use ath12k_link_sta only for control
path operations.

Station view for the data path is revamped as below:

        ath12k_dp_peer
               |
               |-> ath12k_dp_link_peer
               |
               |-> ath12k_dp_link_peer
               |
               |-> ath12k_dp_link_peer

Introduce the structure ath12k_dp_peer to represent the data path version of
corresponding ath12k_sta.

This ath12k_dp_peer contains the fields used in the per packet Tx Rx paths
applicable across all the links and maintains an array of ath12k_dp_link_peer.
Per packet Tx and Rx path operates on ath12k_dp_peer. This ath12k_dp_peer is a
standalone new object and has back pointer reference to ieee80211_sta.

Rename ath12k_peer to ath12k_dp_link_peer and move the fields which are common
across all the links to ath12k_dp_peer.

Add the fields specific to a link which are mostly for statistics and monitor
usage to ath12k_dp_link_peer.

Final view of station in ath12k next-generation driver is shown as below:

            Control Path                            Data Path
        -------------------------------------------------------------------
        ath12k_sta                            ath12k_dp_peer
            |                                       |
            |-> ath12k_link_sta    <---->           |-> ath12k_dp_link_peer
            |                                       |
            |-> ath12k_link_sta    <---->           |-> ath12k_dp_link_peer
            |                                       |
            |-> ath12k_link_sta    <---->           |-> ath12k_dp_link_peer

This patch and the subsequent patches in this series are meant to achieve the
modularization of peer object as mentioned above.

Tested-on: QCN9274 hw2.0 PCI WLAN.WBE.1.4.1-00199-QCAHKSWPL_SILICONZ-1
Tested-on: WCN7850 hw2.0 PCI WLAN.HMT.1.0.c5-00481-QCAHMTSWPL_V1.0_V2.0_SILICONZ-3

Signed-off-by: Harsh Kumar Bijlani <quic_hbijlani@quicinc.com>
Signed-off-by: Ripan Deuri <quic_rdeuri@quicinc.com>
Reviewed-by: Vasanthakumar Thiagarajan <vasanthakumar.thiagarajan@oss.qualcomm.com>
Reviewed-by: Baochen Qiang <baochen.qiang@oss.qualcomm.com>
Link: https://patch.msgid.link/20251024181548.3255166-2-quic_rdeuri@quicinc.com
Signed-off-by: Jeff Johnson <jeff.johnson@oss.qualcomm.com>
drivers/net/wireless/ath/ath12k/Makefile
drivers/net/wireless/ath/ath12k/dp_peer.c [new file with mode: 0644]
drivers/net/wireless/ath/ath12k/dp_peer.h [new file with mode: 0644]
drivers/net/wireless/ath/ath12k/peer.c
drivers/net/wireless/ath/ath12k/peer.h

index 32a0f30faf9222c9ab39af653a27f378163223e3..d397bc494cf253e8546c6dce99d8f8a8fce0668a 100644 (file)
@@ -11,6 +11,7 @@ ath12k-y += core.o \
            dp_tx.o \
            dp_rx.o \
            dp_htt.o \
+           dp_peer.o \
            debug.o \
            ce.o \
            peer.o \
diff --git a/drivers/net/wireless/ath/ath12k/dp_peer.c b/drivers/net/wireless/ath/ath12k/dp_peer.c
new file mode 100644 (file)
index 0000000..e32d3ea
--- /dev/null
@@ -0,0 +1,207 @@
+// SPDX-License-Identifier: BSD-3-Clause-Clear
+/*
+ * Copyright (c) 2018-2021 The Linux Foundation. All rights reserved.
+ * Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.
+ */
+
+#include "core.h"
+#include "dp_peer.h"
+#include "debug.h"
+
+struct ath12k_peer *ath12k_peer_find(struct ath12k_base *ab, int vdev_id,
+                                    const u8 *addr)
+{
+       struct ath12k_peer *peer;
+
+       lockdep_assert_held(&ab->base_lock);
+
+       list_for_each_entry(peer, &ab->peers, list) {
+               if (peer->vdev_id != vdev_id)
+                       continue;
+               if (!ether_addr_equal(peer->addr, addr))
+                       continue;
+
+               return peer;
+       }
+
+       return NULL;
+}
+
+struct ath12k_peer *ath12k_peer_find_by_pdev_idx(struct ath12k_base *ab,
+                                                u8 pdev_idx, const u8 *addr)
+{
+       struct ath12k_peer *peer;
+
+       lockdep_assert_held(&ab->base_lock);
+
+       list_for_each_entry(peer, &ab->peers, list) {
+               if (peer->pdev_idx != pdev_idx)
+                       continue;
+               if (!ether_addr_equal(peer->addr, addr))
+                       continue;
+
+               return peer;
+       }
+
+       return NULL;
+}
+
+struct ath12k_peer *ath12k_peer_find_by_addr(struct ath12k_base *ab,
+                                            const u8 *addr)
+{
+       struct ath12k_peer *peer;
+
+       lockdep_assert_held(&ab->base_lock);
+
+       list_for_each_entry(peer, &ab->peers, list) {
+               if (!ether_addr_equal(peer->addr, addr))
+                       continue;
+
+               return peer;
+       }
+
+       return NULL;
+}
+EXPORT_SYMBOL(ath12k_peer_find_by_addr);
+
+static struct ath12k_peer *ath12k_peer_find_by_ml_id(struct ath12k_base *ab,
+                                                    int ml_peer_id)
+{
+       struct ath12k_peer *peer;
+
+       lockdep_assert_held(&ab->base_lock);
+
+       list_for_each_entry(peer, &ab->peers, list)
+               if (ml_peer_id == peer->ml_id)
+                       return peer;
+
+       return NULL;
+}
+
+struct ath12k_peer *ath12k_peer_find_by_id(struct ath12k_base *ab,
+                                          int peer_id)
+{
+       struct ath12k_peer *peer;
+
+       lockdep_assert_held(&ab->base_lock);
+
+       if (peer_id == HAL_INVALID_PEERID)
+               return NULL;
+
+       if (peer_id & ATH12K_PEER_ML_ID_VALID)
+               return ath12k_peer_find_by_ml_id(ab, peer_id);
+
+       list_for_each_entry(peer, &ab->peers, list)
+               if (peer_id == peer->peer_id)
+                       return peer;
+
+       return NULL;
+}
+
+bool ath12k_peer_exist_by_vdev_id(struct ath12k_base *ab, int vdev_id)
+{
+       struct ath12k_peer *peer;
+
+       spin_lock_bh(&ab->base_lock);
+
+       list_for_each_entry(peer, &ab->peers, list) {
+               if (vdev_id == peer->vdev_id) {
+                       spin_unlock_bh(&ab->base_lock);
+                       return true;
+               }
+       }
+       spin_unlock_bh(&ab->base_lock);
+       return false;
+}
+
+struct ath12k_peer *ath12k_peer_find_by_ast(struct ath12k_base *ab,
+                                           int ast_hash)
+{
+       struct ath12k_peer *peer;
+
+       lockdep_assert_held(&ab->base_lock);
+
+       list_for_each_entry(peer, &ab->peers, list)
+               if (ast_hash == peer->ast_hash)
+                       return peer;
+
+       return NULL;
+}
+
+void ath12k_peer_unmap_event(struct ath12k_base *ab, u16 peer_id)
+{
+       struct ath12k_peer *peer;
+
+       spin_lock_bh(&ab->base_lock);
+
+       peer = ath12k_peer_find_by_id(ab, peer_id);
+       if (!peer) {
+               ath12k_warn(ab, "peer-unmap-event: unknown peer id %d\n",
+                           peer_id);
+               goto exit;
+       }
+
+       ath12k_dbg(ab, ATH12K_DBG_DP_HTT, "htt peer unmap vdev %d peer %pM id %d\n",
+                  peer->vdev_id, peer->addr, peer_id);
+
+       list_del(&peer->list);
+       kfree(peer);
+       wake_up(&ab->peer_mapping_wq);
+
+exit:
+       spin_unlock_bh(&ab->base_lock);
+}
+
+void ath12k_peer_map_event(struct ath12k_base *ab, u8 vdev_id, u16 peer_id,
+                          u8 *mac_addr, u16 ast_hash, u16 hw_peer_id)
+{
+       struct ath12k_peer *peer;
+
+       spin_lock_bh(&ab->base_lock);
+       peer = ath12k_peer_find(ab, vdev_id, mac_addr);
+       if (!peer) {
+               peer = kzalloc(sizeof(*peer), GFP_ATOMIC);
+               if (!peer)
+                       goto exit;
+
+               peer->vdev_id = vdev_id;
+               peer->peer_id = peer_id;
+               peer->ast_hash = ast_hash;
+               peer->hw_peer_id = hw_peer_id;
+               ether_addr_copy(peer->addr, mac_addr);
+               list_add(&peer->list, &ab->peers);
+               wake_up(&ab->peer_mapping_wq);
+       }
+
+       ath12k_dbg(ab, ATH12K_DBG_DP_HTT, "htt peer map vdev %d peer %pM id %d\n",
+                  vdev_id, mac_addr, peer_id);
+
+exit:
+       spin_unlock_bh(&ab->base_lock);
+}
+
+struct ath12k_link_sta *ath12k_peer_get_link_sta(struct ath12k_base *ab,
+                                                struct ath12k_peer *peer)
+{
+       struct ath12k_sta *ahsta;
+       struct ath12k_link_sta *arsta;
+
+       if (!peer->sta)
+               return NULL;
+
+       ahsta = ath12k_sta_to_ahsta(peer->sta);
+       if (peer->ml_id & ATH12K_PEER_ML_ID_VALID) {
+               if (!(ahsta->links_map & BIT(peer->link_id))) {
+                       ath12k_warn(ab, "peer %pM id %d link_id %d can't found in STA link_map 0x%x\n",
+                                   peer->addr, peer->peer_id, peer->link_id,
+                                   ahsta->links_map);
+                       return NULL;
+               }
+               arsta = rcu_dereference(ahsta->link[peer->link_id]);
+               if (!arsta)
+                       return NULL;
+       } else {
+               arsta =  &ahsta->deflink;
+       }
+       return arsta;
+}
diff --git a/drivers/net/wireless/ath/ath12k/dp_peer.h b/drivers/net/wireless/ath/ath12k/dp_peer.h
new file mode 100644 (file)
index 0000000..19f01d6
--- /dev/null
@@ -0,0 +1,82 @@
+/* SPDX-License-Identifier: BSD-3-Clause-Clear */
+/*
+ * Copyright (c) 2018-2021 The Linux Foundation. All rights reserved.
+ * Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.
+ */
+
+#ifndef ATH12K_DP_PEER_H
+#define ATH12K_DP_PEER_H
+
+#include "dp_rx.h"
+
+struct ppdu_user_delayba {
+       u16 sw_peer_id;
+       u32 info0;
+       u16 ru_end;
+       u16 ru_start;
+       u32 info1;
+       u32 rate_flags;
+       u32 resp_rate_flags;
+};
+
+#define ATH12K_PEER_ML_ID_VALID         BIT(13)
+
+struct ath12k_peer {
+       struct list_head list;
+       struct ieee80211_sta *sta;
+       int vdev_id;
+       u8 addr[ETH_ALEN];
+       int peer_id;
+       u16 ast_hash;
+       u8 pdev_idx;
+       u16 hw_peer_id;
+
+       /* protected by ab->data_lock */
+       struct ieee80211_key_conf *keys[WMI_MAX_KEY_INDEX + 1];
+       struct ath12k_dp_rx_tid rx_tid[IEEE80211_NUM_TIDS + 1];
+
+       /* Info used in MMIC verification of
+        * RX fragments
+        */
+       struct crypto_shash *tfm_mmic;
+       u8 mcast_keyidx;
+       u8 ucast_keyidx;
+       u16 sec_type;
+       u16 sec_type_grp;
+       struct ppdu_user_delayba ppdu_stats_delayba;
+       bool delayba_flag;
+       bool is_authorized;
+       bool mlo;
+       /* protected by ab->data_lock */
+       bool dp_setup_done;
+
+       u16 ml_id;
+
+       /* any other ML info common for all partners can be added
+        * here and would be same for all partner peers.
+        */
+       u8 ml_addr[ETH_ALEN];
+
+       /* To ensure only certain work related to dp is done once */
+       bool primary_link;
+
+       /* for reference to ath12k_link_sta */
+       u8 link_id;
+       bool ucast_ra_only;
+};
+
+void ath12k_peer_unmap_event(struct ath12k_base *ab, u16 peer_id);
+void ath12k_peer_map_event(struct ath12k_base *ab, u8 vdev_id, u16 peer_id,
+                          u8 *mac_addr, u16 ast_hash, u16 hw_peer_id);
+struct ath12k_peer *ath12k_peer_find(struct ath12k_base *ab, int vdev_id,
+                                    const u8 *addr);
+struct ath12k_peer *ath12k_peer_find_by_addr(struct ath12k_base *ab,
+                                            const u8 *addr);
+struct ath12k_peer *ath12k_peer_find_by_id(struct ath12k_base *ab, int peer_id);
+bool ath12k_peer_exist_by_vdev_id(struct ath12k_base *ab, int vdev_id);
+struct ath12k_peer *ath12k_peer_find_by_ast(struct ath12k_base *ab, int ast_hash);
+struct ath12k_peer *ath12k_peer_find_by_pdev_idx(struct ath12k_base *ab,
+                                                u8 pdev_idx, const u8 *addr);
+struct ath12k_link_sta *ath12k_peer_get_link_sta(struct ath12k_base *ab,
+                                                struct ath12k_peer *peer);
+#endif
index ce156429865683018125a02fa76c6dcda8963a5d..1e2526bb11865103c23ecc64516bae044d25d386 100644 (file)
@@ -25,178 +25,6 @@ struct ath12k_ml_peer *ath12k_peer_ml_find(struct ath12k_hw *ah, const u8 *addr)
 }
 EXPORT_SYMBOL(ath12k_peer_ml_find);
 
-struct ath12k_peer *ath12k_peer_find(struct ath12k_base *ab, int vdev_id,
-                                    const u8 *addr)
-{
-       struct ath12k_peer *peer;
-
-       lockdep_assert_held(&ab->base_lock);
-
-       list_for_each_entry(peer, &ab->peers, list) {
-               if (peer->vdev_id != vdev_id)
-                       continue;
-               if (!ether_addr_equal(peer->addr, addr))
-                       continue;
-
-               return peer;
-       }
-
-       return NULL;
-}
-
-static struct ath12k_peer *ath12k_peer_find_by_pdev_idx(struct ath12k_base *ab,
-                                                       u8 pdev_idx, const u8 *addr)
-{
-       struct ath12k_peer *peer;
-
-       lockdep_assert_held(&ab->base_lock);
-
-       list_for_each_entry(peer, &ab->peers, list) {
-               if (peer->pdev_idx != pdev_idx)
-                       continue;
-               if (!ether_addr_equal(peer->addr, addr))
-                       continue;
-
-               return peer;
-       }
-
-       return NULL;
-}
-
-struct ath12k_peer *ath12k_peer_find_by_addr(struct ath12k_base *ab,
-                                            const u8 *addr)
-{
-       struct ath12k_peer *peer;
-
-       lockdep_assert_held(&ab->base_lock);
-
-       list_for_each_entry(peer, &ab->peers, list) {
-               if (!ether_addr_equal(peer->addr, addr))
-                       continue;
-
-               return peer;
-       }
-
-       return NULL;
-}
-EXPORT_SYMBOL(ath12k_peer_find_by_addr);
-
-static struct ath12k_peer *ath12k_peer_find_by_ml_id(struct ath12k_base *ab,
-                                                    int ml_peer_id)
-{
-       struct ath12k_peer *peer;
-
-       lockdep_assert_held(&ab->base_lock);
-
-       list_for_each_entry(peer, &ab->peers, list)
-               if (ml_peer_id == peer->ml_id)
-                       return peer;
-
-       return NULL;
-}
-
-struct ath12k_peer *ath12k_peer_find_by_id(struct ath12k_base *ab,
-                                          int peer_id)
-{
-       struct ath12k_peer *peer;
-
-       lockdep_assert_held(&ab->base_lock);
-
-       if (peer_id == HAL_INVALID_PEERID)
-               return NULL;
-
-       if (peer_id & ATH12K_PEER_ML_ID_VALID)
-               return ath12k_peer_find_by_ml_id(ab, peer_id);
-
-       list_for_each_entry(peer, &ab->peers, list)
-               if (peer_id == peer->peer_id)
-                       return peer;
-
-       return NULL;
-}
-
-bool ath12k_peer_exist_by_vdev_id(struct ath12k_base *ab, int vdev_id)
-{
-       struct ath12k_peer *peer;
-
-       spin_lock_bh(&ab->base_lock);
-
-       list_for_each_entry(peer, &ab->peers, list) {
-               if (vdev_id == peer->vdev_id) {
-                       spin_unlock_bh(&ab->base_lock);
-                       return true;
-               }
-       }
-       spin_unlock_bh(&ab->base_lock);
-       return false;
-}
-
-struct ath12k_peer *ath12k_peer_find_by_ast(struct ath12k_base *ab,
-                                           int ast_hash)
-{
-       struct ath12k_peer *peer;
-
-       lockdep_assert_held(&ab->base_lock);
-
-       list_for_each_entry(peer, &ab->peers, list)
-               if (ast_hash == peer->ast_hash)
-                       return peer;
-
-       return NULL;
-}
-
-void ath12k_peer_unmap_event(struct ath12k_base *ab, u16 peer_id)
-{
-       struct ath12k_peer *peer;
-
-       spin_lock_bh(&ab->base_lock);
-
-       peer = ath12k_peer_find_by_id(ab, peer_id);
-       if (!peer) {
-               ath12k_warn(ab, "peer-unmap-event: unknown peer id %d\n",
-                           peer_id);
-               goto exit;
-       }
-
-       ath12k_dbg(ab, ATH12K_DBG_DP_HTT, "htt peer unmap vdev %d peer %pM id %d\n",
-                  peer->vdev_id, peer->addr, peer_id);
-
-       list_del(&peer->list);
-       kfree(peer);
-       wake_up(&ab->peer_mapping_wq);
-
-exit:
-       spin_unlock_bh(&ab->base_lock);
-}
-
-void ath12k_peer_map_event(struct ath12k_base *ab, u8 vdev_id, u16 peer_id,
-                          u8 *mac_addr, u16 ast_hash, u16 hw_peer_id)
-{
-       struct ath12k_peer *peer;
-
-       spin_lock_bh(&ab->base_lock);
-       peer = ath12k_peer_find(ab, vdev_id, mac_addr);
-       if (!peer) {
-               peer = kzalloc(sizeof(*peer), GFP_ATOMIC);
-               if (!peer)
-                       goto exit;
-
-               peer->vdev_id = vdev_id;
-               peer->peer_id = peer_id;
-               peer->ast_hash = ast_hash;
-               peer->hw_peer_id = hw_peer_id;
-               ether_addr_copy(peer->addr, mac_addr);
-               list_add(&peer->list, &ab->peers);
-               wake_up(&ab->peer_mapping_wq);
-       }
-
-       ath12k_dbg(ab, ATH12K_DBG_DP_HTT, "htt peer map vdev %d peer %pM id %d\n",
-                  vdev_id, mac_addr, peer_id);
-
-exit:
-       spin_unlock_bh(&ab->base_lock);
-}
-
 static int ath12k_wait_for_peer_common(struct ath12k_base *ab, int vdev_id,
                                       const u8 *addr, bool expect_mapped)
 {
index 44afc0b7dd53ea41897de3d2e98dc7583a783d55..81e9bcc067ff43b01f4aa9abb1cf533b4e7bfc7e 100644 (file)
@@ -1,69 +1,13 @@
 /* SPDX-License-Identifier: BSD-3-Clause-Clear */
 /*
  * Copyright (c) 2018-2021 The Linux Foundation. All rights reserved.
- * Copyright (c) 2021-2025 Qualcomm Innovation Center, Inc. All rights reserved.
+ * Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.
  */
 
 #ifndef ATH12K_PEER_H
 #define ATH12K_PEER_H
 
-#include "dp_rx.h"
-
-struct ppdu_user_delayba {
-       u16 sw_peer_id;
-       u32 info0;
-       u16 ru_end;
-       u16 ru_start;
-       u32 info1;
-       u32 rate_flags;
-       u32 resp_rate_flags;
-};
-
-#define ATH12K_PEER_ML_ID_VALID         BIT(13)
-
-struct ath12k_peer {
-       struct list_head list;
-       struct ieee80211_sta *sta;
-       int vdev_id;
-       u8 addr[ETH_ALEN];
-       int peer_id;
-       u16 ast_hash;
-       u8 pdev_idx;
-       u16 hw_peer_id;
-
-       /* protected by ab->data_lock */
-       struct ieee80211_key_conf *keys[WMI_MAX_KEY_INDEX + 1];
-       struct ath12k_dp_rx_tid rx_tid[IEEE80211_NUM_TIDS + 1];
-
-       /* Info used in MMIC verification of
-        * RX fragments
-        */
-       struct crypto_shash *tfm_mmic;
-       u8 mcast_keyidx;
-       u8 ucast_keyidx;
-       u16 sec_type;
-       u16 sec_type_grp;
-       struct ppdu_user_delayba ppdu_stats_delayba;
-       bool delayba_flag;
-       bool is_authorized;
-       bool mlo;
-       /* protected by ab->data_lock */
-       bool dp_setup_done;
-
-       u16 ml_id;
-
-       /* any other ML info common for all partners can be added
-        * here and would be same for all partner peers.
-        */
-       u8 ml_addr[ETH_ALEN];
-
-       /* To ensure only certain work related to dp is done once */
-       bool primary_link;
-
-       /* for reference to ath12k_link_sta */
-       u8 link_id;
-       bool ucast_ra_only;
-};
+#include "dp_peer.h"
 
 struct ath12k_ml_peer {
        struct list_head list;
@@ -71,14 +15,6 @@ struct ath12k_ml_peer {
        u16 id;
 };
 
-void ath12k_peer_unmap_event(struct ath12k_base *ab, u16 peer_id);
-void ath12k_peer_map_event(struct ath12k_base *ab, u8 vdev_id, u16 peer_id,
-                          u8 *mac_addr, u16 ast_hash, u16 hw_peer_id);
-struct ath12k_peer *ath12k_peer_find(struct ath12k_base *ab, int vdev_id,
-                                    const u8 *addr);
-struct ath12k_peer *ath12k_peer_find_by_addr(struct ath12k_base *ab,
-                                            const u8 *addr);
-struct ath12k_peer *ath12k_peer_find_by_id(struct ath12k_base *ab, int peer_id);
 void ath12k_peer_cleanup(struct ath12k *ar, u32 vdev_id);
 int ath12k_peer_delete(struct ath12k *ar, u32 vdev_id, u8 *addr);
 int ath12k_peer_create(struct ath12k *ar, struct ath12k_link_vif *arvif,
@@ -86,38 +22,9 @@ int ath12k_peer_create(struct ath12k *ar, struct ath12k_link_vif *arvif,
                       struct ath12k_wmi_peer_create_arg *arg);
 int ath12k_wait_for_peer_delete_done(struct ath12k *ar, u32 vdev_id,
                                     const u8 *addr);
-bool ath12k_peer_exist_by_vdev_id(struct ath12k_base *ab, int vdev_id);
-struct ath12k_peer *ath12k_peer_find_by_ast(struct ath12k_base *ab, int ast_hash);
 int ath12k_peer_ml_create(struct ath12k_hw *ah, struct ieee80211_sta *sta);
 int ath12k_peer_ml_delete(struct ath12k_hw *ah, struct ieee80211_sta *sta);
 int ath12k_peer_mlo_link_peers_delete(struct ath12k_vif *ahvif, struct ath12k_sta *ahsta);
 struct ath12k_ml_peer *ath12k_peer_ml_find(struct ath12k_hw *ah,
                                           const u8 *addr);
-static inline
-struct ath12k_link_sta *ath12k_peer_get_link_sta(struct ath12k_base *ab,
-                                                struct ath12k_peer *peer)
-{
-       struct ath12k_sta *ahsta;
-       struct ath12k_link_sta *arsta;
-
-       if (!peer->sta)
-               return NULL;
-
-       ahsta = ath12k_sta_to_ahsta(peer->sta);
-       if (peer->ml_id & ATH12K_PEER_ML_ID_VALID) {
-               if (!(ahsta->links_map & BIT(peer->link_id))) {
-                       ath12k_warn(ab, "peer %pM id %d link_id %d can't found in STA link_map 0x%x\n",
-                                   peer->addr, peer->peer_id, peer->link_id,
-                                   ahsta->links_map);
-                       return NULL;
-               }
-               arsta = rcu_dereference(ahsta->link[peer->link_id]);
-               if (!arsta)
-                       return NULL;
-       } else {
-               arsta =  &ahsta->deflink;
-       }
-       return arsta;
-}
-
 #endif /* _PEER_H_ */