mirror of
https://github.com/reactos/reactos.git
synced 2025-04-04 20:50:41 +00:00
Pluged in CallMsgFilter, I tested this and no crashes on real hardware.
svn path=/trunk/; revision=15935
This commit is contained in:
parent
8f5dd38cdd
commit
2054ea72e9
3 changed files with 181 additions and 181 deletions
|
@ -1,171 +1,171 @@
|
|||
/*
|
||||
* ReactOS W32 Subsystem
|
||||
* Copyright (C) 2005 ReactOS Team
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation; either version 2 of the License, or
|
||||
* (at your option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
*/
|
||||
/*
|
||||
* COPYRIGHT: See COPYING in the top level directory
|
||||
* PROJECT: ReactOS kernel
|
||||
* PURPOSE: GDI DRIVEROBJ Functions
|
||||
* FILE: subsys/win32k/eng/driverobj.c
|
||||
* PROGRAMER: Gregor Anich
|
||||
* REVISION HISTORY:
|
||||
* 04/01/2005: Created
|
||||
*/
|
||||
#include <w32k.h>
|
||||
|
||||
|
||||
/*!\brief Called when the process is terminated.
|
||||
*
|
||||
* Calls the free-proc for each existing DRIVEROBJ.
|
||||
*
|
||||
* \param Process Pointer to the EPROCESS struct for the process beeing terminated.
|
||||
* \param Win32Process Pointer to the W32PROCESS
|
||||
*/
|
||||
VOID FASTCALL
|
||||
IntEngCleanupDriverObjs(struct _EPROCESS *Process,
|
||||
PW32PROCESS Win32Process)
|
||||
{
|
||||
PDRIVERGDI DrvObjInt;
|
||||
|
||||
IntEngLockProcessDriverObjs(PsGetWin32Process());
|
||||
while (!IsListEmpty(&Win32Process->DriverObjListHead))
|
||||
{
|
||||
DrvObjInt = CONTAINING_RECORD(Win32Process->DriverObjListHead.Flink,
|
||||
DRIVERGDI, ListEntry);
|
||||
IntEngUnLockProcessDriverObjs(PsGetWin32Process());
|
||||
EngDeleteDriverObj((HDRVOBJ)(&DrvObjInt->DriverObj), TRUE, FALSE);
|
||||
IntEngLockProcessDriverObjs(PsGetWin32Process());
|
||||
}
|
||||
IntEngUnLockProcessDriverObjs(PsGetWin32Process());
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
* @implemented
|
||||
*/
|
||||
HDRVOBJ
|
||||
STDCALL
|
||||
EngCreateDriverObj(
|
||||
IN PVOID pvObj,
|
||||
IN FREEOBJPROC pFreeObjProc,
|
||||
IN HDEV hdev
|
||||
)
|
||||
{
|
||||
PDRIVERGDI DrvObjInt;
|
||||
PDRIVEROBJ DrvObjUser;
|
||||
|
||||
/* Create DRIVEROBJ */
|
||||
DrvObjInt = EngAllocMem(0, sizeof (DRIVERGDI), TAG_DRIVEROBJ);
|
||||
if (DrvObjInt == NULL)
|
||||
{
|
||||
DPRINT1("Failed to allocate memory for a DRIVERGDI structure!\n");
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/* fill user object */
|
||||
DrvObjUser = GDIToObj(DrvObjInt, DRIVER);
|
||||
DrvObjUser->pvObj = pvObj;
|
||||
DrvObjUser->pFreeProc = pFreeObjProc;
|
||||
DrvObjUser->hdev = hdev;
|
||||
DrvObjUser->dhpdev = ((GDIDEVICE*)hdev)->PDev;
|
||||
|
||||
/* fill internal object */
|
||||
ExInitializeFastMutex(&DrvObjInt->Lock);
|
||||
IntEngLockProcessDriverObjs(PsGetWin32Process());
|
||||
InsertTailList(&PsGetWin32Process()->DriverObjListHead, &DrvObjInt->ListEntry);
|
||||
IntEngUnLockProcessDriverObjs(PsGetWin32Process());
|
||||
|
||||
return (HDRVOBJ)DrvObjUser;
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
* @implemented
|
||||
*/
|
||||
BOOL
|
||||
STDCALL
|
||||
EngDeleteDriverObj(
|
||||
IN HDRVOBJ hdo,
|
||||
IN BOOL bCallBack,
|
||||
IN BOOL bLocked
|
||||
)
|
||||
{
|
||||
PDRIVEROBJ DrvObjUser = (PDRIVEROBJ)hdo;
|
||||
PDRIVERGDI DrvObjInt = ObjToGDI(DrvObjUser, DRIVER);
|
||||
|
||||
/* Make sure the obj is locked */
|
||||
if (!bLocked)
|
||||
{
|
||||
if (!ExTryToAcquireFastMutex(&DrvObjInt->Lock))
|
||||
{
|
||||
return FALSE;
|
||||
}
|
||||
}
|
||||
|
||||
/* Call the free-proc */
|
||||
if (bCallBack)
|
||||
{
|
||||
if (!DrvObjUser->pFreeProc(DrvObjUser))
|
||||
{
|
||||
return FALSE;
|
||||
}
|
||||
}
|
||||
|
||||
/* Free the DRIVEROBJ */
|
||||
IntEngLockProcessDriverObjs(PsGetWin32Process());
|
||||
RemoveEntryList(&DrvObjInt->ListEntry);
|
||||
IntEngUnLockProcessDriverObjs(PsGetWin32Process());
|
||||
EngFreeMem(DrvObjInt);
|
||||
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
* @implemented
|
||||
*/
|
||||
PDRIVEROBJ
|
||||
STDCALL
|
||||
EngLockDriverObj( IN HDRVOBJ hdo )
|
||||
{
|
||||
PDRIVEROBJ DrvObjUser = (PDRIVEROBJ)hdo;
|
||||
PDRIVERGDI DrvObjInt = ObjToGDI(DrvObjUser, DRIVER);
|
||||
|
||||
if (!ExTryToAcquireFastMutex(&DrvObjInt->Lock))
|
||||
{
|
||||
return NULL;
|
||||
}
|
||||
|
||||
return DrvObjUser;
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
* @implemented
|
||||
*/
|
||||
BOOL
|
||||
STDCALL
|
||||
EngUnlockDriverObj ( IN HDRVOBJ hdo )
|
||||
{
|
||||
PDRIVERGDI DrvObjInt = ObjToGDI((PDRIVEROBJ)hdo, DRIVER);
|
||||
|
||||
ExReleaseFastMutex(&DrvObjInt->Lock);
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
/* EOF */
|
||||
|
||||
/*
|
||||
* ReactOS W32 Subsystem
|
||||
* Copyright (C) 2005 ReactOS Team
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation; either version 2 of the License, or
|
||||
* (at your option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
*/
|
||||
/*
|
||||
* COPYRIGHT: See COPYING in the top level directory
|
||||
* PROJECT: ReactOS kernel
|
||||
* PURPOSE: GDI DRIVEROBJ Functions
|
||||
* FILE: subsys/win32k/eng/driverobj.c
|
||||
* PROGRAMER: Gregor Anich
|
||||
* REVISION HISTORY:
|
||||
* 04/01/2005: Created
|
||||
*/
|
||||
#include <w32k.h>
|
||||
|
||||
|
||||
/*!\brief Called when the process is terminated.
|
||||
*
|
||||
* Calls the free-proc for each existing DRIVEROBJ.
|
||||
*
|
||||
* \param Process Pointer to the EPROCESS struct for the process beeing terminated.
|
||||
* \param Win32Process Pointer to the W32PROCESS
|
||||
*/
|
||||
VOID FASTCALL
|
||||
IntEngCleanupDriverObjs(struct _EPROCESS *Process,
|
||||
PW32PROCESS Win32Process)
|
||||
{
|
||||
PDRIVERGDI DrvObjInt;
|
||||
|
||||
IntEngLockProcessDriverObjs(PsGetWin32Process());
|
||||
while (!IsListEmpty(&Win32Process->DriverObjListHead))
|
||||
{
|
||||
DrvObjInt = CONTAINING_RECORD(Win32Process->DriverObjListHead.Flink,
|
||||
DRIVERGDI, ListEntry);
|
||||
IntEngUnLockProcessDriverObjs(PsGetWin32Process());
|
||||
EngDeleteDriverObj((HDRVOBJ)(&DrvObjInt->DriverObj), TRUE, FALSE);
|
||||
IntEngLockProcessDriverObjs(PsGetWin32Process());
|
||||
}
|
||||
IntEngUnLockProcessDriverObjs(PsGetWin32Process());
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
* @implemented
|
||||
*/
|
||||
HDRVOBJ
|
||||
STDCALL
|
||||
EngCreateDriverObj(
|
||||
IN PVOID pvObj,
|
||||
IN FREEOBJPROC pFreeObjProc,
|
||||
IN HDEV hdev
|
||||
)
|
||||
{
|
||||
PDRIVERGDI DrvObjInt;
|
||||
PDRIVEROBJ DrvObjUser;
|
||||
|
||||
/* Create DRIVEROBJ */
|
||||
DrvObjInt = EngAllocMem(0, sizeof (DRIVERGDI), TAG_DRIVEROBJ);
|
||||
if (DrvObjInt == NULL)
|
||||
{
|
||||
DPRINT1("Failed to allocate memory for a DRIVERGDI structure!\n");
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/* fill user object */
|
||||
DrvObjUser = GDIToObj(DrvObjInt, DRIVER);
|
||||
DrvObjUser->pvObj = pvObj;
|
||||
DrvObjUser->pFreeProc = pFreeObjProc;
|
||||
DrvObjUser->hdev = hdev;
|
||||
DrvObjUser->dhpdev = ((GDIDEVICE*)hdev)->PDev;
|
||||
|
||||
/* fill internal object */
|
||||
ExInitializeFastMutex(&DrvObjInt->Lock);
|
||||
IntEngLockProcessDriverObjs(PsGetWin32Process());
|
||||
InsertTailList(&PsGetWin32Process()->DriverObjListHead, &DrvObjInt->ListEntry);
|
||||
IntEngUnLockProcessDriverObjs(PsGetWin32Process());
|
||||
|
||||
return (HDRVOBJ)DrvObjUser;
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
* @implemented
|
||||
*/
|
||||
BOOL
|
||||
STDCALL
|
||||
EngDeleteDriverObj(
|
||||
IN HDRVOBJ hdo,
|
||||
IN BOOL bCallBack,
|
||||
IN BOOL bLocked
|
||||
)
|
||||
{
|
||||
PDRIVEROBJ DrvObjUser = (PDRIVEROBJ)hdo;
|
||||
PDRIVERGDI DrvObjInt = ObjToGDI(DrvObjUser, DRIVER);
|
||||
|
||||
/* Make sure the obj is locked */
|
||||
if (!bLocked)
|
||||
{
|
||||
if (!ExTryToAcquireFastMutex(&DrvObjInt->Lock))
|
||||
{
|
||||
return FALSE;
|
||||
}
|
||||
}
|
||||
|
||||
/* Call the free-proc */
|
||||
if (bCallBack)
|
||||
{
|
||||
if (!DrvObjUser->pFreeProc(DrvObjUser))
|
||||
{
|
||||
return FALSE;
|
||||
}
|
||||
}
|
||||
|
||||
/* Free the DRIVEROBJ */
|
||||
IntEngLockProcessDriverObjs(PsGetWin32Process());
|
||||
RemoveEntryList(&DrvObjInt->ListEntry);
|
||||
IntEngUnLockProcessDriverObjs(PsGetWin32Process());
|
||||
EngFreeMem(DrvObjInt);
|
||||
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
* @implemented
|
||||
*/
|
||||
PDRIVEROBJ
|
||||
STDCALL
|
||||
EngLockDriverObj( IN HDRVOBJ hdo )
|
||||
{
|
||||
PDRIVEROBJ DrvObjUser = (PDRIVEROBJ)hdo;
|
||||
PDRIVERGDI DrvObjInt = ObjToGDI(DrvObjUser, DRIVER);
|
||||
|
||||
if (!ExTryToAcquireFastMutex(&DrvObjInt->Lock))
|
||||
{
|
||||
return NULL;
|
||||
}
|
||||
|
||||
return DrvObjUser;
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
* @implemented
|
||||
*/
|
||||
BOOL
|
||||
STDCALL
|
||||
EngUnlockDriverObj ( IN HDRVOBJ hdo )
|
||||
{
|
||||
PDRIVERGDI DrvObjInt = ObjToGDI((PDRIVEROBJ)hdo, DRIVER);
|
||||
|
||||
ExReleaseFastMutex(&DrvObjInt->Lock);
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
/* EOF */
|
||||
|
||||
|
|
|
@ -291,6 +291,16 @@ UnpackParam(LPARAM lParamPacked, UINT Msg, WPARAM wParam, LPARAM lParam)
|
|||
return STATUS_INVALID_PARAMETER;
|
||||
}
|
||||
|
||||
BOOL
|
||||
STDCALL
|
||||
NtUserCallMsgFilter(
|
||||
LPMSG msg,
|
||||
INT code)
|
||||
{
|
||||
|
||||
if (HOOK_CallHooks( WH_SYSMSGFILTER, code, 0, (LPARAM)msg)) return TRUE;
|
||||
return HOOK_CallHooks( WH_MSGFILTER, code, 0, (LPARAM)msg);
|
||||
}
|
||||
|
||||
LRESULT STDCALL
|
||||
NtUserDispatchMessage(PNTUSERDISPATCHMESSAGEINFO UnsafeMsgInfo)
|
||||
|
|
|
@ -99,16 +99,6 @@ NtUserCallHwndParamLock(
|
|||
return 0;
|
||||
}
|
||||
|
||||
DWORD
|
||||
STDCALL
|
||||
NtUserCallMsgFilter(
|
||||
DWORD Unknown0,
|
||||
DWORD Unknown1)
|
||||
{
|
||||
UNIMPLEMENTED
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
DWORD
|
||||
STDCALL
|
||||
|
|
Loading…
Reference in a new issue