Función SerCx2CustomReceiveCreate (sercx.h)
El método SerCx2CustomReceiveCreate crea un objeto de recepción personalizado, que la versión 2 de la extensión del marco de serie (SerCx2) usa para leer los datos recibidos del controlador serie mediante un mecanismo personalizado de transferencia de datos.
Sintaxis
NTSTATUS SerCx2CustomReceiveCreate(
[in] WDFDEVICE Device,
[in] PSERCX2_CUSTOM_RECEIVE_CONFIG CustomReceiveConfig,
[in] PWDF_OBJECT_ATTRIBUTES Attributes,
[out] SERCX2CUSTOMRECEIVE *CustomReceive
);
Parámetros
[in] Device
Un identificador WDFDEVICE para el objeto de dispositivo de marco que representa el controlador serie. El controlador de controlador serie creó este objeto en su función de devolución de llamada EvtDriverDeviceAdd. Para obtener más información, vea SerCx2InitializeDevice.
[in] CustomReceiveConfig
Puntero a una estructura de SERCX2_CUSTOM_RECEIVE_CONFIG. Antes de llamar a este método, el llamador debe llamar a la función SERCX2_CUSTOM_RECEIVE_CONFIG_INIT para inicializar la estructura. Esta estructura contiene punteros a un conjunto de rutinas de devolución de llamada de eventos implementadas por el controlador del controlador serie. SerCx2 llama a estas funciones para realizar transacciones de recepción personalizadas.
[in] Attributes
Puntero a una estructura de WDF_OBJECT_ATTRIBUTES que describe los atributos que se van a asignar al nuevo objeto de recepción personalizado. Antes de llamar a este método, el autor de la llamada debe llamar a la función WDF_OBJECT_ATTRIBUTES_INIT para inicializar la estructura. Este parámetro es opcional y se puede especificar como WDF_NO_OBJECT_ATTRIBUTES si el controlador del controlador serie no necesita asignar atributos al objeto . Para obtener más información, vea Comentarios.
[out] CustomReceive
Puntero a una ubicación en la que este método escribe un identificador de SERCX2CUSTOMRECEIVE en el objeto de recepción personalizado recién creado. SerCx2 y el controlador del controlador serie usan este identificador en llamadas posteriores para hacer referencia a este objeto.
Valor devuelto
Este método devuelve STATUS_SUCCESS si la llamada se realiza correctamente. Entre los posibles valores devueltos de error se incluyen los siguientes códigos de estado.
Código devuelto | Descripción |
---|---|
|
Ya existe un objeto de recepción personalizada de un |
|
Un valor de parámetro no es válido. |
|
El valor Config->Size no es igual a sizeof(SERCX2_CUSTOM_RECEIVE_CONFIG). |
|
Hay recursos insuficientes disponibles para crear el objeto de recepción personalizada. |
Observaciones
El controlador del controlador de serie llama a este método para crear un objeto de recepción personalizado. SerCx2 usa este objeto para realizar transacciones de recepción personalizadas, que son transacciones que usan un mecanismo de transferencia de datos personalizado para leer los datos recibidos por el controlador serie.
Un controlador de controlador serie debe llamar correctamente a los métodos SerCx2InitializeDevice y SerCx2PioReceiveCreate métodos antes de llamar a SerCx2CustomReceiveCreate.
Antes de llamar a SerCx2CustomReceiveCreate, el controlador de controlador serie debe llamar a la función SERCX2_CUSTOM_RECEIVE_CONFIG_INIT para inicializar la estructura de SERCX2_CUSTOM_RECEIVE_CONFIG apuntada por CustomReceiveConfig. Esta función establece los siguientes miembros de la estructura en cero:
- de alineación de
- minimumTransactionLength
- MaximumTransactionLength
- minimumTransferUnit
- exclusivo
- Si alineación es cero, SerCx2 establece el valor de alineación de datos en uno, lo que significa que el búfer de lectura puede iniciarse en un límite arbitrario de bytes en la memoria.
- Si minimumTransactionLength es cero, SerCx2 establece la longitud mínima de la transacción en un byte.
- Si MaximumTransactionLength es cero, SerCx2 establece la longitud máxima de transacción en ((ULONG)-1).
- Si minimumTransferUnit es cero, SerCx2 establece la unidad de transferencia mínima en un byte.
- Si exclusivo es cero (FALSE), el modo exclusivo está deshabilitado.
Como opción, un controlador de controlador serie puede usar el parámetro Attributes para crear un contexto para el objeto de recepción personalizada y proporcionar punteros a EvtCleanupCallback y EvtDestroyCallback funciones a las que se llama para preparar el objeto para su eliminación. Para obtener más información, vea WDF_OBJECT_ATTRIBUTES.
Si el parámetro Attributes apunta a una estructura WDF_OBJECT_ATTRIBUTES, el autor de la llamada no debe sobrescribir los valores que escribe la función de inicialización WDF_OBJECT_ATTRIBUTES_INIT en el ParentObject, ExecutionLevely SynchronizationScope miembros de esta estructura.
Para obtener más información sobre cómo crear objetos de recepción personalizados, vea SERCX2CUSTOMRECEIVE. Para obtener más información sobre las transacciones de recepción personalizadas, consulte SerCx2 Custom-Receive Transactions.
Requisitos
Requisito | Valor |
---|---|
cliente mínimo admitido | Disponible a partir de Windows 8.1. |
de la plataforma de destino de |
Universal |
encabezado de |
sercx.h |
irQL | PASSIVE_LEVEL |