Skip to content

Commit 32a2c89

Browse files
committed
Merge branch 'main' into frontend/update-flags
2 parents daa5714 + 885cb59 commit 32a2c89

File tree

1,764 files changed

+109178
-49599
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

1,764 files changed

+109178
-49599
lines changed

.github/renovate.json

Lines changed: 12 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,12 @@
1+
{
2+
"$schema": "https://docs.renovatebot.com/renovate-schema.json",
3+
"extends": [
4+
"config:recommended"
5+
],
6+
"includePaths": [".github/**"],
7+
"schedule": "* 0 * * 1",
8+
"minimumReleaseAge": "3 days",
9+
"assignees": ["boomanaiden154"],
10+
"ignorePaths": [".github/workflows/containers/**"],
11+
"groupName": "[Github] Update GHA Dependencies"
12+
}

.github/workflows/containers/github-action-ci/Dockerfile

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -2,7 +2,7 @@ FROM docker.io/library/ubuntu:24.04 as base
22
ENV LLVM_SYSROOT=/opt/llvm
33

44
FROM base as stage1-toolchain
5-
ENV LLVM_VERSION=21.1.0
5+
ENV LLVM_VERSION=21.1.1
66

77
RUN apt-get update && \
88
apt-get install -y \

.github/workflows/pr-code-lint.yml

Lines changed: 5 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -33,7 +33,7 @@ jobs:
3333

3434
- name: Get changed files
3535
id: changed-files
36-
uses: step-security/changed-files@3dbe17c78367e7d60f00d78ae6781a35be47b4a1 # v45.0.1
36+
uses: tj-actions/changed-files@ed68ef82c095e0d48ec87eccea555d944a631a4c # v46.0.5
3737
with:
3838
separator: ","
3939
skip_initial_fetch: true
@@ -47,10 +47,13 @@ jobs:
4747
echo "Changed files:"
4848
echo "$CHANGED_FILES"
4949
50+
# The clang tidy version should always be upgraded to the first version
51+
# of a release cycle (x.1.0) or the last version of a release cycle, or
52+
# if there have been relevant clang-format backports.
5053
- name: Install clang-tidy
5154
uses: aminya/setup-cpp@17c11551771948abc5752bbf3183482567c7caf0 # v1.1.1
5255
with:
53-
clang-tidy: 20.1.8
56+
clang-tidy: 21.1.0
5457

5558
- name: Setup Python env
5659
uses: actions/setup-python@42375524e23c412d93fb67b49958b491fce71c38 # v5.4.0

