1*f4104b78SMauro Carvalho Chehab // SPDX-License-Identifier: GPL-2.0-only
2*f4104b78SMauro Carvalho Chehab /* Copyright (c) 2013 Samsung Electronics Co., Ltd.
3*f4104b78SMauro Carvalho Chehab  *		http://www.samsung.com/
4*f4104b78SMauro Carvalho Chehab  *
5*f4104b78SMauro Carvalho Chehab  * Author: Jacek Anaszewski <j.anaszewski@samsung.com>
6*f4104b78SMauro Carvalho Chehab  *
7*f4104b78SMauro Carvalho Chehab  * Register interface file for JPEG driver on Exynos4x12.
8*f4104b78SMauro Carvalho Chehab  */
9*f4104b78SMauro Carvalho Chehab #include <linux/io.h>
10*f4104b78SMauro Carvalho Chehab #include <linux/delay.h>
11*f4104b78SMauro Carvalho Chehab 
12*f4104b78SMauro Carvalho Chehab #include "jpeg-core.h"
13*f4104b78SMauro Carvalho Chehab #include "jpeg-hw-exynos4.h"
14*f4104b78SMauro Carvalho Chehab #include "jpeg-regs.h"
15*f4104b78SMauro Carvalho Chehab 
exynos4_jpeg_sw_reset(void __iomem * base)16*f4104b78SMauro Carvalho Chehab void exynos4_jpeg_sw_reset(void __iomem *base)
17*f4104b78SMauro Carvalho Chehab {
18*f4104b78SMauro Carvalho Chehab 	unsigned int reg;
19*f4104b78SMauro Carvalho Chehab 
20*f4104b78SMauro Carvalho Chehab 	reg = readl(base + EXYNOS4_JPEG_CNTL_REG);
21*f4104b78SMauro Carvalho Chehab 	writel(reg & ~(EXYNOS4_DEC_MODE | EXYNOS4_ENC_MODE),
22*f4104b78SMauro Carvalho Chehab 				base + EXYNOS4_JPEG_CNTL_REG);
23*f4104b78SMauro Carvalho Chehab 
24*f4104b78SMauro Carvalho Chehab 	reg = readl(base + EXYNOS4_JPEG_CNTL_REG);
25*f4104b78SMauro Carvalho Chehab 	writel(reg & ~EXYNOS4_SOFT_RESET_HI, base + EXYNOS4_JPEG_CNTL_REG);
26*f4104b78SMauro Carvalho Chehab 
27*f4104b78SMauro Carvalho Chehab 	udelay(100);
28*f4104b78SMauro Carvalho Chehab 
29*f4104b78SMauro Carvalho Chehab 	writel(reg | EXYNOS4_SOFT_RESET_HI, base + EXYNOS4_JPEG_CNTL_REG);
30*f4104b78SMauro Carvalho Chehab }
31*f4104b78SMauro Carvalho Chehab 
exynos4_jpeg_set_enc_dec_mode(void __iomem * base,unsigned int mode)32*f4104b78SMauro Carvalho Chehab void exynos4_jpeg_set_enc_dec_mode(void __iomem *base, unsigned int mode)
33*f4104b78SMauro Carvalho Chehab {
34*f4104b78SMauro Carvalho Chehab 	unsigned int reg;
35*f4104b78SMauro Carvalho Chehab 
36*f4104b78SMauro Carvalho Chehab 	reg = readl(base + EXYNOS4_JPEG_CNTL_REG);
37*f4104b78SMauro Carvalho Chehab 	/* set exynos4_jpeg mod register */
38*f4104b78SMauro Carvalho Chehab 	if (mode == S5P_JPEG_DECODE) {
39*f4104b78SMauro Carvalho Chehab 		writel((reg & EXYNOS4_ENC_DEC_MODE_MASK) |
40*f4104b78SMauro Carvalho Chehab 					EXYNOS4_DEC_MODE,
41*f4104b78SMauro Carvalho Chehab 			base + EXYNOS4_JPEG_CNTL_REG);
42*f4104b78SMauro Carvalho Chehab 	} else if (mode == S5P_JPEG_ENCODE) {/* encode */
43*f4104b78SMauro Carvalho Chehab 		writel((reg & EXYNOS4_ENC_DEC_MODE_MASK) |
44*f4104b78SMauro Carvalho Chehab 					EXYNOS4_ENC_MODE,
45*f4104b78SMauro Carvalho Chehab 			base + EXYNOS4_JPEG_CNTL_REG);
46*f4104b78SMauro Carvalho Chehab 	} else { /* disable both */
47*f4104b78SMauro Carvalho Chehab 		writel(reg & EXYNOS4_ENC_DEC_MODE_MASK,
48*f4104b78SMauro Carvalho Chehab 			base + EXYNOS4_JPEG_CNTL_REG);
49*f4104b78SMauro Carvalho Chehab 	}
50*f4104b78SMauro Carvalho Chehab }
51*f4104b78SMauro Carvalho Chehab 
__exynos4_jpeg_set_img_fmt(void __iomem * base,unsigned int img_fmt,unsigned int version)52*f4104b78SMauro Carvalho Chehab void __exynos4_jpeg_set_img_fmt(void __iomem *base, unsigned int img_fmt,
53*f4104b78SMauro Carvalho Chehab 				unsigned int version)
54*f4104b78SMauro Carvalho Chehab {
55*f4104b78SMauro Carvalho Chehab 	unsigned int reg;
56*f4104b78SMauro Carvalho Chehab 	unsigned int exynos4_swap_chroma_cbcr;
57*f4104b78SMauro Carvalho Chehab 	unsigned int exynos4_swap_chroma_crcb;
58*f4104b78SMauro Carvalho Chehab 
59*f4104b78SMauro Carvalho Chehab 	if (version == SJPEG_EXYNOS4) {
60*f4104b78SMauro Carvalho Chehab 		exynos4_swap_chroma_cbcr = EXYNOS4_SWAP_CHROMA_CBCR;
61*f4104b78SMauro Carvalho Chehab 		exynos4_swap_chroma_crcb = EXYNOS4_SWAP_CHROMA_CRCB;
62*f4104b78SMauro Carvalho Chehab 	} else {
63*f4104b78SMauro Carvalho Chehab 		exynos4_swap_chroma_cbcr = EXYNOS5433_SWAP_CHROMA_CBCR;
64*f4104b78SMauro Carvalho Chehab 		exynos4_swap_chroma_crcb = EXYNOS5433_SWAP_CHROMA_CRCB;
65*f4104b78SMauro Carvalho Chehab 	}
66*f4104b78SMauro Carvalho Chehab 
67*f4104b78SMauro Carvalho Chehab 	reg = readl(base + EXYNOS4_IMG_FMT_REG) &
68*f4104b78SMauro Carvalho Chehab 			EXYNOS4_ENC_IN_FMT_MASK; /* clear except enc format */
69*f4104b78SMauro Carvalho Chehab 
70*f4104b78SMauro Carvalho Chehab 	switch (img_fmt) {
71*f4104b78SMauro Carvalho Chehab 	case V4L2_PIX_FMT_GREY:
72*f4104b78SMauro Carvalho Chehab 		reg = reg | EXYNOS4_ENC_GRAY_IMG | EXYNOS4_GRAY_IMG_IP;
73*f4104b78SMauro Carvalho Chehab 		break;
74*f4104b78SMauro Carvalho Chehab 	case V4L2_PIX_FMT_RGB32:
75*f4104b78SMauro Carvalho Chehab 		reg = reg | EXYNOS4_ENC_RGB_IMG |
76*f4104b78SMauro Carvalho Chehab 				EXYNOS4_RGB_IP_RGB_32BIT_IMG;
77*f4104b78SMauro Carvalho Chehab 		break;
78*f4104b78SMauro Carvalho Chehab 	case V4L2_PIX_FMT_RGB565:
79*f4104b78SMauro Carvalho Chehab 		reg = reg | EXYNOS4_ENC_RGB_IMG |
80*f4104b78SMauro Carvalho Chehab 				EXYNOS4_RGB_IP_RGB_16BIT_IMG;
81*f4104b78SMauro Carvalho Chehab 		break;
82*f4104b78SMauro Carvalho Chehab 	case V4L2_PIX_FMT_NV24:
83*f4104b78SMauro Carvalho Chehab 		reg = reg | EXYNOS4_ENC_YUV_444_IMG |
84*f4104b78SMauro Carvalho Chehab 				EXYNOS4_YUV_444_IP_YUV_444_2P_IMG |
85*f4104b78SMauro Carvalho Chehab 				exynos4_swap_chroma_cbcr;
86*f4104b78SMauro Carvalho Chehab 		break;
87*f4104b78SMauro Carvalho Chehab 	case V4L2_PIX_FMT_NV42:
88*f4104b78SMauro Carvalho Chehab 		reg = reg | EXYNOS4_ENC_YUV_444_IMG |
89*f4104b78SMauro Carvalho Chehab 				EXYNOS4_YUV_444_IP_YUV_444_2P_IMG |
90*f4104b78SMauro Carvalho Chehab 				exynos4_swap_chroma_crcb;
91*f4104b78SMauro Carvalho Chehab 		break;
92*f4104b78SMauro Carvalho Chehab 	case V4L2_PIX_FMT_YUYV:
93*f4104b78SMauro Carvalho Chehab 		reg = reg | EXYNOS4_DEC_YUV_422_IMG |
94*f4104b78SMauro Carvalho Chehab 				EXYNOS4_YUV_422_IP_YUV_422_1P_IMG |
95*f4104b78SMauro Carvalho Chehab 				exynos4_swap_chroma_cbcr;
96*f4104b78SMauro Carvalho Chehab 		break;
97*f4104b78SMauro Carvalho Chehab 
98*f4104b78SMauro Carvalho Chehab 	case V4L2_PIX_FMT_YVYU:
99*f4104b78SMauro Carvalho Chehab 		reg = reg | EXYNOS4_DEC_YUV_422_IMG |
100*f4104b78SMauro Carvalho Chehab 				EXYNOS4_YUV_422_IP_YUV_422_1P_IMG |
101*f4104b78SMauro Carvalho Chehab 				exynos4_swap_chroma_crcb;
102*f4104b78SMauro Carvalho Chehab 		break;
103*f4104b78SMauro Carvalho Chehab 	case V4L2_PIX_FMT_NV16:
104*f4104b78SMauro Carvalho Chehab 		reg = reg | EXYNOS4_DEC_YUV_422_IMG |
105*f4104b78SMauro Carvalho Chehab 				EXYNOS4_YUV_422_IP_YUV_422_2P_IMG |
106*f4104b78SMauro Carvalho Chehab 				exynos4_swap_chroma_cbcr;
107*f4104b78SMauro Carvalho Chehab 		break;
108*f4104b78SMauro Carvalho Chehab 	case V4L2_PIX_FMT_NV61:
109*f4104b78SMauro Carvalho Chehab 		reg = reg | EXYNOS4_DEC_YUV_422_IMG |
110*f4104b78SMauro Carvalho Chehab 				EXYNOS4_YUV_422_IP_YUV_422_2P_IMG |
111*f4104b78SMauro Carvalho Chehab 				exynos4_swap_chroma_crcb;
112*f4104b78SMauro Carvalho Chehab 		break;
113*f4104b78SMauro Carvalho Chehab 	case V4L2_PIX_FMT_NV12:
114*f4104b78SMauro Carvalho Chehab 		reg = reg | EXYNOS4_DEC_YUV_420_IMG |
115*f4104b78SMauro Carvalho Chehab 				EXYNOS4_YUV_420_IP_YUV_420_2P_IMG |
116*f4104b78SMauro Carvalho Chehab 				exynos4_swap_chroma_cbcr;
117*f4104b78SMauro Carvalho Chehab 		break;
118*f4104b78SMauro Carvalho Chehab 	case V4L2_PIX_FMT_NV21:
119*f4104b78SMauro Carvalho Chehab 		reg = reg | EXYNOS4_DEC_YUV_420_IMG |
120*f4104b78SMauro Carvalho Chehab 				EXYNOS4_YUV_420_IP_YUV_420_2P_IMG |
121*f4104b78SMauro Carvalho Chehab 				exynos4_swap_chroma_crcb;
122*f4104b78SMauro Carvalho Chehab 		break;
123*f4104b78SMauro Carvalho Chehab 	case V4L2_PIX_FMT_YUV420:
124*f4104b78SMauro Carvalho Chehab 		reg = reg | EXYNOS4_DEC_YUV_420_IMG |
125*f4104b78SMauro Carvalho Chehab 				EXYNOS4_YUV_420_IP_YUV_420_3P_IMG |
126*f4104b78SMauro Carvalho Chehab 				exynos4_swap_chroma_cbcr;
127*f4104b78SMauro Carvalho Chehab 		break;
128*f4104b78SMauro Carvalho Chehab 	default:
129*f4104b78SMauro Carvalho Chehab 		break;
130*f4104b78SMauro Carvalho Chehab 
131*f4104b78SMauro Carvalho Chehab 	}
132*f4104b78SMauro Carvalho Chehab 
133*f4104b78SMauro Carvalho Chehab 	writel(reg, base + EXYNOS4_IMG_FMT_REG);
134*f4104b78SMauro Carvalho Chehab }
135*f4104b78SMauro Carvalho Chehab 
__exynos4_jpeg_set_enc_out_fmt(void __iomem * base,unsigned int out_fmt,unsigned int version)136*f4104b78SMauro Carvalho Chehab void __exynos4_jpeg_set_enc_out_fmt(void __iomem *base, unsigned int out_fmt,
137*f4104b78SMauro Carvalho Chehab 				    unsigned int version)
138*f4104b78SMauro Carvalho Chehab {
139*f4104b78SMauro Carvalho Chehab 	unsigned int reg;
140*f4104b78SMauro Carvalho Chehab 
141*f4104b78SMauro Carvalho Chehab 	reg = readl(base + EXYNOS4_IMG_FMT_REG) &
142*f4104b78SMauro Carvalho Chehab 			~(version == SJPEG_EXYNOS4 ? EXYNOS4_ENC_FMT_MASK :
143*f4104b78SMauro Carvalho Chehab 			  EXYNOS5433_ENC_FMT_MASK); /* clear enc format */
144*f4104b78SMauro Carvalho Chehab 
145*f4104b78SMauro Carvalho Chehab 	switch (out_fmt) {
146*f4104b78SMauro Carvalho Chehab 	case V4L2_JPEG_CHROMA_SUBSAMPLING_GRAY:
147*f4104b78SMauro Carvalho Chehab 		reg = reg | EXYNOS4_ENC_FMT_GRAY;
148*f4104b78SMauro Carvalho Chehab 		break;
149*f4104b78SMauro Carvalho Chehab 
150*f4104b78SMauro Carvalho Chehab 	case V4L2_JPEG_CHROMA_SUBSAMPLING_444:
151*f4104b78SMauro Carvalho Chehab 		reg = reg | EXYNOS4_ENC_FMT_YUV_444;
152*f4104b78SMauro Carvalho Chehab 		break;
153*f4104b78SMauro Carvalho Chehab 
154*f4104b78SMauro Carvalho Chehab 	case V4L2_JPEG_CHROMA_SUBSAMPLING_422:
155*f4104b78SMauro Carvalho Chehab 		reg = reg | EXYNOS4_ENC_FMT_YUV_422;
156*f4104b78SMauro Carvalho Chehab 		break;
157*f4104b78SMauro Carvalho Chehab 
158*f4104b78SMauro Carvalho Chehab 	case V4L2_JPEG_CHROMA_SUBSAMPLING_420:
159*f4104b78SMauro Carvalho Chehab 		reg = reg | EXYNOS4_ENC_FMT_YUV_420;
160*f4104b78SMauro Carvalho Chehab 		break;
161*f4104b78SMauro Carvalho Chehab 
162*f4104b78SMauro Carvalho Chehab 	default:
163*f4104b78SMauro Carvalho Chehab 		break;
164*f4104b78SMauro Carvalho Chehab 	}
165*f4104b78SMauro Carvalho Chehab 
166*f4104b78SMauro Carvalho Chehab 	writel(reg, base + EXYNOS4_IMG_FMT_REG);
167*f4104b78SMauro Carvalho Chehab }
168*f4104b78SMauro Carvalho Chehab 
exynos4_jpeg_set_interrupt(void __iomem * base,unsigned int version)169*f4104b78SMauro Carvalho Chehab void exynos4_jpeg_set_interrupt(void __iomem *base, unsigned int version)
170*f4104b78SMauro Carvalho Chehab {
171*f4104b78SMauro Carvalho Chehab 	unsigned int reg;
172*f4104b78SMauro Carvalho Chehab 
173*f4104b78SMauro Carvalho Chehab 	if (version == SJPEG_EXYNOS4) {
174*f4104b78SMauro Carvalho Chehab 		reg = readl(base + EXYNOS4_INT_EN_REG) & ~EXYNOS4_INT_EN_MASK;
175*f4104b78SMauro Carvalho Chehab 		writel(reg | EXYNOS4_INT_EN_ALL, base + EXYNOS4_INT_EN_REG);
176*f4104b78SMauro Carvalho Chehab 	} else {
177*f4104b78SMauro Carvalho Chehab 		reg = readl(base + EXYNOS4_INT_EN_REG) &
178*f4104b78SMauro Carvalho Chehab 							~EXYNOS5433_INT_EN_MASK;
179*f4104b78SMauro Carvalho Chehab 		writel(reg | EXYNOS5433_INT_EN_ALL, base + EXYNOS4_INT_EN_REG);
180*f4104b78SMauro Carvalho Chehab 	}
181*f4104b78SMauro Carvalho Chehab }
182*f4104b78SMauro Carvalho Chehab 
exynos4_jpeg_get_int_status(void __iomem * base)183*f4104b78SMauro Carvalho Chehab unsigned int exynos4_jpeg_get_int_status(void __iomem *base)
184*f4104b78SMauro Carvalho Chehab {
185*f4104b78SMauro Carvalho Chehab 	return readl(base + EXYNOS4_INT_STATUS_REG);
186*f4104b78SMauro Carvalho Chehab }
187*f4104b78SMauro Carvalho Chehab 
exynos4_jpeg_get_fifo_status(void __iomem * base)188*f4104b78SMauro Carvalho Chehab unsigned int exynos4_jpeg_get_fifo_status(void __iomem *base)
189*f4104b78SMauro Carvalho Chehab {
190*f4104b78SMauro Carvalho Chehab 	return readl(base + EXYNOS4_FIFO_STATUS_REG);
191*f4104b78SMauro Carvalho Chehab }
192*f4104b78SMauro Carvalho Chehab 
exynos4_jpeg_set_huf_table_enable(void __iomem * base,int value)193*f4104b78SMauro Carvalho Chehab void exynos4_jpeg_set_huf_table_enable(void __iomem *base, int value)
194*f4104b78SMauro Carvalho Chehab {
195*f4104b78SMauro Carvalho Chehab 	unsigned int	reg;
196*f4104b78SMauro Carvalho Chehab 
197*f4104b78SMauro Carvalho Chehab 	reg = readl(base + EXYNOS4_JPEG_CNTL_REG) & ~EXYNOS4_HUF_TBL_EN;
198*f4104b78SMauro Carvalho Chehab 
199*f4104b78SMauro Carvalho Chehab 	if (value == 1)
200*f4104b78SMauro Carvalho Chehab 		writel(reg | EXYNOS4_HUF_TBL_EN,
201*f4104b78SMauro Carvalho Chehab 					base + EXYNOS4_JPEG_CNTL_REG);
202*f4104b78SMauro Carvalho Chehab 	else
203*f4104b78SMauro Carvalho Chehab 		writel(reg & ~EXYNOS4_HUF_TBL_EN,
204*f4104b78SMauro Carvalho Chehab 					base + EXYNOS4_JPEG_CNTL_REG);
205*f4104b78SMauro Carvalho Chehab }
206*f4104b78SMauro Carvalho Chehab 
exynos4_jpeg_set_sys_int_enable(void __iomem * base,int value)207*f4104b78SMauro Carvalho Chehab void exynos4_jpeg_set_sys_int_enable(void __iomem *base, int value)
208*f4104b78SMauro Carvalho Chehab {
209*f4104b78SMauro Carvalho Chehab 	unsigned int	reg;
210*f4104b78SMauro Carvalho Chehab 
211*f4104b78SMauro Carvalho Chehab 	reg = readl(base + EXYNOS4_JPEG_CNTL_REG) & ~(EXYNOS4_SYS_INT_EN);
212*f4104b78SMauro Carvalho Chehab 
213*f4104b78SMauro Carvalho Chehab 	if (value == 1)
214*f4104b78SMauro Carvalho Chehab 		writel(reg | EXYNOS4_SYS_INT_EN, base + EXYNOS4_JPEG_CNTL_REG);
215*f4104b78SMauro Carvalho Chehab 	else
216*f4104b78SMauro Carvalho Chehab 		writel(reg & ~EXYNOS4_SYS_INT_EN, base + EXYNOS4_JPEG_CNTL_REG);
217*f4104b78SMauro Carvalho Chehab }
218*f4104b78SMauro Carvalho Chehab 
exynos4_jpeg_set_stream_buf_address(void __iomem * base,unsigned int address)219*f4104b78SMauro Carvalho Chehab void exynos4_jpeg_set_stream_buf_address(void __iomem *base,
220*f4104b78SMauro Carvalho Chehab 					 unsigned int address)
221*f4104b78SMauro Carvalho Chehab {
222*f4104b78SMauro Carvalho Chehab 	writel(address, base + EXYNOS4_OUT_MEM_BASE_REG);
223*f4104b78SMauro Carvalho Chehab }
224*f4104b78SMauro Carvalho Chehab 
exynos4_jpeg_set_stream_size(void __iomem * base,unsigned int x_value,unsigned int y_value)225*f4104b78SMauro Carvalho Chehab void exynos4_jpeg_set_stream_size(void __iomem *base,
226*f4104b78SMauro Carvalho Chehab 		unsigned int x_value, unsigned int y_value)
227*f4104b78SMauro Carvalho Chehab {
228*f4104b78SMauro Carvalho Chehab 	writel(0x0, base + EXYNOS4_JPEG_IMG_SIZE_REG); /* clear */
229*f4104b78SMauro Carvalho Chehab 	writel(EXYNOS4_X_SIZE(x_value) | EXYNOS4_Y_SIZE(y_value),
230*f4104b78SMauro Carvalho Chehab 			base + EXYNOS4_JPEG_IMG_SIZE_REG);
231*f4104b78SMauro Carvalho Chehab }
232*f4104b78SMauro Carvalho Chehab 
exynos4_jpeg_set_frame_buf_address(void __iomem * base,struct s5p_jpeg_addr * exynos4_jpeg_addr)233*f4104b78SMauro Carvalho Chehab void exynos4_jpeg_set_frame_buf_address(void __iomem *base,
234*f4104b78SMauro Carvalho Chehab 				struct s5p_jpeg_addr *exynos4_jpeg_addr)
235*f4104b78SMauro Carvalho Chehab {
236*f4104b78SMauro Carvalho Chehab 	writel(exynos4_jpeg_addr->y, base + EXYNOS4_IMG_BA_PLANE_1_REG);
237*f4104b78SMauro Carvalho Chehab 	writel(exynos4_jpeg_addr->cb, base + EXYNOS4_IMG_BA_PLANE_2_REG);
238*f4104b78SMauro Carvalho Chehab 	writel(exynos4_jpeg_addr->cr, base + EXYNOS4_IMG_BA_PLANE_3_REG);
239*f4104b78SMauro Carvalho Chehab }
240*f4104b78SMauro Carvalho Chehab 
exynos4_jpeg_set_encode_tbl_select(void __iomem * base,enum exynos4_jpeg_img_quality_level level)241*f4104b78SMauro Carvalho Chehab void exynos4_jpeg_set_encode_tbl_select(void __iomem *base,
242*f4104b78SMauro Carvalho Chehab 		enum exynos4_jpeg_img_quality_level level)
243*f4104b78SMauro Carvalho Chehab {
244*f4104b78SMauro Carvalho Chehab 	unsigned int	reg;
245*f4104b78SMauro Carvalho Chehab 
246*f4104b78SMauro Carvalho Chehab 	reg = EXYNOS4_Q_TBL_COMP1_0 | EXYNOS4_Q_TBL_COMP2_1 |
247*f4104b78SMauro Carvalho Chehab 		EXYNOS4_Q_TBL_COMP3_1 |
248*f4104b78SMauro Carvalho Chehab 		EXYNOS4_HUFF_TBL_COMP1_AC_0_DC_1 |
249*f4104b78SMauro Carvalho Chehab 		EXYNOS4_HUFF_TBL_COMP2_AC_0_DC_0 |
250*f4104b78SMauro Carvalho Chehab 		EXYNOS4_HUFF_TBL_COMP3_AC_1_DC_1;
251*f4104b78SMauro Carvalho Chehab 
252*f4104b78SMauro Carvalho Chehab 	writel(reg, base + EXYNOS4_TBL_SEL_REG);
253*f4104b78SMauro Carvalho Chehab }
254*f4104b78SMauro Carvalho Chehab 
exynos4_jpeg_set_dec_components(void __iomem * base,int n)255*f4104b78SMauro Carvalho Chehab void exynos4_jpeg_set_dec_components(void __iomem *base, int n)
256*f4104b78SMauro Carvalho Chehab {
257*f4104b78SMauro Carvalho Chehab 	unsigned int	reg;
258*f4104b78SMauro Carvalho Chehab 
259*f4104b78SMauro Carvalho Chehab 	reg = readl(base + EXYNOS4_TBL_SEL_REG);
260*f4104b78SMauro Carvalho Chehab 
261*f4104b78SMauro Carvalho Chehab 	reg |= EXYNOS4_NF(n);
262*f4104b78SMauro Carvalho Chehab 	writel(reg, base + EXYNOS4_TBL_SEL_REG);
263*f4104b78SMauro Carvalho Chehab }
264*f4104b78SMauro Carvalho Chehab 
exynos4_jpeg_select_dec_q_tbl(void __iomem * base,char c,char x)265*f4104b78SMauro Carvalho Chehab void exynos4_jpeg_select_dec_q_tbl(void __iomem *base, char c, char x)
266*f4104b78SMauro Carvalho Chehab {
267*f4104b78SMauro Carvalho Chehab 	unsigned int	reg;
268*f4104b78SMauro Carvalho Chehab 
269*f4104b78SMauro Carvalho Chehab 	reg = readl(base + EXYNOS4_TBL_SEL_REG);
270*f4104b78SMauro Carvalho Chehab 
271*f4104b78SMauro Carvalho Chehab 	reg |= EXYNOS4_Q_TBL_COMP(c, x);
272*f4104b78SMauro Carvalho Chehab 	writel(reg, base + EXYNOS4_TBL_SEL_REG);
273*f4104b78SMauro Carvalho Chehab }
274*f4104b78SMauro Carvalho Chehab 
exynos4_jpeg_select_dec_h_tbl(void __iomem * base,char c,char x)275*f4104b78SMauro Carvalho Chehab void exynos4_jpeg_select_dec_h_tbl(void __iomem *base, char c, char x)
276*f4104b78SMauro Carvalho Chehab {
277*f4104b78SMauro Carvalho Chehab 	unsigned int	reg;
278*f4104b78SMauro Carvalho Chehab 
279*f4104b78SMauro Carvalho Chehab 	reg = readl(base + EXYNOS4_TBL_SEL_REG);
280*f4104b78SMauro Carvalho Chehab 
281*f4104b78SMauro Carvalho Chehab 	reg |= EXYNOS4_HUFF_TBL_COMP(c, x);
282*f4104b78SMauro Carvalho Chehab 	writel(reg, base + EXYNOS4_TBL_SEL_REG);
283*f4104b78SMauro Carvalho Chehab }
284*f4104b78SMauro Carvalho Chehab 
exynos4_jpeg_set_encode_hoff_cnt(void __iomem * base,unsigned int fmt)285*f4104b78SMauro Carvalho Chehab void exynos4_jpeg_set_encode_hoff_cnt(void __iomem *base, unsigned int fmt)
286*f4104b78SMauro Carvalho Chehab {
287*f4104b78SMauro Carvalho Chehab 	if (fmt == V4L2_PIX_FMT_GREY)
288*f4104b78SMauro Carvalho Chehab 		writel(0xd2, base + EXYNOS4_HUFF_CNT_REG);
289*f4104b78SMauro Carvalho Chehab 	else
290*f4104b78SMauro Carvalho Chehab 		writel(0x1a2, base + EXYNOS4_HUFF_CNT_REG);
291*f4104b78SMauro Carvalho Chehab }
292*f4104b78SMauro Carvalho Chehab 
exynos4_jpeg_get_stream_size(void __iomem * base)293*f4104b78SMauro Carvalho Chehab unsigned int exynos4_jpeg_get_stream_size(void __iomem *base)
294*f4104b78SMauro Carvalho Chehab {
295*f4104b78SMauro Carvalho Chehab 	return readl(base + EXYNOS4_BITSTREAM_SIZE_REG);
296*f4104b78SMauro Carvalho Chehab }
297*f4104b78SMauro Carvalho Chehab 
exynos4_jpeg_set_dec_bitstream_size(void __iomem * base,unsigned int size)298*f4104b78SMauro Carvalho Chehab void exynos4_jpeg_set_dec_bitstream_size(void __iomem *base, unsigned int size)
299*f4104b78SMauro Carvalho Chehab {
300*f4104b78SMauro Carvalho Chehab 	writel(size, base + EXYNOS4_BITSTREAM_SIZE_REG);
301*f4104b78SMauro Carvalho Chehab }
302*f4104b78SMauro Carvalho Chehab 
exynos4_jpeg_get_frame_size(void __iomem * base,unsigned int * width,unsigned int * height)303*f4104b78SMauro Carvalho Chehab void exynos4_jpeg_get_frame_size(void __iomem *base,
304*f4104b78SMauro Carvalho Chehab 			unsigned int *width, unsigned int *height)
305*f4104b78SMauro Carvalho Chehab {
306*f4104b78SMauro Carvalho Chehab 	*width = (readl(base + EXYNOS4_DECODE_XY_SIZE_REG) &
307*f4104b78SMauro Carvalho Chehab 				EXYNOS4_DECODED_SIZE_MASK);
308*f4104b78SMauro Carvalho Chehab 	*height = (readl(base + EXYNOS4_DECODE_XY_SIZE_REG) >> 16) &
309*f4104b78SMauro Carvalho Chehab 				EXYNOS4_DECODED_SIZE_MASK;
310*f4104b78SMauro Carvalho Chehab }
311*f4104b78SMauro Carvalho Chehab 
exynos4_jpeg_get_frame_fmt(void __iomem * base)312*f4104b78SMauro Carvalho Chehab unsigned int exynos4_jpeg_get_frame_fmt(void __iomem *base)
313*f4104b78SMauro Carvalho Chehab {
314*f4104b78SMauro Carvalho Chehab 	return readl(base + EXYNOS4_DECODE_IMG_FMT_REG) &
315*f4104b78SMauro Carvalho Chehab 				EXYNOS4_JPEG_DECODED_IMG_FMT_MASK;
316*f4104b78SMauro Carvalho Chehab }
317*f4104b78SMauro Carvalho Chehab 
exynos4_jpeg_set_timer_count(void __iomem * base,unsigned int size)318*f4104b78SMauro Carvalho Chehab void exynos4_jpeg_set_timer_count(void __iomem *base, unsigned int size)
319*f4104b78SMauro Carvalho Chehab {
320*f4104b78SMauro Carvalho Chehab 	writel(size, base + EXYNOS4_INT_TIMER_COUNT_REG);
321*f4104b78SMauro Carvalho Chehab }
322