Difference between revisions of "DESK-MX6-L/Development/Hello word example"

From DAVE Developer's Wiki
Jump to: navigation, search
(Setting the cross-compiler)
 
(5 intermediate revisions by 2 users not shown)
Line 3: Line 3:
 
!colspan="4" style="width:100%; text-align:left"; border-bottom:solid 2px #ededed"|History
 
!colspan="4" style="width:100%; text-align:left"; border-bottom:solid 2px #ededed"|History
 
|-  
 
|-  
!style="border-left:solid 2px #73B2C7; border-right:solid 2px #73B2C7;border-top:solid 2px #73B2C7; border-bottom:solid 2px #73B2C7; background-color:#73B2C7; padding:5px; color:white"|Version
 
 
!style="border-left:solid 2px #73B2C7; border-right:solid 2px #73B2C7;border-top:solid 2px #73B2C7; border-bottom:solid 2px #73B2C7; background-color:#73B2C7; padding:5px; color:white"|Issue Date
 
!style="border-left:solid 2px #73B2C7; border-right:solid 2px #73B2C7;border-top:solid 2px #73B2C7; border-bottom:solid 2px #73B2C7; background-color:#73B2C7; padding:5px; color:white"|Issue Date
 
!style="border-left:solid 2px #73B2C7; border-right:solid 2px #73B2C7;border-top:solid 2px #73B2C7; border-bottom:solid 2px #73B2C7; background-color:#73B2C7; padding:5px; color:white"|Notes
 
!style="border-left:solid 2px #73B2C7; border-right:solid 2px #73B2C7;border-top:solid 2px #73B2C7; border-bottom:solid 2px #73B2C7; background-color:#73B2C7; padding:5px; color:white"|Notes
 
|-
 
|-
|style="border-left:solid 2px #73B2C7; border-right:solid 2px #73B2C7;border-top:solid 2px #73B2C7; border-bottom:solid 2px #73B2C7; background-color:#edf8fb; padding:5px; color:#000000"|1.0.0
+
| style="border-left:solid 2px #73B2C7; border-right:solid 2px #73B2C7;border-top:solid 2px #73B2C7; border-bottom:solid 2px #73B2C7; background-color:#edf8fb; padding:5px; color:#000000" |{{oldid|16990|2021/07/21}}
|style="border-left:solid 2px #73B2C7; border-right:solid 2px #73B2C7;border-top:solid 2px #73B2C7; border-bottom:solid 2px #73B2C7; background-color:#edf8fb; padding:5px; color:#000000"|May 2021
+
| style="border-left:solid 2px #73B2C7; border-right:solid 2px #73B2C7;border-top:solid 2px #73B2C7; border-bottom:solid 2px #73B2C7; background-color:#edf8fb; padding:5px; color:#000000" |First DESK release
|style="border-left:solid 2px #73B2C7; border-right:solid 2px #73B2C7;border-top:solid 2px #73B2C7; border-bottom:solid 2px #73B2C7; background-color:#edf8fb; padding:5px; color:#000000"|First DESK release
+
|-
 +
! style="border-left:solid 2px #73B2C7; border-right:solid 2px #73B2C7;border-top:solid 2px #73B2C7; border-bottom:solid 2px #73B2C7; background-color:#ededed; padding:5px; color:#000000" |2023/04/07
 +
! style="border-left:solid 2px #73B2C7; border-right:solid 2px #73B2C7;border-top:solid 2px #73B2C7; border-bottom:solid 2px #73B2C7; background-color:#ededed; padding:5px; color:#000000" |DESK-MX6-L 4.0.0 release
 +
|-
 
|}
 
|}
 
<section end=History/>
 
<section end=History/>
Line 41: Line 43:
 
* configure the build environment
 
* configure the build environment
 
<pre class="workstation-terminal">
 
<pre class="workstation-terminal">
dvdk@vagrant:~/myproject$ source ~/desk-mx-l/desk-mx6-l-1.0.0_env.sh  
+
dvdk@vagrant:~/myproject$ source ~/desk-mx-l/desk-mx6-l-4.0.0_env.sh  
 
</pre>
 
</pre>
  
Line 47: Line 49:
 
<pre class="workstation-terminal">
 
<pre class="workstation-terminal">
 
dvdk@vagrant:~/myproject$ echo $CC
 
dvdk@vagrant:~/myproject$ echo $CC
arm-poky-linux-gnueabi-gcc -march=armv7-a -mfpu=neon -mfloat-abi=hard -mcpu=cortex-a9 --sysroot=/home/dvdk/desk-mx-l/sdk/desk-mx6-l-1.0.0-toolchain/sysroots/cortexa9hf-neon-poky-linux-gnueabi
+
arm-poky-linux-gnueabi-gcc -mthumb -mfpu=neon -mfloat-abi=hard -mcpu=cortex-a9 -fstack-protector-strong -O2 -D_FORTIFY_SOURCE=2 -Wformat -Wformat-security -Werror=format-security --sysroot=/home/dvdk/desk-mx-l/sdk/desk-mx6-l-4.0.0-toolchain/sysroots/cortexa9t2hf-neon-poky-linux-gnueabi
 