bolt/include/bolt/Core/BinaryContext.h

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -326,6 +326,9 @@ class BinaryContext {
326326
/// Returns true if DWARF4 or lower is used.
327327
bool isDWARFLegacyUsed() const { return ContainsDwarfLegacy; }
328328

329+
/// Returns true if DWARFUnit is valid.
330+
bool isValidDwarfUnit(DWARFUnit &DU) const;
331+
329332
std::map<unsigned, DwarfLineTable> &getDwarfLineTables() {
330333
return DwarfLineTablesCUMap;
331334
}

bolt/include/bolt/Core/DIEBuilder.h

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -217,7 +217,8 @@ class DIEBuilder {
217217
std::optional<BOLTDWARF5AccelTableData *> Parent,
218218
uint32_t NumberParentsInChain);
219219

220-
void registerUnit(DWARFUnit &DU, bool NeedSort);
220+
/// Returns true if DWARFUnit is registered successfully.
221+
bool registerUnit(DWARFUnit &DU, bool NeedSort);
221222

222223
/// \return the unique ID of \p U if it exists.
223224
std::optional<uint32_t> getUnitId(const DWARFUnit &DU);

bolt/include/bolt/Core/FunctionLayout.h

Lines changed: 16 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -232,20 +232,31 @@ class FunctionLayout {
232232
return Blocks[Index];
233233
}
234234

235+
/// Return the basic block after the given basic block iterator in the layout
236+
/// or nullptr if the last basic block iterator is given.
237+
const BinaryBasicBlock *getBasicBlockAfter(block_const_iterator BlockIt,
238+
bool IgnoreSplits = true) const;
239+
240+
/// Returns the basic block after the given basic block in the layout or
241+
/// nullptr if the last basic block is given.
242+
///
243+
/// Note: prefer the version that takes the iterator as this function uses
244+
/// linear basic block lookup.
245+
const BinaryBasicBlock *getBasicBlockAfter(const BinaryBasicBlock *BB,
246+
bool IgnoreSplits = true) const;
247+
235248
/// Returns the basic block after the given basic block in the layout or
236249
/// nullptr if the last basic block is given.
250+
///
251+
/// Note: prefer the version that takes the iterator as this function uses
252+
/// linear basic block lookup.
237253
BinaryBasicBlock *getBasicBlockAfter(const BinaryBasicBlock *const BB,
238254
const bool IgnoreSplits = true) {
239255
return const_cast<BinaryBasicBlock *>(
240256
static_cast<const FunctionLayout &>(*this).getBasicBlockAfter(
241257
BB, IgnoreSplits));
242258
}
243259

244-
/// Returns the basic block after the given basic block in the layout or
245-
/// nullptr if the last basic block is given.
246-
const BinaryBasicBlock *getBasicBlockAfter(const BinaryBasicBlock *BB,
247-
bool IgnoreSplits = true) const;
248-
249260
/// True if the layout contains at least two non-empty fragments.
250261
bool isSplit() const;
251262

bolt/lib/Core/BinaryContext.cpp

Lines changed: 16 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1624,10 +1624,26 @@ DWARFContext *BinaryContext::getDWOContext() const {
16241624
return &DWOCUs.begin()->second->getContext();
16251625
}
16261626

1627+
bool BinaryContext::isValidDwarfUnit(DWARFUnit &DU) const {
1628+
// Invalid DWARF unit with a DWOId but lacking a dwo_name.
1629+
if (DU.getDWOId() && !DU.isDWOUnit() &&
1630+
!DU.getUnitDIE().find(
1631+
{dwarf::DW_AT_dwo_name, dwarf::DW_AT_GNU_dwo_name})) {
1632+
this->outs() << "BOLT-ERROR: broken DWARF found in CU at offset 0x"
1633+
<< Twine::utohexstr(DU.getOffset()) << " (DWOId=0x"
1634+
<< Twine::utohexstr(*(DU.getDWOId()))
1635+
<< ", missing DW_AT_dwo_name / DW_AT_GNU_dwo_name)\n";
1636+
return false;
1637+
}
1638+
return true;
1639+
}
1640+
16271641
/// Handles DWO sections that can either be in .o, .dwo or .dwp files.
16281642
void BinaryContext::preprocessDWODebugInfo() {
16291643
for (const std::unique_ptr<DWARFUnit> &CU : DwCtx->compile_units()) {
16301644
DWARFUnit *const DwarfUnit = CU.get();
1645+
if (!isValidDwarfUnit(*DwarfUnit))
1646+
continue;
16311647
if (std::optional<uint64_t> DWOId = DwarfUnit->getDWOId()) {
16321648
std::string DWOName = dwarf::toString(
16331649
DwarfUnit->getUnitDIE().find(

bolt/lib/Core/BinaryFunction.cpp

Lines changed: 4 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -3598,7 +3598,9 @@ void BinaryFunction::fixBranches() {
35983598
auto &MIB = BC.MIB;
35993599
MCContext *Ctx = BC.Ctx.get();
36003600

3601-
for (BinaryBasicBlock *BB : BasicBlocks) {
3601+
for (auto BBI = Layout.block_begin(), BBE = Layout.block_end(); BBI != BBE;
3602+
++BBI) {
3603+
BinaryBasicBlock *BB = *BBI;
36023604
const MCSymbol *TBB = nullptr;
36033605
const MCSymbol *FBB = nullptr;
36043606
MCInst *CondBranch = nullptr;
@@ -3612,7 +3614,7 @@ void BinaryFunction::fixBranches() {
36123614

36133615
// Basic block that follows the current one in the final layout.
36143616
const BinaryBasicBlock *const NextBB =
3615-
Layout.getBasicBlockAfter(BB, /*IgnoreSplits=*/false);
3617+
Layout.getBasicBlockAfter(BBI, /*IgnoreSplits*/ false);
36163618

36173619
if (BB->succ_size() == 1) {
36183620
// __builtin_unreachable() could create a conditional branch that

bolt/lib/Core/DIEBuilder.cpp

Lines changed: 7 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -584,7 +584,8 @@ DWARFDie DIEBuilder::resolveDIEReference(
584584
if ((RefCU =
585585
getUnitForOffset(*this, *DwarfContext, TmpRefOffset, AttrSpec))) {
586586
/// Trying to add to current working set in case it's cross CU reference.
587-
registerUnit(*RefCU, true);
587+
if (!registerUnit(*RefCU, true))
588+
return DWARFDie();
588589
DWARFDataExtractor DebugInfoData = RefCU->getDebugInfoExtractor();
589590
if (DwarfDebugInfoEntry.extractFast(*RefCU, &TmpRefOffset, DebugInfoData,
590591
RefCU->getNextUnitOffset(), 0)) {
@@ -1008,12 +1009,14 @@ static uint64_t getHash(const DWARFUnit &DU) {
10081009
return DU.getOffset();
10091010
}
10101011

1011-
void DIEBuilder::registerUnit(DWARFUnit &DU, bool NeedSort) {
1012+
bool DIEBuilder::registerUnit(DWARFUnit &DU, bool NeedSort) {
1013+
if (!BC.isValidDwarfUnit(DU))
1014+
return false;
10121015
auto IterGlobal = AllProcessed.insert(getHash(DU));
10131016
// If DU is already in a current working set or was already processed we can
10141017
// skip it.
10151018
if (!IterGlobal.second)
1016-
return;
1019+
return true;
10171020
if (getState().Type == ProcessingType::DWARF4TUs) {
10181021
getState().DWARF4TUVector.push_back(&DU);
10191022
} else if (getState().Type == ProcessingType::DWARF5TUs) {
@@ -1034,6 +1037,7 @@ void DIEBuilder::registerUnit(DWARFUnit &DU, bool NeedSort) {
10341037
if (getState().DUList.size() == getState().CloneUnitCtxMap.size())
10351038
getState().CloneUnitCtxMap.emplace_back();
10361039
getState().DUList.push_back(&DU);
1040+
return true;
10371041
}
10381042

10391043
std::optional<uint32_t> DIEBuilder::getUnitId(const DWARFUnit &DU) {

bolt/lib/Core/FunctionLayout.cpp

Lines changed: 13 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -224,23 +224,29 @@ void FunctionLayout::clear() {
224224
}
225225

226226
const BinaryBasicBlock *
227-
FunctionLayout::getBasicBlockAfter(const BinaryBasicBlock *BB,
227+
FunctionLayout::getBasicBlockAfter(block_const_iterator BBIter,
228228
bool IgnoreSplits) const {
229-
const block_const_iterator BBPos = find(blocks(), BB);
230-
if (BBPos == block_end())
231-
return nullptr;
232-
233-
const block_const_iterator BlockAfter = std::next(BBPos);
229+
const block_const_iterator BlockAfter = std::next(BBIter);
234230
if (BlockAfter == block_end())
235231
return nullptr;
236232

237233
if (!IgnoreSplits)
238-
if (BlockAfter == getFragment(BB->getFragmentNum()).end())
234+
if (BlockAfter == getFragment((*BBIter)->getFragmentNum()).end())
239235
return nullptr;
240236

241237
return *BlockAfter;
242238
}
243239

240+
const BinaryBasicBlock *
241+
FunctionLayout::getBasicBlockAfter(const BinaryBasicBlock *BB,
242+
bool IgnoreSplits) const {
243+
const block_const_iterator BBPos = find(blocks(), BB);
244+
if (BBPos == block_end())
245+
return nullptr;
246+
247+
return getBasicBlockAfter(BBPos, IgnoreSplits);
248+
}
249+
244250
bool FunctionLayout::isSplit() const {
245251
const unsigned NonEmptyFragCount = llvm::count_if(
246252
fragments(), [](const FunctionFragment &FF) { return !FF.empty(); });

0 commit comments

Comments
 (0)