summaryrefslogtreecommitdiff
path: root/drivers/media/platform/mtk-jpeg/mtk_jpeg_enc_hw.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/media/platform/mtk-jpeg/mtk_jpeg_enc_hw.c')
-rw-r--r--drivers/media/platform/mtk-jpeg/mtk_jpeg_enc_hw.c154
1 files changed, 0 insertions, 154 deletions
diff --git a/drivers/media/platform/mtk-jpeg/mtk_jpeg_enc_hw.c b/drivers/media/platform/mtk-jpeg/mtk_jpeg_enc_hw.c
deleted file mode 100644
index 1cf037bf72dd..000000000000
--- a/drivers/media/platform/mtk-jpeg/mtk_jpeg_enc_hw.c
+++ /dev/null
@@ -1,154 +0,0 @@
-// SPDX-License-Identifier: GPL-2.0-only
-/*
- * Copyright (c) 2019 MediaTek Inc.
- * Author: Xia Jiang <xia.jiang@mediatek.com>
- *
- */
-
-#include <linux/io.h>
-#include <linux/kernel.h>
-#include <media/videobuf2-core.h>
-#include <media/videobuf2-dma-contig.h>
-
-#include "mtk_jpeg_enc_hw.h"
-
-static const struct mtk_jpeg_enc_qlt mtk_jpeg_enc_quality[] = {
- {.quality_param = 34, .hardware_value = JPEG_ENC_QUALITY_Q34},
- {.quality_param = 39, .hardware_value = JPEG_ENC_QUALITY_Q39},
- {.quality_param = 48, .hardware_value = JPEG_ENC_QUALITY_Q48},
- {.quality_param = 60, .hardware_value = JPEG_ENC_QUALITY_Q60},
- {.quality_param = 64, .hardware_value = JPEG_ENC_QUALITY_Q64},
- {.quality_param = 68, .hardware_value = JPEG_ENC_QUALITY_Q68},
- {.quality_param = 74, .hardware_value = JPEG_ENC_QUALITY_Q74},
- {.quality_param = 80, .hardware_value = JPEG_ENC_QUALITY_Q80},
- {.quality_param = 82, .hardware_value = JPEG_ENC_QUALITY_Q82},
- {.quality_param = 84, .hardware_value = JPEG_ENC_QUALITY_Q84},
- {.quality_param = 87, .hardware_value = JPEG_ENC_QUALITY_Q87},
- {.quality_param = 90, .hardware_value = JPEG_ENC_QUALITY_Q90},
- {.quality_param = 92, .hardware_value = JPEG_ENC_QUALITY_Q92},
- {.quality_param = 95, .hardware_value = JPEG_ENC_QUALITY_Q95},
- {.quality_param = 97, .hardware_value = JPEG_ENC_QUALITY_Q97},
-};
-
-void mtk_jpeg_enc_reset(void __iomem *base)
-{
- writel(0, base + JPEG_ENC_RSTB);
- writel(JPEG_ENC_RESET_BIT, base + JPEG_ENC_RSTB);
- writel(0, base + JPEG_ENC_CODEC_SEL);
-}
-
-u32 mtk_jpeg_enc_get_file_size(void __iomem *base)
-{
- return readl(base + JPEG_ENC_DMA_ADDR0) -
- readl(base + JPEG_ENC_DST_ADDR0);
-}
-
-void mtk_jpeg_enc_start(void __iomem *base)
-{
- u32 value;
-
- value = readl(base + JPEG_ENC_CTRL);
- value |= JPEG_ENC_CTRL_INT_EN_BIT | JPEG_ENC_CTRL_ENABLE_BIT;
- writel(value, base + JPEG_ENC_CTRL);
-}
-
-void mtk_jpeg_set_enc_src(struct mtk_jpeg_ctx *ctx, void __iomem *base,
- struct vb2_buffer *src_buf)
-{
- int i;
- dma_addr_t dma_addr;
-
- for (i = 0; i < src_buf->num_planes; i++) {
- dma_addr = vb2_dma_contig_plane_dma_addr(src_buf, i) +
- src_buf->planes[i].data_offset;
- if (!i)
- writel(dma_addr, base + JPEG_ENC_SRC_LUMA_ADDR);
- else
- writel(dma_addr, base + JPEG_ENC_SRC_CHROMA_ADDR);
- }
-}
-
-void mtk_jpeg_set_enc_dst(struct mtk_jpeg_ctx *ctx, void __iomem *base,
- struct vb2_buffer *dst_buf)
-{
- dma_addr_t dma_addr;
- size_t size;
- u32 dma_addr_offset;
- u32 dma_addr_offsetmask;
-
- dma_addr = vb2_dma_contig_plane_dma_addr(dst_buf, 0);
- dma_addr_offset = ctx->enable_exif ? MTK_JPEG_MAX_EXIF_SIZE : 0;
- dma_addr_offsetmask = dma_addr & JPEG_ENC_DST_ADDR_OFFSET_MASK;
- size = vb2_plane_size(dst_buf, 0);
-
- writel(dma_addr_offset & ~0xf, base + JPEG_ENC_OFFSET_ADDR);
- writel(dma_addr_offsetmask & 0xf, base + JPEG_ENC_BYTE_OFFSET_MASK);
- writel(dma_addr & ~0xf, base + JPEG_ENC_DST_ADDR0);
- writel((dma_addr + size) & ~0xf, base + JPEG_ENC_STALL_ADDR0);
-}
-
-void mtk_jpeg_set_enc_params(struct mtk_jpeg_ctx *ctx, void __iomem *base)
-{
- u32 value;
- u32 width = ctx->out_q.enc_crop_rect.width;
- u32 height = ctx->out_q.enc_crop_rect.height;
- u32 enc_format = ctx->out_q.fmt->fourcc;
- u32 bytesperline = ctx->out_q.pix_mp.plane_fmt[0].bytesperline;
- u32 blk_num;
- u32 img_stride;
- u32 mem_stride;
- u32 i, enc_quality;
-
- value = width << 16 | height;
- writel(value, base + JPEG_ENC_IMG_SIZE);
-
- if (enc_format == V4L2_PIX_FMT_NV12M ||
- enc_format == V4L2_PIX_FMT_NV21M)
- /*
- * Total 8 x 8 block number of luma and chroma.
- * The number of blocks is counted from 0.
- */
- blk_num = DIV_ROUND_UP(width, 16) *
- DIV_ROUND_UP(height, 16) * 6 - 1;
- else
- blk_num = DIV_ROUND_UP(width, 16) *
- DIV_ROUND_UP(height, 8) * 4 - 1;
- writel(blk_num, base + JPEG_ENC_BLK_NUM);
-
- if (enc_format == V4L2_PIX_FMT_NV12M ||
- enc_format == V4L2_PIX_FMT_NV21M) {
- /* 4:2:0 */
- img_stride = round_up(width, 16);
- mem_stride = bytesperline;
- } else {
- /* 4:2:2 */
- img_stride = round_up(width * 2, 32);
- mem_stride = img_stride;
- }
- writel(img_stride, base + JPEG_ENC_IMG_STRIDE);
- writel(mem_stride, base + JPEG_ENC_STRIDE);
-
- enc_quality = mtk_jpeg_enc_quality[0].hardware_value;
- for (i = 0; i < ARRAY_SIZE(mtk_jpeg_enc_quality); i++) {
- if (ctx->enc_quality <= mtk_jpeg_enc_quality[i].quality_param) {
- enc_quality = mtk_jpeg_enc_quality[i].hardware_value;
- break;
- }
- }
- writel(enc_quality, base + JPEG_ENC_QUALITY);
-
- value = readl(base + JPEG_ENC_CTRL);
- value &= ~JPEG_ENC_CTRL_YUV_FORMAT_MASK;
- value |= (ctx->out_q.fmt->hw_format & 3) << 3;
- if (ctx->enable_exif)
- value |= JPEG_ENC_CTRL_FILE_FORMAT_BIT;
- else
- value &= ~JPEG_ENC_CTRL_FILE_FORMAT_BIT;
- if (ctx->restart_interval)
- value |= JPEG_ENC_CTRL_RESTART_EN_BIT;
- else
- value &= ~JPEG_ENC_CTRL_RESTART_EN_BIT;
- writel(value, base + JPEG_ENC_CTRL);
-
- writel(ctx->restart_interval, base + JPEG_ENC_RST_MCU_NUM);
-}