<html><head></head><body lang="en-US" style="background-color: rgb(255, 255, 255); line-height: initial;">                                                                                      <div style="width: 100%; font-size: initial; font-family: Calibri, 'Slate Pro', sans-serif, sans-serif; color: rgb(31, 73, 125); text-align: initial; background-color: rgb(255, 255, 255);">This is just the configuration step. It's setting up your build environment akin to what ‎the rtems-source-builder sb-check does. </div><div style="width: 100%; font-size: initial; font-family: Calibri, 'Slate Pro', sans-serif, sans-serif; color: rgb(31, 73, 125); text-align: initial; background-color: rgb(255, 255, 255);"><br></div><div style="width: 100%; font-size: initial; font-family: Calibri, 'Slate Pro', sans-serif, sans-serif; color: rgb(31, 73, 125); text-align: initial; background-color: rgb(255, 255, 255);">It looks like your on the right path. It checked your compilers and verified it can use them. </div><div style="width: 100%; font-size: initial; font-family: Calibri, 'Slate Pro', sans-serif, sans-serif; color: rgb(31, 73, 125); text-align: initial; background-color: rgb(255, 255, 255);"><br></div><div style="width: 100%; font-size: initial; font-family: Calibri, 'Slate Pro', sans-serif, sans-serif; color: rgb(31, 73, 125); text-align: initial; background-color: rgb(255, 255, 255);">Russ</div>                                                                                                                                     <div style="width: 100%; font-size: initial; font-family: Calibri, 'Slate Pro', sans-serif, sans-serif; color: rgb(31, 73, 125); text-align: initial; background-color: rgb(255, 255, 255);"><br style="display:initial"></div>                                                                                                                                                                                                   <div style="font-size: initial; font-family: Calibri, 'Slate Pro', sans-serif, sans-serif; color: rgb(31, 73, 125); text-align: initial; background-color: rgb(255, 255, 255);">Sent from my BlackBerry 10 smartphone on the Virgin Mobile network.</div>                                                                                                                                                                                  <table width="100%" style="background-color:white;border-spacing:0px;"> <tbody><tr><td colspan="2" style="font-size: initial; text-align: initial; background-color: rgb(255, 255, 255);">                           <div style="border-style: solid none none; border-top-color: rgb(181, 196, 223); border-top-width: 1pt; padding: 3pt 0in 0in; font-family: Tahoma, 'BB Alpha Sans', 'Slate Pro'; font-size: 10pt;">  <div><b>From: </b>xuelin.tian@qkmtech.com</div><div><b>Sent: </b>Thursday, July 20, 2017 8:11 PM</div><div><b>To: </b>Russell Haley</div><div><b>Cc: </b>Joel Sherrill; users@rtems.org</div><div><b>Subject: </b>Re: Re: Has anyone tried to port Mono to RTEMS</div></div></td></tr></tbody></table><div style="border-style: solid none none; border-top-color: rgb(186, 188, 209); border-top-width: 1pt; font-size: initial; text-align: initial; background-color: rgb(255, 255, 255);"></div><br><div id="_originalContent" style=""><meta http-equiv="content-type" content="text/html; charset=UTF-8"><style>body { line-height: 1.5; }blockquote { margin-top: 0px; margin-bottom: 0px; margin-left: 0.5em; }div.foxdiv20170721110401434791 { }body { font-size: 10.5pt; font-family: 微软雅黑; color: rgb(0, 0, 0); line-height: 1.5; }</style>
<div><span></span><div>Sorry about some missing information.</div><div>My host is ubuntu 14.4 (--host=x86_64-unknown-linux), and target is Zynq, ARM family (--target=arm-rtems4.11). </div><div>I want to cross-compile Mono from source, downloaded from Github, the version is 4.8.1.0, not the HEAD. </div></div><div><br></div><div>I think what you mean by build output is shown below:</div><div>=================================================</div>
<div><span style="color: rgb(0, 0, 0); background-color: rgba(0, 0, 0, 0);">Running libtoolize...<br>libtoolize: putting auxiliary files in `.'.<br>libtoolize: copying file `./ltmain.sh'<br>libtoolize: putting macros in AC_CONFIG_MACRO_DIR, `m4'.<br>libtoolize: copying file `m4/libtool.m4'<br>libtoolize: copying file `m4/ltoptions.m4'<br>libtoolize: copying file `m4/ltsugar.m4'<br>libtoolize: copying file `m4/ltversion.m4'<br>libtoolize: copying file `m4/lt~obsolete.m4'<br>Running aclocal -I m4 -I .  ...<br>Running autoheader...<br>Running automake --gnu  ...<br>Running autoconf ...<br>Running libgc/autogen.sh ...<br>Running libtoolize...<br>libtoolize: putting auxiliary files in `.'.<br>libtoolize: copying file `./ltmain.sh'<br>libtoolize: putting macros in AC_CONFIG_MACRO_DIR, `m4'.<br>libtoolize: copying file `m4/libtool.m4'<br>libtoolize: copying file `m4/ltoptions.m4'<br>libtoolize: copying file `m4/ltsugar.m4'<br>libtoolize: copying file `m4/ltversion.m4'<br>libtoolize: copying file `m4/lt~obsolete.m4'<br>Running aclocal  -Wnone ...<br>Running automake --gnu  ...<br>Makefile.am:32: error: Libtool library used but 'LIBTOOL' is undefined<br>Makefile.am:32:   The usual way to define 'LIBTOOL' is to add 'LT_INIT'<br>Makefile.am:32:   to 'configure.ac' and run 'aclocal' and 'autoconf' again.<br>Makefile.am:32:   If 'LT_INIT' is in 'configure.ac', make sure<br>Makefile.am:32:   its definition is in aclocal's search path.<br>**Error**: automake failed.<br>Done running libgc/autogen.sh ...<br>Running eglib/autogen.sh ...<br>Running libtoolize...<br>libtoolize: putting macros in AC_CONFIG_MACRO_DIR, `m4'.<br>libtoolize: copying file `m4/libtool.m4'<br>libtoolize: copying file `m4/ltoptions.m4'<br>libtoolize: copying file `m4/ltsugar.m4'<br>libtoolize: copying file `m4/ltversion.m4'<br>libtoolize: copying file `m4/lt~obsolete.m4'<br>Running aclocal -I m4  ...<br>Running autoheader...<br>Running automake --gnu  ...<br>Running autoconf ...<br>Skipping configure process.<br>Done running eglib/autogen.sh ...<br>Running ./configure --enable-maintainer-mode --enable-compile-warnings --prefix=/opt/Mono/mono-4.8.1.0/mono-arm --target=arm-rtems4.11 --host=x86_64-unknown-linux CC=/opt/rtems-4.11.1-release/4.11-tools/bin/arm-rtems4.11-gcc CFLAGS=-qrtems -B/opt/rtems-4.11.1-release/4.11-bsp/arm-rtems4.11/lib -B/opt/rtems-4.11.1-release/4.11-bsp/arm-rtems4.11/xilinx_zynq_zedboard/lib/ -I//opt/rtems-4.11.1-release/4.11-bsp/arm-rtems4.11/xilinx_zynq_zedboard/lib/include --specs bsp_specs -march=armv7-a -mthumb -mfpu=neon -mfloat-abi=hard -mtune=cortex-a9 ...<br>checking build system type... x86_64-unknown-linux-gnu<br>checking host system type... x86_64-unknown-linux-gnu<br>checking target system type... arm-unknown-rtems4.11<br>checking for a BSD-compatible install... /usr/bin/install -c<br>checking whether build environment is sane... yes<br>checking for x86_64-unknown-linux-strip... no<br>checking for strip... strip<br>checking for a thread-safe mkdir -p... /bin/mkdir -p<br>checking for gawk... no<br>checking for mawk... mawk<br>checking whether make sets $(MAKE)... yes<br>checking how to create a ustar tar archive... gnutar<br>checking whether to enable maintainer-specific portions of Makefiles... yes<br>checking whether ln -s works... yes<br>checking whether make supports nested variables... yes<br>checking host platform characteristics... ok<br>checking for x86_64-unknown-linux-gcc... /opt/rtems-4.11.1-release/4.11-tools/bin/arm-rtems4.11-gcc<br>checking for x86_64-unknown-linux-gcc... (cached) /opt/rtems-4.11.1-release/4.11-tools/bin/arm-rtems4.11-gcc<br>checking whether the C compiler works... yes<br>checking for C compiler default output file name... a.out<br>checking for suffix of executables... <br>checking whether we are cross compiling... yes<br>checking for suffix of object files... o<br>checking whether we are using the GNU C compiler... yes<br>checking whether /opt/rtems-4.11.1-release/4.11-tools/bin/arm-rtems4.11-gcc accepts -g... yes<br>checking for /opt/rtems-4.11.1-release/4.11-tools/bin/arm-rtems4.11-gcc option to accept ISO C89... none needed<br>checking for style of include used by make... GNU<br>checking dependency style of /opt/rtems-4.11.1-release/4.11-tools/bin/arm-rtems4.11-gcc... gcc3<br>checking for x86_64-unknown-linux-g++... no<br>checking for g++... g++<br>configure: WARNING: using cross tools not prefixed with host triplet<br>checking whether we are using the GNU C++ compiler... yes<br>checking whether g++ accepts -g... yes<br>checking dependency style of g++... gcc3<br>checking dependency style of /opt/rtems-4.11.1-release/4.11-tools/bin/arm-rtems4.11-gcc... gcc3<br>checking for gawk... (cached) mawk<br>checking whether /opt/rtems-4.11.1-release/4.11-tools/bin/arm-rtems4.11-gcc and cc understand -c and -o together... yes<br>checking how to run the C preprocessor... /opt/rtems-4.11.1-release/4.11-tools/bin/arm-rtems4.11-gcc -E<br>checking for grep that handles long lines and -e... /bin/grep<br>checking for egrep... /bin/grep -E<br>checking for ANSI C header files... yes<br>checking how to print strings... printf<br>checking for a sed that does not truncate output... /bin/sed<br>checking for fgrep... /bin/grep -F<br>checking for ld used by /opt/rtems-4.11.1-release/4.11-tools/bin/arm-rtems4.11-gcc... /opt/rtems-4.11.1-release/4.11-tools/arm-rtems4.11/bin/ld<br>checking if the linker (/opt/rtems-4.11.1-release/4.11-tools/arm-rtems4.11/bin/ld) is GNU ld... yes<br>checking for BSD- or MS-compatible name lister (nm)... /usr/bin/nm -B<br>checking the name lister (/usr/bin/nm -B) interface... BSD nm<br>checking the maximum length of command line arguments... 1572864<br>checking whether the shell understands some XSI constructs... yes<br>checking whether the shell understands "+="... yes<br>checking how to convert x86_64-unknown-linux-gnu file names to x86_64-unknown-linux-gnu format... func_convert_file_noop<br>checking how to convert x86_64-unknown-linux-gnu file names to toolchain format... func_convert_file_noop<br>checking for /opt/rtems-4.11.1-release/4.11-tools/arm-rtems4.11/bin/ld option to reload object files... -r<br>checking for x86_64-unknown-linux-objdump... objdump<br>checking how to recognize dependent libraries... pass_all<br>checking for x86_64-unknown-linux-dlltool... dlltool<br>checking how to associate runtime and link libraries... printf %s\n<br>checking for x86_64-unknown-linux-ar... no<br>checking for ar... ar<br>checking for archiver @FILE support... @<br>checking for x86_64-unknown-linux-strip... strip<br>checking for x86_64-unknown-linux-ranlib... no<br>checking for ranlib... ranlib<br>checking command to parse /usr/bin/nm -B output from /opt/rtems-4.11.1-release/4.11-tools/bin/arm-rtems4.11-gcc object... ok<br>checking for sysroot... no<br>checking for x86_64-unknown-linux-mt... no<br>checking for mt... mt<br>checking if mt is a manifest tool... no<br>checking for sys/types.h... yes<br>checking for sys/stat.h... yes<br>checking for stdlib.h... yes<br>checking for string.h... yes<br>checking for memory.h... yes<br>checking for strings.h... yes<br>checking for inttypes.h... yes<br>checking for stdint.h... yes<br>checking for unistd.h... yes<br>checking for dlfcn.h... yes<br>checking for objdir... .libs<br>checking if /opt/rtems-4.11.1-release/4.11-tools/bin/arm-rtems4.11-gcc supports -fno-rtti -fno-exceptions... no<br>checking for /opt/rtems-4.11.1-release/4.11-tools/bin/arm-rtems4.11-gcc option to produce PIC... -fPIC -DPIC<br>checking if /opt/rtems-4.11.1-release/4.11-tools/bin/arm-rtems4.11-gcc PIC flag -fPIC -DPIC works... yes<br>checking if /opt/rtems-4.11.1-release/4.11-tools/bin/arm-rtems4.11-gcc static flag -static works... yes<br>checking if /opt/rtems-4.11.1-release/4.11-tools/bin/arm-rtems4.11-gcc supports -c -o file.o... yes<br>checking if /opt/rtems-4.11.1-release/4.11-tools/bin/arm-rtems4.11-gcc supports -c -o file.o... (cached) yes<br>checking whether the /opt/rtems-4.11.1-release/4.11-tools/bin/arm-rtems4.11-gcc linker (/opt/rtems-4.11.1-release/4.11-tools/arm-rtems4.11/bin/ld -m elf_i386) supports shared libraries... no<br>checking dynamic linker characteristics... GNU/Linux ld.so<br>checking how to hardcode library paths into programs... unsupported<br>checking whether stripping libraries is possible... yes<br>checking if libtool supports shared libraries... no<br>checking whether to build shared libraries... no<br>checking whether to build static libraries... yes<br>checking how to run the C++ preprocessor... g++ -E<br>checking for ld used by g++... /opt/rtems-4.11.1-release/4.11-tools/arm-rtems4.11/bin/ld -m elf_i386<br>checking if the linker (/opt/rtems-4.11.1-release/4.11-tools/arm-rtems4.11/bin/ld -m elf_i386) is GNU ld... no<br>checking whether the g++ linker (/opt/rtems-4.11.1-release/4.11-tools/arm-rtems4.11/bin/ld -m elf_i386) supports shared libraries... yes<br>checking for g++ option to produce PIC... -fPIC -DPIC<br>checking if g++ PIC flag -fPIC -DPIC works... yes<br>checking if g++ static flag -static works... yes<br>checking if g++ supports -c -o file.o... yes<br>checking if g++ supports -c -o file.o... (cached) yes<br>checking whether the g++ linker (/opt/rtems-4.11.1-release/4.11-tools/arm-rtems4.11/bin/ld -m elf_i386) supports shared libraries... yes<br>checking dynamic linker characteristics... (cached) GNU/Linux ld.so<br>checking how to hardcode library paths into programs... unsupported<br>checking for bash... /bin/bash<br>checking if dolt supports this host... yes, replacing libtool<br>checking for ld used by /opt/rtems-4.11.1-release/4.11-tools/bin/arm-rtems4.11-gcc... (cached) /opt/rtems-4.11.1-release/4.11-tools/arm-rtems4.11/bin/ld<br>checking if the linker (/opt/rtems-4.11.1-release/4.11-tools/arm-rtems4.11/bin/ld) is GNU ld... (cached) yes<br>checking for ld used by GCC... /opt/rtems-4.11.1-release/4.11-tools/arm-rtems4.11/bin/ld<br>checking if the linker (/opt/rtems-4.11.1-release/4.11-tools/arm-rtems4.11/bin/ld) is GNU ld... yes<br>checking for shared library run path origin... done<br>checking for iconv... yes<br>checking for working iconv... guessing yes<br>checking for iconv declaration... <br>         extern size_t iconv (iconv_t cd, char * *inbuf, size_t *inbytesleft, char * *outbuf, size_t *outbytesleft);<br>checking sys/filio.h usability... yes<br>checking sys/filio.h presence... no<br>configure: WARNING: sys/filio.h: accepted by the compiler, rejected by the preprocessor!<br>configure: WARNING: sys/filio.h: proceeding with the compiler's result<br>checking for sys/filio.h... yes<br>checking sys/sockio.h usability... yes<br>checking sys/sockio.h presence... no<br>configure: WARNING: sys/sockio.h: accepted by the compiler, rejected by the preprocessor!<br>configure: WARNING: sys/sockio.h: proceeding with the compiler's result<br>checking for sys/sockio.h... yes<br>checking netdb.h usability... no<br>checking netdb.h presence... no<br>checking for netdb.h... no<br>checking utime.h usability... yes<br>checking utime.h presence... yes<br>checking for utime.h... yes<br>checking sys/utime.h usability... yes<br>checking sys/utime.h presence... yes<br>checking for sys/utime.h... yes<br>checking semaphore.h usability... yes<br>checking semaphore.h presence... yes<br>checking for semaphore.h... yes<br>checking sys/un.h usability... no<br>checking sys/un.h presence... no<br>checking for sys/un.h... no<br>checking linux/rtc.h usability... no<br>checking linux/rtc.h presence... no<br>checking for linux/rtc.h... no<br>checking sys/syscall.h usability... no<br>checking sys/syscall.h presence... no<br>checking for sys/syscall.h... no<br>checking sys/mkdev.h usability... no<br>checking sys/mkdev.h presence... no<br>checking for sys/mkdev.h... no<br>checking sys/uio.h usability... yes<br>checking sys/uio.h presence... no<br>configure: WARNING: sys/uio.h: accepted by the compiler, rejected by the preprocessor!<br>configure: WARNING: sys/uio.h: proceeding with the compiler's result<br>checking for sys/uio.h... yes<br>checking sys/param.h usability... yes<br>checking sys/param.h presence... yes<br>checking for sys/param.h... yes<br>checking sys/sysctl.h usability... no<br>checking sys/sysctl.h presence... no<br>checking for sys/sysctl.h... no<br>checking libproc.h usability... no<br>checking libproc.h presence... no<br>checking for libproc.h... no<br>checking sys/prctl.h usability... no<br>checking sys/prctl.h presence... no<br>checking for sys/prctl.h... no<br>checking for sys/param.h... (cached) yes<br>checking sys/socket.h usability... no<br>checking sys/socket.h presence... no<br>checking for sys/socket.h... no<br>checking sys/ipc.h usability... no<br>checking sys/ipc.h presence... no<br>checking for sys/ipc.h... no<br>checking sys/utsname.h usability... yes<br>checking sys/utsname.h presence... no<br>configure: WARNING: sys/utsname.h: accepted by the compiler, rejected by the preprocessor!<br>configure: WARNING: sys/utsname.h: proceeding with the compiler's result<br>checking for sys/utsname.h... yes<br>checking alloca.h usability... yes<br>checking alloca.h presence... yes<br>checking for alloca.h... yes<br>checking ucontext.h usability... no<br>checking ucontext.h presence... no<br>checking for ucontext.h... no<br>checking pwd.h usability... yes<br>checking pwd.h presence... yes<br>checking for pwd.h... yes<br>checking sys/select.h usability... no<br>checking sys/select.h presence... no<br>checking for sys/select.h... no<br>checking netinet/tcp.h usability... no<br>checking netinet/tcp.h presence... no<br>checking for netinet/tcp.h... no<br>checking netinet/in.h usability... no<br>checking netinet/in.h presence... no<br>checking for netinet/in.h... no<br>checking for unistd.h... (cached) yes<br>checking for sys/types.h... (cached) yes<br>checking link.h usability... yes<br>checking link.h presence... no<br>configure: WARNING: link.h: accepted by the compiler, rejected by the preprocessor!<br>configure: WARNING: link.h: proceeding with the compiler's result<br>checking for link.h... yes<br>checking asm/sigcontext.h usability... no<br>checking asm/sigcontext.h presence... no<br>checking for asm/sigcontext.h... no<br>checking sys/inotify.h usability... no<br>checking sys/inotify.h presence... no<br>checking for sys/inotify.h... no<br>checking arpa/inet.h usability... no<br>checking arpa/inet.h presence... no<br>checking for arpa/inet.h... no<br>checking complex.h usability... yes<br>checking complex.h presence... yes<br>checking for complex.h... yes<br>checking unwind.h usability... yes<br>checking unwind.h presence... yes<br>checking for unwind.h... yes<br>checking for linux/netlink.h... no<br>checking for linux/rtnetlink.h... no<br>checking for sys/user.h... no<br>checking linux/serial.h usability... no<br>checking linux/serial.h presence... no<br>checking for linux/serial.h... no<br>checking zlib.h usability... yes<br>checking zlib.h presence... no<br>configure: WARNING: zlib.h: accepted by the compiler, rejected by the preprocessor!<br>configure: WARNING: zlib.h: proceeding with the compiler's result<br>checking for zlib.h... yes<br>Using system zlib<br>checking elf.h usability... no<br>checking elf.h presence... no<br>checking for elf.h... no<br>checking poll.h usability... no<br>checking poll.h presence... no<br>checking for poll.h... no<br>checking sys/poll.h usability... yes<br>checking sys/poll.h presence... no<br>configure: WARNING: sys/poll.h: accepted by the compiler, rejected by the preprocessor!<br>configure: WARNING: sys/poll.h: proceeding with the compiler's result<br>checking for sys/poll.h... yes<br>checking sys/wait.h usability... yes<br>checking sys/wait.h presence... yes<br>checking for sys/wait.h... yes<br>checking grp.h usability... yes<br>checking grp.h presence... yes<br>checking for grp.h... yes<br>checking syslog.h usability... no<br>checking syslog.h presence... no<br>checking for syslog.h... no<br>checking wchar.h usability... yes<br>checking wchar.h presence... yes<br>checking for wchar.h... yes<br>checking ieeefp.h usability... yes<br>checking ieeefp.h presence... yes<br>checking for ieeefp.h... yes<br>checking for isinf... yes<br>checking for _finite... no<br>checking for _finite in math.h... no<br>checking linux/magic.h usability... no<br>checking linux/magic.h presence... no<br>checking for linux/magic.h... no<br>checking size of void *... 4<br>checking for clang... no<br>checking for -Wno-unused-but-set-variable option to gcc... yes<br>checking whether NLS is requested... profile_default<br>checking for msgfmt... /usr/bin/msgfmt<br>checking for gmsgfmt... /usr/bin/msgfmt<br>checking for xgettext... /usr/bin/xgettext<br>checking for msgmerge... /usr/bin/msgmerge<br>checking for pkg-config... /usr/bin/pkg-config<br>checking for -mno-tls-direct-seg-refs option to gcc... no<br>yes<br>checking for visibility __attribute__... yes<br>checking whether /opt/rtems-4.11.1-release/4.11-tools/bin/arm-rtems4.11-gcc supports zero length arrays... yes<br>checking nacl/nacl_dyncode.h usability... no<br>checking nacl/nacl_dyncode.h presence... no<br>checking for nacl/nacl_dyncode.h... no<br>checking signal.h usability... yes<br>checking signal.h presence... yes<br>checking for signal.h... yes<br>checking for sigaction... yes<br>checking for kill... yes<br>checking for signal... yes<br>checking for library containing clock_gettime... none required<br>checking for clock_nanosleep... no<br>checking for dlopen... yes<br>checking for preceeding underscore in symbols... (cached) no<br>checking for dlerror... yes<br>checking execinfo.h usability... no<br>checking execinfo.h presence... no<br>checking for execinfo.h... no<br>checking sys/auxv.h usability... no<br>checking sys/auxv.h presence... no<br>checking for sys/auxv.h... no<br>checking sys/resource.h usability... yes<br>checking sys/resource.h presence... yes<br>checking for sys/resource.h... yes<br>checking for getgrgid_r... yes<br>checking for getgrnam_r... yes<br>checking for getpwnam_r... yes<br>checking for getpwuid_r... yes<br>checking for getresuid... no<br>checking for setresuid... no<br>checking for kqueue... no<br>checking for backtrace_symbols... no<br>checking for mkstemp... yes<br>checking for mmap... yes<br>checking for madvise... no<br>checking for getrusage... yes<br>checking for getpriority... no<br>checking for setpriority... no<br>checking for dl_iterate_phdr... no<br>checking for dladdr... no<br>checking for sysconf... yes<br>checking for getrlimit... no<br>checking for prctl... no<br>checking for sched_getaffinity... no<br>checking for sched_setaffinity... no<br>checking for sched_getcpu... no<br>checking for sched_setaffinity from glibc < 2.3.4... yes<br>checking if off_t is 64 bits wide... ok<br>checking for socket in -lsocket... no<br>checking for MSG_NOSIGNAL... no<br>checking for IPPROTO_IP... no<br>checking for IPPROTO_IPV6... no<br>checking for IPPROTO_TCP... no<br>checking for SOL_IP... no<br>checking for SOL_IPV6... no<br>checking for SOL_TCP... no<br>checking for IP_PKTINFO... no<br>checking for IPV6_PKTINFO... no<br>checking for IP_DONTFRAG... no<br>checking for IP_DONTFRAGMENT... no<br>checking for IP_MTU_DISCOVER... no<br>checking for IP_PMTUDISC_DO... no<br>checking for struct ip_mreqn... no<br>checking for struct ip_mreq... no<br>checking for getaddrinfo... no<br>checking for gethostbyname2_r... no<br>checking for gethostbyname2... no<br>checking for gethostbyname... no<br>checking for getprotobyname... no<br>checking for getnameinfo... no<br>checking for inet_ntop... no<br>checking for gethostbyaddr... no<br>checking for gethostbyaddr in -lnsl... no<br>checking for inet_pton... no<br>checking for inet_aton... no<br>checking for main in -lpthread... no<br>checking pthread.h usability... yes<br>checking pthread.h presence... yes<br>checking for pthread.h... yes<br>checking pthread_np.h usability... no<br>checking pthread_np.h presence... no<br>checking for pthread_np.h... no<br>checking for pthread_mutex_timedlock... yes<br>checking for pthread_getattr_np... yes<br>checking for pthread_attr_get_np... no<br>checking for pthread_setname_np... no<br>checking for pthread_kill... yes<br>checking for PTHREAD_MUTEX_RECURSIVE... ok<br>checking for pthread_attr_setstacksize... yes<br>checking for pthread_attr_getstack... yes<br>checking for pthread_attr_getstacksize... yes<br>checking for pthread_get_stacksize_np... no<br>checking for pthread_get_stackaddr_np... no<br>checking for mincore... no<br>checking for working __thread... cross compiling<br>checking for working sigaltstack... cross compiling<br>checking for library containing sem_init... none required<br>checking for library containing shm_open... no<br>checking for shm_open... no<br>checking for tm_gmtoff in struct tm... no<br>checking for timezone variable... no<br>configure: error: unable to find a way to determine timezone<br></span></div><div><span style="color: rgb(0, 0, 0); background-color: rgba(0, 0, 0, 0);">===============================================</span></div><div><div>I googled the time zone variable, and still working on it.</div><div><br></div><div>But actually, I want to know whether I am doing it the right way? I mean, is this a right way to port Mono to RTEMS, just modifying some configuration options? I am still confusing about it. </div></div><div><br></div><hr style="width: 210px; height: 1px;" color="#b5c4df" size="1" align="left">
<div><span><div style="MARGIN: 10px; FONT-FAMILY: verdana; FONT-SIZE: 10pt"><div>Best wishes,</div><div>xuelin.tian@qkmtech.com</div></div></span></div>
<blockquote style="margin-top: 0px; margin-bottom: 0px; margin-left: 0.5em;"><div> </div><div style="border:none;border-top:solid #B5C4DF 1.0pt;padding:3.0pt 0cm 0cm 0cm"><div style="PADDING-RIGHT: 8px; PADDING-LEFT: 8px; FONT-SIZE: 12px;FONT-FAMILY:tahoma;COLOR:#000000; BACKGROUND: #efefef; PADDING-BOTTOM: 8px; PADDING-TOP: 8px"><div><b>From:</b> <a href="mailto:russ.haley@gmail.com">Russell Haley</a></div><div><b>Date:</b> 2017-07-21 10:42</div><div><b>To:</b> <a href="mailto:xuelin.tian@qkmtech.com">xuelin.tian@qkmtech.com</a></div><div><b>CC:</b> <a href="mailto:joel@rtems.org">Joel Sherrill</a>; <a href="mailto:users@rtems.org">users@rtems.org</a></div><div><b>Subject:</b> Re: Re: Has anyone tried to port Mono to RTEMS</div></div></div><div><div class="FoxDiv20170721110401434791"><div dir="ltr"><div class="gmail_extra"><br><div class="gmail_quote">On Thu, Jul 20, 2017 at 7:07 PM, <a href="mailto:xuelin.tian@qkmtech.com">xuelin.tian@qkmtech.com</a> <span dir="ltr"><<a href="mailto:xuelin.tian@qkmtech.com" target="_blank">xuelin.tian@qkmtech.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin: 0px 0px 0px 0.8ex; border-left-width: 1px; border-left-style: solid; border-left-color: rgb(204, 204, 204); padding-left: 1ex;"><div>
<div><span></span>I just followed the instructions from Mono, and did some changes obviously.</div><div>I did not use ScratchBox to cross-compile my Mono on ARM, just use arm-rtems4.11-gcc to cross-compile it. Is that right?</div><div>Do I need to modify the source code from Mono to port to RTEMS?</div>
</div></blockquote><div>Some context you really should provide:<br>- What platform are you building on?<br></div><div>- Where did you get the source files? (if git, are you building head? I have had many problems building mono from head)<br></div><div>- Without posting your complete build output there is no way to tell what is happening. <br><br></div><div>This is just a shot in the dark, but did you google Time Zone variable? Google says you need to set a TZ environment variable. <br></div><div><br></div><div>Russ<br></div><blockquote class="gmail_quote" style="margin: 0px 0px 0px 0.8ex; border-left-width: 1px; border-left-style: solid; border-left-color: rgb(204, 204, 204); padding-left: 1ex;"><div><div></div><hr style="width:210px;height:1px" color="#b5c4df" size="1" align="left">
<div><span><div style="margin:10px;font-family:verdana;font-size:10pt"><div>Best wishes,</div><div><a href="mailto:xuelin.tian@qkmtech.com" target="_blank">xuelin.tian@qkmtech.com</a></div></div></span></div>
<blockquote style="margin-top: 0px; margin-bottom: 0px; margin-left: 0.5em;"><div> </div><div style="border-width:1pt medium medium;border-style:solid none none;border-color:rgb(181,196,223) currentcolor currentcolor;padding:3pt 0cm 0cm"><div style="padding:8px;font-size:12px;font-family:tahoma;color:rgb(0,0,0);background:rgb(239,239,239) none repeat scroll 0% 0%"><div><b>From:</b> <a href="mailto:russ.haley@gmail.com" target="_blank">Russell Haley</a></div><div><b>Date:</b> 2017-07-21 00:16</div><div><div class="gmail-h5"><div><b>To:</b> <a href="mailto:xuelin.tian@qkmtech.com" target="_blank">xuelin.tian</a>; <a href="mailto:joel@rtems.org" target="_blank">Joel Sherrill</a></div><div><b>CC:</b> <a href="mailto:users@rtems.org" target="_blank">users</a></div><div><b>Subject:</b> Re: Has anyone tried to port Mono to RTEMS</div></div></div></div></div><div><div class="gmail-h5"><div><div class="gmail-m_6355668261996299745FoxDiv20170721100246834833">
                                                                                      <div style="width:100%;font-size:initial;font-family:Calibri,"Slate Pro",sans-serif,sans-serif;color:rgb(31,73,125);text-align:initial;background-color:rgb(255,255,255)">Did you get it to build natively?‎ What is your host. Build output would be helpful. </div><div style="width:100%;font-size:initial;font-family:Calibri,"Slate Pro",sans-serif,sans-serif;color:rgb(31,73,125);text-align:initial;background-color:rgb(255,255,255)"><br></div><div style="width:100%;font-size:initial;font-family:Calibri,"Slate Pro",sans-serif,sans-serif;color:rgb(31,73,125);text-align:initial;background-color:rgb(255,255,255)">Russ</div>                                                                                                                                     <div style="width:100%;font-size:initial;font-family:Calibri,"Slate Pro",sans-serif,sans-serif;color:rgb(31,73,125);text-align:initial;background-color:rgb(255,255,255)"><br style="display:initial"></div>                                                                                                                                                                                                   <div style="font-size:initial;font-family:Calibri,"Slate Pro",sans-serif,sans-serif;color:rgb(31,73,125);text-align:initial;background-color:rgb(255,255,255)">Sent from my BlackBerry 10 <wbr>smartphone on the Virgin <wbr>Mobile network.</div>                                                                                                                                                                                  <table style="background-color:white;border-spacing:0px" width="100%"> <tbody><tr><td colspan="2" style="font-size:initial;text-align:initial;background-color:rgb(255,255,255)">                           <div style="border-style:solid none none;border-top:1pt solid rgb(181,196,223);padding:3pt 0in 0in;font-family:Tahoma,"BB Alpha Sans","Slate Pro";font-size:10pt">  <div><b>From: </b><a href="mailto:xuelin.tian@qkmtech.com" target="_blank">xuelin.tian@qkmtech.com</a></div><div><b>Sent: </b>Thursday, July 20, 2017 5:53 AM</div><div><b>To: </b>Russell Haley; Joel Sherrill</div><div><b>Cc: </b><a href="mailto:users@rtems.org" target="_blank">users@rtems.org</a></div><div><b>Subject: </b>Re: Re: Has anyone tried to port Mono to RTEMS</div></div></td></tr></tbody></table><div style="border-style:solid none none;border-top:1pt solid rgb(186,188,209);font-size:initial;text-align:initial;background-color:rgb(255,255,255)"></div><br><div id="gmail-m_6355668261996299745_originalContent">
<div><span></span>I have been struck by it for like 2 days.</div><div>I want to cross-compile Mono for a test, and I enter: </div><div><br></div><div><span style="color:rgb(0,0,0);background-color:transparent"><b>./autogen.sh --prefix=/opt/<wbr>Mono/mono-4.8.1.0/mono-arm --<wbr>target=arm-rtems4.11 --host=<wbr>x86_64-unknown-linux CC=/opt/<wbr>rtems-4.11.1-release/4.11-<wbr>tools/bin/arm-rtems4.11-gcc <wbr>CFLAGS="-qrtems -B/opt/rtems-<wbr>4.11.1-release/4.11-bsp/arm-<wbr>rtems4.11/lib -B/opt/rtems-4.<wbr>11.1-release/4.11-bsp/arm-<wbr>rtems4.11/xilinx_zynq_<wbr>zedboard/lib/ -I//opt/rtems-4.<wbr>11.1-release/4.11-bsp/arm-<wbr>rtems4.11/xilinx_zynq_<wbr>zedboard/lib/include --specs <wbr>bsp_specs -march=armv7-a -<wbr>mthumb -mfpu=neon -mfloat-abi=<wbr>hard -mtune=cortex-a9"</b><br></span></div><div><span style="color:rgb(0,0,0);background-color:transparent"><br></span></div><div><span style="color:rgb(0,0,0);background-color:transparent">It goes well at first, then the error came up:</span></div><div><span style="color:rgb(0,0,0);background-color:transparent"><b>checking for timezone <wbr>variable... no<br>configure: error: unable to <wbr>find a way to determine <wbr>timezone</b><br></span></div><div><span style="color:rgb(0,0,0);background-color:transparent"><br></span></div><div><span style="color:rgb(0,0,0);background-color:transparent">I can not really understand the content from config.log</span></div><div><img src="cid:_Foxmail.1@cfa63317-b0a6-6d18-aa02-328e0ce1b041" border="0"></div><div><br></div><div>Can anyone help me with this? Thanks a lot</div>
<div><br></div><hr style="width:210px;height:1px" color="#b5c4df" size="1" align="left">
<div><span><div style="margin:10px;font-family:verdana;font-size:10pt"><div>Best wishes,</div><div><a href="mailto:xuelin.tian@qkmtech.com" target="_blank">xuelin.tian@qkmtech.com</a></div></div></span></div>
<blockquote style="margin-top: 0px; margin-bottom: 0px; margin-left: 0.5em;"><div> </div><div style="border-width:1pt medium medium;border-style:solid none none;border-color:rgb(181,196,223) currentcolor currentcolor;padding:3pt 0cm 0cm"><div style="padding:8px;font-size:12px;font-family:tahoma;color:rgb(0,0,0);background:rgb(239,239,239) none repeat scroll 0% 0%"><div><b>From:</b> <a href="mailto:russ.haley@gmail.com" target="_blank">Russell Haley</a></div><div><b>Date:</b> 2017-07-14 12:44</div><div><b>To:</b> <a href="mailto:xuelin.tian@qkmtech.com" target="_blank">xuelin.tian</a>; <a href="mailto:joel@rtems.org" target="_blank">Joel Sherrill</a></div><div><b>CC:</b> <a href="mailto:users@rtems.org" target="_blank">users</a></div><div><b>Subject:</b> Re: Has anyone tried to port Mono to RTEMS</div></div></div><div><div class="gmail-m_6355668261996299745FoxDiv20170720204531156386" style="background-color:rgb(255,255,255);line-height:initial">
                                                                                      <div style="width:100%;font-size:initial;font-family:Calibri,"Slate Pro",sans-serif,sans-serif;color:rgb(31,73,125);text-align:initial;background-color:rgb(255,255,255)">Thinking about it, Lua is designed to be statically linked into C applications and your scripts are loaded and executed by your application at runtime. This is how lua is plugged into many video games like world or warcraft and roblox. </div><div style="width:100%;font-size:initial;font-family:Calibri,"Slate Pro",sans-serif,sans-serif;color:rgb(31,73,125);text-align:initial;background-color:rgb(255,255,255)"><br></div><div style="width:100%;font-size:initial;font-family:Calibri,"Slate Pro",sans-serif,sans-serif;color:rgb(31,73,125);text-align:initial;background-color:rgb(255,255,255)">From my simplistic understanding of rtems (and everything I just said), that would be the way you would statically link lua into rtems?</div>                                                                                                                                     <div style="width:100%;font-size:initial;font-family:Calibri,"Slate Pro",sans-serif,sans-serif;color:rgb(31,73,125);text-align:initial;background-color:rgb(255,255,255)"><br></div><div style="width:100%;font-size:initial;font-family:Calibri,"Slate Pro",sans-serif,sans-serif;color:rgb(31,73,125);text-align:initial;background-color:rgb(255,255,255)">Russ</div><div style="width:100%;font-size:initial;font-family:Calibri,"Slate Pro",sans-serif,sans-serif;color:rgb(31,73,125);text-align:initial;background-color:rgb(255,255,255)"><br></div>                                                                                                                                                                                                   <div style="font-size:initial;font-family:Calibri,"Slate Pro",sans-serif,sans-serif;color:rgb(31,73,125);text-align:initial;background-color:rgb(255,255,255)">Sent from my BlackBerry 10 <wbr>smartphone on the Virgin <wbr>Mobile network.</div>                                                                                                                                                                                  <table style="background-color:white;border-spacing:0px" width="100%"> <tbody><tr><td colspan="2" style="font-size:initial;text-align:initial;background-color:rgb(255,255,255)">                           <div style="border-style:solid none none;border-top:1pt solid rgb(181,196,223);padding:3pt 0in 0in;font-family:Tahoma,"BB Alpha Sans","Slate Pro";font-size:10pt">  <div><b>From: </b><a href="mailto:xuelin.tian@qkmtech.com" target="_blank">xuelin.tian@qkmtech.com</a></div><div><b>Sent: </b>Thursday, July 13, 2017 9:03 PM</div><div><b>To: </b>Russell Haley; Joel Sherrill</div><div><b>Cc: </b><a href="mailto:users@rtems.org" target="_blank">users@rtems.org</a></div><div><b>Subject: </b>Re: Re: Has anyone tried to port Mono to RTEMS</div></div></td></tr></tbody></table><div style="border-style:solid none none;border-top:1pt solid rgb(186,188,209);font-size:initial;text-align:initial;background-color:rgb(255,255,255)"></div><br><div id="gmail-m_6355668261996299745_originalContent">
<div><span></span>OK, thanks a lot.</div><div>I will go through Lua today, to see if there is something interesting there.</div>
<div><br></div><hr style="width:210px;height:1px" color="#b5c4df" size="1" align="left">
<div><span><div style="margin:10px;font-family:verdana;font-size:10pt"><div>Best wishes,</div><div><a href="mailto:xuelin.tian@qkmtech.com" target="_blank">xuelin.tian@qkmtech.com</a></div></div></span></div>
<blockquote style="margin-top: 0px; margin-bottom: 0px; margin-left: 0.5em;"><div> </div><div style="border-width:1pt medium medium;border-style:solid none none;border-color:rgb(181,196,223) currentcolor currentcolor;padding:3pt 0cm 0cm"><div style="padding:8px;font-size:12px;font-family:tahoma;color:rgb(0,0,0);background:rgb(239,239,239) none repeat scroll 0% 0%"><div><b>From:</b> <a href="mailto:russ.haley@gmail.com" target="_blank">Russell Haley</a></div><div><b>Date:</b> 2017-07-14 11:57</div><div><b>To:</b> <a href="mailto:xuelin.tian@qkmtech.com" target="_blank">xuelin.tian</a>; <a href="mailto:joel@rtems.org" target="_blank">Joel Sherrill</a></div><div><b>CC:</b> <a href="mailto:users@rtems.org" target="_blank">users</a></div><div><b>Subject:</b> Re: Has anyone tried to port Mono to RTEMS</div></div></div><div><div class="gmail-m_6355668261996299745FoxDiv20170714115950519708" style="background-color:rgb(255,255,255);line-height:initial">
                                                                                      <div style="width:100%;font-size:initial;font-family:Calibri,"Slate Pro",sans-serif,sans-serif;color:rgb(31,73,125);text-align:initial;background-color:rgb(255,255,255)">Just my opinion on the 'or other vm' comment. </div><div style="width:100%;font-size:initial;font-family:Calibri,"Slate Pro",sans-serif,sans-serif;color:rgb(31,73,125);text-align:initial;background-color:rgb(255,255,255)"><br></div><div style="width:100%;font-size:initial;font-family:Calibri,"Slate Pro",sans-serif,sans-serif;color:rgb(31,73,125);text-align:initial;background-color:rgb(255,255,255)">If your requirement is not strictly mono, I highly suggest something small and simple like Lua. It's a a very efficient vm and is cross compatible with all major platforms. The only requirement for Lua is c99. </div><div style="width:100%;font-size:initial;font-family:Calibri,"Slate Pro",sans-serif,sans-serif;color:rgb(31,73,125);text-align:initial;background-color:rgb(255,255,255)"><br></div><div style="width:100%;font-size:initial;font-family:Calibri,"Slate Pro",sans-serif,sans-serif;color:rgb(31,73,125);text-align:initial;background-color:rgb(255,255,255)">The language is very simple and bare bones. You pick your tools from git or a repository manager called luarocks (<a href="http://luarocks.org" target="_blank">luarocks.org</a>). That's where the 'hard part' of Lua comes in. It's very hands on because you need to find or write almost everything you need. </div><div style="width:100%;font-size:initial;font-family:Calibri,"Slate Pro",sans-serif,sans-serif;color:rgb(31,73,125);text-align:initial;background-color:rgb(255,255,255)"><br></div><div style="width:100%;font-size:initial;font-family:Calibri,"Slate Pro",sans-serif,sans-serif;color:rgb(31,73,125);text-align:initial;background-color:rgb(255,255,255)">I am putting together a 'lightweight' IoT platform using Lua 5.3 and a very sophisticated polling library called cqueues. There is an http library called lua-http based on cqueues that contains a client and server implementation of most major http standards including http2 and websockets. The requirements for cqueues are a polling library such as epoll or kqueues (or even poll or select). I'm not sure how well that would plug into rtems. ‎At this point I'm cross compatible for most major Nixs' though. </div>                                                                                                                                     <div style="width:100%;font-size:initial;font-family:Calibri,"Slate Pro",sans-serif,sans-serif;color:rgb(31,73,125);text-align:initial;background-color:rgb(255,255,255)"><br></div><div style="width:100%;font-size:initial;font-family:Calibri,"Slate Pro",sans-serif,sans-serif;color:rgb(31,73,125);text-align:initial;background-color:rgb(255,255,255)">Nonetheless, the overhead of mono is not really worth it if you are doing simple things. ‎That's why I switched away from DotNet for my project. If you have code to port, or have DotNet developers, mono makes sense. </div><div style="width:100%;font-size:initial;font-family:Calibri,"Slate Pro",sans-serif,sans-serif;color:rgb(31,73,125);text-align:initial;background-color:rgb(255,255,255)"><br></div><div style="width:100%;font-size:initial;font-family:Calibri,"Slate Pro",sans-serif,sans-serif;color:rgb(31,73,125);text-align:initial;background-color:rgb(255,255,255)">‎Just my opinion. </div><div style="width:100%;font-size:initial;font-family:Calibri,"Slate Pro",sans-serif,sans-serif;color:rgb(31,73,125);text-align:initial;background-color:rgb(255,255,255)"><br></div><div style="width:100%;font-size:initial;font-family:Calibri,"Slate Pro",sans-serif,sans-serif;color:rgb(31,73,125);text-align:initial;background-color:rgb(255,255,255)">HTH</div><div style="width:100%;font-size:initial;font-family:Calibri,"Slate Pro",sans-serif,sans-serif;color:rgb(31,73,125);text-align:initial;background-color:rgb(255,255,255)">Russ</div><div style="width:100%;font-size:initial;font-family:Calibri,"Slate Pro",sans-serif,sans-serif;color:rgb(31,73,125);text-align:initial;background-color:rgb(255,255,255)"><br></div>                                                                                                                                                                                                   <div style="font-size:initial;font-family:Calibri,"Slate Pro",sans-serif,sans-serif;color:rgb(31,73,125);text-align:initial;background-color:rgb(255,255,255)">Sent from my BlackBerry 10 <wbr>smartphone on the Virgin <wbr>Mobile network.</div>                                                                                                                                                                                  <table style="background-color:white;border-spacing:0px" width="100%"> <tbody><tr><td colspan="2" style="font-size:initial;text-align:initial;background-color:rgb(255,255,255)">                           <div style="border-style:solid none none;border-top:1pt solid rgb(181,196,223);padding:3pt 0in 0in;font-family:Tahoma,"BB Alpha Sans","Slate Pro";font-size:10pt">  <div><b>From: </b><a href="mailto:xuelin.tian@qkmtech.com" target="_blank">xuelin.tian@qkmtech.com</a></div><div><b>Sent: </b>Thursday, July 13, 2017 8:38 PM</div><div><b>To: </b>Joel Sherrill; Russell Haley</div><div><b>Cc: </b><a href="mailto:users@rtems.org" target="_blank">users@rtems.org</a></div><div><b>Subject: </b>Re: Re: Has anyone tried to port Mono to RTEMS</div></div></td></tr></tbody></table><div style="border-style:solid none none;border-top:1pt solid rgb(186,188,209);font-size:initial;text-align:initial;background-color:rgb(255,255,255)"></div><br><div id="gmail-m_6355668261996299745_originalContent">
<div><span></span>Yes, I am trying to build it from source according to Russell.</div><div><br></div><div>As to .net core, I may not have a deep understanding of it. I think for now, Mono may be the best choice for me, since I need to make it (porting Mono or other VM to rtems) work in a few days. </div>
<div><br></div><hr style="width:210px;height:1px" color="#b5c4df" size="1" align="left">
<div><span><div style="margin:10px;font-family:verdana;font-size:10pt"><div>Best wishes,</div><div><a href="mailto:xuelin.tian@qkmtech.com" target="_blank">xuelin.tian@qkmtech.com</a></div></div></span></div>
<blockquote style="margin-top: 0px; margin-bottom: 0px; margin-left: 0.5em;"><div> </div><div style="border-width:1pt medium medium;border-style:solid none none;border-color:rgb(181,196,223) currentcolor currentcolor;padding:3pt 0cm 0cm"><div style="padding:8px;font-size:12px;font-family:tahoma;color:rgb(0,0,0);background:rgb(239,239,239) none repeat scroll 0% 0%"><div><b>From:</b> <a href="mailto:joel@rtems.org" target="_blank">Joel Sherrill</a></div><div><b>Date:</b> 2017-07-13 01:08</div><div><b>To:</b> <a href="mailto:russ.haley@gmail.com" target="_blank">Russell Haley</a></div><div><b>CC:</b> <a href="mailto:xuelin.tian@qkmtech.com" target="_blank">xuelin.tian@qkmtech.com</a>; <a href="mailto:users@rtems.org" target="_blank">users@rtems.org</a></div><div><b>Subject:</b> Re: Re: Has anyone tried to port Mono to RTEMS</div></div></div><div><div class="gmail-m_6355668261996299745FoxDiv20170714113148021310"><div dir="ltr">The reply from Russell is very good advice. Look forward when porting and<div>make sure you are porting something with a future.</div><div><br></div><div>For Mono, I did exactly what he outlined. I built native. I recall it using a </div><div>fairly normal configure script and I just added --target=XXX-rtems. I might</div><div>have added some CFLAGS but don't recall. </div><div><br></div><div>I focused on the run-time interpreter and ignored the JIT. The run-time</div><div>translated Mono calls into C library and POSIX calls. If there was a </div><div>compilation issue, I tried to fix it where ever it had to be fixed. Always being</div><div>open to adding something to either RTEMS or newlib if possible</div><div>and needed.</div><div><br></div><div>--joel</div></div><div class="gmail_extra"><br><div class="gmail_quote">On Wed, Jul 12, 2017 at 11:03 AM, Russell Haley <span dir="ltr"><<a href="mailto:russ.haley@gmail.com" target="_blank">russ.haley@gmail.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin: 0px 0px 0px 0.5em; border-left-width: 1px; border-left-style: solid; border-left-color: rgb(204, 204, 204); padding-left: 1ex;"><span>On Tue, Jul 11, 2017 at 9:31 PM, <a href="mailto:xuelin.tian@qkmtech.com" target="_blank">xuelin.tian@qkmtech.com</a><br>
<<a href="mailto:xuelin.tian@qkmtech.com" target="_blank">xuelin.tian@qkmtech.com</a>> wrote:<br>
> Dear Joel,<br>
> Recently, I continue to port Mono to RTEMS.<br>
> Porting consists of two parts, according to the Mono documents online, JIT<br>
> engine and OS support.<br>
> JIT part is already done, since I use ARM platform.<br>
> And I am confuesd about OS part and how to build Mono on RTEMS.<br>
> Could you recall any details about how to build Mono on RTEMS? Thank you.<br>
<br>
</span>I'm not sure that's quite right. There are really 3 parts: The<br>
application framework, the 'JIT' (Mono Runtime, or Common Language<br>
Runtime in Microsoft .Net) and the OS specific layer. The application<br>
framework and the JIT are common to all platforms. The OS specific<br>
parts are in the Mono Runtime where it translates the Interediate<br>
Language (IL) to machine specific code at ... er ... runtime. The Mono<br>
Runtime is being slowly replaced by the Roslyn compiler, which is open<br>
source from Microsoft (very very cool stuff).<br>
<br>
Building Mono requires a number of parts, including boot strapping the<br>
build and downloading binaries from nuget (last time I did it,<br>
anyway). I've never attempted to cross compile Mono. I would assume<br>
you would change the make file to point to a cross compiler such as<br>
arm-unknown-gcc (not sure about the RTEMS specifics).<br>
<br>
In my opinion the best bet is to pull the mono repository from GitHub<br>
and build it for your host platform first. Then you could look at<br>
modifying it to build on arm.<br>
<br>
That said, Mono is a dead/dying platform. Microsoft has bought<br>
Xamarian (Mono sponsor company). Now the Mono Dev Team is slowly<br>
porting everything over to the Microsoft .Net Core code. Once the<br>
majority of libraries are converted, they can then write Mono specific<br>
modules for legacy applications and then shuffle everyone over to<br>
DotNet Core. It might be wise to look at using the DotNet Core instead<br>
of Mono. There are a number of reasons to prefer the DotNet Core:<br>
<br>
- Designed to be small and use a package manager to import required<br>
external libraries. This was done with embedded systems in mind.<br>
- Better interpreter: the new interpreters (Rosylin and the other that<br>
I don't remember the name of) are very efficient compared to the Mono<br>
mc.<br>
- More efficient runtime. The Mono Runtime is known to be slow.<br>
<br>
 Here would be a good place to start with the DotNet Core as they have<br>
nightly arm builds.<br>
<br>
<a href="https://stevedesmond.ca/blog/net-core-on-arm" rel="noreferrer" target="_blank">https://stevedesmond.ca/blog/n<wbr>et-core-on-arm</a><br>
<br>
<br>
HTH,<br>
<br>
Russ<br>
<div class="gmail-m_6355668261996299745HOEnZb"><div class="gmail-m_6355668261996299745h5"><br>
> ______________________________<wbr>__<br>
> Best wishes,<br>
> <a href="mailto:xuelin.tian@qkmtech.com" target="_blank">xuelin.tian@qkmtech.com</a><br>
><br>
><br>
> From: Joel Sherrill<br>
> Date: 2017-05-24 20:19<br>
> To: xuelin.tian<br>
> CC: <a href="mailto:rtems-users@rtems.org" target="_blank">rtems-users@rtems.org</a><br>
> Subject: Re: Has anyone tried to port Mono to RTEMS<br>
><br>
><br>
> On May 23, 2017 8:58 PM, "<a href="mailto:xuelin.tian@qkmtech.com" target="_blank">xuelin.tian@qkmtech.com</a>" <<a href="mailto:xuelin.tian@qkmtech.com" target="_blank">xuelin.tian@qkmtech.com</a>><br>
> wrote:<br>
><br>
> Dear all,<br>
> Is that possible to port Mono to RTEMS? Has anyone tried this before?<br>
> As I notice that there is an open project in RTEMS projects.<br>
><br>
><br>
> Sometime ago, I was asked to provide an estimate for this. It had to be<br>
> between five and ten years ago because we were at the old office but after<br>
> we had done a few years of GSoC. I did enough work preparing the estimate<br>
> where I had the code building without too much effort. I saw the challenge<br>
> as getting the test suite running since you would have to create a test<br>
> harness and build/assembly helper that packaged the interpreted code with<br>
> the interpreter in order to run it. At that time, I envisioned having to<br>
> create a base image and a filesystem image per test.<br>
><br>
> Our POSIX was good enough then to avoid much trouble. It should only be<br>
> easier now since the POSIX support has improved.<br>
><br>
> There were a lot of Mono tests and I expected most to pass quickly. But<br>
> there was no way to know how many issues would be encountered and how many<br>
> root causes there would be. I expected to fix one or two things and then run<br>
> all the tests. That was where I expected time to be consumed.<br>
><br>
> FWIW I recall the GSoC date part because they thought we could magically get<br>
> students to do testing for free on a schedule. :)<br>
><br>
> I hope that helps. It is feasible but the key is testing.<br>
><br>
> --joel<br>
><br>
><br>
> ______________________________<wbr>__<br>
> Best wishes,<br>
> <a href="mailto:xuelin.tian@qkmtech.com" target="_blank">xuelin.tian@qkmtech.com</a><br>
><br>
> ______________________________<wbr>_________________<br>
> users mailing list<br>
> <a href="mailto:users@rtems.org" target="_blank">users@rtems.org</a><br>
> <a href="http://lists.rtems.org/mailman/listinfo/users" rel="noreferrer" target="_blank">http://lists.rtems.org/mailman<wbr>/listinfo/users</a><br>
><br>
><br>
><br>
> ______________________________<wbr>_________________<br>
> users mailing list<br>
> <a href="mailto:users@rtems.org" target="_blank">users@rtems.org</a><br>
> <a href="http://lists.rtems.org/mailman/listinfo/users" rel="noreferrer" target="_blank">http://lists.rtems.org/mailman<wbr>/listinfo/users</a><br>
</div></div></blockquote></div><br></div>
</div></div></blockquote>
<br></div>
</div></div></blockquote>
<br></div>
</div></div></blockquote>
<br></div></div></div></div></div></blockquote>
</div></blockquote></div><br></div></div>
</div></div></blockquote>
<br><!--end of _originalContent --></div></body></html>