| Commit message (Collapse) | Author | Age | Files | Lines |
|
|
|
| |
So we can see the backtraces for all the crashing tests.
|
|
|
|
|
| |
So we can use that to catch crashes instead of monitoring the whole test
session.
|
| |
|
| |
|
|
|
|
|
| |
Use the device name as model name when the user-chosen device name is available.
This matches what the Bluez backend does.
|
|
|
|
|
| |
Seems like using $(pwd) got broken with newer gitlab versions. Just use
the CI_PROJECT_DIR (though we could also just use '.' even).
|
|
|
|
|
|
|
|
|
|
|
|
| |
Commit 1550d50f ("linux: Remove "usb" subsystem match") broke detection of
some idevices, since it left just the "usbmisc" subsystem match while some
idevice / kernel combinations (at least an iPhone 11 on a 6.0 kernel) don't
present any such udev usbmisc devices.
However, they do present "usb" subsystem ones, so add this match back.
Leave idevice detection also for the "usbmisc" match since that's what the
original (known working) code before aforementioned commit did - it is
possible that it is required for some kernel / idevice combinations.
|
|
|
|
|
|
|
|
|
|
|
| |
up-enumerator-udev.c forgot to include the build config file, resulting in
HAVE_IDEVICE macro always being undefined.
This meant that the idevice backend was never actually instantiated - as
evidenced by the file not even compiling when this was fixed, due to
missing "up-device-idevice.h" include.
Fix both of these issues.
|
|
|
|
| |
Fixes: #208
|
| |
|
|
|
|
| |
As a real mouse would.
|
|
|
|
| |
So we can use, one, the other, or both, and still see a single device.
|
|
|
|
|
|
|
|
|
|
|
|
| |
A lot of newer Logitech devices support both the BATT Bluetooth LE
service as well the HID++ protocol. This advertises 2 separate battery
interfaces, one HID++ one through the kernel, one BATT one through
BlueZ.
Avoid confusing UIs and hide the Bluetooth battery from the interface by
checking for duplicates each time a new device is added.
Closes: #166
|
| |
|
|
|
|
|
| |
Now that we can unregister devices from the bus, make sure that we don't
throw warnings doing that.
|
|
|
|
| |
Otherwise all the following devices will be ignored.
|
|
|
|
|
|
|
|
|
| |
Add up_device_unregister() method to allow backends to hide particular
UpDevices from the D-Bus interface.
Also rename the private up_device_register_device() function, no need to
say "device" twice there, we're registering the only device passed as an
argument.
|
|
|
|
|
| |
This might end up spamming users. Best leave those messages to folks who
are interested in root-causing those problems.
|
| |
|
|
|
|
|
|
| |
Build crash catcher "catchsegv"[1] in CI.
[1]: https://github.com/zatrazz/glibc-tools
|
|
|
|
|
|
|
|
|
|
| |
Newer development versions of libgudev now strip the linefeeds by
themselves, so fix our naive linefeed-stripping which munched on the
last character of the string if there was no linefeed.
Could not find a percentage for capacity level 'Ful'
See https://gitlab.gnome.org/GNOME/libgudev/-/merge_requests/26
|
|
|
|
|
|
| |
This fixes the serial number not being set on Bluetooth devices which
might not have a serial number but should always have a Bluetooth
address to differentiate them.
|
|
|
|
|
|
| |
We were correctly handling an "Alias" property changing, but never
passed the property to that code as we were dropping anything that
wasn't a battery related update.
|
|
|
|
|
|
|
|
|
|
| |
otherwise the native build on openbsd complains:
../src/openbsd/up-backend.c:278:23: warning: variable 'new_state' is uninitialized when used here [-Wuninitialized]
new_time_to_empty = (new_state == UP_DEVICE_STATE_DISCHARGING && a.minutes_left > 0 ? a.minutes_left : 0);
^~~~~~~~~
regression from 8be73b98 ?
|
|
|
|
| |
regression from the refactoring in bd488fac
|
|
|
|
|
|
| |
The version number has been bumped to be able to maintain multiple
branches without conflict. This version bump is not associated with a
API/ABI break.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
This switches to always use the power/current reading if we had a
sensible reading at some point in the past.
In contrast to the older UPower code, will will however ignore the
reading for 10 seconds after a discontinuity (power plug/unplug or
resume) unless we read an explicit zero value after the event happened.
We do this under the assumption that the readings may be wildly off, and
it is better to not show an estimate rather than one that is wildly
incorrect.
Note that this commit also normalises negative power readings while
discharging to be positive.
Closes: #199
|
|
|
|
|
|
|
| |
Estimation code can request a battery poll if the value is not good
enough at the point. Make this a little bit more explicit by renaming
the intenral variable to "repoll_needed" and automatically resetting it
to FALSE.
|
|
|
|
|
|
|
| |
The up_device_battery_estimate function did more than just estimating
the current power consumption (and doing some state guessing). Move the
time to full/empty checking out of the function. Also, let it directly
modify the reported state before it is pushed into the ring-buffer.
|
| |
|
|
|
|
|
|
|
|
|
|
|
|
| |
When polling is resumed the timeout needs to be reevaluated. This
requires running the polling handler once (in the next mainloop
iteration).
Set the ready time to zero to ensure this is happening. Without this, we
would be stuck without actually polling until we get a uevent from the
kernel on one of the power supplies.
Fixes: #198
|
|
|
|
| |
It now has its own repository.
|
| |
|
| |
|
|
|
|
|
|
|
|
|
| |
When a battery is swapped the old history needs to be saved and the
other history should be loaded.
Change the code to load the history lazily when needed. Then, to reload,
we purely need to clear the history object and it'll be loaded again
when required.
|
|
|
|
|
|
|
|
|
|
|
| |
It seems that the test was still flaky, the reason for that would be
that we did not explicitly wait for the log line saying that the
aggregate state was calculated.
The only reason that it did not consistently fail appears to be that
searching for the state conflict caused messages to be skipped. That is
wrong, we should account for every "Calculating percentage" message to
ensure that upowerd and the test is in sync.
|
| |
|
|
|
|
|
| |
It appears this is an old property name. The string does not appear
anywhere in the Linux kernel as of 5.18.0.
|
|
|
|
|
|
|
|
| |
Assuming we have some estimation for the current battery capacity (i.e.
percentage), we can infer a FULL/EMPTY state. Do so if the battery state
is unknown.
Related: #196
|
|
|
|
| |
See: #196
|
|
|
|
|
|
|
|
|
|
|
| |
This should be quite robust, in particular as we should be getting
notifications about AC plug/unplug.
The value for the battery will lag a few seconds. However, the
DisplayDevice will do some guessing taking the AC state into account,
and as such the user should get at least some immediate feedback.
Closes: #196
|
|
|
|
|
|
| |
This makes the switch. There are a few behaviour changes with regard to
estimations (which hopefully got both simpler and more robust at the
same time).
|
|
|
|
|
| |
This split the functionality found in UpDeviceSupply to handle batteries
out and is based on the previously added UpDeviceBattery class.
|
|
|
|
| |
This class can handle laptop battery related quirks and estimations.
|
|
|
|
|
| |
This ensures that all idle handlers have run and we report a consistent
state on the bus.
|
|
|
|
|
| |
Otherwise the fast repolling can get in-between, cause extra logging and
trigger a failure.
|
|
|
|
|
|
| |
We keep giving people these commands for bug triaging. So, lets hope
that adding them to the README removes some of the overhead and can be
helpful to users.
|
|
|
|
|
|
| |
The state guessing code based on the AC state was not tested well.
Improve the test by testing both 1 and 2 batteries and checking the
reported state in more detail.
|
|
|
|
|
|
|
| |
There is no reason to not guess the state if the device has no AC power
and there is more than one battery. Remove the corresponding constraint.
Related: #146
|
|
|
|
|
|
|
|
|
| |
Otherwise we may not have the percentage to work with, rendering the
guessing useless. This also moves the time estimation down (after the
state guessing) and does it unconditionally. This is, however, not an
issue, as the calculation matches with other places.
Related: #146
|