xref: /qemu/tests/unit/socket-helpers.h (revision 0370f239ad14aeacc496775e241b9ef041df4374)
19b589ffbSDaniel P. Berrange /*
29b589ffbSDaniel P. Berrange  * Helper functions for tests using sockets
39b589ffbSDaniel P. Berrange  *
49b589ffbSDaniel P. Berrange  * Copyright 2015-2018 Red Hat, Inc.
59b589ffbSDaniel P. Berrange  *
69b589ffbSDaniel P. Berrange  * This program is free software; you can redistribute it and/or
79b589ffbSDaniel P. Berrange  * modify it under the terms of the GNU General Public License as
89b589ffbSDaniel P. Berrange  * published by the Free Software Foundation; either version 2 or
99b589ffbSDaniel P. Berrange  * (at your option) version 3 of the License.
109b589ffbSDaniel P. Berrange  *
119b589ffbSDaniel P. Berrange  * This program is distributed in the hope that it will be useful,
129b589ffbSDaniel P. Berrange  * but WITHOUT ANY WARRANTY; without even the implied warranty of
139b589ffbSDaniel P. Berrange  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
149b589ffbSDaniel P. Berrange  * GNU General Public License for more details.
159b589ffbSDaniel P. Berrange  *
169b589ffbSDaniel P. Berrange  * You should have received a copy of the GNU General Public License
179b589ffbSDaniel P. Berrange  * along with this program; if not, see <http://www.gnu.org/licenses/>.
189b589ffbSDaniel P. Berrange  */
199b589ffbSDaniel P. Berrange 
20f91005e1SMarkus Armbruster #ifndef TESTS_SOCKET_HELPERS_H
21f91005e1SMarkus Armbruster #define TESTS_SOCKET_HELPERS_H
22f91005e1SMarkus Armbruster 
239b589ffbSDaniel P. Berrange /*
249b589ffbSDaniel P. Berrange  * @has_ipv4: set to true on return if IPv4 is available
259b589ffbSDaniel P. Berrange  * @has_ipv6: set to true on return if IPv6 is available
269b589ffbSDaniel P. Berrange  *
279b589ffbSDaniel P. Berrange  * Check whether IPv4 and/or IPv6 are available for use.
289b589ffbSDaniel P. Berrange  * On success, @has_ipv4 and @has_ipv6 will be set to
299b589ffbSDaniel P. Berrange  * indicate whether the respective protocols are available.
309b589ffbSDaniel P. Berrange  *
319b589ffbSDaniel P. Berrange  * Returns 0 on success, -1 on fatal error
329b589ffbSDaniel P. Berrange  */
339b589ffbSDaniel P. Berrange int socket_check_protocol_support(bool *has_ipv4, bool *has_ipv6);
34f91005e1SMarkus Armbruster 
35*0370f239SBin Meng /*
36*0370f239SBin Meng  * @has_afunix: set to true on return if unix socket support is available
37*0370f239SBin Meng  *
38*0370f239SBin Meng  * Check whether unix domain socket support is available for use.
39*0370f239SBin Meng  * On success, @has_afunix will be set to indicate whether AF_UNIX protocol
40*0370f239SBin Meng  * is available.
41*0370f239SBin Meng  */
42*0370f239SBin Meng void socket_check_afunix_support(bool *has_afunix);
43*0370f239SBin Meng 
44f91005e1SMarkus Armbruster #endif
45