summaryrefslogtreecommitdiffstats
path: root/drivers/staging/media/atomisp/pci/atomisp2/css2400/css_2401_system/hrt/var.h
blob: 19b19ef484f953867e311a95df2e48c418ffa156 (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
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
#ifndef ISP2401
/*
 * Support for Intel Camera Imaging ISP subsystem.
 * Copyright (c) 2015, Intel Corporation.
 *
 * This program is free software; you can redistribute it and/or modify it
 * under the terms and conditions of the GNU General Public License,
 * version 2, as published by the Free Software Foundation.
 *
 * This program is distributed in the hope 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 _HRT_VAR_H
#define _HRT_VAR_H

#include "version.h"
#include "system_api.h"
#include "hive_types.h"

#define hrt_int_type_of_char   char
#define hrt_int_type_of_uchar  unsigned char
#define hrt_int_type_of_short  short
#define hrt_int_type_of_ushort unsigned short
#define hrt_int_type_of_int    int
#define hrt_int_type_of_uint   unsigned int
#define hrt_int_type_of_long   long
#define hrt_int_type_of_ulong  unsigned long
#define hrt_int_type_of_ptr    unsigned int

#define hrt_host_type_of_char   char
#define hrt_host_type_of_uchar  unsigned char
#define hrt_host_type_of_short  short
#define hrt_host_type_of_ushort unsigned short
#define hrt_host_type_of_int    int
#define hrt_host_type_of_uint   unsigned int
#define hrt_host_type_of_long   long
#define hrt_host_type_of_ulong  unsigned long
#define hrt_host_type_of_ptr    void*

#define HRT_TYPE_BYTES(cell, type) (HRT_TYPE_BITS(cell, type)/8)
#define HRT_HOST_TYPE(cell_type)   HRTCAT(hrt_host_type_of_, cell_type)
#define HRT_INT_TYPE(type)         HRTCAT(hrt_int_type_of_, type)

#ifdef C_RUN

#ifdef C_RUN_DYNAMIC_LINK_PROGRAMS
extern void *csim_processor_get_crun_symbol(hive_proc_id p, const char *sym);
#define _hrt_cell_get_crun_symbol(cell,sym)          csim_processor_get_crun_symbol(cell,HRTSTR(sym))
#define _hrt_cell_get_crun_indexed_symbol(cell,sym)  csim_processor_get_crun_symbol(cell,HRTSTR(sym))
#else
#define _hrt_cell_get_crun_symbol(cell,sym)         (&sym)
#define _hrt_cell_get_crun_indexed_symbol(cell,sym) (sym)
#endif //  C_RUN_DYNAMIC_LINK_PROGRAMS

#define hrt_scalar_store(cell, type, var, data) \
	((*(HRT_HOST_TYPE(type)*)_hrt_cell_get_crun_symbol(cell,var)) = (data))
#define hrt_scalar_load(cell, type, var) \
	((*(HRT_HOST_TYPE(type)*)_hrt_cell_get_crun_symbol(cell,var)))

#define hrt_indexed_store(cell, type, array, index, data) \
	((((HRT_HOST_TYPE(type)*)_hrt_cell_get_crun_indexed_symbol(cell,array))[index]) = (data))
#define hrt_indexed_load(cell, type, array, index) \
	(((HRT_HOST_TYPE(type)*)_hrt_cell_get_crun_indexed_symbol(cell,array))[index])

#else /* C_RUN */

#define hrt_scalar_store(cell, type, var, data) \
  HRTCAT(hrt_mem_store_,HRT_TYPE_BITS(cell, type))(\
	       cell, \
	       HRTCAT(HIVE_MEM_,var), \
	       HRTCAT(HIVE_ADDR_,var), \
	       (HRT_INT_TYPE(type))(data))

#define hrt_scalar_load(cell, type, var) \
  (HRT_HOST_TYPE(type))(HRTCAT4(_hrt_mem_load_,HRT_PROC_TYPE(cell),_,type) ( \
	       cell, \
	       HRTCAT(HIVE_MEM_,var), \
	       HRTCAT(HIVE_ADDR_,var)))

#define hrt_indexed_store(cell, type, array, index, data) \
  HRTCAT(hrt_mem_store_,HRT_TYPE_BITS(cell, type))(\
	       cell, \
	       HRTCAT(HIVE_MEM_,array), \
	       (HRTCAT(HIVE_ADDR_,array))+((index)*HRT_TYPE_BYTES(cell, type)), \
	       (HRT_INT_TYPE(type))(data))

#define hrt_indexed_load(cell, type, array, index) \
  (HRT_HOST_TYPE(type))(HRTCAT4(_hrt_mem_load_,HRT_PROC_TYPE(cell),_,type) ( \
         cell, \
	       HRTCAT(HIVE_MEM_,array), \
	       (HRTCAT(HIVE_ADDR_,array))+((index)*HRT_TYPE_BYTES(cell, type))))

#endif /* C_RUN */

#endif /* _HRT_VAR_H */
#endif
OpenPOWER on IntegriCloud