Настройка фильтра BDA
Мини-диск BDA обрабатывает запросы методов набора методов KSMETHODSETID_BdaDeviceConfiguration для настройки экземпляра фильтра для мини-драйвера в текущем графе фильтров.
В следующем фрагменте кода два метода набора методов KSMETHODSETID_BdaDeviceConfiguration отправляются непосредственно в библиотеку поддержки BDA, а оставшийся метод сначала перехватывается мини-накопителем BDA перед отправкой в библиотеку поддержки BDA.
//
// BDA Device Configuration Method Set
//
// Defines the dispatch routines for the filter level
// topology configuration methods
//
DEFINE_KSMETHOD_TABLE(BdaDeviceConfigurationMethods)
{
DEFINE_KSMETHOD_ITEM_BDA_CREATE_PIN_FACTORY(
BdaMethodCreatePin,
NULL
),
DEFINE_KSMETHOD_ITEM_BDA_DELETE_PIN_FACTORY(
BdaMethodDeletePin,
NULL
),
DEFINE_KSMETHOD_ITEM_BDA_CREATE_TOPOLOGY(
CFilter::CreateTopology,
NULL
)
};
/*
** CreateTopology()
**
** Keeps track of topology association between input and output pins
**
*/
NTSTATUS
CFilter::
CreateTopology(
IN PIRP pIrp,
IN PKSMETHOD pKSMethod,
PVOID pvIgnored
)
{
NTSTATUS Status = STATUS_SUCCESS;
CFilter * pFilter;
ULONG ulPinType;
PKSFILTER pKSFilter;
ASSERT( pIrp);
ASSERT( pKSMethod);
// Obtain a "this" pointer for the method.
//
// Because this function is called directly from the property
// dispatch table, get pointer to the underlying object.
//
pFilter = FilterFromIRP( pIrp);
ASSERT( pFilter);
if (!pFilter)
{
Status = STATUS_INVALID_PARAMETER;
goto errExit;
}
// Let the BDA support library create the standard topology.
// It will also validate the method, instance count, etc.
//
Status = BdaMethodCreateTopology( pIrp, pKSMethod, pvIgnored);
if (Status != STATUS_SUCCESS)
{
goto errExit;
}
// This is where the filter can keep track of associated pins.
//
errExit:
return Status;
}
Запрос метода KSMETHOD_BDA_CREATE_TOPOLOGY вызывает метод CFilter::CreateTopology мини-драйвера. Этот метод вызывает функцию библиотеки BdaMethodCreateTopology для создания топологии между контактами фильтров. Эта функция фактически создает структуру топологии в круге 3, которая отражает для других наборов свойств известные соединения фильтра. Мини-накопитель BDA должен перехватывать запрос метода KSMETHOD_BDA_CREATE_TOPOLOGY, как показано в предыдущем фрагменте кода, если этот мини-накопитель должен отправлять специальные инструкции на оборудование при подключении определенных типов контактов, например, если устройство BDA выполняет аппаратное демультлексирование и создает произвольное количество выходных контактов, размыкаемых из одного контактного контакта.