Home | History | Annotate | Line # | Download | only in libnpftest
npf_test_subr.c revision 1.9.2.1
      1  1.9.2.1    tls /*	$NetBSD: npf_test_subr.c,v 1.9.2.1 2014/08/09 06:19:50 tls Exp $	*/
      2      1.1  rmind 
      3      1.1  rmind /*
      4      1.1  rmind  * NPF initialisation and handler routines.
      5      1.1  rmind  *
      6      1.1  rmind  * Public Domain.
      7      1.1  rmind  */
      8      1.1  rmind 
      9      1.1  rmind #include <sys/types.h>
     10      1.7  rmind #include <sys/cprng.h>
     11      1.1  rmind #include <net/if.h>
     12      1.1  rmind #include <net/if_types.h>
     13      1.1  rmind 
     14      1.1  rmind #include "npf_impl.h"
     15      1.1  rmind #include "npf_test.h"
     16      1.1  rmind 
     17      1.1  rmind /* State of the current stream. */
     18      1.1  rmind static npf_state_t	cstream_state;
     19      1.1  rmind static void *		cstream_ptr;
     20      1.1  rmind static bool		cstream_retval;
     21      1.1  rmind 
     22      1.9  rmind static long		(*_random_func)(void);
     23      1.9  rmind static int		(*_pton_func)(int, const char *, void *);
     24      1.9  rmind static const char *	(*_ntop_func)(int, const void *, char *, socklen_t);
     25      1.9  rmind 
     26      1.4  rmind static void		npf_state_sample(npf_state_t *, bool);
     27      1.4  rmind 
     28      1.4  rmind void
     29      1.9  rmind npf_test_init(int (*pton_func)(int, const char *, void *),
     30      1.9  rmind     const char *(*ntop_func)(int, const void *, char *, socklen_t),
     31      1.9  rmind     long (*rndfunc)(void))
     32      1.4  rmind {
     33      1.4  rmind 	npf_state_setsampler(npf_state_sample);
     34      1.9  rmind 	_pton_func = pton_func;
     35      1.9  rmind 	_ntop_func = ntop_func;
     36      1.9  rmind 	_random_func = rndfunc;
     37      1.4  rmind }
     38      1.4  rmind 
     39      1.1  rmind int
     40      1.1  rmind npf_test_load(const void *xml)
     41      1.1  rmind {
     42      1.1  rmind 	prop_dictionary_t npf_dict = prop_dictionary_internalize(xml);
     43      1.1  rmind 	return npfctl_reload(0, npf_dict);
     44      1.1  rmind }
     45      1.1  rmind 
     46      1.6  rmind ifnet_t *
     47      1.6  rmind npf_test_addif(const char *ifname, bool reg, bool verbose)
     48      1.3  rmind {
     49      1.3  rmind 	ifnet_t *ifp = if_alloc(IFT_OTHER);
     50      1.3  rmind 
     51      1.3  rmind 	/*
     52      1.3  rmind 	 * This is a "fake" interface with explicitly set index.
     53      1.6  rmind 	 * Note: test modules may not setup pfil(9) hooks and if_attach()
     54      1.6  rmind 	 * may not trigger npf_ifmap_attach(), so we call it manually.
     55      1.3  rmind 	 */
     56      1.3  rmind 	strlcpy(ifp->if_xname, ifname, sizeof(ifp->if_xname));
     57      1.3  rmind 	ifp->if_dlt = DLT_NULL;
     58      1.6  rmind 	ifp->if_index = 0;
     59      1.3  rmind 	if_attach(ifp);
     60      1.3  rmind 	if_alloc_sadl(ifp);
     61      1.6  rmind 
     62      1.6  rmind 	npf_ifmap_attach(ifp);
     63      1.6  rmind 	if (reg) {
     64      1.6  rmind 		npf_ifmap_register(ifname);
     65      1.6  rmind 	}
     66      1.6  rmind 
     67      1.6  rmind 	if (verbose) {
     68      1.6  rmind 		printf("+ Interface %s\n", ifname);
     69      1.6  rmind 	}
     70      1.6  rmind 	return ifp;
     71      1.3  rmind }
     72      1.3  rmind 
     73      1.6  rmind ifnet_t *
     74      1.3  rmind npf_test_getif(const char *ifname)
     75      1.3  rmind {
     76      1.6  rmind 	return ifunit(ifname);
     77      1.3  rmind }
     78      1.3  rmind 
     79      1.1  rmind /*
     80      1.1  rmind  * State sampler - this routine is called from inside of NPF state engine.
     81      1.1  rmind  */
     82      1.4  rmind static void
     83      1.1  rmind npf_state_sample(npf_state_t *nst, bool retval)
     84      1.1  rmind {
     85      1.1  rmind 	/* Pointer will serve as an ID. */
     86      1.1  rmind 	cstream_ptr = nst;
     87      1.1  rmind 	memcpy(&cstream_state, nst, sizeof(npf_state_t));
     88      1.1  rmind 	cstream_retval = retval;
     89      1.1  rmind }
     90      1.1  rmind 
     91      1.1  rmind int
     92      1.6  rmind npf_test_statetrack(const void *data, size_t len, ifnet_t *ifp,
     93      1.1  rmind     bool forw, int64_t *result)
     94      1.1  rmind {
     95      1.1  rmind 	struct mbuf *m;
     96      1.1  rmind 	int i = 0, error;
     97      1.1  rmind 
     98      1.1  rmind 	m = mbuf_getwithdata(data, len);
     99      1.6  rmind 	error = npf_packet_handler(NULL, &m, ifp, forw ? PFIL_OUT : PFIL_IN);
    100      1.1  rmind 	if (error) {
    101      1.1  rmind 		assert(m == NULL);
    102      1.1  rmind 		return error;
    103      1.1  rmind 	}
    104      1.1  rmind 	assert(m != NULL);
    105      1.1  rmind 	m_freem(m);
    106      1.1  rmind 
    107      1.1  rmind 	const int di = forw ? NPF_FLOW_FORW : NPF_FLOW_BACK;
    108      1.1  rmind 	npf_tcpstate_t *fstate = &cstream_state.nst_tcpst[di];
    109      1.1  rmind 	npf_tcpstate_t *tstate = &cstream_state.nst_tcpst[!di];
    110      1.1  rmind 
    111      1.1  rmind 	result[i++] = (intptr_t)cstream_ptr;
    112      1.1  rmind 	result[i++] = cstream_retval;
    113      1.1  rmind 	result[i++] = cstream_state.nst_state;
    114      1.1  rmind 
    115      1.1  rmind 	result[i++] = fstate->nst_end;
    116      1.1  rmind 	result[i++] = fstate->nst_maxend;
    117      1.1  rmind 	result[i++] = fstate->nst_maxwin;
    118      1.2  rmind 	result[i++] = fstate->nst_wscale;
    119      1.1  rmind 
    120      1.1  rmind 	result[i++] = tstate->nst_end;
    121      1.1  rmind 	result[i++] = tstate->nst_maxend;
    122      1.1  rmind 	result[i++] = tstate->nst_maxwin;
    123      1.2  rmind 	result[i++] = tstate->nst_wscale;
    124      1.1  rmind 
    125      1.1  rmind 	return 0;
    126      1.1  rmind }
    127      1.7  rmind 
    128      1.9  rmind int
    129      1.9  rmind npf_inet_pton(int af, const char *src, void *dst)
    130      1.9  rmind {
    131      1.9  rmind 	return _pton_func(af, src, dst);
    132      1.9  rmind }
    133      1.9  rmind 
    134      1.9  rmind const char *
    135      1.9  rmind npf_inet_ntop(int af, const void *src, char *dst, socklen_t size)
    136      1.9  rmind {
    137      1.9  rmind 	return _ntop_func(af, src, dst, size);
    138      1.9  rmind }
    139      1.9  rmind 
    140      1.7  rmind /*
    141  1.9.2.1    tls  * Need to override cprng_fast32() -- we need deterministic PRNG.
    142      1.7  rmind  */
    143      1.7  rmind uint32_t
    144  1.9.2.1    tls cprng_fast32(void)
    145      1.7  rmind {
    146      1.9  rmind 	return (uint32_t)(_random_func ? _random_func() : random());
    147      1.7  rmind }
    148