From 4cbd17b4281317c6b8a2a9a69f51004e7edc35e2 Mon Sep 17 00:00:00 2001 From: Maksim Levental Date: Mon, 26 Aug 2024 20:13:01 -0500 Subject: [PATCH] fix ldscript emission --- .../Target/AMDAIETargetLdScript.cpp | 57 +++++++++---------- .../AMD-AIE/iree-amd-aie/Target/XCLBinGen.cpp | 1 + 2 files changed, 27 insertions(+), 31 deletions(-) diff --git a/compiler/plugins/target/AMD-AIE/iree-amd-aie/Target/AMDAIETargetLdScript.cpp b/compiler/plugins/target/AMD-AIE/iree-amd-aie/Target/AMDAIETargetLdScript.cpp index 5cbebf39e..dccbd101f 100644 --- a/compiler/plugins/target/AMD-AIE/iree-amd-aie/Target/AMDAIETargetLdScript.cpp +++ b/compiler/plugins/target/AMD-AIE/iree-amd-aie/Target/AMDAIETargetLdScript.cpp @@ -23,43 +23,15 @@ static void writeLDScriptMap(raw_ostream &output, BufferOp buf, int offset) { output << ". += 0x" << llvm::utohexstr(numBytes) << ";\n"; } -///// ld.script format: -// -// MEMORY -// { -// program (RX) : ORIGIN = 0, LENGTH = 0x0020000 -// data (!RX) : ORIGIN = 0x20000, LENGTH = 0x0020000 -// } -// ENTRY(_main_init) -// INPUT(something.o) -// SECTIONS -// { -// . = 0x0; -// .text : { -// // the __start symbol from crt0.o has to come at address zero. -// *crt0.o(.text) -// . = 0x200; -// *(.text) -// } > program -// .data : { *(.data) } > data -// . = 0x20000; -// _sp_start_value_DM_stack = .; -// . = 0x24000; -// a = .; -// . += 1024; -// .bss : { *(.bss) } > data -// } LogicalResult mlir::iree_compiler::AMDAIE::AIETranslateToLdScript( DeviceOp deviceOp, raw_ostream &output, int tileCol, int tileRow) { DenseMap tiles; DenseMap> buffers; - collectTiles(deviceOp, tiles); ::collectBuffers(deviceOp, buffers); - AMDAIEDeviceModel deviceModel = - getDeviceModel(static_cast(deviceOp.getDevice())); + AMDAIEDeviceModel deviceModel = getDeviceModel(deviceOp.getDevice()); for (auto tile : deviceOp.getOps()) if (tile.getCol() == tileCol && tile.getRow() == tileRow) { TileLoc srcCoord = {tile.getCol(), tile.getRow()}; @@ -95,9 +67,33 @@ SECTIONS *(.data*); *(.rodata*) } > data + .comment : { + *(.comment*) + } + .symtab : { + *(.symtab) + } + .shstrtab : { + *(.shstrtab) + } + .strtab : { + *(.strtab) + } + .tctmemtab : { + *(.tctmemtab) + } + .rtstab : { + *(.rtstab) + } + .eoltab : { + *(.eoltab) + } + .chesstypeannotationtab : { + *(.chesstypeannotationtab) + } )THESCRIPT"; auto doBuffer = [&](std::optional tile, int offset, - const std::string& dir) { + const std::string &dir) { if (tile) { if (tiles.count({tile->col, tile->row})) for (auto buf : buffers[tiles[{tile->col, tile->row}]]) @@ -132,7 +128,6 @@ SECTIONS deviceModel.getMemEastBaseAddress(), std::string("east")); output << " .bss : { *(.bss) } > data\n"; - output << " .bss.DMb.4 : { *(.bss.DMb.4) } > data\n"; output << "}\n"; if (auto coreOp = getCoreOp(tile)) { output << "PROVIDE(main = core_" << std::to_string(tile.getCol()) << "_" diff --git a/compiler/plugins/target/AMD-AIE/iree-amd-aie/Target/XCLBinGen.cpp b/compiler/plugins/target/AMD-AIE/iree-amd-aie/Target/XCLBinGen.cpp index 3bdebef02..21afa7b97 100644 --- a/compiler/plugins/target/AMD-AIE/iree-amd-aie/Target/XCLBinGen.cpp +++ b/compiler/plugins/target/AMD-AIE/iree-amd-aie/Target/XCLBinGen.cpp @@ -614,6 +614,7 @@ static LogicalResult generateCoreElfFiles( } flags.emplace_back("--target=" + targetLower + "-none-unknown-elf"); flags.emplace_back("-Wl,--gc-sections"); + flags.emplace_back("-Wl,--orphan-handling=error"); flags.emplace_back("-Wl,-T," + ldscriptPath.string()); flags.emplace_back("-o"); flags.emplace_back(elfFile.string());