Skip to content

Commit

Permalink
Browse files Browse the repository at this point in the history
## [2.0.0-exp.6] - 2022-09-02

### Fixes
* Fixed changelog.

## [2.0.0-exp.5] - 2022-09-01

### New features
* Preliminary WebSocket support. To have a `NetworkDriver` use WebSockets, create it with the appropriate network interface (e.g. `NetworkDriver.Create(new WebSocketNetworkInterface())`). To enable TLS support, create the driver with `NetworkSettings` configured with `WithSecureClientParameters`/`WithSecureServerParameters` (on the client, only the hostname needs to be provided).
* `NetworkSettings.WithSecureClientParameters` and `NetworkSettings.WithSecureServerParameters` now have versions where the certificates and hostnames are provided as normal strings, instead of fixed strings.

### Changes
* `Protocol` field was removed from the `SecureNetworkProtocolParameter` structure. The protocol is now determined automatically from the network interface being used.
* Updated to Collections 2.1.0-exp.1
* `FragmentationPipelineStage.FragContext` was made internal as it is an internal implementation detail that serves no purpose being exposed publicly.
* Multiple APIs were removed or made internal in `ReliableUtility` (more than is practical to list here). These were all internal implementation details that served no purpose being exposed publicly. The only remaining public APIs in `ReliableUtility` are those used to gather statistics from a reliable pipeline (as demonstrated in the Soaker sample).
* All APIs except `Parameters` and `Context` in `SimulatorUtility` were made internal as they are implementation details that serve no purpose being exposed publicly.
* It is no longer possible to configure the read timeout in the secure parameters as values other than the default (0) were never properly supported.
* It is no longer possible to configure the handshake minimum/maximum timeouts in the secure parameters. These values are now derived from the `connectTimeoutMS` and `maxConnectAttempts` values configured with `NetworkSettings.WithNetworkConfigParameters`.
* Hostnames in secure parameters are now `FixedString512Bytes` instead of `FixedString32Bytes`, allowing any possibly hostname to be used instead of only short ones.
* `NetworkSendQueueHandle` was removed. It was not used for anything anymore (previously it was used for custom implementations of `INetworkInterface`).
* `NetworkInterfaceSendHandle` and `SendHandleFlags` were made internal. With the removal of `NetworkSendInterface`, these served no purpose anymore.
* `INetworkInterface.Initialize` now receives a `ref packetPadding` parameter that can be increased to reserve space for headers.
* `BaselibNetworkInterface` was renamed to `UDPNetworkInterface`.

### Fixes
* Fixed an issue where when sending data on a connection and closing that connection in the same update, the data message would not be sent properly.
* Fixed a stack overflow exception when send/receive queue capacity was set very high (>10,000).
* Fixed an issue where `SimulatorPipelineStage` would always use the same seed for its random number generator.

### Upgrade guide

## [2.0.0-exp.4] - 2022-08-03

### New features
* A new global network simulator has been added, configurable through `NetworkSettings.WithNetworkSimulatorParameters` (settings can be modified at runtime with `NetworkDriver.ModifyNetworkSimulatorParameters`). Unlike `SimulatorPipelineStage`, it applies its parameters to _all_ traffic (including control messages). Note that it is currently _much_ less featureful than `SimulatorPipelineStage` (only supports dropping packets for now), so we still recommend using the latter for all network simulation.
* Added a new `NetworkDriver.ModifySimulatorStageParameters` API to modify the parameters of the `SimulatorPipelineStage` at runtime.
* `NetworkDriver` now exposes the `NetworkSettings` currently in use through the `CurrentSettings` property. These settings are read-only.
* To implement the above functionality, `NetworkSettings` now provides a `AsReadOnly` method that returns a read-only copy of the settings.

## [2.0.0-exp.3] - 2022-07-11

### New features

