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

exynos 4412 를 사용한 보드를 제작하였습니다. 

여기에 cmos 카메라를 붙여서 실험을 하고 있습니다. 


삼성에서 제공하는 기본적인 fimc 관련 device driver 는 포팅을 했고,

V4L2 도 삼성에서 기본적으로 제공한 것을 사용하고 있습니다. 

화면 capture, preview 도 잘 됩니다. 

참고로 preview 를 위해 어플에서 pthread 하나 돌리고 있고요.

어플은 C++ 로 만들었습니다. 


그런데, 한가지 문제가 있더군요.


어플단에서 camera open 을 한 다음 close 를 하면 정상적으로 잘 됩니다. 

그러나 open -> preview start -> preview stop -> close 를 하면

close 는 정상적으로 됐다고 return 값이 오는데, 실질적으로 kernel 단의

camera release 함수가 호출이 안됩니다.


좀더 확인해 봤더니 V4L2 의 ioctl 함수를 한번이라도 호출하게 되면,

close 가 안되는 현상이 발생하더군요. 

물론 close 하기전에 open -> preview start -> preview stop -> preview start

-> preview stop 은 잘 됩니다.


카메라 초짜라 이래저래 맨땅에 헤딩하면서 하고 있는데, 위의 문제는 당췌 

모르겠네요. system call 에서 문제가 있는 것인지, 아니면 V4L2가 문제인지 

이런 경우는 처음입니다. 

당근 close 시 memory 도 free 했고요.



혹시 유사한 경험을 가지고 계신분은 조언 좀 부탁드립니다. 


고도리

2017.02.04 23:03:14
*.200.239.210

linux에서 테스트하신건가요?

아니면 안드로이드인가요?


다른 프로세스에서 열고 있지 않나도 확인해 보시는게 좋습니다.

칼마

2017.02.06 02:20:08
*.90.129.146

리눅스에서 테스트 했습니다. 


근데 다른 프로세서에서 열고 있는지 확인을 할 수 가 있나요?

일일이 소스로 뒤지는 수 밖에는 없는 건지..


커널단에서 카메라 캡쳐 이미지를 가져오기 위해 pthread  하나 돌리는게 있는데 이게 문제가 될까요?



칼마

2017.02.06 03:43:56
*.90.129.146

방금 확인한 건데, 카메라 캡쳐할 때 캐쳐이미지를 저장할 메모리를 잡습니다. 

그리고 바로 close 해보니 close 가 안되는 현상이 나오네요. 

아마도 문제는 mmap 으로 잡은 메모리가 해제가 안되어서 그런거 같기는 한데, 

코드상에서는 제대로 해제를 하도록 코딩한거 같거든요.



메모리 잡을 때 

=======================================

   struct v4l2_requestbuffers req;


   buf.type = V4L2_BUF_TYPE_VIDEO_CAPTURE;

   buf.memory = V4L2_MEMORY_MMAP;

   buf.index = 4;


   ioctl(fd, VIDIOC_REQBUFS, &req) 

            ....

   mmap 으로 처리했고요.

=======================================


이렇게 잡았고......


close 하기 전에 

=======================================

   buf.count               = 0;

   buf.type = V4L2_BUF_TYPE_VIDEO_CAPTURE;

   buf.memory = V4L2_MEMORY_MMAP;


   if (ioctl(m_hCameraHandle, VIDIOC_REQBUFS, &req) < 0)

               .......

   munmap 으로 처리.

=======================================


위와 같이 메모리를 해제 해주었습니다. 


근데도 close 가 안되네요. 뭔가 메모리를 해제해줘야 되는 다른방법이 있는건가요?





이동희

2017.02.06 22:46:58
*.169.189.40

문제가 없어 보이는데요. 기본 Samsung BSP를 사용했다면 아마도 fim을 open한 후에 camera select를 하지 않고 close를 하면 문제가 되던 것 밖에 없었습니다.

특히나 Preview와 Capture 모드의 경우에는 Sensor Device Driver에서만 영향을 받기 때문에 모드에 대한 영향이라면 Sensor Device Driver에서 잘못되었을 경우이네요.

IOCTL의 return 값을 모두 검사 해 보세요. 특히 Sensor Device Driver에서 V4L2 함수에서 0이 아닌 값을 return하는지 확인 해 보세요.

고도리

2017.02.07 03:18:22
*.200.239.210

Kernel 버전이 어떻게 되나요?


버전에 따라서도 차이가 있을 수 있습니다.

칼마

2017.02.07 18:23:57
*.90.129.146

3.0.51 버전을 사용하고 있습니다. 


그리고 참고로 cross toll 은 다음과 같습니다. 

gcc version 4.7.3 20121001 (prerelease) (crosstool-NG linaro-1.13.1-4.7-2012.10-20121022 - Linaro GCC 2012.10) 


고도리

2017.02.08 07:43:39
*.200.239.210

오드로이드 커널인가 보네요.


오드로이드 보드는 usb cam만 동작하지 않나요?

일반 카메라면 삼성에서 정식으로 릴리즈된 커널을 쓰시는게 맞을겁니다.


제가 알기로는


3.0.15 :ICS 버전의 경우

3.5.0-R6 : Android 4.2.2_r1

3.4.39: Android 4.2.2_r1


이 세개버전이 공식인 것으로 알고 있습니다.


그나마 가장 안정적인 버전이 3.0.15이고, 나머지 버전은 코드가 3.0.15랑은 꽤 차이가 있습니다.

List of Articles
번호 제목 글쓴이 날짜 조회 수sort
6308 2440보드에서 DM9000 디버깅하는 방법? file [3] DavidKim 2015-08-08 256
6307 AOSP user 모드 빌드 시 주의사항 질문드립니다. [1] 엘카 2015-09-26 256
6306 usb device 구조 질문 [2] ydgoo9 2017-04-12 256
6305 LCD 질문드립니다. file [2] 하하호호하하 2018-04-12 260
6304 자동차에 적용할 만한 솔루션.. 추천 부탁드려요.. [2] 김민욱 2016-05-18 262
6303 [adduser관련] [2] 밥줘잉 2016-05-18 263
6302 DDR2 OCD 설정하는 방법 좀 조언 부탁드립니다. file 션한물 2015-03-16 263
6301 jni 질문드립니다. [2] vain 2015-09-02 264
6300 리눅스에서 /dev/video 와 /dev/bue/usb/ 의 상관관계를 알수 있는 방... [1] pedor11 2015-06-08 266
6299 RTC ALARM 인터럽트 [4] JinJi 2015-09-15 267
6298 arm컴파일러관련 질문인데요.. [2] pedor11 2015-10-23 267
6297 안드로이드 시스템 프로퍼티값을 디바이스 드라이버에서 읽을수 있나요... [1] 하하호호하하 2017-09-28 269
6296 DDR SDRAM불량 현상 [1] 테크 2015-08-15 272
6295 리눅스 스크립트 질문입니다. [3] 하하호호하하 2017-11-07 272
6294 linux container [2] 양파링 2016-02-06 273
6293 Build한 안드로이드의 화면 출력이 이상합니다. file [7] 겟페우스 2016-10-15 275
6292 slattach 기능을 안드로이드에서 이용할 수 있는 방법 문의드립니다 [4] 엘카 2015-11-03 276
6291 7420 동영상 streaming 관련 질문 [2] 김민욱 2016-12-19 277
6290 [4K영상받기] [3] 밥줘잉 2017-07-11 286
6289 android native system service 실행 file [2] rion110 2015-04-06 286

사용자 로그인