Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
linux
Commits
012af0b9
Commit
012af0b9
authored
Jun 25, 2003
by
Bart De Schuymer
Committed by
David S. Miller
Jun 25, 2003
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[NETFILTER]: Add arptables mangle module.
parent
ca97b3b8
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
135 additions
and
0 deletions
+135
-0
include/linux/netfilter_arp/arpt_mangle.h
include/linux/netfilter_arp/arpt_mangle.h
+26
-0
net/ipv4/netfilter/Kconfig
net/ipv4/netfilter/Kconfig
+7
-0
net/ipv4/netfilter/Makefile
net/ipv4/netfilter/Makefile
+1
-0
net/ipv4/netfilter/arpt_mangle.c
net/ipv4/netfilter/arpt_mangle.c
+101
-0
No files found.
include/linux/netfilter_arp/arpt_mangle.h
0 → 100644
View file @
012af0b9
#ifndef _ARPT_MANGLE_H
#define _ARPT_MANGLE_H
#include <linux/netfilter_arp/arp_tables.h>
#define ARPT_MANGLE_ADDR_LEN_MAX sizeof(struct in_addr)
struct
arpt_mangle
{
char
src_devaddr
[
ARPT_DEV_ADDR_LEN_MAX
];
char
tgt_devaddr
[
ARPT_DEV_ADDR_LEN_MAX
];
union
{
struct
in_addr
src_ip
;
}
u_s
;
union
{
struct
in_addr
tgt_ip
;
}
u_t
;
u_int8_t
flags
;
int
target
;
};
#define ARPT_MANGLE_SDEV 0x01
#define ARPT_MANGLE_TDEV 0x02
#define ARPT_MANGLE_SIP 0x04
#define ARPT_MANGLE_TIP 0x08
#define ARPT_MANGLE_MASK 0x0f
#endif
/* _ARPT_MANGLE_H */
net/ipv4/netfilter/Kconfig
View file @
012af0b9
...
...
@@ -553,6 +553,13 @@ config IP_NF_ARPFILTER
tristate "ARP packet filtering"
depends on IP_NF_ARPTABLES
config IP_NF_ARP_MANGLE
tristate "ARP payload mangling"
depends on IP_NF_ARPTABLES
help
Allows altering the ARP packet payload: source and destination
hardware and network addresses.
# Backwards compatibility modules: only if you don't build in the others.
config IP_NF_COMPAT_IPCHAINS
tristate "ipchains (2.2-style) support"
...
...
net/ipv4/netfilter/Makefile
View file @
012af0b9
...
...
@@ -82,6 +82,7 @@ obj-$(CONFIG_IP_NF_TARGET_TCPMSS) += ipt_TCPMSS.o
# generic ARP tables
obj-$(CONFIG_IP_NF_ARPTABLES)
+=
arp_tables.o
obj-$(CONFIG_IP_NF_ARP_MANGLE)
+=
arpt_mangle.o
# just filtering instance of ARP tables for now
obj-$(CONFIG_IP_NF_ARPFILTER)
+=
arptable_filter.o
...
...
net/ipv4/netfilter/arpt_mangle.c
0 → 100644
View file @
012af0b9
/* module that allows mangling of the arp payload */
#include <linux/module.h>
#include <linux/netfilter_arp/arpt_mangle.h>
#include <net/sock.h>
static
unsigned
int
target
(
struct
sk_buff
**
pskb
,
unsigned
int
hooknum
,
const
struct
net_device
*
in
,
const
struct
net_device
*
out
,
const
void
*
targinfo
,
void
*
userinfo
)
{
const
struct
arpt_mangle
*
mangle
=
targinfo
;
struct
arphdr
*
arp
;
unsigned
char
*
arpptr
;
int
pln
,
hln
;
if
(
skb_shared
(
*
pskb
)
||
skb_cloned
(
*
pskb
))
{
struct
sk_buff
*
nskb
;
nskb
=
skb_copy
(
*
pskb
,
GFP_ATOMIC
);
if
(
!
nskb
)
return
NF_DROP
;
if
((
*
pskb
)
->
sk
)
skb_set_owner_w
(
nskb
,
(
*
pskb
)
->
sk
);
kfree_skb
(
*
pskb
);
*
pskb
=
nskb
;
}
arp
=
(
*
pskb
)
->
nh
.
arph
;
arpptr
=
(
*
pskb
)
->
nh
.
raw
+
sizeof
(
*
arp
);
pln
=
arp
->
ar_pln
;
hln
=
arp
->
ar_hln
;
/* We assume that pln and hln were checked in the match */
if
(
mangle
->
flags
&
ARPT_MANGLE_SDEV
)
{
if
(
ARPT_DEV_ADDR_LEN_MAX
<
hln
||
(
arpptr
+
hln
>
(
**
pskb
).
tail
))
return
NF_DROP
;
memcpy
(
arpptr
,
mangle
->
src_devaddr
,
hln
);
}
arpptr
+=
hln
;
if
(
mangle
->
flags
&
ARPT_MANGLE_SIP
)
{
if
(
ARPT_MANGLE_ADDR_LEN_MAX
<
pln
||
(
arpptr
+
pln
>
(
**
pskb
).
tail
))
return
NF_DROP
;
memcpy
(
arpptr
,
&
mangle
->
u_s
.
src_ip
,
pln
);
}
arpptr
+=
pln
;
if
(
mangle
->
flags
&
ARPT_MANGLE_TDEV
)
{
if
(
ARPT_DEV_ADDR_LEN_MAX
<
hln
||
(
arpptr
+
hln
>
(
**
pskb
).
tail
))
return
NF_DROP
;
memcpy
(
arpptr
,
mangle
->
tgt_devaddr
,
hln
);
}
arpptr
+=
hln
;
if
(
mangle
->
flags
&
ARPT_MANGLE_TIP
)
{
if
(
ARPT_MANGLE_ADDR_LEN_MAX
<
pln
||
(
arpptr
+
pln
>
(
**
pskb
).
tail
))
return
NF_DROP
;
memcpy
(
arpptr
,
&
mangle
->
u_t
.
tgt_ip
,
pln
);
}
return
mangle
->
target
;
}
static
int
checkentry
(
const
char
*
tablename
,
const
struct
arpt_entry
*
e
,
void
*
targinfo
,
unsigned
int
targinfosize
,
unsigned
int
hook_mask
)
{
const
struct
arpt_mangle
*
mangle
=
targinfo
;
if
(
mangle
->
flags
&
~
ARPT_MANGLE_MASK
||
!
(
mangle
->
flags
&
ARPT_MANGLE_MASK
))
return
0
;
if
(
mangle
->
target
!=
NF_DROP
&&
mangle
->
target
!=
NF_ACCEPT
&&
mangle
->
target
!=
ARPT_CONTINUE
)
return
0
;
return
1
;
}
static
struct
arpt_target
arpt_mangle_reg
=
{
.
name
=
"mangle"
,
.
target
=
target
,
.
checkentry
=
checkentry
,
.
me
=
THIS_MODULE
,
};
static
int
__init
init
(
void
)
{
if
(
arpt_register_target
(
&
arpt_mangle_reg
))
return
-
EINVAL
;
return
0
;
}
static
void
__exit
fini
(
void
)
{
arpt_unregister_target
(
&
arpt_mangle_reg
);
}
module_init
(
init
);
module_exit
(
fini
);
MODULE_LICENSE
(
"GPL"
);
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment