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
5bf74c91
Commit
5bf74c91
authored
May 31, 2011
by
David S. Miller
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'batman-adv/next' of
git://git.open-mesh.org/ecsv/linux-merge
parents
e11ec900
bb899b89
Changes
31
Show whitespace changes
Inline
Side-by-side
Showing
31 changed files
with
284 additions
and
276 deletions
+284
-276
net/batman-adv/aggregation.c
net/batman-adv/aggregation.c
+12
-11
net/batman-adv/aggregation.h
net/batman-adv/aggregation.h
+3
-2
net/batman-adv/bat_debugfs.c
net/batman-adv/bat_debugfs.c
+6
-5
net/batman-adv/bat_sysfs.c
net/batman-adv/bat_sysfs.c
+7
-8
net/batman-adv/bitarray.c
net/batman-adv/bitarray.c
+3
-3
net/batman-adv/bitarray.h
net/batman-adv/bitarray.h
+3
-3
net/batman-adv/gateway_client.c
net/batman-adv/gateway_client.c
+9
-10
net/batman-adv/gateway_common.c
net/batman-adv/gateway_common.c
+10
-9
net/batman-adv/hard-interface.c
net/batman-adv/hard-interface.c
+13
-12
net/batman-adv/hard-interface.h
net/batman-adv/hard-interface.h
+4
-2
net/batman-adv/hash.c
net/batman-adv/hash.c
+4
-3
net/batman-adv/hash.h
net/batman-adv/hash.h
+3
-3
net/batman-adv/icmp_socket.c
net/batman-adv/icmp_socket.c
+2
-2
net/batman-adv/main.c
net/batman-adv/main.c
+2
-2
net/batman-adv/main.h
net/batman-adv/main.h
+26
-4
net/batman-adv/originator.c
net/batman-adv/originator.c
+6
-6
net/batman-adv/originator.h
net/batman-adv/originator.h
+7
-7
net/batman-adv/ring_buffer.c
net/batman-adv/ring_buffer.c
+2
-2
net/batman-adv/ring_buffer.h
net/batman-adv/ring_buffer.h
+1
-1
net/batman-adv/routing.c
net/batman-adv/routing.c
+27
-27
net/batman-adv/routing.h
net/batman-adv/routing.h
+6
-6
net/batman-adv/send.c
net/batman-adv/send.c
+22
-22
net/batman-adv/send.h
net/batman-adv/send.h
+6
-6
net/batman-adv/soft-interface.c
net/batman-adv/soft-interface.c
+10
-12
net/batman-adv/soft-interface.h
net/batman-adv/soft-interface.h
+2
-2
net/batman-adv/translation-table.c
net/batman-adv/translation-table.c
+23
-21
net/batman-adv/translation-table.h
net/batman-adv/translation-table.h
+7
-6
net/batman-adv/types.h
net/batman-adv/types.h
+4
-4
net/batman-adv/unicast.c
net/batman-adv/unicast.c
+13
-17
net/batman-adv/unicast.h
net/batman-adv/unicast.h
+4
-4
net/batman-adv/vis.c
net/batman-adv/vis.c
+37
-54
No files found.
net/batman-adv/aggregation.c
View file @
5bf74c91
...
...
@@ -26,18 +26,18 @@
#include "hard-interface.h"
/* calculate the size of the tt information for a given packet */
static
int
tt_len
(
struct
batman_packet
*
batman_packet
)
static
int
tt_len
(
const
struct
batman_packet
*
batman_packet
)
{
return
batman_packet
->
num_tt
*
ETH_ALEN
;
}
/* return true if new_packet can be aggregated with forw_packet */
static
bool
can_aggregate_with
(
struct
batman_packet
*
new_batman_packet
,
static
bool
can_aggregate_with
(
const
struct
batman_packet
*
new_batman_packet
,
int
packet_len
,
unsigned
long
send_time
,
bool
directlink
,
struct
hard_iface
*
if_incoming
,
struct
forw_packet
*
forw_packet
)
const
struct
hard_iface
*
if_incoming
,
const
struct
forw_packet
*
forw_packet
)
{
struct
batman_packet
*
batman_packet
=
(
struct
batman_packet
*
)
forw_packet
->
skb
->
data
;
...
...
@@ -97,8 +97,9 @@ static bool can_aggregate_with(struct batman_packet *new_batman_packet,
}
/* create a new aggregated packet and add this packet to it */
static
void
new_aggregated_packet
(
unsigned
char
*
packet_buff
,
int
packet_len
,
unsigned
long
send_time
,
bool
direct_link
,
static
void
new_aggregated_packet
(
const
unsigned
char
*
packet_buff
,
int
packet_len
,
unsigned
long
send_time
,
bool
direct_link
,
struct
hard_iface
*
if_incoming
,
int
own_packet
)
{
...
...
@@ -118,7 +119,7 @@ static void new_aggregated_packet(unsigned char *packet_buff, int packet_len,
}
}
forw_packet_aggr
=
kmalloc
(
sizeof
(
struct
forw_packet
),
GFP_ATOMIC
);
forw_packet_aggr
=
kmalloc
(
sizeof
(
*
forw_packet_aggr
),
GFP_ATOMIC
);
if
(
!
forw_packet_aggr
)
{
if
(
!
own_packet
)
atomic_inc
(
&
bat_priv
->
batman_queue_left
);
...
...
@@ -176,8 +177,7 @@ static void new_aggregated_packet(unsigned char *packet_buff, int packet_len,
/* aggregate a new packet into the existing aggregation */
static
void
aggregate
(
struct
forw_packet
*
forw_packet_aggr
,
unsigned
char
*
packet_buff
,
int
packet_len
,
const
unsigned
char
*
packet_buff
,
int
packet_len
,
bool
direct_link
)
{
unsigned
char
*
skb_buff
;
...
...
@@ -253,8 +253,9 @@ void add_bat_packet_to_list(struct bat_priv *bat_priv,
}
/* unpack the aggregated packets and process them one by one */
void
receive_aggr_bat_packet
(
struct
ethhdr
*
ethhdr
,
unsigned
char
*
packet_buff
,
int
packet_len
,
struct
hard_iface
*
if_incoming
)
void
receive_aggr_bat_packet
(
const
struct
ethhdr
*
ethhdr
,
unsigned
char
*
packet_buff
,
int
packet_len
,
struct
hard_iface
*
if_incoming
)
{
struct
batman_packet
*
batman_packet
;
int
buff_pos
=
0
;
...
...
net/batman-adv/aggregation.h
View file @
5bf74c91
...
...
@@ -37,7 +37,8 @@ void add_bat_packet_to_list(struct bat_priv *bat_priv,
unsigned
char
*
packet_buff
,
int
packet_len
,
struct
hard_iface
*
if_incoming
,
char
own_packet
,
unsigned
long
send_time
);
void
receive_aggr_bat_packet
(
struct
ethhdr
*
ethhdr
,
unsigned
char
*
packet_buff
,
int
packet_len
,
struct
hard_iface
*
if_incoming
);
void
receive_aggr_bat_packet
(
const
struct
ethhdr
*
ethhdr
,
unsigned
char
*
packet_buff
,
int
packet_len
,
struct
hard_iface
*
if_incoming
);
#endif
/* _NET_BATMAN_ADV_AGGREGATION_H_ */
net/batman-adv/bat_debugfs.c
View file @
5bf74c91
...
...
@@ -50,7 +50,8 @@ static void emit_log_char(struct debug_log *debug_log, char c)
debug_log
->
log_start
=
debug_log
->
log_end
-
log_buff_len
;
}
static
int
fdebug_log
(
struct
debug_log
*
debug_log
,
char
*
fmt
,
...)
__printf
(
2
,
3
)
static
int
fdebug_log
(
struct
debug_log
*
debug_log
,
const
char
*
fmt
,
...)
{
va_list
args
;
static
char
debug_log_buf
[
256
];
...
...
@@ -74,14 +75,14 @@ static int fdebug_log(struct debug_log *debug_log, char *fmt, ...)
return
0
;
}
int
debug_log
(
struct
bat_priv
*
bat_priv
,
char
*
fmt
,
...)
int
debug_log
(
struct
bat_priv
*
bat_priv
,
c
onst
c
har
*
fmt
,
...)
{
va_list
args
;
char
tmp_log_buf
[
256
];
va_start
(
args
,
fmt
);
vscnprintf
(
tmp_log_buf
,
sizeof
(
tmp_log_buf
),
fmt
,
args
);
fdebug_log
(
bat_priv
->
debug_log
,
"[%10u] %s"
,
fdebug_log
(
bat_priv
->
debug_log
,
"[%10
l
u] %s"
,
(
jiffies
/
HZ
),
tmp_log_buf
);
va_end
(
args
);
...
...
@@ -114,7 +115,7 @@ static ssize_t log_read(struct file *file, char __user *buf,
!
(
debug_log
->
log_end
-
debug_log
->
log_start
))
return
-
EAGAIN
;
if
(
(
!
buf
)
||
(
count
<
0
)
)
if
(
!
buf
)
return
-
EINVAL
;
if
(
count
==
0
)
...
...
@@ -184,7 +185,7 @@ static int debug_log_setup(struct bat_priv *bat_priv)
if
(
!
bat_priv
->
debug_dir
)
goto
err
;
bat_priv
->
debug_log
=
kzalloc
(
sizeof
(
struct
debug_log
),
GFP_ATOMIC
);
bat_priv
->
debug_log
=
kzalloc
(
sizeof
(
*
bat_priv
->
debug_log
),
GFP_ATOMIC
);
if
(
!
bat_priv
->
debug_log
)
goto
err
;
...
...
net/batman-adv/bat_sysfs.c
View file @
5bf74c91
...
...
@@ -96,7 +96,7 @@ ssize_t show_##_name(struct kobject *kobj, struct attribute *attr, \
static
int
store_bool_attr
(
char
*
buff
,
size_t
count
,
struct
net_device
*
net_dev
,
char
*
attr_name
,
atomic_t
*
attr
)
c
onst
c
har
*
attr_name
,
atomic_t
*
attr
)
{
int
enabled
=
-
1
;
...
...
@@ -138,16 +138,15 @@ static inline ssize_t __store_bool_attr(char *buff, size_t count,
{
int
ret
;
ret
=
store_bool_attr
(
buff
,
count
,
net_dev
,
(
char
*
)
attr
->
name
,
attr_store
);
ret
=
store_bool_attr
(
buff
,
count
,
net_dev
,
attr
->
name
,
attr_store
);
if
(
post_func
&&
ret
)
post_func
(
net_dev
);
return
ret
;
}
static
int
store_uint_attr
(
char
*
buff
,
size_t
count
,
struct
net_device
*
net_dev
,
char
*
attr_name
,
static
int
store_uint_attr
(
c
onst
c
har
*
buff
,
size_t
count
,
struct
net_device
*
net_dev
,
c
onst
c
har
*
attr_name
,
unsigned
int
min
,
unsigned
int
max
,
atomic_t
*
attr
)
{
unsigned
long
uint_val
;
...
...
@@ -183,15 +182,15 @@ static int store_uint_attr(char *buff, size_t count,
return
count
;
}
static
inline
ssize_t
__store_uint_attr
(
char
*
buff
,
size_t
count
,
static
inline
ssize_t
__store_uint_attr
(
c
onst
c
har
*
buff
,
size_t
count
,
int
min
,
int
max
,
void
(
*
post_func
)(
struct
net_device
*
),
struct
attribute
*
attr
,
const
struct
attribute
*
attr
,
atomic_t
*
attr_store
,
struct
net_device
*
net_dev
)
{
int
ret
;
ret
=
store_uint_attr
(
buff
,
count
,
net_dev
,
(
char
*
)
attr
->
name
,
ret
=
store_uint_attr
(
buff
,
count
,
net_dev
,
attr
->
name
,
min
,
max
,
attr_store
);
if
(
post_func
&&
ret
)
post_func
(
net_dev
);
...
...
net/batman-adv/bitarray.c
View file @
5bf74c91
...
...
@@ -26,7 +26,7 @@
/* returns true if the corresponding bit in the given seq_bits indicates true
* and curr_seqno is within range of last_seqno */
uint8_t
get_bit_status
(
unsigned
long
*
seq_bits
,
uint32_t
last_seqno
,
uint8_t
get_bit_status
(
const
unsigned
long
*
seq_bits
,
uint32_t
last_seqno
,
uint32_t
curr_seqno
)
{
int32_t
diff
,
word_offset
,
word_num
;
...
...
@@ -130,7 +130,7 @@ static void bit_reset_window(unsigned long *seq_bits)
char
bit_get_packet
(
void
*
priv
,
unsigned
long
*
seq_bits
,
int32_t
seq_num_diff
,
int8_t
set_mark
)
{
struct
bat_priv
*
bat_priv
=
(
struct
bat_priv
*
)
priv
;
struct
bat_priv
*
bat_priv
=
priv
;
/* sequence number is slightly older. We already got a sequence number
* higher than this one, so we just mark it. */
...
...
@@ -190,7 +190,7 @@ char bit_get_packet(void *priv, unsigned long *seq_bits,
/* count the hamming weight, how many good packets did we receive? just count
* the 1's.
*/
int
bit_packet_count
(
unsigned
long
*
seq_bits
)
int
bit_packet_count
(
const
unsigned
long
*
seq_bits
)
{
int
i
,
hamming
=
0
;
...
...
net/batman-adv/bitarray.h
View file @
5bf74c91
...
...
@@ -26,7 +26,7 @@
/* returns true if the corresponding bit in the given seq_bits indicates true
* and curr_seqno is within range of last_seqno */
uint8_t
get_bit_status
(
unsigned
long
*
seq_bits
,
uint32_t
last_seqno
,
uint8_t
get_bit_status
(
const
unsigned
long
*
seq_bits
,
uint32_t
last_seqno
,
uint32_t
curr_seqno
);
/* turn corresponding bit on, so we can remember that we got the packet */
...
...
@@ -39,6 +39,6 @@ char bit_get_packet(void *priv, unsigned long *seq_bits,
int32_t
seq_num_diff
,
int8_t
set_mark
);
/* count the hamming weight, how many good packets did we receive? */
int
bit_packet_count
(
unsigned
long
*
seq_bits
);
int
bit_packet_count
(
const
unsigned
long
*
seq_bits
);
#endif
/* _NET_BATMAN_ADV_BITARRAY_H_ */
net/batman-adv/gateway_client.c
View file @
5bf74c91
...
...
@@ -86,7 +86,7 @@ static void gw_select(struct bat_priv *bat_priv, struct gw_node *new_gw_node)
if
(
new_gw_node
&&
!
atomic_inc_not_zero
(
&
new_gw_node
->
refcount
))
new_gw_node
=
NULL
;
curr_gw_node
=
bat_priv
->
curr_gw
;
curr_gw_node
=
rcu_dereference_protected
(
bat_priv
->
curr_gw
,
1
)
;
rcu_assign_pointer
(
bat_priv
->
curr_gw
,
new_gw_node
);
if
(
curr_gw_node
)
...
...
@@ -273,11 +273,10 @@ static void gw_node_add(struct bat_priv *bat_priv,
struct
gw_node
*
gw_node
;
int
down
,
up
;
gw_node
=
k
malloc
(
sizeof
(
struct
gw_node
),
GFP_ATOMIC
);
gw_node
=
k
zalloc
(
sizeof
(
*
gw_node
),
GFP_ATOMIC
);
if
(
!
gw_node
)
return
;
memset
(
gw_node
,
0
,
sizeof
(
struct
gw_node
));
INIT_HLIST_NODE
(
&
gw_node
->
list
);
gw_node
->
orig_node
=
orig_node
;
atomic_set
(
&
gw_node
->
refcount
,
1
);
...
...
@@ -394,8 +393,8 @@ void gw_node_purge(struct bat_priv *bat_priv)
/**
* fails if orig_node has no router
*/
static
int
_write_buffer_text
(
struct
bat_priv
*
bat_priv
,
struct
seq_file
*
seq
,
struct
gw_node
*
gw_node
)
static
int
_write_buffer_text
(
struct
bat_priv
*
bat_priv
,
struct
seq_file
*
seq
,
const
struct
gw_node
*
gw_node
)
{
struct
gw_node
*
curr_gw
;
struct
neigh_node
*
router
;
...
...
@@ -509,7 +508,7 @@ int gw_is_target(struct bat_priv *bat_priv, struct sk_buff *skb)
/* check for ip header */
switch
(
ntohs
(
ethhdr
->
h_proto
))
{
case
ETH_P_IP
:
if
(
!
pskb_may_pull
(
skb
,
header_len
+
sizeof
(
struct
iphdr
)))
if
(
!
pskb_may_pull
(
skb
,
header_len
+
sizeof
(
*
iphdr
)))
return
0
;
iphdr
=
(
struct
iphdr
*
)(
skb
->
data
+
header_len
);
header_len
+=
iphdr
->
ihl
*
4
;
...
...
@@ -520,10 +519,10 @@ int gw_is_target(struct bat_priv *bat_priv, struct sk_buff *skb)
break
;
case
ETH_P_IPV6
:
if
(
!
pskb_may_pull
(
skb
,
header_len
+
sizeof
(
struct
ipv6hdr
)))
if
(
!
pskb_may_pull
(
skb
,
header_len
+
sizeof
(
*
ipv6hdr
)))
return
0
;
ipv6hdr
=
(
struct
ipv6hdr
*
)(
skb
->
data
+
header_len
);
header_len
+=
sizeof
(
struct
ipv6hdr
);
header_len
+=
sizeof
(
*
ipv6hdr
);
/* check for udp header */
if
(
ipv6hdr
->
nexthdr
!=
IPPROTO_UDP
)
...
...
@@ -534,10 +533,10 @@ int gw_is_target(struct bat_priv *bat_priv, struct sk_buff *skb)
return
0
;
}
if
(
!
pskb_may_pull
(
skb
,
header_len
+
sizeof
(
struct
udphdr
)))
if
(
!
pskb_may_pull
(
skb
,
header_len
+
sizeof
(
*
udphdr
)))
return
0
;
udphdr
=
(
struct
udphdr
*
)(
skb
->
data
+
header_len
);
header_len
+=
sizeof
(
struct
udphdr
);
header_len
+=
sizeof
(
*
udphdr
);
/* check for bootp port */
if
((
ntohs
(
ethhdr
->
h_proto
)
==
ETH_P_IP
)
&&
...
...
net/batman-adv/gateway_common.c
View file @
5bf74c91
...
...
@@ -76,10 +76,11 @@ void gw_bandwidth_to_kbit(uint8_t gw_srv_class, int *down, int *up)
}
static
bool
parse_gw_bandwidth
(
struct
net_device
*
net_dev
,
char
*
buff
,
long
*
up
,
long
*
down
)
int
*
up
,
int
*
down
)
{
int
ret
,
multi
=
1
;
char
*
slash_ptr
,
*
tmp_ptr
;
long
ldown
,
lup
;
slash_ptr
=
strchr
(
buff
,
'/'
);
if
(
slash_ptr
)
...
...
@@ -96,7 +97,7 @@ static bool parse_gw_bandwidth(struct net_device *net_dev, char *buff,
*
tmp_ptr
=
'\0'
;
}
ret
=
strict_strtoul
(
buff
,
10
,
down
);
ret
=
strict_strtoul
(
buff
,
10
,
&
l
down
);
if
(
ret
)
{
bat_err
(
net_dev
,
"Download speed of gateway mode invalid: %s
\n
"
,
...
...
@@ -104,7 +105,7 @@ static bool parse_gw_bandwidth(struct net_device *net_dev, char *buff,
return
false
;
}
*
down
*=
multi
;
*
down
=
ldown
*
multi
;
/* we also got some upload info */
if
(
slash_ptr
)
{
...
...
@@ -121,7 +122,7 @@ static bool parse_gw_bandwidth(struct net_device *net_dev, char *buff,
*
tmp_ptr
=
'\0'
;
}
ret
=
strict_strtoul
(
slash_ptr
+
1
,
10
,
up
);
ret
=
strict_strtoul
(
slash_ptr
+
1
,
10
,
&
l
up
);
if
(
ret
)
{
bat_err
(
net_dev
,
"Upload speed of gateway mode invalid: "
...
...
@@ -129,7 +130,7 @@ static bool parse_gw_bandwidth(struct net_device *net_dev, char *buff,
return
false
;
}
*
up
*=
multi
;
*
up
=
lup
*
multi
;
}
return
true
;
...
...
@@ -138,7 +139,8 @@ static bool parse_gw_bandwidth(struct net_device *net_dev, char *buff,
ssize_t
gw_bandwidth_set
(
struct
net_device
*
net_dev
,
char
*
buff
,
size_t
count
)
{
struct
bat_priv
*
bat_priv
=
netdev_priv
(
net_dev
);
long
gw_bandwidth_tmp
=
0
,
up
=
0
,
down
=
0
;
long
gw_bandwidth_tmp
=
0
;
int
up
=
0
,
down
=
0
;
bool
ret
;
ret
=
parse_gw_bandwidth
(
net_dev
,
buff
,
&
up
,
&
down
);
...
...
@@ -158,12 +160,11 @@ ssize_t gw_bandwidth_set(struct net_device *net_dev, char *buff, size_t count)
* speeds, hence we need to calculate it back to show the number
* that is going to be propagated
**/
gw_bandwidth_to_kbit
((
uint8_t
)
gw_bandwidth_tmp
,
(
int
*
)
&
down
,
(
int
*
)
&
up
);
gw_bandwidth_to_kbit
((
uint8_t
)
gw_bandwidth_tmp
,
&
down
,
&
up
);
gw_deselect
(
bat_priv
);
bat_info
(
net_dev
,
"Changing gateway bandwidth from: '%i' to: '%ld' "
"(propagating: %
ld%s/%l
d%s)
\n
"
,
"(propagating: %
d%s/%
d%s)
\n
"
,
atomic_read
(
&
bat_priv
->
gw_bandwidth
),
gw_bandwidth_tmp
,
(
down
>
2048
?
down
/
1024
:
down
),
(
down
>
2048
?
"MBit"
:
"KBit"
),
...
...
net/batman-adv/hard-interface.c
View file @
5bf74c91
...
...
@@ -46,7 +46,7 @@ void hardif_free_rcu(struct rcu_head *rcu)
kfree
(
hard_iface
);
}
struct
hard_iface
*
hardif_get_by_netdev
(
struct
net_device
*
net_dev
)
struct
hard_iface
*
hardif_get_by_netdev
(
const
struct
net_device
*
net_dev
)
{
struct
hard_iface
*
hard_iface
;
...
...
@@ -64,7 +64,7 @@ struct hard_iface *hardif_get_by_netdev(struct net_device *net_dev)
return
hard_iface
;
}
static
int
is_valid_iface
(
struct
net_device
*
net_dev
)
static
int
is_valid_iface
(
const
struct
net_device
*
net_dev
)
{
if
(
net_dev
->
flags
&
IFF_LOOPBACK
)
return
0
;
...
...
@@ -86,7 +86,7 @@ static int is_valid_iface(struct net_device *net_dev)
return
1
;
}
static
struct
hard_iface
*
hardif_get_active
(
struct
net_device
*
soft_iface
)
static
struct
hard_iface
*
hardif_get_active
(
const
struct
net_device
*
soft_iface
)
{
struct
hard_iface
*
hard_iface
;
...
...
@@ -138,7 +138,7 @@ static void primary_if_select(struct bat_priv *bat_priv,
if
(
new_hard_iface
&&
!
atomic_inc_not_zero
(
&
new_hard_iface
->
refcount
))
new_hard_iface
=
NULL
;
curr_hard_iface
=
bat_priv
->
primary_if
;
curr_hard_iface
=
rcu_dereference_protected
(
bat_priv
->
primary_if
,
1
)
;
rcu_assign_pointer
(
bat_priv
->
primary_if
,
new_hard_iface
);
if
(
curr_hard_iface
)
...
...
@@ -160,7 +160,7 @@ static void primary_if_select(struct bat_priv *bat_priv,
atomic_set
(
&
bat_priv
->
tt_local_changed
,
1
);
}
static
bool
hardif_is_iface_up
(
struct
hard_iface
*
hard_iface
)
static
bool
hardif_is_iface_up
(
const
struct
hard_iface
*
hard_iface
)
{
if
(
hard_iface
->
net_dev
->
flags
&
IFF_UP
)
return
true
;
...
...
@@ -176,9 +176,9 @@ static void update_mac_addresses(struct hard_iface *hard_iface)
hard_iface
->
net_dev
->
dev_addr
,
ETH_ALEN
);
}
static
void
check_known_mac_addr
(
struct
net_device
*
net_dev
)
static
void
check_known_mac_addr
(
const
struct
net_device
*
net_dev
)
{
struct
hard_iface
*
hard_iface
;
const
struct
hard_iface
*
hard_iface
;
rcu_read_lock
();
list_for_each_entry_rcu
(
hard_iface
,
&
hardif_list
,
list
)
{
...
...
@@ -204,8 +204,8 @@ static void check_known_mac_addr(struct net_device *net_dev)
int
hardif_min_mtu
(
struct
net_device
*
soft_iface
)
{
struct
bat_priv
*
bat_priv
=
netdev_priv
(
soft_iface
);
struct
hard_iface
*
hard_iface
;
const
struct
bat_priv
*
bat_priv
=
netdev_priv
(
soft_iface
);
const
struct
hard_iface
*
hard_iface
;
/* allow big frames if all devices are capable to do so
* (have MTU > 1500 + BAT_HEADER_LEN) */
int
min_mtu
=
ETH_DATA_LEN
;
...
...
@@ -285,7 +285,8 @@ static void hardif_deactivate_interface(struct hard_iface *hard_iface)
update_min_mtu
(
hard_iface
->
soft_iface
);
}
int
hardif_enable_interface
(
struct
hard_iface
*
hard_iface
,
char
*
iface_name
)
int
hardif_enable_interface
(
struct
hard_iface
*
hard_iface
,
const
char
*
iface_name
)
{
struct
bat_priv
*
bat_priv
;
struct
batman_packet
*
batman_packet
;
...
...
@@ -458,7 +459,7 @@ static struct hard_iface *hardif_add_interface(struct net_device *net_dev)
dev_hold
(
net_dev
);
hard_iface
=
kmalloc
(
sizeof
(
struct
hard_iface
),
GFP_ATOMIC
);
hard_iface
=
kmalloc
(
sizeof
(
*
hard_iface
),
GFP_ATOMIC
);
if
(
!
hard_iface
)
{
pr_err
(
"Can't add interface (%s): out of memory
\n
"
,
net_dev
->
name
);
...
...
@@ -522,7 +523,7 @@ void hardif_remove_interfaces(void)
static
int
hard_if_event
(
struct
notifier_block
*
this
,
unsigned
long
event
,
void
*
ptr
)
{
struct
net_device
*
net_dev
=
(
struct
net_device
*
)
ptr
;
struct
net_device
*
net_dev
=
ptr
;
struct
hard_iface
*
hard_iface
=
hardif_get_by_netdev
(
net_dev
);
struct
hard_iface
*
primary_if
=
NULL
;
struct
bat_priv
*
bat_priv
;
...
...
net/batman-adv/hard-interface.h
View file @
5bf74c91
...
...
@@ -31,8 +31,10 @@
extern
struct
notifier_block
hard_if_notifier
;
struct
hard_iface
*
hardif_get_by_netdev
(
struct
net_device
*
net_dev
);
int
hardif_enable_interface
(
struct
hard_iface
*
hard_iface
,
char
*
iface_name
);
struct
hard_iface
*
hardif_get_by_netdev
(
const
struct
net_device
*
net_dev
);
int
hardif_enable_interface
(
struct
hard_iface
*
hard_iface
,
const
char
*
iface_name
);
void
hardif_disable_interface
(
struct
hard_iface
*
hard_iface
);
void
hardif_remove_interfaces
(
void
);
int
hardif_min_mtu
(
struct
net_device
*
soft_iface
);
...
...
net/batman-adv/hash.c
View file @
5bf74c91
...
...
@@ -46,15 +46,16 @@ struct hashtable_t *hash_new(int size)
{
struct
hashtable_t
*
hash
;
hash
=
kmalloc
(
sizeof
(
struct
hashtable_t
),
GFP_ATOMIC
);
hash
=
kmalloc
(
sizeof
(
*
hash
),
GFP_ATOMIC
);
if
(
!
hash
)
return
NULL
;
hash
->
table
=
kmalloc
(
sizeof
(
struct
element_t
*
)
*
size
,
GFP_ATOMIC
);
hash
->
table
=
kmalloc
(
sizeof
(
*
hash
->
table
)
*
size
,
GFP_ATOMIC
);
if
(
!
hash
->
table
)
goto
free_hash
;
hash
->
list_locks
=
kmalloc
(
sizeof
(
spinlock_t
)
*
size
,
GFP_ATOMIC
);
hash
->
list_locks
=
kmalloc
(
sizeof
(
*
hash
->
list_locks
)
*
size
,
GFP_ATOMIC
);
if
(
!
hash
->
list_locks
)
goto
free_table
;
...
...
net/batman-adv/hash.h
View file @
5bf74c91
...
...
@@ -28,12 +28,12 @@
* compare 2 element datas for their keys,
* return 0 if same and not 0 if not
* same */
typedef
int
(
*
hashdata_compare_cb
)(
struct
hlist_node
*
,
void
*
);
typedef
int
(
*
hashdata_compare_cb
)(
const
struct
hlist_node
*
,
const
void
*
);
/* the hashfunction, should return an index
* based on the key in the data of the first
* argument and the size the second */
typedef
int
(
*
hashdata_choose_cb
)(
void
*
,
int
);
typedef
int
(
*
hashdata_choose_cb
)(
const
void
*
,
int
);
typedef
void
(
*
hashdata_free_cb
)(
struct
hlist_node
*
,
void
*
);
struct
hashtable_t
{
...
...
@@ -80,7 +80,7 @@ static inline void hash_delete(struct hashtable_t *hash,
static
inline
int
hash_add
(
struct
hashtable_t
*
hash
,
hashdata_compare_cb
compare
,
hashdata_choose_cb
choose
,
void
*
data
,
struct
hlist_node
*
data_node
)
const
void
*
data
,
struct
hlist_node
*
data_node
)
{
int
index
;
struct
hlist_head
*
head
;
...
...
net/batman-adv/icmp_socket.c
View file @
5bf74c91
...
...
@@ -46,7 +46,7 @@ static int bat_socket_open(struct inode *inode, struct file *file)
nonseekable_open
(
inode
,
file
);
socket_client
=
kmalloc
(
sizeof
(
struct
socket_client
),
GFP_KERNEL
);
socket_client
=
kmalloc
(
sizeof
(
*
socket_client
),
GFP_KERNEL
);
if
(
!
socket_client
)
return
-
ENOMEM
;
...
...
@@ -310,7 +310,7 @@ static void bat_socket_add_packet(struct socket_client *socket_client,
{
struct
socket_packet
*
socket_packet
;
socket_packet
=
kmalloc
(
sizeof
(
struct
socket_packet
),
GFP_ATOMIC
);
socket_packet
=
kmalloc
(
sizeof
(
*
socket_packet
),
GFP_ATOMIC
);
if
(
!
socket_packet
)
return
;
...
...
net/batman-adv/main.c
View file @
5bf74c91
...
...
@@ -155,9 +155,9 @@ void dec_module_count(void)
module_put
(
THIS_MODULE
);
}
int
is_my_mac
(
uint8_t
*
addr
)
int
is_my_mac
(
const
uint8_t
*
addr
)
{
struct
hard_iface
*
hard_iface
;
const
struct
hard_iface
*
hard_iface
;
rcu_read_lock
();
list_for_each_entry_rcu
(
hard_iface
,
&
hardif_list
,
list
)
{
...
...
net/batman-adv/main.h
View file @
5bf74c91
...
...
@@ -133,10 +133,10 @@ int mesh_init(struct net_device *soft_iface);
void
mesh_free
(
struct
net_device
*
soft_iface
);
void
inc_module_count
(
void
);
void
dec_module_count
(
void
);
int
is_my_mac
(
uint8_t
*
addr
);
int
is_my_mac
(
const
uint8_t
*
addr
);
#ifdef CONFIG_BATMAN_ADV_DEBUG
int
debug_log
(
struct
bat_priv
*
bat_priv
,
c
har
*
fmt
,
...
);
int
debug_log
(
struct
bat_priv
*
bat_priv
,
c
onst
char
*
fmt
,
...)
__printf
(
2
,
3
);
#define bat_dbg(type, bat_priv, fmt, arg...) \
do { \
...
...
@@ -145,9 +145,10 @@ int debug_log(struct bat_priv *bat_priv, char *fmt, ...);
} \
while (0)
#else
/* !CONFIG_BATMAN_ADV_DEBUG */
__printf
(
3
,
4
)
static
inline
void
bat_dbg
(
char
type
__always_unused
,
struct
bat_priv
*
bat_priv
__always_unused
,
char
*
fmt
__always_unused
,
...)
c
onst
c
har
*
fmt
__always_unused
,
...)
{
}
#endif
...
...
@@ -172,11 +173,32 @@ static inline void bat_dbg(char type __always_unused,
*
* note: can't use compare_ether_addr() as it requires aligned memory
*/
static
inline
int
compare_eth
(
void
*
data1
,
void
*
data2
)
static
inline
int
compare_eth
(
const
void
*
data1
,
const
void
*
data2
)
{
return
(
memcmp
(
data1
,
data2
,
ETH_ALEN
)
==
0
?
1
:
0
);
}
#define atomic_dec_not_zero(v) atomic_add_unless((v), -1, 0)
/* Returns the smallest signed integer in two's complement with the sizeof x */
#define smallest_signed_int(x) (1u << (7u + 8u * (sizeof(x) - 1u)))
/* Checks if a sequence number x is a predecessor/successor of y.
* they handle overflows/underflows and can correctly check for a
* predecessor/successor unless the variable sequence number has grown by
* more then 2**(bitwidth(x)-1)-1.
* This means that for a uint8_t with the maximum value 255, it would think:
* - when adding nothing - it is neither a predecessor nor a successor
* - before adding more than 127 to the starting value - it is a predecessor,
* - when adding 128 - it is neither a predecessor nor a successor,
* - after adding more than 127 to the starting value - it is a successor */
#define seq_before(x, y) ({typeof(x) _d1 = (x); \
typeof(y) _d2 = (y); \
typeof(x) _dummy = (_d1 - _d2); \
(void) (&_d1 == &_d2); \
_dummy > smallest_signed_int(_dummy); })
#define seq_after(x, y) seq_before(y, x)
#endif
/* _NET_BATMAN_ADV_MAIN_H_ */
net/batman-adv/originator.c
View file @
5bf74c91
...
...
@@ -77,7 +77,7 @@ struct neigh_node *orig_node_get_router(struct orig_node *orig_node)
struct
neigh_node
*
create_neighbor
(
struct
orig_node
*
orig_node
,
struct
orig_node
*
orig_neigh_node
,
uint8_t
*
neigh
,
const
uint8_t
*
neigh
,
struct
hard_iface
*
if_incoming
)
{
struct
bat_priv
*
bat_priv
=
netdev_priv
(
if_incoming
->
soft_iface
);
...
...
@@ -86,7 +86,7 @@ struct neigh_node *create_neighbor(struct orig_node *orig_node,
bat_dbg
(
DBG_BATMAN
,
bat_priv
,
"Creating new last-hop neighbor of originator
\n
"
);
neigh_node
=
kzalloc
(
sizeof
(
struct
neigh_node
),
GFP_ATOMIC
);
neigh_node
=
kzalloc
(
sizeof
(
*
neigh_node
),
GFP_ATOMIC
);
if
(
!
neigh_node
)
return
NULL
;
...
...
@@ -183,7 +183,7 @@ void originator_free(struct bat_priv *bat_priv)
/* this function finds or creates an originator entry for the given
* address if it does not exits */
struct
orig_node
*
get_orig_node
(
struct
bat_priv
*
bat_priv
,
uint8_t
*
addr
)
struct
orig_node
*
get_orig_node
(
struct
bat_priv
*
bat_priv
,
const
uint8_t
*
addr
)
{
struct
orig_node
*
orig_node
;
int
size
;
...
...
@@ -196,7 +196,7 @@ struct orig_node *get_orig_node(struct bat_priv *bat_priv, uint8_t *addr)
bat_dbg
(
DBG_BATMAN
,
bat_priv
,
"Creating new originator: %pM
\n
"
,
addr
);
orig_node
=
kzalloc
(
sizeof
(
struct
orig_node
),
GFP_ATOMIC
);
orig_node
=
kzalloc
(
sizeof
(
*
orig_node
),
GFP_ATOMIC
);
if
(
!
orig_node
)
return
NULL
;
...
...
@@ -559,7 +559,7 @@ static int orig_node_del_if(struct orig_node *orig_node,
memcpy
(
data_ptr
,
orig_node
->
bcast_own
,
del_if_num
*
chunk_size
);
/* copy second part */
memcpy
(
data_ptr
+
del_if_num
*
chunk_size
,
memcpy
(
(
char
*
)
data_ptr
+
del_if_num
*
chunk_size
,
orig_node
->
bcast_own
+
((
del_if_num
+
1
)
*
chunk_size
),
(
max_if_num
-
del_if_num
)
*
chunk_size
);
...
...
@@ -579,7 +579,7 @@ static int orig_node_del_if(struct orig_node *orig_node,
memcpy
(
data_ptr
,
orig_node
->
bcast_own_sum
,
del_if_num
*
sizeof
(
uint8_t
));
memcpy
(
data_ptr
+
del_if_num
*
sizeof
(
uint8_t
),
memcpy
(
(
char
*
)
data_ptr
+
del_if_num
*
sizeof
(
uint8_t
),
orig_node
->
bcast_own_sum
+
((
del_if_num
+
1
)
*
sizeof
(
uint8_t
)),
(
max_if_num
-
del_if_num
)
*
sizeof
(
uint8_t
));
...
...
net/batman-adv/originator.h
View file @
5bf74c91
...
...
@@ -28,10 +28,10 @@ int originator_init(struct bat_priv *bat_priv);
void
originator_free
(
struct
bat_priv
*
bat_priv
);
void
purge_orig_ref
(
struct
bat_priv
*
bat_priv
);
void
orig_node_free_ref
(
struct
orig_node
*
orig_node
);
struct
orig_node
*
get_orig_node
(
struct
bat_priv
*
bat_priv
,
uint8_t
*
addr
);
struct
orig_node
*
get_orig_node
(
struct
bat_priv
*
bat_priv
,
const
uint8_t
*
addr
);
struct
neigh_node
*
create_neighbor
(
struct
orig_node
*
orig_node
,
struct
orig_node
*
orig_neigh_node
,
uint8_t
*
neigh
,
const
uint8_t
*
neigh
,
struct
hard_iface
*
if_incoming
);
void
neigh_node_free_ref
(
struct
neigh_node
*
neigh_node
);
struct
neigh_node
*
orig_node_get_router
(
struct
orig_node
*
orig_node
);
...
...
@@ -41,18 +41,18 @@ int orig_hash_del_if(struct hard_iface *hard_iface, int max_if_num);
/* returns 1 if they are the same originator */
static
inline
int
compare_orig
(
struct
hlist_node
*
node
,
void
*
data2
)
static
inline
int
compare_orig
(
const
struct
hlist_node
*
node
,
const
void
*
data2
)
{
void
*
data1
=
container_of
(
node
,
struct
orig_node
,
hash_entry
);
const
void
*
data1
=
container_of
(
node
,
struct
orig_node
,
hash_entry
);
return
(
memcmp
(
data1
,
data2
,
ETH_ALEN
)
==
0
?
1
:
0
);
}
/* hashfunction to choose an entry in a hash table of given size */
/* hash algorithm from http://en.wikipedia.org/wiki/Hash_table */
static
inline
int
choose_orig
(
void
*
data
,
int32_t
size
)
static
inline
int
choose_orig
(
const
void
*
data
,
int32_t
size
)
{
unsigned
char
*
key
=
data
;
const
unsigned
char
*
key
=
data
;
uint32_t
hash
=
0
;
size_t
i
;
...
...
@@ -70,7 +70,7 @@ static inline int choose_orig(void *data, int32_t size)
}
static
inline
struct
orig_node
*
orig_hash_find
(
struct
bat_priv
*
bat_priv
,
void
*
data
)
const
void
*
data
)
{
struct
hashtable_t
*
hash
=
bat_priv
->
orig_hash
;
struct
hlist_head
*
head
;
...
...
net/batman-adv/ring_buffer.c
View file @
5bf74c91
...
...
@@ -28,9 +28,9 @@ void ring_buffer_set(uint8_t lq_recv[], uint8_t *lq_index, uint8_t value)
*
lq_index
=
(
*
lq_index
+
1
)
%
TQ_GLOBAL_WINDOW_SIZE
;
}
uint8_t
ring_buffer_avg
(
uint8_t
lq_recv
[])
uint8_t
ring_buffer_avg
(
const
uint8_t
lq_recv
[])
{
uint8_t
*
ptr
;
const
uint8_t
*
ptr
;
uint16_t
count
=
0
,
i
=
0
,
sum
=
0
;
ptr
=
lq_recv
;
...
...
net/batman-adv/ring_buffer.h
View file @
5bf74c91
...
...
@@ -23,6 +23,6 @@
#define _NET_BATMAN_ADV_RING_BUFFER_H_
void
ring_buffer_set
(
uint8_t
lq_recv
[],
uint8_t
*
lq_index
,
uint8_t
value
);
uint8_t
ring_buffer_avg
(
uint8_t
lq_recv
[]);
uint8_t
ring_buffer_avg
(
const
uint8_t
lq_recv
[]);
#endif
/* _NET_BATMAN_ADV_RING_BUFFER_H_ */
net/batman-adv/routing.c
View file @
5bf74c91
...
...
@@ -65,7 +65,7 @@ void slide_own_bcast_window(struct hard_iface *hard_iface)
}
static
void
update_TT
(
struct
bat_priv
*
bat_priv
,
struct
orig_node
*
orig_node
,
unsigned
char
*
tt_buff
,
int
tt_buff_len
)
const
unsigned
char
*
tt_buff
,
int
tt_buff_len
)
{
if
((
tt_buff_len
!=
orig_node
->
tt_buff_len
)
||
((
tt_buff_len
>
0
)
&&
...
...
@@ -82,10 +82,9 @@ static void update_TT(struct bat_priv *bat_priv, struct orig_node *orig_node,
}
}
static
void
update_route
(
struct
bat_priv
*
bat_priv
,
struct
orig_node
*
orig_node
,
static
void
update_route
(
struct
bat_priv
*
bat_priv
,
struct
orig_node
*
orig_node
,
struct
neigh_node
*
neigh_node
,
unsigned
char
*
tt_buff
,
int
tt_buff_len
)
const
unsigned
char
*
tt_buff
,
int
tt_buff_len
)
{
struct
neigh_node
*
curr_router
;
...
...
@@ -109,7 +108,7 @@ static void update_route(struct bat_priv *bat_priv,
tt_buff
,
tt_buff_len
);
/* route changed */
}
else
{
}
else
if
(
neigh_node
&&
curr_router
)
{
bat_dbg
(
DBG_ROUTES
,
bat_priv
,
"Changing route towards: %pM "
"(now via %pM - was via %pM)
\n
"
,
...
...
@@ -133,9 +132,8 @@ static void update_route(struct bat_priv *bat_priv,
neigh_node_free_ref
(
curr_router
);
}
void
update_routes
(
struct
bat_priv
*
bat_priv
,
struct
orig_node
*
orig_node
,
struct
neigh_node
*
neigh_node
,
unsigned
char
*
tt_buff
,
struct
neigh_node
*
neigh_node
,
const
unsigned
char
*
tt_buff
,
int
tt_buff_len
)
{
struct
neigh_node
*
router
=
NULL
;
...
...
@@ -348,9 +346,9 @@ static void bonding_candidate_add(struct orig_node *orig_node,
}
/* copy primary address for bonding */
static
void
bonding_save_primary
(
struct
orig_node
*
orig_node
,
static
void
bonding_save_primary
(
const
struct
orig_node
*
orig_node
,
struct
orig_node
*
orig_neigh_node
,
struct
batman_packet
*
batman_packet
)
const
struct
batman_packet
*
batman_packet
)
{
if
(
!
(
batman_packet
->
flags
&
PRIMARIES_FIRST_HOP
))
return
;
...
...
@@ -358,12 +356,11 @@ static void bonding_save_primary(struct orig_node *orig_node,
memcpy
(
orig_neigh_node
->
primary_addr
,
orig_node
->
orig
,
ETH_ALEN
);
}
static
void
update_orig
(
struct
bat_priv
*
bat_priv
,
struct
orig_node
*
orig_node
,
struct
ethhdr
*
ethhdr
,
struct
batman_packet
*
batman_packet
,
static
void
update_orig
(
struct
bat_priv
*
bat_priv
,
struct
orig_node
*
orig_node
,
const
struct
ethhdr
*
ethhdr
,
const
struct
batman_packet
*
batman_packet
,
struct
hard_iface
*
if_incoming
,
unsigned
char
*
tt_buff
,
int
tt_buff_len
,
const
unsigned
char
*
tt_buff
,
int
tt_buff_len
,
char
is_duplicate
)
{
struct
neigh_node
*
neigh_node
=
NULL
,
*
tmp_neigh_node
=
NULL
;
...
...
@@ -531,9 +528,9 @@ static int window_protected(struct bat_priv *bat_priv,
* -1 the packet is old and has been received while the seqno window
* was protected. Caller should drop it.
*/
static
char
count_real_packets
(
struct
ethhdr
*
ethhdr
,
struct
batman_packet
*
batman_packet
,
struct
hard_iface
*
if_incoming
)
static
char
count_real_packets
(
const
struct
ethhdr
*
ethhdr
,
const
struct
batman_packet
*
batman_packet
,
const
struct
hard_iface
*
if_incoming
)
{
struct
bat_priv
*
bat_priv
=
netdev_priv
(
if_incoming
->
soft_iface
);
struct
orig_node
*
orig_node
;
...
...
@@ -595,9 +592,9 @@ static char count_real_packets(struct ethhdr *ethhdr,
return
ret
;
}
void
receive_bat_packet
(
struct
ethhdr
*
ethhdr
,
void
receive_bat_packet
(
const
struct
ethhdr
*
ethhdr
,
struct
batman_packet
*
batman_packet
,
unsigned
char
*
tt_buff
,
int
tt_buff_len
,
const
unsigned
char
*
tt_buff
,
int
tt_buff_len
,
struct
hard_iface
*
if_incoming
)
{
struct
bat_priv
*
bat_priv
=
netdev_priv
(
if_incoming
->
soft_iface
);
...
...
@@ -664,7 +661,7 @@ void receive_bat_packet(struct ethhdr *ethhdr,
hard_iface
->
net_dev
->
dev_addr
))
is_my_oldorig
=
1
;
if
(
compare_eth
(
ethhdr
->
h_source
,
broadcast_addr
))
if
(
is_broadcast_ether_addr
(
ethhdr
->
h_source
))
is_broadcast
=
1
;
}
rcu_read_unlock
();
...
...
@@ -1077,7 +1074,7 @@ int recv_icmp_packet(struct sk_buff *skb, struct hard_iface *recv_if)
* This method rotates the bonding list and increases the
* returned router's refcount. */
static
struct
neigh_node
*
find_bond_router
(
struct
orig_node
*
primary_orig
,
struct
hard_iface
*
recv_if
)
const
struct
hard_iface
*
recv_if
)
{
struct
neigh_node
*
tmp_neigh_node
;
struct
neigh_node
*
router
=
NULL
,
*
first_candidate
=
NULL
;
...
...
@@ -1128,7 +1125,7 @@ static struct neigh_node *find_bond_router(struct orig_node *primary_orig,
*
* Increases the returned router's refcount */
static
struct
neigh_node
*
find_ifalter_router
(
struct
orig_node
*
primary_orig
,
struct
hard_iface
*
recv_if
)
const
struct
hard_iface
*
recv_if
)
{
struct
neigh_node
*
tmp_neigh_node
;
struct
neigh_node
*
router
=
NULL
,
*
first_candidate
=
NULL
;
...
...
@@ -1176,7 +1173,7 @@ static struct neigh_node *find_ifalter_router(struct orig_node *primary_orig,
* refcount.*/
struct
neigh_node
*
find_router
(
struct
bat_priv
*
bat_priv
,
struct
orig_node
*
orig_node
,
struct
hard_iface
*
recv_if
)
const
struct
hard_iface
*
recv_if
)
{
struct
orig_node
*
primary_orig_node
;
struct
orig_node
*
router_orig
;
...
...
@@ -1240,6 +1237,9 @@ struct neigh_node *find_router(struct bat_priv *bat_priv,
router
=
find_ifalter_router
(
primary_orig_node
,
recv_if
);
return_router:
if
(
router
&&
router
->
if_incoming
->
if_status
!=
IF_ACTIVE
)
goto
err_unlock
;
rcu_read_unlock
();
return
router
;
err_unlock:
...
...
@@ -1357,7 +1357,7 @@ int route_unicast_packet(struct sk_buff *skb, struct hard_iface *recv_if)
int
recv_unicast_packet
(
struct
sk_buff
*
skb
,
struct
hard_iface
*
recv_if
)
{
struct
unicast_packet
*
unicast_packet
;
int
hdr_size
=
sizeof
(
struct
unicast_packet
);
int
hdr_size
=
sizeof
(
*
unicast_packet
);
if
(
check_unicast_packet
(
skb
,
hdr_size
)
<
0
)
return
NET_RX_DROP
;
...
...
@@ -1377,7 +1377,7 @@ int recv_ucast_frag_packet(struct sk_buff *skb, struct hard_iface *recv_if)
{
struct
bat_priv
*
bat_priv
=
netdev_priv
(
recv_if
->
soft_iface
);
struct
unicast_frag_packet
*
unicast_packet
;
int
hdr_size
=
sizeof
(
struct
unicast_frag
_packet
);
int
hdr_size
=
sizeof
(
*
unicast
_packet
);
struct
sk_buff
*
new_skb
=
NULL
;
int
ret
;
...
...
@@ -1413,7 +1413,7 @@ int recv_bcast_packet(struct sk_buff *skb, struct hard_iface *recv_if)
struct
orig_node
*
orig_node
=
NULL
;
struct
bcast_packet
*
bcast_packet
;
struct
ethhdr
*
ethhdr
;
int
hdr_size
=
sizeof
(
struct
bcast_packet
);
int
hdr_size
=
sizeof
(
*
bcast_packet
);
int
ret
=
NET_RX_DROP
;
int32_t
seq_diff
;
...
...
@@ -1491,7 +1491,7 @@ int recv_vis_packet(struct sk_buff *skb, struct hard_iface *recv_if)
struct
vis_packet
*
vis_packet
;
struct
ethhdr
*
ethhdr
;
struct
bat_priv
*
bat_priv
=
netdev_priv
(
recv_if
->
soft_iface
);
int
hdr_size
=
sizeof
(
struct
vis_packet
);
int
hdr_size
=
sizeof
(
*
vis_packet
);
/* keep skb linear */
if
(
skb_linearize
(
skb
)
<
0
)
...
...
net/batman-adv/routing.h
View file @
5bf74c91
...
...
@@ -23,12 +23,12 @@
#define _NET_BATMAN_ADV_ROUTING_H_
void
slide_own_bcast_window
(
struct
hard_iface
*
hard_iface
);
void
receive_bat_packet
(
struct
ethhdr
*
ethhdr
,
void
receive_bat_packet
(
const
struct
ethhdr
*
ethhdr
,
struct
batman_packet
*
batman_packet
,
unsigned
char
*
tt_buff
,
int
tt_buff_len
,
const
unsigned
char
*
tt_buff
,
int
tt_buff_len
,
struct
hard_iface
*
if_incoming
);
void
update_routes
(
struct
bat_priv
*
bat_priv
,
struct
orig_node
*
orig_node
,
struct
neigh_node
*
neigh_node
,
unsigned
char
*
tt_buff
,
struct
neigh_node
*
neigh_node
,
const
unsigned
char
*
tt_buff
,
int
tt_buff_len
);
int
route_unicast_packet
(
struct
sk_buff
*
skb
,
struct
hard_iface
*
recv_if
);
int
recv_icmp_packet
(
struct
sk_buff
*
skb
,
struct
hard_iface
*
recv_if
);
...
...
@@ -39,7 +39,7 @@ int recv_vis_packet(struct sk_buff *skb, struct hard_iface *recv_if);
int
recv_bat_packet
(
struct
sk_buff
*
skb
,
struct
hard_iface
*
recv_if
);
struct
neigh_node
*
find_router
(
struct
bat_priv
*
bat_priv
,
struct
orig_node
*
orig_node
,
struct
hard_iface
*
recv_if
);
const
struct
hard_iface
*
recv_if
);
void
bonding_candidate_del
(
struct
orig_node
*
orig_node
,
struct
neigh_node
*
neigh_node
);
...
...
net/batman-adv/send.c
View file @
5bf74c91
...
...
@@ -33,14 +33,14 @@
static
void
send_outstanding_bcast_packet
(
struct
work_struct
*
work
);
/* apply hop penalty for a normal link */
static
uint8_t
hop_penalty
(
const
uint8_t
tq
,
struct
bat_priv
*
bat_priv
)
static
uint8_t
hop_penalty
(
uint8_t
tq
,
const
struct
bat_priv
*
bat_priv
)
{
int
hop_penalty
=
atomic_read
(
&
bat_priv
->
hop_penalty
);
return
(
tq
*
(
TQ_MAX_VALUE
-
hop_penalty
))
/
(
TQ_MAX_VALUE
);
}
/* when do we schedule our own packet to be sent */
static
unsigned
long
own_send_time
(
struct
bat_priv
*
bat_priv
)
static
unsigned
long
own_send_time
(
const
struct
bat_priv
*
bat_priv
)
{
return
jiffies
+
msecs_to_jiffies
(
atomic_read
(
&
bat_priv
->
orig_interval
)
-
...
...
@@ -55,9 +55,8 @@ static unsigned long forward_send_time(void)
/* send out an already prepared packet to the given address via the
* specified batman interface */
int
send_skb_packet
(
struct
sk_buff
*
skb
,
struct
hard_iface
*
hard_iface
,
uint8_t
*
dst_addr
)
int
send_skb_packet
(
struct
sk_buff
*
skb
,
struct
hard_iface
*
hard_iface
,
const
uint8_t
*
dst_addr
)
{
struct
ethhdr
*
ethhdr
;
...
...
@@ -74,7 +73,7 @@ int send_skb_packet(struct sk_buff *skb,
}
/* push to the ethernet header. */
if
(
my_skb_head_push
(
skb
,
sizeof
(
struct
ethhdr
))
<
0
)
if
(
my_skb_head_push
(
skb
,
sizeof
(
*
ethhdr
))
<
0
)
goto
send_skb_err
;
skb_reset_mac_header
(
skb
);
...
...
@@ -145,7 +144,7 @@ static void send_packet_to_if(struct forw_packet *forw_packet,
hard_iface
->
net_dev
->
name
,
hard_iface
->
net_dev
->
dev_addr
);
buff_pos
+=
sizeof
(
struct
batman_packet
)
+
buff_pos
+=
sizeof
(
*
batman_packet
)
+
(
batman_packet
->
num_tt
*
ETH_ALEN
);
packet_num
++
;
batman_packet
=
(
struct
batman_packet
*
)
...
...
@@ -221,19 +220,18 @@ static void rebuild_batman_packet(struct bat_priv *bat_priv,
unsigned
char
*
new_buff
;
struct
batman_packet
*
batman_packet
;
new_len
=
sizeof
(
struct
batman_packet
)
+
(
bat_priv
->
num_local_tt
*
ETH_ALEN
);
new_len
=
sizeof
(
*
batman_packet
)
+
(
bat_priv
->
num_local_tt
*
ETH_ALEN
);
new_buff
=
kmalloc
(
new_len
,
GFP_ATOMIC
);
/* keep old buffer if kmalloc should fail */
if
(
new_buff
)
{
memcpy
(
new_buff
,
hard_iface
->
packet_buff
,
sizeof
(
struct
batman_packet
));
sizeof
(
*
batman_packet
));
batman_packet
=
(
struct
batman_packet
*
)
new_buff
;
batman_packet
->
num_tt
=
tt_local_fill_buffer
(
bat_priv
,
new_buff
+
sizeof
(
struct
batman_packet
),
new_len
-
sizeof
(
struct
batman_packet
));
new_buff
+
sizeof
(
*
batman_packet
),
new_len
-
sizeof
(
*
batman_packet
));
kfree
(
hard_iface
->
packet_buff
);
hard_iface
->
packet_buff
=
new_buff
;
...
...
@@ -307,7 +305,7 @@ void schedule_own_packet(struct hard_iface *hard_iface)
}
void
schedule_forward_packet
(
struct
orig_node
*
orig_node
,
struct
ethhdr
*
ethhdr
,
const
struct
ethhdr
*
ethhdr
,
struct
batman_packet
*
batman_packet
,
uint8_t
directlink
,
int
tt_buff_len
,
struct
hard_iface
*
if_incoming
)
...
...
@@ -369,7 +367,7 @@ void schedule_forward_packet(struct orig_node *orig_node,
send_time
=
forward_send_time
();
add_bat_packet_to_list
(
bat_priv
,
(
unsigned
char
*
)
batman_packet
,
sizeof
(
struct
batman_packet
)
+
tt_buff_len
,
sizeof
(
*
batman_packet
)
+
tt_buff_len
,
if_incoming
,
0
,
send_time
);
}
...
...
@@ -408,11 +406,13 @@ static void _add_bcast_packet_to_list(struct bat_priv *bat_priv,
*
* The skb is not consumed, so the caller should make sure that the
* skb is freed. */
int
add_bcast_packet_to_list
(
struct
bat_priv
*
bat_priv
,
struct
sk_buff
*
skb
)
int
add_bcast_packet_to_list
(
struct
bat_priv
*
bat_priv
,
const
struct
sk_buff
*
skb
)
{
struct
hard_iface
*
primary_if
=
NULL
;
struct
forw_packet
*
forw_packet
;
struct
bcast_packet
*
bcast_packet
;
struct
sk_buff
*
newskb
;
if
(
!
atomic_dec_not_zero
(
&
bat_priv
->
bcast_queue_left
))
{
bat_dbg
(
DBG_BATMAN
,
bat_priv
,
"bcast packet queue full
\n
"
);
...
...
@@ -423,22 +423,22 @@ int add_bcast_packet_to_list(struct bat_priv *bat_priv, struct sk_buff *skb)
if
(
!
primary_if
)
goto
out_and_inc
;
forw_packet
=
kmalloc
(
sizeof
(
struct
forw_packet
),
GFP_ATOMIC
);
forw_packet
=
kmalloc
(
sizeof
(
*
forw_packet
),
GFP_ATOMIC
);
if
(
!
forw_packet
)
goto
out_and_inc
;
skb
=
skb_copy
(
skb
,
GFP_ATOMIC
);
if
(
!
skb
)
new
skb
=
skb_copy
(
skb
,
GFP_ATOMIC
);
if
(
!
new
skb
)
goto
packet_free
;
/* as we have a copy now, it is safe to decrease the TTL */
bcast_packet
=
(
struct
bcast_packet
*
)
skb
->
data
;
bcast_packet
=
(
struct
bcast_packet
*
)
new
skb
->
data
;
bcast_packet
->
ttl
--
;
skb_reset_mac_header
(
skb
);
skb_reset_mac_header
(
new
skb
);
forw_packet
->
skb
=
skb
;
forw_packet
->
skb
=
new
skb
;
forw_packet
->
if_incoming
=
primary_if
;
/* how often did we send the bcast packet ? */
...
...
@@ -537,7 +537,7 @@ void send_outstanding_bat_packet(struct work_struct *work)
}
void
purge_outstanding_packets
(
struct
bat_priv
*
bat_priv
,
struct
hard_iface
*
hard_iface
)
const
struct
hard_iface
*
hard_iface
)
{
struct
forw_packet
*
forw_packet
;
struct
hlist_node
*
tmp_node
,
*
safe_tmp_node
;
...
...
net/batman-adv/send.h
View file @
5bf74c91
...
...
@@ -22,18 +22,18 @@
#ifndef _NET_BATMAN_ADV_SEND_H_
#define _NET_BATMAN_ADV_SEND_H_
int
send_skb_packet
(
struct
sk_buff
*
skb
,
struct
hard_iface
*
hard_iface
,
uint8_t
*
dst_addr
);
int
send_skb_packet
(
struct
sk_buff
*
skb
,
struct
hard_iface
*
hard_iface
,
const
uint8_t
*
dst_addr
);
void
schedule_own_packet
(
struct
hard_iface
*
hard_iface
);
void
schedule_forward_packet
(
struct
orig_node
*
orig_node
,
struct
ethhdr
*
ethhdr
,
const
struct
ethhdr
*
ethhdr
,
struct
batman_packet
*
batman_packet
,
uint8_t
directlink
,
int
tt_buff_len
,
struct
hard_iface
*
if_outgoing
);
int
add_bcast_packet_to_list
(
struct
bat_priv
*
bat_priv
,
struct
sk_buff
*
skb
);
int
add_bcast_packet_to_list
(
struct
bat_priv
*
bat_priv
,
const
struct
sk_buff
*
skb
);
void
send_outstanding_bat_packet
(
struct
work_struct
*
work
);
void
purge_outstanding_packets
(
struct
bat_priv
*
bat_priv
,
struct
hard_iface
*
hard_iface
);
const
struct
hard_iface
*
hard_iface
);
#endif
/* _NET_BATMAN_ADV_SEND_H_ */
net/batman-adv/soft-interface.c
View file @
5bf74c91
...
...
@@ -123,8 +123,7 @@ static struct softif_neigh_vid *softif_neigh_vid_get(struct bat_priv *bat_priv,
goto
out
;
}
softif_neigh_vid
=
kzalloc
(
sizeof
(
struct
softif_neigh_vid
),
GFP_ATOMIC
);
softif_neigh_vid
=
kzalloc
(
sizeof
(
*
softif_neigh_vid
),
GFP_ATOMIC
);
if
(
!
softif_neigh_vid
)
goto
out
;
...
...
@@ -146,7 +145,7 @@ static struct softif_neigh_vid *softif_neigh_vid_get(struct bat_priv *bat_priv,
}
static
struct
softif_neigh
*
softif_neigh_get
(
struct
bat_priv
*
bat_priv
,
uint8_t
*
addr
,
short
vid
)
const
uint8_t
*
addr
,
short
vid
)
{
struct
softif_neigh_vid
*
softif_neigh_vid
;
struct
softif_neigh
*
softif_neigh
=
NULL
;
...
...
@@ -170,7 +169,7 @@ static struct softif_neigh *softif_neigh_get(struct bat_priv *bat_priv,
goto
unlock
;
}
softif_neigh
=
kzalloc
(
sizeof
(
struct
softif_neigh
),
GFP_ATOMIC
);
softif_neigh
=
kzalloc
(
sizeof
(
*
softif_neigh
),
GFP_ATOMIC
);
if
(
!
softif_neigh
)
goto
unlock
;
...
...
@@ -242,7 +241,8 @@ static void softif_neigh_vid_select(struct bat_priv *bat_priv,
if
(
new_neigh
&&
!
atomic_inc_not_zero
(
&
new_neigh
->
refcount
))
new_neigh
=
NULL
;
curr_neigh
=
softif_neigh_vid
->
softif_neigh
;
curr_neigh
=
rcu_dereference_protected
(
softif_neigh_vid
->
softif_neigh
,
1
);
rcu_assign_pointer
(
softif_neigh_vid
->
softif_neigh
,
new_neigh
);
if
((
curr_neigh
)
&&
(
!
new_neigh
))
...
...
@@ -611,7 +611,7 @@ int interface_tx(struct sk_buff *skb, struct net_device *soft_iface)
if
(
!
primary_if
)
goto
dropped
;
if
(
my_skb_head_push
(
skb
,
sizeof
(
struct
bcast_packet
))
<
0
)
if
(
my_skb_head_push
(
skb
,
sizeof
(
*
bcast_packet
))
<
0
)
goto
dropped
;
bcast_packet
=
(
struct
bcast_packet
*
)
skb
->
data
;
...
...
@@ -790,17 +790,16 @@ static void interface_setup(struct net_device *dev)
SET_ETHTOOL_OPS
(
dev
,
&
bat_ethtool_ops
);
memset
(
priv
,
0
,
sizeof
(
struct
bat_
priv
));
memset
(
priv
,
0
,
sizeof
(
*
priv
));
}
struct
net_device
*
softif_create
(
char
*
name
)
struct
net_device
*
softif_create
(
c
onst
c
har
*
name
)
{
struct
net_device
*
soft_iface
;
struct
bat_priv
*
bat_priv
;
int
ret
;
soft_iface
=
alloc_netdev
(
sizeof
(
struct
bat_priv
)
,
name
,
interface_setup
);
soft_iface
=
alloc_netdev
(
sizeof
(
*
bat_priv
),
name
,
interface_setup
);
if
(
!
soft_iface
)
{
pr_err
(
"Unable to allocate the batman interface: %s
\n
"
,
name
);
...
...
@@ -872,7 +871,7 @@ void softif_destroy(struct net_device *soft_iface)
unregister_netdevice
(
soft_iface
);
}
int
softif_is_valid
(
struct
net_device
*
net_dev
)
int
softif_is_valid
(
const
struct
net_device
*
net_dev
)
{
#ifdef HAVE_NET_DEVICE_OPS
if
(
net_dev
->
netdev_ops
->
ndo_start_xmit
==
interface_tx
)
...
...
@@ -924,4 +923,3 @@ static u32 bat_get_link(struct net_device *dev)
{
return
1
;
}
net/batman-adv/soft-interface.h
View file @
5bf74c91
...
...
@@ -29,8 +29,8 @@ int interface_tx(struct sk_buff *skb, struct net_device *soft_iface);
void
interface_rx
(
struct
net_device
*
soft_iface
,
struct
sk_buff
*
skb
,
struct
hard_iface
*
recv_if
,
int
hdr_size
);
struct
net_device
*
softif_create
(
char
*
name
);
struct
net_device
*
softif_create
(
c
onst
c
har
*
name
);
void
softif_destroy
(
struct
net_device
*
soft_iface
);
int
softif_is_valid
(
struct
net_device
*
net_dev
);
int
softif_is_valid
(
const
struct
net_device
*
net_dev
);
#endif
/* _NET_BATMAN_ADV_SOFT_INTERFACE_H_ */
net/batman-adv/translation-table.c
View file @
5bf74c91
...
...
@@ -29,20 +29,22 @@
static
void
tt_local_purge
(
struct
work_struct
*
work
);
static
void
_tt_global_del_orig
(
struct
bat_priv
*
bat_priv
,
struct
tt_global_entry
*
tt_global_entry
,
char
*
message
);
c
onst
c
har
*
message
);
/* returns 1 if they are the same mac addr */
static
int
compare_ltt
(
struct
hlist_node
*
node
,
void
*
data2
)
static
int
compare_ltt
(
const
struct
hlist_node
*
node
,
const
void
*
data2
)
{
void
*
data1
=
container_of
(
node
,
struct
tt_local_entry
,
hash_entry
);
const
void
*
data1
=
container_of
(
node
,
struct
tt_local_entry
,
hash_entry
);
return
(
memcmp
(
data1
,
data2
,
ETH_ALEN
)
==
0
?
1
:
0
);
}
/* returns 1 if they are the same mac addr */
static
int
compare_gtt
(
struct
hlist_node
*
node
,
void
*
data2
)
static
int
compare_gtt
(
const
struct
hlist_node
*
node
,
const
void
*
data2
)
{
void
*
data1
=
container_of
(
node
,
struct
tt_global_entry
,
hash_entry
);
const
void
*
data1
=
container_of
(
node
,
struct
tt_global_entry
,
hash_entry
);
return
(
memcmp
(
data1
,
data2
,
ETH_ALEN
)
==
0
?
1
:
0
);
}
...
...
@@ -54,7 +56,7 @@ static void tt_local_start_timer(struct bat_priv *bat_priv)
}
static
struct
tt_local_entry
*
tt_local_hash_find
(
struct
bat_priv
*
bat_priv
,
void
*
data
)
const
void
*
data
)
{
struct
hashtable_t
*
hash
=
bat_priv
->
tt_local_hash
;
struct
hlist_head
*
head
;
...
...
@@ -82,7 +84,7 @@ static struct tt_local_entry *tt_local_hash_find(struct bat_priv *bat_priv,
}
static
struct
tt_global_entry
*
tt_global_hash_find
(
struct
bat_priv
*
bat_priv
,
void
*
data
)
const
void
*
data
)
{
struct
hashtable_t
*
hash
=
bat_priv
->
tt_global_hash
;
struct
hlist_head
*
head
;
...
...
@@ -126,7 +128,7 @@ int tt_local_init(struct bat_priv *bat_priv)
return
1
;
}
void
tt_local_add
(
struct
net_device
*
soft_iface
,
uint8_t
*
addr
)
void
tt_local_add
(
struct
net_device
*
soft_iface
,
const
uint8_t
*
addr
)
{
struct
bat_priv
*
bat_priv
=
netdev_priv
(
soft_iface
);
struct
tt_local_entry
*
tt_local_entry
;
...
...
@@ -162,7 +164,7 @@ void tt_local_add(struct net_device *soft_iface, uint8_t *addr)
bat_dbg
(
DBG_ROUTES
,
bat_priv
,
"Creating new local tt entry: %pM
\n
"
,
addr
);
tt_local_entry
=
kmalloc
(
sizeof
(
struct
tt_local_entry
),
GFP_ATOMIC
);
tt_local_entry
=
kmalloc
(
sizeof
(
*
tt_local_entry
),
GFP_ATOMIC
);
if
(
!
tt_local_entry
)
return
;
...
...
@@ -311,7 +313,7 @@ int tt_local_seq_print_text(struct seq_file *seq, void *offset)
static
void
_tt_local_del
(
struct
hlist_node
*
node
,
void
*
arg
)
{
struct
bat_priv
*
bat_priv
=
(
struct
bat_priv
*
)
arg
;
struct
bat_priv
*
bat_priv
=
arg
;
void
*
data
=
container_of
(
node
,
struct
tt_local_entry
,
hash_entry
);
kfree
(
data
);
...
...
@@ -321,7 +323,7 @@ static void _tt_local_del(struct hlist_node *node, void *arg)
static
void
tt_local_del
(
struct
bat_priv
*
bat_priv
,
struct
tt_local_entry
*
tt_local_entry
,
char
*
message
)
const
char
*
message
)
{
bat_dbg
(
DBG_ROUTES
,
bat_priv
,
"Deleting local tt entry (%pM): %s
\n
"
,
tt_local_entry
->
addr
,
message
);
...
...
@@ -332,7 +334,7 @@ static void tt_local_del(struct bat_priv *bat_priv,
}
void
tt_local_remove
(
struct
bat_priv
*
bat_priv
,
uint8_t
*
addr
,
char
*
message
)
const
uint8_t
*
addr
,
const
char
*
message
)
{
struct
tt_local_entry
*
tt_local_entry
;
...
...
@@ -409,12 +411,12 @@ int tt_global_init(struct bat_priv *bat_priv)
void
tt_global_add_orig
(
struct
bat_priv
*
bat_priv
,
struct
orig_node
*
orig_node
,
unsigned
char
*
tt_buff
,
int
tt_buff_len
)
const
unsigned
char
*
tt_buff
,
int
tt_buff_len
)
{
struct
tt_global_entry
*
tt_global_entry
;
struct
tt_local_entry
*
tt_local_entry
;
int
tt_buff_count
=
0
;
unsigned
char
*
tt_ptr
;
const
unsigned
char
*
tt_ptr
;
while
((
tt_buff_count
+
1
)
*
ETH_ALEN
<=
tt_buff_len
)
{
spin_lock_bh
(
&
bat_priv
->
tt_ghash_lock
);
...
...
@@ -425,8 +427,7 @@ void tt_global_add_orig(struct bat_priv *bat_priv,
if
(
!
tt_global_entry
)
{
spin_unlock_bh
(
&
bat_priv
->
tt_ghash_lock
);
tt_global_entry
=
kmalloc
(
sizeof
(
struct
tt_global_entry
),
tt_global_entry
=
kmalloc
(
sizeof
(
*
tt_global_entry
),
GFP_ATOMIC
);
if
(
!
tt_global_entry
)
...
...
@@ -557,7 +558,7 @@ int tt_global_seq_print_text(struct seq_file *seq, void *offset)
static
void
_tt_global_del_orig
(
struct
bat_priv
*
bat_priv
,
struct
tt_global_entry
*
tt_global_entry
,
char
*
message
)
c
onst
c
har
*
message
)
{
bat_dbg
(
DBG_ROUTES
,
bat_priv
,
"Deleting global tt entry %pM (via %pM): %s
\n
"
,
...
...
@@ -570,7 +571,7 @@ static void _tt_global_del_orig(struct bat_priv *bat_priv,
}
void
tt_global_del_orig
(
struct
bat_priv
*
bat_priv
,
struct
orig_node
*
orig_node
,
char
*
message
)
struct
orig_node
*
orig_node
,
c
onst
c
har
*
message
)
{
struct
tt_global_entry
*
tt_global_entry
;
int
tt_buff_count
=
0
;
...
...
@@ -616,7 +617,8 @@ void tt_global_free(struct bat_priv *bat_priv)
bat_priv
->
tt_global_hash
=
NULL
;
}
struct
orig_node
*
transtable_search
(
struct
bat_priv
*
bat_priv
,
uint8_t
*
addr
)
struct
orig_node
*
transtable_search
(
struct
bat_priv
*
bat_priv
,
const
uint8_t
*
addr
)
{
struct
tt_global_entry
*
tt_global_entry
;
struct
orig_node
*
orig_node
=
NULL
;
...
...
net/batman-adv/translation-table.h
View file @
5bf74c91
...
...
@@ -23,9 +23,9 @@
#define _NET_BATMAN_ADV_TRANSLATION_TABLE_H_
int
tt_local_init
(
struct
bat_priv
*
bat_priv
);
void
tt_local_add
(
struct
net_device
*
soft_iface
,
uint8_t
*
addr
);
void
tt_local_add
(
struct
net_device
*
soft_iface
,
const
uint8_t
*
addr
);
void
tt_local_remove
(
struct
bat_priv
*
bat_priv
,
uint8_t
*
addr
,
char
*
message
);
const
uint8_t
*
addr
,
const
char
*
message
);
int
tt_local_fill_buffer
(
struct
bat_priv
*
bat_priv
,
unsigned
char
*
buff
,
int
buff_len
);
int
tt_local_seq_print_text
(
struct
seq_file
*
seq
,
void
*
offset
);
...
...
@@ -33,11 +33,12 @@ void tt_local_free(struct bat_priv *bat_priv);
int
tt_global_init
(
struct
bat_priv
*
bat_priv
);
void
tt_global_add_orig
(
struct
bat_priv
*
bat_priv
,
struct
orig_node
*
orig_node
,
unsigned
char
*
tt_buff
,
int
tt_buff_len
);
const
unsigned
char
*
tt_buff
,
int
tt_buff_len
);
int
tt_global_seq_print_text
(
struct
seq_file
*
seq
,
void
*
offset
);
void
tt_global_del_orig
(
struct
bat_priv
*
bat_priv
,
struct
orig_node
*
orig_node
,
char
*
message
);
struct
orig_node
*
orig_node
,
c
onst
c
har
*
message
);
void
tt_global_free
(
struct
bat_priv
*
bat_priv
);
struct
orig_node
*
transtable_search
(
struct
bat_priv
*
bat_priv
,
uint8_t
*
addr
);
struct
orig_node
*
transtable_search
(
struct
bat_priv
*
bat_priv
,
const
uint8_t
*
addr
);
#endif
/* _NET_BATMAN_ADV_TRANSLATION_TABLE_H_ */
net/batman-adv/types.h
View file @
5bf74c91
...
...
@@ -247,9 +247,9 @@ struct frag_packet_list_entry {
struct
vis_info
{
unsigned
long
first_seen
;
struct
list_head
recv_list
;
/* list of server-neighbors we received a vis-packet
* from. we should not reply to them. */
struct
list_head
recv_list
;
struct
list_head
send_list
;
struct
kref
refcount
;
struct
hlist_node
hash_entry
;
...
...
net/batman-adv/unicast.c
View file @
5bf74c91
...
...
@@ -39,8 +39,8 @@ static struct sk_buff *frag_merge_packet(struct list_head *head,
(
struct
unicast_frag_packet
*
)
skb
->
data
;
struct
sk_buff
*
tmp_skb
;
struct
unicast_packet
*
unicast_packet
;
int
hdr_len
=
sizeof
(
struct
unicast_packet
);
int
uni_diff
=
sizeof
(
struct
unicast_frag_packet
)
-
hdr_len
;
int
hdr_len
=
sizeof
(
*
unicast_packet
);
int
uni_diff
=
sizeof
(
*
up
)
-
hdr_len
;
/* set skb to the first part and tmp_skb to the second part */
if
(
up
->
flags
&
UNI_FRAG_HEAD
)
{
...
...
@@ -53,7 +53,7 @@ static struct sk_buff *frag_merge_packet(struct list_head *head,
if
(
skb_linearize
(
skb
)
<
0
||
skb_linearize
(
tmp_skb
)
<
0
)
goto
err
;
skb_pull
(
tmp_skb
,
sizeof
(
struct
unicast_frag_packet
));
skb_pull
(
tmp_skb
,
sizeof
(
*
up
));
if
(
pskb_expand_head
(
skb
,
0
,
tmp_skb
->
len
,
GFP_ATOMIC
)
<
0
)
goto
err
;
...
...
@@ -99,8 +99,7 @@ static int frag_create_buffer(struct list_head *head)
struct
frag_packet_list_entry
*
tfp
;
for
(
i
=
0
;
i
<
FRAG_BUFFER_SIZE
;
i
++
)
{
tfp
=
kmalloc
(
sizeof
(
struct
frag_packet_list_entry
),
GFP_ATOMIC
);
tfp
=
kmalloc
(
sizeof
(
*
tfp
),
GFP_ATOMIC
);
if
(
!
tfp
)
{
frag_list_free
(
head
);
return
-
ENOMEM
;
...
...
@@ -115,7 +114,7 @@ static int frag_create_buffer(struct list_head *head)
}
static
struct
frag_packet_list_entry
*
frag_search_packet
(
struct
list_head
*
head
,
struct
unicast_frag_packet
*
up
)
const
struct
unicast_frag_packet
*
up
)
{
struct
frag_packet_list_entry
*
tfp
;
struct
unicast_frag_packet
*
tmp_up
=
NULL
;
...
...
@@ -218,14 +217,14 @@ int frag_reassemble_skb(struct sk_buff *skb, struct bat_priv *bat_priv,
}
int
frag_send_skb
(
struct
sk_buff
*
skb
,
struct
bat_priv
*
bat_priv
,
struct
hard_iface
*
hard_iface
,
uint8_t
dstaddr
[])
struct
hard_iface
*
hard_iface
,
const
uint8_t
dstaddr
[])
{
struct
unicast_packet
tmp_uc
,
*
unicast_packet
;
struct
hard_iface
*
primary_if
;
struct
sk_buff
*
frag_skb
;
struct
unicast_frag_packet
*
frag1
,
*
frag2
;
int
uc_hdr_len
=
sizeof
(
struct
unicast_packet
);
int
ucf_hdr_len
=
sizeof
(
struct
unicast_frag_packet
);
int
uc_hdr_len
=
sizeof
(
*
unicast_packet
);
int
ucf_hdr_len
=
sizeof
(
*
frag1
);
int
data_len
=
skb
->
len
-
uc_hdr_len
;
int
large_tail
=
0
,
ret
=
NET_RX_DROP
;
uint16_t
seqno
;
...
...
@@ -250,14 +249,14 @@ int frag_send_skb(struct sk_buff *skb, struct bat_priv *bat_priv,
frag1
=
(
struct
unicast_frag_packet
*
)
skb
->
data
;
frag2
=
(
struct
unicast_frag_packet
*
)
frag_skb
->
data
;
memcpy
(
frag1
,
&
tmp_uc
,
sizeof
(
struct
unicast_packet
));
memcpy
(
frag1
,
&
tmp_uc
,
sizeof
(
tmp_uc
));
frag1
->
ttl
--
;
frag1
->
version
=
COMPAT_VERSION
;
frag1
->
packet_type
=
BAT_UNICAST_FRAG
;
memcpy
(
frag1
->
orig
,
primary_if
->
net_dev
->
dev_addr
,
ETH_ALEN
);
memcpy
(
frag2
,
frag1
,
sizeof
(
struct
unicast_frag_packet
));
memcpy
(
frag2
,
frag1
,
sizeof
(
*
frag2
));
if
(
data_len
&
1
)
large_tail
=
UNI_FRAG_LARGETAIL
;
...
...
@@ -295,7 +294,7 @@ int unicast_send_skb(struct sk_buff *skb, struct bat_priv *bat_priv)
/* get routing information */
if
(
is_multicast_ether_addr
(
ethhdr
->
h_dest
))
{
orig_node
=
(
struct
orig_node
*
)
gw_get_selected_orig
(
bat_priv
);
orig_node
=
gw_get_selected_orig
(
bat_priv
);
if
(
orig_node
)
goto
find_router
;
}
...
...
@@ -314,10 +313,7 @@ int unicast_send_skb(struct sk_buff *skb, struct bat_priv *bat_priv)
if
(
!
neigh_node
)
goto
out
;
if
(
neigh_node
->
if_incoming
->
if_status
!=
IF_ACTIVE
)
goto
out
;
if
(
my_skb_head_push
(
skb
,
sizeof
(
struct
unicast_packet
))
<
0
)
if
(
my_skb_head_push
(
skb
,
sizeof
(
*
unicast_packet
))
<
0
)
goto
out
;
unicast_packet
=
(
struct
unicast_packet
*
)
skb
->
data
;
...
...
@@ -331,7 +327,7 @@ int unicast_send_skb(struct sk_buff *skb, struct bat_priv *bat_priv)
memcpy
(
unicast_packet
->
dest
,
orig_node
->
orig
,
ETH_ALEN
);
if
(
atomic_read
(
&
bat_priv
->
fragmentation
)
&&
data_len
+
sizeof
(
struct
unicast_packet
)
>
data_len
+
sizeof
(
*
unicast_packet
)
>
neigh_node
->
if_incoming
->
net_dev
->
mtu
)
{
/* send frag skb decreases ttl */
unicast_packet
->
ttl
++
;
...
...
net/batman-adv/unicast.h
View file @
5bf74c91
...
...
@@ -32,11 +32,11 @@ int frag_reassemble_skb(struct sk_buff *skb, struct bat_priv *bat_priv,
void
frag_list_free
(
struct
list_head
*
head
);
int
unicast_send_skb
(
struct
sk_buff
*
skb
,
struct
bat_priv
*
bat_priv
);
int
frag_send_skb
(
struct
sk_buff
*
skb
,
struct
bat_priv
*
bat_priv
,
struct
hard_iface
*
hard_iface
,
uint8_t
dstaddr
[]);
struct
hard_iface
*
hard_iface
,
const
uint8_t
dstaddr
[]);
static
inline
int
frag_can_reassemble
(
struct
sk_buff
*
skb
,
int
mtu
)
static
inline
int
frag_can_reassemble
(
const
struct
sk_buff
*
skb
,
int
mtu
)
{
struct
unicast_frag_packet
*
unicast_packet
;
const
struct
unicast_frag_packet
*
unicast_packet
;
int
uneven_correction
=
0
;
unsigned
int
merged_size
;
...
...
@@ -49,7 +49,7 @@ static inline int frag_can_reassemble(struct sk_buff *skb, int mtu)
uneven_correction
=
-
1
;
}
merged_size
=
(
skb
->
len
-
sizeof
(
struct
unicast_frag
_packet
))
*
2
;
merged_size
=
(
skb
->
len
-
sizeof
(
*
unicast
_packet
))
*
2
;
merged_size
+=
sizeof
(
struct
unicast_packet
)
+
uneven_correction
;
return
merged_size
<=
mtu
;
...
...
net/batman-adv/vis.c
View file @
5bf74c91
...
...
@@ -30,22 +30,6 @@
#define MAX_VIS_PACKET_SIZE 1000
/* Returns the smallest signed integer in two's complement with the sizeof x */
#define smallest_signed_int(x) (1u << (7u + 8u * (sizeof(x) - 1u)))
/* Checks if a sequence number x is a predecessor/successor of y.
* they handle overflows/underflows and can correctly check for a
* predecessor/successor unless the variable sequence number has grown by
* more then 2**(bitwidth(x)-1)-1.
* This means that for a uint8_t with the maximum value 255, it would think:
* - when adding nothing - it is neither a predecessor nor a successor
* - before adding more than 127 to the starting value - it is a predecessor,
* - when adding 128 - it is neither a predecessor nor a successor,
* - after adding more than 127 to the starting value - it is a successor */
#define seq_before(x, y) ({typeof(x) _dummy = (x - y); \
_dummy > smallest_signed_int(_dummy); })
#define seq_after(x, y) seq_before(y, x)
static
void
start_vis_timer
(
struct
bat_priv
*
bat_priv
);
/* free the info */
...
...
@@ -68,10 +52,10 @@ static void free_info(struct kref *ref)
}
/* Compare two vis packets, used by the hashing algorithm */
static
int
vis_info_cmp
(
struct
hlist_node
*
node
,
void
*
data2
)
static
int
vis_info_cmp
(
const
struct
hlist_node
*
node
,
const
void
*
data2
)
{
struct
vis_info
*
d1
,
*
d2
;
struct
vis_packet
*
p1
,
*
p2
;
const
struct
vis_info
*
d1
,
*
d2
;
const
struct
vis_packet
*
p1
,
*
p2
;
d1
=
container_of
(
node
,
struct
vis_info
,
hash_entry
);
d2
=
data2
;
...
...
@@ -82,11 +66,11 @@ static int vis_info_cmp(struct hlist_node *node, void *data2)
/* hash function to choose an entry in a hash table of given size */
/* hash algorithm from http://en.wikipedia.org/wiki/Hash_table */
static
int
vis_info_choose
(
void
*
data
,
int
size
)
static
int
vis_info_choose
(
const
void
*
data
,
int
size
)
{
struct
vis_info
*
vis_info
=
data
;
struct
vis_packet
*
packet
;
unsigned
char
*
key
;
const
struct
vis_info
*
vis_info
=
data
;
const
struct
vis_packet
*
packet
;
const
unsigned
char
*
key
;
uint32_t
hash
=
0
;
size_t
i
;
...
...
@@ -106,7 +90,7 @@ static int vis_info_choose(void *data, int size)
}
static
struct
vis_info
*
vis_hash_find
(
struct
bat_priv
*
bat_priv
,
void
*
data
)
const
void
*
data
)
{
struct
hashtable_t
*
hash
=
bat_priv
->
vis_hash
;
struct
hlist_head
*
head
;
...
...
@@ -143,7 +127,7 @@ static void vis_data_insert_interface(const uint8_t *interface,
struct
hlist_node
*
pos
;
hlist_for_each_entry
(
entry
,
pos
,
if_list
,
list
)
{
if
(
compare_eth
(
entry
->
addr
,
(
void
*
)
interface
))
if
(
compare_eth
(
entry
->
addr
,
interface
))
return
;
}
...
...
@@ -156,7 +140,8 @@ static void vis_data_insert_interface(const uint8_t *interface,
hlist_add_head
(
&
entry
->
list
,
if_list
);
}
static
ssize_t
vis_data_read_prim_sec
(
char
*
buff
,
struct
hlist_head
*
if_list
)
static
ssize_t
vis_data_read_prim_sec
(
char
*
buff
,
const
struct
hlist_head
*
if_list
)
{
struct
if_list_entry
*
entry
;
struct
hlist_node
*
pos
;
...
...
@@ -189,8 +174,9 @@ static size_t vis_data_count_prim_sec(struct hlist_head *if_list)
}
/* read an entry */
static
ssize_t
vis_data_read_entry
(
char
*
buff
,
struct
vis_info_entry
*
entry
,
uint8_t
*
src
,
bool
primary
)
static
ssize_t
vis_data_read_entry
(
char
*
buff
,
const
struct
vis_info_entry
*
entry
,
const
uint8_t
*
src
,
bool
primary
)
{
/* maximal length: max(4+17+2, 3+17+1+3+2) == 26 */
if
(
primary
&&
entry
->
quality
==
0
)
...
...
@@ -239,7 +225,7 @@ int vis_seq_print_text(struct seq_file *seq, void *offset)
hlist_for_each_entry_rcu
(
info
,
node
,
head
,
hash_entry
)
{
packet
=
(
struct
vis_packet
*
)
info
->
skb_packet
->
data
;
entries
=
(
struct
vis_info_entry
*
)
((
char
*
)
packet
+
sizeof
(
struct
vis_
packet
));
((
char
*
)
packet
+
sizeof
(
*
packet
));
for
(
j
=
0
;
j
<
packet
->
entries
;
j
++
)
{
if
(
entries
[
j
].
quality
==
0
)
...
...
@@ -287,7 +273,7 @@ int vis_seq_print_text(struct seq_file *seq, void *offset)
hlist_for_each_entry_rcu
(
info
,
node
,
head
,
hash_entry
)
{
packet
=
(
struct
vis_packet
*
)
info
->
skb_packet
->
data
;
entries
=
(
struct
vis_info_entry
*
)
((
char
*
)
packet
+
sizeof
(
struct
vis_
packet
));
((
char
*
)
packet
+
sizeof
(
*
packet
));
for
(
j
=
0
;
j
<
packet
->
entries
;
j
++
)
{
if
(
entries
[
j
].
quality
==
0
)
...
...
@@ -361,11 +347,11 @@ static void send_list_del(struct vis_info *info)
/* tries to add one entry to the receive list. */
static
void
recv_list_add
(
struct
bat_priv
*
bat_priv
,
struct
list_head
*
recv_list
,
char
*
mac
)
struct
list_head
*
recv_list
,
c
onst
c
har
*
mac
)
{
struct
recvlist_node
*
entry
;
entry
=
kmalloc
(
sizeof
(
struct
recvlist_node
),
GFP_ATOMIC
);
entry
=
kmalloc
(
sizeof
(
*
entry
),
GFP_ATOMIC
);
if
(
!
entry
)
return
;
...
...
@@ -377,9 +363,9 @@ static void recv_list_add(struct bat_priv *bat_priv,
/* returns 1 if this mac is in the recv_list */
static
int
recv_list_is_in
(
struct
bat_priv
*
bat_priv
,
struct
list_head
*
recv_list
,
char
*
mac
)
const
struct
list_head
*
recv_list
,
const
char
*
mac
)
{
struct
recvlist_node
*
entry
;
const
struct
recvlist_node
*
entry
;
spin_lock_bh
(
&
bat_priv
->
vis_list_lock
);
list_for_each_entry
(
entry
,
recv_list
,
list
)
{
...
...
@@ -412,11 +398,11 @@ static struct vis_info *add_packet(struct bat_priv *bat_priv,
return
NULL
;
/* see if the packet is already in vis_hash */
search_elem
.
skb_packet
=
dev_alloc_skb
(
sizeof
(
struct
vis
_packet
));
search_elem
.
skb_packet
=
dev_alloc_skb
(
sizeof
(
*
search
_packet
));
if
(
!
search_elem
.
skb_packet
)
return
NULL
;
search_packet
=
(
struct
vis_packet
*
)
skb_put
(
search_elem
.
skb_packet
,
sizeof
(
struct
vis
_packet
));
sizeof
(
*
search
_packet
));
memcpy
(
search_packet
->
vis_orig
,
vis_packet
->
vis_orig
,
ETH_ALEN
);
old_info
=
vis_hash_find
(
bat_priv
,
&
search_elem
);
...
...
@@ -442,27 +428,26 @@ static struct vis_info *add_packet(struct bat_priv *bat_priv,
kref_put
(
&
old_info
->
refcount
,
free_info
);
}
info
=
kmalloc
(
sizeof
(
struct
vis_
info
),
GFP_ATOMIC
);
info
=
kmalloc
(
sizeof
(
*
info
),
GFP_ATOMIC
);
if
(
!
info
)
return
NULL
;
info
->
skb_packet
=
dev_alloc_skb
(
sizeof
(
struct
vis_packet
)
+
vis_info_len
+
sizeof
(
struct
ethhdr
));
info
->
skb_packet
=
dev_alloc_skb
(
sizeof
(
*
packet
)
+
vis_info_len
+
sizeof
(
struct
ethhdr
));
if
(
!
info
->
skb_packet
)
{
kfree
(
info
);
return
NULL
;
}
skb_reserve
(
info
->
skb_packet
,
sizeof
(
struct
ethhdr
));
packet
=
(
struct
vis_packet
*
)
skb_put
(
info
->
skb_packet
,
sizeof
(
struct
vis_packet
)
+
vis_info_len
);
packet
=
(
struct
vis_packet
*
)
skb_put
(
info
->
skb_packet
,
sizeof
(
*
packet
)
+
vis_info_len
);
kref_init
(
&
info
->
refcount
);
INIT_LIST_HEAD
(
&
info
->
send_list
);
INIT_LIST_HEAD
(
&
info
->
recv_list
);
info
->
first_seen
=
jiffies
;
info
->
bat_priv
=
bat_priv
;
memcpy
(
packet
,
vis_packet
,
sizeof
(
struct
vis_
packet
)
+
vis_info_len
);
memcpy
(
packet
,
vis_packet
,
sizeof
(
*
packet
)
+
vis_info_len
);
/* initialize and add new packet. */
*
is_new
=
1
;
...
...
@@ -599,9 +584,9 @@ static int find_best_vis_server(struct bat_priv *bat_priv,
}
/* Return true if the vis packet is full. */
static
bool
vis_packet_full
(
struct
vis_info
*
info
)
static
bool
vis_packet_full
(
const
struct
vis_info
*
info
)
{
struct
vis_packet
*
packet
;
const
struct
vis_packet
*
packet
;
packet
=
(
struct
vis_packet
*
)
info
->
skb_packet
->
data
;
if
(
MAX_VIS_PACKET_SIZE
/
sizeof
(
struct
vis_info_entry
)
...
...
@@ -619,7 +604,7 @@ static int generate_vis_packet(struct bat_priv *bat_priv)
struct
hlist_head
*
head
;
struct
orig_node
*
orig_node
;
struct
neigh_node
*
router
;
struct
vis_info
*
info
=
(
struct
vis_info
*
)
bat_priv
->
my_vis_info
;
struct
vis_info
*
info
=
bat_priv
->
my_vis_info
;
struct
vis_packet
*
packet
=
(
struct
vis_packet
*
)
info
->
skb_packet
->
data
;
struct
vis_info_entry
*
entry
;
struct
tt_local_entry
*
tt_local_entry
;
...
...
@@ -632,7 +617,7 @@ static int generate_vis_packet(struct bat_priv *bat_priv)
packet
->
ttl
=
TTL
;
packet
->
seqno
=
htonl
(
ntohl
(
packet
->
seqno
)
+
1
);
packet
->
entries
=
0
;
skb_trim
(
info
->
skb_packet
,
sizeof
(
struct
vis_
packet
));
skb_trim
(
info
->
skb_packet
,
sizeof
(
*
packet
));
if
(
packet
->
vis_type
==
VIS_TYPE_CLIENT_UPDATE
)
{
best_tq
=
find_best_vis_server
(
bat_priv
,
info
);
...
...
@@ -908,17 +893,15 @@ int vis_init(struct bat_priv *bat_priv)
goto
err
;
}
bat_priv
->
my_vis_info
->
skb_packet
=
dev_alloc_skb
(
sizeof
(
struct
vis_packet
)
+
bat_priv
->
my_vis_info
->
skb_packet
=
dev_alloc_skb
(
sizeof
(
*
packet
)
+
MAX_VIS_PACKET_SIZE
+
sizeof
(
struct
ethhdr
));
if
(
!
bat_priv
->
my_vis_info
->
skb_packet
)
goto
free_info
;
skb_reserve
(
bat_priv
->
my_vis_info
->
skb_packet
,
sizeof
(
struct
ethhdr
));
packet
=
(
struct
vis_packet
*
)
skb_put
(
bat_priv
->
my_vis_info
->
skb_packet
,
sizeof
(
struct
vis_packet
));
packet
=
(
struct
vis_packet
*
)
skb_put
(
bat_priv
->
my_vis_info
->
skb_packet
,
sizeof
(
*
packet
));
/* prefill the vis info */
bat_priv
->
my_vis_info
->
first_seen
=
jiffies
-
...
...
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