mirror of
https://github.com/oliverschmidt/contiki.git
synced 2024-12-23 01:29:33 +00:00
Rewrote the sniffer code to use a list, which makes it possible to add any number of sniffers. Sniffers now can be both for incoming and outoing packets.
This commit is contained in:
parent
7a356d0fb5
commit
042180c13f
@ -33,7 +33,7 @@
|
|||||||
*
|
*
|
||||||
* This file is part of the Contiki operating system.
|
* This file is part of the Contiki operating system.
|
||||||
*
|
*
|
||||||
* $Id: rime.c,v 1.14 2008/01/08 07:53:02 adamdunkels Exp $
|
* $Id: rime.c,v 1.15 2008/01/14 09:42:00 adamdunkels Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -48,25 +48,36 @@
|
|||||||
#include "net/rime/route.h"
|
#include "net/rime/route.h"
|
||||||
#include "net/mac/mac.h"
|
#include "net/mac/mac.h"
|
||||||
|
|
||||||
|
#include "lib/list.h"
|
||||||
|
|
||||||
const struct mac_driver *rime_mac;
|
const struct mac_driver *rime_mac;
|
||||||
|
|
||||||
static void (*sniffer_callback)(void);
|
LIST(sniffers);
|
||||||
|
|
||||||
/*---------------------------------------------------------------------------*/
|
/*---------------------------------------------------------------------------*/
|
||||||
void
|
void
|
||||||
rime_set_sniffer(void (* sniffer)(void))
|
rime_sniffer_add(struct rime_sniffer *s)
|
||||||
{
|
{
|
||||||
sniffer_callback = sniffer;
|
list_add(sniffers, s);
|
||||||
|
}
|
||||||
|
/*---------------------------------------------------------------------------*/
|
||||||
|
void
|
||||||
|
rime_sniffer_remove(struct rime_sniffer *s)
|
||||||
|
{
|
||||||
|
list_remove(sniffers, s);
|
||||||
}
|
}
|
||||||
/*---------------------------------------------------------------------------*/
|
/*---------------------------------------------------------------------------*/
|
||||||
static void
|
static void
|
||||||
input(const struct mac_driver *r)
|
input(const struct mac_driver *r)
|
||||||
{
|
{
|
||||||
int len;
|
int len;
|
||||||
|
struct rime_sniffer *s;
|
||||||
len = rime_mac->read();
|
len = rime_mac->read();
|
||||||
if(len > 0) {
|
if(len > 0) {
|
||||||
if(sniffer_callback != NULL) {
|
for(s = list_head(sniffers); s != NULL; s = s->next) {
|
||||||
sniffer_callback();
|
if(s->input_callback != NULL) {
|
||||||
|
s->input_callback();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
RIMESTATS_ADD(rx);
|
RIMESTATS_ADD(rx);
|
||||||
abc_input_packet();
|
abc_input_packet();
|
||||||
@ -87,8 +98,17 @@ rime_init(const struct mac_driver *m)
|
|||||||
void
|
void
|
||||||
rime_output(void)
|
rime_output(void)
|
||||||
{
|
{
|
||||||
|
struct rime_sniffer *s;
|
||||||
|
|
||||||
RIMESTATS_ADD(tx);
|
RIMESTATS_ADD(tx);
|
||||||
rimebuf_compact();
|
rimebuf_compact();
|
||||||
|
|
||||||
|
for(s = list_head(sniffers); s != NULL; s = s->next) {
|
||||||
|
if(s->output_callback != NULL) {
|
||||||
|
s->output_callback();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if(rime_mac) {
|
if(rime_mac) {
|
||||||
rime_mac->send();
|
rime_mac->send();
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user