-
Notifications
You must be signed in to change notification settings - Fork 38
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
linking with SDK stubs 1.12.3 links with libeos.so.1.12 but rpm cannot find it on the switch #34
Comments
I am also experiencing this problem on 4.18.3.1F and 4.18.4F. |
Your application should link against libeos.so.1.12, this is how we can prevent it to try to run on the wrong target and then experience crashes due to binary incompatibilities. In the meantime, you can install the extension with the "force" option, as in:
Or add this line to your rpm spec file header when building your application:
|
Thanks for the hints, I didn't know about the force option, I guess it is an equivalent for --nodeps. I decided to patch Makefile.am file so the soname of the stubs library matches with the soname of the real library on the switch and now I can install my package without --nodeps/force option. I have a dependency on EosSdk package too with specified version >= 1.12.3 to avoid problems when someone is trying to install my package on an old image. AutoReqProv seems like a workaround to the problem not a solution.
Real SDK SONAME:
|
@hubertsokolowskintl We build our agents against EOS 1.8, 1.9, 1.10, and now 1.12.3. Only 1.12.3 output a dependency to libeos.so.1.12. All others just point to libeos.so.1. I am noticing a difference when compiling using the Arista SDK stubs on the support site and the github source code. These are clearly differently sourced... Very confusing from Arista. I am spending a lot of time trying to understand and account for these differences. I agree that 'force', '--nodeps', or AutoReqPrev are not valid workarounds. The dependency is actually available - if we run 'ldd' on the resulting binaries I install on the system, they can clearly find libeos.so.1.12 - dependencies work fine. This seems to be a purely RPM installation issue. |
Yes, we made that change (link against libeos.so.. instead of libeos.so.) to prevent an EosSdk app that was compiled against a different (than the one installed) to run, since those errors ("cannot find lib blah") are more straightforward than crashes due to binary incompatibilities. I diffed the github and the www.arista.com/en/support/software-download stubs too the other day. The differences are mainly white space and copyright year and differences in included example code, which is annoying indeed. Will check how those are generated since that is definitely confusing. So far I could not find out why rpm is more catholic that the pope: if you force the install, ldd and the loader have no problem finding that supposedly missing library! Note on using "version >= 1.12.3": that will not save you from crashing on a EOS that comes with EosSdk 1.13.1 (which given the bump in the version means a recompile is required or binary incompatibilities might crash the app). Note also that using the "extension" cli command (with the "force" option) is better than installing the rpm from bash (using --nodeps), since those will be re-applied on bootup before anything else runs (provided cli "copy installed-extensions boot-extensions" was also run). |
@ruferp This may also be related with Arista SR 91352 I filed this morning. |
The reason for the delta between "software-download-page" and "github" is that the github build failed (travis-ci), and the fix for all those travis-ci warning=failures has not yet made it into our code base. So what was pushed to github was simultaneously too early (version) and too late (all those white-space and other irrelevant changes). |
I agree it is better to link with libeos.1.12 then with libeos.1. I may be wrong but I think rpm dependencies are built based on the SONAME and if you change it in the real SDK when you build it so its SONAME matches with the one in the stubs SDK then the problem would be fixed. I am aware that installing with rpm does not survive reboot. I am doing it just to test my application. Finally my application gets installed as an extension. I just prefer not to use --nodeps or force. |
The problem is that rpm does not know which RPM provides libeos.so.1.12. [admin@ol422 ~]$ rpm -q --provides EosSdk So use the "force" option, or change the soname of your stubbed libeos.so to libeos.so.1, or wait for a new EosSdk.i686.rpm that was built with a "Provides: libeos.so.1.12" (next EOS release I guess). |
I understand your confusion. |
I will be fixed in 4.19.1 (should be out by next week). |
@ruferp Considering this is an RPM/SDK packaging issue, what is the high-level anticipated fix in 4.19.1 ? Are we getting another SDK version to build against? |
same SDK version, we changed EOS.swi (the libeos.so inside the swi had no soname previously, which works fine for linux's loader that looks at filenames only, but the rpm tools are a bit more cranky and pedantic about when an rpm provides something -- not simply because it contains the file). |
Hi,
I am linking my application with SDK stubs 1.12.3 libeos.so library like this:
g++ test.cpp -leos -L.
ldd is showing me that my application is actually linked with libeos.so.1.12.
That is not a problem when trying to run my application on the switch as there is symbolic link with such name, but when I build an RPM packages containing my app it has a dependency to libeos.so.1.12 which is not found by RPM as something that was installed by other RPM package. As a result I get an error during installation of my package:
When you check with rpm command which package provides that library it say no package:
however if you check libeos.so.1 then it find EosSdk package correctly:
Either there is something wrong in building EOS SDK stubs libeos.so.1.12.3 library so it is causing application to link with libeos.so.1.12 instead of libeos.so.1 or there is something wrong with the installation of EosSdk on the switch (build 4.18.4) so rpm cannot find a package that provides libeos.so.1.12.
For now I can workaround this problem by installing my package with --nodeps option but it would be good if it was fixed.
Regards,
Hubert
The text was updated successfully, but these errors were encountered: