Skip to content
This repository has been archived by the owner on Sep 23, 2022. It is now read-only.

Latest commit

 

History

History
134 lines (99 loc) · 3.74 KB

README.md

File metadata and controls

134 lines (99 loc) · 3.74 KB

hlCANopen

wercker status

hlCANopen is an high-level C++ library for the CANopen protocol.

The library provides a generic and async interface, making its usage simpler in comparision to other libraries.

Dependencies

Note: it may be necessary to build folly and hlCANopen with the same compiler.

Examples

CanOpenManager<CanCard> manager(canCard);

// Setup a CANopen server, that can be queried by other nodes in the network.
NodeId serverNodeId = 1;
manager(serverNodeId, NodeManagerType::SERVER);

// Populate the server' object dictionary. Types are automatically deduced.
manager.writeSdoLocal(serverNodeId, SDOIndex(0xabcd, 0), "hello world!");
manager.writeSdoLocal(serverNodeId, SDOIndex(0xabcd, 1), 0x1234);

// Starts the manager. Now it will answer to the read/write requests
// from other nodes. Access for each entry is configurable
thread managerThread = std::thread([&](){
  manager.run();
});

// Read a value from an another server in the network
NodeId otherServerId = 2;
std::future<SdoResponse<int32_t>> readResult =
    manager.readSdoRemote<int32_t>(otherServerId, SDOIndex(0xaabb, 0));
// The returned value is a future, so other actions can be performed
// while the value is read. New request can also be submitted and
// executed concurrently when they involve different nodes.

// now, get the response
if(readResult.get().ok()) {
  std::cout << "result is " << readResult.get().get();
}

// futures allow to write async code sequentially, however it is
// also possible to use callbacks.
manager.readSdoRemote<string>(otherServerId, SDOIndex(0xaabb, 0),
[](SdoResponse<string> res) {
  std::cout << "result is " << res.get();
});

Use

If you use cmake, you can find the package with

find_package(hlcanopen REQUIRED)

you have to add this line

INITIALIZE_EASYLOGGINGPP

possibly before main() in order to initialize easylogging

Build

mkdir build && cd build
cmake ..
make
make test

The library uses C++14, and was tested with the following compilers:

gcc 5.1
clang 3.6

Ubuntu

Ubuntu still does not provide BOOST 1.57 it is possible to build it using https://github.com/team-diana/repo-scripts

also, at least gcc-5 or clang-3.6 must be installed: http://askubuntu.com/a/456849

Then, in order to create the build files:

cmake .. -DCMAKE_CXX_COMPILER=/usr/bin/g++-5 -DCMAKE_C_COMPILER=/usr/bin/gcc-5 -DBOOST_ROOT=/opt/boost

or using clang:

cmake .. -DCMAKE_CXX_COMPILER=/usr/bin/clang++-3.6 -DCMAKE_C_COMPILER=/usr/bin/clang-3.6 -DBOOST_ROOT=/opt/boost

make and run the tests as above in order to check if everything is everything is fine:

It may also be necessary to add the boost and folly path to LD_LIBRARY_PATH before running anything that uses folly or boost >=1.57

export LD_LIBRARY_PATH=/opt/boost/lib/:/usr/local/lib:$LD_LIBRARY_PATH

Implementation details

In order to handle multiple nodes concurrently this library uses Boost Coroutine. So the cost of having multiples thread is avoided (only a thread for CAN network interface should be used).

Status

The library is currently under development.

  • SDO support.
    • basic support for both SDO server and client.
    • future and callback functionality for async read and write.
    • full error handling.
  • PDO support.
  • NMT support.
  • SYNC and TIMESTAMP support.
  • TIMEOUT support.
  • emergency and error control.

Libraries Used