mirror of https://github.com/OISF/suricata
device-storage: introduce feature
The capture method may have to store data depending related to the offloading so having a per interface storage via LiveDevice seems interesting.pull/3221/head
parent
e2d31e1c57
commit
3ae714d354
@ -0,0 +1,111 @@
|
|||||||
|
/* Copyright (C) 2018 Open Information Security Foundation
|
||||||
|
*
|
||||||
|
* You can copy, redistribute or modify this Program under the terms of
|
||||||
|
* the GNU General Public License version 2 as published by the Free
|
||||||
|
* Software Foundation.
|
||||||
|
*
|
||||||
|
* This program 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 General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* version 2 along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
|
||||||
|
* 02110-1301, USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \file
|
||||||
|
*
|
||||||
|
* \author Eric Leblond <eric@regit.org>
|
||||||
|
*
|
||||||
|
* Device wrapper around storage api
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "suricata-common.h"
|
||||||
|
#include "device-storage.h"
|
||||||
|
#include "util-unittest.h"
|
||||||
|
|
||||||
|
unsigned int LiveDevStorageSize(void)
|
||||||
|
{
|
||||||
|
return StorageGetSize(STORAGE_DEVICE);
|
||||||
|
}
|
||||||
|
|
||||||
|
/** \defgroup devicestorage Device storage API
|
||||||
|
*
|
||||||
|
* The device storage API is a per-device storage. It is a mean to extend
|
||||||
|
* the LiveDevice structure with arbitrary data.
|
||||||
|
*
|
||||||
|
* You have first to register the storage via LiveDevStorageRegister() during
|
||||||
|
* the init of your module. Then you can attach data via LiveDevSetStorageById()
|
||||||
|
* and access them via LiveDevGetStorageById().
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \brief Register a LiveDevice storage
|
||||||
|
*
|
||||||
|
* \param name the name of the storage
|
||||||
|
* \param size integer coding the size of the stored value (sizeof(void *) is best choice here)
|
||||||
|
* \param Alloc allocation function for the storage (can be null)
|
||||||
|
* \param Free free function for the new storage
|
||||||
|
*
|
||||||
|
* \retval The ID of the newly register storage that will be used to access data
|
||||||
|
*
|
||||||
|
* It has to be called once during the init of the sub system
|
||||||
|
*/
|
||||||
|
|
||||||
|
int LiveDevStorageRegister(const char *name, const unsigned int size, void *(*Alloc)(unsigned int), void (*Free)(void *)) {
|
||||||
|
return StorageRegister(STORAGE_DEVICE, name, size, Alloc, Free);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \brief Store a pointer in a given LiveDevice storage
|
||||||
|
*
|
||||||
|
* \param d a pointer to the LiveDevice
|
||||||
|
* \param id the id of the storage (return of HostStorageRegister() call)
|
||||||
|
* \param ptr pointer to the data to store
|
||||||
|
*/
|
||||||
|
|
||||||
|
int LiveDevSetStorageById(LiveDevice *d, int id, void *ptr)
|
||||||
|
{
|
||||||
|
return StorageSetById((Storage *)((void *)d + sizeof(LiveDevice)), STORAGE_DEVICE, id, ptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \brief Get a value from a given LiveDevice storage
|
||||||
|
*
|
||||||
|
* \param d a pointer to the LiveDevice
|
||||||
|
* \param id the id of the storage (return of LiveDevStorageRegister() call)
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
void *LiveDevGetStorageById(LiveDevice *d, int id)
|
||||||
|
{
|
||||||
|
return StorageGetById((Storage *)((void *)d + sizeof(LiveDevice)), STORAGE_DEVICE, id);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Start of "private" function */
|
||||||
|
|
||||||
|
void *LiveDevAllocStorageById(LiveDevice *d, int id)
|
||||||
|
{
|
||||||
|
return StorageAllocByIdPrealloc((Storage *)((void *)d + sizeof(LiveDevice)), STORAGE_DEVICE, id);
|
||||||
|
}
|
||||||
|
|
||||||
|
void LiveDevFreeStorageById(LiveDevice *d, int id)
|
||||||
|
{
|
||||||
|
StorageFreeById((Storage *)((void *)d + sizeof(LiveDevice)), STORAGE_DEVICE, id);
|
||||||
|
}
|
||||||
|
|
||||||
|
void LiveDevFreeStorage(LiveDevice *d)
|
||||||
|
{
|
||||||
|
if (LiveDevStorageSize() > 0)
|
||||||
|
StorageFreeAll((Storage *)((void *)d + sizeof(LiveDevice)), STORAGE_DEVICE);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
@ -0,0 +1,45 @@
|
|||||||
|
/* Copyright (C) 2018 Open Information Security Foundation
|
||||||
|
*
|
||||||
|
* You can copy, redistribute or modify this Program under the terms of
|
||||||
|
* the GNU General Public License version 2 as published by the Free
|
||||||
|
* Software Foundation.
|
||||||
|
*
|
||||||
|
* This program 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 General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* version 2 along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
|
||||||
|
* 02110-1301, USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \file
|
||||||
|
*
|
||||||
|
* \author Eric Leblond <eric@regit.org>
|
||||||
|
*
|
||||||
|
* LiveDevice wrapper around storage api
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __DEVICE_STORAGE_H__
|
||||||
|
#define __DEVICE_STORAGE_H__
|
||||||
|
|
||||||
|
#include "util-storage.h"
|
||||||
|
#include "util-device.h"
|
||||||
|
|
||||||
|
unsigned int LiveDevStorageSize(void);
|
||||||
|
|
||||||
|
void *LiveDevGetStorageById(LiveDevice *d, int id);
|
||||||
|
int LiveDevSetStorageById(LiveDevice *d, int id, void *ptr);
|
||||||
|
void *LiveDevAllocStorageById(LiveDevice *d, int id);
|
||||||
|
|
||||||
|
void LiveDevFreeStorageById(LiveDevice *d, int id);
|
||||||
|
void LiveDevFreeStorage(LiveDevice *d);
|
||||||
|
|
||||||
|
void RegisterLiveDevStorageTests(void);
|
||||||
|
|
||||||
|
int LiveDevStorageRegister(const char *name, const unsigned int size, void *(*Alloc)(unsigned int), void (*Free)(void *));
|
||||||
|
|
||||||
|
#endif /* __DEVICE_STORAGE_H__ */
|
Loading…
Reference in New Issue