mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
303 lines
9.1 KiB
C
303 lines
9.1 KiB
C
/*
|
|
* @f ccnl-core.h
|
|
* @b CCN lite (CCNL), core header file (internal data structures)
|
|
*
|
|
* Copyright (C) 2011-13, Christian Tschudin, University of Basel
|
|
*
|
|
* Permission to use, copy, modify, and/or distribute this software for any
|
|
* purpose with or without fee is hereby granted, provided that the above
|
|
* copyright notice and this permission notice appear in all copies.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
|
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
|
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
|
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
|
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
|
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
|
*
|
|
* File history:
|
|
* 2011-04-09 created
|
|
* 2013-03-19 updated (ms): modified struct ccnl_relay_s for 'aux' field
|
|
*/
|
|
|
|
#ifndef CCNL_CORE_H__
|
|
#define CCNL_CORE_H__
|
|
|
|
#define EXACT_MATCH 1
|
|
#define PREFIX_MATCH 0
|
|
|
|
#define CMP_EXACT 0 // used to compare interests among themselves
|
|
#define CMP_MATCH 1 // used to match interest and content
|
|
#define CMP_LONGEST 2 // used to lookup the FIB
|
|
|
|
#define CCNL_FACE_FLAGS_STATIC 1
|
|
#define CCNL_FACE_FLAGS_REFLECT 2
|
|
#define CCNL_FACE_FLAGS_SERVED 4
|
|
#define CCNL_FACE_FLAGS_FWDALLI 8 // forward all interests, also known ones
|
|
#define CCNL_FACE_FLAGS_BROADCAST 16
|
|
|
|
#define CCNL_FRAG_NONE 0
|
|
#define CCNL_FRAG_SEQUENCED2012 1
|
|
#define CCNL_FRAG_CCNx2013 2
|
|
|
|
#define CCNL_CONTENT_FLAGS_STATIC 0x01
|
|
#define CCNL_CONTENT_FLAGS_STALE 0x02
|
|
|
|
#define CCNL_FORWARD_FLAGS_STATIC 0x01
|
|
|
|
#include <inttypes.h>
|
|
#include <time.h>
|
|
#include <sys/time.h>
|
|
|
|
#include "mutex.h"
|
|
|
|
#include "ccnl.h"
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
// ----------------------------------------------------------------------
|
|
|
|
typedef union {
|
|
uint16_t id;
|
|
} sockunion;
|
|
|
|
struct ccnl_txrequest_s {
|
|
struct ccnl_buf_s *buf;
|
|
sockunion dst;
|
|
void (*txdone)(void *, int, int);
|
|
struct ccnl_face_s *txdone_face;
|
|
};
|
|
|
|
struct ccnl_if_s { // interface for packet IO
|
|
sockunion addr;
|
|
int sock;
|
|
int (*sendfunc)(uint8_t *, uint16_t, uint16_t);
|
|
int reflect; // whether to reflect I packets on this interface
|
|
int fwdalli; // whether to forward all I packets rcvd on this interface
|
|
int mtu;
|
|
|
|
int qlen; // number of pending sends
|
|
int qfront; // index of next packet to send
|
|
struct ccnl_txrequest_s queue[CCNL_MAX_IF_QLEN];
|
|
struct ccnl_sched_s *sched;
|
|
struct ccnl_face_s *broadcast_face;
|
|
};
|
|
|
|
struct ccnl_relay_s {
|
|
struct timeval startup_time;
|
|
int id;
|
|
struct ccnl_face_s *faces;
|
|
struct ccnl_forward_s *fib;
|
|
struct ccnl_interest_s *pit;
|
|
struct ccnl_content_s *contents; //, *contentsend;
|
|
struct ccnl_nonce_s *nonces;
|
|
int contentcnt; // number of cached items
|
|
int max_cache_entries; // -1: unlimited
|
|
struct ccnl_if_s ifs[CCNL_MAX_INTERFACES];
|
|
int ifcount; // number of active interfaces
|
|
char halt_flag;
|
|
struct ccnl_sched_s *(*defaultFaceScheduler)(struct ccnl_relay_s *,
|
|
void(*cts_done)(void *, void *));
|
|
struct ccnl_sched_s *(*defaultInterfaceScheduler)(struct ccnl_relay_s *,
|
|
void(*cts_done)(void *, void *));
|
|
struct ccnl_http_s *http;
|
|
struct ccnl_stats_s *stats;
|
|
void *aux;
|
|
int fib_threshold_prefix; /* how may name components should be considdered as dynamic */
|
|
int fib_threshold_aggregate;
|
|
kernel_pid_t riot_pid;
|
|
kernel_pid_t riot_helper_pid;
|
|
mutex_t global_lock;
|
|
mutex_t stop_lock;
|
|
};
|
|
|
|
struct ccnl_buf_s {
|
|
struct ccnl_buf_s *next;
|
|
unsigned int datalen;
|
|
unsigned char data[1];
|
|
};
|
|
|
|
struct ccnl_nonce_s {
|
|
struct ccnl_nonce_s *next, *prev;
|
|
struct timeval created;
|
|
struct ccnl_buf_s *buf;
|
|
};
|
|
|
|
struct ccnl_prefix_s {
|
|
unsigned char **comp;
|
|
int *complen;
|
|
int compcnt;
|
|
unsigned char *path; // memory for name component copies
|
|
};
|
|
|
|
struct ccnl_stat_s {
|
|
int send_interest[CCNL_MAX_INTEREST_RETRANSMIT];
|
|
int send_content[CCNL_MAX_CONTENT_SERVED_STAT];
|
|
int received_interest;
|
|
int received_content;
|
|
};
|
|
|
|
struct ccnl_frag_s {
|
|
int protocol; // (0=plain CCNx)
|
|
int mtu;
|
|
sockunion dest;
|
|
struct ccnl_buf_s *bigpkt;
|
|
unsigned int sendoffs;
|
|
// transport state, if present:
|
|
int ifndx;
|
|
|
|
struct ccnl_buf_s *defrag;
|
|
|
|
unsigned int sendseq;
|
|
unsigned int losscount;
|
|
unsigned int recvseq;
|
|
unsigned char flagwidth;
|
|
unsigned char sendseqwidth;
|
|
unsigned char losscountwidth;
|
|
unsigned char recvseqwidth;
|
|
};
|
|
|
|
struct ccnl_face_s {
|
|
struct ccnl_face_s *next, *prev;
|
|
int faceid;
|
|
int ifndx;
|
|
sockunion peer;
|
|
int flags;
|
|
struct timeval last_used; // updated when we receive a packet
|
|
struct ccnl_buf_s *outq, *outqend; // queue of packets to send
|
|
struct ccnl_frag_s *frag; // which special datagram armoring
|
|
struct ccnl_sched_s *sched;
|
|
|
|
struct ccnl_stat_s stat;
|
|
};
|
|
|
|
struct ccnl_forward_s {
|
|
struct ccnl_forward_s *next, *prev;
|
|
struct ccnl_prefix_s *prefix;
|
|
struct ccnl_face_s *face;
|
|
int flags;
|
|
struct timeval last_used; // updated when we use this fib entry
|
|
};
|
|
|
|
struct ccnl_interest_s {
|
|
struct ccnl_interest_s *next, *prev;
|
|
struct ccnl_face_s *from;
|
|
struct ccnl_pendint_s *pending; // linked list of faces wanting that content
|
|
struct ccnl_prefix_s *prefix;
|
|
int minsuffix, maxsuffix;
|
|
struct ccnl_buf_s *ppkd; // publisher public key digest
|
|
struct ccnl_buf_s *pkt; // full datagram
|
|
struct timeval last_used;
|
|
int retries;
|
|
struct ccnl_forward_s *forwarded_over;
|
|
};
|
|
|
|
struct ccnl_pendint_s { // pending interest
|
|
struct ccnl_pendint_s *next; // , *prev;
|
|
struct ccnl_face_s *face;
|
|
struct timeval last_used;
|
|
};
|
|
|
|
struct ccnl_content_s {
|
|
struct ccnl_content_s *next, *prev;
|
|
struct ccnl_prefix_s *name;
|
|
struct ccnl_buf_s *ppkd; // publisher public key digest
|
|
struct ccnl_buf_s *pkt; // full datagram
|
|
int flags;
|
|
unsigned char *content; // pointer into the data buffer
|
|
int contentlen;
|
|
// NON-CONFORM: "The [ContentSTore] MUST also implement the Staleness Bit."
|
|
// >> CCNL: currently no stale bit, old content is fully removed <<
|
|
struct timeval last_used;
|
|
int served_cnt;
|
|
};
|
|
|
|
// ----------------------------------------------------------------------
|
|
// macros for double linked lists (these double linked lists are not rings)
|
|
|
|
#define DBL_LINKED_LIST_ADD(l,e) \
|
|
do { if ((l)) (l)->prev = (e); \
|
|
(e)->next = (l); \
|
|
(l) = (e); \
|
|
} while(0)
|
|
|
|
#define DBL_LINKED_LIST_REMOVE(l,e) \
|
|
do { if ((l) == (e)) (l) = (e)->next; \
|
|
if ((e)->prev) (e)->prev->next = (e)->next; \
|
|
if ((e)->next) (e)->next->prev = (e)->prev; \
|
|
} while(0)
|
|
|
|
// ----------------------------------------------------------------------
|
|
// collect the USE_* macros in a string
|
|
const char *compile_string(void);
|
|
|
|
int consume(int typ, int num, unsigned char **buf, int *len,
|
|
unsigned char **valptr, int *vallen);
|
|
|
|
void
|
|
ccnl_core_RX(struct ccnl_relay_s *relay, int ifndx, unsigned char *data,
|
|
int datalen, uint16_t sender_id);
|
|
|
|
void ccnl_core_cleanup(struct ccnl_relay_s *ccnl);
|
|
|
|
struct ccnl_buf_s *
|
|
ccnl_buf_new(void *data, int len);
|
|
|
|
struct ccnl_content_s *
|
|
ccnl_content_new(struct ccnl_relay_s *ccnl, struct ccnl_buf_s **pkt,
|
|
struct ccnl_prefix_s **prefix, struct ccnl_buf_s **ppkd,
|
|
unsigned char *content, int contlen);
|
|
|
|
struct ccnl_content_s *
|
|
ccnl_content_add2cache(struct ccnl_relay_s *ccnl, struct ccnl_content_s *c);
|
|
|
|
void ccnl_content_learn_name_route(struct ccnl_relay_s *ccnl, struct ccnl_prefix_s *p,
|
|
struct ccnl_face_s *f, int threshold_prefix, int flags);
|
|
|
|
struct ccnl_face_s *
|
|
ccnl_get_face_or_create(struct ccnl_relay_s *ccnl, int ifndx, uint16_t sender_id);
|
|
|
|
int ccnl_face_enqueue(struct ccnl_relay_s *ccnl, struct ccnl_face_s *to,
|
|
struct ccnl_buf_s *buf);
|
|
|
|
struct ccnl_face_s *
|
|
ccnl_face_remove(struct ccnl_relay_s *ccnl, struct ccnl_face_s *f);
|
|
|
|
struct ccnl_forward_s *
|
|
ccnl_forward_remove(struct ccnl_relay_s *ccnl, struct ccnl_forward_s *fwd);
|
|
|
|
struct ccnl_buf_s *
|
|
ccnl_extract_prefix_nonce_ppkd(unsigned char **data, int *datalen, int *scope,
|
|
int *aok, int *min, int *max, struct ccnl_prefix_s **prefix,
|
|
struct ccnl_buf_s **nonce, struct ccnl_buf_s **ppkd,
|
|
unsigned char **content, int *contlen);
|
|
|
|
void ccnl_do_retransmit(void *ptr, void *dummy);
|
|
void ccnl_do_ageing(void *ptr, void *dummy);
|
|
void ccnl_do_nonce_timeout(void *ptr, void *dummy);
|
|
|
|
void ccnl_interface_CTS(void *aux1, void *aux2);
|
|
|
|
void ccnl_face_print_stat(struct ccnl_face_s *f);
|
|
|
|
#define ccnl_malloc(s) malloc(s)
|
|
#define ccnl_calloc(n,s) calloc(n,s)
|
|
#define ccnl_realloc(p,s) realloc(p,s)
|
|
#define ccnl_free(p) free(p)
|
|
|
|
void free_2ptr_list(void *a, void *b);
|
|
void free_3ptr_list(void *a, void *b, void *c);
|
|
void free_4ptr_list(void *a, void *b, void *c, void *d);
|
|
void free_prefix(struct ccnl_prefix_s *p);
|
|
void free_content(struct ccnl_content_s *c);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /*CCNL_CORE_H__*/
|
|
// eof
|