### Changes
* Updated to Burst 1.7.3.
* Changed: A call to `NetworkDriver.Disconnect` now requires a subsequent call to `NetworkDriver.Update` for the disconnect packet to be effectively sent (Previously `NetworkDriver.FlushSend` was enough).
* Changed: The protocol used to establish connections now supports protocol versioning. This should help maintain compatibility for future releases, but unfortunately it's now incompatible with the protocol used in version 1.X.

### Fixes

### Upgrade guide
* For `NetworkDriver.FlushSend` calls that follows a call to `NetworkDriver.Disconnect`, change it to `NetworkDriver.Update`.
* The communication protocol used to establish connections has had a breaking change and is now incompatible with Unity Transport 1.X. Clients and servers will need to be updated at the same time to maintain compatibility.

## [2.0.0-exp.2] - 2022-06-07

### New features
* Added a new version of `NetworkDriver.CreatePipeline` that takes a `NativeArray` of `NetworkPipelineStageId` as an argument. The old version taking an array of `Type` objects is still fully supported.

### Changes
* Removed: `NetworkSettings.WithDataStreamParameters` has been deleted. The data stream size (the only parameter this API controlled) is now always dynamically-sized to avoid out-of-memory errors.
* Removed: `NetworkSettings.WithPipelineParameters` has been deleted. Initial sizing of the pipeline buffers is now handled internally.
* Removed: `NetworkPipelineStageCollection` has been deleted. See upgrade guide below for details of how to replace its usages.
* Updated to Collections 2.0.0-pre.32.
* Updated to Burst 1.7.2.
* Removed: `NetworkDriver.LastUpdateTime` has been deleted. This value was an internal detail not meant to be consumed by users, and its time reference couldn't be reliably related to typical C# timestamps.

### Fixes
* Removed an error log when receiving messages on a closed DTLS connection (this scenario is common if there were in-flight messages at the moment of disconnection).
* `BeginSend` would not return an error if called on a closed connection before the next `ScheduleUpdate` call.
* Fix broken link in package documentation.
* On iOS, recreate the socket used for communications when coming back from app suspension. This solves an issue where communications would fail after the app was in the background for a few seconds and iOS decided to reclaim its resources.

### Upgrade guide
* Registering custom pipeline stages is now done on a per-`NetworkDriver` basis rather than globally through `NetworkPipelineStageCollection`. Concretely, that means replacing calls to `NetworkPipelineStageCollection.RegisterPipelineStage` with calls to `NetworkDriver.RegisterPipelineStage` for each instance of `NetworkDriver` that will make use of the custom pipeline stage.
* `NetworkPipelineStageId` is now obtained through the static `NetworkPipelineStageId.Get` method, rather than with `NetworkPipelineStageCollection.GetStageId`. Updating only requires replacing calls like `NetworkPipelineStageCollection.GetStageId(typeof(Foo))` with `NetworkPipelineStageId.Get<Foo>()`.
* `NetworkDriver.LocalEndPoint` and `NetworkDriver.RemoteEndPoint` were renamed to `NetworkDriver.GetLocalEndpoint` and `NetworkDriver.RemoteEndpoint`, respectively. This should be updated automatically.
* `INetworkInterface.LocalEndPoint` has been renamed to `INetworkInterface.LocalEndpoint` for consistency with other usages of the term in the API. Since this is an interface property, it must be manually updated (see upgrade guide below).
* Custom implementations of `INetworkInterface` must now implement the `LocalEndpoint` property instead of `LocalEndPoint`. This is purely a change in naming, the behavior should remain the same as before.

## [2.0.0-exp.1] - 2022-04-29

### New features
* Added automatic device reconnection (enabled by default). This feature will attempt to re-establish the connection after some inactivity. This feature is intended to handle IP address changes on mobile devices. The inactivity timeout can be controlled by the new parameter `reconnectionTimeoutMS` in `NetworkConfigParameter`. Setting it to 0 disabled the feature.
* When using the Relay protocol, error messages sent by the Relay server are now properly captured and logged.
* `PacketsQueue` and `PacketProcessor` APIs were added for sending and operating over packets in the `INetworkInterface`.
* A `GetRelayConnectionStatus` method has been added to `NetworkDriver` to query the status of the connection to the Relay server.

