Search code examples
iosunity-game-engineil2cpp

Can't link iOS project with il2cpp and Unity


any of you know what is happening with my project ?

There is this error:

ld: symbol(s) not found for architecture arm64

unity_ios

Unity Player Settings is like this:

player_settings


Solution

  • IL2CPP is the only scripting backend to support deploying to ARM 64-bit on iOS, and is thus mandatory to deploy to the Apple app-store for releasing new apps.

    There iOS 64 bit Upgrade guide provided by Unity which states that

    How to start using IL2CPP on iOS

    Pick it in Scripting Backend dropdown in Player Settings.

    enter image description here

    By default it will build for Universal architecture (including both ARM64 and ARMv7), if needed you might switch to specific architecture in Player Settings. There is number of things that should be done before your application is up and running in 64 bits:

    • You need 64 bit capable device to test on. These are all iOS devices with A7 or later chip (currently these are: iPhone 5S, iPad Air, iPad Mini Retina, iPhone 6, iPhone 6 Plus, iPad Mini 3, iPad Air 2).
    • You need all your native plugins to be compiled with 64 bit support (or be provided as source code). If you are using 3rd party plugin, you should contact your plugin vendor to obtain 64 bit capable and IL2CPP compatible version of that plugin. At the moment all latest Prime31 plugins are known to be good.
    • If you are the plugin vendor or just have your own native plugins then you need keep couple of things in mind:

    (1) IL2CPP is not API-compatible (which is unexposed) with the Mono Runtime API, which means if plugin is using mono_* functions won’t link anymore. The best way to resolve this issue is to switch to managed delegate/callback approach and pass your managed callbacks to the native side of plugin and call them back from there when some native data or event arrives.

    (2) All plugins that come as precompiled static libraries (.a files) should now include ARM64 slice.

    (3) When doing native code/type conversion keep in mind that pointers and longs are now 64 bit wide and ints are still 32 wide.

    • To minimise generated amount of C++ code IL2CPP is always (even when Stripping level is set to Disabled) doing some sort of managed code stripping. Sometimes you will need to help it. Look for link.xml guide in iOS player size optimization manual.

    Troubleshooting

    1. Q: My code is running slower on IL2CPP than on Mono. Why? A: Make sure you are testing your code performance in Xcode Release configuration. If issue still remains, please submit a bugreport!
    2. Q: Unity generated Xcode project fails to compile with following or similar error: Method not found: 'Default constructor not found...ctor() of System.ComponentModel.Int64Converter'. A: Deserializers and serializers often reference some types only via .NET Reflection API and in such cases these methods or even classes might be stripped from project. You can hint managed code stripper that specific class / method is used either via link.xml or via introduction of dummy code that explicitly references it in one of your scripts.
    3. Q: Unity generated Xcode project fails to compile with some other error. A: Please verify if all your plugins support ARM64 and IL2CPP and if that’s the case please submit a bug report and attach your project (or just scripting part of it) to the bug report. Thanks!