All of lore.kernel.org
 help / color / mirror / Atom feed
* aarch64: correct path for ld-linux-aarch64.so
@ 2014-09-16  7:51 Adrian Calianu
  2014-09-16  8:29 ` Kang Kai
  0 siblings, 1 reply; 2+ messages in thread
From: Adrian Calianu @ 2014-09-16  7:51 UTC (permalink / raw)
  To: openembedded-core

[-- Attachment #1: Type: text/plain, Size: 529 bytes --]

Hello,

   Building a core-image-minial with poky distro for a new aarch64 machine I found that the ld-linux-aarch64.so is stored under /lib64 folder into rootfs.
   Due to this issue the init process doesn't start. I think the correct location is under /lib folder.

Kernel panic - not syncing: No working init found.  Try passing init= option to kernel. See Linux Documentation/init.txt for guidance.

   Is there any configuration that need to be done or patch for this issue?

Thank you in advance,
Adrian





[-- Attachment #2: Type: text/html, Size: 3738 bytes --]

^ permalink raw reply	[flat|nested] 2+ messages in thread

* Re: aarch64: correct path for ld-linux-aarch64.so
  2014-09-16  7:51 aarch64: correct path for ld-linux-aarch64.so Adrian Calianu
@ 2014-09-16  8:29 ` Kang Kai
  0 siblings, 0 replies; 2+ messages in thread
From: Kang Kai @ 2014-09-16  8:29 UTC (permalink / raw)
  To: Adrian Calianu, openembedded-core


[-- Attachment #1.1: Type: text/plain, Size: 959 bytes --]

On 2014?09?16? 15:51, Adrian Calianu wrote:
> Hello,

Hi Adrian,

Sorry for late answer. I though you will begin work few hours later.

>     Building a core-image-minial with poky distro for a new aarch64 machine I found that the ld-linux-aarch64.so is stored under /lib64 folder into rootfs.
>     Due to this issue the init process doesn't start. I think the correct location is under /lib folder.

That is the toolchain issue. BASELIB has to be set to 'lib64', so 
ld-linux-aarch64.so.1 is installed to /lib instead of /lib64. Please try 
patch attached that I redefined the dynamic linker position.

Regards,
Kai

>
> Kernel panic - not syncing: No working init found.  Try passing init= option to kernel. See Linux Documentation/init.txt for guidance.
>
>     Is there any configuration that need to be done or patch for this issue?
>
> Thank you in advance,
> Adrian
>
>
>
>
>
>
>



-- 
Regards,
Neil | Kai Kang


[-- Attachment #1.2: Type: text/html, Size: 1909 bytes --]

[-- Attachment #2: 0001-gcc-4.9-redefine-dynamic-linker-for-aarch64.patch --]
[-- Type: text/x-patch, Size: 2938 bytes --]

From 35f41fd8ddb5d8e1246fff43b0c4c87f3a73495b Mon Sep 17 00:00:00 2001
From: Kai Kang <kai.kang@windriver.com>
Date: Tue, 16 Sep 2014 16:20:19 +0800
Subject: [PATCH] gcc-4.9: redefine dynamic linker for aarch64

Redefine dynamic linker for aarch64 from /lib to /lib64.

BASELIB of aarch64 has to be defined with 'lib64', then linker file
ld-linux-aarch64.so.1 is installed into /lib64 rather than /lib. So
update it here too.

Signed-off-by: Kai Kang <kai.kang@windriver.com>
---
 meta/recipes-devtools/gcc/gcc-4.9.inc              |  1 +
 .../0056-redefine-dynamic-linker-for-aarch64.patch | 34 ++++++++++++++++++++++
 2 files changed, 35 insertions(+)
 create mode 100644 meta/recipes-devtools/gcc/gcc-4.9/0056-redefine-dynamic-linker-for-aarch64.patch

diff --git a/meta/recipes-devtools/gcc/gcc-4.9.inc b/meta/recipes-devtools/gcc/gcc-4.9.inc
index 25778bd..c434a45 100644
--- a/meta/recipes-devtools/gcc/gcc-4.9.inc
+++ b/meta/recipes-devtools/gcc/gcc-4.9.inc
@@ -70,6 +70,7 @@ SRC_URI = "\
     file://0053-gcc-fix-segfault-from-calling-free-on-non-malloc-d-a.patch \
     file://0054-gcc-Makefile.in-fix-parallel-building-failure.patch \
     file://0055-PR-rtl-optimization-61801.patch \
+    file://0056-redefine-dynamic-linker-for-aarch64.patch \
 "
 SRC_URI[md5sum] = "fddf71348546af523353bd43d34919c1"
 SRC_URI[sha256sum] = "d334781a124ada6f38e63b545e2a3b8c2183049515a1abab6d513f109f1d717e"
diff --git a/meta/recipes-devtools/gcc/gcc-4.9/0056-redefine-dynamic-linker-for-aarch64.patch b/meta/recipes-devtools/gcc/gcc-4.9/0056-redefine-dynamic-linker-for-aarch64.patch
new file mode 100644
index 0000000..6933e2f
--- /dev/null
+++ b/meta/recipes-devtools/gcc/gcc-4.9/0056-redefine-dynamic-linker-for-aarch64.patch
@@ -0,0 +1,34 @@
+From 8fbb60d89e569b68b13e4fd419e20640eb49cabc Mon Sep 17 00:00:00 2001
+From: Kai Kang <kai.kang@windriver.com>
+Date: Tue, 16 Sep 2014 16:01:31 +0800
+Subject: [PATCH] Redefine dynamic linker for aarch64
+
+Redefine dynamic linker for aarch64 from /lib to /lib64.
+
+BASELIB of aarch64 has to be defined with 'lib64', then linker file
+ld-linux-aarch64.so.1 is installed into /lib64 rather than /lib. So
+update it here too.
+
+Upstream-Status: Pending
+
+Signed-off-by: Kai Kang <kai.kang@windriver.com>
+---
+ gcc/config/aarch64/aarch64-linux.h | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+diff --git a/gcc/config/aarch64/aarch64-linux.h b/gcc/config/aarch64/aarch64-linux.h
+index a8f0771..2a6f06d 100644
+--- a/gcc/config/aarch64/aarch64-linux.h
++++ b/gcc/config/aarch64/aarch64-linux.h
+@@ -21,7 +21,7 @@
+ #ifndef GCC_AARCH64_LINUX_H
+ #define GCC_AARCH64_LINUX_H
+ 
+-#define GLIBC_DYNAMIC_LINKER "/lib/ld-linux-aarch64%{mbig-endian:_be}.so.1"
++#define GLIBC_DYNAMIC_LINKER "/lib64/ld-linux-aarch64%{mbig-endian:_be}.so.1"
+ 
+ #define CPP_SPEC "%{pthread:-D_REENTRANT}"
+ 
+-- 
+1.9.1
+
-- 
1.9.1


^ permalink raw reply related	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2014-09-16  8:29 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2014-09-16  7:51 aarch64: correct path for ld-linux-aarch64.so Adrian Calianu
2014-09-16  8:29 ` Kang Kai

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.