Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src-draft/trunk]: src/sys/dev/pci Wrap firmware upload in a function.
details:   https://anonhg.NetBSD.org/src-all/rev/af997acc28f0
branches:  trunk
changeset: 377031:af997acc28f0
user:      Nathanial Sloss <nat%netbsd.org@localhost>
date:      Sat Nov 20 01:54:23 2021 +1100
description:
Wrap firmware upload in a function.
diffstat:
 sys/dev/pci/if_iwn.c |  53 +++++++++++++++++++++++++++++++--------------------
 1 files changed, 32 insertions(+), 21 deletions(-)
diffs (78 lines):
diff -r 814346378c20 -r af997acc28f0 sys/dev/pci/if_iwn.c
--- a/sys/dev/pci/if_iwn.c      Thu Nov 18 08:39:49 2021 +1100
+++ b/sys/dev/pci/if_iwn.c      Sat Nov 20 01:54:23 2021 +1100
@@ -413,6 +413,7 @@ static int  iwn_hw_prepare(struct iwn_sof
 static int     iwn_hw_init(struct iwn_softc *);
 static void    iwn_hw_stop(struct iwn_softc *);
 static int     iwn_init(struct ifnet *);
+static int     iwn_fw_init(struct iwn_softc *);
 static void    iwn_stop(struct ifnet *, int);
 
 /* XXX MCLGETI alternative */
@@ -6865,6 +6866,36 @@ iwn_hw_stop(struct iwn_softc *sc)
 }
 
 static int
+iwn_fw_init(struct iwn_softc *sc)
+{
+       int error = 0;
+
+       /* Read firmware images from the filesystem. */
+       if ((error = iwn_read_firmware(sc)) != 0) {
+               aprint_error_dev(sc->sc_dev,
+                   "could not read firmware\n");
+               return error;
+       }
+
+       /* Initialize interrupt mask to default value. */
+       sc->int_mask = IWN_INT_MASK_DEF;
+       sc->sc_flags &= ~IWN_FLAG_USE_ICT;
+
+       /* Initialize hardware and upload firmware. */
+       KASSERT(sc->fw.data != NULL && sc->fw.size > 0);
+       error = iwn_hw_init(sc);
+       firmware_free(sc->fw.data, sc->fw.size);
+       sc->fw.data = NULL;
+       sc->fw.size = 0;
+       if (error != 0) {
+               aprint_error_dev(sc->sc_dev,
+                   "could not initialize hardware\n");
+       }
+
+       return error;
+}
+
+static int
 iwn_init(struct ifnet *ifp)
 {
        struct ieee80211vap *vap = ifp->if_softc;
@@ -6890,28 +6921,8 @@ iwn_init(struct ifnet *ifp)
                goto fail;
        }
 
-       /* Read firmware images from the filesystem. */
-       if ((error = iwn_read_firmware(sc)) != 0) {
-               aprint_error_dev(sc->sc_dev,
-                   "could not read firmware\n");
+       if (iwn_fw_init(sc) != 0)
                goto fail;
-       }
-
-       /* Initialize interrupt mask to default value. */
-       sc->int_mask = IWN_INT_MASK_DEF;
-       sc->sc_flags &= ~IWN_FLAG_USE_ICT;
-
-       /* Initialize hardware and upload firmware. */
-       KASSERT(sc->fw.data != NULL && sc->fw.size > 0);
-       error = iwn_hw_init(sc);
-       firmware_free(sc->fw.data, sc->fw.size);
-       sc->fw.data = NULL;
-       sc->fw.size = 0;
-       if (error != 0) {
-               aprint_error_dev(sc->sc_dev,
-                   "could not initialize hardware\n");
-               goto fail;
-       }
 
        /* Configure adapter now that it is ready. */
        if ((error = iwn_config(vap)) != 0) {
Home |
Main Index |
Thread Index |
Old Index