hc
2024-01-03 2f7c68cb55ecb7331f2381deb497c27155f32faf
kernel/drivers/video/rockchip/mpp/mpp_rkvenc.c
....@@ -28,6 +28,7 @@
2828 #include <linux/nospec.h>
2929 #include <linux/workqueue.h>
3030 #include <soc/rockchip/pm_domains.h>
31
+#include <soc/rockchip/rockchip_iommu.h>
3132 #include <soc/rockchip/rockchip_ipa.h>
3233 #include <soc/rockchip/rockchip_opp_select.h>
3334 #include <soc/rockchip/rockchip_system_monitor.h>
....@@ -504,7 +505,6 @@
504505
505506 mpp_write(mpp, RKVENC_INT_MSK_BASE, 0x100);
506507 mpp_write(mpp, RKVENC_INT_CLR_BASE, 0xffffffff);
507
- udelay(5);
508508 mpp_write(mpp, RKVENC_INT_STATUS_BASE, 0);
509509
510510 mpp_debug_leave();
....@@ -534,11 +534,10 @@
534534
535535 if (task->irq_status & RKVENC_INT_ERROR_BITS) {
536536 atomic_inc(&mpp->reset_request);
537
- /* dump register */
538537 if (mpp_debug_unlikely(DEBUG_DUMP_ERR_REG)) {
539
- mpp_debug(DEBUG_DUMP_ERR_REG, "irq_status: %08x\n",
540
- task->irq_status);
541
- mpp_task_dump_hw_reg(mpp, mpp_task);
538
+ /* dump error register */
539
+ mpp_debug(DEBUG_DUMP_ERR_REG, "irq_status: %08x\n", task->irq_status);
540
+ mpp_task_dump_hw_reg(mpp);
542541 }
543542 }
544543
....@@ -756,7 +755,7 @@
756755 }
757756 seq_puts(seq, "\n");
758757 /* item data*/
759
- seq_printf(seq, "|%8p|", session);
758
+ seq_printf(seq, "|%8d|", session->index);
760759 seq_printf(seq, "%8s|", mpp_device_name[session->device_type]);
761760 for (i = ENC_INFO_BASE; i < ENC_INFO_BUTT; i++) {
762761 u32 flag = priv->codec_info[i].flag;
....@@ -789,7 +788,7 @@
789788 mutex_lock(&mpp->srv->session_lock);
790789 list_for_each_entry_safe(session, n,
791790 &mpp->srv->session_list,
792
- session_link) {
791
+ service_link) {
793792 if (session->device_type != MPP_DEVICE_RKVENC)
794793 continue;
795794 if (!session->priv)
....@@ -970,7 +969,7 @@
970969 };
971970
972971 static struct monitor_dev_profile enc_mdevp = {
973
- .type = MONITOR_TPYE_DEV,
972
+ .type = MONITOR_TYPE_DEV,
974973 .low_temp_adjust = rockchip_monitor_dev_low_temp_adjust,
975974 .high_temp_adjust = rockchip_monitor_dev_high_temp_adjust,
976975 };
....@@ -999,15 +998,19 @@
999998 return ret;
1000999 }
10011000
1001
+static const struct rockchip_opp_data __maybe_unused rv1126_rkvenc_opp_data = {
1002
+ .get_soc_info = rv1126_get_soc_info,
1003
+};
1004
+
10021005 static const struct of_device_id rockchip_rkvenc_of_match[] = {
10031006 #ifdef CONFIG_CPU_RV1126
10041007 {
10051008 .compatible = "rockchip,rv1109",
1006
- .data = (void *)&rv1126_get_soc_info,
1009
+ .data = (void *)&rv1126_rkvenc_opp_data,
10071010 },
10081011 {
10091012 .compatible = "rockchip,rv1126",
1010
- .data = (void *)&rv1126_get_soc_info,
1013
+ .data = (void *)&rv1126_rkvenc_opp_data,
10111014 },
10121015 #endif
10131016 {},
....@@ -1018,6 +1021,7 @@
10181021 struct rkvenc_dev *enc = to_rkvenc_dev(mpp);
10191022 struct clk *clk_core = enc->core_clk_info.clk;
10201023 struct devfreq_cooling_power *venc_dcp = &venc_cooling_power_data;
1024
+ struct rockchip_opp_info opp_info = {0};
10211025 int ret = 0;
10221026
10231027 if (!clk_core)
....@@ -1035,8 +1039,8 @@
10351039 return 0;
10361040 }
10371041
1038
- ret = rockchip_init_opp_table(mpp->dev, rockchip_rkvenc_of_match,
1039
- "leakage", "venc");
1042
+ rockchip_get_opp_data(rockchip_rkvenc_of_match, &opp_info);
1043
+ ret = rockchip_init_opp_table(mpp->dev, &opp_info, "leakage", "venc");
10401044 if (ret) {
10411045 dev_err(mpp->dev, "failed to init_opp_table\n");
10421046 return ret;
....@@ -1146,7 +1150,7 @@
11461150 else
11471151 enc->aux_iova = page_iova;
11481152
1149
- rk_iommu_unmask_irq(mpp->dev);
1153
+ rockchip_iommu_unmask_irq(mpp->dev);
11501154 mpp_iommu_up_write(mpp->iommu_info);
11511155
11521156 mpp_debug_leave();
....@@ -1163,7 +1167,7 @@
11631167 mpp_debug(DEBUG_IOMMU, "IOMMU_GET_BUS_ID(status)=%d\n", IOMMU_GET_BUS_ID(status));
11641168 if (IOMMU_GET_BUS_ID(status)) {
11651169 enc->fault_iova = iova;
1166
- rk_iommu_mask_irq(mpp->dev);
1170
+ rockchip_iommu_mask_irq(mpp->dev);
11671171 queue_work(enc->iommu_wq, &enc->iommu_work);
11681172 }
11691173 mpp_debug_leave();
....@@ -1228,7 +1232,7 @@
12281232 }
12291233 INIT_WORK(&enc->iommu_work, rkvenc_iommu_handle_work);
12301234
1231
- mpp->iommu_info->hdl = rkvenc_iommu_fault_handle;
1235
+ mpp->fault_handler = rkvenc_iommu_fault_handle;
12321236
12331237 return ret;
12341238 }
....@@ -1443,7 +1447,7 @@
14431447 if (!enc)
14441448 return -ENOMEM;
14451449 mpp = &enc->mpp;
1446
- platform_set_drvdata(pdev, enc);
1450
+ platform_set_drvdata(pdev, mpp);
14471451
14481452 if (pdev->dev.of_node) {
14491453 match = of_match_node(mpp_rkvenc_dt_match, pdev->dev.of_node);
....@@ -1482,39 +1486,19 @@
14821486 static int rkvenc_remove(struct platform_device *pdev)
14831487 {
14841488 struct device *dev = &pdev->dev;
1485
- struct rkvenc_dev *enc = platform_get_drvdata(pdev);
1489
+ struct mpp_dev *mpp = dev_get_drvdata(dev);
14861490
14871491 dev_info(dev, "remove device\n");
1488
- mpp_dev_remove(&enc->mpp);
1489
- rkvenc_procfs_remove(&enc->mpp);
1492
+ mpp_dev_remove(mpp);
1493
+ rkvenc_procfs_remove(mpp);
14901494
14911495 return 0;
1492
-}
1493
-
1494
-static void rkvenc_shutdown(struct platform_device *pdev)
1495
-{
1496
- int ret;
1497
- int val;
1498
- struct device *dev = &pdev->dev;
1499
- struct rkvenc_dev *enc = platform_get_drvdata(pdev);
1500
- struct mpp_dev *mpp = &enc->mpp;
1501
-
1502
- dev_info(dev, "shutdown device\n");
1503
-
1504
- atomic_inc(&mpp->srv->shutdown_request);
1505
- ret = readx_poll_timeout(atomic_read,
1506
- &mpp->task_count,
1507
- val, val == 0, 1000, 200000);
1508
- if (ret == -ETIMEDOUT)
1509
- dev_err(dev, "wait total running time out\n");
1510
-
1511
- dev_info(dev, "shutdown success\n");
15121496 }
15131497
15141498 struct platform_driver rockchip_rkvenc_driver = {
15151499 .probe = rkvenc_probe,
15161500 .remove = rkvenc_remove,
1517
- .shutdown = rkvenc_shutdown,
1501
+ .shutdown = mpp_dev_shutdown,
15181502 .driver = {
15191503 .name = RKVENC_DRIVER_NAME,
15201504 .of_match_table = of_match_ptr(mpp_rkvenc_dt_match),