1be4f3cd0SPaolo Pisati /*-
2*4d846d26SWarner Losh * SPDX-License-Identifier: BSD-2-Clause
3fe267a55SPedro F. Giffuni *
4be4f3cd0SPaolo Pisati * Copyright (c) 2005 Paolo Pisati <piso@FreeBSD.org>
5be4f3cd0SPaolo Pisati * All rights reserved.
6be4f3cd0SPaolo Pisati *
7be4f3cd0SPaolo Pisati * Redistribution and use in source and binary forms, with or without
8be4f3cd0SPaolo Pisati * modification, are permitted provided that the following conditions
9be4f3cd0SPaolo Pisati * are met:
10be4f3cd0SPaolo Pisati * 1. Redistributions of source code must retain the above copyright
11be4f3cd0SPaolo Pisati * notice, this list of conditions and the following disclaimer.
12be4f3cd0SPaolo Pisati * 2. Redistributions in binary form must reproduce the above copyright
13be4f3cd0SPaolo Pisati * notice, this list of conditions and the following disclaimer in the
14be4f3cd0SPaolo Pisati * documentation and/or other materials provided with the distribution.
15be4f3cd0SPaolo Pisati *
16be4f3cd0SPaolo Pisati * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
17be4f3cd0SPaolo Pisati * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18be4f3cd0SPaolo Pisati * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19be4f3cd0SPaolo Pisati * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
20be4f3cd0SPaolo Pisati * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
21be4f3cd0SPaolo Pisati * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
22be4f3cd0SPaolo Pisati * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
23be4f3cd0SPaolo Pisati * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
24be4f3cd0SPaolo Pisati * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
25be4f3cd0SPaolo Pisati * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26be4f3cd0SPaolo Pisati * SUCH DAMAGE.
27be4f3cd0SPaolo Pisati */
28be4f3cd0SPaolo Pisati
29be4f3cd0SPaolo Pisati #include <sys/cdefs.h>
30be4f3cd0SPaolo Pisati /*
31be4f3cd0SPaolo Pisati * Alias_dummy is just an empty skeleton used to demostrate how to write
32be4f3cd0SPaolo Pisati * a module for libalias, that will run unalterated in userland or in
33be4f3cd0SPaolo Pisati * kernel land.
34be4f3cd0SPaolo Pisati */
35be4f3cd0SPaolo Pisati
36be4f3cd0SPaolo Pisati #ifdef _KERNEL
37be4f3cd0SPaolo Pisati #include <sys/param.h>
38be4f3cd0SPaolo Pisati #include <sys/kernel.h>
39be4f3cd0SPaolo Pisati #include <sys/module.h>
40be4f3cd0SPaolo Pisati #else
41be4f3cd0SPaolo Pisati #include <errno.h>
42be4f3cd0SPaolo Pisati #include <sys/types.h>
43be4f3cd0SPaolo Pisati #include <stdio.h>
44be4f3cd0SPaolo Pisati #endif
45be4f3cd0SPaolo Pisati
46be4f3cd0SPaolo Pisati #include <netinet/in_systm.h>
47be4f3cd0SPaolo Pisati #include <netinet/in.h>
48be4f3cd0SPaolo Pisati #include <netinet/ip.h>
49be4f3cd0SPaolo Pisati #include <netinet/udp.h>
50be4f3cd0SPaolo Pisati
51be4f3cd0SPaolo Pisati #ifdef _KERNEL
52be4f3cd0SPaolo Pisati #include <netinet/libalias/alias_local.h>
53be4f3cd0SPaolo Pisati #include <netinet/libalias/alias_mod.h>
54be4f3cd0SPaolo Pisati #else
55be4f3cd0SPaolo Pisati #include "alias_local.h"
56be4f3cd0SPaolo Pisati #include "alias_mod.h"
57be4f3cd0SPaolo Pisati #endif
58be4f3cd0SPaolo Pisati
59be4f3cd0SPaolo Pisati static void
60be4f3cd0SPaolo Pisati AliasHandleDummy(struct libalias *la, struct ip *ip, struct alias_data *ah);
61be4f3cd0SPaolo Pisati
62be4f3cd0SPaolo Pisati static int
fingerprint(struct libalias * la,struct alias_data * ah)6343197d29SPaolo Pisati fingerprint(struct libalias *la, struct alias_data *ah)
64be4f3cd0SPaolo Pisati {
65be4f3cd0SPaolo Pisati /*
66be4f3cd0SPaolo Pisati * Check here all the data that will be used later, if any field
67be4f3cd0SPaolo Pisati * is empy/NULL, return a -1 value.
68be4f3cd0SPaolo Pisati */
69be4f3cd0SPaolo Pisati if (ah->dport == NULL || ah->sport == NULL || ah->lnk == NULL ||
70be4f3cd0SPaolo Pisati ah->maxpktsize == 0)
71be4f3cd0SPaolo Pisati return (-1);
72be4f3cd0SPaolo Pisati /*
73be4f3cd0SPaolo Pisati * Fingerprint the incoming packet, if it matches any conditions
74be4f3cd0SPaolo Pisati * return an OK value.
75be4f3cd0SPaolo Pisati */
76effc8e57SLutz Donnerhacke if (ntohs(*ah->dport) == 123 || ntohs(*ah->sport) == 456)
77be4f3cd0SPaolo Pisati return (0); /* I know how to handle it. */
78be4f3cd0SPaolo Pisati return (-1); /* I don't recognize this packet. */
79be4f3cd0SPaolo Pisati }
80be4f3cd0SPaolo Pisati
81be4f3cd0SPaolo Pisati /*
82be4f3cd0SPaolo Pisati * Wrap in this general purpose function, the real function used to alias the
83be4f3cd0SPaolo Pisati * packets.
84be4f3cd0SPaolo Pisati */
85be4f3cd0SPaolo Pisati
86be4f3cd0SPaolo Pisati static int
protohandler(struct libalias * la,struct ip * pip,struct alias_data * ah)87be4f3cd0SPaolo Pisati protohandler(struct libalias *la, struct ip *pip, struct alias_data *ah)
88be4f3cd0SPaolo Pisati {
89be4f3cd0SPaolo Pisati AliasHandleDummy(la, pip, ah);
90be4f3cd0SPaolo Pisati return (0);
91be4f3cd0SPaolo Pisati }
92be4f3cd0SPaolo Pisati
93be4f3cd0SPaolo Pisati /*
94be4f3cd0SPaolo Pisati * NOTA BENE: the next variable MUST NOT be renamed in any case if you want
95be4f3cd0SPaolo Pisati * your module to work in userland, cause it's used to find and use all
96be4f3cd0SPaolo Pisati * the protocol handlers present in every module.
97be4f3cd0SPaolo Pisati * So WATCH OUT, your module needs this variables and it needs it with
98be4f3cd0SPaolo Pisati * ITS EXACT NAME: handlers.
99be4f3cd0SPaolo Pisati */
100be4f3cd0SPaolo Pisati
101be4f3cd0SPaolo Pisati struct proto_handler handlers [] = {
102be4f3cd0SPaolo Pisati {
103be4f3cd0SPaolo Pisati .pri = 666,
104be4f3cd0SPaolo Pisati .dir = IN|OUT,
105be4f3cd0SPaolo Pisati .proto = UDP|TCP,
106be4f3cd0SPaolo Pisati .fingerprint = &fingerprint,
107be4f3cd0SPaolo Pisati .protohandler = &protohandler
108be4f3cd0SPaolo Pisati },
109be4f3cd0SPaolo Pisati { EOH }
110be4f3cd0SPaolo Pisati };
111be4f3cd0SPaolo Pisati
112be4f3cd0SPaolo Pisati static int
mod_handler(module_t mod,int type,void * data)113be4f3cd0SPaolo Pisati mod_handler(module_t mod, int type, void *data)
114be4f3cd0SPaolo Pisati {
115be4f3cd0SPaolo Pisati int error;
116be4f3cd0SPaolo Pisati
117be4f3cd0SPaolo Pisati switch (type) {
118be4f3cd0SPaolo Pisati case MOD_LOAD:
119be4f3cd0SPaolo Pisati error = 0;
120be4f3cd0SPaolo Pisati LibAliasAttachHandlers(handlers);
121be4f3cd0SPaolo Pisati break;
122be4f3cd0SPaolo Pisati case MOD_UNLOAD:
123be4f3cd0SPaolo Pisati error = 0;
124be4f3cd0SPaolo Pisati LibAliasDetachHandlers(handlers);
125be4f3cd0SPaolo Pisati break;
126be4f3cd0SPaolo Pisati default:
127be4f3cd0SPaolo Pisati error = EINVAL;
128be4f3cd0SPaolo Pisati }
129be4f3cd0SPaolo Pisati return (error);
130be4f3cd0SPaolo Pisati }
131be4f3cd0SPaolo Pisati
132be4f3cd0SPaolo Pisati #ifdef _KERNEL
133be4f3cd0SPaolo Pisati static
134be4f3cd0SPaolo Pisati #endif
135be4f3cd0SPaolo Pisati moduledata_t alias_mod = {
136be4f3cd0SPaolo Pisati "alias_dummy", mod_handler, NULL
137be4f3cd0SPaolo Pisati };
138be4f3cd0SPaolo Pisati
139be4f3cd0SPaolo Pisati #ifdef _KERNEL
140be4f3cd0SPaolo Pisati DECLARE_MODULE(alias_dummy, alias_mod, SI_SUB_DRIVERS, SI_ORDER_SECOND);
141be4f3cd0SPaolo Pisati MODULE_VERSION(alias_dummy, 1);
142be4f3cd0SPaolo Pisati MODULE_DEPEND(alias_dummy, libalias, 1, 1, 1);
143be4f3cd0SPaolo Pisati #endif
144be4f3cd0SPaolo Pisati
145be4f3cd0SPaolo Pisati static void
AliasHandleDummy(struct libalias * la,struct ip * ip,struct alias_data * ah)146be4f3cd0SPaolo Pisati AliasHandleDummy(struct libalias *la, struct ip *ip, struct alias_data *ah)
147be4f3cd0SPaolo Pisati {
148be4f3cd0SPaolo Pisati ; /* Dummy. */
149be4f3cd0SPaolo Pisati }
150