Jump to content

Building .so on target: Difference between revisions

From LabVIEW Wiki
mNo edit summary
m Add additional categories
 
(2 intermediate revisions by 2 users not shown)
Line 1: Line 1:
{{stub}}{{wikify}}
== Build .so On Target ==
== Build .so On Target ==
The LabVIEW run-time engine on the target (BBB/RPI) runs inside a chroot, which is a Linux construct that is similar to a virtual machine. This allows the LV run-time to be installed and run safely on many different Linux operating systems. Shared objects must be built to run inside the chroot to be accessible from LabVIEW. The easiest way to ensure the shared object is built correctly is to build it inside the chroot on the target.
The LabVIEW run-time engine on the target (BBB/RPI) runs inside a chroot, which is a Linux construct that is similar to a virtual machine. This allows the LV run-time to be installed and run safely on many different Linux operating systems. Shared objects must be built to run inside the chroot to be accessible from LabVIEW. The easiest way to ensure the shared object is built correctly is to build it inside the chroot on the target.
Line 9: Line 10:
''Note that all of the following commands until exiting the chroot must be run inside the chroot or they will fail.''
''Note that all of the following commands until exiting the chroot must be run inside the chroot or they will fail.''
3. Install the build tools:
3. Install the build tools:
* sudo opkg update
* opkg update
* sudo opkg install packagegroup-core-buildessential
* opkg install packagegroup-core-buildessential


4. Optionally install git and gdb:
4. Optionally install git and gdb:
* sudo opkg install git
* opkg install git
* sudo opkg install gdb
* opkg install gdb


5. Build the .so
5. If building updated versions of the Linx target libraries, install the additional development dependencies:
* opkg install --force-depends libc6-dev
* opkg install --force-depends libgcc-s-dev
* opkg install libstdc++-staticdev
 
6. Build the .so


The actual process of building the .so will vary based on the project/source. There are many good tutorials for building shared objects on Linux available online.
The actual process of building the .so will vary based on the project/source. There are many good tutorials for building shared objects on Linux available online.
Line 33: Line 39:
=== Debugging ===
=== Debugging ===
The .so will be loaded into memory the first time it is called using the CLFN in LabVIEW. To debug the .so attach to it using GDB before running the a VI.
The .so will be loaded into memory the first time it is called using the CLFN in LabVIEW. To debug the .so attach to it using GDB before running the a VI.
[[Category:LabVIEW for Linux]]
[[Category:BeagleBoard]]
[[Category:Raspberry Pi]]

Latest revision as of 17:01, 6 August 2024

Build .so On Target

The LabVIEW run-time engine on the target (BBB/RPI) runs inside a chroot, which is a Linux construct that is similar to a virtual machine. This allows the LV run-time to be installed and run safely on many different Linux operating systems. Shared objects must be built to run inside the chroot to be accessible from LabVIEW. The easiest way to ensure the shared object is built correctly is to build it inside the chroot on the target.

1. SSH into the target as a user with root privileges.

2. Run the following command to enter the chroot:

  • sudo schroot --run-session -c lv

Note that all of the following commands until exiting the chroot must be run inside the chroot or they will fail. 3. Install the build tools:

  • opkg update
  • opkg install packagegroup-core-buildessential

4. Optionally install git and gdb:

  • opkg install git
  • opkg install gdb

5. If building updated versions of the Linx target libraries, install the additional development dependencies:

  • opkg install --force-depends libc6-dev
  • opkg install --force-depends libgcc-s-dev
  • opkg install libstdc++-staticdev

6. Build the .so

The actual process of building the .so will vary based on the project/source. There are many good tutorials for building shared objects on Linux available online.

6. Copy the .so to /usr/lib.
Note that this is the /usr/lib directory inside the chroot. Outside of the chroot this directory is /srv/chroot/labview/usr/lib.

7. Call the .so from LabVIEW using the Call Library Function Node
Since /usr/lib is in the LabVIEW search path simply specify the .so name under Library name or path. For example 'myfirstobject.so'.
Under Thread choose Run in any thread to allow the .so to run in any thread rather than just the main thread.

8. Exit the chroot

  • exit


Debugging

The .so will be loaded into memory the first time it is called using the CLFN in LabVIEW. To debug the .so attach to it using GDB before running the a VI.