aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/drivers/staging/media/atomisp/pci/hrt/hive_isp_css_custom_host_hrt.h
blob: c6893d712d61954b9846df38013d9594b5cdf69c (plain) (blame)
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
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
/*
 * Support for Medifield PNW Camera Imaging ISP subsystem.
 *
 * Copyright (c) 2010 Intel Corporation. All Rights Reserved.
 *
 * Copyright (c) 2010 Silicon Hive www.siliconhive.com.
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU General Public License version
 * 2 as published by the Free Software Foundation.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 *
 */
#ifndef _hive_isp_css_custom_host_hrt_h_
#define _hive_isp_css_custom_host_hrt_h_

#include <linux/delay.h>
#include "atomisp_helper.h"

/*
 * _hrt_master_port_store/load/uload -macros using __force attributed
 * cast to intentional dereferencing __iomem attributed (noderef)
 * pointer from atomisp_get_io_virt_addr
 */
#define _hrt_master_port_store_8(a, d) \
	(*((s8 __force *)atomisp_get_io_virt_addr(a)) = (d))

#define _hrt_master_port_store_16(a, d) \
	(*((s16 __force *)atomisp_get_io_virt_addr(a)) = (d))

#define _hrt_master_port_store_32(a, d) \
	(*((s32 __force *)atomisp_get_io_virt_addr(a)) = (d))

#define _hrt_master_port_load_8(a) \
	(*(s8 __force *)atomisp_get_io_virt_addr(a))

#define _hrt_master_port_load_16(a) \
	(*(s16 __force *)atomisp_get_io_virt_addr(a))

#define _hrt_master_port_load_32(a) \
	(*(s32 __force *)atomisp_get_io_virt_addr(a))

#define _hrt_master_port_uload_8(a) \
	(*(u8 __force *)atomisp_get_io_virt_addr(a))

#define _hrt_master_port_uload_16(a) \
	(*(u16 __force *)atomisp_get_io_virt_addr(a))

#define _hrt_master_port_uload_32(a) \
	(*(u32 __force *)atomisp_get_io_virt_addr(a))

#define _hrt_master_port_store_8_volatile(a, d)  _hrt_master_port_store_8(a, d)
#define _hrt_master_port_store_16_volatile(a, d) _hrt_master_port_store_16(a, d)
#define _hrt_master_port_store_32_volatile(a, d) _hrt_master_port_store_32(a, d)

#define _hrt_master_port_load_8_volatile(a)      _hrt_master_port_load_8(a)
#define _hrt_master_port_load_16_volatile(a)     _hrt_master_port_load_16(a)
#define _hrt_master_port_load_32_volatile(a)     _hrt_master_port_load_32(a)

#define _hrt_master_port_uload_8_volatile(a)     _hrt_master_port_uload_8(a)
#define _hrt_master_port_uload_16_volatile(a)    _hrt_master_port_uload_16(a)
#define _hrt_master_port_uload_32_volatile(a)    _hrt_master_port_uload_32(a)

static inline void hrt_sleep(void)
{
	udelay(1);
}

static inline u32 _hrt_mem_store(u32 to, const void *from, size_t n)
{
	unsigned int i;
	u32 _to = to;
	const char *_from = (const char *)from;

	for (i = 0; i < n; i++, _to++, _from++)
		_hrt_master_port_store_8(_to, *_from);
	return _to;
}

static inline void *_hrt_mem_load(u32 from, void *to, size_t n)
{
	unsigned int i;
	char *_to = (char *)to;
	u32 _from = from;

	for (i = 0; i < n; i++, _to++, _from++)
		*_to = _hrt_master_port_load_8(_from);
	return _to;
}

static inline u32 _hrt_mem_set(u32 to, int c, size_t n)
{
	unsigned int i;
	u32 _to = to;

	for (i = 0; i < n; i++, _to++)
		_hrt_master_port_store_8(_to, c);
	return _to;
}

#endif /* _hive_isp_css_custom_host_hrt_h_ */