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

[CIR] [Lowering] [X86_64] Support VAArg in shape #1100

Merged
merged 1 commit into from
Nov 13, 2024

Conversation

ChuanqiXu9
Copy link
Member

This patch implements transformations for VAArg in X86_64 ABI in shape. In shape means it can't work properly due to the dependent X86_64 ABI is not robust. e.g., when we want to use VAArg with long double, we need #1087.

This patch literally implement https://github.com/llvm/llvm-project/blob/d233fedfb0de882353c348cd1ac57dab619efa6d/clang/lib/CodeGen/Targets/X86.cpp#L3015-L3240 in CIR.

There some differences due to the traditional pipeline are converting AST to LLVM and we're transforming CIR to CIR. And also to get the ABI Info, I moved X86_64ABIInfo to the header.

Copy link
Member

@bcardosolopes bcardosolopes left a comment

Choose a reason for hiding this comment

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

LGTM after fixing nits

@ChuanqiXu9 ChuanqiXu9 force-pushed the users/ChuanqiXu9/VAArgInX86 branch from ae0cf06 to ef39145 Compare November 12, 2024 03:43
@bcardosolopes bcardosolopes merged commit ef90a8b into main Nov 13, 2024
6 checks passed
bcardosolopes pushed a commit that referenced this pull request Nov 13, 2024
This is the following of #1100.

After #1100, when we want to use
LongDouble for VAArg, we will be in trouble due to details in X86_64's
ABI and this patch tries to address this.

The practical impact the patch is, after this patch, with
#1088 and a small following up fix,
we can build and run all C's benchmark in SpecCPU 2017. I think it is a
milestone.
bcardosolopes pushed a commit that referenced this pull request Nov 25, 2024
Recommit #1101

I am not sure what happened. But that merged PR doesn't show in the git
log. Maybe the stacked PR may not get successed? But after all, we need
to land it again.

Following off are original commit messages:

---

This is the following of #1100.

After #1100, when we want to use
LongDouble for VAArg, we will be in trouble due to details in X86_64's
ABI and this patch tries to address this.

The practical impact the patch is, after this patch, with
#1088 and a small following up fix,
we can build and run all C's benchmark in SpecCPU 2017. I think it is a
milestone.
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.

2 participants