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

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 커널 소스에 있는 드라이버에 대해서...<--완료 [1] 박현진 2006-05-16 5189
6307 한가지 궁금한 점 문의드립니다 ... [완료] [2] 장석원 2007-03-28 5172
6306 [완료] Ethernet... [2] 정경진 2007-04-11 5110
6305 삼성 6410 git 페이지 [1] 최영진 2009-02-25 4927
6304 [질문] 휴대용으로 사용하려면..[완료] [2] 김성주 2007-04-14 4867
6303 디바이스 노드파일을 동적으로 생성하려면 어찌해야하나요? USB관련,... [2] ice179 2014-02-28 4818
6302 Exynos 4412 Sd Card or USB booting 후 바이너리 다운로드 [9] 마빡 2014-02-28 4810
6301 이더넷 관련 질문 [1] 류영렬 2007-04-12 4780
6300 [완료] VGA out 에 대하여 질문 있어요 [5] 임은향 2007-04-11 4717
6299 [완료] lx-800의 능력이 어느 정도일까요? [3] 임은향 2007-04-19 4654
6298 V310 Base소스 구할 수 있을까요? [1] 훌러덩 2011-07-21 4647
6297 aesop-lx800 보드에서 질문있어요 [2] 안문기 2007-04-12 4577
6296 core dump 파일 분석 [1] 이성호 2009-02-17 4562
6295 [완료] USB 메모리에 부팅 CD 이미지 넣기... [1] 정경진 2007-06-09 4537
6294 [질문] LCD_BL_PWM라인에 대해서,[완료] [2] 조영택 2007-04-14 4521
6293 [질문] 공구 LX800 화면 잔상 생김 [6] 구현우 2007-05-07 4478
6292 [완료]pci device관련 [2] 조성철 2007-04-19 4464
6291 부팅시 System UIDs inconsistent 에러에 관해 질문드립니다. [1] 김승한 2009-06-17 4337
6290 lcd interface 관련 [6] 류영렬 2007-05-10 4293
6289 [완료] LCD구입 관련 질문입니다. [2] 박영학 2007-05-02 4265

사용자 로그인