dvdk@vagrant:~/myproject$  
 
dvdk@vagrant:~/myproject$  
 
</pre>
 
</pre>
Line 55: Line 57:
 
dvdk@vagrant:~/myproject$ $CC hello.c -o hello
 
dvdk@vagrant:~/myproject$ $CC hello.c -o hello
 
dvdk@vagrant:~/myproject$ file hello
 
dvdk@vagrant:~/myproject$ file hello
hello: ELF 32-bit LSB executable, ARM, EABI5 version 1 (SYSV), dynamically linked, interpreter /lib/ld-linux-armhf.so.3, for GNU/Linux 3.2.0, BuildID[sha1]=212bc8245d6274bb4ed675b71128b0e835870fab, not stripped
+
hello: ELF 32-bit LSB pie executable, ARM, EABI5 version 1 (SYSV), dynamically linked, interpreter /lib/ld-linux-armhf.so.3, BuildID[sha1]=cca65e0cfb17eb97c0aca03d1222d4db656bda9f, for GNU/Linux 3.2.0, with debug_info, not stripped
 
dvdk@vagrant:~/myproject$  
 
dvdk@vagrant:~/myproject$  
 
</pre>
 
</pre>
Line 61: Line 63:
 
=== Running the example on the target ===
 
=== Running the example on the target ===
  
Now it is enough to copy the object file in the <code>/home/root</code> rfs directory and [[AXEL_Lite_SOM/DESK-MX6-L/General/Booting_from_NFS | boot from nfs...]]
+
Now it is enough to copy the object file in the <code>/home/root</code> rfs directory and [[DESK-MX6-L/General/Booting_from_NFS | boot from nfs...]]
  
 
<pre class="workstation-terminal">
 
<pre class="workstation-terminal">
 
dvdk@vagrant:~/myproject$ sudo cp hello /home/dvdk/desk-mx-l/rfs/desk-mx6-l/home/root/
 
dvdk@vagrant:~/myproject$ sudo cp hello /home/dvdk/desk-mx-l/rfs/desk-mx6-l/home/root/
dvdk@vagrant:~/myproject$ sudo ls -la /home/dvdk/desk-mx-l/rfs/desk-mx6-l/home/root/
+
dvdk@vagrant:~/myproject$ sudo ls -la /home/dvdk/desk-mx-l/rfs/desk-mx6-l/home/root
total 32
+
total 28
drwx------ 2 root root  4096 Jun 8 12:36 .
+
drwx------ 3 root root  4096 Apr 7 16:02 .
drwxr-xr-x 3 root root  4096 Jan 28 23:54 ..
+
drwxr-xr-x 4 root root  4096 Mar  9  2018 ..
-rwxr-xr-x 1 root root 16432 Jun 8 12:36 hello
+
-rwxr-xr-x 1 root root 12180 Apr 7 16:02 hello
-rw-r--r-- 1 root root  1011 Nov 25 2020 .profile
+
drwxr-xr-x 6 root root  4096 Mar  9  2018 .nxp-demo-experience
 +
-rw-r--r-- 1 root root  1011 Mar  9 2018 .profile
 
dvdk@vagrant:~/myproject$  
 
dvdk@vagrant:~/myproject$  
 
</pre>
 
</pre>
Line 80: Line 83:
 
...
 
...
 
...
 
...
[  OK  ] Started Terminate Psplash Boot Screen.
+
[  OK  ] Started Xinetd A Powerful Replacement For Inetd.
[  OK  ] Started /etc/rc.local Compatibility.
+
[  OK  ] Started Avahi mDNS/DNS-SD Stack.
        Starting Hostname Service...
+
[  OK  ] Started Target Communication Framework agent.
        Starting WPA supplicant...
+
[  OK  ] Reached target Multi-User System.
[  OK  ] Started Serial Getty on ttymxc2.
+
        Starting Record Runlevel Change in UTMP...
[  OK  ] Started Getty on tty1.
+
[  OK  ] Finished Record Runlevel Change in UTMP.
[  OK  ] Started WPA supplicant.
 
[  OK  ] Started Hostname Service.
 
  
NXP i.MX Release Distro 4.14-sumo desk-mx6 ttymxc2
+
NXP i.MX Release Distro 5.15-kirkstone desk-mx6 ttymxc2
  
 
desk-mx6 login: root
 
desk-mx6 login: root
 
root@desk-mx6:~# ls -la
 
