[PATCH libdrm 1/2] xf86drm: fallback to MODALIAS for OF less platform devices

Eric Engestrom eric.engestrom at intel.com
Wed Jan 23 11:04:24 UTC 2019


On Wednesday, 2019-01-23 10:45:17 +0000, Emil Velikov wrote:
> From: Emil Velikov <emil.velikov at collabora.com>
> 
> Some devices can lack OF data or it may not be available in the uevent
> file. Fallback to the MODALIAS data in those cases.
> 
> We strip any leading "MODALIAS=.*:" thus the resulting information is
> compatible with existing code in Mesa.
> 
> Signed-off-by: Emil Velikov <emil.velikov at collabora.com>
> ---
>  xf86drm.c | 55 ++++++++++++++++++++++++++++++++++++++++++-------------
>  1 file changed, 42 insertions(+), 13 deletions(-)
> 
> diff --git a/xf86drm.c b/xf86drm.c
> index 10df682b..374734eb 100644
> --- a/xf86drm.c
> +++ b/xf86drm.c
> @@ -3511,15 +3511,28 @@ free_device:
>  static int drmParsePlatformBusInfo(int maj, int min, drmPlatformBusInfoPtr info)
>  {
>  #ifdef __linux__
> -    char path[PATH_MAX + 1], *name;
> +    char path[PATH_MAX + 1], *name, *foo;

I assume you didn't mean to send this patch yet? :P

>  
>      snprintf(path, sizeof(path), "/sys/dev/char/%d:%d/device", maj, min);
>  
>      name = sysfs_uevent_get(path, "OF_FULLNAME");
> -    if (!name)
> -        return -ENOENT;
> +    foo = name;
> +    if (!name) {
> +        /* If the device lacks OF data, pick the MODALIAS info */
> +        name = sysfs_uevent_get(path, "MODALIAS");
> +        if (!name)
> +            return -ENOENT;
> +
> +        /* .. and strip the MODALIAS=[platform,usb...]: part. */
> +        foo = strrchr(name, ':');
> +        if (!foo) {
> +            free(name);
> +            return -ENOENT;
> +        }
> +        foo++;
> +    }
>  
> -    strncpy(info->fullname, name, DRM_PLATFORM_DEVICE_NAME_LEN);
> +    strncpy(info->fullname, foo, DRM_PLATFORM_DEVICE_NAME_LEN);
>      info->fullname[DRM_PLATFORM_DEVICE_NAME_LEN - 1] = '\0';
>      free(name);
>  
> @@ -3534,18 +3547,20 @@ static int drmParsePlatformDeviceInfo(int maj, int min,
>                                        drmPlatformDeviceInfoPtr info)
>  {
>  #ifdef __linux__
> -    char path[PATH_MAX + 1], *value;
> +    char path[PATH_MAX + 1], *value, *foo;
>      unsigned int count, i;
>      int err;
>  
>      snprintf(path, sizeof(path), "/sys/dev/char/%d:%d/device", maj, min);
>  
>      value = sysfs_uevent_get(path, "OF_COMPATIBLE_N");
> -    if (!value)
> -        return -ENOENT;
> -
> -    sscanf(value, "%u", &count);
> -    free(value);
> +    if (value) {
> +        sscanf(value, "%u", &count);
> +        free(value);
> +    } else {
> +        /* Assume one entry if the device lack OF data */
> +        count = 1;
> +    }
>  
>      info->compatible = calloc(count + 1, sizeof(*info->compatible));
>      if (!info->compatible)
> @@ -3553,12 +3568,26 @@ static int drmParsePlatformDeviceInfo(int maj, int min,
>  
>      for (i = 0; i < count; i++) {
>          value = sysfs_uevent_get(path, "OF_COMPATIBLE_%u", i);
> +        foo = value;
>          if (!value) {
> -            err = -ENOENT;
> -            goto free;
> +            /* If the device lacks OF data, pick the MODALIAS info */
> +            value = sysfs_uevent_get(path, "MODALIAS");
> +            if (!value) {
> +                err = -ENOENT;
> +                goto free;
> +            }
> +
> +            /* .. and strip the MODALIAS=[platform,usb...]: part. */
> +            foo = strrchr(value, ':');
> +            if (!foo) {
> +                free(value);
> +                return -ENOENT;
> +            }
> +            foo = strdup(foo + 1);
> +            free(value);
>          }
>  
> -        info->compatible[i] = value;
> +        info->compatible[i] = foo;
>      }
>  
>      return 0;
> -- 
> 2.20.1
> 
> _______________________________________________
> dri-devel mailing list
> dri-devel at lists.freedesktop.org
> https://lists.freedesktop.org/mailman/listinfo/dri-devel


More information about the dri-devel mailing list