network_conf.h 8.8 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24
/*
 * network_conf.h: network XML handling
 *
 * Copyright (C) 2006-2008 Red Hat, Inc.
 * Copyright (C) 2006-2008 Daniel P. Berrange
 *
 * 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
 * License along with this library; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307  USA
 *
 * Author: Daniel P. Berrange <berrange@redhat.com>
 */

#ifndef __NETWORK_CONF_H__
25
# define __NETWORK_CONF_H__
26

27 28 29
# include <libxml/parser.h>
# include <libxml/tree.h>
# include <libxml/xpath.h>
30

31 32
# include "internal.h"
# include "threads.h"
33 34 35
# include "virsocketaddr.h"
# include "virnetdevbandwidth.h"
# include "virnetdevvportprofile.h"
36
# include "util.h"
37 38 39 40 41

enum virNetworkForwardType {
    VIR_NETWORK_FORWARD_NONE   = 0,
    VIR_NETWORK_FORWARD_NAT,
    VIR_NETWORK_FORWARD_ROUTE,
42 43 44 45
    VIR_NETWORK_FORWARD_BRIDGE,
    VIR_NETWORK_FORWARD_PRIVATE,
    VIR_NETWORK_FORWARD_VEPA,
    VIR_NETWORK_FORWARD_PASSTHROUGH,
46 47 48 49 50 51 52

    VIR_NETWORK_FORWARD_LAST,
};

typedef struct _virNetworkDHCPRangeDef virNetworkDHCPRangeDef;
typedef virNetworkDHCPRangeDef *virNetworkDHCPRangeDefPtr;
struct _virNetworkDHCPRangeDef {
53 54
    virSocketAddr start;
    virSocketAddr end;
55 56
};

57 58 59 60 61
typedef struct _virNetworkDHCPHostDef virNetworkDHCPHostDef;
typedef virNetworkDHCPHostDef *virNetworkDHCPHostDefPtr;
struct _virNetworkDHCPHostDef {
    char *mac;
    char *name;
62
    virSocketAddr ip;
63 64
};

65 66 67 68 69 70 71
typedef struct _virNetworkDNSTxtRecordsDef virNetworkDNSTxtRecordsDef;
typedef virNetworkDNSTxtRecordsDef *virNetworkDNSTxtRecordsDefPtr;
struct _virNetworkDNSTxtRecordsDef {
    char *name;
    char *value;
};

72
struct _virNetworkDNSHostsDef {
73 74 75
    virSocketAddr ip;
    int nnames;
    char **names;
76
};
77

78
typedef struct _virNetworkDNSHostsDef *virNetworkDNSHostsDefPtr;
79

80
struct _virNetworkDNSDef {
81 82
    unsigned int ntxtrecords;
    virNetworkDNSTxtRecordsDefPtr txtrecords;
83 84
    unsigned int nhosts;
    virNetworkDNSHostsDefPtr hosts;
85
};
86

87
typedef struct _virNetworkDNSDef *virNetworkDNSDefPtr;
88

89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114
typedef struct _virNetworkIpDef virNetworkIpDef;
typedef virNetworkIpDef *virNetworkIpDefPtr;
struct _virNetworkIpDef {
    char *family;               /* ipv4 or ipv6 - default is ipv4 */
    virSocketAddr address;      /* Bridge IP address */

    /* One or the other of the following two will be used for a given
     * IP address, but never both. The parser guarantees this.
     * Use virNetworkIpDefPrefix/virNetworkIpDefNetmask rather
     * than accessing the data directly - these utility functions
     * will convert one into the other as necessary.
     */
    unsigned int prefix;        /* ipv6 - only prefix allowed */
    virSocketAddr netmask;      /* ipv4 - either netmask or prefix specified */

    unsigned int nranges;        /* Zero or more dhcp ranges */
    virNetworkDHCPRangeDefPtr ranges;

    unsigned int nhosts;         /* Zero or more dhcp hosts */
    virNetworkDHCPHostDefPtr hosts;

    char *tftproot;
    char *bootfile;
    virSocketAddr bootserver;
   };

115 116 117 118 119 120 121 122 123 124 125 126
typedef struct _virNetworkForwardIfDef virNetworkForwardIfDef;
typedef virNetworkForwardIfDef *virNetworkForwardIfDefPtr;
struct _virNetworkForwardIfDef {
    char *dev;      /* name of device */
    int usageCount; /* how many guest interfaces are bound to this device? */
};

typedef struct _virPortGroupDef virPortGroupDef;
typedef virPortGroupDef *virPortGroupDefPtr;
struct _virPortGroupDef {
    char *name;
    bool isDefault;
127
    virNetDevVPortProfilePtr virtPortProfile;
128
    virNetDevBandwidthPtr bandwidth;
129 130
};

131 132 133 134 135 136 137
typedef struct _virNetworkDef virNetworkDef;
typedef virNetworkDef *virNetworkDefPtr;
struct _virNetworkDef {
    unsigned char uuid[VIR_UUID_BUFLEN];
    char *name;

    char *bridge;       /* Name of bridge device */
138
    char *domain;
139
    unsigned long delay;   /* Bridge forward delay (ms) */
140
    unsigned int stp :1; /* Spanning tree protocol */
141 142
    unsigned char mac[VIR_MAC_BUFLEN]; /* mac address of bridge device */
    bool mac_specified;
143 144

    int forwardType;    /* One of virNetworkForwardType constants */
145 146 147 148 149 150

    /* If there are multiple forward devices (i.e. a pool of
     * interfaces), they will be listed here.
     */
    size_t nForwardIfs;
    virNetworkForwardIfDefPtr forwardIfs;
151

152 153
    size_t nips;
    virNetworkIpDefPtr ips; /* ptr to array of IP addresses on this network */
154 155

    virNetworkDNSDefPtr dns; /* ptr to dns related configuration */
156
    virNetDevVPortProfilePtr virtPortProfile;
157 158 159

    size_t nPortGroups;
    virPortGroupDefPtr portGroups;
160
    virNetDevBandwidthPtr bandwidth;
161 162 163 164 165
};

typedef struct _virNetworkObj virNetworkObj;
typedef virNetworkObj *virNetworkObjPtr;
struct _virNetworkObj {
166
    virMutex lock;
167

168
    pid_t dnsmasqPid;
169
    pid_t radvdPid;
170 171 172 173 174 175
    unsigned int active : 1;
    unsigned int autostart : 1;
    unsigned int persistent : 1;

    virNetworkDefPtr def; /* The current definition */
    virNetworkDefPtr newDef; /* New definition to activate at shutdown */
176
};
177

178 179 180 181 182
typedef struct _virNetworkObjList virNetworkObjList;
typedef virNetworkObjList *virNetworkObjListPtr;
struct _virNetworkObjList {
    unsigned int count;
    virNetworkObjPtr *objs;
183 184 185
};

static inline int
D
Daniel P. Berrange 已提交
186
virNetworkObjIsActive(const virNetworkObjPtr net)
187 188 189 190
{
    return net->active;
}

191
virNetworkObjPtr virNetworkFindByUUID(const virNetworkObjListPtr nets,
192
                                      const unsigned char *uuid);
193
virNetworkObjPtr virNetworkFindByName(const virNetworkObjListPtr nets,
194 195 196 197 198
                                      const char *name);


void virNetworkDefFree(virNetworkDefPtr def);
void virNetworkObjFree(virNetworkObjPtr net);
199
void virNetworkObjListFree(virNetworkObjListPtr vms);
200

201
virNetworkObjPtr virNetworkAssignDef(virNetworkObjListPtr nets,
202
                                     const virNetworkDefPtr def);
203
void virNetworkRemoveInactive(virNetworkObjListPtr nets,
204 205
                              const virNetworkObjPtr net);

206 207 208
virNetworkDefPtr virNetworkDefParseString(const char *xmlStr);
virNetworkDefPtr virNetworkDefParseFile(const char *filename);
virNetworkDefPtr virNetworkDefParseNode(xmlDocPtr xml,
209 210
                                        xmlNodePtr root);

211
char *virNetworkDefFormat(const virNetworkDefPtr def);
212

213 214 215 216 217 218 219 220 221 222
static inline const char *
virNetworkDefForwardIf(const virNetworkDefPtr def, size_t n)
{
    return ((def->forwardIfs && (def->nForwardIfs > n))
            ? def->forwardIfs[n].dev : NULL);
}

virPortGroupDefPtr virPortGroupFindByName(virNetworkDefPtr net,
                                          const char *portgroup);

223 224 225 226 227 228
virNetworkIpDefPtr
virNetworkDefGetIpByIndex(const virNetworkDefPtr def,
                          int family, size_t n);
int virNetworkIpDefPrefix(const virNetworkIpDefPtr def);
int virNetworkIpDefNetmask(const virNetworkIpDefPtr def,
                           virSocketAddrPtr netmask);
229

230
int virNetworkSaveXML(const char *configDir,
231 232 233
                      virNetworkDefPtr def,
                      const char *xml);

234
int virNetworkSaveConfig(const char *configDir,
235
                         virNetworkDefPtr def);
236

237
virNetworkObjPtr virNetworkLoadConfig(virNetworkObjListPtr nets,
238 239 240 241
                                      const char *configDir,
                                      const char *autostartDir,
                                      const char *file);

242
int virNetworkLoadAllConfigs(virNetworkObjListPtr nets,
243 244 245
                             const char *configDir,
                             const char *autostartDir);

246
int virNetworkDeleteConfig(const char *configDir,
247
                           const char *autostartDir,
248 249
                           virNetworkObjPtr net);

250
char *virNetworkConfigFile(const char *dir,
251 252
                           const char *name);

253 254 255 256
int virNetworkBridgeInUse(const virNetworkObjListPtr nets,
                          const char *bridge,
                          const char *skipname);

257
char *virNetworkAllocateBridge(const virNetworkObjListPtr nets,
258
                               const char *template);
259

260
int virNetworkSetBridgeName(const virNetworkObjListPtr nets,
261 262
                            virNetworkDefPtr def,
                            int check_collision);
263

264 265
void virNetworkSetBridgeMacAddr(virNetworkDefPtr def);

266 267 268 269
int virNetworkObjIsDuplicate(virNetworkObjListPtr doms,
                             virNetworkDefPtr def,
                             unsigned int check_active);

D
Daniel P. Berrange 已提交
270 271 272
void virNetworkObjLock(virNetworkObjPtr obj);
void virNetworkObjUnlock(virNetworkObjPtr obj);

273
#endif /* __NETWORK_CONF_H__ */