/* * Author: Paul.Russell@rustcorp.com.au and mneuling@radlogic.com.au * * Based on the ipchains code by Paul Russell and Michael Neuling * * (C) 2000-2002 by the netfilter coreteam : * Paul 'Rusty' Russell * Marc Boucher * James Morris * Harald Welte * Jozsef Kadlecsik * * arptables -- IP firewall administration for kernels with * firewall table (aimed for the 2.3 kernels) * * See the accompanying manual page arptables(8) for information * about proper usage of this program. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ #include #include #include #include #include #include "nft.h" #include "xtables-multi.h" extern struct xtables_globals xtables_globals; extern const char *program_version, *program_name; static const struct xtables_afinfo afinfo_bridge = { .kmod = "eb_tables", .proc_exists = "/proc/net/eb_tables_names", .libprefix = "libeb_", .family = NFPROTO_BRIDGE, .ipproto = IPPROTO_IP, .so_rev_match = -1, .so_rev_target = -1, }; int xtables_eb_main(int argc, char *argv[]) { int ret; char *table = "filter"; struct nft_handle h = { .family = NFPROTO_BRIDGE, }; xtables_globals.program_name = "ebtables"; /* This code below could be replaced by xtables_init_all, which * doesn't support NFPROTO_BRIDGE yet. */ xtables_init(); afinfo = &afinfo_bridge; ret = xtables_set_params(&xtables_globals); if (ret < 0) { fprintf(stderr, "%s/%s Failed to initialize xtables\n", xtables_globals.program_name, xtables_globals.program_version); exit(1); } #if defined(ALL_INCLUSIVE) || defined(NO_SHARED_LIBS) init_extensions(); #endif ret = do_commandeb(&h, argc, argv, &table); if (ret) ret = nft_commit(&h); exit(!ret); }