-----Original Message----- From: linux-bluetooth-owner@xxxxxxxxxxxxxxx [mailto:linux-bluetooth-owner@xxxxxxxxxxxxxxx] On Behalf Of Luiz Augusto von Dentz Sent: Wednesday, April 14, 2010 1:11 AM To: linux-bluetooth@xxxxxxxxxxxxxxx Subject: detecting dead link Hi, It seems that most of the chips take a lot of time to detect that a link in dead, due to out of range or power off (no hci disconnect), the most common problem regarding this is when we try to connect SCO: 2010-03-31 18:40:19.975128 < HCI Command: Setup Synchronous Connection (0x01|0x0028) plen 17 handle 11 voice setting 0x0060 2010-03-31 18:40:19.981780 > HCI Event: Command Status (0x0f) plen 4 Setup Synchronous Connection (0x01|0x0028) status 0x00 ncmd 1 2010-03-31 18:40:33.318023 < ACL data: handle 11 flags 0x02 dlen 22 L2CAP(d): cid 0x0073 len 18 [psm 0] 0000: 69 ef 1d 0d 0a 2b 43 49 45 56 3a 20 32 2c 33 0d i....+CIEV: 2,3. 0010: 0a 3e .> 2010-03-31 18:40:33.318145 < HCI Command: Exit Sniff Mode (0x02|0x0004) plen 2 handle 11 2010-03-31 18:40:33.324615 > HCI Event: Command Status (0x0f) plen 4 Exit Sniff Mode (0x02|0x0004) status 0x00 ncmd 1 2010-03-31 18:40:51.207885 < ACL data: handle 11 flags 0x02 dlen 22 L2CAP(d): cid 0x0073 len 18 [psm 0] 0000: 69 ef 1d 0d 0a 2b 43 49 45 56 3a 20 32 2c 32 0d i....+CIEV: 2,2. 0010: 0a 3e .> 2010-03-31 18:40:54.965362 > HCI Event: Max Slots Change (0x1b) plen 3 handle 11 slots 5 2010-03-31 18:40:54.966094 > HCI Event: Synchronous Connect Complete (0x2c) plen 17 status 0x08 handle 0 bdaddr 00:1E:DC:B3:40:9D type eSCO Error: Connection Timeout 2010-03-31 18:40:54.968353 > HCI Event: Number of Completed Packets (0x13) plen 5 handle 11 packets 2 2010-03-31 18:40:54.968658 > HCI Event: Disconn Complete (0x05) plen 4 status 0x00 handle 11 reason 0x08 Reason: Connection Timeout It took 35 sec to timeout where connections attempt normally only take 5 sec due to page timeout (configurable in main.conf), it is probably due to being in sniff mode but even after exiting it takes another 20 sec to timeout (probably lmp timeout). So I was wondering why this timeout is not derived from page timeout, to me it seems quite obvious that if the connection doesn't complete within page timeout there is something wrong since that is supposed to be much faster on an active link, also if that assumption is correct what would be the impact to have such a logic that takes page timeout as timeout for any connection attempt in active/dead links dropping them if the timeout is reached, of course this has to take into account the user authorization framework/defer setup so it only timeout if there is no activity in the link. Hi Luiz, [MT] Page timeout is for creating ACL data link. In this case, ACL link is already created so page timeout is not involved. The 20 second timeout is the default link supervision timeout and the 35 second timeout is the LMP timeout (actually 30 seconds). I think if you have the sniff log for the LMP, it would appear that one of the LMP might be lost during SCO negotiation and it is quite possibly due to the existing sniff mode. A proper implementation of host stack shall probably exit sniff mode first before start the SCO link creation. So the log would look like this, HCI command: Exit Sniff Mode HCI event: Command status, Exit Sniff Mode HCI event: Mode changed HCI command: Setup Synchronous Connection I think the host was sending the commands out of order. It asks controller to set up SCO link before it asks controller to exit sniff mode. Note that both commands are async commands (meaning it will request controller to go through several state transition for those commands), so the controller might have hard time executing the host commands. -- Luiz Augusto von Dentz Computer Engineer -- To unsubscribe from this list: send the line "unsubscribe linux-bluetooth" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html -- To unsubscribe from this list: send the line "unsubscribe linux-bluetooth" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html