200 lines
5.5 KiB
C
200 lines
5.5 KiB
C
/* -*- tab-width: 8; c-basic-offset: 4 -*- */
|
|
|
|
/*
|
|
* MSACM32 library
|
|
*
|
|
* Copyright 1998 Patrik Stridvall
|
|
* 1999 Eric Pouech
|
|
*/
|
|
|
|
#include "winbase.h"
|
|
#include "winerror.h"
|
|
#include "windef.h"
|
|
#include "debugtools.h"
|
|
#include "msacm.h"
|
|
#include "msacmdrv.h"
|
|
#include "wineacm.h"
|
|
|
|
DEFAULT_DEBUG_CHANNEL(msacm);
|
|
|
|
/**********************************************************************/
|
|
|
|
static DWORD MSACM_dwProcessesAttached = 0;
|
|
HINSTANCE MSACM_hInstance32 = 0;
|
|
|
|
/***********************************************************************
|
|
* MSACM_LibMain (MSACM32.init)
|
|
*/
|
|
BOOL WINAPI MSACM32_LibMain(HINSTANCE hInstDLL, DWORD fdwReason, LPVOID lpvReserved)
|
|
{
|
|
TRACE("0x%x 0x%lx %p\n", hInstDLL, fdwReason, lpvReserved);
|
|
|
|
switch (fdwReason) {
|
|
case DLL_PROCESS_ATTACH:
|
|
if (MSACM_dwProcessesAttached == 0) {
|
|
MSACM_hHeap = HeapCreate(0, 0x10000, 0);
|
|
MSACM_hInstance32 = hInstDLL;
|
|
MSACM_RegisterAllDrivers();
|
|
}
|
|
MSACM_dwProcessesAttached++;
|
|
break;
|
|
case DLL_PROCESS_DETACH:
|
|
MSACM_dwProcessesAttached--;
|
|
if (MSACM_dwProcessesAttached == 0) {
|
|
MSACM_UnregisterAllDrivers();
|
|
HeapDestroy(MSACM_hHeap);
|
|
MSACM_hHeap = (HANDLE) NULL;
|
|
MSACM_hInstance32 = (HINSTANCE)NULL;
|
|
}
|
|
break;
|
|
case DLL_THREAD_ATTACH:
|
|
break;
|
|
case DLL_THREAD_DETACH:
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
return TRUE;
|
|
}
|
|
|
|
/***********************************************************************
|
|
* XRegThunkEntry (MSACM32.1)
|
|
* FIXME
|
|
* No documentation found.
|
|
*/
|
|
|
|
/***********************************************************************
|
|
* acmGetVersion (MSACM32.34)
|
|
*/
|
|
DWORD WINAPI acmGetVersion(void)
|
|
{
|
|
OSVERSIONINFOA version;
|
|
GetVersionExA( &version );
|
|
switch(version.dwPlatformId)
|
|
{
|
|
case VER_PLATFORM_WIN32_NT:
|
|
return 0x04000565; /* 4.0.1381 */
|
|
default:
|
|
FIXME("%ld not supported",version.dwPlatformId);
|
|
case VER_PLATFORM_WIN32_WINDOWS:
|
|
return 0x04000000; /* 4.0.0 */
|
|
}
|
|
}
|
|
|
|
/***********************************************************************
|
|
* acmMessage32 (MSACM32.35)
|
|
* FIXME
|
|
* No documentation found.
|
|
*/
|
|
|
|
/***********************************************************************
|
|
* acmMetrics (MSACM32.36)
|
|
*/
|
|
MMRESULT WINAPI acmMetrics(HACMOBJ hao, UINT uMetric, LPVOID pMetric)
|
|
{
|
|
PWINE_ACMOBJ pao = MSACM_GetObj(hao, WINE_ACMOBJ_DONTCARE);
|
|
BOOL bLocal = TRUE;
|
|
PWINE_ACMDRIVERID padid;
|
|
DWORD val = 0;
|
|
MMRESULT mmr = MMSYSERR_NOERROR;
|
|
|
|
TRACE("(0x%08x, %d, %p);\n", hao, uMetric, pMetric);
|
|
|
|
switch (uMetric) {
|
|
case ACM_METRIC_COUNT_DRIVERS:
|
|
bLocal = FALSE;
|
|
/* fall thru */
|
|
case ACM_METRIC_COUNT_LOCAL_DRIVERS:
|
|
if (!pao)
|
|
return MMSYSERR_INVALHANDLE;
|
|
for (padid = MSACM_pFirstACMDriverID; padid; padid = padid->pNextACMDriverID)
|
|
if (padid->bEnabled /* && (local(padid) || !bLocal) */)
|
|
val++;
|
|
*(LPDWORD)pMetric = val;
|
|
break;
|
|
|
|
case ACM_METRIC_COUNT_CODECS:
|
|
if (!pao)
|
|
return MMSYSERR_INVALHANDLE;
|
|
bLocal = FALSE;
|
|
/* fall thru */
|
|
case ACM_METRIC_COUNT_LOCAL_CODECS:
|
|
/* FIXME: don't know how to differentiate codec, converters & filters yet */
|
|
for (padid = MSACM_pFirstACMDriverID; padid; padid = padid->pNextACMDriverID)
|
|
if (padid->bEnabled /* && (local(padid) || !bLocal) */)
|
|
val++;
|
|
*(LPDWORD)pMetric = val;
|
|
break;
|
|
|
|
case ACM_METRIC_COUNT_CONVERTERS:
|
|
bLocal = FALSE;
|
|
/* fall thru */
|
|
case ACM_METRIC_COUNT_LOCAL_CONVERTERS:
|
|
/* FIXME: don't know how to differentiate codec, converters & filters yet */
|
|
for (padid = MSACM_pFirstACMDriverID; padid; padid = padid->pNextACMDriverID)
|
|
if (padid->bEnabled /* && (local(padid) || !bLocal) */)
|
|
val++;
|
|
*(LPDWORD)pMetric = val;
|
|
break;
|
|
|
|
case ACM_METRIC_COUNT_FILTERS:
|
|
bLocal = FALSE;
|
|
/* fall thru */
|
|
case ACM_METRIC_COUNT_LOCAL_FILTERS:
|
|
/* FIXME: don't know how to differentiate codec, converters & filters yet */
|
|
for (padid = MSACM_pFirstACMDriverID; padid; padid = padid->pNextACMDriverID)
|
|
if (padid->bEnabled /* && (local(padid) || !bLocal) */)
|
|
val++;
|
|
*(LPDWORD)pMetric = val;
|
|
break;
|
|
|
|
case ACM_METRIC_COUNT_DISABLED:
|
|
bLocal = FALSE;
|
|
/* fall thru */
|
|
case ACM_METRIC_COUNT_LOCAL_DISABLED:
|
|
if (!pao)
|
|
return MMSYSERR_INVALHANDLE;
|
|
for (padid = MSACM_pFirstACMDriverID; padid; padid = padid->pNextACMDriverID)
|
|
if (!padid->bEnabled /* && (local(padid) || !bLocal) */)
|
|
val++;
|
|
*(LPDWORD)pMetric = val;
|
|
break;
|
|
|
|
case ACM_METRIC_MAX_SIZE_FORMAT:
|
|
{
|
|
ACMFORMATTAGDETAILSW aftd;
|
|
|
|
aftd.cbStruct = sizeof(aftd);
|
|
aftd.dwFormatTag = WAVE_FORMAT_UNKNOWN;
|
|
|
|
if (hao == (HACMOBJ)NULL) {
|
|
mmr = acmFormatTagDetailsW((HACMDRIVER)NULL, &aftd, ACM_FORMATTAGDETAILSF_LARGESTSIZE);
|
|
} else if (MSACM_GetObj(hao, WINE_ACMOBJ_DRIVER)) {
|
|
mmr = acmFormatTagDetailsW((HACMDRIVER)hao, &aftd, ACM_FORMATTAGDETAILSF_LARGESTSIZE);
|
|
} else if (MSACM_GetObj(hao, WINE_ACMOBJ_DRIVERID)) {
|
|
HACMDRIVER had;
|
|
|
|
if (acmDriverOpen(&had, (HACMDRIVERID)hao, 0) == 0) {
|
|
mmr = acmFormatTagDetailsW((HACMDRIVER)hao, &aftd, ACM_FORMATTAGDETAILSF_LARGESTSIZE);
|
|
acmDriverClose(had, 0);
|
|
}
|
|
} else {
|
|
mmr = MMSYSERR_INVALHANDLE;
|
|
}
|
|
if (mmr == MMSYSERR_NOERROR) *(LPDWORD)pMetric = aftd.cbFormatSize;
|
|
}
|
|
break;
|
|
|
|
case ACM_METRIC_COUNT_HARDWARE:
|
|
case ACM_METRIC_HARDWARE_WAVE_INPUT:
|
|
case ACM_METRIC_HARDWARE_WAVE_OUTPUT:
|
|
case ACM_METRIC_MAX_SIZE_FILTER:
|
|
case ACM_METRIC_DRIVER_SUPPORT:
|
|
case ACM_METRIC_DRIVER_PRIORITY:
|
|
default:
|
|
FIXME("(0x%08x, %d, %p): stub\n", hao, uMetric, pMetric);
|
|
mmr = MMSYSERR_NOTSUPPORTED;
|
|
}
|
|
return mmr;
|
|
}
|