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

Again, the releases don't have the libraries. #11091

Open
0wwafa opened this issue Jan 5, 2025 · 6 comments
Open

Again, the releases don't have the libraries. #11091

0wwafa opened this issue Jan 5, 2025 · 6 comments

Comments

@0wwafa
Copy link

0wwafa commented Jan 5, 2025

./build/bin/llama-quantize: error while loading shared libraries: libllama.so: cannot open shared object file: No such file or directory

it already happened in the past...

@0wwafa
Copy link
Author

0wwafa commented Jan 5, 2025

Please test the binaries on colab :D if it works there it works everywhere.

@0wwafa
Copy link
Author

0wwafa commented Jan 5, 2025

Version 40xx work..
Version 42xx don't

I tried a few. don't know ehen it "EFFED UP" :D

@dagbs
Copy link

dagbs commented Jan 6, 2025

Version b4406 built successfully with no libllama.so error.

I setup a script to automatically go through and test until I found one that works. Although, yes... this is currently an issue with latest versions.

To be used with: https://gist.github.com/dagbs/1258a52addeb61cbf26e24f75b2ad7d9

#!/bin/bash

# Starting version and minimum version
start_version=4416
min_version=4000

current_version=$start_version

while [ $current_version -ge $min_version ]; do
    echo "Attempting to build and test version b$current_version"
    
    # Download the specified version
    ./download_latest.sh "b$current_version"
    
    # Build and check if llama-cli works without errors
    if ./build/bin/llama-cli --help 2>&1 | grep -q 'libllama.so'; then
        echo "Error: libllama.so not found in version b$current_version."
    else
        echo "Version b$current_version built successfully with no libllama.so error."
        break # Exit the loop if a successful build is found
    fi
    
    # Decrease the version number and wait 5 seconds before the next attempt
    current_version=$((current_version - 1))
    sleep 5
done

if [ $current_version -lt $min_version ]; then
    echo "No suitable version found. All versions from b$start_version to b$min_version had issues."
fi

@bandoti
Copy link
Contributor

bandoti commented Jan 6, 2025

@0wwafa Do you mean to say that when downloading llama.cpp it is not including the shared libraries? If so where are you downloading from? Or are you building, installing, and then running the application and those shared libraries are missing?

If this happened before it is helpful to include a link to a previous issue or PR that resolved the problem you are seeing.

Folks use llama.cpp in various ways so it is necessary to have the extra context so we can help resolve the issue accordingly!

@pjh64
Copy link

pjh64 commented Jan 8, 2025

I ran into the same issue and I remember it to also happen on other platforms such as x86_64.
There seem to be two inconveniences for me. The first is, that cmake does seem to be necessary now. I really appreciated the ease of just running make on even the most basic systems to compile llama.cpp. But that aside, this change will certainly have its reasons. The library issue however seems to be much more of a problem.
It works however when calling the binaries directly from their build dir.

Here is the entire build log from my last compiling attempt on the arm64 platform (but the same happens on x86_64):
:
https://pastebin.com/EK6vNMn0

@bandoti
Copy link
Contributor

bandoti commented Jan 9, 2025

@pjh64 thanks for the detailed logs!

So, what I gather is that you are running on a Raspberry Pi. In that case, here are the considerations when using the dynamic build, and I will offer some possible resolutions after.

When Llama.cpp is being installed on your system, it is using a default prefix of /usr/local/bin and /usr/local/lib. The backend libraries are getting installed to the libs directory, and the applications to the bin directory. Now, my first guess is that these paths are not in the default loader path so the system doesn't know where to find them.

And we cannot guarantee that all operating systems will use the same default paths although perhaps there's a smarter way to query that info at build time and some improvements can be made. However, what I would suggest is:

  1. If you want to keep the current install path simply prefix running export LD_LIBRARY_PATH="/usr/local/lib:$LD_LIBRARY_PATH" before running llama-cli &co.
  2. Change the install prefix to match the system you are running on using cmake --build . --prefix /usr/lib (or similar) instead of the default make install.
  3. Compile Llama.cpp statically if you know you are going to use the same backend cmake .. -DBUILD_SHARED_LIBS=OFF

You will have to verify where your system typically loads shared libraries by default and go from there!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

4 participants