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

remove more global state from codegen #36260

Merged
merged 2 commits into from
Jun 17, 2020
Merged

remove more global state from codegen #36260

merged 2 commits into from
Jun 17, 2020

Conversation

vtjnash
Copy link
Member

@vtjnash vtjnash commented Jun 12, 2020

Annoyed by https://build.julialang.org/#/builders/48/builds/527, I decided to spend some time removing more global state from codegen and wrapping it into our jl_codegen_params_t context.

While we still have some work to do to remove the global use of many Type objects, and to remove the global counter (we'll need to figure out a different mechanism when merging modules to identify unique values), this is another step in that direction.

@JeffBezanson JeffBezanson added the compiler:codegen Generation of LLVM IR and native code label Jun 12, 2020
@vtjnash vtjnash force-pushed the jn/codegen-unglobal branch from 52a9119 to b5cff71 Compare June 13, 2020 02:53
@timotaularson
Copy link

Not sure if exactly the same bug as https://build.julialang.org/#/builders/48/builds/527 but I was getting an inconsistent error like that during builds and "solved" it (temporarily worked around it) by adding a '\0' to the end of the numbered function names. It looks like somewhere explicit-length strings are not getting converted correctly to null terminated string where required for native function names.

@vtjnash vtjnash force-pushed the jn/codegen-unglobal branch from b5cff71 to cb993f3 Compare June 15, 2020 04:04
@vtjnash
Copy link
Member Author

vtjnash commented Jun 15, 2020

Yes, it is that bug, and is caused by the unpredictability of the ordering of running finalizers. It is being fixed here.

@vtjnash
Copy link
Member Author

vtjnash commented Jun 15, 2020

I'll plan to merge this tomorrow. Though review would be good (@JeffBezanson @Keno or @maleadt perhaps).

src/codegen.cpp Outdated Show resolved Hide resolved
@vchuravy vchuravy requested a review from maleadt June 16, 2020 02:32
@maleadt maleadt removed their request for review June 16, 2020 17:49
Copy link
Member

@Keno Keno left a comment

Choose a reason for hiding this comment

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

As discussed this morning, needs to be adjusted to avoid breaking the GPU stack (at least for the moment).

vtjnash added 2 commits June 17, 2020 13:02
…unctions

We already had prepare_global/prepare_call functions. This simply lets
us use that to allocate these on-demand instead of keeping around a
global copy of them to template from.
@vtjnash vtjnash force-pushed the jn/codegen-unglobal branch from cb993f3 to 26de664 Compare June 17, 2020 17:03
@vtjnash vtjnash requested a review from Keno June 17, 2020 17:04
@vtjnash vtjnash merged commit 731126d into master Jun 17, 2020
@vtjnash vtjnash deleted the jn/codegen-unglobal branch June 17, 2020 21:24
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
compiler:codegen Generation of LLVM IR and native code
Projects
None yet
Development

Successfully merging this pull request may close these issues.

6 participants