Compartilhar via


Modelo de IoMmu

Esta página descreve o modelo IoMmu introduzido no WDDM 2.0. Consulte Isolamento de GPU baseado em IOMMU e remapeamento de DMA IOMMU para obter atualizações mais recentes de IOMMU.

Visão geral

Uma Unidade de Gerenciamento de Memória de Entrada-Saída (IOMMU) é um componente MMU que conecta um barramento de E/S compatível com DMA à memória do sistema. Ele mapeia endereços virtuais visíveis por dispositivos para endereços físicos, tornando-o útil na virtualização.

No modelo IoMmu do WDDM 2.0, cada processo tem um único espaço de endereço virtual que é:

  • Compartilhado entre a CPU e a GPU.
  • Gerenciado pelo gerenciador de memória do sistema operacional.

Para acessar a memória, a GPU envia uma solicitação de dados para um IOMMU compatível. A solicitação inclui um endereço virtual compartilhado e um identificador de espaço de endereço de processo (PASID). A IOMMU executa a conversão de endereços usando a tabela de página compartilhada. Essa ação é ilustrada no diagrama a seguir.

Diagrama que mostra a conversão de espaço de endereço do processo IOMMU no WDDM 2.0.

O driver de exibição de modo kernel (KMD) expressa suporte para o modelo IoMmu definindo as tampas DXGK_VIDMMCAPS::IoMmuSupported . Quando esse sinalizador é definido, o gerenciador de memória de vídeo (VidMm) registra automaticamente qualquer processo usando a GPU com a IOMMU e obtém um PASID para esse espaço de endereço de processo. O PASID é passado para o driver durante a criação do dispositivo.

O VidMm mapeia as alocações primárias no segmento de abertura antes de ser exibido, garantindo que o controlador de exibição tenha acesso físico a essas alocações.

No modelo IoMmu, o driver de exibição de modo de usuário (UMD) continua a alocar memória de vídeo para a GPU usando o serviço Allocate do VidMm. Este processo permite ao UMD:

  • Siga o modelo de residência.
  • Suporte ao modelo de compartilhamento de recursos do DirectX.
  • Certifique-se de que as superfícies primárias estejam visíveis para o kernel e sejam mapeadas na abertura antes de serem exibidas.

O UMD gerencia inteiramente o primeiro nível de tradução (endereço de recurso de bloco para endereço de CPU/GPU compartilhado) no modo de usuário.