Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-cw
Commits
6c370766
Commit
6c370766
authored
Jan 18, 2006
by
Alex Villacís Lasso
Committed by
Alexandre Julliard
Jan 18, 2006
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
msacm: acmDriverAdd() support for ACM_DRIVERADDF_FUNCTION, implemented
local drivers.
parent
07dc3c54
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
74 additions
and
9 deletions
+74
-9
driver.c
dlls/msacm/driver.c
+42
-7
internal.c
dlls/msacm/internal.c
+0
-0
wineacm.h
dlls/msacm/wineacm.h
+32
-2
No files found.
dlls/msacm/driver.c
View file @
6c370766
...
@@ -101,6 +101,8 @@ MMRESULT WINAPI acmDriverAddA(PHACMDRIVERID phadid, HINSTANCE hinstModule,
...
@@ -101,6 +101,8 @@ MMRESULT WINAPI acmDriverAddA(PHACMDRIVERID phadid, HINSTANCE hinstModule,
MMRESULT
WINAPI
acmDriverAddW
(
PHACMDRIVERID
phadid
,
HINSTANCE
hinstModule
,
MMRESULT
WINAPI
acmDriverAddW
(
PHACMDRIVERID
phadid
,
HINSTANCE
hinstModule
,
LPARAM
lParam
,
DWORD
dwPriority
,
DWORD
fdwAdd
)
LPARAM
lParam
,
DWORD
dwPriority
,
DWORD
fdwAdd
)
{
{
PWINE_ACMLOCALDRIVER
pLocalDrv
=
NULL
;
TRACE
(
"(%p, %p, %08lx, %08lx, %08lx)
\n
"
,
TRACE
(
"(%p, %p, %08lx, %08lx, %08lx)
\n
"
,
phadid
,
hinstModule
,
lParam
,
dwPriority
,
fdwAdd
);
phadid
,
hinstModule
,
lParam
,
dwPriority
,
fdwAdd
);
...
@@ -144,11 +146,17 @@ MMRESULT WINAPI acmDriverAddW(PHACMDRIVERID phadid, HINSTANCE hinstModule,
...
@@ -144,11 +146,17 @@ MMRESULT WINAPI acmDriverAddW(PHACMDRIVERID phadid, HINSTANCE hinstModule,
dwPriority (unused, set to 0)
dwPriority (unused, set to 0)
*/
*/
fdwAdd
&=
~
ACM_DRIVERADDF_TYPEMASK
;
fdwAdd
&=
~
ACM_DRIVERADDF_TYPEMASK
;
/* FIXME: fdwAdd ignored */
*
phadid
=
0
;
/* Application-supplied acmDriverProc's are placed at the top of the priority unless
FIXME
(
"(%p, %p, %ld, %ld, %ld): ACM_DRIVERADDF_FUNCTION: stub
\n
"
,
phadid
,
hinstModule
,
lParam
,
dwPriority
,
fdwAdd
);
fdwAdd indicates ACM_DRIVERADDF_GLOBAL
SetLastError
(
ERROR_CALL_NOT_IMPLEMENTED
);
*/
return
MMSYSERR_ERROR
;
pLocalDrv
=
MSACM_RegisterLocalDriver
(
hinstModule
,
(
DRIVERPROC
)
lParam
);
*
phadid
=
pLocalDrv
?
(
HACMDRIVERID
)
MSACM_RegisterDriver
(
NULL
,
NULL
,
pLocalDrv
)
:
NULL
;
if
(
!*
phadid
)
{
ERR
(
"Unable to register driver via ACM_DRIVERADDF_FUNCTION
\n
"
);
return
MMSYSERR_INVALPARAM
;
}
break
;
case
ACM_DRIVERADDF_NOTIFYHWND
:
case
ACM_DRIVERADDF_NOTIFYHWND
:
/*
/*
hInstModule (unused)
hInstModule (unused)
...
@@ -203,8 +211,10 @@ MMRESULT WINAPI acmDriverClose(HACMDRIVER had, DWORD fdwClose)
...
@@ -203,8 +211,10 @@ MMRESULT WINAPI acmDriverClose(HACMDRIVER had, DWORD fdwClose)
}
}
/* close driver if it has been opened */
/* close driver if it has been opened */
if
(
pad
->
hDrvr
&&
!
pad
id
->
hInstModule
)
if
(
pad
->
hDrvr
&&
!
pad
->
pLocalDrvrInst
)
CloseDriver
(
pad
->
hDrvr
,
0
,
0
);
CloseDriver
(
pad
->
hDrvr
,
0
,
0
);
else
if
(
pad
->
pLocalDrvrInst
)
MSACM_CloseLocalDriver
(
pad
->
pLocalDrvrInst
);
HeapFree
(
MSACM_hHeap
,
0
,
pad
);
HeapFree
(
MSACM_hHeap
,
0
,
pad
);
...
@@ -506,8 +516,10 @@ MMRESULT WINAPI acmDriverOpen(PHACMDRIVER phad, HACMDRIVERID hadid, DWORD fdwOpe
...
@@ -506,8 +516,10 @@ MMRESULT WINAPI acmDriverOpen(PHACMDRIVER phad, HACMDRIVERID hadid, DWORD fdwOpe
pad
->
obj
.
dwType
=
WINE_ACMOBJ_DRIVER
;
pad
->
obj
.
dwType
=
WINE_ACMOBJ_DRIVER
;
pad
->
obj
.
pACMDriverID
=
padid
;
pad
->
obj
.
pACMDriverID
=
padid
;
pad
->
hDrvr
=
0
;
pad
->
pLocalDrvrInst
=
NULL
;
if
(
!
(
pad
->
hDrvr
=
(
HDRVR
)
padid
->
hInstModule
)
)
if
(
padid
->
pLocalDriver
==
NULL
)
{
{
ACMDRVOPENDESCW
adod
;
ACMDRVOPENDESCW
adod
;
int
len
;
int
len
;
...
@@ -540,6 +552,29 @@ MMRESULT WINAPI acmDriverOpen(PHACMDRIVER phad, HACMDRIVERID hadid, DWORD fdwOpe
...
@@ -540,6 +552,29 @@ MMRESULT WINAPI acmDriverOpen(PHACMDRIVER phad, HACMDRIVERID hadid, DWORD fdwOpe
goto
gotError
;
goto
gotError
;
}
}
}
}
else
{
ACMDRVOPENDESCW
adod
;
pad
->
hDrvr
=
NULL
;
adod
.
cbStruct
=
sizeof
(
adod
);
adod
.
fccType
=
ACMDRIVERDETAILS_FCCTYPE_AUDIOCODEC
;
adod
.
fccComp
=
ACMDRIVERDETAILS_FCCCOMP_UNDEFINED
;
adod
.
dwVersion
=
acmGetVersion
();
adod
.
dwFlags
=
fdwOpen
;
adod
.
dwError
=
0
;
adod
.
pszSectionName
=
NULL
;
adod
.
pszAliasName
=
NULL
;
adod
.
dnDevNode
=
0
;
pad
->
pLocalDrvrInst
=
MSACM_OpenLocalDriver
(
padid
->
pLocalDriver
,
(
DWORD
)
&
adod
);
if
(
!
pad
->
pLocalDrvrInst
)
{
ret
=
adod
.
dwError
;
goto
gotError
;
}
}
/* insert new pad at beg of list */
/* insert new pad at beg of list */
pad
->
pNextACMDriver
=
padid
->
pACMDriverList
;
pad
->
pNextACMDriver
=
padid
->
pACMDriverList
;
...
...
dlls/msacm/internal.c
View file @
6c370766
This diff is collapsed.
Click to expand it.
dlls/msacm/wineacm.h
View file @
6c370766
...
@@ -292,6 +292,7 @@ typedef struct _WINE_ACMDRIVER *PWINE_ACMDRIVER;
...
@@ -292,6 +292,7 @@ typedef struct _WINE_ACMDRIVER *PWINE_ACMDRIVER;
#define WINE_ACMOBJ_DRIVER 0x5EED0002
#define WINE_ACMOBJ_DRIVER 0x5EED0002
#define WINE_ACMOBJ_STREAM 0x5EED0003
#define WINE_ACMOBJ_STREAM 0x5EED0003
#define WINE_ACMOBJ_NOTIFYWND 0x5EED0004
#define WINE_ACMOBJ_NOTIFYWND 0x5EED0004
#define WINE_ACMOBJ_LOCALDRIVER 0x5EED0005
typedef
struct
_WINE_ACMOBJ
typedef
struct
_WINE_ACMOBJ
{
{
...
@@ -299,10 +300,32 @@ typedef struct _WINE_ACMOBJ
...
@@ -299,10 +300,32 @@ typedef struct _WINE_ACMOBJ
PWINE_ACMDRIVERID
pACMDriverID
;
PWINE_ACMDRIVERID
pACMDriverID
;
}
WINE_ACMOBJ
,
*
PWINE_ACMOBJ
;
}
WINE_ACMOBJ
,
*
PWINE_ACMOBJ
;
typedef
struct
_WINE_ACMLOCALDRIVER
*
PWINE_ACMLOCALDRIVER
;
typedef
struct
_WINE_ACMLOCALDRIVERINST
*
PWINE_ACMLOCALDRIVERINST
;
typedef
struct
_WINE_ACMLOCALDRIVER
{
WINE_ACMOBJ
obj
;
HMODULE
hModule
;
DRIVERPROC
lpDrvProc
;
PWINE_ACMLOCALDRIVERINST
pACMInstList
;
PWINE_ACMLOCALDRIVER
pNextACMLocalDrv
;
PWINE_ACMLOCALDRIVER
pPrevACMLocalDrv
;
}
WINE_ACMLOCALDRIVER
;
typedef
struct
_WINE_ACMLOCALDRIVERINST
{
PWINE_ACMLOCALDRIVER
pLocalDriver
;
DWORD
dwDriverID
;
BOOL
bSession
;
PWINE_ACMLOCALDRIVERINST
pNextACMInst
;
}
WINE_ACMLOCALDRIVERINST
;
typedef
struct
_WINE_ACMDRIVER
typedef
struct
_WINE_ACMDRIVER
{
{
WINE_ACMOBJ
obj
;
WINE_ACMOBJ
obj
;
HDRVR
hDrvr
;
HDRVR
hDrvr
;
PWINE_ACMLOCALDRIVERINST
pLocalDrvrInst
;
PWINE_ACMDRIVER
pNextACMDriver
;
PWINE_ACMDRIVER
pNextACMDriver
;
}
WINE_ACMDRIVER
;
}
WINE_ACMDRIVER
;
...
@@ -319,7 +342,7 @@ typedef struct _WINE_ACMDRIVERID
...
@@ -319,7 +342,7 @@ typedef struct _WINE_ACMDRIVERID
WINE_ACMOBJ
obj
;
WINE_ACMOBJ
obj
;
LPWSTR
pszDriverAlias
;
LPWSTR
pszDriverAlias
;
LPWSTR
pszFileName
;
LPWSTR
pszFileName
;
HINSTANCE
hInstModule
;
/* NULL if global */
PWINE_ACMLOCALDRIVER
pLocalDriver
;
/* NULL if global */
PWINE_ACMDRIVER
pACMDriverList
;
PWINE_ACMDRIVER
pACMDriverList
;
PWINE_ACMDRIVERID
pNextACMDriverID
;
PWINE_ACMDRIVERID
pNextACMDriverID
;
PWINE_ACMDRIVERID
pPrevACMDriverID
;
PWINE_ACMDRIVERID
pPrevACMDriverID
;
...
@@ -349,7 +372,7 @@ extern HANDLE MSACM_hHeap;
...
@@ -349,7 +372,7 @@ extern HANDLE MSACM_hHeap;
extern
PWINE_ACMDRIVERID
MSACM_pFirstACMDriverID
;
extern
PWINE_ACMDRIVERID
MSACM_pFirstACMDriverID
;
extern
PWINE_ACMDRIVERID
MSACM_pLastACMDriverID
;
extern
PWINE_ACMDRIVERID
MSACM_pLastACMDriverID
;
extern
PWINE_ACMDRIVERID
MSACM_RegisterDriver
(
LPCWSTR
pszDriverAlias
,
LPCWSTR
pszFileName
,
extern
PWINE_ACMDRIVERID
MSACM_RegisterDriver
(
LPCWSTR
pszDriverAlias
,
LPCWSTR
pszFileName
,
HINSTANCE
hinstModule
);
PWINE_ACMLOCALDRIVER
pLocalDriver
);
extern
void
MSACM_RegisterAllDrivers
(
void
);
extern
void
MSACM_RegisterAllDrivers
(
void
);
extern
PWINE_ACMDRIVERID
MSACM_UnregisterDriver
(
PWINE_ACMDRIVERID
p
);
extern
PWINE_ACMDRIVERID
MSACM_UnregisterDriver
(
PWINE_ACMDRIVERID
p
);
extern
void
MSACM_UnregisterAllDrivers
(
void
);
extern
void
MSACM_UnregisterAllDrivers
(
void
);
...
@@ -371,6 +394,13 @@ extern PWINE_ACMNOTIFYWND MSACM_UnRegisterNotificationWindow(PWINE_ACMNOTIFYWND)
...
@@ -371,6 +394,13 @@ extern PWINE_ACMNOTIFYWND MSACM_UnRegisterNotificationWindow(PWINE_ACMNOTIFYWND)
extern
PWINE_ACMDRIVERID
MSACM_RegisterDriverFromRegistry
(
LPCWSTR
pszRegEntry
);
extern
PWINE_ACMDRIVERID
MSACM_RegisterDriverFromRegistry
(
LPCWSTR
pszRegEntry
);
extern
PWINE_ACMLOCALDRIVER
MSACM_RegisterLocalDriver
(
HMODULE
hModule
,
DRIVERPROC
lpDriverProc
);
extern
PWINE_ACMLOCALDRIVERINST
MSACM_OpenLocalDriver
(
PWINE_ACMLOCALDRIVER
,
LPARAM
);
extern
LRESULT
MSACM_CloseLocalDriver
(
PWINE_ACMLOCALDRIVERINST
);
extern
PWINE_ACMLOCALDRIVER
MSACM_UnregisterLocalDriver
(
PWINE_ACMLOCALDRIVER
);
/*
extern PWINE_ACMLOCALDRIVER MSACM_GetLocalDriver(HACMDRIVER hDriver);
*/
/* From msacm32.c */
/* From msacm32.c */
extern
HINSTANCE
MSACM_hInstance32
;
extern
HINSTANCE
MSACM_hInstance32
;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment