-
-
Notifications
You must be signed in to change notification settings - Fork 5.5k
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
release-1.8: Backports for Julia 1.8.1 #46376
Conversation
(cherry picked from commit ef511c9)
Yes, the backport label was not added in that PR when I made this. Now that it is, it will get picked up. |
* Consistently use `RUNPATH` in our libraries When loading dependencies on Linux, we can either use `RPATH` or `RUNPATH` as a list of relative paths to search for libraries. The difference, for our purposes, mainly lies within how this interacts with `LD_LIBRARY_PATH`: `RPATH` is searched first, then `LD_LIBRARY_PATH`, then `RUNPATH`. So by using `RUNPATH` here, we are explicitly allowing ourselves to be overridden by `LD_LIBRARY_PATH`. This is fine, as long as we are consistent across our entire library line, however in the `v1.8.0` release, there was an inconsistency, reported in [0]. The inconsistency occured because of the following confluence of factors: - Ancient `ld` builds (such as the one used in our build environment) do not default to using `RUNPATH`, but instead use `RPATH`. - `patchelf`, when it rewrites the RPATH, will default to using `RUNPATH` instead. - We were only using `patchelf` on `libjulia-internal`, not on `libjulia-codegen`, which was newly added in `v1.8`. These three factors together caused us to ship a binary with `RUNPATH` in `libjulia-internal`, but `RPATH` in `libjulia-codegen`, which caused loading to fail in [0] due to first `libjulia-internal` being loaded, (which brought in the external `libstdc++`), then `libjulia-codegen` failed to load (because it found an incompatible `libstdc++`), causing the mysterious compiler error. This PR fixes this twofold; first, when building the libraries in the first place, we pass `--enable-new-dtags` to the linker to encourage it to use `runpath` when possible. This removes the possibility for a missing `patchelf` invocation to break things in this way. Second, we apply `patchelf` properly to `libjulia-codegen` as well. [0] #46409 * fix whitespace Co-authored-by: Kristoffer Carlsson <kcarlsson89@gmail.com>
I think #46010 can be removed from your TODO list, see #46010 (comment) |
Can #46436 get added? |
Is it not? |
f50efb0
to
a239589
Compare
oops, not sure how I missed it. |
Co-authored-by: Kristoffer Carlsson <kcarlsson89@gmail.com> (cherry picked from commit 3b81696)
@nanosoldier |
Looks like the Nanosoldier syntax has changed: https://github.com/JuliaCI/Nanosoldier.jl#trigger-syntax-1 |
and: Thanks. |
@nanosoldier |
Your package evaluation job has completed - possible new issues were detected. A full report can be found here. |
@nanosoldier |
`CachedMethodTable` was removed within #44240 as we couldn't confirm any performance improvement then. However it turns out the optimization was critical in some real world cases (e.g. #46492), so this commit revives the mechanism with the following tweaks that should make it more effective: - create method table cache per inference (rather than per local inference on a function call as on the previous implementation) - only use cache mechanism for abstract types (since we already cache lookup result at the next level as for concrete types) As a result, the following snippet reported at #46492 recovers the compilation performance: ```julia using ControlSystems a_2 = [-5 -3; 2 -9] C_212 = ss(a_2, [1; 2], [1 0; 0 1], [0; 0]) @time norm(C_212) ``` > on master ``` julia> @time norm(C_212) 364.489044 seconds (724.44 M allocations: 92.524 GiB, 6.01% gc time, 100.00% compilation time) 0.5345224838248489 ``` > on this commit ``` julia> @time norm(C_212) 26.539016 seconds (62.09 M allocations: 5.537 GiB, 5.55% gc time, 100.00% compilation time) 0.5345224838248489 ``` (cherry picked from commit 8445744)
Your package evaluation job has completed - possible new issues were detected. A full report can be found here. |
(cherry picked from commit ce6e9ee)
(cherry picked from commit b64743b)
(cherry picked from commit 5c5af1f)
(cherry picked from commit 431071b)
(cherry picked from commit 1fae1b9)
(cherry picked from commit 99340fe)
(cherry picked from commit 1715110)
* Make `Fix1(f, Int)` inference-stable * split `_xfadjoint` into `_xfadjoint_unwrap` and `_xfadjoint_wrap` * Improve `(c::ComposedFunction)(x...)`'s inferability * and fuse it in `Base._xfadjoint`. * define a `Typeof` operator that will partly work around internal type-system bugs Closes #45715 (cherry picked from commit d58289c)
(cherry picked from commit c2a1650)
@nanosoldier |
Your job failed. |
@nanosoldier |
@vtjnash, any idea what's up with the job failure? |
* fix invalidations in REPL LineEdit.jl from Static.jl (cherry picked from commit 99d8c7b)
Your job failed. |
Backported PRs:
foldl
's stability on nested Iterators. #45789 <!-- Improvefoldl
's stability on nested Iterators. -@kwdef
: handle const and atomic fields #46276leq
for reals falls back tole
andeq
#46341PhiNode
withedge==0
#46388@noinline
exp
by default. #46359@time
compat description #46416deepcopy
forBase.GenericCondition
#46406AbstractQ
s #46237dot
for 1x1 structured matrices #46473nextind
#46489#define _GNU_SOURCE
comes first #46183CachedMethodTable
mechanism #46535StringIndexError
display (correct escaping) #46039isinf
from Static.jl #46493Need manual backport:
PRs with backport label: