dnp3


Distributed Network Protocol 3.0

Goal

The goal of this project is to provide the utility industry with a production-ready reference implementation of Distributed Network Protocol (DNP3) under a commercially compatible license.

Support

A Google Group is used for mail lists and archived discussion. Users requests and developer feedback can be posted to this list. Developers are friendly and quick to respond.

The project is part of the Total Grid Community sponsored by Green Energy Corp (GEC). A commercially supported branch is offered by Automatak.

Applications

The library is targeted for platforms with an operating system and a C++ compiler. It is primarily for high-performance SCADA server applications, but embeds nicely on linux based IEDs that cross compile to ARM. Primary applications include:

  • Frontends with scalability up to the OS socket limits
  • Highly parallel slave device simulations
  • Embedded linux based gateways, RTUs, and IEDs

It is NOT a traditional low-level C library. In our experience, these libraries are necessary for micro-controller IED implementations, but are less desirable for high-level DNP3 interoperability and performance in server applications.

Features

  • Level 2+ master/slave library.
  • High-level API for creating user applications abstracts DNP3 specifics
  • Over 400 individual test cases providing 85-90% test coverage
  • Scalable performance for front end processors and device simulations
  • 3rd party tool was used to remedy conformance issues
  • TCP/IP and serial support via Boost.Asio
  • Masters/slaves/ports can be added/removed dynamically at runtime
  • Multi-drop support (multiple devices per communication port)
  • Bindings for Microsoft CLR. Run the stack from any .NET language.
  • Automatically generated Java bindings. Use the library with JVM languages.
  • Platform-neutral C++ verified on 32/64 bit Windows, Linux, and embedded Linux ARM

Topics

  • Source Respository on Github
  • Instructions for becoming a contributor.
  • Continuous Integration - The CI server is here
  • Community wish list - Desired features for future releases
  • Performance testing - The test cases and metrics used
  • Design issues - Architecture and patterns
  • Security - Security testing

Project Information

Labels:
DNP3 DNP Boost Asio CPlusPlus asynchronous crossplatform smartgrid Concurrency SCADA