/*
    mtr  --  a network diagnostic tool
    Copyright (C) 2016  Matt Kimball
    This program is free software; you can redistribute it and/or modify
    it under the terms of the GNU General Public License version 2 as
    published by the Free Software Foundation.
    This program is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    GNU General Public License for more details.
    You should have received a copy of the GNU General Public License along
    with this program; if not, write to the Free Software Foundation, Inc.,
    51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*/
#ifndef PROBE_UNIX_H
#define PROBE_UNIX_H
#ifndef IPPROTO_SCTP
// Needed for Netbsd.
#define IPPROTO_SCTP           132             /* SCTP */
#endif
/*  The range of local port numbers to use for probes  */
#define MIN_PORT 33000
#define MAX_PORT 65535
/*  We need to track the transmission and timeouts on Unix systems  */
struct probe_platform_t {
    /*  The socket for the outgoing connection  (used by TCP probes)  */
    int socket;
    /*  The time at which the probe is considered lost  */
    struct timeval timeout_time;
    /*  The time at which the probe was sent  */
    struct timeval departure_time;
};
/*  We'll use rack sockets to send and receive probes on Unix systems  */
struct net_state_platform_t {
    /*  true if we were successful at opening IPv4 sockets  */
    bool ip4_present;
    /*  true if we were successful at opening IPv6 sockets  */
    bool ip6_present;
    /* true if ipv4 socket is raw socket */
    bool ip4_socket_raw;
    /* true if ipv6 socket is raw socket */
    bool ip6_socket_raw;
    /*  Socket used to send raw IPv4 packets  */
    int ip4_send_socket;
    /*  Socket used to receive IPv4 ICMP replies  */
    int ip4_recv_socket;
    /*  Socket used to probe byte order */
    int ip4_tmp_icmp_socket;
    /*  Socket used to tx & rx non-raw IPv4 icmp packets */
    int ip4_txrx_icmp_socket;
    /*  Socket used to send IPv4 udp packets and receive icmp err packets */
    int ip4_txrx_udp_socket;
    /*  Send socket for ICMPv6 packets  */
    int icmp6_send_socket;
    /*  Send socket for UDPv6 packets  */
    int udp6_send_socket;
    /*  Receive socket for IPv6 packets  */
    int ip6_recv_socket;
    /*  Socket used to tx & rx non-raw IPv6 icmp packets */
    int ip6_txrx_icmp_socket;
    /*  Socket used to send IPv6 udp packets and receive icmp err packets */
    int ip6_txrx_udp_socket;
    /*
       true if we should encode the IP header length in host order.
       (as opposed to network order)
     */
    bool ip_length_host_order;
    /*  true if the operating system supports SCTP sockets  */
    bool sctp_support;
    /*  The next port number to use when creating a new probe  */
    int next_sequence;
};
struct net_state_t;
struct probe_t;
struct mpls_label_t;
void set_socket_nonblocking(
    int socket);
void receive_probe(
    struct net_state_t *net_state,
    struct probe_t *probe,
    int icmp_type,
    const struct sockaddr_storage *remote_addr,
    struct timeval *timestamp,
    int mpls_count,
    struct mpls_label_t *mpls);
int gather_probe_sockets(
    const struct net_state_t *net_state,
    fd_set * write_set);
#endif
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>