af-packet: configurable tpacket_v3 block size

It is used to set the block size in tpacket_v3. It will allow user
to tune the capture depending on his bandwidth.

Default block size value has been updated to a bigger value to
allow more efficient wlak on block.
pull/2091/head
Eric Leblond 10 years ago committed by Victor Julien
parent c7bde9dff6
commit fa902abedf

@ -361,6 +361,21 @@ void *ParseAFPConfig(const char *iface)
aconf->ring_size = max_pending_packets * 2 / aconf->threads; aconf->ring_size = max_pending_packets * 2 / aconf->threads;
} }
aconf->block_size = getpagesize() << AFP_BLOCK_SIZE_DEFAULT_ORDER;
if ((ConfGetChildValueIntWithDefault(if_root, if_default, "block-size", &value)) == 1) {
if (value % getpagesize()) {
SCLogError(SC_ERR_INVALID_VALUE, "Block-size must be a multiple of pagesize.");
} else {
aconf->block_size = value;
}
}
if ((ConfGetChildValueIntWithDefault(if_root, if_default, "block-timeout", &value)) == 1) {
aconf->block_timeout = value;
} else {
aconf->block_timeout = 10;
}
(void)ConfGetChildValueBoolWithDefault(if_root, if_default, "disable-promisc", (int *)&boolval); (void)ConfGetChildValueBoolWithDefault(if_root, if_default, "disable-promisc", (int *)&boolval);
if (boolval) { if (boolval) {
SCLogInfo("Disabling promiscuous mode on iface %s", SCLogInfo("Disabling promiscuous mode on iface %s",

@ -231,11 +231,11 @@ typedef struct AFPThreadVars_
int socket; int socket;
int ring_size; int ring_size;
/* Filter */ int block_size;
char *bpf_filter;
/* socket buffer size */ /* socket buffer size */
int buffer_size; int buffer_size;
/* Filter */
char *bpf_filter;
int promisc; int promisc;
@ -1555,7 +1555,7 @@ frame size: TPACKET_ALIGN(snaplen + TPACKET_ALIGN(TPACKET_ALIGN(tp_hdrlen) + siz
static int AFPComputeRingParamsV3(AFPThreadVars *ptv) static int AFPComputeRingParamsV3(AFPThreadVars *ptv)
{ {
ptv->req3.tp_block_size = getpagesize(); ptv->req3.tp_block_size = ptv->block_size;
ptv->req3.tp_frame_size = 2048; ptv->req3.tp_frame_size = 2048;
int frames_per_block = 0; int frames_per_block = 0;
int tp_hdrlen = sizeof(struct tpacket3_hdr); int tp_hdrlen = sizeof(struct tpacket3_hdr);
@ -1649,8 +1649,7 @@ static int AFPSetupRing(AFPThreadVars *ptv, char *devname)
return AFP_FATAL_ERROR; return AFP_FATAL_ERROR;
} }
} else { } else {
#define DEFAULT_ORDER 3 for (order = AFP_BLOCK_SIZE_DEFAULT_ORDER; order >= 0; order--) {
for (order = DEFAULT_ORDER; order >= 0; order--) {
if (AFPComputeRingParams(ptv, order) != 1) { if (AFPComputeRingParams(ptv, order) != 1) {
SCLogInfo("Ring parameter are incorrect. Please correct the devel"); SCLogInfo("Ring parameter are incorrect. Please correct the devel");
return AFP_FATAL_ERROR; return AFP_FATAL_ERROR;
@ -1982,6 +1981,7 @@ TmEcode ReceiveAFPThreadInit(ThreadVars *tv, void *initdata, void **data)
ptv->buffer_size = afpconfig->buffer_size; ptv->buffer_size = afpconfig->buffer_size;
ptv->ring_size = afpconfig->ring_size; ptv->ring_size = afpconfig->ring_size;
ptv->block_size = afpconfig->block_size;
ptv->promisc = afpconfig->promisc; ptv->promisc = afpconfig->promisc;
ptv->checksum_mode = afpconfig->checksum_mode; ptv->checksum_mode = afpconfig->checksum_mode;

@ -58,6 +58,8 @@
#define AFP_FILE_MAX_PKTS 256 #define AFP_FILE_MAX_PKTS 256
#define AFP_IFACE_NAME_LENGTH 48 #define AFP_IFACE_NAME_LENGTH 48
#define AFP_BLOCK_SIZE_DEFAULT_ORDER 3
typedef struct AFPIfaceConfig_ typedef struct AFPIfaceConfig_
{ {
char iface[AFP_IFACE_NAME_LENGTH]; char iface[AFP_IFACE_NAME_LENGTH];
@ -67,6 +69,8 @@ typedef struct AFPIfaceConfig_
int buffer_size; int buffer_size;
/* ring size in number of packets */ /* ring size in number of packets */
int ring_size; int ring_size;
/* block size for tpacket_v3 */
int block_size;
/* cluster param */ /* cluster param */
int cluster_id; int cluster_id;
int cluster_type; int cluster_type;

@ -478,6 +478,10 @@ af-packet:
# intensive single-flow you could want to set the ring-size independantly of the number # intensive single-flow you could want to set the ring-size independantly of the number
# of threads: # of threads:
#ring-size: 2048 #ring-size: 2048
# Block size is used by tpacket_v3 only. It should set to a value high enough to contain
# a decent number of packets. Size is in bytes so please consider your MTU. It should be
# a power of 2 and it must be multiple of page size (usually 4096).
#block-size: 32768
# On busy system, this could help to set it to yes to recover from a packet drop # On busy system, this could help to set it to yes to recover from a packet drop
# phase. This will result in some packets (at max a ring flush) being non treated. # phase. This will result in some packets (at max a ring flush) being non treated.
#use-emergency-flush: yes #use-emergency-flush: yes

Loading…
Cancel
Save