mirror of
https://git.proxmox.com/git/mirror_frr
synced 2025-11-06 01:05:47 +00:00
Infrastructure that allows protocol buffers to be used in Quagga. The
changes below comprise of:
- Build hooks
- Protobuf definitions for common types.
- Library routines for working with protobuf, including functions
that help translate between common quagga types and their protobuf
equivalents.
Changes:
* qpb/{Makefile.am,README.txt,qpb.h,.gitignore}
Add the qpb library, which provides shared code and definitions
for using protocol buffers in quagga code.
* qpb/qpb.proto
Protobuf definitions that can be shared by all of quagga.
* qpb/linear_allocator.h
An allocator that allocates memory by walking down towards the end
of a buffer. This is used to cheaply allocate/deallocate memory on
the stack for protobuf operations.
* qpb/qpb_allocator.[ch]
Thin layer that allows a linear allocator to be used with the
protobuf-c library.
* common.am
This is an automake fragment that is intended to be shared by
Makefile.am files in the tree. It currently includes definitions
related to protobuf.
* configure.ac
- Add logic to optionally build protobuf code.
By default, protobuf support is enabled if the protobuf C
compiler (protoc-c) is available, and the associated header
files/library can be found.
The user can choose to override this behavior via the new
--disable-protobuf/--enable-protobuf flags.
- Include the quagga protobuf library (qpb) in the build.
* .gitignore
Ignore source code generated by protobuf compiler.
* Makefile.am
Add 'qpb' to the list of subdirectories.
Signed-off-by: Avneesh Sachdev <avneesh@sproute.com>
Edited: Paul Jakma <paul.jakma@hpe.com>: Change the sense of the
configure enable option to require explicit specifying, as
an experimental feature.
68 lines
1.6 KiB
C
68 lines
1.6 KiB
C
/*
|
|
* qpb_allocator.c
|
|
*
|
|
* @copyright Copyright (C) 2016 Sproute Networks, Inc.
|
|
*
|
|
* @author Avneesh Sachdev <avneesh@sproute.com>
|
|
*
|
|
* This file is part of Quagga.
|
|
*
|
|
* Quagga is free software; you can redistribute it and/or modify it
|
|
* under the terms of the GNU General Public License as published by the
|
|
* Free Software Foundation; either version 2, or (at your option) any
|
|
* later version.
|
|
*
|
|
* Quagga 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
|
|
* along with Quagga; see the file COPYING. If not, write to the Free
|
|
* Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
|
|
* 02111-1307, USA.
|
|
*/
|
|
|
|
#include "linear_allocator.h"
|
|
|
|
#include "qpb_allocator.h"
|
|
|
|
/*
|
|
* _qpb_alloc
|
|
*/
|
|
static void *
|
|
_qpb_alloc (void *allocator_data, size_t size)
|
|
{
|
|
return linear_allocator_alloc (allocator_data, size);
|
|
}
|
|
|
|
/*
|
|
* _qpb_free
|
|
*/
|
|
static void
|
|
_qpb_free (void *allocator_data, void *ptr)
|
|
{
|
|
linear_allocator_free (allocator_data, ptr);
|
|
}
|
|
|
|
static ProtobufCAllocator allocator_template = {
|
|
_qpb_alloc,
|
|
_qpb_free,
|
|
NULL,
|
|
8192,
|
|
NULL
|
|
};
|
|
|
|
/*
|
|
* qpb_allocator_init_linear
|
|
*
|
|
* Initialize qpb_allocator_t with the given linear allocator.
|
|
*/
|
|
void
|
|
qpb_allocator_init_linear (qpb_allocator_t *allocator,
|
|
linear_allocator_t *linear_allocator)
|
|
{
|
|
*allocator = allocator_template;
|
|
allocator->allocator_data = linear_allocator;
|
|
}
|