cachepc-linux

Fork of AMDESE/linux with modifications for CachePC side-channel attack
git clone https://git.sinitax.com/sinitax/cachepc-linux
Log | Files | Refs | README | LICENSE | sfeed.txt

hw_ops.h (6670B)


      1/* SPDX-License-Identifier: GPL-2.0-only */
      2/*
      3 * This file is part of wlcore
      4 *
      5 * Copyright (C) 2011 Texas Instruments Inc.
      6 */
      7
      8#ifndef __WLCORE_HW_OPS_H__
      9#define __WLCORE_HW_OPS_H__
     10
     11#include "wlcore.h"
     12#include "rx.h"
     13
     14static inline u32
     15wlcore_hw_calc_tx_blocks(struct wl1271 *wl, u32 len, u32 spare_blks)
     16{
     17	if (!wl->ops->calc_tx_blocks)
     18		BUG_ON(1);
     19
     20	return wl->ops->calc_tx_blocks(wl, len, spare_blks);
     21}
     22
     23static inline void
     24wlcore_hw_set_tx_desc_blocks(struct wl1271 *wl, struct wl1271_tx_hw_descr *desc,
     25			     u32 blks, u32 spare_blks)
     26{
     27	if (!wl->ops->set_tx_desc_blocks)
     28		BUG_ON(1);
     29
     30	return wl->ops->set_tx_desc_blocks(wl, desc, blks, spare_blks);
     31}
     32
     33static inline void
     34wlcore_hw_set_tx_desc_data_len(struct wl1271 *wl,
     35			       struct wl1271_tx_hw_descr *desc,
     36			       struct sk_buff *skb)
     37{
     38	if (!wl->ops->set_tx_desc_data_len)
     39		BUG_ON(1);
     40
     41	wl->ops->set_tx_desc_data_len(wl, desc, skb);
     42}
     43
     44static inline enum wl_rx_buf_align
     45wlcore_hw_get_rx_buf_align(struct wl1271 *wl, u32 rx_desc)
     46{
     47
     48	if (!wl->ops->get_rx_buf_align)
     49		BUG_ON(1);
     50
     51	return wl->ops->get_rx_buf_align(wl, rx_desc);
     52}
     53
     54static inline int
     55wlcore_hw_prepare_read(struct wl1271 *wl, u32 rx_desc, u32 len)
     56{
     57	if (wl->ops->prepare_read)
     58		return wl->ops->prepare_read(wl, rx_desc, len);
     59
     60	return 0;
     61}
     62
     63static inline u32
     64wlcore_hw_get_rx_packet_len(struct wl1271 *wl, void *rx_data, u32 data_len)
     65{
     66	if (!wl->ops->get_rx_packet_len)
     67		BUG_ON(1);
     68
     69	return wl->ops->get_rx_packet_len(wl, rx_data, data_len);
     70}
     71
     72static inline int wlcore_hw_tx_delayed_compl(struct wl1271 *wl)
     73{
     74	if (wl->ops->tx_delayed_compl)
     75		return wl->ops->tx_delayed_compl(wl);
     76
     77	return 0;
     78}
     79
     80static inline void wlcore_hw_tx_immediate_compl(struct wl1271 *wl)
     81{
     82	if (wl->ops->tx_immediate_compl)
     83		wl->ops->tx_immediate_compl(wl);
     84}
     85
     86static inline int
     87wlcore_hw_init_vif(struct wl1271 *wl, struct wl12xx_vif *wlvif)
     88{
     89	if (wl->ops->init_vif)
     90		return wl->ops->init_vif(wl, wlvif);
     91
     92	return 0;
     93}
     94
     95static inline void
     96wlcore_hw_convert_fw_status(struct wl1271 *wl, void *raw_fw_status,
     97			    struct wl_fw_status *fw_status)
     98{
     99	BUG_ON(!wl->ops->convert_fw_status);
    100
    101	wl->ops->convert_fw_status(wl, raw_fw_status, fw_status);
    102}
    103
    104static inline u32
    105wlcore_hw_sta_get_ap_rate_mask(struct wl1271 *wl, struct wl12xx_vif *wlvif)
    106{
    107	if (!wl->ops->sta_get_ap_rate_mask)
    108		BUG_ON(1);
    109
    110	return wl->ops->sta_get_ap_rate_mask(wl, wlvif);
    111}
    112
    113static inline int wlcore_identify_fw(struct wl1271 *wl)
    114{
    115	if (wl->ops->identify_fw)
    116		return wl->ops->identify_fw(wl);
    117
    118	return 0;
    119}
    120
    121static inline void
    122wlcore_hw_set_tx_desc_csum(struct wl1271 *wl,
    123			   struct wl1271_tx_hw_descr *desc,
    124			   struct sk_buff *skb)
    125{
    126	if (!wl->ops->set_tx_desc_csum)
    127		BUG_ON(1);
    128
    129	wl->ops->set_tx_desc_csum(wl, desc, skb);
    130}
    131
    132static inline void
    133wlcore_hw_set_rx_csum(struct wl1271 *wl,
    134		      struct wl1271_rx_descriptor *desc,
    135		      struct sk_buff *skb)
    136{
    137	if (wl->ops->set_rx_csum)
    138		wl->ops->set_rx_csum(wl, desc, skb);
    139}
    140
    141static inline u32
    142wlcore_hw_ap_get_mimo_wide_rate_mask(struct wl1271 *wl,
    143				     struct wl12xx_vif *wlvif)
    144{
    145	if (wl->ops->ap_get_mimo_wide_rate_mask)
    146		return wl->ops->ap_get_mimo_wide_rate_mask(wl, wlvif);
    147
    148	return 0;
    149}
    150
    151static inline int
    152wlcore_debugfs_init(struct wl1271 *wl, struct dentry *rootdir)
    153{
    154	if (wl->ops->debugfs_init)
    155		return wl->ops->debugfs_init(wl, rootdir);
    156
    157	return 0;
    158}
    159
    160static inline int
    161wlcore_handle_static_data(struct wl1271 *wl, void *static_data)
    162{
    163	if (wl->ops->handle_static_data)
    164		return wl->ops->handle_static_data(wl, static_data);
    165
    166	return 0;
    167}
    168
    169static inline int
    170wlcore_hw_get_spare_blocks(struct wl1271 *wl, bool is_gem)
    171{
    172	if (!wl->ops->get_spare_blocks)
    173		BUG_ON(1);
    174
    175	return wl->ops->get_spare_blocks(wl, is_gem);
    176}
    177
    178static inline int
    179wlcore_hw_set_key(struct wl1271 *wl, enum set_key_cmd cmd,
    180		  struct ieee80211_vif *vif,
    181		  struct ieee80211_sta *sta,
    182		  struct ieee80211_key_conf *key_conf)
    183{
    184	if (!wl->ops->set_key)
    185		BUG_ON(1);
    186
    187	return wl->ops->set_key(wl, cmd, vif, sta, key_conf);
    188}
    189
    190static inline u32
    191wlcore_hw_pre_pkt_send(struct wl1271 *wl, u32 buf_offset, u32 last_len)
    192{
    193	if (wl->ops->pre_pkt_send)
    194		return wl->ops->pre_pkt_send(wl, buf_offset, last_len);
    195
    196	return buf_offset;
    197}
    198
    199static inline void
    200wlcore_hw_sta_rc_update(struct wl1271 *wl, struct wl12xx_vif *wlvif)
    201{
    202	if (wl->ops->sta_rc_update)
    203		wl->ops->sta_rc_update(wl, wlvif);
    204}
    205
    206static inline int
    207wlcore_hw_interrupt_notify(struct wl1271 *wl, bool action)
    208{
    209	if (wl->ops->interrupt_notify)
    210		return wl->ops->interrupt_notify(wl, action);
    211	return 0;
    212}
    213
    214static inline int
    215wlcore_hw_rx_ba_filter(struct wl1271 *wl, bool action)
    216{
    217	if (wl->ops->rx_ba_filter)
    218		return wl->ops->rx_ba_filter(wl, action);
    219	return 0;
    220}
    221
    222static inline int
    223wlcore_hw_ap_sleep(struct wl1271 *wl)
    224{
    225	if (wl->ops->ap_sleep)
    226		return wl->ops->ap_sleep(wl);
    227
    228	return 0;
    229}
    230
    231static inline int
    232wlcore_hw_set_peer_cap(struct wl1271 *wl,
    233		       struct ieee80211_sta_ht_cap *ht_cap,
    234		       bool allow_ht_operation,
    235		       u32 rate_set, u8 hlid)
    236{
    237	if (wl->ops->set_peer_cap)
    238		return wl->ops->set_peer_cap(wl, ht_cap, allow_ht_operation,
    239					     rate_set, hlid);
    240
    241	return 0;
    242}
    243
    244static inline u32
    245wlcore_hw_convert_hwaddr(struct wl1271 *wl, u32 hwaddr)
    246{
    247	if (!wl->ops->convert_hwaddr)
    248		BUG_ON(1);
    249
    250	return wl->ops->convert_hwaddr(wl, hwaddr);
    251}
    252
    253static inline bool
    254wlcore_hw_lnk_high_prio(struct wl1271 *wl, u8 hlid,
    255			struct wl1271_link *lnk)
    256{
    257	if (!wl->ops->lnk_high_prio)
    258		BUG_ON(1);
    259
    260	return wl->ops->lnk_high_prio(wl, hlid, lnk);
    261}
    262
    263static inline bool
    264wlcore_hw_lnk_low_prio(struct wl1271 *wl, u8 hlid,
    265		       struct wl1271_link *lnk)
    266{
    267	if (!wl->ops->lnk_low_prio)
    268		BUG_ON(1);
    269
    270	return wl->ops->lnk_low_prio(wl, hlid, lnk);
    271}
    272
    273static inline int
    274wlcore_smart_config_start(struct wl1271 *wl, u32 group_bitmap)
    275{
    276	if (!wl->ops->smart_config_start)
    277		return -EINVAL;
    278
    279	return wl->ops->smart_config_start(wl, group_bitmap);
    280}
    281
    282static inline int
    283wlcore_smart_config_stop(struct wl1271 *wl)
    284{
    285	if (!wl->ops->smart_config_stop)
    286		return -EINVAL;
    287
    288	return wl->ops->smart_config_stop(wl);
    289}
    290
    291static inline int
    292wlcore_smart_config_set_group_key(struct wl1271 *wl, u16 group_id,
    293				  u8 key_len, u8 *key)
    294{
    295	if (!wl->ops->smart_config_set_group_key)
    296		return -EINVAL;
    297
    298	return wl->ops->smart_config_set_group_key(wl, group_id, key_len, key);
    299}
    300
    301static inline int
    302wlcore_hw_set_cac(struct wl1271 *wl, struct wl12xx_vif *wlvif, bool start)
    303{
    304	if (!wl->ops->set_cac)
    305		return -EINVAL;
    306
    307	return wl->ops->set_cac(wl, wlvif, start);
    308}
    309
    310static inline int
    311wlcore_hw_dfs_master_restart(struct wl1271 *wl, struct wl12xx_vif *wlvif)
    312{
    313	if (!wl->ops->dfs_master_restart)
    314		return -EINVAL;
    315
    316	return wl->ops->dfs_master_restart(wl, wlvif);
    317}
    318#endif