X-Git-Url: http://git.droids-corp.org/?a=blobdiff_plain;f=lib%2Flibrte_power%2Fguest_channel.c;h=b984d55bc893b07526024df6f7cf7ccd24099bd6;hb=cdfa0dc1702bcfe6c403d3cfe4046b29c8e6c5b9;hp=9cf7d2cb246ccd27533b4f82e737e7f29373aa70;hpb=b4b2f84a5970709e7fb060e3bcd4afb7c19b0121;p=dpdk.git diff --git a/lib/librte_power/guest_channel.c b/lib/librte_power/guest_channel.c index 9cf7d2cb24..b984d55bc8 100644 --- a/lib/librte_power/guest_channel.c +++ b/lib/librte_power/guest_channel.c @@ -10,6 +10,7 @@ #include #include #include +#include #include @@ -19,6 +20,9 @@ #define RTE_LOGTYPE_GUEST_CHANNEL RTE_LOGTYPE_USER1 +/* Timeout for incoming message in milliseconds. */ +#define TIMEOUT 10 + static int global_fds[RTE_MAX_LCORE] = { [0 ... RTE_MAX_LCORE-1] = -1 }; int @@ -125,6 +129,67 @@ int rte_power_guest_channel_send_msg(struct channel_packet *pkt, return guest_channel_send_msg(pkt, lcore_id); } +int power_guest_channel_read_msg(void *pkt, + size_t pkt_len, + unsigned int lcore_id) +{ + int ret; + struct pollfd fds; + + if (pkt_len == 0 || pkt == NULL) + return -1; + + fds.fd = global_fds[lcore_id]; + fds.events = POLLIN; + + ret = poll(&fds, 1, TIMEOUT); + if (ret == 0) { + RTE_LOG(DEBUG, GUEST_CHANNEL, "Timeout occurred during poll function.\n"); + return -1; + } else if (ret < 0) { + RTE_LOG(ERR, GUEST_CHANNEL, "Error occurred during poll function: %s\n", + strerror(errno)); + return -1; + } + + if (lcore_id >= RTE_MAX_LCORE) { + RTE_LOG(ERR, GUEST_CHANNEL, "Channel(%u) is out of range 0...%d\n", + lcore_id, RTE_MAX_LCORE-1); + return -1; + } + + if (global_fds[lcore_id] < 0) { + RTE_LOG(ERR, GUEST_CHANNEL, "Channel is not connected\n"); + return -1; + } + + while (pkt_len > 0) { + ret = read(global_fds[lcore_id], + pkt, pkt_len); + + if (ret < 0) { + if (errno == EINTR) + continue; + return -1; + } + + if (ret == 0) { + RTE_LOG(ERR, GUEST_CHANNEL, "Expected more data, but connection has been closed.\n"); + return -1; + } + pkt = (char *)pkt + ret; + pkt_len -= ret; + } + + return 0; +} + +int rte_power_guest_channel_receive_msg(void *pkt, + size_t pkt_len, + unsigned int lcore_id) +{ + return power_guest_channel_read_msg(pkt, pkt_len, lcore_id); +} void guest_channel_host_disconnect(unsigned int lcore_id)