mirror of
https://github.com/reactos/reactos.git
synced 2025-01-12 09:07:54 +00:00
c424146e2c
svn path=/branches/cmake-bringup/; revision=48236
258 lines
6.9 KiB
C
258 lines
6.9 KiB
C
/*
|
|
* KSUSER.DLL - ReactOS
|
|
*
|
|
* Copyright 2008 Magnus Olsen and Dmitry Chapyshev
|
|
*
|
|
* This library is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
* License as published by the Free Software Foundation; either
|
|
* version 2.1 of the License, or (at your option) any later version.
|
|
*
|
|
* This library 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
|
|
* Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
* License along with this library; if not, write to the Free Software
|
|
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
|
|
*/
|
|
|
|
|
|
#include "ksuser.h"
|
|
#define NDEBUG
|
|
#include <debug.h>
|
|
|
|
NTSTATUS NTAPI KsiCreateObjectType( HANDLE hHandle, PVOID guidstr, PVOID Buffer, ULONG BufferSize, ACCESS_MASK DesiredAccess, PHANDLE phHandle);
|
|
|
|
NTSTATUS
|
|
NTAPI
|
|
KsiCreateObjectType( HANDLE hHandle,
|
|
PVOID IID,
|
|
PVOID Buffer,
|
|
ULONG BufferSize,
|
|
ACCESS_MASK DesiredAccess,
|
|
PHANDLE phHandle)
|
|
{
|
|
NTSTATUS Status;
|
|
ULONG Length;
|
|
ULONG TotalSize;
|
|
LPWSTR pStr;
|
|
UNICODE_STRING ObjectName;
|
|
OBJECT_ATTRIBUTES ObjectAttributes;
|
|
IO_STATUS_BLOCK IoStatusBlock;
|
|
|
|
Length = wcslen(IID);
|
|
|
|
TotalSize = (Length * sizeof(WCHAR)) + BufferSize + 4 * sizeof(WCHAR);
|
|
|
|
pStr = HeapAlloc(GetProcessHeap(), 0, TotalSize);
|
|
if (!pStr)
|
|
return STATUS_INSUFFICIENT_RESOURCES;
|
|
pStr[0] = L'\\';
|
|
wcscpy(&pStr[1], (LPWSTR)IID);
|
|
pStr[Length+1] = L'\\';
|
|
memcpy(&pStr[Length+2], Buffer, BufferSize);
|
|
pStr[Length+3+(BufferSize/sizeof(WCHAR))] = L'\0';
|
|
|
|
RtlInitUnicodeString(&ObjectName, pStr);
|
|
ObjectName.Length = ObjectName.MaximumLength = TotalSize;
|
|
|
|
InitializeObjectAttributes(&ObjectAttributes, &ObjectName, OBJ_CASE_INSENSITIVE, hHandle, NULL);
|
|
|
|
Status = NtCreateFile(phHandle, DesiredAccess, &ObjectAttributes, &IoStatusBlock, NULL, FILE_ATTRIBUTE_NORMAL, 0, 1, 0, NULL, 0);
|
|
HeapFree(GetProcessHeap(), 0, pStr);
|
|
if (!NT_SUCCESS(Status))
|
|
{
|
|
*phHandle = INVALID_HANDLE_VALUE;
|
|
Status = RtlNtStatusToDosError(Status);
|
|
}
|
|
return Status;
|
|
}
|
|
|
|
/*++
|
|
* @name KsCreateAllocator
|
|
* @implemented
|
|
* The function KsCreateAllocator creates a handle to an allocator for the given sink connection handle
|
|
*
|
|
* @param HANDLE ConnectionHandle
|
|
* Handle to the sink connection on which to create the allocator
|
|
*
|
|
* @param PKSALLOCATOR_FRAMING AllocatorFraming
|
|
* the input param we using to alloc our framing
|
|
*
|
|
* @param PHANDLE AllocatorHandle
|
|
* Our new handle that we have alloc
|
|
*
|
|
* @return
|
|
* Return NTSTATUS error code or sussess code.
|
|
*
|
|
* @remarks.
|
|
* none
|
|
*
|
|
*--*/
|
|
KSDDKAPI
|
|
DWORD
|
|
NTAPI
|
|
KsCreateAllocator(HANDLE ConnectionHandle,
|
|
PKSALLOCATOR_FRAMING AllocatorFraming,
|
|
PHANDLE AllocatorHandle)
|
|
|
|
{
|
|
return KsiCreateObjectType( ConnectionHandle,
|
|
KSSTRING_Allocator,
|
|
(PVOID) AllocatorFraming,
|
|
sizeof(KSALLOCATOR_FRAMING),
|
|
GENERIC_READ,
|
|
AllocatorHandle);
|
|
}
|
|
|
|
/*++
|
|
* @name KsCreateClock
|
|
* @implemented
|
|
*
|
|
* The function KsCreateClock creates handle to clock instance
|
|
*
|
|
* @param HANDLE ConnectionHandle
|
|
* Handle to use to create the clock
|
|
*
|
|
* @param PKSCLOCK_CREATE ClockCreate
|
|
* paramenter to use to create the clock
|
|
*
|
|
* @param PHANDLE ClockHandle
|
|
* The new handle
|
|
*
|
|
* @return
|
|
* Return NTSTATUS error code or sussess code.
|
|
*
|
|
* @remarks.
|
|
* none
|
|
*
|
|
*--*/
|
|
KSDDKAPI
|
|
DWORD
|
|
NTAPI
|
|
KsCreateClock(HANDLE ConnectionHandle,
|
|
PKSCLOCK_CREATE ClockCreate,
|
|
PHANDLE ClockHandle)
|
|
{
|
|
return KsiCreateObjectType( ConnectionHandle,
|
|
KSSTRING_Clock,
|
|
(PVOID) ClockCreate,
|
|
sizeof(KSCLOCK_CREATE),
|
|
GENERIC_READ,
|
|
ClockHandle);
|
|
}
|
|
|
|
/*++
|
|
* @name KsCreatePin
|
|
* @implemented
|
|
*
|
|
* The function KsCreatePin passes a connection request to device and create pin instance
|
|
*
|
|
* @param HANDLE FilterHandle
|
|
* handle of the filter initiating the create request
|
|
*
|
|
* @param PKSPIN_CONNECT Connect
|
|
* Pointer to a KSPIN_CONNECT structure that contains parameters for the requested connection.
|
|
* This should be followed in memory by a KSDATAFORMAT data structure, describing the data format
|
|
* requested for the connection.
|
|
|
|
* @param ACCESS_MASK DesiredAccess
|
|
* Desrided access
|
|
*
|
|
* @param PHANDLE ConnectionHandle
|
|
* connection handle passed
|
|
*
|
|
* @return
|
|
* Return NTSTATUS error code or sussess code.
|
|
*
|
|
* @remarks.
|
|
* The flag in PKSDATAFORMAT is not really document,
|
|
* to find it u need api mointor allot api and figout
|
|
* how it works, only flag I have found is the
|
|
* KSDATAFORMAT_ATTRIBUTES flag, it doing a Align
|
|
* of LONLONG size, it also round up it.
|
|
*
|
|
*--*/
|
|
|
|
KSDDKAPI
|
|
DWORD
|
|
NTAPI
|
|
KsCreatePin(HANDLE FilterHandle,
|
|
PKSPIN_CONNECT Connect,
|
|
ACCESS_MASK DesiredAccess,
|
|
PHANDLE ConnectionHandle)
|
|
{
|
|
ULONG BufferSize = sizeof(KSPIN_CONNECT);
|
|
PKSDATAFORMAT DataFormat = ((PKSDATAFORMAT) ((ULONG_PTR)Connect + sizeof(KSPIN_CONNECT)));
|
|
|
|
BufferSize += DataFormat->FormatSize;
|
|
|
|
return KsiCreateObjectType(FilterHandle,
|
|
KSSTRING_Pin,
|
|
Connect,
|
|
BufferSize,
|
|
DesiredAccess,
|
|
ConnectionHandle);
|
|
|
|
}
|
|
|
|
/*++
|
|
* @name KsCreateTopologyNode
|
|
* @implemented
|
|
*
|
|
* The function KsCreateTopologyNode creates a handle to a topology node instance
|
|
*
|
|
* @param HANDLE ParentHandle
|
|
* Handle to parent when want to use when we created the node on
|
|
*
|
|
*
|
|
* @param PKSNODE_CREATE NodeCreate
|
|
* topology node parameters to use when it is create
|
|
*
|
|
* @param ACCESS_MASK DesiredAccess
|
|
* Desrided access
|
|
*
|
|
* @param PHANDLE NodeHandle
|
|
* Location for the topology node handle
|
|
*
|
|
* @return
|
|
* Return NTSTATUS error code or sussess code.
|
|
*
|
|
* @remarks.
|
|
* none
|
|
*
|
|
*--*/
|
|
KSDDKAPI
|
|
DWORD
|
|
NTAPI
|
|
KsCreateTopologyNode(HANDLE ParentHandle,
|
|
PKSNODE_CREATE NodeCreate,
|
|
IN ACCESS_MASK DesiredAccess,
|
|
OUT PHANDLE NodeHandle)
|
|
{
|
|
return KsiCreateObjectType( ParentHandle,
|
|
KSSTRING_TopologyNode,
|
|
(PVOID) NodeCreate,
|
|
sizeof(KSNODE_CREATE),
|
|
DesiredAccess,
|
|
NodeHandle);
|
|
}
|
|
|
|
|
|
BOOL
|
|
APIENTRY
|
|
DllMain(HANDLE hModule, DWORD ulreason, LPVOID lpReserved)
|
|
{
|
|
switch (ulreason)
|
|
{
|
|
case DLL_PROCESS_ATTACH:
|
|
case DLL_THREAD_ATTACH:
|
|
case DLL_THREAD_DETACH:
|
|
case DLL_PROCESS_DETACH:
|
|
break;
|
|
}
|
|
|
|
return TRUE;
|
|
}
|