### Changes
* Updated to Collections 2.0.0-pre.15
* Updated to Burst 1.7.1.
* Updated to Mathematics 1.2.6.
* Minimal Unity Editor version supported is now 2022.2.0a11.
* Added `NetworkSettings` struct and API for defining network parameters.
* Added `reconnectionTimeoutMS` in `NetworkConfigParameter` to support device reconnection (see above).
* Creating a pipeline with `FragmentationPipelineStage` _after_ `ReliableSequencedPipelineStage` is now forbidden (will throw an exception if collections checks are enabled). That order never worked properly to begin with. The reverse order is fully supported and is the recommended way to configure a reliable pipeline with support for large packets.
* If collections checks are enabled, trying to create an IPv6 `NetworkEndPoint` will now throw an exception on consoles that don't support IPv6 (PS4, PS5, Switch).
* Documentation has been moved to the [offical multiplayer documentation site](https://docs-multiplayer.unity3d.com/transport/1.0.0/introduction).
* The `INetworkInterface.ScheduleSend()` method signature was modified to receive a `SendJobArguments` struct instead of a `NativeQueue`. A `PacketsQueue` parameter is passed in this new struct.
* `sendQueueCapacity` and `receiveQueueCapacity` parameters moved from `BaselibNetworkParameter` to `NetworkConfigParameter`.
* Removed: `BaselibNetworkParameter.maximumPayloadSize` is not needed anymore as it is handled internally.
* Removed: `INetworkInterface.CreateSendInterface` is not needed anymore, the send queue is managed internally by the `NetworkDriver`. Operations from the `INetworkInterface` must be done through the `ScheduleSend` and `ScheduleReceive` methods. This removes the need of function pointers which where casing GC allocations on `BeginSend`, `EndSend` and `AbortSend` when burst is not enabled.
* Added: `SendJobArguments` and `ReceiveJobArguments` structs to pass arguments to the send and receive jobs of the `INetworkInterface`.
* Obsolete: `NetworkDriver` constructor is now obsolete, instead use `NetworkDriver.Create` methods. This improves burst compatibility as generic methods allows to know the INeworkInterface type at compilation time.
* Obsolete: `NetworkPacketReceiver` is now deprecated. Use the `ReceiveJobArguments.ReceiveQueue` and `PacketProcessor` instead.
* `NetworkDriver.LastUpdateTime` is now consistent across different copies of a driver. It is now also set by the job scheduled with `ScheduleUpdate`, so any job scheduled before it will not see the updated value. This also means the value will not be updated right after `ScheduleUpdate` returns (only once its jobs completes).
* An error is now logged if failing to decrypt a DTLS message when using Relay.
* Decreased default Relay keep-alive period to 3 seconds (was 9 seconds). The value can still be configured through the `relayConnectionTimeMS` parameter of `NetworkSettings.WithRelayParameters`.
* `NetworkDriver` now requires that the `INetworkInterface` provided is an unmanaged type. Managed `INetworkInterfaces` are still supported but are required to be wrapped into an unmanaged type: `myInterface.WrapToUnmanaged()`.
* Instantiating a `NetworkDriver` is now only supported through the `NetworkDriver.Create` methods.
* Don't warn when overwriting settings in `NetworkSettings` (e.g. when calling the same `WithFooParameters` method twice).
* Added new methods to set security parameters: `NetworkSettings.WithSecureClientParameters` and `NetworkSettings.WithSecureServerParameters`. These replace the existing `WithSecureParameters`.
* `NetworkInterfaceEndPoint` usage replaced with `NetworkEndPoint`.
* Removed: `INetworkInterface.CreateInterfaceEndPoint` and `INetworkInterface.GetGenericEndPoint` removed as interfaces use now `NetworkEndPoint`.
* Renamed `NetworkEndPoint` to `NetworkEndpoint`. This should be automatically updated.

### Fixes
* Fixed: Error message when scheduling an update on an unbound `NetworkDriver` (case 1370584)
* Fixed: Removed boxing in `NetworkDriver` initialization by passing `NetworkSettings` parameter instead of `INetworkParameter[]`
* Fixed: `BeginSend` wouldn't return an error if the required payload size was larger than the supported payload size when close to the MTU
* Fixed: Issue where an overflow of the `ReliableSequencedPipelineStage` sequence numbers would not be handled properly.
* Updated Relay sample to the most recent Relay SDK APIs (would fail to compile with latest packages).
* Fixed client certificate not being passed to UnityTLS on secure connections. This prevented client authentication from properly working.
* Fixed: Reliable pipeline drop statistics inaccurate.

### Upgrade guide
* `INetworkPipelineStage` and `INetworkInterface` initialization methods now receive a `NetworkSettings` parameter instead of `INetworkParameter[]`.
* `SimulatorPipelineStageInSend` is no longer required and can be safely removed from your pipeline construction. To replace it, `SimulatorPipelineStage` now supports handling both sending and receiving via `ApplyMode.AllPackets`.
* On fragmented and reliable pipelines, sending a large packet when the reliable window was almost full could result in the packet being lost.
* Revert decrease of MTU to 1384 on Xbox platforms (now back at 1400). It would cause issues for cross-platform communications.
* For custom implementation of the `INetworkInterface`: Remove the `CreateSendInterface` and update the `ScheduleSend` and `ScheduleReceive` signature; to iterate over the send/receive queue use the `PacketsQueue[]` operator.
* Move the definition of the `sendQueueCapacity` and `receiveQueueCapacity` parameters from the `WithBaselibNetworkParameters()` to the `WithNetworkConfigParameters()`.
* Update all `new NetworkDriver()` usages to `NetworkDriver.Create()`.
* For custom implementations of `INetworkInterface` that are managed types, use the `INetworkInterface.WrapToUnmanaged()` configuring the `NetworkDriver`.
* For custom implementations of `INetworkInterface`: Remove `CreateInterfaceEndPoint` and `GetGenericEndPoint` implementations and update `NetworkInterfaceEndPoint` usages to `NetworkEndPoint`.
  • Loading branch information
Unity Technologies committed Sep 2, 2022
1 parent 2eca5b0 commit 6a6cae5
Show file tree
Hide file tree
Showing 273 changed files with 11,927 additions and 20,532 deletions.
4 changes: 0 additions & 4 deletions .buginfo

This file was deleted.

27 changes: 0 additions & 27 deletions .vscode/tasks.json

This file was deleted.

Binary file modified Analyzers/Unity.Transport.Analyzers.dll
Binary file not shown.
3 changes: 2 additions & 1 deletion Analyzers/Unity.Transport.Analyzers.dll.meta

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

198 changes: 113 additions & 85 deletions CHANGELOG.md

Large diffs are not rendered by default.

20 changes: 0 additions & 20 deletions DESIGN.md

This file was deleted.

7 changes: 0 additions & 7 deletions DESIGN.md.meta

This file was deleted.

2 changes: 1 addition & 1 deletion Documentation~/index.md
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ The full documentation for the package can be found on the [Unity multiplayer do

This version of `com.unity.transport` is compatible with the following Unity versions and platforms:

* 2020.1.2 and later.
* 2020.3 and later.
* All platforms supported by Unity are supported, except WebGL.

## Document revision history
Expand Down
2 changes: 1 addition & 1 deletion Editor.meta

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion Editor/Unity.Networking.Editor.asmdef
Original file line number Diff line number Diff line change
Expand Up @@ -13,4 +13,4 @@
"defineConstraints": [],
"versionDefines": [],
"noEngineReferences": false
}
}
22 changes: 0 additions & 22 deletions README.md

This file was deleted.

7 changes: 0 additions & 7 deletions README.md.meta

This file was deleted.

12 changes: 9 additions & 3 deletions Runtime/AssemblyInfo.cs
Original file line number Diff line number Diff line change
@@ -1,9 +1,15 @@
using System.Runtime.CompilerServices;

[assembly: InternalsVisibleTo("Unity.Networking.Transport.EditorTests")]
[assembly: InternalsVisibleTo("Unity.Networking.Transport.RuntimeTests")]
[assembly: InternalsVisibleTo("Unity.Networking.Transport.Editor.Tests")]
[assembly: InternalsVisibleTo("Unity.Networking.Transport.Runtime.Tests")]
[assembly: InternalsVisibleTo("Unity.Networking.Transport.Tests.Integration")]
[assembly: InternalsVisibleTo("Unity.Networking.Transport.Tests.Utilities")]
[assembly: InternalsVisibleTo("Unity.Networking.Transport.PlayTests.Performance")]

// We are making certain things visible for certain projects that require
// access to Network Protocols thus not requiring the API be visible
[assembly: InternalsVisibleTo("Unity.InternalAPINetworkingBridge.001")]
[assembly: InternalsVisibleTo("Unity.InternalAPINetworkingBridge.001")]

// NetCode needs access to writeable Pipeline buffers, but the feature needs further thought.
// Thus, exception is made here.
[assembly: InternalsVisibleTo("Unity.NetCode")]
12 changes: 9 additions & 3 deletions Runtime/AtomicFreeList.cs
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ internal unsafe struct UnsafeAtomicFreeList : IDisposable
// free indices...
[NativeDisableUnsafePtrRestriction]
private int* m_Buffer;
private int m_BufferSize;
private int m_Length;
private Allocator m_Allocator;

Expand All @@ -29,9 +30,9 @@ public UnsafeAtomicFreeList(int capacity, Allocator allocator)
{
m_Allocator = allocator;
m_Length = capacity;
var size = UnsafeUtility.SizeOf<int>() * (capacity + 2);
m_Buffer = (int*)UnsafeUtility.Malloc(size, UnsafeUtility.AlignOf<int>(), allocator);
UnsafeUtility.MemClear(m_Buffer, size);
m_BufferSize = UnsafeUtility.SizeOf<int>() * (capacity + 2);
m_Buffer = (int*)UnsafeUtility.Malloc(m_BufferSize, UnsafeUtility.AlignOf<int>(), allocator);
UnsafeUtility.MemClear(m_Buffer, m_BufferSize);
}

public void Dispose()
Expand All @@ -40,6 +41,11 @@ public void Dispose()
UnsafeUtility.Free(m_Buffer, m_Allocator);
}

public void Reset()
{
UnsafeUtility.MemClear(m_Buffer, m_BufferSize);
}

/// <summary>
/// Inserts an item on top of the stack.
/// </summary>
Expand Down
3 changes: 0 additions & 3 deletions Runtime/Base64.cs
Original file line number Diff line number Diff line change
Expand Up @@ -5,9 +5,6 @@

