media-entity.h 31 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970
  1. /*
  2. * Media entity
  3. *
  4. * Copyright (C) 2010 Nokia Corporation
  5. *
  6. * Contacts: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
  7. * Sakari Ailus <sakari.ailus@iki.fi>
  8. *
  9. * This program is free software; you can redistribute it and/or modify
  10. * it under the terms of the GNU General Public License version 2 as
  11. * published by the Free Software Foundation.
  12. *
  13. * This program is distributed in the hope that it will be useful,
  14. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  15. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  16. * GNU General Public License for more details.
  17. *
  18. * You should have received a copy of the GNU General Public License
  19. * along with this program; if not, write to the Free Software
  20. * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
  21. */
  22. #ifndef _MEDIA_ENTITY_H
  23. #define _MEDIA_ENTITY_H
  24. #include <linux/bitmap.h>
  25. #include <linux/bug.h>
  26. #include <linux/kernel.h>
  27. #include <linux/list.h>
  28. #include <linux/media.h>
  29. /* Enums used internally at the media controller to represent graphs */
  30. /**
  31. * enum media_gobj_type - type of a graph object
  32. *
  33. * @MEDIA_GRAPH_ENTITY: Identify a media entity
  34. * @MEDIA_GRAPH_PAD: Identify a media pad
  35. * @MEDIA_GRAPH_LINK: Identify a media link
  36. * @MEDIA_GRAPH_INTF_DEVNODE: Identify a media Kernel API interface via
  37. * a device node
  38. */
  39. enum media_gobj_type {
  40. MEDIA_GRAPH_ENTITY,
  41. MEDIA_GRAPH_PAD,
  42. MEDIA_GRAPH_LINK,
  43. MEDIA_GRAPH_INTF_DEVNODE,
  44. };
  45. #define MEDIA_BITS_PER_TYPE 8
  46. #define MEDIA_BITS_PER_ID (32 - MEDIA_BITS_PER_TYPE)
  47. #define MEDIA_ID_MASK GENMASK_ULL(MEDIA_BITS_PER_ID - 1, 0)
  48. /* Structs to represent the objects that belong to a media graph */
  49. /**
  50. * struct media_gobj - Define a graph object.
  51. *
  52. * @mdev: Pointer to the struct media_device that owns the object
  53. * @id: Non-zero object ID identifier. The ID should be unique
  54. * inside a media_device, as it is composed by
  55. * %MEDIA_BITS_PER_TYPE to store the type plus
  56. * %MEDIA_BITS_PER_ID to store the ID
  57. * @list: List entry stored in one of the per-type mdev object lists
  58. *
  59. * All objects on the media graph should have this struct embedded
  60. */
  61. struct media_gobj {
  62. struct media_device *mdev;
  63. u32 id;
  64. struct list_head list;
  65. };
  66. #define MEDIA_ENTITY_ENUM_MAX_DEPTH 16
  67. /**
  68. * struct media_entity_enum - An enumeration of media entities.
  69. *
  70. * @bmap: Bit map in which each bit represents one entity at struct
  71. * media_entity->internal_idx.
  72. * @idx_max: Number of bits in bmap
  73. */
  74. struct media_entity_enum {
  75. unsigned long *bmap;
  76. int idx_max;
  77. };
  78. /**
  79. * struct media_entity_graph - Media graph traversal state
  80. *
  81. * @stack: Graph traversal stack; the stack contains information
  82. * on the path the media entities to be walked and the
  83. * links through which they were reached.
  84. * @ent_enum: Visited entities
  85. * @top: The top of the stack
  86. */
  87. struct media_entity_graph {
  88. struct {
  89. struct media_entity *entity;
  90. struct list_head *link;
  91. } stack[MEDIA_ENTITY_ENUM_MAX_DEPTH];
  92. struct media_entity_enum ent_enum;
  93. int top;
  94. };
  95. /*
  96. * struct media_pipeline - Media pipeline related information
  97. *
  98. * @streaming_count: Streaming start count - streaming stop count
  99. * @graph: Media graph walk during pipeline start / stop
  100. */
  101. struct media_pipeline {
  102. int streaming_count;
  103. struct media_entity_graph graph;
  104. };
  105. /**
  106. * struct media_link - A link object part of a media graph.
  107. *
  108. * @graph_obj: Embedded structure containing the media object common data
  109. * @list: Linked list associated with an entity or an interface that
  110. * owns the link.
  111. * @gobj0: Part of a union. Used to get the pointer for the first
  112. * graph_object of the link.
  113. * @source: Part of a union. Used only if the first object (gobj0) is
  114. * a pad. In that case, it represents the source pad.
  115. * @intf: Part of a union. Used only if the first object (gobj0) is
  116. * an interface.
  117. * @gobj1: Part of a union. Used to get the pointer for the second
  118. * graph_object of the link.
  119. * @source: Part of a union. Used only if the second object (gobj1) is
  120. * a pad. In that case, it represents the sink pad.
  121. * @entity: Part of a union. Used only if the second object (gobj1) is
  122. * an entity.
  123. * @reverse: Pointer to the link for the reverse direction of a pad to pad
  124. * link.
  125. * @flags: Link flags, as defined in uapi/media.h (MEDIA_LNK_FL_*)
  126. * @is_backlink: Indicate if the link is a backlink.
  127. */
  128. struct media_link {
  129. struct media_gobj graph_obj;
  130. struct list_head list;
  131. union {
  132. struct media_gobj *gobj0;
  133. struct media_pad *source;
  134. struct media_interface *intf;
  135. };
  136. union {
  137. struct media_gobj *gobj1;
  138. struct media_pad *sink;
  139. struct media_entity *entity;
  140. };
  141. struct media_link *reverse;
  142. unsigned long flags;
  143. bool is_backlink;
  144. };
  145. /**
  146. * struct media_pad - A media pad graph object.
  147. *
  148. * @graph_obj: Embedded structure containing the media object common data
  149. * @entity: Entity this pad belongs to
  150. * @index: Pad index in the entity pads array, numbered from 0 to n
  151. * @flags: Pad flags, as defined in uapi/media.h (MEDIA_PAD_FL_*)
  152. */
  153. struct media_pad {
  154. struct media_gobj graph_obj; /* must be first field in struct */
  155. struct media_entity *entity;
  156. u16 index;
  157. unsigned long flags;
  158. };
  159. /**
  160. * struct media_entity_operations - Media entity operations
  161. * @link_setup: Notify the entity of link changes. The operation can
  162. * return an error, in which case link setup will be
  163. * cancelled. Optional.
  164. * @link_validate: Return whether a link is valid from the entity point of
  165. * view. The media_entity_pipeline_start() function
  166. * validates all links by calling this operation. Optional.
  167. */
  168. struct media_entity_operations {
  169. int (*link_setup)(struct media_entity *entity,
  170. const struct media_pad *local,
  171. const struct media_pad *remote, u32 flags);
  172. int (*link_validate)(struct media_link *link);
  173. };
  174. /**
  175. * struct media_entity - A media entity graph object.
  176. *
  177. * @graph_obj: Embedded structure containing the media object common data.
  178. * @name: Entity name.
  179. * @function: Entity main function, as defined in uapi/media.h
  180. * (MEDIA_ENT_F_*)
  181. * @flags: Entity flags, as defined in uapi/media.h (MEDIA_ENT_FL_*)
  182. * @num_pads: Number of sink and source pads.
  183. * @num_links: Total number of links, forward and back, enabled and disabled.
  184. * @num_backlinks: Number of backlinks
  185. * @internal_idx: An unique internal entity specific number. The numbers are
  186. * re-used if entities are unregistered or registered again.
  187. * @pads: Pads array with the size defined by @num_pads.
  188. * @links: List of data links.
  189. * @ops: Entity operations.
  190. * @stream_count: Stream count for the entity.
  191. * @use_count: Use count for the entity.
  192. * @pipe: Pipeline this entity belongs to.
  193. * @info: Union with devnode information. Kept just for backward
  194. * compatibility.
  195. * @major: Devnode major number (zero if not applicable). Kept just
  196. * for backward compatibility.
  197. * @minor: Devnode minor number (zero if not applicable). Kept just
  198. * for backward compatibility.
  199. *
  200. * NOTE: @stream_count and @use_count reference counts must never be
  201. * negative, but are signed integers on purpose: a simple WARN_ON(<0) check
  202. * can be used to detect reference count bugs that would make them negative.
  203. */
  204. struct media_entity {
  205. struct media_gobj graph_obj; /* must be first field in struct */
  206. const char *name;
  207. u32 function;
  208. unsigned long flags;
  209. u16 num_pads;
  210. u16 num_links;
  211. u16 num_backlinks;
  212. int internal_idx;
  213. struct media_pad *pads;
  214. struct list_head links;
  215. const struct media_entity_operations *ops;
  216. /* Reference counts must never be negative, but are signed integers on
  217. * purpose: a simple WARN_ON(<0) check can be used to detect reference
  218. * count bugs that would make them negative.
  219. */
  220. int stream_count;
  221. int use_count;
  222. struct media_pipeline *pipe;
  223. union {
  224. struct {
  225. u32 major;
  226. u32 minor;
  227. } dev;
  228. } info;
  229. };
  230. /**
  231. * struct media_interface - A media interface graph object.
  232. *
  233. * @graph_obj: embedded graph object
  234. * @links: List of links pointing to graph entities
  235. * @type: Type of the interface as defined in the
  236. * uapi/media/media.h header, e. g.
  237. * MEDIA_INTF_T_*
  238. * @flags: Interface flags as defined in uapi/media/media.h
  239. */
  240. struct media_interface {
  241. struct media_gobj graph_obj;
  242. struct list_head links;
  243. u32 type;
  244. u32 flags;
  245. };
  246. /**
  247. * struct media_intf_devnode - A media interface via a device node.
  248. *
  249. * @intf: embedded interface object
  250. * @major: Major number of a device node
  251. * @minor: Minor number of a device node
  252. */
  253. struct media_intf_devnode {
  254. struct media_interface intf;
  255. /* Should match the fields at media_v2_intf_devnode */
  256. u32 major;
  257. u32 minor;
  258. };
  259. /**
  260. * media_entity_id() - return the media entity graph object id
  261. *
  262. * @entity: pointer to entity
  263. */
  264. static inline u32 media_entity_id(struct media_entity *entity)
  265. {
  266. return entity->graph_obj.id;
  267. }
  268. /**
  269. * media_type() - return the media object type
  270. *
  271. * @gobj: pointer to the media graph object
  272. */
  273. static inline enum media_gobj_type media_type(struct media_gobj *gobj)
  274. {
  275. return gobj->id >> MEDIA_BITS_PER_ID;
  276. }
  277. /**
  278. * media_id() - return the media object ID
  279. *
  280. * @gobj: pointer to the media graph object
  281. */
  282. static inline u32 media_id(struct media_gobj *gobj)
  283. {
  284. return gobj->id & MEDIA_ID_MASK;
  285. }
  286. /**
  287. * media_gobj_gen_id() - encapsulates type and ID on at the object ID
  288. *
  289. * @type: object type as define at enum &media_gobj_type.
  290. * @local_id: next ID, from struct &media_device.@id.
  291. */
  292. static inline u32 media_gobj_gen_id(enum media_gobj_type type, u64 local_id)
  293. {
  294. u32 id;
  295. id = type << MEDIA_BITS_PER_ID;
  296. id |= local_id & MEDIA_ID_MASK;
  297. return id;
  298. }
  299. /**
  300. * is_media_entity_v4l2_io() - identify if the entity main function
  301. * is a V4L2 I/O
  302. *
  303. * @entity: pointer to entity
  304. *
  305. * Return: true if the entity main function is one of the V4L2 I/O types
  306. * (video, VBI or SDR radio); false otherwise.
  307. */
  308. static inline bool is_media_entity_v4l2_io(struct media_entity *entity)
  309. {
  310. if (!entity)
  311. return false;
  312. switch (entity->function) {
  313. case MEDIA_ENT_F_IO_V4L:
  314. case MEDIA_ENT_F_IO_VBI:
  315. case MEDIA_ENT_F_IO_SWRADIO:
  316. return true;
  317. default:
  318. return false;
  319. }
  320. }
  321. /**
  322. * is_media_entity_v4l2_subdev - return true if the entity main function is
  323. * associated with the V4L2 API subdev usage
  324. *
  325. * @entity: pointer to entity
  326. *
  327. * This is an ancillary function used by subdev-based V4L2 drivers.
  328. * It checks if the entity function is one of functions used by a V4L2 subdev,
  329. * e. g. camera-relatef functions, analog TV decoder, TV tuner, V4L2 DSPs.
  330. */
  331. static inline bool is_media_entity_v4l2_subdev(struct media_entity *entity)
  332. {
  333. if (!entity)
  334. return false;
  335. switch (entity->function) {
  336. case MEDIA_ENT_F_V4L2_SUBDEV_UNKNOWN:
  337. case MEDIA_ENT_F_CAM_SENSOR:
  338. case MEDIA_ENT_F_FLASH:
  339. case MEDIA_ENT_F_LENS:
  340. case MEDIA_ENT_F_ATV_DECODER:
  341. case MEDIA_ENT_F_TUNER:
  342. return true;
  343. default:
  344. return false;
  345. }
  346. }
  347. /**
  348. * __media_entity_enum_init - Initialise an entity enumeration
  349. *
  350. * @ent_enum: Entity enumeration to be initialised
  351. * @idx_max: Maximum number of entities in the enumeration
  352. *
  353. * Return: Returns zero on success or a negative error code.
  354. */
  355. __must_check int __media_entity_enum_init(struct media_entity_enum *ent_enum,
  356. int idx_max);
  357. /**
  358. * media_entity_enum_cleanup - Release resources of an entity enumeration
  359. *
  360. * @ent_enum: Entity enumeration to be released
  361. */
  362. void media_entity_enum_cleanup(struct media_entity_enum *ent_enum);
  363. /**
  364. * media_entity_enum_zero - Clear the entire enum
  365. *
  366. * @ent_enum: Entity enumeration to be cleared
  367. */
  368. static inline void media_entity_enum_zero(struct media_entity_enum *ent_enum)
  369. {
  370. bitmap_zero(ent_enum->bmap, ent_enum->idx_max);
  371. }
  372. /**
  373. * media_entity_enum_set - Mark a single entity in the enum
  374. *
  375. * @ent_enum: Entity enumeration
  376. * @entity: Entity to be marked
  377. */
  378. static inline void media_entity_enum_set(struct media_entity_enum *ent_enum,
  379. struct media_entity *entity)
  380. {
  381. if (WARN_ON(entity->internal_idx >= ent_enum->idx_max))
  382. return;
  383. __set_bit(entity->internal_idx, ent_enum->bmap);
  384. }
  385. /**
  386. * media_entity_enum_clear - Unmark a single entity in the enum
  387. *
  388. * @ent_enum: Entity enumeration
  389. * @entity: Entity to be unmarked
  390. */
  391. static inline void media_entity_enum_clear(struct media_entity_enum *ent_enum,
  392. struct media_entity *entity)
  393. {
  394. if (WARN_ON(entity->internal_idx >= ent_enum->idx_max))
  395. return;
  396. __clear_bit(entity->internal_idx, ent_enum->bmap);
  397. }
  398. /**
  399. * media_entity_enum_test - Test whether the entity is marked
  400. *
  401. * @ent_enum: Entity enumeration
  402. * @entity: Entity to be tested
  403. *
  404. * Returns true if the entity was marked.
  405. */
  406. static inline bool media_entity_enum_test(struct media_entity_enum *ent_enum,
  407. struct media_entity *entity)
  408. {
  409. if (WARN_ON(entity->internal_idx >= ent_enum->idx_max))
  410. return true;
  411. return test_bit(entity->internal_idx, ent_enum->bmap);
  412. }
  413. /**
  414. * media_entity_enum_test - Test whether the entity is marked, and mark it
  415. *
  416. * @ent_enum: Entity enumeration
  417. * @entity: Entity to be tested
  418. *
  419. * Returns true if the entity was marked, and mark it before doing so.
  420. */
  421. static inline bool
  422. media_entity_enum_test_and_set(struct media_entity_enum *ent_enum,
  423. struct media_entity *entity)
  424. {
  425. if (WARN_ON(entity->internal_idx >= ent_enum->idx_max))
  426. return true;
  427. return __test_and_set_bit(entity->internal_idx, ent_enum->bmap);
  428. }
  429. /**
  430. * media_entity_enum_empty - Test whether the entire enum is empty
  431. *
  432. * @ent_enum: Entity enumeration
  433. *
  434. * Returns true if the entity was marked.
  435. */
  436. static inline bool media_entity_enum_empty(struct media_entity_enum *ent_enum)
  437. {
  438. return bitmap_empty(ent_enum->bmap, ent_enum->idx_max);
  439. }
  440. /**
  441. * media_entity_enum_intersects - Test whether two enums intersect
  442. *
  443. * @ent_enum1: First entity enumeration
  444. * @ent_enum2: Second entity enumeration
  445. *
  446. * Returns true if entity enumerations e and f intersect, otherwise false.
  447. */
  448. static inline bool media_entity_enum_intersects(
  449. struct media_entity_enum *ent_enum1,
  450. struct media_entity_enum *ent_enum2)
  451. {
  452. WARN_ON(ent_enum1->idx_max != ent_enum2->idx_max);
  453. return bitmap_intersects(ent_enum1->bmap, ent_enum2->bmap,
  454. min(ent_enum1->idx_max, ent_enum2->idx_max));
  455. }
  456. #define gobj_to_entity(gobj) \
  457. container_of(gobj, struct media_entity, graph_obj)
  458. #define gobj_to_pad(gobj) \
  459. container_of(gobj, struct media_pad, graph_obj)
  460. #define gobj_to_link(gobj) \
  461. container_of(gobj, struct media_link, graph_obj)
  462. #define gobj_to_link(gobj) \
  463. container_of(gobj, struct media_link, graph_obj)
  464. #define gobj_to_pad(gobj) \
  465. container_of(gobj, struct media_pad, graph_obj)
  466. #define gobj_to_intf(gobj) \
  467. container_of(gobj, struct media_interface, graph_obj)
  468. #define intf_to_devnode(intf) \
  469. container_of(intf, struct media_intf_devnode, intf)
  470. /**
  471. * media_gobj_create - Initialize a graph object
  472. *
  473. * @mdev: Pointer to the media_device that contains the object
  474. * @type: Type of the object
  475. * @gobj: Pointer to the graph object
  476. *
  477. * This routine initializes the embedded struct media_gobj inside a
  478. * media graph object. It is called automatically if media_*_create()
  479. * calls are used. However, if the object (entity, link, pad, interface)
  480. * is embedded on some other object, this function should be called before
  481. * registering the object at the media controller.
  482. */
  483. void media_gobj_create(struct media_device *mdev,
  484. enum media_gobj_type type,
  485. struct media_gobj *gobj);
  486. /**
  487. * media_gobj_destroy - Stop using a graph object on a media device
  488. *
  489. * @gobj: Pointer to the graph object
  490. *
  491. * This should be called by all routines like media_device_unregister()
  492. * that remove/destroy media graph objects.
  493. */
  494. void media_gobj_destroy(struct media_gobj *gobj);
  495. /**
  496. * media_entity_pads_init() - Initialize the entity pads
  497. *
  498. * @entity: entity where the pads belong
  499. * @num_pads: total number of sink and source pads
  500. * @pads: Array of @num_pads pads.
  501. *
  502. * The pads array is managed by the entity driver and passed to
  503. * media_entity_pads_init() where its pointer will be stored in the entity
  504. * structure.
  505. *
  506. * If no pads are needed, drivers could either directly fill
  507. * &media_entity->@num_pads with 0 and &media_entity->@pads with NULL or call
  508. * this function that will do the same.
  509. *
  510. * As the number of pads is known in advance, the pads array is not allocated
  511. * dynamically but is managed by the entity driver. Most drivers will embed the
  512. * pads array in a driver-specific structure, avoiding dynamic allocation.
  513. *
  514. * Drivers must set the direction of every pad in the pads array before calling
  515. * media_entity_pads_init(). The function will initialize the other pads fields.
  516. */
  517. int media_entity_pads_init(struct media_entity *entity, u16 num_pads,
  518. struct media_pad *pads);
  519. /**
  520. * media_entity_cleanup() - free resources associated with an entity
  521. *
  522. * @entity: entity where the pads belong
  523. *
  524. * This function must be called during the cleanup phase after unregistering
  525. * the entity (currently, it does nothing).
  526. */
  527. static inline void media_entity_cleanup(struct media_entity *entity) {};
  528. /**
  529. * media_create_pad_link() - creates a link between two entities.
  530. *
  531. * @source: pointer to &media_entity of the source pad.
  532. * @source_pad: number of the source pad in the pads array
  533. * @sink: pointer to &media_entity of the sink pad.
  534. * @sink_pad: number of the sink pad in the pads array.
  535. * @flags: Link flags, as defined in include/uapi/linux/media.h.
  536. *
  537. * Valid values for flags:
  538. * A %MEDIA_LNK_FL_ENABLED flag indicates that the link is enabled and can be
  539. * used to transfer media data. When two or more links target a sink pad,
  540. * only one of them can be enabled at a time.
  541. *
  542. * A %MEDIA_LNK_FL_IMMUTABLE flag indicates that the link enabled state can't
  543. * be modified at runtime. If %MEDIA_LNK_FL_IMMUTABLE is set, then
  544. * %MEDIA_LNK_FL_ENABLED must also be set since an immutable link is
  545. * always enabled.
  546. *
  547. * NOTE:
  548. *
  549. * Before calling this function, media_entity_pads_init() and
  550. * media_device_register_entity() should be called previously for both ends.
  551. */
  552. __must_check int media_create_pad_link(struct media_entity *source,
  553. u16 source_pad, struct media_entity *sink,
  554. u16 sink_pad, u32 flags);
  555. /**
  556. * media_create_pad_links() - creates a link between two entities.
  557. *
  558. * @mdev: Pointer to the media_device that contains the object
  559. * @source_function: Function of the source entities. Used only if @source is
  560. * NULL.
  561. * @source: pointer to &media_entity of the source pad. If NULL, it will use
  562. * all entities that matches the @sink_function.
  563. * @source_pad: number of the source pad in the pads array
  564. * @sink_function: Function of the sink entities. Used only if @sink is NULL.
  565. * @sink: pointer to &media_entity of the sink pad. If NULL, it will use
  566. * all entities that matches the @sink_function.
  567. * @sink_pad: number of the sink pad in the pads array.
  568. * @flags: Link flags, as defined in include/uapi/linux/media.h.
  569. * @allow_both_undefined: if true, then both @source and @sink can be NULL.
  570. * In such case, it will create a crossbar between all entities that
  571. * matches @source_function to all entities that matches @sink_function.
  572. * If false, it will return 0 and won't create any link if both @source
  573. * and @sink are NULL.
  574. *
  575. * Valid values for flags:
  576. * A %MEDIA_LNK_FL_ENABLED flag indicates that the link is enabled and can be
  577. * used to transfer media data. If multiple links are created and this
  578. * flag is passed as an argument, only the first created link will have
  579. * this flag.
  580. *
  581. * A %MEDIA_LNK_FL_IMMUTABLE flag indicates that the link enabled state can't
  582. * be modified at runtime. If %MEDIA_LNK_FL_IMMUTABLE is set, then
  583. * %MEDIA_LNK_FL_ENABLED must also be set since an immutable link is
  584. * always enabled.
  585. *
  586. * It is common for some devices to have multiple source and/or sink entities
  587. * of the same type that should be linked. While media_create_pad_link()
  588. * creates link by link, this function is meant to allow 1:n, n:1 and even
  589. * cross-bar (n:n) links.
  590. *
  591. * NOTE: Before calling this function, media_entity_pads_init() and
  592. * media_device_register_entity() should be called previously for the entities
  593. * to be linked.
  594. */
  595. int media_create_pad_links(const struct media_device *mdev,
  596. const u32 source_function,
  597. struct media_entity *source,
  598. const u16 source_pad,
  599. const u32 sink_function,
  600. struct media_entity *sink,
  601. const u16 sink_pad,
  602. u32 flags,
  603. const bool allow_both_undefined);
  604. void __media_entity_remove_links(struct media_entity *entity);
  605. /**
  606. * media_entity_remove_links() - remove all links associated with an entity
  607. *
  608. * @entity: pointer to &media_entity
  609. *
  610. * Note: this is called automatically when an entity is unregistered via
  611. * media_device_register_entity().
  612. */
  613. void media_entity_remove_links(struct media_entity *entity);
  614. /**
  615. * __media_entity_setup_link - Configure a media link without locking
  616. * @link: The link being configured
  617. * @flags: Link configuration flags
  618. *
  619. * The bulk of link setup is handled by the two entities connected through the
  620. * link. This function notifies both entities of the link configuration change.
  621. *
  622. * If the link is immutable or if the current and new configuration are
  623. * identical, return immediately.
  624. *
  625. * The user is expected to hold link->source->parent->mutex. If not,
  626. * media_entity_setup_link() should be used instead.
  627. */
  628. int __media_entity_setup_link(struct media_link *link, u32 flags);
  629. /**
  630. * media_entity_setup_link() - changes the link flags properties in runtime
  631. *
  632. * @link: pointer to &media_link
  633. * @flags: the requested new link flags
  634. *
  635. * The only configurable property is the %MEDIA_LNK_FL_ENABLED link flag
  636. * flag to enable/disable a link. Links marked with the
  637. * %MEDIA_LNK_FL_IMMUTABLE link flag can not be enabled or disabled.
  638. *
  639. * When a link is enabled or disabled, the media framework calls the
  640. * link_setup operation for the two entities at the source and sink of the
  641. * link, in that order. If the second link_setup call fails, another
  642. * link_setup call is made on the first entity to restore the original link
  643. * flags.
  644. *
  645. * Media device drivers can be notified of link setup operations by setting the
  646. * media_device::link_notify pointer to a callback function. If provided, the
  647. * notification callback will be called before enabling and after disabling
  648. * links.
  649. *
  650. * Entity drivers must implement the link_setup operation if any of their links
  651. * is non-immutable. The operation must either configure the hardware or store
  652. * the configuration information to be applied later.
  653. *
  654. * Link configuration must not have any side effect on other links. If an
  655. * enabled link at a sink pad prevents another link at the same pad from
  656. * being enabled, the link_setup operation must return -EBUSY and can't
  657. * implicitly disable the first enabled link.
  658. *
  659. * NOTE: the valid values of the flags for the link is the same as described
  660. * on media_create_pad_link(), for pad to pad links or the same as described
  661. * on media_create_intf_link(), for interface to entity links.
  662. */
  663. int media_entity_setup_link(struct media_link *link, u32 flags);
  664. /**
  665. * media_entity_find_link - Find a link between two pads
  666. * @source: Source pad
  667. * @sink: Sink pad
  668. *
  669. * Return a pointer to the link between the two entities. If no such link
  670. * exists, return NULL.
  671. */
  672. struct media_link *media_entity_find_link(struct media_pad *source,
  673. struct media_pad *sink);
  674. /**
  675. * media_entity_remote_pad - Find the pad at the remote end of a link
  676. * @pad: Pad at the local end of the link
  677. *
  678. * Search for a remote pad connected to the given pad by iterating over all
  679. * links originating or terminating at that pad until an enabled link is found.
  680. *
  681. * Return a pointer to the pad at the remote end of the first found enabled
  682. * link, or NULL if no enabled link has been found.
  683. */
  684. struct media_pad *media_entity_remote_pad(struct media_pad *pad);
  685. /**
  686. * media_entity_get - Get a reference to the parent module
  687. *
  688. * @entity: The entity
  689. *
  690. * Get a reference to the parent media device module.
  691. *
  692. * The function will return immediately if @entity is NULL.
  693. *
  694. * Return a pointer to the entity on success or NULL on failure.
  695. */
  696. struct media_entity *media_entity_get(struct media_entity *entity);
  697. __must_check int media_entity_graph_walk_init(
  698. struct media_entity_graph *graph, struct media_device *mdev);
  699. /**
  700. * media_entity_graph_walk_cleanup - Release resources used by graph walk.
  701. *
  702. * @graph: Media graph structure that will be used to walk the graph
  703. */
  704. void media_entity_graph_walk_cleanup(struct media_entity_graph *graph);
  705. /**
  706. * media_entity_put - Release the reference to the parent module
  707. *
  708. * @entity: The entity
  709. *
  710. * Release the reference count acquired by media_entity_get().
  711. *
  712. * The function will return immediately if @entity is NULL.
  713. */
  714. void media_entity_put(struct media_entity *entity);
  715. /**
  716. * media_entity_graph_walk_start - Start walking the media graph at a given entity
  717. * @graph: Media graph structure that will be used to walk the graph
  718. * @entity: Starting entity
  719. *
  720. * Before using this function, media_entity_graph_walk_init() must be
  721. * used to allocate resources used for walking the graph. This
  722. * function initializes the graph traversal structure to walk the
  723. * entities graph starting at the given entity. The traversal
  724. * structure must not be modified by the caller during graph
  725. * traversal. After the graph walk, the resources must be released
  726. * using media_entity_graph_walk_cleanup().
  727. */
  728. void media_entity_graph_walk_start(struct media_entity_graph *graph,
  729. struct media_entity *entity);
  730. /**
  731. * media_entity_graph_walk_next - Get the next entity in the graph
  732. * @graph: Media graph structure
  733. *
  734. * Perform a depth-first traversal of the given media entities graph.
  735. *
  736. * The graph structure must have been previously initialized with a call to
  737. * media_entity_graph_walk_start().
  738. *
  739. * Return the next entity in the graph or NULL if the whole graph have been
  740. * traversed.
  741. */
  742. struct media_entity *
  743. media_entity_graph_walk_next(struct media_entity_graph *graph);
  744. /**
  745. * media_entity_pipeline_start - Mark a pipeline as streaming
  746. * @entity: Starting entity
  747. * @pipe: Media pipeline to be assigned to all entities in the pipeline.
  748. *
  749. * Mark all entities connected to a given entity through enabled links, either
  750. * directly or indirectly, as streaming. The given pipeline object is assigned to
  751. * every entity in the pipeline and stored in the media_entity pipe field.
  752. *
  753. * Calls to this function can be nested, in which case the same number of
  754. * media_entity_pipeline_stop() calls will be required to stop streaming. The
  755. * pipeline pointer must be identical for all nested calls to
  756. * media_entity_pipeline_start().
  757. */
  758. __must_check int media_entity_pipeline_start(struct media_entity *entity,
  759. struct media_pipeline *pipe);
  760. /**
  761. * __media_entity_pipeline_start - Mark a pipeline as streaming
  762. *
  763. * @entity: Starting entity
  764. * @pipe: Media pipeline to be assigned to all entities in the pipeline.
  765. *
  766. * Note: This is the non-locking version of media_entity_pipeline_start()
  767. */
  768. __must_check int __media_entity_pipeline_start(struct media_entity *entity,
  769. struct media_pipeline *pipe);
  770. /**
  771. * media_entity_pipeline_stop - Mark a pipeline as not streaming
  772. * @entity: Starting entity
  773. *
  774. * Mark all entities connected to a given entity through enabled links, either
  775. * directly or indirectly, as not streaming. The media_entity pipe field is
  776. * reset to NULL.
  777. *
  778. * If multiple calls to media_entity_pipeline_start() have been made, the same
  779. * number of calls to this function are required to mark the pipeline as not
  780. * streaming.
  781. */
  782. void media_entity_pipeline_stop(struct media_entity *entity);
  783. /**
  784. * __media_entity_pipeline_stop - Mark a pipeline as not streaming
  785. *
  786. * @entity: Starting entity
  787. *
  788. * Note: This is the non-locking version of media_entity_pipeline_stop()
  789. */
  790. void __media_entity_pipeline_stop(struct media_entity *entity);
  791. /**
  792. * media_devnode_create() - creates and initializes a device node interface
  793. *
  794. * @mdev: pointer to struct &media_device
  795. * @type: type of the interface, as given by MEDIA_INTF_T_* macros
  796. * as defined in the uapi/media/media.h header.
  797. * @flags: Interface flags as defined in uapi/media/media.h.
  798. * @major: Device node major number.
  799. * @minor: Device node minor number.
  800. *
  801. * Return: if succeeded, returns a pointer to the newly allocated
  802. * &media_intf_devnode pointer.
  803. */
  804. struct media_intf_devnode *
  805. __must_check media_devnode_create(struct media_device *mdev,
  806. u32 type, u32 flags,
  807. u32 major, u32 minor);
  808. /**
  809. * media_devnode_remove() - removes a device node interface
  810. *
  811. * @devnode: pointer to &media_intf_devnode to be freed.
  812. *
  813. * When a device node interface is removed, all links to it are automatically
  814. * removed.
  815. */
  816. void media_devnode_remove(struct media_intf_devnode *devnode);
  817. struct media_link *
  818. /**
  819. * media_create_intf_link() - creates a link between an entity and an interface
  820. *
  821. * @entity: pointer to %media_entity
  822. * @intf: pointer to %media_interface
  823. * @flags: Link flags, as defined in include/uapi/linux/media.h.
  824. *
  825. *
  826. * Valid values for flags:
  827. * The %MEDIA_LNK_FL_ENABLED flag indicates that the interface is connected to
  828. * the entity hardware. That's the default value for interfaces. An
  829. * interface may be disabled if the hardware is busy due to the usage
  830. * of some other interface that it is currently controlling the hardware.
  831. * A typical example is an hybrid TV device that handle only one type of
  832. * stream on a given time. So, when the digital TV is streaming,
  833. * the V4L2 interfaces won't be enabled, as such device is not able to
  834. * also stream analog TV or radio.
  835. *
  836. * Note:
  837. *
  838. * Before calling this function, media_devnode_create() should be called for
  839. * the interface and media_device_register_entity() should be called for the
  840. * interface that will be part of the link.
  841. */
  842. __must_check media_create_intf_link(struct media_entity *entity,
  843. struct media_interface *intf,
  844. u32 flags);
  845. /**
  846. * __media_remove_intf_link() - remove a single interface link
  847. *
  848. * @link: pointer to &media_link.
  849. *
  850. * Note: this is an unlocked version of media_remove_intf_link()
  851. */
  852. void __media_remove_intf_link(struct media_link *link);
  853. /**
  854. * media_remove_intf_link() - remove a single interface link
  855. *
  856. * @link: pointer to &media_link.
  857. *
  858. * Note: prefer to use this one, instead of __media_remove_intf_link()
  859. */
  860. void media_remove_intf_link(struct media_link *link);
  861. /**
  862. * __media_remove_intf_links() - remove all links associated with an interface
  863. *
  864. * @intf: pointer to &media_interface
  865. *
  866. * Note: this is an unlocked version of media_remove_intf_links().
  867. */
  868. void __media_remove_intf_links(struct media_interface *intf);
  869. /**
  870. * media_remove_intf_links() - remove all links associated with an interface
  871. *
  872. * @intf: pointer to &media_interface
  873. *
  874. * Notes:
  875. *
  876. * this is called automatically when an entity is unregistered via
  877. * media_device_register_entity() and by media_devnode_remove().
  878. *
  879. * Prefer to use this one, instead of __media_remove_intf_links().
  880. */
  881. void media_remove_intf_links(struct media_interface *intf);
  882. #define media_entity_call(entity, operation, args...) \
  883. (((entity)->ops && (entity)->ops->operation) ? \
  884. (entity)->ops->operation((entity) , ##args) : -ENOIOCTLCMD)
  885. #endif