Skip to content

Commit 63c4cec

Browse files
committed
Merge tag 'drm-misc-fixes-2019-10-03' of git://anongit.freedesktop.org/drm/drm-misc into drm-fixes
- One include fix for tilcdc - A clock fix for OMAP - A memory leak fix for Komeda - Some fixes for resources cleanups with writeback Signed-off-by: Dave Airlie <[email protected]> From: Maxime Ripard <[email protected]> Link: https://patchwork.freedesktop.org/patch/msgid/20191003081031.oykms5fg4tijvdri@gilmour
2 parents 0f83eb8 + b6559bf commit 63c4cec

File tree

8 files changed

+36
-23
lines changed

8 files changed

+36
-23
lines changed

drivers/gpu/drm/arm/display/komeda/komeda_wb_connector.c

Lines changed: 4 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -43,9 +43,8 @@ komeda_wb_encoder_atomic_check(struct drm_encoder *encoder,
4343
struct komeda_data_flow_cfg dflow;
4444
int err;
4545

46-
if (!writeback_job || !writeback_job->fb) {
46+
if (!writeback_job)
4747
return 0;
48-
}
4948

5049
if (!crtc_st->active) {
5150
DRM_DEBUG_ATOMIC("Cannot write the composition result out on a inactive CRTC.\n");
@@ -166,8 +165,10 @@ static int komeda_wb_connector_add(struct komeda_kms_dev *kms,
166165
&komeda_wb_encoder_helper_funcs,
167166
formats, n_formats);
168167
komeda_put_fourcc_list(formats);
169-
if (err)
168+
if (err) {
169+
kfree(kwb_conn);
170170
return err;
171+
}
171172

172173
drm_connector_helper_add(&wb_conn->base, &komeda_wb_conn_helper_funcs);
173174

drivers/gpu/drm/arm/malidp_mw.c

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -131,7 +131,7 @@ malidp_mw_encoder_atomic_check(struct drm_encoder *encoder,
131131
struct drm_framebuffer *fb;
132132
int i, n_planes;
133133

134-
if (!conn_state->writeback_job || !conn_state->writeback_job->fb)
134+
if (!conn_state->writeback_job)
135135
return 0;
136136

137137
fb = conn_state->writeback_job->fb;
@@ -248,7 +248,7 @@ void malidp_mw_atomic_commit(struct drm_device *drm,
248248

249249
mw_state = to_mw_state(conn_state);
250250

251-
if (conn_state->writeback_job && conn_state->writeback_job->fb) {
251+
if (conn_state->writeback_job) {
252252
struct drm_framebuffer *fb = conn_state->writeback_job->fb;
253253

254254
DRM_DEV_DEBUG_DRIVER(drm->dev,

drivers/gpu/drm/drm_atomic.c

Lines changed: 9 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -430,10 +430,15 @@ static int drm_atomic_connector_check(struct drm_connector *connector,
430430
return -EINVAL;
431431
}
432432

433-
if (writeback_job->out_fence && !writeback_job->fb) {
434-
DRM_DEBUG_ATOMIC("[CONNECTOR:%d:%s] requesting out-fence without framebuffer\n",
435-
connector->base.id, connector->name);
436-
return -EINVAL;
433+
if (!writeback_job->fb) {
434+
if (writeback_job->out_fence) {
435+
DRM_DEBUG_ATOMIC("[CONNECTOR:%d:%s] requesting out-fence without framebuffer\n",
436+
connector->base.id, connector->name);
437+
return -EINVAL;
438+
}
439+
440+
drm_writeback_cleanup_job(writeback_job);
441+
state->writeback_job = NULL;
437442
}
438443

439444
return 0;

drivers/gpu/drm/drm_writeback.c

Lines changed: 15 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -324,6 +324,9 @@ void drm_writeback_cleanup_job(struct drm_writeback_job *job)
324324
if (job->fb)
325325
drm_framebuffer_put(job->fb);
326326

327+
if (job->out_fence)
328+
dma_fence_put(job->out_fence);
329+
327330
kfree(job);
328331
}
329332
EXPORT_SYMBOL(drm_writeback_cleanup_job);
@@ -366,25 +369,29 @@ drm_writeback_signal_completion(struct drm_writeback_connector *wb_connector,
366369
{
367370
unsigned long flags;
368371
struct drm_writeback_job *job;
372+
struct dma_fence *out_fence;
369373

370374
spin_lock_irqsave(&wb_connector->job_lock, flags);
371375
job = list_first_entry_or_null(&wb_connector->job_queue,
372376
struct drm_writeback_job,
373377
list_entry);
374-
if (job) {
378+
if (job)
375379
list_del(&job->list_entry);
376-
if (job->out_fence) {
377-
if (status)
378-
dma_fence_set_error(job->out_fence, status);
379-
dma_fence_signal(job->out_fence);
380-
dma_fence_put(job->out_fence);
381-
}
382-
}
380+
383381
spin_unlock_irqrestore(&wb_connector->job_lock, flags);
384382

385383
if (WARN_ON(!job))
386384
return;
387385

386+
out_fence = job->out_fence;
387+
if (out_fence) {
388+
if (status)
389+
dma_fence_set_error(out_fence, status);
390+
dma_fence_signal(out_fence);
391+
dma_fence_put(out_fence);
392+
job->out_fence = NULL;
393+
}
394+
388395
INIT_WORK(&job->cleanup_work, cleanup_work);
389396
queue_work(system_long_wq, &job->cleanup_work);
390397
}

drivers/gpu/drm/omapdrm/dss/dss.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1083,7 +1083,7 @@ static const struct dss_features omap34xx_dss_feats = {
10831083

10841084
static const struct dss_features omap3630_dss_feats = {
10851085
.model = DSS_MODEL_OMAP3,
1086-
.fck_div_max = 32,
1086+
.fck_div_max = 31,
10871087
.fck_freq_max = 173000000,
10881088
.dss_fck_multiplier = 1,
10891089
.parent_clk_name = "dpll4_ck",

drivers/gpu/drm/rcar-du/rcar_du_writeback.c

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -147,7 +147,7 @@ static int rcar_du_wb_enc_atomic_check(struct drm_encoder *encoder,
147147
struct drm_device *dev = encoder->dev;
148148
struct drm_framebuffer *fb;
149149

150-
if (!conn_state->writeback_job || !conn_state->writeback_job->fb)
150+
if (!conn_state->writeback_job)
151151
return 0;
152152

153153
fb = conn_state->writeback_job->fb;
@@ -221,7 +221,7 @@ void rcar_du_writeback_setup(struct rcar_du_crtc *rcrtc,
221221
unsigned int i;
222222

223223
state = rcrtc->writeback.base.state;
224-
if (!state || !state->writeback_job || !state->writeback_job->fb)
224+
if (!state || !state->writeback_job)
225225
return;
226226

227227
fb = state->writeback_job->fb;

drivers/gpu/drm/tilcdc/tilcdc_tfp410.c

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -7,6 +7,7 @@
77
#include <linux/gpio.h>
88
#include <linux/mod_devicetable.h>
99
#include <linux/of_gpio.h>
10+
#include <linux/pinctrl/consumer.h>
1011
#include <linux/platform_device.h>
1112

1213
#include <drm/drm_atomic_helper.h>

drivers/gpu/drm/vc4/vc4_txp.c

Lines changed: 2 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -231,7 +231,7 @@ static int vc4_txp_connector_atomic_check(struct drm_connector *conn,
231231
int i;
232232

233233
conn_state = drm_atomic_get_new_connector_state(state, conn);
234-
if (!conn_state->writeback_job || !conn_state->writeback_job->fb)
234+
if (!conn_state->writeback_job)
235235
return 0;
236236

237237
crtc_state = drm_atomic_get_new_crtc_state(state, conn_state->crtc);
@@ -271,8 +271,7 @@ static void vc4_txp_connector_atomic_commit(struct drm_connector *conn,
271271
u32 ctrl;
272272
int i;
273273

274-
if (WARN_ON(!conn_state->writeback_job ||
275-
!conn_state->writeback_job->fb))
274+
if (WARN_ON(!conn_state->writeback_job))
276275
return;
277276

278277
mode = &conn_state->crtc->state->adjusted_mode;

0 commit comments

Comments
 (0)