[1/2] xfree86: Fallback to first platform device as primary

Submitted by Thierry Reding on June 25, 2014, 1:49 p.m.

Details

Message ID 1403704186-31148-2-git-send-email-thierry.reding@gmail.com
State Accepted
Headers show

Not browsing as part of any series.

Commit Message

Thierry Reding June 25, 2014, 1:49 p.m.
From: Thierry Reding <treding@nvidia.com>

When neither of the various bus implementations was able to find a
primary bus and device, fallback to using the platform bus as primary
bus and the first platform device as primary device.

Signed-off-by: Thierry Reding <treding@nvidia.com>
---
 hw/xfree86/common/xf86Bus.c         |  3 +++
 hw/xfree86/common/xf86platformBus.c | 17 +++++++++++++++++
 hw/xfree86/common/xf86platformBus.h |  1 +
 3 files changed, 21 insertions(+)

Patch hide | download patch | download mbox

diff --git a/hw/xfree86/common/xf86Bus.c b/hw/xfree86/common/xf86Bus.c
index b3b3f8cc524b..bd3e4e37bbb3 100644
--- a/hw/xfree86/common/xf86Bus.c
+++ b/hw/xfree86/common/xf86Bus.c
@@ -210,6 +210,9 @@  xf86BusProbe(void)
 #if (defined(__sparc__) || defined(__sparc)) && !defined(__OpenBSD__)
     xf86SbusProbe();
 #endif
+#ifdef XSERVER_PLATFORM_BUS
+    xf86platformPrimary();
+#endif
 }
 
 /*
diff --git a/hw/xfree86/common/xf86platformBus.c b/hw/xfree86/common/xf86platformBus.c
index dd118a28565b..467b26b1de1a 100644
--- a/hw/xfree86/common/xf86platformBus.c
+++ b/hw/xfree86/common/xf86platformBus.c
@@ -560,4 +560,21 @@  void xf86platformVTProbe(void)
         xf86PlatformReprobeDevice(i, xf86_platform_devices[i].attribs);
     }
 }
+
+void xf86platformPrimary(void)
+{
+    /* use the first platform device as a fallback */
+    if (primaryBus.type == BUS_NONE) {
+        xf86Msg(X_INFO, "no primary bus or device found\n");
+
+        if (xf86_num_platform_devices > 0) {
+            char *syspath = xf86_get_platform_attrib(0, ODEV_ATTRIB_SYSPATH);
+
+            xf86Msg(X_NONE, "\tfalling back to %s\n", syspath);
+
+            primaryBus.id.plat = &xf86_platform_devices[0];
+            primaryBus.type = BUS_PLATFORM;
+        }
+    }
+}
 #endif
diff --git a/hw/xfree86/common/xf86platformBus.h b/hw/xfree86/common/xf86platformBus.h
index 5dee4e0e029a..dec1956489fd 100644
--- a/hw/xfree86/common/xf86platformBus.h
+++ b/hw/xfree86/common/xf86platformBus.h
@@ -77,6 +77,7 @@  extern _X_EXPORT int
 xf86PlatformMatchDriver(char *matches[], int nmatches);
 
 extern void xf86platformVTProbe(void);
+extern void xf86platformPrimary(void);
 #endif
 
 #endif

Comments

On Wed, Jun 25, 2014 at 9:49 AM, Thierry Reding
<thierry.reding@gmail.com> wrote:
> From: Thierry Reding <treding@nvidia.com>
>
> When neither of the various bus implementations was able to find a
> primary bus and device, fallback to using the platform bus as primary
> bus and the first platform device as primary device.
>
> Signed-off-by: Thierry Reding <treding@nvidia.com>

Reviewed-by: Rob Clark <robdclark@gmail.com>
Tested-by: Rob Clark <robdclark@gmail.com>

