Структура NDIS-пакетов
Драйвер протокола выделяет ресурсы под NDIS-пакеты, заполняет их данными и посылает вниз следующему NDIS-драйверу. Драйверы сетевых карт выделяют ресурсы под NDIS-пакеты, чтобы поместить в них полученные из сети данные и передать наверх соответствующим драйверам. Иногда драйвер протокола размещает NDIS-пакет и передает его драйверу сетевой карты с требованием, чтобы драйвер сетевой карты скопировал полученные из сети данные в этот пакет. NDIS обеспечивает функции, размещающие и обрабатывающие структуры, из которых состоит NDIS-пакет.
Описатель NDIS-пакета является структурой NDIS_PACKET, содержащей, помимо прочих, следующие поля (см. рис. 28):
- закрытые области данных для драйвера минипорта и драйвера протокола;
- флаги;
- число физических страниц, содержащих пакет;
- полную длину пакета;
- указатели на описатели первого и последнего буфера пакета.
Описатель буфера является структурой NDIS_BUFFER (в действительности, NDIS_BUFFER определяется как тип MDL), содержащей, помимо всего прочего, следующее:
- начальный виртуальный адрес буфера;
- смещение буфера относительно страницы;
- длину буфера в байтах;
- указатель на описатель следующего буфера (или NULL, если его нет).
Основные функции для работы с NDIS-пакетами и NDIS-буферами:
- NdisAllocatePacketPool – размещает и инициализирует пространство для пула описателей пакетов;
- NdisAllocatePacket – размещает и инициализирует описатель пакета;
- NdisReinitializePacket – удаляет все присоединенные буфера из пакета и инициализирует его для повторного использования;
- NdisCopyFromPacketToPacket;
- NdisQueryPacket – возвращает информацию о "шкете;
- NdisFreePacket;
- NdisAllocateBufferPool – возвращает указатель, с помощью которого затем можно разместить описатели буферов, вызвав NdisAllocateBufFer;
- NdisAllocateBuffer – создает описатель буфера;
- NdisChainBufferAtBack (NdisChainBufferAtFront) – присоединяет описатель буфера в хвост (в начало) цепи описателей буферов, присоединенных к пакету;
- NdisCopyBuffer;
- NdisFreeBuffer;
- NdisGetFirstBufferFromPacket – возвращает указатель на буфер первый в цепи буферов пакета;
- NdisUnchainBufferAtBack, NdisUnchainBufferAtFront.
Рис. 28. Структура NDIS-пакета и NDIS-буфера