2011-05-18 04:10:07 -07:00
|
|
|
#ifndef __VIDEO_SH_MOBILE_MERAM_H__
|
|
|
|
#define __VIDEO_SH_MOBILE_MERAM_H__
|
|
|
|
|
|
|
|
/* For sh_mobile_meram_info.addr_mode */
|
|
|
|
enum {
|
|
|
|
SH_MOBILE_MERAM_MODE0 = 0,
|
|
|
|
SH_MOBILE_MERAM_MODE1
|
|
|
|
};
|
|
|
|
|
|
|
|
enum {
|
|
|
|
SH_MOBILE_MERAM_PF_NV = 0,
|
2011-05-18 04:10:08 -07:00
|
|
|
SH_MOBILE_MERAM_PF_RGB,
|
|
|
|
SH_MOBILE_MERAM_PF_NV24
|
2011-05-18 04:10:07 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
struct sh_mobile_meram_priv;
|
|
|
|
|
2011-12-12 08:36:13 -07:00
|
|
|
/*
|
|
|
|
* struct sh_mobile_meram_info - MERAM platform data
|
|
|
|
* @reserved_icbs: Bitmask of reserved ICBs (for instance used through UIO)
|
|
|
|
*/
|
2011-05-18 04:10:07 -07:00
|
|
|
struct sh_mobile_meram_info {
|
|
|
|
int addr_mode;
|
2011-12-12 08:36:13 -07:00
|
|
|
u32 reserved_icbs;
|
2011-05-18 04:10:07 -07:00
|
|
|
struct sh_mobile_meram_priv *priv;
|
|
|
|
struct platform_device *pdev;
|
|
|
|
};
|
|
|
|
|
|
|
|
/* icb config */
|
2011-09-19 02:40:31 -07:00
|
|
|
struct sh_mobile_meram_icb_cfg {
|
|
|
|
unsigned int meram_size; /* MERAM Buffer Size to use */
|
2011-05-18 04:10:07 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
struct sh_mobile_meram_cfg {
|
2011-09-19 02:40:31 -07:00
|
|
|
struct sh_mobile_meram_icb_cfg icb[2];
|
2011-05-18 04:10:07 -07:00
|
|
|
};
|
|
|
|
|
2012-03-15 04:40:47 -07:00
|
|
|
#if defined(CONFIG_FB_SH_MOBILE_MERAM) || \
|
|
|
|
defined(CONFIG_FB_SH_MOBILE_MERAM_MODULE)
|
2012-03-15 05:18:17 -07:00
|
|
|
unsigned long sh_mobile_meram_alloc(struct sh_mobile_meram_info *meram_dev,
|
|
|
|
size_t size);
|
|
|
|
void sh_mobile_meram_free(struct sh_mobile_meram_info *meram_dev,
|
|
|
|
unsigned long mem, size_t size);
|
2012-03-15 04:40:47 -07:00
|
|
|
void *sh_mobile_meram_cache_alloc(struct sh_mobile_meram_info *dev,
|
|
|
|
const struct sh_mobile_meram_cfg *cfg,
|
|
|
|
unsigned int xres, unsigned int yres,
|
|
|
|
unsigned int pixelformat,
|
|
|
|
unsigned int *pitch);
|
|
|
|
void sh_mobile_meram_cache_free(struct sh_mobile_meram_info *dev, void *data);
|
|
|
|
void sh_mobile_meram_cache_update(struct sh_mobile_meram_info *dev, void *data,
|
|
|
|
unsigned long base_addr_y,
|
|
|
|
unsigned long base_addr_c,
|
|
|
|
unsigned long *icb_addr_y,
|
|
|
|
unsigned long *icb_addr_c);
|
|
|
|
#else
|
2012-03-15 05:18:17 -07:00
|
|
|
static inline unsigned long
|
|
|
|
sh_mobile_meram_alloc(struct sh_mobile_meram_info *meram_dev, size_t size)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void
|
|
|
|
sh_mobile_meram_free(struct sh_mobile_meram_info *meram_dev,
|
|
|
|
unsigned long mem, size_t size)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2012-03-15 04:40:47 -07:00
|
|
|
static inline void *
|
|
|
|
sh_mobile_meram_cache_alloc(struct sh_mobile_meram_info *dev,
|
|
|
|
const struct sh_mobile_meram_cfg *cfg,
|
|
|
|
unsigned int xres, unsigned int yres,
|
|
|
|
unsigned int pixelformat,
|
|
|
|
unsigned int *pitch)
|
|
|
|
{
|
|
|
|
return ERR_PTR(-ENODEV);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void
|
|
|
|
sh_mobile_meram_cache_free(struct sh_mobile_meram_info *dev, void *data)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void
|
|
|
|
sh_mobile_meram_cache_update(struct sh_mobile_meram_info *dev, void *data,
|
2011-11-21 16:56:58 -07:00
|
|
|
unsigned long base_addr_y,
|
|
|
|
unsigned long base_addr_c,
|
|
|
|
unsigned long *icb_addr_y,
|
2012-03-15 04:40:47 -07:00
|
|
|
unsigned long *icb_addr_c)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
#endif
|
2011-05-18 04:10:07 -07:00
|
|
|
|
|
|
|
#endif /* __VIDEO_SH_MOBILE_MERAM_H__ */
|