Sdílet prostřednictvím


IDiaSession::getFunctionFragments_VA

Načte adresy a délky nesouvislých fragmentů funkce na zadané virtuální adrese (VA).

Syntaxe

HRESULT getFunctionFragments_VA(
    ULONGLONG vaFunc,
    DWORD cbFunc,
    DWORD cFragments,
    ULONGLONG *pVaFragment,
    DWORD *pLenFragment
);

Parametry

vaFunc

[v] Virtuální adresa funkce.

cbFunc

[v] Celková velikost v bajtech funkce (to znamená délka funkce).

cFragments

[v] Počet prvků přidělených pro pVaFragment a pLenFragment.

pVaFragment

[ven] Vyrovnávací paměť pole pro příjem virtuálních adres každého fragmentu. Musí to být aspoň cFragments dlouhé.

pLenFragment

[ven] Vyrovnávací paměť pole pro příjem délky každého fragmentu v bajtech. Musí to být aspoň cFragments dlouhé.

Návratová hodnota

V případě úspěchu vrátí hodnotu S_OK; v opačném případě vrátí kód chyby.

Příklad

Ukazuje, jak načíst adresu a délku funkce prostřednictvím IDiaSymbol, pak počet fragmentů, načíst sadu fragmentů funkce a pak je vytisknout jako seznam počátečních a koncových adres.

HRESULT PrintFunctionFragments(CComPtr<IDiaSymbol> pFunc) {
   ULONGLONG vaStart = 0;
   ULONGLONG cbFunc = 0;

   HRESULT hr = pFunc->get_relativeVirtualAddress(&vaStart);
   if (FAILED(hr)) {
       return hr;
   }
   hr = pFunc->get_length(&cbFunc);
   if (FAILED(hr)) {
       return hr;
   }

   DWORD cFragments = 0;

   hr = pSession->getNumberOfFunctionFragments_VA(vaStart, (DWORD) cbFunc, &cFragments);
   if (FAILED(hr)) {
       return hr;
   }

   ULONGLONG * rgVA = new (std::nothrow) ULONGLONG[cFragments];
   if (rgVA == nullptr) {
       return E_OUTOFMEMORY;
   }

   DWORD * rgLen = new (std::nothrow) DWORD[cFragments];
   if (rgLen == nullptr) {
       delete[] rgVA;
       return E_OUTOFMEMORY;
   }

   hr = pSession->getFunctionFragments_VA(vaStart, (DWORD) cbFunc, cFragments, rgVA, rgLen);
   if (FAILED(hr)) {
       delete[] rgVA;
       delete[] rgLen;
       return hr;

   }
   for (DWORD i = 0; i < cFragments; i++) {
       printf("  %016llX -- %016llX\n", rgVA[i], rgVA[i] + rgLen[i] - 1);
   }

   delete [] rgVA;
   delete [] rgLen;

   return S_OK;
}

Viz také