'\" t .\" Title: blazer_usb .\" Author: [see the "AUTHORS" section] .\" Generator: DocBook XSL Stylesheets vsnapshot .\" Date: 05/20/2024 .\" Manual: NUT Manual .\" Source: Network UPS Tools 2.8.2 .\" Language: English .\" .TH "BLAZER_USB" "8" "05/20/2024" "Network UPS Tools 2\&.8\&.2" "NUT Manual" .\" ----------------------------------------------------------------- .\" * Define some portability stuff .\" ----------------------------------------------------------------- .\" ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ .\" http://bugs.debian.org/507673 .\" http://lists.gnu.org/archive/html/groff/2009-02/msg00013.html .\" ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ .ie \n(.g .ds Aq \(aq .el .ds Aq ' .\" ----------------------------------------------------------------- .\" * set default formatting .\" ----------------------------------------------------------------- .\" disable hyphenation .nh .\" disable justification (adjust text to left margin only) .ad l .\" ----------------------------------------------------------------- .\" * MAIN CONTENT STARTS HERE * .\" ----------------------------------------------------------------- .SH "NAME" blazer_usb \- Driver for Megatec/Q1 protocol USB based UPS equipment .SH "SYNOPSIS" .sp \fBblazer_usb\fR \-h .sp \fBblazer_usb\fR \-a \fIUPS_NAME\fR [\fIOPTIONS\fR] .SH "NOTE" .sp This man page only documents the hardware\-specific features of the blazer driver\&. For information about the core driver, see \fBnutupsdrv\fR(8)\&. .SH "NOTE" .sp Please note that this driver is deprecated and will not receive new development\&. If it works for managing your devices \(em fine, but if you are running it to try setting up a new device, please consider the newer \fBnutdrv_qx\fR(8) instead, which should handle all \fIQ*\fR protocol variants for NUT\&. .sp Please do also report if your device works with this driver, but \fBnutdrv_qx\fR(8) would not actually support it with any subdriver! .SH "SUPPORTED HARDWARE" .sp The blazer driver is known to work with various UPSes from Blazer, Energy Sistem, Fenton Technologies, General Electric, Mustek and many others\&. The NUT compatibility table lists all the known supported models\&. Keep in mind, however, that other models not listed there may also be supported, but haven\(cqt been tested\&. .sp All devices with a serial interface (use the \fBblazer_ser\fR driver) and many with a USB interface (use the \fBblazer_usb\fR driver) are supported\&. .SH "EXTRA ARGUMENTS" .sp You may need to override or provide defaults for some values, depending on the make and model of your UPS\&. The following are the ones that most likely will need changing (see \fBups.conf\fR(5)): .PP \fBdefault\&.battery\&.voltage\&.high =\fR \fIvalue\fR .RS 4 Maximum battery voltage that is reached after about 12 to 24 hours charging\&. If you want the driver to report a guesstimated \fBbattery\&.charge\fR, you need to specify this (see BATTERY CHARGE GUESSTIMATION)\&. .RE .PP \fBdefault\&.battery\&.voltage\&.low =\fR \fIvalue\fR .RS 4 Minimum battery voltage just before the UPS automatically shuts down\&. If you want the driver to report a guesstimated \fBbattery\&.charge\fR, you need to specify this (see BATTERY CHARGE GUESSTIMATION)\&. .RE .PP \fBdefault\&.battery\&.voltage\&.nominal =\fR \fIvalue\fR, \fBoverride\&.battery\&.voltage\&.nominal =\fR \fIvalue\fR .RS 4 Some devices show a wrong nominal battery voltage (or none at all), so you may need to override or set a default value\&. .RE .PP \fBoverride\&.battery\&.packs =\fR \fIvalue\fR .RS 4 Some devices report a part of the total battery voltage\&. For instance, if \fBbattery\&.voltage\&.nominal\fR is 24 V, but it reports a \fBbattery\&.voltage\fR of around 2 V, the number of \fBbattery\&.packs\fR to correct this reading would be 12\&. The driver will attempt to detect this automatically, but if this fails somehow, you may want to override this value\&. .RE .PP \fBondelay =\fR \fIvalue\fR .RS 4 Time to wait before switching on the UPS (minutes)\&. Note that a value below 3 minutes, may cause earlier firmware versions to not switch on automatically, so it defaults to 3 minutes\&. The acceptable range is 0\&.\&.9999 minutes\&. .RE .PP \fBoffdelay =\fR \fIvalue\fR .RS 4 Time to wait before shutting down the UPS (seconds)\&. This value is truncated to units of 6 seconds (less than 60 seconds) or 60 seconds (more than 60 seconds)\&. Defaults to 30 seconds\&. The acceptable range is 12\&.\&.600 seconds\&. .RE .PP \fBnorating\fR .RS 4 Some UPSes will lock up if you attempt to read rating information from them\&. Setting this flag will make the driver skip this step\&. .RE .PP \fBnovendor\fR .RS 4 Some UPSes will lock up if you attempt to read vendor information from them\&. Setting this flag will make the driver skip this step\&. .RE .PP \fBprotocol =\fR \fIstring\fR .RS 4 Skip autodetection of the protocol to use and only use the one specified\&. Supported values \fImegatec\fR, \fImegatec/old\fR, \fImustek\fR and \fIzinto\fR\&. .RE .PP \fBruntimecal =\fR \fIvalue,value,value,value\fR .RS 4 Parameter used in the (optional) runtime estimation\&. This takes two runtimes at different loads\&. Typically, this uses the runtime at full load and the runtime at half load\&. For instance, if your UPS has a rated runtime of 240 seconds at full load and 720 seconds at half load, you would enter .sp .if n \{\ .RS 4 .\} .nf runtimecal = 240,100,720,50 .fi .if n \{\ .RE .\} .sp The first load should always be higher than the second\&. If you have values available for loads other than 100 and 50 % respectively, you can use those too, but keep them spaced apart as far as reasonably possible\&. Just don\(cqt get too close to no load (prediction of runtime depends more on idle load for the battery then)\&. .RE .PP \fBchargetime =\fR \fIvalue\fR .RS 4 The time needed to fully recharge the battery after being fully discharged\&. If not specified, the driver defaults to 43200 seconds (12 hours)\&. Only used if \fBruntimecal\fR is also specified\&. .RE .PP \fBidleload =\fR \fIvalue\fR .RS 4 Minimum battery load used by the driver to estimate the runtime\&. If not specified, the driver defaults to 10%\&. Only used if \fBruntimecal\fR is also specified\&. .RE .SS "USB INTERFACE ONLY" .PP \fBport =\fR \fIstring\fR .RS 4 Some \fIvalue\fR must be set, typically \fBauto\fR\&. .if n \{\ .sp .\} .RS 4 .it 1 an-trap .nr an-no-space-flag 1 .nr an-break-flag 1 .br .ps +1 \fBNote\fR .ps -1 .br This could be a device filesystem path like /dev/usb/hiddev0 but current use of libusb API precludes knowing and matching by such identifiers\&. They may also be inherently unreliable (dependent on re\-plugging and enumeration order)\&. At this time the actual \fIvalue\fR is ignored, but syntactically some \fIport\fR configuration must still be there\&. .sp .5v .RE .RE .sp It is possible to control multiple UPS units simultaneously by running several instances of this driver, provided they can be uniquely distinguished by setting some combination of the \fBvendor\fR, \fBproduct\fR, \fBvendorid\fR, \fBproductid\fR, \fBserial\fR, \fBbus\fR and/or \fBdevice\fR options detailed below\&. For devices or operating systems that do not provide sufficient information, the \fBallow_duplicates\fR option can be of use (limited and risky!) .PP \fBvendorid =\fR \fIregex\fR, \fBproductid =\fR \fIregex\fR, \fBvendor =\fR \fIregex\fR, \fBproduct =\fR \fIregex\fR, \fBserial =\fR \fIregex\fR .RS 4 Select a specific UPS, in case there is more than one connected via USB\&. Each option specifies an extended regular expression (see \fBregex(7)\fR for more information on regular expressions), which must match the UPS\(cqs entire respective vendor/product/serial string (minus any surrounding whitespace), or the whole 4\-digit hexadecimal code for vendorid and productid\&. .sp Try \fBlsusb(8)\fR or running this NUT driver with \fB\-DD\fR command\-line argument for finding out the strings to match\&. .sp Examples: .sp .RS 4 .ie n \{\ \h'-04'\(bu\h'+03'\c .\} .el \{\ .sp -1 .IP \(bu 2.3 .\} \-x vendor="Foo\&.Corporation\&.*" .RE .sp .RS 4 .ie n \{\ \h'-04'\(bu\h'+03'\c .\} .el \{\ .sp -1 .IP \(bu 2.3 .\} \-x vendorid="051d*" (APC) .RE .sp .RS 4 .ie n \{\ \h'-04'\(bu\h'+03'\c .\} .el \{\ .sp -1 .IP \(bu 2.3 .\} \-x product="\&.*(Smart|Back)\-?UPS\&.*" .RE .RE .PP \fBbus =\fR \fIregex\fR .RS 4 Select a UPS on a specific USB bus or group of buses\&. The argument is a regular expression that must match the bus name where the UPS is connected (e\&.g\&. bus="002" or bus="00[2\-3]") as seen on Linux in /sys/bus/usb/devices or \fBlsusb(8)\fR; including leading zeroes\&. .RE .PP \fBdevice =\fR \fIregex\fR .RS 4 Select a UPS on a specific USB device or group of devices\&. The argument is a regular expression that must match the device name where the UPS is connected (e\&.g\&. device="001" or device="00[1\-2]") as seen on Linux in /sys/bus/usb/devices or \fBlsusb(8)\fR; including leading zeroes\&. .if n \{\ .sp .\} .RS 4 .it 1 an-trap .nr an-no-space-flag 1 .nr an-break-flag 1 .br .ps +1 \fBNote\fR .ps -1 .br device numbers are not guaranteed by the OS to be stable across re\-boots or device re\-plugging\&. .sp .5v .RE .RE .PP \fBbusport =\fR \fIregex\fR .RS 4 If supported by the hardware, OS and libusb on the particular deployment, this option should allow to specify physical port numbers on an USB hub, rather than logical device enumeration values, and in turn \(em this should be less volatile across reboots or re\-plugging\&. The value may be seen in the USB topology output of lsusb \-tv on systems with that tool, for example\&. .if n \{\ .sp .\} .RS 4 .it 1 an-trap .nr an-no-space-flag 1 .nr an-break-flag 1 .br .ps +1 \fBNote\fR .ps -1 .br this option is not practically supported by some NUT builds (it should be ignored with a warning then), and not by all systems that NUT can run on\&. .sp .5v .RE .RE .PP \fBallow_duplicates\fR .RS 4 If you have several UPS devices which may not be uniquely identified by the options above (e\&.g\&. only VID:PID can be discovered there), this flag allows each driver instance where it is set to take the first match if available, or proceed to try another\&. .sp Normally the driver initialization would abort at this point claiming "Resource busy" or similar error, assuming that the otherwise properly matched device is unique \(em and some other process already handles it\&. .if n \{\ .sp .\} .RS 4 .it 1 an-trap .nr an-no-space-flag 1 .nr an-break-flag 1 .br .ps +1 \fBWarning\fR .ps -1 .br This feature is inherently non\-deterministic! The association of driver instance name to actual device may vary between runs! .sp If you only care to know that \fBat least\fR one of your no\-name UPSes is online, this option can help\&. .sp If you must really know \fBwhich\fR one, it will not! .sp .5v .RE .RE .PP \fBusb_set_altinterface =\fR \fIbAlternateSetting\fR .RS 4 Force redundant call to usb_set_altinterface(), especially if needed for devices serving multiple USB roles where the UPS is not represented by the interface number 0 (default)\&. .RE .PP \fBusb_config_index\fR, \fBusb_hid_rep_index\fR, \fBusb_hid_desc_index\fR, \fBusb_hid_ep_in\fR, \fBusb_hid_ep_out\fR .RS 4 Force use of specific interface, endpoint, descriptor index etc\&. numbers, rather than defaulting to 0 (rarely other values in certain drivers for some devices known to use non\-zero numbers)\&. Specified as a hexadecimal number\&. .sp As a rule of thumb for usb_hid_desc_index discovery, you can see larger wDescriptorLength values (roughly 600+ bytes) in reports of lsusb or similar tools\&. .RE .PP \fBsubdriver =\fR \fIstring\fR .RS 4 Select a serial\-over\-USB subdriver to use\&. You have a choice between \fBphoenix\fR, \fBippon\fR, \fBcypress\fR, and \fBkrauler\fR\&. When using this option, it is mandatory to also specify the \fBvendorid\fR and \fBproductid\fR\&. .RE .PP \fBlangid_fix =\fR \fIvalue\fR .RS 4 Apply the language ID workaround to the krauler subdriver\&. This is mandatory for some devices to work (LDLC, Dynamix and others)\&. You must to provide \fBvalue\fR (0x409 or 0x4095), according to your device entry in NUT hardware compatibility list (HCL)\&. .RE .SH "UPS COMMANDS" .sp This driver supports some instant commands (see \fBupscmd\fR(8)): .PP \fBbeeper\&.toggle\fR .RS 4 Toggle the UPS beeper\&. (Not available on some hardware\&.) .RE .PP \fBload\&.on\fR .RS 4 Turn on the load immediately\&. .RE .PP \fBload\&.off\fR .RS 4 Turn off the load immediately (see KNOWN PROBLEMS)\&. .RE .PP \fBshutdown\&.return\fR .RS 4 Turn off the load and return when power is back\&. Uses the timers defined by \fBondelay\fR and \fBoffdelay\fR\&. .RE .PP \fBshutdown\&.stayoff\fR .RS 4 Turn off the load and remain off (see KNOWN PROBLEMS)\&. Uses the timer defined by \fBoffdelay\fR\&. .RE .PP \fBshutdown\&.stop\fR .RS 4 Stop a shutdown in progress\&. .RE .PP \fBtest\&.battery\&.start\&.deep\fR .RS 4 Perform a long battery test (Not available on some hardware\&.) .RE .PP \fBtest\&.battery\&.start\&.quick\fR .RS 4 Perform a (10 second) battery test\&. .RE .PP \fBtest\&.battery\&.start\fR \fIvalue\fR .RS 4 Perform a battery test for the duration of \fIvalue\fR minutes\&. .RE .PP \fBtest\&.battery\&.stop\fR .RS 4 Stop a running battery test (not available on some hardware\&.) .RE .SH "BATTERY CHARGE GUESSTIMATION" .sp Due to popular demand, this driver will report a guesstimated \fBbattery\&.charge\fR value and optionally \fBbattery\&.runtime\fR, provided you specified a couple of the EXTRA ARGUMENTS listed above\&. .sp If you specify both \fBbattery\&.voltage\&.high\fR and \fBbattery\&.voltage\&.low\fR in \fBups.conf\fR(5), but don\(cqt enter \fBruntimecal\fR, it will guesstimate the state of charge by looking at the battery voltage alone\&. This is not reliable under load, as this only gives reasonably accurate readings if you disconnect the load, let the battery rest for a couple of minutes and then measure the open cell voltage\&. This just isn\(cqt practical if the power went out and the UPS is providing power for your systems\&. .sp .if n \{\ .RS 4 .\} .nf battery\&.voltage \- battery\&.voltage\&.low battery\&.charge = \-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\- x 100 % battery\&.voltage\&.high \- battery\&.voltage\&.low .fi .if n \{\ .RE .\} .sp There is a way to get better readings without disconnecting the load, but this requires one to keep track on how much (and how fast) current is going in\- and out of the battery\&. If you specified the \fBruntimecal\fR, the driver will attempt to do this\&. Note however, that this heavily relies on the values you enter and that the UPS must be able to report the load as well\&. There are quite a couple of devices that report 0% (or any other fixed value) at all times, in which case this obviously doesn\(cqt work\&. .sp The driver also has no way of determining the degradation of the battery capacity over time, so you\(cqll have to deal with this yourself (by adjusting the values in \fBruntimecal\fR)\&. Also note that the driver guesses the initial state of charge based on the battery voltage, so this may be less than 100%, even when you are certain that they are full\&. There is just no way to reliably measure this between 0 and 100% full charge\&. .sp This is better than nothing (but not by much)\&. If any of the above calculations are giving you incorrect readings, remember that you are the one who put in the values in \fBups.conf\fR(5), so don\(cqt complain to the author\&. If you need something better, consider buy an UPS that reports \fBbattery\&.charge\fR and \fBbattery\&.runtime\fR all by itself without the help of a NUT driver\&. .SH "NOTES FOR THE PREVIOUS USER OF MEGATEC DRIVERS" .sp The blazer drivers having replaced the megatec ones, some configuration changes may be required by users switching to blazer\&. .sp Part of this, the following megatec options, in ups\&.conf, have to be changed: .PP \fBbattvolts\fR .RS 4 You need to use \fIdefault\&.battery\&.voltage\&.high\fR and \fIdefault\&.battery\&.voltage\&.low\fR .RE .PP \fBdtr and rts\fR .RS 4 You need to use \fIcablepower\fR .RE .PP \fBignoreoff\fR .RS 4 This parameter can simply be discarded, since it was a wrong understanding of the specification\&. .RE .SH "KNOWN PROBLEMS" .sp Some UPS commands aren\(cqt 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\(cqt even provide a way for the driver to check for this, so the unsupported commands will silently fail\&. .sp Both the \fBload\&.off\fR and \fBshutdown\&.stayoff\fR instant commands are meant to turn the load off indefinitely\&. However, some UPS models don\(cqt allow this\&. .sp Some models report a bogus value for the beeper status (will always be \fIenabled\fR or \fIdisabled\fR)\&. So, the \fBbeeper\&.toggle\fR command may appear to have no effect in the status reported by the driver when, in fact, it is working fine\&. .sp The temperature and load value is known to be bogus in some models\&. .SH "AUTHORS" .sp .RS 4 .ie n \{\ \h'-04'\(bu\h'+03'\c .\} .el \{\ .sp -1 .IP \(bu 2.3 .\} Arjen de Korte .RE .sp .RS 4 .ie n \{\ \h'-04'\(bu\h'+03'\c .\} .el \{\ .sp -1 .IP \(bu 2.3 .\} Alexander Gordeev .RE .SH "SEE ALSO" .sp \fBblazer_ser\fR(8), \fBnutupsdrv\fR(8), \fBupsc\fR(8), \fBupscmd\fR(8), \fBupsrw\fR(8) .SS "Internet Resources:" .sp .RS 4 .ie n \{\ \h'-04'\(bu\h'+03'\c .\} .el \{\ .sp -1 .IP \(bu 2.3 .\} The NUT (Network UPS Tools) home page: https://www\&.networkupstools\&.org/ .RE .sp .RS 4 .ie n \{\ \h'-04'\(bu\h'+03'\c .\} .el \{\ .sp -1 .IP \(bu 2.3 .\} The NUT HCL: https://www\&.networkupstools\&.org/stable\-hcl\&.html .RE