编译设备而不是模拟器时出现MonoTouch错误:MONO_PATCH_INFO_JIT_ICALL_ADDR mono_marshal_safearray_create

时间:2011-11-08 18:37:44

标签: ios binding crash xamarin.ios armv6

在MonoTouch中,我在编译设备时遇到这个奇怪的错误 (在模拟器上它工作正常,只有在为iPhone编译它时 崩溃):

    Loaded assembly:
    /private/var/mobile/Applications/FC6B7E68-E408-42A9-92A6-BC5AC73B3EEC/MyApp4.app/Mono.Security.dll
    [External]
    Loaded assembly:
    /private/var/mobile/Applications/FC6B7E68-E408-42A9-92A6-BC5AC73B3EEC/MyApp4.app/System.dll
    [External]
    Loaded assembly:
    /private/var/mobile/Applications/FC6B7E68-E408-42A9-92A6-BC5AC73B3EEC/MyApp4.app/monotouch.dll
    [External]
    unknown MONO_PATCH_INFO_JIT_ICALL_ADDR mono_marshal_safearray_create
    * Assertion: should not be reached at ../../../../../mono/mono/mini/mini.c:3179

    Stacktrace:

     at (wrapper managed-to-native)
    object.__icall_wrapper_mono_object_new_fast (intptr) <0xffffffff>

    Native stacktrace:

       0   MyApp4                     0x00628b38 mono_handle_native_sigsegv + 456
       1   MyApp4                     0x006561e4 sigabrt_signal_handler + 168
       2   libsystem_c.dylib                   0x337ed539 _sigtramp + 48
       3   libsystem_c.dylib                   0x337e2f5b pthread_kill + 54
       4   libsystem_c.dylib                   0x337dbfeb abort + 94
       5   MyApp4                     0x007a6310 monoeg_g_logv + 268
       6   MyApp4                     0x007a63e4 monoeg_assertion_message + 80
       7   MyApp4                     0x005fdea0 mono_resolve_patch_target + 2736
       8   MyApp4                     0x0061cd7c mono_aot_plt_resolve + 432
       9   MyApp4                     0x0062b460 mono_aot_plt_trampoline + 88
       10  MyApp4                     0x003948c0 generic_trampoline_aot_plt + 136
       11  MyApp4                     0x00357370
wrapper_runtime_invoke_object_runtime_invoke_dynamic_intptr_intptr_intptr_intptr
+ 200
       12  MyApp4                     0x006013a8 mono_jit_runtime_invoke + 2892
       13  MyApp4                     0x00714dd8 mono_runtime_invoke + 200
       14  MyApp4                     0x0070d6cc mono_runtime_class_init_full + 2060
       15  MyApp4                     0x0070ceb0 mono_runtime_class_init + 28
       16  MyApp4                     0x005fed78 mono_jit_compile_method_inner + 224
       17  MyApp4                     0x005fffa4 mono_jit_compile_method_with_opt + 660
       18  MyApp4                     0x00600bcc mono_jit_runtime_invoke + 880
       19  MyApp4                     0x00714dd8 mono_runtime_invoke + 200
       20  MyApp4                     0x007cc154 monotouch_init + 640
       21  MyApp4                     0x005f71d8 main + 3704
       22  MyApp4                     0x00070b58 start + 52

=================================================================
Got a SIGABRT while executing native code. This usually indicates
a fatal error in the mono runtime or one of the native libraries
used by your application.
=================================================================

这让我很生气。我不知道,崩溃似乎发生在任何代码被调用之前。我在我的项目中使用了两个绑定库(TestFlight和CorePlot),所以这可能与MonoTouch与iPhone的ARMV6架构的互操作编组问题有关。

任何帮助或建议,无论多小,都表示赞赏。 谢谢!

更新: 我可以确认使用实验编译器(在编译设备时在MonoDevelop中设置:LLVM armv7)应用程序工作正常,完全没有崩溃。它似乎真的与MonoTouch的armv6绑定错误有关。但是我需要调试我的App,而LLVM编译器在调试模式下不起作用。有一些解决方法吗?

目前正在讨论Xamarin邮件列表:

http://monotouch.2284126.n4.nabble.com/Native-library-with-Monotouch-5-0-part-2-td3992408.html

1 个答案:

答案 0 :(得分:0)

运行时正在寻找方法mono_marshal_safearray_create(在运行时内),但MonoTouch中不包含该方法,因为它与COM(在iOS上不可用)有关。

这只是猜测,但你在任何地方都有这样的属性:

[MarshalAs (UnmanagedType.SafeArray, ...)]

在您的代码或您正在使用的任何外部库中?请记住,这不是您可以拥有与COM相关的代码的唯一方法。

无论如何,我建议filing a bug,以便可以修复此问题(或者至少有更好的错误报告)。请提供一种方法来重现它(源代码或应用程序本身应该适用于此错误)。