提交 951fd874 编写于 作者: J Joe Perches 提交者: David S. Miller

llc: Use normal etherdevice.h tests

Convert the llc_<foo> static inlines to the
equivalents from etherdevice.h and remove
the llc_<foo> static inline functions.

llc_mac_null -> is_zero_ether_addr
llc_mac_multicast -> is_multicast_ether_addr
llc_mac_match -> ether_addr_equal
Signed-off-by: NJoe Perches <joe@perches.com>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 7367d0b5
...@@ -62,36 +62,6 @@ ...@@ -62,36 +62,6 @@
#define LLC_STATUS_CONFLICT 7 /* disconnect conn */ #define LLC_STATUS_CONFLICT 7 /* disconnect conn */
#define LLC_STATUS_RESET_DONE 8 /* */ #define LLC_STATUS_RESET_DONE 8 /* */
/**
* llc_mac_null - determines if a address is a null mac address
* @mac: Mac address to test if null.
*
* Determines if a given address is a null mac address. Returns 0 if the
* address is not a null mac, 1 if the address is a null mac.
*/
static inline int llc_mac_null(const u8 *mac)
{
return is_zero_ether_addr(mac);
}
static inline int llc_mac_multicast(const u8 *mac)
{
return is_multicast_ether_addr(mac);
}
/**
* llc_mac_match - determines if two mac addresses are the same
* @mac1: First mac address to compare.
* @mac2: Second mac address to compare.
*
* Determines if two given mac address are the same. Returns 0 if there
* is not a complete match up to len, 1 if a complete match up to len is
* found.
*/
static inline int llc_mac_match(const u8 *mac1, const u8 *mac2)
{
return !compare_ether_addr(mac1, mac2);
}
extern int llc_establish_connection(struct sock *sk, u8 *lmac, extern int llc_establish_connection(struct sock *sk, u8 *lmac,
u8 *dmac, u8 dsap); u8 *dmac, u8 dsap);
extern int llc_build_and_send_pkt(struct sock *sk, struct sk_buff *skb); extern int llc_build_and_send_pkt(struct sock *sk, struct sk_buff *skb);
......
...@@ -321,12 +321,12 @@ static int llc_ui_bind(struct socket *sock, struct sockaddr *uaddr, int addrlen) ...@@ -321,12 +321,12 @@ static int llc_ui_bind(struct socket *sock, struct sockaddr *uaddr, int addrlen)
if (llc->dev) { if (llc->dev) {
if (!addr->sllc_arphrd) if (!addr->sllc_arphrd)
addr->sllc_arphrd = llc->dev->type; addr->sllc_arphrd = llc->dev->type;
if (llc_mac_null(addr->sllc_mac)) if (is_zero_ether_addr(addr->sllc_mac))
memcpy(addr->sllc_mac, llc->dev->dev_addr, memcpy(addr->sllc_mac, llc->dev->dev_addr,
IFHWADDRLEN); IFHWADDRLEN);
if (addr->sllc_arphrd != llc->dev->type || if (addr->sllc_arphrd != llc->dev->type ||
!llc_mac_match(addr->sllc_mac, !ether_addr_equal(addr->sllc_mac,
llc->dev->dev_addr)) { llc->dev->dev_addr)) {
rc = -EINVAL; rc = -EINVAL;
llc->dev = NULL; llc->dev = NULL;
} }
......
...@@ -478,8 +478,8 @@ static inline bool llc_estab_match(const struct llc_sap *sap, ...@@ -478,8 +478,8 @@ static inline bool llc_estab_match(const struct llc_sap *sap,
return llc->laddr.lsap == laddr->lsap && return llc->laddr.lsap == laddr->lsap &&
llc->daddr.lsap == daddr->lsap && llc->daddr.lsap == daddr->lsap &&
llc_mac_match(llc->laddr.mac, laddr->mac) && ether_addr_equal(llc->laddr.mac, laddr->mac) &&
llc_mac_match(llc->daddr.mac, daddr->mac); ether_addr_equal(llc->daddr.mac, daddr->mac);
} }
/** /**
...@@ -550,7 +550,7 @@ static inline bool llc_listener_match(const struct llc_sap *sap, ...@@ -550,7 +550,7 @@ static inline bool llc_listener_match(const struct llc_sap *sap,
return sk->sk_type == SOCK_STREAM && sk->sk_state == TCP_LISTEN && return sk->sk_type == SOCK_STREAM && sk->sk_state == TCP_LISTEN &&
llc->laddr.lsap == laddr->lsap && llc->laddr.lsap == laddr->lsap &&
llc_mac_match(llc->laddr.mac, laddr->mac); ether_addr_equal(llc->laddr.mac, laddr->mac);
} }
static struct sock *__llc_lookup_listener(struct llc_sap *sap, static struct sock *__llc_lookup_listener(struct llc_sap *sap,
......
...@@ -302,7 +302,7 @@ static inline bool llc_dgram_match(const struct llc_sap *sap, ...@@ -302,7 +302,7 @@ static inline bool llc_dgram_match(const struct llc_sap *sap,
return sk->sk_type == SOCK_DGRAM && return sk->sk_type == SOCK_DGRAM &&
llc->laddr.lsap == laddr->lsap && llc->laddr.lsap == laddr->lsap &&
llc_mac_match(llc->laddr.mac, laddr->mac); ether_addr_equal(llc->laddr.mac, laddr->mac);
} }
/** /**
...@@ -425,7 +425,7 @@ void llc_sap_handler(struct llc_sap *sap, struct sk_buff *skb) ...@@ -425,7 +425,7 @@ void llc_sap_handler(struct llc_sap *sap, struct sk_buff *skb)
llc_pdu_decode_da(skb, laddr.mac); llc_pdu_decode_da(skb, laddr.mac);
llc_pdu_decode_dsap(skb, &laddr.lsap); llc_pdu_decode_dsap(skb, &laddr.lsap);
if (llc_mac_multicast(laddr.mac)) { if (is_multicast_ether_addr(laddr.mac)) {
llc_sap_mcast(sap, &laddr, skb); llc_sap_mcast(sap, &laddr, skb);
kfree_skb(skb); kfree_skb(skb);
} else { } else {
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册