[PATCH v2 00/25] drm: fb emulation: Step 1: Create new drm_fb_helper wrapper funcs

Archit Taneja architt at codeaurora.org
Tue Jul 21 23:59:36 PDT 2015


DRM drivers using drm_fb_helpers still call some fbdev core functions.
This makes the driver depend on CONFIG_FB, resulting in complicated
Kconfig options, and preventing us from creating a top level drm config
option to enable/disable FBDEV emulation.

Create new drm_fb_helper functions that replace these fbdev functions.

In most cases, the new helper funcs simply wrap around the original fbdev
functions. For a few (like framebufer_alloc), we actually do some work
that is currently redundant across multiple drivers.

With these patches, the drivers don't call any fbdev functions directly.
They are now called through functions in drm_fb_helper.c. We will later
create a fbdev emulation config option to stub out the fb helpers.

The only exception is vmwgfx driver. This doesn't use drm_fb_helper. It
creates a fb device how a driver in drivers/video/fbdev would. Maybe this
needs to be converted to use drm_fb_helpers.

For more info, have a look at the threads:
http://lists.freedesktop.org/archives/dri-devel/2015-March/078729.html
http://lists.freedesktop.org/archives/dri-devel/2015-March/078975.html

v2:
- Remove if (info) checks in fb_sys functions
- Use 'if (fb_helper && fb_helper->fbdev)' checks where appropriate
- Add kerneldocs for the new helper funcs
- Follow drm way of aligning of arguments in func definitions
- Fixed build error in drm/virtio
- Fixed error cleanup path in drm/tegra
- Fixed build error in drm/rockchip
- Fixed return issue in drm/amdgpu
- Fixed 'unused variable' warnings in bochs, ast, udl and radeon
- Fixed stray goto labels in cirrus, exynos, mgag

Archit Taneja (25):
  drm/fb_helper: Add drm_fb_helper functions to manage fb_info creation
  drm/fb_helper: Create a wrapper for unlink_framebuffer
  drm/fb_helper: Create wrappers for fb_sys_read/write funcs
  drm/fb_helper: Create wrappers for blit, copyarea and fillrect funcs
  drm/fb_helper: Create a wrapper for fb_set_suspend
  drm/fb_helper: Create a wrapper for remove_conflicting_framebuffers
  drm/cirrus: Use new drm_fb_helper functions
  drm/rockchip: Use new drm_fb_helper functions
  drm/armada: Use new drm_fb_helper functions
  drm/ast: Use new drm_fb_helper functions
  drm/omap: Use new drm_fb_helper functions
  drm/tegra: Use new drm_fb_helper functions
  drm/msm: Use new drm_fb_helper functions
  drm/exynos: Use new drm_fb_helper functions
  drm/gma500: Use new drm_fb_helper functions
  drm/mgag200: Use new drm_fb_helper functions
  drm/radeon: Use new drm_fb_helper functions
  drm/qxl: Use new drm_fb_helper functions
  drm/i915: Use new drm_fb_helper functions
  drm/nouveau: Use new drm_fb_helper functions
  drm/udl: Use new drm_fb_helper functions
  drm/bochs: Use new drm_fb_helper functions
  drm/amdgpu: Use new drm_fb_helper functions
  drm/virtio: Use new drm_fb_helper functions
  drm/fb_cma_helper: Use new drm_fb_helper functions

 drivers/gpu/drm/Kconfig                       |   7 +
 drivers/gpu/drm/amd/amdgpu/amdgpu_drv.c       |   4 +-
 drivers/gpu/drm/amd/amdgpu/amdgpu_fb.c        |  45 ++----
 drivers/gpu/drm/armada/armada_fbdev.c         |  33 ++--
 drivers/gpu/drm/ast/ast_fb.c                  |  48 ++----
 drivers/gpu/drm/bochs/bochs_drv.c             |   6 +-
 drivers/gpu/drm/bochs/bochs_fbdev.c           |  36 ++---
 drivers/gpu/drm/cirrus/cirrus_drv.c           |   7 +-
 drivers/gpu/drm/cirrus/cirrus_fbdev.c         |  41 +----
 drivers/gpu/drm/drm_fb_cma_helper.c           |  45 ++----
 drivers/gpu/drm/drm_fb_helper.c               | 225 ++++++++++++++++++++++++++
 drivers/gpu/drm/exynos/exynos_drm_fbdev.c     |  47 ++----
 drivers/gpu/drm/gma500/accel_2d.c             |   6 +-
 drivers/gpu/drm/gma500/framebuffer.c          |  48 ++----
 drivers/gpu/drm/i915/i915_dma.c               |   3 +-
 drivers/gpu/drm/i915/intel_fbdev.c            |  40 ++---
 drivers/gpu/drm/mgag200/mgag200_drv.c         |   3 +-
 drivers/gpu/drm/mgag200/mgag200_fb.c          |  39 +----
 drivers/gpu/drm/mgag200/mgag200_main.c        |   2 +-
 drivers/gpu/drm/msm/msm_fbdev.c               |  34 ++--
 drivers/gpu/drm/nouveau/nouveau_drm.c         |   3 +-
 drivers/gpu/drm/nouveau/nouveau_fbcon.c       |  39 ++---
 drivers/gpu/drm/omapdrm/omap_fbdev.c          |  34 ++--
 drivers/gpu/drm/qxl/qxl_fb.c                  |  40 ++---
 drivers/gpu/drm/radeon/radeon_drv.c           |   4 +-
 drivers/gpu/drm/radeon/radeon_fb.c            |  42 ++---
 drivers/gpu/drm/rockchip/rockchip_drm_fbdev.c |  47 ++----
 drivers/gpu/drm/tegra/fb.c                    |  35 ++--
 drivers/gpu/drm/udl/udl_fb.c                  |  41 ++---
 drivers/gpu/drm/virtio/virtgpu_drm_bus.c      |   3 +-
 drivers/gpu/drm/virtio/virtgpu_drv.h          |   1 +
 drivers/gpu/drm/virtio/virtgpu_fb.c           |  32 ++--
 include/drm/drm_fb_helper.h                   |  31 ++++
 33 files changed, 508 insertions(+), 563 deletions(-)

-- 
The Qualcomm Innovation Center, Inc. is a member of the Code Aurora Forum,
hosted by The Linux Foundation



More information about the dri-devel mailing list