Compartilhar via


IOCTL_PWM_CONTROLLER_SET_DESIRED_PERIOD IOCTL (pwm.h)

Define o período de sinal de saída de um controlador PWM (Pulse Width Modulation) como um valor sugerido.

Buffer de entrada

Um ponteiro para um buffer que contém um struct PWM_CONTROLLER_SET_DESIRED_PERIOD_INPUT . O valor associado é o período de sinal de saída solicitado, em picoseconds, para o controlador. Esse valor deve ser maior que zero (0). Ele deve estar no intervalo de períodos com suporte do controlador, que está entre os valores MinimumPeriod e MaximumPeriod , inclusive, que você pode obter usando IOCTL_PWM_CONTROLLER_GET_INFO.

Comprimento do buffer de entrada

O tamanho, em bytes, do buffer de entrada.

Buffer de saída

Um ponteiro para um buffer que contém um struct PWM_CONTROLLER_SET_DESIRED_PERIOD_INPUT . O valor associado é o período de sinal de saída efetivo do controlador PWM (Pulse Width Modulation). Posteriormente, ele pode ser recuperado usando IOCTL_PWM_CONTROLLER_GET_ACTUAL_PERIOD.

Comprimento do buffer de saída

O tamanho do buffer de saída em bytes.

Comentários

Para executar essa operação, chame a função DeviceIoControl com os parâmetros a seguir.

BOOL 
   WINAPI 
   DeviceIoControl( (HANDLE)       hDevice,         // handle to device
                    (DWORD)        IOCTL_PWM_CONTROLLER_SET_DESIRED_PERIOD, // dwIoControlCode(LPDWORD)      lpInBuffer,      // input buffer
                    (DWORD)        nInBufferSize,   // size of input buffer
                    (LPDWORD)      lpOutBuffer,     // output buffer
                    (DWORD)        nOutBufferSize,  // size of output buffer
                    (LPDWORD)      lpBytesReturned, // number of bytes returned
                    (LPOVERLAPPED) lpOverlapped );  // OVERLAPPED structure
Parâmetros Descrição
hDevice [in] Um identificador para o dispositivo. Para obter um identificador de dispositivo, chame a função CreateFile .
dwIoControlCode [in] O código de controle da operação. Use IOCTL_PWM_CONTROLLER_SET_DESIRED_PERIOD para esta operação.
lpInBuffer Um ponteiro para um buffer que contém um struct PWM_CONTROLLER_SET_DESIRED_PERIOD_INPUT . O valor associado é o período de sinal de saída solicitado, em picoseconds, para o controlador. Esse valor deve ser maior que zero (0). Ele deve estar no intervalo de períodos com suporte do controlador, que está entre os valores MinimumPeriod e MaximumPeriod , inclusive, que você pode obter usando IOCTL_PWM_CONTROLLER_GET_INFO.
nInBufferSize [in] O tamanho, em bytes, do buffer de entrada.
lpOutBuffer [out] Um ponteiro para um buffer que contém um struct PWM_CONTROLLER_SET_DESIRED_PERIOD_INPUT . O valor associado é o período de sinal de saída efetivo do controlador PWM (Pulse Width Modulation). Posteriormente, ele pode ser recuperado usando IOCTL_PWM_CONTROLLER_GET_ACTUAL_PERIOD.
nOutBufferSize [in] O tamanho do buffer de saída em bytes.
lpBytesReturned [out] LPDWORD

Um ponteiro para uma variável que recebe o tamanho dos dados armazenados no buffer de saída, em bytes.

Se o buffer de saída for muito pequeno, a chamada falhará, GetLastError retornará ERROR_INSUFFICIENT_BUFFER e lpBytesReturned será zero.

Se lpOverlapped for NULL, lpBytesReturned não poderá ser NULL. Mesmo quando uma operação não retorna dados de saída e lpOutBuffer for NULL, DeviceIoControl usará lpBytesReturned. Após essa operação, o valor de lpBytesReturned não terá sentido.

Se lpOverlapped não for NULL, lpBytesReturned poderá ser NULL. Se esse parâmetro não for NULL e a operação retornar dados, lpBytesReturned não terá sentido até que a operação sobreposta seja concluída. Para recuperar o número de bytes retornados, chame GetOverlappedResult. Se o parâmetro hDevice estiver associado a uma porta de conclusão de E/S, você poderá recuperar o número de bytes retornados chamando GetQueuedCompletionStatus.

lpOverlapped [in] LPOVERLAPPED

Um ponteiro para uma estrutura OVERLAPPED.

Se hDevice tiver sido aberto sem especificar FILE_FLAG_OVERLAPPED, lpOverlapped será ignorado.

Se hDevice tiver sido aberto com o sinalizador FILE_FLAG_OVERLAPPED, a operação será executada como uma operação sobreposta (assíncrona). Nesse caso, lpOverlapped deve apontar para uma estrutura OVERLAPPED válida que contenha um identificador para um objeto de evento. Caso contrário, a função falhará de maneiras imprevisíveis.

Em operações sobrepostas, DeviceIoControl retorna imediatamente e o objeto do evento é sinalizado quando a operação é concluída. Caso contrário, a função não será retornada até que a operação seja concluída ou ocorra um erro.

Requisitos

Requisito Valor
Cliente mínimo com suporte Windows 10 [somente aplicativos da área de trabalho]
Servidor mínimo com suporte Windows Server 2016 [somente aplicativos da área de trabalho]
Cabeçalho pwm.h (inclua Pwm.h)

Confira também

DeviceIoControl