| commit | 539197a4b446ff3f5ceaf2a53d3471e39d2bf816 | [log] [tgz] |
|---|---|---|
| author | Android Build Coastguard Worker <android-build-coastguard-worker@google.com> | Mon Apr 04 10:42:27 2022 +0000 |
| committer | Android Build Coastguard Worker <android-build-coastguard-worker@google.com> | Mon Apr 04 10:42:27 2022 +0000 |
| tree | 599fce2ebe81c58d468695203d147556507867b2 | |
| parent | 3cf3af8d4340f80592e7b74a4cf9977599457e80 [diff] | |
| parent | 8e9a1e745cd1aa274f99890eaeabe1ce9b8cecb7 [diff] |
Snap for 8401988 from 8e9a1e745cd1aa274f99890eaeabe1ce9b8cecb7 to mainline-adservices-release Change-Id: Ie1417d1084d616b65ab2afae072be6b79a474688
Full documentation can be found here: https://source.android.com/devices/architecture/hidl/
hidl-gen is a compiler for the HIDL (HAL Interface Design Language) which generates C++ and Java endpoints for RPC mechanisms. The main userspace libraries which this compiler uses can be found at system/libhidl.
m hidl-gen
Note that options for hidl-gen expected to be invoked by the build system are marked with ‘internal’ in the help menu.
hidl-gen -h hidl-gen -o output -L c++-impl -r android.hardware:hardware/interfaces -r android.hidl:system/libhidl/transport android.hardware.nfc@1.0
Some defaults for package roots are also provided
hidl-gen -o output -L c++-impl android.hardware.nfc@1.0 hidl-gen -o output -L vts android.hardware.nfc@1.0 hidl-gen -L hash android.hardware.nfc@1.0
Example command for vendor project
hidl-gen -L c++-impl -r vendor.foo:vendor/foo/interfaces vendor.foo.nfc@1.0
See update-makefiles-helper.sh and update-all-google-makefiles.sh for examples of how to generate HIDL makefiles (using the -Landroidbp option).
NOTE: When using the -Landroidbp option, you can force generated modules to be installed in
/system_extrather than other partition by putting a marker file.hidl_for_system_extalongside*.halfiles.
NOTE: You can also install the vendor variant of the generated modules to be installed in
/odmrather than/vendorby putting a marker file.hidl_for_odmalongside*.halfiles.
This is a helper tool to convert C headers to valid .hal files.
m c2hal && c2hal -h