libslirp.h revision 1b097ed3dfab440934c002fd83612f6fb216f345
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsync * NAT - slirp interface.
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsync * Copyright (C) 2006-2010 Oracle Corporation
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsync * This file is part of VirtualBox Open Source Edition (OSE), as
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsync * available from http://www.virtualbox.org. This file is free software;
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsync * you can redistribute it and/or modify it under the terms of the GNU
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsync * General Public License (GPL) as published by the Free Software
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsync * Foundation, in version 2 as it comes in the "COPYING" file of the
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsync * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsync * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsyncextern "C" {
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsync# ifdef RT_OS_OS2 /* temporary workaround, see ticket #127 */
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsyncextern "C" {
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsyncint slirp_init(PNATState *, uint32_t, uint32_t, bool, bool, int, int, void *);
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsyncvoid slirp_register_statistics(PNATState pData, PPDMDRVINS pDrvIns);
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsyncvoid slirp_deregister_statistics(PNATState pData, PPDMDRVINS pDrvIns);
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsyncvoid slirp_select_fill(PNATState pData, int *pndfs);
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsyncvoid slirp_select_poll(PNATState pData, int fTimeout, int fIcmp);
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsync#else /* RT_OS_WINDOWS */
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsyncvoid slirp_select_fill(PNATState pData, int *pnfds, struct pollfd *polls);
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsyncvoid slirp_select_poll(PNATState pData, struct pollfd *polls, int ndfs);
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsync#endif /* !RT_OS_WINDOWS */
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsyncvoid slirp_input(PNATState pData, struct mbuf *m, size_t cbBuf);
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsyncvoid slirp_set_ethaddr_and_activate_port_forwarding(PNATState pData, const uint8_t *ethaddr, uint32_t GuestIP);
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsync/* you must provide the following functions: */
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsyncvoid slirp_output(void * pvUser, struct mbuf *m, const uint8_t *pkt, int pkt_len);
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsyncvoid slirp_urg_output(void *pvUser, struct mbuf *, const uint8_t *pu8Buf, int cb);
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsyncint slirp_add_redirect(PNATState pData, int is_udp, struct in_addr host_addr,
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsyncint slirp_remove_redirect(PNATState pData, int is_udp, struct in_addr host_addr,
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsyncint slirp_add_exec(PNATState pData, int do_pty, const char *args, int addr_low_byte,
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsyncvoid slirp_set_dhcp_TFTP_prefix(PNATState pData, const char *tftpPrefix);
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsyncvoid slirp_set_dhcp_TFTP_bootfile(PNATState pData, const char *bootFile);
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsyncvoid slirp_set_dhcp_next_server(PNATState pData, const char *nextServer);
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsyncvoid slirp_set_dhcp_dns_proxy(PNATState pData, bool fDNSProxy);
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsyncvoid slirp_set_rcvbuf(PNATState pData, int kilobytes);
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsyncvoid slirp_set_sndbuf(PNATState pData, int kilobytes);
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsyncvoid slirp_set_tcp_rcvspace(PNATState pData, int kilobytes);
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsyncvoid slirp_set_tcp_sndspace(PNATState pData, int kilobytes);
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsyncint slirp_set_binding_address(PNATState, char *addr);
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsyncvoid slirp_info(PNATState pData, PCDBGFINFOHLP pHlp, const char *pszArgs);
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsyncvoid slirp_set_somaxconn(PNATState pData, int iSoMaxConn);
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsync * ICMP handle state change
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsync * This event is for
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsync * - slirp_input
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsync * - slirp_link_up
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsync * - slirp_link_down
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsync * UDP/TCP socket state change (socket ready to receive, to send, ...)
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsync * The number of events for WSAWaitForMultipleEvents().
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsyncvoid slirp_register_external_event(PNATState pData, HANDLE hEvent, int index);
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsync#endif /* RT_OS_WINDOWS */
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsyncstruct mbuf *slirp_ext_m_get(PNATState pData, size_t cbMin, void **ppvBuf, size_t *pcbBuf);
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsyncvoid slirp_ext_m_free(PNATState pData, struct mbuf *, uint8_t *pu8Buf);
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsync * Returns the timeout.
e36f03470adaee73199dcdddd8eb9cf39bbdf7advboxsync * Returns the number of sockets.