diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2016-01-17 13:40:25 -0800 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2016-01-17 13:40:25 -0800 | 
| commit | 984065055e6e39f8dd812529e11922374bd39352 (patch) | |
| tree | a8f1bcbd81e0fadce0cef39ab5ce09ab84b261fe /drivers/gpu/drm/imx/imx-drm-core.c | |
| parent | 12768c1e2c83b05ea1658470045789a14b6edf4c (diff) | |
| parent | 1df59b8497f47495e873c23abd6d3d290c730505 (diff) | |
Merge branch 'drm-next' of git://people.freedesktop.org/~airlied/linux
Pull drm updates from Dave Airlie:
 "This is the main drm pull request for 4.5.  I don't think I've missed
  anything too major, I'm mostly back at work now but I'll probably get
  some sleep in 5 years time.
  Summary:
  New drivers:
   - etnaviv:
     GPU driver for the 3D core on the Vivante core used in numerous
     ARM boards.
  Highlights:
  Core:
   - Atomic suspend/resume helpers
   - Move the headers to using userspace friendlier types.
   - Documentation updates
   - Lots of struct_mutex removal.
   - Bunch of DP MST fixes from AMD.
  Panel:
   - More DSI helpers
   - Support for some new basic panels
  i915:
   - Basic Kabylake support
   - DP link training and detect code refactoring
   - fbc/psr fixes
   - FIFO underrun fixes
   - SDE interrupt handling fixes
   - dma-buf/fence support in pageflip path.
   - GPU side for MST audio support
  radeon/amdgpu:
   - Drop UMS support
   - GPUVM/Scheduler optimisations
   - Initial Powerplay support for Tonga/Fiji/CZ/ST
   - ACP audio prerequisites
  nouveau:
   - GK20a instmem improvements
   - PCIE link speed change support
  msm:
   - DSI support for msm8960/apq8064
  tegra:
   - Host1X support for Tegra210 SoC
  vc4:
   - 3D acceleration support
  armada:
   - Get rid of struct mutex
  tda998x:
   - Atomic modesetting support
   - TMDS clock limitations
  omapdrm:
   - Atomic modesetting support
   - improved TILER performance
  rockchip:
   - RK3036 VOP support
   - Atomic modesetting support
   - Synopsys DW MIPI DSI support
  exynos:
   - Runtime PM support
   - of_graph binding for DP panels
   - Cleanup of IPP code
   - Configurable plane support
   - Kernel panic fixes at release time"
* 'drm-next' of git://people.freedesktop.org/~airlied/linux: (711 commits)
  drm/fb_cma_helper: Remove implicit call to disable_unused_functions
  drm/amdgpu: add missing irq.h include
  drm/vmwgfx: Fix a width / pitch mismatch on framebuffer updates
  drm/vmwgfx: Fix an incorrect lock check
  drm: nouveau: fix nouveau_debugfs_init prototype
  drm/nouveau/pci: fix check in nvkm_pcie_set_link
  drm/amdgpu: validate duplicates first
  drm/amdgpu: move VM page tables to the LRU end on CS v2
  drm/ttm: add ttm_bo_move_to_lru_tail function v2
  drm/ttm: fix adding foreign BOs to the swap LRU
  drm/ttm: fix adding foreign BOs to the LRU during init v2
  drm/radeon: use kobj_to_dev()
  drm/amdgpu: use kobj_to_dev()
  drm/amdgpu/cz: force vce clocks when sclks are forced
  drm/amdgpu/cz: force uvd clocks when sclks are forced
  drm/amdgpu/cz: add code to enable forcing VCE clocks
  drm/amdgpu/cz: add code to enable forcing UVD clocks
  drm/amdgpu: fix lost sync_to if scheduler is enabled.
  drm/amd/powerplay: fix static checker warning for return meaningless value.
  drm/sysfs: use kobj_to_dev()
  ...
