diff options
| -rw-r--r-- | hwdb/60-evdev.hwdb | 6 | ||||
| -rw-r--r-- | src/basic/time-util.c | 7 | ||||
| -rw-r--r-- | src/libsystemd/sd-path/sd-path.c | 9 | 
3 files changed, 18 insertions, 4 deletions
| diff --git a/hwdb/60-evdev.hwdb b/hwdb/60-evdev.hwdb index 598172256b..4f04539e12 100644 --- a/hwdb/60-evdev.hwdb +++ b/hwdb/60-evdev.hwdb @@ -98,6 +98,12 @@ evdev:name:ETPS/2 Elantech Touchpad:dmi:bvn*:bvr*:bd*:svnASUSTeKComputerInc.:pnK   EVDEV_ABS_35=::18   EVDEV_ABS_36=::16 +evdev:name:ETPS/2 Elantech Touchpad:dmi:*:svnASUSTeKCOMPUTERINC.:pnX550CC:* + EVDEV_ABS_00=::31 + EVDEV_ABS_01=::30 + EVDEV_ABS_35=::31 + EVDEV_ABS_36=::30 +  #########################################  # Dell  ######################################### diff --git a/src/basic/time-util.c b/src/basic/time-util.c index 7ca764abeb..c16460a198 100644 --- a/src/basic/time-util.c +++ b/src/basic/time-util.c @@ -47,12 +47,15 @@ static clockid_t map_clock_id(clockid_t c) {          /* Some more exotic archs (s390, ppc, …) lack the "ALARM" flavour of the clocks. Thus, clock_gettime() will           * fail for them. Since they are essentially the same as their non-ALARM pendants (their only difference is           * when timers are set on them), let's just map them accordingly. This way, we can get the correct time even on -         * those archs. */ +         * those archs. +         * +         * Also, older kernels don't support CLOCK_BOOTTIME: fall back to CLOCK_MONOTONIC. */          switch (c) { +        case CLOCK_BOOTTIME:          case CLOCK_BOOTTIME_ALARM: -                return CLOCK_BOOTTIME; +                return clock_boottime_or_monotonic ();          case CLOCK_REALTIME_ALARM:                  return CLOCK_REALTIME; diff --git a/src/libsystemd/sd-path/sd-path.c b/src/libsystemd/sd-path/sd-path.c index 480f1ad065..b7aec1f20a 100644 --- a/src/libsystemd/sd-path/sd-path.c +++ b/src/libsystemd/sd-path/sd-path.c @@ -89,7 +89,8 @@ static int from_home_dir(const char *envname, const char *suffix, char **buffer,  static int from_user_dir(const char *field, char **buffer, const char **ret) {          _cleanup_fclose_ FILE *f = NULL;          _cleanup_free_ char *b = NULL; -        const char *fn = NULL; +        _cleanup_free_ const char *fn = NULL; +        const char *c = NULL;          char line[LINE_MAX];          size_t n;          int r; @@ -98,10 +99,14 @@ static int from_user_dir(const char *field, char **buffer, const char **ret) {          assert(buffer);          assert(ret); -        r = from_home_dir(NULL, ".config/user-dirs.dirs", &b, &fn); +        r = from_home_dir("XDG_CONFIG_HOME", ".config", &b, &c);          if (r < 0)                  return r; +        fn = strappend(c, "/user-dirs.dirs"); +        if (!fn) +                return -ENOMEM; +          f = fopen(fn, "re");          if (!f) {                  if (errno == ENOENT) | 
