~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/Documentation/driver-api/media/dtv-common.rst

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.12 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

Diff markup

Differences between /Documentation/driver-api/media/dtv-common.rst (Architecture m68k) and /Documentation/driver-api/media/dtv-common.rst (Architecture sparc)


  1 .. SPDX-License-Identifier: GPL-2.0                 1 .. SPDX-License-Identifier: GPL-2.0
  2                                                     2 
  3 Digital TV Common functions                         3 Digital TV Common functions
  4 ---------------------------                         4 ---------------------------
  5                                                     5 
  6 DVB devices                                         6 DVB devices
  7 ~~~~~~~~~~~                                         7 ~~~~~~~~~~~
  8                                                     8 
  9 Those functions are responsible for handling t      9 Those functions are responsible for handling the DVB device nodes.
 10                                                    10 
 11 .. kernel-doc:: include/media/dvbdev.h             11 .. kernel-doc:: include/media/dvbdev.h
 12                                                    12 
 13 Digital TV Ring buffer                             13 Digital TV Ring buffer
 14 ~~~~~~~~~~~~~~~~~~~~~~                             14 ~~~~~~~~~~~~~~~~~~~~~~
 15                                                    15 
 16 Those routines implement ring buffers used to      16 Those routines implement ring buffers used to handle digital TV data and
 17 copy it from/to userspace.                         17 copy it from/to userspace.
 18                                                    18 
 19 .. note::                                          19 .. note::
 20                                                    20 
 21   1) For performance reasons read and write ro     21   1) For performance reasons read and write routines don't check buffer sizes
 22      and/or number of bytes free/available. Th     22      and/or number of bytes free/available. This has to be done before these
 23      routines are called. For example:             23      routines are called. For example:
 24                                                    24 
 25    .. code-block:: c                               25    .. code-block:: c
 26                                                    26 
 27         /* write @buflen: bytes */                 27         /* write @buflen: bytes */
 28         free = dvb_ringbuffer_free(rbuf);          28         free = dvb_ringbuffer_free(rbuf);
 29         if (free >= buflen)                        29         if (free >= buflen)
 30                 count = dvb_ringbuffer_write(r     30                 count = dvb_ringbuffer_write(rbuf, buffer, buflen);
 31         else                                       31         else
 32                 /* do something */                 32                 /* do something */
 33                                                    33 
 34         /* read min. 1000, max. @bufsize: byte     34         /* read min. 1000, max. @bufsize: bytes */
 35         avail = dvb_ringbuffer_avail(rbuf);        35         avail = dvb_ringbuffer_avail(rbuf);
 36         if (avail >= 1000)                         36         if (avail >= 1000)
 37                 count = dvb_ringbuffer_read(rb     37                 count = dvb_ringbuffer_read(rbuf, buffer, min(avail, bufsize));
 38         else                                       38         else
 39                 /* do something */                 39                 /* do something */
 40                                                    40 
 41   2) If there is exactly one reader and one wr     41   2) If there is exactly one reader and one writer, there is no need
 42      to lock read or write operations.             42      to lock read or write operations.
 43      Two or more readers must be locked agains     43      Two or more readers must be locked against each other.
 44      Flushing the buffer counts as a read oper     44      Flushing the buffer counts as a read operation.
 45      Resetting the buffer counts as a read and     45      Resetting the buffer counts as a read and write operation.
 46      Two or more writers must be locked agains     46      Two or more writers must be locked against each other.
 47                                                    47 
 48 .. kernel-doc:: include/media/dvb_ringbuffer.h     48 .. kernel-doc:: include/media/dvb_ringbuffer.h
 49                                                    49 
 50 Digital TV VB2 handler                             50 Digital TV VB2 handler
 51 ~~~~~~~~~~~~~~~~~~~~~~                             51 ~~~~~~~~~~~~~~~~~~~~~~
 52                                                    52 
 53 .. kernel-doc:: include/media/dvb_vb2.h            53 .. kernel-doc:: include/media/dvb_vb2.h
                                                      

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php