[Kde-hardware-devel] [GSoC] Preliminary UPnP support proposal
Tuomo Penttinen
tp at herqq.org
Fri Apr 9 03:15:49 CEST 2010
Hello all,
On Wed, April 7, 2010 3:09 pm, Friedrich W. H. Kossebau wrote:
> Hi all (and Tuomo),
>
> Mardi, le 6 avril 2010, à 23:41, Kevin Ottens a écrit:
>> On Wednesday 31 March 2010 14:42:03 Tuomo Penttinen wrote:
>> > I agree. The UPnP discovery protocol is lightweight enough that I
>> > wouldn't worry about it in most environments.
>
> Emphasis on _most_ environments ;)
Indeed. ;)
>> Actually I like numbers. :-)
>>
>> My worry lies in the fact that we're going for the full game of having
>> it in libsolid, which means that such a discovery will be triggered by
>> any apps which starts and ask for a StorageAccess (which means at least
>> anything which spawns a file dialog).
>
> And slightly worse. Any SSDP message coming in will wake up all of the
> processes which listen for these, just to find out if it is interesting to
> them or not. Minor case, but still burns ressources (think of mobile uses)
> and should be avoided as a standard pattern.
So you would replace the aforementioned "wakeup of all" with some type of
central registration mechanism? This system would enable processes to tell
the registrar which messages / resources they are interested of and in
turn the registrar would inform them upon reception of desired message
types?
Fair enough, but to me it would seem that maintaining and using such a
registry comes up with a price, which justification still isn't so clear
to me. Of course, it doesn't have to be, but I find this interesting
enough to comment. :-)
First, it's not entirely straightforward to pull numbers in this matter to
show that the registration mechanism is so much more efficient that more
complex code and a dependency to an external service are warranted.
Second, in the worst case the registrar would have to inform every
registrant upon receiving a SSDP message via some IPC mechanism anyway.
Third, UPnP discovery is lightweight compared to the description phase,
action invocation and eventing, so I'm not sure caching the results of
discovery alone will have any meaningful impact on a large scale. I say
this because if an application is interested in SSDP messages it is
probably interested of UPnP in general, which includes action invocation
and eventing. You can't really cache these and incidentally these two are
potentially far worse resource consumers.
> Though HAL/Solid isn't any better here, both also don't offer any kind of
> active search/query (cmp. view in database), if I looked correctly
> (DeviceNotifier reports simply about all devices), so wake up all of the
> processes.
>
> Still no numbers. And these might be small. But all those small numbers
add up :)
Indeed they do and I'm not saying that you shouldn't consider the little
details. I'm just not sure if devising a cache mechanism for UPnP
discovery will provide any true benefit.
In any case, here's some numbers and background information about the UPnP
discovery for the interested.
To discover all UPnP devices on a network a control point usually sends
1-3 UDP messages to the 239.255.255.250 multicast address. A single
message is enough, but more may be sent due to the unreliable nature of
UDP. Each UPnP root device in turn should respond *directly* to the
control point with 3+2d+k UDP messages, where 'd' is the number of
embedded devices and 'k' is the number of distinct service types within a
device tree. Often UPnP devices do not have any embedded devices and
contain only a few services. But again, the datagrams may be sent more
than once due to the unreliable nature of the protocol.
On the other hand, a UPnP device has to announce itself to the network
using the said multicast address when it becomes online. After that it has
to repeat the announcements periodically before they expire until it goes
offline, which it also has to announce. A root UPnP device announces
itself, its embedded devices and distinct service types similar to the
response it sends to a discovery issued by a control point. The interval
between the repeated announcements seems to be quite often something
around 5-15 minutes, although the UPnP device architecture specification
instructs to use values greater than or equal to 30 minutes.
A typical discovery request is around 125 bytes in size and a typical
response to that or an "alive announcement" is between 300 and 400 bytes.
It is important to note that control points should perform discovery only
when they enter network, since devices are required by the UDA
specification to announce their presence as outlined above.
>> > In my opinion, even the description
>> > phase doesn't add that much of network load that I'd want to pay the
>> > price of added complexity, which the inter-process caching solution
>> > introduces.
>>
>> Fair enough, let's avoid premature optimization. And it's all buried in
>> the backend anyway so it's not like we're going to break BC later on if
>> we introduce complexity for the optimizations.
My thoughts exactly.
> Currently KDE software basically will be a client to services from UPnP
> devices (being control point in UPnP terms). So if there is a convenience
> lib one should be just for client stuff IMHO. Server stuff should be
handled
> by a different lib. I suppose that code for server stuff is larger and
would
> just be unneeded payload for most applications (also in disk size).
> (not sure how the P2P situation with mobile devices proves me wrong here)
>
> We also wouldn't put http server stuff into the http access lib, would we?
Actually, that's not entirely true. UPnP eventing requires a control point
to listen for asynchronous events published by UPnP devices. The protocol
is called "GENA", which is layered above HTTP and it requires minimal HTTP
servers on both sides. In addition, I wouldn't say that the server stuff
is larger or more complex compared to a proper control point. In many ways
a UPnP device is actually more straightforward to implement compared to a
control point that implements the UPnP stack in full and provides some
type of an API for users.
The HUPnP shared library is about 1.2 megabytes built on my 64 bit kubuntu
machine. I haven't optimized for the binary size yet, so there could be
some leeway. The object codes for control point and upnp device
functionality are roughly equal in size and they actually share quite a
bit of the code base, including the "device model" users code against on
client and server side. Taking purely the server stuff out would probably
yield a save of 300-350 kilobytes. Certainly, purely UPnP device (server)
stuff isn't required at a client that is purely a control point. On the
other hand, there are valid use-cases where a client application will need
both the server and client code. For instance, there could be a device or
an application that is both a media renderer (a UPnP device) and a control
point. The control point fetches the content from a media server and uses
the built-in media renderer to render the content.
> Doing the discovery in a proxy/cache not only avoids work duplication
> (increase of resource needs per process), it has also the advantage to be
> faster (cache). And it is done for other discovery systems, too: There is
> Avahi for DNS-SD, as a central small proxy process (our code layer to it
> is KDNSSD).
It could be faster if properly implemented, I agree, but are such
(possibly very small) gains in speed in this particular area worth the
trouble? Furthermore, if the work to be done is very small the benefits of
avoiding it tend to be very small as well... ;) I'd still be inclined to
properly profile and test the need for such a system before actually doing
it. :)
>
>> > By the way, if any of you have ideas or feature requests for HUPnP, or
>> > feedback in general, this is a good chance to influence the
>> development
>> > before the API & ABI is locked for the first major release. I'd
>> > appreciate your comments.
>
> Would like to give you some more comments, but please accept my limited
> time and find my ideas/thoughts in these emails :)
Of course, I did and I thank you. Some interesting thoughts there to which
I enjoyed answering. :)
Regards,
Tuomo
More information about the Kde-hardware-devel
mailing list