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

Update C++ to standard 20 for Windows #17706

Open
wants to merge 75 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 17 commits
Commits
Show all changes
75 commits
Select commit Hold shift + click to select a range
3259827
C++20 for Windows
jchen351 Sep 26, 2023
c34e2df
Disable C4189 warnign for MSC_VER
jchen351 Oct 3, 2023
200fa0e
UPDATE to _WIN32
jchen351 Oct 4, 2023
3eb33e9
Merge branch 'main' into Cjian/win_c++20
jchen351 Oct 4, 2023
a4e7339
Merge branch 'main' into Cjian/win_c++20
jchen351 Oct 6, 2023
6281fbb
Update format
jchen351 Oct 6, 2023
fefb39a
Merge branch 'main' into Cjian/win_c++20
jchen351 Oct 12, 2023
8e74584
Try to fix std::move_iterator::operator->() is deprecated in C++20
jchen351 Oct 13, 2023
19aef6a
Replace is_pod with is_trivial
jchen351 Oct 13, 2023
b81fa78
Replace "" with nullptr
jchen351 Oct 13, 2023
f62ef98
Update capture for lamda function -> void*
jchen351 Oct 13, 2023
22d8289
Merge remote-tracking branch 'refs/remotes/origin/main' into Cjian/wi…
jchen351 Jun 3, 2024
9671ae7
Fix misspell
jchen351 Jun 3, 2024
9d5b8c4
change is_pod to is_trivial
jchen351 Jun 3, 2024
caafe6d
chrono
jchen351 Jun 3, 2024
aa07557
chrono
jchen351 Jun 4, 2024
17d0322
::date::operator<<
jchen351 Jun 4, 2024
c23528b
Merge branch 'refs/heads/main' into Cjian/win_c++20
jchen351 Jun 6, 2024
59c8597
cast
jchen351 Jun 6, 2024
fe337ac
Merge branch 'refs/heads/main' into Cjian/win_c++20
jchen351 Jun 13, 2024
a968243
reinterpret_cast
jchen351 Jun 13, 2024
3bbffc3
#pragma warning(disable : 4189) // Disable warning C4189
jchen351 Jun 13, 2024
62f4300
#pragma warning(disable : 4189) // Disable warning C4189
jchen351 Jun 13, 2024
b54cee6
#pragma warning(disable : 4189) // Disable warning C4189
jchen351 Jun 13, 2024
89e48b7
_WIN32
jchen351 Jun 14, 2024
1b73721
using timestamp_ns::operator<<;
jchen351 Jun 14, 2024
8307dfe
lint
jchen351 Jun 14, 2024
bb47599
Merge remote-tracking branch 'refs/remotes/origin/main' into Cjian/wi…
jchen351 Jun 19, 2024
6c4c15f
Merge remote-tracking branch 'refs/remotes/origin/main' into Cjian/wi…
jchen351 Jun 20, 2024
8b22860
Merge remote-tracking branch 'origin/main' into Cjian/win_c++20
jchen351 Jun 20, 2024
c4a739d
Merge remote-tracking branch 'origin/main' into Cjian/win_c++20
snnn Jul 30, 2024
84de59b
Merge remote-tracking branch 'origin/main' into Cjian/win_c++20
snnn Jul 30, 2024
2746743
Merge branch 'refs/heads/main' into Cjian/win_c++20
jchen351 Aug 27, 2024
c3411c9
Merge remote-tracking branch 'origin/Cjian/win_c++20' into Cjian/win_…
jchen351 Aug 27, 2024
5360f02
Merge branch 'refs/heads/main' into Cjian/win_c++20
jchen351 Aug 27, 2024
415d350
Remvoing the reference of date.h which is no longer part of abseil
jchen351 Aug 27, 2024
cf6ee7a
Adding #include "date/date.h" back to the top of logging.h file
jchen351 Aug 27, 2024
837f45d
Adding #include "date/date.h" back to the top of logging.h file
jchen351 Aug 27, 2024
46d6d03
Merge branch 'refs/heads/main' into Cjian/win_c++20
jchen351 Aug 27, 2024
81496e0
fixes 2 problems that passes build in c++17 but would fail in c++20 o…
fs-eire Aug 27, 2024
38c8794
Including assert.h to the etw_sink.cc
jchen351 Aug 27, 2024
994f1bd
Merge remote-tracking branch 'refs/remotes/origin/fs-eire/small-fixes…
jchen351 Aug 27, 2024
ac3b8aa
Merge with fs-eire/small-fixes
jchen351 Aug 27, 2024
cce039b
Excluding ARM64 QNN from c++ supported platform
jchen351 Aug 27, 2024
1df956b
Changing ostingstream to wostringstream
jchen351 Aug 28, 2024
8184354
Change TestImageBindingStyleTransfer (..., .. , wchar_t*) to TestImag…
jchen351 Aug 28, 2024
c2f9a9b
Using wostringstream only on Windows
jchen351 Aug 30, 2024
acd5f23
Using wostringstream only on Windows
jchen351 Aug 30, 2024
cd1380c
change ifndef to ifdef
jchen351 Aug 30, 2024
dfa0b64
c_str()
jchen351 Aug 30, 2024
b59dfd3
c_str()
jchen351 Aug 30, 2024
93ffa11
lint
jchen351 Aug 30, 2024
2cc3079
Adding case when in windows for ostream sink
jchen351 Sep 3, 2024
fb1d7c6
Only allow OStreamSink to be used in Unix OSes
jchen351 Sep 4, 2024
4f82fc9
Implment FileSink with WOStreamSink for windows
jchen351 Sep 4, 2024
056e8c3
Implement FileSink with WOStreamSink for windows
jchen351 Sep 4, 2024
ee3d438
Revert previous changes
jchen351 Sep 4, 2024
ade9091
Update fileshink
jchen351 Sep 4, 2024
0137be2
Update sinks_test.cc
jchen351 Sep 4, 2024
9124045
Update sinks_test.cc
jchen351 Sep 4, 2024
3604a68
Update logging_test.cc
jchen351 Sep 4, 2024
b813203
Update lint
jchen351 Sep 4, 2024
7c6d738
Apply ToWideString to filename
jchen351 Sep 4, 2024
63bb6be
Add core/common/common.h
jchen351 Sep 4, 2024
933804b
Add core/common/common.h
jchen351 Sep 4, 2024
37afbfd
Merge branch 'refs/heads/main' into Cjian/wostream
jchen351 Sep 4, 2024
6bd7846
Fix comparing string with wstring
jchen351 Sep 4, 2024
efb7ea4
Using make_unique
jchen351 Sep 5, 2024
2d2354f
Update commend about date.h
jchen351 Sep 5, 2024
7afbb1e
onnxruntime::ToWideString(filename), false, false)
jchen351 Sep 6, 2024
287a69c
Merge branch 'refs/heads/Cjian/wostream' into Cjian/win_c++20
jchen351 Sep 6, 2024
e97ae47
Merge branch 'refs/heads/main' into Cjian/win_c++20
jchen351 Sep 6, 2024
4b07785
Merge branch 'refs/heads/main' into Cjian/win_c++20
jchen351 Sep 9, 2024
9901c2d
Merge branch 'refs/heads/main' into Cjian/win_c++20
jchen351 Sep 10, 2024
5ca5da1
Merge branch 'refs/heads/main' into Cjian/win_c++20
jchen351 Sep 17, 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
2 changes: 1 addition & 1 deletion cmake/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ include(FetchContent)
include(CheckFunctionExists)

