Commit 50ac6607 authored by Amitkumar Karwar's avatar Amitkumar Karwar Committed by Johannes Berg

cfg80211/nl80211: rename packet pattern related structures and enums

Currently packet patterns and it's enum/structures are used only
for WoWLAN feature. As we intend to reuse them for new feature
packet coalesce, they are renamed in this patch.

Older names are kept for backward compatibility purpose.
Signed-off-by: default avatarAmitkumar Karwar <akarwar@marvell.com>
Signed-off-by: default avatarBing Zhao <bzhao@marvell.com>
Signed-off-by: default avatarJohannes Berg <johannes@sipsolutions.net>
parent ad81f054
...@@ -2094,7 +2094,7 @@ static void ath9k_wow_add_pattern(struct ath_softc *sc, ...@@ -2094,7 +2094,7 @@ static void ath9k_wow_add_pattern(struct ath_softc *sc,
{ {
struct ath_hw *ah = sc->sc_ah; struct ath_hw *ah = sc->sc_ah;
struct ath9k_wow_pattern *wow_pattern = NULL; struct ath9k_wow_pattern *wow_pattern = NULL;
struct cfg80211_wowlan_trig_pkt_pattern *patterns = wowlan->patterns; struct cfg80211_pkt_pattern *patterns = wowlan->patterns;
int mask_len; int mask_len;
s8 i = 0; s8 i = 0;
......
...@@ -2298,8 +2298,7 @@ EXPORT_SYMBOL_GPL(mwifiex_del_virtual_intf); ...@@ -2298,8 +2298,7 @@ EXPORT_SYMBOL_GPL(mwifiex_del_virtual_intf);
#ifdef CONFIG_PM #ifdef CONFIG_PM
static bool static bool
mwifiex_is_pattern_supported(struct cfg80211_wowlan_trig_pkt_pattern *pat, mwifiex_is_pattern_supported(struct cfg80211_pkt_pattern *pat, s8 *byte_seq)
s8 *byte_seq)
{ {
int j, k, valid_byte_cnt = 0; int j, k, valid_byte_cnt = 0;
bool dont_care_byte = false; bool dont_care_byte = false;
......
...@@ -1315,7 +1315,7 @@ static struct sk_buff *wl12xx_alloc_dummy_packet(struct wl1271 *wl) ...@@ -1315,7 +1315,7 @@ static struct sk_buff *wl12xx_alloc_dummy_packet(struct wl1271 *wl)
#ifdef CONFIG_PM #ifdef CONFIG_PM
static int static int
wl1271_validate_wowlan_pattern(struct cfg80211_wowlan_trig_pkt_pattern *p) wl1271_validate_wowlan_pattern(struct cfg80211_pkt_pattern *p)
{ {
int num_fields = 0, in_field = 0, fields_size = 0; int num_fields = 0, in_field = 0, fields_size = 0;
int i, pattern_len = 0; int i, pattern_len = 0;
...@@ -1458,9 +1458,9 @@ void wl1271_rx_filter_flatten_fields(struct wl12xx_rx_filter *filter, ...@@ -1458,9 +1458,9 @@ void wl1271_rx_filter_flatten_fields(struct wl12xx_rx_filter *filter,
* Allocates an RX filter returned through f * Allocates an RX filter returned through f
* which needs to be freed using rx_filter_free() * which needs to be freed using rx_filter_free()
*/ */
static int wl1271_convert_wowlan_pattern_to_rx_filter( static int
struct cfg80211_wowlan_trig_pkt_pattern *p, wl1271_convert_wowlan_pattern_to_rx_filter(struct cfg80211_pkt_pattern *p,
struct wl12xx_rx_filter **f) struct wl12xx_rx_filter **f)
{ {
int i, j, ret = 0; int i, j, ret = 0;
struct wl12xx_rx_filter *filter; struct wl12xx_rx_filter *filter;
...@@ -1562,7 +1562,7 @@ static int wl1271_configure_wowlan(struct wl1271 *wl, ...@@ -1562,7 +1562,7 @@ static int wl1271_configure_wowlan(struct wl1271 *wl,
/* Translate WoWLAN patterns into filters */ /* Translate WoWLAN patterns into filters */
for (i = 0; i < wow->n_patterns; i++) { for (i = 0; i < wow->n_patterns; i++) {
struct cfg80211_wowlan_trig_pkt_pattern *p; struct cfg80211_pkt_pattern *p;
struct wl12xx_rx_filter *filter = NULL; struct wl12xx_rx_filter *filter = NULL;
p = &wow->patterns[i]; p = &wow->patterns[i];
......
...@@ -1698,7 +1698,7 @@ struct cfg80211_pmksa { ...@@ -1698,7 +1698,7 @@ struct cfg80211_pmksa {
}; };
/** /**
* struct cfg80211_wowlan_trig_pkt_pattern - packet pattern * struct cfg80211_pkt_pattern - packet pattern
* @mask: bitmask where to match pattern and where to ignore bytes, * @mask: bitmask where to match pattern and where to ignore bytes,
* one bit per byte, in same format as nl80211 * one bit per byte, in same format as nl80211
* @pattern: bytes to match where bitmask is 1 * @pattern: bytes to match where bitmask is 1
...@@ -1708,7 +1708,7 @@ struct cfg80211_pmksa { ...@@ -1708,7 +1708,7 @@ struct cfg80211_pmksa {
* Internal note: @mask and @pattern are allocated in one chunk of * Internal note: @mask and @pattern are allocated in one chunk of
* memory, free @mask only! * memory, free @mask only!
*/ */
struct cfg80211_wowlan_trig_pkt_pattern { struct cfg80211_pkt_pattern {
u8 *mask, *pattern; u8 *mask, *pattern;
int pattern_len; int pattern_len;
int pkt_offset; int pkt_offset;
...@@ -1770,7 +1770,7 @@ struct cfg80211_wowlan { ...@@ -1770,7 +1770,7 @@ struct cfg80211_wowlan {
bool any, disconnect, magic_pkt, gtk_rekey_failure, bool any, disconnect, magic_pkt, gtk_rekey_failure,
eap_identity_req, four_way_handshake, eap_identity_req, four_way_handshake,
rfkill_release; rfkill_release;
struct cfg80211_wowlan_trig_pkt_pattern *patterns; struct cfg80211_pkt_pattern *patterns;
struct cfg80211_wowlan_tcp *tcp; struct cfg80211_wowlan_tcp *tcp;
int n_patterns; int n_patterns;
}; };
......
...@@ -3060,11 +3060,11 @@ enum nl80211_tx_power_setting { ...@@ -3060,11 +3060,11 @@ enum nl80211_tx_power_setting {
}; };
/** /**
* enum nl80211_wowlan_packet_pattern_attr - WoWLAN packet pattern attribute * enum nl80211_packet_pattern_attr - packet pattern attribute
* @__NL80211_WOWLAN_PKTPAT_INVALID: invalid number for nested attribute * @__NL80211_PKTPAT_INVALID: invalid number for nested attribute
* @NL80211_WOWLAN_PKTPAT_PATTERN: the pattern, values where the mask has * @NL80211_PKTPAT_PATTERN: the pattern, values where the mask has
* a zero bit are ignored * a zero bit are ignored
* @NL80211_WOWLAN_PKTPAT_MASK: pattern mask, must be long enough to have * @NL80211_PKTPAT_MASK: pattern mask, must be long enough to have
* a bit for each byte in the pattern. The lowest-order bit corresponds * a bit for each byte in the pattern. The lowest-order bit corresponds
* to the first byte of the pattern, but the bytes of the pattern are * to the first byte of the pattern, but the bytes of the pattern are
* in a little-endian-like format, i.e. the 9th byte of the pattern * in a little-endian-like format, i.e. the 9th byte of the pattern
...@@ -3075,23 +3075,23 @@ enum nl80211_tx_power_setting { ...@@ -3075,23 +3075,23 @@ enum nl80211_tx_power_setting {
* Note that the pattern matching is done as though frames were not * Note that the pattern matching is done as though frames were not
* 802.11 frames but 802.3 frames, i.e. the frame is fully unpacked * 802.11 frames but 802.3 frames, i.e. the frame is fully unpacked
* first (including SNAP header unpacking) and then matched. * first (including SNAP header unpacking) and then matched.
* @NL80211_WOWLAN_PKTPAT_OFFSET: packet offset, pattern is matched after * @NL80211_PKTPAT_OFFSET: packet offset, pattern is matched after
* these fixed number of bytes of received packet * these fixed number of bytes of received packet
* @NUM_NL80211_WOWLAN_PKTPAT: number of attributes * @NUM_NL80211_PKTPAT: number of attributes
* @MAX_NL80211_WOWLAN_PKTPAT: max attribute number * @MAX_NL80211_PKTPAT: max attribute number
*/ */
enum nl80211_wowlan_packet_pattern_attr { enum nl80211_packet_pattern_attr {
__NL80211_WOWLAN_PKTPAT_INVALID, __NL80211_PKTPAT_INVALID,
NL80211_WOWLAN_PKTPAT_MASK, NL80211_PKTPAT_MASK,
NL80211_WOWLAN_PKTPAT_PATTERN, NL80211_PKTPAT_PATTERN,
NL80211_WOWLAN_PKTPAT_OFFSET, NL80211_PKTPAT_OFFSET,
NUM_NL80211_WOWLAN_PKTPAT, NUM_NL80211_PKTPAT,
MAX_NL80211_WOWLAN_PKTPAT = NUM_NL80211_WOWLAN_PKTPAT - 1, MAX_NL80211_PKTPAT = NUM_NL80211_PKTPAT - 1,
}; };
/** /**
* struct nl80211_wowlan_pattern_support - pattern support information * struct nl80211_pattern_support - packet pattern support information
* @max_patterns: maximum number of patterns supported * @max_patterns: maximum number of patterns supported
* @min_pattern_len: minimum length of each pattern * @min_pattern_len: minimum length of each pattern
* @max_pattern_len: maximum length of each pattern * @max_pattern_len: maximum length of each pattern
...@@ -3101,13 +3101,22 @@ enum nl80211_wowlan_packet_pattern_attr { ...@@ -3101,13 +3101,22 @@ enum nl80211_wowlan_packet_pattern_attr {
* that is part of %NL80211_ATTR_WOWLAN_TRIGGERS_SUPPORTED in the * that is part of %NL80211_ATTR_WOWLAN_TRIGGERS_SUPPORTED in the
* capability information given by the kernel to userspace. * capability information given by the kernel to userspace.
*/ */
struct nl80211_wowlan_pattern_support { struct nl80211_pattern_support {
__u32 max_patterns; __u32 max_patterns;
__u32 min_pattern_len; __u32 min_pattern_len;
__u32 max_pattern_len; __u32 max_pattern_len;
__u32 max_pkt_offset; __u32 max_pkt_offset;
} __attribute__((packed)); } __attribute__((packed));
/* only for backward compatibility */
#define __NL80211_WOWLAN_PKTPAT_INVALID __NL80211_PKTPAT_INVALID
#define NL80211_WOWLAN_PKTPAT_MASK NL80211_PKTPAT_MASK
#define NL80211_WOWLAN_PKTPAT_PATTERN NL80211_PKTPAT_PATTERN
#define NL80211_WOWLAN_PKTPAT_OFFSET NL80211_PKTPAT_OFFSET
#define NUM_NL80211_WOWLAN_PKTPAT NUM_NL80211_PKTPAT
#define MAX_NL80211_WOWLAN_PKTPAT MAX_NL80211_PKTPAT
#define nl80211_wowlan_pattern_support nl80211_pattern_support
/** /**
* enum nl80211_wowlan_triggers - WoWLAN trigger definitions * enum nl80211_wowlan_triggers - WoWLAN trigger definitions
* @__NL80211_WOWLAN_TRIG_INVALID: invalid number for nested attributes * @__NL80211_WOWLAN_TRIG_INVALID: invalid number for nested attributes
...@@ -3127,7 +3136,7 @@ struct nl80211_wowlan_pattern_support { ...@@ -3127,7 +3136,7 @@ struct nl80211_wowlan_pattern_support {
* pattern matching is done after the packet is converted to the MSDU. * pattern matching is done after the packet is converted to the MSDU.
* *
* In %NL80211_ATTR_WOWLAN_TRIGGERS_SUPPORTED, it is a binary attribute * In %NL80211_ATTR_WOWLAN_TRIGGERS_SUPPORTED, it is a binary attribute
* carrying a &struct nl80211_wowlan_pattern_support. * carrying a &struct nl80211_pattern_support.
* *
* When reporting wakeup. it is a u32 attribute containing the 0-based * When reporting wakeup. it is a u32 attribute containing the 0-based
* index of the pattern that caused the wakeup, in the patterns passed * index of the pattern that caused the wakeup, in the patterns passed
...@@ -3284,7 +3293,7 @@ struct nl80211_wowlan_tcp_data_token_feature { ...@@ -3284,7 +3293,7 @@ struct nl80211_wowlan_tcp_data_token_feature {
* @NL80211_WOWLAN_TCP_WAKE_PAYLOAD: wake packet payload, for advertising a * @NL80211_WOWLAN_TCP_WAKE_PAYLOAD: wake packet payload, for advertising a
* u32 attribute holding the maximum length * u32 attribute holding the maximum length
* @NL80211_WOWLAN_TCP_WAKE_MASK: Wake packet payload mask, not used for * @NL80211_WOWLAN_TCP_WAKE_MASK: Wake packet payload mask, not used for
* feature advertising. The mask works like @NL80211_WOWLAN_PKTPAT_MASK * feature advertising. The mask works like @NL80211_PKTPAT_MASK
* but on the TCP payload only. * but on the TCP payload only.
* @NUM_NL80211_WOWLAN_TCP: number of TCP attributes * @NUM_NL80211_WOWLAN_TCP: number of TCP attributes
* @MAX_NL80211_WOWLAN_TCP: highest attribute number * @MAX_NL80211_WOWLAN_TCP: highest attribute number
......
...@@ -974,7 +974,7 @@ static int nl80211_send_wowlan(struct sk_buff *msg, ...@@ -974,7 +974,7 @@ static int nl80211_send_wowlan(struct sk_buff *msg,
return -ENOBUFS; return -ENOBUFS;
if (dev->wiphy.wowlan->n_patterns) { if (dev->wiphy.wowlan->n_patterns) {
struct nl80211_wowlan_pattern_support pat = { struct nl80211_pattern_support pat = {
.max_patterns = dev->wiphy.wowlan->n_patterns, .max_patterns = dev->wiphy.wowlan->n_patterns,
.min_pattern_len = dev->wiphy.wowlan->pattern_min_len, .min_pattern_len = dev->wiphy.wowlan->pattern_min_len,
.max_pattern_len = dev->wiphy.wowlan->pattern_max_len, .max_pattern_len = dev->wiphy.wowlan->pattern_max_len,
...@@ -7591,12 +7591,11 @@ static int nl80211_send_wowlan_patterns(struct sk_buff *msg, ...@@ -7591,12 +7591,11 @@ static int nl80211_send_wowlan_patterns(struct sk_buff *msg,
if (!nl_pat) if (!nl_pat)
return -ENOBUFS; return -ENOBUFS;
pat_len = wowlan->patterns[i].pattern_len; pat_len = wowlan->patterns[i].pattern_len;
if (nla_put(msg, NL80211_WOWLAN_PKTPAT_MASK, if (nla_put(msg, NL80211_PKTPAT_MASK, DIV_ROUND_UP(pat_len, 8),
DIV_ROUND_UP(pat_len, 8),
wowlan->patterns[i].mask) || wowlan->patterns[i].mask) ||
nla_put(msg, NL80211_WOWLAN_PKTPAT_PATTERN, nla_put(msg, NL80211_PKTPAT_PATTERN, pat_len,
pat_len, wowlan->patterns[i].pattern) || wowlan->patterns[i].pattern) ||
nla_put_u32(msg, NL80211_WOWLAN_PKTPAT_OFFSET, nla_put_u32(msg, NL80211_PKTPAT_OFFSET,
wowlan->patterns[i].pkt_offset)) wowlan->patterns[i].pkt_offset))
return -ENOBUFS; return -ENOBUFS;
nla_nest_end(msg, nl_pat); nla_nest_end(msg, nl_pat);
...@@ -7937,7 +7936,7 @@ static int nl80211_set_wowlan(struct sk_buff *skb, struct genl_info *info) ...@@ -7937,7 +7936,7 @@ static int nl80211_set_wowlan(struct sk_buff *skb, struct genl_info *info)
struct nlattr *pat; struct nlattr *pat;
int n_patterns = 0; int n_patterns = 0;
int rem, pat_len, mask_len, pkt_offset; int rem, pat_len, mask_len, pkt_offset;
struct nlattr *pat_tb[NUM_NL80211_WOWLAN_PKTPAT]; struct nlattr *pat_tb[NUM_NL80211_PKTPAT];
nla_for_each_nested(pat, tb[NL80211_WOWLAN_TRIG_PKT_PATTERN], nla_for_each_nested(pat, tb[NL80211_WOWLAN_TRIG_PKT_PATTERN],
rem) rem)
...@@ -7956,26 +7955,25 @@ static int nl80211_set_wowlan(struct sk_buff *skb, struct genl_info *info) ...@@ -7956,26 +7955,25 @@ static int nl80211_set_wowlan(struct sk_buff *skb, struct genl_info *info)
nla_for_each_nested(pat, tb[NL80211_WOWLAN_TRIG_PKT_PATTERN], nla_for_each_nested(pat, tb[NL80211_WOWLAN_TRIG_PKT_PATTERN],
rem) { rem) {
nla_parse(pat_tb, MAX_NL80211_WOWLAN_PKTPAT, nla_parse(pat_tb, MAX_NL80211_PKTPAT, nla_data(pat),
nla_data(pat), nla_len(pat), NULL); nla_len(pat), NULL);
err = -EINVAL; err = -EINVAL;
if (!pat_tb[NL80211_WOWLAN_PKTPAT_MASK] || if (!pat_tb[NL80211_PKTPAT_MASK] ||
!pat_tb[NL80211_WOWLAN_PKTPAT_PATTERN]) !pat_tb[NL80211_PKTPAT_PATTERN])
goto error; goto error;
pat_len = nla_len(pat_tb[NL80211_WOWLAN_PKTPAT_PATTERN]); pat_len = nla_len(pat_tb[NL80211_PKTPAT_PATTERN]);
mask_len = DIV_ROUND_UP(pat_len, 8); mask_len = DIV_ROUND_UP(pat_len, 8);
if (nla_len(pat_tb[NL80211_WOWLAN_PKTPAT_MASK]) != if (nla_len(pat_tb[NL80211_PKTPAT_MASK]) != mask_len)
mask_len)
goto error; goto error;
if (pat_len > wowlan->pattern_max_len || if (pat_len > wowlan->pattern_max_len ||
pat_len < wowlan->pattern_min_len) pat_len < wowlan->pattern_min_len)
goto error; goto error;
if (!pat_tb[NL80211_WOWLAN_PKTPAT_OFFSET]) if (!pat_tb[NL80211_PKTPAT_OFFSET])
pkt_offset = 0; pkt_offset = 0;
else else
pkt_offset = nla_get_u32( pkt_offset = nla_get_u32(
pat_tb[NL80211_WOWLAN_PKTPAT_OFFSET]); pat_tb[NL80211_PKTPAT_OFFSET]);
if (pkt_offset > wowlan->max_pkt_offset) if (pkt_offset > wowlan->max_pkt_offset)
goto error; goto error;
new_triggers.patterns[i].pkt_offset = pkt_offset; new_triggers.patterns[i].pkt_offset = pkt_offset;
...@@ -7989,11 +7987,11 @@ static int nl80211_set_wowlan(struct sk_buff *skb, struct genl_info *info) ...@@ -7989,11 +7987,11 @@ static int nl80211_set_wowlan(struct sk_buff *skb, struct genl_info *info)
new_triggers.patterns[i].pattern = new_triggers.patterns[i].pattern =
new_triggers.patterns[i].mask + mask_len; new_triggers.patterns[i].mask + mask_len;
memcpy(new_triggers.patterns[i].mask, memcpy(new_triggers.patterns[i].mask,
nla_data(pat_tb[NL80211_WOWLAN_PKTPAT_MASK]), nla_data(pat_tb[NL80211_PKTPAT_MASK]),
mask_len); mask_len);
new_triggers.patterns[i].pattern_len = pat_len; new_triggers.patterns[i].pattern_len = pat_len;
memcpy(new_triggers.patterns[i].pattern, memcpy(new_triggers.patterns[i].pattern,
nla_data(pat_tb[NL80211_WOWLAN_PKTPAT_PATTERN]), nla_data(pat_tb[NL80211_PKTPAT_PATTERN]),
pat_len); pat_len);
i++; i++;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment