Merge branch 'msm-fixes-3.15-rc3' of git://people.freedesktop.org/~robclark/linux into drm-next
Fixes for msm for 3.15.. a memory leak fix for devices using vram carveout instead of iommu. Plus I think finally managed to sort out / workaround some cursor vs underflow issues. And small fbcon tweak needed to avoid extra full-modesets at boot. * 'msm-fixes-3.15-rc3' of git://people.freedesktop.org/~robclark/linux: drm/msm/mdp4: cure for the cursor blues (v2) drm/msm: default to XR24 rather than AR24 drm/msm: fix memory leak
This commit is contained in:
@@ -510,9 +510,8 @@ static void update_cursor(struct drm_crtc *crtc)
|
|||||||
MDP4_DMA_CURSOR_BLEND_CONFIG_CURSOR_EN);
|
MDP4_DMA_CURSOR_BLEND_CONFIG_CURSOR_EN);
|
||||||
} else {
|
} else {
|
||||||
/* disable cursor: */
|
/* disable cursor: */
|
||||||
mdp4_write(mdp4_kms, REG_MDP4_DMA_CURSOR_BASE(dma), 0);
|
mdp4_write(mdp4_kms, REG_MDP4_DMA_CURSOR_BASE(dma),
|
||||||
mdp4_write(mdp4_kms, REG_MDP4_DMA_CURSOR_BLEND_CONFIG(dma),
|
mdp4_kms->blank_cursor_iova);
|
||||||
MDP4_DMA_CURSOR_BLEND_CONFIG_FORMAT(CURSOR_ARGB));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* and drop the iova ref + obj rev when done scanning out: */
|
/* and drop the iova ref + obj rev when done scanning out: */
|
||||||
@@ -574,11 +573,9 @@ static int mdp4_crtc_cursor_set(struct drm_crtc *crtc,
|
|||||||
|
|
||||||
if (old_bo) {
|
if (old_bo) {
|
||||||
/* drop our previous reference: */
|
/* drop our previous reference: */
|
||||||
msm_gem_put_iova(old_bo, mdp4_kms->id);
|
drm_flip_work_queue(&mdp4_crtc->unref_cursor_work, old_bo);
|
||||||
drm_gem_object_unreference_unlocked(old_bo);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
crtc_flush(crtc);
|
|
||||||
request_pending(crtc, PENDING_CURSOR);
|
request_pending(crtc, PENDING_CURSOR);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|||||||
@@ -70,12 +70,12 @@ irqreturn_t mdp4_irq(struct msm_kms *kms)
|
|||||||
|
|
||||||
VERB("status=%08x", status);
|
VERB("status=%08x", status);
|
||||||
|
|
||||||
|
mdp_dispatch_irqs(mdp_kms, status);
|
||||||
|
|
||||||
for (id = 0; id < priv->num_crtcs; id++)
|
for (id = 0; id < priv->num_crtcs; id++)
|
||||||
if (status & mdp4_crtc_vblank(priv->crtcs[id]))
|
if (status & mdp4_crtc_vblank(priv->crtcs[id]))
|
||||||
drm_handle_vblank(dev, id);
|
drm_handle_vblank(dev, id);
|
||||||
|
|
||||||
mdp_dispatch_irqs(mdp_kms, status);
|
|
||||||
|
|
||||||
return IRQ_HANDLED;
|
return IRQ_HANDLED;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -144,6 +144,10 @@ static void mdp4_preclose(struct msm_kms *kms, struct drm_file *file)
|
|||||||
static void mdp4_destroy(struct msm_kms *kms)
|
static void mdp4_destroy(struct msm_kms *kms)
|
||||||
{
|
{
|
||||||
struct mdp4_kms *mdp4_kms = to_mdp4_kms(to_mdp_kms(kms));
|
struct mdp4_kms *mdp4_kms = to_mdp4_kms(to_mdp_kms(kms));
|
||||||
|
if (mdp4_kms->blank_cursor_iova)
|
||||||
|
msm_gem_put_iova(mdp4_kms->blank_cursor_bo, mdp4_kms->id);
|
||||||
|
if (mdp4_kms->blank_cursor_bo)
|
||||||
|
drm_gem_object_unreference(mdp4_kms->blank_cursor_bo);
|
||||||
kfree(mdp4_kms);
|
kfree(mdp4_kms);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -372,6 +376,23 @@ struct msm_kms *mdp4_kms_init(struct drm_device *dev)
|
|||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
mutex_lock(&dev->struct_mutex);
|
||||||
|
mdp4_kms->blank_cursor_bo = msm_gem_new(dev, SZ_16K, MSM_BO_WC);
|
||||||
|
mutex_unlock(&dev->struct_mutex);
|
||||||
|
if (IS_ERR(mdp4_kms->blank_cursor_bo)) {
|
||||||
|
ret = PTR_ERR(mdp4_kms->blank_cursor_bo);
|
||||||
|
dev_err(dev->dev, "could not allocate blank-cursor bo: %d\n", ret);
|
||||||
|
mdp4_kms->blank_cursor_bo = NULL;
|
||||||
|
goto fail;
|
||||||
|
}
|
||||||
|
|
||||||
|
ret = msm_gem_get_iova(mdp4_kms->blank_cursor_bo, mdp4_kms->id,
|
||||||
|
&mdp4_kms->blank_cursor_iova);
|
||||||
|
if (ret) {
|
||||||
|
dev_err(dev->dev, "could not pin blank-cursor bo: %d\n", ret);
|
||||||
|
goto fail;
|
||||||
|
}
|
||||||
|
|
||||||
return kms;
|
return kms;
|
||||||
|
|
||||||
fail:
|
fail:
|
||||||
|
|||||||
@@ -44,6 +44,10 @@ struct mdp4_kms {
|
|||||||
struct clk *lut_clk;
|
struct clk *lut_clk;
|
||||||
|
|
||||||
struct mdp_irq error_handler;
|
struct mdp_irq error_handler;
|
||||||
|
|
||||||
|
/* empty/blank cursor bo to use when cursor is "disabled" */
|
||||||
|
struct drm_gem_object *blank_cursor_bo;
|
||||||
|
uint32_t blank_cursor_iova;
|
||||||
};
|
};
|
||||||
#define to_mdp4_kms(x) container_of(x, struct mdp4_kms, base)
|
#define to_mdp4_kms(x) container_of(x, struct mdp4_kms, base)
|
||||||
|
|
||||||
|
|||||||
@@ -71,11 +71,11 @@ static void mdp5_irq_mdp(struct mdp_kms *mdp_kms)
|
|||||||
|
|
||||||
VERB("status=%08x", status);
|
VERB("status=%08x", status);
|
||||||
|
|
||||||
|
mdp_dispatch_irqs(mdp_kms, status);
|
||||||
|
|
||||||
for (id = 0; id < priv->num_crtcs; id++)
|
for (id = 0; id < priv->num_crtcs; id++)
|
||||||
if (status & mdp5_crtc_vblank(priv->crtcs[id]))
|
if (status & mdp5_crtc_vblank(priv->crtcs[id]))
|
||||||
drm_handle_vblank(dev, id);
|
drm_handle_vblank(dev, id);
|
||||||
|
|
||||||
mdp_dispatch_irqs(mdp_kms, status);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
irqreturn_t mdp5_irq(struct msm_kms *kms)
|
irqreturn_t mdp5_irq(struct msm_kms *kms)
|
||||||
|
|||||||
@@ -62,11 +62,8 @@ static int msm_fbdev_create(struct drm_fb_helper *helper,
|
|||||||
dma_addr_t paddr;
|
dma_addr_t paddr;
|
||||||
int ret, size;
|
int ret, size;
|
||||||
|
|
||||||
/* only doing ARGB32 since this is what is needed to alpha-blend
|
|
||||||
* with video overlays:
|
|
||||||
*/
|
|
||||||
sizes->surface_bpp = 32;
|
sizes->surface_bpp = 32;
|
||||||
sizes->surface_depth = 32;
|
sizes->surface_depth = 24;
|
||||||
|
|
||||||
DBG("create fbdev: %dx%d@%d (%dx%d)", sizes->surface_width,
|
DBG("create fbdev: %dx%d@%d (%dx%d)", sizes->surface_width,
|
||||||
sizes->surface_height, sizes->surface_bpp,
|
sizes->surface_height, sizes->surface_bpp,
|
||||||
|
|||||||
@@ -118,8 +118,10 @@ static void put_pages(struct drm_gem_object *obj)
|
|||||||
|
|
||||||
if (iommu_present(&platform_bus_type))
|
if (iommu_present(&platform_bus_type))
|
||||||
drm_gem_put_pages(obj, msm_obj->pages, true, false);
|
drm_gem_put_pages(obj, msm_obj->pages, true, false);
|
||||||
else
|
else {
|
||||||
drm_mm_remove_node(msm_obj->vram_node);
|
drm_mm_remove_node(msm_obj->vram_node);
|
||||||
|
drm_free_large(msm_obj->pages);
|
||||||
|
}
|
||||||
|
|
||||||
msm_obj->pages = NULL;
|
msm_obj->pages = NULL;
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user