Bluetooth: convert force_reliable variable to flag in l2cap chan
authorAndrei Emeltchenko <andrei.emeltchenko@intel.com>
Tue, 11 Oct 2011 11:04:32 +0000 (14:04 +0300)
committerGustavo F. Padovan <padovan@profusion.mobi>
Tue, 11 Oct 2011 13:48:21 +0000 (10:48 -0300)
force_reliable variable inside l2cap_chan is a logical one and can
be easily converted to flag

Signed-off-by: Andrei Emeltchenko <andrei.emeltchenko@intel.com>
Signed-off-by: Gustavo F. Padovan <padovan@profusion.mobi>
include/net/bluetooth/l2cap.h
net/bluetooth/l2cap_core.c
net/bluetooth/l2cap_sock.c

index 0fe5d59b71a33cfc2937c751af657165b8a60d6a..6c0d247de94ced048615719e090ec308bc740081 100644 (file)
@@ -325,7 +325,6 @@ struct l2cap_chan {
 
        __u8            sec_level;
        __u8            role_switch;
-       __u8            force_reliable;
        __u8            force_active;
 
        __u8            ident;
@@ -465,6 +464,7 @@ enum {
 
 /* Definitions for flags in l2cap_chan */
 enum {
+       FLAG_FORCE_RELIABLE,
        FLAG_FLUSHABLE,
 };
 
index b21ecfffcaa9e749832fc248de0a7d1d58475f6d..57e4b2cf7b6a32211b7199a5a6a479430f4e50de 100644 (file)
@@ -948,7 +948,7 @@ static void l2cap_conn_unreliable(struct l2cap_conn *conn, int err)
        list_for_each_entry(chan, &conn->chan_l, list) {
                struct sock *sk = chan->sk;
 
-               if (chan->force_reliable)
+               if (test_bit(FLAG_FORCE_RELIABLE, &chan->flags))
                        sk->sk_err = err;
        }
 
index 99782cb4f0b4d5d9b6556d89792b75d793eb9ebc..405d736131e22645ba53fe39f03f36896bb651c3 100644 (file)
@@ -359,7 +359,7 @@ static int l2cap_sock_getsockopt_old(struct socket *sock, int optname, char __us
                if (chan->role_switch)
                        opt |= L2CAP_LM_MASTER;
 
-               if (chan->force_reliable)
+               if (test_bit(FLAG_FORCE_RELIABLE, &chan->flags))
                        opt |= L2CAP_LM_RELIABLE;
 
                if (put_user(opt, (u32 __user *) optval))
@@ -550,7 +550,11 @@ static int l2cap_sock_setsockopt_old(struct socket *sock, int optname, char __us
                        chan->sec_level = BT_SECURITY_HIGH;
 
                chan->role_switch    = (opt & L2CAP_LM_MASTER);
-               chan->force_reliable = (opt & L2CAP_LM_RELIABLE);
+
+               if (opt & L2CAP_LM_RELIABLE)
+                       set_bit(FLAG_FORCE_RELIABLE, &chan->flags);
+               else
+                       clear_bit(FLAG_FORCE_RELIABLE, &chan->flags);
                break;
 
        default:
@@ -934,7 +938,6 @@ static void l2cap_sock_init(struct sock *sk, struct sock *parent)
                chan->tx_win = pchan->tx_win;
                chan->sec_level = pchan->sec_level;
                chan->role_switch = pchan->role_switch;
-               chan->force_reliable = pchan->force_reliable;
                chan->flags = pchan->flags;
                chan->force_active = pchan->force_active;
        } else {
@@ -965,7 +968,6 @@ static void l2cap_sock_init(struct sock *sk, struct sock *parent)
                chan->tx_win = L2CAP_DEFAULT_TX_WINDOW;
                chan->sec_level = BT_SECURITY_LOW;
                chan->role_switch = 0;
-               chan->force_reliable = 0;
                chan->flags = 0;
                chan->force_active = BT_POWER_FORCE_ACTIVE_ON;