root@desk-mx6:~# ls -la
total 32
+
total 24
drwx------ 2 root root  4096 Jun  8  2021 .
+
drwx------ 2 root root  4096 Apr 28 22:23 .
drwxr-xr-x 3 root root  4096 Jan 28 2021 ..
+
drwxr-xr-x 3 root root  4096 Mar  9 2018 ..
-rw-r--r-- 1 root root 1011 Nov 25  2020 .profile
+
-rw------- 1 root root   475 Apr 28 18:01 .bash_history
-rwxr-xr-x 1 root root 16432 Jun  8  2021 hello
+
-rwxr-xr-x 1 root root 12180 Apr 28 22:23 hello
 
root@desk-mx6:~# ./hello
 
root@desk-mx6:~# ./hello
 
Hello, World!
 
Hello, World!

Latest revision as of 16:55, 8 January 2024

History
Issue Date Notes

2021/07/21

First DESK release
2023/04/07 DESK-MX6-L 4.0.0 release



Hello word example[edit | edit source]

Here below an example on C code displaying the classic Hello World! message on the target serial console.

This example shows how to use the arm cross-compiler using the environment configured for this purpose

Setting the cross-compiler[edit | edit source]

It is assumed that the development environment has been set up properly as described here.

  • start the Linux development VM and login into the system
  • open a terminal window and cd into your source code directory
dvdk@vagrant:~$ mkdir myproject
dvdk@vagrant:~$ cd myproject/
dvdk@vagrant:~/myproject$ vi hello.c
dvdk@vagrant:~/myproject$ cat hello.c
#include <stdio.h>

int main(){
	printf("Hello, World!\n");
	return 0;
}
  • configure the build environment
dvdk@vagrant:~/myproject$ source ~/desk-mx-l/desk-mx6-l-4.0.0_env.sh 
  • as you can see here below, the $CC environment variable has been properly configured for using the SDK sysroot parameter:
dvdk@vagrant:~/myproject$ echo $CC
arm-poky-linux-gnueabi-gcc -mthumb -mfpu=neon -mfloat-abi=hard -mcpu=cortex-a9 -fstack-protector-strong -O2 -D_FORTIFY_SOURCE=2 -Wformat -Wformat-security -Werror=format-security --sysroot=/home/dvdk/desk-mx-l/sdk/desk-mx6-l-4.0.0-toolchain/sysroots/cortexa9t2hf-neon-poky-linux-gnueabi
dvdk@vagrant:~/myproject$ 
  • invoke the cross-compiler for compiling your source code example: the object file obtained, is a proper ELF 32-bit for the target microprocessor
dvdk@vagrant:~/myproject$ $CC hello.c -o hello
dvdk@vagrant:~/myproject$ file hello
hello: ELF 32-bit LSB pie executable, ARM, EABI5 version 1 (SYSV), dynamically linked, interpreter /lib/ld-linux-armhf.so.3, BuildID[sha1]=cca65e0cfb17eb97c0aca03d1222d4db656bda9f, for GNU/Linux 3.2.0, with debug_info, not stripped
dvdk@vagrant:~/myproject$ 

Running the example on the target[edit | edit source]

Now it is enough to copy the object file in the /home/root rfs directory and boot from nfs...

dvdk@vagrant:~/myproject$ sudo cp hello /home/dvdk/desk-mx-l/rfs/desk-mx6-l/home/root/
dvdk@vagrant:~/myproject$ sudo ls -la /home/dvdk/desk-mx-l/rfs/desk-mx6-l/home/root
total 28
drwx------ 3 root root  4096 Apr  7 16:02 .
drwxr-xr-x 4 root root  4096 Mar  9  2018 ..
-rwxr-xr-x 1 root root 12180 Apr  7 16:02 hello
drwxr-xr-x 6 root root  4096 Mar  9  2018 .nxp-demo-experience
-rw-r--r-- 1 root root  1011 Mar  9  2018 .profile
dvdk@vagrant:~/myproject$ 

on the target:

...
...
...
[  OK  ] Started Xinetd A Powerful Replacement For Inetd.
[  OK  ] Started Avahi mDNS/DNS-SD Stack.
[  OK  ] Started Target Communication Framework agent.
[  OK  ] Reached target Multi-User System.
         Starting Record Runlevel Change in UTMP...
[  OK  ] Finished Record Runlevel Change in UTMP.

NXP i.MX Release Distro 5.15-kirkstone desk-mx6 ttymxc2

desk-mx6 login: root
root@desk-mx6:~# ls -la
total 24
drwx------ 2 root root  4096 Apr 28 22:23 .
drwxr-xr-x 3 root root  4096 Mar  9  2018 ..
-rw------- 1 root root   475 Apr 28 18:01 .bash_history
-rwxr-xr-x 1 root root 12180 Apr 28 22:23 hello
root@desk-mx6:~# ./hello
Hello, World!
root@desk-mx6:~#