* question about 'read' system call of sco socket
@ 2010-03-02 14:28 liu yang
2010-03-03 2:42 ` Zhu Yanhai
0 siblings, 1 reply; 2+ messages in thread
From: liu yang @ 2010-03-02 14:28 UTC (permalink / raw)
To: linux-bluetooth; +Cc: Tan Miaoqing, Valerio Valerio
Hi experts,
I have one question about 'read' system call of sco socket. I'm using
an open source library which implements bluetooth handfree profile on
linux platform. About our use case, cell phone works as audio gateway
that all audio received on cell phone will be streamed to linux PC,
and vice versa. Everything works just fine of audio streaming above
bluetooth channel. But our special application is very sensitive on
timing that we need send/receive bluetooth audio frame every 20ms.
Regarding sending direction, I can tweak MTU of bluetooth donglel
installed on my linux PC. Let's say, MTU is set to 320 bytes, so every
20ms 'send' system call only needs be called one time. ( the audio
frame conveyed aboved bluetooth is of signed linear 16bit per sample,
8K sampling-rate ) But this does not affect receiving direction that
every 'read' system call on sco socket returns exact 48 bytes. Also I
find such 'read' event on linux 'poll' is triggered every 10ms. Every
10ms, such 'read' action is invoked, but it takes 3 or 4 times
invokation ( sometimes 3 , sometimes 4) of 'read' to consume this
'read' event, which results in 'EAGAIN'. So every 20ms, I get 288
(48*6) or 336 (48*7) bytes, not exact 320 I expect.
Shortly, my question is how to receive ( 'read' system call ) exact
320 bytes every 20ms.
Thanks
Kandy
^ permalink raw reply [flat|nested] 2+ messages in thread
* Re: question about 'read' system call of sco socket
2010-03-02 14:28 question about 'read' system call of sco socket liu yang
@ 2010-03-03 2:42 ` Zhu Yanhai
0 siblings, 0 replies; 2+ messages in thread
From: Zhu Yanhai @ 2010-03-03 2:42 UTC (permalink / raw)
To: liu yang; +Cc: linux-bluetooth, Tan Miaoqing, Valerio Valerio
On 03/02/2010 10:28 PM, liu yang wrote:
> Hi experts,
> I have one question about 'read' system call of sco socket. I'm using
> an open source library which implements bluetooth handfree profile on
> linux platform. About our use case, cell phone works as audio gateway
> that all audio received on cell phone will be streamed to linux PC,
> and vice versa. Everything works just fine of audio streaming above
> bluetooth channel. But our special application is very sensitive on
> timing that we need send/receive bluetooth audio frame every 20ms.
> Regarding sending direction, I can tweak MTU of bluetooth donglel
> installed on my linux PC. Let's say, MTU is set to 320 bytes, so every
> 20ms 'send' system call only needs be called one time. ( the audio
> frame conveyed aboved bluetooth is of signed linear 16bit per sample,
> 8K sampling-rate ) But this does not affect receiving direction that
> every 'read' system call on sco socket returns exact 48 bytes. Also I
> find such 'read' event on linux 'poll' is triggered every 10ms. Every
> 10ms, such 'read' action is invoked, but it takes 3 or 4 times
> invokation ( sometimes 3 , sometimes 4) of 'read' to consume this
> 'read' event, which results in 'EAGAIN'. So every 20ms, I get 288
> (48*6) or 336 (48*7) bytes, not exact 320 I expect.
>
> Shortly, my question is how to receive ( 'read' system call ) exact
> 320 bytes every 20ms.
>
> Thanks
>
> Kandy
> --
> To unsubscribe from this list: send the line "unsubscribe linux-bluetooth" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at http://vger.kernel.org/majordomo-info.html
>
Hi Yang,
I'm not a expert at this. IIRC SCO connection is designed to carry fixed
rated data, which is 64kbps[1]. In your case, you are expecting about
16bit*8K = 128kbps, which is beyond of SCO's capability. Maybe you can
consider creating two SCO links (the upper limit is 3 between two
Bluetooth devices) to carry your data or maybe you could consider using
a eSCO link?
Again, I'm not good at this, just saying...
Regards,
Zhu Yanhai
[1] Bluetooth specification Version 2.1, Vol 1, Page 44,
3.5.5 Synchronous connection-oriented (SCO)
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2010-03-03 2:42 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2010-03-02 14:28 question about 'read' system call of sco socket liu yang
2010-03-03 2:42 ` Zhu Yanhai
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).