From: Fabrizio Guglielmino <guglielmino@infitsrl.com>
To: BlueZ development <bluez-devel@lists.sourceforge.net>
Subject: Re: [Bluez-devel] Scan and push images
Date: Tue, 27 Nov 2007 11:51:06 +0100 [thread overview]
Message-ID: <474BF69A.3030008@infitsrl.com> (raw)
In-Reply-To: <1196151954.17196.15.camel@aeonflux>
Marcel Holtmann ha scritto:
> Hi Fabrizio,
>
> if you wanna get any real attention on this mailing list, you better
> fill in a subject. I tend to quickly delete messages without a subject.
>
>
>> I made a simple software to send small pictures to all bluetooth
>> devices in range (it's used by a museum ).
>> This software is made in C using bluez api, I've used two bluetooth
>> dongles : one to make periodic inquiry (not with HCI periodic inquiry
>> command by with a loop) and the other to make sdp query looking for
>> obex push service and sending image.
>> My requirement was to use this software in some embedded linux based
>> computer so I chose to limit external library, I made all using
>> pthread so there is an infinite thread for inquiries and one thread
>> to handle every sdp query and relative connection when devices are
>> discovered. I've discarded also using python or other scripting
>> languages for the platfom limitations.
>>
>> All works but I found it not so efficient, also with 6/7 devices it's
>> really slow to identify and connect to devices, some times connection
>> are unexpectedly closed and so on....
>>
>
> A lot of people tried to make this work and there are ways to make it
> work as efficient as possible. However you need an understanding on how
> the Bluetooth radio and baseband are working and what the limits are.
> For example using one or two threads doesn't give anything useful. This
> is the wrong approach to start with. No excuses. You are simply blocking
> the baseband with your random attempts. It is also better to use
> periodic inquiry or explicitly cancel an inquiry when you wanna page the
> remote device for a SDP query. It also makes sense to use the class of
> device to a pre-filter on remote devices that actually support object
> transfer.
>
> Run a "hcidump -X -V" during your scans and connect attempts and you see
> the errors that will present themself when you try to page during an
> inquiry. The kernel taIs it my approch to the problem wrong or bluetooth protocol is not
> suitable for this type of use?
>
>
> Do you have any choice when it comes to communicate with mobile phones?
>
>
>> I'm using libs version 3.7-1 (on debian 4.0)
>>
>
> The latest version is 3.22 :)
>
> Regards
>
> Marcel
>
>
>
> -------------------------------------------------------------------------
> This SF.net email is sponsored by: Microsoft
> Defy all challenges. Microsoft(R) Visual Studio 2005.
> http://clk.atdmt.com/MRT/go/vse0120000070mrt/direct/01/
> _______________________________________________
> Bluez-devel mailing list
> Bluez-devel@lists.sourceforge.net
> https://lists.sourceforge.net/lists/listinfo/bluez-devel
>
>
Ok for the subject, excuse me.
I can't undertand "You are simply blocking the baseband with your random
attempts", where are the random attemps?
One thread is dedicated to make inquiry, it bind on a specific local
adapter and make an infinite loop of inquiry (with a parametric sleep on
every iteration).
On the other side for every device discovered it's lauched a thread for
these operations:
1) sdp query for OPUSH service (serialized with a mutex)
2) connection to eventually discovered RFCOMM channel of the object push
service
3) push of the content (with my own working obex implementation)
I'd like to accept Your suggests but:
- If I use periodic inquiry I need obligatory dbus to receive callback
events?
- How can I perform pre-filter on remote devices that support object
transfer if I've not discovered their servies?
About library version I known I'm a little outdated ;-) but I'm
preparing a new working environment with latest version.
Many thanks
Fabrizio
-------------------------------------------------------------------------
This SF.net email is sponsored by: Microsoft
Defy all challenges. Microsoft(R) Visual Studio 2005.
http://clk.atdmt.com/MRT/go/vse0120000070mrt/direct/01/
_______________________________________________
Bluez-devel mailing list
Bluez-devel@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/bluez-devel
next prev parent reply other threads:[~2007-11-27 10:51 UTC|newest]
Thread overview: 11+ messages / expand[flat|nested] mbox.gz Atom feed top
2007-11-26 20:49 [Bluez-devel] (no subject) Fabrizio Guglielmino
2007-11-27 7:14 ` jm
2007-11-27 10:56 ` Fabrizio Guglielmino
2007-11-27 8:25 ` Marcel Holtmann
2007-11-27 10:51 ` Fabrizio Guglielmino [this message]
2007-11-27 11:06 ` [Bluez-devel] Scan and push images Marcel Holtmann
2007-11-27 11:13 ` Fabrizio Guglielmino
2007-11-27 11:47 ` Marcel Holtmann
2007-11-27 12:52 ` Fabrizio Guglielmino
2007-11-27 13:08 ` Manuel Naranjo
2007-11-27 13:25 ` Fabrizio Guglielmino
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=474BF69A.3030008@infitsrl.com \
--to=guglielmino@infitsrl.com \
--cc=bluez-devel@lists.sourceforge.net \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
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).