.NET 6 Upgrade#
Warning
From ATLAS (11.4.4.349-W47) and SQL RACE (2.1.25308.1-ci) please see .NET 8 Upgrade
ATLAS client is now updated to .NET 6.
Users will need to consider upgrading any custom plugins or scripts they might have written. Provided the custom ATLAS plugin does not use any .NET Framework libraries that are no longer supported in .NET 6, they should still work with this release of ATLAS, but this is not something we can guarantee. You may find it necessary to recompile against .NET 6.
C##
You may wish to determine any initial portability concerns using the Platform Compatibility Analyzer and .NET Portability Analyzer. For C# there is also the .NET Upgrade Assistant to upgrade projects, this will:
- Upgrade to new project format
- Replace old style packages.config with project file-based package references
- Update dependencies as required to support at least .NET Standard
There might be instances when certain dependencies may have to be updated/replaced, e.g., if it is no longer supported in .NET 6. Useful sites:
Porting Guides#
https://docs.microsoft.com/en-us/dotnet/core/porting/
https://docs.microsoft.com/en-gb/dotnet/core/porting/net-framework-tech-unavailable
https://docs.microsoft.com/en-us/dotnet/standard/library-guidance/cross-platform-targeting
.NET Upgrade Assistants#
https://docs.microsoft.com/en-us/dotnet/core/porting/upgrade-assistant-overview
.NET Portability Analyzer#
https://docs.microsoft.com/en-us/dotnet/standard/analyzers/portability-analyzer
Platform Compatibility Analyzer#
https://docs.microsoft.com/en-us/dotnet/standard/analyzers/platform-compat-analyzer
MATLAB#
Targeting a Specific .NET Version#
MATLAB R2025a or newer#
For MATLAB R2025a or newer, you can target a specific .NET Core version and specify required frameworks directly when initializing the environment. This is especially important if your code or dependencies require assemblies such as Microsoft.Extensions.Caching.Memory, which is included in Microsoft.AspNetCore.App.
Example:
ne = dotnetenv("core", Version="6", Frameworks="Microsoft.AspNetCore.App");
ne = dotnetenv("core", Version="6", Frameworks=["Microsoft.AspNetCore.App", "Microsoft.NETCore.App"]);
MATLAB R2024b and older#
MATLAB versions earlier than 2022b do not support the .NET core runtime.
The default .NET runtime for MATLAB versions 2022b can be configured to .NET Core with the following command
dotnetenv('core')
MATLAB R2024b with .NET 6
MATLAB R2024b has a known issue with .NET6.
To patch:
From a .NET 6 installation, copy ijwhost.dll from
./packs/Microsoft.NETCore.App.Host.win-x64/6.0.XX/runtimes/win-x64/native/ijwhost.dll
into
The runtime configuration file for the .NET runtime can be found
in matlabroot/bin/win64/dotnetcli_netcore.runtimeconfig.json.
With this file, MATLAB loads the latest appropriate assemblies compatible with SQLRace API.
An example configuration for the runtime is provided below.
{
"runtimeOptions": {
"rollForward": "Minor",
"tfm": "net6.0",
"frameworks": [
{
"name": "Microsoft.NETCore.App",
"version": "6.0.0"
},
{
"name": "Microsoft.WindowsDesktop.App",
"version": "6.0.0"
},
{
"name": "Microsoft.AspNetCore.App",
"version": "6.0.0"
}
],
"configProperties": {
"System.Runtime.Serialization.EnableUnsafeBinaryFormatterSerialization": true
}
}
}
More information about calling .NET from MATLAB can be found in the MATLAB documentation.
Python#
The .NET core runtime can be loaded via calling pythonnet.load or configuring the environment variable.
The runtime must be configured before clr is imported, otherwise the default runtime will be initialized and used.
Information on the runtime in use can be retrieved using pythonnet.get_runtime_info()).
Calling pythonnet.load
from pythonnet import load
load("coreclr", runtime_config=r"C:\Program Files\McLaren Applied Technologies\ATLAS 10\MAT.Atlas.Host.runtimeconfig.json")
PYTHONNET_RUNTIME=coreclr
PYTHONNET_CORECLR_RUNTIME_CONFIG=C:\Program Files\McLaren Applied Technologies\ATLAS 10\MAT.Atlas.Host.runtimeconfig.json
More information about calling .NET from Python can be found in the pythonnet documentation.