Note. This driver is experimental at the moment. It is currently being worked on and may change over time. However, it is stable in execution and does what is needed.
The megatec_usb driver is known to work with various UPSes from Krauler, Agiler, and Upsonic (Ablerex interface). Others that use the Megatec protocol may work, but haven't been tested.
This driver supports the USB versions of UPSs, if you have only serial interface then use the straight megatec(8) driver.
If you find that this driver does not work, and you are sure that your hardware speaks megatec protocol, then you can easily extend this driver. However, you will need to do some analysis of the commands that are sent to the UPS. Please see the forums for discussions on this and how to extend this driver.
This driver extends the standard megatec(8) driver to work with certain UPSes that have a USB interface. These devices do not obey the normal rules for HID USB devices and therefore the newhidups(8) driver will not work for them.
This driver takes the standard serial interface and passes this over USB to the UPS. This means that most, but not all, commands available for the serial driver will work. For Krauler, Agiler, and Upsonic (with Ablerex interface) UPSes it appears to give very similar results to the serial interface. The driver supports monitoring most of the usual UPS variables, and also supports automatic shutdown.
Optional. Specify the UPS manufacturer name.
Optional. Specify the UPS model name.
Optional. Specify the UPS serial number.
Optional. Low battery level (%). Overrides the hardware default level.
Optional. Delay before the UPS is turned back on (minutes).
Optional. Delay before the UPS is turned off (minutes).
Optional. The battery voltage interval <empty:full> (volts).
Select a specific UPS, in case there is more than one connected via USB. Each option specifies an extended regular expression (see regex(7)) that must match the UPS's entire vendor/product/serial string (minus any surrounding whitespace), or the whole 4-digit hexadecimal code for vendorid and productid. Try -DD for finding out the strings to match.
-x vendorid=05b8 (Agiler)
Select a UPS on a specific USB bus or group of busses. The argument is a regular expression that must match the bus name where the UPS is connected (e.g. bus="002", bus="00[2-3]").
Select a serial-over-USB subdriver to use. You have a choice between "agiler" and "krauler" subdrivers currently.
This driver supports some extra commands (see upscmd(8)):
The behavior of the driver can be controlled by some user definable variables (see upsrw(8)):
The battery charge (%) value is only a best-effort calculation and may be incorrect, or non-existant, for some UPS models. In any case, you can always resort to finding the voltages at which the battery becomes fully discharged and fully charged, and specify them manually using the "battvolts" option. If you do this, please notify the author of this driver.
Some UPS commands aren't supported by all models. In most cases, the driver will send a message to the system log when the user tries to execute an unsupported command. Unfortunately, some models don't even provide a way for the driver to check for this, so the unsupported commands will silently fail.
Some models report a bogus value for the beeper status (will always be "enabled" or "disabled"). So, the "beeper.toggle" command may appear to have no effect in the status reported by the driver when, in fact, it is working fine.
The temperature value is also known to be bogus in some models.
megatec(8), nutupsdrv(8), upsc(8), upscmd(8), upsrw(8)