提交 ba07d0cb 编写于 作者: A Andy Shevchenko 提交者: Greg Kroah-Hartman

staging: brcm80211: remove useless bcm_ether_ntoa()

Since we have '%pM' modifier in the kernel's *printf() we don't need to
convert address to the string beforehand.
Signed-off-by: NAndy Shevchenko <andy.shevchenko@gmail.com>
Cc: Nohee Ko <noheek@broadcom.com>
Cc: Greg Kroah-Hartman <gregkh@suse.de>
Cc: linux-wireless@vger.kernel.org
Cc: devel@driverdev.osuosl.org
Signed-off-by: NGreg Kroah-Hartman <gregkh@suse.de>
上级 88b3eaa4
...@@ -143,8 +143,6 @@ void dhd_common_init(void) ...@@ -143,8 +143,6 @@ void dhd_common_init(void)
static int dhd_dump(dhd_pub_t *dhdp, char *buf, int buflen) static int dhd_dump(dhd_pub_t *dhdp, char *buf, int buflen)
{ {
char eabuf[ETHER_ADDR_STR_LEN];
struct bcmstrbuf b; struct bcmstrbuf b;
struct bcmstrbuf *strbuf = &b; struct bcmstrbuf *strbuf = &b;
...@@ -157,9 +155,8 @@ static int dhd_dump(dhd_pub_t *dhdp, char *buf, int buflen) ...@@ -157,9 +155,8 @@ static int dhd_dump(dhd_pub_t *dhdp, char *buf, int buflen)
dhdp->up, dhdp->txoff, dhdp->busstate); dhdp->up, dhdp->txoff, dhdp->busstate);
bcm_bprintf(strbuf, "pub.hdrlen %d pub.maxctl %d pub.rxsz %d\n", bcm_bprintf(strbuf, "pub.hdrlen %d pub.maxctl %d pub.rxsz %d\n",
dhdp->hdrlen, dhdp->maxctl, dhdp->rxsz); dhdp->hdrlen, dhdp->maxctl, dhdp->rxsz);
bcm_bprintf(strbuf, "pub.iswl %d pub.drv_version %ld pub.mac %s\n", bcm_bprintf(strbuf, "pub.iswl %d pub.drv_version %ld pub.mac %pM\n",
dhdp->iswl, dhdp->drv_version, bcm_ether_ntoa(&dhdp->mac, dhdp->iswl, dhdp->drv_version, &dhdp->mac);
eabuf));
bcm_bprintf(strbuf, "pub.bcmerror %d tickcnt %d\n", dhdp->bcmerror, bcm_bprintf(strbuf, "pub.bcmerror %d tickcnt %d\n", dhdp->bcmerror,
dhdp->tickcnt); dhdp->tickcnt);
...@@ -600,13 +597,7 @@ static void wl_show_host_event(wl_event_msg_t *event, void *event_data) ...@@ -600,13 +597,7 @@ static void wl_show_host_event(wl_event_msg_t *event, void *event_data)
auth_type = ntoh32(event->auth_type); auth_type = ntoh32(event->auth_type);
datalen = ntoh32(event->datalen); datalen = ntoh32(event->datalen);
/* debug dump of event messages */ /* debug dump of event messages */
sprintf(eabuf, "%02x:%02x:%02x:%02x:%02x:%02x", sprintf(eabuf, "%pM", event->addr.octet);
(unsigned char) event->addr.octet[0] & 0xff,
(unsigned char) event->addr.octet[1] & 0xff,
(unsigned char) event->addr.octet[2] & 0xff,
(unsigned char) event->addr.octet[3] & 0xff,
(unsigned char) event->addr.octet[4] & 0xff,
(unsigned char) event->addr.octet[5] & 0xff);
event_name = "UNKNOWN"; event_name = "UNKNOWN";
for (i = 0; i < ARRAY_SIZE(event_names); i++) { for (i = 0; i < ARRAY_SIZE(event_names); i++) {
......
...@@ -2006,16 +2006,12 @@ static __used s32 ...@@ -2006,16 +2006,12 @@ static __used s32
wl_update_pmklist(struct net_device *dev, struct wl_pmk_list *pmk_list, wl_update_pmklist(struct net_device *dev, struct wl_pmk_list *pmk_list,
s32 err) s32 err)
{ {
s8 eabuf[ETHER_ADDR_STR_LEN];
int i, j; int i, j;
memset(eabuf, 0, ETHER_ADDR_STR_LEN);
WL_DBG(("No of elements %d\n", pmk_list->pmkids.npmkid)); WL_DBG(("No of elements %d\n", pmk_list->pmkids.npmkid));
for (i = 0; i < pmk_list->pmkids.npmkid; i++) { for (i = 0; i < pmk_list->pmkids.npmkid; i++) {
WL_DBG(("PMKID[%d]: %s =\n", i, WL_DBG(("PMKID[%d]: %pM =\n", i,
bcm_ether_ntoa(&pmk_list->pmkids.pmkid[i].BSSID, &pmk_list->pmkids.pmkid[i].BSSID));
eabuf)));
for (j = 0; j < WPA2_PMKID_LEN; j++) { for (j = 0; j < WPA2_PMKID_LEN; j++) {
WL_DBG(("%02x\n", pmk_list->pmkids.pmkid[i].PMKID[j])); WL_DBG(("%02x\n", pmk_list->pmkids.pmkid[i].PMKID[j]));
} }
...@@ -2033,12 +2029,10 @@ wl_cfg80211_set_pmksa(struct wiphy *wiphy, struct net_device *dev, ...@@ -2033,12 +2029,10 @@ wl_cfg80211_set_pmksa(struct wiphy *wiphy, struct net_device *dev,
struct cfg80211_pmksa *pmksa) struct cfg80211_pmksa *pmksa)
{ {
struct wl_priv *wl = wiphy_to_wl(wiphy); struct wl_priv *wl = wiphy_to_wl(wiphy);
s8 eabuf[ETHER_ADDR_STR_LEN];
s32 err = 0; s32 err = 0;
int i; int i;
CHECK_SYS_UP(); CHECK_SYS_UP();
memset(eabuf, 0, ETHER_ADDR_STR_LEN);
for (i = 0; i < wl->pmk_list->pmkids.npmkid; i++) for (i = 0; i < wl->pmk_list->pmkids.npmkid; i++)
if (!memcmp(pmksa->bssid, &wl->pmk_list->pmkids.pmkid[i].BSSID, if (!memcmp(pmksa->bssid, &wl->pmk_list->pmkids.pmkid[i].BSSID,
ETHER_ADDR_LEN)) ETHER_ADDR_LEN))
...@@ -2053,10 +2047,8 @@ wl_cfg80211_set_pmksa(struct wiphy *wiphy, struct net_device *dev, ...@@ -2053,10 +2047,8 @@ wl_cfg80211_set_pmksa(struct wiphy *wiphy, struct net_device *dev,
} else { } else {
err = -EINVAL; err = -EINVAL;
} }
WL_DBG(("set_pmksa,IW_PMKSA_ADD - PMKID: %s =\n", WL_DBG(("set_pmksa,IW_PMKSA_ADD - PMKID: %pM =\n",
bcm_ether_ntoa(&wl->pmk_list->pmkids. &wl->pmk_list->pmkids.pmkid[wl->pmk_list->pmkids.npmkid].BSSID));
pmkid[wl->pmk_list->pmkids.npmkid].BSSID,
eabuf)));
for (i = 0; i < WPA2_PMKID_LEN; i++) { for (i = 0; i < WPA2_PMKID_LEN; i++) {
WL_DBG(("%02x\n", WL_DBG(("%02x\n",
wl->pmk_list->pmkids.pmkid[wl->pmk_list->pmkids.npmkid]. wl->pmk_list->pmkids.pmkid[wl->pmk_list->pmkids.npmkid].
...@@ -2073,18 +2065,16 @@ wl_cfg80211_del_pmksa(struct wiphy *wiphy, struct net_device *dev, ...@@ -2073,18 +2065,16 @@ wl_cfg80211_del_pmksa(struct wiphy *wiphy, struct net_device *dev,
struct cfg80211_pmksa *pmksa) struct cfg80211_pmksa *pmksa)
{ {
struct wl_priv *wl = wiphy_to_wl(wiphy); struct wl_priv *wl = wiphy_to_wl(wiphy);
s8 eabuf[ETHER_ADDR_STR_LEN];
struct _pmkid_list pmkid; struct _pmkid_list pmkid;
s32 err = 0; s32 err = 0;
int i; int i;
CHECK_SYS_UP(); CHECK_SYS_UP();
memset(eabuf, 0, ETHER_ADDR_STR_LEN);
memcpy(&pmkid.pmkid[0].BSSID, pmksa->bssid, ETHER_ADDR_LEN); memcpy(&pmkid.pmkid[0].BSSID, pmksa->bssid, ETHER_ADDR_LEN);
memcpy(&pmkid.pmkid[0].PMKID, pmksa->pmkid, WPA2_PMKID_LEN); memcpy(&pmkid.pmkid[0].PMKID, pmksa->pmkid, WPA2_PMKID_LEN);
WL_DBG(("del_pmksa,IW_PMKSA_REMOVE - PMKID: %s =\n", WL_DBG(("del_pmksa,IW_PMKSA_REMOVE - PMKID: %pM =\n",
bcm_ether_ntoa(&pmkid.pmkid[0].BSSID, eabuf))); &pmkid.pmkid[0].BSSID));
for (i = 0; i < WPA2_PMKID_LEN; i++) { for (i = 0; i < WPA2_PMKID_LEN; i++) {
WL_DBG(("%02x\n", pmkid.pmkid[0].PMKID[i])); WL_DBG(("%02x\n", pmkid.pmkid[0].PMKID[i]));
} }
...@@ -2585,10 +2575,7 @@ static s32 wl_update_bss_info(struct wl_priv *wl) ...@@ -2585,10 +2575,7 @@ static s32 wl_update_bss_info(struct wl_priv *wl)
if (unlikely(err)) if (unlikely(err))
goto update_bss_info_out; goto update_bss_info_out;
} else { } else {
WL_DBG(("Found the AP in the list - " WL_DBG(("Found the AP in the list - BSSID %pM\n", bss->bssid));
"BSSID %02x:%02x:%02x:%02x:%02x:%02x\n",
bss->bssid[0], bss->bssid[1], bss->bssid[2],
bss->bssid[3], bss->bssid[4], bss->bssid[5]));
cfg80211_put_bss(bss); cfg80211_put_bss(bss);
} }
......
...@@ -800,9 +800,8 @@ wl_iw_set_wap(struct net_device *dev, ...@@ -800,9 +800,8 @@ wl_iw_set_wap(struct net_device *dev,
} }
if (g_ssid.SSID_len) { if (g_ssid.SSID_len) {
WL_TRACE(("%s: join SSID=%s BSSID=" MACSTR " ch=%d\n", WL_TRACE(("%s: join SSID=%s BSSID=%pM ch=%d\n",
__func__, g_ssid.SSID, __func__, g_ssid.SSID, awrq->sa_data,
MAC2STR((u8 *) awrq->sa_data),
g_wl_iw_params.target_channel)); g_wl_iw_params.target_channel));
} }
...@@ -2638,14 +2637,12 @@ wl_iw_set_pmksa(struct net_device *dev, ...@@ -2638,14 +2637,12 @@ wl_iw_set_pmksa(struct net_device *dev,
struct iw_pmksa *iwpmksa; struct iw_pmksa *iwpmksa;
uint i; uint i;
int ret = 0; int ret = 0;
char eabuf[ETHER_ADDR_STR_LEN];
WL_WSEC(("%s: SIOCSIWPMKSA\n", dev->name)); WL_WSEC(("%s: SIOCSIWPMKSA\n", dev->name));
CHECK_EXTRA_FOR_NULL(extra); CHECK_EXTRA_FOR_NULL(extra);
iwpmksa = (struct iw_pmksa *)extra; iwpmksa = (struct iw_pmksa *)extra;
bzero((char *)eabuf, ETHER_ADDR_STR_LEN);
if (iwpmksa->cmd == IW_PMKSA_FLUSH) { if (iwpmksa->cmd == IW_PMKSA_FLUSH) {
WL_WSEC(("wl_iw_set_pmksa - IW_PMKSA_FLUSH\n")); WL_WSEC(("wl_iw_set_pmksa - IW_PMKSA_FLUSH\n"));
...@@ -2663,8 +2660,8 @@ wl_iw_set_pmksa(struct net_device *dev, ...@@ -2663,8 +2660,8 @@ wl_iw_set_pmksa(struct net_device *dev,
bcopy(&iwpmksa->pmkid[0], &pmkidptr->pmkid[0].PMKID, bcopy(&iwpmksa->pmkid[0], &pmkidptr->pmkid[0].PMKID,
WPA2_PMKID_LEN); WPA2_PMKID_LEN);
WL_WSEC(("wl_iw_set_pmksa:IW_PMKSA_REMOVE:PMKID: %s = ", WL_WSEC(("wl_iw_set_pmksa:IW_PMKSA_REMOVE:PMKID: "
bcm_ether_ntoa(&pmkidptr->pmkid[0].BSSID, eabuf))); "%pM = ", &pmkidptr->pmkid[0].BSSID));
for (j = 0; j < WPA2_PMKID_LEN; j++) for (j = 0; j < WPA2_PMKID_LEN; j++)
WL_WSEC(("%02x ", pmkidptr->pmkid[0].PMKID[j])); WL_WSEC(("%02x ", pmkidptr->pmkid[0].PMKID[j]));
WL_WSEC(("\n")); WL_WSEC(("\n"));
...@@ -2713,9 +2710,8 @@ wl_iw_set_pmksa(struct net_device *dev, ...@@ -2713,9 +2710,8 @@ wl_iw_set_pmksa(struct net_device *dev,
uint j; uint j;
uint k; uint k;
k = pmkid_list.pmkids.npmkid; k = pmkid_list.pmkids.npmkid;
WL_WSEC(("wl_iw_set_pmksa,IW_PMKSA_ADD - PMKID: %s = ", WL_WSEC(("wl_iw_set_pmksa,IW_PMKSA_ADD - PMKID: %pM = ",
bcm_ether_ntoa(&pmkid_list.pmkids.pmkid[k]. &pmkid_list.pmkids.pmkid[k].BSSID));
BSSID, eabuf)));
for (j = 0; j < WPA2_PMKID_LEN; j++) for (j = 0; j < WPA2_PMKID_LEN; j++)
WL_WSEC(("%02x ", WL_WSEC(("%02x ",
pmkid_list.pmkids.pmkid[k].PMKID[j])); pmkid_list.pmkids.pmkid[k].PMKID[j]));
...@@ -2726,9 +2722,8 @@ wl_iw_set_pmksa(struct net_device *dev, ...@@ -2726,9 +2722,8 @@ wl_iw_set_pmksa(struct net_device *dev,
pmkid_list.pmkids.npmkid)); pmkid_list.pmkids.npmkid));
for (i = 0; i < pmkid_list.pmkids.npmkid; i++) { for (i = 0; i < pmkid_list.pmkids.npmkid; i++) {
uint j; uint j;
WL_WSEC(("PMKID[%d]: %s = ", i, WL_WSEC(("PMKID[%d]: %pM = ", i,
bcm_ether_ntoa(&pmkid_list.pmkids.pmkid[i].BSSID, &pmkid_list.pmkids.pmkid[i].BSSID));
eabuf)));
for (j = 0; j < WPA2_PMKID_LEN; j++) for (j = 0; j < WPA2_PMKID_LEN; j++)
WL_WSEC(("%02x ", pmkid_list.pmkids.pmkid[i].PMKID[j])); WL_WSEC(("%02x ", pmkid_list.pmkids.pmkid[i].PMKID[j]));
WL_WSEC(("\n")); WL_WSEC(("\n"));
......
...@@ -42,9 +42,6 @@ ...@@ -42,9 +42,6 @@
#define PNOENABLE_SET_CMD "PNOFORCE" #define PNOENABLE_SET_CMD "PNOFORCE"
#define PNODEBUG_SET_CMD "PNODEBUG" #define PNODEBUG_SET_CMD "PNODEBUG"
#define MAC2STR(a) (a)[0], (a)[1], (a)[2], (a)[3], (a)[4], (a)[5]
#define MACSTR "%02x:%02x:%02x:%02x:%02x:%02x"
typedef struct wl_iw_extra_params { typedef struct wl_iw_extra_params {
int target_channel; int target_channel;
} wl_iw_extra_params_t; } wl_iw_extra_params_t;
......
...@@ -163,7 +163,6 @@ ...@@ -163,7 +163,6 @@
#define PKTPRIO_DSCP 0x800 /* DSCP prio found */ #define PKTPRIO_DSCP 0x800 /* DSCP prio found */
/* ethernet address */ /* ethernet address */
extern char *bcm_ether_ntoa(const struct ether_addr *ea, char *buf);
extern int bcm_ether_atoe(char *p, struct ether_addr *ea); extern int bcm_ether_atoe(char *p, struct ether_addr *ea);
/* ip address */ /* ip address */
...@@ -427,7 +426,6 @@ ...@@ -427,7 +426,6 @@
/* Check that bcm_tlv_t fits into the given buflen */ /* Check that bcm_tlv_t fits into the given buflen */
#define bcm_valid_tlv(elt, buflen) ((buflen) >= 2 && (int)(buflen) >= (int)(2 + (elt)->len)) #define bcm_valid_tlv(elt, buflen) ((buflen) >= 2 && (int)(buflen) >= (int)(2 + (elt)->len))
/* buffer length for ethernet address from bcm_ether_ntoa() */
#define ETHER_ADDR_STR_LEN 18 /* 18-bytes of Ethernet address buffer length */ #define ETHER_ADDR_STR_LEN 18 /* 18-bytes of Ethernet address buffer length */
/* crypto utility function */ /* crypto utility function */
......
...@@ -484,11 +484,8 @@ wl_ops_bss_info_changed(struct ieee80211_hw *hw, ...@@ -484,11 +484,8 @@ wl_ops_bss_info_changed(struct ieee80211_hw *hw,
/* Beacon interval changed */ /* Beacon interval changed */
} }
if (changed & BSS_CHANGED_BSSID) { if (changed & BSS_CHANGED_BSSID) {
/* char eabuf[ETHER_ADDR_STR_LEN]; */ WL_NONE(("new BSSID:\taid %d bss:%pM\n", info->aid,
WL_NONE(("new BSSID:\taid %d bss:%s\n", info->bssid));
info->aid,
bcm_ether_ntoa((struct ether_addr *)info->bssid,
eabuf)));
/* BSSID changed, for whatever reason (IBSS and managed mode) */ /* BSSID changed, for whatever reason (IBSS and managed mode) */
/* FIXME: need to store bssid in bsscfg */ /* FIXME: need to store bssid in bsscfg */
wlc_set_addrmatch(wl->wlc, RCM_BSSID_OFFSET, wlc_set_addrmatch(wl->wlc, RCM_BSSID_OFFSET,
......
...@@ -7215,9 +7215,6 @@ void BCMFASTPATH wlc_recv(wlc_info_t *wlc, void *p) ...@@ -7215,9 +7215,6 @@ void BCMFASTPATH wlc_recv(wlc_info_t *wlc, void *p)
u16 fc; u16 fc;
uint len; uint len;
bool is_amsdu; bool is_amsdu;
#ifdef BCMDBG
char eabuf[ETHER_ADDR_STR_LEN];
#endif
WL_TRACE(("wl%d: wlc_recv\n", wlc->pub->unit)); WL_TRACE(("wl%d: wlc_recv\n", wlc->pub->unit));
...@@ -7271,7 +7268,9 @@ void BCMFASTPATH wlc_recv(wlc_info_t *wlc, void *p) ...@@ -7271,7 +7268,9 @@ void BCMFASTPATH wlc_recv(wlc_info_t *wlc, void *p)
/* CTS and ACK CTL frames are w/o a2 */ /* CTS and ACK CTL frames are w/o a2 */
if (FC_TYPE(fc) == FC_TYPE_DATA || FC_TYPE(fc) == FC_TYPE_MNG) { if (FC_TYPE(fc) == FC_TYPE_DATA || FC_TYPE(fc) == FC_TYPE_MNG) {
if ((ETHER_ISNULLADDR(&h->a2) || ETHER_ISMULTI(&h->a2))) { if ((ETHER_ISNULLADDR(&h->a2) || ETHER_ISMULTI(&h->a2))) {
WL_ERROR(("wl%d: %s: dropping a frame with invalid" " src mac address, a2: %s\n", wlc->pub->unit, __func__, bcm_ether_ntoa(&h->a2, eabuf))); WL_ERROR(("wl%d: %s: dropping a frame with "
"invalid src mac address, a2: %pM\n",
wlc->pub->unit, __func__, &h->a2));
WLCNTINCR(wlc->pub->_cnt->rxbadsrcmac); WLCNTINCR(wlc->pub->_cnt->rxbadsrcmac);
goto toss; goto toss;
} }
......
...@@ -504,10 +504,8 @@ int srom_parsecis(osl_t *osh, u8 *pcis[], uint ciscnt, char **vars, uint *count) ...@@ -504,10 +504,8 @@ int srom_parsecis(osl_t *osh, u8 *pcis[], uint ciscnt, char **vars, uint *count)
&& !(ETHER_ISMULTI(&cis[i + 2]))) { && !(ETHER_ISMULTI(&cis[i + 2]))) {
ASSERT(cis[i + 1] == ASSERT(cis[i + 1] ==
ETHER_ADDR_LEN); ETHER_ADDR_LEN);
bcm_ether_ntoa( snprintf(eabuf, sizeof(eabuf),
(struct ether_addr *) "%pM", &cis[i + 2]);
&cis[i + 2],
eabuf);
/* set boardnum if HNBU_BOARDNUM not seen yet */ /* set boardnum if HNBU_BOARDNUM not seen yet */
if (boardnum == -1) if (boardnum == -1)
...@@ -976,10 +974,8 @@ int srom_parsecis(osl_t *osh, u8 *pcis[], uint ciscnt, char **vars, uint *count) ...@@ -976,10 +974,8 @@ int srom_parsecis(osl_t *osh, u8 *pcis[], uint ciscnt, char **vars, uint *count)
case HNBU_MACADDR: case HNBU_MACADDR:
if (!(ETHER_ISNULLADDR(&cis[i + 1])) && if (!(ETHER_ISNULLADDR(&cis[i + 1])) &&
!(ETHER_ISMULTI(&cis[i + 1]))) { !(ETHER_ISMULTI(&cis[i + 1]))) {
bcm_ether_ntoa( snprintf(eabuf, sizeof(eabuf),
(struct ether_addr *) "%pM", &cis[i + 1]);
&cis[i + 1],
eabuf);
/* set boardnum if HNBU_BOARDNUM not seen yet */ /* set boardnum if HNBU_BOARDNUM not seen yet */
if (boardnum == -1) if (boardnum == -1)
...@@ -1728,7 +1724,6 @@ static void _initvars_srom_pci(u8 sromrev, u16 *srom, uint off, varbuf_t *b) ...@@ -1728,7 +1724,6 @@ static void _initvars_srom_pci(u8 sromrev, u16 *srom, uint off, varbuf_t *b)
continue; continue;
if (flags & SRFL_ETHADDR) { if (flags & SRFL_ETHADDR) {
char eabuf[ETHER_ADDR_STR_LEN];
struct ether_addr ea; struct ether_addr ea;
ea.octet[0] = (srom[srv->off - off] >> 8) & 0xff; ea.octet[0] = (srom[srv->off - off] >> 8) & 0xff;
...@@ -1737,9 +1732,8 @@ static void _initvars_srom_pci(u8 sromrev, u16 *srom, uint off, varbuf_t *b) ...@@ -1737,9 +1732,8 @@ static void _initvars_srom_pci(u8 sromrev, u16 *srom, uint off, varbuf_t *b)
ea.octet[3] = srom[srv->off + 1 - off] & 0xff; ea.octet[3] = srom[srv->off + 1 - off] & 0xff;
ea.octet[4] = (srom[srv->off + 2 - off] >> 8) & 0xff; ea.octet[4] = (srom[srv->off + 2 - off] >> 8) & 0xff;
ea.octet[5] = srom[srv->off + 2 - off] & 0xff; ea.octet[5] = srom[srv->off + 2 - off] & 0xff;
bcm_ether_ntoa(&ea, eabuf);
varbuf_append(b, "%s=%s", name, eabuf); varbuf_append(b, "%s=%pM", name, ea.octet);
} else { } else {
ASSERT(mask_valid(srv->mask)); ASSERT(mask_valid(srv->mask));
ASSERT(mask_width(srv->mask)); ASSERT(mask_width(srv->mask));
......
...@@ -358,12 +358,6 @@ int bcm_ether_atoe(char *p, struct ether_addr *ea) ...@@ -358,12 +358,6 @@ int bcm_ether_atoe(char *p, struct ether_addr *ea)
return i == 6; return i == 6;
} }
char *bcm_ether_ntoa(const struct ether_addr *ea, char *buf)
{
snprintf(buf, 18, "%pM", ea->octet);
return buf;
}
/* /*
* Search the name=value vars for a specific one and return its value. * Search the name=value vars for a specific one and return its value.
* Returns NULL if not found. * Returns NULL if not found.
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册