Compartilhar via


Método IVdsSubSystem2::QueryMaxLunCreateSize2 (vds.h)

[Começando com Windows 8 e Windows Server 2012, a interface COM do Serviço de Disco Virtual é substituída pela API de Gerenciamento de Armazenamento do Windows.]

Retorna o tamanho do LUN máximo que pode ser criado usando o tipo LUN e as dicas especificados. Esse método é idêntico ao método IVdsSubSystem::QueryMaxLunCreateSize , exceto que as dicas automatizadas são fornecidas usando uma estrutura VDS_HINTS2 em vez de uma estrutura VDS_HINTS .

Sintaxe

HRESULT QueryMaxLunCreateSize2(
  [in]  VDS_LUN_TYPE  type,
  [in]  VDS_OBJECT_ID *pDriveIdArray,
  [in]  LONG          lNumberOfDrives,
  [in]  VDS_HINTS2    *pHints2,
  [out] ULONGLONG     *pullMaxLunSize
);

Parâmetros

[in] type

Um VDS_LUN_TYPE valor de enumeração que especifica o tipo LUN.

[in] pDriveIdArray

Um ponteiro para uma matriz que contém um VDS_OBJECT_ID para cada uma das unidades a serem usadas na criação do LUN. O provedor deve tentar usar as unidades na ordem fornecida. Esse parâmetro poderá ser NULL se o parâmetro lNumberOfDrives for zero, nesse caso, o provedor deverá selecionar automaticamente unidades.

[in] lNumberOfDrives

O número de entradas na matriz pDriveIdArray . Esse parâmetro é opcional e pode ser zero.

[in] pHints2

Um ponteiro para a estrutura VDS_HINTS2 usada para criar o LUN. As dicas sempre têm prioridade menor do que os parâmetros listados antes. Esse parâmetro é necessário e não pode ser NULL.

[out] pullMaxLunSize

Um ponteiro para um buffer que contém o tamanho máximo do LUN em bytes. Esse parâmetro é necessário e não pode ser NULL.

Retornar valor

Esse método pode retornar valores HRESULT padrão, como E_INVALIDARG ou E_OUTOFMEMORY, e valores retornados específicos do VDS. Ele também pode retornar códigos de erro do sistema convertidos usando a macro HRESULT_FROM_WIN32 . Os erros podem se originar do próprio VDS ou do provedor de VDS subjacente que está sendo usado. Os possíveis valores retornados incluem o seguinte.

Valor/código retornado Descrição
VDS_E_PROVIDER_CACHE_CORRUPT
0x8004241FL
Há um problema de software ou comunicação dentro de um provedor que armazena em cache informações sobre a matriz. Use o método IVdsHwProvider::Reenumerate seguido pelo método IVdsHwProvider::Refresh para restaurar o cache.
VDS_E_OBJECT_DELETED
0x8004240BL
O objeto de subsistema não está mais presente.
VDS_E_OBJECT_STATUS_FAILED
0x80042431L
O subsistema está em um estado de falha e não consegue executar a operação solicitada.
VDS_E_ANOTHER_CALL_IN_PROGRESS
0x80042404L
Outra operação está em andamento; essa operação não pode continuar até que a operação ou as operações anteriores sejam concluídas.
VDS_E_OBJECT_NOT_FOUND
0x80042405L
O identificador não se refere a um objeto existente. Esse valor pode ser retornado de qualquer método que usa uma constante VDS_OBJECT_ID .
VDS_E_NOT_SUPPORTED
0x80042400L
Essa operação ou combinação de parâmetros não é compatível com esse provedor.

Requisitos

Requisito Valor
Cliente mínimo com suporte Windows 7 [somente aplicativos da área de trabalho]
Servidor mínimo com suporte Windows Server 2008 R2 [somente aplicativos da área de trabalho]
Plataforma de Destino Windows
Cabeçalho vds.h
Biblioteca Uuid.lib

Confira também

IVdsSubSystem2

VDS_HINTS2