mirror of https://github.com/tongzx/nt5src
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
307 lines
12 KiB
307 lines
12 KiB
//==========================================================================;
|
|
//
|
|
// THIS CODE AND INFORMATION IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY
|
|
// KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
|
|
// IMPLIED WARRANTIES OF MERCHANTABILITY AND/OR FITNESS FOR A PARTICULAR
|
|
// PURPOSE.
|
|
//
|
|
// Copyright (c) 1992 - 1996 Microsoft Corporation. All Rights Reserved.
|
|
//
|
|
//==========================================================================;
|
|
|
|
#ifndef __SLIP_STREAM_H__
|
|
#define __SLIP_STREAM_H__
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif // __cplusplus
|
|
|
|
|
|
// ------------------------------------------------------------------------
|
|
// Property set for all video capture streams
|
|
// ------------------------------------------------------------------------
|
|
|
|
DEFINE_KSPROPERTY_TABLE(SlipConnectionProperties)
|
|
{
|
|
DEFINE_KSPROPERTY_ITEM
|
|
(
|
|
KSPROPERTY_CONNECTION_ALLOCATORFRAMING,
|
|
TRUE, // GetSupported or Handler
|
|
sizeof(KSPROPERTY), // MinProperty
|
|
sizeof(KSALLOCATOR_FRAMING), // MinData
|
|
FALSE, // SetSupported or Handler
|
|
NULL, // Values
|
|
0, // RelationsCount
|
|
NULL, // Relations
|
|
NULL, // SupportHandler
|
|
sizeof(ULONG) // SerializedSize
|
|
)
|
|
};
|
|
|
|
// ------------------------------------------------------------------------
|
|
// Array of all of the property sets supported by video streams
|
|
// ------------------------------------------------------------------------
|
|
|
|
DEFINE_KSPROPERTY_SET_TABLE(SlipStreamProperties)
|
|
{
|
|
DEFINE_KSPROPERTY_SET
|
|
(
|
|
&KSPROPSETID_Connection, // Set
|
|
SIZEOF_ARRAY(SlipConnectionProperties), // PropertiesCount
|
|
SlipConnectionProperties, // PropertyItems
|
|
0, // FastIoCount
|
|
NULL // FastIoTable
|
|
),
|
|
};
|
|
|
|
|
|
#define NUMBER_SLIP_STREAM_PROPERTIES (SIZEOF_ARRAY(SlipStreamProperties))
|
|
|
|
|
|
//---------------------------------------------------------------------------
|
|
// All of the video and vbi data formats we might use
|
|
//---------------------------------------------------------------------------
|
|
|
|
KSDATARANGE StreamFormatSlip =
|
|
{
|
|
//
|
|
// KSDATARANGE
|
|
//
|
|
sizeof (KSDATAFORMAT),
|
|
0,
|
|
1548, // sizeof a SLIP Packet
|
|
0, // Reserved
|
|
{ STATIC_KSDATAFORMAT_TYPE_BDA_IP },
|
|
{ STATIC_KSDATAFORMAT_SUBTYPE_BDA_IP },
|
|
{ STATIC_KSDATAFORMAT_SPECIFIER_BDA_IP }
|
|
};
|
|
|
|
KSDATARANGE StreamFormatIPv4 =
|
|
{
|
|
//
|
|
// KSDATARANGE
|
|
//
|
|
sizeof (KSDATAFORMAT),
|
|
0,
|
|
1548, // sizeof a IPv4 Packet
|
|
0, // Reserved
|
|
{ STATIC_KSDATAFORMAT_TYPE_BDA_IP },
|
|
{ STATIC_KSDATAFORMAT_SUBTYPE_BDA_IP },
|
|
{ STATIC_KSDATAFORMAT_SPECIFIER_BDA_IP }
|
|
};
|
|
|
|
|
|
KSDATARANGE StreamFormatNABTS =
|
|
{
|
|
sizeof (KSDATARANGE),
|
|
0,
|
|
sizeof (NABTS_BUFFER) + 8, //$$BUG NOTE Add 8
|
|
0, // Reserved
|
|
{ STATIC_KSDATAFORMAT_TYPE_NABTS },
|
|
{ STATIC_KSDATAFORMAT_SUBTYPE_NABTS },
|
|
{ STATIC_KSDATAFORMAT_SPECIFIER_NONE }
|
|
};
|
|
|
|
KSDATARANGE StreamFormatNABTSFEC =
|
|
{
|
|
sizeof (KSDATARANGE),
|
|
0,
|
|
sizeof (NABTSFEC_BUFFER),
|
|
0, // Reserved
|
|
{ STATIC_KSDATAFORMAT_TYPE_NABTS },
|
|
{ STATIC_KSDATAFORMAT_SUBTYPE_NABTS_FEC },
|
|
{ STATIC_KSDATAFORMAT_SPECIFIER_NONE }
|
|
};
|
|
|
|
|
|
//---------------------------------------------------------------------------
|
|
// STREAM_Input Formats
|
|
//---------------------------------------------------------------------------
|
|
|
|
static PKSDATAFORMAT Stream0Formats[] =
|
|
{
|
|
// (PKSDATAFORMAT) &StreamFormatNABTS,
|
|
(PKSDATAFORMAT) &StreamFormatNABTSFEC
|
|
|
|
|
|
// Add more formats here for to mirror output formats for "passthrough" mode
|
|
// The idea is that upstream capture drivers may have done some decoding already
|
|
// or downstream drivers may wish to have the raw data without any decoding at all.
|
|
// In that case all we need to do is copy the data(if there is a pending SRB) OR
|
|
// forward the SRB to the downstream client.
|
|
};
|
|
|
|
#define NUM_STREAM_0_FORMATS (SIZEOF_ARRAY(Stream0Formats))
|
|
|
|
|
|
//---------------------------------------------------------------------------
|
|
// STREAM_Output Formats
|
|
//---------------------------------------------------------------------------
|
|
|
|
static PKSDATAFORMAT Stream1Formats[] =
|
|
{
|
|
(PKSDATAFORMAT) &StreamFormatIPv4,
|
|
|
|
//
|
|
// Add more formats here for whatever output formats are supported.
|
|
//
|
|
};
|
|
#define NUM_STREAM_1_FORMATS (SIZEOF_ARRAY (Stream1Formats))
|
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
//---------------------------------------------------------------------------
|
|
// Create an array that holds the list of all of the streams supported
|
|
//---------------------------------------------------------------------------
|
|
|
|
typedef struct _ALL_STREAM_INFO
|
|
{
|
|
HW_STREAM_INFORMATION hwStreamInfo;
|
|
HW_STREAM_OBJECT hwStreamObject;
|
|
|
|
} ALL_STREAM_INFO, *PALL_STREAM_INFO;
|
|
|
|
static ALL_STREAM_INFO Streams [] =
|
|
{
|
|
//
|
|
// NABTS input stream
|
|
//
|
|
|
|
{
|
|
// HW_STREAM_INFORMATION -------------------------------------------
|
|
{
|
|
1, // NumberOfPossibleInstances
|
|
KSPIN_DATAFLOW_IN, // DataFlow
|
|
TRUE, // DataAccessible
|
|
NUM_STREAM_0_FORMATS, // NumberOfFormatArrayEntries
|
|
Stream0Formats, // StreamFormatsArray
|
|
0, // ClassReserved[0]
|
|
0, // ClassReserved[1]
|
|
0, // ClassReserved[2]
|
|
0, // ClassReserved[3]
|
|
NUMBER_SLIP_STREAM_PROPERTIES, // Number of stream properties
|
|
(PKSPROPERTY_SET) SlipStreamProperties, // Stream Property Array
|
|
0, // NumStreamEventArrayEntries
|
|
0, // StreamEventsArray
|
|
NULL, // Category
|
|
(GUID *)&PINNAME_VIDEO_NABTS, // Name
|
|
0, // MediumsCount
|
|
NULL, // Mediums
|
|
},
|
|
|
|
// HW_STREAM_OBJECT ------------------------------------------------
|
|
{
|
|
sizeof (HW_STREAM_OBJECT), // SizeOfThisPacket
|
|
0, // StreamNumber
|
|
(PVOID)NULL, // HwStreamExtension
|
|
ReceiveDataPacket,
|
|
ReceiveCtrlPacket,
|
|
{ // HW_CLOCK_OBJECT
|
|
NULL, // .HWClockFunction
|
|
0, // .ClockSupportFlags
|
|
},
|
|
FALSE, // Dma
|
|
TRUE, // Pio
|
|
(PVOID)NULL, // HwDeviceExtension
|
|
0, // StreamHeaderMediaSpecific
|
|
0, // StreamHeaderWorkspace
|
|
TRUE, // Allocator
|
|
NULL, // HwEventRoutine
|
|
},
|
|
},
|
|
|
|
//
|
|
// IPv4 Control Interface Pin
|
|
//
|
|
{
|
|
// HW_STREAM_INFORMATION -------------------------------------------
|
|
{
|
|
1, // NumberOfPossibleInstances
|
|
KSPIN_DATAFLOW_OUT, // DataFlow
|
|
TRUE, // DataAccessible
|
|
NUM_STREAM_1_FORMATS, // NumberOfFormatArrayEntries
|
|
Stream1Formats, // StreamFormatsArray
|
|
0, // ClassReserved[0]
|
|
0, // ClassReserved[1]
|
|
0, // ClassReserved[2]
|
|
0, // ClassReserved[3]
|
|
NUMBER_SLIP_STREAM_PROPERTIES, // Number of stream properties
|
|
(PKSPROPERTY_SET) SlipStreamProperties, // Stream Property Array
|
|
0, // NumStreamEventArrayEntries
|
|
0, // StreamEventsArray
|
|
NULL, // Category
|
|
(GUID *)&PINNAME_IPSINK_INPUT, // Name
|
|
0, // MediumsCount
|
|
NULL, // Mediums
|
|
},
|
|
|
|
// HW_STREAM_OBJECT ------------------------------------------------
|
|
{
|
|
sizeof (HW_STREAM_OBJECT), // SizeOfThisPacket
|
|
0, // StreamNumber
|
|
(PVOID)NULL, // HwStreamExtension
|
|
ReceiveDataPacket, // HwReceiveDataPacket Handler
|
|
ReceiveCtrlPacket, // HwReceiveControlPacket Handler
|
|
{ // HW_CLOCK_OBJECT
|
|
NULL, // .HWClockFunction
|
|
0, // .ClockSupportFlags
|
|
},
|
|
FALSE, // Dma
|
|
TRUE, // Pio
|
|
(PVOID)NULL, // HwDeviceExtension
|
|
0, // StreamHeaderMediaSpecific
|
|
0, // StreamHeaderWorkspace
|
|
TRUE, // Allocator
|
|
NULL, // HwEventRoutine
|
|
},
|
|
}
|
|
|
|
};
|
|
|
|
#define DRIVER_STREAM_COUNT (SIZEOF_ARRAY (Streams))
|
|
|
|
|
|
//---------------------------------------------------------------------------
|
|
// Topology
|
|
//---------------------------------------------------------------------------
|
|
|
|
// Categories define what the device does.
|
|
|
|
static GUID Categories[] =
|
|
{
|
|
STATIC_KSCATEGORY_BDA_RECEIVER_COMPONENT
|
|
};
|
|
|
|
#define NUMBER_OF_CATEGORIES SIZEOF_ARRAY (Categories)
|
|
|
|
static KSTOPOLOGY Topology = {
|
|
NUMBER_OF_CATEGORIES,
|
|
(GUID*) &Categories,
|
|
0,
|
|
(GUID*) NULL,
|
|
0,
|
|
NULL
|
|
};
|
|
|
|
|
|
//---------------------------------------------------------------------------
|
|
// The Main stream header
|
|
//---------------------------------------------------------------------------
|
|
|
|
static HW_STREAM_HEADER StreamHeader =
|
|
{
|
|
DRIVER_STREAM_COUNT, // NumberOfStreams
|
|
sizeof (HW_STREAM_INFORMATION), // Future proofing
|
|
0, // NumDevPropArrayEntries set at init time
|
|
NULL, // DevicePropertiesArray set at init time
|
|
0, // NumDevEventArrayEntries;
|
|
NULL, // DeviceEventsArray;
|
|
&Topology // Pointer to Device Topology
|
|
};
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif // __cplusplus
|
|
|
|
#endif // __SLIP_STREAM_H__
|
|
|