Hi all. I'm using a CentOS 6.8 VM to do volunteer builds for an open source project. I want to build Pale Moon with a gtk2 library older than 2.24, to allow people with older linuxes to run it. Short summary, if built against version gtk2-2.24 and/or higher, the binary will use a function that does not exist in gtk2-2.23 and lower. Net result is that the program dies with an "undefined symbol:" error for people with machines lower than gtk2-2.24. Yes, before you ask, they do get security fixes backported. The hits from my Google search suggested... yum downgrade gtk2 The response from yum was... Only Upgrade available on package: gtk-2.24.23-8.e16.i686 Nothing to do Are there ways around this? -- Walter Dnes <waltdnes at waltdnes.org>
Walter Dnes wrote:> Hi all. I'm using a CentOS 6.8 VM to do volunteer builds for an open > source project. I want to build Pale Moon with a gtk2 library older > than 2.24, to allow people with older linuxes to run it. Short summary, > if built against version gtk2-2.24 and/or higher, the binary will use a > function that does not exist in gtk2-2.23 and lower. Net result is that > the program dies with an "undefined symbol:" error for people with > machines lower than gtk2-2.24. Yes, before you ask, they do get > security fixes backported. > > The hits from my Google search suggested... > > yum downgrade gtk2 > > The response from yum was... > > Only Upgrade available on package: gtk-2.24.23-8.e16.i686 > Nothing to do > > Are there ways around this?One way would be to do the build on the same OS as the 'older linux' ? However, CentOS 6.5 shipped with gtk2-2.20.1-4.el6, CentOS 6.6 and above shipped with gtk-2.24 - see vault.centos.org/6.5/os You _might_ be able to downgrade gtk-2 to that shipped with CentOS 6.5 - but I guess there may be a myriad of dependencies on gtk-2.24 that prevent this on a CentOS 6.8 install ... Otherwise, use a CentOS 6.5 VM to do the build (with the usual caveats that 6.5 is old/out-of-date/etc)? James Pearson
Jonathan Billings
2017-Jan-09 13:54 UTC
[CentOS] How to downgrade gtk2 libs in CentOS 6.8?
On Jan 9, 2017, at 4:08 AM, Walter Dnes <waltdnes at waltdnes.org> wrote:> Hi all. I'm using a CentOS 6.8 VM to do volunteer builds for an open > source project. I want to build Pale Moon with a gtk2 library older > than 2.24, to allow people with older linuxes to run it. Short summary, > if built against version gtk2-2.24 and/or higher, the binary will use a > function that does not exist in gtk2-2.23 and lower. Net result is that > the program dies with an "undefined symbol:" error for people with > machines lower than gtk2-2.24. Yes, before you ask, they do get > security fixes backported. > > The hits from my Google search suggested... > > yum downgrade gtk2 > > The response from yum was... > > Only Upgrade available on package: gtk-2.24.23-8.e16.i686 > Nothing to do > > Are there ways around this?I suggest building the software using mock chroots, built against older versions of CentOS. You can set up custom chroots in /etc/mock/. For example, I have staged versions of CentOS7 (with staged yum repos) that I use to build kernel modules, so I can build the latest version of OpenAFS against kernels other than the latest, since our environment?s kernels don?t get updated immediately but I will still need to have OpenAFS kmods. You could do something similar, only pointing the yum repos at vault.centos.org <vault.centos.org> repos. -- Jonathan Billings <billings at negate.org>
On 01/09/2017 07:54 AM, Jonathan Billings wrote:> On Jan 9, 2017, at 4:08 AM, Walter Dnes <waltdnes at waltdnes.org> wrote: >> Hi all. I'm using a CentOS 6.8 VM to do volunteer builds for an open >> source project. I want to build Pale Moon with a gtk2 library older >> than 2.24, to allow people with older linuxes to run it. Short summary, >> if built against version gtk2-2.24 and/or higher, the binary will use a >> function that does not exist in gtk2-2.23 and lower. Net result is that >> the program dies with an "undefined symbol:" error for people with >> machines lower than gtk2-2.24. Yes, before you ask, they do get >> security fixes backported. >> >> The hits from my Google search suggested... >> >> yum downgrade gtk2 >> >> The response from yum was... >> >> Only Upgrade available on package: gtk-2.24.23-8.e16.i686 >> Nothing to do >> >> Are there ways around this? > > > I suggest building the software using mock chroots, built against older versions of CentOS. You can set up custom chroots in /etc/mock/. > > For example, I have staged versions of CentOS7 (with staged yum repos) that I use to build kernel modules, so I can build the latest version of OpenAFS against kernels other than the latest, since our environment?s kernels don?t get updated immediately but I will still need to have OpenAFS kmods. You could do something similar, only pointing the yum repos at vault.centos.org <vault.centos.org> repos. >This ^^ (use mock). You can use mock chroots in sandbox mode to manually get whatever install you want, or if all the things you want are in (for example) CentOS 6.5, you can point your config files for mock to use 6.5 repo from vault.centos.org and build against that. -------------- next part -------------- A non-text attachment was scrubbed... Name: signature.asc Type: application/pgp-signature Size: 198 bytes Desc: OpenPGP digital signature URL: <lists.centos.org/pipermail/centos/attachments/20170109/f4c64039/attachment-0001.sig>
On Mon, Jan 09, 2017 at 11:24:14AM +0000, James Pearson wrote> One way would be to do the build on the same OS as the 'older linux' ?The 'older linux' is "Lucid Puppy Revitalized as 5.2.8.7 - December, 2016" murga-linux.com/puppy/viewtopic.php?t=90461 It's a low-memory end-user distro, targetted at really old, low-memory machines. It can do simple compiles, but it's not a development environment suitable for building Pale Moon, which is an independant Firefox fork.> However, CentOS 6.5 shipped with gtk2-2.20.1-4.el6, CentOS 6.6 and > above shipped with gtk-2.24 - see vault.centos.org/6.5/osThanks for the pointer; I didn't know about that URL. I'll try to get 6.5 up and running as a VM.> Otherwise, use a CentOS 6.5 VM to do the build (with the usual caveats > that 6.5 is old/out-of-date/etc)?That seems the best route. As it was, even on 6.8, I had to "yum install autoconf213", and manually downloand tarballs and build from source yasm, python 2.7, and gcc 4.9.4. I'm not a programmer, but I can "./configure --with-options && make && make install". It's no more difficult than "yum install <whatever>". I realize that CentOS 6.5 is "not safe for surfing", but I'll be using it only for doing builds. The build will not be statically linking in libraries, so CentOS security holes are not a problem. Lucid Puppy has an "ancient" glibc, but has backported patches for the "Ghost" exploit, etc. Ditto for ssl and other exploits. -- Walter Dnes <waltdnes at waltdnes.org>