[PATCH v2 1/1] drm: fix alpha build after drm_util.h change
Daniel Vetter
daniel at ffwll.ch
Wed Jan 16 10:16:30 UTC 2019
On Tue, Jan 15, 2019 at 10:48:45PM +0100, Sam Ravnborg wrote:
> 0-DAY reported the following bug:
>
> tree: git://anongit.freedesktop.org/drm/drm-misc drm-misc-next
> head: 21376e2c3c5bad5e87ba700c055c8a8235c2bfd5
> commit: e9eafcb589213395232084a2378e2e90f67feb29 [1/2] drm: move drm_can_sleep() to drm_util.h
> config: alpha-allmodconfig (attached as .config)
> ...
> In file included from include/linux/irqflags.h:16:0,
> from include/drm/drm_util.h:35,
> from drivers/gpu/drm/qxl/qxl_cmd.c:28:
> >> arch/alpha/include/asm/irqflags.h:58:15: error: unknown type name 'bool'
> static inline bool arch_irqs_disabled_flags(unsigned long flags)
> ^~~~
>
> And later following bug:
> tree: git://anongit.freedesktop.org/drm/drm-misc drm-misc-next
> head: 21376e2c3c5bad5e87ba700c055c8a8235c2bfd5
> commit: e9eafcb589213395232084a2378e2e90f67feb29 [1/2] drm: move drm_can_sleep() to drm_util.h
> config: ia64-allyesconfig (attached as .config)
> ...
> In file included from arch/ia64/include/asm/irqflags.h:14,
> from include/linux/irqflags.h:16,
> from include/drm/drm_util.h:35,
> from drivers/gpu/drm/qxl/qxl_cmd.c:28:
> arch/ia64/include/asm/pal.h: In function 'ia64_pal_tr_read':
> arch/ia64/include/asm/pal.h:1703:64: error: implicit declaration of function 'ia64_tpa'; did you mean 'ia64_pal'? [-Werror=implicit-function-declaration]
> PAL_CALL_PHYS_STK(iprv, PAL_VM_TR_READ, reg_num, tr_type,(u64)ia64_tpa(tr_buffer));
> ^~~~~~~~
> ...
>
> So we have a situation where we do not pull in <linux/types.h>
> when building for alpha and for ia64 we need even more definitions
> are required.
>
> Two invasive fixes where considered:
> - Change all declarations of arch_irqs_disabled_flags() to use bool
> - Add include of <linux/types.h> to all files that uses bool for
> arch_irqs_disabled_flags
>
> To invasive with a too high pain/benefit ratio, so dropped.
> They would not cover ia64 either.
>
> Some less invasive fixes was also considered:
> - Add include of <linux/types.h> to drm_util.h
> - Add include of <linux/interrupt.h> to drm_util.h
>
> The first was dropped as this did not cover the ia64 case.
>
> The latter was considered the best option as there could
> be other similar cases and we would like the header files below
> include/drm/ to be selfcontained.
> So we end up pulling in a lot of stuff not needed, but this is
> the price we pay in drm/ because the kernel headers are not all
> selfcontained.
>
> While at it, ordred the includefiles in drm_util in alphabetical order.
>
> Build tested with alpha,ia64,arm,x86 with allmodconfig and allyesconfig.
>
> v2:
> - fix ia64 build, changed to include interrupt.h
> - sort include files alphabetically
>
> Fixes: 733748ac37b45 ("drm: move drm_can_sleep() to drm_util.h")
> Signed-off-by: Sam Ravnborg <sam at ravnborg.org>
> Cc: Maarten Lankhorst <maarten.lankhorst at linux.intel.com>
> Cc: Maxime Ripard <maxime.ripard at bootlin.com>
> Cc: Sean Paul <sean at poorly.run>
> Cc: David Airlie <airlied at linux.ie>
> Cc: Daniel Vetter <daniel at ffwll.ch>
Applied, thanks for your patch.
-Daniel
> ---
> include/drm/drm_util.h | 4 ++--
> 1 file changed, 2 insertions(+), 2 deletions(-)
>
> diff --git a/include/drm/drm_util.h b/include/drm/drm_util.h
> index 0500da65b1d1..8163d35f8327 100644
> --- a/include/drm/drm_util.h
> +++ b/include/drm/drm_util.h
> @@ -32,9 +32,9 @@
> * Macros and inline functions that does not naturally belong in other places
> */
>
> -#include <linux/irqflags.h>
> -#include <linux/preempt.h>
> +#include <linux/interrupt.h>
> #include <linux/kgdb.h>
> +#include <linux/preempt.h>
> #include <linux/smp.h>
>
> /*
> --
> 2.12.0
>
--
Daniel Vetter
Software Engineer, Intel Corporation
http://blog.ffwll.ch
More information about the dri-devel
mailing list