gpt4 book ai didi

debugging - Android NDK调试: device can't be opened

转载 作者:行者123 更新时间:2023-12-04 05:02:41 25 4
gpt4 key购买 nike

我现在正在尝试调试我的 native 库一段时间,但它不起作用。 native 代码可以运行并编译,但出于优化目的,我真的需要调试 native 代码。

我已经逐步阅读并遵循了许多教程(例如 tutorial1tutorial2 ),但是我遇到了一些找不到解决方案的错误。

我已经设置了 Android 和 C++ 调试配置,在我使用 Android 调试配置进行调试后,它在加载库(只有一个)后遇到断点。我去 cygwin 看看我的设备是否被检测到(它是)。然后运行:

$ ndk-gdb --start --verbose

这给了我以下输出:
Android NDK installation path: /cygdrive/c/Android/android-ndk/android-ndk-r8
Using default adb command: /cygdrive/c/Android/android-sdk/platform-tools/adb
ADB version found: Android Debug Bridge version 1.0.29
Using ADB flags:
Using auto-detected project path: .
Found package name: com.mypackage
ABIs targetted by application: armeabi-v7a
Device API Level: 15
Device CPU ABIs: armeabi-v7a armeabi
Compatible device ABI: armeabi-v7a
Using gdb setup init: ./libs/armeabi-v7a/gdb.setup
Using toolchain prefix: /cygdrive/c/Android/android-ndk/android-ndk-r8/toolchains/arm-linux-androideabi-4.4.3/prebuilt/windows/bin/arm-linux-androideabi-
Using app out directory: ./obj/local/armeabi-v7a
Found debuggable flag: true
Found device gdbserver: /data/data/com.mypackage/lib/gdbserver
Found data directory: '/data/data/com.mypackage'
Found first launchable activity: .MainActivity
Launching activity: com.mypackage/.MainActivity
## COMMAND: /cygdrive/c/Android/android-sdk/platform-tools/adb shell am start -n com.mypackage/.MainActivity
Starting: Intent { cmp=com.mypackage/.MainActivity }
## COMMAND: /cygdrive/c/Android/android-sdk/platform-tools/adb shell sleep 2
Found running PID: 6907
Launched gdbserver succesfully.
Setup network redirection
## COMMAND: /cygdrive/c/Android/android-sdk/platform-tools/adb shell run-as com.mypackage lib/gdbserver +debug-socket --attach 6907
## COMMAND: /cygdrive/c/Android/android-sdk/platform-tools/adb forward tcp:5039 localfilesystem:/data/data/com.mypackage/debug-socket
Attached; pid = 6907
Could not open remote device: Invalid argument.
Detaching process(es): 6907
## COMMAND: /cygdrive/c/Android/android-sdk/platform-tools/adb pull /system/bin/app_process obj/local/armeabi-v7a/app_process
2405 KB/s (9852 bytes in 0.004s)
Pulled app_process from device/emulator.
## COMMAND: /cygdrive/c/Android/android-sdk/platform-tools/adb pull /system/lib/libc.so obj/local/armeabi-v7a/libc.so
4994 KB/s (286412 bytes in 0.056s)
Pulled libc.so from device/emulator.

User@This-PC /cygdrive/c/Development/MyAppAndroid/trunk/MyApp
$

可以看到gdbserver已经启动成功了,很好,但是不知道为什么会这样:
Could not open remote device: Invalid argument

因为 adb 可以连接到设备(如之前测试过的)。在那之后,在我看来(我不太熟悉 cygwin)gdb 只是关闭了所有东西,这也会使 eclipse 中的 c++ 调试失败。当我运行它时,出现以下错误:
76-target-select remote localhost:5039
&"Remote communication error: Bad file descriptor.\n"
Remote communication error: Bad file descriptor.
76^error,msg="Remote communication error: Bad file descriptor."

有什么可以阻止我的设备被 adb 检测到的吗?我一直使用这个设备进行测试(没有 C++ 调试),没有问题。

还是问题出在端口错误上?

最佳答案

我遇到了同样的问题,所以我在 ndk-gdb 文件中替换了以下几行:

原文:

run adb_cmd shell run-as $PACKAGE_NAME lib/gdbserver +$DEBUG_SOCKET --attach $PID & 

替换:
run adb_cmd shell run-as $PACKAGE_NAME lib/gdbserver tcp:5888 --attach $PID & 

和原文:
run adb_cmd forward tcp:$DEBUG_PORT localfilesystem:$DATA_DIR/$DEBUG_SOCKET 

替换:
run adb_cmd forward tcp:5039 tcp:5888

修复了“无效参数”问题。

P。

关于debugging - Android NDK调试: device can't be opened,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15938848/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com