Commit 456ba992 authored by Rémi Bernon's avatar Rémi Bernon Committed by Alexandre Julliard

dmsynth: Improve debug traces of DLS2 connections.

parent a1e8352f
...@@ -25,11 +25,93 @@ ...@@ -25,11 +25,93 @@
#include "dmksctrl.h" #include "dmksctrl.h"
#include "dmsynth_private.h" #include "dmsynth_private.h"
#include "dls2.h"
#include <fluidsynth.h> #include <fluidsynth.h>
WINE_DEFAULT_DEBUG_CHANNEL(dmsynth); WINE_DEFAULT_DEBUG_CHANNEL(dmsynth);
#define CONN_SRC_CC2 0x0082
#define CONN_SRC_RPN0 0x0100
static const char *debugstr_conn_src(UINT src)
{
switch (src)
{
case CONN_SRC_NONE: return "SRC_NONE";
case CONN_SRC_LFO: return "SRC_LFO";
case CONN_SRC_KEYONVELOCITY: return "SRC_KEYONVELOCITY";
case CONN_SRC_KEYNUMBER: return "SRC_KEYNUMBER";
case CONN_SRC_EG1: return "SRC_EG1";
case CONN_SRC_EG2: return "SRC_EG2";
case CONN_SRC_PITCHWHEEL: return "SRC_PITCHWHEEL";
case CONN_SRC_CC1: return "SRC_CC1";
case CONN_SRC_CC7: return "SRC_CC7";
case CONN_SRC_CC10: return "SRC_CC10";
case CONN_SRC_CC11: return "SRC_CC11";
case CONN_SRC_POLYPRESSURE: return "SRC_POLYPRESSURE";
case CONN_SRC_CHANNELPRESSURE: return "SRC_CHANNELPRESSURE";
case CONN_SRC_VIBRATO: return "SRC_VIBRATO";
case CONN_SRC_MONOPRESSURE: return "SRC_MONOPRESSURE";
case CONN_SRC_CC91: return "SRC_CC91";
case CONN_SRC_CC93: return "SRC_CC93";
case CONN_SRC_CC2: return "SRC_CC2";
case CONN_SRC_RPN0: return "SRC_RPN0";
}
return wine_dbg_sprintf("%#x", src);
}
static const char *debugstr_conn_dst(UINT dst)
{
switch (dst)
{
case CONN_DST_NONE: return "DST_NONE";
/* case CONN_DST_ATTENUATION: return "DST_ATTENUATION"; Same as CONN_DST_GAIN */
case CONN_DST_PITCH: return "DST_PITCH";
case CONN_DST_PAN: return "DST_PAN";
case CONN_DST_LFO_FREQUENCY: return "DST_LFO_FREQUENCY";
case CONN_DST_LFO_STARTDELAY: return "DST_LFO_STARTDELAY";
case CONN_DST_EG1_ATTACKTIME: return "DST_EG1_ATTACKTIME";
case CONN_DST_EG1_DECAYTIME: return "DST_EG1_DECAYTIME";
case CONN_DST_EG1_RELEASETIME: return "DST_EG1_RELEASETIME";
case CONN_DST_EG1_SUSTAINLEVEL: return "DST_EG1_SUSTAINLEVEL";
case CONN_DST_EG2_ATTACKTIME: return "DST_EG2_ATTACKTIME";
case CONN_DST_EG2_DECAYTIME: return "DST_EG2_DECAYTIME";
case CONN_DST_EG2_RELEASETIME: return "DST_EG2_RELEASETIME";
case CONN_DST_EG2_SUSTAINLEVEL: return "DST_EG2_SUSTAINLEVEL";
case CONN_DST_GAIN: return "DST_GAIN";
case CONN_DST_KEYNUMBER: return "DST_KEYNUMBER";
case CONN_DST_LEFT: return "DST_LEFT";
case CONN_DST_RIGHT: return "DST_RIGHT";
case CONN_DST_CENTER: return "DST_CENTER";
case CONN_DST_LEFTREAR: return "DST_LEFTREAR";
case CONN_DST_RIGHTREAR: return "DST_RIGHTREAR";
case CONN_DST_LFE_CHANNEL: return "DST_LFE_CHANNEL";
case CONN_DST_CHORUS: return "DST_CHORUS";
case CONN_DST_REVERB: return "DST_REVERB";
case CONN_DST_VIB_FREQUENCY: return "DST_VIB_FREQUENCY";
case CONN_DST_VIB_STARTDELAY: return "DST_VIB_STARTDELAY";
case CONN_DST_EG1_DELAYTIME: return "DST_EG1_DELAYTIME";
case CONN_DST_EG1_HOLDTIME: return "DST_EG1_HOLDTIME";
case CONN_DST_EG1_SHUTDOWNTIME: return "DST_EG1_SHUTDOWNTIME";
case CONN_DST_EG2_DELAYTIME: return "DST_EG2_DELAYTIME";
case CONN_DST_EG2_HOLDTIME: return "DST_EG2_HOLDTIME";
case CONN_DST_FILTER_CUTOFF: return "DST_FILTER_CUTOFF";
case CONN_DST_FILTER_Q: return "DST_FILTER_Q";
}
return wine_dbg_sprintf("%#x", dst);
}
static const char *debugstr_connection(const CONNECTION *conn)
{
return wine_dbg_sprintf("%s (%#x) x %s (%#x) -> %s (%#x): %ld", debugstr_conn_src(conn->usSource),
(conn->usTransform >> 10) & 0x3f, debugstr_conn_src(conn->usControl), (conn->usTransform >> 4) & 0x3f,
debugstr_conn_dst(conn->usDestination), (conn->usTransform & 0xf), conn->lScale);
}
static void dump_dmus_instrument(DMUS_INSTRUMENT *instrument) static void dump_dmus_instrument(DMUS_INSTRUMENT *instrument)
{ {
TRACE("DMUS_INSTRUMENT:\n"); TRACE("DMUS_INSTRUMENT:\n");
...@@ -85,14 +167,7 @@ static void dump_connectionlist(CONNECTIONLIST *list) ...@@ -85,14 +167,7 @@ static void dump_connectionlist(CONNECTIONLIST *list)
TRACE(" - cConnections = %lu\n", list->cConnections); TRACE(" - cConnections = %lu\n", list->cConnections);
for (i = 0; i < list->cConnections; i++) for (i = 0; i < list->cConnections; i++)
{ TRACE("- CONNECTION[%u]: %s\n", i, debugstr_connection(connections + i));
TRACE("- CONNECTION[%u]:\n", i);
TRACE(" - usSource = %u\n", connections[i].usSource);
TRACE(" - usControl = %u\n", connections[i].usControl);
TRACE(" - usDestination = %u\n", connections[i].usDestination);
TRACE(" - usTransform = %u\n", connections[i].usTransform);
TRACE(" - lScale = %lu\n", connections[i].lScale);
}
} }
static void dump_dmus_wave(DMUS_WAVE *wave) static void dump_dmus_wave(DMUS_WAVE *wave)
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment