CanKit.Adapter.SocketCAN
0.3.1
See the version list below for details.
dotnet add package CanKit.Adapter.SocketCAN --version 0.3.1
NuGet\Install-Package CanKit.Adapter.SocketCAN -Version 0.3.1
<PackageReference Include="CanKit.Adapter.SocketCAN" Version="0.3.1" />
<PackageVersion Include="CanKit.Adapter.SocketCAN" Version="0.3.1" />
<PackageReference Include="CanKit.Adapter.SocketCAN" />
paket add CanKit.Adapter.SocketCAN --version 0.3.1
#r "nuget: CanKit.Adapter.SocketCAN, 0.3.1"
#:package CanKit.Adapter.SocketCAN@0.3.1
#addin nuget:?package=CanKit.Adapter.SocketCAN&version=0.3.1
#tool nuget:?package=CanKit.Adapter.SocketCAN&version=0.3.1
CanKit.Adapter.SocketCAN
SocketCAN adapter for CanKit. Provides a unified .NET API to Linux SocketCAN interfaces.
- Repository: https://github.com/pkuyo/CanKit
- Package:
CanKit.Adapter.SocketCAN - Depends on:
CanKit.Core
Requirements
- Linux with SocketCAN enabled (
can,vcan,vxcan). - Ensure libsocketcan/netlink is installed.
简体中文
- 仅支持 Linux(SocketCAN)。
- 需安装 libsocketcan。
Install
# Core + SocketCAN adapter
dotnet add package CanKit.Core
dotnet add package CanKit.Adapter.SocketCAN
Endpoint Formats
socketcan://can0socketcan://vcan0socketcan://can0#netlink(enable netlink-based configuration)socketcan://can0?rcvbuf=1048576(set receive buffer)
Quick Start
using CanKit.Core;
using CanKit.Core.Definitions;
// Open can0, set 500 kbps
using var bus = CanBus.Open("socketcan://can0", cfg => cfg.Baud(500_000));
var tx = new CanClassicFrame(0x123, new byte[] { 1, 2, 3 });
bus.Transmit(new[] { tx });
foreach (var rx in bus.Receive(1, 100))
{
var f = rx.CanFrame;
Console.WriteLine($"RX 0x{f.ID:X} dlc={f.Dlc}");
}
Discover Endpoints
using CanKit.Core.Endpoints;
foreach (var ep in BusEndpointEntry.Enumerate("socketcan"))
{
Console.WriteLine($"{ep.Title}: {ep.Endpoint}");
}
Notes
- When using
#netlink, the adapter may attempt to set bitrate via libsocketcan; otherwise, ensure the interface is pre-configured (e.g.,ip link set can0 up type can bitrate 500000).
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net8.0-windows7.0 is compatible. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
| .NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
| .NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
| .NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
| MonoAndroid | monoandroid was computed. |
| MonoMac | monomac was computed. |
| MonoTouch | monotouch was computed. |
| Tizen | tizen40 was computed. tizen60 was computed. |
| Xamarin.iOS | xamarinios was computed. |
| Xamarin.Mac | xamarinmac was computed. |
| Xamarin.TVOS | xamarintvos was computed. |
| Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- CanKit.Core (>= 0.3.1)
-
net8.0
- CanKit.Core (>= 0.3.1)
-
net8.0-windows7.0
- CanKit.Core (>= 0.3.1)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated | |
|---|---|---|---|
| 0.5.4 | 185 | 12/14/2025 | |
| 0.5.3 | 358 | 12/8/2025 | |
| 0.5.2 | 690 | 12/2/2025 | |
| 0.5.1 | 298 | 11/10/2025 | |
| 0.5.0 | 151 | 11/1/2025 | |
| 0.4.0 | 207 | 10/27/2025 | |
| 0.3.3.1 | 201 | 10/23/2025 | |
| 0.3.3 | 209 | 10/23/2025 | |
| 0.3.2 | 198 | 10/21/2025 | |
| 0.3.1 | 142 | 10/18/2025 | |
| 0.2.1 | 234 | 10/13/2025 | |
| 0.2.0 | 214 | 10/12/2025 | |
| 0.1.0 | 325 | 10/8/2025 |
0.3.0
**Feature**
- Added Fake Backend: Introduced a mock backend implementation for easier unit testing and integration simulation.
- Added `NativeHandle` in `ICanBus`: Allows direct access to the underlying native handle for advanced scenarios and custom native library calls.
- Added uint overload for `AccMask` in IBusInitOptionsConfigurator: Provides more flexibility in CAN bus initialization options.
**Improvements**
- Expanded and improved unit test coverage for better reliability and maintainability.
- Optimized ZLG adapter and SocketCAN adapter performance for faster and more stable communication.
**Fixes**
- Fixed multiple issues across all adapters, improving overall stability and compatibility.
**API Stability Notice**
Starting from this release, the API is considered stable.
Future updates will not introduce breaking changes unless explicitly marked as `BREAKING` in the release notes.