Provide script to TSSA build in tracing JIT#18353
Open
+8 −0
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
For the following script:
When comparing the TSSA (via opcache.jit_debug) vs the opcache SSA (via opcache.opt_debug_level=0x400000) we note that in TSSA, the RECV op for
test
does not infer the type of the argument to be classFoo
. This is because the optimizer uses thescript
pointer to figure out known classes but TSSA always setsscript
to NULL. This in turn generates suboptimal assembly becausezend_may_throw
returns 1 due to the unknown CE in the TSSA, resulting in an extra exception check in the assembly code.