/* * Copyright (C) 2015 Freie Universität Berlin * * This file is subject to the terms and conditions of the GNU Lesser * General Public License v2.1. See the file LICENSE in the top level * directory for more details. */ /** * @{ * @ingroup net_ng_netapi * @file * @brief This file contains a number of helper functions that provide * some shortcuts for some always repeating code snippets when * servicing the netapi interface * * @author Hauke Petersen * @} */ #include "kernel.h" #include "msg.h" #include "net/ng_netapi.h" /** * @brief Unified function for getting and setting netapi options * * @param[in] pid PID of the targeted thread * @param[in] type specify if option is to be set or get * @param[in] opt option to set or get * @param[in] data data to set or pointer to buffer for reading options * @param[in] data_len size of the given buffer * * @return the value from the received ACK message */ static inline int _get_set(kernel_pid_t pid, uint16_t type, ng_netconf_opt_t opt, uint16_t context, void *data, size_t data_len) { msg_t cmd; msg_t ack; ng_netapi_opt_t opt; /* set ńetapi's option struct */ opt.type = opt; opt.context = context; opt.data = data; opt.data_len = data_len; /* set outgoing message's fields */ cmd.type = type; cmd.content.ptr = (void *)&opt; /* trigger the netapi */ msg_send_receive(&cmd, &ack, pid); /* return the ACK message's value */ return (int)ack.content.value; } int ng_netapi_send(kernel_pid_t pid, ng_pktsnip_t *pkt) { msg_t msg; /* set the outgoing message's fields */ msg.type = NETAPI_MSG_TYPE_SND; msg.content.ptr = (void *)pkt; /* send data using netapi */ return msg_send(&msg, pid); } int ng_netapi_get(kernel_pid_t pid, ng_netconf_opt_t opt, uint16_t context, void *data, size_t data_len) { return _get_set(pid, NG_NETAPI_MSG_TYPE_GETOPT, opt, context, data, data_len); } int ng_netapi_set(kernel_pid_t pid, ng_netconf_opt_t opt, uint16_t context, void *data, size_t data_len) { return _get_set(pid, NG_NETAPI_MSG_TYPE_SETOPT, opt, context, data, data_len); }