blob: 11348379f0939095704b2e20dd17d3755ef2508f [file] [log] [blame]
Damian7caa4342011-05-18 11:10:07 +00001#ifndef __VIDEO_SH_MOBILE_MERAM_H__
2#define __VIDEO_SH_MOBILE_MERAM_H__
3
4/* For sh_mobile_meram_info.addr_mode */
5enum {
6 SH_MOBILE_MERAM_MODE0 = 0,
7 SH_MOBILE_MERAM_MODE1
8};
9
10enum {
11 SH_MOBILE_MERAM_PF_NV = 0,
Damian3fedd2a2011-05-18 11:10:08 +000012 SH_MOBILE_MERAM_PF_RGB,
13 SH_MOBILE_MERAM_PF_NV24
Damian7caa4342011-05-18 11:10:07 +000014};
15
16
17struct sh_mobile_meram_priv;
Damian7caa4342011-05-18 11:10:07 +000018
Laurent Pinchart48110052011-12-12 16:36:13 +010019/*
20 * struct sh_mobile_meram_info - MERAM platform data
21 * @reserved_icbs: Bitmask of reserved ICBs (for instance used through UIO)
22 */
Damian7caa4342011-05-18 11:10:07 +000023struct sh_mobile_meram_info {
24 int addr_mode;
Laurent Pinchart48110052011-12-12 16:36:13 +010025 u32 reserved_icbs;
Damian7caa4342011-05-18 11:10:07 +000026 struct sh_mobile_meram_priv *priv;
27 struct platform_device *pdev;
28};
29
30/* icb config */
Laurent Pinchartd272f422011-09-19 11:40:31 +020031struct sh_mobile_meram_icb_cfg {
Laurent Pinchartd272f422011-09-19 11:40:31 +020032 unsigned int meram_size; /* MERAM Buffer Size to use */
Damian7caa4342011-05-18 11:10:07 +000033};
34
35struct sh_mobile_meram_cfg {
Laurent Pinchart2a618e02011-09-19 11:40:31 +020036 struct sh_mobile_meram_icb_cfg icb[2];
Damian7caa4342011-05-18 11:10:07 +000037};
38
Laurent Pinchart6e729b42012-03-15 12:40:47 +010039#if defined(CONFIG_FB_SH_MOBILE_MERAM) || \
40 defined(CONFIG_FB_SH_MOBILE_MERAM_MODULE)
41void *sh_mobile_meram_cache_alloc(struct sh_mobile_meram_info *dev,
42 const struct sh_mobile_meram_cfg *cfg,
43 unsigned int xres, unsigned int yres,
44 unsigned int pixelformat,
45 unsigned int *pitch);
46void sh_mobile_meram_cache_free(struct sh_mobile_meram_info *dev, void *data);
47void sh_mobile_meram_cache_update(struct sh_mobile_meram_info *dev, void *data,
48 unsigned long base_addr_y,
49 unsigned long base_addr_c,
50 unsigned long *icb_addr_y,
51 unsigned long *icb_addr_c);
52#else
53static inline void *
54sh_mobile_meram_cache_alloc(struct sh_mobile_meram_info *dev,
55 const struct sh_mobile_meram_cfg *cfg,
56 unsigned int xres, unsigned int yres,
57 unsigned int pixelformat,
58 unsigned int *pitch)
59{
60 return ERR_PTR(-ENODEV);
61}
Damian7caa4342011-05-18 11:10:07 +000062
Laurent Pinchart6e729b42012-03-15 12:40:47 +010063static inline void
64sh_mobile_meram_cache_free(struct sh_mobile_meram_info *dev, void *data)
65{
66}
67
68static inline void
69sh_mobile_meram_cache_update(struct sh_mobile_meram_info *dev, void *data,
Laurent Pinchartcdf88b92011-11-22 00:56:58 +010070 unsigned long base_addr_y,
71 unsigned long base_addr_c,
72 unsigned long *icb_addr_y,
Laurent Pinchart6e729b42012-03-15 12:40:47 +010073 unsigned long *icb_addr_c)
74{
75}
76#endif
Damian7caa4342011-05-18 11:10:07 +000077
78#endif /* __VIDEO_SH_MOBILE_MERAM_H__ */