Note: With the latest 1.23.0 release, the Anbox Cloud documentation is moved to https://documentation.ubuntu.com/anbox-cloud/en/latest/. Hence, the information in this discourse post may be obsolete. The documentation posts on discourse will be unlisted and archived shortly.
Discourse will still be used for user engagement and release announcements.
since 1.22.0
Replacing the Anbox VHAL is only supported on AAOS images.
The Anbox Cloud dashboard does not support custom VHAL implementations.
This document will guide through the process of replacing the Anbox Cloud VHAL
implementation with your own implementation placed in the
ODM partition
using an addon.
Prerequisites
Your custom VHAL implementation must provide an
HIDL VHAL interface
and be built against VNDK 29.
If your VHAL implementation requires additional libraries, they must also be
bundled with the addon and copied in the ODM partition.
Create the addon
This addon will be tasked with the following:
- Copying the VHAL binary to
/odm/bin/hw
. - Copying an
init.rc file
for your VHAL service to /odm/etc/init
.
- Disabling the Anbox Cloud VHAL by setting the
ro.anbox.automotive.vhal
property toodm
. This will be done by writing that system property to the
/odm/etc/build.prop
file.
In the following example, we will name our addon custom-vhal
.
To override the VHAL implementation, we will use a
pre-start hook which is executed
before Android gets started.
The directory layout for the addon is strict and must be:
custom-vhal/
├── hooks
│ └── pre-start
├── manifest.yaml
├── vhal
└── vhal.rc
As mentioned in the prerequisites, any additional libraries must also be bundled with the addon.
vhal
is your custom VHAL implementation.
vhal.rc
is an init.rc file for your VHAL service, such as:
service custom-vhal /odm/bin/hw/vhal
class hal
user vehicle_network
group system inet
disabled
on property:ro.anbox.automotive.vhal=odm
start custom-vhal
hooks/pre-start
must be an executable file which will handle the tasks
outlined at the beginning of this section, such as the following bash script:
#!/bin/bash -x
#
# Copyright 2024 Canonical Ltd. All rights reserved.
#
ANDROID_ODM_DIR="${ANBOX_DIR}/android-odm"
if [ "${INSTANCE_TYPE}" != base ]; then
exit 0
fi
# Ensure all needed directories are created
mkdir -p "${ANDROID_ODM_DIR}/etc/init"
mkdir -p "${ANDROID_ODM_DIR}/bin/hw"
# Copy the custom VHAL and the associated init file in /odm
cp "${ADDON_DIR}/vhal" "${ANDROID_ODM_DIR}/bin/hw/"
cp "${ADDON_DIR}/vhal.rc" "${ANDROID_ODM_DIR}/etc/init/"
# Set the ro.anbox.anbox.vhal system property to 'odm'
echo "ro.anbox.automotive.vhal=odm" >> "${ANDROID_ODM_DIR}/etc/build.prop"
The addon
manifest.yaml
file
contains metadata:
name: custom-vhal
description: |
Addon replacing the Anbox Cloud VHAL with a custom implementation.
Once everything is in place, you can add the addon to your Anbox Cloud instance,
with:
amc addon add custom-vhal ./custom-vhal
Please note that due to Snap strict confinement, the addon directory
(custom-vhal
here) must be located in the home directory of the user executing
the amc
command.
Use the addon
The newly added custom-vhal
addon must now be enabled to be used with
Anbox Cloud applications.
If you plan to always override the Anbox Cloud VHAL implementation in all
applications, you can
enable the addon globally:
amc config set application.addons custom-vhal
Otherwise, add it to your
application manifest:
name: my-app
addons:
- custom-vhal