v4l2-common.c 27 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936
  1. /*
  2. * Video for Linux Two
  3. *
  4. * A generic video device interface for the LINUX operating system
  5. * using a set of device structures/vectors for low level operations.
  6. *
  7. * This file replaces the videodev.c file that comes with the
  8. * regular kernel distribution.
  9. *
  10. * This program is free software; you can redistribute it and/or
  11. * modify it under the terms of the GNU General Public License
  12. * as published by the Free Software Foundation; either version
  13. * 2 of the License, or (at your option) any later version.
  14. *
  15. * Author: Bill Dirks <bdirks@pacbell.net>
  16. * based on code by Alan Cox, <alan@cymru.net>
  17. *
  18. */
  19. /*
  20. * Video capture interface for Linux
  21. *
  22. * A generic video device interface for the LINUX operating system
  23. * using a set of device structures/vectors for low level operations.
  24. *
  25. * This program is free software; you can redistribute it and/or
  26. * modify it under the terms of the GNU General Public License
  27. * as published by the Free Software Foundation; either version
  28. * 2 of the License, or (at your option) any later version.
  29. *
  30. * Author: Alan Cox, <alan@redhat.com>
  31. *
  32. * Fixes:
  33. */
  34. /*
  35. * Video4linux 1/2 integration by Justin Schoeman
  36. * <justin@suntiger.ee.up.ac.za>
  37. * 2.4 PROCFS support ported from 2.4 kernels by
  38. * Iñaki García Etxebarria <garetxe@euskalnet.net>
  39. * Makefile fix by "W. Michael Petullo" <mike@flyn.org>
  40. * 2.4 devfs support ported from 2.4 kernels by
  41. * Dan Merillat <dan@merillat.org>
  42. * Added Gerd Knorrs v4l1 enhancements (Justin Schoeman)
  43. */
  44. #include <linux/config.h>
  45. #include <linux/module.h>
  46. #include <linux/types.h>
  47. #include <linux/kernel.h>
  48. #include <linux/sched.h>
  49. #include <linux/smp_lock.h>
  50. #include <linux/mm.h>
  51. #include <linux/string.h>
  52. #include <linux/errno.h>
  53. #include <asm/uaccess.h>
  54. #include <asm/system.h>
  55. #include <asm/pgtable.h>
  56. #include <asm/io.h>
  57. #include <asm/div64.h>
  58. #include <linux/video_decoder.h>
  59. #include <media/v4l2-common.h>
  60. #ifdef CONFIG_KMOD
  61. #include <linux/kmod.h>
  62. #endif
  63. #if defined(CONFIG_UST) || defined(CONFIG_UST_MODULE)
  64. #include <linux/ust.h>
  65. #endif
  66. #include <linux/videodev.h>
  67. MODULE_AUTHOR("Bill Dirks, Justin Schoeman, Gerd Knorr");
  68. MODULE_DESCRIPTION("misc helper functions for v4l2 device drivers");
  69. MODULE_LICENSE("GPL");
  70. /*
  71. *
  72. * V 4 L 2 D R I V E R H E L P E R A P I
  73. *
  74. */
  75. /*
  76. * Video Standard Operations (contributed by Michael Schimek)
  77. */
  78. /* Fill in the fields of a v4l2_standard structure according to the
  79. 'id' and 'transmission' parameters. Returns negative on error. */
  80. int v4l2_video_std_construct(struct v4l2_standard *vs,
  81. int id, char *name)
  82. {
  83. u32 index = vs->index;
  84. memset(vs, 0, sizeof(struct v4l2_standard));
  85. vs->index = index;
  86. vs->id = id;
  87. if (id & V4L2_STD_525_60) {
  88. vs->frameperiod.numerator = 1001;
  89. vs->frameperiod.denominator = 30000;
  90. vs->framelines = 525;
  91. } else {
  92. vs->frameperiod.numerator = 1;
  93. vs->frameperiod.denominator = 25;
  94. vs->framelines = 625;
  95. }
  96. strlcpy(vs->name,name,sizeof(vs->name));
  97. return 0;
  98. }
  99. /* ----------------------------------------------------------------- */
  100. /* priority handling */
  101. #define V4L2_PRIO_VALID(val) (val == V4L2_PRIORITY_BACKGROUND || \
  102. val == V4L2_PRIORITY_INTERACTIVE || \
  103. val == V4L2_PRIORITY_RECORD)
  104. int v4l2_prio_init(struct v4l2_prio_state *global)
  105. {
  106. memset(global,0,sizeof(*global));
  107. return 0;
  108. }
  109. int v4l2_prio_change(struct v4l2_prio_state *global, enum v4l2_priority *local,
  110. enum v4l2_priority new)
  111. {
  112. if (!V4L2_PRIO_VALID(new))
  113. return -EINVAL;
  114. if (*local == new)
  115. return 0;
  116. atomic_inc(&global->prios[new]);
  117. if (V4L2_PRIO_VALID(*local))
  118. atomic_dec(&global->prios[*local]);
  119. *local = new;
  120. return 0;
  121. }
  122. int v4l2_prio_open(struct v4l2_prio_state *global, enum v4l2_priority *local)
  123. {
  124. return v4l2_prio_change(global,local,V4L2_PRIORITY_DEFAULT);
  125. }
  126. int v4l2_prio_close(struct v4l2_prio_state *global, enum v4l2_priority *local)
  127. {
  128. if (V4L2_PRIO_VALID(*local))
  129. atomic_dec(&global->prios[*local]);
  130. return 0;
  131. }
  132. enum v4l2_priority v4l2_prio_max(struct v4l2_prio_state *global)
  133. {
  134. if (atomic_read(&global->prios[V4L2_PRIORITY_RECORD]) > 0)
  135. return V4L2_PRIORITY_RECORD;
  136. if (atomic_read(&global->prios[V4L2_PRIORITY_INTERACTIVE]) > 0)
  137. return V4L2_PRIORITY_INTERACTIVE;
  138. if (atomic_read(&global->prios[V4L2_PRIORITY_BACKGROUND]) > 0)
  139. return V4L2_PRIORITY_BACKGROUND;
  140. return V4L2_PRIORITY_UNSET;
  141. }
  142. int v4l2_prio_check(struct v4l2_prio_state *global, enum v4l2_priority *local)
  143. {
  144. if (*local < v4l2_prio_max(global))
  145. return -EBUSY;
  146. return 0;
  147. }
  148. /* ----------------------------------------------------------------- */
  149. /* some arrays for pretty-printing debug messages of enum types */
  150. char *v4l2_field_names[] = {
  151. [V4L2_FIELD_ANY] = "any",
  152. [V4L2_FIELD_NONE] = "none",
  153. [V4L2_FIELD_TOP] = "top",
  154. [V4L2_FIELD_BOTTOM] = "bottom",
  155. [V4L2_FIELD_INTERLACED] = "interlaced",
  156. [V4L2_FIELD_SEQ_TB] = "seq-tb",
  157. [V4L2_FIELD_SEQ_BT] = "seq-bt",
  158. [V4L2_FIELD_ALTERNATE] = "alternate",
  159. };
  160. char *v4l2_type_names[] = {
  161. [V4L2_BUF_TYPE_VIDEO_CAPTURE] = "video-cap",
  162. [V4L2_BUF_TYPE_VIDEO_OVERLAY] = "video-over",
  163. [V4L2_BUF_TYPE_VIDEO_OUTPUT] = "video-out",
  164. [V4L2_BUF_TYPE_VBI_CAPTURE] = "vbi-cap",
  165. [V4L2_BUF_TYPE_VBI_OUTPUT] = "vbi-out",
  166. };
  167. static char *v4l2_memory_names[] = {
  168. [V4L2_MEMORY_MMAP] = "mmap",
  169. [V4L2_MEMORY_USERPTR] = "userptr",
  170. [V4L2_MEMORY_OVERLAY] = "overlay",
  171. };
  172. #define prt_names(a,arr) (((a)>=0)&&((a)<ARRAY_SIZE(arr)))?arr[a]:"unknown"
  173. /* ------------------------------------------------------------------ */
  174. /* debug help functions */
  175. #ifdef HAVE_V4L1
  176. static const char *v4l1_ioctls[] = {
  177. [_IOC_NR(VIDIOCGCAP)] = "VIDIOCGCAP",
  178. [_IOC_NR(VIDIOCGCHAN)] = "VIDIOCGCHAN",
  179. [_IOC_NR(VIDIOCSCHAN)] = "VIDIOCSCHAN",
  180. [_IOC_NR(VIDIOCGTUNER)] = "VIDIOCGTUNER",
  181. [_IOC_NR(VIDIOCSTUNER)] = "VIDIOCSTUNER",
  182. [_IOC_NR(VIDIOCGPICT)] = "VIDIOCGPICT",
  183. [_IOC_NR(VIDIOCSPICT)] = "VIDIOCSPICT",
  184. [_IOC_NR(VIDIOCCAPTURE)] = "VIDIOCCAPTURE",
  185. [_IOC_NR(VIDIOCGWIN)] = "VIDIOCGWIN",
  186. [_IOC_NR(VIDIOCSWIN)] = "VIDIOCSWIN",
  187. [_IOC_NR(VIDIOCGFBUF)] = "VIDIOCGFBUF",
  188. [_IOC_NR(VIDIOCSFBUF)] = "VIDIOCSFBUF",
  189. [_IOC_NR(VIDIOCKEY)] = "VIDIOCKEY",
  190. [_IOC_NR(VIDIOCGFREQ)] = "VIDIOCGFREQ",
  191. [_IOC_NR(VIDIOCSFREQ)] = "VIDIOCSFREQ",
  192. [_IOC_NR(VIDIOCGAUDIO)] = "VIDIOCGAUDIO",
  193. [_IOC_NR(VIDIOCSAUDIO)] = "VIDIOCSAUDIO",
  194. [_IOC_NR(VIDIOCSYNC)] = "VIDIOCSYNC",
  195. [_IOC_NR(VIDIOCMCAPTURE)] = "VIDIOCMCAPTURE",
  196. [_IOC_NR(VIDIOCGMBUF)] = "VIDIOCGMBUF",
  197. [_IOC_NR(VIDIOCGUNIT)] = "VIDIOCGUNIT",
  198. [_IOC_NR(VIDIOCGCAPTURE)] = "VIDIOCGCAPTURE",
  199. [_IOC_NR(VIDIOCSCAPTURE)] = "VIDIOCSCAPTURE",
  200. [_IOC_NR(VIDIOCSPLAYMODE)] = "VIDIOCSPLAYMODE",
  201. [_IOC_NR(VIDIOCSWRITEMODE)] = "VIDIOCSWRITEMODE",
  202. [_IOC_NR(VIDIOCGPLAYINFO)] = "VIDIOCGPLAYINFO",
  203. [_IOC_NR(VIDIOCSMICROCODE)] = "VIDIOCSMICROCODE",
  204. [_IOC_NR(VIDIOCGVBIFMT)] = "VIDIOCGVBIFMT",
  205. [_IOC_NR(VIDIOCSVBIFMT)] = "VIDIOCSVBIFMT"
  206. };
  207. #define V4L1_IOCTLS ARRAY_SIZE(v4l1_ioctls)
  208. #endif
  209. static const char *v4l2_ioctls[] = {
  210. [_IOC_NR(VIDIOC_QUERYCAP)] = "VIDIOC_QUERYCAP",
  211. [_IOC_NR(VIDIOC_RESERVED)] = "VIDIOC_RESERVED",
  212. [_IOC_NR(VIDIOC_ENUM_FMT)] = "VIDIOC_ENUM_FMT",
  213. [_IOC_NR(VIDIOC_G_FMT)] = "VIDIOC_G_FMT",
  214. [_IOC_NR(VIDIOC_S_FMT)] = "VIDIOC_S_FMT",
  215. [_IOC_NR(VIDIOC_G_MPEGCOMP)] = "VIDIOC_G_MPEGCOMP",
  216. [_IOC_NR(VIDIOC_S_MPEGCOMP)] = "VIDIOC_S_MPEGCOMP",
  217. [_IOC_NR(VIDIOC_REQBUFS)] = "VIDIOC_REQBUFS",
  218. [_IOC_NR(VIDIOC_QUERYBUF)] = "VIDIOC_QUERYBUF",
  219. [_IOC_NR(VIDIOC_G_FBUF)] = "VIDIOC_G_FBUF",
  220. [_IOC_NR(VIDIOC_S_FBUF)] = "VIDIOC_S_FBUF",
  221. [_IOC_NR(VIDIOC_OVERLAY)] = "VIDIOC_OVERLAY",
  222. [_IOC_NR(VIDIOC_QBUF)] = "VIDIOC_QBUF",
  223. [_IOC_NR(VIDIOC_DQBUF)] = "VIDIOC_DQBUF",
  224. [_IOC_NR(VIDIOC_STREAMON)] = "VIDIOC_STREAMON",
  225. [_IOC_NR(VIDIOC_STREAMOFF)] = "VIDIOC_STREAMOFF",
  226. [_IOC_NR(VIDIOC_G_PARM)] = "VIDIOC_G_PARM",
  227. [_IOC_NR(VIDIOC_S_PARM)] = "VIDIOC_S_PARM",
  228. [_IOC_NR(VIDIOC_G_STD)] = "VIDIOC_G_STD",
  229. [_IOC_NR(VIDIOC_S_STD)] = "VIDIOC_S_STD",
  230. [_IOC_NR(VIDIOC_ENUMSTD)] = "VIDIOC_ENUMSTD",
  231. [_IOC_NR(VIDIOC_ENUMINPUT)] = "VIDIOC_ENUMINPUT",
  232. [_IOC_NR(VIDIOC_G_CTRL)] = "VIDIOC_G_CTRL",
  233. [_IOC_NR(VIDIOC_S_CTRL)] = "VIDIOC_S_CTRL",
  234. [_IOC_NR(VIDIOC_G_TUNER)] = "VIDIOC_G_TUNER",
  235. [_IOC_NR(VIDIOC_S_TUNER)] = "VIDIOC_S_TUNER",
  236. [_IOC_NR(VIDIOC_G_AUDIO)] = "VIDIOC_G_AUDIO",
  237. [_IOC_NR(VIDIOC_S_AUDIO)] = "VIDIOC_S_AUDIO",
  238. [_IOC_NR(VIDIOC_QUERYCTRL)] = "VIDIOC_QUERYCTRL",
  239. [_IOC_NR(VIDIOC_QUERYMENU)] = "VIDIOC_QUERYMENU",
  240. [_IOC_NR(VIDIOC_G_INPUT)] = "VIDIOC_G_INPUT",
  241. [_IOC_NR(VIDIOC_S_INPUT)] = "VIDIOC_S_INPUT",
  242. [_IOC_NR(VIDIOC_G_OUTPUT)] = "VIDIOC_G_OUTPUT",
  243. [_IOC_NR(VIDIOC_S_OUTPUT)] = "VIDIOC_S_OUTPUT",
  244. [_IOC_NR(VIDIOC_ENUMOUTPUT)] = "VIDIOC_ENUMOUTPUT",
  245. [_IOC_NR(VIDIOC_G_AUDOUT)] = "VIDIOC_G_AUDOUT",
  246. [_IOC_NR(VIDIOC_S_AUDOUT)] = "VIDIOC_S_AUDOUT",
  247. [_IOC_NR(VIDIOC_G_MODULATOR)] = "VIDIOC_G_MODULATOR",
  248. [_IOC_NR(VIDIOC_S_MODULATOR)] = "VIDIOC_S_MODULATOR",
  249. [_IOC_NR(VIDIOC_G_FREQUENCY)] = "VIDIOC_G_FREQUENCY",
  250. [_IOC_NR(VIDIOC_S_FREQUENCY)] = "VIDIOC_S_FREQUENCY",
  251. [_IOC_NR(VIDIOC_CROPCAP)] = "VIDIOC_CROPCAP",
  252. [_IOC_NR(VIDIOC_G_CROP)] = "VIDIOC_G_CROP",
  253. [_IOC_NR(VIDIOC_S_CROP)] = "VIDIOC_S_CROP",
  254. [_IOC_NR(VIDIOC_G_JPEGCOMP)] = "VIDIOC_G_JPEGCOMP",
  255. [_IOC_NR(VIDIOC_S_JPEGCOMP)] = "VIDIOC_S_JPEGCOMP",
  256. [_IOC_NR(VIDIOC_QUERYSTD)] = "VIDIOC_QUERYSTD",
  257. [_IOC_NR(VIDIOC_TRY_FMT)] = "VIDIOC_TRY_FMT",
  258. [_IOC_NR(VIDIOC_ENUMAUDIO)] = "VIDIOC_ENUMAUDIO",
  259. [_IOC_NR(VIDIOC_ENUMAUDOUT)] = "VIDIOC_ENUMAUDOUT",
  260. [_IOC_NR(VIDIOC_G_PRIORITY)] = "VIDIOC_G_PRIORITY",
  261. [_IOC_NR(VIDIOC_S_PRIORITY)] = "VIDIOC_S_PRIORITY",
  262. #if 1
  263. [_IOC_NR(VIDIOC_G_SLICED_VBI_CAP)] = "VIDIOC_G_SLICED_VBI_CAP",
  264. #endif
  265. [_IOC_NR(VIDIOC_LOG_STATUS)] = "VIDIOC_LOG_STATUS"
  266. };
  267. #define V4L2_IOCTLS ARRAY_SIZE(v4l2_ioctls)
  268. static const char *v4l2_int_ioctls[] = {
  269. #ifdef HAVE_VIDEO_DECODER
  270. [_IOC_NR(DECODER_GET_CAPABILITIES)] = "DECODER_GET_CAPABILITIES",
  271. [_IOC_NR(DECODER_GET_STATUS)] = "DECODER_GET_STATUS",
  272. [_IOC_NR(DECODER_SET_NORM)] = "DECODER_SET_NORM",
  273. [_IOC_NR(DECODER_SET_INPUT)] = "DECODER_SET_INPUT",
  274. [_IOC_NR(DECODER_SET_OUTPUT)] = "DECODER_SET_OUTPUT",
  275. [_IOC_NR(DECODER_ENABLE_OUTPUT)] = "DECODER_ENABLE_OUTPUT",
  276. [_IOC_NR(DECODER_SET_PICTURE)] = "DECODER_SET_PICTURE",
  277. [_IOC_NR(DECODER_SET_GPIO)] = "DECODER_SET_GPIO",
  278. [_IOC_NR(DECODER_INIT)] = "DECODER_INIT",
  279. [_IOC_NR(DECODER_SET_VBI_BYPASS)] = "DECODER_SET_VBI_BYPASS",
  280. [_IOC_NR(DECODER_DUMP)] = "DECODER_DUMP",
  281. #endif
  282. [_IOC_NR(AUDC_SET_RADIO)] = "AUDC_SET_RADIO",
  283. [_IOC_NR(TUNER_SET_TYPE_ADDR)] = "TUNER_SET_TYPE_ADDR",
  284. [_IOC_NR(TUNER_SET_STANDBY)] = "TUNER_SET_STANDBY",
  285. [_IOC_NR(TDA9887_SET_CONFIG)] = "TDA9887_SET_CONFIG",
  286. [_IOC_NR(VIDIOC_INT_S_TUNER_MODE)] = "VIDIOC_INT_S_TUNER_MODE",
  287. [_IOC_NR(VIDIOC_INT_S_REGISTER)] = "VIDIOC_INT_S_REGISTER",
  288. [_IOC_NR(VIDIOC_INT_G_REGISTER)] = "VIDIOC_INT_G_REGISTER",
  289. [_IOC_NR(VIDIOC_INT_RESET)] = "VIDIOC_INT_RESET",
  290. [_IOC_NR(VIDIOC_INT_AUDIO_CLOCK_FREQ)] = "VIDIOC_INT_AUDIO_CLOCK_FREQ",
  291. [_IOC_NR(VIDIOC_INT_DECODE_VBI_LINE)] = "VIDIOC_INT_DECODE_VBI_LINE",
  292. [_IOC_NR(VIDIOC_INT_S_VBI_DATA)] = "VIDIOC_INT_S_VBI_DATA",
  293. [_IOC_NR(VIDIOC_INT_G_VBI_DATA)] = "VIDIOC_INT_G_VBI_DATA",
  294. [_IOC_NR(VIDIOC_INT_G_CHIP_IDENT)] = "VIDIOC_INT_G_CHIP_IDENT",
  295. [_IOC_NR(VIDIOC_INT_I2S_CLOCK_FREQ)] = "VIDIOC_INT_I2S_CLOCK_FREQ",
  296. [_IOC_NR(VIDIOC_INT_S_STANDBY)] = "VIDIOC_INT_S_STANDBY",
  297. [_IOC_NR(VIDIOC_INT_S_AUDIO_ROUTING)] = "VIDIOC_INT_S_AUDIO_ROUTING",
  298. [_IOC_NR(VIDIOC_INT_G_AUDIO_ROUTING)] = "VIDIOC_INT_G_AUDIO_ROUTING",
  299. [_IOC_NR(VIDIOC_INT_S_VIDEO_ROUTING)] = "VIDIOC_INT_S_VIDEO_ROUTING",
  300. [_IOC_NR(VIDIOC_INT_G_VIDEO_ROUTING)] = "VIDIOC_INT_G_VIDEO_ROUTING"
  301. };
  302. #define V4L2_INT_IOCTLS ARRAY_SIZE(v4l2_int_ioctls)
  303. static void v4l_print_pix_fmt (char *s, struct v4l2_pix_format *fmt)
  304. {
  305. printk ("%s: width=%d, height=%d, format=%d, field=%s, "
  306. "bytesperline=%d sizeimage=%d, colorspace=%d\n", s,
  307. fmt->width,fmt->height,fmt->pixelformat,
  308. prt_names(fmt->field,v4l2_field_names),
  309. fmt->bytesperline,fmt->sizeimage,fmt->colorspace);
  310. };
  311. /* Common ioctl debug function. This function can be used by
  312. external ioctl messages as well as internal V4L ioctl */
  313. void v4l_printk_ioctl(unsigned int cmd)
  314. {
  315. char *dir;
  316. switch (_IOC_DIR(cmd)) {
  317. case _IOC_NONE: dir = "--"; break;
  318. case _IOC_READ: dir = "r-"; break;
  319. case _IOC_WRITE: dir = "-w"; break;
  320. case _IOC_READ | _IOC_WRITE: dir = "rw"; break;
  321. default: dir = "*ERR*"; break;
  322. }
  323. switch (_IOC_TYPE(cmd)) {
  324. case 'd':
  325. printk("v4l2_int ioctl %s, dir=%s (0x%08x)\n",
  326. (_IOC_NR(cmd) < V4L2_INT_IOCTLS) ?
  327. v4l2_int_ioctls[_IOC_NR(cmd)] : "UNKNOWN", dir, cmd);
  328. break;
  329. #ifdef HAVE_V4L1
  330. case 'v':
  331. printk("v4l1 ioctl %s, dir=%s (0x%08x)\n",
  332. (_IOC_NR(cmd) < V4L1_IOCTLS) ?
  333. v4l1_ioctls[_IOC_NR(cmd)] : "UNKNOWN", dir, cmd);
  334. break;
  335. #endif
  336. case 'V':
  337. printk("v4l2 ioctl %s, dir=%s (0x%08x)\n",
  338. (_IOC_NR(cmd) < V4L2_IOCTLS) ?
  339. v4l2_ioctls[_IOC_NR(cmd)] : "UNKNOWN", dir, cmd);
  340. break;
  341. default:
  342. printk("unknown ioctl '%c', dir=%s, #%d (0x%08x)\n",
  343. _IOC_TYPE(cmd), dir, _IOC_NR(cmd), cmd);
  344. }
  345. }
  346. /* Common ioctl debug function. This function can be used by
  347. external ioctl messages as well as internal V4L ioctl and its
  348. arguments */
  349. void v4l_printk_ioctl_arg(char *s,unsigned int cmd, void *arg)
  350. {
  351. printk(s);
  352. printk(": ");
  353. v4l_printk_ioctl(cmd);
  354. switch (cmd) {
  355. case VIDIOC_INT_G_CHIP_IDENT:
  356. {
  357. enum v4l2_chip_ident *p=arg;
  358. printk ("%s: chip ident=%d\n", s, *p);
  359. break;
  360. }
  361. case VIDIOC_G_PRIORITY:
  362. case VIDIOC_S_PRIORITY:
  363. {
  364. enum v4l2_priority *p=arg;
  365. printk ("%s: priority=%d\n", s, *p);
  366. break;
  367. }
  368. case VIDIOC_INT_S_TUNER_MODE:
  369. {
  370. enum v4l2_tuner_type *p=arg;
  371. printk ("%s: tuner type=%d\n", s, *p);
  372. break;
  373. }
  374. case DECODER_SET_VBI_BYPASS:
  375. case DECODER_ENABLE_OUTPUT:
  376. case DECODER_GET_STATUS:
  377. case DECODER_SET_OUTPUT:
  378. case DECODER_SET_INPUT:
  379. case DECODER_SET_GPIO:
  380. case DECODER_SET_NORM:
  381. case VIDIOCCAPTURE:
  382. case VIDIOCSYNC:
  383. case VIDIOCSWRITEMODE:
  384. case TUNER_SET_TYPE_ADDR:
  385. case TUNER_SET_STANDBY:
  386. case TDA9887_SET_CONFIG:
  387. case VIDIOC_OVERLAY_OLD:
  388. case VIDIOC_STREAMOFF:
  389. case VIDIOC_G_OUTPUT:
  390. case VIDIOC_S_OUTPUT:
  391. case VIDIOC_STREAMON:
  392. case VIDIOC_G_INPUT:
  393. case VIDIOC_OVERLAY:
  394. case VIDIOC_S_INPUT:
  395. {
  396. int *p=arg;
  397. printk ("%s: value=%d\n", s, *p);
  398. break;
  399. }
  400. case VIDIOC_G_AUDIO:
  401. case VIDIOC_S_AUDIO:
  402. case VIDIOC_ENUMAUDIO:
  403. case VIDIOC_G_AUDIO_OLD:
  404. {
  405. struct v4l2_audio *p=arg;
  406. printk ("%s: index=%d, name=%s, capability=%d, mode=%d\n",
  407. s,p->index, p->name,p->capability, p->mode);
  408. break;
  409. }
  410. case VIDIOC_G_AUDOUT:
  411. case VIDIOC_S_AUDOUT:
  412. case VIDIOC_ENUMAUDOUT:
  413. case VIDIOC_G_AUDOUT_OLD:
  414. {
  415. struct v4l2_audioout *p=arg;
  416. printk ("%s: index=%d, name=%s, capability=%d, mode=%d\n", s,
  417. p->index, p->name, p->capability,p->mode);
  418. break;
  419. }
  420. case VIDIOC_QBUF:
  421. case VIDIOC_DQBUF:
  422. case VIDIOC_QUERYBUF:
  423. {
  424. struct v4l2_buffer *p=arg;
  425. struct v4l2_timecode *tc=&p->timecode;
  426. printk ("%s: %02ld:%02d:%02d.%08ld index=%d, type=%s, "
  427. "bytesused=%d, flags=0x%08x, "
  428. "field=%0d, sequence=%d, memory=%s, offset/userptr=0x%08lx\n",
  429. s,
  430. (p->timestamp.tv_sec/3600),
  431. (int)(p->timestamp.tv_sec/60)%60,
  432. (int)(p->timestamp.tv_sec%60),
  433. p->timestamp.tv_usec,
  434. p->index,
  435. prt_names(p->type,v4l2_type_names),
  436. p->bytesused,p->flags,
  437. p->field,p->sequence,
  438. prt_names(p->memory,v4l2_memory_names),
  439. p->m.userptr);
  440. printk ("%s: timecode= %02d:%02d:%02d type=%d, "
  441. "flags=0x%08x, frames=%d, userbits=0x%p\n",
  442. s,tc->hours,tc->minutes,tc->seconds,
  443. tc->type, tc->flags, tc->frames, tc->userbits);
  444. break;
  445. }
  446. case VIDIOC_QUERYCAP:
  447. {
  448. struct v4l2_capability *p=arg;
  449. printk ("%s: driver=%s, card=%s, bus=%s, version=0x%08x, "
  450. "capabilities=0x%08x\n", s,
  451. p->driver,p->card,p->bus_info,
  452. p->version,
  453. p->capabilities);
  454. break;
  455. }
  456. case VIDIOC_G_CTRL:
  457. case VIDIOC_S_CTRL:
  458. case VIDIOC_S_CTRL_OLD:
  459. {
  460. struct v4l2_control *p=arg;
  461. printk ("%s: id=%d, value=%d\n", s, p->id, p->value);
  462. break;
  463. }
  464. case VIDIOC_G_CROP:
  465. case VIDIOC_S_CROP:
  466. {
  467. struct v4l2_crop *p=arg;
  468. /*FIXME: Should also show rect structs */
  469. printk ("%s: type=%d\n", s, p->type);
  470. break;
  471. }
  472. case VIDIOC_CROPCAP:
  473. case VIDIOC_CROPCAP_OLD:
  474. {
  475. struct v4l2_cropcap *p=arg;
  476. /*FIXME: Should also show rect structs */
  477. printk ("%s: type=%d\n", s, p->type);
  478. break;
  479. }
  480. case VIDIOC_INT_DECODE_VBI_LINE:
  481. {
  482. struct v4l2_decode_vbi_line *p=arg;
  483. printk ("%s: is_second_field=%d, ptr=0x%08lx, line=%d, "
  484. "type=%d\n", s,
  485. p->is_second_field,(unsigned long)p->p,p->line,p->type);
  486. break;
  487. }
  488. case VIDIOC_ENUM_FMT:
  489. {
  490. struct v4l2_fmtdesc *p=arg;
  491. printk ("%s: index=%d, type=%d, flags=%d, description=%s,"
  492. " pixelformat=%d\n", s,
  493. p->index, p->type, p->flags,p->description,
  494. p->pixelformat);
  495. break;
  496. }
  497. case VIDIOC_G_FMT:
  498. case VIDIOC_S_FMT:
  499. case VIDIOC_TRY_FMT:
  500. {
  501. struct v4l2_format *p=arg;
  502. printk ("%s: type=%s\n", s,
  503. prt_names(p->type,v4l2_type_names));
  504. switch (p->type) {
  505. case V4L2_BUF_TYPE_VIDEO_CAPTURE:
  506. v4l_print_pix_fmt (s, &p->fmt.pix);
  507. break;
  508. default:
  509. break;
  510. }
  511. }
  512. case VIDIOC_G_FBUF:
  513. case VIDIOC_S_FBUF:
  514. {
  515. struct v4l2_framebuffer *p=arg;
  516. printk ("%s: capability=%d, flags=%d, base=0x%08lx\n", s,
  517. p->capability,p->flags, (unsigned long)p->base);
  518. v4l_print_pix_fmt (s, &p->fmt);
  519. break;
  520. }
  521. case VIDIOC_G_FREQUENCY:
  522. case VIDIOC_S_FREQUENCY:
  523. {
  524. struct v4l2_frequency *p=arg;
  525. printk ("%s: tuner=%d, type=%d, frequency=%d\n", s,
  526. p->tuner,p->type,p->frequency);
  527. break;
  528. }
  529. case VIDIOC_ENUMINPUT:
  530. {
  531. struct v4l2_input *p=arg;
  532. printk ("%s: index=%d, name=%s, type=%d, audioset=%d, "
  533. "tuner=%d, std=%Ld, status=%d\n", s,
  534. p->index,p->name,p->type,p->audioset,
  535. p->tuner,
  536. (unsigned long long)p->std,
  537. p->status);
  538. break;
  539. }
  540. case VIDIOC_G_JPEGCOMP:
  541. case VIDIOC_S_JPEGCOMP:
  542. {
  543. struct v4l2_jpegcompression *p=arg;
  544. printk ("%s: quality=%d, APPn=%d, APP_len=%d, COM_len=%d,"
  545. " jpeg_markers=%d\n", s,
  546. p->quality,p->APPn,p->APP_len,
  547. p->COM_len,p->jpeg_markers);
  548. break;
  549. }
  550. case VIDIOC_G_MODULATOR:
  551. case VIDIOC_S_MODULATOR:
  552. {
  553. struct v4l2_modulator *p=arg;
  554. printk ("%s: index=%d, name=%s, capability=%d, rangelow=%d,"
  555. " rangehigh=%d, txsubchans=%d\n", s,
  556. p->index, p->name,p->capability,p->rangelow,
  557. p->rangehigh,p->txsubchans);
  558. break;
  559. }
  560. case VIDIOC_G_MPEGCOMP:
  561. case VIDIOC_S_MPEGCOMP:
  562. {
  563. struct v4l2_mpeg_compression *p=arg;
  564. /*FIXME: Several fields not shown */
  565. printk ("%s: ts_pid_pmt=%d, ts_pid_audio=%d, ts_pid_video=%d, "
  566. "ts_pid_pcr=%d, ps_size=%d, au_sample_rate=%d, "
  567. "au_pesid=%c, vi_frame_rate=%d, vi_frames_per_gop=%d, "
  568. "vi_bframes_count=%d, vi_pesid=%c\n", s,
  569. p->ts_pid_pmt,p->ts_pid_audio, p->ts_pid_video,
  570. p->ts_pid_pcr, p->ps_size, p->au_sample_rate,
  571. p->au_pesid, p->vi_frame_rate,
  572. p->vi_frames_per_gop, p->vi_bframes_count,
  573. p->vi_pesid);
  574. break;
  575. }
  576. case VIDIOC_ENUMOUTPUT:
  577. {
  578. struct v4l2_output *p=arg;
  579. printk ("%s: index=%d, name=%s,type=%d, audioset=%d, "
  580. "modulator=%d, std=%Ld\n",
  581. s,p->index,p->name,p->type,p->audioset,
  582. p->modulator,
  583. (unsigned long long)p->std);
  584. break;
  585. }
  586. case VIDIOC_QUERYCTRL:
  587. {
  588. struct v4l2_queryctrl *p=arg;
  589. printk ("%s: id=%d, type=%d, name=%s, min/max=%d/%d,"
  590. " step=%d, default=%d, flags=0x%08x\n", s,
  591. p->id,p->type,p->name,p->minimum,p->maximum,
  592. p->step,p->default_value,p->flags);
  593. break;
  594. }
  595. case VIDIOC_QUERYMENU:
  596. {
  597. struct v4l2_querymenu *p=arg;
  598. printk ("%s: id=%d, index=%d, name=%s\n", s,
  599. p->id,p->index,p->name);
  600. break;
  601. }
  602. case VIDIOC_INT_G_REGISTER:
  603. case VIDIOC_INT_S_REGISTER:
  604. {
  605. struct v4l2_register *p=arg;
  606. printk ("%s: i2c_id=%d, reg=%lu, val=%d\n", s,
  607. p->i2c_id,p->reg,p->val);
  608. break;
  609. }
  610. case VIDIOC_REQBUFS:
  611. {
  612. struct v4l2_requestbuffers *p=arg;
  613. printk ("%s: count=%d, type=%s, memory=%s\n", s,
  614. p->count,
  615. prt_names(p->type,v4l2_type_names),
  616. prt_names(p->memory,v4l2_memory_names));
  617. break;
  618. }
  619. case VIDIOC_INT_S_AUDIO_ROUTING:
  620. case VIDIOC_INT_S_VIDEO_ROUTING:
  621. case VIDIOC_INT_G_AUDIO_ROUTING:
  622. case VIDIOC_INT_G_VIDEO_ROUTING:
  623. {
  624. struct v4l2_routing *p=arg;
  625. printk ("%s: input=0x%x, output=0x%x\n", s, p->input, p->output);
  626. break;
  627. }
  628. case VIDIOC_G_SLICED_VBI_CAP:
  629. {
  630. struct v4l2_sliced_vbi_cap *p=arg;
  631. printk ("%s: service_set=%d\n", s,
  632. p->service_set);
  633. break;
  634. }
  635. case VIDIOC_INT_S_VBI_DATA:
  636. case VIDIOC_INT_G_VBI_DATA:
  637. {
  638. struct v4l2_sliced_vbi_data *p=arg;
  639. printk ("%s: id=%d, field=%d, line=%d\n", s,
  640. p->id, p->field, p->line);
  641. break;
  642. }
  643. case VIDIOC_ENUMSTD:
  644. {
  645. struct v4l2_standard *p=arg;
  646. printk ("%s: index=%d, id=%Ld, name=%s, fps=%d/%d, "
  647. "framelines=%d\n", s, p->index,
  648. (unsigned long long)p->id, p->name,
  649. p->frameperiod.numerator,
  650. p->frameperiod.denominator,
  651. p->framelines);
  652. break;
  653. }
  654. case VIDIOC_G_PARM:
  655. case VIDIOC_S_PARM:
  656. case VIDIOC_S_PARM_OLD:
  657. {
  658. struct v4l2_streamparm *p=arg;
  659. printk ("%s: type=%d\n", s, p->type);
  660. break;
  661. }
  662. case VIDIOC_G_TUNER:
  663. case VIDIOC_S_TUNER:
  664. {
  665. struct v4l2_tuner *p=arg;
  666. printk ("%s: index=%d, name=%s, type=%d, capability=%d, "
  667. "rangelow=%d, rangehigh=%d, signal=%d, afc=%d, "
  668. "rxsubchans=%d, audmode=%d\n", s,
  669. p->index, p->name, p->type,
  670. p->capability, p->rangelow,p->rangehigh,
  671. p->rxsubchans, p->audmode, p->signal,
  672. p->afc);
  673. break;
  674. }
  675. case VIDIOCGVBIFMT:
  676. case VIDIOCSVBIFMT:
  677. {
  678. struct vbi_format *p=arg;
  679. printk ("%s: sampling_rate=%d, samples_per_line=%d, "
  680. "sample_format=%d, start=%d/%d, count=%d/%d, flags=%d\n", s,
  681. p->sampling_rate,p->samples_per_line,
  682. p->sample_format,p->start[0],p->start[1],
  683. p->count[0],p->count[1],p->flags);
  684. break;
  685. }
  686. case VIDIOCGAUDIO:
  687. case VIDIOCSAUDIO:
  688. {
  689. struct video_audio *p=arg;
  690. printk ("%s: audio=%d, volume=%d, bass=%d, treble=%d, "
  691. "flags=%d, name=%s, mode=%d, balance=%d, step=%d\n",
  692. s,p->audio,p->volume,p->bass, p->treble,
  693. p->flags,p->name,p->mode,p->balance,p->step);
  694. break;
  695. }
  696. case VIDIOCGFBUF:
  697. case VIDIOCSFBUF:
  698. {
  699. struct video_buffer *p=arg;
  700. printk ("%s: base=%08lx, height=%d, width=%d, depth=%d, "
  701. "bytesperline=%d\n", s,
  702. (unsigned long) p->base, p->height, p->width,
  703. p->depth,p->bytesperline);
  704. break;
  705. }
  706. case VIDIOCGCAP:
  707. {
  708. struct video_capability *p=arg;
  709. printk ("%s: name=%s, type=%d, channels=%d, audios=%d, "
  710. "maxwidth=%d, maxheight=%d, minwidth=%d, minheight=%d\n",
  711. s,p->name,p->type,p->channels,p->audios,
  712. p->maxwidth,p->maxheight,p->minwidth,
  713. p->minheight);
  714. break;
  715. }
  716. case VIDIOCGCAPTURE:
  717. case VIDIOCSCAPTURE:
  718. {
  719. struct video_capture *p=arg;
  720. printk ("%s: x=%d, y=%d, width=%d, height=%d, decimation=%d,"
  721. " flags=%d\n", s,
  722. p->x, p->y,p->width, p->height,
  723. p->decimation,p->flags);
  724. break;
  725. }
  726. case VIDIOCGCHAN:
  727. case VIDIOCSCHAN:
  728. {
  729. struct video_channel *p=arg;
  730. printk ("%s: channel=%d, name=%s, tuners=%d, flags=%d, "
  731. "type=%d, norm=%d\n", s,
  732. p->channel,p->name,p->tuners,
  733. p->flags,p->type,p->norm);
  734. break;
  735. }
  736. case VIDIOCSMICROCODE:
  737. {
  738. struct video_code *p=arg;
  739. printk ("%s: loadwhat=%s, datasize=%d\n", s,
  740. p->loadwhat,p->datasize);
  741. break;
  742. }
  743. case DECODER_GET_CAPABILITIES:
  744. {
  745. struct video_decoder_capability *p=arg;
  746. printk ("%s: flags=%d, inputs=%d, outputs=%d\n", s,
  747. p->flags,p->inputs,p->outputs);
  748. break;
  749. }
  750. case DECODER_INIT:
  751. {
  752. struct video_decoder_init *p=arg;
  753. printk ("%s: len=%c\n", s, p->len);
  754. break;
  755. }
  756. case VIDIOCGPLAYINFO:
  757. {
  758. struct video_info *p=arg;
  759. printk ("%s: frame_count=%d, h_size=%d, v_size=%d, "
  760. "smpte_timecode=%d, picture_type=%d, "
  761. "temporal_reference=%d, user_data=%s\n", s,
  762. p->frame_count, p->h_size,
  763. p->v_size, p->smpte_timecode,
  764. p->picture_type, p->temporal_reference,
  765. p->user_data);
  766. break;
  767. }
  768. case VIDIOCKEY:
  769. {
  770. struct video_key *p=arg;
  771. printk ("%s: key=%s, flags=%d\n", s,
  772. p->key, p->flags);
  773. break;
  774. }
  775. case VIDIOCGMBUF:
  776. {
  777. struct video_mbuf *p=arg;
  778. printk ("%s: size=%d, frames=%d, offsets=0x%08lx\n", s,
  779. p->size,
  780. p->frames,
  781. (unsigned long)p->offsets);
  782. break;
  783. }
  784. case VIDIOCMCAPTURE:
  785. {
  786. struct video_mmap *p=arg;
  787. printk ("%s: frame=%d, height=%d, width=%d, format=%d\n", s,
  788. p->frame,
  789. p->height, p->width,
  790. p->format);
  791. break;
  792. }
  793. case VIDIOCGPICT:
  794. case VIDIOCSPICT:
  795. case DECODER_SET_PICTURE:
  796. {
  797. struct video_picture *p=arg;
  798. printk ("%s: brightness=%d, hue=%d, colour=%d, contrast=%d,"
  799. " whiteness=%d, depth=%d, palette=%d\n", s,
  800. p->brightness, p->hue, p->colour,
  801. p->contrast, p->whiteness, p->depth,
  802. p->palette);
  803. break;
  804. }
  805. case VIDIOCSPLAYMODE:
  806. {
  807. struct video_play_mode *p=arg;
  808. printk ("%s: mode=%d, p1=%d, p2=%d\n", s,
  809. p->mode,p->p1,p->p2);
  810. break;
  811. }
  812. case VIDIOCGTUNER:
  813. case VIDIOCSTUNER:
  814. {
  815. struct video_tuner *p=arg;
  816. printk ("%s: tuner=%d, name=%s, rangelow=%ld, rangehigh=%ld, "
  817. "flags=%d, mode=%d, signal=%d\n", s,
  818. p->tuner, p->name,p->rangelow, p->rangehigh,
  819. p->flags,p->mode, p->signal);
  820. break;
  821. }
  822. case VIDIOCGUNIT:
  823. {
  824. struct video_unit *p=arg;
  825. printk ("%s: video=%d, vbi=%d, radio=%d, audio=%d, "
  826. "teletext=%d\n", s,
  827. p->video,p->vbi,p->radio,p->audio,p->teletext);
  828. break;
  829. }
  830. case VIDIOCGWIN:
  831. case VIDIOCSWIN:
  832. {
  833. struct video_window *p=arg;
  834. printk ("%s: x=%d, y=%d, width=%d, height=%d, chromakey=%d,"
  835. " flags=%d, clipcount=%d\n", s,
  836. p->x, p->y,p->width, p->height,
  837. p->chromakey,p->flags,
  838. p->clipcount);
  839. break;
  840. }
  841. case VIDIOC_INT_AUDIO_CLOCK_FREQ:
  842. case VIDIOC_INT_I2S_CLOCK_FREQ:
  843. case VIDIOC_INT_S_STANDBY:
  844. {
  845. u32 *p=arg;
  846. printk ("%s: value=%d\n", s, *p);
  847. break;
  848. }
  849. case VIDIOCGFREQ:
  850. case VIDIOCSFREQ:
  851. {
  852. unsigned long *p=arg;
  853. printk ("%s: value=%lu\n", s, *p);
  854. break;
  855. }
  856. case VIDIOC_G_STD:
  857. case VIDIOC_S_STD:
  858. case VIDIOC_QUERYSTD:
  859. {
  860. v4l2_std_id *p=arg;
  861. printk ("%s: value=%Lu\n", s, (unsigned long long)*p);
  862. break;
  863. }
  864. }
  865. }
  866. /* ----------------------------------------------------------------- */
  867. EXPORT_SYMBOL(v4l2_video_std_construct);
  868. EXPORT_SYMBOL(v4l2_prio_init);
  869. EXPORT_SYMBOL(v4l2_prio_change);
  870. EXPORT_SYMBOL(v4l2_prio_open);
  871. EXPORT_SYMBOL(v4l2_prio_close);
  872. EXPORT_SYMBOL(v4l2_prio_max);
  873. EXPORT_SYMBOL(v4l2_prio_check);
  874. EXPORT_SYMBOL(v4l2_field_names);
  875. EXPORT_SYMBOL(v4l2_type_names);
  876. EXPORT_SYMBOL(v4l_printk_ioctl);
  877. EXPORT_SYMBOL(v4l_printk_ioctl_arg);
  878. /*
  879. * Local variables:
  880. * c-basic-offset: 8
  881. * End:
  882. */