virnetdevtap.h 3.2 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 42
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_RETURN_CHECK;

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 51 52
char* virNetDevTapGetRealDeviceName(char *ifname)
      ATTRIBUTE_NONNULL(1) ATTRIBUTE_RETURN_CHECK;

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
int virNetDevTapCreateInBridgePort(const char *brname,
                                   char **ifname,
67
                                   const virMacAddr *macaddr,
68
                                   const unsigned char *vmuuid,
69
                                   const char *tunpath,
A
Ansis Atteka 已提交
70
                                   int *tapfd,
71
                                   size_t tapfdSize,
72
                                   virNetDevVPortProfilePtr virtPortProfile,
73
                                   virNetDevVlanPtr virtVlan,
74 75
                                   unsigned int mtu,
                                   unsigned int *actualMTU,
76
                                   unsigned int flags)
77 78 79
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_NONNULL(3)
    ATTRIBUTE_RETURN_CHECK;

80 81 82
int virNetDevTapInterfaceStats(const char *ifname,
                               virDomainInterfaceStatsPtr stats)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_RETURN_CHECK;
A
Ansis Atteka 已提交
83

84
#endif /* __VIR_NETDEV_TAP_H__ */