source: rtems-libbsd/rtemsbsd/include/rtems/mdns.h @ 7ba9b7f

4.1155-freebsd-126-freebsd-12freebsd-9.3
Last change on this file since 7ba9b7f was 7ba9b7f, checked in by Sebastian Huber <sebastian.huber@…>, on 11/03/14 at 14:53:46

Add mDNS support for name service dispatcher

  • Property mode set to 100644
File size: 2.6 KB
Line 
1/*
2 * Copyright (c) 2014 embedded brains GmbH.  All rights reserved.
3 *
4 *  embedded brains GmbH
5 *  Dornierstr. 4
6 *  82178 Puchheim
7 *  Germany
8 *  <rtems@embedded-brains.de>
9 *
10 * Redistribution and use in source and binary forms, with or without
11 * modification, are permitted provided that the following conditions
12 * are met:
13 * 1. Redistributions of source code must retain the above copyright
14 *    notice, this list of conditions and the following disclaimer.
15 * 2. Redistributions in binary form must reproduce the above copyright
16 *    notice, this list of conditions and the following disclaimer in the
17 *    documentation and/or other materials provided with the distribution.
18 *
19 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
20 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22 * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
23 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
24 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
25 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
26 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
27 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
28 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
29 * SUCH DAMAGE.
30 */
31
32#ifndef _RTEMS_MDNS_H_
33#define _RTEMS_MDNS_H_
34
35#include <mDNSEmbeddedAPI.h>
36
37#include <rtems.h>
38
39#ifdef __cplusplus
40extern "C" {
41#endif /* __cplusplus */
42
43/**
44 * @brief Initializes an mDNS resolver instance.
45 *
46 * Calling this function multiple times leads to unpredictable results.
47 *
48 * @param[in] daemon_priority The task priority of the mDNS daemon.
49 * @param[in] rrcachestorage The resource record cache storage.  Use
50 *   mDNS_Init_NoCache in case no cache is desired.
51 * @param[in] rrcachesize The resource record cache entity count of the
52 *   provided storage.  Use mDNS_Init_ZeroCacheSize in case no cache is desired.
53 *
54 * @retval RTEMS_SUCCESSFUL Successful operation.
55 * @retval RTEMS_UNSATISFIED Initialization is incomplete.
56 */
57rtems_status_code rtems_mdns_initialize(rtems_task_priority daemon_priority,
58    CacheEntity *rrcachestorage, mDNSu32 rrcachesize);
59
60/**
61 * @brief Returns the mDNS resolver instance.
62 *
63 * Using of this instance is only allowed after a successful call to
64 * rtems_mdns_initialize().
65 *
66 * @retval instance The mDNS resolver instance.
67 */
68mDNS *rtems_mdns_get_instance(void);
69
70#ifdef __cplusplus
71}
72#endif /* __cplusplus */
73
74#endif /* _RTEMS_MDNS_H_ */
Note: See TracBrowser for help on using the repository browser.