virnetdevtap.h 3.8 KB
Newer Older
1
/*
2
 * Copyright (C) 2007-2011, 2013 Red Hat, Inc.
3 4 5 6 7 8 9 10 11 12 13 14
 *
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2.1 of the License, or (at your option) any later version.
 *
 * This library 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
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
15
 * License along with this library.  If not, see
O
Osier Yang 已提交
16
 * <http://www.gnu.org/licenses/>.
17 18 19 20 21 22 23 24 25 26
 *
 * Authors:
 *     Mark McLoughlin <markmc@redhat.com>
 *     Daniel P. Berrange <berrange@redhat.com>
 */

#ifndef __VIR_NETDEV_TAP_H__
# define __VIR_NETDEV_TAP_H__

# include "internal.h"
27
# include "virnetdev.h"
A
Ansis Atteka 已提交
28
# include "virnetdevvportprofile.h"
29
# include "virnetdevvlan.h"
30

31 32 33 34 35 36
# ifdef __FreeBSD__
/* This should be defined on OSes that don't automatically
 * cleanup released devices */
#  define VIR_NETDEV_TAP_REQUIRE_MANUAL_CLEANUP 1
# endif

37
int virNetDevTapCreate(char **ifname,
38
                       const char *tunpath,
39
                       int *tapfd,
40
                       size_t tapfdSize,
41
                       unsigned int flags)
42
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_RETURN_CHECK ATTRIBUTE_NOINLINE;
43

44 45
int virNetDevTapDelete(const char *ifname,
                       const char *tunpath)
46 47
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_RETURN_CHECK;

48 49 50
int virNetDevTapGetName(int tapfd, char **ifname)
    ATTRIBUTE_NONNULL(2) ATTRIBUTE_RETURN_CHECK;

51
char* virNetDevTapGetRealDeviceName(char *ifname)
52
      ATTRIBUTE_NONNULL(1) ATTRIBUTE_RETURN_CHECK ATTRIBUTE_NOINLINE;
53

54 55 56 57 58 59 60 61
typedef enum {
   VIR_NETDEV_TAP_CREATE_NONE = 0,
   /* Bring the interface up */
   VIR_NETDEV_TAP_CREATE_IFUP               = 1 << 0,
   /* Enable IFF_VNET_HDR on the tap device */
   VIR_NETDEV_TAP_CREATE_VNET_HDR           = 1 << 1,
   /* Set this interface's MAC as the bridge's MAC address */
   VIR_NETDEV_TAP_CREATE_USE_MAC_FOR_BRIDGE = 1 << 2,
62 63
   /* The device will persist after the file descriptor is closed */
   VIR_NETDEV_TAP_CREATE_PERSIST            = 1 << 3,
64 65
} virNetDevTapCreateFlags;

66 67 68 69 70 71 72 73 74 75 76 77
int
virNetDevTapAttachBridge(const char *tapname,
                         const char *brname,
                         const virMacAddr *macaddr,
                         const unsigned char *vmuuid,
                         virNetDevVPortProfilePtr virtPortProfile,
                         virNetDevVlanPtr virtVlan,
                         unsigned int mtu,
                         unsigned int *actualMTU)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_NONNULL(3)
    ATTRIBUTE_RETURN_CHECK;

78 79
int virNetDevTapCreateInBridgePort(const char *brname,
                                   char **ifname,
80
                                   const virMacAddr *macaddr,
81
                                   const unsigned char *vmuuid,
82
                                   const char *tunpath,
A
Ansis Atteka 已提交
83
                                   int *tapfd,
84
                                   size_t tapfdSize,
85
                                   virNetDevVPortProfilePtr virtPortProfile,
86
                                   virNetDevVlanPtr virtVlan,
87
                                   virNetDevCoalescePtr coalesce,
88 89
                                   unsigned int mtu,
                                   unsigned int *actualMTU,
90
                                   unsigned int flags)
91
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_NONNULL(3)
92
    ATTRIBUTE_RETURN_CHECK ATTRIBUTE_NOINLINE;
93

94 95 96
int virNetDevTapInterfaceStats(const char *ifname,
                               virDomainInterfaceStatsPtr stats)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_RETURN_CHECK;
A
Ansis Atteka 已提交
97

98
#endif /* __VIR_NETDEV_TAP_H__ */