From ea8a2fb3d4dbd2ade67834f25f5110635bb3adc5 Mon Sep 17 00:00:00 2001 From: hxy Date: Tue, 31 Jul 2012 17:34:50 +0800 Subject: [PATCH] rk31: add rga support --- arch/arm/configs/rk31_fpga_defconfig | 1 + drivers/video/rockchip/rga/Kconfig | 4 +- drivers/video/rockchip/rga/rga.h | 2 + drivers/video/rockchip/rga/rga_drv.c | 95 +++++++++------------------- 4 files changed, 36 insertions(+), 66 deletions(-) diff --git a/arch/arm/configs/rk31_fpga_defconfig b/arch/arm/configs/rk31_fpga_defconfig index 49213e435eae..d6e2dafed4f6 100644 --- a/arch/arm/configs/rk31_fpga_defconfig +++ b/arch/arm/configs/rk31_fpga_defconfig @@ -95,6 +95,7 @@ CONFIG_FB_ROCKCHIP=y CONFIG_LCDC_RK31=y CONFIG_LCDC1_RK31=y # CONFIG_THREE_FB_BUFFER is not set +CONFIG_RGA_RK30=y CONFIG_LOGO=y # CONFIG_LOGO_LINUX_MONO is not set # CONFIG_LOGO_LINUX_VGA16 is not set diff --git a/drivers/video/rockchip/rga/Kconfig b/drivers/video/rockchip/rga/Kconfig index 152e2bd55ef0..305130cac236 100755 --- a/drivers/video/rockchip/rga/Kconfig +++ b/drivers/video/rockchip/rga/Kconfig @@ -1,8 +1,8 @@ menu "RGA" - depends on ARCH_RK30 || ARCH_RK2928 + depends on ARCH_RK30 || ARCH_RK2928 || ARCH_RK31 config RGA_RK30 - tristate "ROCKCHIP RK30 || RK2928 RGA" + tristate "ROCKCHIP RK30 || RK2928 RGA || RK31 RGA " help rk30 rga module. diff --git a/drivers/video/rockchip/rga/rga.h b/drivers/video/rockchip/rga/rga.h index bbf5fa94833d..2623d6dd1e9b 100755 --- a/drivers/video/rockchip/rga/rga.h +++ b/drivers/video/rockchip/rga/rga.h @@ -390,6 +390,8 @@ typedef struct rga_service_info { #define RGA_BASE 0x1010c000 #elif defined(CONFIG_ARCH_RK30) #define RGA_BASE 0x10114000 +#elif defined(CONFIG_ARCH_RK31) +#define RGA_BASE 0x10114000 #endif //General Registers diff --git a/drivers/video/rockchip/rga/rga_drv.c b/drivers/video/rockchip/rga/rga_drv.c index 149769b85c1b..65f17f4e412e 100755 --- a/drivers/video/rockchip/rga/rga_drv.c +++ b/drivers/video/rockchip/rga/rga_drv.c @@ -60,7 +60,7 @@ #define RGA_MAJOR 255 -#if 0 +#if 1 #if CONFIG_ARCH_RK2928 #define RK30_RGA_PHYS 0x1010C000 #define RK30_RGA_SIZE SZ_8K @@ -69,6 +69,10 @@ #define RK30_RGA_PHYS 0x10114000 #define RK30_RGA_SIZE SZ_8K #define RGA_RESET_TIMEOUT 1000 +#elif CONFIG_ARCH_RK31 +#define RK30_RGA_PHYS 0x10114000 +#define RK30_RGA_SIZE SZ_8K +#define RGA_RESET_TIMEOUT 1000 #endif #endif @@ -132,7 +136,7 @@ static inline u32 rga_read(u32 r) return __raw_readl(drvdata->rga_base + r); } -#if defined(CONFIG_ARCH_RK30) +#if defined(CONFIG_ARCH_RK30) || defined(CONFIG_ARCH_RK31) static void rga_soft_reset(void) { u32 i; @@ -583,6 +587,8 @@ static void rga_try_set_reg(void) #if defined(CONFIG_ARCH_RK30) rga_soft_reset(); + #elif defined(CONFIG_ARCH_RK31) + rga_soft_reset(); #endif rga_write(0, RGA_MMU_CTRL); @@ -1114,6 +1120,8 @@ static int __devinit rga_drv_probe(struct platform_device *pdev) if (!request_mem_region(RK2928_RGA_PHYS, RK2928_RGA_SIZE, "rga_io")) #elif defined(CONFIG_ARCH_RK30) if (!request_mem_region(RK30_RGA_PHYS, RK30_RGA_SIZE, "rga_io")) + #elif defined(CONFIG_ARCH_RK31) + if (!request_mem_region(RK30_RGA_PHYS, RK30_RGA_SIZE, "rga_io")) #endif { pr_info("failed to reserve rga HW regs\n"); @@ -1124,6 +1132,8 @@ static int __devinit rga_drv_probe(struct platform_device *pdev) data->rga_base = (void*)ioremap_nocache(RK2928_RGA_PHYS, RK2928_RGA_SIZE); #elif defined(CONFIG_ARCH_RK30) data->rga_base = (void*)ioremap_nocache(RK30_RGA_PHYS, RK30_RGA_SIZE); + #elif defined(CONFIG_ARCH_RK31) + data->rga_base = (void*)ioremap_nocache(RK30_RGA_PHYS, RK30_RGA_SIZE); #endif if (data->rga_base == NULL) { @@ -1242,7 +1252,7 @@ static int __init rga_init(void) return ret; } - //rga_test_0(); + // rga_test_0(); INFO("Module initialized.\n"); @@ -1309,10 +1319,10 @@ void rga_test_0(void) src = src_buf; dst = dst_buf; - //memset(src_buf, 0x80, 1920*1080*4); + memset(src_buf, 0xff, 1920*1080*4); - //dmac_flush_range(&src_buf[0], &src_buf[1920*1080]); - //outer_flush_range(virt_to_phys(&src_buf[0]),virt_to_phys(&src_buf[1024*1024])); + dmac_flush_range(&src_buf[0], &src_buf[1920*1080]); + outer_flush_range(virt_to_phys(&src_buf[0]),virt_to_phys(&src_buf[1024*1024])); #if 0 memset(src_buf, 0x80, 800*480*4); @@ -1322,21 +1332,21 @@ void rga_test_0(void) outer_flush_range(virt_to_phys(&dst_buf[0]),virt_to_phys(&dst_buf[800*480])); #endif - req.src.act_w = 1280; - req.src.act_h = 800; + req.src.act_w = 320; + req.src.act_h = 240; - req.src.vir_w = 1280; - req.src.vir_h = 800; + req.src.vir_w = 320; + req.src.vir_h = 240; req.src.yrgb_addr = (uint32_t)virt_to_phys(src); req.src.uv_addr = (uint32_t)virt_to_phys(src); req.src.v_addr = (uint32_t)virt_to_phys(src); req.src.format = 0; - req.dst.act_w = 1280; - req.dst.act_h = 800; + req.dst.act_w = 320; + req.dst.act_h = 240; - req.dst.vir_w = 1280; - req.dst.vir_h = 800; + req.dst.vir_w = 800; + req.dst.vir_h = 480; req.dst.x_offset = 0; req.dst.y_offset = 0; req.dst.yrgb_addr = (uint32_t)virt_to_phys(dst); @@ -1344,58 +1354,15 @@ void rga_test_0(void) //req.dst.format = RK_FORMAT_RGB_565; req.clip.xmin = 0; - req.clip.xmax = 1279; + req.clip.xmax = 799; req.clip.ymin = 0; - req.clip.ymax = 799; + req.clip.ymax = 479; //req.render_mode = color_fill_mode; //req.fg_color = 0x80ffffff; - req.rotate_mode = 1; - req.scale_mode = 2; - - //req.alpha_rop_flag = 0; - //req.alpha_rop_mode = 0x1; - - req.sina = 0; - req.cosa = 65536; - - req.mmu_info.mmu_flag = 0x21; - req.mmu_info.mmu_en = 1; - - rga_blit_sync(&session, &req); - - req.src.act_w = 1280; - req.src.act_h = 800; - - req.src.vir_w = 1280; - req.src.vir_h = 800; - req.src.yrgb_addr = (uint32_t)virt_to_phys(src); - req.src.uv_addr = (uint32_t)virt_to_phys(src); - req.src.v_addr = (uint32_t)virt_to_phys(src); - req.src.format = RK_FORMAT_YCbCr_420_SP; - - req.dst.act_w = 1280; - req.dst.act_h = 800; - - req.dst.vir_w = 1280; - req.dst.vir_h = 800; - req.dst.x_offset = 0; - req.dst.y_offset = 0; - req.dst.yrgb_addr = (uint32_t)virt_to_phys(dst); - - //req.dst.format = RK_FORMAT_RGB_565; - - req.clip.xmin = 0; - req.clip.xmax = 1279; - req.clip.ymin = 0; - req.clip.ymax = 799; - - //req.render_mode = color_fill_mode; - //req.fg_color = 0x80ffffff; - - req.rotate_mode = 1; - req.scale_mode = 2; + //req.rotate_mode = 1; + //req.scale_mode = 2; //req.alpha_rop_flag = 0; //req.alpha_rop_mode = 0x1; @@ -1408,11 +1375,11 @@ void rga_test_0(void) rga_blit_sync(&session, &req); - #if 0 + #if 1 fb->var.bits_per_pixel = 32; - fb->var.xres = 1280; - fb->var.yres = 800; + fb->var.xres = 800; + fb->var.yres = 480; fb->var.red.length = 8; fb->var.red.offset = 0; -- 2.34.1