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
ca619c62
Commit
ca619c62
authored
May 09, 2003
by
Maksim Krasnyanskiy
Browse files
Options
Browse Files
Download
Plain Diff
Merge
bk://linux-bt.bkbits.net/marcel-2.5
into qualcomm.com:/home/kernel/bt-2.5
parents
318ce727
761cb06c
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
16 additions
and
14 deletions
+16
-14
include/net/bluetooth/rfcomm.h
include/net/bluetooth/rfcomm.h
+1
-0
net/bluetooth/rfcomm/core.c
net/bluetooth/rfcomm/core.c
+15
-14
No files found.
include/net/bluetooth/rfcomm.h
View file @
ca619c62
...
@@ -185,6 +185,7 @@ struct rfcomm_dlc {
...
@@ -185,6 +185,7 @@ struct rfcomm_dlc {
atomic_t
refcnt
;
atomic_t
refcnt
;
u8
dlci
;
u8
dlci
;
u8
addr
;
u8
addr
;
u8
priority
;
uint
mtu
;
uint
mtu
;
u8
v24_sig
;
u8
v24_sig
;
...
...
net/bluetooth/rfcomm/core.c
View file @
ca619c62
...
@@ -304,10 +304,11 @@ static int __rfcomm_dlc_open(struct rfcomm_dlc *d, bdaddr_t *src, bdaddr_t *dst,
...
@@ -304,10 +304,11 @@ static int __rfcomm_dlc_open(struct rfcomm_dlc *d, bdaddr_t *src, bdaddr_t *dst,
rfcomm_dlc_clear_state
(
d
);
rfcomm_dlc_clear_state
(
d
);
d
->
dlci
=
dlci
;
d
->
dlci
=
dlci
;
d
->
addr
=
__addr
(
s
->
initiator
,
dlci
);
d
->
addr
=
__addr
(
s
->
initiator
,
dlci
);
d
->
priority
=
7
;
d
->
state
=
BT_CONFIG
;
d
->
state
=
BT_CONFIG
;
rfcomm_dlc_link
(
s
,
d
);
rfcomm_dlc_link
(
s
,
d
);
d
->
mtu
=
s
->
mtu
;
d
->
mtu
=
s
->
mtu
;
...
@@ -744,7 +745,7 @@ static int rfcomm_send_pn(struct rfcomm_session *s, int cr, struct rfcomm_dlc *d
...
@@ -744,7 +745,7 @@ static int rfcomm_send_pn(struct rfcomm_session *s, int cr, struct rfcomm_dlc *d
pn
=
(
void
*
)
ptr
;
ptr
+=
sizeof
(
*
pn
);
pn
=
(
void
*
)
ptr
;
ptr
+=
sizeof
(
*
pn
);
pn
->
dlci
=
d
->
dlci
;
pn
->
dlci
=
d
->
dlci
;
pn
->
priority
=
0
;
pn
->
priority
=
d
->
priority
;
pn
->
ack_timer
=
0
;
pn
->
ack_timer
=
0
;
pn
->
max_retrans
=
0
;
pn
->
max_retrans
=
0
;
...
@@ -1102,8 +1103,6 @@ static int rfcomm_apply_pn(struct rfcomm_dlc *d, int cr, struct rfcomm_pn *pn)
...
@@ -1102,8 +1103,6 @@ static int rfcomm_apply_pn(struct rfcomm_dlc *d, int cr, struct rfcomm_pn *pn)
set_bit
(
RFCOMM_TX_THROTTLED
,
&
d
->
flags
);
set_bit
(
RFCOMM_TX_THROTTLED
,
&
d
->
flags
);
d
->
credits
=
0
;
d
->
credits
=
0
;
}
}
d
->
mtu
=
btohs
(
pn
->
mtu
);
}
else
{
}
else
{
if
(
pn
->
flow_ctrl
==
0xe0
)
{
if
(
pn
->
flow_ctrl
==
0xe0
)
{
d
->
tx_credits
=
pn
->
credits
;
d
->
tx_credits
=
pn
->
credits
;
...
@@ -1111,10 +1110,12 @@ static int rfcomm_apply_pn(struct rfcomm_dlc *d, int cr, struct rfcomm_pn *pn)
...
@@ -1111,10 +1110,12 @@ static int rfcomm_apply_pn(struct rfcomm_dlc *d, int cr, struct rfcomm_pn *pn)
set_bit
(
RFCOMM_TX_THROTTLED
,
&
d
->
flags
);
set_bit
(
RFCOMM_TX_THROTTLED
,
&
d
->
flags
);
d
->
credits
=
0
;
d
->
credits
=
0
;
}
}
d
->
mtu
=
btohs
(
pn
->
mtu
);
}
}
d
->
priority
=
pn
->
priority
;
d
->
mtu
=
btohs
(
pn
->
mtu
);
return
0
;
return
0
;
}
}
...
@@ -1140,7 +1141,7 @@ static int rfcomm_recv_pn(struct rfcomm_session *s, int cr, struct sk_buff *skb)
...
@@ -1140,7 +1141,7 @@ static int rfcomm_recv_pn(struct rfcomm_session *s, int cr, struct sk_buff *skb)
switch
(
d
->
state
)
{
switch
(
d
->
state
)
{
case
BT_CONFIG
:
case
BT_CONFIG
:
rfcomm_apply_pn
(
d
,
cr
,
pn
);
rfcomm_apply_pn
(
d
,
cr
,
pn
);
d
->
state
=
BT_CONNECT
;
d
->
state
=
BT_CONNECT
;
rfcomm_send_sabm
(
s
,
d
->
dlci
);
rfcomm_send_sabm
(
s
,
d
->
dlci
);
break
;
break
;
...
@@ -1151,7 +1152,7 @@ static int rfcomm_recv_pn(struct rfcomm_session *s, int cr, struct sk_buff *skb)
...
@@ -1151,7 +1152,7 @@ static int rfcomm_recv_pn(struct rfcomm_session *s, int cr, struct sk_buff *skb)
if
(
!
cr
)
if
(
!
cr
)
return
0
;
return
0
;
/* PN request for non existing DLC.
/* PN request for non existing DLC.
* Assume incoming connection. */
* Assume incoming connection. */
if
(
rfcomm_connect_ind
(
s
,
channel
,
&
d
))
{
if
(
rfcomm_connect_ind
(
s
,
channel
,
&
d
))
{
...
@@ -1160,7 +1161,7 @@ static int rfcomm_recv_pn(struct rfcomm_session *s, int cr, struct sk_buff *skb)
...
@@ -1160,7 +1161,7 @@ static int rfcomm_recv_pn(struct rfcomm_session *s, int cr, struct sk_buff *skb)
rfcomm_dlc_link
(
s
,
d
);
rfcomm_dlc_link
(
s
,
d
);
rfcomm_apply_pn
(
d
,
cr
,
pn
);
rfcomm_apply_pn
(
d
,
cr
,
pn
);
d
->
state
=
BT_OPEN
;
d
->
state
=
BT_OPEN
;
rfcomm_send_pn
(
s
,
0
,
d
);
rfcomm_send_pn
(
s
,
0
,
d
);
}
else
{
}
else
{
...
@@ -1232,21 +1233,21 @@ static int rfcomm_recv_rpn(struct rfcomm_session *s, int cr, int len, struct sk_
...
@@ -1232,21 +1233,21 @@ static int rfcomm_recv_rpn(struct rfcomm_session *s, int cr, int len, struct sk_
if
(
rpn
->
param_mask
&
RFCOMM_RPN_PM_FLOW
)
{
if
(
rpn
->
param_mask
&
RFCOMM_RPN_PM_FLOW
)
{
if
(
rpn
->
flow_ctrl
!=
RFCOMM_RPN_FLOW_NONE
)
{
if
(
rpn
->
flow_ctrl
!=
RFCOMM_RPN_FLOW_NONE
)
{
BT_DBG
(
"RPN flow ctrl mismatch 0x%x"
,
rpn
->
flow_ctrl
);
BT_DBG
(
"RPN flow ctrl mismatch 0x%x"
,
rpn
->
flow_ctrl
);
rpn
->
flow_ctrl
=
RFCOMM_RPN_FLOW_NONE
;
flow_ctrl
=
RFCOMM_RPN_FLOW_NONE
;
rpn_mask
^=
RFCOMM_RPN_PM_FLOW
;
rpn_mask
^=
RFCOMM_RPN_PM_FLOW
;
}
}
}
}
if
(
rpn
->
param_mask
&
RFCOMM_RPN_PM_XON
)
{
if
(
rpn
->
param_mask
&
RFCOMM_RPN_PM_XON
)
{
if
(
rpn
->
xon_char
!=
RFCOMM_RPN_XON_CHAR
)
{
if
(
rpn
->
xon_char
!=
RFCOMM_RPN_XON_CHAR
)
{
BT_DBG
(
"RPN XON char mismatch 0x%x"
,
rpn
->
xon_char
);
BT_DBG
(
"RPN XON char mismatch 0x%x"
,
rpn
->
xon_char
);
rpn
->
xon_char
=
RFCOMM_RPN_XON_CHAR
;
xon_char
=
RFCOMM_RPN_XON_CHAR
;
rpn_mask
^=
RFCOMM_RPN_PM_XON
;
rpn_mask
^=
RFCOMM_RPN_PM_XON
;
}
}
}
}
if
(
rpn
->
param_mask
&
RFCOMM_RPN_PM_XOFF
)
{
if
(
rpn
->
param_mask
&
RFCOMM_RPN_PM_XOFF
)
{
if
(
rpn
->
xoff_char
!=
RFCOMM_RPN_XOFF_CHAR
)
{
if
(
rpn
->
xoff_char
!=
RFCOMM_RPN_XOFF_CHAR
)
{
BT_DBG
(
"RPN XOFF char mismatch 0x%x"
,
rpn
->
xoff_char
);
BT_DBG
(
"RPN XOFF char mismatch 0x%x"
,
rpn
->
xoff_char
);
rpn
->
xoff_char
=
RFCOMM_RPN_XOFF_CHAR
;
xoff_char
=
RFCOMM_RPN_XOFF_CHAR
;
rpn_mask
^=
RFCOMM_RPN_PM_XOFF
;
rpn_mask
^=
RFCOMM_RPN_PM_XOFF
;
}
}
}
}
...
...
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