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