> ---
>  hw/xfree86/common/xf86Bus.c         |  3 +++
>  hw/xfree86/common/xf86platformBus.c | 17 +++++++++++++++++
>  hw/xfree86/common/xf86platformBus.h |  1 +
>  3 files changed, 21 insertions(+)
>
> diff --git a/hw/xfree86/common/xf86Bus.c b/hw/xfree86/common/xf86Bus.c
> index b3b3f8cc524b..bd3e4e37bbb3 100644
> --- a/hw/xfree86/common/xf86Bus.c
> +++ b/hw/xfree86/common/xf86Bus.c
> @@ -210,6 +210,9 @@ xf86BusProbe(void)
>  #if (defined(__sparc__) || defined(__sparc)) && !defined(__OpenBSD__)
>      xf86SbusProbe();
>  #endif
> +#ifdef XSERVER_PLATFORM_BUS
> +    xf86platformPrimary();
> +#endif
>  }
>
>  /*
> diff --git a/hw/xfree86/common/xf86platformBus.c b/hw/xfree86/common/xf86platformBus.c
> index dd118a28565b..467b26b1de1a 100644
> --- a/hw/xfree86/common/xf86platformBus.c
> +++ b/hw/xfree86/common/xf86platformBus.c
> @@ -560,4 +560,21 @@ void xf86platformVTProbe(void)
>          xf86PlatformReprobeDevice(i, xf86_platform_devices[i].attribs);
>      }
>  }
> +
> +void xf86platformPrimary(void)
> +{
> +    /* use the first platform device as a fallback */
> +    if (primaryBus.type == BUS_NONE) {
> +        xf86Msg(X_INFO, "no primary bus or device found\n");
> +
> +        if (xf86_num_platform_devices > 0) {
> +            char *syspath = xf86_get_platform_attrib(0, ODEV_ATTRIB_SYSPATH);
> +
> +            xf86Msg(X_NONE, "\tfalling back to %s\n", syspath);
> +
> +            primaryBus.id.plat = &xf86_platform_devices[0];
> +            primaryBus.type = BUS_PLATFORM;
> +        }
> +    }
> +}
>  #endif
> diff --git a/hw/xfree86/common/xf86platformBus.h b/hw/xfree86/common/xf86platformBus.h
> index 5dee4e0e029a..dec1956489fd 100644
> --- a/hw/xfree86/common/xf86platformBus.h
> +++ b/hw/xfree86/common/xf86platformBus.h
> @@ -77,6 +77,7 @@ extern _X_EXPORT int
>  xf86PlatformMatchDriver(char *matches[], int nmatches);
>
>  extern void xf86platformVTProbe(void);
> +extern void xf86platformPrimary(void);
>  #endif
>
>  #endif
> --
> 2.0.0
>
On Wed, Jun 25, 2014 at 9:49 AM, Thierry Reding
<thierry.reding@gmail.com> wrote:
> From: Thierry Reding <treding@nvidia.com>
>
> When neither of the various bus implementations was able to find a
> primary bus and device, fallback to using the platform bus as primary
> bus and the first platform device as primary device.
>
> Signed-off-by: Thierry Reding <treding@nvidia.com>

Reviewed-by: Rob Clark <robdclark@gmail.com>
Tested-by: Rob Clark <robdclark@gmail.com>

> ---
>  hw/xfree86/common/xf86Bus.c         |  3 +++
>  hw/xfree86/common/xf86platformBus.c | 17 +++++++++++++++++
>  hw/xfree86/common/xf86platformBus.h |  1 +
>  3 files changed, 21 insertions(+)
>
> diff --git a/hw/xfree86/common/xf86Bus.c b/hw/xfree86/common/xf86Bus.c
> index b3b3f8cc524b..bd3e4e37bbb3 100644
> --- a/hw/xfree86/common/xf86Bus.c
> +++ b/hw/xfree86/common/xf86Bus.c
> @@ -210,6 +210,9 @@ xf86BusProbe(void)
>  #if (defined(__sparc__) || defined(__sparc)) && !defined(__OpenBSD__)
>      xf86SbusProbe();
>  #endif
> +#ifdef XSERVER_PLATFORM_BUS
> +    xf86platformPrimary();
> +#endif
>  }
>
>  /*
> diff --git a/hw/xfree86/common/xf86platformBus.c b/hw/xfree86/common/xf86platformBus.c
> index dd118a28565b..467b26b1de1a 100644
> --- a/hw/xfree86/common/xf86platformBus.c
> +++ b/hw/xfree86/common/xf86platformBus.c
> @@ -560,4 +560,21 @@ void xf86platformVTProbe(void)
>          xf86PlatformReprobeDevice(i, xf86_platform_devices[i].attribs);
>      }
>  }
> +
> +void xf86platformPrimary(void)
> +{
> +    /* use the first platform device as a fallback */
> +    if (primaryBus.type == BUS_NONE) {
> +        xf86Msg(X_INFO, "no primary bus or device found\n");
> +
> +        if (xf86_num_platform_devices > 0) {
> +            char *syspath = xf86_get_platform_attrib(0, ODEV_ATTRIB_SYSPATH);
> +
> +            xf86Msg(X_NONE, "\tfalling back to %s\n", syspath);
> +
> +            primaryBus.id.plat = &xf86_platform_devices[0];
> +            primaryBus.type = BUS_PLATFORM;
> +        }
> +    }
> +}
>  #endif
> diff --git a/hw/xfree86/common/xf86platformBus.h b/hw/xfree86/common/xf86platformBus.h
> index 5dee4e0e029a..dec1956489fd 100644
> --- a/hw/xfree86/common/xf86platformBus.h
> +++ b/hw/xfree86/common/xf86platformBus.h
> @@ -77,6 +77,7 @@ extern _X_EXPORT int
>  xf86PlatformMatchDriver(char *matches[], int nmatches);
>
>  extern void xf86platformVTProbe(void);
> +extern void xf86platformPrimary(void);
>  #endif
>
>  #endif
> --
> 2.0.0
>
op 25-06-14 15:49, Thierry Reding schreef:
> From: Thierry Reding <treding@nvidia.com>
>
> When neither of the various bus implementations was able to find a
> primary bus and device, fallback to using the platform bus as primary
> bus and the first platform device as primary device.
>
Looks sane, I believe we already had similar patches in ubuntu to the same effect. :-)

~Maarten