/* SPDX-License-Identifier: GPL-2.0-only */
/*
* Copyright (c) 2019 MediaTek Inc.
* Author: Xia Jiang <xia.jiang@mediatek.com>
*
*/
#ifndef _MTK_JPEG_ENC_HW_H
#define _MTK_JPEG_ENC_HW_H
#include <media/videobuf2-core.h>
#include "mtk_jpeg_core.h"
#define JPEG_ENC_INT_STATUS_DONE BIT(0 )
#define JPEG_ENC_INT_STATUS_MASK_ALLIRQ 0 x13
#define JPEG_ENC_DST_ADDR_OFFSET_MASK GENMASK(3 , 0 )
#define JPEG_ENC_CTRL_YUV_FORMAT_MASK 0 x18
#define JPEG_ENC_CTRL_RESTART_EN_BIT BIT(10 )
#define JPEG_ENC_CTRL_FILE_FORMAT_BIT BIT(5 )
#define JPEG_ENC_CTRL_INT_EN_BIT BIT(2 )
#define JPEG_ENC_CTRL_ENABLE_BIT BIT(0 )
#define JPEG_ENC_RESET_BIT BIT(0 )
#define JPEG_ENC_YUV_FORMAT_YUYV 0
#define JPEG_ENC_YUV_FORMAT_YVYU 1
#define JPEG_ENC_YUV_FORMAT_NV12 2
#define JEPG_ENC_YUV_FORMAT_NV21 3
#define JPEG_ENC_QUALITY_Q60 0 x0
#define JPEG_ENC_QUALITY_Q80 0 x1
#define JPEG_ENC_QUALITY_Q90 0 x2
#define JPEG_ENC_QUALITY_Q95 0 x3
#define JPEG_ENC_QUALITY_Q39 0 x4
#define JPEG_ENC_QUALITY_Q68 0 x5
#define JPEG_ENC_QUALITY_Q84 0 x6
#define JPEG_ENC_QUALITY_Q92 0 x7
#define JPEG_ENC_QUALITY_Q48 0 x8
#define JPEG_ENC_QUALITY_Q74 0 xa
#define JPEG_ENC_QUALITY_Q87 0 xb
#define JPEG_ENC_QUALITY_Q34 0 xc
#define JPEG_ENC_QUALITY_Q64 0 xe
#define JPEG_ENC_QUALITY_Q82 0 xf
#define JPEG_ENC_QUALITY_Q97 0 x10
#define JPEG_ENC_RSTB 0 x100
#define JPEG_ENC_CTRL 0 x104
#define JPEG_ENC_QUALITY 0 x108
#define JPEG_ENC_BLK_NUM 0 x10C
#define JPEG_ENC_BLK_CNT 0 x110
#define JPEG_ENC_INT_STS 0 x11c
#define JPEG_ENC_DST_ADDR0 0 x120
#define JPEG_ENC_DMA_ADDR0 0 x124
#define JPEG_ENC_STALL_ADDR0 0 x128
#define JPEG_ENC_OFFSET_ADDR 0 x138
#define JPEG_ENC_RST_MCU_NUM 0 x150
#define JPEG_ENC_IMG_SIZE 0 x154
#define JPEG_ENC_DEBUG_INFO0 0 x160
#define JPEG_ENC_DEBUG_INFO1 0 x164
#define JPEG_ENC_TOTAL_CYCLE 0 x168
#define JPEG_ENC_BYTE_OFFSET_MASK 0 x16c
#define JPEG_ENC_SRC_LUMA_ADDR 0 x170
#define JPEG_ENC_SRC_CHROMA_ADDR 0 x174
#define JPEG_ENC_STRIDE 0 x178
#define JPEG_ENC_IMG_STRIDE 0 x17c
#define JPEG_ENC_DCM_CTRL 0 x300
#define JPEG_ENC_CODEC_SEL 0 x314
#define JPEG_ENC_ULTRA_THRES 0 x318
#define JPEG_ENC_SRC_LUMA_ADDR_EXT 0 x584
#define JPEG_ENC_SRC_CHRO_ADDR_EXT 0 x588
#define JPEG_ENC_Q_TBL_ADDR_EXT 0 x58C
#define JPEG_ENC_DEST_ADDR0_EXT 0 x590
#define JPEG_ENC_STALL_ADDR0_EXT 0 x594
/**
* struct mtk_jpeg_enc_qlt - JPEG encoder quality data
* @quality_param: quality value
* @hardware_value: hardware value of quality
*/
struct mtk_jpeg_enc_qlt {
u8 quality_param;
u8 hardware_value;
};
void mtk_jpeg_enc_reset(void __iomem *base);
u32 mtk_jpeg_enc_get_file_size(void __iomem *base, bool support_34bit);
void mtk_jpeg_enc_start(void __iomem *enc_reg_base);
void mtk_jpeg_set_enc_src(struct mtk_jpeg_ctx *ctx, void __iomem *base,
struct vb2_buffer *src_buf);
void mtk_jpeg_set_enc_dst(struct mtk_jpeg_ctx *ctx, void __iomem *base,
struct vb2_buffer *dst_buf);
void mtk_jpeg_set_enc_params(struct mtk_jpeg_ctx *ctx, void __iomem *base);
#endif /* _MTK_JPEG_ENC_HW_H */
Messung V0.5 in Prozent C=96 H=93 G=94
¤ Dauer der Verarbeitung: 0.8 Sekunden
(vorverarbeitet am 2026-06-08)
¤
*© Formatika GbR, Deutschland