m5602_s5k83a.c 8.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391
  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 (m5602_read_sensor(sd, 0x00, &prod_id, 1))
  48. return -ENODEV;
  49. if (m5602_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_init(struct sd *sd)
  91. {
  92. int i, err = 0;
  93. for (i = 0; i < ARRAY_SIZE(init_s5k83a) && !err; i++) {
  94. u8 data[2] = {0x00, 0x00};
  95. switch (init_s5k83a[i][0]) {
  96. case BRIDGE:
  97. err = m5602_write_bridge(sd,
  98. init_s5k83a[i][1],
  99. init_s5k83a[i][2]);
  100. break;
  101. case SENSOR:
  102. data[0] = init_s5k83a[i][2];
  103. err = m5602_write_sensor(sd,
  104. init_s5k83a[i][1], data, 1);
  105. break;
  106. case SENSOR_LONG:
  107. data[0] = init_s5k83a[i][2];
  108. data[1] = init_s5k83a[i][3];
  109. err = m5602_write_sensor(sd,
  110. init_s5k83a[i][1], data, 2);
  111. break;
  112. default:
  113. info("Invalid stream command, exiting init");
  114. return -EINVAL;
  115. }
  116. }
  117. if (dump_sensor)
  118. s5k83a_dump_registers(sd);
  119. return (err < 0) ? err : 0;
  120. }
  121. int s5k83a_power_down(struct sd *sd)
  122. {
  123. return 0;
  124. }
  125. void s5k83a_dump_registers(struct sd *sd)
  126. {
  127. int address;
  128. u8 page, old_page;
  129. m5602_read_sensor(sd, S5K83A_PAGE_MAP, &old_page, 1);
  130. for (page = 0; page < 16; page++) {
  131. m5602_write_sensor(sd, S5K83A_PAGE_MAP, &page, 1);
  132. info("Dumping the s5k83a register state for page 0x%x", page);
  133. for (address = 0; address <= 0xff; address++) {
  134. u8 val = 0;
  135. m5602_read_sensor(sd, address, &val, 1);
  136. info("register 0x%x contains 0x%x",
  137. address, val);
  138. }
  139. }
  140. info("s5k83a register state dump complete");
  141. for (page = 0; page < 16; page++) {
  142. m5602_write_sensor(sd, S5K83A_PAGE_MAP, &page, 1);
  143. info("Probing for which registers that are read/write "
  144. "for page 0x%x", page);
  145. for (address = 0; address <= 0xff; address++) {
  146. u8 old_val, ctrl_val, test_val = 0xff;
  147. m5602_read_sensor(sd, address, &old_val, 1);
  148. m5602_write_sensor(sd, address, &test_val, 1);
  149. m5602_read_sensor(sd, address, &ctrl_val, 1);
  150. if (ctrl_val == test_val)
  151. info("register 0x%x is writeable", address);
  152. else
  153. info("register 0x%x is read only", address);
  154. /* Restore original val */
  155. m5602_write_sensor(sd, address, &old_val, 1);
  156. }
  157. }
  158. info("Read/write register probing complete");
  159. m5602_write_sensor(sd, S5K83A_PAGE_MAP, &old_page, 1);
  160. }
  161. int s5k83a_get_brightness(struct gspca_dev *gspca_dev, __s32 *val)
  162. {
  163. int err;
  164. u8 data[2];
  165. struct sd *sd = (struct sd *) gspca_dev;
  166. err = m5602_read_sensor(sd, S5K83A_BRIGHTNESS, data, 2);
  167. if (err < 0)
  168. goto out;
  169. data[1] = data[1] << 1;
  170. *val = data[1];
  171. out:
  172. return err;
  173. }
  174. int s5k83a_set_brightness(struct gspca_dev *gspca_dev, __s32 val)
  175. {
  176. int err;
  177. u8 data[2];
  178. struct sd *sd = (struct sd *) gspca_dev;
  179. data[0] = 0x00;
  180. data[1] = 0x20;
  181. err = m5602_write_sensor(sd, 0x14, data, 2);
  182. if (err < 0)
  183. goto out;
  184. data[0] = 0x01;
  185. data[1] = 0x00;
  186. err = m5602_write_sensor(sd, 0x0d, data, 2);
  187. if (err < 0)
  188. goto out;
  189. /* FIXME: This is not sane, we need to figure out the composition
  190. of these registers */
  191. data[0] = val >> 3; /* brightness, high 5 bits */
  192. data[1] = val >> 1; /* brightness, high 7 bits */
  193. err = m5602_write_sensor(sd, S5K83A_BRIGHTNESS, data, 2);
  194. out:
  195. return err;
  196. }
  197. int s5k83a_get_whiteness(struct gspca_dev *gspca_dev, __s32 *val)
  198. {
  199. int err;
  200. u8 data;
  201. struct sd *sd = (struct sd *) gspca_dev;
  202. err = m5602_read_sensor(sd, S5K83A_WHITENESS, &data, 1);
  203. if (err < 0)
  204. goto out;
  205. *val = data;
  206. out:
  207. return err;
  208. }
  209. int s5k83a_set_whiteness(struct gspca_dev *gspca_dev, __s32 val)
  210. {
  211. int err;
  212. u8 data[1];
  213. struct sd *sd = (struct sd *) gspca_dev;
  214. data[0] = val;
  215. err = m5602_write_sensor(sd, S5K83A_WHITENESS, data, 1);
  216. return err;
  217. }
  218. int s5k83a_get_gain(struct gspca_dev *gspca_dev, __s32 *val)
  219. {
  220. int err;
  221. u8 data[2];
  222. struct sd *sd = (struct sd *) gspca_dev;
  223. err = m5602_read_sensor(sd, S5K83A_GAIN, data, 2);
  224. if (err < 0)
  225. goto out;
  226. data[1] = data[1] & 0x3f;
  227. if (data[1] > S5K83A_MAXIMUM_GAIN)
  228. data[1] = S5K83A_MAXIMUM_GAIN;
  229. *val = data[1];
  230. out:
  231. return err;
  232. }
  233. int s5k83a_set_gain(struct gspca_dev *gspca_dev, __s32 val)
  234. {
  235. int err;
  236. u8 data[2];
  237. struct sd *sd = (struct sd *) gspca_dev;
  238. data[0] = 0;
  239. data[1] = val;
  240. err = m5602_write_sensor(sd, S5K83A_GAIN, data, 2);
  241. return err;
  242. }
  243. int s5k83a_get_vflip(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] = 0x05;
  249. err = m5602_write_sensor(sd, S5K83A_PAGE_MAP, data, 1);
  250. if (err < 0)
  251. goto out;
  252. err = m5602_read_sensor(sd, S5K83A_FLIP, data, 1);
  253. *val = (data[0] | 0x40) ? 1 : 0;
  254. out:
  255. return err;
  256. }
  257. int s5k83a_set_vflip(struct gspca_dev *gspca_dev, __s32 val)
  258. {
  259. int err;
  260. u8 data[1];
  261. struct sd *sd = (struct sd *) gspca_dev;
  262. data[0] = 0x05;
  263. err = m5602_write_sensor(sd, S5K83A_PAGE_MAP, data, 1);
  264. if (err < 0)
  265. goto out;
  266. err = m5602_read_sensor(sd, S5K83A_FLIP, data, 1);
  267. if (err < 0)
  268. goto out;
  269. /* set or zero six bit, seven is hflip */
  270. data[0] = (val) ? (data[0] & 0x80) | 0x40 | S5K83A_FLIP_MASK
  271. : (data[0] & 0x80) | S5K83A_FLIP_MASK;
  272. err = m5602_write_sensor(sd, S5K83A_FLIP, data, 1);
  273. if (err < 0)
  274. goto out;
  275. data[0] = (val) ? 0x0b : 0x0a;
  276. err = m5602_write_sensor(sd, S5K83A_VFLIP_TUNE, data, 1);
  277. out:
  278. return err;
  279. }
  280. int s5k83a_get_hflip(struct gspca_dev *gspca_dev, __s32 *val)
  281. {
  282. int err;
  283. u8 data[1];
  284. struct sd *sd = (struct sd *) gspca_dev;
  285. data[0] = 0x05;
  286. err = m5602_write_sensor(sd, S5K83A_PAGE_MAP, data, 1);
  287. if (err < 0)
  288. goto out;
  289. err = m5602_read_sensor(sd, S5K83A_FLIP, data, 1);
  290. *val = (data[0] | 0x80) ? 1 : 0;
  291. out:
  292. return err;
  293. }
  294. int s5k83a_set_hflip(struct gspca_dev *gspca_dev, __s32 val)
  295. {
  296. int err;
  297. u8 data[1];
  298. struct sd *sd = (struct sd *) gspca_dev;
  299. data[0] = 0x05;
  300. err = m5602_write_sensor(sd, S5K83A_PAGE_MAP, data, 1);
  301. if (err < 0)
  302. goto out;
  303. err = m5602_read_sensor(sd, S5K83A_FLIP, data, 1);
  304. if (err < 0)
  305. goto out;
  306. /* set or zero seven bit, six is vflip */
  307. data[0] = (val) ? (data[0] & 0x40) | 0x80 | S5K83A_FLIP_MASK
  308. : (data[0] & 0x40) | S5K83A_FLIP_MASK;
  309. err = m5602_write_sensor(sd, S5K83A_FLIP, data, 1);
  310. if (err < 0)
  311. goto out;
  312. data[0] = (val) ? 0x0a : 0x0b;
  313. err = m5602_write_sensor(sd, S5K83A_HFLIP_TUNE, data, 1);
  314. out:
  315. return err;
  316. }