Настройка фильтра 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 выполняет аппаратное демультлексирование и создает произвольное количество выходных контактов, размыкаемых из одного контактного контакта.