summaryrefslogtreecommitdiff
path: root/include/linux/ipu-v3-prg.h
blob: 2ab803a6699f393d2c37bd985938cb212c256ac7 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
/*
 * Copyright (C) 2014-2015 Freescale Semiconductor, Inc.
 *
 * The code contained herein is licensed under the GNU General Public
 * License. You may obtain a copy of the GNU General Public License
 * Version 2 or later at the following locations:
 *
 * http://www.opensource.org/licenses/gpl-license.html
 * http://www.gnu.org/copyleft/gpl.html
 */
#ifndef __LINUX_IPU_V3_PRG_H_
#define __LINUX_IPU_V3_PRG_H_

#include <linux/ipu-v3.h>

#define PRG_SO_INTERLACE	1
#define PRG_SO_PROGRESSIVE	0
#define PRG_BLOCK_MODE		1
#define PRG_SCAN_MODE		0

struct ipu_prg_config {
	unsigned int id;
	unsigned int pre_num;
	ipu_channel_t ipu_ch;
	unsigned int stride;
	unsigned int height;
	unsigned int ipu_height;
	unsigned int crop_line;
	unsigned int so;
	unsigned int ilo;
	unsigned int block_mode;
	bool vflip;
	u32 baddr;
	u32 offset;
};

#ifdef CONFIG_MXC_IPU_V3_PRG
int ipu_prg_config(struct ipu_prg_config *config);
int ipu_prg_disable(unsigned int ipu_id, unsigned int pre_num);
int ipu_prg_wait_buf_ready(unsigned int ipu_id, unsigned int pre_num,
			   unsigned int hsk_line_num,
			   int pre_store_out_height);
#else
int ipu_prg_config(struct ipu_prg_config *config)
{
	return -ENODEV;
}

int ipu_prg_disable(unsigned int ipu_id, unsigned int pre_num)
{
	return -ENODEV;
}

int ipu_prg_wait_buf_ready(unsigned int ipu_id, unsigned int pre_num,
			   unsigned int hsk_line_num,
			   int pre_store_out_height)
{
	return -ENODEV;
}
#endif
#endif /* __LINUX_IPU_V3_PRG_H_ */