From owner-svn-src-all@FreeBSD.ORG Sat Jun 20 22:24:45 2015 Return-Path: Delivered-To: svn-src-all@hub.freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [8.8.178.115]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by hub.freebsd.org (Postfix) with ESMTPS id 6B30A7B6; Sat, 20 Jun 2015 22:24:45 +0000 (UTC) (envelope-from davidcs@FreeBSD.org) Received: from svn.freebsd.org (svn.freebsd.org [IPv6:2001:1900:2254:2068::e6a:0]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (Client did not present a certificate) by mx1.freebsd.org (Postfix) with ESMTPS id 58E916B7; Sat, 20 Jun 2015 22:24:45 +0000 (UTC) (envelope-from davidcs@FreeBSD.org) Received: from svn.freebsd.org ([127.0.1.70]) by svn.freebsd.org (8.14.9/8.14.9) with ESMTP id t5KMOjcQ010062; Sat, 20 Jun 2015 22:24:45 GMT (envelope-from davidcs@FreeBSD.org) Received: (from davidcs@localhost) by svn.freebsd.org (8.14.9/8.14.9/Submit) id t5KMOj8l010061; Sat, 20 Jun 2015 22:24:45 GMT (envelope-from davidcs@FreeBSD.org) Message-Id: <201506202224.t5KMOj8l010061@svn.freebsd.org> X-Authentication-Warning: svn.freebsd.org: davidcs set sender to davidcs@FreeBSD.org using -f From: David C Somayajulu Date: Sat, 20 Jun 2015 22:24:45 +0000 (UTC) To: src-committers@freebsd.org, svn-src-all@freebsd.org, svn-src-head@freebsd.org Subject: svn commit: r284651 - head/sys/dev/bxe X-SVN-Group: head MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-BeenThere: svn-src-all@freebsd.org X-Mailman-Version: 2.1.20 Precedence: list List-Id: "SVN commit messages for the entire src tree \(except for " user" and " projects" \)" List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Sat, 20 Jun 2015 22:24:45 -0000 Author: davidcs Date: Sat Jun 20 22:24:44 2015 New Revision: 284651 URL: https://svnweb.freebsd.org/changeset/base/284651 Log: Simplified implementation of bxe_set_mc_list() removed bxe_free_mcast_macs_list() and bxe_init_mcast_macs_list() fixed bug where copy of multicast list mta was deleted prior to passing the list to firmware MFC after:5 days Modified: head/sys/dev/bxe/bxe.c Modified: head/sys/dev/bxe/bxe.c ============================================================================== --- head/sys/dev/bxe/bxe.c Sat Jun 20 21:48:07 2015 (r284650) +++ head/sys/dev/bxe/bxe.c Sat Jun 20 22:24:44 2015 (r284651) @@ -12499,24 +12499,21 @@ bxe_initial_phy_init(struct bxe_softc *s } /* must be called under IF_ADDR_LOCK */ + static int -bxe_init_mcast_macs_list(struct bxe_softc *sc, - struct ecore_mcast_ramrod_params *p) +bxe_set_mc_list(struct bxe_softc *sc) { - if_t ifp = sc->ifp; + struct ecore_mcast_ramrod_params rparam = { NULL }; + int rc = 0; int mc_count = 0; int mcnt, i; - struct ecore_mcast_list_elem *mc_mac; + struct ecore_mcast_list_elem *mc_mac, *mc_mac_start; unsigned char *mta; + if_t ifp = sc->ifp; mc_count = if_multiaddr_count(ifp, -1);/* XXX they don't have a limit */ - /* should we enforce one? */ - ECORE_LIST_INIT(&p->mcast_list); - p->mcast_list_len = 0; - - if (!mc_count) { + if (!mc_count) return (0); - } mta = malloc(sizeof(unsigned char) * ETHER_ADDR_LEN * mc_count, M_DEVBUF, M_NOWAIT); @@ -12527,8 +12524,9 @@ bxe_init_mcast_macs_list(struct bxe_soft } bzero(mta, (sizeof(unsigned char) * ETHER_ADDR_LEN * mc_count)); - mc_mac = malloc(sizeof(*mc_mac) * mc_count, M_DEVBUF, - (M_NOWAIT | M_ZERO)); + mc_mac = malloc(sizeof(*mc_mac) * mc_count, M_DEVBUF, (M_NOWAIT | M_ZERO)); + mc_mac_start = mc_mac; + if (!mc_mac) { free(mta, M_DEVBUF); BLOGE(sc, "Failed to allocate temp mcast list\n"); @@ -12536,12 +12534,17 @@ bxe_init_mcast_macs_list(struct bxe_soft } bzero(mc_mac, (sizeof(*mc_mac) * mc_count)); - if_multiaddr_array(ifp, mta, &mcnt, mc_count); /* mta and mcnt not expected - to be different */ + /* mta and mcnt not expected to be different */ + if_multiaddr_array(ifp, mta, &mcnt, mc_count); + + + rparam.mcast_obj = &sc->mcast_obj; + ECORE_LIST_INIT(&rparam.mcast_list); + for(i=0; i< mcnt; i++) { - mc_mac->mac = (uint8_t *)(mta + (i * ETHER_ADDR_LEN)); - ECORE_LIST_PUSH_TAIL(&mc_mac->link, &p->mcast_list); + mc_mac->mac = (uint8_t *)(mta + (i * ETHER_ADDR_LEN)); + ECORE_LIST_PUSH_TAIL(&mc_mac->link, &rparam.mcast_list); BLOGD(sc, DBG_LOAD, "Setting MCAST %02X:%02X:%02X:%02X:%02X:%02X\n", @@ -12550,34 +12553,7 @@ bxe_init_mcast_macs_list(struct bxe_soft mc_mac++; } - - p->mcast_list_len = mc_count; - free(mta, M_DEVBUF); - - return (0); -} - -static void -bxe_free_mcast_macs_list(struct ecore_mcast_ramrod_params *p) -{ - struct ecore_mcast_list_elem *mc_mac = - ECORE_LIST_FIRST_ENTRY(&p->mcast_list, - struct ecore_mcast_list_elem, - link); - - if (mc_mac) { - /* only a single free as all mc_macs are in the same heap array */ - free(mc_mac, M_DEVBUF); - } -} - -static int -bxe_set_mc_list(struct bxe_softc *sc) -{ - struct ecore_mcast_ramrod_params rparam = { NULL }; - int rc = 0; - - rparam.mcast_obj = &sc->mcast_obj; + rparam.mcast_list_len = mc_count; BXE_MCAST_LOCK(sc); @@ -12586,14 +12562,8 @@ bxe_set_mc_list(struct bxe_softc *sc) if (rc < 0) { BLOGE(sc, "Failed to clear multicast configuration: %d\n", rc); BXE_MCAST_UNLOCK(sc); - return (rc); - } - - /* configure a new MACs list */ - rc = bxe_init_mcast_macs_list(sc, &rparam); - if (rc) { - BLOGE(sc, "Failed to create mcast MACs list (%d)\n", rc); - BXE_MCAST_UNLOCK(sc); + free(mc_mac_start, M_DEVBUF); + free(mta, M_DEVBUF); return (rc); } @@ -12603,10 +12573,11 @@ bxe_set_mc_list(struct bxe_softc *sc) BLOGE(sc, "Failed to set new mcast config (%d)\n", rc); } - bxe_free_mcast_macs_list(&rparam); - BXE_MCAST_UNLOCK(sc); + free(mc_mac_start, M_DEVBUF); + free(mta, M_DEVBUF); + return (rc); }