функция обратного вызова GPIO_CLIENT_CONNECT_IO_PINS (gpioclx.h)

Функция обратного вызова события CLIENT_ConnectIoPins открывает логическое соединение с набором контактов ввода-вывода общего назначения (GPIO) и настраивает эти контакты для операций чтения и записи данных.

Синтаксис

GPIO_CLIENT_CONNECT_IO_PINS GpioClientConnectIoPins;

NTSTATUS GpioClientConnectIoPins(
  [in] PVOID Context,
  [in] PGPIO_CONNECT_IO_PINS_PARAMETERS ConnectParameters
)
{...}

Параметры

[in] Context

Указатель на контекст устройства драйвера контроллера GPIO.

[in] ConnectParameters

Указатель на структуру GPIO_CONNECT_IO_PINS_PARAMETERS , которая описывает подключение к набору контактов GPIO и указывает, следует ли настроить эти контакты в качестве входных или выходных данных.

Возвращаемое значение

Функция CLIENT_ConnectIoPins возвращает STATUS_SUCCESS, если вызов выполнен успешно. В противном случае возвращается соответствующий код ошибки.

Комментарии

Эта функция обратного вызова реализуется драйвером контроллера GPIO. Расширение платформы GPIO (GpioClx) вызывает эту функцию для открытия подключения к набору контактов GPIO. Эти контакты указываются в массиве PinNumberTable в структуре GPIO_CONNECT_IO_PINS_PARAMETERS , на которую указывает ConnectParameters. Элемент ConnectMode этой структуры указывает, следует ли настроить контакты в качестве входных или выходных данных.

Чтобы закрыть подключение, GpioClx вызывает функцию обратного вызова CLIENT_DisconnectIoPins .

Чтобы зарегистрировать функцию обратного вызова CLIENT_ConnectIoPins драйвера, вызовите метод GPIO_CLX_RegisterClient . Этот метод принимает в качестве входного параметра указатель на структуру GPIO_CLIENT_REGISTRATION_PACKET , содержащую указатель CLIENT_ConnectIoPins функции.

Примеры

Чтобы определить функцию обратного вызова CLIENT_ConnectIoPins , необходимо сначала предоставить объявление функции, определяющее тип определяемой функции обратного вызова. Windows предоставляет набор типов функций обратного вызова для драйверов. Объявление функции с помощью типов функций обратного вызова помогает анализу кода для драйверов, средству проверки статических драйверов (SDV) и другим средствам проверки находить ошибки, и это требование для написания драйверов для операционной системы Windows.

Например, чтобы определить функцию обратного вызова CLIENT_ConnectIoPins с именем MyEvtGpioConnectIoPins, используйте тип функции GPIO_CLIENT_CONNECT_IO_PINS, как показано в следующем примере кода:

GPIO_CLIENT_CONNECT_IO_PINS MyEvtGpioConnectIoPins;

Затем реализуйте функцию обратного вызова следующим образом:

_Use_decl_annotations_
NTSTATUS
  MyEvtGpioConnectIoPins(
    PVOID Context,
    PGPIO_CONNECT_IO_PINS_PARAMETERS ConnectParameters
    )
{ ... }

Тип функции GPIO_CLIENT_CONNECT_IO_PINS определен в файле заголовка Gpioclx.h. Чтобы более точно определить ошибки при запуске средств анализа кода, не забудьте добавить заметку Use_decl_annotations в определение функции. Заметка Use_decl_annotations гарантирует использование заметок, которые применяются к типу функции GPIO_CLIENT_CONNECT_IO_PINS в файле заголовка. Дополнительные сведения о требованиях к объявлениям функций см. в статье Объявление функций с помощью типов ролей функций для драйверов KMDF. Дополнительные сведения о Use_decl_annotations см. в статье О поведении функции.

Требования

Требование Значение
Минимальная версия клиента Поддерживается начиная с Windows 8.
Целевая платформа Персональный компьютер
Верхняя часть gpioclx.h
IRQL Вызывается на PASSIVE_LEVEL.

См. также раздел

CLIENT_DisconnectIoPins

GPIO_CLIENT_REGISTRATION_PACKET

GPIO_CLX_RegisterClient