namespace Unity.Networking.Transport
{
/// <summary>
/// Utility class used to Decode a base64 string
/// </summary>
internal static class Base64
{
/// <summary>
Expand Down
50 changes: 20 additions & 30 deletions Runtime/BaselibNetworkArray.cs
Original file line number Diff line number Diff line change
@@ -1,9 +1,3 @@
#if UNITY_STANDALONE_WIN || UNITY_GAMECORE || UNITY_XBOXONE || UNITY_EDITOR_WIN
#define BASELIB_USE_SPLIT_BUFFERS
#else
#undef BASELIB_USE_SPLIT_BUFFERS
#endif

using System;
using Unity.Baselib.LowLevel;
using Unity.Mathematics;
Expand All @@ -14,25 +8,26 @@

namespace Unity.Networking.Transport
{
using size_t = UIntPtr;

internal unsafe struct UnsafeBaselibNetworkArray : IDisposable
{
[NativeDisableUnsafePtrRestriction] UnsafePtrList<Binding.Baselib_RegisteredNetwork_Buffer> m_BufferPool;
private uint m_ElementSize;

public uint ElementSize => m_ElementSize;

/// <summary>
/// Initializes a new instance of the UnsafeBaselibNetworkArray struct.
/// </summary>
/// <param name="capacity"></param>
/// <param name="typeSize"></param>
/// <param name="usePooling"></param>
/// <exception cref="ArgumentOutOfRangeException">Thrown if the capacity is less then 0 or if the value exceeds <see cref="int.MaxValue"/></exception>
/// <exception cref="Exception">Thrown on internal baselib errors</exception>
public UnsafeBaselibNetworkArray(int capacity, int typeSize)
{
m_ElementSize = (uint)typeSize;

var totalSize = (long)typeSize;
#if !BASELIB_USE_SPLIT_BUFFERS
totalSize = capacity * typeSize;
#endif

#if ENABLE_UNITY_COLLECTIONS_CHECKS
if (typeSize < 0)
Expand All @@ -43,18 +38,15 @@ public UnsafeBaselibNetworkArray(int capacity, int typeSize)
#endif

var poolSize = capacity;
#if !BASELIB_USE_SPLIT_BUFFERS
poolSize = 1;
#endif

m_BufferPool = new UnsafePtrList<Binding.Baselib_RegisteredNetwork_Buffer>(poolSize, Allocator.Persistent);

var pageInfo = stackalloc Binding.Baselib_Memory_PageSizeInfo[1];
Binding.Baselib_Memory_GetPageSizeInfo(pageInfo);
var defaultPageSize = (ulong)pageInfo->defaultPageSize;

for (int i = 0; i < poolSize; i++)
{
var pageInfo = stackalloc Binding.Baselib_Memory_PageSizeInfo[1];
Binding.Baselib_Memory_GetPageSizeInfo(pageInfo);
var defaultPageSize = (ulong)pageInfo->defaultPageSize;

var pageCount = (ulong)1;
if ((ulong)totalSize > defaultPageSize)
{
Expand Down Expand Up @@ -111,15 +103,13 @@ public void Dispose()
}

/// <summary>
/// Gets a element at the specified index, with the size of <see cref="elementSize" />.
/// Gets a element at the specified index.
/// </summary>
/// <value>A <see cref="Binding.Baselib_RegisteredNetwork_BufferSlice" /> pointing to the index supplied.</value>
public Binding.Baselib_RegisteredNetwork_BufferSlice AtIndexAsSlice(int index, uint elementSize)
public Binding.Baselib_RegisteredNetwork_BufferSlice AtIndexAsSlice(int index)
{
uint offset = 0;
IntPtr data;
Binding.Baselib_RegisteredNetwork_Buffer* buffer = null;
#if BASELIB_USE_SPLIT_BUFFERS
#if ENABLE_UNITY_COLLECTIONS_CHECKS
if (index >= m_BufferPool.Length)
{
Expand All @@ -128,18 +118,18 @@ public Binding.Baselib_RegisteredNetwork_BufferSlice AtIndexAsSlice(int index, u
#endif
buffer = m_BufferPool[index];
data = (IntPtr)((byte*)buffer->allocation.ptr);
#else // BASELIB_USE_SPLIT_BUFFERS
buffer = m_BufferPool[0];
offset = elementSize * (uint)index;
data = (IntPtr)((byte*)buffer->allocation.ptr + offset);
#endif // BASELIB_USE_SPLIT_BUFFERS

Binding.Baselib_RegisteredNetwork_BufferSlice slice;
slice.id = buffer->id;
slice.data = data;
slice.offset = offset;
slice.size = elementSize;
slice.offset = 0;
slice.size = m_ElementSize;
return slice;
}

public IntPtr GetBufferPtr(int index)
{
return m_BufferPool[index]->allocation.ptr;
}
}
}
}
Loading

0 comments on commit 6a6cae5

Please sign in to comment.