Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/dev - fix a confusion between midi(4) unit and connected...



details:   https://anonhg.NetBSD.org/src/rev/4274218b22ec
branches:  trunk
changeset: 805358:4274218b22ec
user:      mrg <mrg%NetBSD.org@localhost>
date:      Tue Dec 30 07:33:44 2014 +0000

description:
- fix a confusion between midi(4) unit and connected to sequencer
  devices.
- minor comment/debug clean ups.

fixes problems attempting to read or write from the right midi(4)
device using the sequencer(4) device when one or more of the
non-final devices fails to open with midiseq_open().

diffstat:

 sys/dev/sequencer.c |  21 +++++++++++++--------
 1 files changed, 13 insertions(+), 8 deletions(-)

diffs (79 lines):

diff -r c8bd5b9d76e8 -r 4274218b22ec sys/dev/sequencer.c
--- a/sys/dev/sequencer.c       Tue Dec 30 07:28:34 2014 +0000
+++ b/sys/dev/sequencer.c       Tue Dec 30 07:33:44 2014 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: sequencer.c,v 1.61 2014/12/23 11:37:40 mrg Exp $       */
+/*     $NetBSD: sequencer.c,v 1.62 2014/12/30 07:33:44 mrg Exp $       */
 
 /*
  * Copyright (c) 1998, 2008 The NetBSD Foundation, Inc.
@@ -55,7 +55,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: sequencer.c,v 1.61 2014/12/23 11:37:40 mrg Exp $");
+__KERNEL_RCSID(0, "$NetBSD: sequencer.c,v 1.62 2014/12/30 07:33:44 mrg Exp $");
 
 #include "sequencer.h"
 
@@ -299,7 +299,7 @@
        struct sequencer_softc *sc;
        struct midi_dev *md;
        struct midi_softc *msc;
-       int error, unit;
+       int error, unit, mdno;
 
        DPRINTF(("sequenceropen\n"));
 
@@ -342,7 +342,11 @@
                                sc->devs[sc->nmidi++] = md;
                                md->seq = sc;
                                md->doingsysex = 0;
-                       }
+                               DPRINTF(("%s: midi unit %d opened as seq %p\n",
+                                   __func__, unit, md));
+                       } else
+                               DPRINTF(("%s: midi unit %d not opened as seq\n",
+                                   __func__, unit));
                }
                mutex_enter(&sc->lock);
        } else {
@@ -350,10 +354,10 @@
        }
 
        /* Only now redirect input from MIDI devices. */
-       for (unit = 0; unit < sc->nmidi; unit++) {
+       for (mdno = 0; mdno < sc->nmidi; mdno++) {
                extern struct cfdriver midi_cd;
 
-               msc = device_lookup_private(&midi_cd, unit);
+               msc = device_lookup_private(&midi_cd, sc->devs[mdno]->unit);
                if (msc) {
                        mutex_enter(msc->lock);
                        msc->seqopen = 1;
@@ -573,7 +577,7 @@
        t += sc->timer.divs_lastchange;
        if (t != sc->input_stamp) {
                seq_input_event(sc, &SEQ_MK_TIMING(WAIT_ABS, .divisions=t));
-               sc->input_stamp = t; /* XXX wha hoppen if timer is reset? */
+               sc->input_stamp = t; /* XXX what happens if timer is reset? */
        }
        seq_input_event(sc, &ev);
        mutex_exit(&sc->lock);
@@ -587,7 +591,7 @@
        seq_event_t ev;
        int error;
 
-       DPRINTFN(20, ("sequencerread: %"PRIx64", count=%d, ioflag=%x\n",
+       DPRINTFN(2, ("sequencerread: %"PRIx64", count=%d, ioflag=%x\n",
           dev, (int)uio->uio_resid, ioflag));
 
        if ((error = sequencer_enter(dev, &sc)) != 0)
@@ -800,6 +804,7 @@
        case SEQUENCER_TMR_TEMPO:
                error = seq_do_timing(sc,
                    &SEQ_MK_TIMING(TEMPO, .bpm=*(int *)addr));
+               RECALC_USPERDIV(&sc->timer);
                if (error == 0)
                        *(int *)addr = sc->timer.tempo_beatpermin;
                break;



Home | Main Index | Thread Index | Old Index