openwrt/target/linux/s3c24xx/patches-2.6.26/1146-uplevel-samsung-camera-unit.patch.patch

1691 lines
55 KiB
Diff
Raw Normal View History

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