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
1893f0e5
Commit
1893f0e5
authored
Mar 15, 2004
by
Linus Torvalds
Browse files
Options
Browse Files
Download
Plain Diff
Merge
bk://kernel.bkbits.net/davem/net-2.6
into ppc970.osdl.org:/home/torvalds/v2.5/linux
parents
0f994f5d
7b667cd3
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 @
1893f0e5
...
@@ -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 @
1893f0e5
...
@@ -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 @
1893f0e5
...
@@ -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 @
1893f0e5
...
@@ -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 @
1893f0e5
...
@@ -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 @
1893f0e5
...
@@ -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 @
1893f0e5
...
@@ -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 @
1893f0e5
...
@@ -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 @
1893f0e5
...
@@ -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 @
1893f0e5
...
@@ -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 @
1893f0e5
...
@@ -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 @
1893f0e5
...
@@ -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 @
1893f0e5
...
@@ -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 @
1893f0e5
...
@@ -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 @
1893f0e5
...
@@ -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 @
1893f0e5
...
@@ -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 @
1893f0e5
...
@@ -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 @
1893f0e5
...
@@ -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 @
1893f0e5
...
@@ -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 @
1893f0e5
...
@@ -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 @
1893f0e5
...
@@ -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