Compartilhar via


PDRIVER_IO_PORT_UCHAR_STRING função de retorno de chamada (video.h)

SvgaHwIoPortUcharString intercepta uma porta de E/S para a qual um aplicativo MS-DOS de tela inteira em um computador baseado em x86 está enviando uma sequência de dados do tamanho de UCHAR.

Sintaxe

PDRIVER_IO_PORT_UCHAR_STRING PdriverIoPortUcharString;

VP_STATUS PdriverIoPortUcharString(
  ULONG_PTR Context,
  ULONG Port,
  UCHAR AccessMode,
  PUCHAR Data,
  ULONG DataLength
)
{...}

Parâmetros

Context

Especifica o valor de contexto determinado pelo driver de miniport que foi definido no membro EmulatorAccessEntriesContext de VIDEO_PORT_CONFIG_INFO.

Port

Especifica a porta de E/S mapeada.

AccessMode

Especifica o tipo de acesso permitido, que pode ser uma ou uma combinação (ORed) dos seguintes valores:

EMULATOR_READ_ACCESS
EMULATOR_WRITE_ACCESS

Data

Ponteiro para a cadeia de caracteres UCHAR a ser transferida. Um caractere de cada vez é fisgado até que toda a cadeia de caracteres seja transferida.

DataLength

Especifica o número de valores UCHAR na cadeia de caracteres.

Retornar valor

SvgaHwIoPortUcharString retorna a status final da operação.

Comentários

Somente drivers de miniporta de adaptadores SVGA compatíveis com VGA têm funções SvgaHwIoPortXxx . (Consulte Funções SVGA.)

SvgaHwIoPortUcharString intercepta qualquer acesso de byte tentado por um aplicativo MS-DOS de tela inteira que emite ou ambas as instruções REP OUTSB DX, ESI e REP INSB EDI, DX.

Se o driver de miniporto habilitar a Porta para acesso direto chamando VideoSetTrappedEmulatorPorts, sua função SvgaHwIoPortUcharString não será chamada. Em seguida, esse aplicativo terá acesso direto à porta de E/S, a menos que o driver de miniporta desabilite a porta com outra chamada para VideoSetTrappedEmulatorPorts.

Se uma ou mais instruções de INSB ou OUTSB x86 emitidas pelo aplicativo podem afetar o estado do registro do sequenciador de adaptador compatível com VGA, o registro de saída diversos ou qualquer registro específico do adaptador e, assim, fazer com que o computador seja travado, o driver de miniporto não deverá habilitar a porta para acesso direto chamando VideoPortSetTrappedEmulatorPorts.

SvgaHwIoPortUcharString deve armazenar em buffer as instruções subsequentes do aplicativo e marcar que nenhuma pode travar o computador. Se o aplicativo emitir qualquer sequência de instruções que possam travar o computador, SvgaHwIoPortUcharString deverá descartar as instruções armazenadas em buffer. Caso contrário, ele deverá gerá-los, um UCHAR por vez, para a porta de E/S mapeada especificada.

SvgaHwIoPortUcharString deve ser tornado paginável.

Requisitos

Requisito Valor
Plataforma de Destino Área de Trabalho
Cabeçalho video.h (incluir Video.h)

Confira também

EMULATOR_ACCESS_ENTRY

Funções SVGA

SvgaHwIoPortUchar

VIDEO_ACCESS_RANGE

VIDEO_PORT_CONFIG_INFO

VideoPortGetDeviceBase

VideoPortSetTrappedEmulatorPorts