X-Git-Url: https://codewiz.org/gitweb?a=blobdiff_plain;f=bertos%2Fnet%2Fpocketcmd.c;h=14bdc020d2a20f00adbb82a49763f61236c7d396;hb=b30ca67e54f665181d85a49bff3af2862e86601e;hp=3c92a2faf5883fe2c326334d5c818a29867faf7c;hpb=56df77502283f05666f8e80e7b246c3a500e1485;p=bertos.git diff --git a/bertos/net/pocketcmd.c b/bertos/net/pocketcmd.c index 3c92a2fa..14bdc020 100644 --- a/bertos/net/pocketcmd.c +++ b/bertos/net/pocketcmd.c @@ -50,16 +50,20 @@ * The CMD ID used is the same supplied by the master when * the command was sent. * - * \version $Id$ - * * \author Francesco Sacchi */ #include "pocketcmd.h" #include "pocketbus.h" -#include +#include "cfg/cfg_pocketbus.h" + +// Define logging setting (for cfg/log.h module). +#define LOG_LEVEL POCKETBUS_LOG_LEVEL +#define LOG_VERBOSITY POCKETBUS_LOG_FORMAT +#include #include +#include #include #include @@ -74,6 +78,26 @@ * Call it to read and process pocketBus commands. */ void pocketcmd_poll(struct PocketCmdCtx *ctx) +{ + PocketCmdMsg msg; + while (pocketcmd_recv(ctx, &msg)) + { + /* Check for command callback */ + pocketcmd_hook_t callback = ctx->search(msg.cmd); + + /* Call it if exists */ + if (callback) + callback(&msg); + } +} + + + +/** + * pocketBus Command recv function. + * Call it to read and process pocketBus commands. + */ +bool pocketcmd_recv(struct PocketCmdCtx *ctx, PocketCmdMsg *recv_msg) { PocketMsg msg; @@ -108,25 +132,19 @@ void pocketcmd_poll(struct PocketCmdCtx *ctx) if (cmd == ctx->waiting) ctx->waiting = PKTCMD_NULL; - /* Check for command callback */ - pocketcmd_hook_t callback = ctx->search(cmd); + recv_msg->cmd_ctx = ctx; + recv_msg->cmd = cmd; + recv_msg->len = msg.len - sizeof(PocketCmdHdr); + recv_msg->buf = msg.payload + sizeof(PocketCmdHdr); - /* Call it if exists */ - if (callback) - { - PocketCmdMsg cmd_msg; - - cmd_msg.cmd_ctx = ctx; - cmd_msg.cmd = cmd; - cmd_msg.len = msg.len - sizeof(PocketCmdHdr); - cmd_msg.buf = msg.payload + sizeof(PocketCmdHdr); - - callback(&cmd_msg); - } + return true; } } + + return false; } + /** * Send command \a cmd to/from slave adding \a len arguments in \a buf. * Address used is contained in \a ctx->addr . @@ -139,14 +157,14 @@ bool pocketcmd_send(struct PocketCmdCtx *ctx, pocketcmd_t cmd, const void *buf, if (ctx->waiting != PKTCMD_NULL) { /* Check is reply timeout is elapsed */ - if (timer_clock() - ctx->reply_timer < ms_to_ticks(PKTCMD_REPLY_TIMEOUT)) + if (timer_clock() - ctx->reply_timer < ms_to_ticks(CONFIG_POCKETBUS_CMD_REPLY_TIMEOUT)) { - TRACEMSG("Pkt discard! waiting cmd[%04X]\n", ctx->waiting); + LOG_ERR("Pkt discard! waiting cmd[%04X]\n", ctx->waiting); return false; } else { - TRACEMSG("Timeout waiting cmd[%04X]\n", ctx->waiting); + LOG_INFO("Timeout waiting cmd[%04X]\n", ctx->waiting); ctx->waiting = PKTCMD_NULL; } } @@ -162,9 +180,10 @@ bool pocketcmd_send(struct PocketCmdCtx *ctx, pocketcmd_t cmd, const void *buf, if (wait_reply) { - ctx->waiting = cmd; + ctx->waiting = be16_to_cpu(cmd); ctx->reply_timer = timer_clock(); } + return true; }