Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add DNMD into src/native #107961

Open
wants to merge 148 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
148 commits
Select commit Hold shift + click to select a range
4f1bc36
Initial commit of DNMD
AaronRobinsonMSFT Oct 24, 2022
fdb4920
Simple mddump impl
AaronRobinsonMSFT Oct 24, 2022
aaa8aac
Remove uses of C file I/O API
AaronRobinsonMSFT Oct 24, 2022
428b569
Create table/column index enum
AaronRobinsonMSFT Oct 26, 2022
157318e
Add support for Portable PDBs
AaronRobinsonMSFT Oct 26, 2022
39670eb
Minor nits
AaronRobinsonMSFT Oct 27, 2022
fe7a626
Fix C and C++ issues on clang
AaronRobinsonMSFT Oct 28, 2022
7c2f48a
Add PE data structures to platform.h
AaronRobinsonMSFT Oct 28, 2022
87cfbbe
Move around platform headers
AaronRobinsonMSFT Oct 28, 2022
23382a8
Incorrect macro used.
AaronRobinsonMSFT Oct 29, 2022
097796f
Cursor updates
AaronRobinsonMSFT Oct 29, 2022
eeb50cb
Change query API to permit bulk
AaronRobinsonMSFT Oct 30, 2022
f5b058a
Start implementation for interfaces
AaronRobinsonMSFT Oct 30, 2022
8a1a4d2
Add build of static and shared
AaronRobinsonMSFT Oct 30, 2022
d1abd88
Start Regression testing suite
AaronRobinsonMSFT Oct 31, 2022
302aaf1
Missed test props file.
AaronRobinsonMSFT Oct 31, 2022
c11b1fd
Create CoTaskMemAlloc and malloc smart pointers
AaronRobinsonMSFT Oct 31, 2022
10fe9f2
EnumTypeDefs always skips the first row.
AaronRobinsonMSFT Oct 31, 2022
6647a1f
Add find logic for sorted tables in dnmd
AaronRobinsonMSFT Nov 1, 2022
ec235b3
Add impl and test for EnumMembers
AaronRobinsonMSFT Nov 2, 2022
44f7f5a
EnumParams and EnumFields
AaronRobinsonMSFT Nov 2, 2022
8e6ad50
EnumProperties
AaronRobinsonMSFT Nov 2, 2022
5f1848e
Add entries for tables not defined in ECMA
AaronRobinsonMSFT Nov 3, 2022
018cf61
Enum Events and UserStrings
AaronRobinsonMSFT Nov 5, 2022
a5ee998
GetClassLayout
AaronRobinsonMSFT Nov 7, 2022
78b76ea
Mark MetadataImportRO final and all methods
AaronRobinsonMSFT Nov 7, 2022
f3f5167
Nits
AaronRobinsonMSFT Nov 7, 2022
bad5bf6
GetTypeSpecFromToken and GetRVA
AaronRobinsonMSFT Nov 7, 2022
8f7c0de
Add flags for specific table to mddump.
AaronRobinsonMSFT Nov 7, 2022
aa1db66
IsGlobal
AaronRobinsonMSFT Nov 10, 2022
87a7d06
Update Regression test project
AaronRobinsonMSFT Nov 11, 2022
d30ea61
Fix CMake logic for publishing headers
AaronRobinsonMSFT Nov 12, 2022
adf15ae
Always emit symbols
AaronRobinsonMSFT Nov 12, 2022
42b0503
Add project to compare perf and profile
AaronRobinsonMSFT Nov 12, 2022
f8de5cb
Style nits
AaronRobinsonMSFT Nov 12, 2022
9409fa0
EnumPermissionSets
AaronRobinsonMSFT Nov 13, 2022
5f4ae38
Remove some unnecessary overhead
AaronRobinsonMSFT Nov 13, 2022
52a6df0
Make testing against NETFX 2/4 easier.
AaronRobinsonMSFT Nov 13, 2022
3ba53ee
Add tests for running against NETFX 2/4 BCL
AaronRobinsonMSFT Nov 14, 2022
6d9ac81
GetTypeDefProps
AaronRobinsonMSFT Nov 19, 2022
7452733
EnumMembersWithName
AaronRobinsonMSFT Nov 19, 2022
a16f8f7
Add lifetime cleanup mechanism for enum
AaronRobinsonMSFT Nov 19, 2022
31682c8
EnumMethodsWithName
AaronRobinsonMSFT Nov 20, 2022
e7873a9
GetMethodProps
AaronRobinsonMSFT Nov 20, 2022
f1aa57b
GetScopeProps
AaronRobinsonMSFT Nov 20, 2022
4724df7
EnumMemberRefs
AaronRobinsonMSFT Nov 20, 2022
781a76d
dnmd library nits.
AaronRobinsonMSFT Nov 21, 2022
0d7f55b
Improve performance test for expansion
AaronRobinsonMSFT Nov 21, 2022
529eba3
Request LTCG
AaronRobinsonMSFT Nov 22, 2022
50a3d5a
GetPinvokeMap
AaronRobinsonMSFT Nov 22, 2022
f33b003
GetTypeRefProps
AaronRobinsonMSFT Nov 22, 2022
5a5e25a
GetModuleRefProps
AaronRobinsonMSFT Nov 23, 2022
3feefdb
GetFieldMarshal
AaronRobinsonMSFT Nov 23, 2022
97b4216
GetNestedClassProps
AaronRobinsonMSFT Nov 23, 2022
88a5c5b
FindTypeRef
AaronRobinsonMSFT Nov 23, 2022
151e41c
GetParamForMethodIndex
AaronRobinsonMSFT Nov 24, 2022
dac337a
EnumMethodImpls
AaronRobinsonMSFT Nov 24, 2022
6018085
EnumCustomAttributes
AaronRobinsonMSFT Nov 25, 2022
d376c51
GetCustomAttributeProps
AaronRobinsonMSFT Nov 25, 2022
90687aa
GetEventProps
AaronRobinsonMSFT Nov 29, 2022
1a59d14
GetMemberProps
AaronRobinsonMSFT Nov 30, 2022
75da83d
GetCustomAttributeByName
AaronRobinsonMSFT Dec 1, 2022
2bd11ed
Fix TypeSpec reading for CustomAttributes
AaronRobinsonMSFT Dec 1, 2022
062e09e
GetCustomAttributeByName benchmark
AaronRobinsonMSFT Dec 3, 2022
2a50e58
Nits
AaronRobinsonMSFT Dec 3, 2022
77dd2c1
GetNameFromToken
AaronRobinsonMSFT Dec 3, 2022
493c97b
GetNativeCallConvFromSig
AaronRobinsonMSFT Dec 6, 2022
57f409a
Nits
AaronRobinsonMSFT Dec 6, 2022
c439fd4
FindTypeDefByName
AaronRobinsonMSFT Dec 11, 2022
88fc3b6
Fix bug in GetMethodProps
AaronRobinsonMSFT Jan 10, 2023
4b34fcb
Add notes about running tests.
AaronRobinsonMSFT Jan 11, 2023
8bf3db2
Reference IL project in UnitTests project.
AaronRobinsonMSFT Jan 11, 2023
986c037
Show the il file in VS's solution view
jkoritzinsky Jan 11, 2023
26d2a56
Include the interop debugging configuration in checked-in source
jkoritzinsky Jan 11, 2023
e601dfe
Implement IMetaDataImport2 APIs for generics and MethodSpecs
jkoritzinsky Jan 11, 2023
9ef3e53
Implement GetVersionString and add comment about GetPEKind
jkoritzinsky Jan 11, 2023
f99db3e
Implement IMetadataImport::FindMethod
jkoritzinsky Jan 13, 2023
e72083f
Implement FindMember, FindField, and FindMemberRef APIs
jkoritzinsky Jan 14, 2023
23b1439
PR feedback
jkoritzinsky Jan 17, 2023
58de7bd
Remove span.hpp
jkoritzinsky Jan 17, 2023
1a51885
Fix build
jkoritzinsky Jan 17, 2023
cc6f85d
Update managed tests to only use IMetaDataImport2 as there's no tests…
jkoritzinsky Jan 17, 2023
0f6b30b
Always call FindMethod before FindField
jkoritzinsky Jan 17, 2023
403fdbb
Fix up string handling feedback
jkoritzinsky Jan 17, 2023
5d02e18
Merge pull request #2 from AaronRobinsonMSFT/interface-generic
jkoritzinsky Jan 19, 2023
31238a3
Style nits
AaronRobinsonMSFT Jan 20, 2023
708d722
Reduce allocation for context
AaronRobinsonMSFT Jan 21, 2023
2b59b3a
Add predicate to query functions to avoid
AaronRobinsonMSFT Jan 23, 2023
e55983d
Move regperf to a regnative location for shared
AaronRobinsonMSFT Jan 27, 2023
d45df75
Port unit test logic to C++
AaronRobinsonMSFT Jan 29, 2023
b1ce758
Fix build on macOS
AaronRobinsonMSFT Jan 30, 2023
291738f
Respond to macOS build support on Windows
AaronRobinsonMSFT Jan 30, 2023
23f0afe
Tests pass on macOS
AaronRobinsonMSFT Feb 1, 2023
1d85e15
Linux builds if utf16 <=> utf8 conversion
AaronRobinsonMSFT Feb 1, 2023
875b951
Merge in Import implementation and testing
AaronRobinsonMSFT Feb 1, 2023
9bc8775
Remove "unknown pragma" suppressions.
AaronRobinsonMSFT Feb 1, 2023
c168abc
Add main CI job that builds, tests, and reports test failures as anot…
jkoritzinsky Feb 1, 2023
3fe4779
Update main.yml
jkoritzinsky Feb 2, 2023
9e62fd3
Make a small whitespace change to trigger the action
jkoritzinsky Feb 2, 2023
5452f9f
Merge pull request #13 from jkoritzinsky/ci
jkoritzinsky Feb 2, 2023
cfc7aed
Set some loader and build settings to make the macos build work better.
Feb 3, 2023
58ba75f
Don't to IPO on debug builds. Clang's ThinLTO in dynamic libraries cr…
Feb 11, 2023
ddd13a2
Null terminate buffers passed to the encoding conversion functions
Feb 11, 2023
6d50918
Set the right upload path for test results.
Feb 11, 2023
9368501
Fix test results uupload
Feb 11, 2023
fdd4279
Add rpath settings for macOS.
AaronRobinsonMSFT Feb 11, 2023
7f23e99
Merge pull request #15 from jkoritzinsky/fix-mac-build
AaronRobinsonMSFT Feb 11, 2023
f56d6b3
Compare baseline results to current results by value instead of by po…
jkoritzinsky Feb 11, 2023
0f6cd39
Implement and test IMetaDataAssemblyImport (#11)
jkoritzinsky Feb 12, 2023
1e874d8
Disable fail-fast on strategy (#17)
jkoritzinsky Feb 23, 2023
669b5ed
Publish test results in separate workflow (#16)
jkoritzinsky Feb 23, 2023
5e86175
Add license (#20)
AaronRobinsonMSFT Feb 27, 2023
4bb22b4
Enable building with GCC and Linux. (#21)
jkoritzinsky Feb 28, 2023
5506a36
Add support for the uncompressed stream, indirection tables, and mini…
jkoritzinsky Mar 29, 2023
901a319
Define when to run CI on push
AaronRobinsonMSFT Mar 31, 2023
f805a5d
Fixes based on fuzzing with afl++ (#25)
AaronRobinsonMSFT Mar 31, 2023
068261a
Update build infrastructure to install as a modern CMake package (#26)
jkoritzinsky Jun 22, 2023
58f314e
Stubbed out delta API in `dnmd` (#27)
AaronRobinsonMSFT Jul 28, 2023
3a2da4d
Explicitly validate that the user is asking for a sorted column when …
jkoritzinsky Jul 28, 2023
b2f9b79
Change the interfaces library to use a tear-off model to make adding …
jkoritzinsky Jul 30, 2023
7a060b7
Use macros to templatize search functions (#31)
AaronRobinsonMSFT Aug 11, 2023
de389c3
Add a writing API and implement the md_apply_delta API in terms of it…
jkoritzinsky Aug 14, 2023
c813324
Update style to be consistent (#32)
AaronRobinsonMSFT Aug 15, 2023
c8ba731
Create API for accessing raw column data. (#34)
AaronRobinsonMSFT Aug 16, 2023
c09468c
Implement save APIs and provide an mdmerge tool that composes an imag…
jkoritzinsky Aug 24, 2023
5b7bd51
Add specialized parsing functions for portable pdb blobs (#38)
jkoritzinsky Aug 30, 2023
3f2ad67
Introduce a marker interface and move ownership to it (#39)
jkoritzinsky Sep 2, 2023
9538281
Various improvements for PDBs (#40)
jkoritzinsky Sep 11, 2023
ca08231
Fix refcount leaks in dnmd::interfaces (#41)
jkoritzinsky Sep 13, 2023
9982141
Remove tool source duplication (#42)
AaronRobinsonMSFT Nov 28, 2023
334d8cb
Change the "data to write" parameters in `md_set_column_value_as_*` m…
jkoritzinsky Nov 29, 2023
31e70b8
Add a new md_add_new_row_to_sorted_list function to insert a row into…
jkoritzinsky Nov 30, 2023
454300f
Move the "get MethodDefSig from a MethodRefSig" functionality into dn…
jkoritzinsky Dec 5, 2023
e457e73
Initial infrastructure for SymReader support (#46)
AaronRobinsonMSFT Dec 6, 2023
63745b3
Update to .NET 8 (#47)
AaronRobinsonMSFT Dec 6, 2023
71939f2
Fix the version length field when saving (#51)
jkoritzinsky Jan 4, 2024
66ce795
Implement signature importing (#48)
jkoritzinsky Jan 10, 2024
e2e6276
Add DNMD API to create a new metadata handle and implement IMetaDataD…
jkoritzinsky Jan 18, 2024
af70b97
Convert our unit tests and perf harness to use native entry-points (#50)
jkoritzinsky Jan 26, 2024
9b986e1
Disable the Preview SDK message (#53)
jkoritzinsky Apr 10, 2024
e592785
Provide single-threaded (no-locking) implementation of IMetadataEmit …
jkoritzinsky Jun 18, 2024
bccf406
Add a thread-safe wrapping implementation (#54)
jkoritzinsky Jul 23, 2024
b4d7ca7
Implement fix in DNMD for dotnet/runtime#108907
jkoritzinsky Oct 16, 2024
9a97253
Change the DNMD APIs to act on single rows and bring other
jkoritzinsky Oct 31, 2024
99a7991
Merge branch 'dnmd-only' into HEAD
jkoritzinsky Oct 31, 2024
a6d049e
Move the native non-crypto-use SHA1 impl to minipal and reuse it from…
jkoritzinsky Oct 15, 2024
4167a4c
Integrate DNMD into the runtime repos build.
jkoritzinsky Sep 16, 2024
6d99e39
Remove the implicit conversion from span<T> to T* and instead introdu…
jkoritzinsky Nov 1, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Remove the implicit conversion from span<T> to T* and instead introdu…
…ce a .data() member, matching the C++20 design for span<T>
  • Loading branch information
jkoritzinsky committed Nov 6, 2024
commit 6d99e39bfde6f8e43a63dcf6a066a4896affbab3
18 changes: 9 additions & 9 deletions src/native/dnmd/src/inc/internal/dnmd_tools_platform.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@
inline bool create_mdhandle(malloc_span<uint8_t> const& buffer, mdhandle_ptr& handle)
{
mdhandle_t h;
if (!md_create_handle(buffer, buffer.size(), &h))
if (!md_create_handle(buffer.data(), buffer.size(), &h))
return false;
handle.reset(h);
return true;
Expand Down Expand Up @@ -71,7 +71,7 @@ inline bool read_in_file(char const* file, malloc_span<uint8_t>& b)
return false;

b = { (uint8_t*)std::malloc(size), size };
fd.read((char*)(uint8_t*)b, b.size());
fd.read((char*)b.data(), b.size());
return true;
}

Expand All @@ -82,7 +82,7 @@ inline bool write_out_file(char const* file, malloc_span<uint8_t> b)
if (!fd)
return false;

fd.write((char*)(uint8_t*)b, b.size());
fd.write((char*)b.data(), b.size());
return true;
}

Expand All @@ -95,7 +95,7 @@ inline bool find_pe_image_bitness(uint16_t machine, uint8_t& bitness)
case ((x) ^ IMAGE_FILE_MACHINE_OS_MASK_NETBSD): \
case ((x) ^ IMAGE_FILE_MACHINE_OS_MASK_SUN): \
case (x)

switch (machine)
{
MAKE_MACHINE_CASE(IMAGE_FILE_MACHINE_I386):
Expand All @@ -120,7 +120,7 @@ inline bool get_metadata_from_pe(malloc_span<uint8_t>& b)

// [TODO] Handle endian issues with .NET generated PE images
// All integers should be read as little-endian.
auto dos_header = (PIMAGE_DOS_HEADER)(void*)b;
auto dos_header = (PIMAGE_DOS_HEADER)(void*)b.data();
bool is_pe = dos_header->e_magic == IMAGE_DOS_SIGNATURE;
if (!is_pe)
return false;
Expand All @@ -138,7 +138,7 @@ inline bool get_metadata_from_pe(malloc_span<uint8_t>& b)
size_t remaining_pe_size = b.size() - dos_header->e_lfanew;
uint16_t section_header_count;
uint8_t* section_header_begin;
auto nt_header_any = (PIMAGE_NT_HEADERS)(b + dos_header->e_lfanew);
auto nt_header_any = (PIMAGE_NT_HEADERS)(b.data() + dos_header->e_lfanew);
uint16_t machine = nt_header_any->FileHeader.Machine;

uint8_t bitness;
Expand Down Expand Up @@ -196,7 +196,7 @@ inline bool get_metadata_from_pe(malloc_span<uint8_t>& b)
if (cor_header_offset > b.size() - sizeof(IMAGE_COR20_HEADER))
return false;

auto cor_header = (PIMAGE_COR20_HEADER)(b + cor_header_offset);
auto cor_header = (PIMAGE_COR20_HEADER)(b.data() + cor_header_offset);
tgt_header = find_section_header(section_headers, cor_header->MetaData.VirtualAddress);
if (tgt_header == nullptr)
return false;
Expand All @@ -209,15 +209,15 @@ inline bool get_metadata_from_pe(malloc_span<uint8_t>& b)
if (metadata_offset > b.size())
return false;

void* ptr = (void*)(b + metadata_offset);
void* ptr = (void*)(b.data() + metadata_offset);

size_t metadata_length = cor_header->MetaData.Size;
if (metadata_length > b.size() - metadata_offset)
return false;

// Capture the metadata portion of the image.
malloc_span<uint8_t> metadata = { (uint8_t*)std::malloc(metadata_length), metadata_length };
std::memcpy(metadata, ptr, metadata.size());
std::memcpy(metadata.data(), ptr, metadata.size());
b = std::move(metadata);
return true;
}
Expand Down
8 changes: 4 additions & 4 deletions src/native/dnmd/src/inc/internal/span.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -29,12 +29,12 @@ class span
return _size;
}

operator T* () noexcept
T* data() noexcept
{
return _ptr;
}

operator T const* () const noexcept
T const* data() const noexcept
{
return _ptr;
}
Expand Down Expand Up @@ -137,7 +137,7 @@ span<T> slice(span<T> b, size_t offset)
{
if (offset > b.size())
throw std::out_of_range{ "Out of bounds access" };
return { b + offset, b.size() - offset };
return { b.data() + offset, b.size() - offset };
}

#endif // _SRC_INC_INTERNAL_SPAN_HPP_
#endif // _SRC_INC_INTERNAL_SPAN_HPP_
16 changes: 5 additions & 11 deletions src/native/dnmd/src/interfaces/importhelpers.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -206,13 +206,13 @@ namespace
if (publicKeyBlob.size() < sizeof(PublicKeyBlob))
return CORSEC_E_INVALID_PUBLICKEY;

PublicKeyBlob const* publicKey = reinterpret_cast<PublicKeyBlob const*>((uint8_t const*)publicKeyBlob);
PublicKeyBlob const* publicKey = reinterpret_cast<PublicKeyBlob const*>(publicKeyBlob.data());

if (publicKey->PublicKeyLength != publicKeyBlob.size() - sizeof(PublicKeyBlob))
return CORSEC_E_INVALID_PUBLICKEY;

if (publicKeyBlob.size() == sizeof(StrongNameKeys::EcmaPublicKey)
&& std::memcmp(publicKeyBlob, StrongNameKeys::EcmaPublicKey, sizeof(StrongNameKeys::EcmaPublicKey)) == 0)
&& std::memcmp(publicKeyBlob.data(), StrongNameKeys::EcmaPublicKey, sizeof(StrongNameKeys::EcmaPublicKey)) == 0)
{
return S_OK;
}
Expand Down Expand Up @@ -685,14 +685,10 @@ namespace
if (!md_set_column_value_as_utf8(assemblyRef, mdtAssemblyRef_Culture, assemblyCulture))
return E_FAIL;

uint8_t const* hash = sourceAssemblyHash;
uint32_t hashLength = (uint32_t)sourceAssemblyHash.size();
if (!md_set_column_value_as_blob(assemblyRef, mdtAssemblyRef_HashValue, hash, hashLength))
if (!md_set_column_value_as_blob(assemblyRef, mdtAssemblyRef_HashValue, sourceAssemblyHash.data(), (uint32_t)sourceAssemblyHash.size()))
return E_FAIL;

uint8_t const* publicKeyTokenBlob = publicKeyToken.data();
uint32_t publicKeyTokenLength = (uint32_t)publicKeyToken.size();
if (!md_set_column_value_as_blob(assemblyRef, mdtAssemblyRef_PublicKeyOrToken, publicKeyTokenBlob, publicKeyTokenLength))
if (!md_set_column_value_as_blob(assemblyRef, mdtAssemblyRef_PublicKeyOrToken, publicKeyToken.data(), (uint32_t)publicKeyToken.size()))
return E_FAIL;

*targetAssembly = assemblyRef;
Expand Down Expand Up @@ -1704,9 +1700,7 @@ HRESULT ImportReferenceToTypeDefOrRefOrSpec(
if (!md_append_row(targetModule, mdtid_TypeSpec, &typeSpec))
return E_FAIL;

uint8_t const* importedSignatureData = importedSignature;
uint32_t importedSignatureLength = (uint32_t)importedSignature.size();
if (!md_set_column_value_as_blob(typeSpec, mdtTypeSpec_Signature, importedSignatureData, importedSignatureLength))
if (!md_set_column_value_as_blob(typeSpec, mdtTypeSpec_Signature, importedSignature.data(), (uint32_t)importedSignature.size()))
return E_FAIL;

if (!md_cursor_to_token(typeSpec, importedToken))
Expand Down
2 changes: 1 addition & 1 deletion src/native/dnmd/src/interfaces/metadataimport.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1153,7 +1153,7 @@ HRESULT STDMETHODCALLTYPE MetadataImportRO::FindMethod(
if (!md_get_column_value_as_blob(target, mdtMethodDef_Signature, &sig, &sigLen))
return CLDB_E_FILE_CORRUPT;
if (sigLen != methodDefSig.size()
|| ::memcmp(methodDefSig, sig, sigLen) != 0)
|| ::memcmp(methodDefSig.data(), sig, sigLen) != 0)
{
continue;
}
Expand Down
2 changes: 1 addition & 1 deletion src/native/dnmd/src/interfaces/pal.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -113,7 +113,7 @@ int strcat_s(char* dest, rsize_t destsz, char const* src)

bool pal::ComputeSha1Hash(span<uint8_t const> data, std::array<uint8_t, SHA1_HASH_SIZE>& hashDestination)
{
minipal_sha1(data, data.size(), hashDestination.data(), SHA1_HASH_SIZE);
minipal_sha1(data.data(), data.size(), hashDestination.data(), SHA1_HASH_SIZE);
return true;
}

Expand Down
12 changes: 6 additions & 6 deletions src/native/dnmd/src/interfaces/signatures.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -11,23 +11,23 @@ namespace
std::tuple<uint32_t, span<T>> read_compressed_uint(span<T> signature)
{
ULONG value = 0;
signature = slice(signature, CorSigUncompressData(signature, &value));
signature = slice(signature, CorSigUncompressData(signature.data(), &value));
return std::make_tuple(value, signature);
}

template<typename T, typename = typename std::enable_if<std::is_same<typename std::remove_const<T>::type, uint8_t>::value>::type>
std::tuple<int32_t, span<T>> read_compressed_int(span<T> signature)
{
int value = 0;
signature = slice(signature, CorSigUncompressSignedInt(signature, &value));
signature = slice(signature, CorSigUncompressSignedInt(signature.data(), &value));
return std::make_tuple(value, signature);
}

template<typename T, typename = typename std::enable_if<std::is_same<typename std::remove_const<T>::type, uint8_t>::value>::type>
std::tuple<mdToken, span<T>> read_compressed_token(span<T> signature)
{
mdToken value = mdTokenNil;
signature = slice(signature, CorSigUncompressToken(signature, &value));
signature = slice(signature, CorSigUncompressToken(signature.data(), &value));
return std::make_tuple(value, signature);
}

Expand Down Expand Up @@ -272,14 +272,14 @@ void GetMethodDefSigFromMethodRefSig(span<uint8_t> methodRefSig, inline_span<uin
methodDefSig[offset++] = callingConvention;
if ((callingConvention & IMAGE_CEE_CS_CALLCONV_GENERIC) == IMAGE_CEE_CS_CALLCONV_GENERIC)
{
offset += CorSigCompressData(genericParameterCount, methodDefSig + offset);
offset += CorSigCompressData(genericParameterCount, methodDefSig.data() + offset);
}
std::memcpy(methodDefSig + offset, compressedNewParamCount, newParamCountCompressedSize);
std::memcpy(methodDefSig.data() + offset, compressedNewParamCount.data(), newParamCountCompressedSize);
offset += newParamCountCompressedSize;

// Now that we've re-written the parameter count, we can copy the rest of the signature directly from the MethodRefSig
assert(returnTypeAndParameters.size() >= methodDefSigBufferLength - offset);
std::memcpy(methodDefSig + offset, returnTypeAndParameters, methodDefSigBufferLength - offset);
std::memcpy(methodDefSig.data() + offset, returnTypeAndParameters.data(), methodDefSigBufferLength - offset);

return;
}
Expand Down
2 changes: 1 addition & 1 deletion src/native/dnmd/src/mdmerge/main.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -82,7 +82,7 @@ void merge(merge_config_t cfg)
size_t save_size;
md_write_to_buffer(handle.get(), nullptr, &save_size);
malloc_span<uint8_t> out_buffer { (uint8_t*)malloc(save_size), save_size };
if (!md_write_to_buffer(handle.get(), out_buffer, &save_size))
if (!md_write_to_buffer(handle.get(), out_buffer.data(), &save_size))
{
std::fprintf(stderr, "Failed to save image.\n");
}
Expand Down
2 changes: 1 addition & 1 deletion src/native/dnmd/test/regpal/pal.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -140,7 +140,7 @@ bool pal::ReadFile(pal::path path, malloc_span<uint8_t>& b)
b = { (uint8_t*)std::malloc(size), size };

DWORD bytesRead;
if (!ReadFile(file.get(), b, (DWORD)b.size(), &bytesRead, nullptr))
if (!::ReadFile(file.get(), b.data(), (DWORD)b.size(), &bytesRead, nullptr))
return false;

return bytesRead == b.size();
Expand Down
2 changes: 1 addition & 1 deletion src/native/dnmd/test/regperf/perf.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -207,7 +207,7 @@ int MAIN_CALLCONV main(int argc, char** argv)
}

RETURN_IF_FAILED(PerfInitialize(
dataImage,
dataImage.data(),
(uint32_t)dataImage.size()));

benchmark::Initialize(&argc, argv);
Expand Down
2 changes: 1 addition & 1 deletion src/native/dnmd/test/regtest/discovery.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -150,7 +150,7 @@ namespace
THROW_IF_FAILED(image->GetSaveSize(cssAccurate, &size));

malloc_span<uint8_t> imageWithIndirectionTables{ (uint8_t*)malloc(size), size };
THROW_IF_FAILED(image->SaveToMemory(imageWithIndirectionTables, size));
THROW_IF_FAILED(image->SaveToMemory(imageWithIndirectionTables.data(), size));

return imageWithIndirectionTables;
}
Expand Down
8 changes: 4 additions & 4 deletions src/native/dnmd/test/regtest/metadata.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1624,14 +1624,14 @@ TEST(FindTest, FindAPIs)
malloc_span<uint8_t> metadata = GetRegressionAssemblyMetadata();

minipal::com_ptr<IMetaDataImport2> baselineImport;
ASSERT_HRESULT_SUCCEEDED(CreateImport(TestBaseline::Metadata, metadata, (uint32_t)metadata.size(), &baselineImport));
ASSERT_HRESULT_SUCCEEDED(CreateImport(TestBaseline::Metadata, metadata.data(), (uint32_t)metadata.size(), &baselineImport));
// Load metadata
minipal::com_ptr<IMetaDataImport2> currentImport;

minipal::com_ptr<IMetaDataDispenser> dispenser;
ASSERT_HRESULT_SUCCEEDED(GetDispenser(IID_IMetaDataDispenser, (void**)&dispenser));

ASSERT_HRESULT_SUCCEEDED(CreateImport(dispenser, metadata, (uint32_t)metadata.size(), &currentImport));
ASSERT_HRESULT_SUCCEEDED(CreateImport(dispenser, metadata.data(), (uint32_t)metadata.size(), &currentImport));

static auto FindTokenByName = [](IMetaDataImport2* import, LPCWSTR name, mdToken enclosing = mdTokenNil) -> mdToken
{
Expand Down Expand Up @@ -1767,7 +1767,7 @@ TEST_P(MetadataImportTest, ImportAPIs)
{
auto param = GetParam();
span<uint8_t> blob = GetMetadataForFile(param);
void const* data = blob;
void const* data = blob.data();
uint32_t dataLen = (uint32_t)blob.size();

// Load metadata
Expand Down Expand Up @@ -2004,7 +2004,7 @@ TEST_P(MetaDataLongRunningTest, ImportAPIs)
{
auto param = GetParam();
span<uint8_t> blob = GetMetadataForFile(param);
void const* data = blob;
void const* data = blob.data();
uint32_t dataLen = (uint32_t)blob.size();

// Load metadata
Expand Down
Loading