Получение сигнала 11 (SIGSEGV), ошибка addr deadbaad в Android
Я создаю C\C++ нативное приложение для Android, пытаюсь запустить его на Android, но я получаю следующую ошибку:
02-14 14: 05: 40.261: INFO / DEBUG (31): *** *** *** *** *** *** *** *** *** *** *** * ** *** *** *** *** 02-14 14: 05: 40.261: INFO / DEBUG (31): Создание отпечатка пальца: 'generic/sdk/generic/:2.2/FRF91/43546:eng/test-keys' 02-14 14:05:40.280: INFO/DEBUG(31): pid: 467, tid: 467 >>> com.keypoint_tech.adaptxt.inputmethod.core.testAdaptxt <<< 02-14 14:05:40.280: INFO/DEBUG(31): сигнал 11 (SIGSEGV), адрес ошибки deadbaad 02-14 14:05:40.292: INFO/DEBUG(31): r0 00000000 r1 00000000 r2 00000027 r3 00000000 02-14 14:05:40.292: INFO/DEBUG(31): r4 00000000 r5 deadbaad r6 00001728 r7 44f35010 02-14 14:05:40.292: INFO/DEBUG(31): r8 430be000 r9 43170000 10 0000001d fp beb92724 02-14 14:05:40.302: INFO/ ОТЛАДКА (31): ip ffffffff sp beb92448 lr afd154c5 pc afd11dc4 cpsr 40000030 02-14 14:05:40.851: INFO/DEBUG(31): #00 pc 00011dc4 /system/lib/libc.so 02-14 14:05:40.851: INFO/DEBUG(31): #01 pc 00006ecc /system/lib/libcutils.so 02-14 14:05:40.871: INFO/DEBUG(31): код вокруг ПК: 02-14 14:05:40.881: INFO/DEBUG(31): afd11da4 1c2bd00b 2d00682d e026d1fb 2b0068db 02-14 14:05:40.891: INFO/DEBUG(31): afd11db4 4e17d003 51a02001 4d164798 24002227 02-14 14:05:40.891: INFO/DEBUG(31): 2106f2fffff070fdfcfdfdfbb5dfbb5dfbb5dfbbb5dfbbb5dfbbbb5cfbb5cfcfcfcfcfcfcfd: 05: 40.900: INFO / DEBUG (31): afd11dd4 6091aa01 1c116054 94012006 eab6f7fc 02-14 14: 05: 40.910: INFO / DEBUG (31): afd11de4 2200a905 f7fc2002 f7fbeac2 2106ee00 02-14 14: 05: 40: INFO (31): код около lr: 02-14 14: 05: 40.910: INFO / DEBUG (31): afd154a4 b0834a0d 589c447b 26009001 686768a5 02-14 14: 05: 40.910: INFO / DEBUG (31): afd154b4 220ce008 2b005eab 1 888 099 02-14 14: 05: 40.922: INFO / DEBUG (31): afd154c4 35544306 d5f43f01 2c006824 b003d1ee 02-14 14: 05: 40.922: INFO / DEBUG (31): afd154d4 bdf01c30 0002ae7c 000000d4 1c0f.9 40 05: 0: INFO / DEBUG (31): afd154e4 43551c3d a904b087 1c16ac01 604d9004 02-14 14: 05: 40.922: INFO / DEBUG (31): стек: 02-14 14:05:40.932: INFO/DEBUG(31): beb92408 000006fd 02-14 14:05:40.961: INFO/DEBUG(31): beb9240c afd1453b /system/lib/libc.so 02-14 14:05:40.961: INFO/DEBUG(31): beb92410 afd40498 /system/lib/libc.so 02-14 14:05:40.961: INFO/DEBUG(31): beb92414 afd41c14 /system/lib/libc.so 02-14 14:05:40.961: INFO/DEBUG(31): beb92418 00000000 02-14 14:05:40.961: INFO/DEBUG(31): beb9241c afd154c5 /system/lib/libc.so 02-14 14:05:40.961: INFO/DEBUG(31): beb92420 6f737265 02-14 14:05:40.981: INFO/DEBUG(31): beb92424 afd1450d /system/lib/libc.so 02-14 14:05:40.981: INFO/DEBUG(31): beb92428 50776569 02-14 14:05:40.981: INFO/DEBUG(31): beb9242c afd40328 /system/lib/libc.so 02-14 14:05:40.981: INFO/DEBUG(31): beb92430 00000000 02-14 14:05:40.981: INFO/DEBUG(31): beb92434 00001728 02-14 14:05:40.981: INFO/DEBUG(31): beb92438 44f35010 /dev/ashmem/mspace/dalvik-heap/2 (удалено) 02-14 14:05:40.991: INFO/DEBUG(31): beb9243c afd147ab /system/lib/libc.so 02-14 14:05:40.991: INFO/DEBUG(31): beb92440 df002777 02-14 14:05:40.991: INFO/DEBUG(31): beb92444 e3a070ad 02-14 14:05:41.002: INFO/DEBUG(31): #00 beb92448 696a202c 02-14 14:05:41.002: INFO/DEBUG(31): beb9244c 202c746e 02-14 14:05:41.002: INFO/DEBUG(31): beb92450 746e696a 02-14 14:05:41.002: INFO/DEBUG(31): beb92454 696a202c 02-14 14:05:41.012: INFO/DEBUG(31): beb92458 2029746e 02-14 14:05:41.012: INFO/DEBUG(31): beb9245c fffffbdf 02-14 14:05:41.012: INFO/DEBUG(31): beb92460 beb9264c [стек] 02-14 14:05:41.012: INFO/DEBUG(31): beb92464 400092e8 /dev/ashmem/mspace/dalvik-heap/zygote/0 (удалено) 02-14 14:05:41.012: INFO/DEBUG(31): beb92468 00000002 02-14 14:05:41.012: INFO/DEBUG(31): beb9246c af906ecf /system/lib/libcutils.so 02-14 14:05:41.031: INFO/DEBUG(31): #01 beb92470 beb9264c [стек] 02-14 14:05:41.031: INFO/DEBUG(31): beb92474 af906ecf /system/lib/libcutils.so 02-14 14:05:41.041: INFO/DEBUG(31): beb92478 00001893 02-14 14:05:41.052: INFO/DEBUG(31): beb9247c beb9264c [стек] 02-14 14:05:41.052: INFO/DEBUG(31): beb92480 400092e8 /dev/ashmem/mspace/dalvik-heap/zygote/0 (удалено) 02-14 14:05:41.052: INFO/DEBUG(31): beb92484 45168728 /dev/ashmem/mspace/dalvik-heap/2 (удалено) 02-14 14:05:41.052: INFO/DEBUG(31): beb92488 0000005f 02-14 14:05:41.052: INFO/DEBUG(31): beb9248c 8084a30f /system/lib/libdvm.so 02-14 14:05:41.052: INFO/DEBUG(31): beb92490 44f35018 /dev/ashmem/mspace/dalvik-heap/2 (удалено) 02-14 14:05:41.070: INFO/DEBUG(31): beb92494 00000063 02-14 14:05:41.070: INFO/DEBUG(31): beb92498 474f6028 02-14 14:05:41.070: INFO/DEBUG(31): beb9249c 00000063 02-14 14:05:41.080: INFO/DEBUG(31): beb924a0 00000063 02-14 14:05:41.091: INFO/DEBUG(31): beb924a4 beb924d0 [стек] 02-14 14:05:41.091: INFO/DEBUG(31): beb924a8 40009408 /dev/ashmem/mspace/dalvik-heap/zygote/0 (удалено) 02-14 14:05:41.091: INFO/DEBUG(31): beb924ac 8081c020 /system/lib/libdvm.so 02-14 14:05:41.102: INFO/DEBUG(31): beb924b0 00008cdc /system/bin/app_process 02-14 14:05:41.112: INFO/DEBUG(31): beb924b4 00002337 02-14 14:05:42.000: INFO/WindowManager(59): WIN DEATH: Window{44f9e8f0 com.keypoint_tech.adaptxt.inputmethod.core.testAdaptxt/com.keypoint_tech.adaptxt.inputmethod.core.testAdaptxt.TestAdaptxt paused=false} 02-14 14:05:42.012: INFO/ActivityManager(59): процесс com.keypoint_tech.adaptxt.inputmethod.core.testAdaptxt (pid 467) завершен. 02-14 14:05:42.121: INFO/BootReceiver(59): копирование /data/tombstones/tombstone_06 в DropBox (SYSTEM_TOMBSTONE) 02-14 14:05:42.191: INFO/UsageStats(59): неожиданное резюме com.android.launcher уже возобновлен в com.keypoint_tech.adaptxt.inputmethod.core.testAdaptxt 02-14 14:05:42.271: WARN/InputManagerService(59): Получено RemoteException, отправляющее уведомление setActive(false) на pid 467 uid 10032
Я пытался использовать arm-eabi-addr2line
с адресом 0001072a
чем я получил следующий результат
/usr/local/google/home/digit/android/main/cupcake/android/bionic/libc/unistd/brk.c:45
Я получаю это для всех платформ: Android 1.6, 2.1 и 2.2.
Моя программа получает сбой, когда я пытаюсь получить значения из буфера, который заполнен на стороне JNI.
Вот следующий код, который я использую, чтобы получить значение из заполненного буфера стороны JNI.
for(int j = 0; j < count; j++)
{
len = outBuf.getInt();
CharBuffer cbuf = outBuf.asCharBuffer();
CharSequence cS = cbuf.subSequence(0, len);
wordsPage[j] = cS.toString();
outBuf.position(outBuf.position()+ (len*2));
}
И не могли бы вы рассказать мне какой-нибудь механизм полного доказательства для разделения памяти между Java и JNI.
1 ответ
Какой ваш wordsPage
размер? Есть ли какие-либо проблемы с индексом? Предложить вам включить dalvik.vm.checkjni=true
и увидеть больше информации.