데이터 베이스 MySQL 튜토리얼 TI Omap37xx 系列MPU调试 SE4500扫描头2D扫软解记录

TI Omap37xx 系列MPU调试 SE4500扫描头2D扫软解记录

Jun 07, 2016 pm 03:07 PM
스캐닝 시리즈 디버그

虽然摩托罗拉现在也出售给了斑马公司,但针对行业设备的支持还说的过去,但是网上针对SE4500在TI Omap平台的调试文章少之又少,不信你随便搜搜互联网。 公司使用的是TI(德州仪器)公司提供的方案Omap37xx系列Mpu,系统是WM6.5(Windows Mobile 6.5.3)的,调试

       虽然摩托罗拉现在也出售给了斑马公司,但针对行业设备的支持还说的过去,但是网上针对SE4500在TI Omap平台的调试文章少之又少,不信你随便搜搜互联网。

       公司使用的是TI(德州仪器)公司提供的方案Omap37xx系列Mpu,系统是WM6.5(Windows Mobile 6.5.3)的,调试到SE4500的时候,开始是I2C问题,I2C死活不通,后来解决了I2C读写问题,但是在上层应用层调用对应的API获取图像数据,就直接崩溃了,但是地址打印出来,还是可以看到对应的地址的,但是使用IsBadPtr测试该指针以后,不可以读,只要一读,直接崩溃(data abort)。

       这个问题是这样的,需要修改摩托罗拉提供的驱动程序的部分代码,修改基本上如下:

       驱动添加根据Motorola\Motorola Software Decode SDK for ARM\Drivers\TI\cam_SE4500\WM65 目录下的readme.txt操作,

在对应的drvr_intf.cpp源文件的CAM_IOControl()函数中,具体修改如下:

