* [PATCH v3 0/3] Update streaming related documentation
@ 2024-09-20 7:35 Sakari Ailus
2024-09-20 7:35 ` [PATCH v3 1/3] media: Documentation: Deprecate s_stream video op, update docs Sakari Ailus
` (2 more replies)
0 siblings, 3 replies; 7+ messages in thread
From: Sakari Ailus @ 2024-09-20 7:35 UTC (permalink / raw)
To: linux-media
Cc: laurent.pinchart, tomi.valkeinen, Alain Volmat, Benjamin Mugnier,
hverkuil
Hi folks,
This set updates streaming starting and stopping related documentation.
since v2:
- Fix spelling in the commit message of the 1st patch.
- Improved language in the 2nd patch as suggested by Laurent.
since v1:
- Document the use of v4l2_subdev_{en,dis}able_streams() and setting the
streams_mask for drivers that do not support streams.
Sakari Ailus (3):
media: Documentation: Deprecate s_stream video op, update docs
media: Documentation: Update {enable,disable}_streams documentation
media: Documentation: Improve v4l2_subdev_{en,dis}able_streams
documentation
.../driver-api/media/camera-sensor.rst | 8 ++++----
Documentation/driver-api/media/tx-rx.rst | 13 ++++++++-----
include/media/v4l2-subdev.h | 17 +++++++++++++++--
3 files changed, 27 insertions(+), 11 deletions(-)
--
2.39.5
^ permalink raw reply [flat|nested] 7+ messages in thread
* [PATCH v3 1/3] media: Documentation: Deprecate s_stream video op, update docs
2024-09-20 7:35 [PATCH v3 0/3] Update streaming related documentation Sakari Ailus
@ 2024-09-20 7:35 ` Sakari Ailus
2024-09-20 7:35 ` [PATCH v3 2/3] media: Documentation: Update {enable,disable}_streams documentation Sakari Ailus
2024-09-20 7:35 ` [PATCH v3 3/3] media: Documentation: Improve v4l2_subdev_{en,dis}able_streams documentation Sakari Ailus
2 siblings, 0 replies; 7+ messages in thread
From: Sakari Ailus @ 2024-09-20 7:35 UTC (permalink / raw)
To: linux-media
Cc: laurent.pinchart, tomi.valkeinen, Alain Volmat, Benjamin Mugnier,
hverkuil
The scope of the s_stream video operation is now fully supported by
{enable,disable}_streams. Explicitly document the s_stream() op as
deprecated and update the related documentation.
Signed-off-by: Sakari Ailus <sakari.ailus@linux.intel.com>
Reviewed-by: Laurent Pinchart <laurent.pinchart+renesas@ideasonboard.com>
---
Documentation/driver-api/media/camera-sensor.rst | 8 ++++----
Documentation/driver-api/media/tx-rx.rst | 13 ++++++++-----
include/media/v4l2-subdev.h | 5 +++--
3 files changed, 15 insertions(+), 11 deletions(-)
diff --git a/Documentation/driver-api/media/camera-sensor.rst b/Documentation/driver-api/media/camera-sensor.rst
index b4920b34cebc..c290833165e6 100644
--- a/Documentation/driver-api/media/camera-sensor.rst
+++ b/Documentation/driver-api/media/camera-sensor.rst
@@ -81,10 +81,10 @@ restart when the system is resumed. This requires coordination between the
camera sensor and the rest of the camera pipeline. Bridge drivers are
responsible for this coordination, and instruct camera sensors to stop and
restart streaming by calling the appropriate subdev operations
-(``.s_stream()``, ``.enable_streams()`` or ``.disable_streams()``). Camera
-sensor drivers shall therefore **not** keep track of the streaming state to
-stop streaming in the PM suspend handler and restart it in the resume handler.
-Drivers should in general not implement the system PM handlers.
+(``.enable_streams()`` or ``.disable_streams()``). Camera sensor drivers shall
+therefore **not** keep track of the streaming state to stop streaming in the PM
+suspend handler and restart it in the resume handler. Drivers should in general
+not implement the system PM handlers.
Camera sensor drivers shall **not** implement the subdev ``.s_power()``
operation, as it is deprecated. While this operation is implemented in some
diff --git a/Documentation/driver-api/media/tx-rx.rst b/Documentation/driver-api/media/tx-rx.rst
index 29d66a47b56e..dd09484df1d3 100644
--- a/Documentation/driver-api/media/tx-rx.rst
+++ b/Documentation/driver-api/media/tx-rx.rst
@@ -49,11 +49,14 @@ Link frequency
The :ref:`V4L2_CID_LINK_FREQ <v4l2-cid-link-freq>` control is used to tell the
receiver the frequency of the bus (i.e. it is not the same as the symbol rate).
-``.s_stream()`` callback
-^^^^^^^^^^^^^^^^^^^^^^^^
+``.enable_streams()`` and ``.disable_streams()`` callbacks
+^^^^^^^^^^^^^^^^^^^^^^^^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
-The struct struct v4l2_subdev_video_ops->s_stream() callback is used by the
-receiver driver to control the transmitter driver's streaming state.
+The struct v4l2_subdev_pad_ops->enable_streams() and struct
+v4l2_subdev_pad_ops->disable_streams() callbacks are used by the receiver driver
+to control the transmitter driver's streaming state. These callbacks may not be
+called directly, but by using ``v4l2_subdev_enable_streams()`` and
+``v4l2_subdev_disable_streams()``.
CSI-2 transmitter drivers
@@ -127,7 +130,7 @@ Stopping the transmitter
^^^^^^^^^^^^^^^^^^^^^^^^
A transmitter stops sending the stream of images as a result of
-calling the ``.s_stream()`` callback. Some transmitters may stop the
+calling the ``.disable_streams()`` callback. Some transmitters may stop the
stream at a frame boundary whereas others stop immediately,
effectively leaving the current frame unfinished. The receiver driver
should not make assumptions either way, but function properly in both
diff --git a/include/media/v4l2-subdev.h b/include/media/v4l2-subdev.h
index 8daa0929865c..3cc6b4a5935f 100644
--- a/include/media/v4l2-subdev.h
+++ b/include/media/v4l2-subdev.h
@@ -450,8 +450,9 @@ enum v4l2_subdev_pre_streamon_flags {
* already started or stopped subdev. Also see call_s_stream wrapper in
* v4l2-subdev.c.
*
- * New drivers should instead implement &v4l2_subdev_pad_ops.enable_streams
- * and &v4l2_subdev_pad_ops.disable_streams operations, and use
+ * This callback is DEPRECATED. New drivers should instead implement
+ * &v4l2_subdev_pad_ops.enable_streams and
+ * &v4l2_subdev_pad_ops.disable_streams operations, and use
* v4l2_subdev_s_stream_helper for the &v4l2_subdev_video_ops.s_stream
* operation to support legacy users.
*
--
2.39.5
^ permalink raw reply related [flat|nested] 7+ messages in thread
* [PATCH v3 2/3] media: Documentation: Update {enable,disable}_streams documentation
2024-09-20 7:35 [PATCH v3 0/3] Update streaming related documentation Sakari Ailus
2024-09-20 7:35 ` [PATCH v3 1/3] media: Documentation: Deprecate s_stream video op, update docs Sakari Ailus
@ 2024-09-20 7:35 ` Sakari Ailus
2024-09-25 21:46 ` Laurent Pinchart
2024-09-20 7:35 ` [PATCH v3 3/3] media: Documentation: Improve v4l2_subdev_{en,dis}able_streams documentation Sakari Ailus
2 siblings, 1 reply; 7+ messages in thread
From: Sakari Ailus @ 2024-09-20 7:35 UTC (permalink / raw)
To: linux-media
Cc: laurent.pinchart, tomi.valkeinen, Alain Volmat, Benjamin Mugnier,
hverkuil
Document the expected {enable,disable}_streams callback behaviour for
drivers that are stream-unaware i.e. don't specify the
V4L2_SUBDEV_CAP_STREAMS sub-device capability flat. In this specific case,
the mask argument can be ignored.
Signed-off-by: Sakari Ailus <sakari.ailus@linux.intel.com>
---
include/media/v4l2-subdev.h | 8 ++++++++
1 file changed, 8 insertions(+)
diff --git a/include/media/v4l2-subdev.h b/include/media/v4l2-subdev.h
index 3cc6b4a5935f..ff63fb6046b1 100644
--- a/include/media/v4l2-subdev.h
+++ b/include/media/v4l2-subdev.h
@@ -834,11 +834,19 @@ struct v4l2_subdev_state {
* v4l2_subdev_init_finalize() at initialization time). Do not call
* directly, use v4l2_subdev_enable_streams() instead.
*
+ * Drivers that support only a single stream without setting the
+ * V4L2_SUBDEV_CAP_STREAMS sub-device capability flag can ignore the mask
+ * argument.
+ *
* @disable_streams: Disable the streams defined in streams_mask on the given
* source pad. Subdevs that implement this operation must use the active
* state management provided by the subdev core (enabled through a call to
* v4l2_subdev_init_finalize() at initialization time). Do not call
* directly, use v4l2_subdev_disable_streams() instead.
+ *
+ * Drivers that support only a single stream without setting the
+ * V4L2_SUBDEV_CAP_STREAMS sub-device capability flag can ignore the mask
+ * argument.
*/
struct v4l2_subdev_pad_ops {
int (*enum_mbus_code)(struct v4l2_subdev *sd,
--
2.39.5
^ permalink raw reply related [flat|nested] 7+ messages in thread
* [PATCH v3 3/3] media: Documentation: Improve v4l2_subdev_{en,dis}able_streams documentation
2024-09-20 7:35 [PATCH v3 0/3] Update streaming related documentation Sakari Ailus
2024-09-20 7:35 ` [PATCH v3 1/3] media: Documentation: Deprecate s_stream video op, update docs Sakari Ailus
2024-09-20 7:35 ` [PATCH v3 2/3] media: Documentation: Update {enable,disable}_streams documentation Sakari Ailus
@ 2024-09-20 7:35 ` Sakari Ailus
2024-09-25 21:47 ` Laurent Pinchart
2 siblings, 1 reply; 7+ messages in thread
From: Sakari Ailus @ 2024-09-20 7:35 UTC (permalink / raw)
To: linux-media
Cc: laurent.pinchart, tomi.valkeinen, Alain Volmat, Benjamin Mugnier,
hverkuil
Document that callers of v4l2_subdev_{en,dis}able_streams() need to set
the mask to BIT_ULL(0).
Signed-off-by: Sakari Ailus <sakari.ailus@linux.intel.com>
---
include/media/v4l2-subdev.h | 4 ++++
1 file changed, 4 insertions(+)
diff --git a/include/media/v4l2-subdev.h b/include/media/v4l2-subdev.h
index ff63fb6046b1..2f2200875b03 100644
--- a/include/media/v4l2-subdev.h
+++ b/include/media/v4l2-subdev.h
@@ -1685,6 +1685,8 @@ int v4l2_subdev_routing_validate(struct v4l2_subdev *sd,
* function implements a best-effort compatibility by calling the .s_stream()
* operation, limited to subdevs that have a single source pad.
*
+ * Drivers that are not stream-aware shall set @streams_mask to BIT_ULL(0).
+ *
* Return:
* * 0: Success
* * -EALREADY: One of the streams in streams_mask is already enabled
@@ -1715,6 +1717,8 @@ int v4l2_subdev_enable_streams(struct v4l2_subdev *sd, u32 pad,
* function implements a best-effort compatibility by calling the .s_stream()
* operation, limited to subdevs that have a single source pad.
*
+ * Drivers that are not stream-aware shall set @streams_mask to BIT_ULL(0).
+ *
* Return:
* * 0: Success
* * -EALREADY: One of the streams in streams_mask is not enabled
--
2.39.5
^ permalink raw reply related [flat|nested] 7+ messages in thread
* Re: [PATCH v3 2/3] media: Documentation: Update {enable,disable}_streams documentation
2024-09-20 7:35 ` [PATCH v3 2/3] media: Documentation: Update {enable,disable}_streams documentation Sakari Ailus
@ 2024-09-25 21:46 ` Laurent Pinchart
2024-10-07 11:03 ` Sakari Ailus
0 siblings, 1 reply; 7+ messages in thread
From: Laurent Pinchart @ 2024-09-25 21:46 UTC (permalink / raw)
To: Sakari Ailus
Cc: linux-media, tomi.valkeinen, Alain Volmat, Benjamin Mugnier,
hverkuil
Hi Sakari,
Thank you for the patch.
On Fri, Sep 20, 2024 at 10:35:02AM +0300, Sakari Ailus wrote:
> Document the expected {enable,disable}_streams callback behaviour for
> drivers that are stream-unaware i.e. don't specify the
> V4L2_SUBDEV_CAP_STREAMS sub-device capability flat. In this specific case,
s/flat/flag/
> the mask argument can be ignored.
>
> Signed-off-by: Sakari Ailus <sakari.ailus@linux.intel.com>
Reviewed-by: Laurent Pinchart <laurent.pinchart+renesas@ideasonboard.com>
> ---
> include/media/v4l2-subdev.h | 8 ++++++++
> 1 file changed, 8 insertions(+)
>
> diff --git a/include/media/v4l2-subdev.h b/include/media/v4l2-subdev.h
> index 3cc6b4a5935f..ff63fb6046b1 100644
> --- a/include/media/v4l2-subdev.h
> +++ b/include/media/v4l2-subdev.h
> @@ -834,11 +834,19 @@ struct v4l2_subdev_state {
> * v4l2_subdev_init_finalize() at initialization time). Do not call
> * directly, use v4l2_subdev_enable_streams() instead.
> *
> + * Drivers that support only a single stream without setting the
> + * V4L2_SUBDEV_CAP_STREAMS sub-device capability flag can ignore the mask
> + * argument.
> + *
> * @disable_streams: Disable the streams defined in streams_mask on the given
> * source pad. Subdevs that implement this operation must use the active
> * state management provided by the subdev core (enabled through a call to
> * v4l2_subdev_init_finalize() at initialization time). Do not call
> * directly, use v4l2_subdev_disable_streams() instead.
> + *
> + * Drivers that support only a single stream without setting the
> + * V4L2_SUBDEV_CAP_STREAMS sub-device capability flag can ignore the mask
> + * argument.
> */
> struct v4l2_subdev_pad_ops {
> int (*enum_mbus_code)(struct v4l2_subdev *sd,
--
Regards,
Laurent Pinchart
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH v3 3/3] media: Documentation: Improve v4l2_subdev_{en,dis}able_streams documentation
2024-09-20 7:35 ` [PATCH v3 3/3] media: Documentation: Improve v4l2_subdev_{en,dis}able_streams documentation Sakari Ailus
@ 2024-09-25 21:47 ` Laurent Pinchart
0 siblings, 0 replies; 7+ messages in thread
From: Laurent Pinchart @ 2024-09-25 21:47 UTC (permalink / raw)
To: Sakari Ailus
Cc: linux-media, tomi.valkeinen, Alain Volmat, Benjamin Mugnier,
hverkuil
Hi Sakari,
Thank you for the patch.
On Fri, Sep 20, 2024 at 10:35:03AM +0300, Sakari Ailus wrote:
> Document that callers of v4l2_subdev_{en,dis}able_streams() need to set
> the mask to BIT_ULL(0).
>
> Signed-off-by: Sakari Ailus <sakari.ailus@linux.intel.com>
Reviewed-by: Laurent Pinchart <laurent.pinchart+renesas@ideasonboard.com>
> ---
> include/media/v4l2-subdev.h | 4 ++++
> 1 file changed, 4 insertions(+)
>
> diff --git a/include/media/v4l2-subdev.h b/include/media/v4l2-subdev.h
> index ff63fb6046b1..2f2200875b03 100644
> --- a/include/media/v4l2-subdev.h
> +++ b/include/media/v4l2-subdev.h
> @@ -1685,6 +1685,8 @@ int v4l2_subdev_routing_validate(struct v4l2_subdev *sd,
> * function implements a best-effort compatibility by calling the .s_stream()
> * operation, limited to subdevs that have a single source pad.
> *
> + * Drivers that are not stream-aware shall set @streams_mask to BIT_ULL(0).
> + *
> * Return:
> * * 0: Success
> * * -EALREADY: One of the streams in streams_mask is already enabled
> @@ -1715,6 +1717,8 @@ int v4l2_subdev_enable_streams(struct v4l2_subdev *sd, u32 pad,
> * function implements a best-effort compatibility by calling the .s_stream()
> * operation, limited to subdevs that have a single source pad.
> *
> + * Drivers that are not stream-aware shall set @streams_mask to BIT_ULL(0).
> + *
> * Return:
> * * 0: Success
> * * -EALREADY: One of the streams in streams_mask is not enabled
--
Regards,
Laurent Pinchart
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH v3 2/3] media: Documentation: Update {enable,disable}_streams documentation
2024-09-25 21:46 ` Laurent Pinchart
@ 2024-10-07 11:03 ` Sakari Ailus
0 siblings, 0 replies; 7+ messages in thread
From: Sakari Ailus @ 2024-10-07 11:03 UTC (permalink / raw)
To: Laurent Pinchart
Cc: linux-media, tomi.valkeinen, Alain Volmat, Benjamin Mugnier,
hverkuil
Hi Laurent,
On Thu, Sep 26, 2024 at 12:46:54AM +0300, Laurent Pinchart wrote:
> Hi Sakari,
>
> Thank you for the patch.
>
> On Fri, Sep 20, 2024 at 10:35:02AM +0300, Sakari Ailus wrote:
> > Document the expected {enable,disable}_streams callback behaviour for
> > drivers that are stream-unaware i.e. don't specify the
> > V4L2_SUBDEV_CAP_STREAMS sub-device capability flat. In this specific case,
>
> s/flat/flag/
>
> > the mask argument can be ignored.
> >
> > Signed-off-by: Sakari Ailus <sakari.ailus@linux.intel.com>
>
> Reviewed-by: Laurent Pinchart <laurent.pinchart+renesas@ideasonboard.com>
Thanks!
I'll fix the commit message while applying the patch.
--
Kind regards,
Sakari Ailus
^ permalink raw reply [flat|nested] 7+ messages in thread
end of thread, other threads:[~2024-10-07 11:03 UTC | newest]
Thread overview: 7+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2024-09-20 7:35 [PATCH v3 0/3] Update streaming related documentation Sakari Ailus
2024-09-20 7:35 ` [PATCH v3 1/3] media: Documentation: Deprecate s_stream video op, update docs Sakari Ailus
2024-09-20 7:35 ` [PATCH v3 2/3] media: Documentation: Update {enable,disable}_streams documentation Sakari Ailus
2024-09-25 21:46 ` Laurent Pinchart
2024-10-07 11:03 ` Sakari Ailus
2024-09-20 7:35 ` [PATCH v3 3/3] media: Documentation: Improve v4l2_subdev_{en,dis}able_streams documentation Sakari Ailus
2024-09-25 21:47 ` Laurent Pinchart
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox