camsys_drv : v0.9.0
[firefly-linux-kernel-4.4.55.git] / drivers / media / video / rk29_camera.c
index 3e19731fe08ce3e81200bd6f56d0989c40d035cf..e8cf5d2ecca1bdca7ae26a55c04b441ee18768b3 100755 (executable)
 #include <mach/rk29_camera.h> \r
+#include <mach/iomux.h>\r
 \r
 #ifndef PMEM_CAM_SIZE\r
-#ifdef CONFIG_VIDEO_RK29 \r
-/*---------------- Camera Sensor Fixed Macro Begin  ------------------------*/\r
-// Below Macro is fixed, programer don't change it!!!!!!
-#define _CONS(a,b) a##b
-#define CONS(a,b) _CONS(a,b)\r
-\r
-#define __STR(x) #x
-#define _STR(x) __STR(x)
-#define STR(x) _STR(x)\r
-\r
-#if (CONFIG_SENSOR_IIC_ADDR_0 != 0x00)
-#define PMEM_SENSOR_FULL_RESOLUTION_0  CONS(CONFIG_SENSOR_0,_FULL_RESOLUTION)
-#if !(PMEM_SENSOR_FULL_RESOLUTION_0)
-#undef PMEM_SENSOR_FULL_RESOLUTION_0
-#define PMEM_SENSOR_FULL_RESOLUTION_0  0x500000
-#endif
-#else
-#define PMEM_SENSOR_FULL_RESOLUTION_0  0x00
-#endif
-#if (CONFIG_SENSOR_IIC_ADDR_1 != 0x00)
-#define PMEM_SENSOR_FULL_RESOLUTION_1  CONS(CONFIG_SENSOR_1,_FULL_RESOLUTION)
-#if !(PMEM_SENSOR_FULL_RESOLUTION_1)
-#undef PMEM_SENSOR_FULL_RESOLUTION_1
-#define PMEM_SENSOR_FULL_RESOLUTION_1  0x500000
-#endif
-#else
-#define PMEM_SENSOR_FULL_RESOLUTION_1  0x00
-#endif
-
-#if (PMEM_SENSOR_FULL_RESOLUTION_0 > PMEM_SENSOR_FULL_RESOLUTION_1)
-#define PMEM_CAM_FULL_RESOLUTION   PMEM_SENSOR_FULL_RESOLUTION_0
-#else
-#define PMEM_CAM_FULL_RESOLUTION   PMEM_SENSOR_FULL_RESOLUTION_1
-#endif
-
-#if (PMEM_CAM_FULL_RESOLUTION == 0x500000)
-#define PMEM_CAM_NECESSARY   0x1200000       /* 1280*720*1.5*4(preview) + 7.5M(capture raw) + 4M(jpeg encode output) */\r
-#elif (PMEM_CAM_FULL_RESOLUTION == 0x300000)
-#define PMEM_CAM_NECESSARY   0xe00000        /* 1280*720*1.5*4(preview) + 4.5M(capture raw) + 3M(jpeg encode output) */\r
-#elif (PMEM_CAM_FULL_RESOLUTION == 0x200000) /* 1280*720*1.5*4(preview) + 3M(capture raw) + 3M(jpeg encode output) */\r
-#define PMEM_CAM_NECESSARY   0xc00000\r
-#elif ((PMEM_CAM_FULL_RESOLUTION == 0x100000) || (PMEM_CAM_FULL_RESOLUTION == 0x130000))
-#define PMEM_CAM_NECESSARY   0x800000        /* 800*600*1.5*4(preview) + 2M(capture raw) + 2M(jpeg encode output) */\r
-#elif (PMEM_CAM_FULL_RESOLUTION == 0x30000)\r
-#define PMEM_CAM_NECESSARY   0x400000        /* 640*480*1.5*4(preview) + 1M(capture raw) + 1M(jpeg encode output) */\r
+#include "../../../arch/arm/plat-rk/rk_camera.c"\r
 #else\r
-#define PMEM_CAM_NECESSARY   0x1200000\r
-#endif\r
-/*---------------- Camera Sensor Fixed Macro End  ------------------------*/\r
-#else   //#ifdef CONFIG_VIDEO_RK29 \r
-#define PMEM_CAM_NECESSARY   0x00000000\r
-#endif\r
-#else   // #ifdef PMEM_CAM_SIZE\r
 \r
-/*****************************************************************************************
- * camera  devices
- * author: ddl@rock-chips.com
+/*****************************************************************************************\r
+ * camera  devices\r
+ * author: ddl@rock-chips.com\r
  *****************************************************************************************/\r
 #ifdef CONFIG_VIDEO_RK29 \r
