Android指纹解锁源码分析

简介: Android指纹解锁源码分析

systemServer进程会在ZygoteInit中进行创建,而ZygoteInit是Zygote进程启动的。

在systemServer进程的run方法中会启动重要服务其中就包括指纹解锁相对应的服务。

指纹解锁需要和Hal层进行交互,并对上层framewrok提供接口以实现解锁功能

整体流程可以大致分为:

1.SystemServer中调用startOtherService方法根据设备支持的功能启动对应的服务

该例中如果设备支持指纹解锁就执行接下来的方法:

启动指纹解锁对应的Service,也就是FingerprintService这个类

startOtherService方法:

startService:

2.可以看到会反射创建这个类的构造方法并把它添加到services中,接着执行这个类的onStart方法

FingerprintService这个类的onStart方法

3.FingerprintService这个类的onStart方法中可以看到创建了一个 FingerprintServiceWrapper()这个类。

发布服务保存在SystemServer中,可以看到这个服务对应的接口是

IFingerprintService.Stub

可以看到是在用了个线程池在调用这个run方法,接下来去看看这个Runnable接口做了什么操作

getFingerprintDaemon函数首先调用getService函数不断尝试链接HAL层的进程(IBiometricsFingerprint这个服务是在HAL层初始化的之后讲解),链接成功之后调用setNotify设置回调函数,最后加载用户相关数据。至此,Framework层已经启动完成。

BiometricsFingerprint

上面讲到FrameWork中会获取BiometricsFingerprint这个服务,这个服务是在哪个地方初始化的呢?

首先需要讲下Android.bp文件:

Android.bp的出现就是为了替换Android.mk文件,随着Android越来越庞大,module越来越多,编译时间也越来越长,而使用ninja在编译的并发处理上较make有很大的提升。Ninja的配置文件就是Android.bp,Android系统使用Blueprint和Soong工具来解析Android.bp转换生成ninja文件

详细内容及自定义文件可参考这篇博客 Android.bp文件详解

这里首先看下一些配置信息

这是一些注释信息:

cc_library_shared :编译成动态库,类似于Android.mk中的BUILD_SHARED_LIBRARY

cc_binary:编译成可执行文件,类似于Android.mk中的BUILD_EXECUTABLE

name :编译出的模块的名称,类似于Android.mk中的LOCAL_MODULE

srcs:源文件,类似于Android.mk中的LOCAL_SRC_FILES

local_include_dirs:指定路径查找头文件,类似于Android.mk中的LOCAL_C_INCLUDES

shared_libs:编译所依赖的动态库,类似于Android.mk中的LOCAL_SHARED_LIBRARIES

static_libs:编译所依赖的静态库,类似于Android.mk中的LOCAL_STATIC_LIBRARIES

cflags:编译flag,类似于Android.mk中的LOCAL_CFLAGS

Service.cpp是HAL层启动的入口文件。

1.首先通过BiometricsFingerprint::getInstance()实例化一个bio服务,不同厂商的指纹识别算法和逻辑也都在这个bibo服务中体现出来。这个方法里面会进行初始化HAL层关于指纹的一些初始化动作最后讲

2.接着设置用于RPC通信的线程数

3.接着把自己添加到线程池中,用于之后framework获取进行返回bibo服务

BiometricsFingerprint::getInstance()

该函数单利创建出来一个BiometricsFingerprint对象,接着看他的构造方法

BiometricsFingerprint构造方法,可以看到调用了openHal方法。

1.openHal方法第一步首先打开指纹HW模块,也就是获取厂商指纹模组的so

hw_get_module(FINGERPRINT_HARDWARE_MODULE_ID, &hw_mdl)

2.接着调用open方法

3.这个open方法主要是将厂商指纹模组模块的算法识别逻辑结果和HAL层进行绑定,设置回调通知。

大致流程:

首先将framework中的指纹解锁Service启动接着去获取HAL层的指纹解锁服务Service。
framework层的Service主要用于和HAL层进行通信(获取HAL层的Service)
HAL层的Service收到后会使用厂商自定义的指纹模组so模块对应的逻辑去判断是否是本人
最后结果在给到framework层响应

  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值