기존 이솝 임베디드 포럼의 지식인 서비스가 게시판 형태로 변경되었습니다.

안녕하세요.

Android 플랫폼에 간단한 디바이스를 붙여보려고 노력중인 대학원생입니다.

Android 프레임워크에 대해서 공부하고 있습니다.


Android 프레임워크에 HAL이 왜 필요한지 잘 이해가 되질 않습니다.

만약 리눅스에서 잘 동작하는 디바이스 드라이버가 있다면

이 디바이스 드라이버를 Android 플랫폼에 옮기고,

디바이스 드라이버를를 Java 언어로도 접근 할 수 있도록

JNI를 이용하여 연결만 해주면될거 같은데...

만약 추가하는 장치를 위한 Android 서비스를 생성한다고

해도 서비스도 JNI을 이용하여 디바이스에 충분히 접근

가능할거 같습니다.


안드로이드용 디바이스 드라이버는

리눅스드라이버와 다른점이 있나요?


HAL의 의마가 Hardware Abstract Layer인데

그냥 디바이스 드라이버마다 다른 인터페이스를

추상화시켜 통합만 해주는 역활을 하는건가요?


그런데 또 잘 이해가 되지 않는점은

HAL은 공개되지 않는걸로 알고 있는데

단순히 인터페이스 통합을 위한 Layer를

굳이 비공개로 유지해야하나?하는 생각이 듭니다.

인터페이스 통합말고도 다른 기능이 있을거같은데..


잘 이해가 되질 않습니다.

감사합니다. 


고도리

2015.10.03 02:28:40
*.200.239.210

Android HAL이 있는 이유는 표준화 때문입니다.


리눅스 디바이스 드라이버가 있어도, 예를 들어..........카메라의 경우 Qualcomm과 삼성 Exynos 시리즈는 

카메라를 다루는 방법이 확연히 다릅니다(v4l2란 스택을 쓰지만, 드라이버를 다루는 방식이 다릅니다).


하지만, android app은 표준화된 방식으로 Qualcomm이건 Exynos건 접근을 해야합니다.

해서 app이 하드웨어에 공통된 표준방식으로 접근하기 위해서는 중간에 표준을 맞춰서 리눅스를 제어해 주는 완충코드가 필요한 겁니다.

Supsupi

2015.10.08 18:34:44
*.234.67.230

답글 감사드립니다.


그렇다면 Android는 App에 제공하는 표준 인터페이스만 정의하고

각 디바이스 밴더들이 표준 인터페이스에 맞게 HAL을 제작한다.

그리고 디바이스를 어떻게 제어하는지를 감추기위해서

라이브러리화 하여 Android에 넣는다

이게 맞을까요?


맞다면 HAL이 app에 제공해야하는 정의된? 인터페이스를

어디서 확인할 수 있을까요?


감사합니다.



조이재즈

2015.10.08 18:40:59
*.241.151.50

구현하고자 하는 HAL 의 종류에 따라 구현해야할 인터페이스는 각각 다르겠지요.


hardware/libhardware/modules

hardware/libhardware_legacy


두 폴더의 내용을 확인해보시기 바랍니다.

Supsupi

2015.10.08 19:48:24
*.234.67.230

답글 감사드립니다.!!

List of Articles
번호 제목 글쓴이 날짜 조회 수

사용자 로그인