blob: 33fc71cd9703cc9790d5275cc41f2e64f4f2f9cb [file] [log] [blame]
Yasuyuki KOZAKAI45e4c692007-07-24 07:22:24 +00001/* Shared library add-on to iptables to add TCPMSS target support.
2 *
3 * Copyright (c) 2000 Marc Boucher
4*/
5#include <stdio.h>
6#include <string.h>
7#include <stdlib.h>
8#include <getopt.h>
9
10#include <xtables.h>
11#include <linux/netfilter/x_tables.h>
12#include <linux/netfilter/xt_TCPMSS.h>
13
14struct mssinfo {
15 struct xt_entry_target t;
16 struct xt_tcpmss_info mss;
17};
18
Jan Engelhardt932e6482007-10-04 16:27:30 +000019static void __TCPMSS_help(int hdrsize)
Yasuyuki KOZAKAI45e4c692007-07-24 07:22:24 +000020{
21 printf(
Jan Engelhardt8b7c64d2008-04-15 11:48:25 +020022"TCPMSS target mutually-exclusive options:\n"
Yasuyuki KOZAKAI45e4c692007-07-24 07:22:24 +000023" --set-mss value explicitly set MSS option to specified value\n"
24" --clamp-mss-to-pmtu automatically clamp MSS value to (path_MTU - %d)\n",
Jan Engelhardt8b7c64d2008-04-15 11:48:25 +020025hdrsize);
Yasuyuki KOZAKAI45e4c692007-07-24 07:22:24 +000026}
27
Jan Engelhardt932e6482007-10-04 16:27:30 +000028static void TCPMSS_help(void)
Yasuyuki KOZAKAI45e4c692007-07-24 07:22:24 +000029{
Jan Engelhardt932e6482007-10-04 16:27:30 +000030 __TCPMSS_help(40);
Yasuyuki KOZAKAI45e4c692007-07-24 07:22:24 +000031}
32
Jan Engelhardt932e6482007-10-04 16:27:30 +000033static void TCPMSS_help6(void)
Yasuyuki KOZAKAI45e4c692007-07-24 07:22:24 +000034{
Jan Engelhardt932e6482007-10-04 16:27:30 +000035 __TCPMSS_help(60);
Yasuyuki KOZAKAI45e4c692007-07-24 07:22:24 +000036}
37
Jan Engelhardt932e6482007-10-04 16:27:30 +000038static const struct option TCPMSS_opts[] = {
Patrick McHardy500f4832007-09-08 15:59:04 +000039 { "set-mss", 1, NULL, '1' },
40 { "clamp-mss-to-pmtu", 0, NULL, '2' },
Max Kellermann9ee386a2008-01-29 13:48:05 +000041 { .name = NULL }
Yasuyuki KOZAKAI45e4c692007-07-24 07:22:24 +000042};
43
Jan Engelhardt932e6482007-10-04 16:27:30 +000044static int __TCPMSS_parse(int c, char **argv, int invert, unsigned int *flags,
45 const void *entry, struct xt_entry_target **target,
46 int hdrsize)
Yasuyuki KOZAKAI45e4c692007-07-24 07:22:24 +000047{
48 struct xt_tcpmss_info *mssinfo
49 = (struct xt_tcpmss_info *)(*target)->data;
50
51 switch (c) {
52 unsigned int mssval;
53
54 case '1':
55 if (*flags)
56 exit_error(PARAMETER_PROBLEM,
57 "TCPMSS target: Only one option may be specified");
Jan Engelhardt5f2922c2009-01-27 18:43:01 +010058 if (!xtables_strtoui(optarg, NULL, &mssval,
59 0, UINT16_MAX - hdrsize))
Yasuyuki KOZAKAI45e4c692007-07-24 07:22:24 +000060 exit_error(PARAMETER_PROBLEM, "Bad TCPMSS value `%s'", optarg);
61
62 mssinfo->mss = mssval;
63 *flags = 1;
64 break;
65
66 case '2':
67 if (*flags)
68 exit_error(PARAMETER_PROBLEM,
69 "TCPMSS target: Only one option may be specified");
70 mssinfo->mss = XT_TCPMSS_CLAMP_PMTU;
71 *flags = 1;
72 break;
73
74 default:
75 return 0;
76 }
77
78 return 1;
79}
80
Jan Engelhardt932e6482007-10-04 16:27:30 +000081static int TCPMSS_parse(int c, char **argv, int invert, unsigned int *flags,
82 const void *entry, struct xt_entry_target **target)
Yasuyuki KOZAKAI45e4c692007-07-24 07:22:24 +000083{
Jan Engelhardt932e6482007-10-04 16:27:30 +000084 return __TCPMSS_parse(c, argv, invert, flags, entry, target, 40);
Yasuyuki KOZAKAI45e4c692007-07-24 07:22:24 +000085}
86
Jan Engelhardt932e6482007-10-04 16:27:30 +000087static int TCPMSS_parse6(int c, char **argv, int invert, unsigned int *flags,
88 const void *entry, struct xt_entry_target **target)
Yasuyuki KOZAKAI45e4c692007-07-24 07:22:24 +000089{
Jan Engelhardt932e6482007-10-04 16:27:30 +000090 return __TCPMSS_parse(c, argv, invert, flags, entry, target, 60);
Yasuyuki KOZAKAI45e4c692007-07-24 07:22:24 +000091}
92
Jan Engelhardt932e6482007-10-04 16:27:30 +000093static void TCPMSS_check(unsigned int flags)
Yasuyuki KOZAKAI45e4c692007-07-24 07:22:24 +000094{
95 if (!flags)
96 exit_error(PARAMETER_PROBLEM,
97 "TCPMSS target: At least one parameter is required");
98}
99
Jan Engelhardt932e6482007-10-04 16:27:30 +0000100static void TCPMSS_print(const void *ip, const struct xt_entry_target *target,
101 int numeric)
Yasuyuki KOZAKAI45e4c692007-07-24 07:22:24 +0000102{
103 const struct xt_tcpmss_info *mssinfo =
104 (const struct xt_tcpmss_info *)target->data;
105 if(mssinfo->mss == XT_TCPMSS_CLAMP_PMTU)
106 printf("TCPMSS clamp to PMTU ");
107 else
108 printf("TCPMSS set %u ", mssinfo->mss);
109}
110
Jan Engelhardt932e6482007-10-04 16:27:30 +0000111static void TCPMSS_save(const void *ip, const struct xt_entry_target *target)
Yasuyuki KOZAKAI45e4c692007-07-24 07:22:24 +0000112{
113 const struct xt_tcpmss_info *mssinfo =
114 (const struct xt_tcpmss_info *)target->data;
115
116 if(mssinfo->mss == XT_TCPMSS_CLAMP_PMTU)
117 printf("--clamp-mss-to-pmtu ");
118 else
119 printf("--set-mss %u ", mssinfo->mss);
120}
121
Jan Engelhardt932e6482007-10-04 16:27:30 +0000122static struct xtables_target tcpmss_target = {
Jan Engelhardt03d99482008-11-18 12:27:54 +0100123 .family = NFPROTO_IPV4,
Yasuyuki KOZAKAI45e4c692007-07-24 07:22:24 +0000124 .name = "TCPMSS",
Jan Engelhardt8b7c64d2008-04-15 11:48:25 +0200125 .version = XTABLES_VERSION,
Yasuyuki KOZAKAI45e4c692007-07-24 07:22:24 +0000126 .size = XT_ALIGN(sizeof(struct xt_tcpmss_info)),
127 .userspacesize = XT_ALIGN(sizeof(struct xt_tcpmss_info)),
Jan Engelhardt932e6482007-10-04 16:27:30 +0000128 .help = TCPMSS_help,
129 .parse = TCPMSS_parse,
130 .final_check = TCPMSS_check,
131 .print = TCPMSS_print,
132 .save = TCPMSS_save,
133 .extra_opts = TCPMSS_opts,
Yasuyuki KOZAKAI45e4c692007-07-24 07:22:24 +0000134};
135
Jan Engelhardt932e6482007-10-04 16:27:30 +0000136static struct xtables_target tcpmss_target6 = {
Jan Engelhardt03d99482008-11-18 12:27:54 +0100137 .family = NFPROTO_IPV6,
Yasuyuki KOZAKAI45e4c692007-07-24 07:22:24 +0000138 .name = "TCPMSS",
Jan Engelhardt8b7c64d2008-04-15 11:48:25 +0200139 .version = XTABLES_VERSION,
Yasuyuki KOZAKAI45e4c692007-07-24 07:22:24 +0000140 .size = XT_ALIGN(sizeof(struct xt_tcpmss_info)),
141 .userspacesize = XT_ALIGN(sizeof(struct xt_tcpmss_info)),
Jan Engelhardt932e6482007-10-04 16:27:30 +0000142 .help = TCPMSS_help6,
143 .parse = TCPMSS_parse6,
144 .final_check = TCPMSS_check,
145 .print = TCPMSS_print,
146 .save = TCPMSS_save,
147 .extra_opts = TCPMSS_opts,
Yasuyuki KOZAKAI45e4c692007-07-24 07:22:24 +0000148};
149
150void _init(void)
151{
Jan Engelhardt932e6482007-10-04 16:27:30 +0000152 xtables_register_target(&tcpmss_target);
153 xtables_register_target(&tcpmss_target6);
Yasuyuki KOZAKAI45e4c692007-07-24 07:22:24 +0000154}