m5602_s5k83a.c 9.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435
  1. /*
  2. * Driver for the s5k83a sensor
  3. *
  4. * Copyright (C) 2008 Erik Andrén
  5. * Copyright (C) 2007 Ilyes Gouta. Based on the m5603x Linux Driver Project.
  6. * Copyright (C) 2005 m5603x Linux Driver Project <m5602@x3ng.com.br>
  7. *
  8. * Portions of code to USB interface and ALi driver software,
  9. * Copyright (c) 2006 Willem Duinker
  10. * v4l2 interface modeled after the V4L2 driver
  11. * for SN9C10x PC Camera Controllers
  12. *
  13. * This program is free software; you can redistribute it and/or
  14. * modify it under the terms of the GNU General Public License as
  15. * published by the Free Software Foundation, version 2.
  16. *
  17. */
  18. #include "m5602_s5k83a.h"
  19. static void s5k83a_dump_registers(struct sd *sd);
  20. int s5k83a_probe(struct sd *sd)
  21. {
  22. u8 prod_id = 0, ver_id = 0;
  23. int i, err = 0;
  24. if (force_sensor) {
  25. if (force_sensor == S5K83A_SENSOR) {
  26. info("Forcing a %s sensor", s5k83a.name);
  27. goto sensor_found;
  28. }
  29. /* If we want to force another sensor, don't try to probe this
  30. * one */
  31. return -ENODEV;
  32. }
  33. info("Probing for a s5k83a sensor");
  34. /* Preinit the sensor */
  35. for (i = 0; i < ARRAY_SIZE(preinit_s5k83a) && !err; i++) {
  36. u8 data[2] = {preinit_s5k83a[i][2], preinit_s5k83a[i][3]};
  37. if (preinit_s5k83a[i][0] == SENSOR)
  38. err = m5602_write_sensor(sd, preinit_s5k83a[i][1],
  39. data, 2);
  40. else
  41. err = m5602_write_bridge(sd, preinit_s5k83a[i][1],
  42. data[0]);
  43. }
  44. /* We don't know what register (if any) that contain the product id
  45. * Just pick the first addresses that seem to produce the same results
  46. * on multiple machines */
  47. if (s5k83a_read_sensor(sd, 0x00, &prod_id, 1))
  48. return -ENODEV;
  49. if (s5k83a_read_sensor(sd, 0x01, &ver_id, 1))
  50. return -ENODEV;
  51. if ((prod_id == 0xff) || (ver_id == 0xff))
  52. return -ENODEV;
  53. else
  54. info("Detected a s5k83a sensor");
  55. sensor_found:
  56. sd->gspca_dev.cam.cam_mode = s5k83a.modes;
  57. sd->gspca_dev.cam.nmodes = s5k83a.nmodes;
  58. sd->desc->ctrls = s5k83a.ctrls;
  59. sd->desc->nctrls = s5k83a.nctrls;
  60. return 0;
  61. }
  62. int s5k83a_read_sensor(struct sd *sd, const u8 address,
  63. u8 *i2c_data, const u8 len)
  64. {
  65. int err, i;
  66. do {
  67. err = m5602_read_bridge(sd, M5602_XB_I2C_STATUS, i2c_data);
  68. } while ((*i2c_data & I2C_BUSY) && !err);
  69. if (err < 0)
  70. goto out;
  71. err = m5602_write_bridge(sd, M5602_XB_I2C_DEV_ADDR,
  72. sd->sensor->i2c_slave_id);
  73. if (err < 0)
  74. goto out;
  75. err = m5602_write_bridge(sd, M5602_XB_I2C_REG_ADDR, address);
  76. if (err < 0)
  77. goto out;
  78. err = m5602_write_bridge(sd, M5602_XB_I2C_CTRL, 0x18 + len);
  79. do {
  80. err = m5602_read_bridge(sd, M5602_XB_I2C_STATUS, i2c_data);
  81. } while ((*i2c_data & I2C_BUSY) && !err);
  82. for (i = 0; i < len && !len; i++) {
  83. err = m5602_read_bridge(sd, M5602_XB_I2C_DATA, &(i2c_data[i]));
  84. PDEBUG(D_CONF, "Reading sensor register "
  85. "0x%x containing 0x%x ", address, *i2c_data);
  86. }
  87. out:
  88. return err;
  89. }
  90. int s5k83a_write_sensor(struct sd *sd, const u8 address,
  91. u8 *i2c_data, const u8 len)
  92. {
  93. int err, i;
  94. u8 *p;
  95. struct usb_device *udev = sd->gspca_dev.dev;
  96. __u8 *buf = sd->gspca_dev.usb_buf;
  97. /* No sensor with a data width larger than 16 bits has yet been seen */
  98. if (len > 2 || !len)
  99. return -EINVAL;
  100. memcpy(buf, sensor_urb_skeleton,
  101. sizeof(sensor_urb_skeleton));
  102. buf[11] = sd->sensor->i2c_slave_id;
  103. buf[15] = address;
  104. /* Special case larger sensor writes */
  105. p = buf + 16;
  106. /* Copy a four byte write sequence for each byte to be written to */
  107. for (i = 0; i < len; i++) {
  108. memcpy(p, sensor_urb_skeleton + 16, 4);
  109. p[3] = i2c_data[i];
  110. p += 4;
  111. PDEBUG(D_CONF, "Writing sensor register 0x%x with 0x%x",
  112. address, i2c_data[i]);
  113. }
  114. /* Copy the tailer */
  115. memcpy(p, sensor_urb_skeleton + 20, 4);
  116. /* Set the total length */
  117. p[3] = 0x10 + len;
  118. err = usb_control_msg(udev, usb_sndctrlpipe(udev, 0),
  119. 0x04, 0x40, 0x19,
  120. 0x0000, buf,
  121. 20 + len * 4, M5602_URB_MSG_TIMEOUT);
  122. return (err < 0) ? err : 0;
  123. }
  124. int s5k83a_init(struct sd *sd)
  125. {
  126. int i, err = 0;
  127. for (i = 0; i < ARRAY_SIZE(init_s5k83a) && !err; i++) {
  128. u8 data[2] = {0x00, 0x00};
  129. switch (init_s5k83a[i][0]) {
  130. case BRIDGE:
  131. err = m5602_write_bridge(sd,
  132. init_s5k83a[i][1],
  133. init_s5k83a[i][2]);
  134. break;
  135. case SENSOR:
  136. data[0] = init_s5k83a[i][2];
  137. err = m5602_write_sensor(sd,
  138. init_s5k83a[i][1], data, 1);
  139. break;
  140. case SENSOR_LONG:
  141. data[0] = init_s5k83a[i][2];
  142. data[1] = init_s5k83a[i][3];
  143. err = m5602_write_sensor(sd,
  144. init_s5k83a[i][1], data, 2);
  145. break;
  146. default:
  147. info("Invalid stream command, exiting init");
  148. return -EINVAL;
  149. }
  150. }
  151. if (dump_sensor)
  152. s5k83a_dump_registers(sd);
  153. return (err < 0) ? err : 0;
  154. }
  155. int s5k83a_power_down(struct sd *sd)
  156. {
  157. return 0;
  158. }
  159. void s5k83a_dump_registers(struct sd *sd)
  160. {
  161. int address;
  162. u8 page, old_page;
  163. s5k83a_read_sensor(sd, S5K83A_PAGE_MAP, &old_page, 1);
  164. for (page = 0; page < 16; page++) {
  165. m5602_write_sensor(sd, S5K83A_PAGE_MAP, &page, 1);
  166. info("Dumping the s5k83a register state for page 0x%x", page);
  167. for (address = 0; address <= 0xff; address++) {
  168. u8 val = 0;
  169. s5k83a_read_sensor(sd, address, &val, 1);
  170. info("register 0x%x contains 0x%x",
  171. address, val);
  172. }
  173. }
  174. info("s5k83a register state dump complete");
  175. for (page = 0; page < 16; page++) {
  176. m5602_write_sensor(sd, S5K83A_PAGE_MAP, &page, 1);
  177. info("Probing for which registers that are read/write "
  178. "for page 0x%x", page);
  179. for (address = 0; address <= 0xff; address++) {
  180. u8 old_val, ctrl_val, test_val = 0xff;
  181. s5k83a_read_sensor(sd, address, &old_val, 1);
  182. m5602_write_sensor(sd, address, &test_val, 1);
  183. s5k83a_read_sensor(sd, address, &ctrl_val, 1);
  184. if (ctrl_val == test_val)
  185. info("register 0x%x is writeable", address);
  186. else
  187. info("register 0x%x is read only", address);
  188. /* Restore original val */
  189. m5602_write_sensor(sd, address, &old_val, 1);
  190. }
  191. }
  192. info("Read/write register probing complete");
  193. m5602_write_sensor(sd, S5K83A_PAGE_MAP, &old_page, 1);
  194. }
  195. int s5k83a_get_brightness(struct gspca_dev *gspca_dev, __s32 *val)
  196. {
  197. int err;
  198. u8 data[2];
  199. struct sd *sd = (struct sd *) gspca_dev;
  200. err = s5k83a_read_sensor(sd, S5K83A_BRIGHTNESS, data, 2);
  201. if (err < 0)
  202. goto out;
  203. data[1] = data[1] << 1;
  204. *val = data[1];
  205. out:
  206. return err;
  207. }
  208. int s5k83a_set_brightness(struct gspca_dev *gspca_dev, __s32 val)
  209. {
  210. int err;
  211. u8 data[2];
  212. struct sd *sd = (struct sd *) gspca_dev;
  213. data[0] = 0x00;
  214. data[1] = 0x20;
  215. err = m5602_write_sensor(sd, 0x14, data, 2);
  216. if (err < 0)
  217. goto out;
  218. data[0] = 0x01;
  219. data[1] = 0x00;
  220. err = m5602_write_sensor(sd, 0x0d, data, 2);
  221. if (err < 0)
  222. goto out;
  223. /* FIXME: This is not sane, we need to figure out the composition
  224. of these registers */
  225. data[0] = val >> 3; /* brightness, high 5 bits */
  226. data[1] = val >> 1; /* brightness, high 7 bits */
  227. err = m5602_write_sensor(sd, S5K83A_BRIGHTNESS, data, 2);
  228. out:
  229. return err;
  230. }
  231. int s5k83a_get_whiteness(struct gspca_dev *gspca_dev, __s32 *val)
  232. {
  233. int err;
  234. u8 data;
  235. struct sd *sd = (struct sd *) gspca_dev;
  236. err = s5k83a_read_sensor(sd, S5K83A_WHITENESS, &data, 1);
  237. if (err < 0)
  238. goto out;
  239. *val = data;
  240. out:
  241. return err;
  242. }
  243. int s5k83a_set_whiteness(struct gspca_dev *gspca_dev, __s32 val)
  244. {
  245. int err;
  246. u8 data[1];
  247. struct sd *sd = (struct sd *) gspca_dev;
  248. data[0] = val;
  249. err = m5602_write_sensor(sd, S5K83A_WHITENESS, data, 1);
  250. return err;
  251. }
  252. int s5k83a_get_gain(struct gspca_dev *gspca_dev, __s32 *val)
  253. {
  254. int err;
  255. u8 data[2];
  256. struct sd *sd = (struct sd *) gspca_dev;
  257. err = s5k83a_read_sensor(sd, S5K83A_GAIN, data, 2);
  258. if (err < 0)
  259. goto out;
  260. data[1] = data[1] & 0x3f;
  261. if (data[1] > S5K83A_MAXIMUM_GAIN)
  262. data[1] = S5K83A_MAXIMUM_GAIN;
  263. *val = data[1];
  264. out:
  265. return err;
  266. }
  267. int s5k83a_set_gain(struct gspca_dev *gspca_dev, __s32 val)
  268. {
  269. int err;
  270. u8 data[2];
  271. struct sd *sd = (struct sd *) gspca_dev;
  272. data[0] = 0;
  273. data[1] = val;
  274. err = m5602_write_sensor(sd, S5K83A_GAIN, data, 2);
  275. return err;
  276. }
  277. int s5k83a_get_vflip(struct gspca_dev *gspca_dev, __s32 *val)
  278. {
  279. int err;
  280. u8 data[1];
  281. struct sd *sd = (struct sd *) gspca_dev;
  282. data[0] = 0x05;
  283. err = m5602_write_sensor(sd, S5K83A_PAGE_MAP, data, 1);
  284. if (err < 0)
  285. goto out;
  286. err = s5k83a_read_sensor(sd, S5K83A_FLIP, data, 1);
  287. *val = (data[0] | 0x40) ? 1 : 0;
  288. out:
  289. return err;
  290. }
  291. int s5k83a_set_vflip(struct gspca_dev *gspca_dev, __s32 val)
  292. {
  293. int err;
  294. u8 data[1];
  295. struct sd *sd = (struct sd *) gspca_dev;
  296. data[0] = 0x05;
  297. err = m5602_write_sensor(sd, S5K83A_PAGE_MAP, data, 1);
  298. if (err < 0)
  299. goto out;
  300. err = s5k83a_read_sensor(sd, S5K83A_FLIP, data, 1);
  301. if (err < 0)
  302. goto out;
  303. /* set or zero six bit, seven is hflip */
  304. data[0] = (val) ? (data[0] & 0x80) | 0x40 | S5K83A_FLIP_MASK
  305. : (data[0] & 0x80) | S5K83A_FLIP_MASK;
  306. err = m5602_write_sensor(sd, S5K83A_FLIP, data, 1);
  307. if (err < 0)
  308. goto out;
  309. data[0] = (val) ? 0x0b : 0x0a;
  310. err = m5602_write_sensor(sd, S5K83A_VFLIP_TUNE, data, 1);
  311. out:
  312. return err;
  313. }
  314. int s5k83a_get_hflip(struct gspca_dev *gspca_dev, __s32 *val)
  315. {
  316. int err;
  317. u8 data[1];
  318. struct sd *sd = (struct sd *) gspca_dev;
  319. data[0] = 0x05;
  320. err = m5602_write_sensor(sd, S5K83A_PAGE_MAP, data, 1);
  321. if (err < 0)
  322. goto out;
  323. err = s5k83a_read_sensor(sd, S5K83A_FLIP, data, 1);
  324. *val = (data[0] | 0x80) ? 1 : 0;
  325. out:
  326. return err;
  327. }
  328. int s5k83a_set_hflip(struct gspca_dev *gspca_dev, __s32 val)
  329. {
  330. int err;
  331. u8 data[1];
  332. struct sd *sd = (struct sd *) gspca_dev;
  333. data[0] = 0x05;
  334. err = m5602_write_sensor(sd, S5K83A_PAGE_MAP, data, 1);
  335. if (err < 0)
  336. goto out;
  337. err = s5k83a_read_sensor(sd, S5K83A_FLIP, data, 1);
  338. if (err < 0)
  339. goto out;
  340. /* set or zero seven bit, six is vflip */
  341. data[0] = (val) ? (data[0] & 0x40) | 0x80 | S5K83A_FLIP_MASK
  342. : (data[0] & 0x40) | S5K83A_FLIP_MASK;
  343. err = m5602_write_sensor(sd, S5K83A_FLIP, data, 1);
  344. if (err < 0)
  345. goto out;
  346. data[0] = (val) ? 0x0a : 0x0b;
  347. err = m5602_write_sensor(sd, S5K83A_HFLIP_TUNE, data, 1);
  348. out:
  349. return err;
  350. }