diff options
author | Marcel Holtmann <marcel@holtmann.org> | 2010-03-15 17:12:58 -0400 |
---|---|---|
committer | Marcel Holtmann <marcel@holtmann.org> | 2010-03-21 00:49:32 -0400 |
commit | 101545f6fef4a0a3ea8daf0b5b880df2c6a92a69 (patch) | |
tree | 5b4254a64db65f1958a36ec6955dbba1b71031a7 /net/bluetooth/l2cap.c | |
parent | af98441397227a5a4f212cd48710eea72a14dbdb (diff) |
Bluetooth: Fix potential bad memory access with sysfs files
When creating a high number of Bluetooth sockets (L2CAP, SCO
and RFCOMM) it is possible to scribble repeatedly on arbitrary
pages of memory. Ensure that the content of these sysfs files is
always less than one page. Even if this means truncating. The
files in question are scheduled to be moved over to debugfs in
the future anyway.
Based on initial patches from Neil Brown and Linus Torvalds
Reported-by: Neil Brown <neilb@suse.de>
Signed-off-by: Marcel Holtmann <marcel@holtmann.org>
Diffstat (limited to 'net/bluetooth/l2cap.c')
-rw-r--r-- | net/bluetooth/l2cap.c | 10 |
1 files changed, 9 insertions, 1 deletions
diff --git a/net/bluetooth/l2cap.c b/net/bluetooth/l2cap.c index 4db7ae2fe07d..27551820741e 100644 --- a/net/bluetooth/l2cap.c +++ b/net/bluetooth/l2cap.c | |||
@@ -3944,16 +3944,24 @@ static ssize_t l2cap_sysfs_show(struct class *dev, | |||
3944 | struct sock *sk; | 3944 | struct sock *sk; |
3945 | struct hlist_node *node; | 3945 | struct hlist_node *node; |
3946 | char *str = buf; | 3946 | char *str = buf; |
3947 | int size = PAGE_SIZE; | ||
3947 | 3948 | ||
3948 | read_lock_bh(&l2cap_sk_list.lock); | 3949 | read_lock_bh(&l2cap_sk_list.lock); |
3949 | 3950 | ||
3950 | sk_for_each(sk, node, &l2cap_sk_list.head) { | 3951 | sk_for_each(sk, node, &l2cap_sk_list.head) { |
3951 | struct l2cap_pinfo *pi = l2cap_pi(sk); | 3952 | struct l2cap_pinfo *pi = l2cap_pi(sk); |
3953 | int len; | ||
3952 | 3954 | ||
3953 | str += sprintf(str, "%s %s %d %d 0x%4.4x 0x%4.4x %d %d %d\n", | 3955 | len = snprintf(str, size, "%s %s %d %d 0x%4.4x 0x%4.4x %d %d %d\n", |
3954 | batostr(&bt_sk(sk)->src), batostr(&bt_sk(sk)->dst), | 3956 | batostr(&bt_sk(sk)->src), batostr(&bt_sk(sk)->dst), |
3955 | sk->sk_state, __le16_to_cpu(pi->psm), pi->scid, | 3957 | sk->sk_state, __le16_to_cpu(pi->psm), pi->scid, |
3956 | pi->dcid, pi->imtu, pi->omtu, pi->sec_level); | 3958 | pi->dcid, pi->imtu, pi->omtu, pi->sec_level); |
3959 | |||
3960 | size -= len; | ||
3961 | if (size <= 0) | ||
3962 | break; | ||
3963 | |||
3964 | str += len; | ||
3957 | } | 3965 | } |
3958 | 3966 | ||
3959 | read_unlock_bh(&l2cap_sk_list.lock); | 3967 | read_unlock_bh(&l2cap_sk_list.lock); |