em28xx-core.c 31 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260
  1. /*
  2. em28xx-core.c - driver for Empia EM2800/EM2820/2840 USB video capture devices
  3. Copyright (C) 2005 Ludovico Cavedon <cavedon@sssup.it>
  4. Markus Rechberger <mrechberger@gmail.com>
  5. Mauro Carvalho Chehab <mchehab@infradead.org>
  6. Sascha Sommer <saschasommer@freenet.de>
  7. This program is free software; you can redistribute it and/or modify
  8. it under the terms of the GNU General Public License as published by
  9. the Free Software Foundation; either version 2 of the License, or
  10. (at your option) any later version.
  11. This program is distributed in the hope that it will be useful,
  12. but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  14. GNU General Public License for more details.
  15. You should have received a copy of the GNU General Public License
  16. along with this program; if not, write to the Free Software
  17. Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
  18. */
  19. #include <linux/init.h>
  20. #include <linux/list.h>
  21. #include <linux/module.h>
  22. #include <linux/slab.h>
  23. #include <linux/usb.h>
  24. #include <linux/vmalloc.h>
  25. #include <sound/ac97_codec.h>
  26. #include <media/v4l2-common.h>
  27. #include "em28xx.h"
  28. /* #define ENABLE_DEBUG_ISOC_FRAMES */
  29. static unsigned int core_debug;
  30. module_param(core_debug, int, 0644);
  31. MODULE_PARM_DESC(core_debug, "enable debug messages [core]");
  32. #define em28xx_coredbg(fmt, arg...) do {\
  33. if (core_debug) \
  34. printk(KERN_INFO "%s %s :"fmt, \
  35. dev->name, __func__ , ##arg); } while (0)
  36. static unsigned int reg_debug;
  37. module_param(reg_debug, int, 0644);
  38. MODULE_PARM_DESC(reg_debug, "enable debug messages [URB reg]");
  39. #define em28xx_regdbg(fmt, arg...) do {\
  40. if (reg_debug) \
  41. printk(KERN_INFO "%s %s :"fmt, \
  42. dev->name, __func__ , ##arg); } while (0)
  43. static int alt;
  44. module_param(alt, int, 0644);
  45. MODULE_PARM_DESC(alt, "alternate setting to use for video endpoint");
  46. static unsigned int disable_vbi;
  47. module_param(disable_vbi, int, 0644);
  48. MODULE_PARM_DESC(disable_vbi, "disable vbi support");
  49. /* FIXME */
  50. #define em28xx_isocdbg(fmt, arg...) do {\
  51. if (core_debug) \
  52. printk(KERN_INFO "%s %s :"fmt, \
  53. dev->name, __func__ , ##arg); } while (0)
  54. /*
  55. * em28xx_read_reg_req()
  56. * reads data from the usb device specifying bRequest
  57. */
  58. int em28xx_read_reg_req_len(struct em28xx *dev, u8 req, u16 reg,
  59. char *buf, int len)
  60. {
  61. int ret;
  62. int pipe = usb_rcvctrlpipe(dev->udev, 0);
  63. if (dev->state & DEV_DISCONNECTED)
  64. return -ENODEV;
  65. if (len > URB_MAX_CTRL_SIZE)
  66. return -EINVAL;
  67. if (reg_debug) {
  68. printk(KERN_DEBUG "(pipe 0x%08x): "
  69. "IN: %02x %02x %02x %02x %02x %02x %02x %02x ",
  70. pipe,
  71. USB_DIR_IN | USB_TYPE_VENDOR | USB_RECIP_DEVICE,
  72. req, 0, 0,
  73. reg & 0xff, reg >> 8,
  74. len & 0xff, len >> 8);
  75. }
  76. mutex_lock(&dev->ctrl_urb_lock);
  77. ret = usb_control_msg(dev->udev, pipe, req,
  78. USB_DIR_IN | USB_TYPE_VENDOR | USB_RECIP_DEVICE,
  79. 0x0000, reg, dev->urb_buf, len, HZ);
  80. if (ret < 0) {
  81. if (reg_debug)
  82. printk(" failed!\n");
  83. mutex_unlock(&dev->ctrl_urb_lock);
  84. return ret;
  85. }
  86. if (len)
  87. memcpy(buf, dev->urb_buf, len);
  88. mutex_unlock(&dev->ctrl_urb_lock);
  89. if (reg_debug) {
  90. int byte;
  91. printk("<<<");
  92. for (byte = 0; byte < len; byte++)
  93. printk(" %02x", (unsigned char)buf[byte]);
  94. printk("\n");
  95. }
  96. return ret;
  97. }
  98. /*
  99. * em28xx_read_reg_req()
  100. * reads data from the usb device specifying bRequest
  101. */
  102. int em28xx_read_reg_req(struct em28xx *dev, u8 req, u16 reg)
  103. {
  104. int ret;
  105. u8 val;
  106. ret = em28xx_read_reg_req_len(dev, req, reg, &val, 1);
  107. if (ret < 0)
  108. return ret;
  109. return val;
  110. }
  111. int em28xx_read_reg(struct em28xx *dev, u16 reg)
  112. {
  113. return em28xx_read_reg_req(dev, USB_REQ_GET_STATUS, reg);
  114. }
  115. EXPORT_SYMBOL_GPL(em28xx_read_reg);
  116. /*
  117. * em28xx_write_regs_req()
  118. * sends data to the usb device, specifying bRequest
  119. */
  120. int em28xx_write_regs_req(struct em28xx *dev, u8 req, u16 reg, char *buf,
  121. int len)
  122. {
  123. int ret;
  124. int pipe = usb_sndctrlpipe(dev->udev, 0);
  125. if (dev->state & DEV_DISCONNECTED)
  126. return -ENODEV;
  127. if ((len < 1) || (len > URB_MAX_CTRL_SIZE))
  128. return -EINVAL;
  129. if (reg_debug) {
  130. int byte;
  131. printk(KERN_DEBUG "(pipe 0x%08x): "
  132. "OUT: %02x %02x %02x %02x %02x %02x %02x %02x >>>",
  133. pipe,
  134. USB_DIR_OUT | USB_TYPE_VENDOR | USB_RECIP_DEVICE,
  135. req, 0, 0,
  136. reg & 0xff, reg >> 8,
  137. len & 0xff, len >> 8);
  138. for (byte = 0; byte < len; byte++)
  139. printk(" %02x", (unsigned char)buf[byte]);
  140. printk("\n");
  141. }
  142. mutex_lock(&dev->ctrl_urb_lock);
  143. memcpy(dev->urb_buf, buf, len);
  144. ret = usb_control_msg(dev->udev, pipe, req,
  145. USB_DIR_OUT | USB_TYPE_VENDOR | USB_RECIP_DEVICE,
  146. 0x0000, reg, dev->urb_buf, len, HZ);
  147. mutex_unlock(&dev->ctrl_urb_lock);
  148. if (dev->wait_after_write)
  149. msleep(dev->wait_after_write);
  150. return ret;
  151. }
  152. int em28xx_write_regs(struct em28xx *dev, u16 reg, char *buf, int len)
  153. {
  154. int rc;
  155. rc = em28xx_write_regs_req(dev, USB_REQ_GET_STATUS, reg, buf, len);
  156. /* Stores GPO/GPIO values at the cache, if changed
  157. Only write values should be stored, since input on a GPIO
  158. register will return the input bits.
  159. Not sure what happens on reading GPO register.
  160. */
  161. if (rc >= 0) {
  162. if (reg == dev->reg_gpo_num)
  163. dev->reg_gpo = buf[0];
  164. else if (reg == dev->reg_gpio_num)
  165. dev->reg_gpio = buf[0];
  166. }
  167. return rc;
  168. }
  169. EXPORT_SYMBOL_GPL(em28xx_write_regs);
  170. /* Write a single register */
  171. int em28xx_write_reg(struct em28xx *dev, u16 reg, u8 val)
  172. {
  173. return em28xx_write_regs(dev, reg, &val, 1);
  174. }
  175. EXPORT_SYMBOL_GPL(em28xx_write_reg);
  176. /*
  177. * em28xx_write_reg_bits()
  178. * sets only some bits (specified by bitmask) of a register, by first reading
  179. * the actual value
  180. */
  181. int em28xx_write_reg_bits(struct em28xx *dev, u16 reg, u8 val,
  182. u8 bitmask)
  183. {
  184. int oldval;
  185. u8 newval;
  186. /* Uses cache for gpo/gpio registers */
  187. if (reg == dev->reg_gpo_num)
  188. oldval = dev->reg_gpo;
  189. else if (reg == dev->reg_gpio_num)
  190. oldval = dev->reg_gpio;
  191. else
  192. oldval = em28xx_read_reg(dev, reg);
  193. if (oldval < 0)
  194. return oldval;
  195. newval = (((u8) oldval) & ~bitmask) | (val & bitmask);
  196. return em28xx_write_regs(dev, reg, &newval, 1);
  197. }
  198. EXPORT_SYMBOL_GPL(em28xx_write_reg_bits);
  199. /*
  200. * em28xx_is_ac97_ready()
  201. * Checks if ac97 is ready
  202. */
  203. static int em28xx_is_ac97_ready(struct em28xx *dev)
  204. {
  205. int ret, i;
  206. /* Wait up to 50 ms for AC97 command to complete */
  207. for (i = 0; i < 10; i++, msleep(5)) {
  208. ret = em28xx_read_reg(dev, EM28XX_R43_AC97BUSY);
  209. if (ret < 0)
  210. return ret;
  211. if (!(ret & 0x01))
  212. return 0;
  213. }
  214. em28xx_warn("AC97 command still being executed: not handled properly!\n");
  215. return -EBUSY;
  216. }
  217. /*
  218. * em28xx_read_ac97()
  219. * write a 16 bit value to the specified AC97 address (LSB first!)
  220. */
  221. int em28xx_read_ac97(struct em28xx *dev, u8 reg)
  222. {
  223. int ret;
  224. u8 addr = (reg & 0x7f) | 0x80;
  225. u16 val;
  226. ret = em28xx_is_ac97_ready(dev);
  227. if (ret < 0)
  228. return ret;
  229. ret = em28xx_write_regs(dev, EM28XX_R42_AC97ADDR, &addr, 1);
  230. if (ret < 0)
  231. return ret;
  232. ret = dev->em28xx_read_reg_req_len(dev, 0, EM28XX_R40_AC97LSB,
  233. (u8 *)&val, sizeof(val));
  234. if (ret < 0)
  235. return ret;
  236. return le16_to_cpu(val);
  237. }
  238. EXPORT_SYMBOL_GPL(em28xx_read_ac97);
  239. /*
  240. * em28xx_write_ac97()
  241. * write a 16 bit value to the specified AC97 address (LSB first!)
  242. */
  243. int em28xx_write_ac97(struct em28xx *dev, u8 reg, u16 val)
  244. {
  245. int ret;
  246. u8 addr = reg & 0x7f;
  247. __le16 value;
  248. value = cpu_to_le16(val);
  249. ret = em28xx_is_ac97_ready(dev);
  250. if (ret < 0)
  251. return ret;
  252. ret = em28xx_write_regs(dev, EM28XX_R40_AC97LSB, (u8 *) &value, 2);
  253. if (ret < 0)
  254. return ret;
  255. ret = em28xx_write_regs(dev, EM28XX_R42_AC97ADDR, &addr, 1);
  256. if (ret < 0)
  257. return ret;
  258. return 0;
  259. }
  260. EXPORT_SYMBOL_GPL(em28xx_write_ac97);
  261. struct em28xx_vol_itable {
  262. enum em28xx_amux mux;
  263. u8 reg;
  264. };
  265. static struct em28xx_vol_itable inputs[] = {
  266. { EM28XX_AMUX_VIDEO, AC97_VIDEO },
  267. { EM28XX_AMUX_LINE_IN, AC97_LINE },
  268. { EM28XX_AMUX_PHONE, AC97_PHONE },
  269. { EM28XX_AMUX_MIC, AC97_MIC },
  270. { EM28XX_AMUX_CD, AC97_CD },
  271. { EM28XX_AMUX_AUX, AC97_AUX },
  272. { EM28XX_AMUX_PCM_OUT, AC97_PCM },
  273. };
  274. static int set_ac97_input(struct em28xx *dev)
  275. {
  276. int ret, i;
  277. enum em28xx_amux amux = dev->ctl_ainput;
  278. /* EM28XX_AMUX_VIDEO2 is a special case used to indicate that
  279. em28xx should point to LINE IN, while AC97 should use VIDEO
  280. */
  281. if (amux == EM28XX_AMUX_VIDEO2)
  282. amux = EM28XX_AMUX_VIDEO;
  283. /* Mute all entres but the one that were selected */
  284. for (i = 0; i < ARRAY_SIZE(inputs); i++) {
  285. if (amux == inputs[i].mux)
  286. ret = em28xx_write_ac97(dev, inputs[i].reg, 0x0808);
  287. else
  288. ret = em28xx_write_ac97(dev, inputs[i].reg, 0x8000);
  289. if (ret < 0)
  290. em28xx_warn("couldn't setup AC97 register %d\n",
  291. inputs[i].reg);
  292. }
  293. return 0;
  294. }
  295. static int em28xx_set_audio_source(struct em28xx *dev)
  296. {
  297. int ret;
  298. u8 input;
  299. if (dev->board.is_em2800) {
  300. if (dev->ctl_ainput == EM28XX_AMUX_VIDEO)
  301. input = EM2800_AUDIO_SRC_TUNER;
  302. else
  303. input = EM2800_AUDIO_SRC_LINE;
  304. ret = em28xx_write_regs(dev, EM2800_R08_AUDIOSRC, &input, 1);
  305. if (ret < 0)
  306. return ret;
  307. }
  308. if (dev->board.has_msp34xx)
  309. input = EM28XX_AUDIO_SRC_TUNER;
  310. else {
  311. switch (dev->ctl_ainput) {
  312. case EM28XX_AMUX_VIDEO:
  313. input = EM28XX_AUDIO_SRC_TUNER;
  314. break;
  315. default:
  316. input = EM28XX_AUDIO_SRC_LINE;
  317. break;
  318. }
  319. }
  320. if (dev->board.mute_gpio && dev->mute)
  321. em28xx_gpio_set(dev, dev->board.mute_gpio);
  322. else
  323. em28xx_gpio_set(dev, INPUT(dev->ctl_input)->gpio);
  324. ret = em28xx_write_reg_bits(dev, EM28XX_R0E_AUDIOSRC, input, 0xc0);
  325. if (ret < 0)
  326. return ret;
  327. msleep(5);
  328. switch (dev->audio_mode.ac97) {
  329. case EM28XX_NO_AC97:
  330. break;
  331. default:
  332. ret = set_ac97_input(dev);
  333. }
  334. return ret;
  335. }
  336. struct em28xx_vol_otable {
  337. enum em28xx_aout mux;
  338. u8 reg;
  339. };
  340. static const struct em28xx_vol_otable outputs[] = {
  341. { EM28XX_AOUT_MASTER, AC97_MASTER },
  342. { EM28XX_AOUT_LINE, AC97_HEADPHONE },
  343. { EM28XX_AOUT_MONO, AC97_MASTER_MONO },
  344. { EM28XX_AOUT_LFE, AC97_CENTER_LFE_MASTER },
  345. { EM28XX_AOUT_SURR, AC97_SURROUND_MASTER },
  346. };
  347. int em28xx_audio_analog_set(struct em28xx *dev)
  348. {
  349. int ret, i;
  350. u8 xclk;
  351. if (!dev->audio_mode.has_audio)
  352. return 0;
  353. /* It is assumed that all devices use master volume for output.
  354. It would be possible to use also line output.
  355. */
  356. if (dev->audio_mode.ac97 != EM28XX_NO_AC97) {
  357. /* Mute all outputs */
  358. for (i = 0; i < ARRAY_SIZE(outputs); i++) {
  359. ret = em28xx_write_ac97(dev, outputs[i].reg, 0x8000);
  360. if (ret < 0)
  361. em28xx_warn("couldn't setup AC97 register %d\n",
  362. outputs[i].reg);
  363. }
  364. }
  365. xclk = dev->board.xclk & 0x7f;
  366. if (!dev->mute)
  367. xclk |= EM28XX_XCLK_AUDIO_UNMUTE;
  368. ret = em28xx_write_reg(dev, EM28XX_R0F_XCLK, xclk);
  369. if (ret < 0)
  370. return ret;
  371. msleep(10);
  372. /* Selects the proper audio input */
  373. ret = em28xx_set_audio_source(dev);
  374. /* Sets volume */
  375. if (dev->audio_mode.ac97 != EM28XX_NO_AC97) {
  376. int vol;
  377. em28xx_write_ac97(dev, AC97_POWERDOWN, 0x4200);
  378. em28xx_write_ac97(dev, AC97_EXTENDED_STATUS, 0x0031);
  379. em28xx_write_ac97(dev, AC97_PCM_LR_ADC_RATE, 0xbb80);
  380. /* LSB: left channel - both channels with the same level */
  381. vol = (0x1f - dev->volume) | ((0x1f - dev->volume) << 8);
  382. /* Mute device, if needed */
  383. if (dev->mute)
  384. vol |= 0x8000;
  385. /* Sets volume */
  386. for (i = 0; i < ARRAY_SIZE(outputs); i++) {
  387. if (dev->ctl_aoutput & outputs[i].mux)
  388. ret = em28xx_write_ac97(dev, outputs[i].reg,
  389. vol);
  390. if (ret < 0)
  391. em28xx_warn("couldn't setup AC97 register %d\n",
  392. outputs[i].reg);
  393. }
  394. if (dev->ctl_aoutput & EM28XX_AOUT_PCM_IN) {
  395. int sel = ac97_return_record_select(dev->ctl_aoutput);
  396. /* Use the same input for both left and right
  397. channels */
  398. sel |= (sel << 8);
  399. em28xx_write_ac97(dev, AC97_REC_SEL, sel);
  400. }
  401. }
  402. return ret;
  403. }
  404. EXPORT_SYMBOL_GPL(em28xx_audio_analog_set);
  405. int em28xx_audio_setup(struct em28xx *dev)
  406. {
  407. int vid1, vid2, feat, cfg;
  408. u32 vid;
  409. if (dev->chip_id == CHIP_ID_EM2870 || dev->chip_id == CHIP_ID_EM2874
  410. || dev->chip_id == CHIP_ID_EM28174) {
  411. /* Digital only device - don't load any alsa module */
  412. dev->audio_mode.has_audio = false;
  413. dev->has_audio_class = false;
  414. dev->has_alsa_audio = false;
  415. return 0;
  416. }
  417. dev->audio_mode.has_audio = true;
  418. /* See how this device is configured */
  419. cfg = em28xx_read_reg(dev, EM28XX_R00_CHIPCFG);
  420. em28xx_info("Config register raw data: 0x%02x\n", cfg);
  421. if (cfg < 0) {
  422. /* Register read error? */
  423. cfg = EM28XX_CHIPCFG_AC97; /* Be conservative */
  424. } else if ((cfg & EM28XX_CHIPCFG_AUDIOMASK) == 0x00) {
  425. /* The device doesn't have vendor audio at all */
  426. dev->has_alsa_audio = false;
  427. dev->audio_mode.has_audio = false;
  428. return 0;
  429. } else if ((cfg & EM28XX_CHIPCFG_AUDIOMASK) ==
  430. EM28XX_CHIPCFG_I2S_3_SAMPRATES) {
  431. em28xx_info("I2S Audio (3 sample rates)\n");
  432. dev->audio_mode.i2s_3rates = 1;
  433. } else if ((cfg & EM28XX_CHIPCFG_AUDIOMASK) ==
  434. EM28XX_CHIPCFG_I2S_5_SAMPRATES) {
  435. em28xx_info("I2S Audio (5 sample rates)\n");
  436. dev->audio_mode.i2s_5rates = 1;
  437. }
  438. if ((cfg & EM28XX_CHIPCFG_AUDIOMASK) != EM28XX_CHIPCFG_AC97) {
  439. /* Skip the code that does AC97 vendor detection */
  440. dev->audio_mode.ac97 = EM28XX_NO_AC97;
  441. goto init_audio;
  442. }
  443. dev->audio_mode.ac97 = EM28XX_AC97_OTHER;
  444. vid1 = em28xx_read_ac97(dev, AC97_VENDOR_ID1);
  445. if (vid1 < 0) {
  446. /*
  447. * Device likely doesn't support AC97
  448. * Note: (some) em2800 devices without eeprom reports 0x91 on
  449. * CHIPCFG register, even not having an AC97 chip
  450. */
  451. em28xx_warn("AC97 chip type couldn't be determined\n");
  452. dev->audio_mode.ac97 = EM28XX_NO_AC97;
  453. dev->has_alsa_audio = false;
  454. dev->audio_mode.has_audio = false;
  455. goto init_audio;
  456. }
  457. vid2 = em28xx_read_ac97(dev, AC97_VENDOR_ID2);
  458. if (vid2 < 0)
  459. goto init_audio;
  460. vid = vid1 << 16 | vid2;
  461. dev->audio_mode.ac97_vendor_id = vid;
  462. em28xx_warn("AC97 vendor ID = 0x%08x\n", vid);
  463. feat = em28xx_read_ac97(dev, AC97_RESET);
  464. if (feat < 0)
  465. goto init_audio;
  466. dev->audio_mode.ac97_feat = feat;
  467. em28xx_warn("AC97 features = 0x%04x\n", feat);
  468. /* Try to identify what audio processor we have */
  469. if (((vid == 0xffffffff) || (vid == 0x83847650)) && (feat == 0x6a90))
  470. dev->audio_mode.ac97 = EM28XX_AC97_EM202;
  471. else if ((vid >> 8) == 0x838476)
  472. dev->audio_mode.ac97 = EM28XX_AC97_SIGMATEL;
  473. init_audio:
  474. /* Reports detected AC97 processor */
  475. switch (dev->audio_mode.ac97) {
  476. case EM28XX_NO_AC97:
  477. em28xx_info("No AC97 audio processor\n");
  478. break;
  479. case EM28XX_AC97_EM202:
  480. em28xx_info("Empia 202 AC97 audio processor detected\n");
  481. break;
  482. case EM28XX_AC97_SIGMATEL:
  483. em28xx_info("Sigmatel audio processor detected(stac 97%02x)\n",
  484. dev->audio_mode.ac97_vendor_id & 0xff);
  485. break;
  486. case EM28XX_AC97_OTHER:
  487. em28xx_warn("Unknown AC97 audio processor detected!\n");
  488. break;
  489. default:
  490. break;
  491. }
  492. return em28xx_audio_analog_set(dev);
  493. }
  494. EXPORT_SYMBOL_GPL(em28xx_audio_setup);
  495. int em28xx_colorlevels_set_default(struct em28xx *dev)
  496. {
  497. em28xx_write_reg(dev, EM28XX_R20_YGAIN, 0x10); /* contrast */
  498. em28xx_write_reg(dev, EM28XX_R21_YOFFSET, 0x00); /* brightness */
  499. em28xx_write_reg(dev, EM28XX_R22_UVGAIN, 0x10); /* saturation */
  500. em28xx_write_reg(dev, EM28XX_R23_UOFFSET, 0x00);
  501. em28xx_write_reg(dev, EM28XX_R24_VOFFSET, 0x00);
  502. em28xx_write_reg(dev, EM28XX_R25_SHARPNESS, 0x00);
  503. em28xx_write_reg(dev, EM28XX_R14_GAMMA, 0x20);
  504. em28xx_write_reg(dev, EM28XX_R15_RGAIN, 0x20);
  505. em28xx_write_reg(dev, EM28XX_R16_GGAIN, 0x20);
  506. em28xx_write_reg(dev, EM28XX_R17_BGAIN, 0x20);
  507. em28xx_write_reg(dev, EM28XX_R18_ROFFSET, 0x00);
  508. em28xx_write_reg(dev, EM28XX_R19_GOFFSET, 0x00);
  509. return em28xx_write_reg(dev, EM28XX_R1A_BOFFSET, 0x00);
  510. }
  511. int em28xx_capture_start(struct em28xx *dev, int start)
  512. {
  513. int rc;
  514. if (dev->chip_id == CHIP_ID_EM2874 ||
  515. dev->chip_id == CHIP_ID_EM2884 ||
  516. dev->chip_id == CHIP_ID_EM28174) {
  517. /* The Transport Stream Enable Register moved in em2874 */
  518. if (!start) {
  519. rc = em28xx_write_reg_bits(dev, EM2874_R5F_TS_ENABLE,
  520. 0x00,
  521. EM2874_TS1_CAPTURE_ENABLE);
  522. return rc;
  523. }
  524. /* Enable Transport Stream */
  525. rc = em28xx_write_reg_bits(dev, EM2874_R5F_TS_ENABLE,
  526. EM2874_TS1_CAPTURE_ENABLE,
  527. EM2874_TS1_CAPTURE_ENABLE);
  528. return rc;
  529. }
  530. /* FIXME: which is the best order? */
  531. /* video registers are sampled by VREF */
  532. rc = em28xx_write_reg_bits(dev, EM28XX_R0C_USBSUSP,
  533. start ? 0x10 : 0x00, 0x10);
  534. if (rc < 0)
  535. return rc;
  536. if (!start) {
  537. /* disable video capture */
  538. rc = em28xx_write_reg(dev, EM28XX_R12_VINENABLE, 0x27);
  539. return rc;
  540. }
  541. if (dev->board.is_webcam)
  542. rc = em28xx_write_reg(dev, 0x13, 0x0c);
  543. /* enable video capture */
  544. rc = em28xx_write_reg(dev, 0x48, 0x00);
  545. if (dev->mode == EM28XX_ANALOG_MODE)
  546. rc = em28xx_write_reg(dev, EM28XX_R12_VINENABLE, 0x67);
  547. else
  548. rc = em28xx_write_reg(dev, EM28XX_R12_VINENABLE, 0x37);
  549. msleep(6);
  550. return rc;
  551. }
  552. int em28xx_vbi_supported(struct em28xx *dev)
  553. {
  554. /* Modprobe option to manually disable */
  555. if (disable_vbi == 1)
  556. return 0;
  557. if (dev->chip_id == CHIP_ID_EM2860 ||
  558. dev->chip_id == CHIP_ID_EM2883)
  559. return 1;
  560. /* Version of em28xx that does not support VBI */
  561. return 0;
  562. }
  563. int em28xx_set_outfmt(struct em28xx *dev)
  564. {
  565. int ret;
  566. u8 vinctrl;
  567. ret = em28xx_write_reg_bits(dev, EM28XX_R27_OUTFMT,
  568. dev->format->reg | 0x20, 0xff);
  569. if (ret < 0)
  570. return ret;
  571. ret = em28xx_write_reg(dev, EM28XX_R10_VINMODE, dev->vinmode);
  572. if (ret < 0)
  573. return ret;
  574. vinctrl = dev->vinctl;
  575. if (em28xx_vbi_supported(dev) == 1) {
  576. vinctrl |= EM28XX_VINCTRL_VBI_RAW;
  577. em28xx_write_reg(dev, EM28XX_R34_VBI_START_H, 0x00);
  578. em28xx_write_reg(dev, EM28XX_R36_VBI_WIDTH, dev->vbi_width/4);
  579. em28xx_write_reg(dev, EM28XX_R37_VBI_HEIGHT, dev->vbi_height);
  580. if (dev->norm & V4L2_STD_525_60) {
  581. /* NTSC */
  582. em28xx_write_reg(dev, EM28XX_R35_VBI_START_V, 0x09);
  583. } else if (dev->norm & V4L2_STD_625_50) {
  584. /* PAL */
  585. em28xx_write_reg(dev, EM28XX_R35_VBI_START_V, 0x07);
  586. }
  587. }
  588. return em28xx_write_reg(dev, EM28XX_R11_VINCTRL, vinctrl);
  589. }
  590. static int em28xx_accumulator_set(struct em28xx *dev, u8 xmin, u8 xmax,
  591. u8 ymin, u8 ymax)
  592. {
  593. em28xx_coredbg("em28xx Scale: (%d,%d)-(%d,%d)\n",
  594. xmin, ymin, xmax, ymax);
  595. em28xx_write_regs(dev, EM28XX_R28_XMIN, &xmin, 1);
  596. em28xx_write_regs(dev, EM28XX_R29_XMAX, &xmax, 1);
  597. em28xx_write_regs(dev, EM28XX_R2A_YMIN, &ymin, 1);
  598. return em28xx_write_regs(dev, EM28XX_R2B_YMAX, &ymax, 1);
  599. }
  600. static int em28xx_capture_area_set(struct em28xx *dev, u8 hstart, u8 vstart,
  601. u16 width, u16 height)
  602. {
  603. u8 cwidth = width;
  604. u8 cheight = height;
  605. u8 overflow = (height >> 7 & 0x02) | (width >> 8 & 0x01);
  606. em28xx_coredbg("em28xx Area Set: (%d,%d)\n",
  607. (width | (overflow & 2) << 7),
  608. (height | (overflow & 1) << 8));
  609. em28xx_write_regs(dev, EM28XX_R1C_HSTART, &hstart, 1);
  610. em28xx_write_regs(dev, EM28XX_R1D_VSTART, &vstart, 1);
  611. em28xx_write_regs(dev, EM28XX_R1E_CWIDTH, &cwidth, 1);
  612. em28xx_write_regs(dev, EM28XX_R1F_CHEIGHT, &cheight, 1);
  613. return em28xx_write_regs(dev, EM28XX_R1B_OFLOW, &overflow, 1);
  614. }
  615. static int em28xx_scaler_set(struct em28xx *dev, u16 h, u16 v)
  616. {
  617. u8 mode;
  618. /* the em2800 scaler only supports scaling down to 50% */
  619. if (dev->board.is_em2800) {
  620. mode = (v ? 0x20 : 0x00) | (h ? 0x10 : 0x00);
  621. } else {
  622. u8 buf[2];
  623. buf[0] = h;
  624. buf[1] = h >> 8;
  625. em28xx_write_regs(dev, EM28XX_R30_HSCALELOW, (char *)buf, 2);
  626. buf[0] = v;
  627. buf[1] = v >> 8;
  628. em28xx_write_regs(dev, EM28XX_R32_VSCALELOW, (char *)buf, 2);
  629. /* it seems that both H and V scalers must be active
  630. to work correctly */
  631. mode = (h || v) ? 0x30 : 0x00;
  632. }
  633. return em28xx_write_reg_bits(dev, EM28XX_R26_COMPR, mode, 0x30);
  634. }
  635. /* FIXME: this only function read values from dev */
  636. int em28xx_resolution_set(struct em28xx *dev)
  637. {
  638. int width, height;
  639. width = norm_maxw(dev);
  640. height = norm_maxh(dev);
  641. /* Properly setup VBI */
  642. dev->vbi_width = 720;
  643. if (dev->norm & V4L2_STD_525_60)
  644. dev->vbi_height = 12;
  645. else
  646. dev->vbi_height = 18;
  647. em28xx_set_outfmt(dev);
  648. em28xx_accumulator_set(dev, 1, (width - 4) >> 2, 1, (height - 4) >> 2);
  649. /* If we don't set the start position to 2 in VBI mode, we end up
  650. with line 20/21 being YUYV encoded instead of being in 8-bit
  651. greyscale. The core of the issue is that line 21 (and line 23 for
  652. PAL WSS) are inside of active video region, and as a result they
  653. get the pixelformatting associated with that area. So by cropping
  654. it out, we end up with the same format as the rest of the VBI
  655. region */
  656. if (em28xx_vbi_supported(dev) == 1)
  657. em28xx_capture_area_set(dev, 0, 2, width >> 2, height >> 2);
  658. else
  659. em28xx_capture_area_set(dev, 0, 0, width >> 2, height >> 2);
  660. return em28xx_scaler_set(dev, dev->hscale, dev->vscale);
  661. }
  662. int em28xx_set_alternate(struct em28xx *dev)
  663. {
  664. int errCode, prev_alt = dev->alt;
  665. int i;
  666. unsigned int min_pkt_size = dev->width * 2 + 4;
  667. /*
  668. * alt = 0 is used only for control messages, so, only values
  669. * greater than 0 can be used for streaming.
  670. */
  671. if (alt && alt < dev->num_alt) {
  672. em28xx_coredbg("alternate forced to %d\n", dev->alt);
  673. dev->alt = alt;
  674. goto set_alt;
  675. }
  676. /* When image size is bigger than a certain value,
  677. the frame size should be increased, otherwise, only
  678. green screen will be received.
  679. */
  680. if (dev->width * 2 * dev->height > 720 * 240 * 2)
  681. min_pkt_size *= 2;
  682. for (i = 0; i < dev->num_alt; i++) {
  683. /* stop when the selected alt setting offers enough bandwidth */
  684. if (dev->alt_max_pkt_size[i] >= min_pkt_size) {
  685. dev->alt = i;
  686. break;
  687. /* otherwise make sure that we end up with the maximum bandwidth
  688. because the min_pkt_size equation might be wrong...
  689. */
  690. } else if (dev->alt_max_pkt_size[i] >
  691. dev->alt_max_pkt_size[dev->alt])
  692. dev->alt = i;
  693. }
  694. set_alt:
  695. if (dev->alt != prev_alt) {
  696. em28xx_coredbg("minimum isoc packet size: %u (alt=%d)\n",
  697. min_pkt_size, dev->alt);
  698. dev->max_pkt_size = dev->alt_max_pkt_size[dev->alt];
  699. em28xx_coredbg("setting alternate %d with wMaxPacketSize=%u\n",
  700. dev->alt, dev->max_pkt_size);
  701. errCode = usb_set_interface(dev->udev, 0, dev->alt);
  702. if (errCode < 0) {
  703. em28xx_errdev("cannot change alternate number to %d (error=%i)\n",
  704. dev->alt, errCode);
  705. return errCode;
  706. }
  707. }
  708. return 0;
  709. }
  710. int em28xx_gpio_set(struct em28xx *dev, struct em28xx_reg_seq *gpio)
  711. {
  712. int rc = 0;
  713. if (!gpio)
  714. return rc;
  715. if (dev->mode != EM28XX_SUSPEND) {
  716. em28xx_write_reg(dev, 0x48, 0x00);
  717. if (dev->mode == EM28XX_ANALOG_MODE)
  718. em28xx_write_reg(dev, EM28XX_R12_VINENABLE, 0x67);
  719. else
  720. em28xx_write_reg(dev, EM28XX_R12_VINENABLE, 0x37);
  721. msleep(6);
  722. }
  723. /* Send GPIO reset sequences specified at board entry */
  724. while (gpio->sleep >= 0) {
  725. if (gpio->reg >= 0) {
  726. rc = em28xx_write_reg_bits(dev,
  727. gpio->reg,
  728. gpio->val,
  729. gpio->mask);
  730. if (rc < 0)
  731. return rc;
  732. }
  733. if (gpio->sleep > 0)
  734. msleep(gpio->sleep);
  735. gpio++;
  736. }
  737. return rc;
  738. }
  739. EXPORT_SYMBOL_GPL(em28xx_gpio_set);
  740. int em28xx_set_mode(struct em28xx *dev, enum em28xx_mode set_mode)
  741. {
  742. if (dev->mode == set_mode)
  743. return 0;
  744. if (set_mode == EM28XX_SUSPEND) {
  745. dev->mode = set_mode;
  746. /* FIXME: add suspend support for ac97 */
  747. return em28xx_gpio_set(dev, dev->board.suspend_gpio);
  748. }
  749. dev->mode = set_mode;
  750. if (dev->mode == EM28XX_DIGITAL_MODE)
  751. return em28xx_gpio_set(dev, dev->board.dvb_gpio);
  752. else
  753. return em28xx_gpio_set(dev, INPUT(dev->ctl_input)->gpio);
  754. }
  755. EXPORT_SYMBOL_GPL(em28xx_set_mode);
  756. /* ------------------------------------------------------------------
  757. URB control
  758. ------------------------------------------------------------------*/
  759. /*
  760. * IRQ callback, called by URB callback
  761. */
  762. static void em28xx_irq_callback(struct urb *urb)
  763. {
  764. struct em28xx *dev = urb->context;
  765. int i;
  766. switch (urb->status) {
  767. case 0: /* success */
  768. case -ETIMEDOUT: /* NAK */
  769. break;
  770. case -ECONNRESET: /* kill */
  771. case -ENOENT:
  772. case -ESHUTDOWN:
  773. return;
  774. default: /* error */
  775. em28xx_isocdbg("urb completition error %d.\n", urb->status);
  776. break;
  777. }
  778. /* Copy data from URB */
  779. spin_lock(&dev->slock);
  780. dev->isoc_ctl.isoc_copy(dev, urb);
  781. spin_unlock(&dev->slock);
  782. /* Reset urb buffers */
  783. for (i = 0; i < urb->number_of_packets; i++) {
  784. urb->iso_frame_desc[i].status = 0;
  785. urb->iso_frame_desc[i].actual_length = 0;
  786. }
  787. urb->status = 0;
  788. urb->status = usb_submit_urb(urb, GFP_ATOMIC);
  789. if (urb->status) {
  790. em28xx_isocdbg("urb resubmit failed (error=%i)\n",
  791. urb->status);
  792. }
  793. }
  794. /*
  795. * Stop and Deallocate URBs
  796. */
  797. void em28xx_uninit_isoc(struct em28xx *dev, enum em28xx_mode mode)
  798. {
  799. struct urb *urb;
  800. struct em28xx_usb_isoc_bufs *isoc_bufs;
  801. int i;
  802. em28xx_isocdbg("em28xx: called em28xx_uninit_isoc in mode %d\n", mode);
  803. if (mode == EM28XX_DIGITAL_MODE)
  804. isoc_bufs = &dev->isoc_ctl.digital_bufs;
  805. else
  806. isoc_bufs = &dev->isoc_ctl.analog_bufs;
  807. for (i = 0; i < isoc_bufs->num_bufs; i++) {
  808. urb = isoc_bufs->urb[i];
  809. if (urb) {
  810. if (!irqs_disabled())
  811. usb_kill_urb(urb);
  812. else
  813. usb_unlink_urb(urb);
  814. if (isoc_bufs->transfer_buffer[i]) {
  815. usb_free_coherent(dev->udev,
  816. urb->transfer_buffer_length,
  817. isoc_bufs->transfer_buffer[i],
  818. urb->transfer_dma);
  819. }
  820. usb_free_urb(urb);
  821. isoc_bufs->urb[i] = NULL;
  822. }
  823. isoc_bufs->transfer_buffer[i] = NULL;
  824. }
  825. kfree(isoc_bufs->urb);
  826. kfree(isoc_bufs->transfer_buffer);
  827. isoc_bufs->urb = NULL;
  828. isoc_bufs->transfer_buffer = NULL;
  829. isoc_bufs->num_bufs = 0;
  830. em28xx_capture_start(dev, 0);
  831. }
  832. EXPORT_SYMBOL_GPL(em28xx_uninit_isoc);
  833. /*
  834. * Stop URBs
  835. */
  836. void em28xx_stop_urbs(struct em28xx *dev)
  837. {
  838. int i;
  839. struct urb *urb;
  840. struct em28xx_usb_isoc_bufs *isoc_bufs = &dev->isoc_ctl.digital_bufs;
  841. em28xx_isocdbg("em28xx: called em28xx_stop_urbs\n");
  842. for (i = 0; i < isoc_bufs->num_bufs; i++) {
  843. urb = isoc_bufs->urb[i];
  844. if (urb) {
  845. if (!irqs_disabled())
  846. usb_kill_urb(urb);
  847. else
  848. usb_unlink_urb(urb);
  849. }
  850. }
  851. em28xx_capture_start(dev, 0);
  852. }
  853. EXPORT_SYMBOL_GPL(em28xx_stop_urbs);
  854. /*
  855. * Allocate URBs
  856. */
  857. int em28xx_alloc_isoc(struct em28xx *dev, enum em28xx_mode mode,
  858. int max_packets, int num_bufs, int max_pkt_size)
  859. {
  860. struct em28xx_usb_isoc_bufs *isoc_bufs;
  861. int i;
  862. int sb_size, pipe;
  863. struct urb *urb;
  864. int j, k;
  865. em28xx_isocdbg("em28xx: called em28xx_alloc_isoc in mode %d\n", mode);
  866. if (mode == EM28XX_DIGITAL_MODE)
  867. isoc_bufs = &dev->isoc_ctl.digital_bufs;
  868. else
  869. isoc_bufs = &dev->isoc_ctl.analog_bufs;
  870. /* De-allocates all pending stuff */
  871. em28xx_uninit_isoc(dev, mode);
  872. isoc_bufs->num_bufs = num_bufs;
  873. isoc_bufs->urb = kzalloc(sizeof(void *)*num_bufs, GFP_KERNEL);
  874. if (!isoc_bufs->urb) {
  875. em28xx_errdev("cannot alloc memory for usb buffers\n");
  876. return -ENOMEM;
  877. }
  878. isoc_bufs->transfer_buffer = kzalloc(sizeof(void *)*num_bufs,
  879. GFP_KERNEL);
  880. if (!isoc_bufs->transfer_buffer) {
  881. em28xx_errdev("cannot allocate memory for usb transfer\n");
  882. kfree(isoc_bufs->urb);
  883. return -ENOMEM;
  884. }
  885. isoc_bufs->max_pkt_size = max_pkt_size;
  886. isoc_bufs->num_packets = max_packets;
  887. dev->isoc_ctl.vid_buf = NULL;
  888. dev->isoc_ctl.vbi_buf = NULL;
  889. sb_size = isoc_bufs->num_packets * isoc_bufs->max_pkt_size;
  890. /* allocate urbs and transfer buffers */
  891. for (i = 0; i < isoc_bufs->num_bufs; i++) {
  892. urb = usb_alloc_urb(isoc_bufs->num_packets, GFP_KERNEL);
  893. if (!urb) {
  894. em28xx_err("cannot alloc isoc_ctl.urb %i\n", i);
  895. em28xx_uninit_isoc(dev, mode);
  896. return -ENOMEM;
  897. }
  898. isoc_bufs->urb[i] = urb;
  899. isoc_bufs->transfer_buffer[i] = usb_alloc_coherent(dev->udev,
  900. sb_size, GFP_KERNEL, &urb->transfer_dma);
  901. if (!isoc_bufs->transfer_buffer[i]) {
  902. em28xx_err("unable to allocate %i bytes for transfer"
  903. " buffer %i%s\n",
  904. sb_size, i,
  905. in_interrupt() ? " while in int" : "");
  906. em28xx_uninit_isoc(dev, mode);
  907. return -ENOMEM;
  908. }
  909. memset(isoc_bufs->transfer_buffer[i], 0, sb_size);
  910. /* FIXME: this is a hack - should be
  911. 'desc.bEndpointAddress & USB_ENDPOINT_NUMBER_MASK'
  912. should also be using 'desc.bInterval'
  913. */
  914. pipe = usb_rcvisocpipe(dev->udev,
  915. mode == EM28XX_ANALOG_MODE ?
  916. EM28XX_EP_ANALOG : EM28XX_EP_DIGITAL);
  917. usb_fill_int_urb(urb, dev->udev, pipe,
  918. isoc_bufs->transfer_buffer[i], sb_size,
  919. em28xx_irq_callback, dev, 1);
  920. urb->number_of_packets = isoc_bufs->num_packets;
  921. urb->transfer_flags = URB_ISO_ASAP | URB_NO_TRANSFER_DMA_MAP;
  922. k = 0;
  923. for (j = 0; j < isoc_bufs->num_packets; j++) {
  924. urb->iso_frame_desc[j].offset = k;
  925. urb->iso_frame_desc[j].length =
  926. isoc_bufs->max_pkt_size;
  927. k += isoc_bufs->max_pkt_size;
  928. }
  929. }
  930. return 0;
  931. }
  932. EXPORT_SYMBOL_GPL(em28xx_alloc_isoc);
  933. /*
  934. * Allocate URBs and start IRQ
  935. */
  936. int em28xx_init_isoc(struct em28xx *dev, enum em28xx_mode mode,
  937. int max_packets, int num_bufs, int max_pkt_size,
  938. int (*isoc_copy) (struct em28xx *dev, struct urb *urb))
  939. {
  940. struct em28xx_dmaqueue *dma_q = &dev->vidq;
  941. struct em28xx_dmaqueue *vbi_dma_q = &dev->vbiq;
  942. struct em28xx_usb_isoc_bufs *isoc_bufs;
  943. int i;
  944. int rc;
  945. int alloc;
  946. em28xx_isocdbg("em28xx: called em28xx_init_isoc in mode %d\n", mode);
  947. dev->isoc_ctl.isoc_copy = isoc_copy;
  948. if (mode == EM28XX_DIGITAL_MODE) {
  949. isoc_bufs = &dev->isoc_ctl.digital_bufs;
  950. /* no need to free/alloc isoc buffers in digital mode */
  951. alloc = 0;
  952. } else {
  953. isoc_bufs = &dev->isoc_ctl.analog_bufs;
  954. alloc = 1;
  955. }
  956. if (alloc) {
  957. rc = em28xx_alloc_isoc(dev, mode, max_packets,
  958. num_bufs, max_pkt_size);
  959. if (rc)
  960. return rc;
  961. }
  962. init_waitqueue_head(&dma_q->wq);
  963. init_waitqueue_head(&vbi_dma_q->wq);
  964. em28xx_capture_start(dev, 1);
  965. /* submit urbs and enables IRQ */
  966. for (i = 0; i < isoc_bufs->num_bufs; i++) {
  967. rc = usb_submit_urb(isoc_bufs->urb[i], GFP_ATOMIC);
  968. if (rc) {
  969. em28xx_err("submit of urb %i failed (error=%i)\n", i,
  970. rc);
  971. em28xx_uninit_isoc(dev, mode);
  972. return rc;
  973. }
  974. }
  975. return 0;
  976. }
  977. EXPORT_SYMBOL_GPL(em28xx_init_isoc);
  978. /*
  979. * em28xx_wake_i2c()
  980. * configure i2c attached devices
  981. */
  982. void em28xx_wake_i2c(struct em28xx *dev)
  983. {
  984. v4l2_device_call_all(&dev->v4l2_dev, 0, core, reset, 0);
  985. v4l2_device_call_all(&dev->v4l2_dev, 0, video, s_routing,
  986. INPUT(dev->ctl_input)->vmux, 0, 0);
  987. v4l2_device_call_all(&dev->v4l2_dev, 0, video, s_stream, 0);
  988. }
  989. /*
  990. * Device control list
  991. */
  992. static LIST_HEAD(em28xx_devlist);
  993. static DEFINE_MUTEX(em28xx_devlist_mutex);
  994. /*
  995. * Extension interface
  996. */
  997. static LIST_HEAD(em28xx_extension_devlist);
  998. int em28xx_register_extension(struct em28xx_ops *ops)
  999. {
  1000. struct em28xx *dev = NULL;
  1001. mutex_lock(&em28xx_devlist_mutex);
  1002. list_add_tail(&ops->next, &em28xx_extension_devlist);
  1003. list_for_each_entry(dev, &em28xx_devlist, devlist) {
  1004. ops->init(dev);
  1005. }
  1006. mutex_unlock(&em28xx_devlist_mutex);
  1007. printk(KERN_INFO "Em28xx: Initialized (%s) extension\n", ops->name);
  1008. return 0;
  1009. }
  1010. EXPORT_SYMBOL(em28xx_register_extension);
  1011. void em28xx_unregister_extension(struct em28xx_ops *ops)
  1012. {
  1013. struct em28xx *dev = NULL;
  1014. mutex_lock(&em28xx_devlist_mutex);
  1015. list_for_each_entry(dev, &em28xx_devlist, devlist) {
  1016. ops->fini(dev);
  1017. }
  1018. list_del(&ops->next);
  1019. mutex_unlock(&em28xx_devlist_mutex);
  1020. printk(KERN_INFO "Em28xx: Removed (%s) extension\n", ops->name);
  1021. }
  1022. EXPORT_SYMBOL(em28xx_unregister_extension);
  1023. void em28xx_init_extension(struct em28xx *dev)
  1024. {
  1025. const struct em28xx_ops *ops = NULL;
  1026. mutex_lock(&em28xx_devlist_mutex);
  1027. list_add_tail(&dev->devlist, &em28xx_devlist);
  1028. list_for_each_entry(ops, &em28xx_extension_devlist, next) {
  1029. if (ops->init)
  1030. ops->init(dev);
  1031. }
  1032. mutex_unlock(&em28xx_devlist_mutex);
  1033. }
  1034. void em28xx_close_extension(struct em28xx *dev)
  1035. {
  1036. const struct em28xx_ops *ops = NULL;
  1037. mutex_lock(&em28xx_devlist_mutex);
  1038. list_for_each_entry(ops, &em28xx_extension_devlist, next) {
  1039. if (ops->fini)
  1040. ops->fini(dev);
  1041. }
  1042. list_del(&dev->devlist);
  1043. mutex_unlock(&em28xx_devlist_mutex);
  1044. }