virnetdevtap.h 3.7 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"
A
Ansis Atteka 已提交
27
# include "virnetdevvportprofile.h"
28
# include "virnetdevvlan.h"
29

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

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

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

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

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

53 54 55 56 57 58 59 60
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,
61 62
   /* The device will persist after the file descriptor is closed */
   VIR_NETDEV_TAP_CREATE_PERSIST            = 1 << 3,
63 64
} virNetDevTapCreateFlags;

65 66 67 68 69 70 71 72 73 74 75 76
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;

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

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

96
#endif /* __VIR_NETDEV_TAP_H__ */