• Android13 新增 Stable AIDL接口


    问题描述:

    我需要在netd aidl 中添加新的接口:

    设置网卡MAC地址:

    void setHardwareAddress(in @utf8InCpp String iface, in @utf8InCpp String hwAddr);

    背景:

    Android 10 添加了对稳定的 Android 接口定义语言 (AIDL) 的支持,这是一种跟踪由 AIDL 接口提供的应用编程接口 (API)/应用二进制接口 (ABI) 的新方法。稳定的 AIDL 与 AIDL 的主要区别如下:

    在构建系统中使用 aidl_interfaces 定义接口。
    接口只能包含结构化数据。对于代表所需类型的 Parcelable,系统会根据其 AIDL 定义自动创建,并自动对其进行编组和解组。
    可以将接口声明为“稳定”接口(向后兼容)。声明之后,会在 AIDL 接口旁的一个文件中对这些接口的 API 进行跟踪和版本编号。
     

    添加以后:使用如下指令编译模块

    mmm /frameworks/libs/net/common/netd

    报错提示说需要更新api:

    API dump for the current version of AIDL interface setHardwareAddress does not exist.

    Run m netd_aidl_interface-update-api or add unstable: true to the build rule for the interface if it does not need to be versioned

    我们按照提示更新api:

    make netd_aidl_interface-update-api 更新当前api 此命令执行成会更新如下目录下的aidl文件

    QSSI.13\frameworks\libs\net\common\netd\aidl_api\netd_aidl_interface\current 

    因为我们是在原来的aidl文件内新增的接口, 所以我们需要使用如下指令重新生成一个version 的api

    make netd_aidl_interface-freeze-api 此命令会生成新的版本号的api:之前最大是10,更新以后多了11

    QSSI.13\frameworks\libs\net\common\netd\aidl_api\netd_aidl_interface\11 

    然后我们再重新编译模块:

    mmm /frameworks/libs/net/common/netd 在如下路径会生成该版本的aidl对应的java文件和.h文件。 QSSI.13\out\soong\.intermediates\frameworks\libs\net\common\netd\netd_aidl_interface-V11-java-source\gen\android\net QSSI.13\out\soong\.intermediates\frameworks\libs\net\common\netd\netd_aidl_interface-V11-cpp-source\gen\include\android\net 

    我们可以打开.h文件找到我们定义的方法:

    经过如上操作我们就可以实现该方法了: 

    1. //QSSI.13\system\netd\server\NetdNativeService.h
    2. binder::Status setHardwareAddress(const ::std::string& iface, const ::std::string& hwAddr) override;
    3. QSSI.13\system\netd\server\NetdNativeService.cpp
    4. binder::Status NetdNativeService::setHardwareAddress(const std::string& iface,const std::string& hwAddr){
    5. ....
    6. return binder::Status::ok();
    7. }

     service层就实现好了,我们可以编译模块然后上层就可以调用了

    编译模块的时候,报错如下:

    FAILED: out/soong/apex/depsinfo/new-allowed-deps.txt.check if grep -v '^#' packages/modules/common/build/allowed_deps.txt | diff -B - out/soong/apex/depsinfo/new-allowed-deps.txt; then touch out/soong/apex/depsinfo/new-allowed-deps.txt.check; else echo -e "\n******************************"; echo "ERROR: go/apex-allowed-deps-error"; echo "******************************"; echo "Detected changes to allowed dependencies in updatable modules."; echo "To fix and update packages/modules/common/build/allowed_deps.txt, please run:"; echo -e "$ (croot && packages/modules/common/build/update-apex-allowed-deps.sh)\n"; echo "When submitting the generated CL, you must include the following information"; echo "in the commit message if you are adding a new dependency:"; echo "Apex-Size-Increase:"; echo "Previous-Platform-Support:"; echo "Aosp-First:"; echo "Test-Info:"; echo "You do not need OWNERS approval to submit the change, but mainline-modularization@"; echo "will periodically review additions and may require changes."; echo -e "******************************\n"; exit 1; fi; 738a739,740 > netd_aidl_interface-V11-java(minSdkVersion:29) > netd_aidl_interface-V11-ndk(minSdkVersion:29) ****************************** ERROR: go/apex-allowed-deps-error ****************************** Detected changes to allowed dependencies in updatable modules. To fix and update packages/modules/common/build/allowed_deps.txt, please run: $ (croot && packages/modules/common/build/update-apex-allowed-deps.sh) When submitting the generated CL, you must include the following information in the commit message if you are adding a new dependency: Apex-Size-Increase: Previous-Platform-Support: Aosp-First: Test-Info: You do not need OWNERS approval to submit the change, but mainline-modularization@ will periodically review additions and may require changes. ******************************

    可以看到提示,需要我们在系统添加如下声明:

    netd_aidl_interface-V11-java(minSdkVersion:29)

    netd_aidl_interface-V11-ndk(minSdkVersion:29)

    如上声明我们可以使用脚本自动生成:

    运行如下python脚本就可以了。

    (croot && packages/modules/common/build/update-apex-allowed-deps.sh)

    如上我们就可以编译模块成功了,编译成功以后,我们就可以通过INetd 调用该函数了

    1. @Override
    2. public void setHardwareAddress(String iface, String hwAddr) {
    3. // TODO: Remove CONNECTIVITY_INTERNAL after bluetooth tethering has no longer called these
    4. // APIs.
    5. NetworkStack.checkNetworkStackPermissionOr(mContext, CONNECTIVITY_INTERNAL);
    6. Slog.i(TAG, "setHardwareAddress..." + iface + ":" + hwAddr);
    7. try {
    8. mNetdService.setHardwareAddress(iface, hwAddr);
    9. } catch (RemoteException | ServiceSpecificException e) {
    10. throw new IllegalStateException(e);
    11. }
    12. }

    在调试过程中,遇到的错误如下:

    • Backward incompatible change detected on AIDL API

    该问题的原因是因为我新增的方法加在了中间,导致原始的API顺序产生了变化,我们需要把新增的接口,加在最后面,然后使用make netd_aidl_interface-update-api 更新current

    • ERROR: Modification detected of stable AIDL API file

    该问题产生的原因是因为我手动修改QSSI.13\frameworks\libs\net\common\netd\aidl_api\netd_aidl_interface\10 目录下的aidl文件,导致hash值更改了,后面通过make netd_aidl_interface-freeze-api  生成新的api,后续更改应用的版本就可以了。

    • java层通过INetd 调用不到新增的方法

    该问题的原因为:frameworks\libs\net\common\netd\Android.bp 使用的AIDL版本为10,我们新增的aidl接口是在11版本里面

    所以我们需要将这里的10修改成11。

    如上即为新增aidl接口遇到的全部问题。

    关于Stable  AIDL的详细资料:穩定的 AIDL  |  Android Open Source Project

  • 相关阅读:
    c++标准模板(STL)- 算法 (std::remove, std::remove_if)
    重学Java8新特性(三) : Collection、List、Map 新增的API, Collectors收集器
    并发bug之源(一)-可见性
    JavaWeb-高级分页查询
    Linux 回收内存到底怎么计算anon/file回收比例,只是swappiness这么简单?
    Pytorch实战:基于鲸鱼WOA优化1DCNN的轴承故障诊断
    Zotero实现中英文对照?
    『C++ - STL』之优先级队列( priority_queue )
    转铁蛋白修饰脂质体定制,Transferrin-Liposome
    Python实现最小公约数和最小公倍数
  • 原文地址:https://blog.csdn.net/androidzmm/article/details/134524702