Diffstat (limited to 'drivers/gpu/drm/imx/imx-drm-core.c')
| -rw-r--r-- | drivers/gpu/drm/imx/imx-drm-core.c | 26 | 
1 files changed, 13 insertions, 13 deletions
| diff --git a/drivers/gpu/drm/imx/imx-drm-core.c b/drivers/gpu/drm/imx/imx-drm-core.c index 882cf3d4b7a8..2f57d7967417 100644 --- a/drivers/gpu/drm/imx/imx-drm-core.c +++ b/drivers/gpu/drm/imx/imx-drm-core.c @@ -39,13 +39,12 @@ struct imx_drm_component {  struct imx_drm_device {  	struct drm_device			*drm;  	struct imx_drm_crtc			*crtc[MAX_CRTC]; -	int					pipes; +	unsigned int				pipes;  	struct drm_fbdev_cma			*fbhelper;  };  struct imx_drm_crtc {  	struct drm_crtc				*crtc; -	int					pipe;  	struct imx_drm_crtc_helper_funcs	imx_drm_helper_funcs;  }; @@ -54,9 +53,9 @@ static int legacyfb_depth = 16;  module_param(legacyfb_depth, int, 0444);  #endif -int imx_drm_crtc_id(struct imx_drm_crtc *crtc) +unsigned int imx_drm_crtc_id(struct imx_drm_crtc *crtc)  { -	return crtc->pipe; +	return drm_crtc_index(crtc->crtc);  }  EXPORT_SYMBOL_GPL(imx_drm_crtc_id); @@ -124,19 +123,19 @@ EXPORT_SYMBOL_GPL(imx_drm_set_bus_format);  int imx_drm_crtc_vblank_get(struct imx_drm_crtc *imx_drm_crtc)  { -	return drm_vblank_get(imx_drm_crtc->crtc->dev, imx_drm_crtc->pipe); +	return drm_crtc_vblank_get(imx_drm_crtc->crtc);  }  EXPORT_SYMBOL_GPL(imx_drm_crtc_vblank_get);  void imx_drm_crtc_vblank_put(struct imx_drm_crtc *imx_drm_crtc)  { -	drm_vblank_put(imx_drm_crtc->crtc->dev, imx_drm_crtc->pipe); +	drm_crtc_vblank_put(imx_drm_crtc->crtc);  }  EXPORT_SYMBOL_GPL(imx_drm_crtc_vblank_put);  void imx_drm_handle_vblank(struct imx_drm_crtc *imx_drm_crtc)  { -	drm_handle_vblank(imx_drm_crtc->crtc->dev, imx_drm_crtc->pipe); +	drm_crtc_handle_vblank(imx_drm_crtc->crtc);  }  EXPORT_SYMBOL_GPL(imx_drm_handle_vblank); @@ -215,7 +214,7 @@ static void imx_drm_output_poll_changed(struct drm_device *drm)  	drm_fbdev_cma_hotplug_event(imxdrm->fbhelper);  } -static struct drm_mode_config_funcs imx_drm_mode_config_funcs = { +static const struct drm_mode_config_funcs imx_drm_mode_config_funcs = {  	.fb_create = drm_fb_cma_create,  	.output_poll_changed = imx_drm_output_poll_changed,  }; @@ -306,6 +305,7 @@ static int imx_drm_driver_load(struct drm_device *drm, unsigned long flags)  		dev_warn(drm->dev, "Invalid legacyfb_depth.  Defaulting to 16bpp\n");  		legacyfb_depth = 16;  	} +	drm_helper_disable_unused_functions(drm);  	imxdrm->fbhelper = drm_fbdev_cma_init(drm, legacyfb_depth,  				drm->mode_config.num_crtc, MAX_CRTC);  	if (IS_ERR(imxdrm->fbhelper)) { @@ -356,12 +356,11 @@ int imx_drm_add_crtc(struct drm_device *drm, struct drm_crtc *crtc,  		return -ENOMEM;  	imx_drm_crtc->imx_drm_helper_funcs = *imx_drm_helper_funcs; -	imx_drm_crtc->pipe = imxdrm->pipes++;  	imx_drm_crtc->crtc = crtc;  	crtc->port = port; -	imxdrm->crtc[imx_drm_crtc->pipe] = imx_drm_crtc; +	imxdrm->crtc[imxdrm->pipes++] = imx_drm_crtc;  	*new_crtc = imx_drm_crtc; @@ -373,12 +372,12 @@ int imx_drm_add_crtc(struct drm_device *drm, struct drm_crtc *crtc,  			imx_drm_crtc->imx_drm_helper_funcs.crtc_helper_funcs);  	drm_crtc_init_with_planes(drm, crtc, primary_plane, NULL, -			imx_drm_crtc->imx_drm_helper_funcs.crtc_funcs); +			imx_drm_crtc->imx_drm_helper_funcs.crtc_funcs, NULL);  	return 0;  err_register: -	imxdrm->crtc[imx_drm_crtc->pipe] = NULL; +	imxdrm->crtc[--imxdrm->pipes] = NULL;  	kfree(imx_drm_crtc);  	return ret;  } @@ -390,10 +389,11 @@ EXPORT_SYMBOL_GPL(imx_drm_add_crtc);  int imx_drm_remove_crtc(struct imx_drm_crtc *imx_drm_crtc)  {  	struct imx_drm_device *imxdrm = imx_drm_crtc->crtc->dev->dev_private; +	unsigned int pipe = drm_crtc_index(imx_drm_crtc->crtc);  	drm_crtc_cleanup(imx_drm_crtc->crtc); -	imxdrm->crtc[imx_drm_crtc->pipe] = NULL; +	imxdrm->crtc[pipe] = NULL;  	kfree(imx_drm_crtc); | 
