mirror of
https://github.com/reactos/reactos.git
synced 2025-01-01 12:04:51 +00:00
139 lines
2.6 KiB
C++
139 lines
2.6 KiB
C++
/*
|
|
ReactOS Kernel Streaming
|
|
Digital Rights Management
|
|
|
|
Please see COPYING in the top-level directory for license information.
|
|
|
|
Author: Andrew Greenwood
|
|
|
|
Notes:
|
|
This is just a file containing stub functions. The DRMK kernel library
|
|
deals with Digital Rights Management. This is not essential for the
|
|
operation of audio/video (except in the cases where content has digital
|
|
rights information) but is needed for linking with PORTCLS.
|
|
*/
|
|
|
|
#include <ntddk.h>
|
|
#include <portcls.h>
|
|
#include <debug.h>
|
|
|
|
/*
|
|
Provide a driver interface consisting of functions for handling DRM
|
|
protected content
|
|
*/
|
|
/*
|
|
* @unimplemented
|
|
*/
|
|
NTSTATUS
|
|
NTAPI
|
|
DrmAddContentHandlers(
|
|
IN ULONG ContentId,
|
|
IN PVOID *paHandlers,
|
|
IN ULONG NumHandlers)
|
|
{
|
|
UNIMPLEMENTED;
|
|
return STATUS_UNSUCCESSFUL;
|
|
}
|
|
|
|
/*
|
|
Creates a DRM content ID to identify a KS audio stream containing
|
|
mixed content from several input streams.
|
|
*/
|
|
/*
|
|
* @unimplemented
|
|
*/
|
|
NTSTATUS
|
|
NTAPI
|
|
DrmCreateContentMixed(
|
|
IN PULONG paContentId,
|
|
IN ULONG cContentId,
|
|
OUT PULONG pMixedContentId)
|
|
{
|
|
UNIMPLEMENTED;
|
|
return STATUS_UNSUCCESSFUL;
|
|
}
|
|
|
|
/*
|
|
Deletes a DRM content ID.
|
|
*/
|
|
/*
|
|
* @unimplemented
|
|
*/
|
|
NTSTATUS
|
|
NTAPI
|
|
DrmDestroyContent(
|
|
IN ULONG ContentId)
|
|
{
|
|
UNIMPLEMENTED;
|
|
return STATUS_UNSUCCESSFUL;
|
|
}
|
|
|
|
/*
|
|
Authenticates a driver, then passes it the DRM content ID, along with
|
|
the content rights which have been assigned to a stream.
|
|
*/
|
|
/*
|
|
* @unimplemented
|
|
*/
|
|
NTSTATUS
|
|
NTAPI
|
|
DrmForwardContentToDeviceObject(
|
|
IN ULONG ContentId,
|
|
IN PVOID Reserved,
|
|
IN PCDRMFORWARD DrmForward)
|
|
{
|
|
UNIMPLEMENTED;
|
|
return STATUS_UNSUCCESSFUL;
|
|
}
|
|
|
|
/*
|
|
Obsolete because it forces the system to run at a lower DRM security
|
|
level. Returns STATUS_NOT_IMPLEMENTED if a pin associated with
|
|
FileObject doesnt support the rights assigned to ContentId.
|
|
*/
|
|
/*
|
|
* @unimplemented
|
|
*/
|
|
NTSTATUS
|
|
NTAPI
|
|
DrmForwardContentToFileObject(
|
|
IN ULONG ContentId,
|
|
IN PFILE_OBJECT FileObject)
|
|
{
|
|
UNIMPLEMENTED;
|
|
return STATUS_UNSUCCESSFUL;
|
|
}
|
|
|
|
/*
|
|
Similar to DrmForwardContentToDeviceObject, except this works with a driver
|
|
object rather than just a driver.
|
|
*/
|
|
/*
|
|
* @unimplemented
|
|
*/
|
|
NTSTATUS
|
|
NTAPI
|
|
DrmForwardContentToInterface(
|
|
IN ULONG ContentId,
|
|
IN PUNKNOWN pUnknown,
|
|
IN ULONG NumMethods)
|
|
{
|
|
UNIMPLEMENTED;
|
|
return STATUS_UNSUCCESSFUL;
|
|
}
|
|
|
|
/*
|
|
Retrieves DRM Content rights that have been assigned to a DRM Content ID.
|
|
*/
|
|
/*
|
|
* @unimplemented
|
|
*/
|
|
NTSTATUS
|
|
NTAPI
|
|
DrmGetContentRights(
|
|
IN ULONG ContentId,
|
|
OUT PDRMRIGHTS DrmRights)
|
|
{
|
|
UNIMPLEMENTED;
|
|
return STATUS_UNSUCCESSFUL;
|
|
}
|