1 /* -*- tab-width: 8; c-basic-offset: 4 -*- */
6 * Copyright 1998 Patrik Stridvall
17 #include "wine/winestring.h"
18 #include "debugtools.h"
26 DEFAULT_DEBUG_CHANNEL(msacm
);
28 /***********************************************************************
29 * acmDriverAddA (MSACM32.2)
31 MMRESULT WINAPI
acmDriverAddA(PHACMDRIVERID phadid
, HINSTANCE hinstModule
,
32 LPARAM lParam
, DWORD dwPriority
, DWORD fdwAdd
)
35 return MMSYSERR_INVALPARAM
;
37 /* Check if any unknown flags */
39 ~(ACM_DRIVERADDF_FUNCTION
|ACM_DRIVERADDF_NOTIFYHWND
|
40 ACM_DRIVERADDF_GLOBAL
))
41 return MMSYSERR_INVALFLAG
;
43 /* Check if any incompatible flags */
44 if ((fdwAdd
& ACM_DRIVERADDF_FUNCTION
) &&
45 (fdwAdd
& ACM_DRIVERADDF_NOTIFYHWND
))
46 return MMSYSERR_INVALFLAG
;
48 /* FIXME: in fact, should GetModuleFileName(hinstModule) and do a
49 * LoadDriver on it, to be sure we can call SendDriverMessage on the
52 *phadid
= (HACMDRIVERID
) MSACM_RegisterDriver(NULL
, NULL
, hinstModule
);
54 /* FIXME: lParam, dwPriority and fdwAdd ignored */
56 return MMSYSERR_NOERROR
;
59 /***********************************************************************
60 * acmDriverAddW (MSACM32.3)
64 MMRESULT WINAPI
acmDriverAddW(PHACMDRIVERID phadid
, HINSTANCE hinstModule
,
65 LPARAM lParam
, DWORD dwPriority
, DWORD fdwAdd
)
67 FIXME("(%p, 0x%08x, %ld, %ld, %ld): stub\n",
68 phadid
, hinstModule
, lParam
, dwPriority
, fdwAdd
);
70 SetLastError(ERROR_CALL_NOT_IMPLEMENTED
);
71 return MMSYSERR_ERROR
;
74 /***********************************************************************
75 * acmDriverClose (MSACM32.4)
77 MMRESULT WINAPI
acmDriverClose(HACMDRIVER had
, DWORD fdwClose
)
83 return MMSYSERR_INVALFLAG
;
85 p
= MSACM_GetDriver(had
);
87 return MMSYSERR_INVALHANDLE
;
89 for (tp
= &(p
->obj
.pACMDriverID
->pACMDriverList
); *tp
; *tp
= (*tp
)->pNextACMDriver
) {
91 *tp
= (*tp
)->pNextACMDriver
;
96 if (p
->hDrvr
&& !p
->obj
.pACMDriverID
->pACMDriverList
)
97 CloseDriver(p
->hDrvr
, 0, 0);
99 HeapFree(MSACM_hHeap
, 0, p
);
101 return MMSYSERR_NOERROR
;
104 /***********************************************************************
105 * acmDriverDetailsA (MSACM32.5)
107 MMRESULT WINAPI
acmDriverDetailsA(HACMDRIVERID hadid
, PACMDRIVERDETAILSA padd
, DWORD fdwDetails
)
110 ACMDRIVERDETAILSW addw
;
112 addw
.cbStruct
= sizeof(addw
);
113 mmr
= acmDriverDetailsW(hadid
, &addw
, fdwDetails
);
115 padd
->fccType
= addw
.fccType
;
116 padd
->fccComp
= addw
.fccComp
;
117 padd
->wMid
= addw
.wMid
;
118 padd
->wPid
= addw
.wPid
;
119 padd
->vdwACM
= addw
.vdwACM
;
120 padd
->vdwDriver
= addw
.vdwDriver
;
121 padd
->fdwSupport
= addw
.fdwSupport
;
122 padd
->cFormatTags
= addw
.cFormatTags
;
123 padd
->cFilterTags
= addw
.cFilterTags
;
124 padd
->hicon
= addw
.hicon
;
125 lstrcpyWtoA(padd
->szShortName
, addw
.szShortName
);
126 lstrcpyWtoA(padd
->szLongName
, addw
.szLongName
);
127 lstrcpyWtoA(padd
->szCopyright
, addw
.szCopyright
);
128 lstrcpyWtoA(padd
->szLicensing
, addw
.szLicensing
);
129 lstrcpyWtoA(padd
->szFeatures
, addw
.szFeatures
);
134 /***********************************************************************
135 * acmDriverDetailsW (MSACM32.6)
137 MMRESULT WINAPI
acmDriverDetailsW(HACMDRIVERID hadid
, PACMDRIVERDETAILSW padd
, DWORD fdwDetails
)
143 return MMSYSERR_INVALFLAG
;
145 mmr
= acmDriverOpen(&acmDrvr
, hadid
, 0);
146 if (mmr
== MMSYSERR_NOERROR
) {
147 mmr
= (MMRESULT
)MSACM_Message(acmDrvr
, ACMDM_DRIVER_DETAILS
, (LPARAM
)padd
, 0);
149 acmDriverClose(acmDrvr
, 0);
155 /***********************************************************************
156 * acmDriverEnum (MSACM32.7)
158 MMRESULT WINAPI
acmDriverEnum(ACMDRIVERENUMCB fnCallback
, DWORD dwInstance
, DWORD fdwEnum
)
161 ACMDRIVERDETAILSW add
;
163 if (!fnCallback
) return MMSYSERR_INVALPARAM
;
165 if (fdwEnum
&& ~(ACM_DRIVERENUMF_NOLOCAL
|ACM_DRIVERENUMF_DISABLED
))
166 return MMSYSERR_INVALFLAG
;
168 add
.cbStruct
= sizeof(add
);
169 for (p
= MSACM_pFirstACMDriverID
; p
; p
= p
->pNextACMDriverID
) {
170 if (acmDriverDetailsW((HACMDRIVERID
)p
, &add
, 0) != MMSYSERR_NOERROR
)
173 if (fdwEnum
& ACM_DRIVERENUMF_DISABLED
)
174 add
.fdwSupport
|= ACMDRIVERDETAILS_SUPPORTF_DISABLED
;
178 if (!(*fnCallback
)((HACMDRIVERID
)p
, dwInstance
, add
.fdwSupport
))
182 return MMSYSERR_NOERROR
;
185 /***********************************************************************
186 * acmDriverID (MSACM32.8)
188 MMRESULT WINAPI
acmDriverID(HACMOBJ hao
, PHACMDRIVERID phadid
, DWORD fdwDriverID
)
193 return MMSYSERR_INVALPARAM
;
196 return MMSYSERR_INVALFLAG
;
198 pao
= MSACM_GetObj(hao
, WINE_ACMOBJ_DONTCARE
);
200 return MMSYSERR_INVALHANDLE
;
202 *phadid
= (HACMDRIVERID
) pao
->pACMDriverID
;
204 return MMSYSERR_NOERROR
;
207 /***********************************************************************
208 * acmDriverMessage (MSACM32.9)
211 LRESULT WINAPI
acmDriverMessage(HACMDRIVER had
, UINT uMsg
, LPARAM lParam1
, LPARAM lParam2
)
213 if ((uMsg
>= ACMDM_USER
&& uMsg
< ACMDM_RESERVED_LOW
) ||
214 uMsg
== ACMDM_DRIVER_ABOUT
||
215 uMsg
== DRV_QUERYCONFIGURE
||
216 uMsg
== DRV_CONFIGURE
)
217 return MSACM_Message(had
, uMsg
, lParam1
, lParam2
);
218 return MMSYSERR_INVALPARAM
;
222 /***********************************************************************
223 * acmDriverOpen (MSACM32.10)
225 MMRESULT WINAPI
acmDriverOpen(PHACMDRIVER phad
, HACMDRIVERID hadid
, DWORD fdwOpen
)
227 PWINE_ACMDRIVERID padid
;
230 TRACE("(%p, %x, %08lu)\n", phad
, hadid
, fdwOpen
);
233 return MMSYSERR_INVALPARAM
;
235 padid
= MSACM_GetDriverID(hadid
);
237 return MMSYSERR_INVALHANDLE
;
240 return MMSYSERR_INVALFLAG
;
242 pad
= HeapAlloc(MSACM_hHeap
, 0, sizeof(WINE_ACMDRIVER
));
243 if (!pad
) return MMSYSERR_NOMEM
;
245 pad
->obj
.dwType
= WINE_ACMOBJ_DRIVER
;
246 pad
->obj
.pACMDriverID
= padid
;
248 if (!padid
->hInstModule
)
249 pad
->hDrvr
= OpenDriverA(padid
->pszDriverAlias
, "drivers32", 0);
251 pad
->hDrvr
= padid
->hInstModule
;
254 HeapFree(MSACM_hHeap
, 0, pad
);
255 return MMSYSERR_ERROR
;
258 pad
->pfnDriverProc
= GetProcAddress(pad
->hDrvr
, "DriverProc");
260 /* insert new pad at beg of list */
261 pad
->pNextACMDriver
= padid
->pACMDriverList
;
262 padid
->pACMDriverList
= pad
;
264 /* FIXME: Create a WINE_ACMDRIVER32 */
265 *phad
= (HACMDRIVER
)pad
;
267 return MMSYSERR_NOERROR
;
270 /***********************************************************************
271 * acmDriverPriority (MSACM32.11)
273 MMRESULT WINAPI
acmDriverPriority(HACMDRIVERID hadid
, DWORD dwPriority
, DWORD fdwPriority
)
275 PWINE_ACMDRIVERID padid
;
278 LONG lBufferLength
= sizeof(szBuffer
);
281 DWORD dwPriorityCounter
;
283 padid
= MSACM_GetDriverID(hadid
);
285 return MMSYSERR_INVALHANDLE
;
287 /* Check for unknown flags */
289 ~(ACM_DRIVERPRIORITYF_ENABLE
|ACM_DRIVERPRIORITYF_DISABLE
|
290 ACM_DRIVERPRIORITYF_BEGIN
|ACM_DRIVERPRIORITYF_END
))
291 return MMSYSERR_INVALFLAG
;
293 /* Check for incompatible flags */
294 if ((fdwPriority
& ACM_DRIVERPRIORITYF_ENABLE
) &&
295 (fdwPriority
& ACM_DRIVERPRIORITYF_DISABLE
))
296 return MMSYSERR_INVALFLAG
;
298 /* Check for incompatible flags */
299 if ((fdwPriority
& ACM_DRIVERPRIORITYF_BEGIN
) &&
300 (fdwPriority
& ACM_DRIVERPRIORITYF_END
))
301 return MMSYSERR_INVALFLAG
;
303 lError
= RegOpenKeyA(HKEY_CURRENT_USER
,
304 "Software\\Microsoft\\Multimedia\\"
305 "Audio Compression Manager\\Priority v4.00",
308 /* FIXME: Create key */
309 if (lError
!= ERROR_SUCCESS
)
310 return MMSYSERR_ERROR
;
312 for (dwPriorityCounter
= 1; ; dwPriorityCounter
++) {
313 snprintf(szSubKey
, 17, "Priorty%ld", dwPriorityCounter
);
314 lError
= RegQueryValueA(hPriorityKey
, szSubKey
, szBuffer
, &lBufferLength
);
315 if (lError
!= ERROR_SUCCESS
)
318 FIXME("(0x%08x, %ld, %ld): stub (partial)\n",
319 hadid
, dwPriority
, fdwPriority
);
323 RegCloseKey(hPriorityKey
);
325 return MMSYSERR_ERROR
;
328 /***********************************************************************
329 * acmDriverRemove (MSACM32.12)
331 MMRESULT WINAPI
acmDriverRemove(HACMDRIVERID hadid
, DWORD fdwRemove
)
333 PWINE_ACMDRIVERID padid
;
335 padid
= MSACM_GetDriverID(hadid
);
337 return MMSYSERR_INVALHANDLE
;
340 return MMSYSERR_INVALFLAG
;
342 MSACM_UnregisterDriver(padid
);
344 return MMSYSERR_NOERROR
;