Network Driver Interface Specification
La Specifica di Interfaccia di Driver di rete (NDIS) è un'interfaccia per la programmazione di applicazioni (API) per schede di rete (NICs). È stata sviluppata da Microsoft e 3Com: è utilizzata da Microsoft Windows e da vari progetti open-source driver wrapper NDISwrapper e Project Evil permettono a molte schede compatibili con NDIS di essere usate con Linux, FreeBSD e NetBSD. magnussoft ZETA, un derivato di BeOS, supporta un gran numero di driver NDIS.
La NDIS è una connessione logica di controllo Logical Link Control (LLC) che forma lo strato superiore dello strato di connessione dati nel livello datalink (livello 2 di 7) del modello OSI, ed agisce come un'interfaccia tra i livelli 2 e 3 (il livello di rete). Il livello più basso è il driver del dispositivo di controllo di accesso sul media Media Access Control (MAC).
La NDIS è una libreria di funzioni a cui spesso ci si riferisce come ad un "wrapper" che nasconde la complessità dello strato sottostante del NIC hardware e serve come interfaccia standard per i driver di protocollo di livello 3 e il livello dei driver del livello hardware MAC. Un altro comune LLC è l'interfaccia Open Data-Link Interface (ODI).
Seguono le versioni di NDIS, supportate dalle varie versioni di Windows:
- NDIS 2.0: MS-DOS, Windows for Workgroups 3.1, OS/2
- NDIS 3.0: Windows for Workgroups 3.11
- NDIS 3.1: Windows 95
- NDIS 4.0: Windows 95 OSR2, NT 4.0
- NDIS 5.0: Windows 98, 98 SE, Me, 2000
- NDIS 5.1: Windows XP, Server 2003, CE
- NDIS 5.2: Windows Server 2003 SP2
- NDIS 6.0: Windows Vista
- NDIS 6.1: Windows Vista SP1, Server 2008
- NDIS 6.20: Windows 7, Server 2008 R2
Il traffico accettato dal NIC è controllato dal driver NDIS Miniport, mentre vari protocolli, come il TCP/IP sono implementati dai driver di protocollo della NDIS. Una singola miniport può essere associata con uno o più protocolli. Questo significa che il traffico che arriva nel miniport può essere ricevuto in parallelo da diversi driver di protocollo. Per esempio, Winpcap aggiunge un secondo driver di protocollo sul selezionato miniport allo scopo di catturare i pacchetti in ingresso. Inoltre, è possibile simulare diversi NICs virtuali implementando driver di miniporte che spediscono e ricevono traffico da un singolo fisico NIC. Un esempio d'uso di driver di miniport virtuali è aggiungere NIC virtuali, ciascuno con differenti Virtual LAN. Poiché le implementazioni non possono sapere in anticipo se altri driver riceveranno lo stesso buffer, uno deve trattare il buffer in ingresso come di sola lettura. Un driver che cambia il contenuto di un pacchetto, deve allocare il suo proprio buffer.
Un altro tipo di driver è quello intermedio della NDIS. I driver intermedi sono localizzati tra il MAC e il livello IP e possono controllare tutto il traffico che sarà accettato da una scheda di rete NIC. In pratica, i driver intermedi implementano entrambe le interfacce di miniport e protocollo. Il driver di miniport e il driver di protocollo realmente comunicano con il corrispondente protocollo e l'interfaccia miniport che risiede nel driver intermedio. Questo scelta progettuale permette l'aggiunta di una catena di diversi driver intermedi tra la miniport e i driver di protocollo. Quindi, i venditori di driver devono stare attenti e non assumere che il traffico che essi spediscono fuori verso la successiva interfaccia sia implementato dall'ultimo driver nella catena. Allo scopo di scrivere applicazioni che usano la NDIS uno può usare gli esempi che accompagnano il Microsoft's Windows Driver Kit (WDK). L'esempio de filtro "PassThru" è un buon punto di inizio per i filtri intermedi poiché implementa tutti i dettagli necessari, richiesti nel tipo di driver, ma l'esempio lascia semplicemente passare tutto il traffico attraverso verso il filtro successivo della catena.
Voci correlate
Collegamenti esterni
- http://blogs.msdn.com/wndp/ Windows Core Networking
- http://www.ndis.com/
- http://msdn.microsoft.com/en-us/library/ms797120.aspx Microsoft MSDN Design Guide
- http://www.wd-3.com/archive/ExtendingPassthru.htm Extending PassThru