-static int camera_debug;\r
-module_param(camera_debug, int, S_IRUGO|S_IWUSR);\r
-
-#define ddprintk(level, fmt, arg...) do {                      \\r
-       if (camera_debug >= level)                                      \\r
-           printk(KERN_WARNING"rk29_cam_io: " fmt , ## arg); } while (0)\r
+static int rk_sensor_iomux(int pin)\r
+{    \r
+    switch (pin)\r
+    {\r
+        case RK29_PIN0_PA0:        \r
+        case RK29_PIN0_PA1:        \r
+        case RK29_PIN0_PA2:\r
+        case RK29_PIN0_PA3:\r
+        case RK29_PIN0_PA4:\r
+        {\r
+            break;     \r
+        }\r
+        case RK29_PIN0_PA5:\r
+        {\r
+             rk29_mux_api_set(GPIO0A5_FLASHDQS_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN0_PA6:\r
+        {\r
+             rk29_mux_api_set(GPIO0A6_MIIMD_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN0_PA7:\r
+        {\r
+             rk29_mux_api_set(GPIO0A7_MIIMDCLK_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN0_PB0:\r
+        {\r
+             rk29_mux_api_set(GPIO0B0_EBCSDCE0_SMCADDR0_HOSTDATA0_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN0_PB1:\r
+        {\r
+             rk29_mux_api_set(GPIO0B1_EBCSDCE1_SMCADDR1_HOSTDATA1_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN0_PB2:\r
+        {\r
+             rk29_mux_api_set(GPIO0B2_EBCSDCE2_SMCADDR2_HOSTDATA2_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN0_PB3:\r
+        {\r
+             rk29_mux_api_set(GPIO0B3_EBCBORDER0_SMCADDR3_HOSTDATA3_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN0_PB4:\r
+        {\r
+             rk29_mux_api_set(GPIO0B4_EBCBORDER1_SMCWEN_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN0_PB5:\r
+        {\r
+             rk29_mux_api_set(GPIO0B5_EBCVCOM_SMCBLSN0_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN0_PB6:\r
+        {\r
+             rk29_mux_api_set(GPIO0B6_EBCSDSHR_SMCBLSN1_HOSTINT_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN0_PB7:\r
+        {\r
+             rk29_mux_api_set(GPIO0B7_EBCGDOE_SMCOEN_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN0_PC0:\r
+        {\r
+             rk29_mux_api_set(GPIO0C0_EBCGDSP_SMCDATA8_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN0_PC1:\r
+        {\r
+             rk29_mux_api_set(GPIO0C1_EBCGDR1_SMCDATA9_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN0_PC2:\r
+        {\r
+             rk29_mux_api_set(GPIO0C2_EBCSDCE0_SMCDATA10_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN0_PC3:\r
+        {\r
+             rk29_mux_api_set(GPIO0C3_EBCSDCE1_SMCDATA11_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN0_PC4:\r
+        {\r
+             rk29_mux_api_set(GPIO0C4_EBCSDCE2_SMCDATA12_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN0_PC5:\r
+        {\r
+             rk29_mux_api_set(GPIO0C5_EBCSDCE3_SMCDATA13_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN0_PC6:\r
+        {\r
+             rk29_mux_api_set(GPIO0C6_EBCSDCE4_SMCDATA14_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN0_PC7:\r
+        {\r
+             rk29_mux_api_set(GPIO0C7_EBCSDCE5_SMCDATA15_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN0_PD0:\r
+        {\r
+             rk29_mux_api_set(GPIO0D0_EBCSDOE_SMCADVN_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN0_PD1:\r
+        {\r
+             rk29_mux_api_set(GPIO0D1_EBCGDCLK_SMCADDR4_HOSTDATA4_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN0_PD2:\r
+        {\r
+             rk29_mux_api_set(GPIO0D2_FLASHCSN1_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN0_PD3:\r
+        {\r
+             rk29_mux_api_set(GPIO0D3_FLASHCSN2_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN0_PD4:\r
+        {\r
+             rk29_mux_api_set(GPIO0D4_FLASHCSN3_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN0_PD5:\r
+        {\r
+             rk29_mux_api_set(GPIO0D5_FLASHCSN4_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN0_PD6:\r
+        {\r
+             rk29_mux_api_set(GPIO0D6_FLASHCSN5_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN0_PD7:\r
+        {\r
+             rk29_mux_api_set(GPIO0D7_FLASHCSN6_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN1_PA0:\r
+        {\r
+             rk29_mux_api_set(GPIO1A0_FLASHCS7_MDDRTQ_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN1_PA1:\r
+        {\r
+             rk29_mux_api_set(GPIO1A1_SMCCSN0_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN1_PA2:\r
+        {\r
+             rk29_mux_api_set(GPIO1A2_SMCCSN1_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN1_PA3:\r
+        {\r
+             rk29_mux_api_set(GPIO1A3_EMMCDETECTN_SPI1CS1_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN1_PA4:\r
+        {\r
+             rk29_mux_api_set(GPIO1A4_EMMCWRITEPRT_SPI0CS1_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN1_PA5:\r
+        {\r
+             rk29_mux_api_set(GPIO1A5_EMMCPWREN_PWM3_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN1_PA6:\r
+        {\r
+             rk29_mux_api_set(GPIO1A6_I2C1SDA_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN1_PA7:\r
+        {\r
+             rk29_mux_api_set(GPIO1A7_I2C1SCL_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN1_PB0:\r
+        {\r
+             rk29_mux_api_set(GPIO1B0_VIPDATA0_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN1_PB1:\r
+        {\r
+             rk29_mux_api_set(GPIO1B1_VIPDATA1_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN1_PB2:\r
+        {\r
+             rk29_mux_api_set(GPIO1B2_VIPDATA2_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN1_PB3:\r
+        {\r
+             rk29_mux_api_set(GPIO1B3_VIPDATA3_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN1_PB4:\r
+        {\r
+             rk29_mux_api_set(GPIO1B4_VIPCLKOUT_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN1_PB5:\r
+        {\r
+             rk29_mux_api_set(GPIO1B5_PWM0_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN1_PB6:\r
+        {\r
+             rk29_mux_api_set(GPIO1B6_UART0SIN_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN1_PB7:\r
+        {\r
+             rk29_mux_api_set(GPIO1B7_UART0SOUT_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN1_PC0:\r
+        {\r
+             rk29_mux_api_set(GPIO1C0_UART0CTSN_SDMMC1DETECTN_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN1_PC1:\r
+        {\r
+             rk29_mux_api_set(GPIO1C1_UART0RTSN_SDMMC1WRITEPRT_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN1_PC2:\r
+        {\r
+             rk29_mux_api_set(GPIO1C2_SDMMC1CMD_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN1_PC3:\r
+        {\r
+             rk29_mux_api_set(GPIO1C3_SDMMC1DATA0_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN1_PC4:\r
+        {\r
+             rk29_mux_api_set(GPIO1C4_SDMMC1DATA1_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN1_PC5:\r
+        {\r
+             rk29_mux_api_set(GPIO1C5_SDMMC1DATA2_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN1_PC6:\r
+        {\r
+             rk29_mux_api_set(GPIO1C6_SDMMC1DATA3_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN1_PC7:\r
+        {\r
+             rk29_mux_api_set(GPIO1C7_SDMMC1CLKOUT_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN1_PD0:\r
+        {\r
+             rk29_mux_api_set(GPIO1D0_SDMMC0CLKOUT_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN1_PD1:\r
+        {\r
+             rk29_mux_api_set(GPIO1D1_SDMMC0CMD_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN1_PD2:\r
+        {\r
+             rk29_mux_api_set(GPIO1D2_SDMMC0DATA0_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN1_PD3:\r
+        {\r
+             rk29_mux_api_set(GPIO1D3_SDMMC0DATA1_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN1_PD4:\r
+        {\r
+             rk29_mux_api_set(GPIO1D4_SDMMC0DATA2_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN1_PD5:\r
+        {\r
+             rk29_mux_api_set(GPIO1D5_SDMMC0DATA3_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN1_PD6:\r
+        {\r
+             rk29_mux_api_set(GPIO1D6_SDMMC0DATA4_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN1_PD7:\r
+        {\r
+             rk29_mux_api_set(GPIO1D7_SDMMC0DATA5_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN2_PA0:\r
+        {\r
+             rk29_mux_api_set(GPIO2A0_SDMMC0DATA6_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN2_PA1:\r
+        {\r
+             rk29_mux_api_set(GPIO2A1_SDMMC0DATA7_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN2_PA2:\r
+        {\r
+             rk29_mux_api_set(GPIO2A2_SDMMC0DETECTN_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN2_PA3:\r
+        {\r
+             rk29_mux_api_set(GPIO2A3_SDMMC0WRITEPRT_PWM2_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN2_PA4:\r
+        {\r
+             rk29_mux_api_set(GPIO2A4_UART1SIN_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN2_PA5:\r
+        {\r
+             rk29_mux_api_set(GPIO2A5_UART1SOUT_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN2_PA6:\r
+        {\r
+             rk29_mux_api_set(GPIO2A6_UART2CTSN_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN2_PA7:\r
+        {\r
+             rk29_mux_api_set(GPIO2A7_UART2RTSN_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN2_PB0:\r
+        {\r
+             rk29_mux_api_set(GPIO2B0_UART2SIN_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN2_PB1:\r
+        {\r
+             rk29_mux_api_set(GPIO2B1_UART2SOUT_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN2_PB2:\r
+        {\r
+             rk29_mux_api_set(GPIO2B2_UART3SIN_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN2_PB3:\r
+        {\r
+             rk29_mux_api_set(GPIO2B3_UART3SOUT_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN2_PB4:\r
+        {\r
+             rk29_mux_api_set(GPIO2B4_UART3CTSN_I2C3SDA_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN2_PB5:\r
+        {\r
+             rk29_mux_api_set(GPIO2B5_UART3RTSN_I2C3SCL_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN2_PB6:\r
+        {\r
+             rk29_mux_api_set(GPIO2B6_I2C0SDA_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN2_PB7:\r
+        {\r
+             rk29_mux_api_set(GPIO2B7_I2C0SCL_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN2_PC0:\r
+        {\r
+             rk29_mux_api_set(GPIO2C0_SPI0CLK_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN2_PC1:\r
+        {\r
+             rk29_mux_api_set(GPIO2C1_SPI0CSN0_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN2_PC2:\r
+        {\r
+             rk29_mux_api_set(GPIO2C2_SPI0TXD_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN2_PC3:\r
+        {\r
+             rk29_mux_api_set(GPIO2C3_SPI0RXD_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN2_PC4:\r
+        {\r
+             rk29_mux_api_set(GPIO2C4_SPI1CLK_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN2_PC5:\r
+        {\r
+             rk29_mux_api_set(GPIO2C5_SPI1CSN0_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN2_PC6:\r
+        {\r
+             rk29_mux_api_set(GPIO2C6_SPI1TXD_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN2_PC7:\r
+        {\r
+             rk29_mux_api_set(GPIO2C7_SPI1RXD_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN2_PD0:\r
+        {\r
+             rk29_mux_api_set(GPIO2D0_I2S0CLK_MIIRXCLKIN_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN2_PD1:\r
+        {\r
+             rk29_mux_api_set(GPIO2D1_I2S0SCLK_MIICRS_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN2_PD2:\r
+        {\r
+             rk29_mux_api_set(GPIO2D2_I2S0LRCKRX_MIITXERR_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN2_PD3:\r
+        {\r
+             rk29_mux_api_set(GPIO2D3_I2S0SDI_MIICOL_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN2_PD4:\r
+        {\r
+             rk29_mux_api_set(GPIO2D4_I2S0SDO0_MIIRXD2_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN2_PD5:\r
+        {\r
+             rk29_mux_api_set(GPIO2D5_I2S0SDO1_MIIRXD3_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN2_PD6:\r
+        {\r
+             rk29_mux_api_set(GPIO2D6_I2S0SDO2_MIITXD2_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN2_PD7:\r
+        {\r
+             rk29_mux_api_set(GPIO2D7_I2S0SDO3_MIITXD3_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN3_PA0:\r
+        {\r
+             rk29_mux_api_set(GPIO3A0_I2S1CLK_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN3_PA1:\r
+        {\r
+             rk29_mux_api_set(GPIO3A1_I2S1SCLK_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN3_PA2:\r
+        {\r
+             rk29_mux_api_set(GPIO3A2_I2S1LRCKRX_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN3_PA3:\r
+        {\r
+             rk29_mux_api_set(GPIO3A3_I2S1SDI_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN3_PA4:\r
+        {\r
+             rk29_mux_api_set(GPIO3A4_I2S1SDO_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN3_PA5:\r
+        {\r
+             rk29_mux_api_set(GPIO3A5_I2S1LRCKTX_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN3_PA6:\r
+        {\r
+             rk29_mux_api_set(GPIO3A6_SMCADDR14_HOSTDATA14_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN3_PA7:\r
+        {\r
+             rk29_mux_api_set(GPIO3A7_SMCADDR15_HOSTDATA15_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN3_PB0:\r
+        {\r
+             rk29_mux_api_set(GPIO3B0_EMMCLKOUT_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN3_PB1:\r
+        {\r
+             rk29_mux_api_set(GPIO3B1_EMMCMD_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN3_PB2:\r
+        {\r
+             rk29_mux_api_set(GPIO3B2_EMMCDATA0_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN3_PB3:\r
+        {\r
+             rk29_mux_api_set(GPIO3B3_EMMCDATA1_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN3_PB4:\r
+        {\r
+             rk29_mux_api_set(GPIO3B4_EMMCDATA2_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN3_PB5:\r
+        {\r
+             rk29_mux_api_set(GPIO3B5_EMMCDATA3_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN3_PB6:\r
+        {\r
+             rk29_mux_api_set(GPIO3B6_EMMCDATA4_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN3_PB7:\r
+        {\r
+             rk29_mux_api_set(GPIO3B7_EMMCDATA5_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN3_PC0:\r
+        {\r
+             rk29_mux_api_set(GPIO3C0_EMMCDATA6_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN3_PC1:\r
+        {\r
+             rk29_mux_api_set(GPIO3C1_EMMCDATA7_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN3_PC2:\r
+        {\r
+             rk29_mux_api_set(GPIO3C2_SMCADDR13_HOSTDATA13_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN3_PC3:\r
+        {\r
+             rk29_mux_api_set(GPIO3C3_SMCADDR10_HOSTDATA10_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN3_PC4:\r
+        {\r
+             rk29_mux_api_set(GPIO3C4_SMCADDR11_HOSTDATA11_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN3_PC5:\r
+        {\r
+             rk29_mux_api_set(GPIO3C5_SMCADDR12_HOSTDATA12_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN3_PC6:\r
+        {\r
+             rk29_mux_api_set(GPIO3C6_SMCADDR16_HOSTDATA16_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN3_PC7:\r
+        {\r
+             rk29_mux_api_set(GPIO3C7_SMCADDR17_HOSTDATA17_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN3_PD0:\r
+        {\r
+             rk29_mux_api_set(GPIO3D0_SMCADDR18_HOSTADDR0_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN3_PD1:\r
+        {\r
+             rk29_mux_api_set(GPIO3D1_SMCADDR19_HOSTADDR1_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN3_PD2:\r
+        {\r
+             rk29_mux_api_set(GPIO3D2_HOSTCSN_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN3_PD3:\r
+        {\r
+             rk29_mux_api_set(GPIO3D3_HOSTRDN_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN3_PD4:\r
+        {\r
+             rk29_mux_api_set(GPIO3D4_HOSTWRN_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN3_PD5:\r
+        {\r
+             rk29_mux_api_set(GPIO3D5_SMCADDR7_HOSTDATA7_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN3_PD6:\r
+        {\r
+             rk29_mux_api_set(GPIO3D6_SMCADDR8_HOSTDATA8_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN3_PD7:\r
+        {\r
+             rk29_mux_api_set(GPIO3D7_SMCADDR9_HOSTDATA9_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN4_PA0:\r
+        case RK29_PIN4_PA1:\r
+        case RK29_PIN4_PA2:\r
+        case RK29_PIN4_PA3:\r
+        case RK29_PIN4_PA4:\r
+        {            \r
+            break;     \r
+        }\r
+        case RK29_PIN4_PA5:\r
+        {\r
+             rk29_mux_api_set(GPIO4A5_OTG0DRVVBUS_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN4_PA6:\r
+        {\r
+             rk29_mux_api_set(GPIO4A6_OTG1DRVVBUS_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN4_PA7:\r
+        {\r
+             rk29_mux_api_set(GPIO4A7_SPDIFTX_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN4_PB0:\r
+        {\r
+             rk29_mux_api_set(GPIO4B0_FLASHDATA8_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN4_PB1:\r
+        {\r
+             rk29_mux_api_set(GPIO4B1_FLASHDATA9_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN4_PB2:\r
+        {\r
+             rk29_mux_api_set(GPIO4B2_FLASHDATA10_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN4_PB3:\r
+        {\r
+             rk29_mux_api_set(GPIO4B3_FLASHDATA11_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN4_PB4:\r
+        {\r
+             rk29_mux_api_set(GPIO4B4_FLASHDATA12_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN4_PB5:\r
+        {\r
+             rk29_mux_api_set(GPIO4B5_FLASHDATA13_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN4_PB6:\r
+        {\r
+             rk29_mux_api_set(GPIO4B6_FLASHDATA14_NAME ,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN4_PB7:\r
+        {\r
+             rk29_mux_api_set(GPIO4B7_FLASHDATA15_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN4_PC0:\r
+        {\r
+             rk29_mux_api_set(GPIO4C0_RMIICLKOUT_RMIICLKIN_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN4_PC1:\r
+        {\r
+             rk29_mux_api_set(GPIO4C1_RMIITXEN_MIITXEN_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN4_PC2:\r
+        {\r
+             rk29_mux_api_set(GPIO4C2_RMIITXD1_MIITXD1_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN4_PC3:\r
+        {\r
+             rk29_mux_api_set(GPIO4C3_RMIITXD0_MIITXD0_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN4_PC4:\r
+        {\r
+             rk29_mux_api_set(GPIO4C4_RMIIRXERR_MIIRXERR_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN4_PC5:\r
+        {\r
+             rk29_mux_api_set(GPIO4C5_RMIICSRDVALID_MIIRXDVALID_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN4_PC6:\r
+        {\r
+             rk29_mux_api_set(GPIO4C6_RMIIRXD1_MIIRXD1_NAME,0);\r
+            break;     \r
+        }\r
 \r
-#define dprintk(format, ...) ddprintk(1, format, ## __VA_ARGS__)    \r
+        case RK29_PIN4_PC7:\r
+        {\r
+             rk29_mux_api_set(GPIO4C7_RMIIRXD0_MIIRXD0_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN4_PD0:\r
+        case RK29_PIN4_PD1:\r
+        {\r
+             rk29_mux_api_set(GPIO4D10_CPUTRACEDATA10_NAME,0);             \r
+            break;     \r
+        }\r
+        case RK29_PIN4_PD2:\r
+        case RK29_PIN4_PD3:\r
+        {\r
+             rk29_mux_api_set(GPIO4D32_CPUTRACEDATA32_NAME,0);           \r
+            break;     \r
+        }\r
+        case RK29_PIN4_PD4:\r
+        {\r
+             rk29_mux_api_set(GPIO4D4_CPUTRACECLK_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN4_PD5:\r
+        {\r
+             rk29_mux_api_set(GPIO4D5_CPUTRACECTL_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN4_PD6:\r
+        {\r
+             rk29_mux_api_set(GPIO4D6_I2S0LRCKTX0_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN4_PD7:\r
+        {\r
+             rk29_mux_api_set(GPIO4D7_I2S0LRCKTX1_NAME,0);\r
+            break;     \r
+        } \r
+        case RK29_PIN5_PA0:\r
+        case RK29_PIN5_PA1:\r
+        case RK29_PIN5_PA2:\r
+        {      \r
+            break;     \r
+        }\r
+        case RK29_PIN5_PA3:\r
+        {\r
+             rk29_mux_api_set(GPIO5A3_MIITXCLKIN_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN5_PA4:\r
+        {\r
+             rk29_mux_api_set(GPIO5A4_TSSYNC_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN5_PA5:\r
+        {\r
+             rk29_mux_api_set(GPIO5A5_HSADCDATA0_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN5_PA6:\r
+        {\r
+             rk29_mux_api_set(GPIO5A6_HSADCDATA1_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN5_PA7:\r
+        {\r
+             rk29_mux_api_set(GPIO5A7_HSADCDATA2_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN5_PB0:\r
+        {\r
+             rk29_mux_api_set(GPIO5B0_HSADCDATA3_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN5_PB1:\r
+        {\r
+             rk29_mux_api_set(GPIO5B1_HSADCDATA4_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN5_PB2:\r
+        {\r
+             rk29_mux_api_set(GPIO5B2_HSADCDATA5_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN5_PB3:\r
+        {\r
+             rk29_mux_api_set(GPIO5B3_HSADCDATA6_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN5_PB4:\r
+        {\r
+             rk29_mux_api_set(GPIO5B4_HSADCDATA7_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN5_PB5:\r
+        {\r
+             rk29_mux_api_set(GPIO5B5_HSADCDATA8_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN5_PB6:\r
+        {\r
+             rk29_mux_api_set(GPIO5B6_HSADCDATA9_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN5_PB7:\r
+        {\r
+             rk29_mux_api_set(GPIO5B7_HSADCCLKOUTGPSCLK_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN5_PC0:\r
+        {\r
+             rk29_mux_api_set(GPIO5C0_EBCSDDO0_SMCDATA0_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN5_PC1:\r
+        {\r
+             rk29_mux_api_set(GPIO5C1_EBCSDDO1_SMCDATA1_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN5_PC2:\r
+        {\r
+             rk29_mux_api_set(GPIO5C2_EBCSDDO2_SMCDATA2_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN5_PC3:\r
+        {\r
+             rk29_mux_api_set(GPIO5C3_EBCSDDO3_SMCDATA3_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN5_PC4:\r
+        {\r
+             rk29_mux_api_set(GPIO5C4_EBCSDDO4_SMCDATA4_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN5_PC5:\r
+        {\r
+             rk29_mux_api_set(GPIO5C5_EBCSDDO5_SMCDATA5_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN5_PC6:\r
+        {\r
+             rk29_mux_api_set(GPIO5C6_EBCSDDO6_SMCDATA6_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN5_PC7:\r
+        {\r
+             rk29_mux_api_set(GPIO5C7_EBCSDDO7_SMCDATA7_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN5_PD0:\r
+        {\r
+             rk29_mux_api_set(GPIO5D0_EBCSDLE_SMCADDR5_HOSTDATA5_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN5_PD1:\r
+        {\r
+             rk29_mux_api_set(GPIO5D1_EBCSDCLK_SMCADDR6_HOSTDATA6_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN5_PD2:\r
+        {\r
+             rk29_mux_api_set(GPIO5D2_PWM1_UART1SIRIN_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN5_PD3:\r
+        {\r
+             rk29_mux_api_set(GPIO5D3_I2C2SDA_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN5_PD4:\r
+        {\r
+             rk29_mux_api_set(GPIO5D4_I2C2SCL_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN5_PD5:\r
+        {\r
+             rk29_mux_api_set(GPIO5D5_SDMMC0PWREN_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN5_PD6:\r
+        {\r
+             rk29_mux_api_set(GPIO5D6_SDMMC1PWREN_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN5_PD7:\r
+        case RK29_PIN6_PA0:\r
+        case RK29_PIN6_PA1:\r
+        case RK29_PIN6_PA2:\r
+        case RK29_PIN6_PA3:\r
+        case RK29_PIN6_PA4:\r
+        case RK29_PIN6_PA5:\r
+        case RK29_PIN6_PA6:\r
+        case RK29_PIN6_PA7:\r
+        case RK29_PIN6_PB0:\r
+        case RK29_PIN6_PB1:\r
+        case RK29_PIN6_PB2:\r
+        case RK29_PIN6_PB3:\r
+        case RK29_PIN6_PB4:\r
+        case RK29_PIN6_PB5:\r
+        case RK29_PIN6_PB6:\r
+        case RK29_PIN6_PB7:\r
+        case RK29_PIN6_PC0:\r
+        case RK29_PIN6_PC1:\r
+        case RK29_PIN6_PC2:\r
+        case RK29_PIN6_PC3:\r
+        {\r
+            break;\r
+        }\r
+        case RK29_PIN6_PC4:\r
+        case RK29_PIN6_PC5:\r
+        {\r
+             rk29_mux_api_set(GPIO6C54_CPUTRACEDATA54_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN6_PC6:\r
+        case RK29_PIN6_PC7:\r
+        {\r
+             rk29_mux_api_set(GPIO6C76_CPUTRACEDATA76_NAME,0);\r
+            break;     \r
+        }\r
+        case RK29_PIN6_PD0:\r
+        case RK29_PIN6_PD1:\r
+        case RK29_PIN6_PD2:\r
+        case RK29_PIN6_PD3:\r
+        case RK29_PIN6_PD4:\r
+        case RK29_PIN6_PD5:\r
+        case RK29_PIN6_PD6:\r
+        case RK29_PIN6_PD7:\r
+        {\r
+            break;     \r
+        }    \r
+        default:\r
+        {\r
+            printk("Pin=%d isn't RK29 GPIO, Please init it's iomux yourself!",pin);\r
+            break;\r
+        }\r
+    }\r
+    return 0;\r
+}\r
+#include "../../../arch/arm/plat-rk/rk_camera.c"\r
 \r
-#define SENSOR_NAME_0 STR(CONFIG_SENSOR_0)                     /* back camera sensor */
-#define SENSOR_NAME_1 STR(CONFIG_SENSOR_1)                     /* front camera sensor */
-#define SENSOR_DEVICE_NAME_0  STR(CONS(CONFIG_SENSOR_0, _back))
-#define SENSOR_DEVICE_NAME_1  STR(CONS(CONFIG_SENSOR_1, _front))
-
-static int rk29_sensor_io_init(void);
-static int rk29_sensor_io_deinit(int sensor);
-static int rk29_sensor_ioctrl(struct device *dev,enum rk29camera_ioctrl_cmd cmd,int on);
-
-static struct rk29camera_platform_data rk29_camera_platform_data = {\r
-    .io_init = rk29_sensor_io_init,
-    .io_deinit = rk29_sensor_io_deinit,
-    .sensor_ioctrl = rk29_sensor_ioctrl,
-    .gpio_res = {
-        {
-            .gpio_reset = CONFIG_SENSOR_RESET_PIN_0,
-            .gpio_power = CONFIG_SENSOR_POWER_PIN_0,
-            .gpio_powerdown = CONFIG_SENSOR_POWERDN_PIN_0,
-            .gpio_flash = CONFIG_SENSOR_FALSH_PIN_0,
-            .gpio_flag = (CONFIG_SENSOR_POWERACTIVE_LEVEL_0|CONFIG_SENSOR_RESETACTIVE_LEVEL_0|CONFIG_SENSOR_POWERDNACTIVE_LEVEL_0|CONFIG_SENSOR_FLASHACTIVE_LEVEL_0),
-            .gpio_init = 0,
-            .dev_name = SENSOR_DEVICE_NAME_0,
-        }, {
-            .gpio_reset = CONFIG_SENSOR_RESET_PIN_1,
-            .gpio_power = CONFIG_SENSOR_POWER_PIN_1,
-            .gpio_powerdown = CONFIG_SENSOR_POWERDN_PIN_1,
-            .gpio_flash = CONFIG_SENSOR_FALSH_PIN_1,
-            .gpio_flag = (CONFIG_SENSOR_POWERACTIVE_LEVEL_1|CONFIG_SENSOR_RESETACTIVE_LEVEL_1|CONFIG_SENSOR_POWERDNACTIVE_LEVEL_1|CONFIG_SENSOR_FLASHACTIVE_LEVEL_1),
-            .gpio_init = 0,
-            .dev_name = SENSOR_DEVICE_NAME_1,
-        }
-    },
-       #ifdef CONFIG_VIDEO_RK29_WORK_IPP
-       .meminfo = {
-           .name  = "camera_ipp_mem",
-               .start = MEM_CAMIPP_BASE,
-               .size   = MEM_CAMIPP_SIZE,
-       }
-       #endif
+#if (CONFIG_SENSOR_IIC_ADDR_0 != 0x00)\r
+static struct i2c_board_info rk29_i2c_cam_info_0[] = {\r
+       {\r
+               I2C_BOARD_INFO(SENSOR_NAME_0, CONFIG_SENSOR_IIC_ADDR_0>>1)\r
+       },\r
 };\r
 \r
-
-\r
-static int sensor_power_default_cb (struct rk29camera_gpio_res *res, int on)\r
-{\r
-    int camera_power = res->gpio_power;\r
-    int camera_ioflag = res->gpio_flag;\r
-    int camera_io_init = res->gpio_init;\r
-    int ret = 0;\r
-    \r
-    if (camera_power != INVALID_GPIO)  {\r
-        if (camera_io_init & RK29_CAM_POWERACTIVE_MASK) {\r
-            if (on) {\r
-               gpio_set_value(camera_power, ((camera_ioflag&RK29_CAM_POWERACTIVE_MASK)>>RK29_CAM_POWERACTIVE_BITPOS));\r
-                       dprintk("\n%s..%s..PowerPin=%d ..PinLevel = %x   \n",__FUNCTION__,res->dev_name, camera_power, ((camera_ioflag&RK29_CAM_POWERACTIVE_MASK)>>RK29_CAM_POWERACTIVE_BITPOS));\r
-                       msleep(10);\r
-               } else {\r
-                       gpio_set_value(camera_power, (((~camera_ioflag)&RK29_CAM_POWERACTIVE_MASK)>>RK29_CAM_POWERACTIVE_BITPOS));\r
-                       dprintk("\n%s..%s..PowerPin=%d ..PinLevel = %x   \n",__FUNCTION__,res->dev_name, camera_power, (((~camera_ioflag)&RK29_CAM_POWERACTIVE_MASK)>>RK29_CAM_POWERACTIVE_BITPOS));\r
-               }\r
-               } else {\r
-                       ret = RK29_CAM_EIO_REQUESTFAIL;\r
-                       printk("\n%s..%s..PowerPin=%d request failed!\n",__FUNCTION__,res->dev_name,camera_power);\r
-           }        \r
-    } else {\r
-               ret = RK29_CAM_EIO_INVALID;\r
-    } \r
+static struct soc_camera_link rk29_iclink_0 = {\r
+       .bus_id         = RK29_CAM_PLATFORM_DEV_ID,\r
+       .power          = rk_sensor_power,\r
+#if (CONFIG_SENSOR_RESET_PIN_0 != INVALID_GPIO)\r
+    .reset      = rk_sensor_reset,\r
+#endif    \r
+       .powerdown  = rk_sensor_powerdown,\r
+       .board_info     = &rk29_i2c_cam_info_0[0],\r
+       .i2c_adapter_id = CONFIG_SENSOR_IIC_ADAPTER_ID_0,\r
+       .module_name    = SENSOR_NAME_0,\r
+};\r
 \r
-    return ret;\r
-}\r
+/*platform_device : soc-camera need  */\r
+static struct platform_device rk29_soc_camera_pdrv_0 = {\r
+       .name   = "soc-camera-pdrv",\r
+       .id     = 0,\r
+       .dev    = {\r
+               .init_name = SENSOR_DEVICE_NAME_0,\r
+               .platform_data = &rk29_iclink_0,\r
+       },\r
+};\r
+#endif\r
+#if (CONFIG_SENSOR_IIC_ADDR_1 != 0x00)\r
+static struct i2c_board_info rk29_i2c_cam_info_1[] = {\r
+       {\r
+               I2C_BOARD_INFO(SENSOR_NAME_1, CONFIG_SENSOR_IIC_ADDR_1>>1)\r
+       },\r
+};\r
 \r
-static int sensor_reset_default_cb (struct rk29camera_gpio_res *res, int on)\r
-{
-    int camera_reset = res->gpio_reset;\r
-    int camera_ioflag = res->gpio_flag;\r
-    int camera_io_init = res->gpio_init;  \r
-    int ret = 0;\r
-    \r
-    if (camera_reset != INVALID_GPIO) {\r
-               if (camera_io_init & RK29_CAM_RESETACTIVE_MASK) {\r
-                       if (on) {\r
-                       gpio_set_value(camera_reset, ((camera_ioflag&RK29_CAM_RESETACTIVE_MASK)>>RK29_CAM_RESETACTIVE_BITPOS));\r
-                       dprintk("\n%s..%s..ResetPin=%d ..PinLevel = %x \n",__FUNCTION__,res->dev_name,camera_reset, ((camera_ioflag&RK29_CAM_RESETACTIVE_MASK)>>RK29_CAM_RESETACTIVE_BITPOS));\r
-                       } else {\r
-                               gpio_set_value(camera_reset,(((~camera_ioflag)&RK29_CAM_RESETACTIVE_MASK)>>RK29_CAM_RESETACTIVE_BITPOS));\r
-                       dprintk("\n%s..%s..ResetPin= %d..PinLevel = %x   \n",__FUNCTION__,res->dev_name, camera_reset, (((~camera_ioflag)&RK29_CAM_RESETACTIVE_MASK)>>RK29_CAM_RESETACTIVE_BITPOS));\r
-               }\r
-               } else {\r
-                       ret = RK29_CAM_EIO_REQUESTFAIL;\r
-                       printk("\n%s..%s..ResetPin=%d request failed!\n",__FUNCTION__,res->dev_name,camera_reset);\r
-               }\r
-    } else {\r
-               ret = RK29_CAM_EIO_INVALID;\r
-    }\r
+static struct soc_camera_link rk29_iclink_1 = {\r
+       .bus_id         = RK29_CAM_PLATFORM_DEV_ID,\r
+       .power          = rk_sensor_power,\r
+#if (CONFIG_SENSOR_RESET_PIN_1 != INVALID_GPIO)\r
+    .reset      = rk_sensor_reset,\r
+#endif         \r
+       .powerdown  = rk_sensor_powerdown,\r
+       .board_info     = &rk29_i2c_cam_info_1[0],\r
+       .i2c_adapter_id = CONFIG_SENSOR_IIC_ADAPTER_ID_1,\r
+       .module_name    = SENSOR_NAME_1,\r
+};\r
 \r
-    return ret;\r
-}
+/*platform_device : soc-camera need  */\r
+static struct platform_device rk29_soc_camera_pdrv_1 = {\r
+       .name   = "soc-camera-pdrv",\r
+       .id     = 1,\r
+       .dev    = {\r
+               .init_name = SENSOR_DEVICE_NAME_1,\r
+               .platform_data = &rk29_iclink_1,\r
+       },\r
+};\r
+#endif\r
 \r
-static int sensor_powerdown_default_cb (struct rk29camera_gpio_res *res, int on)\r
-{
-    int camera_powerdown = res->gpio_powerdown;\r
-    int camera_ioflag = res->gpio_flag;\r
-    int camera_io_init = res->gpio_init;  \r
-    int ret = 0;    \r
+static u64 rockchip_device_camera_dmamask = 0xffffffffUL;\r
+static struct resource rk29_camera_resource[] = {\r
+       [0] = {\r
+               .start = RK29_VIP_PHYS,\r
+               .end   = RK29_VIP_PHYS + RK29_VIP_SIZE - 1,\r
+               .flags = IORESOURCE_MEM,\r
+       },\r
+       [1] = {\r
+               .start = IRQ_VIP,\r
+               .end   = IRQ_VIP,\r
+               .flags = IORESOURCE_IRQ,\r
+       }\r
+};\r
 \r
-    if (camera_powerdown != INVALID_GPIO) {\r
-               if (camera_io_init & RK29_CAM_POWERDNACTIVE_MASK) {\r
-                       if (on) {\r
-                       gpio_set_value(camera_powerdown, ((camera_ioflag&RK29_CAM_POWERDNACTIVE_MASK)>>RK29_CAM_POWERDNACTIVE_BITPOS));\r
-                       dprintk("\n%s..%s..PowerDownPin=%d ..PinLevel = %x \n",__FUNCTION__,res->dev_name,camera_powerdown, ((camera_ioflag&RK29_CAM_POWERDNACTIVE_MASK)>>RK29_CAM_POWERDNACTIVE_BITPOS));\r
-                       } else {\r
-                               gpio_set_value(camera_powerdown,(((~camera_ioflag)&RK29_CAM_POWERDNACTIVE_MASK)>>RK29_CAM_POWERDNACTIVE_BITPOS));\r
-                       dprintk("\n%s..%s..PowerDownPin= %d..PinLevel = %x   \n",__FUNCTION__,res->dev_name, camera_powerdown, (((~camera_ioflag)&RK29_CAM_POWERDNACTIVE_MASK)>>RK29_CAM_POWERDNACTIVE_BITPOS));\r
-               }\r
-               } else {\r
-                       ret = RK29_CAM_EIO_REQUESTFAIL;\r
-                       dprintk("\n%s..%s..PowerDownPin=%d request failed!\n",__FUNCTION__,res->dev_name,camera_powerdown);\r
-               }\r
-    } else {\r
-               ret = RK29_CAM_EIO_INVALID;\r
-    }\r
-    return ret;\r
-}
+/*platform_device : */\r
+static struct platform_device rk29_device_camera = {\r
+       .name             = RK29_CAM_DRV_NAME,\r
+       .id               = RK29_CAM_PLATFORM_DEV_ID,               /* This is used to put cameras on this interface */\r
+       .num_resources    = ARRAY_SIZE(rk29_camera_resource),\r
+       .resource         = rk29_camera_resource,\r
+       .dev            = {\r
+               .dma_mask = &rockchip_device_camera_dmamask,\r
+               .coherent_dma_mask = 0xffffffffUL,\r
+               .platform_data  = &rk_camera_platform_data,\r
+       }\r
+};\r
 \r
-
-static int sensor_flash_default_cb (struct rk29camera_gpio_res *res, int on)\r
+static void rk_init_camera_plateform_data(void)\r
 {\r
-    int camera_flash = res->gpio_flash;\r
-    int camera_ioflag = res->gpio_flag;\r
-    int camera_io_init = res->gpio_init;  \r
-    int ret = 0;    \r
-\r
-    if (camera_flash != INVALID_GPIO) {\r
-               if (camera_io_init & RK29_CAM_FLASHACTIVE_MASK) {\r
-            switch (on)\r
-            {\r
-                case Flash_Off:\r
-                {\r
-                    gpio_set_value(camera_flash,(((~camera_ioflag)&RK29_CAM_FLASHACTIVE_MASK)>>RK29_CAM_FLASHACTIVE_BITPOS));\r
-                           dprintk("\n%s..%s..FlashPin= %d..PinLevel = %x   \n",__FUNCTION__,res->dev_name, camera_flash, (((~camera_ioflag)&RK29_CAM_FLASHACTIVE_MASK)>>RK29_CAM_FLASHACTIVE_BITPOS)); \r
-                           break;\r
-                }\r
-\r
-                case Flash_On:\r
-                {\r
-                    gpio_set_value(camera_flash, ((camera_ioflag&RK29_CAM_FLASHACTIVE_MASK)>>RK29_CAM_FLASHACTIVE_BITPOS));\r
-                           dprintk("\n%s..%s..FlashPin=%d ..PinLevel = %x \n",__FUNCTION__,res->dev_name,camera_flash, ((camera_ioflag&RK29_CAM_FLASHACTIVE_MASK)>>RK29_CAM_FLASHACTIVE_BITPOS));\r
-                           break;\r
-                }\r
-\r
-                case Flash_Torch:\r
-                {\r
-                    gpio_set_value(camera_flash, ((camera_ioflag&RK29_CAM_FLASHACTIVE_MASK)>>RK29_CAM_FLASHACTIVE_BITPOS));\r
-                           dprintk("\n%s..%s..FlashPin=%d ..PinLevel = %x \n",__FUNCTION__,res->dev_name,camera_flash, ((camera_ioflag&RK29_CAM_FLASHACTIVE_MASK)>>RK29_CAM_FLASHACTIVE_BITPOS));\r
-                           break;\r
-                }\r
-\r
-                default:\r
-                {\r
-                    printk("\n%s..%s..Flash command(%d) is invalidate \n",__FUNCTION__,res->dev_name,on);\r
-                    break;\r
-                }\r
-            }\r
-               } else {\r
-                       ret = RK29_CAM_EIO_REQUESTFAIL;\r
-                       printk("\n%s..%s..FlashPin=%d request failed!\n",__FUNCTION__,res->dev_name,camera_flash);\r
-               }\r
-    } else {\r
-               ret = RK29_CAM_EIO_INVALID;\r
+    int i,dev_idx;\r
+    \r
+    dev_idx = 0;\r
+    for (i=0; i<RK_CAM_NUM; i++) {\r
+        if (rk_camera_platform_data.register_dev[i].device_info.name) {            \r
+            rk_camera_platform_data.register_dev[i].link_info.board_info = \r
+                &rk_camera_platform_data.register_dev[i].i2c_cam_info;\r
+            rk_camera_platform_data.register_dev[i].device_info.id = dev_idx;\r
+            rk_camera_platform_data.register_dev[i].device_info.dev.platform_data = \r
+                &rk_camera_platform_data.register_dev[i].link_info;\r
+            dev_idx++;\r
+        }\r
     }\r
-    return ret;\r
 }\r
 \r
-
-static int rk29_sensor_io_init(void)
-{
-    int ret = 0, i;
-    unsigned int camera_reset = INVALID_GPIO, camera_power = INVALID_GPIO;
-       unsigned int camera_powerdown = INVALID_GPIO, camera_flash = INVALID_GPIO;
-       unsigned int camera_ioflag;
-\r
-    if (sensor_ioctl_cb.sensor_power_cb == NULL)\r
-        sensor_ioctl_cb.sensor_power_cb = sensor_power_default_cb;\r
-    if (sensor_ioctl_cb.sensor_reset_cb == NULL)\r
-        sensor_ioctl_cb.sensor_reset_cb = sensor_reset_default_cb;\r
-    if (sensor_ioctl_cb.sensor_powerdown_cb == NULL)\r
-        sensor_ioctl_cb.sensor_powerdown_cb = sensor_powerdown_default_cb;\r
-    if (sensor_ioctl_cb.sensor_flash_cb == NULL)\r
-        sensor_ioctl_cb.sensor_flash_cb = sensor_flash_default_cb;\r
+static int rk_register_camera_devices(void)\r
+{   \r
+    int i;\r
     \r
-    for (i=0; i<2; i++) {
-        camera_reset = rk29_camera_platform_data.gpio_res[i].gpio_reset;
-        camera_power = rk29_camera_platform_data.gpio_res[i].gpio_power;
-               camera_powerdown = rk29_camera_platform_data.gpio_res[i].gpio_powerdown;
-        camera_flash = rk29_camera_platform_data.gpio_res[i].gpio_flash;
-               camera_ioflag = rk29_camera_platform_data.gpio_res[i].gpio_flag;
-               rk29_camera_platform_data.gpio_res[i].gpio_init = 0;
-
-        if (camera_power != INVALID_GPIO) {
-            ret = gpio_request(camera_power, "camera power");
-            if (ret) {
-                if (i == 0) {\r
-                                   goto sensor_io_int_loop_end;
-                } else {\r
-                    if (camera_power != rk29_camera_platform_data.gpio_res[0].gpio_power)\r
-                        goto sensor_io_int_loop_end;\r
-                }\r
-            }\r
-                       rk29_camera_platform_data.gpio_res[i].gpio_init |= RK29_CAM_POWERACTIVE_MASK;
-            gpio_set_value(camera_reset, (((~camera_ioflag)&RK29_CAM_POWERACTIVE_MASK)>>RK29_CAM_POWERACTIVE_BITPOS));
-            gpio_direction_output(camera_power, (((~camera_ioflag)&RK29_CAM_POWERACTIVE_MASK)>>RK29_CAM_POWERACTIVE_BITPOS));
-
-                       dprintk("\n%s....power pin(%d) init success(0x%x)  \n",__FUNCTION__,camera_power,(((~camera_ioflag)&RK29_CAM_POWERACTIVE_MASK)>>RK29_CAM_POWERACTIVE_BITPOS));\r
-
-        }
-
-        if (camera_reset != INVALID_GPIO) {
-            ret = gpio_request(camera_reset, "camera reset");
-            if (ret)
-                               goto sensor_io_int_loop_end;
-                       rk29_camera_platform_data.gpio_res[i].gpio_init |= RK29_CAM_RESETACTIVE_MASK;
-            gpio_set_value(camera_reset, ((camera_ioflag&RK29_CAM_RESETACTIVE_MASK)>>RK29_CAM_RESETACTIVE_BITPOS));
-            gpio_direction_output(camera_reset, ((camera_ioflag&RK29_CAM_RESETACTIVE_MASK)>>RK29_CAM_RESETACTIVE_BITPOS));
-
-                       dprintk("\n%s....reset pin(%d) init success(0x%x)\n",__FUNCTION__,camera_reset,((camera_ioflag&RK29_CAM_RESETACTIVE_MASK)>>RK29_CAM_RESETACTIVE_BITPOS));\r
-
-        }
-
-               if (camera_powerdown != INVALID_GPIO) {
-            ret = gpio_request(camera_powerdown, "camera powerdown");
-            if (ret)
-                               goto sensor_io_int_loop_end;
-                       rk29_camera_platform_data.gpio_res[i].gpio_init |= RK29_CAM_POWERDNACTIVE_MASK;
-            gpio_set_value(camera_powerdown, ((camera_ioflag&RK29_CAM_POWERDNACTIVE_MASK)>>RK29_CAM_POWERDNACTIVE_BITPOS));
-            gpio_direction_output(camera_powerdown, ((camera_ioflag&RK29_CAM_POWERDNACTIVE_MASK)>>RK29_CAM_POWERDNACTIVE_BITPOS));
-
-                       dprintk("\n%s....powerdown pin(%d) init success(0x%x) \n",__FUNCTION__,camera_powerdown,((camera_ioflag&RK29_CAM_POWERDNACTIVE_BITPOS)>>RK29_CAM_POWERDNACTIVE_BITPOS));\r
-
-        }
-
-               if (camera_flash != INVALID_GPIO) {
-            ret = gpio_request(camera_flash, "camera flash");
-            if (ret)
-                               goto sensor_io_int_loop_end;
-                       rk29_camera_platform_data.gpio_res[i].gpio_init |= RK29_CAM_FLASHACTIVE_MASK;
-            gpio_set_value(camera_flash, ((~camera_ioflag&RK29_CAM_FLASHACTIVE_MASK)>>RK29_CAM_FLASHACTIVE_BITPOS));    /* falsh off */\r
-            gpio_direction_output(camera_flash, ((~camera_ioflag&RK29_CAM_FLASHACTIVE_MASK)>>RK29_CAM_FLASHACTIVE_BITPOS));\r
-
-                       dprintk("\n%s....flash pin(%d) init success(0x%x) \n",__FUNCTION__,camera_flash,((camera_ioflag&RK29_CAM_FLASHACTIVE_MASK)>>RK29_CAM_FLASHACTIVE_BITPOS));\r
-
-        }
-               continue;
-sensor_io_int_loop_end:
-               rk29_sensor_io_deinit(i);
-               continue;
-    }
-
-    return 0;
-}
-
-static int rk29_sensor_io_deinit(int sensor)
-{
-    unsigned int camera_reset = INVALID_GPIO, camera_power = INVALID_GPIO;
-       unsigned int camera_powerdown = INVALID_GPIO, camera_flash = INVALID_GPIO;
-
-    camera_reset = rk29_camera_platform_data.gpio_res[sensor].gpio_reset;
-    camera_power = rk29_camera_platform_data.gpio_res[sensor].gpio_power;
-       camera_powerdown = rk29_camera_platform_data.gpio_res[sensor].gpio_powerdown;
-    camera_flash = rk29_camera_platform_data.gpio_res[sensor].gpio_flash;
-
-       if (rk29_camera_platform_data.gpio_res[sensor].gpio_init & RK29_CAM_POWERACTIVE_MASK) {
-           if (camera_power != INVALID_GPIO) {
-               gpio_direction_input(camera_power);
-               gpio_free(camera_power);
-           }
-       }
-
-       if (rk29_camera_platform_data.gpio_res[sensor].gpio_init & RK29_CAM_RESETACTIVE_MASK) {
-           if (camera_reset != INVALID_GPIO)  {
-               gpio_direction_input(camera_reset);
-               gpio_free(camera_reset);
-           }
-       }
-
-       if (rk29_camera_platform_data.gpio_res[sensor].gpio_init & RK29_CAM_POWERDNACTIVE_MASK) {
-           if (camera_powerdown != INVALID_GPIO)  {
-               gpio_direction_input(camera_powerdown);
-               gpio_free(camera_powerdown);
-           }
-       }
-
-       if (rk29_camera_platform_data.gpio_res[sensor].gpio_init & RK29_CAM_FLASHACTIVE_MASK) {
-           if (camera_flash != INVALID_GPIO)  {
-               gpio_direction_input(camera_flash);
-               gpio_free(camera_flash);
-           }
-       }
-
-       rk29_camera_platform_data.gpio_res[sensor].gpio_init = 0;
-    return 0;
-}
-static int rk29_sensor_ioctrl(struct device *dev,enum rk29camera_ioctrl_cmd cmd, int on)
-{
-    struct rk29camera_gpio_res *res = NULL;    \r
-       int ret = RK29_CAM_IO_SUCCESS;
-
-    if(rk29_camera_platform_data.gpio_res[0].dev_name &&  (strcmp(rk29_camera_platform_data.gpio_res[0].dev_name, dev_name(dev)) == 0)) {
-               res = (struct rk29camera_gpio_res *)&rk29_camera_platform_data.gpio_res[0];\r
-    } else if (rk29_camera_platform_data.gpio_res[1].dev_name && (strcmp(rk29_camera_platform_data.gpio_res[1].dev_name, dev_name(dev)) == 0)) {
-       res = (struct rk29camera_gpio_res *)&rk29_camera_platform_data.gpio_res[1];\r
-    } else {\r
-        printk(KERN_ERR "%s is not regisiterd in rk29_camera_platform_data!!\n",dev_name(dev));\r
-        ret = RK29_CAM_EIO_INVALID;\r
-        goto rk29_sensor_ioctrl_end;\r
+       rk_init_camera_plateform_data();\r
+    for (i=0; i<RK_CAM_NUM; i++) {\r
+        if (rk_camera_platform_data.register_dev[i].device_info.name\r
+            && !strcmp(rk_camera_platform_data.register_dev[i].device_info.dev.init_name,SENSOR_DEVICE_NAME_0)\r
+            && !strcmp(rk_camera_platform_data.register_dev[i].device_info.dev.init_name,SENSOR_DEVICE_NAME_1)) {\r
+            platform_device_register(&rk_camera_platform_data.register_dev[i].device_info);\r
+        }\r
     }\r
-
-       switch (cmd)
-       {
-               case Cam_Power:
-               {
-                       if (sensor_ioctl_cb.sensor_power_cb) {\r
-                ret = sensor_ioctl_cb.sensor_power_cb(res, on);\r
-                       } else {\r
-                printk(KERN_ERR "sensor_ioctl_cb.sensor_power_cb is NULL");\r
-                WARN_ON(1);\r
-                       }\r
-                       break;
-               }
-               case Cam_Reset:
-               {
-                       if (sensor_ioctl_cb.sensor_reset_cb) {\r
-                ret = sensor_ioctl_cb.sensor_reset_cb(res, on);\r
-                       } else {\r
-                printk(KERN_ERR "sensor_ioctl_cb.sensor_reset_cb is NULL");\r
-                WARN_ON(1);\r
-                       }\r
-                       break;
-               }
-
-               case Cam_PowerDown:
-               {
-                       if (sensor_ioctl_cb.sensor_powerdown_cb) {\r
-                ret = sensor_ioctl_cb.sensor_powerdown_cb(res, on);\r
-                       } else {\r
-                printk(KERN_ERR "sensor_ioctl_cb.sensor_powerdown_cb is NULL");\r
-                WARN_ON(1);\r
-                       }\r
-                       break;
-               }
-
-               case Cam_Flash:
-               {
-                       if (sensor_ioctl_cb.sensor_flash_cb) {\r
-                ret = sensor_ioctl_cb.sensor_flash_cb(res, on);\r
-                       } else {\r
-                printk(KERN_ERR "sensor_ioctl_cb.sensor_flash_cb is NULL!");\r
-                WARN_ON(1);\r
-                       }\r
-                       break;
-               }
-
-               default:
-               {
-                       printk("%s cmd(0x%x) is unknown!\n",__FUNCTION__, cmd);
-                       break;
-               }
-       }\r
-rk29_sensor_ioctrl_end:\r
-    return ret;
-}
-static int rk29_sensor_power(struct device *dev, int on)
-{
-       rk29_sensor_ioctrl(dev,Cam_Power,on);
-    return 0;
+       return 0;\r
 }\r
-#if 0\r
-static int rk29_sensor_reset(struct device *dev)
-{
-       rk29_sensor_ioctrl(dev,Cam_Reset,1);
-       msleep(2);
-       rk29_sensor_ioctrl(dev,Cam_Reset,0);
-       return 0;
-}\r
-#endif\r
-static int rk29_sensor_powerdown(struct device *dev, int on)
-{
-       return rk29_sensor_ioctrl(dev,Cam_PowerDown,on);
-}
-#if (CONFIG_SENSOR_IIC_ADDR_0 != 0x00)
-static struct i2c_board_info rk29_i2c_cam_info_0[] = {
-       {
-               I2C_BOARD_INFO(SENSOR_NAME_0, CONFIG_SENSOR_IIC_ADDR_0>>1)
-       },
-};
-
-static struct soc_camera_link rk29_iclink_0 = {
-       .bus_id         = RK29_CAM_PLATFORM_DEV_ID,
-       .power          = rk29_sensor_power,
-       .powerdown  = rk29_sensor_powerdown,
-       .board_info     = &rk29_i2c_cam_info_0[0],
-       .i2c_adapter_id = CONFIG_SENSOR_IIC_ADAPTER_ID_0,
-       .module_name    = SENSOR_NAME_0,
-};
-
-/*platform_device : soc-camera need  */
-static struct platform_device rk29_soc_camera_pdrv_0 = {
-       .name   = "soc-camera-pdrv",
-       .id     = 0,
-       .dev    = {
-               .init_name = SENSOR_DEVICE_NAME_0,
-               .platform_data = &rk29_iclink_0,
-       },
-};
-#endif
-static struct i2c_board_info rk29_i2c_cam_info_1[] = {
-       {
-               I2C_BOARD_INFO(SENSOR_NAME_1, CONFIG_SENSOR_IIC_ADDR_1>>1)
-       },
-};
-
-static struct soc_camera_link rk29_iclink_1 = {
-       .bus_id         = RK29_CAM_PLATFORM_DEV_ID,
-       .power          = rk29_sensor_power,
-       .powerdown  = rk29_sensor_powerdown,
-       .board_info     = &rk29_i2c_cam_info_1[0],
-       .i2c_adapter_id = CONFIG_SENSOR_IIC_ADAPTER_ID_1,
-       .module_name    = SENSOR_NAME_1,
-};
-
-/*platform_device : soc-camera need  */
-static struct platform_device rk29_soc_camera_pdrv_1 = {
-       .name   = "soc-camera-pdrv",
-       .id     = 1,
-       .dev    = {
-               .init_name = SENSOR_DEVICE_NAME_1,
-               .platform_data = &rk29_iclink_1,
-       },
-};
-
-
-static u64 rockchip_device_camera_dmamask = 0xffffffffUL;
-static struct resource rk29_camera_resource[] = {
-       [0] = {
-               .start = RK29_VIP_PHYS,
-               .end   = RK29_VIP_PHYS + RK29_VIP_SIZE - 1,
-               .flags = IORESOURCE_MEM,
-       },
-       [1] = {
-               .start = IRQ_VIP,
-               .end   = IRQ_VIP,
-               .flags = IORESOURCE_IRQ,
-       }
-};
-
-/*platform_device : */
-static struct platform_device rk29_device_camera = {
-       .name             = RK29_CAM_DRV_NAME,
-       .id               = RK29_CAM_PLATFORM_DEV_ID,               /* This is used to put cameras on this interface */
-       .num_resources    = ARRAY_SIZE(rk29_camera_resource),
-       .resource         = rk29_camera_resource,
-       .dev            = {
-               .dma_mask = &rockchip_device_camera_dmamask,
-               .coherent_dma_mask = 0xffffffffUL,
-               .platform_data  = &rk29_camera_platform_data,
-       }
-};
-
-static struct android_pmem_platform_data android_pmem_cam_pdata = {
-       .name           = "pmem_cam",
-       .start          = PMEM_CAM_BASE,
-       .size           = PMEM_CAM_SIZE,
-       .no_allocator   = 1,
-       .cached         = 1,
-};
-
-static struct platform_device android_pmem_cam_device = {
-       .name           = "android_pmem",
-       .id             = 1,
-       .dev            = {
-               .platform_data = &android_pmem_cam_pdata,
-       },
-};\r
+\r
+module_init(rk_register_camera_devices);\r
 \r
 #endif\r
 \r
-#endif //#ifdef CONFIG_VIDEO_RK29
\ No newline at end of file
+#endif //#ifdef CONFIG_VIDEO_RK29\r