On 12/01/2014 09:17 PM, Zoltan Kiss wrote:


On 01/12/14 16:15, Maxim Uvarov wrote:
Define API and implement promisc functions for linux-generic.

Signed-off-by: Maxim Uvarov <[email protected]>
---
  platform/linux-generic/include/api/odp_packet_io.h | 24 +++++++
platform/linux-generic/odp_packet_io.c | 74 ++++++++++++++++++++++
  2 files changed, 98 insertions(+)

diff --git a/platform/linux-generic/include/api/odp_packet_io.h b/platform/linux-generic/include/api/odp_packet_io.h
index 667395c..c7d1e40 100644
--- a/platform/linux-generic/include/api/odp_packet_io.h
+++ b/platform/linux-generic/include/api/odp_packet_io.h
@@ -149,6 +149,30 @@ int odp_pktio_set_mtu(odp_pktio_t id, int mtu);
  int odp_pktio_mtu(odp_pktio_t id);

  /**
+ * Enable promiscuous mode on a packet IO interface.
+ *
+ * @param[in] id    ODP packet IO handle.
+ * @param[in] enable    1 enabled, 0 disabled.
+ *
+ * @retval  0 on success.
+ * @retval -1 on a bad pktio id
+ * @retval -1 any other error
I would consider choosing 1 (or 2, or any positive value) as a "bad pktio id" return value, because in the linux-generic implementation the ioctl can return any negative errno, -1 means EPERM. Or INT_MIN.

Zoltan, for 1.0 we stayed with 0 on success and !0 on error. After 1.0 we will rework all apis for return error codes.

Maxim.


+ */
+int odp_pktio_promisc_set(odp_pktio_t id, odp_bool_t enable);
+
+/**
+ * Determine if promiscuous mode is enabled for a packet IO interface.
+ *
+ * @param[in] id ODP packet IO handle.
+ *
+ * @retval  1 if promiscuous mode is enabled.
+ * @retval  0 if promiscuous mode is disabled.
+ * @retval -1 on a bad pktio id
+ * @retval -1 any other error
Same here
+*/
+int odp_pktio_promisc_enabled(odp_pktio_t id);
+
+/**
   * @}
   */

diff --git a/platform/linux-generic/odp_packet_io.c b/platform/linux-generic/odp_packet_io.c
index acc03bb..d97910f 100644
--- a/platform/linux-generic/odp_packet_io.c
+++ b/platform/linux-generic/odp_packet_io.c
@@ -545,3 +545,77 @@ int odp_pktio_mtu(odp_pktio_t id)

      return ifr.ifr_mtu;
  }
+
+int odp_pktio_promisc_set(odp_pktio_t id, odp_bool_t enable)
+{
+    pktio_entry_t *entry;
+    int sockfd;
+    struct ifreq ifr;
+    int ret;
+
+    entry = get_entry(id);
+    if (entry == NULL) {
+        ODP_DBG("pktio entry %d does not exist\n", id);
+        return -1;
+    }
+
+    if (entry->s.pkt_sock_mmap.sockfd > -1)
+        sockfd = entry->s.pkt_sock_mmap.sockfd;
+    else
+        sockfd = entry->s.pkt_sock.sockfd;
+
+    strncpy(ifr.ifr_name, entry->s.name, IFNAMSIZ - 1);
+    ifr.ifr_name[IFNAMSIZ - 1] = 0;
+
+    ret = ioctl(sockfd, SIOCGIFFLAGS, &ifr);
+    if (ret < 0) {
+        ODP_DBG("ioctl SIOCGIFFLAGS error\n");
+        return -1;
I would print out ret, and then return it, same applies to the other ioctl's
+    }
+
+    if (enable)
+        ifr.ifr_flags |= IFF_PROMISC;
+    else
+        ifr.ifr_flags &= ~(IFF_PROMISC);
+
+    ret = ioctl(sockfd, SIOCSIFFLAGS, &ifr);
+    if (ret < 0) {
+        ODP_DBG("ioctl SIOCSIFFLAGS error\n");
+        return -1;
+    }
+
+    return 0;
+}
+
+int odp_pktio_promisc_enabled(odp_pktio_t id)
+{
+    pktio_entry_t *entry;
+    int sockfd;
+    struct ifreq ifr;
+    int ret;
+
+    entry = get_entry(id);
+    if (entry == NULL) {
+        ODP_DBG("pktio entry %d does not exist\n", id);
+        return -1;
+    }
+
+    if (entry->s.pkt_sock_mmap.sockfd > -1)
+        sockfd = entry->s.pkt_sock_mmap.sockfd;
+    else
+        sockfd = entry->s.pkt_sock.sockfd;
+
+    strncpy(ifr.ifr_name, entry->s.name, IFNAMSIZ - 1);
+    ifr.ifr_name[IFNAMSIZ - 1] = 0;
+
+    ret = ioctl(sockfd, SIOCGIFFLAGS, &ifr);
+    if (ret < 0) {
+        ODP_DBG("ioctl SIOCGIFFLAGS error\n");
+        return -1;
+    }
+
+    if (ifr.ifr_flags & IFF_PROMISC)
+        return 1;
+    else
+        return 0;
+}



_______________________________________________
lng-odp mailing list
[email protected]
http://lists.linaro.org/mailman/listinfo/lng-odp

Reply via email to