-
Notifications
You must be signed in to change notification settings - Fork 484
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
VITIS-11401 : Shim DMA based array reconfiguration overhead (#8308)
* VITIS-11401 : Shim DMA based array reconfiguration overhead Signed-off-by: Akshay Tondak <[email protected]> * VITIS-11401 : Shim DMA based array reconfiguration overhead v2 Signed-off-by: Akshay Tondak <[email protected]> * VITIS-11401 : Shim DMA based array reconfiguration overhead v3 : Name changes Signed-off-by: Akshay Tondak <[email protected]> * VITIS-11401: Fix for review comments Signed-off-by: Akshay Tondak <[email protected]> * Algorithm update Signed-off-by: Akshay Tondak <[email protected]> * Unit change to ms for better visualization Signed-off-by: Akshay Tondak <[email protected]> --------- Signed-off-by: Akshay Tondak <[email protected]> Co-authored-by: Akshay Tondak <[email protected]>
- Loading branch information
Showing
11 changed files
with
249 additions
and
179 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
182 changes: 182 additions & 0 deletions
182
src/runtime_src/core/tools/common/tests/TestAIEReconfigOverhead.cpp
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,182 @@ | ||
// ------ I N C L U D E F I L E S ------------------------------------------- | ||
// Local - Include Files | ||
|
||
#include "TestAIEReconfigOverhead.h" | ||
#include "tools/common/XBUtilities.h" | ||
#include "xrt/xrt_bo.h" | ||
#include "xrt/xrt_device.h" | ||
#include "xrt/xrt_hw_context.h" | ||
#include "xrt/xrt_kernel.h" | ||
|
||
// System - Include Files | ||
#include <fstream> | ||
#include <filesystem> | ||
#include <thread> | ||
#include <iostream> | ||
static constexpr size_t buffer_size_mb = 128; | ||
static constexpr size_t buffer_size = buffer_size_mb * 1024 * 1024; //128 MB | ||
static constexpr size_t word_count = buffer_size/16; | ||
static constexpr int itr_count = 1000; | ||
static constexpr size_t inter_size = 1024 * 1024; | ||
static constexpr unsigned int StartAddr = 32 * 1024 * 1024; | ||
|
||
TestAIEReconfigOverhead::TestAIEReconfigOverhead() | ||
: TestRunner("aie-reconfig-overhead", "Run end-to-end array reconfiguration overhead through shim DMA") | ||
{} | ||
|
||
boost::property_tree::ptree | ||
TestAIEReconfigOverhead::run(std::shared_ptr<xrt_core::device> dev) | ||
{ | ||
boost::property_tree::ptree ptree = get_test_header(); | ||
ptree.erase("xclbin"); | ||
|
||
const auto xclbin_name = xrt_core::device_query<xrt_core::query::xclbin_name>(dev, xrt_core::query::xclbin_name::type::validate); | ||
auto xclbin_path = findPlatformFile(xclbin_name, ptree); | ||
if (!std::filesystem::exists(xclbin_path)) | ||
return ptree; | ||
|
||
logger(ptree, "Xclbin", xclbin_path); | ||
|
||
xrt::xclbin xclbin; | ||
try { | ||
xclbin = xrt::xclbin(xclbin_path); | ||
} | ||
catch (const std::runtime_error& ex) { | ||
logger(ptree, "Error", ex.what()); | ||
ptree.put("status", test_token_failed); | ||
return ptree; | ||
} | ||
|
||
// Determine The DPU Kernel Name | ||
auto xkernels = xclbin.get_kernels(); | ||
|
||
auto itr = std::find_if(xkernels.begin(), xkernels.end(), [](xrt::xclbin::kernel& k) { | ||
auto name = k.get_name(); | ||
return name.rfind("DPU",0) == 0; // Starts with "DPU" | ||
}); | ||
|
||
xrt::xclbin::kernel xkernel; | ||
if (itr!=xkernels.end()) | ||
xkernel = *itr; | ||
else { | ||
logger(ptree, "Error", "No kernel with `DPU` found in the xclbin"); | ||
ptree.put("status", test_token_failed); | ||
return ptree; | ||
} | ||
auto kernelName = xkernel.get_name(); | ||
if(XBUtilities::getVerbose()) | ||
logger(ptree, "Details", boost::str(boost::format("Kernel name is '%s'") % kernelName)); | ||
|
||
auto working_dev = xrt::device(dev); | ||
working_dev.register_xclbin(xclbin); | ||
xrt::hw_context hwctx; | ||
xrt::kernel kernel; | ||
try { | ||
hwctx = xrt::hw_context(working_dev, xclbin.get_uuid()); | ||
kernel = xrt::kernel(hwctx, kernelName); | ||
} | ||
catch (const std::exception& ex) | ||
{ | ||
logger(ptree, "Error", ex.what()); | ||
ptree.put("status", test_token_failed); | ||
return ptree; | ||
} | ||
|
||
const auto seq_name = xrt_core::device_query<xrt_core::query::sequence_name>(dev, xrt_core::query::sequence_name::type::aie_reconfig_overhead); | ||
auto dpu_instr = findPlatformFile(seq_name, ptree); | ||
if (!std::filesystem::exists(dpu_instr)) | ||
return ptree; | ||
|
||
logger(ptree, "DPU-Sequence", dpu_instr); | ||
|
||
size_t instr_size = 0; | ||
try { | ||
instr_size = get_instr_size(dpu_instr); | ||
} | ||
catch(const std::exception& ex) { | ||
logger(ptree, "Error", ex.what()); | ||
ptree.put("status", test_token_failed); | ||
return ptree; | ||
} | ||
|
||
//Create BOs | ||
int argno = 1; | ||
xrt::bo bo_ifm(working_dev, buffer_size, XRT_BO_FLAGS_HOST_ONLY, kernel.group_id(argno++)); | ||
argno++; | ||
xrt::bo bo_ofm(working_dev, buffer_size, XRT_BO_FLAGS_HOST_ONLY, kernel.group_id(argno++)); | ||
xrt::bo bo_inter(working_dev, inter_size, XRT_BO_FLAGS_HOST_ONLY, kernel.group_id(argno++)); | ||
xrt::bo bo_instr(working_dev, instr_size*sizeof(int), XCL_BO_FLAGS_CACHEABLE, kernel.group_id(argno)); | ||
xrt::bo bo_instr_no_op(working_dev, instr_size*sizeof(int), XCL_BO_FLAGS_CACHEABLE, kernel.group_id(argno++)); | ||
argno++; | ||
xrt::bo bo_mc(working_dev, 16, XRT_BO_FLAGS_HOST_ONLY, kernel.group_id(argno++)); | ||
|
||
init_instr_buf(bo_instr, dpu_instr); | ||
//Create ctrlcode with NOPs | ||
std::memset(bo_instr_no_op.map<char*>(), 0, instr_size); | ||
|
||
// map input buffer | ||
// Incremental byte pattern | ||
auto ifm_mapped = bo_ifm.map<int*>(); | ||
for (size_t i = 0; i < word_count; i++) | ||
ifm_mapped[i] = (int)(i % word_count); | ||
|
||
//Sync BOs | ||
bo_instr.sync(XCL_BO_SYNC_BO_TO_DEVICE); | ||
bo_mc.sync(XCL_BO_SYNC_BO_TO_DEVICE); | ||
bo_ifm.sync(XCL_BO_SYNC_BO_TO_DEVICE); | ||
|
||
//Log | ||
if(XBUtilities::getVerbose()) { | ||
logger(ptree, "Details", boost::str(boost::format("Buffer size: '%f'MB") % buffer_size_mb)); | ||
logger(ptree, "Details", boost::str(boost::format("No. of iterations: '%f'") % itr_count)); | ||
} | ||
|
||
auto start = std::chrono::high_resolution_clock::now(); | ||
for (int i = 0 ;i < itr_count ; i++){ | ||
try{ | ||
auto run = kernel(1, bo_ifm, NULL, bo_ofm, bo_inter, bo_instr_no_op, instr_size, bo_mc); | ||
run.wait2(); | ||
} | ||
catch (const std::exception& ex) | ||
{ | ||
logger(ptree, "Error", ex.what()); | ||
ptree.put("status", test_token_failed); | ||
return ptree; | ||
} | ||
bo_ofm.sync(XCL_BO_SYNC_BO_FROM_DEVICE); | ||
} | ||
auto end = std::chrono::high_resolution_clock::now(); | ||
float elapsedSecsNoOpAverage = std::chrono::duration_cast<std::chrono::duration<float>>(end-start).count(); | ||
elapsedSecsNoOpAverage /= itr_count; | ||
|
||
start = std::chrono::high_resolution_clock::now(); | ||
for (int i = 0; i< itr_count; i++) | ||
{ | ||
try{ | ||
auto run = kernel(1, bo_ifm, NULL, bo_ofm, bo_inter, bo_instr, instr_size, bo_mc); | ||
run.wait2(); | ||
} | ||
catch (const std::exception& ex) | ||
{ | ||
logger(ptree, "Error", ex.what()); | ||
ptree.put("status", test_token_failed); | ||
return ptree; | ||
} | ||
bo_ofm.sync(XCL_BO_SYNC_BO_FROM_DEVICE); | ||
auto *ofm_mapped = bo_ofm.map<int8_t*>(); | ||
if(std::memcmp(ifm_mapped, ofm_mapped + StartAddr, word_count)){ | ||
logger(ptree, "Error", "Value read back does not match reference for array reconfiguration instruction buffer"); | ||
ptree.put("status", test_token_failed); | ||
return ptree; | ||
} | ||
} | ||
|
||
end = std::chrono::high_resolution_clock::now(); | ||
float elapsedSecsAverage = std::chrono::duration_cast<std::chrono::duration<float>>(end-start).count(); | ||
elapsedSecsAverage /= itr_count; | ||
float overhead = elapsedSecsAverage - elapsedSecsNoOpAverage; | ||
logger(ptree, "Details", boost::str(boost::format("Array reconfiguration overhead: '%.1f'ms") % (overhead * 1000))); | ||
|
||
ptree.put("status", test_token_passed); | ||
return ptree; | ||
} |
16 changes: 16 additions & 0 deletions
16
src/runtime_src/core/tools/common/tests/TestAIEReconfigOverhead.h
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,16 @@ | ||
// SPDX-License-Identifier: Apache-2.0 | ||
// Copyright (C) 2024 Advanced Micro Devices, Inc. All rights reserved. | ||
|
||
#ifndef __TestArrayReconfOverhead_h_ | ||
#define __TestArrayReconfOverhead_h_ | ||
|
||
#include "tools/common/TestRunner.h" | ||
#include "xrt/xrt_device.h" | ||
|
||
class TestAIEReconfigOverhead : public TestRunner { | ||
public : | ||
boost::property_tree::ptree run(std::shared_ptr<xrt_core::device> dev); | ||
|
||
TestAIEReconfigOverhead(); | ||
}; | ||
#endif |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.