Figured it out. Two kernel configuration options were in play:
CONFIG_COMPAT=y CONFIG_LSM_MMAP_MIN_ADDR=32768
Above is what is required to run armv5tel and armv7hl chroots on aarch64. Default for the latter option is 65535, which prevents 32-bit binaries from running. Up and running with 4.9.153 now.
I hope this is useful to someone else.
On Sat, Jan 26, 2019 at 8:08 PM Gordan Bobic gordan@redsleeve.org wrote:
I did a bit more digging, and rebuilding 4.9.153 with CONFIG_COMPAT and a few related options, had an effect - no longer do I get "exec format error"
- now it just outright segfaults.
4.4.172 works perfectly.
I'm using clean mainline kernels with no additional patches.
chrooting to aarch64 chroots works.
On Sat, Jan 26, 2019 at 6:07 PM Stephen John Smoogen smooge@gmail.com wrote:
On Sat, 26 Jan 2019 at 18:45, Gordan Bobic gordan@redsleeve.org wrote:
Yes, they are "wrong", but not "WRONG!".
As I (possibly poorly) explained, I'm running on an aarch64 machine, but am trying to run armv5tel and armv7hl chroots. I just dug out an old kernel I was using (4.4.72) and I can now chroot just fine.
So it's something that changed in the kernel, but I'm not sure what else it could be other than the page size (which I already checked).
I'm going to build the latest 4.4.172 with my 4.4.72 config and see if that works. If it does, I'll try to make oldconfig that on 4.9.153 and try again, see if that breaks things again. I was just hoping there might be an option I missed in 4.9 that enables/disables downward compatibility.
The places I have seen where this breaks before was
- it works on only specific aarch64 devices
- it works but only after you update the firmware to a newer vendor
version (because the kernel expects that to fix something else)
- it is a regression and needs to be fixed.
[The first one was where someone remembered it working but forgot they were working on XYZ box and then replicated in ABC and found the arch didn't have that.]
I am expecting it is going to be 3... but I would check on 2 also.
Gordan
On Sat, Jan 26, 2019 at 5:41 PM Stephan GUILLOUX < stephan.guilloux@free.fr> wrote:
Wrong architecture binaries, in the chroot'ed folder ?
What do you get with:
file <chroot>/bin/bash
On 26-Jan-19 17:49, Gordan Bobic wrote:
It's been so long since I last had to do this, that it looks like a kernel update somewhere along the way broke this for me. :-(
What happens now:
# chroot rs7 chroot: failed to run command ‘/bin/bash’: Exec format error
I could have sworn that this was all I needed to make this work last
time:
# grep 4K_PAGES config-4.9.153-1.el7.centos.aarch64 CONFIG_ARM64_4K_PAGES=y # CONFIG_ARM64_64K_PAGES is not set
Unfortunately, now trying to chroot into either hard-float or soft-float chroot results in the exec format error.
Looking at time stamps of various things, I had this working with 4.4.70, but have since switched to 4.9.x kernels. Any thoughts on
what
changed between 4.4 and 4.9 would be most appreciated.
What am I missing?
Arm-dev mailing list Arm-dev@centos.org https://lists.centos.org/mailman/listinfo/arm-dev
Arm-dev mailing list Arm-dev@centos.org https://lists.centos.org/mailman/listinfo/arm-dev
Arm-dev mailing list Arm-dev@centos.org https://lists.centos.org/mailman/listinfo/arm-dev
-- Stephen J Smoogen.
Arm-dev mailing list Arm-dev@centos.org https://lists.centos.org/mailman/listinfo/arm-dev