Skip to content

Commit 09aea13

Browse files
kyriewu-hwmchehab
authored andcommitted
media: mtk-jpeg: refactor some variables
Refactor some variables to reduce redundancy and optimize the initialization process. Signed-off-by: kyrie wu <[email protected]> Signed-off-by: irui wang <[email protected]> Signed-off-by: Hans Verkuil <[email protected]> Signed-off-by: Mauro Carvalho Chehab <[email protected]>
1 parent 6a7a883 commit 09aea13

File tree

4 files changed

+37
-44
lines changed

4 files changed

+37
-44
lines changed

drivers/media/platform/mediatek/jpeg/mtk_jpeg_core.c

+23-8
Original file line numberDiff line numberDiff line change
@@ -1004,8 +1004,8 @@ static void mtk_jpegenc_worker(struct work_struct *work)
10041004
retry_select:
10051005
hw_id = mtk_jpegenc_get_hw(ctx);
10061006
if (hw_id < 0) {
1007-
ret = wait_event_interruptible(jpeg->enc_hw_wq,
1008-
atomic_read(&jpeg->enchw_rdy) > 0);
1007+
ret = wait_event_interruptible(jpeg->hw_wq,
1008+
atomic_read(&jpeg->hw_rdy) > 0);
10091009
if (ret != 0 || (i++ > MTK_JPEG_MAX_RETRY_TIME)) {
10101010
dev_err(jpeg->dev, "%s : %d, all HW are busy\n",
10111011
__func__, __LINE__);
@@ -1016,7 +1016,7 @@ static void mtk_jpegenc_worker(struct work_struct *work)
10161016
goto retry_select;
10171017
}
10181018

1019-
atomic_dec(&jpeg->enchw_rdy);
1019+
atomic_dec(&jpeg->hw_rdy);
10201020
src_buf = v4l2_m2m_next_src_buf(ctx->fh.m2m_ctx);
10211021
if (!src_buf)
10221022
goto getbuf_fail;
@@ -1073,7 +1073,7 @@ static void mtk_jpegenc_worker(struct work_struct *work)
10731073
v4l2_m2m_buf_done(src_buf, buf_state);
10741074
v4l2_m2m_buf_done(dst_buf, buf_state);
10751075
getbuf_fail:
1076-
atomic_inc(&jpeg->enchw_rdy);
1076+
atomic_inc(&jpeg->hw_rdy);
10771077
mtk_jpegenc_put_hw(jpeg, hw_id);
10781078
v4l2_m2m_job_finish(jpeg->m2m_dev, ctx->fh.m2m_ctx);
10791079
}
@@ -1198,8 +1198,8 @@ static void mtk_jpegdec_worker(struct work_struct *work)
11981198
retry_select:
11991199
hw_id = mtk_jpegdec_get_hw(ctx);
12001200
if (hw_id < 0) {
1201-
ret = wait_event_interruptible_timeout(jpeg->dec_hw_wq,
1202-
atomic_read(&jpeg->dechw_rdy) > 0,
1201+
ret = wait_event_interruptible_timeout(jpeg->hw_wq,
1202+
atomic_read(&jpeg->hw_rdy) > 0,
12031203
MTK_JPEG_HW_TIMEOUT_MSEC);
12041204
if (ret != 0 || (i++ > MTK_JPEG_MAX_RETRY_TIME)) {
12051205
dev_err(jpeg->dev, "%s : %d, all HW are busy\n",
@@ -1211,7 +1211,7 @@ static void mtk_jpegdec_worker(struct work_struct *work)
12111211
goto retry_select;
12121212
}
12131213

1214-
atomic_dec(&jpeg->dechw_rdy);
1214+
atomic_dec(&jpeg->hw_rdy);
12151215
src_buf = v4l2_m2m_next_src_buf(ctx->fh.m2m_ctx);
12161216
if (!src_buf)
12171217
goto getbuf_fail;
@@ -1290,7 +1290,7 @@ static void mtk_jpegdec_worker(struct work_struct *work)
12901290
v4l2_m2m_buf_done(src_buf, buf_state);
12911291
v4l2_m2m_buf_done(dst_buf, buf_state);
12921292
getbuf_fail:
1293-
atomic_inc(&jpeg->dechw_rdy);
1293+
atomic_inc(&jpeg->hw_rdy);
12941294
mtk_jpegdec_put_hw(jpeg, hw_id);
12951295
v4l2_m2m_job_finish(jpeg->m2m_dev, ctx->fh.m2m_ctx);
12961296
}
@@ -1710,6 +1710,8 @@ static int mtk_jpeg_single_core_init(struct platform_device *pdev,
17101710
static int mtk_jpeg_probe(struct platform_device *pdev)
17111711
{
17121712
struct mtk_jpeg_dev *jpeg;
1713+
struct device_node *child;
1714+
int num_child = 0;
17131715
int ret;
17141716

17151717
jpeg = devm_kzalloc(&pdev->dev, sizeof(*jpeg), GFP_KERNEL);
@@ -1733,6 +1735,19 @@ static int mtk_jpeg_probe(struct platform_device *pdev)
17331735
v4l2_err(&jpeg->v4l2_dev, "mtk_jpeg_single_core_init failed.");
17341736
return -EINVAL;
17351737
}
1738+
} else {
1739+
init_waitqueue_head(&jpeg->hw_wq);
1740+
1741+
for_each_child_of_node(pdev->dev.of_node, child)
1742+
num_child++;
1743+
1744+
atomic_set(&jpeg->hw_rdy, num_child);
1745+
1746+
jpeg->workqueue = alloc_ordered_workqueue(MTK_JPEG_NAME,
1747+
WQ_MEM_RECLAIM
1748+
| WQ_FREEZABLE);
1749+
if (!jpeg->workqueue)
1750+
return -EINVAL;
17361751
}
17371752

17381753
ret = v4l2_device_register(&pdev->dev, &jpeg->v4l2_dev);

drivers/media/platform/mediatek/jpeg/mtk_jpeg_core.h

+6-12
Original file line numberDiff line numberDiff line change
@@ -203,14 +203,11 @@ struct mtk_jpegdec_comp_dev {
203203
* @job_timeout_work: IRQ timeout structure
204204
* @variant: driver variant to be used
205205
* @reg_encbase: jpg encode register base addr
206-
* @enc_hw_dev: jpg encode hardware device
207-
* @enc_hw_wq: jpg encode wait queue
208-
* @enchw_rdy: jpg encode hw ready flag
206+
* @enc_hw_dev: jpg encode hardware device
207+
* @hw_wq: jpg wait queue
208+
* @hw_rdy: jpg hw ready flag
209209
* @reg_decbase: jpg decode register base addr
210-
* @dec_hw_dev: jpg decode hardware device
211-
* @dec_hw_wq: jpg decode wait queue
212-
* @dec_workqueue: jpg decode work queue
213-
* @dechw_rdy: jpg decode hw ready flag
210+
* @dec_hw_dev: jpg decode hardware device
214211
*/
215212
struct mtk_jpeg_dev {
216213
struct mutex lock;
@@ -227,14 +224,11 @@ struct mtk_jpeg_dev {
227224

228225
void __iomem *reg_encbase[MTK_JPEGENC_HW_MAX];
229226
struct mtk_jpegenc_comp_dev *enc_hw_dev[MTK_JPEGENC_HW_MAX];
230-
wait_queue_head_t enc_hw_wq;
231-
atomic_t enchw_rdy;
227+
wait_queue_head_t hw_wq;
228+
atomic_t hw_rdy;
232229

233230
void __iomem *reg_decbase[MTK_JPEGDEC_HW_MAX];
234231
struct mtk_jpegdec_comp_dev *dec_hw_dev[MTK_JPEGDEC_HW_MAX];
235-
wait_queue_head_t dec_hw_wq;
236-
struct workqueue_struct *dec_workqueue;
237-
atomic_t dechw_rdy;
238232
};
239233

240234
/**

drivers/media/platform/mediatek/jpeg/mtk_jpeg_dec_hw.c

+4-12
Original file line numberDiff line numberDiff line change
@@ -503,8 +503,8 @@ static void mtk_jpegdec_timeout_work(struct work_struct *work)
503503
clk_disable_unprepare(cjpeg->jdec_clk.clks->clk);
504504
pm_runtime_put(cjpeg->dev);
505505
cjpeg->hw_state = MTK_JPEG_HW_IDLE;
506-
atomic_inc(&master_jpeg->dechw_rdy);
507-
wake_up(&master_jpeg->dec_hw_wq);
506+
atomic_inc(&master_jpeg->hw_rdy);
507+
wake_up(&master_jpeg->hw_wq);
508508
v4l2_m2m_buf_done(src_buf, buf_state);
509509
mtk_jpegdec_put_buf(cjpeg);
510510
}
@@ -551,8 +551,8 @@ static irqreturn_t mtk_jpegdec_hw_irq_handler(int irq, void *priv)
551551
clk_disable_unprepare(jpeg->jdec_clk.clks->clk);
552552

553553
jpeg->hw_state = MTK_JPEG_HW_IDLE;
554-
wake_up(&master_jpeg->dec_hw_wq);
555-
atomic_inc(&master_jpeg->dechw_rdy);
554+
wake_up(&master_jpeg->hw_wq);
555+
atomic_inc(&master_jpeg->hw_rdy);
556556

557557
return IRQ_HANDLED;
558558
}
@@ -608,20 +608,12 @@ static int mtk_jpegdec_hw_probe(struct platform_device *pdev)
608608
dev->plat_dev = pdev;
609609
dev->dev = &pdev->dev;
610610

611-
init_waitqueue_head(&master_dev->dec_hw_wq);
612-
master_dev->workqueue = alloc_ordered_workqueue(MTK_JPEG_NAME,
613-
WQ_MEM_RECLAIM
614-
| WQ_FREEZABLE);
615-
if (!master_dev->workqueue)
616-
return -EINVAL;
617-
618611
ret = devm_add_action_or_reset(&pdev->dev,
619612
mtk_jpegdec_destroy_workqueue,
620613
master_dev->workqueue);
621614
if (ret)
622615
return ret;
623616

624-
atomic_set(&master_dev->dechw_rdy, MTK_JPEGDEC_HW_MAX);
625617
spin_lock_init(&dev->hw_lock);
626618
dev->hw_state = MTK_JPEG_HW_IDLE;
627619

drivers/media/platform/mediatek/jpeg/mtk_jpeg_enc_hw.c

+4-12
Original file line numberDiff line numberDiff line change
@@ -248,8 +248,8 @@ static void mtk_jpegenc_timeout_work(struct work_struct *work)
248248
clk_disable_unprepare(cjpeg->venc_clk.clks->clk);
249249
pm_runtime_put(cjpeg->dev);
250250
cjpeg->hw_state = MTK_JPEG_HW_IDLE;
251-
atomic_inc(&master_jpeg->enchw_rdy);
252-
wake_up(&master_jpeg->enc_hw_wq);
251+
atomic_inc(&master_jpeg->hw_rdy);
252+
wake_up(&master_jpeg->hw_wq);
253253
v4l2_m2m_buf_done(src_buf, buf_state);
254254
mtk_jpegenc_put_buf(cjpeg);
255255
}
@@ -288,8 +288,8 @@ static irqreturn_t mtk_jpegenc_hw_irq_handler(int irq, void *priv)
288288
clk_disable_unprepare(jpeg->venc_clk.clks->clk);
289289

290290
jpeg->hw_state = MTK_JPEG_HW_IDLE;
291-
wake_up(&master_jpeg->enc_hw_wq);
292-
atomic_inc(&master_jpeg->enchw_rdy);
291+
wake_up(&master_jpeg->hw_wq);
292+
atomic_inc(&master_jpeg->hw_rdy);
293293

294294
return IRQ_HANDLED;
295295
}
@@ -340,14 +340,6 @@ static int mtk_jpegenc_hw_probe(struct platform_device *pdev)
340340
dev->plat_dev = pdev;
341341
dev->dev = &pdev->dev;
342342

343-
init_waitqueue_head(&master_dev->enc_hw_wq);
344-
master_dev->workqueue = alloc_ordered_workqueue(MTK_JPEG_NAME,
345-
WQ_MEM_RECLAIM
346-
| WQ_FREEZABLE);
347-
if (!master_dev->workqueue)
348-
return -EINVAL;
349-
350-
atomic_set(&master_dev->enchw_rdy, MTK_JPEGENC_HW_MAX);
351343
spin_lock_init(&dev->hw_lock);
352344
dev->hw_state = MTK_JPEG_HW_IDLE;
353345

0 commit comments

Comments
 (0)