2012-04-12 5 views
1

OMAP-L138 Exp Kit을 사용합니다. 먼저 내 U 부팅 속성을 확인하십시오. 이c6accel 샘플 실행 후 세그먼트 오류 오류

그들은 다음과 같습니다

U-Boot > printenv 
    baudrate=115200 
    autoload=no 
    bootcmd=run netboot 
    bootfile=uImage-da850-omapl138-evm.bin 
    filesize=204104 
    fileaddr=C0700000 
    rootpath=/home/my_name/targetfs 
    netboot=tftpboot 0xc0700000 uImage-da850-omapl138-evm.bin; bootm 0xc0700000 
    bootargs=console=ttyS2,115200n8 mem=64M root=/dev/nfs rw nfsroot=192.168.1.218:/home/my_name/targetfs ip=192.168.1.231 
    netargs=console=ttyS2,115200n8 noinitrd rw mem=64M root=/dev/nfs rw nfsroot=192.168.1.218:/home/my_name/targetfs,nolock ip=192.168.1.231 
    stdin=serial 
    stdout=serial 
    stderr=serial 
    ver=U-Boot 2009.11 (Jan 13 2011 - 01:05:37) 
    Environment size: 728/65532 bytes 

는 DVSDK의 setup.sh에서 나는 다음 매개 변수를 사용 : 보드 메모리 64메가바이트, 리눅스 커널 위치 - TFTP, 루트 파일 시스템 위치 - NFS. DVSDK 만들기가 성공적이었습니다. c6accel_1_01_00_07 디렉토리에도 설치했습니다.

[email protected]_name-desktop:/usr/local/dvsdk/c6accel_1_01_00_07# make install 
Creating /home/my_name/targetfs/c6accel_app 
Copying kernel modules to target file system: /home/my_name/targetfs/c6accel_app/ 
Copying cmemk.ko 
Copying dsplinkk.ko 
Copying c6accel codec servers from /usr/local/dvsdk/c6accel_1_01_00_07 
Copying c6accel test app from /usr/local/dvsdk/c6accel_1_01_00_07 
Copying testfile from /usr/local/dvsdk/c6accel_1_01_00_07 

이제 C6accel 샘플을 실행하고 싶습니다. 그래서 목표를 재설정했습니다. 오, 그게 뭐죠?

CMEM Range Overlaps Kernel Physical - allowing overlap 
CMEM phys_start (0xc2000000) overlaps kernel (0xc0000000 -> 0xc4000000) 
CMEMK Error: Failed to request_mem_region(0xc2000000, 18874368) 
FATAL: Error inserting cmemk (/lib/modules/2.6.37/kernel/drivers/dsp/cmemk.ko): Bad address 

확인. I 을 무시하고 login을 입력하십시오.

[email protected]:/c6accel_app# ls 
benchmarking.txt     dsplinkk.ko 
c6accel_app      loadmodules_omapl138_c6accel.sh 
c6accel_omapl138.x674   test_files 
cmemk.ko 

[email protected]:/c6accel_app# ./loadmodules_omapl138_c6accel.sh 
    CMEMK module: built on Apr 12 2012 at 17:32:52 
     Reference Linux version 2.6.37 
     File /usr/local/dvsdk/linuxutils_2_26_02_05/packages/ti/sdo/linuxutils/cmem/src/module/cmemk.c 
    CMEM Range Overlaps Kernel Physical - allowing overlap 
    CMEM phys_start (0xc2000000) overlaps kernel (0xc0000000 -> 0xc4000000) 
    CMEMK Error: Failed to request_mem_region(0xc2000000, 18874368) 
    FATAL: Error inserting cmemk (/lib/modules/2.6.37/kernel/drivers/dsp/cmemk.ko): Bad address 

다시 같은 오류가 발생했습니다.

는 파일 loadmodules_omapl138_c6accel.sh에서 나는 finnaly 내가

modprobe cmemk phys_start=0xC4000000 phys_end=0xC5200000 pools=20x4096 allowOverlap=1 

그것을 저장 한, 그래서 하나의 문자열을

modprobe cmemk phys_start=0xC2000000 phys_end=0xC3200000 pools=20x4096 allowOverlap=1 

를 수정했습니다. 시도 2.

[email protected]:/c6accel_app# ./loadmodules_omapl138_c6accel.sh 
CMEMK module: built on Apr 12 2012 at 17:32:52 
    Reference Linux version 2.6.37 
    File /usr/local/dvsdk/linuxutils_2_26_02_05/packages/ti/sdo/linuxutils/cmem/src/module/cmemk.c 
allocated heap buffer 0xc5000000 of size 0x11ec000 
cmemk initialized 

성공!가 그럼 난 .... 일찍

Test for Arithmetic RTS functions successful 
****************************************************************************** 
All tests done. 
****************************************************************************** 

libgcc_s.so.1 must be installed for pthread_cancel to work 

하지만를보고 행복했다

을 ./c6accel_app 실행

[email protected]:/c6accel_app# ls 
Segmentation fault 

뭔가 끊었다. 그것은 완전히 망가졌습니다. 이 경우 어떻게해야합니까? 고맙습니다.

답변

0

개통 쉽게 열 ...

장치에는 64MB RAM이 있습니다. 이 명령

bootargs=console=ttyS2,115200n8 mem=64M root=/dev/nfs rw nfsroot=192.168.1.218:/home/my_name/targetfs ip=192.168.1.231 

함으로써 단순히 "좋아, 커널, 모두를 가지고 그것은 모두 당신."라고

그래서 ... 내가 원하는 걸 얻었 : 32메가바이트 - 커널을. 기타 CMEM의 경우 32MB. 세그먼트 화 오류가 없습니다.