aboutsummaryrefslogtreecommitdiffstats
path: root/target/linux/s3c24xx/patches/0146-uplevel-samsung-camera-unit.patch.patch
diff options
context:
space:
mode:
Diffstat (limited to 'target/linux/s3c24xx/patches/0146-uplevel-samsung-camera-unit.patch.patch')
-rwxr-xr-xtarget/linux/s3c24xx/patches/0146-uplevel-samsung-camera-unit.patch.patch1690
1 files changed, 0 insertions, 1690 deletions
diff --git a/target/linux/s3c24xx/patches/0146-uplevel-samsung-camera-unit.patch.patch b/target/linux/s3c24xx/patches/0146-uplevel-samsung-camera-unit.patch.patch
deleted file mode 100755
index 26f0035595..0000000000
--- a/target/linux/s3c24xx/patches/0146-uplevel-samsung-camera-unit.patch.patch
+++ /dev/null
@@ -1,1690 +0,0 @@
-From 0bd2a8e00d4a1814d0a9d8206d52717e3f538b68 Mon Sep 17 00:00:00 2001
-From: Andy Green <andy@opennoko.com>
-Date: Fri, 25 Jul 2008 23:06:10 +0100
-Subject: [PATCH] uplevel-samsung-camera-unit.patch
-
-Update this old code to clk API, I2C changes, official GPIO API
-various struct changes, explicit readl() writel(), DMA API changes.
-Still not ready for actual use (eg, I2C) but a LOT closer.
-
-Compiles on 2.6.24 without errors or warnings now.
-
-Use CONFIG_S3C2440_CAMERA=y in .config
-
-Signed-off-by: Andy Green <andy@openmoko.com>
----
- arch/arm/mach-s3c2440/Kconfig | 5 +-
- arch/arm/mach-s3c2440/Makefile | 9 +-
- arch/arm/mach-s3c2440/camera/Makefile | 1 -
- arch/arm/mach-s3c2440/camera/cam_reg.h | 92 +++--
- arch/arm/mach-s3c2440/camera/camif.c | 633 +++++++++++++++------------
- arch/arm/mach-s3c2440/camera/camif_fsm.c | 5 +
- arch/arm/mach-s3c2440/camera/imgsensor.c | 43 +-
- arch/arm/mach-s3c2440/camera/qt-driver.c | 5 +-
- arch/arm/mach-s3c2440/camera/video-driver.c | 87 +++--
- arch/arm/mach-s3c2440/camera/videodev.c | 24 +-
- arch/arm/mach-s3c2440/camera/videodev.h | 16 +-
- 11 files changed, 516 insertions(+), 404 deletions(-)
-
-diff --git a/arch/arm/mach-s3c2440/Kconfig b/arch/arm/mach-s3c2440/Kconfig
-index e042965..20dd2c5 100644
---- a/arch/arm/mach-s3c2440/Kconfig
-+++ b/arch/arm/mach-s3c2440/Kconfig
-@@ -30,9 +30,6 @@ config S3C2440_C_FIQ
- Support for S3C2440 FIQ support in C -- see
- ./arch/arm/macs3c2440/fiq_c_isr.c
-
--source "arch/arm/mach-s3c2440/camera/Kconfig"
--
--
- menu "S3C2440 Machines"
-
- config MACH_ANUBIS
-@@ -96,3 +93,5 @@ config NEO1973_GTA02_2440
- of the FIC/Openmoko Neo1973 GTA02 GSM Phone.
-
- endmenu
-+
-+#source "arch/arm/mach-s3c2440/camera/Kconfig"
-diff --git a/arch/arm/mach-s3c2440/Makefile b/arch/arm/mach-s3c2440/Makefile
-index e9c6334..964e50b 100644
---- a/arch/arm/mach-s3c2440/Makefile
-+++ b/arch/arm/mach-s3c2440/Makefile
-@@ -1,4 +1,10 @@
--obj-y += camera/
-+# arch/arm/mach-s3c2440/Makefile
-+#
-+# Copyright 2007 Simtec Electronics
-+#
-+# Licensed under GPLv2
-+
-+obj-y :=
- obj-m :=
- obj-n :=
- obj- :=
-@@ -17,5 +23,6 @@ obj-$(CONFIG_MACH_RX3715) += mach-rx3715.o
- obj-$(CONFIG_ARCH_S3C2440) += mach-smdk2440.o
- obj-$(CONFIG_MACH_NEXCODER_2440) += mach-nexcoder.o
- obj-$(CONFIG_MACH_AT2440EVB) += mach-at2440evb.o
-+obj-$(CONFIG_MACH_HXD8) += mach-hxd8.o
- obj-$(CONFIG_MACH_NEO1973_GTA02) += mach-gta02.o
-
-diff --git a/arch/arm/mach-s3c2440/camera/Makefile b/arch/arm/mach-s3c2440/camera/Makefile
-index a46d3be..9cd6d79 100644
---- a/arch/arm/mach-s3c2440/camera/Makefile
-+++ b/arch/arm/mach-s3c2440/camera/Makefile
-@@ -1,7 +1,6 @@
- obj-$(CONFIG_S3C2440_CAMERA) += \
- videodev.o \
- imgsensor.o \
-- videodrv.o \
- video-driver.o \
- camif.o \
- camif_fsm.o \
-diff --git a/arch/arm/mach-s3c2440/camera/cam_reg.h b/arch/arm/mach-s3c2440/camera/cam_reg.h
-index 7247a4e..93d59b8 100644
---- a/arch/arm/mach-s3c2440/camera/cam_reg.h
-+++ b/arch/arm/mach-s3c2440/camera/cam_reg.h
-@@ -7,6 +7,7 @@
- #ifndef __FIMC20_CAMERA_H__
- #define __FIMC20_CAMERA_H__
-
-+extern u32 * camregs;
-
- #ifdef CONFIG_ARCH_S3C24A0
- #define CAM_BASE_ADD 0x48000000
-@@ -14,10 +15,23 @@
- #define CAM_BASE_ADD 0x4F000000
- #endif
-
-+#if ! defined(FExtr)
-+#define UData(Data) ((unsigned long) (Data))
-+#define FExtr(Data, Field) \
-+ ((UData (Data) >> FShft (Field)) & FAlnMsk (Field))
-+#define FInsrt(Value, Field) \
-+ (UData (Value) << FShft (Field))
-+#define FSize(Field) ((Field) >> 16)
-+#define FShft(Field) ((Field) & 0x0000FFFF)
-+#define FMsk(Field) (((UData (1) << FSize (Field)) - 1) << FShft (Field))
-+#define FAlnMsk(Field) ((UData (1) << FSize (Field)) - 1)
-+#define F1stBit(Field) (UData (1) << FShft (Field))
-+#define Fld(Size, Shft) (((Size) << 16) + (Shft))
-+#endif
-
- /*
- * CAMERA IP
-- * P-port is used as RGB Capturing device which including scale and crop
-+ * P-port is used as RGB Capturing device which including scale and crop
- * those who want to see(preview ) the image on display needs RGB image.
- *
- * C-port is used as YCbCr(4:2:0, 4:2:2) Capturing device which including the scale and crop
-@@ -25,45 +39,45 @@
- YCBCB format not RGB
- */
-
--#define CISRCFMT __REG(CAM_BASE_ADD+0x00) // RW Input Source Format
--#define CIWDOFST __REG(CAM_BASE_ADD+0x04) // Window offset register
--#define CIGCTRL __REG(CAM_BASE_ADD+0x08) // Global control register
--#define CICOYSA0 __REG(CAM_BASE_ADD+0x18) // Y 1 st frame start address
--#define CICOYSA1 __REG(CAM_BASE_ADD+0x1C) // Y 2 nd frame start address
--#define CICOYSA2 __REG(CAM_BASE_ADD+0x20) // Y 3 rd frame start address
--#define CICOYSA3 __REG(CAM_BASE_ADD+0x24) // Y 4 th frame start address
--#define CICOCBSA0 __REG(CAM_BASE_ADD+0x28) // Cb 1 st frame start address
--#define CICOCBSA1 __REG(CAM_BASE_ADD+0x2C) // Cb 2 nd frame start address
--#define CICOCBSA2 __REG(CAM_BASE_ADD+0x30) // Cb 3 rd frame start address
--#define CICOCBSA3 __REG(CAM_BASE_ADD+0x34) // Cb 4 th frame start address
--#define CICOCRSA0 __REG(CAM_BASE_ADD+0x38) // Cr 1 st frame start address
--#define CICOCRSA1 __REG(CAM_BASE_ADD+0x3C) // Cr 2 nd frame start address
--#define CICOCRSA2 __REG(CAM_BASE_ADD+0x40) // Cr 3 rd frame start address
--#define CICOCRSA3 __REG(CAM_BASE_ADD+0x44) // Cr 4 th frame start address
--#define CICOTRGFMT __REG(CAM_BASE_ADD+0x48) // Target image format of codec
--#define CICOCTRL __REG(CAM_BASE_ADD+0x4C) // Codec DMA control related
--#define CICOSCPRERATIO __REG(CAM_BASE_ADD+0x50) // Codec pre-scaler ratio control
--#define CICOSCPREDST __REG(CAM_BASE_ADD+0x54) // Codec pre-scaler destination
--#define CICOSCCTRL __REG(CAM_BASE_ADD+0x58) // Codec main-scaler control
--#define CICOTAREA __REG(CAM_BASE_ADD+0x5C) // Codec pre-scaler destination
--#define CICOSTATUS __REG(CAM_BASE_ADD+0x64) // Codec path status
--#define CIPRCLRSA0 __REG(CAM_BASE_ADD+0x6C) // RGB 1 st frame start address
--#define CIPRCLRSA1 __REG(CAM_BASE_ADD+0x70) // RGB 2 nd frame start address
--#define CIPRCLRSA2 __REG(CAM_BASE_ADD+0x74) // RGB 3 rd frame start address
--#define CIPRCLRSA3 __REG(CAM_BASE_ADD+0x78) // RGB 4 th frame start address
--#define CIPRTRGFMT __REG(CAM_BASE_ADD+0x7C) // Target image format of preview
--#define CIPRCTRL __REG(CAM_BASE_ADD+0x80) // Preview DMA control related
--#define CIPRSCPRERATIO __REG(CAM_BASE_ADD+0x84) // Preview pre-scaler ratio control
--#define CIPRSCPREDST __REG(CAM_BASE_ADD+0x88) // Preview pre-scaler destination
--#define CIPRSCCTRL __REG(CAM_BASE_ADD+0x8C) // Preview main-scaler control
--#define CIPRTAREA __REG(CAM_BASE_ADD+0x90) // Preview pre-scaler destination
--#define CIPRSTATUS __REG(CAM_BASE_ADD+0x98) // Preview path status
--#define CIIMGCPT __REG(CAM_BASE_ADD+0xA0) // Image capture enable command
--
--#define CICOYSA(__x) __REG(CAM_BASE_ADD+0x18 + (__x)*4 )
--#define CICOCBSA(__x) __REG(CAM_BASE_ADD+0x28 + (__x)*4 )
--#define CICOCRSA(__x) __REG(CAM_BASE_ADD+0x38 + (__x)*4 )
--#define CIPRCLRSA(__x) __REG(CAM_BASE_ADD+0x6C + (__x)*4 )
-+#define S3C2440_CAM_REG_CISRCFMT (0x00) // RW Input Source Format
-+#define S3C2440_CAM_REG_CIWDOFST (0x04) // Window offset register
-+#define S3C2440_CAM_REG_CIGCTRL (0x08) // Global control register
-+#define S3C2440_CAM_REG_CICOYSA0 (0x18) // Y 1 st frame start ads
-+#define S3C2440_CAM_REG_CICOYSA1 (0x1C) // Y 2 nd frame start ads
-+#define S3C2440_CAM_REG_CICOYSA2 (0x20) // Y 3 rd frame start ads
-+#define S3C2440_CAM_REG_CICOYSA3 (0x24) // Y 4 th frame start ads
-+#define S3C2440_CAM_REG_CICOCBSA0 (0x28) // Cb 1 st frame start ads
-+#define S3C2440_CAM_REG_CICOCBSA1 (0x2C) // Cb 2 nd frame start ads
-+#define S3C2440_CAM_REG_CICOCBSA2 (0x30) // Cb 3 rd frame start ads
-+#define S3C2440_CAM_REG_CICOCBSA3 (0x34) // Cb 4 th frame start ads
-+#define S3C2440_CAM_REG_CICOCRSA0 (0x38) // Cr 1 st frame start ads
-+#define S3C2440_CAM_REG_CICOCRSA1 (0x3C) // Cr 2 nd frame start ads
-+#define S3C2440_CAM_REG_CICOCRSA2 (0x40) // Cr 3 rd frame start ads
-+#define S3C2440_CAM_REG_CICOCRSA3 (0x44) // Cr 4 th frame start ads
-+#define S3C2440_CAM_REG_CICOTRGFMT (0x48) // Target img format of codec
-+#define S3C2440_CAM_REG_CICOCTRL (0x4C) // Codec DMA control related
-+#define S3C2440_CAM_REG_CICOSCPRERATIO (0x50) // Codec pre-scaler ratio
-+#define S3C2440_CAM_REG_CICOSCPREDST (0x54) // Codec pre-scaler dest
-+#define S3C2440_CAM_REG_CICOSCCTRL (0x58) // Codec main-scaler control
-+#define S3C2440_CAM_REG_CICOTAREA (0x5C) // Codec pre-scaler dest
-+#define S3C2440_CAM_REG_CICOSTATUS (0x64) // Codec path status
-+#define S3C2440_CAM_REG_CIPRCLRSA0 (0x6C) // RGB 1 st frame start ads
-+#define S3C2440_CAM_REG_CIPRCLRSA1 (0x70) // RGB 2 nd frame start ads
-+#define S3C2440_CAM_REG_CIPRCLRSA2 (0x74) // RGB 3 rd frame start ads
-+#define S3C2440_CAM_REG_CIPRCLRSA3 (0x78) // RGB 4 th frame start ads
-+#define S3C2440_CAM_REG_CIPRTRGFMT (0x7C) // Target img fmt of preview
-+#define S3C2440_CAM_REG_CIPRCTRL (0x80) // Preview DMA ctl related
-+#define S3C2440_CAM_REG_CIPRSCPRERATIO (0x84) // Preview pre-scaler ratio
-+#define S3C2440_CAM_REG_CIPRSCPREDST (0x88) // Preview pre-scaler dest
-+#define S3C2440_CAM_REG_CIPRSCCTRL (0x8C) // Preview main-scaler ctl
-+#define S3C2440_CAM_REG_CIPRTAREA (0x90) // Preview pre-scaler dest
-+#define S3C2440_CAM_REG_CIPRSTATUS (0x98) // Preview path status
-+#define S3C2440_CAM_REG_CIIMGCPT (0xA0) // Image capture enable cmd
-+
-+#define S3C2440_CAM_REG_CICOYSA(__x) (0x18 + (__x)*4 )
-+#define S3C2440_CAM_REG_CICOCBSA(__x) (0x28 + (__x)*4 )
-+#define S3C2440_CAM_REG_CICOCRSA(__x) (0x38 + (__x)*4 )
-+#define S3C2440_CAM_REG_CIPRCLRSA(__x) (0x6C + (__x)*4 )
-
- /* CISRCFMT BitField */
- #define SRCFMT_ITU601 BIT31
-diff --git a/arch/arm/mach-s3c2440/camera/camif.c b/arch/arm/mach-s3c2440/camera/camif.c
-index 36d4ccc..2e97e21 100644
---- a/arch/arm/mach-s3c2440/camera/camif.c
-+++ b/arch/arm/mach-s3c2440/camera/camif.c
-@@ -7,14 +7,11 @@
- * for more details.
- */
-
--#include <linux/config.h>
- #include <linux/module.h>
- #include <linux/kernel.h>
- #include <linux/init.h>
- #include <linux/sched.h>
- #include <linux/irq.h>
--#include <linux/tqueue.h>
--#include <linux/locks.h>
- #include <linux/completion.h>
- #include <linux/delay.h>
- #include <linux/slab.h>
-@@ -26,28 +23,29 @@
- #include <asm/semaphore.h>
- #include <asm/hardware.h>
- #include <asm/uaccess.h>
-+#include <linux/device.h>
-+#include <linux/dma-mapping.h>
-+#include <linux/clk.h>
-
- #ifdef CONFIG_ARCH_S3C24A0A
- #include <asm/arch/S3C24A0.h>
- #include <asm/arch/clocks.h>
- #else
--#include <asm/arch/S3C2440.h>
--#include <asm/arch/clocks.h>
-+#include <asm/arch/regs-gpio.h>
-+#include <asm/arch/regs-gpioj.h>
-+#include <asm/arch/regs-irq.h>
- #endif
-
- #include "cam_reg.h"
- //#define SW_DEBUG
-+#define CONFIG_VIDEO_V4L1_COMPAT
-+#include <linux/videodev.h>
- #include "camif.h"
--#include "videodev.h"
- #include "miscdevice.h"
-
--
- static int camif_dma_burst(camif_cfg_t *);
- static int camif_scaler(camif_cfg_t *);
-
--static const char *camif_version =
-- "$Id: camif.c,v 1.10 2004/06/04 04:24:14 swlee Exp $";
--
- /* For SXGA Image */
- #define RESERVE_MEM 15*1024*1024
- #define YUV_MEM 10*1024*1024
-@@ -66,11 +64,13 @@ static int camif_malloc(camif_cfg_t *cfg)
- t_size = t_size *cfg->pp_num;
-
- #ifndef SAMSUNG_SXGA_CAM
-- cfg->pp_virt_buf = consistent_alloc(GFP_KERNEL, t_size, &cfg->pp_phys_buf);
-+ cfg->pp_virt_buf = dma_alloc_coherent(cfg->v->dev,
-+ t_size, &cfg->pp_phys_buf,
-+ GFP_KERNEL);
- #else
- printk(KERN_INFO "Reserving High RAM Addresses \n");
- cfg->pp_phys_buf = PHYS_OFFSET + (MEM_SIZE - RESERVE_MEM);
-- cfg->pp_virt_buf = ioremap_nocache(cfg->pp_phys_buf,YUV_MEM);
-+ cfg->pp_virt_buf = ioremap_nocache(cfg->pp_phys_buf, YUV_MEM);
- #endif
-
- if ( !cfg->pp_virt_buf ) {
-@@ -90,7 +90,9 @@ static int camif_malloc(camif_cfg_t *cfg)
- }
- t_size = t_size * cfg->pp_num;
- #ifndef SAMSUNG_SXGA_CAM
-- cfg->pp_virt_buf = consistent_alloc(GFP_KERNEL, t_size, &cfg->pp_phys_buf);
-+ cfg->pp_virt_buf = dma_alloc_coherent(cfg->v->dev,
-+ t_size, &cfg->pp_phys_buf,
-+ GFP_KERNEL);
- #else
- printk(KERN_INFO "Reserving High RAM Addresses \n");
- cfg->pp_phys_buf = PHYS_OFFSET + (MEM_SIZE - RESERVE_MEM ) + YUV_MEM;
-@@ -112,7 +114,8 @@ static int camif_demalloc(camif_cfg_t *cfg)
- {
- #ifndef SAMSUNG_SXGA_CAM
- if ( cfg->pp_virt_buf ) {
-- consistent_free(cfg->pp_virt_buf,cfg->pp_totalsize,cfg->pp_phys_buf);
-+ dma_free_coherent(cfg->v->dev, cfg->pp_totalsize,
-+ cfg->pp_virt_buf, cfg->pp_phys_buf);
- cfg->pp_virt_buf = 0;
- }
- #else
-@@ -131,13 +134,14 @@ int camif_g_frame_num(camif_cfg_t *cfg)
- int index = 0;
-
- if (cfg->dma_type & CAMIF_CODEC ) {
-- index = FRAME_CNT(CICOSTATUS);
-+ index = FRAME_CNT(readl(camregs + S3C2440_CAM_REG_CICOSTATUS));
- DPRINTK("CAMIF_CODEC frame %d \n", index);
- }
- else {
- assert(cfg->dma_type & CAMIF_PREVIEW );
-- index = FRAME_CNT(CIPRSTATUS);
-- DPRINTK("CAMIF_PREVIEW frame %d 0x%08X \n", index, CIPRSTATUS);
-+ index = FRAME_CNT(readl(camregs + S3C2440_CAM_REG_CIPRSTATUS));
-+ DPRINTK("CAMIF_PREVIEW frame %d 0x%08X \n", index,
-+ readl(camregs + S3C2440_CAM_REG_CIPRSTATUS));
- }
- cfg->now_frame_num = (index + 2) % 4; /* When 4 PingPong */
- return index; /* meaningless */
-@@ -148,60 +152,59 @@ static int camif_pp_codec(camif_cfg_t *cfg)
- u32 i, c_size; /* Cb,Cr size */
- u32 one_p_size;
- u32 daon = cfg->target_x * cfg->target_y;
-- if (cfg->fmt & CAMIF_OUT_YCBCR420) {
-- c_size = daon /4;
-- }
-+ if (cfg->fmt & CAMIF_OUT_YCBCR420)
-+ c_size = daon / 4;
- else {
- assert(cfg->fmt & CAMIF_OUT_YCBCR422);
-- c_size = daon /2;
-+ c_size = daon / 2;
- }
- switch ( cfg->pp_num ) {
-- case 1 :
-- for ( i =0 ; i < 4; i=i+1) {
-- cfg->img_buf[i].virt_y = cfg->pp_virt_buf;
-- cfg->img_buf[i].phys_y = cfg->pp_phys_buf;
-- cfg->img_buf[i].virt_cb = cfg->pp_virt_buf + daon;
-- cfg->img_buf[i].phys_cb = cfg->pp_phys_buf + daon;
-- cfg->img_buf[i].virt_cr = cfg->pp_virt_buf + daon + c_size;
-- cfg->img_buf[i].phys_cr = cfg->pp_phys_buf + daon + c_size;
-- CICOYSA(i) = cfg->img_buf[i].phys_y;
-- CICOCBSA(i) = cfg->img_buf[i].phys_cb;
-- CICOCRSA(i) = cfg->img_buf[i].phys_cr;
-- }
-- break;
-- case 2:
-+ case 1 :
-+ for (i =0 ; i < 4; i++) {
-+ cfg->img_buf[i].virt_y = cfg->pp_virt_buf;
-+ cfg->img_buf[i].phys_y = cfg->pp_phys_buf;
-+ cfg->img_buf[i].virt_cb = cfg->pp_virt_buf + daon;
-+ cfg->img_buf[i].phys_cb = cfg->pp_phys_buf + daon;
-+ cfg->img_buf[i].virt_cr = cfg->pp_virt_buf + daon + c_size;
-+ cfg->img_buf[i].phys_cr = cfg->pp_phys_buf + daon + c_size;
-+ writel(cfg->img_buf[i].phys_y, camregs + S3C2440_CAM_REG_CICOYSA(i));
-+ writel(cfg->img_buf[i].phys_cb, camregs + S3C2440_CAM_REG_CICOCBSA(i));
-+ writel(cfg->img_buf[i].phys_cr, camregs + S3C2440_CAM_REG_CICOCRSA(i));
-+ }
-+ break;
-+ case 2:
- #define TRY (( i%2 ) ? 1 :0)
-- one_p_size = daon + 2*c_size;
-- for (i = 0; i < 4 ; i++) {
-- cfg->img_buf[i].virt_y = cfg->pp_virt_buf + TRY * one_p_size;
-- cfg->img_buf[i].phys_y = cfg->pp_phys_buf + TRY * one_p_size;
-- cfg->img_buf[i].virt_cb = cfg->pp_virt_buf + daon + TRY * one_p_size;
-- cfg->img_buf[i].phys_cb = cfg->pp_phys_buf + daon + TRY * one_p_size;
-- cfg->img_buf[i].virt_cr = cfg->pp_virt_buf + daon + c_size + TRY * one_p_size;
-- cfg->img_buf[i].phys_cr = cfg->pp_phys_buf + daon + c_size + TRY * one_p_size;
-- CICOYSA(i) = cfg->img_buf[i].phys_y;
-- CICOCBSA(i) = cfg->img_buf[i].phys_cb;
-- CICOCRSA(i) = cfg->img_buf[i].phys_cr;
-- }
-- break;
-- case 4:
-- one_p_size = daon + 2*c_size;
-- for (i = 0; i < 4 ; i++) {
-- cfg->img_buf[i].virt_y = cfg->pp_virt_buf + i * one_p_size;
-- cfg->img_buf[i].phys_y = cfg->pp_phys_buf + i * one_p_size;
-- cfg->img_buf[i].virt_cb = cfg->pp_virt_buf + daon + i * one_p_size;
-- cfg->img_buf[i].phys_cb = cfg->pp_phys_buf + daon + i * one_p_size;
-- cfg->img_buf[i].virt_cr = cfg->pp_virt_buf + daon + c_size + i * one_p_size;
-- cfg->img_buf[i].phys_cr = cfg->pp_phys_buf + daon + c_size + i * one_p_size;
-- CICOYSA(i) = cfg->img_buf[i].phys_y;
-- CICOCBSA(i) = cfg->img_buf[i].phys_cb;
-- CICOCRSA(i) = cfg->img_buf[i].phys_cr;
-- }
-- break;
-- default:
-- printk("Invalid PingPong Number %d \n",cfg->pp_num);
-- panic("halt\n");
-- }
-+ one_p_size = daon + 2*c_size;
-+ for (i = 0; i < 4 ; i++) {
-+ cfg->img_buf[i].virt_y = cfg->pp_virt_buf + TRY * one_p_size;
-+ cfg->img_buf[i].phys_y = cfg->pp_phys_buf + TRY * one_p_size;
-+ cfg->img_buf[i].virt_cb = cfg->pp_virt_buf + daon + TRY * one_p_size;
-+ cfg->img_buf[i].phys_cb = cfg->pp_phys_buf + daon + TRY * one_p_size;
-+ cfg->img_buf[i].virt_cr = cfg->pp_virt_buf + daon + c_size + TRY * one_p_size;
-+ cfg->img_buf[i].phys_cr = cfg->pp_phys_buf + daon + c_size + TRY * one_p_size;
-+ writel(cfg->img_buf[i].phys_y, camregs + S3C2440_CAM_REG_CICOYSA(i));
-+ writel(cfg->img_buf[i].phys_cb, camregs + S3C2440_CAM_REG_CICOCBSA(i));
-+ writel(cfg->img_buf[i].phys_cr, camregs + S3C2440_CAM_REG_CICOCRSA(i));
-+ }
-+ break;
-+ case 4:
-+ one_p_size = daon + 2*c_size;
-+ for (i = 0; i < 4 ; i++) {
-+ cfg->img_buf[i].virt_y = cfg->pp_virt_buf + i * one_p_size;
-+ cfg->img_buf[i].phys_y = cfg->pp_phys_buf + i * one_p_size;
-+ cfg->img_buf[i].virt_cb = cfg->pp_virt_buf + daon + i * one_p_size;
-+ cfg->img_buf[i].phys_cb = cfg->pp_phys_buf + daon + i * one_p_size;
-+ cfg->img_buf[i].virt_cr = cfg->pp_virt_buf + daon + c_size + i * one_p_size;
-+ cfg->img_buf[i].phys_cr = cfg->pp_phys_buf + daon + c_size + i * one_p_size;
-+ writel(cfg->img_buf[i].phys_y, camregs + S3C2440_CAM_REG_CICOYSA(i));
-+ writel(cfg->img_buf[i].phys_cb, camregs + S3C2440_CAM_REG_CICOCBSA(i));
-+ writel(cfg->img_buf[i].phys_cr, camregs + S3C2440_CAM_REG_CICOCRSA(i));
-+ }
-+ break;
-+ default:
-+ printk("Invalid PingPong Number %d \n",cfg->pp_num);
-+ panic("halt\n");
-+}
- return 0;
- }
-
-@@ -222,21 +225,21 @@ static int camif_pp_preview(camif_cfg_t *cfg)
- for ( i = 0; i < 4 ; i++ ) {
- cfg->img_buf[i].virt_rgb = cfg->pp_virt_buf ;
- cfg->img_buf[i].phys_rgb = cfg->pp_phys_buf ;
-- CIPRCLRSA(i) = cfg->img_buf[i].phys_rgb;
-+ writel(cfg->img_buf[i].phys_rgb, camregs + S3C2440_CAM_REG_CICOCRSA(i));
- }
- break;
- case 2:
- for ( i = 0; i < 4 ; i++) {
- cfg->img_buf[i].virt_rgb = cfg->pp_virt_buf + TRY * daon;
- cfg->img_buf[i].phys_rgb = cfg->pp_phys_buf + TRY * daon;
-- CIPRCLRSA(i) = cfg->img_buf[i].phys_rgb;
-+ writel(cfg->img_buf[i].phys_rgb, camregs + S3C2440_CAM_REG_CICOCRSA(i));
- }
- break;
- case 4:
- for ( i = 0; i < 4 ; i++) {
- cfg->img_buf[i].virt_rgb = cfg->pp_virt_buf + i * daon;
- cfg->img_buf[i].phys_rgb = cfg->pp_phys_buf + i * daon;
-- CIPRCLRSA(i) = cfg->img_buf[i].phys_rgb;
-+ writel(cfg->img_buf[i].phys_rgb, camregs + S3C2440_CAM_REG_CICOCRSA(i));
- }
- break;
- default:
-@@ -308,7 +311,7 @@ static int camif_source_fmt(camif_gc_t *gc)
- cmd |= SOURCE_HSIZE(gc->source_x)| SOURCE_VSIZE(gc->source_y);
- /* Order422 */
- cmd |= gc->order422;
-- CISRCFMT = cmd;
-+ writel(cmd, camregs + S3C2440_CAM_REG_CISRCFMT);
-
- return 0 ;
- }
-@@ -331,33 +334,24 @@ static int camif_target_fmt(camif_cfg_t *cfg)
- assert(cfg->fmt & CAMIF_OUT_YCBCR422);
- cmd |= OUT_YCBCR422|IN_YCBCR422;
- }
-- CICOTRGFMT = cmd | cfg->flip;
-- }
-- else {
-+ writel(cmd | cfg->flip, camregs + S3C2440_CAM_REG_CICOTRGFMT);
-+
-+ } else {
- assert(cfg->dma_type & CAMIF_PREVIEW);
-- CIPRTRGFMT =
-- TARGET_HSIZE(cfg->target_x)|TARGET_VSIZE(cfg->target_y)|cfg->flip;
-+ writel(TARGET_HSIZE(cfg->target_x)|TARGET_VSIZE(cfg->target_y)|cfg->flip,
-+ camregs + S3C2440_CAM_REG_CIPRTRGFMT);
- }
- return 0;
- }
-
- void camif_change_flip(camif_cfg_t *cfg)
- {
-- u32 cmd = 0;
-+ u32 cmd = readl(camregs + S3C2440_CAM_REG_CICOTRGFMT);
-
-- if (cfg->dma_type & CAMIF_CODEC ) {
-- /* YCBCR setting */
-- cmd = CICOTRGFMT;
-- cmd &= ~(BIT14|BIT15); /* Clear FLIP Mode */
-- cmd |= cfg->flip;
-- CICOTRGFMT = cmd;
-- }
-- else {
-- cmd = CIPRTRGFMT;
-- cmd &= ~(BIT14|BIT15);
-- cmd |= cfg->flip;
-- CICOTRGFMT = cmd;
-- }
-+ cmd &= ~(BIT14|BIT15);
-+ cmd |= cfg->flip;
-+
-+ writel(cmd, camregs + S3C2440_CAM_REG_CICOTRGFMT);
- }
-
-
-@@ -373,70 +367,81 @@ int camif_capture_start(camif_cfg_t *cfg)
- u32 n_cmd = 0; /* Next Command */
-
- switch(cfg->exec) {
-- case CAMIF_BOTH_DMA_ON:
-- camif_reset(CAMIF_RESET,0); /* Flush Camera Core Buffer */
-- CIPRSCCTRL |= SCALERSTART;
-- CICOSCCTRL |= SCALERSTART;
-- n_cmd = CAMIF_CAP_PREVIEW_ON|CAMIF_CAP_CODEC_ON;
-- break;
-- case CAMIF_DMA_ON:
-- camif_reset(CAMIF_RESET,0); /* Flush Camera Core Buffer */
-- if (cfg->dma_type&CAMIF_CODEC) {
-- CICOSCCTRL |= SCALERSTART;
-- n_cmd = CAMIF_CAP_CODEC_ON;
-- }else {
-- CIPRSCCTRL |= SCALERSTART;
-- n_cmd = CAMIF_CAP_PREVIEW_ON;
-- }
-+ case CAMIF_BOTH_DMA_ON:
-+ camif_reset(CAMIF_RESET, 0); /* Flush Camera Core Buffer */
-+ writel(readl(camregs + S3C2440_CAM_REG_CIPRSCCTRL) |
-+ SCALERSTART, camregs + S3C2440_CAM_REG_CIPRSCCTRL);
-+ writel(readl(camregs + S3C2440_CAM_REG_CICOSCCTRL) |
-+ SCALERSTART, camregs + S3C2440_CAM_REG_CICOSCCTRL);
-+ n_cmd = CAMIF_CAP_PREVIEW_ON | CAMIF_CAP_CODEC_ON;
-+ break;
-+ case CAMIF_DMA_ON:
-+ camif_reset(CAMIF_RESET, 0); /* Flush Camera Core Buffer */
-+ if (cfg->dma_type&CAMIF_CODEC) {
-+ writel(readl(camregs + S3C2440_CAM_REG_CICOSCCTRL) |
-+ SCALERSTART, camregs + S3C2440_CAM_REG_CICOSCCTRL);
-+ n_cmd = CAMIF_CAP_CODEC_ON;
-+ } else {
-+ writel(readl(camregs + S3C2440_CAM_REG_CIPRSCCTRL) |
-+ SCALERSTART, camregs + S3C2440_CAM_REG_CIPRSCCTRL);
-+ n_cmd = CAMIF_CAP_PREVIEW_ON;
-+ }
-
-- /* wait until Sync Time expires */
-- /* First settting, to wait VSYNC fall */
-- /* By VESA spec,in 640x480 @60Hz
-- MAX Delay Time is around 64us which "while" has.*/
-- while(VSYNC & CICOSTATUS);
-- break;
-- default:
-- break;
-- }
-- CIIMGCPT = n_cmd|CAMIF_CAP_ON;
-+ /* wait until Sync Time expires */
-+ /* First settting, to wait VSYNC fall */
-+ /* By VESA spec,in 640x480 @60Hz
-+ MAX Delay Time is around 64us which "while" has.*/
-+ while(VSYNC & readl(camregs + S3C2440_CAM_REG_CICOSTATUS));
-+ break;
-+ default:
-+ break;
-+}
-+ writel(n_cmd | CAMIF_CAP_ON, camregs + S3C2440_CAM_REG_CIIMGCPT);
- return 0;
- }
-
-
- int camif_capture_stop(camif_cfg_t *cfg)
- {
-- u32 n_cmd = CIIMGCPT; /* Next Command */
-+ u32 n_cmd = readl(camregs + S3C2440_CAM_REG_CIIMGCPT); /* Next Command */
-
- switch(cfg->exec) {
-- case CAMIF_BOTH_DMA_OFF:
-- CIPRSCCTRL &= ~SCALERSTART;
-- CICOSCCTRL &= ~SCALERSTART;
-- n_cmd = 0;
-- break;
-- case CAMIF_DMA_OFF_L_IRQ: /* fall thru */
-- case CAMIF_DMA_OFF:
-- if (cfg->dma_type&CAMIF_CODEC) {
-- CICOSCCTRL &= ~SCALERSTART;
-- n_cmd &= ~CAMIF_CAP_CODEC_ON;
-- if (!(n_cmd & CAMIF_CAP_PREVIEW_ON))
-- n_cmd = 0;
-- }else {
-- CIPRSCCTRL &= ~SCALERSTART;
-- n_cmd &= ~CAMIF_CAP_PREVIEW_ON;
-- if (!(n_cmd & CAMIF_CAP_CODEC_ON))
-- n_cmd = 0;
-- }
-- break;
-- default:
-- panic("Unexpected \n");
-- }
-- CIIMGCPT = n_cmd;
-- if(cfg->exec == CAMIF_DMA_OFF_L_IRQ) { /* Last IRQ */
-- if (cfg->dma_type & CAMIF_CODEC)
-- CICOCTRL |= LAST_IRQ_EN;
-- else
-- CIPRCTRL |= LAST_IRQ_EN;
-- }
-+ case CAMIF_BOTH_DMA_OFF:
-+ writel(readl(camregs + S3C2440_CAM_REG_CIPRSCCTRL) &
-+ ~SCALERSTART, camregs + S3C2440_CAM_REG_CIPRSCCTRL);
-+ writel(readl(camregs + S3C2440_CAM_REG_CICOSCCTRL) &
-+ ~SCALERSTART, camregs + S3C2440_CAM_REG_CICOSCCTRL);
-+ n_cmd = 0;
-+ break;
-+ case CAMIF_DMA_OFF_L_IRQ: /* fall thru */
-+ case CAMIF_DMA_OFF:
-+ if (cfg->dma_type&CAMIF_CODEC) {
-+ writel(readl(camregs + S3C2440_CAM_REG_CICOSCCTRL) &
-+ ~SCALERSTART, camregs + S3C2440_CAM_REG_CICOSCCTRL);
-+ n_cmd &= ~CAMIF_CAP_CODEC_ON;
-+ if (!(n_cmd & CAMIF_CAP_PREVIEW_ON))
-+ n_cmd = 0;
-+ } else {
-+ writel(readl(camregs + S3C2440_CAM_REG_CIPRSCCTRL) &
-+ ~SCALERSTART, camregs + S3C2440_CAM_REG_CIPRSCCTRL);
-+ n_cmd &= ~CAMIF_CAP_PREVIEW_ON;
-+ if (!(n_cmd & CAMIF_CAP_CODEC_ON))
-+ n_cmd = 0;
-+ }
-+ break;
-+ default:
-+ panic("Unexpected \n");
-+ }
-+ writel(n_cmd, camregs + S3C2440_CAM_REG_CIIMGCPT);
-+
-+ if (cfg->exec == CAMIF_DMA_OFF_L_IRQ) { /* Last IRQ */
-+ if (cfg->dma_type & CAMIF_CODEC)
-+ writel(readl(camregs + S3C2440_CAM_REG_CICOCTRL) |
-+ LAST_IRQ_EN, camregs + S3C2440_CAM_REG_CICOCTRL);
-+ else
-+ writel(readl(camregs + S3C2440_CAM_REG_CIPRCTRL) |
-+ LAST_IRQ_EN, camregs + S3C2440_CAM_REG_CIPRCTRL);
-+ }
- #if 0
- else { /* to make internal state machine of CAMERA stop */
- camif_reset(CAMIF_RESET, 0);
-@@ -449,16 +454,13 @@ int camif_capture_stop(camif_cfg_t *cfg)
- /* LastIRQEn is autoclear */
- void camif_last_irq_en(camif_cfg_t *cfg)
- {
-- if(cfg->exec == CAMIF_BOTH_DMA_ON) {
-- CIPRCTRL |= LAST_IRQ_EN;
-- CICOCTRL |= LAST_IRQ_EN;
-- }
-- else {
-- if (cfg->dma_type & CAMIF_CODEC)
-- CICOCTRL |= LAST_IRQ_EN;
-- else
-- CIPRCTRL |= LAST_IRQ_EN;
-- }
-+ if ((cfg->exec == CAMIF_BOTH_DMA_ON) || (cfg->dma_type & CAMIF_CODEC))
-+ writel(readl(camregs + S3C2440_CAM_REG_CICOCTRL) |
-+ LAST_IRQ_EN, camregs + S3C2440_CAM_REG_CICOCTRL);
-+
-+ if ((cfg->exec == CAMIF_BOTH_DMA_ON) || !(cfg->dma_type & CAMIF_CODEC))
-+ writel(readl(camregs + S3C2440_CAM_REG_CIPRCTRL) |
-+ LAST_IRQ_EN, camregs + S3C2440_CAM_REG_CIPRCTRL);
- }
-
- static int
-@@ -502,23 +504,33 @@ int camif_g_fifo_status(camif_cfg_t *cfg)
- u32 reg;
-
- if (cfg->dma_type & CAMIF_CODEC) {
-- u32 flag = CO_OVERFLOW_Y|CO_OVERFLOW_CB|CO_OVERFLOW_CR;
-- reg = CICOSTATUS;
-+ u32 flag = CO_OVERFLOW_Y | CO_OVERFLOW_CB | CO_OVERFLOW_CR;
-+ reg = readl(camregs + S3C2440_CAM_REG_CICOSTATUS);
- if (reg & flag) {
- printk("CODEC: FIFO error(0x%08x) and corrected\n",reg);
- /* FIFO Error Count ++ */
-- CIWDOFST |= CO_FIFO_Y|CO_FIFO_CB|CO_FIFO_CR;
-- CIWDOFST &= ~(CO_FIFO_Y|CO_FIFO_CB|CO_FIFO_CR);
-+ writel(readl(camregs + S3C2440_CAM_REG_CIWDOFST) |
-+ CO_FIFO_Y | CO_FIFO_CB | CO_FIFO_CR,
-+ camregs + S3C2440_CAM_REG_CIWDOFST);
-+
-+ writel(readl(camregs + S3C2440_CAM_REG_CIWDOFST) &
-+ ~(CO_FIFO_Y | CO_FIFO_CB | CO_FIFO_CR),
-+ camregs + S3C2440_CAM_REG_CIWDOFST);
- return 1; /* Error */
- }
- }
- if (cfg->dma_type & CAMIF_PREVIEW) {
-- u32 flag = PR_OVERFLOW_CB|PR_OVERFLOW_CR;
-- reg = CIPRSTATUS;
-+ u32 flag = PR_OVERFLOW_CB | PR_OVERFLOW_CR;
-+ reg = readl(camregs + S3C2440_CAM_REG_CIPRSTATUS);
- if (reg & flag) {
- printk("PREVIEW:FIFO error(0x%08x) and corrected\n",reg);
-- CIWDOFST |= PR_FIFO_CB|PR_FIFO_CR;
-- CIWDOFST &= ~(CO_FIFO_Y|CO_FIFO_CB|CO_FIFO_CR);
-+ writel(readl(camregs + S3C2440_CAM_REG_CIWDOFST) |
-+ CO_FIFO_CB | CO_FIFO_CR,
-+ camregs + S3C2440_CAM_REG_CIWDOFST);
-+
-+ writel(readl(camregs + S3C2440_CAM_REG_CIWDOFST) &
-+ ~(CO_FIFO_Y | CO_FIFO_CB | CO_FIFO_CR),
-+ camregs + S3C2440_CAM_REG_CIWDOFST);
- /* FIFO Error Count ++ */
- return 1; /* Error */
- }
-@@ -537,13 +549,16 @@ int camif_win_offset(camif_gc_t *gc )
- u32 v = gc->win_ver_ofst;
-
- /*Clear Overflow */
-- CIWDOFST = CO_FIFO_Y|CO_FIFO_CB|CO_FIFO_CR|PR_FIFO_CB|PR_FIFO_CB;
-- CIWDOFST = 0; /* ? Dummy */
-+ writel(CO_FIFO_Y | CO_FIFO_CB | CO_FIFO_CR | PR_FIFO_CB | PR_FIFO_CB,
-+ camregs + S3C2440_CAM_REG_CIWDOFST);
-+ writel(0, camregs + S3C2440_CAM_REG_CIWDOFST);
-+
- if (!h && !v) {
-- CIWDOFST = 0;
-+ writel(0, camregs + S3C2440_CAM_REG_CIWDOFST);
- return 0;
- }
-- CIWDOFST = WINOFEN | WINHOROFST(h) | WINVEROFST(v);
-+
-+ writel(WINOFEN | WINHOROFST(h) | WINVEROFST(v), camregs + S3C2440_CAM_REG_CIWDOFST);
- return 0;
- }
-
-@@ -554,7 +569,7 @@ int camif_win_offset(camif_gc_t *gc )
- */
- static void camif_polarity(camif_gc_t *gc)
- {
-- u32 cmd = CIGCTRL;
-+ u32 cmd = readl(camregs + S3C2440_CAM_REG_CIGCTRL);;
-
- cmd = cmd & ~(BIT26|BIT25|BIT24); /* clear polarity */
- if (gc->polarity_pclk)
-@@ -563,7 +578,8 @@ static void camif_polarity(camif_gc_t *gc)
- cmd |= GC_INVPOLVSYNC;
- if (gc->polarity_href)
- cmd |= GC_INVPOLHREF;
-- CIGCTRL |= cmd;
-+ writel(readl(camregs + S3C2440_CAM_REG_CIGCTRL) |
-+ cmd, camregs + S3C2440_CAM_REG_CIGCTRL);
- }
-
-
-@@ -599,12 +615,13 @@ int camif_dynamic_close(camif_cfg_t *cfg)
- static int camif_target_area(camif_cfg_t *cfg)
- {
- u32 rect = cfg->target_x * cfg->target_y;
-- if (cfg->dma_type & CAMIF_CODEC ) {
-- CICOTAREA = rect;
-- }
-- if (cfg->dma_type & CAMIF_PREVIEW) {
-- CIPRTAREA = rect;
-- }
-+
-+ if (cfg->dma_type & CAMIF_CODEC)
-+ writel(rect, camregs + S3C2440_CAM_REG_CICOTAREA);
-+
-+ if (cfg->dma_type & CAMIF_PREVIEW)
-+ writel(rect, camregs + S3C2440_CAM_REG_CIPRTAREA);
-+
- return 0;
- }
-
-@@ -613,40 +630,44 @@ static int inline camif_hw_reg(camif_cfg_t *cfg)
- u32 cmd = 0;
-
- if (cfg->dma_type & CAMIF_CODEC) {
-- CICOSCPRERATIO = PRE_SHIFT(cfg->sc.shfactor)
-- |PRE_HRATIO(cfg->sc.prehratio)|PRE_VRATIO(cfg->sc.prevratio);
-- CICOSCPREDST =
-- PRE_DST_WIDTH(cfg->sc.predst_x)|PRE_DST_HEIGHT(cfg->sc.predst_y);
-+ writel(PRE_SHIFT(cfg->sc.shfactor) |
-+ PRE_HRATIO(cfg->sc.prehratio) |
-+ PRE_VRATIO(cfg->sc.prevratio),
-+ camregs + S3C2440_CAM_REG_CICOSCPRERATIO);
-+ writel(PRE_DST_WIDTH(cfg->sc.predst_x) |
-+ PRE_DST_HEIGHT(cfg->sc.predst_y),
-+ camregs + S3C2440_CAM_REG_CICOSCPREDST);
-
- /* Differ from Preview */
- if (cfg->sc.scalerbypass)
- cmd |= SCALERBYPASS;
- if (cfg->sc.scaleup_h & cfg->sc.scaleup_v)
- cmd |= BIT30|BIT29;
-- CICOSCCTRL = cmd | MAIN_HRATIO(cfg->sc.mainhratio)
-- |MAIN_VRATIO(cfg->sc.mainvratio);
-+ writel(cmd | MAIN_HRATIO(cfg->sc.mainhratio) |
-+ MAIN_VRATIO(cfg->sc.mainvratio),
-+ camregs + S3C2440_CAM_REG_CICOSCCTRL);
- return 0;
- }
-- else if (cfg->dma_type & CAMIF_PREVIEW) {
-- CIPRSCPRERATIO = PRE_SHIFT(cfg->sc.shfactor)
-- |PRE_HRATIO(cfg->sc.prehratio)|PRE_VRATIO(cfg->sc.prevratio);
-- CIPRSCPREDST =
-- PRE_DST_WIDTH(cfg->sc.predst_x)|PRE_DST_HEIGHT(cfg->sc.predst_y);
-+ if (cfg->dma_type & CAMIF_PREVIEW) {
-+ writel(PRE_SHIFT(cfg->sc.shfactor) |
-+ PRE_HRATIO(cfg->sc.prehratio) |
-+ PRE_VRATIO(cfg->sc.prevratio),
-+ camregs + S3C2440_CAM_REG_CIPRSCPRERATIO);
-+ writel(PRE_DST_WIDTH(cfg->sc.predst_x) |
-+ PRE_DST_HEIGHT(cfg->sc.predst_y),
-+ camregs + S3C2440_CAM_REG_CIPRSCPREDST);
- /* Differ from Codec */
-- if (cfg->fmt & CAMIF_RGB24) {
-+ if (cfg->fmt & CAMIF_RGB24)
- cmd |= RGB_FMT24;
-- }
-- else {
-- /* RGB16 */;
-- }
- if (cfg->sc.scaleup_h & cfg->sc.scaleup_v)
-- cmd |= BIT29|BIT28;
-- CIPRSCCTRL = cmd |MAIN_HRATIO(cfg->sc.mainhratio)|S_METHOD
-- |MAIN_VRATIO(cfg->sc.mainvratio);
-- }else {
-- panic("CAMERA:DMA_TYPE Wrong \n");
-+ cmd |= BIT29 | BIT28;
-+ writel(cmd | MAIN_HRATIO(cfg->sc.mainhratio) | S_METHOD |
-+ MAIN_VRATIO(cfg->sc.mainvratio),
-+ camregs + S3C2440_CAM_REG_CIPRSCCTRL);
-+ return 0;
- }
-
-+ panic("CAMERA:DMA_TYPE Wrong \n");
- return 0;
- }
-
-@@ -654,46 +675,50 @@ static int inline camif_hw_reg(camif_cfg_t *cfg)
- /* Configure Pre-scaler control & main scaler control register */
- static int camif_scaler(camif_cfg_t *cfg)
- {
-- int tx = cfg->target_x,ty=cfg->target_y;
-+ int tx = cfg->target_x, ty = cfg->target_y;
- int sx, sy;
-
-- if (tx <= 0 || ty<= 0) panic("CAMERA: Invalid target size \n");
-+ if (tx <= 0 || ty <= 0)
-+ panic("CAMERA: Invalid target size \n");
-+
-+ sx = cfg->gc->source_x - 2 * cfg->gc->win_hor_ofst;
-+ sy = cfg->gc->source_y - 2 * cfg->gc->win_ver_ofst;
-+ if (sx <= 0 || sy <= 0)
-+ panic("CAMERA: Invalid source size \n");
-
-- sx = cfg->gc->source_x - 2*cfg->gc->win_hor_ofst;
-- sy = cfg->gc->source_y - 2*cfg->gc->win_ver_ofst;
-- if (sx <= 0 || sy<= 0) panic("CAMERA: Invalid source size \n");
- cfg->sc.modified_src_x = sx;
- cfg->sc.modified_src_y = sy;
-
- /* Pre-scaler control register 1 */
-- camif_scaler_internal(sx,tx,&cfg->sc.prehratio,&cfg->sc.hfactor);
-- camif_scaler_internal(sy,ty,&cfg->sc.prevratio,&cfg->sc.vfactor);
-+ camif_scaler_internal(sx, tx, &cfg->sc.prehratio, &cfg->sc.hfactor);
-+ camif_scaler_internal(sy, ty, &cfg->sc.prevratio, &cfg->sc.vfactor);
-
-- if (cfg->dma_type & CAMIF_PREVIEW) {
-- if ( (sx /cfg->sc.prehratio) <= 640 ) {}
-- else {
-- printk(KERN_INFO "CAMERA: Internal Preview line buffer is 640 pixels\n");
-+ if (cfg->dma_type & CAMIF_PREVIEW)
-+ if ((sx / cfg->sc.prehratio) > 640) {
-+ printk(KERN_INFO "CAMERA: Internal Preview line "
-+ "buffer is 640 pixels\n");
- return 1; /* Error */
- }
-- }
-
-- cfg->sc.shfactor = 10-(cfg->sc.hfactor+cfg->sc.vfactor);
-+ cfg->sc.shfactor = 10 - (cfg->sc.hfactor + cfg->sc.vfactor);
- /* Pre-scaler control register 2 */
- cfg->sc.predst_x = sx / cfg->sc.prehratio;
- cfg->sc.predst_y = sy / cfg->sc.prevratio;
-
- /* Main-scaler control register */
-- cfg->sc.mainhratio = (sx << 8)/(tx << cfg->sc.hfactor);
-- cfg->sc.mainvratio = (sy << 8)/(ty << cfg->sc.vfactor);
-- DPRINTK(" sx %d, sy %d tx %d ty %d \n",sx,sy,tx,ty);
-- DPRINTK(" hfactor %d vfactor %d \n",cfg->sc.hfactor,cfg->sc.vfactor);
-+ cfg->sc.mainhratio = (sx << 8) / (tx << cfg->sc.hfactor);
-+ cfg->sc.mainvratio = (sy << 8) / (ty << cfg->sc.vfactor);
-+ DPRINTK(" sx %d, sy %d tx %d ty %d \n", sx, sy, tx, ty);
-+ DPRINTK(" hfactor %d vfactor %d \n",cfg->sc.hfactor, cfg->sc.vfactor);
-
- cfg->sc.scaleup_h = (sx <= tx) ? 1: 0;
- cfg->sc.scaleup_v = (sy <= ty) ? 1: 0;
-- if ( cfg->sc.scaleup_h != cfg->sc.scaleup_v)
-+ if (cfg->sc.scaleup_h != cfg->sc.scaleup_v)
- printk(KERN_ERR "scaleup_h must be same to scaleup_v \n");
-+
- camif_hw_reg(cfg);
- camif_target_area(cfg);
-+
- return 0;
- }
-
-@@ -706,38 +731,38 @@ static void camif_g_bsize(u32 hsize, u32 *mburst, u32 *rburst)
- {
- u32 tmp;
-
-- tmp = (hsize/4) % 16;
-+ tmp = (hsize / 4) % 16;
- switch(tmp) {
-+ case 0:
-+ *mburst=16;
-+ *rburst=16;
-+ break;
-+ case 4:
-+ *mburst=16;
-+ *rburst=4;
-+ break;
-+ case 8:
-+ *mburst=16;
-+ *rburst=8;
-+ break;
-+ default:
-+ tmp=(hsize / 4) % 8;
-+ switch(tmp) {
- case 0:
-- *mburst=16;
-- *rburst=16;
-+ *mburst = 8;
-+ *rburst = 8;
- break;
- case 4:
-- *mburst=16;
-- *rburst=4;
-- break;
-- case 8:
-- *mburst=16;
-- *rburst=8;
-- break;
-+ *mburst = 8;
-+ *rburst = 4;
- default:
-- tmp=(hsize/4)%8;
-- switch(tmp) {
-- case 0:
-- *mburst=8;
-- *rburst=8;
-- break;
-- case 4:
-- *mburst=8;
-- *rburst=4;
-- default:
-- *mburst=4;
-- tmp=(hsize/4)%4;
-- *rburst= (tmp) ? tmp: 4;
-- break;
-- }
-+ *mburst = 4;
-+ tmp = (hsize / 4) % 4;
-+ *rburst= (tmp) ? tmp: 4;
- break;
- }
-+ break;
-+ }
- }
-
- /* SXGA 1028x1024*/
-@@ -759,24 +784,30 @@ static int camif_dma_burst(camif_cfg_t *cfg)
- u32 yburst_m, yburst_r;
- u32 cburst_m, cburst_r;
- /* CODEC DMA WIDHT is multiple of 16 */
-- if (width %16 != 0 ) return BURST_ERR; /* DMA Burst Length Error */
-- camif_g_bsize(width,&yburst_m,&yburst_r);
-- camif_g_bsize(width/2,&cburst_m,&cburst_r);
-- CICOCTRL =YBURST_M(yburst_m)|CBURST_M(cburst_m)
-- |YBURST_R(yburst_r)|CBURST_R(cburst_r);
-+ if (width % 16)
-+ return BURST_ERR; /* DMA Burst Length Error */
-+ camif_g_bsize(width, &yburst_m, &yburst_r);
-+ camif_g_bsize(width / 2, &cburst_m, &cburst_r);
-+
-+ writel(YBURST_M(yburst_m) | CBURST_M(cburst_m) |
-+ YBURST_R(yburst_r) | CBURST_R(cburst_r),
-+ camregs + S3C2440_CAM_REG_CICOCTRL);
- }
-
- if (cfg->dma_type & CAMIF_PREVIEW) {
- u32 rgburst_m, rgburst_r;
- if(cfg->fmt == CAMIF_RGB24) {
-- if (width %2 != 0 ) return BURST_ERR; /* DMA Burst Length Error */
-+ if (width % 2)
-+ return BURST_ERR; /* DMA Burst Length Error */
- camif_g_bsize(width*4,&rgburst_m,&rgburst_r);
-- }
-- else { /* CAMIF_RGB16 */
-- if ((width/2) %2 != 0 ) return BURST_ERR; /* DMA Burst Length Error */
-+ } else { /* CAMIF_RGB16 */
-+ if ((width / 2) %2)
-+ return BURST_ERR; /* DMA Burst Length Error */
- camif_g_bsize(width*2,&rgburst_m,&rgburst_r);
- }
-- CIPRCTRL = RGBURST_M(rgburst_m) | RGBURST_R(rgburst_r);
-+
-+ writel(RGBURST_M(rgburst_m) | RGBURST_R(rgburst_r),
-+ camregs + S3C2440_CAM_REG_CIPRCTRL);
- }
- return 0;
- }
-@@ -786,19 +817,20 @@ static int camif_gpio_init(void)
- #ifdef CONFIG_ARCH_S3C24A0A
- /* S3C24A0A has the dedicated signal pins for Camera */
- #else
-- set_gpio_ctrl(GPIO_CAMDATA0);
-- set_gpio_ctrl(GPIO_CAMDATA1);
-- set_gpio_ctrl(GPIO_CAMDATA2);
-- set_gpio_ctrl(GPIO_CAMDATA3);
-- set_gpio_ctrl(GPIO_CAMDATA4);
-- set_gpio_ctrl(GPIO_CAMDATA5);
-- set_gpio_ctrl(GPIO_CAMDATA6);
-- set_gpio_ctrl(GPIO_CAMDATA7);
-- set_gpio_ctrl(GPIO_CAMPCLKIN);
-- set_gpio_ctrl(GPIO_CAMVSYNC);
-- set_gpio_ctrl(GPIO_CAMHREF);
-- set_gpio_ctrl(GPIO_CAMPCLKOUT);
-- set_gpio_ctrl(GPIO_CAMRESET);
-+ s3c2410_gpio_cfgpin(S3C2440_GPJ0, S3C2440_GPJ0_CAMDATA0);
-+ s3c2410_gpio_cfgpin(S3C2440_GPJ1, S3C2440_GPJ1_CAMDATA1);
-+ s3c2410_gpio_cfgpin(S3C2440_GPJ2, S3C2440_GPJ2_CAMDATA2);
-+ s3c2410_gpio_cfgpin(S3C2440_GPJ3, S3C2440_GPJ3_CAMDATA3);
-+ s3c2410_gpio_cfgpin(S3C2440_GPJ4, S3C2440_GPJ4_CAMDATA4);
-+ s3c2410_gpio_cfgpin(S3C2440_GPJ5, S3C2440_GPJ5_CAMDATA5);
-+ s3c2410_gpio_cfgpin(S3C2440_GPJ6, S3C2440_GPJ6_CAMDATA6);
-+ s3c2410_gpio_cfgpin(S3C2440_GPJ7, S3C2440_GPJ7_CAMDATA7);
-+
-+ s3c2410_gpio_cfgpin(S3C2440_GPJ8, S3C2440_GPJ8_CAMPCLK);
-+ s3c2410_gpio_cfgpin(S3C2440_GPJ9, S3C2440_GPJ9_CAMVSYNC);
-+ s3c2410_gpio_cfgpin(S3C2440_GPJ10, S3C2440_GPJ10_CAMHREF);
-+ s3c2410_gpio_cfgpin(S3C2440_GPJ11, S3C2440_GPJ11_CAMCLKOUT);
-+ s3c2410_gpio_cfgpin(S3C2440_GPJ12, S3C2440_GPJ12_CAMRESET);
- #endif
- return 0;
- }
-@@ -827,21 +859,33 @@ int camif_clock_init(camif_gc_t *gc)
- camclk_div = (upll+ROUND_ADD) / camclk - 1;
- CLKDIVN = (CLKDIVN & 0xFF) | CLKDIVN_CAM(camclk_div);
- printk(KERN_INFO"CAMERA:upll %d MACRO 0x%08X CLKDIVN 0x%08X \n",
-- upll, CLKDIVN_CAM(camclk_div),CLKDIVN);
-- CIIMGCPT = 0; /* Dummy ? */
-+ upll, CLKDIVN_CAM(camclk_div), CLKDIVN);
-+ writel(0, camregs + S3C2440_CAM_REG_CIIMGCPT); /* Dummy ? */
-+
- return 0;
- }
- #else
- int camif_clock_init(camif_gc_t *gc)
- {
-- unsigned int upll, camclk_div, camclk;
-- if (!gc) camclk = 24000000;
-- else {
-+ unsigned int camclk;
-+ struct clk *clk_camif = clk_get(NULL, "camif");
-+ struct clk *clk_camif_upll = clk_get(NULL, "camif-upll");
-+
-+ if (!gc)
-+ camclk = 24000000;
-+ else {
- camclk = gc->camclk;
- if (camclk > 48000000)
- printk(KERN_ERR "Wrong Camera Clock\n");
- }
-
-+ clk_set_rate(clk_camif, camclk);
-+
-+ clk_enable(clk_camif);
-+ clk_enable(clk_camif_upll);
-+
-+
-+#if 0
- CLKCON |= CLKCON_CAMIF;
- upll = elfin_get_bus_clk(GET_UPLL);
- printk(KERN_INFO "CAMERA:Default UPLL %08d and Assing 96Mhz to UPLL\n",upll);
-@@ -854,7 +898,9 @@ int camif_clock_init(camif_gc_t *gc)
- camclk_div = (upll+ROUND_ADD) /(camclk * 2) -1;
- CAMDIVN = CAMCLK_SET_DIV|(camclk_div&0xf);
- printk(KERN_INFO "CAMERA:upll %08d cam_clk %08d CAMDIVN 0x%08x \n",upll,camclk, CAMDIVN);
-- CIIMGCPT = 0; /* Dummy ? */
-+#endif
-+ writel(0, camregs + S3C2440_CAM_REG_CIIMGCPT); /* Dummy ? */
-+
- return 0;
- }
- #endif
-@@ -867,23 +913,39 @@ void camif_reset(int is, int delay)
- {
- switch (is) {
- case CAMIF_RESET:
-- CIGCTRL |= GC_SWRST;
-+ writel(readl(camregs + S3C2440_CAM_REG_CIGCTRL) |
-+ GC_SWRST,
-+ camregs + S3C2440_CAM_REG_CIGCTRL);
- mdelay(1);
-- CIGCTRL &= ~GC_SWRST;
-+ writel(readl(camregs + S3C2440_CAM_REG_CIGCTRL) &
-+ ~GC_SWRST,
-+ camregs + S3C2440_CAM_REG_CIGCTRL);
- break;
- case CAMIF_EX_RESET_AH: /*Active High */
-- CIGCTRL &= ~GC_CAMRST;
-+ writel(readl(camregs + S3C2440_CAM_REG_CIGCTRL) &
-+ ~GC_CAMRST,
-+ camregs + S3C2440_CAM_REG_CIGCTRL);
- udelay(200);
-- CIGCTRL |= GC_CAMRST;
-+ writel(readl(camregs + S3C2440_CAM_REG_CIGCTRL) |
-+ GC_CAMRST,
-+ camregs + S3C2440_CAM_REG_CIGCTRL);
- udelay(delay);
-- CIGCTRL &= ~GC_CAMRST;
-+ writel(readl(camregs + S3C2440_CAM_REG_CIGCTRL) &
-+ ~GC_CAMRST,
-+ camregs + S3C2440_CAM_REG_CIGCTRL);
- break;
- case CAMIF_EX_RESET_AL: /*Active Low */
-- CIGCTRL |= GC_CAMRST;
-+ writel(readl(camregs + S3C2440_CAM_REG_CIGCTRL) |
-+ GC_CAMRST,
-+ camregs + S3C2440_CAM_REG_CIGCTRL);
- udelay(200);
-- CIGCTRL &= ~GC_CAMRST;
-+ writel(readl(camregs + S3C2440_CAM_REG_CIGCTRL) &
-+ ~GC_CAMRST,
-+ camregs + S3C2440_CAM_REG_CIGCTRL);
- udelay(delay);
-- CIGCTRL |= GC_CAMRST;
-+ writel(readl(camregs + S3C2440_CAM_REG_CIGCTRL) |
-+ GC_CAMRST,
-+ camregs + S3C2440_CAM_REG_CIGCTRL);
- break;
- default:
- break;
-@@ -908,10 +970,10 @@ static void camif_bus_priority(int flag)
- PRIORITY1 = PRIORITY_I_FIX;
-
- #else
-- old_priority = PRIORITY;
-- PRIORITY &= ~(3<<7);
-- PRIORITY |= (1<<7); /* Arbiter 1, REQ2 first */
-- PRIORITY &= ~(1<<1); /* Disable Priority Rotate */
-+ old_priority = readl(S3C2410_PRIORITY);
-+ writel(readl(S3C2410_PRIORITY) & ~(3<<7), S3C2410_PRIORITY);
-+ writel(readl(S3C2410_PRIORITY) | (1<<7), S3C2410_PRIORITY); /* Arbiter 1, REQ2 first */
-+ writel(readl(S3C2410_PRIORITY) & ~(1<<1), S3C2410_PRIORITY); /* Disable Priority Rotate */
- #endif
- }
- else {
-@@ -919,19 +981,26 @@ static void camif_bus_priority(int flag)
- PRIORITY0 = old_priority;
- PRIORITY1 = old_priority;
- #else
-- PRIORITY = old_priority;
-+ writel(old_priority, S3C2410_PRIORITY);
- #endif
- }
- }
-
- static void inline camif_clock_off(void)
- {
-- CIIMGCPT = 0;
- #if defined (CONFIG_ARCH_S3C24A0A)
-+ writel(0, camregs + S3C2440_CAM_REG_CIIMGCPT);
-+
- CLKCON &= ~CLKCON_CAM_UPLL;
- CLKCON &= ~CLKCON_CAM_HCLK;
- #else
-- CLKCON &= ~CLKCON_CAMIF;
-+ struct clk *clk_camif = clk_get(NULL, "camif");
-+ struct clk *clk_camif_upll = clk_get(NULL, "camif-upll");
-+
-+ writel(0, camregs + S3C2440_CAM_REG_CIIMGCPT);
-+
-+ clk_disable(clk_camif);
-+ clk_disable(clk_camif_upll);
- #endif
- }
-
-diff --git a/arch/arm/mach-s3c2440/camera/camif_fsm.c b/arch/arm/mach-s3c2440/camera/camif_fsm.c
-index 3e2b71a..b534aca 100644
---- a/arch/arm/mach-s3c2440/camera/camif_fsm.c
-+++ b/arch/arm/mach-s3c2440/camera/camif_fsm.c
-@@ -31,7 +31,12 @@
- #include <asm/semaphore.h>
- #include <linux/miscdevice.h>
-
-+#define CONFIG_VIDEO_V4L1_COMPAT
-+#include <linux/videodev.h>
-+#include "camif.h"
-+
- //#define SW_DEBUG
-+static void camif_start_p_with_c(camif_cfg_t *cfg);
-
- #include "camif.h"
- const char *fsm_version =
-diff --git a/arch/arm/mach-s3c2440/camera/imgsensor.c b/arch/arm/mach-s3c2440/camera/imgsensor.c
-index 44b7bee..2099b69 100644
---- a/arch/arm/mach-s3c2440/camera/imgsensor.c
-+++ b/arch/arm/mach-s3c2440/camera/imgsensor.c
-@@ -11,7 +11,7 @@
- * Driver for FIMC20 Camera Decoder
- */
-
--#include <linux/config.h>
-+
- #include <linux/module.h>
- #include <linux/kernel.h>
- #include <linux/init.h>
-@@ -24,10 +24,12 @@
-
- #ifdef CONFIG_ARCH_S3C24A0A
- #else
--#include <asm/arch/S3C2440.h>
-+//#include <asm/arch/S3C2440.h>
- #endif
-
- #define SW_DEBUG
-+#define CONFIG_VIDEO_V4L1_COMPAT
-+#include <linux/videodev.h>
- #include "camif.h"
- #include "sensor.h"
-
-@@ -37,10 +39,6 @@
- #include "sxga.h"
- #endif
-
--static const char *sensor_version =
-- "$Id: imgsensor.c,v 1.11 2004/06/10 12:45:40 swlee Exp $";
--
--
- static struct i2c_driver s5x532_driver;
- static camif_gc_t data = {
- itu_fmt: CAMIF_ITU601,
-@@ -69,22 +67,18 @@ static camif_gc_t data = {
-
- #define CAM_ID 0x5a
-
--static unsigned short ignore[] = { I2C_CLIENT_END };
-+static unsigned short ignore = I2C_CLIENT_END;
- static unsigned short normal_addr[] = { (CAM_ID>>1), I2C_CLIENT_END };
- static struct i2c_client_address_data addr_data = {
- normal_i2c: normal_addr,
-- normal_i2c_range: ignore,
-- probe: ignore,
-- probe_range: ignore,
-- ignore: ignore,
-- ignore_range: ignore,
-- force: ignore,
-+ probe: &ignore,
-+ ignore: &ignore,
- };
-
- s5x532_t s5x532_regs_mirror[S5X532_REGS];
-
- unsigned char
--s5x532_read(struct i2c_client *client,unsigned char subaddr)
-+s5x532_read(struct i2c_client *client, unsigned char subaddr)
- {
- int ret;
- unsigned char buf[1];
-@@ -151,7 +145,7 @@ void inline s5x532_init(struct i2c_client *sam_client)
- }
-
- static int
--s5x532_attach(struct i2c_adapter *adap, int addr, unsigned short flags,int kind)
-+s5x532_attach(struct i2c_adapter *adap, int addr, int kind)
- {
- struct i2c_client *c;
-
-@@ -159,13 +153,13 @@ s5x532_attach(struct i2c_adapter *adap, int addr, unsigned short flags,int kind)
- if (!c) return -ENOMEM;
-
- strcpy(c->name, "S5X532");
-- c->id = s5x532_driver.id;
-- c->flags = I2C_CLIENT_ALLOW_USE;
-+// c->id = s5x532_driver.id;
-+ c->flags = 0 /* I2C_CLIENT_ALLOW_USE */;
- c->addr = addr;
- c->adapter = adap;
- c->driver = &s5x532_driver;
-- c->data = &data;
-- data.sensor = c;
-+ data.sensor = c;
-+ i2c_set_clientdata(c, &data);
-
- camif_register_decoder(c);
- return i2c_attach_client(c);
-@@ -192,10 +186,10 @@ s5x532_command(struct i2c_client *client, unsigned int cmd, void *arg)
- printk(KERN_INFO "CAMERA: S5X532 Sensor initialized\n");
- break;
- case USER_ADD:
-- MOD_INC_USE_COUNT;
-+ /* MOD_INC_USE_COUNT; uh.. 2.6 deals with this, old-timer */
- break;
- case USER_EXIT:
-- MOD_DEC_USE_COUNT;
-+ /* MOD_DEC_USE_COUNT; */
- break;
- /* Todo
- case SENSOR_BRIGHTNESS:
-@@ -210,9 +204,8 @@ s5x532_command(struct i2c_client *client, unsigned int cmd, void *arg)
- }
-
- static struct i2c_driver s5x532_driver = {
-- name: "S5X532",
-- id: I2C_ALGO_S3C,
-- flags: I2C_DF_NOTIFY,
-+ driver: { name: "S5X532" },
-+ id: 0, /* optional in i2c-id.h I2C_ALGO_S3C, */
- attach_adapter: s5x532_probe,
- detach_client: s5x532_detach,
- command: s5x532_command
-@@ -220,11 +213,13 @@ static struct i2c_driver s5x532_driver = {
-
- static void iic_gpio_port(void)
- {
-+/* FIXME: no gpio config for i2c !!!
- #ifdef CONFIG_ARCH_S3C24A0A
- #else
- GPECON &= ~(0xf <<28);
- GPECON |= 0xa <<28;
- #endif
-+*/
- }
-
- static __init int camif_sensor_init(void)
-diff --git a/arch/arm/mach-s3c2440/camera/qt-driver.c b/arch/arm/mach-s3c2440/camera/qt-driver.c
-index 0c5dd40..cbf8565 100644
---- a/arch/arm/mach-s3c2440/camera/qt-driver.c
-+++ b/arch/arm/mach-s3c2440/camera/qt-driver.c
-@@ -31,12 +31,15 @@
-
- //#define SW_DEBUG
-
-+#define CONFIG_VIDEO_V4L1_COMPAT
-+#include <linux/videodev.h>
- #include "camif.h"
--#include "videodev.h"
- #include "miscdevice.h"
- #include "cam_reg.h"
- #include "sensor.h"
- #include "userapp.h"
-+
-+extern camif_cfg_t * get_camif(int nr);
-
-
- /************************* Sharp Zarus API **************************
-diff --git a/arch/arm/mach-s3c2440/camera/video-driver.c b/arch/arm/mach-s3c2440/camera/video-driver.c
-index fe9130c..9c77475 100644
---- a/arch/arm/mach-s3c2440/camera/video-driver.c
-+++ b/arch/arm/mach-s3c2440/camera/video-driver.c
-@@ -29,11 +29,12 @@
- #include <asm/irq.h>
- #include <asm/semaphore.h>
- #include <linux/miscdevice.h>
-+#include <asm/arch/irqs.h>
-
- //#define SW_DEBUG
--
-+#define CONFIG_VIDEO_V4L1_COMPAT
-+#include <linux/videodev.h>
- #include "camif.h"
--#include "videodev.h"
- #include "miscdevice.h"
- #include "cam_reg.h"
- #include "sensor.h"
-@@ -46,12 +47,14 @@
- /* Codec and Preview */
- #define CAMIF_NUM 2
- static camif_cfg_t fimc[CAMIF_NUM];
-+u32 *camregs;
-
- static const char *driver_version =
- "$Id: video-driver.c,v 1.9 2004/06/02 03:10:36 swlee Exp $";
- extern const char *fimc_version;
- extern const char *fsm_version;
-
-+extern void camif_start_c_with_p (camif_cfg_t *cfg, camif_cfg_t *other);
-
- camif_cfg_t * get_camif(int nr)
- {
-@@ -177,28 +180,34 @@ camif_c_read(struct file *file, char *buf, size_t count, loff_t *pos)
- }
-
-
--static void camif_c_irq(int irq, void *dev_id, struct pt_regs *regs)
-+static irqreturn_t camif_c_irq(int irq, void *dev_id)
- {
- camif_cfg_t *cfg = (camif_cfg_t *)dev_id;
-+
- DPRINTK("\n");
- camif_g_fifo_status(cfg);
- camif_g_frame_num(cfg);
-- if(camif_enter_c_4fsm(cfg) == INSTANT_SKIP) return;
-- wake_up_interruptible(&cfg->waitq);
-+ if(camif_enter_c_4fsm(cfg) != INSTANT_SKIP)
-+ wake_up_interruptible(&cfg->waitq);
-+
-+ return IRQ_HANDLED;
- }
-
--static void camif_p_irq(int irq, void *dev_id, struct pt_regs * regs)
-+static irqreturn_t camif_p_irq(int irq, void *dev_id)
- {
- camif_cfg_t *cfg = (camif_cfg_t *)dev_id;
-+
- DPRINTK("\n");
- camif_g_fifo_status(cfg);
- camif_g_frame_num(cfg);
-- if(camif_enter_p_4fsm(cfg) == INSTANT_SKIP) return;
-- wake_up_interruptible(&cfg->waitq);
-+ if(camif_enter_p_4fsm(cfg) != INSTANT_SKIP)
-+ wake_up_interruptible(&cfg->waitq);
- #if 0
- if( (cfg->perf.frames % 5) == 0)
- DPRINTK("5\n");
- #endif
-+
-+ return IRQ_HANDLED;
- }
-
- static void camif_release_irq(camif_cfg_t *cfg)
-@@ -213,13 +222,13 @@ static int camif_irq_request(camif_cfg_t *cfg)
-
- if (cfg->dma_type & CAMIF_CODEC) {
- if ((ret = request_irq(cfg->irq, camif_c_irq,
-- SA_INTERRUPT,cfg->shortname, cfg))) {
-+ 0, cfg->shortname, cfg))) {
- printk("request_irq(CAM_C) failed.\n");
- }
- }
- if (cfg->dma_type & CAMIF_PREVIEW) {
- if ((ret = request_irq(cfg->irq, camif_p_irq,
-- SA_INTERRUPT,cfg->shortname, cfg))) {
-+ 0, cfg->shortname, cfg))) {
- printk("request_irq(CAM_P) failed.\n");
- }
- }
-@@ -438,7 +447,7 @@ static struct video_device codec_template =
- {
- .name = "CODEC_IF",
- .type = VID_TYPE_CAPTURE|VID_TYPE_CLIPPING|VID_TYPE_SCALES,
-- .hardware = VID_HARDWARE_SAMSUNG_FIMC20,
-+/* .hardware = VID_HARDWARE_SAMSUNG_FIMC20, */
- .fops = &camif_c_fops,
- // .release = camif_release
- .minor = -1,
-@@ -448,7 +457,7 @@ static struct video_device preview_template =
- {
- .name = "PREVIEW_IF",
- .type = VID_TYPE_CAPTURE|VID_TYPE_CLIPPING|VID_TYPE_SCALES,
-- .hardware = VID_HARDWARE_SAMSUNG_FIMC20,
-+/* .hardware = VID_HARDWARE_SAMSUNG_FIMC20, */
- .fops = &camif_p_fops,
- .minor = -1,
- };
-@@ -465,8 +474,8 @@ static int preview_init(camif_cfg_t *cfg)
- cfg->fmt = CAMIF_RGB16;
- cfg->flip = CAMIF_FLIP_Y;
- cfg->v = &preview_template;
-- init_MUTEX(&cfg->v->lock);
-- cfg->irq = IRQ_CAM_P;
-+ mutex_init(&cfg->v->lock);
-+ cfg->irq = IRQ_S3C2440_CAM_P;
-
- strcpy(cfg->shortname,name);
- init_waitqueue_head(&cfg->waitq);
-@@ -486,8 +495,8 @@ static int codec_init(camif_cfg_t *cfg)
- cfg->fmt = CAMIF_IN_YCBCR422|CAMIF_OUT_YCBCR420;
- cfg->flip = CAMIF_FLIP_X;
- cfg->v = &codec_template;
-- init_MUTEX(&cfg->v->lock);
-- cfg->irq = IRQ_CAM_C;
-+ mutex_init(&cfg->v->lock);
-+ cfg->irq = IRQ_S3C2440_CAM_C;
- strcpy(cfg->shortname,name);
- init_waitqueue_head(&cfg->waitq);
- cfg->status = CAMIF_STOPPED;
-@@ -510,25 +519,44 @@ static void print_version(void)
-
- static int camif_m_in(void)
- {
-- int ret = 0;
-+ int ret = -EINVAL;
- camif_cfg_t * cfg;
-
-+ printk(KERN_INFO"Starting S3C2440 Camera Driver\n");
-+
-+ camregs = ioremap(CAM_BASE_ADD, 0x100);
-+ if (!camregs) {
-+ printk(KERN_ERR"Unable to map camera regs\n");
-+ ret = -ENOMEM;
-+ goto bail1;
-+ }
-+
- camif_init();
- cfg = get_camif(CODEC_MINOR);
- codec_init(cfg);
-
-- if (video_register_device(cfg->v,0,CODEC_MINOR)!=0) {
-- DPRINTK("Couldn't register codec driver.\n");
-- return 0;
-+ ret = video_register_device(cfg->v,0,CODEC_MINOR);
-+ if (ret) {
-+ printk(KERN_ERR"Couldn't register codec driver.\n");
-+ goto bail2;
- }
- cfg = get_camif(PREVIEW_MINOR);
- preview_init(cfg);
-- if (video_register_device(cfg->v,0,PREVIEW_MINOR)!=0) {
-- DPRINTK("Couldn't register preview driver.\n");
-- return 0;
-+ ret = video_register_device(cfg->v,0,PREVIEW_MINOR);
-+ if (ret) {
-+ printk(KERN_ERR"Couldn't register preview driver.\n");
-+ goto bail3; /* hm seems it us unregistered the once */
- }
-
- print_version();
-+ return 0;
-+
-+bail3:
-+ video_unregister_device(cfg->v);
-+bail2:
-+ iounmap(camregs);
-+ camregs = NULL;
-+bail1:
- return ret;
- }
-
-@@ -536,7 +564,9 @@ static void unconfig_device(camif_cfg_t *cfg)
- {
- video_unregister_device(cfg->v);
- camif_hw_close(cfg);
-+ iounmap(camregs);
- //memset(cfg, 0, sizeof(camif_cfg_t));
-+ camregs = NULL;
- }
-
- static void camif_m_out(void) /* module out */
-@@ -547,20 +577,22 @@ static void camif_m_out(void) /* module out */
- unconfig_device(cfg);
- cfg = get_camif(PREVIEW_MINOR);
- unconfig_device(cfg);
-+
- return;
- }
-
- void camif_register_decoder(struct i2c_client *ptr)
- {
- camif_cfg_t *cfg;
-+ void * data = i2c_get_clientdata(ptr);
-
- cfg =get_camif(CODEC_MINOR);
-- cfg->gc = (camif_gc_t *)(ptr->data);
-+ cfg->gc = (camif_gc_t *)(data);
-
- cfg =get_camif(PREVIEW_MINOR);
-- cfg->gc = (camif_gc_t *)(ptr->data);
-+ cfg->gc = (camif_gc_t *)(data);
-
-- sema_init(&cfg->gc->lock,1); /* global lock for both Codec and Preview */
-+ sema_init(&cfg->gc->lock, 1); /* global lock for both Codec and Preview */
- cfg->gc->status |= PNOTWORKING; /* Default Value */
- camif_hw_open(cfg->gc);
- }
-@@ -568,8 +600,9 @@ void camif_register_decoder(struct i2c_client *ptr)
- void camif_unregister_decoder(struct i2c_client *ptr)
- {
- camif_gc_t *gc;
-+ void * data = i2c_get_clientdata(ptr);
-
-- gc = (camif_gc_t *)(ptr->data);
-+ gc = (camif_gc_t *)(data);
- gc->init_sensor = 0; /* need to modify */
- }
-
-diff --git a/arch/arm/mach-s3c2440/camera/videodev.c b/arch/arm/mach-s3c2440/camera/videodev.c
-index 0b3498f..6f862e4 100644
---- a/arch/arm/mach-s3c2440/camera/videodev.c
-+++ b/arch/arm/mach-s3c2440/camera/videodev.c
-@@ -22,7 +22,7 @@
- #include <linux/init.h>
- #include <linux/kmod.h>
- #include <linux/slab.h>
--#include <linux/devfs_fs_kernel.h>
-+/* #include <linux/devfs_fs_kernel.h> */
- #include <linux/miscdevice.h>
- #include <asm/uaccess.h>
- #include <asm/system.h>
-@@ -30,8 +30,9 @@
-
-
-
-+#define CONFIG_VIDEO_V4L1_COMPAT
-+#include <linux/videodev.h>
- #include "camif.h"
--#include "videodev.h"
- #include "miscdevice.h"
-
-
-@@ -42,18 +43,7 @@ const char *fimc_version = "$Id: videodev.c,v 1.1.1.1 2004/04/27 03:52:50 swlee
- #define VIDEO_NAME "video4linux"
-
-
--static inline unsigned iminor(struct inode *inode)
--{
-- return MINOR(inode->i_rdev);
--}
--
--static inline unsigned imajor(struct inode *inode)
--{
-- return MAJOR(inode->i_rdev);
--}
--
--
--#define VIDEO_NUM_DEVICES 2
-+#define VIDEO_NUM_DEVICES 2
- static struct video_device *video_device[VIDEO_NUM_DEVICES];
-
- static inline struct video_device * get_vd(int nr)
-@@ -104,7 +94,7 @@ static int video_open(struct inode *inode, struct file *file)
- int minor = MINOR(inode->i_rdev);
- int err = 0;
- struct video_device *vfl;
-- struct file_operations *old_fops;
-+ struct file_operations const *old_fops;
-
- down(&videodev_lock);
-
-@@ -131,13 +121,13 @@ extern int video_exclusive_open(struct inode *inode, struct file *file)
- struct video_device *vfl = get_vd(MINOR(inode->i_rdev));
- int retval = 0;
-
-- down(&vfl->lock);
-+ mutex_lock(&vfl->lock);
- if (vfl->users) {
- retval = -EBUSY;
- } else {
- vfl->users++;
- }
-- up(&vfl->lock);
-+ mutex_unlock(&vfl->lock);
- return retval;
- }
-
-diff --git a/arch/arm/mach-s3c2440/camera/videodev.h b/arch/arm/mach-s3c2440/camera/videodev.h
-index f12db43..1c2e35a 100644
---- a/arch/arm/mach-s3c2440/camera/videodev.h
-+++ b/arch/arm/mach-s3c2440/camera/videodev.h
-@@ -1,11 +1,11 @@
--#ifndef __LINUX_S3C_VIDEODEV_H
--#define __LINUX_S3C_VIDEODEV_H
-+//#ifndef __LINUX_S3C_VIDEODEV_H
-+//#define __LINUX_S3C_VIDEODEV_H
-
- #include <linux/types.h>
- #include <linux/version.h>
--#include "videodev2.h"
--
-+#include <media/v4l2-dev.h>
-
-+#if 0
- struct video_device
- {
- /* device info */
-@@ -96,12 +96,10 @@ extern int video_usercopy(struct inode *inode, struct file *file,
-
-
-
--#define VID_HARDWARE_SAMSUNG_FIMC 255
--
--
--
--#endif
-+#endif
-+//#endif
-
-+#define VID_HARDWARE_SAMSUNG_FIMC 255
-
- /*
- * Local variables:
---
-1.5.6.3
-