Функция AtaPortRegistryControllerKeyWrite (irb.h)
Подпрограмма AtaPortRegistryControllerKeyWrite записывает данные в указанное имя значения в разделе HKLM\CurrentControlSet\Services\<service name>\ControllerN
реестра , где N — это номер контроллера.
Синтаксис
BOOLEAN AtaPortRegistryControllerKeyWrite(
[in] PVOID ChannelExtension,
[in] UCHAR ControllerNumber,
[in] PCHAR ValueName,
[in] UCHAR ValueType,
[in] PUCHAR Buffer,
PULONG BufferLength
);
Параметры
[in] ChannelExtension
Указатель на расширение канала.
[in] ControllerNumber
Содержит номер контроллера.
[in] ValueName
Содержит имя значения реестра для записи.
[in] ValueType
Указывает тип данных, содержащихся в значении реестра. Этому члену следует присвоить одно из значений, указанных в следующей таблице.
Значение | Значение |
---|---|
IDE_REG_DWORD | 4-байтовое числовое значение. |
IDE_REG_BINARY | Двоичные данные. |
IDE_REG_SZ | Строка Юникода, заканчивающаяся null. |
[in] Buffer
Указатель на исходный буфер, содержащий данные для записи в значение реестра.
BufferLength
Указатель на количество байтов данных для копирования. Если операция завершается сбоем, расположение, указываемое параметром Length , обновит длину данных, которые были успешно скопированы в реестр.
Возвращаемое значение
AtaPortRegistryControllerKeyWrite возвращает значение TRUE , если операция выполнена успешно. В противном случае возвращается значение FALSE. Подпрограмма также возвращает значение FALSE , если драйвер мини-порта не вызывает его из правильной подпрограммы.
Комментарии
Буфер должен быть выделен с помощью AtaPortRegistryAllocateBuffer.
Драйвер мини-порта должен вызывать AtaPortRegistryControllerKeyWrite во время подпрограммы AtaChannelInitRoutine или подпрограммы IdeHwControl . Драйвер мини-порта не может вызывать AtaPortRegistryControllerKeyWrite из любой другой подпрограммы или возвращает значение FALSE. Кроме того, драйвер мини-порта может вызывать AtaPortRegistryControllerKeyWrite из своей подпрограммы IdeHwControl, только если была вызвана подпрограмма IdeHwControl и в параметре ControlAction было задано значение StartChannel или StopChannel.
Требования
Требование | Значение |
---|---|
Целевая платформа | Персональный компьютер |
Верхняя часть | irb.h (включая Ata.h, Irb.h) |