From owner-freebsd-current@FreeBSD.ORG Sun Feb 25 08:50:42 2007 Return-Path: X-Original-To: current@freebsd.org Delivered-To: freebsd-current@FreeBSD.ORG Received: from mx1.freebsd.org (mx1.freebsd.org [69.147.83.52]) by hub.freebsd.org (Postfix) with ESMTP id C825F16A400 for ; Sun, 25 Feb 2007 08:50:42 +0000 (UTC) (envelope-from thompsa@freebsd.org) Received: from heff.fud.org.nz (203-109-251-39.static.bliink.ihug.co.nz [203.109.251.39]) by mx1.freebsd.org (Postfix) with ESMTP id 070DC13C478 for ; Sun, 25 Feb 2007 08:50:42 +0000 (UTC) (envelope-from thompsa@freebsd.org) Received: by heff.fud.org.nz (Postfix, from userid 1001) id D1A771CC58; Sun, 25 Feb 2007 21:37:23 +1300 (NZDT) Date: Sun, 25 Feb 2007 21:37:23 +1300 From: Andrew Thompson To: FreeBSD Current Message-ID: <20070225083723.GA8131@heff.fud.org.nz> Mail-Followup-To: Andrew Thompson , FreeBSD Current MIME-Version: 1.0 Content-Type: multipart/mixed; boundary="x+6KMIRAuhnl3hBn" Content-Disposition: inline User-Agent: Mutt/1.5.13 (2006-08-11) Cc: Subject: correct way to pass callbacks X-BeenThere: freebsd-current@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: Discussions about the use of FreeBSD-current List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Sun, 25 Feb 2007 08:50:43 -0000 --x+6KMIRAuhnl3hBn Content-Type: text/plain; charset=us-ascii Content-Disposition: inline Hi, The bridgestp module needs two callbacks from the bridge when it attaches which so far I have just passed on with the function call. bstp_attach(&sc->sc_stp, bridge_state_change, bridge_rtable_expire); I have always felt this was rather ugly so have attached a patch to put them both in a struct, is this the right way to do it? bstp_attach(&sc->sc_stp, &cb); cheers, Andrew --x+6KMIRAuhnl3hBn Content-Type: text/plain; charset=us-ascii Content-Disposition: attachment; filename="bstp_cb.diff" Index: bridgestp.c =================================================================== RCS file: /home/ncvs/src/sys/net/bridgestp.c,v retrieving revision 1.34 diff -u -p -r1.34 bridgestp.c --- bridgestp.c 18 Jan 2007 07:13:01 -0000 1.34 +++ bridgestp.c 23 Feb 2007 22:27:08 -0000 @@ -2087,8 +2087,7 @@ DECLARE_MODULE(bridgestp, bstp_mod, SI_S MODULE_VERSION(bridgestp, 1); void -bstp_attach(struct bstp_state *bs, bstp_state_cb_t state_callback, - bstp_rtage_cb_t rtage_callback) +bstp_attach(struct bstp_state *bs, struct bstp_cb *cb) { BSTP_LOCK_INIT(bs); callout_init_mtx(&bs->bs_bstpcallout, &bs->bs_mtx, 0); @@ -2102,8 +2101,8 @@ bstp_attach(struct bstp_state *bs, bstp_ bs->bs_migration_delay = BSTP_DEFAULT_MIGRATE_DELAY; bs->bs_txholdcount = BSTP_DEFAULT_HOLD_COUNT; bs->bs_protover = BSTP_PROTO_RSTP; - bs->bs_state_cb = state_callback; - bs->bs_rtage_cb = rtage_callback; + bs->bs_state_cb = cb->bcb_state; + bs->bs_rtage_cb = cb->bcb_rtage; getmicrotime(&bs->bs_last_tc_time); Index: bridgestp.h =================================================================== RCS file: /home/ncvs/src/sys/net/bridgestp.h,v retrieving revision 1.12 diff -u -p -r1.12 bridgestp.h --- bridgestp.h 11 Dec 2006 23:46:40 -0000 1.12 +++ bridgestp.h 23 Feb 2007 22:25:27 -0000 @@ -186,6 +186,11 @@ typedef void (*bstp_state_cb_t)(struct ifnet *, int); typedef void (*bstp_rtage_cb_t)(struct ifnet *, int); +struct bstp_cb { + bstp_state_cb_t bcb_state; + bstp_rtage_cb_t bcb_rtage; +}; + /* * Because BPDU's do not make nicely aligned structures, two different * declarations are used: bstp_?bpdu (wire representation, packed) and @@ -365,7 +370,7 @@ extern const uint8_t bstp_etheraddr[]; extern void (*bstp_linkstate_p)(struct ifnet *ifp, int state); -void bstp_attach(struct bstp_state *, bstp_state_cb_t, bstp_rtage_cb_t); +void bstp_attach(struct bstp_state *, struct bstp_cb *); void bstp_detach(struct bstp_state *); void bstp_init(struct bstp_state *); void bstp_stop(struct bstp_state *); Index: if_bridge.c =================================================================== RCS file: /home/ncvs/src/sys/net/if_bridge.c,v retrieving revision 1.92 diff -u -p -r1.92 if_bridge.c --- if_bridge.c 11 Dec 2006 23:46:40 -0000 1.92 +++ if_bridge.c 23 Feb 2007 22:26:48 -0000 @@ -528,6 +528,7 @@ bridge_clone_create(struct if_clone *ifc { struct bridge_softc *sc, *sc2; struct ifnet *bifp, *ifp; + struct bstp_cb cb; u_char eaddr[6]; int retry; @@ -583,7 +584,9 @@ bridge_clone_create(struct if_clone *ifc mtx_unlock(&bridge_list_mtx); } - bstp_attach(&sc->sc_stp, bridge_state_change, bridge_rtable_expire); + cb.bcb_state = bridge_state_change; + cb.bcb_rtage = bridge_rtable_expire; + bstp_attach(&sc->sc_stp, &cb); ether_ifattach(ifp, eaddr); /* Now undo some of the damage... */ ifp->if_baudrate = 0; --x+6KMIRAuhnl3hBn--