-
Notifications
You must be signed in to change notification settings - Fork 64
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
Inconsistent AlignToPtr use #309
Comments
Correct note. But i don't have the hardware with required align, so my fix will be blind, w/o tests... so I don't want to fix it. |
Just remove the IFDEF (for testing). Your intel/amd will not complain about the extra alignment. |
I will try it after #303 is merged... |
@User4martin Will you help me with this issue, please? to do it you need to enable the $define here:
after fix done, that block needs to be removed. |
Disclaimer: Someone with background on different CPU/arch should maybe double check some of my statements.... Well, right now, with that define enabled, it will fail on all platforms. My understanding is that there are some CPU that can not access a Currently I would expect TRegExpr to fail on such CPU.
is likely to fail, because ABuffer may not be aligned. It could also be that on some CPU such code runs slower, due to the non align (though then, its a gamble versus needing more cache lines). Those CPU are probably mostly embedded/RISC. (Afaik they may cause an exception, if the address is not aligned / so I really am not sure) Afaik, fpc has a copy of this, does it have testcases? I would imagine the fpc team running there tests on various cpu. As for the question if it may have a speed impact => maybe a CPU expert from the fpc team knows. (just testing is likely not revealing much, as things like cache hits may cause timings to vary to much.) So first thing is to find out:
If it isn't urgent, more than half of the code that needs to be fixed could probably be replaced by code that doesn't need alignment on any architecture. (E.g. with a few exceptions the "next pointer" can be In either case, fixing the alignment code seems to be closer to rewriting it. So I wont be able to squeeze that in right now. |
@User4martin Any ideas for future PRs? besides the AlignToPtr. If no, let's suggest our new version to FPC bugtracker? |
I think this issue can be deferred. I may have other stuff later this year... Not sure yet. |
Let's suggest our new version to FPC bugtracker? who should do it: you / me? |
if you would. |
Getting the next opcode is sometimes done with
PRENextOff(AlignToPtr(scan + REOpSz))^
and sometimesInc(s, REOpSz + RENextOffSz)
It doesn't fail on many arch:
But compile on an arch that requires align, and it should fail
The text was updated successfully, but these errors were encountered: