我正在考慮使用Boost Asio來讀取Socket CAN的數據。 linux/can.h中沒有什麼特別的事情發生,設備應該 的行爲類似於回送接口,並且與原始套接字一起使用。boost :: asio通過SocketCAN
望着basic_raw_socket
界面似乎我可以利用 basic_raw_socket::assign分配與
socket(PF_CAN, SOCK_RAW, CAN_RAW);
這產生與天然插座是我到目前爲止
namespace can {
class CanSocket {
public:
typedef boost::asio::ip::basic_endpoint<CanSocket> endpoint;
typedef boost::asio::ip::basic_resolver_query<CanSocket> resolver_query;
typedef boost::asio::ip::basic_resolver_iterator<CanSocket> resolver_iterator;
typedef boost::asio::basic_raw_socket<CanSocket> socket;
typedef boost::asio::ip::basic_resolver<CanSocket> resolver;
CanSocket()
: _protocol(CAN_RAW)
, _family(PF_CAN)
{
}
static CanSocket v4()
{
return CanSocket();
}
static CanSocket v6();
int type() const;
int protocol() const;
int family() const;
friend bool operator==(const CanSocket& p1, const CanSocket& p2)
{
return p1._protocol != p2._protocol || p1._family != p2._family;
}
friend bool operator!=(const CanSocket& p1, const CanSocket& p2)
{
return p1._protocol == p2._protocol || p1._family == p2._family;
}
private:
int _protocol;
int _family;
};
}
這是我如何在我的應用程序中使用它
boost::asio::io_service ioserv;
CanSocket::socket s(ioserv);
int sock = socket(PF_CAN, SOCK_RAW, CAN_RAW);
s.assign(CanSocket::v4(), sock);
struct ifreq ifr;
strcpy(ifr.ifr_name, "vcan0");
ioctl(sock, SIOCGIFINDEX, &ifr); /* ifr.ifr_ifindex gets filled
* with that device's index */
/* Select that CAN interface, and bind the socket to it. */
/* this should be the endpoint */
struct sockaddr_can addr;
addr.can_family = AF_CAN;
addr.can_ifindex = ifr.ifr_ifindex;
/* s.bind (....) */
bind(sock, (struct sockaddr*)&addr, sizeof(addr));
我不太清楚的是我如何binds
到本地端點?沒有涉及的IP或端口。
除了端點以外還有其他應該實現的功能嗎?
能否請您閱讀提供了完整的例子/寫CAN幀就像我做了它的Python:HTTP://libbits.wordpress .com/2012/05/22/socketcan-support-in-python /然後我將它放在http://elinux.org/CAN_Bus#SocketCAN_Support_in_Programming_Languages.2FEnvironments – yegorich