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
821bc517
Commit
821bc517
authored
Dec 09, 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.6/linux
parents
08d65cfe
f6c27cdd
Changes
16
Hide whitespace changes
Inline
Side-by-side
Showing
16 changed files
with
149 additions
and
64 deletions
+149
-64
drivers/bluetooth/hci_usb.c
drivers/bluetooth/hci_usb.c
+3
-3
drivers/net/irda/irda-usb.c
drivers/net/irda/irda-usb.c
+10
-10
drivers/net/irda/stir4200.c
drivers/net/irda/stir4200.c
+2
-2
drivers/net/irda/via-ircc.c
drivers/net/irda/via-ircc.c
+20
-3
include/net/bluetooth/hci_core.h
include/net/bluetooth/hci_core.h
+13
-2
include/net/ip_vs.h
include/net/ip_vs.h
+2
-0
net/bluetooth/hci_conn.c
net/bluetooth/hci_conn.c
+4
-3
net/bluetooth/hci_core.c
net/bluetooth/hci_core.c
+15
-7
net/bluetooth/hci_event.c
net/bluetooth/hci_event.c
+22
-10
net/bluetooth/hci_sysfs.c
net/bluetooth/hci_sysfs.c
+6
-6
net/ipv4/ipvs/ip_vs_conn.c
net/ipv4/ipvs/ip_vs_conn.c
+3
-1
net/ipv4/ipvs/ip_vs_ctl.c
net/ipv4/ipvs/ip_vs_ctl.c
+20
-11
net/ipv4/tcp_input.c
net/ipv4/tcp_input.c
+1
-1
net/ipv6/af_inet6.c
net/ipv6/af_inet6.c
+23
-1
net/sched/ipt.c
net/sched/ipt.c
+1
-2
net/sched/sch_netem.c
net/sched/sch_netem.c
+4
-2
No files found.
drivers/bluetooth/hci_usb.c
View file @
821bc517
...
@@ -67,7 +67,7 @@
...
@@ -67,7 +67,7 @@
#endif
#endif
#ifdef CONFIG_BT_HCIUSB_SCO
#ifdef CONFIG_BT_HCIUSB_SCO
static
int
isoc
=
1
;
static
int
isoc
=
2
;
#endif
#endif
#define VERSION "2.7"
#define VERSION "2.7"
...
@@ -898,7 +898,7 @@ static int hci_usb_probe(struct usb_interface *intf, const struct usb_device_id
...
@@ -898,7 +898,7 @@ static int hci_usb_probe(struct usb_interface *intf, const struct usb_device_id
switch
(
ep
->
desc
.
bmAttributes
&
USB_ENDPOINT_XFERTYPE_MASK
)
{
switch
(
ep
->
desc
.
bmAttributes
&
USB_ENDPOINT_XFERTYPE_MASK
)
{
case
USB_ENDPOINT_XFER_ISOC
:
case
USB_ENDPOINT_XFER_ISOC
:
if
(
ep
->
desc
.
wMaxPacketSize
<
size
||
if
(
ep
->
desc
.
wMaxPacketSize
<
size
||
uif
->
desc
.
bAlternateSetting
>
2
)
uif
->
desc
.
bAlternateSetting
!=
isoc
)
break
;
break
;
size
=
ep
->
desc
.
wMaxPacketSize
;
size
=
ep
->
desc
.
wMaxPacketSize
;
...
@@ -1037,7 +1037,7 @@ module_init(hci_usb_init);
...
@@ -1037,7 +1037,7 @@ module_init(hci_usb_init);
module_exit
(
hci_usb_exit
);
module_exit
(
hci_usb_exit
);
#ifdef CONFIG_BT_HCIUSB_SCO
#ifdef CONFIG_BT_HCIUSB_SCO
module_param
(
isoc
,
bool
,
0
);
module_param
(
isoc
,
int
,
0644
);
MODULE_PARM_DESC
(
isoc
,
"Set isochronous transfers for SCO over HCI support"
);
MODULE_PARM_DESC
(
isoc
,
"Set isochronous transfers for SCO over HCI support"
);
#endif
#endif
...
...
drivers/net/irda/irda-usb.c
View file @
821bc517
...
@@ -52,7 +52,7 @@
...
@@ -52,7 +52,7 @@
/*------------------------------------------------------------------*/
/*------------------------------------------------------------------*/
#include <linux/module.h>
#include <linux/module.h>
#include <linux/moduleparam.h>
#include <linux/kernel.h>
#include <linux/kernel.h>
#include <linux/types.h>
#include <linux/types.h>
#include <linux/init.h>
#include <linux/init.h>
...
@@ -88,10 +88,10 @@ static struct usb_device_id dongles[] = {
...
@@ -88,10 +88,10 @@ static struct usb_device_id dongles[] = {
/*
/*
* Important note :
* Important note :
* Devices based on the SigmaTel chipset (0x66f, 0x4200) are not
compliant
* Devices based on the SigmaTel chipset (0x66f, 0x4200) are not
designed
*
with the USB-IrDA specification (and actually very very different
), and
*
using the "USB-IrDA specification" (yes, there exist such a thing
), and
* there
is no way this driver can support those devices, apart from
* there
fore not supported by this driver (don't add them above).
*
a complete rewrite..
.
*
There is a Linux driver, stir4200, that support those USB devices
.
* Jean II
* Jean II
*/
*/
...
@@ -1007,9 +1007,9 @@ static int irda_usb_net_close(struct net_device *netdev)
...
@@ -1007,9 +1007,9 @@ static int irda_usb_net_close(struct net_device *netdev)
}
}
/* Cancel Tx and speed URB - need to be synchronous to avoid races */
/* Cancel Tx and speed URB - need to be synchronous to avoid races */
self
->
tx_urb
->
transfer_flags
&=
~
URB_ASYNC_UNLINK
;
self
->
tx_urb
->
transfer_flags
&=
~
URB_ASYNC_UNLINK
;
usb_
unlink
_urb
(
self
->
tx_urb
);
usb_
kill
_urb
(
self
->
tx_urb
);
self
->
speed_urb
->
transfer_flags
&=
~
URB_ASYNC_UNLINK
;
self
->
speed_urb
->
transfer_flags
&=
~
URB_ASYNC_UNLINK
;
usb_
unlink
_urb
(
self
->
speed_urb
);
usb_
kill
_urb
(
self
->
speed_urb
);
/* Stop and remove instance of IrLAP */
/* Stop and remove instance of IrLAP */
if
(
self
->
irlap
)
if
(
self
->
irlap
)
...
@@ -1520,9 +1520,9 @@ static void irda_usb_disconnect(struct usb_interface *intf)
...
@@ -1520,9 +1520,9 @@ static void irda_usb_disconnect(struct usb_interface *intf)
/* Cancel Tx and speed URB.
/* Cancel Tx and speed URB.
* Toggle flags to make sure it's synchronous. */
* Toggle flags to make sure it's synchronous. */
self
->
tx_urb
->
transfer_flags
&=
~
URB_ASYNC_UNLINK
;
self
->
tx_urb
->
transfer_flags
&=
~
URB_ASYNC_UNLINK
;
usb_
unlink
_urb
(
self
->
tx_urb
);
usb_
kill
_urb
(
self
->
tx_urb
);
self
->
speed_urb
->
transfer_flags
&=
~
URB_ASYNC_UNLINK
;
self
->
speed_urb
->
transfer_flags
&=
~
URB_ASYNC_UNLINK
;
usb_
unlink
_urb
(
self
->
speed_urb
);
usb_
kill
_urb
(
self
->
speed_urb
);
}
}
/* Cleanup the device stuff */
/* Cleanup the device stuff */
...
@@ -1593,7 +1593,7 @@ module_exit(usb_irda_cleanup);
...
@@ -1593,7 +1593,7 @@ module_exit(usb_irda_cleanup);
/*
/*
* Module parameters
* Module parameters
*/
*/
MODULE_PARM
(
qos_mtt_bits
,
"i"
);
module_param
(
qos_mtt_bits
,
int
,
0
);
MODULE_PARM_DESC
(
qos_mtt_bits
,
"Minimum Turn Time"
);
MODULE_PARM_DESC
(
qos_mtt_bits
,
"Minimum Turn Time"
);
MODULE_AUTHOR
(
"Roman Weissgaerber <weissg@vienna.at>, Dag Brattli <dag@brattli.net> and Jean Tourrilhes <jt@hpl.hp.com>"
);
MODULE_AUTHOR
(
"Roman Weissgaerber <weissg@vienna.at>, Dag Brattli <dag@brattli.net> and Jean Tourrilhes <jt@hpl.hp.com>"
);
MODULE_DESCRIPTION
(
"IrDA-USB Dongle Driver"
);
MODULE_DESCRIPTION
(
"IrDA-USB Dongle Driver"
);
...
...
drivers/net/irda/stir4200.c
View file @
821bc517
...
@@ -705,7 +705,7 @@ static int receive_start(struct stir_cb *stir)
...
@@ -705,7 +705,7 @@ static int receive_start(struct stir_cb *stir)
static
void
receive_stop
(
struct
stir_cb
*
stir
)
static
void
receive_stop
(
struct
stir_cb
*
stir
)
{
{
stir
->
receiving
=
0
;
stir
->
receiving
=
0
;
usb_
unlink
_urb
(
stir
->
rx_urb
);
usb_
kill
_urb
(
stir
->
rx_urb
);
if
(
stir
->
rx_buff
.
in_frame
)
if
(
stir
->
rx_buff
.
in_frame
)
stir
->
stats
.
collisions
++
;
stir
->
stats
.
collisions
++
;
...
@@ -974,7 +974,7 @@ static int stir_net_close(struct net_device *netdev)
...
@@ -974,7 +974,7 @@ static int stir_net_close(struct net_device *netdev)
kfree
(
stir
->
fifo_status
);
kfree
(
stir
->
fifo_status
);
/* Mop up receive urb's */
/* Mop up receive urb's */
usb_
unlink
_urb
(
stir
->
rx_urb
);
usb_
kill
_urb
(
stir
->
rx_urb
);
kfree
(
stir
->
io_buf
);
kfree
(
stir
->
io_buf
);
usb_free_urb
(
stir
->
rx_urb
);
usb_free_urb
(
stir
->
rx_urb
);
...
...
drivers/net/irda/via-ircc.c
View file @
821bc517
...
@@ -75,6 +75,9 @@ static int dongle_id = 0; /* default: probe */
...
@@ -75,6 +75,9 @@ static int dongle_id = 0; /* default: probe */
/* We can't guess the type of connected dongle, user *must* supply it. */
/* We can't guess the type of connected dongle, user *must* supply it. */
MODULE_PARM
(
dongle_id
,
"i"
);
MODULE_PARM
(
dongle_id
,
"i"
);
/* FIXME : we should not need this, because instances should be automatically
* managed by the PCI layer. Especially that we seem to only be using the
* first entry. Jean II */
/* Max 4 instances for now */
/* Max 4 instances for now */
static
struct
via_ircc_cb
*
dev_self
[]
=
{
NULL
,
NULL
,
NULL
,
NULL
};
static
struct
via_ircc_cb
*
dev_self
[]
=
{
NULL
,
NULL
,
NULL
,
NULL
};
...
@@ -153,11 +156,9 @@ static int __init via_ircc_init(void)
...
@@ -153,11 +156,9 @@ static int __init via_ircc_init(void)
IRDA_DEBUG
(
3
,
"%s()
\n
"
,
__FUNCTION__
);
IRDA_DEBUG
(
3
,
"%s()
\n
"
,
__FUNCTION__
);
rc
=
pci_register_driver
(
&
via_driver
);
rc
=
pci_register_driver
(
&
via_driver
);
if
(
rc
<
1
)
{
if
(
rc
<
0
)
{
IRDA_DEBUG
(
0
,
"%s(): error rc = %d, returning -ENODEV...
\n
"
,
IRDA_DEBUG
(
0
,
"%s(): error rc = %d, returning -ENODEV...
\n
"
,
__FUNCTION__
,
rc
);
__FUNCTION__
,
rc
);
if
(
rc
==
0
)
pci_unregister_driver
(
&
via_driver
);
return
-
ENODEV
;
return
-
ENODEV
;
}
}
return
0
;
return
0
;
...
@@ -288,15 +289,27 @@ static void __exit via_remove_one (struct pci_dev *pdev)
...
@@ -288,15 +289,27 @@ static void __exit via_remove_one (struct pci_dev *pdev)
{
{
IRDA_DEBUG
(
3
,
"%s()
\n
"
,
__FUNCTION__
);
IRDA_DEBUG
(
3
,
"%s()
\n
"
,
__FUNCTION__
);
/* FIXME : This is ugly. We should use pci_get_drvdata(pdev);
* to get our driver instance and call directly via_ircc_close().
* See vlsi_ir for details...
* Jean II */
via_ircc_clean
();
via_ircc_clean
();
/* FIXME : This should be in via_ircc_close(), because here we may
* theoritically disable still configured devices :-( - Jean II */
pci_disable_device
(
pdev
);
}
}
static
void
__exit
via_ircc_cleanup
(
void
)
static
void
__exit
via_ircc_cleanup
(
void
)
{
{
IRDA_DEBUG
(
3
,
"%s()
\n
"
,
__FUNCTION__
);
IRDA_DEBUG
(
3
,
"%s()
\n
"
,
__FUNCTION__
);
/* FIXME : This should be redundant, as pci_unregister_driver()
* should call via_remove_one() on each device.
* Jean II */
via_ircc_clean
();
via_ircc_clean
();
/* Cleanup all instances of the driver */
pci_unregister_driver
(
&
via_driver
);
pci_unregister_driver
(
&
via_driver
);
}
}
...
@@ -323,6 +336,10 @@ static __devinit int via_ircc_open(int i, chipio_t * info, unsigned int id)
...
@@ -323,6 +336,10 @@ static __devinit int via_ircc_open(int i, chipio_t * info, unsigned int id)
self
->
netdev
=
dev
;
self
->
netdev
=
dev
;
spin_lock_init
(
&
self
->
lock
);
spin_lock_init
(
&
self
->
lock
);
/* FIXME : We should store our driver instance in the PCI layer,
* using pci_set_drvdata(), not in this array.
* See vlsi_ir for details... - Jean II */
/* FIXME : 'i' is always 0 (see via_init_one()) :-( - Jean II */
/* Need to store self somewhere */
/* Need to store self somewhere */
dev_self
[
i
]
=
self
;
dev_self
[
i
]
=
self
;
self
->
index
=
i
;
self
->
index
=
i
;
...
...
include/net/bluetooth/hci_core.h
View file @
821bc517
...
@@ -38,10 +38,20 @@ extern struct proc_dir_entry *proc_bt_hci;
...
@@ -38,10 +38,20 @@ extern struct proc_dir_entry *proc_bt_hci;
/* HCI Core structures */
/* HCI Core structures */
struct
inquiry_data
{
bdaddr_t
bdaddr
;
__u8
pscan_rep_mode
;
__u8
pscan_period_mode
;
__u8
pscan_mode
;
__u8
dev_class
[
3
];
__u16
clock_offset
;
__s8
rssi
;
};
struct
inquiry_entry
{
struct
inquiry_entry
{
struct
inquiry_entry
*
next
;
struct
inquiry_entry
*
next
;
__u32
timestamp
;
__u32
timestamp
;
struct
inquiry_
info
info
;
struct
inquiry_
data
data
;
};
};
struct
inquiry_cache
{
struct
inquiry_cache
{
...
@@ -142,6 +152,7 @@ struct hci_conn {
...
@@ -142,6 +152,7 @@ struct hci_conn {
__u16
state
;
__u16
state
;
__u8
type
;
__u8
type
;
__u8
out
;
__u8
out
;
__u8
dev_class
[
3
];
__u32
link_mode
;
__u32
link_mode
;
unsigned
long
pend
;
unsigned
long
pend
;
...
@@ -199,7 +210,7 @@ static inline long inquiry_entry_age(struct inquiry_entry *e)
...
@@ -199,7 +210,7 @@ static inline long inquiry_entry_age(struct inquiry_entry *e)
}
}
struct
inquiry_entry
*
hci_inquiry_cache_lookup
(
struct
hci_dev
*
hdev
,
bdaddr_t
*
bdaddr
);
struct
inquiry_entry
*
hci_inquiry_cache_lookup
(
struct
hci_dev
*
hdev
,
bdaddr_t
*
bdaddr
);
void
hci_inquiry_cache_update
(
struct
hci_dev
*
hdev
,
struct
inquiry_
info
*
info
);
void
hci_inquiry_cache_update
(
struct
hci_dev
*
hdev
,
struct
inquiry_
data
*
data
);
/* ----- HCI Connections ----- */
/* ----- HCI Connections ----- */
enum
{
enum
{
...
...
include/net/ip_vs.h
View file @
821bc517
...
@@ -358,6 +358,7 @@ enum {
...
@@ -358,6 +358,7 @@ enum {
NET_IPV4_VS_EXPIRE_NODEST_CONN
=
23
,
NET_IPV4_VS_EXPIRE_NODEST_CONN
=
23
,
NET_IPV4_VS_SYNC_THRESHOLD
=
24
,
NET_IPV4_VS_SYNC_THRESHOLD
=
24
,
NET_IPV4_VS_NAT_ICMP_SEND
=
25
,
NET_IPV4_VS_NAT_ICMP_SEND
=
25
,
NET_IPV4_VS_EXPIRE_QUIESCENT_TEMPLATE
=
26
,
NET_IPV4_VS_LAST
NET_IPV4_VS_LAST
};
};
...
@@ -879,6 +880,7 @@ extern int ip_vs_leave(struct ip_vs_service *svc, struct sk_buff *skb,
...
@@ -879,6 +880,7 @@ extern int ip_vs_leave(struct ip_vs_service *svc, struct sk_buff *skb,
*/
*/
extern
int
sysctl_ip_vs_cache_bypass
;
extern
int
sysctl_ip_vs_cache_bypass
;
extern
int
sysctl_ip_vs_expire_nodest_conn
;
extern
int
sysctl_ip_vs_expire_nodest_conn
;
extern
int
sysctl_ip_vs_expire_quiescent_template
;
extern
int
sysctl_ip_vs_sync_threshold
[
2
];
extern
int
sysctl_ip_vs_sync_threshold
[
2
];
extern
int
sysctl_ip_vs_nat_icmp_send
;
extern
int
sysctl_ip_vs_nat_icmp_send
;
extern
struct
ip_vs_stats
ip_vs_stats
;
extern
struct
ip_vs_stats
ip_vs_stats
;
...
...
net/bluetooth/hci_conn.c
View file @
821bc517
...
@@ -71,9 +71,10 @@ void hci_acl_connect(struct hci_conn *conn)
...
@@ -71,9 +71,10 @@ void hci_acl_connect(struct hci_conn *conn)
if
((
ie
=
hci_inquiry_cache_lookup
(
hdev
,
&
conn
->
dst
))
&&
if
((
ie
=
hci_inquiry_cache_lookup
(
hdev
,
&
conn
->
dst
))
&&
inquiry_entry_age
(
ie
)
<=
INQUIRY_ENTRY_AGE_MAX
)
{
inquiry_entry_age
(
ie
)
<=
INQUIRY_ENTRY_AGE_MAX
)
{
cp
.
pscan_rep_mode
=
ie
->
info
.
pscan_rep_mode
;
cp
.
pscan_rep_mode
=
ie
->
data
.
pscan_rep_mode
;
cp
.
pscan_mode
=
ie
->
info
.
pscan_mode
;
cp
.
pscan_mode
=
ie
->
data
.
pscan_mode
;
cp
.
clock_offset
=
ie
->
info
.
clock_offset
|
__cpu_to_le16
(
0x8000
);
cp
.
clock_offset
=
ie
->
data
.
clock_offset
|
__cpu_to_le16
(
0x8000
);
memcpy
(
conn
->
dev_class
,
ie
->
data
.
dev_class
,
3
);
}
}
cp
.
pkt_type
=
__cpu_to_le16
(
hdev
->
pkt_type
&
ACL_PTYPE_MASK
);
cp
.
pkt_type
=
__cpu_to_le16
(
hdev
->
pkt_type
&
ACL_PTYPE_MASK
);
...
...
net/bluetooth/hci_core.c
View file @
821bc517
...
@@ -313,19 +313,19 @@ struct inquiry_entry *hci_inquiry_cache_lookup(struct hci_dev *hdev, bdaddr_t *b
...
@@ -313,19 +313,19 @@ struct inquiry_entry *hci_inquiry_cache_lookup(struct hci_dev *hdev, bdaddr_t *b
BT_DBG
(
"cache %p, %s"
,
cache
,
batostr
(
bdaddr
));
BT_DBG
(
"cache %p, %s"
,
cache
,
batostr
(
bdaddr
));
for
(
e
=
cache
->
list
;
e
;
e
=
e
->
next
)
for
(
e
=
cache
->
list
;
e
;
e
=
e
->
next
)
if
(
!
bacmp
(
&
e
->
info
.
bdaddr
,
bdaddr
))
if
(
!
bacmp
(
&
e
->
data
.
bdaddr
,
bdaddr
))
break
;
break
;
return
e
;
return
e
;
}
}
void
hci_inquiry_cache_update
(
struct
hci_dev
*
hdev
,
struct
inquiry_
info
*
info
)
void
hci_inquiry_cache_update
(
struct
hci_dev
*
hdev
,
struct
inquiry_
data
*
data
)
{
{
struct
inquiry_cache
*
cache
=
&
hdev
->
inq_cache
;
struct
inquiry_cache
*
cache
=
&
hdev
->
inq_cache
;
struct
inquiry_entry
*
e
;
struct
inquiry_entry
*
e
;
BT_DBG
(
"cache %p, %s"
,
cache
,
batostr
(
&
info
->
bdaddr
));
BT_DBG
(
"cache %p, %s"
,
cache
,
batostr
(
&
data
->
bdaddr
));
if
(
!
(
e
=
hci_inquiry_cache_lookup
(
hdev
,
&
info
->
bdaddr
)))
{
if
(
!
(
e
=
hci_inquiry_cache_lookup
(
hdev
,
&
data
->
bdaddr
)))
{
/* Entry not in the cache. Add new one. */
/* Entry not in the cache. Add new one. */
if
(
!
(
e
=
kmalloc
(
sizeof
(
struct
inquiry_entry
),
GFP_ATOMIC
)))
if
(
!
(
e
=
kmalloc
(
sizeof
(
struct
inquiry_entry
),
GFP_ATOMIC
)))
return
;
return
;
...
@@ -334,7 +334,7 @@ void hci_inquiry_cache_update(struct hci_dev *hdev, struct inquiry_info *info)
...
@@ -334,7 +334,7 @@ void hci_inquiry_cache_update(struct hci_dev *hdev, struct inquiry_info *info)
cache
->
list
=
e
;
cache
->
list
=
e
;
}
}
memcpy
(
&
e
->
info
,
info
,
sizeof
(
*
info
));
memcpy
(
&
e
->
data
,
data
,
sizeof
(
*
data
));
e
->
timestamp
=
jiffies
;
e
->
timestamp
=
jiffies
;
cache
->
timestamp
=
jiffies
;
cache
->
timestamp
=
jiffies
;
}
}
...
@@ -346,8 +346,16 @@ static int inquiry_cache_dump(struct hci_dev *hdev, int num, __u8 *buf)
...
@@ -346,8 +346,16 @@ static int inquiry_cache_dump(struct hci_dev *hdev, int num, __u8 *buf)
struct
inquiry_entry
*
e
;
struct
inquiry_entry
*
e
;
int
copied
=
0
;
int
copied
=
0
;
for
(
e
=
cache
->
list
;
e
&&
copied
<
num
;
e
=
e
->
next
,
copied
++
)
for
(
e
=
cache
->
list
;
e
&&
copied
<
num
;
e
=
e
->
next
,
copied
++
)
{
memcpy
(
info
++
,
&
e
->
info
,
sizeof
(
*
info
));
struct
inquiry_data
*
data
=
&
e
->
data
;
bacpy
(
&
info
->
bdaddr
,
&
data
->
bdaddr
);
info
->
pscan_rep_mode
=
data
->
pscan_rep_mode
;
info
->
pscan_period_mode
=
data
->
pscan_period_mode
;
info
->
pscan_mode
=
data
->
pscan_mode
;
memcpy
(
info
->
dev_class
,
data
->
dev_class
,
3
);
info
->
clock_offset
=
data
->
clock_offset
;
info
++
;
}
BT_DBG
(
"cache %p, copied %d"
,
cache
,
copied
);
BT_DBG
(
"cache %p, copied %d"
,
cache
,
copied
);
return
copied
;
return
copied
;
...
...
net/bluetooth/hci_event.c
View file @
821bc517
...
@@ -491,8 +491,18 @@ static inline void hci_inquiry_result_evt(struct hci_dev *hdev, struct sk_buff *
...
@@ -491,8 +491,18 @@ static inline void hci_inquiry_result_evt(struct hci_dev *hdev, struct sk_buff *
BT_DBG
(
"%s num_rsp %d"
,
hdev
->
name
,
num_rsp
);
BT_DBG
(
"%s num_rsp %d"
,
hdev
->
name
,
num_rsp
);
hci_dev_lock
(
hdev
);
hci_dev_lock
(
hdev
);
for
(;
num_rsp
;
num_rsp
--
)
for
(;
num_rsp
;
num_rsp
--
)
{
hci_inquiry_cache_update
(
hdev
,
info
++
);
struct
inquiry_data
data
;
bacpy
(
&
data
.
bdaddr
,
&
info
->
bdaddr
);
data
.
pscan_rep_mode
=
info
->
pscan_rep_mode
;
data
.
pscan_period_mode
=
info
->
pscan_period_mode
;
data
.
pscan_mode
=
info
->
pscan_mode
;
memcpy
(
data
.
dev_class
,
info
->
dev_class
,
3
);
data
.
clock_offset
=
info
->
clock_offset
;
data
.
rssi
=
0x00
;
info
++
;
hci_inquiry_cache_update
(
hdev
,
&
data
);
}
hci_dev_unlock
(
hdev
);
hci_dev_unlock
(
hdev
);
}
}
...
@@ -506,15 +516,16 @@ static inline void hci_inquiry_result_with_rssi_evt(struct hci_dev *hdev, struct
...
@@ -506,15 +516,16 @@ static inline void hci_inquiry_result_with_rssi_evt(struct hci_dev *hdev, struct
hci_dev_lock
(
hdev
);
hci_dev_lock
(
hdev
);
for
(;
num_rsp
;
num_rsp
--
)
{
for
(;
num_rsp
;
num_rsp
--
)
{
struct
inquiry_info
tmp
;
struct
inquiry_data
data
;
bacpy
(
&
tmp
.
bdaddr
,
&
info
->
bdaddr
);
bacpy
(
&
data
.
bdaddr
,
&
info
->
bdaddr
);
tmp
.
pscan_rep_mode
=
info
->
pscan_rep_mode
;
data
.
pscan_rep_mode
=
info
->
pscan_rep_mode
;
tmp
.
pscan_period_mode
=
info
->
pscan_period_mode
;
data
.
pscan_period_mode
=
info
->
pscan_period_mode
;
tmp
.
pscan_mode
=
0x00
;
data
.
pscan_mode
=
0x00
;
memcpy
(
tmp
.
dev_class
,
&
info
->
dev_class
,
3
);
memcpy
(
data
.
dev_class
,
info
->
dev_class
,
3
);
tmp
.
clock_offset
=
info
->
clock_offset
;
data
.
clock_offset
=
info
->
clock_offset
;
data
.
rssi
=
info
->
rssi
;
info
++
;
info
++
;
hci_inquiry_cache_update
(
hdev
,
&
tmp
);
hci_inquiry_cache_update
(
hdev
,
&
data
);
}
}
hci_dev_unlock
(
hdev
);
hci_dev_unlock
(
hdev
);
}
}
...
@@ -544,6 +555,7 @@ static inline void hci_conn_request_evt(struct hci_dev *hdev, struct sk_buff *sk
...
@@ -544,6 +555,7 @@ static inline void hci_conn_request_evt(struct hci_dev *hdev, struct sk_buff *sk
return
;
return
;
}
}
}
}
memcpy
(
conn
->
dev_class
,
ev
->
dev_class
,
3
);
conn
->
state
=
BT_CONNECT
;
conn
->
state
=
BT_CONNECT
;
hci_dev_unlock
(
hdev
);
hci_dev_unlock
(
hdev
);
...
...
net/bluetooth/hci_sysfs.c
View file @
821bc517
...
@@ -48,14 +48,14 @@ static ssize_t show_inquiry_cache(struct class_device *cdev, char *buf)
...
@@ -48,14 +48,14 @@ static ssize_t show_inquiry_cache(struct class_device *cdev, char *buf)
hci_dev_lock_bh
(
hdev
);
hci_dev_lock_bh
(
hdev
);
for
(
e
=
cache
->
list
;
e
;
e
=
e
->
next
)
{
for
(
e
=
cache
->
list
;
e
;
e
=
e
->
next
)
{
struct
inquiry_
info
*
info
=
&
e
->
info
;
struct
inquiry_
data
*
data
=
&
e
->
data
;
bdaddr_t
bdaddr
;
bdaddr_t
bdaddr
;
baswap
(
&
bdaddr
,
&
info
->
bdaddr
);
baswap
(
&
bdaddr
,
&
data
->
bdaddr
);
n
+=
sprintf
(
buf
+
n
,
"%s %d %d %d 0x%.2x%.2x%.2x 0x%.4x
0x%.2x
%u
\n
"
,
n
+=
sprintf
(
buf
+
n
,
"%s %d %d %d 0x%.2x%.2x%.2x 0x%.4x
%d
%u
\n
"
,
batostr
(
&
bdaddr
),
batostr
(
&
bdaddr
),
info
->
pscan_rep_mode
,
info
->
pscan_period_mode
,
info
->
pscan_mode
,
data
->
pscan_rep_mode
,
data
->
pscan_period_mode
,
data
->
pscan_mode
,
info
->
dev_class
[
2
],
info
->
dev_class
[
1
],
info
->
dev_class
[
0
],
data
->
dev_class
[
2
],
data
->
dev_class
[
1
],
data
->
dev_class
[
0
],
info
->
clock_offset
,
0
,
e
->
timestamp
);
data
->
clock_offset
,
data
->
rssi
,
e
->
timestamp
);
}
}
hci_dev_unlock_bh
(
hdev
);
hci_dev_unlock_bh
(
hdev
);
...
...
net/ipv4/ipvs/ip_vs_conn.c
View file @
821bc517
...
@@ -453,7 +453,9 @@ int ip_vs_check_template(struct ip_vs_conn *ct)
...
@@ -453,7 +453,9 @@ int ip_vs_check_template(struct ip_vs_conn *ct)
* Checking the dest server status.
* Checking the dest server status.
*/
*/
if
((
dest
==
NULL
)
||
if
((
dest
==
NULL
)
||
!
(
dest
->
flags
&
IP_VS_DEST_F_AVAILABLE
))
{
!
(
dest
->
flags
&
IP_VS_DEST_F_AVAILABLE
)
||
(
sysctl_ip_vs_expire_quiescent_template
&&
(
atomic_read
(
&
dest
->
weight
)
==
0
)))
{
IP_VS_DBG
(
9
,
"check_template: dest not available for "
IP_VS_DBG
(
9
,
"check_template: dest not available for "
"protocol %s s:%u.%u.%u.%u:%d v:%u.%u.%u.%u:%d "
"protocol %s s:%u.%u.%u.%u:%d v:%u.%u.%u.%u:%d "
"-> d:%u.%u.%u.%u:%d
\n
"
,
"-> d:%u.%u.%u.%u:%d
\n
"
,
...
...
net/ipv4/ipvs/ip_vs_ctl.c
View file @
821bc517
...
@@ -75,6 +75,7 @@ static int sysctl_ip_vs_amemthresh = 1024;
...
@@ -75,6 +75,7 @@ static int sysctl_ip_vs_amemthresh = 1024;
static
int
sysctl_ip_vs_am_droprate
=
10
;
static
int
sysctl_ip_vs_am_droprate
=
10
;
int
sysctl_ip_vs_cache_bypass
=
0
;
int
sysctl_ip_vs_cache_bypass
=
0
;
int
sysctl_ip_vs_expire_nodest_conn
=
0
;
int
sysctl_ip_vs_expire_nodest_conn
=
0
;
int
sysctl_ip_vs_expire_quiescent_template
=
0
;
int
sysctl_ip_vs_sync_threshold
[
2
]
=
{
3
,
50
};
int
sysctl_ip_vs_sync_threshold
[
2
]
=
{
3
,
50
};
int
sysctl_ip_vs_nat_icmp_send
=
0
;
int
sysctl_ip_vs_nat_icmp_send
=
0
;
...
@@ -1447,9 +1448,9 @@ static struct ctl_table vs_vars[] = {
...
@@ -1447,9 +1448,9 @@ static struct ctl_table vs_vars[] = {
{
{
.ctl_name = NET_IPV4_VS_TO_ES,
.ctl_name = NET_IPV4_VS_TO_ES,
.procname = "timeout_established",
.procname = "timeout_established",
.data = &vs_timeout_table_dos.timeout[IP_VS_S_ESTABLISHED],
.data = &vs_timeout_table_dos.timeout[IP_VS_S_ESTABLISHED],
.maxlen = sizeof(int),
.maxlen = sizeof(int),
.mode = 0644,
.mode = 0644,
.proc_handler = &proc_dointvec_jiffies,
.proc_handler = &proc_dointvec_jiffies,
},
},
{
{
...
@@ -1457,7 +1458,7 @@ static struct ctl_table vs_vars[] = {
...
@@ -1457,7 +1458,7 @@ static struct ctl_table vs_vars[] = {
.procname = "timeout_synsent",
.procname = "timeout_synsent",
.data = &vs_timeout_table_dos.timeout[IP_VS_S_SYN_SENT],
.data = &vs_timeout_table_dos.timeout[IP_VS_S_SYN_SENT],
.maxlen = sizeof(int),
.maxlen = sizeof(int),
.mode = 0644,
.mode = 0644,
.proc_handler = &proc_dointvec_jiffies,
.proc_handler = &proc_dointvec_jiffies,
},
},
{
{
...
@@ -1465,7 +1466,7 @@ static struct ctl_table vs_vars[] = {
...
@@ -1465,7 +1466,7 @@ static struct ctl_table vs_vars[] = {
.procname = "timeout_synrecv",
.procname = "timeout_synrecv",
.data = &vs_timeout_table_dos.timeout[IP_VS_S_SYN_RECV],
.data = &vs_timeout_table_dos.timeout[IP_VS_S_SYN_RECV],
.maxlen = sizeof(int),
.maxlen = sizeof(int),
.mode = 0644,
.mode = 0644,
.proc_handler = &proc_dointvec_jiffies,
.proc_handler = &proc_dointvec_jiffies,
},
},
{
{
...
@@ -1473,7 +1474,7 @@ static struct ctl_table vs_vars[] = {
...
@@ -1473,7 +1474,7 @@ static struct ctl_table vs_vars[] = {
.procname = "timeout_finwait",
.procname = "timeout_finwait",
.data = &vs_timeout_table_dos.timeout[IP_VS_S_FIN_WAIT],
.data = &vs_timeout_table_dos.timeout[IP_VS_S_FIN_WAIT],
.maxlen = sizeof(int),
.maxlen = sizeof(int),
.mode = 0644,
.mode = 0644,
.proc_handler = &proc_dointvec_jiffies,
.proc_handler = &proc_dointvec_jiffies,
},
},
{
{
...
@@ -1489,7 +1490,7 @@ static struct ctl_table vs_vars[] = {
...
@@ -1489,7 +1490,7 @@ static struct ctl_table vs_vars[] = {
.procname = "timeout_close",
.procname = "timeout_close",
.data = &vs_timeout_table_dos.timeout[IP_VS_S_CLOSE],
.data = &vs_timeout_table_dos.timeout[IP_VS_S_CLOSE],
.maxlen = sizeof(int),
.maxlen = sizeof(int),
.mode = 0644,
.mode = 0644,
.proc_handler = &proc_dointvec_jiffies,
.proc_handler = &proc_dointvec_jiffies,
},
},
{
{
...
@@ -1497,7 +1498,7 @@ static struct ctl_table vs_vars[] = {
...
@@ -1497,7 +1498,7 @@ static struct ctl_table vs_vars[] = {
.procname = "timeout_closewait",
.procname = "timeout_closewait",
.data = &vs_timeout_table_dos.timeout[IP_VS_S_CLOSE_WAIT],
.data = &vs_timeout_table_dos.timeout[IP_VS_S_CLOSE_WAIT],
.maxlen = sizeof(int),
.maxlen = sizeof(int),
.mode = 0644,
.mode = 0644,
.proc_handler = &proc_dointvec_jiffies,
.proc_handler = &proc_dointvec_jiffies,
},
},
{
{
...
@@ -1505,7 +1506,7 @@ static struct ctl_table vs_vars[] = {
...
@@ -1505,7 +1506,7 @@ static struct ctl_table vs_vars[] = {
.procname = "timeout_lastack",
.procname = "timeout_lastack",
.data = &vs_timeout_table_dos.timeout[IP_VS_S_LAST_ACK],
.data = &vs_timeout_table_dos.timeout[IP_VS_S_LAST_ACK],
.maxlen = sizeof(int),
.maxlen = sizeof(int),
.mode = 0644,
.mode = 0644,
.proc_handler = &proc_dointvec_jiffies,
.proc_handler = &proc_dointvec_jiffies,
},
},
{
{
...
@@ -1513,7 +1514,7 @@ static struct ctl_table vs_vars[] = {
...
@@ -1513,7 +1514,7 @@ static struct ctl_table vs_vars[] = {
.procname = "timeout_listen",
.procname = "timeout_listen",
.data = &vs_timeout_table_dos.timeout[IP_VS_S_LISTEN],
.data = &vs_timeout_table_dos.timeout[IP_VS_S_LISTEN],
.maxlen = sizeof(int),
.maxlen = sizeof(int),
.mode = 0644,
.mode = 0644,
.proc_handler = &proc_dointvec_jiffies,
.proc_handler = &proc_dointvec_jiffies,
},
},
{
{
...
@@ -1521,7 +1522,7 @@ static struct ctl_table vs_vars[] = {
...
@@ -1521,7 +1522,7 @@ static struct ctl_table vs_vars[] = {
.procname = "timeout_synack",
.procname = "timeout_synack",
.data = &vs_timeout_table_dos.timeout[IP_VS_S_SYNACK],
.data = &vs_timeout_table_dos.timeout[IP_VS_S_SYNACK],
.maxlen = sizeof(int),
.maxlen = sizeof(int),
.mode = 0644,
.mode = 0644,
.proc_handler = &proc_dointvec_jiffies,
.proc_handler = &proc_dointvec_jiffies,
},
},
{
{
...
@@ -1529,7 +1530,7 @@ static struct ctl_table vs_vars[] = {
...
@@ -1529,7 +1530,7 @@ static struct ctl_table vs_vars[] = {
.procname = "timeout_udp",
.procname = "timeout_udp",
.data = &vs_timeout_table_dos.timeout[IP_VS_S_UDP],
.data = &vs_timeout_table_dos.timeout[IP_VS_S_UDP],
.maxlen = sizeof(int),
.maxlen = sizeof(int),
.mode = 0644,
.mode = 0644,
.proc_handler = &proc_dointvec_jiffies,
.proc_handler = &proc_dointvec_jiffies,
},
},
{
{
...
@@ -1557,6 +1558,14 @@ static struct ctl_table vs_vars[] = {
...
@@ -1557,6 +1558,14 @@ static struct ctl_table vs_vars[] = {
.
mode
=
0644
,
.
mode
=
0644
,
.
proc_handler
=
&
proc_dointvec
,
.
proc_handler
=
&
proc_dointvec
,
},
},
{
.
ctl_name
=
NET_IPV4_VS_EXPIRE_QUIESCENT_TEMPLATE
,
.
procname
=
"expire_quiescent_template"
,
.
data
=
&
sysctl_ip_vs_expire_quiescent_template
,
.
maxlen
=
sizeof
(
int
),
.
mode
=
0644
,
.
proc_handler
=
&
proc_dointvec
,
},
{
{
.
ctl_name
=
NET_IPV4_VS_SYNC_THRESHOLD
,
.
ctl_name
=
NET_IPV4_VS_SYNC_THRESHOLD
,
.
procname
=
"sync_threshold"
,
.
procname
=
"sync_threshold"
,
...
...
net/ipv4/tcp_input.c
View file @
821bc517
...
@@ -3028,7 +3028,7 @@ void tcp_parse_options(struct sk_buff *skb, struct tcp_opt *tp, int estab)
...
@@ -3028,7 +3028,7 @@ void tcp_parse_options(struct sk_buff *skb, struct tcp_opt *tp, int estab)
tp
->
snd_wscale
=
*
(
__u8
*
)
ptr
;
tp
->
snd_wscale
=
*
(
__u8
*
)
ptr
;
if
(
tp
->
snd_wscale
>
14
)
{
if
(
tp
->
snd_wscale
>
14
)
{
if
(
net_ratelimit
())
if
(
net_ratelimit
())
printk
(
"tcp_parse_options: Illegal window "
printk
(
KERN_INFO
"tcp_parse_options: Illegal window "
"scaling value %d >14 received."
,
"scaling value %d >14 received."
,
tp
->
snd_wscale
);
tp
->
snd_wscale
);
tp
->
snd_wscale
=
14
;
tp
->
snd_wscale
=
14
;
...
...
net/ipv6/af_inet6.c
View file @
821bc517
...
@@ -524,11 +524,33 @@ extern void ipv6_sysctl_register(void);
...
@@ -524,11 +524,33 @@ extern void ipv6_sysctl_register(void);
extern
void
ipv6_sysctl_unregister
(
void
);
extern
void
ipv6_sysctl_unregister
(
void
);
#endif
#endif
/* Same as inet6_dgram_ops, sans udp_poll. */
static
struct
proto_ops
inet6_sockraw_ops
=
{
.
family
=
PF_INET6
,
.
owner
=
THIS_MODULE
,
.
release
=
inet6_release
,
.
bind
=
inet6_bind
,
.
connect
=
inet_dgram_connect
,
/* ok */
.
socketpair
=
sock_no_socketpair
,
/* a do nothing */
.
accept
=
sock_no_accept
,
/* a do nothing */
.
getname
=
inet6_getname
,
.
poll
=
datagram_poll
,
/* ok */
.
ioctl
=
inet6_ioctl
,
/* must change */
.
listen
=
sock_no_listen
,
/* ok */
.
shutdown
=
inet_shutdown
,
/* ok */
.
setsockopt
=
sock_common_setsockopt
,
/* ok */
.
getsockopt
=
sock_common_getsockopt
,
/* ok */
.
sendmsg
=
inet_sendmsg
,
/* ok */
.
recvmsg
=
sock_common_recvmsg
,
/* ok */
.
mmap
=
sock_no_mmap
,
.
sendpage
=
sock_no_sendpage
,
};
static
struct
inet_protosw
rawv6_protosw
=
{
static
struct
inet_protosw
rawv6_protosw
=
{
.
type
=
SOCK_RAW
,
.
type
=
SOCK_RAW
,
.
protocol
=
IPPROTO_IP
,
/* wild card */
.
protocol
=
IPPROTO_IP
,
/* wild card */
.
prot
=
&
rawv6_prot
,
.
prot
=
&
rawv6_prot
,
.
ops
=
&
inet6_
dgram
_ops
,
.
ops
=
&
inet6_
sockraw
_ops
,
.
capability
=
CAP_NET_RAW
,
.
capability
=
CAP_NET_RAW
,
.
no_check
=
UDP_CSUM_DEFAULT
,
.
no_check
=
UDP_CSUM_DEFAULT
,
.
flags
=
INET_PROTOSW_REUSE
,
.
flags
=
INET_PROTOSW_REUSE
,
...
...
net/sched/ipt.c
View file @
821bc517
...
@@ -63,8 +63,7 @@ init_targ(struct tcf_ipt *p)
...
@@ -63,8 +63,7 @@ init_targ(struct tcf_ipt *p)
target
=
__ipt_find_target_lock
(
t
->
u
.
user
.
name
,
&
ret
);
target
=
__ipt_find_target_lock
(
t
->
u
.
user
.
name
,
&
ret
);
if
(
!
target
)
{
if
(
!
target
)
{
printk
(
"init_targ: Failed to find %s
\n
"
,
printk
(
"init_targ: Failed to find %s
\n
"
,
t
->
u
.
user
.
name
);
t
->
u
.
kernel
.
target
->
name
);
return
-
1
;
return
-
1
;
}
}
...
...
net/sched/sch_netem.c
View file @
821bc517
...
@@ -258,12 +258,13 @@ static void netem_watchdog(unsigned long arg)
...
@@ -258,12 +258,13 @@ static void netem_watchdog(unsigned long arg)
{
{
struct
Qdisc
*
sch
=
(
struct
Qdisc
*
)
arg
;
struct
Qdisc
*
sch
=
(
struct
Qdisc
*
)
arg
;
struct
netem_sched_data
*
q
=
qdisc_priv
(
sch
);
struct
netem_sched_data
*
q
=
qdisc_priv
(
sch
);
struct
net_device
*
dev
=
sch
->
dev
;
struct
sk_buff
*
skb
;
struct
sk_buff
*
skb
;
psched_time_t
now
;
psched_time_t
now
;
pr_debug
(
"netem_watchdog: fired @%lu
\n
"
,
jiffies
);
pr_debug
(
"netem_watchdog: fired @%lu
\n
"
,
jiffies
);
spin_lock_bh
(
&
sch
->
dev
->
queue_lock
);
spin_lock_bh
(
&
dev
->
queue_lock
);
PSCHED_GET_TIME
(
now
);
PSCHED_GET_TIME
(
now
);
while
((
skb
=
skb_peek
(
&
q
->
delayed
))
!=
NULL
)
{
while
((
skb
=
skb_peek
(
&
q
->
delayed
))
!=
NULL
)
{
...
@@ -286,7 +287,8 @@ static void netem_watchdog(unsigned long arg)
...
@@ -286,7 +287,8 @@ static void netem_watchdog(unsigned long arg)
else
else
sch
->
q
.
qlen
++
;
sch
->
q
.
qlen
++
;
}
}
spin_unlock_bh
(
&
sch
->
dev
->
queue_lock
);
qdisc_restart
(
dev
);
spin_unlock_bh
(
&
dev
->
queue_lock
);
}
}
static
void
netem_reset
(
struct
Qdisc
*
sch
)
static
void
netem_reset
(
struct
Qdisc
*
sch
)
...
...
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