Julia
http://julialang.org/
Julia is a high-level, high-performance dynamic programming language for technical computing, with syntax that is familiar to users of other technical computing environments. It provides a sophisticated compiler, distributed parallel execution, numerical accuracy, and an extensive mathematical function library. The library, largely written in Julia itself, also integrates mature, best-of-breed C and Fortran libraries for linear algebra, random number generation, signal processing, and string processing.
- Devel package for openSUSE:Factory
-
5
derived packages
- Links to openSUSE:Factory / julia
- Download package
-
Checkout Package
osc -A https://api.opensuse.org checkout science/julia && cd $_
- Create Badge
Refresh
Refresh
Source Files (show merged sources derived from linked package)
Filename | Size | Changed |
---|---|---|
CompilerSupportLibraries.v1.1.1+0.aarch64-linux-gn |
0020763581 19.8 MB | |
CompilerSupportLibraries.v1.1.1+0.powerpc64le-linu |
0021275184 20.3 MB | |
CompilerSupportLibraries.v1.1.1+0.x86_64-linux-gnu |
0022932730 21.9 MB | |
GMP.v6.2.1+6.aarch64-linux-gnu-cxx11.tar.gz | 0000445144 435 KB | |
GMP.v6.2.1+6.powerpc64le-linux-gnu-cxx11.tar.gz | 0000476586 465 KB | |
GMP.v6.2.1+6.x86_64-linux-gnu-cxx11.tar.gz | 0000528807 516 KB | |
LLD.v15.0.7+10.aarch64-linux-gnu-cxx11-llvm_versio |
0004914229 4.69 MB | |
LLD.v15.0.7+10.powerpc64le-linux-gnu-cxx11-llvm_ve |
0005326792 5.08 MB | |
LLD.v15.0.7+10.x86_64-linux-gnu-cxx11-llvm_version |
0005231424 4.99 MB | |
LibCURL.v8.4.0+0.aarch64-linux-gnu.tar.gz | 0000707448 691 KB | |
LibCURL.v8.4.0+0.powerpc64le-linux-gnu.tar.gz | 0000747133 730 KB | |
LibCURL.v8.4.0+0.x86_64-linux-gnu.tar.gz | 0000749418 732 KB | |
LibGit2.v1.6.4+0.aarch64-linux-gnu.tar.gz | 0000856789 837 KB | |
LibGit2.v1.6.4+0.powerpc64le-linux-gnu.tar.gz | 0000955285 933 KB | |
LibGit2.v1.6.4+0.x86_64-linux-gnu.tar.gz | 0000952168 930 KB | |
LibSSH2.v1.11.0+1.aarch64-linux-gnu.tar.gz | 0000410826 401 KB | |
LibSSH2.v1.11.0+1.powerpc64le-linux-gnu.tar.gz | 0000441415 431 KB | |
LibSSH2.v1.11.0+1.x86_64-linux-gnu.tar.gz | 0000431463 421 KB | |
LibUV.v2.0.1+14.aarch64-linux-gnu.tar.gz | 0000693211 677 KB | |
LibUV.v2.0.1+14.powerpc64le-linux-gnu.tar.gz | 0000649465 634 KB | |
LibUV.v2.0.1+14.x86_64-linux-gnu.tar.gz | 0000622742 608 KB | |
LibUnwind.v1.5.0+5.aarch64-linux-gnu.tar.gz | 0001283293 1.22 MB | |
LibUnwind.v1.5.0+5.powerpc64le-linux-gnu.tar.gz | 0001086558 1.04 MB | |
LibUnwind.v1.5.0+5.x86_64-linux-gnu.tar.gz | 0001208108 1.15 MB | |
MPFR.v4.2.0+1.aarch64-linux-gnu.tar.gz | 0000884650 864 KB | |
MPFR.v4.2.0+1.powerpc64le-linux-gnu.tar.gz | 0000921950 900 KB | |
MPFR.v4.2.0+1.x86_64-linux-gnu.tar.gz | 0000891545 871 KB | |
MbedTLS.v2.28.2+1.aarch64-linux-gnu.tar.gz | 0002097771 2 MB | |
MbedTLS.v2.28.2+1.powerpc64le-linux-gnu.tar.gz | 0002253652 2.15 MB | |
MbedTLS.v2.28.2+1.x86_64-linux-gnu.tar.gz | 0002178218 2.08 MB | |
OpenBLAS.v0.3.23+4.aarch64-linux-gnu-libgfortran5. |
0007439063 7.09 MB | |
OpenBLAS.v0.3.23+4.powerpc64le-linux-gnu-libgfortr |
0006638089 6.33 MB | |
OpenBLAS.v0.3.23+4.x86_64-linux-gnu-libgfortran5.t |
0009531958 9.09 MB | |
OpenLibm.v0.8.1+2.aarch64-linux-gnu.tar.gz | 0000329479 322 KB | |
OpenLibm.v0.8.1+2.powerpc64le-linux-gnu.tar.gz | 0000201113 196 KB | |
OpenLibm.v0.8.1+2.x86_64-linux-gnu.tar.gz | 0000268364 262 KB | |
PCRE2.v10.42.0+1.aarch64-linux-gnu.tar.gz | 0002166988 2.07 MB | |
PCRE2.v10.42.0+1.powerpc64le-linux-gnu.tar.gz | 0002339780 2.23 MB | |
PCRE2.v10.42.0+1.x86_64-linux-gnu.tar.gz | 0002332880 2.22 MB | |
SuiteSparse.v7.2.1+1.aarch64-linux-gnu.tar.gz | 0001369667 1.31 MB | |
SuiteSparse.v7.2.1+1.powerpc64le-linux-gnu.tar.gz | 0001571419 1.5 MB | |
SuiteSparse.v7.2.1+1.x86_64-linux-gnu.tar.gz | 0001476769 1.41 MB | |
UnicodeData.txt | 0001851767 1.77 MB | |
Zlib.v1.2.13+1.aarch64-linux-gnu.tar.gz | 0000146800 143 KB | |
Zlib.v1.2.13+1.powerpc64le-linux-gnu.tar.gz | 0000152417 149 KB | |
Zlib.v1.2.13+1.x86_64-linux-gnu.tar.gz | 0000156413 153 KB | |
_constraints | 0000000804 804 Bytes | |
_link | 0000000124 124 Bytes | |
_multibuild | 0000000055 55 Bytes | |
apply-gmp-arm64-invert_limb.patch | 0000000675 675 Bytes | |
dSFMT.v2.2.4+4.aarch64-linux-gnu.tar.gz | 0000007210 7.04 KB | |
dSFMT.v2.2.4+4.powerpc64le-linux-gnu.tar.gz | 0000009039 8.83 KB | |
dSFMT.v2.2.4+4.x86_64-linux-gnu.tar.gz | 0000006617 6.46 KB | |
disable-doc-gen-in-makefile.patch | 0000000863 863 Bytes | |
disable-download-of-unicode-for-doc-gen.patch | 0000000509 509 Bytes | |
gmp-6.2.1-arm64-invert_limb.patch | 0000000393 393 Bytes | |
julia-1.10.5-full.tar.gz | 0318683963 304 MB | |
julia-1.10.5-full.tar.gz.asc | 0000000866 866 Bytes | |
julia-env-script-interpreter.patch | 0000000370 370 Bytes | |
julia-hardcoded-libs.patch | 0000001180 1.15 KB | |
julia-remove-libcholmod_cuda.patch | 0000001642 1.6 KB | |
julia-rpmlintrc | 0000001252 1.22 KB | |
julia.changes | 0000063357 61.9 KB | |
julia.keyring | 0000003094 3.02 KB | |
julia.spec | 0000040770 39.8 KB | |
libLLVM.v15.0.7+10.aarch64-linux-gnu-cxx11-llvm_ve |
0078372324 74.7 MB | |
libLLVM.v15.0.7+10.powerpc64le-linux-gnu-cxx11-llv |
0082317366 78.5 MB | |
libLLVM.v15.0.7+10.x86_64-linux-gnu-cxx11-llvm_ver |
0085634590 81.7 MB | |
libblastrampoline.v5.11.0+0.aarch64-linux-gnu.tar. |
0000812862 794 KB | |
libblastrampoline.v5.11.0+0.powerpc64le-linux-gnu. |
0000880007 859 KB | |
libblastrampoline.v5.11.0+0.x86_64-linux-gnu.tar.g |
0000869004 849 KB | |
mpfr-looking-for-gmp-fix.patch | 0000000934 934 Bytes | |
nghttp2.v1.52.0+1.aarch64-linux-gnu.tar.gz | 0000756822 739 KB | |
nghttp2.v1.52.0+1.powerpc64le-linux-gnu.tar.gz | 0000723880 707 KB | |
nghttp2.v1.52.0+1.x86_64-linux-gnu.tar.gz | 0000700352 684 KB | |
openlibm.patch | 0000000507 507 Bytes | |
p7zip.v17.4.0+2.aarch64-linux-gnu.tar.gz | 0001271747 1.21 MB | |
p7zip.v17.4.0+2.powerpc64le-linux-gnu.tar.gz | 0001318384 1.26 MB | |
p7zip.v17.4.0+2.x86_64-linux-gnu.tar.gz | 0001257704 1.2 MB |
Comments 51
I think the project has to prefer libnghttp2-14 as the dependency?
This package is totally broken ATM. It bundles tons of system libraries (e.g. libgcc_1.so, libnghttp2) and breaks the complete science repository.
I have disabled the build for now, and purged all binaries.
Hi @StefanBruens,
Julia needs those libraries. It uses a JIT compiler that is tightly integrated with the system. Long time ago I tried to separate but it became impossible to manage old LLVM versions, for example, in openSUSE. If you use different, unsupported versions, you can have problems and very bad bugs. Julia must be shipped with those versions, it has been like this for ages here in openSUSE and in other distros as well. Thus, I have no idea why this is "breaking" science repo just now.
This problem has been introduced when updating to 1.6.0.
This package breaks the whole science repository (as I already told you), and would break Factory when submitted.
The package bundles libgcc_s (which is a system library), it bundles libnghttp2 (which is part of the curl) package, and these provides end up in the RPM packages. You make it impossible for the resolver to do its job, both on the OBS and at runtime.
If you don't believe me, check the "Details" section of the built packages. Or ask yourself why after building julia the whole science repo ends up with the "Have choice ..." dependency problem.
But it has always been like this... you can check, we always bundled LLVM for at least 4 years.
No, it has not - this has been introduced by the update to 1.6.0, probably by upstream changes.
libLLVM is actually ok here, as it is not named libLLVM, but libLLVM-9jl.so (note the "jl" suffix).
See https://build.opensuse.org/package/binary/openSUSE:Factory/julia/standard/x86_64/julia-1.5.2-1.5.x86_64.rpm for package Provides.
libgit2 is wrong, though not critical - system soversion is 1.1 (libgit2.so.1.1), while julia has libgit2.so.28, so currently there is no problem.
libopenlibm is a problem already with version 1.5.2, as julia provides libopenlibm.so.3(), which should only provided by the system package.
So you are saying that, for some reason, we cannot bundle any system library in a openSUSE package now?
I only see a problem with the libnghttp2.so.14 library until now, which was introduced in Julia 1.6.0. We just need to fix this and use the system version, since it seems to match the upstream version. It does not mean that the package is "totally broken".
Check again. Julia 1.6.0 provides libnghtttp2.so.14, libopenlibm.so.3, libgcc_1.so.
nghttp2 dependency was indeed introduced by 1.6.0. libopenlibm.so.3 was already provided in 1.5.2 and nobody pointed out any problem. libgcc_1.so I need to wait for the build to analyze.
Hence, since we already had libopenlibm.so.3 inside Julia without problem and now you are telling me that this is a problem, can we conclude that you are telling me that now we cannot have bundled system libraries in openSUSE packages?
Just because nobody has mentioned it does not mean it is no problem - it is.
Please build it julia in a branched repository and fix it there. There obviously is a problem with the package, and breaking the complete science repository is not acceptable.
I am building to figure out, but in my local repository it worked. I think I just need to tell RPM to do not provide those libraries. I haven't found any problem or guideline prohibiting to bundle libraries in openSUSE packages.
I will just ask, please, to inform me first instead of disabling everything without given the maintainer proper time to check the logs next time.
The build worked, but apparently you did not check the results.
I am repeating this for the 3rd time, you broke the whole science repository. This was the case for 3 days (as can be seen by the very first comment here). You have not acted, and now you have reenabled it without checking the results first. Your actions will cause another breakage as soon as the package has been built. Deleting the binary julia packages is the only way to unbreak the repository.
But how am I suppose to know what happen if, when you disabled the builds and deleted the files, the logs were also deleted? You just said "It bundles tons of system libraries (e.g. libgcc_1.so, libnghttp2) and breaks the complete science repository." I needed to reenable to see the problem and fix it.
Again, your actions were not friendly. A simple: "@Ronis_BR we have a problem, it seems that Julia 1.6.0 is interfering with the entire repo. Can you check out please?" I would verify the conflict and would disabled the builds until a fix is found.
It is very different from: "this package is completely broken, I will disable everything".
You got a "we have a problem" three days ago.
There was no need to reenable the repository, rebuilding it in a branch suffices.
No, I had a comment "I think the project has to prefer libnghttp2-14 as the dependency?". This is a work I do for free in my spare time. If I do not receive a message saying "Hey! Look, a big problem", then I will just look when I have time, which can take more than 3 days.
One more time, you were not friendly. In this package, please, next time just ping me telling that we have a problem. If you are not happy with this, you are my guest to take over the maintenance of Julia.
You broke the repository for everyone, users and all other maintainers here - so a lot of other persons who also do the work for free.
You could have checked the results from the pending SR, to verify the problems. Instead you kept repeating "this package is fine", apparently without checking any of the raised concerns.
And how long should I have waited for any actions on your side? The broken repository state blocked all work in this repository, hindering everyone else here.
I did not keep repeating "This package is fine", meaning that no problem was occurring, but "I have been bundling LLVM and many system libraries since forever". YOU, on the other hand, said that this package is "completely broken".
I even wrote: "Thus, I have no idea why this is "breaking" science repo just now." I did not deny that a problem exist, just that the package as it is (with a lot of libraries bundled) has been like this for a long time.
Again, you told me that the package was broken because it is bundling system libraries, which is not true. It is a specific new bundled system library that is causing the problem, which I would have identified 10,000x faster if you had let me just analyze the logs.
Again, and for the last time: in this package, next time, tell me that something is wrong and I will fix it. If, for any specific reason, I do not respond fast (which I did today), then you can take actions. If you do not accept this, then ask for the maintenance role.
I have re-enabled the builds until anyone really point me out a problem. Again, Julia package has been like this for ages, and it must be like this. It is a computing language and we must use only supported libraries versions with the upstream patched when applicable.
And, by the way, if the openSUSE policy has changed (last time I checked I could bundle libraries if I want to), then you can completely delete this package and remove Julia from openSUSE. It is virtually impossible to maintain Julia without using those supported versions. It will lead to a ton of bugs, as we have verified in the past.
Hi @StefanBruens,
I think we are safe now. If you look at the binary created in my repo:
https://build.opensuse.org/package/binary/home:Ronis_BR/julia/openSUSE_Tumbleweed/x86_64/julia-1.6.0-112.1.x86_64.rpm
then you will see that even with a lot of bundled system libraries, RPM is not considering them as provided by Julia package. This should solve all the problems. Locally, Julia is working fine also, so no drawbacks up to now. If everything went wrong with those dependencies, let me know please.
I created a small bash script to download julia from release-1.6 branch and the libraries strictly needed by it (they check also sha1 or md5 of the files besides the repository revision, what complicate things a bit). Overall, the size of the package is greatly reduced as is also the time to build it (unluckily, had no success to build it against a standard system llvm).
May you be interested, let me know.
Regards, André
is there any plan to update this software to latest stable?
Yes! I am just waiting for 1.8.0 be released. 1.7 cannot build agains the current openSUSE tools... Sorry about that!
Hi,
Julia 1.8.1 is released by Sept. 6, could you update this repository for openSUSE TW?
Sincerely,
Hi!
I am really trying, but for some reason I am having build failures when using OBS (locally). I can build julia inside my machine using TW but not in OBS. I have no clue what is going on.
Maybe we can retire this package now that juliaup exists. My other reason would be that it is hard to maintain this package as well. Also, in the julia community, we really do not recommend using built binaries since the ones built upstream contains patches for LLVM and other dependencies for Julia to work properly. Not sure if that's what you want but this package has not been updated for a while due to weird build failures as you mentioned.
Sorry, but juliaup is no replacement for a julia built using the libraries available for the respective system. It works in a lot of cases, but no always. As an example try to run the GR surface plot example using the julia version installed using juliaup. At least on my system, it crashes because of unsatisfied references whereas it works using my locally compiled version. I'm using TW.
I didn't try to compile julia in OBS, because I don't know enough about rpm and OBS, but I think it would be good, if Ronis_BR could make his failed attempts somehow public, so people more experienced than me can have a look.
I will take a look next week to see what i can do for this. since there are two packages that provide julia, i will probably check if it is possible to add the
update-alternatives
on the spec for both of these packages.@Ronis_BR I will branch this and check if I can build this package.
@GNE as long as you built julia with the necessary patchsets to LLVM, you should be fine, we don't really recommend it though if it's just vanilla LLVM. I have seen some issues with it in ArchLinux and the solution was to use Julia's binary from their download's page since that contain patchsets for Julia to work properly.
Hi! Sorry for the delay!
Please, go ahead. Any help is appreciated! I will add you as a maintainer of this package.
I tried a lot, but the build process always failed in OBS during the sysimg creation. My attempts were based on using more bundled libraries instead of linking them to the ones in openSUSE.
Since we are using Julia for sensitive applications, I could not use the repository version anymore because I have never been able to make all tests pass. Hence, I needed to download the binary version from julialang.org.
Currently, I have time to perform some minor maintenance, but I no longer have time to solve those significant issues.
Thanks for the help!
By the way, we have not been using the openSUSE LLVM for a long time. I think somewhere between Julia 0.4 or 0.7, I needed to bundled LLVM due to significant version mismatch between the supported version and Tumbleweed.
I really suggest keeping the LLVM bundled because it will break when Tumbleweed upgrade to a newer version that is not supported by Julia. This scenario happened many times in the past. Since it is not easy to install two versions of LLVM, it is easier and safer to bundle it, IMHO.
Seems to me that it really is hard to package Julia. I have a feeling I should start from scratch and take it from there. Anyone can still use
juliaup
for the time being for convenience or download from the website. Personal life has caught up to me so updating julia won't happen anytime soon-ish unless someone helps.I have been trying to build julia-1.8.5 under leap-15.4. There are a couple of block points I've struck: - It is not possible to build julia against system llvm13, as it needs libLLVMDemangle and nothing provides it on SUSE; - It, for some reason, can't find some libraries that reside under /lib, as a workaround, I did place links to them inside the libraries build directory; - In my experience, some libraries that julia regular building process patches, are better left outside of USE_SYSTEM*; - It needs -DSUN64, so that functions that use huge indexes can coexist with others that use 32 bit ones (see https://github.com/Reference-LAPACK/lapack/issues/666). It means that many libraries must be build with this flag (at least openBLAS and suitesparse, but probably others will need to be build with it too); - No matter how much I tried, downloads happen under building process, what is quite annoying.
On coming days I will clone the current version, make the changes and submit a request. There are, still, some tests that didn't complete but, maybe, the effort can be properly shared.
I am checking out how Fedora does it. but for now I don't have time to do it because I have other things to do in school 😅
OK, had success building julia-1.8.5.
Now, the problem is, as I said on previous post, SUSE has to have openBLAS built with INTERFACE64=1 and a special version of SuiteSparse linked against it. This means to have a proper library name convention on place.
I inserted a definition i64 for that in openblas.spec: %if "%{?index64:defined}" == "" %global i64 %nil %else %global i64 64 %endif
and, on many places, modified the packages names to be:
lib%{name}%{?so_v}%{?i64:_%{i64}}
or
lib%{name}%{i64}-devel
So, this is what is missing, define what package names (and libraries and include directories) will be.
Regards, André
@StefanBruens what do you think of this approach? I remembered that bundling system libraries broke the science repository last time
The only sane approach is to build OpenBLAS with
INTERFACE64=1
andSYMBOLSUFFIX=64_
, and provide this as an additional variant.Otherwise, you end up with a BLAS library with potentially different calling convention for the same symbols, which breaks miserably when two dependent libraries refer to these symbols, one using 32bit indexes, the other 64bit indexes.
Yes, but we still have to have a name that follow SUSE conventions, this is the input I would like to get.
On a proto package I generated, I renamed openblas.pc to openblas64.pc and openBLASconfig.cmake had its path adjusted.
Same considerations should be done about libopenblas.so and libopenblas_openmp.so. Would the resulting names be libopenblas_64.so and libopenblas_openmp_64.so?
Some of the libraries were a bit more laborious to adjust, and I had to patch their building process, but seems to be fine now. Also, needed to fix the rpm .spec files.
Now, as a last decision, would be nice to establish what will be used for library suffix and include files (mainly).
My suggestion is to put them under "%{_libdir}/ilp64" and "%{_includedir}/ilp64". Even though this simple steps seem to fix most of the problems, I had an error while building SuiteSparse and it's mongoose library picking the installed regular Suitesparse suitesparseconfig, so, I suggest really adding _ilp64 to libraries to prevent this kind of error, or others that could arise from using just the regular names and risk ld picking the wrong library.
Suggestions?
have you asked some help in julia slack or in julia zulip?
also thanks for giving your time to improve the spec for julia and find ways to fix the build issues. i was too busy with personal stuff and maintain other packages on some devel projects at OBS, thus, i really can't help much here.
Did all of the adjustments on my computer. Will check the above projects to see if they have some suggestions. It would be wise to talk with Fedora maintainers also, just to have some common basic location settings to easy the testing done by upstream developers.
yes i think it's a good idea to ask for advice/help from fedora. it seems they have packaged julia like this https://src.fedoraproject.org/rpms/julia/blob/rawhide/f/julia.spec
I will check if I am able to.
This is my third attempt of updating julia to 1.9.4 https://build.opensuse.org/package/show/home:uncomfyhalomacro:branches:science/julia
however, it seems it's a lot difficult and may even be worthless effort in the end as noted in the arch wiki https://wiki.archlinux.org/title/Julia.
I will give time and probably request for deletion. The only other alternative of this is for users to use juliaup.
Unless someone steps up, I will request for its deletion within a week.
Afaik @Ronis_BR has abandoned the maintenance of this package and understandably so. Hopefully, even after its deletion, juliaup will satisfy the users.
Well it's successful :) so no deletion but imma put a warning
Hi @uncomfyhalomacro!
Thanks for your contribution! It would be nice to have Julia again in openSUSE repos. I had to abandon because it was taking a lot of time to make things works at each new release. Some people in openSUSE did not like the idea to bundle everything (like Fedora does, AFAIK), which was my only idea to make things work at that time.
Well it will be the same. In a separate branch, I will be using bundled library of LLVM. So if merged, there will only be two bundled libraries: LLVM and libuv.
LLVM and libuv are important since these are the only two that seem to affect numerical correctness whereas the former is the most important of them all since using system LLVM can affect Julia packages such as Sundials.jl
@Ronis_BR juliaup and julia are now enabled as
update-alternatives
. Going to experiment tomorrow if it still works.still broken. need to know why libLLVM-14jl.so is missing
just need to add INTERFACE_64=1 to openblas in opensuse hmm
EDIT: not needed. lolz
I guess the only way for this package to work correctly is to bundle suitesparse as well.