From 1ebf8d5edf59d21837513e65948567a7a01f91fb Mon Sep 17 00:00:00 2001 From: LLVM Packaging Team Date: Fri, 18 Sep 2020 10:47:25 +0100 Subject: [PATCH] Make ordering of OPENCL_EXTENSION_TYPES reproducible Author: Rebecca N. Palmer Bug-Debian: https://bugs.debian.org/877359 Forwarded: no Gbp-Pq: Name reproducible-pch.diff --- clang/lib/Serialization/ASTWriter.cpp | 14 +++++++++++--- 1 file changed, 11 insertions(+), 3 deletions(-) diff --git a/clang/lib/Serialization/ASTWriter.cpp b/clang/lib/Serialization/ASTWriter.cpp index f74269ee3..bfbc0b2f6 100644 --- a/clang/lib/Serialization/ASTWriter.cpp +++ b/clang/lib/Serialization/ASTWriter.cpp @@ -4293,9 +4293,13 @@ void ASTWriter::WriteOpenCLExtensionTypes(Sema &SemaRef) { return; RecordData Record; + // Sort to allow reproducible .pch files - https://bugs.debian.org/877359 + std::map> sortedOpenCLTypeExtMap; for (const auto &I : SemaRef.OpenCLTypeExtMap) { - Record.push_back( - static_cast(getTypeID(I.first->getCanonicalTypeInternal()))); + sortedOpenCLTypeExtMap[getTypeID(I.first->getCanonicalTypeInternal())]=I.second; + } + for (const auto &I : sortedOpenCLTypeExtMap) { + Record.push_back(static_cast(I.first)); Record.push_back(I.second.size()); for (auto Ext : I.second) AddString(Ext, Record); @@ -4308,8 +4312,12 @@ void ASTWriter::WriteOpenCLExtensionDecls(Sema &SemaRef) { return; RecordData Record; + std::map> sortedOpenCLDeclExtMap; for (const auto &I : SemaRef.OpenCLDeclExtMap) { - Record.push_back(getDeclID(I.first)); + sortedOpenCLDeclExtMap[getDeclID(I.first)]=I.second; + } + for (const auto &I : sortedOpenCLDeclExtMap) { + Record.push_back(I.first); Record.push_back(static_cast(I.second.size())); for (auto Ext : I.second) AddString(Ext, Record); -- 2.30.2