# TODO: update this once all system adapt c++20
if(CMAKE_SYSTEM_NAME STREQUAL "Darwin")
if(CMAKE_SYSTEM_NAME STREQUAL "Darwin" OR CMAKE_SYSTEM_NAME STREQUAL "Windows")
set(CMAKE_CXX_STANDARD 20)
else()
set(CMAKE_CXX_STANDARD 17)
Expand Down
12 changes: 6 additions & 6 deletions include/onnxruntime/core/common/gpu_profiler_common.h
Original file line number Diff line number Diff line change
Expand Up @@ -325,8 +325,8 @@ class GPUTracerManager {
auto p_event_list = GetEventListForUniqueCorrelationId(unique_correlation_id);
if (p_event_list != nullptr) {
p_event_list->insert(p_event_list->end(),
std::make_move_iterator(events.begin()),
std::make_move_iterator(events.end()));
std::make_move_iterator(events.begin()).base(),
std::make_move_iterator(events.end()).base());
}
}

Expand Down Expand Up @@ -379,8 +379,8 @@ class GPUProfilerBase : public EpProfiler {
void MergeEvents(std::map<uint64_t, Events>& events_to_merge, Events& events) {
Events merged_events;

auto event_iter = std::make_move_iterator(events.begin());
auto event_end = std::make_move_iterator(events.end());
auto event_iter = std::make_move_iterator(events.begin()).base();
auto event_end = std::make_move_iterator(events.end()).base();
for (auto& map_iter : events_to_merge) {
if (map_iter.second.empty()) {
continue;
Expand Down Expand Up @@ -423,8 +423,8 @@ class GPUProfilerBase : public EpProfiler {
}

merged_events.insert(merged_events.end(),
std::make_move_iterator(map_iter.second.begin()),
std::make_move_iterator(map_iter.second.end()));
std::make_move_iterator(map_iter.second.begin()).base(),
std::make_move_iterator(map_iter.second.end()).base());
}

// move any remaining events
Expand Down
8 changes: 4 additions & 4 deletions onnxruntime/contrib_ops/cuda/math/cufft_plan_cache.h
Original file line number Diff line number Diff line change
Expand Up @@ -34,9 +34,9 @@ struct CufftPlanInfo {
template <typename T>
struct ParamsHash {
// Params must be a POD because we read out its memory
// contenst as char* when hashing
// contents as char* when hashing

static_assert(std::is_pod<T>::value, "Params is not POD");
static_assert(std::is_trivial<T>::value, "Params is not POD");
size_t operator()(const T& params) const {
auto ptr = reinterpret_cast<const uint8_t*>(&params);
uint32_t value = 0x811C9DC5;
Expand All @@ -51,9 +51,9 @@ struct ParamsHash {
template <typename T>
struct ParamsEqual {
// Params must be a POD because we read out its memory
// contenst as char* when comparing
// contents as char* when comparing

static_assert(std::is_pod<T>::value, "Params is not POD");
static_assert(std::is_trivial<T>::value, "Params is not POD");

bool operator()(const T& a, const T& b) const {
auto ptr1 = reinterpret_cast<const uint8_t*>(&a);
Expand Down
6 changes: 5 additions & 1 deletion onnxruntime/core/common/logging/sinks/ostream_sink.cc
Original file line number Diff line number Diff line change
Expand Up @@ -65,7 +65,11 @@ void OStreamSink::SendImpl(const Timestamp& timestamp, const std::string& logger
#ifdef _WIN32
void WOStreamSink::SendImpl(const Timestamp& timestamp, const std::string& logger_id, const Capture& message) {
// operator for formatting of timestamp in ISO8601 format including microseconds
using date::operator<<;
#if __cplusplus >= 202002L
jchen351 marked this conversation as resolved.
Show resolved Hide resolved
using std::chrono::date::operator<<;
#else
using date::operator<<
#endif

// Two options as there may be multiple calls attempting to write to the same sink at once:
// 1) Use mutex to synchronize access to the stream.
Expand Down
2 changes: 1 addition & 1 deletion onnxruntime/core/framework/bfc_arena.cc
Original file line number Diff line number Diff line change
Expand Up @@ -108,7 +108,7 @@ Status BFCArena::Extend(size_t rounded_bytes) {
" is smaller than requested bytes of ", rounded_bytes);
}

auto safe_alloc = [this](size_t alloc_bytes) {
auto safe_alloc = [this](size_t alloc_bytes) -> void* {
void* new_mem = nullptr;
ORT_TRY {
new_mem = device_allocator_->Alloc(alloc_bytes);
Expand Down
6 changes: 6 additions & 0 deletions onnxruntime/core/providers/cpu/tensor/upsample_antialias.h
Original file line number Diff line number Diff line change
Expand Up @@ -193,6 +193,9 @@ void SetupUpsampleFilterAntiAlias(FilterParamsAntiAlias<T>& p,
}

float total_weight_inv = total_weight == 0.0f ? 1.f : 1.0f / total_weight;
#ifdef _WIN32
#pragma warning(disable : 4189)
jchen351 marked this conversation as resolved.
Show resolved Hide resolved
#endif
auto* scale_buffer_int = reinterpret_cast<int32_t*>(scale_buffer);
for (x = 0; x < xmax_cut - xmin_cut; x++) {
scale_buffer[x] *= total_weight_inv;
Expand All @@ -202,6 +205,9 @@ void SetupUpsampleFilterAntiAlias(FilterParamsAntiAlias<T>& p,
scale_buffer_int[x] = static_cast<int32_t>(std::round(scale_buffer[x] * ConstValue::mag_factor_x_2));
}
}
#ifdef _WIN32
#pragma warning(default : 4189)
#endif
/*for (; x < window_size; x++) {
scale_buffer[x] = 0;
}*/
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -55,7 +55,7 @@ class QnnBackendManager {
~QnnBackendManager();
char* DlError() {
#ifdef _WIN32
return "";
return nullptr;
jchen351 marked this conversation as resolved.
Show resolved Hide resolved
#else
return ::dlerror();
#endif
Expand Down
4 changes: 2 additions & 2 deletions orttraining/orttraining/training_ops/cuda/nn/conv_shared.h
Original file line number Diff line number Diff line change
Expand Up @@ -55,14 +55,14 @@ struct ConvArgs {

struct ConvParamsHash {
// ConvParams must be a POD because we read out its memory constant as char* when hashing.
static_assert(std::is_pod<ConvParams>::value, "ConvParams is not POD");
static_assert(std::is_trivial<ConvParams>::value, "ConvParams is not POD");

size_t operator()(const ConvParams& conv_params) const;
};

struct ConvParamsEqual {
// ConvParams must be a POD because we read out its memory constant as char* when hashing.
static_assert(std::is_pod<ConvParams>::value, "ConvParams is not POD");
static_assert(std::is_trivial<ConvParams>::value, "ConvParams is not POD");

bool operator()(const ConvParams& a, const ConvParams& b) const;
};
Expand Down
4 changes: 2 additions & 2 deletions orttraining/orttraining/training_ops/rocm/nn/conv_grad.cc
Original file line number Diff line number Diff line change
Expand Up @@ -72,7 +72,7 @@ std::vector<T_Perf> GetValidAlgorithms(const T_Perf* perf_results, int n_algo) {

struct ConvParamsHash {
// ConvParams must be a POD because we read out its memory constant as char* when hashing.
static_assert(std::is_pod<ConvParams>::value, "ConvParams is not POD");
static_assert(std::is_trivial<ConvParams>::value, "ConvParams is not POD");
size_t operator()(const ConvParams& conv_params) const {
auto ptr = reinterpret_cast<const uint8_t*>(&conv_params);
uint32_t value = 0x811C9DC5;
Expand All @@ -86,7 +86,7 @@ struct ConvParamsHash {

struct ConvParamsEqual {
// ConvParams must be a POD because we read out its memory constant as char* when hashing.
static_assert(std::is_pod<ConvParams>::value, "ConvParams is not POD");
static_assert(std::is_trivial<ConvParams>::value, "ConvParams is not POD");
bool operator()(const ConvParams& a, const ConvParams& b) const {
auto ptr1 = reinterpret_cast<const uint8_t*>(&a);
auto ptr2 = reinterpret_cast<const uint8_t*>(&b);
Expand Down
Loading