I'm not so sure this is the right way around. because serial ports are not automatic we should use the user to our advantage:<br><br>Instead of probing the port for hardware you have in hal the fact that there is a serial port (I'm sure this is in the bios some place, abut what IRQ ect for what serial port) on the computer should be made available in HAL.
<br><br>Then my program can see there is a serial port and allow the user to select the device connected to the port. having the ability to create new device definitions will be important and allowing the probing to then take place on a device by device selection basis.
<br><br>Once selected my program modified HAL (create a new node) and saves an fdi file for that serial port saying what the child node is model, manufacturer, name, capabilities anything you want (not sure if this is possible in HAL but it should be)
<br><br>another program listening to hal can pick up on the changes and probe the serial port further if it wishes. modem software ect can see the device by it's capabilities and use it.<br><br>What do you all think?<br><br>
Best Regards, Martin Owens<br><br><div><span class="gmail_quote">On 9/7/06, <b class="gmail_sendername">David Zeuthen</b> <<a href="mailto:david@fubar.dk">david@fubar.dk</a>> wrote:</span><blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">
<br>Hi,<br><br>Sorry for the lag, I was on vacation,<br><br>On Thu, 2006-08-31 at 13:47 +0200, Arnaud Quette wrote:<br>> > This is easy to provide for e.g. NUT, it simply includes a HAL FDI<br>> > file that looks somewhat like this
<br>> ><br>> > <deviceinfo version="0.2"><br>> > <device><br>> > <match key="legacy_port.type" string="serial">
<br>> > <append key="legacy_port.probers.type" type="strlist">nut-serial-ups</append><br>> > <append key="legacy_port.probers.capabilities" type="strlist">
battery.ups</append><br>> > <append key="legacy_port.probers.programs" type="strlist">nut-hal-serial-prober</append><br>> > </match>
<br>> > </device><br>> > </deviceinfo><br>><br>> there is a big problem here:<br>> NUT can't provide a generic serial prober since there are far too many<br>
> protocols, and issuing some wrong protocol commands might have bad<br>> effect on wrong UPS.<br><br>Good point. It might not even be a UPS; it might be a modem or something<br>else that one of the probers touch. Something I forgot, need to be very
<br>careful here. It's fixable though.<br><br><br>> so the only thing we (NUT) can do is to provide a list in which the<br>> user will pick his mfr/model, and then launch the right driver in<br>> probe mode to see if the device is there.
<br><br>Right, ok, so we introduce a new infrastructure to have each prober<br>return a list of device id's, e.g. the NUT serial prober would return<br><br> "Ablerex MS-RT",<br> "AEC MiniGuard UPS 700 Megatec M2501 cable",
<br> "APC Back-UPS RS 500 custom non-USB cable",<br> ...<br><br>which are strings that can be presented to the user (pretty sure we just<br>want to ditch i18n here). It's important to note that these device id's
<br>are completely opaque to HAL itself though they will appear in end-user<br>UI.<br><br><br>> Note that this probe mode is not yet implemented, though it can be<br>> easily done. It's simply a "-p" flag that cause the driver to exit
<br>> after the driver discovery function (upsdrv_initinfo()), printing out<br>> mfr/model info or some magic if nothing was detected...<br>><br>> > 3. With the legacy_port.* properties we can now provide a sane UI
<br>> > (both API and UI-wise) to provide probing for serial devices. Said<br>> > configuration programs would look at legacy_port.probers.<br>> > capabilities which contains well-defined HAL capabilities that can
<br>> > be translated into the users language. So in addition to the<br>> > legacy_port capability we'd export an interface with methods called<br>> ><br>> > org.freedesktop.Hal.Device.LegacyPort
<br>> ><br>> > with methods<br>> ><br>> > UnconfigurePort()<br>> ><br>> > to simply unconfigure a port and,<br><br>We'd want a new method here<br><br> GetSupportedDevices (IN int proberNumber, OUT string[] deviceIds)
<br><br>that returns the list of device id's. Note that we could use HAL device<br>properties to carry this information but it would be a lot of<br>information and it's not something one needs in .fdi files to match on<br>
so retrieving through a method call is fine I suppose.<br><br>Implementation-wise this just call the prober program with the option<br>--get-list-of-supported-device-id or something and the prober program<br>prints these to stdout, one line at a time.
<br><br>> ><br>> > ConfigurePort (IN int proberNumber)<br>> > throws AlreadConfiguredException,<br>> > NoSuchProberException,<br>> > ProberDidNotFindDeviceException
<br>> ><br><br>Now, this method would be<br><br> ConfigurePort (IN int proberNumber, IN string deviceId)<br><br>where deviceId is an item from GetSupportedDevices().<br><br>> > where the latter method, ConfigurePort, will try to run the
<br>> > requested prober. If that fails (e.g. return code is != 0) then<br>> > this exception is thrown. If it succeeds, then the properties<br>> > legacy_port.is_configured and legacy_port.configured_type
<br>> > is set accordingly.<br><br><snip><br><br>> > 4. To preserve the value of the properties<br>> ><br>> > legacy_port.is_configured,<br>> > legacy_port.configured_type
<br>> ><br>> > across HAL restarts, the ConfigurePort() method simply saves<br>> > the values somewhere in /var/run/hald/blah and we have a callout<br>> > on the device object pick them up. The file name chosen to save
<br>> > it under will include system.product and system.product from the<br>> > /o/fd/Hal/d/computer object to satisfy requirement f) above.<br><br>We also want legacy_port.configured_device_id so we remember this.
<br><br>> you will have an MGE unit soon, with both USB and serial connection ;-)<br><br>Sounds good, saw that, thanks!<br><br>> one more important thought:<br>> nut drivers generally need some more config param. Ie some generic
<br>> drivers (like genericups, a generic dry contact UPS driver) need a<br>> mandatory upstype to know which serial pin match which UPS signal (ie<br>> DCD = low battery).<br><br>Can't this be solved by just have a lot of generic entries in the device
<br>id list, e.g.<br><br> "Generic UPS (DCD = low battery)"<br> "Generic UPS (DST = low battery)"<br> ...<br><br>and so on? That way, we'll only have to poke the user for one option,<br>namely the device id.
<br><br>> we have 2 choices here:<br>><br>> 1) rely upon the nut config files to define detailed options.<br>><br>> - the below things are based on the new NUT config format and tools,<br>> not yet available in the trunk, but from the JD-NewConf branch and
<br>> scheduled for nut 2.2<br>> - the config is in the form:<br>> mode = "pm"<br>> ups.myups (<br>> <a href="http://driver.name">driver.name</a> = genericups<br>> driver.parameter.port
= /dev/ttyS0<br>> driver.parameter.upstype = 1<br>> )<br>><br>> - it only requires the ups section name ("myups" here) on the HAL<br>> side, then the nut driver will take care of finding its info to run.
<br>> Ie<br>> - the HAL config is in the form:<br>> <deviceinfo version="0.2"><br>> <device><br>> <match key="legacy_port.configured_type" contains="nut-serial-ups">
<br>> <append key="info.addons"<br>> type="strlist">hald-addon-genericups</append><br>> <append key="info.addons.ups-name" type="int">myups</append>
<br>> </match><br>> </device><br>> </deviceinfo><br>><br>> - the addon has to be called using "addon-name -a ups-name"<br><br>With this proposal it would simply just read
<br><br> legacy_port.configured_device_id<br><br>which is exported in the environment too.<br><br>> - the NUT compat list (drivers.list) include the mandatory parameters<br>> for the exact model, if any or none otherwise.
<br>> ie the right upstype for genericups:<br>> "mfr" "model" "" "genericups upstype=1"<br>><br>> - NUT provides libupsconfig to configure things easilly (ie
<br>> configuring in pm-Power Management mode for a serial unit is few lines<br>> of code):<br>> > new_config();<br>> > set_mode("pm");<br>> > add_ups("myups", "genericups", "/dev/ttyS0");
<br>> > set_driver_parameter("upstype", "1", string_type);<br>> > save_config(destination, comments_template, 1, error_handler);<br>><br>> -everything has been prepared by Jonathan Dion, during his internship
<br>> at MGE (ending today), to deal with such a case,<br>> - this leaves all the UPS specifics outside of HAL, and is IMO the<br>> best approach, though it has to be generic (ie gpsd must also have the<br>> same approach?). This is also the simplest approach for the nut
<br>> driver, since the same config code is used.<br>><br>><br>> 2) Store things in the HAL file, ie:<br>><br>> - the hal config is in the form:<br>> <deviceinfo version="0.2"><br>
> <device><br>> <match key="legacy_port.configured_type" contains="nut-serial-ups"><br>> <append key="info.addons"<br>> type="strlist">hald-addon-genericups</append>
<br>> <append key="info.addons.upstype" type="int">1</append><br>> </match><br>> </device><br>> </deviceinfo><br>><br>
> - that implies g-p-m (or other apps) will manages that format<br>> - it has the advantage to centralise config things, but the<br>> disadvantage to need some specific code in the nut drivers to read<br>> this, though is simply some hal_get queries.
<br><br>I'd like the interface between serial probers and HAL to be as simple as<br>possible so doing 1) would be preferable. So, to recap, from the HAL<br>point of view, the serial prober needs to perform two functions.<br>
<br> 1) give a list of supported device id's<br><br> 2) given a device id, look if a device is on the port<br><br>For 2), we can assume that the user have been instructed that he should<br>only push the "probe for device" button in the UI if he is certain the
<br>device is supported. Ie. that it's a dangerous operation.<br><br>How does this sound?<br><br>Cheers,<br>David<br><br><br>_______________________________________________<br>hal mailing list<br><a href="mailto:hal@lists.freedesktop.org">
hal@lists.freedesktop.org</a><br><a href="http://lists.freedesktop.org/mailman/listinfo/hal">http://lists.freedesktop.org/mailman/listinfo/hal</a><br></blockquote></div><br>