/* * Frame buffer driver for ADV7393/2 video encoder * * Copyright 2006-2009 Analog Devices Inc. * Licensed under the GPL-2 or late. */ #ifndef __BFIN_ADV7393FB_H__ #define __BFIN_ADV7393FB_H__ #define BFIN_LCD_NBR_PALETTE_ENTRIES 256 #ifdef CONFIG_NTSC # define VMODE 0 #endif #ifdef CONFIG_PAL # define VMODE 1 #endif #ifdef CONFIG_NTSC_640x480 # define VMODE 2 #endif #ifdef CONFIG_PAL_640x480 # define VMODE 3 #endif #ifdef CONFIG_NTSC_YCBCR # define VMODE 4 #endif #ifdef CONFIG_PAL_YCBCR # define VMODE 5 #endif #ifndef VMODE # define VMODE 1 #endif #ifdef CONFIG_ADV7393_2XMEM # define VMEM 2 #else # define VMEM 1 #endif #if defined(CONFIG_BF537) || defined(CONFIG_BF536) || defined(CONFIG_BF534) # define DMA_CFG_VAL 0x7935 /* Set Sync Bit */ # define VB_DUMMY_MEMORY_SOURCE L1_DATA_B_START #else # define DMA_CFG_VAL 0x7915 # define VB_DUMMY_MEMORY_SOURCE BOOT_ROM_START #endif enum { DESTRUCT, BUILD, }; enum { POWER_ON, POWER_DOWN, BLANK_ON, BLANK_OFF, }; #define DRIVER_NAME "bfin-adv7393" struct adv7393fb_modes { const s8 name[25]; /* Full name */ u16 xres; /* Active Horizonzal Pixels */ u16 yres; /* Active Vertical Pixels */ u16 bpp; u16 vmode; u16 a_lines; /* Active Lines per Field */ u16 vb1_lines; /* Vertical Blanking Field 1 Lines */ u16 vb2_lines; /* Vertical Blanking Field 2 Lines */ u16 tot_lines; /* Total Lines per Frame */ u16 boeft_blank; /* Before Odd/Even Field Transition No. of Blank Pixels */ u16 aoeft_blank; /* After Odd/Even Field Transition No. of Blank Pixels */ const s8 *adv7393_i2c_initd; u16 adv7393_i2c_initd_len; }; static const u8 init_NTSC_TESTPATTERN[] = { 0x00, 0x1E, /* Power up all DACs and PLL */ 0x01, 0x00, /* SD-Only Mode */ 0x80, 0x10, /* SSAF Luma Filter Enabled, NTSC Mode */ 0x82, 0xCB, /* Step control on, pixel data valid, pedestal on, PrPb SSAF on, CVBS/YC output */ 0x84, 0x40, /* SD Color Bar Test Pattern Enabled, DAC 2 = Luma, DAC 3 = Chroma */ }; static const u8 init_NTSC[] = { 0x00, 0x1E, /* Power up all DACs and PLL */ 0xC3, 0x26, /* Program RGB->YCrCb Color Space conversion matrix */ 0xC5, 0x12, /* Program RGB->YCrCb Color Space conversion matrix */ 0xC2, 0x4A, /* Program RGB->YCrCb Color Space conversion matrix */ 0xC6, 0x5E, /* Program RGB->YCrCb Color Space conversion matrix */ 0xBD, 0x19, /* Program RGB->YCrCb Color Space conversion matrix */ 0xBF, 0x42, /* Program RGB->YCrCb Color Space conversion matrix */ 0x8C, 0x1F, /* NTSC Subcarrier Frequency */ 0x8D, 0x7C, /* NTSC Subcarrier Frequency */ 0x8E, 0xF0, /* NTSC Subcarrier Frequency */ 0x8F, 0x21, /* NTSC Subcarrier Frequency */ 0x01, 0x00, /* SD-Only Mode */ 0x80, 0x30, /* SSAF Luma Filter Enabled, NTSC Mode */ 0x82, 0x8B, /* Step control on, pixel data invalid, pedestal on, PrPb SSAF on, CVBS/YC output */ 0x87, 0x80, /* SD Color Bar Test Pattern Enabled, DAC 2 = Luma, DAC 3 = Chroma */ 0x86, 0x82, 0x8B, 0x11, 0x88, 0x20, 0x8A, 0x0d, }; static const u8 init_PAL[] = { 0x00, 0x1E, /* Power up all DACs and PLL */ 0xC3, 0x26, /* Program RGB->YCrCb Color Space conversion matrix */ 0xC5, 0x12, /* Program RGB->YCrCb Color Space conversion matrix */ 0xC2, 0x4A, /* Program RGB->YCrCb Color Space conversion matrix */ 0xC6, 0x5E, /* Program RGB->YCrCb Color Space conversion matrix */ 0xBD, 0x19, /* Program RGB->YCrCb Color Space conversion matrix */ 0xBF, 0x42, /* Program RGB->YCrCb Color Space conversion matrix */ 0x8C, 0xCB, /* PAL Subcarrier Frequency */ 0x8D, 0x8A, /* PAL Subcarrier Frequency */ 0x8E, 0x09, /* PAL Subcarrier Frequency */ 0x8F, 0x2A, /* PAL Subcarrier Frequency */ 0x01, 0x00, /* SD-Only Mode */ 0x80, 0x11, /* SSAF Luma Filter Enabled, PAL Mode */ 0x82, 0x8B, /* Step control on, pixel data invalid, pedestal on, PrPb SSAF on, CVBS/YC output */ 0x87, 0x80, /* SD Color Bar Test Pattern Enabled, DAC 2 = Luma, DAC 3 = Chroma */ 0x86, 0x82, 0x8B, 0x11, 0x88, 0x20, 0x8A, 0x0d, }; static const u8 init_NTSC_YCbCr[] = { 0x00, 0x1E, /* Power up all DACs and PLL */ 0x8C, 0x1F, /* NTSC Subcarrier Frequency */ 0x8D, 0x7C, /* NTSC Subcarrier Frequency */ 0x8E, 0xF0, /* NTSC Subcarrier Frequency */ 0x8F, 0x21, /* NTSC Subcarrier Frequency */ 0x01, 0x00, /* SD-Only Mode */ 0x80, 0x30, /* SSAF Luma Filter Enabled, NTSC Mode */ 0x82, 0x8B, /* Step control on, pixel data invalid, pedestal on, PrPb SSAF on, CVBS/YC output */ 0x87, 0x00, /* DAC 2 = Luma, DAC 3 = Chroma */ 0x86, 0x82, 0x8B, 0x11, 0x88, 0x08, 0x8A, 0x0d, }; static const u8 init_PAL_YCbCr[] = { 0x00, 0x1E, /* Power up all DACs and PLL */ 0x8C, 0xCB, /* PAL Subcarrier Frequency */ 0x8D, 0x8A, /* PAL Subcarrier Frequency */ 0x8E, 0x09, /* PAL Subcarrier Frequency */ 0x8F, 0x2A, /* PAL Subcarrier Frequency */ 0x01, 0x00, /* SD-Only Mode */ 0x80, 0x11, /* SSAF Luma Filter Enabled, PAL Mode */ 0x82, 0x8B, /* Step control on, pixel data invalid, pedestal on, PrPb SSAF on, CVBS/YC output */ 0x87, 0x00, /* DAC 2 = Luma, DAC 3 = Chroma */ 0x86, 0x82, 0x8B, 0x11, 0x88, 0x08, 0x8A, 0x0d, }; static struct adv7393fb_modes known_modes[] = { /* NTSC 720x480 CRT */ { .name = "NTSC 720x480", .xres = 720, .yres = 480, .bpp = 16, .vmode = FB_VMODE_INTERLACED, .a_lines = 240, .vb1_lines = 22, .vb2_lines = 23, .tot_lines = 525, .boeft_blank = 16, .aoeft_blank = 122, .adv7393_i2c_initd = init_NTSC, .adv7393_i2c_initd_len = sizeof(init_NTSC) }, /* PAL 720x480 CRT */ { .name = "PAL 720x576", .xres = 720, .yres = 576, .bpp = 16, .vmode = FB_VMODE_INTERLACED, .a_lines = 288, .vb1_lines = 24, .vb2_lines = 25, .tot_lines = 625, .boeft_blank = 12, .aoeft_blank = 132, .adv7393_i2c_initd = init_PAL, .adv7393_i2c_initd_len = sizeof(init_PAL) }, /* NTSC 640x480 CRT Experimental */ { .name = "NTSC 640x480", .xres = 640, .yres = 480, .bpp = 16, .vmode = FB_VMODE_INTERLACED, .a_lines = 240, .vb1_lines = 22, .vb2_lines = 23, .tot_lines = 525, .boeft_blank = 16 + 40, .aoeft_blank = 122 + 40, .adv7393_i2c_initd = init_NTSC, .adv7393_i2c_initd_len = sizeof(init_NTSC) }, /* PAL 640x480 CRT Experimental */ { .name = "PAL 640x480", .xres = 640, .yres = 480, .bpp = 16, .vmode = FB_VMODE_INTERLACED, .a_lines = 288 - 20, .vb1_lines = 24 + 20, .vb2_lines = 25 + 20, .tot_lines = 625, .boeft_blank = 12 + 40, .aoeft_blank = 132 + 40, .adv7393_i2c_initd = init_PAL, .adv7393_i2c_initd_len = sizeof(init_PAL) }, /* NTSC 720x480 YCbCR */ { .name = "NTSC 720x480 YCbCR", .xres = 720, .yres = 480, .bpp = 16, .vmode = FB_VMODE_INTERLACED, .a_lines = 240, .vb1_lines = 22, .vb2_lines = 23, .tot_lines = 525, .boeft_blank = 16, .aoeft_blank = 122, .adv7393_i2c_initd = init_NTSC_YCbCr, .adv7393_i2c_initd_len = sizeof(init_NTSC_YCbCr) }, /* PAL 720x480 CRT */ { .name = "PAL 720x576 YCbCR", .xres = 720, .yres = 576, .bpp = 16, .vmode = FB_VMODE_INTERLACED, .a_lines = 288, .vb1_lines = 24, .vb2_lines = 25, .tot_lines = 625, .boeft_blank = 12, .aoeft_blank = 132, .adv7393_i2c_initd = init_PAL_YCbCr, .adv7393_i2c_initd_len = sizeof(init_PAL_YCbCr) } }; struct adv7393fb_regs { }; struct adv7393fb_device { struct fb_info info; /* FB driver info record */ struct i2c_client *client; struct dmasg *descriptor_list_head; struct dmasg *vb1; struct dmasg *av1; struct dmasg *vb2; struct dmasg *av2; dma_addr_t dma_handle; struct fb_info bfin_adv7393_fb; struct adv7393fb_modes *modes; struct adv7393fb_regs *regs; /* Registers memory map */ size_t regs_len; size_t fb_len; size_t line_len; u16 open; u16 *fb_mem; /* RGB Buffer */ }; #define to_adv7393fb_device(_info) \ (_info ? container_of(_info, struct adv7393fb_device, info) : NULL); static int bfin_adv7393_fb_open(struct fb_info *info, int user); static int bfin_adv7393_fb_release(struct fb_info *info, int user); static int bfin_adv7393_fb_check_var(struct fb_var_screeninfo *var, struct fb_info *info); static int bfin_adv7393_fb_pan_display(struct fb_var_screeninfo *var, struct fb_info *info); static int bfin_adv7393_fb_blank(int blank, struct fb_info *info); static void bfin_config_ppi(struct adv7393fb_device *fbdev); static int bfin_config_dma(struct adv7393fb_device *fbdev); static void bfin_disable_dma(void); static void bfin_enable_ppi(void); static void bfin_disable_ppi(void); static inline int adv7393_write(struct i2c_client *client, u8 reg, u8 value); static inline int adv7393_read(struct i2c_client *client, u8 reg); static int adv7393_write_block(struct i2c_client *client, const u8 *data, unsigned int len); int bfin_adv7393_fb_cursor(struct fb_info *info, struct fb_cursor *cursor); static int bfin_adv7393_fb_setcolreg(u_int, u_int, u_int, u_int, u_int, struct fb_info *info); #endif