Hi Sangwook, On 08/02/2012 03:42 PM, Sangwook Lee wrote: > The following 2 patches add driver for S5K4ECGX sensor with embedded ISP SoC, > and minor v4l2 control API enhancement. S5K4ECGX is 5M CMOS Image sensor from Samsung > > Changes since v2: > - added GPIO (reset/stby) and regulators > - updated I2C read/write, based on s5k6aa datasheet > - fixed set_fmt errors > - reduced register tables a bit > - removed vmalloc It looks like a great improvement, well done! Thanks! In the S5K4CAGX sensor datasheet, that can be found on the internet, there is 0x0000...0x002E registers description, which look very much same as in S5K6AAFX case and likely is also valid for S5K4CAGX. My second thought was, if we won't be able to get rid of those hundreds of initial register values, to convert them to regular firmware blob. And add regular firmware handling at the driver. I know it may sound not standard but imagine dozens of such sensor drivers coexisting in the mainline kernel. The source code would have been mainly register address/value arrays... What do you think about converting s5k4ecgx_img_regs arrays (it has over 2700 entries) to a firmware file and adding some simple parser to the driver ? Then we would have the problem solved in most part. Regarding various preview resolution set up, the difference in all those s5k4ecgx_*_preview[] arrays is rather small, only register values differ, e.g. for 640x480 and 720x480 there is only 8 different entries: $ diff -a s5k4ec_640.txt s5k4ec_720.txt 1c1 < static const struct regval_list s5k4ecgx_640_preview[] = { --- > static const struct regval_list s5k4ecgx_720_preview[] = { 3c3 < { 0x70000252, 0x0780 }, --- > { 0x70000252, 0x06a8 }, 5c5 < { 0x70000256, 0x000c }, --- > { 0x70000256, 0x0078 }, 7c7 < { 0x7000025a, 0x0780 }, --- > { 0x7000025a, 0x06a8 }, 9c9 < { 0x7000025e, 0x000c }, --- > { 0x7000025e, 0x0078 }, 11c11 < { 0x70000496, 0x0780 }, --- > { 0x70000496, 0x06a8 }, 15c15 < { 0x7000049e, 0x0780 }, --- > { 0x7000049e, 0x06a8 }, 21c21 < { 0x700002a6, 0x0280 }, --- > { 0x700002a6, 0x02d0 }, 28c28 < { 0x700002c4, 0x014a }, --- > { 0x700002c4, 0x014d }, I've found S5K4ECGX sensor datasheet on internet (Rev 0.07), and on a quick look the description of most of registers from those tables could be found there. Could you please try to implement a function that replaces those tables, based s5k6aa_set_prev_config() and s5k6aa_set_output_framefmt() ? Regards, Sylwester -- To unsubscribe from this list: send the line "unsubscribe linux-media" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html