|
@@ -356,7 +356,7 @@ static int l2cap_sock_getsockopt_old(struct socket *sock, int optname, char __us
|
|
break;
|
|
break;
|
|
}
|
|
}
|
|
|
|
|
|
- if (chan->role_switch)
|
|
|
|
|
|
+ if (test_bit(FLAG_ROLE_SWITCH, &chan->flags))
|
|
opt |= L2CAP_LM_MASTER;
|
|
opt |= L2CAP_LM_MASTER;
|
|
|
|
|
|
if (test_bit(FLAG_FORCE_RELIABLE, &chan->flags))
|
|
if (test_bit(FLAG_FORCE_RELIABLE, &chan->flags))
|
|
@@ -549,7 +549,10 @@ static int l2cap_sock_setsockopt_old(struct socket *sock, int optname, char __us
|
|
if (opt & L2CAP_LM_SECURE)
|
|
if (opt & L2CAP_LM_SECURE)
|
|
chan->sec_level = BT_SECURITY_HIGH;
|
|
chan->sec_level = BT_SECURITY_HIGH;
|
|
|
|
|
|
- chan->role_switch = (opt & L2CAP_LM_MASTER);
|
|
|
|
|
|
+ if (opt & L2CAP_LM_MASTER)
|
|
|
|
+ set_bit(FLAG_ROLE_SWITCH, &chan->flags);
|
|
|
|
+ else
|
|
|
|
+ clear_bit(FLAG_ROLE_SWITCH, &chan->flags);
|
|
|
|
|
|
if (opt & L2CAP_LM_RELIABLE)
|
|
if (opt & L2CAP_LM_RELIABLE)
|
|
set_bit(FLAG_FORCE_RELIABLE, &chan->flags);
|
|
set_bit(FLAG_FORCE_RELIABLE, &chan->flags);
|
|
@@ -941,7 +944,6 @@ static void l2cap_sock_init(struct sock *sk, struct sock *parent)
|
|
chan->max_tx = pchan->max_tx;
|
|
chan->max_tx = pchan->max_tx;
|
|
chan->tx_win = pchan->tx_win;
|
|
chan->tx_win = pchan->tx_win;
|
|
chan->sec_level = pchan->sec_level;
|
|
chan->sec_level = pchan->sec_level;
|
|
- chan->role_switch = pchan->role_switch;
|
|
|
|
chan->flags = pchan->flags;
|
|
chan->flags = pchan->flags;
|
|
} else {
|
|
} else {
|
|
|
|
|
|
@@ -970,7 +972,6 @@ static void l2cap_sock_init(struct sock *sk, struct sock *parent)
|
|
chan->fcs = L2CAP_FCS_CRC16;
|
|
chan->fcs = L2CAP_FCS_CRC16;
|
|
chan->tx_win = L2CAP_DEFAULT_TX_WINDOW;
|
|
chan->tx_win = L2CAP_DEFAULT_TX_WINDOW;
|
|
chan->sec_level = BT_SECURITY_LOW;
|
|
chan->sec_level = BT_SECURITY_LOW;
|
|
- chan->role_switch = 0;
|
|
|
|
chan->flags = 0;
|
|
chan->flags = 0;
|
|
set_bit(FLAG_FORCE_ACTIVE, &chan->flags);
|
|
set_bit(FLAG_FORCE_ACTIVE, &chan->flags);
|
|
}
|
|
}
|