2015-09-17 4 views
5
nodejs0.12.2

मैं Atmel SAMA5D36 के लिए 0.12.2 NodeJS संकलित क्रॉस का उपयोग कर उपकरण श्रृंखला निम्नलिखितNPM -v और Node.js क्रूस पर अवैध निर्देश फेंकने के रूप में</p> <p>इस प्रकार संकलित

export AR=arm-linux-gnueabihf-ar 
export CC=arm-linux-gnueabihf-gcc 
export CXX=arm-linux-gnueabihf-g++ 
export LINK=arm-linux-gnueabihf-g++ 

और विन्यस्त और निर्माण ./configure --without-snapshot --dest-cpu = arm --dest-os = linux --prefix =/home/root/nodejs-v0.12.2

DESTDIR =/home/user इंस्टॉल करें/डेस्कटॉप/nodejs_arm/nodebins

संकलित फ़ोल्डर के अंदर उत्पन्न होता है/घर/उपयोगकर्ता/डेस्कटॉप/nodejs_arm/nodebins/घर/जड़

मैं संकुचित टार फ़ाइल में फ़ोल्डर और AtmelSAMA5D36 को हस्तांतरित हाथ कि board.I/घर में बोर्ड पर असम्पीडित/रूट निर्देशिका और प्रतीकात्मक कड़ी निम्नलिखित बनाया

ln -s /home/root/nodejs-v0.12.2/bin/npm /bin/npm 
ln -s /home/root/nodejs-v0.12.2/bin/node /bin/node 

जब मैं का उपयोग कर "नोड -v" और "NPM -v",

"नोड -v" सही उत्पादन देता है, लेकिन

"यह परीक्षण एनपीएम-वी "फेंकना" बीमार समान निर्देश "त्रुटि
" नोड "के साथ ही।

हालांकि क्रॉस संकलित नोडजे 0.10.40 पूरी तरह से ठीक काम कर रहा है।

किसी भी मदद की अत्यधिक सराहना की जाती है।

अद्यतन:

(gdb) run 
Starting program: /usr/bin/node 
[Thread debugging using libthread_db enabled] 
Using host libthread_db library "/lib/libthread_db.so.1". 

Program received signal SIGILL, Illegal instruction. 
0xb6edfec0 in _armv7_neon_probe() from /usr/lib/libcrypto.so.1.0.0 
(gdb) c 
Continuing. 

Program received signal SIGILL, Illegal instruction. 
0xb6edfec8 in _armv7_tick() from /usr/lib/libcrypto.so.1.0.0 
(gdb) c 
Continuing. 
[New Thread 0xb65ca4c0 (LWP 3774)] 
[New Thread 0xb67ca4c0 (LWP 3773)] 
[New Thread 0xb69ca4c0 (LWP 3772)] 
[New Thread 0xb6bca4c0 (LWP 3771)] 

Program received signal SIGILL, Illegal instruction. 
0x0054b504 in v8::internal::ComputeFlagListHash()() 
(gdb) c 
Continuing. 
[Thread 0xb65ca4c0 (LWP 3774) exited] 
[Thread 0xb67ca4c0 (LWP 3773) exited] 
[Thread 0xb69ca4c0 (LWP 3772) exited] 
[Thread 0xb6bca4c0 (LWP 3771) exited] 

Program terminated with signal SIGILL, Illegal instruction. 
The program no longer exists. 
(gdb) q 
# gdb node -e 0 
GNU gdb (GDB) 7.9.1 
Copyright (C) 2015 Free Software Foundation, Inc. 
License GPLv3+: GNU GPL version 3 or later <http://gnu.org/licenses/gpl.html> 
This is free software: you are free to change and redistribute it. 
There is NO WARRANTY, to the extent permitted by law. Type "show copying" 
and "show warranty" for details. 
This GDB was configured as "arm-buildroot-linux-uclibcgnueabihf". 
Type "show configuration" for configuration details. 
For bug reporting instructions, please see: 
<http://www.gnu.org/software/gdb/bugs/>. 
Find the GDB manual and other documentation resources online at: 
<http://www.gnu.org/software/gdb/documentation/>. 
For help, type "help". 
Type "apropos word" to search for commands related to "word"... 
Reading symbols from node... 
(gdb) 
(gdb) run 
Starting program: /usr/bin/node 
[Thread debugging using libthread_db enabled] 
Using host libthread_db library "/lib/libthread_db.so.1". 
[New Thread 0xb64f84c0 (LWP 14382)] 
[New Thread 0xb66f84c0 (LWP 14381)] 
[New Thread 0xb68f84c0 (LWP 14380)] 
[New Thread 0xb6af84c0 (LWP 14379)] 

