博客
关于我
HAL——概要
阅读量:483 次
发布时间:2019-03-06

本文共 404 字,大约阅读时间需要 1 分钟。

what

android硬件抽象层,简单说就是对Linux内核驱动程序的封装,向上提供接口,屏蔽底层的细节。硬件把对硬件的支持分成两层,一层放在userspace,一层放在kernel space,其中硬件抽象层在用户空间,内核驱动程序运行在内核空间。

why

硬件抽象层和内核驱动整合一起放内核空间,技术实现的角度看,可以的,商业角度看,Linux内核源代码遵循GNU License,Android源代码遵循Apache License,前者发布产品时,必须公布源代码,后者无需发布源代码,如果把对硬件支持的所有代码放在Linux驱动层,意味着要公开驱动程序源代码,意味着把硬件的相关参数和实现都公开了,损害了商家的利益。

how

学习过程,学会如何在内核空间编写硬件驱动程序,如何在硬件驱动层添加接口支持访问硬件,如何在系统启动时提供硬件访问服务,如何编写jni使得可以通过java接口来访问硬件等等。

在这里插入图片描述

转载地址:http://tjtdz.baihongyu.com/

你可能感兴趣的文章
mysql进阶-查询优化-慢查询日志
查看>>
wargame narnia writeup
查看>>
MySQL进阶篇SQL优化(InnoDB锁问题排查与解决)
查看>>
Mysql进阶索引篇03——2个新特性,11+7条设计原则教你创建索引
查看>>
Mysql连接时报时区错误
查看>>
mysql逗号分隔的字符串如何搜索
查看>>
MYSQL遇到Deadlock found when trying to get lock,解决方案
查看>>
MYSQL遇到Deadlock found when trying to get lock,解决方案
查看>>
mysql部署错误
查看>>
MySQL配置信息解读(my.cnf)
查看>>
Mysql配置文件my.ini详解
查看>>
MySQL配置文件深度解析:10个关键参数及优化技巧---强烈要求的福利来咯。
查看>>
Mysql配置表名忽略大小写(SpringBoot连接表时提示不存在,实际是存在的)
查看>>
mysql配置读写分离并在若依框架使用读写分离
查看>>
MySQL里为什么会建议不要使用SELECT *?
查看>>
MySQL里的那些日志们
查看>>
MySQL锁
查看>>
MySQL锁与脏读、不可重复读、幻读详解
查看>>
MySQL锁机制
查看>>
mysql锁机制,主从复制
查看>>