IDiaSession::getFunctionFragments_VA
Извлекает адреса и длину дисконимых фрагментов для функции по указанному виртуальному адресу (VA).
Синтаксис
HRESULT getFunctionFragments_VA(
ULONGLONG vaFunc,
DWORD cbFunc,
DWORD cFragments,
ULONGLONG *pVaFragment,
DWORD *pLenFragment
);
Параметры
vaFunc
[in] Виртуальный адрес функции.
cbFunc
[in] Общий размер функции в байтах (т. е. длина функции).
cFragments
[in] Количество элементов, выделенных для pVaFragment
и pLenFragment
.
pVaFragment
[out] Буфер массива для получения виртуальных адресов каждого фрагмента. Это должно быть по крайней мере cFragments
длинным.
pLenFragment
[out] Буфер массива для получения длины в байтах каждого фрагмента. Это должно быть по крайней мере cFragments
длинным.
Возвращаемое значение
В случае успешного выполнения возвращается S_OK
; в противном случае возвращается код ошибки.
Пример
В этом разделе показано, как получить адрес и длину функции с помощью IDiaSymbol
, а затем количество фрагментов, получить набор фрагментов функций, а затем распечатать их в виде списка начальных и конечных адресов.
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;
}