mirror of
https://github.com/libvirt/libvirt.git
synced 2025-02-25 18:55:26 -06:00
conf: move virNWFilterBindingDefPtr into its own files
There's no code sharing between virNWFilterDef and virNWFilterBindingDefPtr types, so it is clearer if they live in separate source files and headers. Reviewed-by: John Ferlan <jferlan@redhat.com> Signed-off-by: Daniel P. Berrangé <berrange@redhat.com>
This commit is contained in:
parent
ce376228e9
commit
7c7880dd98
@ -85,6 +85,8 @@ NWFILTER_CONF_SOURCES = \
|
|||||||
conf/nwfilter_conf.h \
|
conf/nwfilter_conf.h \
|
||||||
conf/virnwfilterobj.c \
|
conf/virnwfilterobj.c \
|
||||||
conf/virnwfilterobj.h \
|
conf/virnwfilterobj.h \
|
||||||
|
conf/virnwfilterbindingdef.c \
|
||||||
|
conf/virnwfilterbindingdef.h \
|
||||||
$(NULL)
|
$(NULL)
|
||||||
|
|
||||||
STORAGE_CONF_SOURCES = \
|
STORAGE_CONF_SOURCES = \
|
||||||
|
@ -3265,57 +3265,3 @@ virNWFilterRuleIsProtocolEthernet(virNWFilterRuleDefPtr rule)
|
|||||||
return true;
|
return true;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void
|
|
||||||
virNWFilterBindingDefFree(virNWFilterBindingDefPtr def)
|
|
||||||
{
|
|
||||||
if (!def)
|
|
||||||
return;
|
|
||||||
|
|
||||||
VIR_FREE(def->ownername);
|
|
||||||
VIR_FREE(def->portdevname);
|
|
||||||
VIR_FREE(def->linkdevname);
|
|
||||||
VIR_FREE(def->filter);
|
|
||||||
virHashFree(def->filterparams);
|
|
||||||
|
|
||||||
VIR_FREE(def);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
virNWFilterBindingDefPtr
|
|
||||||
virNWFilterBindingDefCopy(virNWFilterBindingDefPtr src)
|
|
||||||
{
|
|
||||||
virNWFilterBindingDefPtr ret;
|
|
||||||
|
|
||||||
if (VIR_ALLOC(ret) < 0)
|
|
||||||
return NULL;
|
|
||||||
|
|
||||||
if (VIR_STRDUP(ret->ownername, src->ownername) < 0)
|
|
||||||
goto error;
|
|
||||||
|
|
||||||
memcpy(ret->owneruuid, src->owneruuid, sizeof(ret->owneruuid));
|
|
||||||
|
|
||||||
if (VIR_STRDUP(ret->portdevname, src->portdevname) < 0)
|
|
||||||
goto error;
|
|
||||||
|
|
||||||
if (VIR_STRDUP(ret->linkdevname, src->linkdevname) < 0)
|
|
||||||
goto error;
|
|
||||||
|
|
||||||
ret->mac = src->mac;
|
|
||||||
|
|
||||||
if (VIR_STRDUP(ret->filter, src->filter) < 0)
|
|
||||||
goto error;
|
|
||||||
|
|
||||||
if (!(ret->filterparams = virNWFilterHashTableCreate(0)))
|
|
||||||
goto error;
|
|
||||||
|
|
||||||
if (virNWFilterHashTablePutAll(src->filterparams, ret->filterparams) < 0)
|
|
||||||
goto error;
|
|
||||||
|
|
||||||
return ret;
|
|
||||||
|
|
||||||
error:
|
|
||||||
virNWFilterBindingDefFree(ret);
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
@ -545,19 +545,6 @@ struct _virNWFilterDef {
|
|||||||
virNWFilterEntryPtr *filterEntries;
|
virNWFilterEntryPtr *filterEntries;
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef struct _virNWFilterBindingDef virNWFilterBindingDef;
|
|
||||||
typedef virNWFilterBindingDef *virNWFilterBindingDefPtr;
|
|
||||||
|
|
||||||
struct _virNWFilterBindingDef {
|
|
||||||
char *ownername;
|
|
||||||
unsigned char owneruuid[VIR_UUID_BUFLEN];
|
|
||||||
char *portdevname;
|
|
||||||
char *linkdevname;
|
|
||||||
virMacAddr mac;
|
|
||||||
char *filter;
|
|
||||||
virHashTablePtr filterparams;
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
typedef enum {
|
typedef enum {
|
||||||
STEP_APPLY_NEW,
|
STEP_APPLY_NEW,
|
||||||
@ -663,10 +650,6 @@ virNWFilterRuleIsProtocolIPv6(virNWFilterRuleDefPtr rule);
|
|||||||
bool
|
bool
|
||||||
virNWFilterRuleIsProtocolEthernet(virNWFilterRuleDefPtr rule);
|
virNWFilterRuleIsProtocolEthernet(virNWFilterRuleDefPtr rule);
|
||||||
|
|
||||||
void
|
|
||||||
virNWFilterBindingDefFree(virNWFilterBindingDefPtr binding);
|
|
||||||
virNWFilterBindingDefPtr
|
|
||||||
virNWFilterBindingDefCopy(virNWFilterBindingDefPtr src);
|
|
||||||
|
|
||||||
VIR_ENUM_DECL(virNWFilterRuleAction);
|
VIR_ENUM_DECL(virNWFilterRuleAction);
|
||||||
VIR_ENUM_DECL(virNWFilterRuleDirection);
|
VIR_ENUM_DECL(virNWFilterRuleDirection);
|
||||||
|
83
src/conf/virnwfilterbindingdef.c
Normal file
83
src/conf/virnwfilterbindingdef.c
Normal file
@ -0,0 +1,83 @@
|
|||||||
|
/*
|
||||||
|
* virnwfilterbindingdef.c: network filter binding XML processing
|
||||||
|
*
|
||||||
|
* Copyright (C) 2018 Red Hat, Inc.
|
||||||
|
*
|
||||||
|
* 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, see
|
||||||
|
* <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <config.h>
|
||||||
|
|
||||||
|
#include "viralloc.h"
|
||||||
|
#include "virerror.h"
|
||||||
|
#include "virstring.h"
|
||||||
|
#include "nwfilter_params.h"
|
||||||
|
#include "virnwfilterbindingdef.h"
|
||||||
|
|
||||||
|
|
||||||
|
#define VIR_FROM_THIS VIR_FROM_NWFILTER
|
||||||
|
|
||||||
|
void
|
||||||
|
virNWFilterBindingDefFree(virNWFilterBindingDefPtr def)
|
||||||
|
{
|
||||||
|
if (!def)
|
||||||
|
return;
|
||||||
|
|
||||||
|
VIR_FREE(def->ownername);
|
||||||
|
VIR_FREE(def->portdevname);
|
||||||
|
VIR_FREE(def->linkdevname);
|
||||||
|
VIR_FREE(def->filter);
|
||||||
|
virHashFree(def->filterparams);
|
||||||
|
|
||||||
|
VIR_FREE(def);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
virNWFilterBindingDefPtr
|
||||||
|
virNWFilterBindingDefCopy(virNWFilterBindingDefPtr src)
|
||||||
|
{
|
||||||
|
virNWFilterBindingDefPtr ret;
|
||||||
|
|
||||||
|
if (VIR_ALLOC(ret) < 0)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
if (VIR_STRDUP(ret->ownername, src->ownername) < 0)
|
||||||
|
goto error;
|
||||||
|
|
||||||
|
memcpy(ret->owneruuid, src->owneruuid, sizeof(ret->owneruuid));
|
||||||
|
|
||||||
|
if (VIR_STRDUP(ret->portdevname, src->portdevname) < 0)
|
||||||
|
goto error;
|
||||||
|
|
||||||
|
if (VIR_STRDUP(ret->linkdevname, src->linkdevname) < 0)
|
||||||
|
goto error;
|
||||||
|
|
||||||
|
ret->mac = src->mac;
|
||||||
|
|
||||||
|
if (VIR_STRDUP(ret->filter, src->filter) < 0)
|
||||||
|
goto error;
|
||||||
|
|
||||||
|
if (!(ret->filterparams = virNWFilterHashTableCreate(0)))
|
||||||
|
goto error;
|
||||||
|
|
||||||
|
if (virNWFilterHashTablePutAll(src->filterparams, ret->filterparams) < 0)
|
||||||
|
goto error;
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
|
||||||
|
error:
|
||||||
|
virNWFilterBindingDefFree(ret);
|
||||||
|
return NULL;
|
||||||
|
}
|
47
src/conf/virnwfilterbindingdef.h
Normal file
47
src/conf/virnwfilterbindingdef.h
Normal file
@ -0,0 +1,47 @@
|
|||||||
|
/*
|
||||||
|
* virnwfilterbindingdef.h: network filter binding XML processing
|
||||||
|
*
|
||||||
|
* Copyright (C) 2018 Red Hat, Inc.
|
||||||
|
*
|
||||||
|
* 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, see
|
||||||
|
* <http://www.gnu.org/licenses/>.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#ifndef VIR_NWFILTER_BINDING_DEF_H
|
||||||
|
# define VIR_NWFILTER_BINDING_DEF_H
|
||||||
|
|
||||||
|
# include "internal.h"
|
||||||
|
# include "virmacaddr.h"
|
||||||
|
# include "virhash.h"
|
||||||
|
|
||||||
|
typedef struct _virNWFilterBindingDef virNWFilterBindingDef;
|
||||||
|
typedef virNWFilterBindingDef *virNWFilterBindingDefPtr;
|
||||||
|
|
||||||
|
struct _virNWFilterBindingDef {
|
||||||
|
char *ownername;
|
||||||
|
unsigned char owneruuid[VIR_UUID_BUFLEN];
|
||||||
|
char *portdevname;
|
||||||
|
char *linkdevname;
|
||||||
|
virMacAddr mac;
|
||||||
|
char *filter;
|
||||||
|
virHashTablePtr filterparams;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
void
|
||||||
|
virNWFilterBindingDefFree(virNWFilterBindingDefPtr binding);
|
||||||
|
virNWFilterBindingDefPtr
|
||||||
|
virNWFilterBindingDefCopy(virNWFilterBindingDefPtr src);
|
||||||
|
|
||||||
|
#endif /* VIR_NWFILTER_BINDING_DEF_H */
|
@ -787,8 +787,6 @@ virDomainNumatuneSpecifiedMaxNode;
|
|||||||
|
|
||||||
|
|
||||||
# conf/nwfilter_conf.h
|
# conf/nwfilter_conf.h
|
||||||
virNWFilterBindingDefCopy;
|
|
||||||
virNWFilterBindingDefFree;
|
|
||||||
virNWFilterCallbackDriversLock;
|
virNWFilterCallbackDriversLock;
|
||||||
virNWFilterCallbackDriversUnlock;
|
virNWFilterCallbackDriversUnlock;
|
||||||
virNWFilterChainSuffixTypeToString;
|
virNWFilterChainSuffixTypeToString;
|
||||||
@ -1049,6 +1047,11 @@ virNodeDeviceObjListNumOfDevices;
|
|||||||
virNodeDeviceObjListRemove;
|
virNodeDeviceObjListRemove;
|
||||||
|
|
||||||
|
|
||||||
|
# conf/virnwfilterbindingdef.h
|
||||||
|
virNWFilterBindingDefCopy;
|
||||||
|
virNWFilterBindingDefFree;
|
||||||
|
|
||||||
|
|
||||||
# conf/virnwfilterobj.h
|
# conf/virnwfilterobj.h
|
||||||
virNWFilterObjGetDef;
|
virNWFilterObjGetDef;
|
||||||
virNWFilterObjGetNewDef;
|
virNWFilterObjGetNewDef;
|
||||||
|
Loading…
Reference in New Issue
Block a user