Rasterizzatore WGF11
Questo test automatizzato verifica vari aspetti del rasterizzatore primitivo D3D e dello stato del rasterizzatore come implementato dall'hardware.
Questo argomento si applica ai processi di test seguenti:
Rasterizzatore WGF11
Rasterizzatore WGF11 (WoW64)
Dettagli del test
Specifiche |
|
Piattaforme |
|
Versioni supportate |
|
Tempo di esecuzione previsto (in minuti) | 2 |
Categoria | Compatibilità |
Timeout (in minuti) | 120 |
Richiede il riavvio | false |
Richiede una configurazione speciale | false |
Tipo | automatic |
Documentazione aggiuntiva
I test in questa area di funzionalità potrebbero avere documentazione aggiuntiva, inclusi i prerequisiti, la configurazione e le informazioni sulla risoluzione dei problemi, disponibili negli argomenti seguenti:
Esecuzione del test
Prima di eseguire il test, completare la configurazione di test come descritto nei requisiti di test: Adattatore grafico o Prerequisiti di test del chipset.
Risoluzione dei problemi relativi
Per la risoluzione generica degli errori di test HLK, vedere Risoluzione dei problemi di test di Windows HLK.
Per informazioni sulla risoluzione dei problemi, vedere Risoluzione dei problemi relativi a Device.Graphics Testing.
Tutti i test case restituiscono PASS o FAIL. Esaminare i risultati del test nel file di log per informazioni dettagliate specifiche sugli errori. Il test potrebbe restituire SKIP se viene eseguito con un livello di funzionalità che non supporta la funzionalità sottoposta a test. Il test potrebbe restituire BLOCKED se si verifica un'eccezione non rilevata (il framework lo rileva alla fine e lo registra).
Altre informazioni
Per D3D10 e versioni successive, questo test verifica quanto segue:
Culling primitivo, modalità di riempimento e ordine di avvolgimento in base allo stato rasterizzatore.
Modalità di interpolazione nel pixel shader
La modalità costante è semplice, perché non viene apportata alcuna modifica dai valori inviati dal vertex shader.
Poiché non è strettamente specifica, le modalità lineari vengono verificate assicurandosi che i pixel adiacenti non siano uguali e seguano la sfumatura di un bordo.
Chiamata del pixel shader di frequenza di esempio (D3D10.1 e versioni successive).
Per D3D11, questo test verifica la valutazione dell'attributo del modello pull.
Le funzioni intrinseche seguenti verranno introdotte in D3D11 (HLSL 5.0) per la funzionalità di valutazione degli attributi del modello pull:
EvaluateAttributeSnapped( attrib numeric value, int2 pixeloffset )
EvaluateAttributeAtSample( attrib numeric value, uint sampleindex )
EvaluateAttributeAtCentroid( valore numerico attrib )
Per ogni funzione intrinseca, verrà generato un set di pixel shader, destinato ai case su diverse combinazioni dei valori dei parametri della funzione intrinseca e delle modalità di interpolazione dichiarate degli attributi di input.
Di seguito sono riportati i fattori di test per tutti e tre gli intrinseci:
Attributi di input passati dal vertex shader.
Nota
È possibile interpolare solo l'attributo di tipo float; Il tipo int/uint sarà sempre la modalità di interpolazione costante
float4 texCoord : TEXCOORD
colore float4: COLOR
float clipDis : SV_ClipDistance
Dichiarazioni di modalità di interpolazione.
Nota
La modalità nointerpolation non è consentita dal compilatore HLSL quando l'attributo corrispondente viene valutato con il modello pull nello shader.
linear
lineare noPerspective
centroide lineare
esempio lineare
centroide lineare noPerspective
esempio lineare noPerspective
Primitive da disegnare:
Quando la modalità di interpolazione è lineare, verrà disegnato un triangolo C1-C2-C3 come indicato di seguito. Questo copre un pixel intero e due mezzo pixel. Le coordinate dei vertici nello spazio di proiezione sono le seguenti:
<è necessaria l'immagine qui
C1: (-1, 1, 0), C2(-1, -1, 0), C3(1, 1, 0).
Triangolo destro all'interno di un quadrato, con vertici C1, C2 e C3; C1 forma l'angolo di 90 gradi e si trova nell'angolo superiore sinistro del quadrato
Quando la modalità di interpolazione è noperspective, verrà disegnato un triangolo A-B-C con le coordinate dei vertici seguenti nello spazio di proiezione:
A:(-1, 1, 1);
B:(-1, -1, 0);
C:(1, 1, 1)
Il triangolo dello spazio dello schermo deve coprire le stesse aree pixel e pixel del triangolo C1-C2-C3 illustrato in precedenza.
Destinazione di rendering
Formato: tutti i formati che supportano la destinazione di rendering.
Conteggio campioni: 1, 2, ... numero massimo di campioni supportati.
Valori diversi di pixeloffset per EvaluateAttributeSnapped( )
Idealmente, tutte le possibili 256 posizioni di offset. Se il test viene eseguito troppo a lungo, questo gruppo di test case verrà ridotto a 4 posizioni di angolo, 8 posizioni del bordo, 4 posizioni dalla griglia 4x4, 4 posizioni dalla griglia 8x8 e 4 posizioni dalla griglia 16x16.
Valori diversi di sampleindex per EvaluateAttributeAtSample( )
Tutti gli indici di esempio supportati dalla destinazione di rendering
Il metodo di verifica inizia quando il pixel shader scrive il valore dell'attributo interpolato nella destinazione di rendering. I dati di destinazione di rendering vengono quindi mappati e letti. Nei casi di destinazioni di rendering con multicampionamento, è necessario risolvere il multisample prima del mapping. I dati dei risultati verranno confrontati con i dati interpolati precalcocati o i dati ottenuti dall'accesso diretto all'attributo.
Quando la modalità di interpolazione è lineare noperspective:
Calcolare e archiviare i valori interpolati (ed estrapolati per l'area scoperta di p2 e p3) per 256 posizioni di offset di ogni pixel di p1, p2, p3.
Per EvaluateAttributeSnapped:
Pixel p1 deve avere un valore di attributo "pulled" tra i valori previsti per sinistra e destra (oltre che superiore e inferiore) offset adiacenti dell'offset "pulled".
Pixel p2 e p3:
Nei casi a campionamento singolo non deve essere eseguito il rendering.
Nei casi con più campioni, devono avere un valore di attributo "pulled" tra i valori previsti per sinistra e destra (oltre che superiore e inferiore) offset adiacenti dell'offset "pulled".
Per EvaluateAttributeAtSample con SampleFinder, trovare la posizione dell'indice di esempio nel sistema di coordinate di esempio con intervallo [-8, 7]. Usare questa posizione per eseguire la verifica come in EvaluateAttributeSnapped precedente.
Per EvaluateAttributeAtCentroid, disegnare il triangolo C1-C2-C3 con SV_COVERAGE per scoprire il primo campione coperto, ovvero la posizione centroide definita dal modello shader 5.0. Usare l'indice di esempio per centoid per eseguire la verifica come in EvaluateAttributeAtSample precedente.
Quando la modalità di interpolazione è lineare:
Calcolare e archiviare i valori interpolati (ed estrapolati per l'area scoperta di p2 e p3) per 256 posizioni di offset di ogni pixel, usando l'interpolazione corretta della prospettiva. Interpolare i valori dell'attributo divisi per il rispettivo valore di profondità, quindi dividere il valore dell'attributo interpolato in base al reciproco interpolato della profondità.
Per EvaluateAttributeSnapped(), usare la stessa verifica della versione 2.a.
Per EvaluateAttributeAtCentroid(), usare la stessa verifica di 2.c.
Per EvaluateAttributeAtSample(), usare la stessa verifica di 2.b.
Usare PSInvocation per verificare il numero di chiamate PS per tutti i test case.
Se un attributo ha la modalità di interpolazione di esempio o SV_SAMPLEINDEX viene dichiarato e il numero di campioni è maggiore di 1, PSInvocation deve essere 3*(numero di campioni).
Quando il numero di campioni è 1, PSInvocation deve essere 1.
Sintassi dei comandi
Opzione di comando | Descrizione |
---|---|
Wgf11rasterizer |
Esegue i processi di test. Senza opzioni, il test enumera i dispositivi. |
-FeatureLevel:XX.X |
Imposta il livello di feauture, dove XX.X è il livello di funzionalità, il test verrà eseguito a: 10.0, 10.1 o 11.0. |
Nota
Per la Guida della riga di comando per questo file binario di test, digitare /?.
Elenco file
File | Posizione |
---|---|
Configdisplay.exe |
<[testbinroot]>\nttest\windowstest\tools\ |
D3d11_1sdklayers.dll |
<[testbinroot]>\nttest\windowstest\graphics\d3d\support\ |
D3d11ref.dll |
<[testbinroot]>\nttest\windowstest\graphics\d3d\support\ |
D3d11sdklayers.dll |
<[testbinroot]>\nttest\windowstest\graphics\d3d\support\ |
D3dcompiler_test.dll |
<[testbinroot]>\nttest\windowstest\graphics\d3d\support |
D3dx10_test.dll |
<[testbinroot]>\nttest\windowstest\graphics\d3d\support\ |
d3dx11_test.dll |
<[testbinroot]>\nttest\windowstest\graphics\d3d\support\ |
TDRWatch.exe |
<[testbinroot]>\nttest\windowstest\graphics\ |
Wgf11rasterizer.exe |
<[testbinroot]>\nttest\windowstest\graphics\d3d\conf |
Parametri
Nome parametro | Descrizione dei parametri |
---|---|
MODIFIEDCMDLINE | Argomenti aggiuntivi della riga di comando per l'eseguibile di test |
LLU_NetAccessOnly | Nome LLU dell'utente net |
ConfigDisplayCommandLine | Riga di comando personalizzata per ConfigDisplay. Impostazione predefinita: logo |
TDRArgs | /get o /set |