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

XRT smi code cleanup to remove device specific help printing logic #8825

Merged
merged 6 commits into from
Mar 25, 2025

Conversation

aktondak
Copy link
Collaborator

@aktondak aktondak commented Mar 19, 2025

Problem solved by the commit

This PR cleans up the xrt-smi code which depended on the configuration embedded in xbutil.cpp.
With all the xrt-smi re-architecture we did previously, there is no longer a need for xrt-smi subcommands to book keep device/platform specific behavior within XRT. Instead its the responsibility of each shim to provide correct configuration. This clean-up aims at simplifying the xrt-smi help printing and option adding logic. There are following broad changes in this PR :

  1. Some improved naming conventions for smi specific files and data structures in each shim (smi.cpp --> smi_pcie.cpp etc). Also moved the base smi class members to private as pointed out in a previous review.
  2. Removal of m_commandConfig setting in two subcommands : validate and configure. Configure is common between xbmgmt thus cleaning it up will require pcie/edge shim changes. I'll plan that in subsequent patches.
  3. Simplifies the help printing by removing all print_help_internal calls/definitions which were device dependent and simply using the base printHelp() for all help printing. Note for future, there should be no device specific help printing logic added to XRT code.

Bug / issue (if any) fixed, which PR introduced the bug, how it was discovered

https://jira.xilinx.com/browse/VITIS-14551
Discovered through internal testing

How problem was solved, alternative solutions (if any) and why they were rejected

Solved through xrt-smi re-architecture done in last release. This is mostly subsequent code cleanup.

Risks (if any) associated the changes in the commit

This change has a potential of breaking some of the help printing possibly in non xrt-smi code. Will be testing it further

What has been tested and how, request additional testing if necessary

Tested for all 3 commands on windows.

Documentation impact (if any)

None

Akshay Tondak added 2 commits March 19, 2025 10:24
Signed-off-by: Akshay Tondak <[email protected]>
@gbuildx
Copy link
Collaborator

gbuildx commented Mar 19, 2025

Can one of the admins verify this patch?

@aktondak aktondak requested a review from rchane March 19, 2025 21:17
Copy link

@github-actions github-actions bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

clang-tidy made some suggestions

@aktondak aktondak changed the title Vitis 14551 configure XRT smi code cleanup to remove device specific help printing logic Mar 19, 2025
Copy link
Collaborator

@AShivangi AShivangi left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for the cleanup!!
Please double check if the copyrights are up to date

Copy link

clang-tidy review says "All clean, LGTM! 👍"

Signed-off-by: Akshay Tondak <[email protected]>
Copy link

clang-tidy review says "All clean, LGTM! 👍"

Akshay Tondak and others added 2 commits March 24, 2025 11:51
Copy link

clang-tidy review says "All clean, LGTM! 👍"

1 similar comment
Copy link

clang-tidy review says "All clean, LGTM! 👍"

@stsoe stsoe merged commit c701c2c into Xilinx:master Mar 25, 2025
21 of 24 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants