| # hidl-gen |
| |
| 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. |
| |
| ## 1. Build |
| |
| ``` |
| m hidl-gen |
| ``` |
| |
| ## 2. Run |
| |
| 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 [email protected] |
| ``` |
| |
| Some defaults for package roots are also provided |
| |
| ``` |
| hidl-gen -o output -L c++-impl [email protected] |
| hidl-gen -o output -L vts [email protected] |
| hidl-gen -L hash [email protected] |
| ``` |
| |
| Example command for vendor project |
| |
| ``` |
| hidl-gen -L c++-impl -r vendor.foo:vendor/foo/interfaces [email protected] |
| ``` |
| |
| 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_ext` rather than other partition by putting a |
| > marker file `.hidl_for_system_ext` alongside `*.hal` files. |
| |
| > **_NOTE:_** You can also install the vendor variant of the generated modules |
| > to be installed in `/odm` rather than `/vendor` by putting a marker file |
| > `.hidl_for_odm` alongside `*.hal` files. |
| |
| # c2hal |
| |
| This is a helper tool to convert C headers to valid .hal files. |
| |
| ``` |
| m c2hal && c2hal -h |
| ``` |