Program received signal SIGILL, Illegal instruction. 
0x0054b504 in v8::internal::ComputeFlagListHash()() 
(gdb) 
(gdb) run 
The program being debugged has been started already. 
Start it from the beginning? (y or n) y 
Starting program: /usr/bin/node 
[Thread debugging using libthread_db enabled] 
Using host libthread_db library "/lib/libthread_db.so.1". 
[New Thread 0xb653d4c0 (LWP 14531)] 
[New Thread 0xb673d4c0 (LWP 14530)] 
[New Thread 0xb693d4c0 (LWP 14529)] 
[New Thread 0xb6b3d4c0 (LWP 14528)] 

Program received signal SIGILL, Illegal instruction. 
0x0054b504 in v8::internal::ComputeFlagListHash()() 
(gdb) Program received signal SIGILL, Illegal instruction. 
Undefined command: "Program". Try "help". 
(gdb) 0x0054b504 in v8::internal::ComputeFlagListHash()()bt 
Undefined command: "0x0054b504". Try "help". 
(gdb) bt 
#0 0x0054b504 in v8::internal::ComputeFlagListHash()() 
#1 0x007b8a54 in v8::internal::V8::InitializeOncePerProcessImpl()() 
#2 0x009281b0 in v8::base::CallOnceImpl(int*, void (*)(void*), void*)() 
#3 0x007b8ba8 in v8::internal::V8::Initialize()() 
#4 0x0028fc74 in v8::V8::Initialize()() 
#5 0x00897a34 in node::Start(int, char**)() 
#6 0xb6b95634 in __uClibc_main() from /lib/libc.so.1 
#7 0x00000000 in ??() 
Backtrace stopped: previous frame identical to this frame (corrupt stack?) 
(gdb) q 
+0

कर सकते हैं आप उत्पादन 'नोड --v8-options' का परिणाम – Corbin

+0

नोड --v8-विकल्पों में से उत्पादन की पहली कुछ पंक्तियों के रूप में –

+1

लक्ष्य हाथ v7 vfp3 कठिन ARMv7 = 1 VFP3 = 1 VFP32DREGS = 1 नियोन इस प्रकार हैं = 0 SUDIV = 0 UNALIGNED_ACCESSES = 1 MOVW_MOVT_IMMEDIATE_LOADS = 0 USE_EABI_HARDFLOAT = 1 –

उत्तर

2

हम ने वही समस्या SAMA5D31 पर एक buildroot toolchain के माध्यम से 6.1.0 NodeJS उपयोग करने के लिए कोशिश कर रहा था, और एक ही "अवैध अनुदेश" मुद्दों में भाग गया। अंत में हमने संस्करण 0.10.45 का उपयोग करने के लिए स्विच किया जो पुराने प्रोसेसर (armv5 और पुराने) के लिए buildroot में शामिल है।

समस्या निवारण में, यह समस्या नोड द्वारा उपयोग की जाने वाली नोडजे और ओपनएसएसएल पुस्तकालयों में प्रतीत होती है जहां संकलित कोड फ़्लोटिंग पॉइंट ऑपरेशंस के लिए नियॉन निर्देशों का उपयोग करने का प्रयास कर रहा है। SAMA5D3X प्रोसेसर एक armV7 के रूप में रिपोर्ट करता है, लेकिन इसमें नियॉन एफपीयू नहीं है। हालांकि, नोडज (और हमारे लिए openssl) नियॉन निर्देशों का उपयोग करने की कोशिश कर रहे हैं क्योंकि यह एक armV7 के रूप में मानता है। जब तक नोडज गैर-नियॉन armV7 को संभाल नहीं लेता है, तब तक सबसे अच्छा विकल्प नोड के 0.10.40 या 0.10.45 संस्करण का उपयोग करना है जब तक इसे हल नहीं किया जा सकता है। या गैर-नियॉन armV7 को संभालने के लिए नोड के लिए बिल्ड कॉन्फ़िगरेशन स्वयं को संशोधित करें।

संबंधित मुद्दे