Difference between revisions of "ROS2"
From ElphelWiki
(Created page with "==GitHub== https://github.com/bmwcarit/meta-ros.git ==ROS1== * Won't build ==ROS2== * Add path to bblayers.conf * Add to "IMAGE_INSTALL_append" of core-image-elphel393.bb:...") |
(→ROS1) |
||
(19 intermediate revisions by the same user not shown) | |||
Line 1: | Line 1: | ||
− | ==GitHub== | + | ==<font color='blue'>GitHub</font>== |
https://github.com/bmwcarit/meta-ros.git | https://github.com/bmwcarit/meta-ros.git | ||
+ | ==<font color='blue'>ROS2</font>== | ||
− | == | + | ===Build=== |
− | |||
− | |||
− | |||
* Add path to bblayers.conf | * Add path to bblayers.conf | ||
* Add to "IMAGE_INSTALL_append" of core-image-elphel393.bb: | * Add to "IMAGE_INSTALL_append" of core-image-elphel393.bb: | ||
Line 13: | Line 11: | ||
ros2msg \ | ros2msg \ | ||
ros2run \ | ros2run \ | ||
+ | |||
+ | <font color='green'>'''Notes:''' | ||
+ | * Is this a required minimum? | ||
+ | * '''ROS_USE_PYTHON3 = "yes"''' no effect? It already uses python3?</font> | ||
+ | ===Work=== | ||
+ | ====1. Test Talker and Listener==== | ||
+ | * SSH session 1: | ||
+ | root@elphel393:~# export AMENT_PREFIX_PATH=/usr | ||
+ | root@elphel393:~# ros2 run demo_nodes_cpp talker | ||
+ | * SSH session 2: | ||
+ | root@elphel393:~# export AMENT_PREFIX_PATH=/usr | ||
+ | root@elphel393:~# ros2 run demo_nodes_cpp listener | ||
+ | |||
+ | <font color='green'>'''Notes:'''</font> | ||
+ | * <font color='green'>If AMENT_PREFIX_PATH is not set then:</font> | ||
+ | <font size='1'>Traceback (most recent call last): | ||
+ | File "/usr/bin/ros2", line 11, in <module> | ||
+ | load_entry_point('ros2cli==0.4.0', 'console_scripts', 'ros2')() | ||
+ | File "/usr/lib/python3.5/site-packages/ros2cli/cli.py", line 64, in main | ||
+ | rc = extension.main(parser=parser, args=args) | ||
+ | File "/usr/lib/python3.5/site-packages/ros2run/command/run.py", line 59, in main | ||
+ | executable_name=args.executable_name) | ||
+ | File "/usr/lib/python3.5/site-packages/ros2run/api/__init__.py", line 30, in get_executable_path | ||
+ | paths = get_executable_paths(package_name=package_name) | ||
+ | File "/usr/lib/python3.5/site-packages/ros2pkg/api/__init__.py", line 41, in get_executable_paths | ||
+ | prefix_path = get_prefix_path(package_name) | ||
+ | File "/usr/lib/python3.5/site-packages/ros2pkg/api/__init__.py", line 34, in get_prefix_path | ||
+ | prefix_path = get_package_prefix(package_name) | ||
+ | File "/usr/lib/python3.5/site-packages/ament_index_python/packages.py", line 49, in get_package_prefix | ||
+ | content, package_prefix = get_resource('packages', package_name) | ||
+ | File "/usr/lib/python3.5/site-packages/ament_index_python/resources.py", line 37, in get_resource | ||
+ | for path in get_search_paths(): | ||
+ | File "/usr/lib/python3.5/site-packages/ament_index_python/search_paths.py", line 30, in get_search_paths | ||
+ | "Environment variable '{}' is not set or empty".format(AMENT_PREFIX_PATH_ENV_VAR)) | ||
+ | <font color='red'>'''OSError: Environment variable 'AMENT_PREFIX_PATH' is not set or empty'''</font></font> | ||
+ | |||
+ | ====2. Available packages==== | ||
+ | * SSH session: | ||
+ | root@elphel393:~# export AMENT_PREFIX_PATH=/usr | ||
+ | root@elphel393:~# ros2 pkg list | ||
+ | <font size='1'>builtin_interfaces | ||
+ | demo_nodes_cpp | ||
+ | example_interfaces | ||
+ | geometry_msgs | ||
+ | rcl | ||
+ | rcl_interfaces | ||
+ | rclcpp | ||
+ | rclpy | ||
+ | rcutils | ||
+ | rmw | ||
+ | rmw_fastrtps_cpp | ||
+ | rosidl_cmake | ||
+ | rosidl_generator_c | ||
+ | rosidl_generator_cpp | ||
+ | rosidl_parser | ||
+ | rosidl_typesupport_interface | ||
+ | rosidl_typesupport_introspection_c | ||
+ | rosidl_typesupport_introspection_cpp | ||
+ | sensor_msgs</font> | ||
+ | |||
+ | ==<font color='blue'>ROS1</font>== | ||
+ | |||
+ | ===Build=== | ||
+ | <font color='red'>'''Won't build'''</font> | ||
+ | <font size='1'>Build Configuration: | ||
+ | BB_VERSION = "1.37.0" | ||
+ | BUILD_SYS = "x86_64-linux" | ||
+ | NATIVELSBSTRING = "universal" | ||
+ | TARGET_SYS = "arm-poky-linux-gnueabi" | ||
+ | MACHINE = "elphel393" | ||
+ | DISTRO = "poky" | ||
+ | DISTRO_VERSION = "2.4+snapshot-20181204" | ||
+ | TUNE_FEATURES = "arm armv7a vfp neon cortexa9" | ||
+ | TARGET_FPU = "softfp" | ||
+ | meta | ||
+ | meta-poky | ||
+ | meta-yocto-bsp = "HEAD:72867393fe2004ab9f0ee23eb09a975c82938b9e" | ||
+ | meta-ezynq = "rocko:046de13c06cc248b725cb7b9928f35d4a369b50f" | ||
+ | meta-elphel393 = "rocko:0cea9b9b8776f0fe725316f1be1501396c95feb4" | ||
+ | meta-ros = "HEAD:72068b17e4192b51e09c8dc633805a35edac8701" | ||
+ | meta-xilinx-bsp = "HEAD:a18947c20dba2c0c38db8bde1ad4684995df4bbd" | ||
+ | meta-oe | ||
+ | meta-python | ||
+ | meta-networking | ||
+ | meta-webserver = "HEAD:34aa4c3202b427f59f843dc43a4e1afda4f81d13"</font> | ||
+ | |||
+ | * Error 1: | ||
+ | ** ROS_USE_PYTHON3 = "yes" | ||
+ | ** IMAGE_INSTALL += "roslaunch" | ||
+ | |||
+ | <font size='1'>NOTE: Resolving any missing task queue dependencies | ||
+ | ERROR: Nothing RPROVIDES 'python3-pycrypto' (but /home/oleg/GIT/elphel393_rocko_clean_install/meta/meta-ros/recipes-devtools/python/python3-paramiko_1.16.0.bb RDEPENDS on or otherwise requires it) | ||
+ | NOTE: Runtime target 'python3-pycrypto' is unbuildable, removing... | ||
+ | Missing or unbuildable dependency chain was: ['python3-pycrypto'] | ||
+ | NOTE: Runtime target 'python3-paramiko' is unbuildable, removing... | ||
+ | Missing or unbuildable dependency chain was: ['python3-paramiko', 'python3-pycrypto'] | ||
+ | NOTE: Runtime target 'roslaunch' is unbuildable, removing... | ||
+ | Missing or unbuildable dependency chain was: ['roslaunch', 'python3-paramiko', 'python3-pycrypto'] | ||
+ | ERROR: Required build target 'core-image-elphel393' has no buildable providers. | ||
+ | Missing or unbuildable dependency chain was: ['core-image-elphel393', 'roslaunch', 'python3-paramiko', 'python3-pycrypto']</font> | ||
+ | |||
+ | * Successful build: | ||
+ | ** IMAGE_INSTALL += "roslaunch" | ||
+ | |||
+ | <font size='1'>NOTE: Resolving any missing task queue dependencies | ||
+ | ERROR: Nothing RPROVIDES 'python3-pycrypto' (but /home/oleg/GIT/elphel393_rocko_clean_install/meta/meta-ros/recipes-devtools/python/python3-paramiko_1.16.0.bb RDEPENDS on or otherwise requires it) | ||
+ | NOTE: Runtime target 'python3-pycrypto' is unbuildable, removing... | ||
+ | Missing or unbuildable dependency chain was: ['python3-pycrypto'] | ||
+ | NOTE: Runtime target 'python3-paramiko' is unbuildable, removing... | ||
+ | Missing or unbuildable dependency chain was: ['python3-paramiko', 'python3-pycrypto'] | ||
+ | NOTE: Runtime target 'roslaunch' is unbuildable, removing... | ||
+ | Missing or unbuildable dependency chain was: ['roslaunch', 'python3-paramiko', 'python3-pycrypto'] | ||
+ | ERROR: Required build target 'core-image-elphel393' has no buildable providers. | ||
+ | Missing or unbuildable dependency chain was: ['core-image-elphel393', 'roslaunch', 'python3-paramiko', 'python3-pycrypto']</font> | ||
+ | |||
+ | |||
+ | * Error 2: | ||
+ | ** <font color='red'>Seems like '''rostopic''' causes:</font> | ||
+ | <font size='1'>ERROR: python-imaging-1.1.7-r5 do_package_qa: QA Issue: python-imaging: The compile log indicates that host include and/or library paths were used. | ||
+ | Please check the log '/home/oleg/GIT/elphel393_rocko_clean_install/poky/build/tmp/work/cortexa9-neon-poky-linux-gnueabi/python-imaging/1.1.7-r5/temp/log.do_compile' for more information. [compile- host-path] | ||
+ | ERROR: python-imaging-1.1.7-r5 do_package_qa: QA run found fatal errors. Please consider fixing them. | ||
+ | ERROR: python-imaging-1.1.7-r5 do_package_qa: Function failed: do_package_qa | ||
+ | ERROR: Logfile of failure stored in: /home/oleg/GIT/elphel393_rocko_clean_install/poky/build/tmp/work/cortexa9-neon-poky-linux-gnueabi/python-imaging/1.1.7-r5/temp/log.do_package_qa.19425 | ||
+ | ERROR: Task (/home/oleg/GIT/elphel393_rocko_clean_install/meta/meta-openembedded/meta-python/recipes-devtools/python/python-imaging_1.1.7.bb:do_package_qa) failed with exit code '1'</font> | ||
+ | |||
+ | potential links: | ||
+ | https://github.com/intel-aero/meta-intel-aero/issues/81 | ||
+ | https://github.com/bmwcarit/meta-ros/issues/395 | ||
+ | |||
+ | |||
+ | ===Work=== | ||
+ | * Won't work |
Revision as of 14:38, 4 December 2018
Contents
GitHub
https://github.com/bmwcarit/meta-ros.git
ROS2
Build
- Add path to bblayers.conf
- Add to "IMAGE_INSTALL_append" of core-image-elphel393.bb:
ros2-demo-nodes-cpp \ ros2topic \ ros2msg \ ros2run \
Notes:
- Is this a required minimum?
- ROS_USE_PYTHON3 = "yes" no effect? It already uses python3?
Work
1. Test Talker and Listener
- SSH session 1:
root@elphel393:~# export AMENT_PREFIX_PATH=/usr root@elphel393:~# ros2 run demo_nodes_cpp talker
- SSH session 2:
root@elphel393:~# export AMENT_PREFIX_PATH=/usr root@elphel393:~# ros2 run demo_nodes_cpp listener
Notes:
- If AMENT_PREFIX_PATH is not set then:
Traceback (most recent call last): File "/usr/bin/ros2", line 11, in <module> load_entry_point('ros2cli==0.4.0', 'console_scripts', 'ros2')() File "/usr/lib/python3.5/site-packages/ros2cli/cli.py", line 64, in main rc = extension.main(parser=parser, args=args) File "/usr/lib/python3.5/site-packages/ros2run/command/run.py", line 59, in main executable_name=args.executable_name) File "/usr/lib/python3.5/site-packages/ros2run/api/__init__.py", line 30, in get_executable_path paths = get_executable_paths(package_name=package_name) File "/usr/lib/python3.5/site-packages/ros2pkg/api/__init__.py", line 41, in get_executable_paths prefix_path = get_prefix_path(package_name) File "/usr/lib/python3.5/site-packages/ros2pkg/api/__init__.py", line 34, in get_prefix_path prefix_path = get_package_prefix(package_name) File "/usr/lib/python3.5/site-packages/ament_index_python/packages.py", line 49, in get_package_prefix content, package_prefix = get_resource('packages', package_name) File "/usr/lib/python3.5/site-packages/ament_index_python/resources.py", line 37, in get_resource for path in get_search_paths(): File "/usr/lib/python3.5/site-packages/ament_index_python/search_paths.py", line 30, in get_search_paths "Environment variable '{}' is not set or empty".format(AMENT_PREFIX_PATH_ENV_VAR)) OSError: Environment variable 'AMENT_PREFIX_PATH' is not set or empty
2. Available packages
- SSH session:
root@elphel393:~# export AMENT_PREFIX_PATH=/usr root@elphel393:~# ros2 pkg list builtin_interfaces demo_nodes_cpp example_interfaces geometry_msgs rcl rcl_interfaces rclcpp rclpy rcutils rmw rmw_fastrtps_cpp rosidl_cmake rosidl_generator_c rosidl_generator_cpp rosidl_parser rosidl_typesupport_interface rosidl_typesupport_introspection_c rosidl_typesupport_introspection_cpp sensor_msgs
ROS1
Build
Won't build
Build Configuration: BB_VERSION = "1.37.0" BUILD_SYS = "x86_64-linux" NATIVELSBSTRING = "universal" TARGET_SYS = "arm-poky-linux-gnueabi" MACHINE = "elphel393" DISTRO = "poky" DISTRO_VERSION = "2.4+snapshot-20181204" TUNE_FEATURES = "arm armv7a vfp neon cortexa9" TARGET_FPU = "softfp" meta meta-poky meta-yocto-bsp = "HEAD:72867393fe2004ab9f0ee23eb09a975c82938b9e" meta-ezynq = "rocko:046de13c06cc248b725cb7b9928f35d4a369b50f" meta-elphel393 = "rocko:0cea9b9b8776f0fe725316f1be1501396c95feb4" meta-ros = "HEAD:72068b17e4192b51e09c8dc633805a35edac8701" meta-xilinx-bsp = "HEAD:a18947c20dba2c0c38db8bde1ad4684995df4bbd" meta-oe meta-python meta-networking meta-webserver = "HEAD:34aa4c3202b427f59f843dc43a4e1afda4f81d13"
- Error 1:
- ROS_USE_PYTHON3 = "yes"
- IMAGE_INSTALL += "roslaunch"
NOTE: Resolving any missing task queue dependencies ERROR: Nothing RPROVIDES 'python3-pycrypto' (but /home/oleg/GIT/elphel393_rocko_clean_install/meta/meta-ros/recipes-devtools/python/python3-paramiko_1.16.0.bb RDEPENDS on or otherwise requires it) NOTE: Runtime target 'python3-pycrypto' is unbuildable, removing... Missing or unbuildable dependency chain was: ['python3-pycrypto'] NOTE: Runtime target 'python3-paramiko' is unbuildable, removing... Missing or unbuildable dependency chain was: ['python3-paramiko', 'python3-pycrypto'] NOTE: Runtime target 'roslaunch' is unbuildable, removing... Missing or unbuildable dependency chain was: ['roslaunch', 'python3-paramiko', 'python3-pycrypto'] ERROR: Required build target 'core-image-elphel393' has no buildable providers. Missing or unbuildable dependency chain was: ['core-image-elphel393', 'roslaunch', 'python3-paramiko', 'python3-pycrypto']
- Successful build:
- IMAGE_INSTALL += "roslaunch"
NOTE: Resolving any missing task queue dependencies ERROR: Nothing RPROVIDES 'python3-pycrypto' (but /home/oleg/GIT/elphel393_rocko_clean_install/meta/meta-ros/recipes-devtools/python/python3-paramiko_1.16.0.bb RDEPENDS on or otherwise requires it) NOTE: Runtime target 'python3-pycrypto' is unbuildable, removing... Missing or unbuildable dependency chain was: ['python3-pycrypto'] NOTE: Runtime target 'python3-paramiko' is unbuildable, removing... Missing or unbuildable dependency chain was: ['python3-paramiko', 'python3-pycrypto'] NOTE: Runtime target 'roslaunch' is unbuildable, removing... Missing or unbuildable dependency chain was: ['roslaunch', 'python3-paramiko', 'python3-pycrypto'] ERROR: Required build target 'core-image-elphel393' has no buildable providers. Missing or unbuildable dependency chain was: ['core-image-elphel393', 'roslaunch', 'python3-paramiko', 'python3-pycrypto']
- Error 2:
- Seems like rostopic causes:
ERROR: python-imaging-1.1.7-r5 do_package_qa: QA Issue: python-imaging: The compile log indicates that host include and/or library paths were used. Please check the log '/home/oleg/GIT/elphel393_rocko_clean_install/poky/build/tmp/work/cortexa9-neon-poky-linux-gnueabi/python-imaging/1.1.7-r5/temp/log.do_compile' for more information. [compile- host-path] ERROR: python-imaging-1.1.7-r5 do_package_qa: QA run found fatal errors. Please consider fixing them. ERROR: python-imaging-1.1.7-r5 do_package_qa: Function failed: do_package_qa ERROR: Logfile of failure stored in: /home/oleg/GIT/elphel393_rocko_clean_install/poky/build/tmp/work/cortexa9-neon-poky-linux-gnueabi/python-imaging/1.1.7-r5/temp/log.do_package_qa.19425 ERROR: Task (/home/oleg/GIT/elphel393_rocko_clean_install/meta/meta-openembedded/meta-python/recipes-devtools/python/python-imaging_1.1.7.bb:do_package_qa) failed with exit code '1' potential links: https://github.com/intel-aero/meta-intel-aero/issues/81 https://github.com/bmwcarit/meta-ros/issues/395
Work
- Won't work