162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0 */
262306a36Sopenharmony_ci/*
362306a36Sopenharmony_ci * i.MX8QXP/i.MX8QM JPEG encoder/decoder v4l2 driver
462306a36Sopenharmony_ci *
562306a36Sopenharmony_ci * Copyright 2018-2019 NXP
662306a36Sopenharmony_ci */
762306a36Sopenharmony_ci
862306a36Sopenharmony_ci#ifndef _MXC_JPEG_HW_H
962306a36Sopenharmony_ci#define _MXC_JPEG_HW_H
1062306a36Sopenharmony_ci
1162306a36Sopenharmony_ci/* JPEG Decoder/Encoder Wrapper Register Map */
1262306a36Sopenharmony_ci#define GLB_CTRL			0x0
1362306a36Sopenharmony_ci#define COM_STATUS			0x4
1462306a36Sopenharmony_ci#define BUF_BASE0			0x14
1562306a36Sopenharmony_ci#define BUF_BASE1			0x18
1662306a36Sopenharmony_ci#define LINE_PITCH			0x1C
1762306a36Sopenharmony_ci#define STM_BUFBASE			0x20
1862306a36Sopenharmony_ci#define STM_BUFSIZE			0x24
1962306a36Sopenharmony_ci#define IMGSIZE				0x28
2062306a36Sopenharmony_ci#define STM_CTRL			0x2C
2162306a36Sopenharmony_ci
2262306a36Sopenharmony_ci/* CAST JPEG-Decoder/Encoder Status Register Map (read-only)*/
2362306a36Sopenharmony_ci#define CAST_STATUS0			0x100
2462306a36Sopenharmony_ci#define CAST_STATUS1			0x104
2562306a36Sopenharmony_ci#define CAST_STATUS2			0x108
2662306a36Sopenharmony_ci#define CAST_STATUS3			0x10c
2762306a36Sopenharmony_ci#define CAST_STATUS4			0x110
2862306a36Sopenharmony_ci#define CAST_STATUS5			0x114
2962306a36Sopenharmony_ci#define CAST_STATUS6			0x118
3062306a36Sopenharmony_ci#define CAST_STATUS7			0x11c
3162306a36Sopenharmony_ci#define CAST_STATUS8			0x120
3262306a36Sopenharmony_ci#define CAST_STATUS9			0x124
3362306a36Sopenharmony_ci#define CAST_STATUS10			0x128
3462306a36Sopenharmony_ci#define CAST_STATUS11			0x12c
3562306a36Sopenharmony_ci#define CAST_STATUS12			0x130
3662306a36Sopenharmony_ci#define CAST_STATUS13			0x134
3762306a36Sopenharmony_ci/* the following are for encoder only */
3862306a36Sopenharmony_ci#define CAST_STATUS14		0x138
3962306a36Sopenharmony_ci#define CAST_STATUS15		0x13c
4062306a36Sopenharmony_ci#define CAST_STATUS16		0x140
4162306a36Sopenharmony_ci#define CAST_STATUS17		0x144
4262306a36Sopenharmony_ci#define CAST_STATUS18		0x148
4362306a36Sopenharmony_ci#define CAST_STATUS19		0x14c
4462306a36Sopenharmony_ci
4562306a36Sopenharmony_ci/* CAST JPEG-Decoder Control Register Map (write-only) */
4662306a36Sopenharmony_ci#define CAST_CTRL			CAST_STATUS13
4762306a36Sopenharmony_ci
4862306a36Sopenharmony_ci/* CAST JPEG-Encoder Control Register Map (write-only) */
4962306a36Sopenharmony_ci#define CAST_MODE			CAST_STATUS0
5062306a36Sopenharmony_ci#define CAST_CFG_MODE			CAST_STATUS1
5162306a36Sopenharmony_ci#define CAST_QUALITY			CAST_STATUS2
5262306a36Sopenharmony_ci#define CAST_RSVD			CAST_STATUS3
5362306a36Sopenharmony_ci#define CAST_REC_REGS_SEL		CAST_STATUS4
5462306a36Sopenharmony_ci#define CAST_LUMTH			CAST_STATUS5
5562306a36Sopenharmony_ci#define CAST_CHRTH			CAST_STATUS6
5662306a36Sopenharmony_ci#define CAST_NOMFRSIZE_LO		CAST_STATUS16
5762306a36Sopenharmony_ci#define CAST_NOMFRSIZE_HI		CAST_STATUS17
5862306a36Sopenharmony_ci#define CAST_OFBSIZE_LO			CAST_STATUS18
5962306a36Sopenharmony_ci#define CAST_OFBSIZE_HI			CAST_STATUS19
6062306a36Sopenharmony_ci
6162306a36Sopenharmony_ci/* JPEG-Decoder Wrapper Slot Registers 0..3 */
6262306a36Sopenharmony_ci#define SLOT_BASE			0x10000
6362306a36Sopenharmony_ci#define SLOT_STATUS			0x0
6462306a36Sopenharmony_ci#define SLOT_IRQ_EN			0x4
6562306a36Sopenharmony_ci#define SLOT_BUF_PTR			0x8
6662306a36Sopenharmony_ci#define SLOT_CUR_DESCPT_PTR		0xC
6762306a36Sopenharmony_ci#define SLOT_NXT_DESCPT_PTR		0x10
6862306a36Sopenharmony_ci#define MXC_SLOT_OFFSET(slot, offset)	((SLOT_BASE * ((slot) + 1)) + (offset))
6962306a36Sopenharmony_ci
7062306a36Sopenharmony_ci/* GLB_CTRL fields */
7162306a36Sopenharmony_ci#define GLB_CTRL_JPG_EN					0x1
7262306a36Sopenharmony_ci#define GLB_CTRL_SFT_RST				(0x1 << 1)
7362306a36Sopenharmony_ci#define GLB_CTRL_DEC_GO					(0x1 << 2)
7462306a36Sopenharmony_ci#define GLB_CTRL_L_ENDIAN(le)				((le) << 3)
7562306a36Sopenharmony_ci#define GLB_CTRL_SLOT_EN(slot)				(0x1 << ((slot) + 4))
7662306a36Sopenharmony_ci
7762306a36Sopenharmony_ci/* COM_STAUS fields */
7862306a36Sopenharmony_ci#define COM_STATUS_DEC_ONGOING(r)		(((r) & (1 << 31)) >> 31)
7962306a36Sopenharmony_ci#define COM_STATUS_CUR_SLOT(r)			(((r) & (0x3 << 29)) >> 29)
8062306a36Sopenharmony_ci
8162306a36Sopenharmony_ci/* STM_CTRL fields */
8262306a36Sopenharmony_ci#define STM_CTRL_PIXEL_PRECISION		(0x1 << 2)
8362306a36Sopenharmony_ci#define STM_CTRL_IMAGE_FORMAT(img_fmt)		((img_fmt) << 3)
8462306a36Sopenharmony_ci#define STM_CTRL_IMAGE_FORMAT_MASK		(0xF << 3)
8562306a36Sopenharmony_ci#define STM_CTRL_BITBUF_PTR_CLR(clr)		((clr) << 7)
8662306a36Sopenharmony_ci#define STM_CTRL_AUTO_START(go)			((go) << 8)
8762306a36Sopenharmony_ci#define STM_CTRL_CONFIG_MOD(mod)		((mod) << 9)
8862306a36Sopenharmony_ci
8962306a36Sopenharmony_ci/* SLOT_STATUS fields for slots 0..3 */
9062306a36Sopenharmony_ci#define SLOT_STATUS_FRMDONE			(0x1 << 3)
9162306a36Sopenharmony_ci#define SLOT_STATUS_ENC_CONFIG_ERR		(0x1 << 8)
9262306a36Sopenharmony_ci
9362306a36Sopenharmony_ci/* SLOT_IRQ_EN fields TBD */
9462306a36Sopenharmony_ci
9562306a36Sopenharmony_ci#define MXC_NXT_DESCPT_EN			0x1
9662306a36Sopenharmony_ci#define MXC_DEC_EXIT_IDLE_MODE			0x4
9762306a36Sopenharmony_ci
9862306a36Sopenharmony_ci/* JPEG-Decoder Wrapper - STM_CTRL Register Fields */
9962306a36Sopenharmony_ci#define MXC_PIXEL_PRECISION(precision) ((precision) / 8 << 2)
10062306a36Sopenharmony_cienum mxc_jpeg_image_format {
10162306a36Sopenharmony_ci	MXC_JPEG_INVALID = -1,
10262306a36Sopenharmony_ci	MXC_JPEG_YUV420 = 0x0, /* 2 Plannar, Y=1st plane UV=2nd plane */
10362306a36Sopenharmony_ci	MXC_JPEG_YUV422 = 0x1, /* 1 Plannar, YUYV sequence */
10462306a36Sopenharmony_ci	MXC_JPEG_BGR	= 0x2, /* BGR packed format */
10562306a36Sopenharmony_ci	MXC_JPEG_YUV444	= 0x3, /* 1 Plannar, YUVYUV sequence */
10662306a36Sopenharmony_ci	MXC_JPEG_GRAY = 0x4, /* Y8 or Y12 or Single Component */
10762306a36Sopenharmony_ci	MXC_JPEG_RESERVED = 0x5,
10862306a36Sopenharmony_ci	MXC_JPEG_ABGR	= 0x6,
10962306a36Sopenharmony_ci};
11062306a36Sopenharmony_ci
11162306a36Sopenharmony_ci#include "mxc-jpeg.h"
11262306a36Sopenharmony_civoid print_descriptor_info(struct device *dev, struct mxc_jpeg_desc *desc);
11362306a36Sopenharmony_civoid print_cast_status(struct device *dev, void __iomem *reg,
11462306a36Sopenharmony_ci		       unsigned int mode);
11562306a36Sopenharmony_civoid print_wrapper_info(struct device *dev, void __iomem *reg);
11662306a36Sopenharmony_civoid mxc_jpeg_sw_reset(void __iomem *reg);
11762306a36Sopenharmony_ciint mxc_jpeg_enable(void __iomem *reg);
11862306a36Sopenharmony_civoid wait_frmdone(struct device *dev, void __iomem *reg);
11962306a36Sopenharmony_civoid mxc_jpeg_enc_mode_conf(struct device *dev, void __iomem *reg, u8 extseq);
12062306a36Sopenharmony_civoid mxc_jpeg_enc_mode_go(struct device *dev, void __iomem *reg, u8 extseq);
12162306a36Sopenharmony_civoid mxc_jpeg_enc_set_quality(struct device *dev, void __iomem *reg, u8 quality);
12262306a36Sopenharmony_civoid mxc_jpeg_dec_mode_go(struct device *dev, void __iomem *reg);
12362306a36Sopenharmony_ciint mxc_jpeg_get_slot(void __iomem *reg);
12462306a36Sopenharmony_ciu32 mxc_jpeg_get_offset(void __iomem *reg, int slot);
12562306a36Sopenharmony_civoid mxc_jpeg_enable_slot(void __iomem *reg, int slot);
12662306a36Sopenharmony_civoid mxc_jpeg_set_l_endian(void __iomem *reg, int le);
12762306a36Sopenharmony_civoid mxc_jpeg_enable_irq(void __iomem *reg, int slot);
12862306a36Sopenharmony_civoid mxc_jpeg_disable_irq(void __iomem *reg, int slot);
12962306a36Sopenharmony_ciint mxc_jpeg_set_input(void __iomem *reg, u32 in_buf, u32 bufsize);
13062306a36Sopenharmony_ciint mxc_jpeg_set_output(void __iomem *reg, u16 out_pitch, u32 out_buf,
13162306a36Sopenharmony_ci			u16 w, u16 h);
13262306a36Sopenharmony_civoid mxc_jpeg_set_config_mode(void __iomem *reg, int config_mode);
13362306a36Sopenharmony_ciint mxc_jpeg_set_params(struct mxc_jpeg_desc *desc,  u32 bufsize, u16
13462306a36Sopenharmony_ci			out_pitch, u32 format);
13562306a36Sopenharmony_civoid mxc_jpeg_set_bufsize(struct mxc_jpeg_desc *desc,  u32 bufsize);
13662306a36Sopenharmony_civoid mxc_jpeg_set_res(struct mxc_jpeg_desc *desc, u16 w, u16 h);
13762306a36Sopenharmony_civoid mxc_jpeg_set_line_pitch(struct mxc_jpeg_desc *desc, u32 line_pitch);
13862306a36Sopenharmony_civoid mxc_jpeg_set_desc(u32 desc, void __iomem *reg, int slot);
13962306a36Sopenharmony_civoid mxc_jpeg_clr_desc(void __iomem *reg, int slot);
14062306a36Sopenharmony_civoid mxc_jpeg_set_regs_from_desc(struct mxc_jpeg_desc *desc,
14162306a36Sopenharmony_ci				 void __iomem *reg);
14262306a36Sopenharmony_ci#endif
143