WelcomeWelcome | FAQFAQ | DownloadsDownloads | WikiWiki

Author Topic: Tiny Core 9.0 Alpha 1 Testing  (Read 19787 times)

Offline andyj

  • Hero Member
  • *****
  • Posts: 1036
Re: Tiny Core 9.0 Alpha 1 Testing
« Reply #15 on: January 11, 2018, 08:48:37 AM »
Would it be possible for the next alpha build to not to strip glibc? I'm trying to figure out why open-vm-tools builds on 8.2 with glibc 2.24 and not on 9.0 with glibc 2.26. Somewhere along the way libtool says it can't find the xdr* functions that are supposed to be in glibc. I compiled glibc myself but when I grafted it into the rootfs somebody (busybox?) complained about not being able to find libcrypt.

Offline Juanito

  • Administrator
  • Hero Member
  • *****
  • Posts: 14872
Re: Tiny Core 9.0 Alpha 1 Testing
« Reply #16 on: January 11, 2018, 09:23:31 AM »
You can compile glibc, install it somewhere outside of the root filesystem, and make a tarball of it.

Next, boot tc, copy the tarball to / and untar it as root.

Offline andyj

  • Hero Member
  • *****
  • Posts: 1036
Re: Tiny Core 9.0 Alpha 1 Testing
« Reply #17 on: January 11, 2018, 11:18:01 AM »
I tried that first, but it didn't work like I hoped. How can I get it to boot with the un-stripped libraries?

Offline Juanito

  • Administrator
  • Hero Member
  • *****
  • Posts: 14872
Re: Tiny Core 9.0 Alpha 1 Testing
« Reply #18 on: January 11, 2018, 11:27:52 AM »
Hmm - it works for me...

To boot with unstripped libs you’d need to replace the libs in roots64.gz

Offline andyj

  • Hero Member
  • *****
  • Posts: 1036
Re: Tiny Core 9.0 Alpha 1 Testing
« Reply #19 on: January 11, 2018, 03:40:34 PM »
I did that. That's how I got the "cant find libcrypt" error. I wouldn't have thought there was another step, but maybe there is something else that needs to be done to the rootfs before putting it back together? I've added plenty of stuff to the rootfs over the years so I am familiar with that process, but I've never swapped out core libraries before.

Offline andyj

  • Hero Member
  • *****
  • Posts: 1036
Re: Tiny Core 9.0 Alpha 1 Testing
« Reply #20 on: January 11, 2018, 04:04:52 PM »
OK, I had to ldconfig in the new fs first. But now it can't login, complaining it can't set groups. There's another step?

Offline andyj

  • Hero Member
  • *****
  • Posts: 1036
Re: Tiny Core 9.0 Alpha 1 Testing
« Reply #21 on: January 11, 2018, 04:53:17 PM »
Got it to work, didn't fix the problem making open-vm-tools, so maybe it's a difference in gcc 7.2 behavior. Anyway, I discovered that /lib/udev owner is 755 instead of root. Also, would it be possible to have ldd to give a version string when asked by adding this as the first option:

Code: [Select]
  --version) echo 'ldd (GNU libc) 2.26'
    break
    ;;

This would make a few glibc version detection tricks in configure happier.

Offline Juanito

  • Administrator
  • Hero Member
  • *****
  • Posts: 14872
Re: Tiny Core 9.0 Alpha 1 Testing
« Reply #22 on: January 12, 2018, 02:59:49 AM »
Maybe it would be better to take the version from /lib/libc.so.6 so that the ldd script would not need to be changed every glibc update?

Code: [Select]
$ /lib/libc.so.6
GNU C Library (GNU libc) stable release version 2.26, by Roland McGrath et al.
...
« Last Edit: January 12, 2018, 03:22:32 AM by Juanito »

Offline Juanito

  • Administrator
  • Hero Member
  • *****
  • Posts: 14872
Re: Tiny Core 9.0 Alpha 1 Testing
« Reply #23 on: January 12, 2018, 06:55:47 AM »
Got it to work, didn't fix the problem making open-vm-tools, so maybe it's a difference in gcc 7.2 behavior.

rpc has been obsolete in glibc for a while now - using open-vm-tools-stable-10.2.0 with:
Code: [Select]
LIBS="-ltirpc" CC="gcc -flto -fuse-linker-plugin -mtune=generic -Os -pipe" CXX="g++-flto -fuse-linker-plugin -mtune=generic -Os -pipe" ./configure --prefix=/usr/local --disable-static --localstatedir=/var --sysconfdir=/etc --without-kernel-modules --disable-glibc-check --without-pam --without-xerces --without-dnet
..seems to work?

Edit:
Code: [Select]
$ nm -D /lib/libnsl-2.26.so | grep -i xdrmem_create
                 U xdrmem_create
$ nm -D /usr/local/lib/libtirpc.so.3.0.0 | grep -i xdrmem_create
0000000000012e04 T xdrmem_create

..with LIBS="-lnsl" it fails with:
Code: [Select]
/tmp/ccFyMhli.ltrans0.ltrans.o: In function `XdrUtil_Deserialize':
<artificial>:(.text+0xf52): undefined reference to `xdrmem_create'
« Last Edit: January 12, 2018, 08:09:55 AM by Juanito »

Offline andyj

  • Hero Member
  • *****
  • Posts: 1036
Re: Tiny Core 9.0 Alpha 1 Testing
« Reply #24 on: January 12, 2018, 10:09:21 AM »
Tried that already. The problem is that the configure scripts I've come across expect the version to be at the end:

Code: [Select]
ldd (GNU libc) 2.26
which gives 2.26, versus

Code: [Select]
GNU C Library (GNU libc) stable release version 2.26, by Roland McGrath et al.
which gives "al." when then breaks the math. Besides, it's how the full ldd GNU script does it so it seems they change it for every glibc update. How about this instead? A little long but it does the job:

Code: [Select]
  --version) echo "ldd (GNU libc)" $(ls /lib/libc-*.so | sed -e 's/^.*-//' -e 's/\.so//')
        break
        ;;

I believe having dnet allows the guest to know if the host's network is disconnected, which might be desirable in some cases. Using TI-RPC it does compile, so I'm going to go with that for now, and add it as a dependency.

Offline Juanito

  • Administrator
  • Hero Member
  • *****
  • Posts: 14872
Re: Tiny Core 9.0 Alpha 1 Testing
« Reply #25 on: January 15, 2018, 06:20:35 AM »
OK - could you submit the change as a patch please?

Offline andyj

  • Hero Member
  • *****
  • Posts: 1036
Re: Tiny Core 9.0 Alpha 1 Testing
« Reply #26 on: January 15, 2018, 11:21:32 AM »
Here we go.

Thanks

Offline uli

  • Newbie
  • *
  • Posts: 9
Re: Tiny Core 9.0 Alpha 1 Testing
« Reply #27 on: January 18, 2018, 02:52:53 AM »
Excellent piece of work.

Almost easily brought up on Hyper-V Gen2 (x64).

EXCEPT  scsi_transport_fc.ko is missing. Therefore it is not possible to start from .iso right away.

Those who are using Tc x64 on Hyper-V would probably go for Gen2 machines, therefore it would make a lot of sense to add the missing lib to the x64 version, given that all Hyper-V drivers are already there.