<pre name="code" class="cpp">	case SE45_IOCTL_ALLOC_BUFFER:
		if ((pBufOut == NULL) || (dwLenOut dwBufferCount - 1) * sizeof(DWORD))) ||
				(pdwActualOut == NULL))
		{
			dwReturn = ERROR_INVALID_PARAMETER;
			goto BadParameter;
		}
		else
		{
			UINT i, nOutputByteCount;
			PSE45_ALLOC_BUF_REQ pAllocReq;
			HANDLE hCaller;
			PBYTE pVirtAddr;
			//wince5.0.2内核限制,所以必须增加该判断
#if (_WINCEOSVERdwBufferCount - 1) * sizeof(DWORD);
#if (CE_VERSION == 5)
			//hCaller = GetOwnerProcess();
			//为什么要注释掉上面一行代码,改成下面这行?因为调用的同时,他们应该是同一进程地址空间
			hCaller = GetCurrentProcess();
			pAllocReq = (PSE45_ALLOC_BUF_REQ )MapCallerPtr( pBufOut, nOutputByteCount );
#endif
#if ((CE_VERSION == 6) || (CE_VERSION == 7))
//			hCaller = OpenProcess(0, FALSE, GetCallerVMProcessId());
			hCaller = OpenProcess(0, FALSE, GetDirectCallerProcessId());
			// CE 6 automatically marshals the IOCTL parameters mapCallerPtr() is obsolete
			pAllocReq = (PSE45_ALLOC_BUF_REQ)pBufOut;
#endif
			if (NULL == pAllocReq)
			{
				dwReturn = ERROR_INVALID_PARAMETER;
				goto BadParameter;
			}

			// Reset the user buffers in the low level driver
			camera_reset_buffers(pDev);

			pAllocReq-&gt;nNumBuffers = pDev-&gt;dwBufferCount;
			pAllocReq-&gt;nBufferSize = pDev-&gt;dwBufferSize;
			// Save the caller handler
			pDev-&gt;dstProcess = hCaller;
			/* return a list of buffer start addresses mapped to caller's process space */
			for (i = 0; i dwBufferCount; i++)
			{
				if (camera_get_buffer_addr(pDev, i, &amp;pVirtAddr))
				{
#if (CE_VERSION == 5)
					pAllocReq-&gt;ppBuffers[i] = (DWORD )MapPtrToProcess(pVirtAddr, hCaller);
#endif
#if ((CE_VERSION == 6) || (CE_VERSION == 7))
					pAllocReq-&gt;ppBuffers[i] = (DWORD)VirtualAllocCopyEx(GetCurrentProcess(), hCaller,
						pVirtAddr, pDev-&gt;dwBufferSize, PAGE_READWRITE);
#endif
					// Save it in the driver context for freeing this memory later
					pDev-&gt;baseAddr[i] = pAllocReq-&gt;ppBuffers[i];
				}
				else
				{
					pVirtAddr = NULL;
					pAllocReq-&gt;ppBuffers[i] = (DWORD)NULL;
				}
				DEBUGMSG(ZONE_IOCTL, (TEXT("SE4500 : App:0x%x mapped from Kernel:0x%x\r\n"),pAllocReq-&gt;ppBuffers[i], pVirtAddr));
			}
			*pdwActualOut = sizeof(DWORD) * (pDev-&gt;dwBufferCount - 1) +
							sizeof(SE45_ALLOC_BUF_REQ);
#if (_WINCEOSVER<br>

<pre class="brush:php;toolbar:false">
로그인 후 복사

       后来就考虑直接在系统驱动里面,将获取到的图像直接保存到文件,这里似乎有一个问题,保存文件操作是在单独的一个线程里面做的,是异步操作,有可能出现保存数据只有部分的情况。经过多次测试,传输过来的图像752 x 480分辨率始终是条纹状,要么颜色不对,基本上都是如下图像:

     TI Omap37xx 系列MPU调试 SE4500扫描头2D扫软解记录

TI Omap37xx 系列MPU调试 SE4500扫描头2D扫软解记录

TI Omap37xx 系列MPU调试 SE4500扫描头2D扫软解记录


       在驱动图像帧回调函数中保存了这些图片,基本上过来30多张只有一两张还能看得到图像,其他基本上都是斜的条纹,颜色明显不对,正常的颜色是应该是黑白单色。后来查硬件问题,发现是PCLK的电平转换芯片的最大支持频率不够,和其他公司一样,你使用TI的方案,那周边的什么PMIC,电平转换芯片等等都用他的,做高通、MTK的也都一个样。

       本来用的是TXS0104/08针对SE4500的PCLK过来的3.3V电平,转换成1.8V的提供给Omap37xx,结果发现TXS0104/08在Vcca为1.8V时最大支持的data rate只有24Mbps(参考该电平转换芯片手册),远远不够。

       前前后后折腾了几个月,没有解决这个问题,后来换成了TXB0104/08系列电平转换芯片,用了摩托提供的C#写成的SDL_GUI测试程序,SE4500出光了以后直接就解码了。

         至此,问题已经得到解决,但是总结一点。也许是TI针对大多数的应用场景,根本不需要多高的数据速率,只是简单的电平转换而已,但是用在视频传输上,电平转换的芯片选择就尤为重要了,速率不对,传过来的数据就有可能是错的。芯片选型的时候,一定要充分考虑它的应用场景。

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

뜨거운 기사 태그

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

C++ 함수 디버깅에 대한 자세한 설명: 다중 스레드 함수의 문제를 디버깅하는 방법은 무엇입니까? C++ 함수 디버깅에 대한 자세한 설명: 다중 스레드 함수의 문제를 디버깅하는 방법은 무엇입니까? May 02, 2024 pm 04:15 PM

C++ 함수 디버깅에 대한 자세한 설명: 다중 스레드 함수의 문제를 디버깅하는 방법은 무엇입니까?

LeakSanitizer를 사용하여 C++ 메모리 누수를 디버깅하는 방법은 무엇입니까? LeakSanitizer를 사용하여 C++ 메모리 누수를 디버깅하는 방법은 무엇입니까? Jun 02, 2024 pm 09:46 PM

LeakSanitizer를 사용하여 C++ 메모리 누수를 디버깅하는 방법은 무엇입니까?

Xiaomi 15 시리즈 전체 코드명 공개: Dada, Haotian, Xuanyuan Xiaomi 15 시리즈 전체 코드명 공개: Dada, Haotian, Xuanyuan Aug 22, 2024 pm 06:47 PM

Xiaomi 15 시리즈 전체 코드명 공개: Dada, Haotian, Xuanyuan

golang 함수 디버깅 및 분석 바로가기 golang 함수 디버깅 및 분석 바로가기 May 06, 2024 pm 10:42 PM

golang 함수 디버깅 및 분석 바로가기

화웨이 메이트 60 시리즈 구매 최적기, 새로운 AI 제거 + 이미지 업그레이드, 가을 프로모션 즐기기 화웨이 메이트 60 시리즈 구매 최적기, 새로운 AI 제거 + 이미지 업그레이드, 가을 프로모션 즐기기 Aug 29, 2024 pm 03:33 PM

화웨이 메이트 60 시리즈 구매 최적기, 새로운 AI 제거 + 이미지 업그레이드, 가을 프로모션 즐기기

Java 동시 프로그래밍에서 동시성 테스트 및 디버깅을 수행하는 방법은 무엇입니까? Java 동시 프로그래밍에서 동시성 테스트 및 디버깅을 수행하는 방법은 무엇입니까? May 09, 2024 am 09:33 AM

Java 동시 프로그래밍에서 동시성 테스트 및 디버깅을 수행하는 방법은 무엇입니까?

PHP 디버깅 오류: 일반적인 실수에 대한 가이드 PHP 디버깅 오류: 일반적인 실수에 대한 가이드 Jun 05, 2024 pm 03:18 PM

PHP 디버깅 오류: 일반적인 실수에 대한 가이드

PHP 비동기 코드를 디버깅하는 방법 PHP 비동기 코드를 디버깅하는 방법 May 31, 2024 am 09:08 AM

PHP 비동기 코드를 디버깅하는 방법

See all articles