-
Notifications
You must be signed in to change notification settings - Fork 96
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Packaging for foreign architectures #740
Comments
I don't believe there's anything in Bloom that is architecture-specific. The deb and RPM metadata generated by this tool should be usable on any architecture supported by the downstream build process. For that downstream build process, given that Ubuntu distributes debs for I've been working on a new tool called colcon-ros-buildfarm that would allow you to reproduce the official ROS buildfarm process on a local host. It should be possible to fork the official As far as officially producing debs for |
Yep. I agree. The actual colcon build process happening under the hood determines the package architecture. Are you aware of a mechanism to inject cmake flags easily through bloom? If I can do that, then I will have full control of what is being built.
Nice. I will take a look.
Totally fair. Part of me is surprised that cross-compilation isn't a more prominent workflow in the ecosystem. It would limit the type of box required to build things to just |
This is a nuanced point, but beyond the
When bloom generates the metadata, it is possible to inject patches into the process. Keep in mind, however, that this is done by the package maintainers when they generate the metadata. Setting up an environment where you can modify an existing package's metadata is exceedingly difficult to do, and essentially involves forking the entire ROS distribution. |
Because it keeps things simple for us on the infrastructure side, we rely on emulation to produce native builds rather than cross-complation. Prior to the availability of high performance ARM compute. The ARMv7 (armhf) and ARMv8 (arm64) package builds ran in ARM native containers using qemu-user-static to emulate on x86_64 hardware. I would recommend this same approach for building riscv or any other architecture that is:
|
Since this is a question rather than an issue representing a bug or a feature request. I'm going to close it. We can carry on the discussion with the issue closed. |
Hello!
Is there a way to use this tool to package something for a CPU architecture different from the host system?
I have a RiscV board with somewhat less grunt than a Raspberry Pi. As no RiscV ROS debs are publicly available, I have been cross-compiling the core of ROS2 along with any packages I develop and then copying them to the machine. This has significantly reduced build times compared to compiling on the board natively or emulating the architecture to do a "native" build.
The next workflow improvement I am interested in is packaging debs to limit the number of source builds for an even faster turnaround to testing. I have done some playing around, and there might be a way to do so if I modify the deb generator template to look for the foreign rootfs when bloom does its internal rebuild for packaging.
Either way, I thought it would be good to ask if there was ever any discussion around this point and there is another way to do things that I haven't seen yet.
The text was updated successfully, but these errors were encountered: