-
Notifications
You must be signed in to change notification settings - Fork 17.8k
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
cmd/link: external linking for ppc64le doesn't work #11184
Comments
FWIW, I have a branch that implements this. It's a bit tangled up with other things but I'll get it submitted in early 1.6 I hope. One detail that isn't noted is that you can't always translate R_ADDRPOWER to a R_PPC_ADDR16_HA / R_PPC_ADDR16_LO pair, sometimes it has to be R_PPC64_ADDR16_LO_DS because it is applied to loads as well as addi, and a few loads (lwa, for example) are DS form. |
It would be nice if we could get the changes in that I outlined above. Almost all the changes already exist in various CLs from Minux but were never merged, or in the case of some, are now in files that have moved to other directories. With these changes, external linking for ppc64le at least works in most cases (although I agree there are probably some bugs as noted in the previous comment). Without these changes it doesn't work at all. |
Update #11184 (linux/ppc64). Filed #12178 (solaris) for Go 1.6. Change-Id: I9e3a456aaccb49590ad4e14b53ddfefca5b0801c Reviewed-on: https://go-review.googlesource.com/13679 Reviewed-by: Russ Cox <[email protected]>
@mwhudson In you last post you said you hoped to get this in early Go 1.6. Do you know when that might be? There are users who would like to try this out at least on ppc64le. Thanks. |
I go back to my external lining CLs very soon.
But I will need help for the ppc64le side of things
because I don't have access to that.
I will first update the ppc64 CLs.
|
This issue shows what changes are needed from your original CLs to make it work on ppc64le at least for what I tried. Michael also pointed out a few additional problems with some relocations which I haven't tried to use. I am willing to help build and test on ppc64le, just let me know when you have patches ready. Thanks. |
I can post my changes today, I hope. |
I've just pushed up a series of changes
They pass ./all.bash on ppc64le. |
I was able to build this, and tried a few simple cases of external linking on ppc64le, static and dynamic and they worked as I expected. |
What is the outlook on this? If ppc64 for big endian is still an issue, can we at least get this support merged for ppc64le? |
The branches are just waiting for reviewer time, I think. The simple ones have been approved. |
Thanks for the response. Please note that the dynamic linker for ppc64le (ABI v2) is ld64.so.2, not ld64.so.1 as is for ppc64. |
I might have made a mistake in my previous testing, I am no longer able to pull your CLs and build a toolchain that works for ppc64le. There are multiple dependent CLs and I'm not sure how to get all the right code. Any suggestions on how to do that would be helpful, or maybe they need to be rebased. These CLs haven't been looked at for over two weeks. |
On 3 October 2015 at 01:36, laboger [email protected] wrote:
|
I have built and tested with these CLs on ppc64le and they seem to work as expected. Thanks! I will try ppc64 as well. |
Good to hear! I have no way of testing ppc64 and wasn't thinking at all On 13 October 2015 at 01:40, laboger [email protected] wrote:
|
Rebuilt with your latest rebase and all continued to work for ppc64le. |
I've just submitted the changes that should fix this (somehow I failed to notice Russ had reviewed them) |
This is working as expected now for ppc64le. |
Currently external linking is not enabled for ppc64le in golang master probably because it doesn't work as is, but there are some existing CLs that mostly provide the support needed to make external linking work with some minor modifications. I'm using Ubuntu 14.04 and 14.10.
Following are the list of errors that occur. I've noted the files from existing CLs that were used to resolve the errors.
Here are the files from the CLs with notes on what needs changing.
Change the compare string from "ppc64le" to "ppc" to enable external linking for ppc64le. Without this external linking on ppc64le is not enabled. File is now in a different directory cmd/link/internal/ppc64.
Base support for Power specific relocations. This file has been moved to a different directory so the patches need to be applied to the new file in cmd/link/internal/ppc64
Needed
New file asm.go is in cmd/link/internal/ppc64/
Additional support needed for Tlsg symbol. When the TPREL relocation is used then 0x7000 must be added to the offset since the TPREL relocation subtracts off that amount and the tls_ppc64x.s code also subtracts off 0x7000.
I don't understand the status of these CLs, especially those that cannot be merged anymore because the files are in different directories. Can someone clarify? It was be good if we could get these changes in so external linking for ppc64le can be enabled and made to work.
The text was updated successfully, but these errors were encountered: