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
nexedi
linux
Commits
7b667cd3
Commit
7b667cd3
authored
Mar 14, 2004
by
David S. Miller
Browse files
Options
Browse Files
Download
Plain Diff
Merge davem@nuts.davemloft.net:/disk1/BK/net-2.6
into kernel.bkbits.net:/home/davem/net-2.6
parents
92c06c66
ee127b1d
Changes
21
Hide whitespace changes
Inline
Side-by-side
Showing
21 changed files
with
124 additions
and
105 deletions
+124
-105
drivers/atm/suni.c
drivers/atm/suni.c
+1
-1
drivers/bluetooth/bcm203x.c
drivers/bluetooth/bcm203x.c
+3
-2
drivers/bluetooth/bfusb.c
drivers/bluetooth/bfusb.c
+3
-2
drivers/bluetooth/hci_bcsp.c
drivers/bluetooth/hci_bcsp.c
+1
-1
drivers/bluetooth/hci_ldisc.c
drivers/bluetooth/hci_ldisc.c
+4
-3
drivers/bluetooth/hci_usb.c
drivers/bluetooth/hci_usb.c
+6
-5
drivers/net/tun.c
drivers/net/tun.c
+29
-27
include/linux/netdevice.h
include/linux/netdevice.h
+1
-1
include/linux/tcp.h
include/linux/tcp.h
+0
-1
net/8021q/vlanproc.c
net/8021q/vlanproc.c
+1
-1
net/bluetooth/af_bluetooth.c
net/bluetooth/af_bluetooth.c
+4
-3
net/bluetooth/bnep/core.c
net/bluetooth/bnep/core.c
+7
-6
net/bluetooth/bnep/netdev.c
net/bluetooth/bnep/netdev.c
+1
-1
net/bluetooth/bnep/sock.c
net/bluetooth/bnep/sock.c
+1
-1
net/bluetooth/cmtp/core.c
net/bluetooth/cmtp/core.c
+5
-4
net/bluetooth/hci_event.c
net/bluetooth/hci_event.c
+2
-2
net/bluetooth/l2cap.c
net/bluetooth/l2cap.c
+7
-6
net/bluetooth/rfcomm/core.c
net/bluetooth/rfcomm/core.c
+4
-3
net/bluetooth/sco.c
net/bluetooth/sco.c
+13
-12
net/ipv4/tcp_input.c
net/ipv4/tcp_input.c
+27
-19
net/sched/sch_htb.c
net/sched/sch_htb.c
+4
-4
No files found.
drivers/atm/suni.c
View file @
7b667cd3
...
@@ -230,7 +230,7 @@ static int suni_start(struct atm_dev *dev)
...
@@ -230,7 +230,7 @@ static int suni_start(struct atm_dev *dev)
unsigned
long
flags
;
unsigned
long
flags
;
int
first
;
int
first
;
if
(
!
(
dev
->
dev
_data
=
kmalloc
(
sizeof
(
struct
suni_priv
),
GFP_KERNEL
)))
if
(
!
(
dev
->
phy
_data
=
kmalloc
(
sizeof
(
struct
suni_priv
),
GFP_KERNEL
)))
return
-
ENOMEM
;
return
-
ENOMEM
;
PRIV
(
dev
)
->
dev
=
dev
;
PRIV
(
dev
)
->
dev
=
dev
;
...
...
drivers/bluetooth/bcm203x.c
View file @
7b667cd3
...
@@ -296,14 +296,15 @@ static int __init bcm203x_init(void)
...
@@ -296,14 +296,15 @@ static int __init bcm203x_init(void)
return
err
;
return
err
;
}
}
static
void
__exit
bcm203x_
cleanup
(
void
)
static
void
__exit
bcm203x_
exit
(
void
)
{
{
usb_deregister
(
&
bcm203x_driver
);
usb_deregister
(
&
bcm203x_driver
);
}
}
module_init
(
bcm203x_init
);
module_init
(
bcm203x_init
);
module_exit
(
bcm203x_
cleanup
);
module_exit
(
bcm203x_
exit
);
MODULE_AUTHOR
(
"Marcel Holtmann <marcel@holtmann.org>"
);
MODULE_AUTHOR
(
"Marcel Holtmann <marcel@holtmann.org>"
);
MODULE_DESCRIPTION
(
"Broadcom Blutonium firmware driver ver "
VERSION
);
MODULE_DESCRIPTION
(
"Broadcom Blutonium firmware driver ver "
VERSION
);
MODULE_VERSION
(
VERSION
);
MODULE_LICENSE
(
"GPL"
);
MODULE_LICENSE
(
"GPL"
);
drivers/bluetooth/bfusb.c
View file @
7b667cd3
...
@@ -779,14 +779,15 @@ static int __init bfusb_init(void)
...
@@ -779,14 +779,15 @@ static int __init bfusb_init(void)
return
err
;
return
err
;
}
}
static
void
__exit
bfusb_
cleanup
(
void
)
static
void
__exit
bfusb_
exit
(
void
)
{
{
usb_deregister
(
&
bfusb_driver
);
usb_deregister
(
&
bfusb_driver
);
}
}
module_init
(
bfusb_init
);
module_init
(
bfusb_init
);
module_exit
(
bfusb_
cleanup
);
module_exit
(
bfusb_
exit
);
MODULE_AUTHOR
(
"Marcel Holtmann <marcel@holtmann.org>"
);
MODULE_AUTHOR
(
"Marcel Holtmann <marcel@holtmann.org>"
);
MODULE_DESCRIPTION
(
"BlueFRITZ! USB driver ver "
VERSION
);
MODULE_DESCRIPTION
(
"BlueFRITZ! USB driver ver "
VERSION
);
MODULE_VERSION
(
VERSION
);
MODULE_LICENSE
(
"GPL"
);
MODULE_LICENSE
(
"GPL"
);
drivers/bluetooth/hci_bcsp.c
View file @
7b667cd3
...
@@ -512,7 +512,7 @@ static int bcsp_recv(struct hci_uart *hu, void *data, int count)
...
@@ -512,7 +512,7 @@ static int bcsp_recv(struct hci_uart *hu, void *data, int count)
struct
bcsp_struct
*
bcsp
=
hu
->
priv
;
struct
bcsp_struct
*
bcsp
=
hu
->
priv
;
register
unsigned
char
*
ptr
;
register
unsigned
char
*
ptr
;
BT_DBG
(
"hu %p count %d rx_state %
l
d rx_count %ld"
,
BT_DBG
(
"hu %p count %d rx_state %d rx_count %ld"
,
hu
,
count
,
bcsp
->
rx_state
,
bcsp
->
rx_count
);
hu
,
count
,
bcsp
->
rx_state
,
bcsp
->
rx_count
);
ptr
=
data
;
ptr
=
data
;
...
...
drivers/bluetooth/hci_ldisc.c
View file @
7b667cd3
...
@@ -521,7 +521,7 @@ int bcsp_init(void);
...
@@ -521,7 +521,7 @@ int bcsp_init(void);
int
bcsp_deinit
(
void
);
int
bcsp_deinit
(
void
);
#endif
#endif
int
__init
hci_uart_init
(
void
)
static
int
__init
hci_uart_init
(
void
)
{
{
static
struct
tty_ldisc
hci_uart_ldisc
;
static
struct
tty_ldisc
hci_uart_ldisc
;
int
err
;
int
err
;
...
@@ -559,7 +559,7 @@ int __init hci_uart_init(void)
...
@@ -559,7 +559,7 @@ int __init hci_uart_init(void)
return
0
;
return
0
;
}
}
void
hci_uart_cleanup
(
void
)
static
void
__exit
hci_uart_exit
(
void
)
{
{
int
err
;
int
err
;
...
@@ -576,9 +576,10 @@ void hci_uart_cleanup(void)
...
@@ -576,9 +576,10 @@ void hci_uart_cleanup(void)
}
}
module_init
(
hci_uart_init
);
module_init
(
hci_uart_init
);
module_exit
(
hci_uart_
cleanup
);
module_exit
(
hci_uart_
exit
);
MODULE_AUTHOR
(
"Maxim Krasnyansky <maxk@qualcomm.com>"
);
MODULE_AUTHOR
(
"Maxim Krasnyansky <maxk@qualcomm.com>"
);
MODULE_DESCRIPTION
(
"Bluetooth HCI UART driver ver "
VERSION
);
MODULE_DESCRIPTION
(
"Bluetooth HCI UART driver ver "
VERSION
);
MODULE_VERSION
(
VERSION
);
MODULE_LICENSE
(
"GPL"
);
MODULE_LICENSE
(
"GPL"
);
MODULE_ALIAS_LDISC
(
N_HCI
);
MODULE_ALIAS_LDISC
(
N_HCI
);
drivers/bluetooth/hci_usb.c
View file @
7b667cd3
...
@@ -55,7 +55,7 @@
...
@@ -55,7 +55,7 @@
#include "hci_usb.h"
#include "hci_usb.h"
#ifndef
HCI_
USB_DEBUG
#ifndef
CONFIG_BT_HCI
USB_DEBUG
#undef BT_DBG
#undef BT_DBG
#define BT_DBG( A... )
#define BT_DBG( A... )
#undef BT_DMP
#undef BT_DMP
...
@@ -795,7 +795,7 @@ int hci_usb_probe(struct usb_interface *intf, const struct usb_device_id *id)
...
@@ -795,7 +795,7 @@ int hci_usb_probe(struct usb_interface *intf, const struct usb_device_id *id)
struct
hci_dev
*
hdev
;
struct
hci_dev
*
hdev
;
int
i
,
a
,
e
,
size
,
ifn
,
isoc_ifnum
,
isoc_alts
;
int
i
,
a
,
e
,
size
,
ifn
,
isoc_ifnum
,
isoc_alts
;
BT_DBG
(
"udev %p i
fnum %d"
,
udev
,
ifnum
);
BT_DBG
(
"udev %p i
ntf %p"
,
udev
,
intf
);
if
(
!
id
->
driver_info
)
{
if
(
!
id
->
driver_info
)
{
const
struct
usb_device_id
*
match
;
const
struct
usb_device_id
*
match
;
...
@@ -991,7 +991,7 @@ static struct usb_driver hci_usb_driver = {
...
@@ -991,7 +991,7 @@ static struct usb_driver hci_usb_driver = {
.
id_table
=
bluetooth_ids
,
.
id_table
=
bluetooth_ids
,
};
};
in
t
hci_usb_init
(
void
)
static
int
__ini
t
hci_usb_init
(
void
)
{
{
int
err
;
int
err
;
...
@@ -1003,14 +1003,15 @@ int hci_usb_init(void)
...
@@ -1003,14 +1003,15 @@ int hci_usb_init(void)
return
err
;
return
err
;
}
}
void
hci_usb_cleanup
(
void
)
static
void
__exit
hci_usb_exit
(
void
)
{
{
usb_deregister
(
&
hci_usb_driver
);
usb_deregister
(
&
hci_usb_driver
);
}
}
module_init
(
hci_usb_init
);
module_init
(
hci_usb_init
);
module_exit
(
hci_usb_
cleanup
);
module_exit
(
hci_usb_
exit
);
MODULE_AUTHOR
(
"Maxim Krasnyansky <maxk@qualcomm.com>, Marcel Holtmann <marcel@holtmann.org>"
);
MODULE_AUTHOR
(
"Maxim Krasnyansky <maxk@qualcomm.com>, Marcel Holtmann <marcel@holtmann.org>"
);
MODULE_DESCRIPTION
(
"Bluetooth HCI USB driver ver "
VERSION
);
MODULE_DESCRIPTION
(
"Bluetooth HCI USB driver ver "
VERSION
);
MODULE_VERSION
(
VERSION
);
MODULE_LICENSE
(
"GPL"
);
MODULE_LICENSE
(
"GPL"
);
drivers/net/tun.c
View file @
7b667cd3
...
@@ -169,7 +169,7 @@ static unsigned int tun_chr_poll(struct file *file, poll_table * wait)
...
@@ -169,7 +169,7 @@ static unsigned int tun_chr_poll(struct file *file, poll_table * wait)
return
mask
;
return
mask
;
}
}
/* Get packet from user space buffer
(already verified)
*/
/* Get packet from user space buffer */
static
__inline__
ssize_t
tun_get_user
(
struct
tun_struct
*
tun
,
struct
iovec
*
iv
,
size_t
count
)
static
__inline__
ssize_t
tun_get_user
(
struct
tun_struct
*
tun
,
struct
iovec
*
iv
,
size_t
count
)
{
{
struct
tun_pi
pi
=
{
0
,
__constant_htons
(
ETH_P_IP
)
};
struct
tun_pi
pi
=
{
0
,
__constant_htons
(
ETH_P_IP
)
};
...
@@ -180,7 +180,8 @@ static __inline__ ssize_t tun_get_user(struct tun_struct *tun, struct iovec *iv,
...
@@ -180,7 +180,8 @@ static __inline__ ssize_t tun_get_user(struct tun_struct *tun, struct iovec *iv,
if
((
len
-=
sizeof
(
pi
))
>
len
)
if
((
len
-=
sizeof
(
pi
))
>
len
)
return
-
EINVAL
;
return
-
EINVAL
;
memcpy_fromiovec
((
void
*
)
&
pi
,
iv
,
sizeof
(
pi
));
if
(
memcpy_fromiovec
((
void
*
)
&
pi
,
iv
,
sizeof
(
pi
)))
return
-
EFAULT
;
}
}
if
(
!
(
skb
=
alloc_skb
(
len
+
2
,
GFP_KERNEL
)))
{
if
(
!
(
skb
=
alloc_skb
(
len
+
2
,
GFP_KERNEL
)))
{
...
@@ -189,7 +190,8 @@ static __inline__ ssize_t tun_get_user(struct tun_struct *tun, struct iovec *iv,
...
@@ -189,7 +190,8 @@ static __inline__ ssize_t tun_get_user(struct tun_struct *tun, struct iovec *iv,
}
}
skb_reserve
(
skb
,
2
);
skb_reserve
(
skb
,
2
);
memcpy_fromiovec
(
skb_put
(
skb
,
len
),
iv
,
len
);
if
(
memcpy_fromiovec
(
skb_put
(
skb
,
len
),
iv
,
len
))
return
-
EFAULT
;
skb
->
dev
=
tun
->
dev
;
skb
->
dev
=
tun
->
dev
;
switch
(
tun
->
flags
&
TUN_TYPE_MASK
)
{
switch
(
tun
->
flags
&
TUN_TYPE_MASK
)
{
...
@@ -213,26 +215,29 @@ static __inline__ ssize_t tun_get_user(struct tun_struct *tun, struct iovec *iv,
...
@@ -213,26 +215,29 @@ static __inline__ ssize_t tun_get_user(struct tun_struct *tun, struct iovec *iv,
return
count
;
return
count
;
}
}
static
inline
size_t
iov_total
(
const
struct
iovec
*
iv
,
unsigned
long
count
)
{
unsigned
long
i
;
size_t
len
;
for
(
i
=
0
,
len
=
0
;
i
<
count
;
i
++
)
len
+=
iv
[
i
].
iov_len
;
return
len
;
}
/* Writev */
/* Writev */
static
ssize_t
tun_chr_writev
(
struct
file
*
file
,
const
struct
iovec
*
iv
,
static
ssize_t
tun_chr_writev
(
struct
file
*
file
,
const
struct
iovec
*
iv
,
unsigned
long
count
,
loff_t
*
pos
)
unsigned
long
count
,
loff_t
*
pos
)
{
{
struct
tun_struct
*
tun
=
file
->
private_data
;
struct
tun_struct
*
tun
=
file
->
private_data
;
unsigned
long
i
;
size_t
len
;
if
(
!
tun
)
if
(
!
tun
)
return
-
EBADFD
;
return
-
EBADFD
;
DBG
(
KERN_INFO
"%s: tun_chr_write %ld
\n
"
,
tun
->
dev
->
name
,
count
);
DBG
(
KERN_INFO
"%s: tun_chr_write %ld
\n
"
,
tun
->
dev
->
name
,
count
);
for
(
i
=
0
,
len
=
0
;
i
<
count
;
i
++
)
{
return
tun_get_user
(
tun
,
(
struct
iovec
*
)
iv
,
iov_total
(
iv
,
count
));
if
(
verify_area
(
VERIFY_READ
,
iv
[
i
].
iov_base
,
iv
[
i
].
iov_len
))
return
-
EFAULT
;
len
+=
iv
[
i
].
iov_len
;
}
return
tun_get_user
(
tun
,
(
struct
iovec
*
)
iv
,
len
);
}
}
/* Write */
/* Write */
...
@@ -243,7 +248,7 @@ static ssize_t tun_chr_write(struct file * file, const char * buf,
...
@@ -243,7 +248,7 @@ static ssize_t tun_chr_write(struct file * file, const char * buf,
return
tun_chr_writev
(
file
,
&
iv
,
1
,
pos
);
return
tun_chr_writev
(
file
,
&
iv
,
1
,
pos
);
}
}
/* Put packet to the user space buffer
(already verified)
*/
/* Put packet to the user space buffer */
static
__inline__
ssize_t
tun_put_user
(
struct
tun_struct
*
tun
,
static
__inline__
ssize_t
tun_put_user
(
struct
tun_struct
*
tun
,
struct
sk_buff
*
skb
,
struct
sk_buff
*
skb
,
struct
iovec
*
iv
,
int
len
)
struct
iovec
*
iv
,
int
len
)
...
@@ -260,7 +265,8 @@ static __inline__ ssize_t tun_put_user(struct tun_struct *tun,
...
@@ -260,7 +265,8 @@ static __inline__ ssize_t tun_put_user(struct tun_struct *tun,
pi
.
flags
|=
TUN_PKT_STRIP
;
pi
.
flags
|=
TUN_PKT_STRIP
;
}
}
memcpy_toiovec
(
iv
,
(
void
*
)
&
pi
,
sizeof
(
pi
));
if
(
memcpy_toiovec
(
iv
,
(
void
*
)
&
pi
,
sizeof
(
pi
)))
return
-
EFAULT
;
total
+=
sizeof
(
pi
);
total
+=
sizeof
(
pi
);
}
}
...
@@ -283,18 +289,13 @@ static ssize_t tun_chr_readv(struct file *file, const struct iovec *iv,
...
@@ -283,18 +289,13 @@ static ssize_t tun_chr_readv(struct file *file, const struct iovec *iv,
DECLARE_WAITQUEUE
(
wait
,
current
);
DECLARE_WAITQUEUE
(
wait
,
current
);
struct
sk_buff
*
skb
;
struct
sk_buff
*
skb
;
ssize_t
len
,
ret
=
0
;
ssize_t
len
,
ret
=
0
;
unsigned
long
i
;
if
(
!
tun
)
if
(
!
tun
)
return
-
EBADFD
;
return
-
EBADFD
;
DBG
(
KERN_INFO
"%s: tun_chr_read
\n
"
,
tun
->
dev
->
name
);
DBG
(
KERN_INFO
"%s: tun_chr_read
\n
"
,
tun
->
dev
->
name
);
for
(
i
=
0
,
len
=
0
;
i
<
count
;
i
++
)
{
len
=
iov_total
(
iv
,
count
);
if
(
verify_area
(
VERIFY_WRITE
,
iv
[
i
].
iov_base
,
iv
[
i
].
iov_len
))
return
-
EFAULT
;
len
+=
iv
[
i
].
iov_len
;
}
if
(
len
<
0
)
if
(
len
<
0
)
return
-
EINVAL
;
return
-
EINVAL
;
...
@@ -602,21 +603,22 @@ static struct file_operations tun_fops = {
...
@@ -602,21 +603,22 @@ static struct file_operations tun_fops = {
static
struct
miscdevice
tun_miscdev
=
{
static
struct
miscdevice
tun_miscdev
=
{
.
minor
=
TUN_MINOR
,
.
minor
=
TUN_MINOR
,
.
name
=
"net/tun"
,
.
name
=
"tun"
,
.
fops
=
&
tun_fops
.
fops
=
&
tun_fops
,
.
devfs_name
=
"net/tun"
,
};
};
int
__init
tun_init
(
void
)
int
__init
tun_init
(
void
)
{
{
int
ret
=
0
;
printk
(
KERN_INFO
"Universal TUN/TAP device driver %s "
printk
(
KERN_INFO
"Universal TUN/TAP device driver %s "
"(C)1999-2002 Maxim Krasnyansky
\n
"
,
TUN_VER
);
"(C)1999-2002 Maxim Krasnyansky
\n
"
,
TUN_VER
);
if
(
misc_register
(
&
tun_miscdev
))
{
ret
=
misc_register
(
&
tun_miscdev
);
if
(
ret
)
printk
(
KERN_ERR
"tun: Can't register misc device %d
\n
"
,
TUN_MINOR
);
printk
(
KERN_ERR
"tun: Can't register misc device %d
\n
"
,
TUN_MINOR
);
return
-
EIO
;
return
ret
;
}
return
0
;
}
}
void
tun_cleanup
(
void
)
void
tun_cleanup
(
void
)
...
...
include/linux/netdevice.h
View file @
7b667cd3
...
@@ -29,11 +29,11 @@
...
@@ -29,11 +29,11 @@
#include <linux/if_ether.h>
#include <linux/if_ether.h>
#include <linux/if_packet.h>
#include <linux/if_packet.h>
#ifdef __KERNEL__
#include <asm/atomic.h>
#include <asm/atomic.h>
#include <asm/cache.h>
#include <asm/cache.h>
#include <asm/byteorder.h>
#include <asm/byteorder.h>
#ifdef __KERNEL__
#include <linux/config.h>
#include <linux/config.h>
#include <linux/device.h>
#include <linux/device.h>
#include <linux/percpu.h>
#include <linux/percpu.h>
...
...
include/linux/tcp.h
View file @
7b667cd3
...
@@ -377,7 +377,6 @@ struct tcp_opt {
...
@@ -377,7 +377,6 @@ struct tcp_opt {
/* TCP Westwood structure */
/* TCP Westwood structure */
struct
{
struct
{
__u32
bw_sample
;
/* bandwidth sample */
__u32
bw_ns_est
;
/* first bandwidth estimation..not too smoothed 8) */
__u32
bw_ns_est
;
/* first bandwidth estimation..not too smoothed 8) */
__u32
bw_est
;
/* bandwidth estimate */
__u32
bw_est
;
/* bandwidth estimate */
__u32
rtt_win_sx
;
/* here starts a new evaluation... */
__u32
rtt_win_sx
;
/* here starts a new evaluation... */
...
...
net/8021q/vlanproc.c
View file @
7b667cd3
...
@@ -305,7 +305,7 @@ static int vlandev_seq_show(struct seq_file *seq, void *offset)
...
@@ -305,7 +305,7 @@ static int vlandev_seq_show(struct seq_file *seq, void *offset)
struct
net_device
*
vlandev
=
(
struct
net_device
*
)
seq
->
private
;
struct
net_device
*
vlandev
=
(
struct
net_device
*
)
seq
->
private
;
const
struct
vlan_dev_info
*
dev_info
=
VLAN_DEV_INFO
(
vlandev
);
const
struct
vlan_dev_info
*
dev_info
=
VLAN_DEV_INFO
(
vlandev
);
struct
net_device_stats
*
stats
;
struct
net_device_stats
*
stats
;
static
const
char
*
fmt
=
"%30s %12lu
\n
"
;
static
const
char
fmt
[]
=
"%30s %12lu
\n
"
;
int
i
;
int
i
;
if
((
vlandev
==
NULL
)
||
(
!
(
vlandev
->
priv_flags
&
IFF_802_1Q_VLAN
)))
if
((
vlandev
==
NULL
)
||
(
!
(
vlandev
->
priv_flags
&
IFF_802_1Q_VLAN
)))
...
...
net/bluetooth/af_bluetooth.c
View file @
7b667cd3
...
@@ -323,7 +323,7 @@ int bt_sock_wait_state(struct sock *sk, int state, unsigned long timeo)
...
@@ -323,7 +323,7 @@ int bt_sock_wait_state(struct sock *sk, int state, unsigned long timeo)
return
err
;
return
err
;
}
}
struct
net_proto_family
bt_sock_family_ops
=
{
st
atic
st
ruct
net_proto_family
bt_sock_family_ops
=
{
.
owner
=
THIS_MODULE
,
.
owner
=
THIS_MODULE
,
.
family
=
PF_BLUETOOTH
,
.
family
=
PF_BLUETOOTH
,
.
create
=
bt_sock_create
,
.
create
=
bt_sock_create
,
...
@@ -364,7 +364,7 @@ static int __init bt_init(void)
...
@@ -364,7 +364,7 @@ static int __init bt_init(void)
return
0
;
return
0
;
}
}
static
void
__exit
bt_
cleanup
(
void
)
static
void
__exit
bt_
exit
(
void
)
{
{
hci_sock_cleanup
();
hci_sock_cleanup
();
...
@@ -377,9 +377,10 @@ static void __exit bt_cleanup(void)
...
@@ -377,9 +377,10 @@ static void __exit bt_cleanup(void)
}
}
subsys_initcall
(
bt_init
);
subsys_initcall
(
bt_init
);
module_exit
(
bt_
cleanup
);
module_exit
(
bt_
exit
);
MODULE_AUTHOR
(
"Maxim Krasnyansky <maxk@qualcomm.com>, Marcel Holtmann <marcel@holtmann.org>"
);
MODULE_AUTHOR
(
"Maxim Krasnyansky <maxk@qualcomm.com>, Marcel Holtmann <marcel@holtmann.org>"
);
MODULE_DESCRIPTION
(
"Bluetooth Core ver "
VERSION
);
MODULE_DESCRIPTION
(
"Bluetooth Core ver "
VERSION
);
MODULE_VERSION
(
VERSION
);
MODULE_LICENSE
(
"GPL"
);
MODULE_LICENSE
(
"GPL"
);
MODULE_ALIAS_NETPROTO
(
PF_BLUETOOTH
);
MODULE_ALIAS_NETPROTO
(
PF_BLUETOOTH
);
net/bluetooth/bnep/core.c
View file @
7b667cd3
...
@@ -5,7 +5,7 @@
...
@@ -5,7 +5,7 @@
Clment Moreau <clement.moreau@inventel.fr>
Clment Moreau <clement.moreau@inventel.fr>
David Libault <david.libault@inventel.fr>
David Libault <david.libault@inventel.fr>
Copyright (C) 2002 Maxim Krasnyansk
i
y <maxk@qualcomm.com>
Copyright (C) 2002 Maxim Krasnyansky <maxk@qualcomm.com>
This program is free software; you can redistribute it and/or modify
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License version 2 as
it under the terms of the GNU General Public License version 2 as
...
@@ -672,7 +672,7 @@ int bnep_get_conninfo(struct bnep_conninfo *ci)
...
@@ -672,7 +672,7 @@ int bnep_get_conninfo(struct bnep_conninfo *ci)
return
err
;
return
err
;
}
}
static
int
__init
bnep_init_module
(
void
)
static
int
__init
bnep_init
(
void
)
{
{
char
flt
[
50
]
=
""
;
char
flt
[
50
]
=
""
;
...
@@ -694,15 +694,16 @@ static int __init bnep_init_module(void)
...
@@ -694,15 +694,16 @@ static int __init bnep_init_module(void)
return
0
;
return
0
;
}
}
static
void
__exit
bnep_
cleanup_module
(
void
)
static
void
__exit
bnep_
exit
(
void
)
{
{
bnep_sock_cleanup
();
bnep_sock_cleanup
();
}
}
module_init
(
bnep_init
_module
);
module_init
(
bnep_init
);
module_exit
(
bnep_
cleanup_module
);
module_exit
(
bnep_
exit
);
MODULE_AUTHOR
(
"David Libault <david.libault@inventel.fr>, Maxim Krasnyansky <maxk@qualcomm.com>"
);
MODULE_DESCRIPTION
(
"Bluetooth BNEP ver "
VERSION
);
MODULE_DESCRIPTION
(
"Bluetooth BNEP ver "
VERSION
);
MODULE_
AUTHOR
(
"David Libault <david.libault@inventel.fr>, Maxim Krasnyanskiy <maxk@qualcomm.com>"
);
MODULE_
VERSION
(
VERSION
);
MODULE_LICENSE
(
"GPL"
);
MODULE_LICENSE
(
"GPL"
);
MODULE_ALIAS
(
"bt-proto-4"
);
MODULE_ALIAS
(
"bt-proto-4"
);
net/bluetooth/bnep/netdev.c
View file @
7b667cd3
...
@@ -5,7 +5,7 @@
...
@@ -5,7 +5,7 @@
Clment Moreau <clement.moreau@inventel.fr>
Clment Moreau <clement.moreau@inventel.fr>
David Libault <david.libault@inventel.fr>
David Libault <david.libault@inventel.fr>
Copyright (C) 2002 Maxim Krasnyansk
i
y <maxk@qualcomm.com>
Copyright (C) 2002 Maxim Krasnyansky <maxk@qualcomm.com>
This program is free software; you can redistribute it and/or modify
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License version 2 as
it under the terms of the GNU General Public License version 2 as
...
...
net/bluetooth/bnep/sock.c
View file @
7b667cd3
...
@@ -4,7 +4,7 @@
...
@@ -4,7 +4,7 @@
Written 2001-2002 by
Written 2001-2002 by
David Libault <david.libault@inventel.fr>
David Libault <david.libault@inventel.fr>
Copyright (C) 2002 Maxim Krasnyansk
i
y <maxk@qualcomm.com>
Copyright (C) 2002 Maxim Krasnyansky <maxk@qualcomm.com>
This program is free software; you can redistribute it and/or modify
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License version 2 as
it under the terms of the GNU General Public License version 2 as
...
...
net/bluetooth/cmtp/core.c
View file @
7b667cd3
...
@@ -482,7 +482,7 @@ int cmtp_get_conninfo(struct cmtp_conninfo *ci)
...
@@ -482,7 +482,7 @@ int cmtp_get_conninfo(struct cmtp_conninfo *ci)
}
}
int
__init
init_cmtp
(
void
)
static
int
__init
cmtp_init
(
void
)
{
{
l2cap_load
();
l2cap_load
();
...
@@ -493,15 +493,16 @@ int __init init_cmtp(void)
...
@@ -493,15 +493,16 @@ int __init init_cmtp(void)
return
0
;
return
0
;
}
}
void
__exit
exit_cmtp
(
void
)
static
void
__exit
cmtp_exit
(
void
)
{
{
cmtp_cleanup_sockets
();
cmtp_cleanup_sockets
();
}
}
module_init
(
init_cmtp
);
module_init
(
cmtp_init
);
module_exit
(
exit_cmtp
);
module_exit
(
cmtp_exit
);
MODULE_AUTHOR
(
"Marcel Holtmann <marcel@holtmann.org>"
);
MODULE_AUTHOR
(
"Marcel Holtmann <marcel@holtmann.org>"
);
MODULE_DESCRIPTION
(
"Bluetooth CMTP ver "
VERSION
);
MODULE_DESCRIPTION
(
"Bluetooth CMTP ver "
VERSION
);
MODULE_VERSION
(
VERSION
);
MODULE_LICENSE
(
"GPL"
);
MODULE_LICENSE
(
"GPL"
);
MODULE_ALIAS
(
"bt-proto-5"
);
MODULE_ALIAS
(
"bt-proto-5"
);
net/bluetooth/hci_event.c
View file @
7b667cd3
...
@@ -222,7 +222,7 @@ static void hci_cc_host_ctl(struct hci_dev *hdev, __u16 ocf, struct sk_buff *skb
...
@@ -222,7 +222,7 @@ static void hci_cc_host_ctl(struct hci_dev *hdev, __u16 ocf, struct sk_buff *skb
vs
=
(
struct
hci_rp_read_voice_setting
*
)
skb
->
data
;
vs
=
(
struct
hci_rp_read_voice_setting
*
)
skb
->
data
;
if
(
vs
->
status
)
{
if
(
vs
->
status
)
{
BT_DBG
(
"%s READ_VOICE_SETTING failed %d"
,
hdev
->
name
,
v
c
->
status
);
BT_DBG
(
"%s READ_VOICE_SETTING failed %d"
,
hdev
->
name
,
v
s
->
status
);
break
;
break
;
}
}
...
@@ -359,7 +359,7 @@ static inline void hci_cs_create_conn(struct hci_dev *hdev, __u8 status)
...
@@ -359,7 +359,7 @@ static inline void hci_cs_create_conn(struct hci_dev *hdev, __u8 status)
conn
=
hci_conn_hash_lookup_ba
(
hdev
,
ACL_LINK
,
&
cp
->
bdaddr
);
conn
=
hci_conn_hash_lookup_ba
(
hdev
,
ACL_LINK
,
&
cp
->
bdaddr
);
BT_DBG
(
"%s status 0x%x bdaddr %s conn %p"
,
hdev
->
name
,
BT_DBG
(
"%s status 0x%x bdaddr %s conn %p"
,
hdev
->
name
,
status
,
batostr
(
&
c
c
->
bdaddr
),
conn
);
status
,
batostr
(
&
c
p
->
bdaddr
),
conn
);
if
(
status
)
{
if
(
status
)
{
if
(
conn
)
{
if
(
conn
)
{
...
...
net/bluetooth/l2cap.c
View file @
7b667cd3
...
@@ -535,7 +535,7 @@ static int l2cap_sock_connect(struct socket *sock, struct sockaddr *addr, int al
...
@@ -535,7 +535,7 @@ static int l2cap_sock_connect(struct socket *sock, struct sockaddr *addr, int al
return
err
;
return
err
;
}
}
int
l2cap_sock_listen
(
struct
socket
*
sock
,
int
backlog
)
static
int
l2cap_sock_listen
(
struct
socket
*
sock
,
int
backlog
)
{
{
struct
sock
*
sk
=
sock
->
sk
;
struct
sock
*
sk
=
sock
->
sk
;
int
err
=
0
;
int
err
=
0
;
...
@@ -563,7 +563,7 @@ int l2cap_sock_listen(struct socket *sock, int backlog)
...
@@ -563,7 +563,7 @@ int l2cap_sock_listen(struct socket *sock, int backlog)
return
err
;
return
err
;
}
}
int
l2cap_sock_accept
(
struct
socket
*
sock
,
struct
socket
*
newsock
,
int
flags
)
static
int
l2cap_sock_accept
(
struct
socket
*
sock
,
struct
socket
*
newsock
,
int
flags
)
{
{
DECLARE_WAITQUEUE
(
wait
,
current
);
DECLARE_WAITQUEUE
(
wait
,
current
);
struct
sock
*
sk
=
sock
->
sk
,
*
nsk
;
struct
sock
*
sk
=
sock
->
sk
,
*
nsk
;
...
@@ -1051,7 +1051,7 @@ static void l2cap_chan_ready(struct sock *sk)
...
@@ -1051,7 +1051,7 @@ static void l2cap_chan_ready(struct sock *sk)
}
}
/* Copy frame to all raw sockets on that connection */
/* Copy frame to all raw sockets on that connection */
void
l2cap_raw_recv
(
struct
l2cap_conn
*
conn
,
struct
sk_buff
*
skb
)
static
void
l2cap_raw_recv
(
struct
l2cap_conn
*
conn
,
struct
sk_buff
*
skb
)
{
{
struct
l2cap_chan_list
*
l
=
&
conn
->
chan_list
;
struct
l2cap_chan_list
*
l
=
&
conn
->
chan_list
;
struct
sk_buff
*
nskb
;
struct
sk_buff
*
nskb
;
...
@@ -2153,7 +2153,7 @@ static struct hci_proto l2cap_hci_proto = {
...
@@ -2153,7 +2153,7 @@ static struct hci_proto l2cap_hci_proto = {
.
recv_acldata
=
l2cap_recv_acldata
.
recv_acldata
=
l2cap_recv_acldata
};
};
int
__init
l2cap_init
(
void
)
static
int
__init
l2cap_init
(
void
)
{
{
int
err
;
int
err
;
...
@@ -2175,7 +2175,7 @@ int __init l2cap_init(void)
...
@@ -2175,7 +2175,7 @@ int __init l2cap_init(void)
return
0
;
return
0
;
}
}
void
__exit
l2cap_cleanup
(
void
)
static
void
__exit
l2cap_exit
(
void
)
{
{
l2cap_proc_cleanup
();
l2cap_proc_cleanup
();
...
@@ -2197,9 +2197,10 @@ void l2cap_load(void)
...
@@ -2197,9 +2197,10 @@ void l2cap_load(void)
EXPORT_SYMBOL
(
l2cap_load
);
EXPORT_SYMBOL
(
l2cap_load
);
module_init
(
l2cap_init
);
module_init
(
l2cap_init
);
module_exit
(
l2cap_
cleanup
);
module_exit
(
l2cap_
exit
);
MODULE_AUTHOR
(
"Maxim Krasnyansky <maxk@qualcomm.com>"
);
MODULE_AUTHOR
(
"Maxim Krasnyansky <maxk@qualcomm.com>"
);
MODULE_DESCRIPTION
(
"Bluetooth L2CAP ver "
VERSION
);
MODULE_DESCRIPTION
(
"Bluetooth L2CAP ver "
VERSION
);
MODULE_VERSION
(
VERSION
);
MODULE_LICENSE
(
"GPL"
);
MODULE_LICENSE
(
"GPL"
);
MODULE_ALIAS
(
"bt-proto-0"
);
MODULE_ALIAS
(
"bt-proto-0"
);
net/bluetooth/rfcomm/core.c
View file @
7b667cd3
...
@@ -1948,7 +1948,7 @@ static void __exit rfcomm_proc_cleanup(void)
...
@@ -1948,7 +1948,7 @@ static void __exit rfcomm_proc_cleanup(void)
#endif
/* CONFIG_PROC_FS */
#endif
/* CONFIG_PROC_FS */
/* ---- Initialization ---- */
/* ---- Initialization ---- */
int
__init
rfcomm_init
(
void
)
static
int
__init
rfcomm_init
(
void
)
{
{
l2cap_load
();
l2cap_load
();
...
@@ -1967,7 +1967,7 @@ int __init rfcomm_init(void)
...
@@ -1967,7 +1967,7 @@ int __init rfcomm_init(void)
return
0
;
return
0
;
}
}
void
__exit
rfcomm_cleanup
(
void
)
static
void
__exit
rfcomm_exit
(
void
)
{
{
/* Terminate working thread.
/* Terminate working thread.
* ie. Set terminate flag and wake it up */
* ie. Set terminate flag and wake it up */
...
@@ -1988,9 +1988,10 @@ void __exit rfcomm_cleanup(void)
...
@@ -1988,9 +1988,10 @@ void __exit rfcomm_cleanup(void)
}
}
module_init
(
rfcomm_init
);
module_init
(
rfcomm_init
);
module_exit
(
rfcomm_
cleanup
);
module_exit
(
rfcomm_
exit
);
MODULE_AUTHOR
(
"Maxim Krasnyansky <maxk@qualcomm.com>, Marcel Holtmann <marcel@holtmann.org>"
);
MODULE_AUTHOR
(
"Maxim Krasnyansky <maxk@qualcomm.com>, Marcel Holtmann <marcel@holtmann.org>"
);
MODULE_DESCRIPTION
(
"Bluetooth RFCOMM ver "
VERSION
);
MODULE_DESCRIPTION
(
"Bluetooth RFCOMM ver "
VERSION
);
MODULE_VERSION
(
VERSION
);
MODULE_LICENSE
(
"GPL"
);
MODULE_LICENSE
(
"GPL"
);
MODULE_ALIAS
(
"bt-proto-3"
);
MODULE_ALIAS
(
"bt-proto-3"
);
net/bluetooth/sco.c
View file @
7b667cd3
...
@@ -194,7 +194,7 @@ static inline int sco_chan_add(struct sco_conn *conn, struct sock *sk, struct so
...
@@ -194,7 +194,7 @@ static inline int sco_chan_add(struct sco_conn *conn, struct sock *sk, struct so
return
err
;
return
err
;
}
}
int
sco_connect
(
struct
sock
*
sk
)
static
int
sco_connect
(
struct
sock
*
sk
)
{
{
bdaddr_t
*
src
=
&
bt_sk
(
sk
)
->
src
;
bdaddr_t
*
src
=
&
bt_sk
(
sk
)
->
src
;
bdaddr_t
*
dst
=
&
bt_sk
(
sk
)
->
dst
;
bdaddr_t
*
dst
=
&
bt_sk
(
sk
)
->
dst
;
...
@@ -533,7 +533,7 @@ static int sco_sock_connect(struct socket *sock, struct sockaddr *addr, int alen
...
@@ -533,7 +533,7 @@ static int sco_sock_connect(struct socket *sock, struct sockaddr *addr, int alen
return
err
;
return
err
;
}
}
int
sco_sock_listen
(
struct
socket
*
sock
,
int
backlog
)
static
int
sco_sock_listen
(
struct
socket
*
sock
,
int
backlog
)
{
{
struct
sock
*
sk
=
sock
->
sk
;
struct
sock
*
sk
=
sock
->
sk
;
int
err
=
0
;
int
err
=
0
;
...
@@ -556,7 +556,7 @@ int sco_sock_listen(struct socket *sock, int backlog)
...
@@ -556,7 +556,7 @@ int sco_sock_listen(struct socket *sock, int backlog)
return
err
;
return
err
;
}
}
int
sco_sock_accept
(
struct
socket
*
sock
,
struct
socket
*
newsock
,
int
flags
)
static
int
sco_sock_accept
(
struct
socket
*
sock
,
struct
socket
*
newsock
,
int
flags
)
{
{
DECLARE_WAITQUEUE
(
wait
,
current
);
DECLARE_WAITQUEUE
(
wait
,
current
);
struct
sock
*
sk
=
sock
->
sk
,
*
ch
;
struct
sock
*
sk
=
sock
->
sk
,
*
ch
;
...
@@ -655,7 +655,7 @@ static int sco_sock_sendmsg(struct kiocb *iocb, struct socket *sock,
...
@@ -655,7 +655,7 @@ static int sco_sock_sendmsg(struct kiocb *iocb, struct socket *sock,
return
err
;
return
err
;
}
}
int
sco_sock_setsockopt
(
struct
socket
*
sock
,
int
level
,
int
optname
,
char
*
optval
,
int
optlen
)
static
int
sco_sock_setsockopt
(
struct
socket
*
sock
,
int
level
,
int
optname
,
char
*
optval
,
int
optlen
)
{
{
struct
sock
*
sk
=
sock
->
sk
;
struct
sock
*
sk
=
sock
->
sk
;
int
err
=
0
;
int
err
=
0
;
...
@@ -674,7 +674,7 @@ int sco_sock_setsockopt(struct socket *sock, int level, int optname, char *optva
...
@@ -674,7 +674,7 @@ int sco_sock_setsockopt(struct socket *sock, int level, int optname, char *optva
return
err
;
return
err
;
}
}
int
sco_sock_getsockopt
(
struct
socket
*
sock
,
int
level
,
int
optname
,
char
*
optval
,
int
*
optlen
)
static
int
sco_sock_getsockopt
(
struct
socket
*
sock
,
int
level
,
int
optname
,
char
*
optval
,
int
*
optlen
)
{
{
struct
sock
*
sk
=
sock
->
sk
;
struct
sock
*
sk
=
sock
->
sk
;
struct
sco_options
opts
;
struct
sco_options
opts
;
...
@@ -835,7 +835,7 @@ static void sco_conn_ready(struct sco_conn *conn)
...
@@ -835,7 +835,7 @@ static void sco_conn_ready(struct sco_conn *conn)
}
}
/* ----- SCO interface with lower layer (HCI) ----- */
/* ----- SCO interface with lower layer (HCI) ----- */
int
sco_connect_ind
(
struct
hci_dev
*
hdev
,
bdaddr_t
*
bdaddr
,
__u8
type
)
static
int
sco_connect_ind
(
struct
hci_dev
*
hdev
,
bdaddr_t
*
bdaddr
,
__u8
type
)
{
{
BT_DBG
(
"hdev %s, bdaddr %s"
,
hdev
->
name
,
batostr
(
bdaddr
));
BT_DBG
(
"hdev %s, bdaddr %s"
,
hdev
->
name
,
batostr
(
bdaddr
));
...
@@ -843,7 +843,7 @@ int sco_connect_ind(struct hci_dev *hdev, bdaddr_t *bdaddr, __u8 type)
...
@@ -843,7 +843,7 @@ int sco_connect_ind(struct hci_dev *hdev, bdaddr_t *bdaddr, __u8 type)
return
HCI_LM_ACCEPT
;
return
HCI_LM_ACCEPT
;
}
}
int
sco_connect_cfm
(
struct
hci_conn
*
hcon
,
__u8
status
)
static
int
sco_connect_cfm
(
struct
hci_conn
*
hcon
,
__u8
status
)
{
{
BT_DBG
(
"hcon %p bdaddr %s status %d"
,
hcon
,
batostr
(
&
hcon
->
dst
),
status
);
BT_DBG
(
"hcon %p bdaddr %s status %d"
,
hcon
,
batostr
(
&
hcon
->
dst
),
status
);
...
@@ -862,7 +862,7 @@ int sco_connect_cfm(struct hci_conn *hcon, __u8 status)
...
@@ -862,7 +862,7 @@ int sco_connect_cfm(struct hci_conn *hcon, __u8 status)
return
0
;
return
0
;
}
}
int
sco_disconn_ind
(
struct
hci_conn
*
hcon
,
__u8
reason
)
static
int
sco_disconn_ind
(
struct
hci_conn
*
hcon
,
__u8
reason
)
{
{
BT_DBG
(
"hcon %p reason %d"
,
hcon
,
reason
);
BT_DBG
(
"hcon %p reason %d"
,
hcon
,
reason
);
...
@@ -873,7 +873,7 @@ int sco_disconn_ind(struct hci_conn *hcon, __u8 reason)
...
@@ -873,7 +873,7 @@ int sco_disconn_ind(struct hci_conn *hcon, __u8 reason)
return
0
;
return
0
;
}
}
int
sco_recv_scodata
(
struct
hci_conn
*
hcon
,
struct
sk_buff
*
skb
)
static
int
sco_recv_scodata
(
struct
hci_conn
*
hcon
,
struct
sk_buff
*
skb
)
{
{
struct
sco_conn
*
conn
=
hcon
->
sco_data
;
struct
sco_conn
*
conn
=
hcon
->
sco_data
;
...
@@ -1013,7 +1013,7 @@ static struct hci_proto sco_hci_proto = {
...
@@ -1013,7 +1013,7 @@ static struct hci_proto sco_hci_proto = {
.
recv_scodata
=
sco_recv_scodata
.
recv_scodata
=
sco_recv_scodata
};
};
int
__init
sco_init
(
void
)
static
int
__init
sco_init
(
void
)
{
{
int
err
;
int
err
;
...
@@ -1035,7 +1035,7 @@ int __init sco_init(void)
...
@@ -1035,7 +1035,7 @@ int __init sco_init(void)
return
0
;
return
0
;
}
}
void
__exit
sco_cleanup
(
void
)
static
void
__exit
sco_exit
(
void
)
{
{
int
err
;
int
err
;
...
@@ -1050,9 +1050,10 @@ void __exit sco_cleanup(void)
...
@@ -1050,9 +1050,10 @@ void __exit sco_cleanup(void)
}
}
module_init
(
sco_init
);
module_init
(
sco_init
);
module_exit
(
sco_
cleanup
);
module_exit
(
sco_
exit
);
MODULE_AUTHOR
(
"Maxim Krasnyansky <maxk@qualcomm.com>"
);
MODULE_AUTHOR
(
"Maxim Krasnyansky <maxk@qualcomm.com>"
);
MODULE_DESCRIPTION
(
"Bluetooth SCO ver "
VERSION
);
MODULE_DESCRIPTION
(
"Bluetooth SCO ver "
VERSION
);
MODULE_VERSION
(
VERSION
);
MODULE_LICENSE
(
"GPL"
);
MODULE_LICENSE
(
"GPL"
);
MODULE_ALIAS
(
"bt-proto-2"
);
MODULE_ALIAS
(
"bt-proto-2"
);
net/ipv4/tcp_input.c
View file @
7b667cd3
...
@@ -2051,21 +2051,25 @@ static void tcp_process_frto(struct sock *sk, u32 prior_snd_una)
...
@@ -2051,21 +2051,25 @@ static void tcp_process_frto(struct sock *sk, u32 prior_snd_una)
*/
*/
tp
->
frto_counter
=
(
tp
->
frto_counter
+
1
)
%
3
;
tp
->
frto_counter
=
(
tp
->
frto_counter
+
1
)
%
3
;
}
}
/*
/*
* TCP Westwood
* TCP Westwood+
* Functions needed for estimating bandwidth.
*/
*/
/*
/*
* This function initializes fields used in TCP Westwood.
* @init_westwood
* We can't get no information about RTT at this time so
* This function initializes fields used in TCP Westwood+. We can't
* we are forced to set it to 0.
* get no information about RTTmin at this time so we simply set it to
* TCP_WESTWOOD_INIT_RTT. This value was chosen to be too conservative
* since in this way we're sure it will be updated in a consistent
* way as soon as possible. It will reasonably happen within the first
* RTT period of the connection lifetime.
*/
*/
static
void
init_westwood
(
struct
sock
*
sk
)
static
void
init_westwood
(
struct
sock
*
sk
)
{
{
struct
tcp_opt
*
tp
=
tcp_sk
(
sk
);
struct
tcp_opt
*
tp
=
tcp_sk
(
sk
);
tp
->
westwood
.
bw_sample
=
0
;
tp
->
westwood
.
bw_ns_est
=
0
;
tp
->
westwood
.
bw_ns_est
=
0
;
tp
->
westwood
.
bw_est
=
0
;
tp
->
westwood
.
bw_est
=
0
;
tp
->
westwood
.
accounted
=
0
;
tp
->
westwood
.
accounted
=
0
;
...
@@ -2080,6 +2084,7 @@ static void init_westwood(struct sock *sk)
...
@@ -2080,6 +2084,7 @@ static void init_westwood(struct sock *sk)
* @westwood_do_filter
* @westwood_do_filter
* Low-pass filter. Implemented using constant coeffients.
* Low-pass filter. Implemented using constant coeffients.
*/
*/
static
inline
__u32
westwood_do_filter
(
__u32
a
,
__u32
b
)
static
inline
__u32
westwood_do_filter
(
__u32
a
,
__u32
b
)
{
{
return
(((
7
*
a
)
+
b
)
>>
3
);
return
(((
7
*
a
)
+
b
)
>>
3
);
...
@@ -2088,20 +2093,21 @@ static inline __u32 westwood_do_filter(__u32 a, __u32 b)
...
@@ -2088,20 +2093,21 @@ static inline __u32 westwood_do_filter(__u32 a, __u32 b)
static
void
westwood_filter
(
struct
sock
*
sk
,
__u32
delta
)
static
void
westwood_filter
(
struct
sock
*
sk
,
__u32
delta
)
{
{
struct
tcp_opt
*
tp
=
tcp_sk
(
sk
);
struct
tcp_opt
*
tp
=
tcp_sk
(
sk
);
__u32
sample
=
tp
->
westwood
.
bk
/
delta
;
tp
->
westwood
.
bw_ns_est
=
tp
->
westwood
.
bw_ns_est
=
westwood_do_filter
(
tp
->
westwood
.
bw_ns_est
,
sample
);
westwood_do_filter
(
tp
->
westwood
.
bw_ns_est
,
tp
->
westwood
.
bk
/
delta
);
tp
->
westwood
.
bw_est
=
tp
->
westwood
.
bw_est
=
westwood_do_filter
(
tp
->
westwood
.
bw_est
,
westwood_do_filter
(
tp
->
westwood
.
bw_est
,
tp
->
westwood
.
bw_ns_est
);
tp
->
westwood
.
bw_ns_est
);
tp
->
westwood
.
bw_sample
=
sample
;
}
}
/* @westwood_update_rttmin
/*
* @westwood_update_rttmin
* It is used to update RTTmin. In this case we MUST NOT use
* It is used to update RTTmin. In this case we MUST NOT use
* WESTWOOD_RTT_MIN minimum bound since we could be on a LAN!
* WESTWOOD_RTT_MIN minimum bound since we could be on a LAN!
*/
*/
static
inline
__u32
westwood_update_rttmin
(
struct
sock
*
sk
)
static
inline
__u32
westwood_update_rttmin
(
struct
sock
*
sk
)
{
{
struct
tcp_opt
*
tp
=
tcp_sk
(
sk
);
struct
tcp_opt
*
tp
=
tcp_sk
(
sk
);
...
@@ -2118,9 +2124,9 @@ static inline __u32 westwood_update_rttmin(struct sock *sk)
...
@@ -2118,9 +2124,9 @@ static inline __u32 westwood_update_rttmin(struct sock *sk)
/*
/*
* @westwood_acked
* @westwood_acked
* Evaluate increases for dk. It requires no lock since when it is
* Evaluate increases for dk.
* called lock should already be held. Be careful about it!
*/
*/
static
inline
__u32
westwood_acked
(
struct
sock
*
sk
)
static
inline
__u32
westwood_acked
(
struct
sock
*
sk
)
{
{
struct
tcp_opt
*
tp
=
tcp_sk
(
sk
);
struct
tcp_opt
*
tp
=
tcp_sk
(
sk
);
...
@@ -2136,6 +2142,7 @@ static inline __u32 westwood_acked(struct sock *sk)
...
@@ -2136,6 +2142,7 @@ static inline __u32 westwood_acked(struct sock *sk)
* It returns 0 if we are still evaluating samples in the same RTT
* It returns 0 if we are still evaluating samples in the same RTT
* window, 1 if the sample has to be considered in the next window.
* window, 1 if the sample has to be considered in the next window.
*/
*/
static
int
westwood_new_window
(
struct
sock
*
sk
)
static
int
westwood_new_window
(
struct
sock
*
sk
)
{
{
struct
tcp_opt
*
tp
=
tcp_sk
(
sk
);
struct
tcp_opt
*
tp
=
tcp_sk
(
sk
);
...
@@ -2164,11 +2171,9 @@ static int westwood_new_window(struct sock *sk)
...
@@ -2164,11 +2171,9 @@ static int westwood_new_window(struct sock *sk)
/*
/*
* @westwood_update_window
* @westwood_update_window
* It updates RTT evaluation window if it is the right moment to do
* It updates RTT evaluation window if it is the right moment to do
* it. If so it calls filter for evaluating bandwidth. Be careful
* it. If so it calls filter for evaluating bandwidth.
* about __westwood_update_window() since it is called without
* any form of lock. It should be used only for internal purposes.
* Call westwood_update_window() instead.
*/
*/
static
void
__westwood_update_window
(
struct
sock
*
sk
,
__u32
now
)
static
void
__westwood_update_window
(
struct
sock
*
sk
,
__u32
now
)
{
{
struct
tcp_opt
*
tp
=
tcp_sk
(
sk
);
struct
tcp_opt
*
tp
=
tcp_sk
(
sk
);
...
@@ -2192,11 +2197,12 @@ static void westwood_update_window(struct sock *sk, __u32 now)
...
@@ -2192,11 +2197,12 @@ static void westwood_update_window(struct sock *sk, __u32 now)
}
}
/*
/*
* @__westwood_fast_bw
* @__
tcp_
westwood_fast_bw
* It is called when we are in fast path. In particular it is called when
* It is called when we are in fast path. In particular it is called when
* header prediction is successfull. In such case infact update is
* header prediction is successfull. In such case infact update is
* straight forward and doesn't need any particular care.
* straight forward and doesn't need any particular care.
*/
*/
void
__tcp_westwood_fast_bw
(
struct
sock
*
sk
,
struct
sk_buff
*
skb
)
void
__tcp_westwood_fast_bw
(
struct
sock
*
sk
,
struct
sk_buff
*
skb
)
{
{
struct
tcp_opt
*
tp
=
tcp_sk
(
sk
);
struct
tcp_opt
*
tp
=
tcp_sk
(
sk
);
...
@@ -2210,7 +2216,7 @@ void __tcp_westwood_fast_bw(struct sock *sk, struct sk_buff *skb)
...
@@ -2210,7 +2216,7 @@ void __tcp_westwood_fast_bw(struct sock *sk, struct sk_buff *skb)
/*
/*
* @
tcp_
westwood_dupack_update
* @westwood_dupack_update
* It updates accounted and cumul_ack when receiving a dupack.
* It updates accounted and cumul_ack when receiving a dupack.
*/
*/
...
@@ -2244,6 +2250,7 @@ static inline void westwood_complete_update(struct tcp_opt *tp)
...
@@ -2244,6 +2250,7 @@ static inline void westwood_complete_update(struct tcp_opt *tp)
* This function evaluates cumul_ack for evaluating dk in case of
* This function evaluates cumul_ack for evaluating dk in case of
* delayed or partial acks.
* delayed or partial acks.
*/
*/
static
__u32
westwood_acked_count
(
struct
sock
*
sk
)
static
__u32
westwood_acked_count
(
struct
sock
*
sk
)
{
{
struct
tcp_opt
*
tp
=
tcp_sk
(
sk
);
struct
tcp_opt
*
tp
=
tcp_sk
(
sk
);
...
@@ -2271,11 +2278,12 @@ static __u32 westwood_acked_count(struct sock *sk)
...
@@ -2271,11 +2278,12 @@ static __u32 westwood_acked_count(struct sock *sk)
/*
/*
* @__westwood_slow_bw
* @__
tcp_
westwood_slow_bw
* It is called when something is going wrong..even if there could
* It is called when something is going wrong..even if there could
* be no problems! Infact a simple delayed packet may trigger a
* be no problems! Infact a simple delayed packet may trigger a
* dupack. But we need to be careful in such case.
* dupack. But we need to be careful in such case.
*/
*/
void
__tcp_westwood_slow_bw
(
struct
sock
*
sk
,
struct
sk_buff
*
skb
)
void
__tcp_westwood_slow_bw
(
struct
sock
*
sk
,
struct
sk_buff
*
skb
)
{
{
struct
tcp_opt
*
tp
=
tcp_sk
(
sk
);
struct
tcp_opt
*
tp
=
tcp_sk
(
sk
);
...
...
net/sched/sch_htb.c
View file @
7b667cd3
...
@@ -437,13 +437,13 @@ static void htb_add_to_wait_tree (struct htb_sched *q,
...
@@ -437,13 +437,13 @@ static void htb_add_to_wait_tree (struct htb_sched *q,
cl
->
pq_key
++
;
cl
->
pq_key
++
;
/* update the nearest event cache */
/* update the nearest event cache */
if
(
q
->
near_ev_cache
[
cl
->
level
]
-
cl
->
pq_key
<
0x80000000
)
if
(
time_after
(
q
->
near_ev_cache
[
cl
->
level
],
cl
->
pq_key
)
)
q
->
near_ev_cache
[
cl
->
level
]
=
cl
->
pq_key
;
q
->
near_ev_cache
[
cl
->
level
]
=
cl
->
pq_key
;
while
(
*
p
)
{
while
(
*
p
)
{
struct
htb_class
*
c
;
parent
=
*
p
;
struct
htb_class
*
c
;
parent
=
*
p
;
c
=
rb_entry
(
parent
,
struct
htb_class
,
pq_node
);
c
=
rb_entry
(
parent
,
struct
htb_class
,
pq_node
);
if
(
cl
->
pq_key
-
c
->
pq_key
<
0x80000000
)
if
(
time_after_eq
(
cl
->
pq_key
,
c
->
pq_key
)
)
p
=
&
parent
->
rb_right
;
p
=
&
parent
->
rb_right
;
else
else
p
=
&
parent
->
rb_left
;
p
=
&
parent
->
rb_left
;
...
@@ -869,7 +869,7 @@ static long htb_do_events(struct htb_sched *q,int level)
...
@@ -869,7 +869,7 @@ static long htb_do_events(struct htb_sched *q,int level)
while
(
p
->
rb_left
)
p
=
p
->
rb_left
;
while
(
p
->
rb_left
)
p
=
p
->
rb_left
;
cl
=
rb_entry
(
p
,
struct
htb_class
,
pq_node
);
cl
=
rb_entry
(
p
,
struct
htb_class
,
pq_node
);
if
(
cl
->
pq_key
-
(
q
->
jiffies
+
1
)
<
0x80000000
)
{
if
(
time_after
(
cl
->
pq_key
,
q
->
jiffies
)
)
{
HTB_DBG
(
8
,
3
,
"htb_do_ev_ret delay=%ld
\n
"
,
cl
->
pq_key
-
q
->
jiffies
);
HTB_DBG
(
8
,
3
,
"htb_do_ev_ret delay=%ld
\n
"
,
cl
->
pq_key
-
q
->
jiffies
);
return
cl
->
pq_key
-
q
->
jiffies
;
return
cl
->
pq_key
-
q
->
jiffies
;
}
}
...
@@ -1048,7 +1048,7 @@ static struct sk_buff *htb_dequeue(struct Qdisc *sch)
...
@@ -1048,7 +1048,7 @@ static struct sk_buff *htb_dequeue(struct Qdisc *sch)
/* common case optimization - skip event handler quickly */
/* common case optimization - skip event handler quickly */
int
m
;
int
m
;
long
delay
;
long
delay
;
if
(
q
->
jiffies
-
q
->
near_ev_cache
[
level
]
<
0x80000000
||
0
)
{
if
(
time_after_eq
(
q
->
jiffies
,
q
->
near_ev_cache
[
level
])
)
{
delay
=
htb_do_events
(
q
,
level
);
delay
=
htb_do_events
(
q
,
level
);
q
->
near_ev_cache
[
level
]
=
q
->
jiffies
+
(
delay
?
delay
:
HZ
);
q
->
near_ev_cache
[
level
]
=
q
->
jiffies
+
(
delay
?
delay
:
HZ
);
#ifdef HTB_DEBUG
#ifdef HTB_DEBUG
...
...
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