Here is a short log of a pipeline starting and stopping: Available Sensor modes : 4104 x 3046 FR=30.000000 CF=0x1009208a10 SensorModeType=4 CSIPixelBitDepth=12 DynPixelBitDepth=12 NvCameraSrc: Trying To Set Default Camera Resolution. Selected sensorModeIndex = 0 WxH = 4104x3046 FrameRate = 30.000000 ... Available Sensor modes : 4104 x 3046 FR=30.000000 CF=0x1009208a10 SensorModeType=4 CSIPixelBitDepth=12 DynPixelBitDepth=12 NvCameraSrc: Trying To Set Default Camera Resolution. Selected sensorModeIndex = 0 WxH = 4104x3046 FrameRate = 30.000000 ... Framerate set to : 30 at NvxVideoEncoderSetParameterNvMMLiteOpen : Block : BlockType = 4 ===== MSENC ===== NvMMLiteBlockCreate : Block : BlockType = 4 NvH264MSEncSetCommonStreamAttribute: LevelIdc conformance violation NvH264MSEncSetCommonStreamAttribute: LevelIdc conformance violation Framerate set to : 30 at NvxVideoEncoderSetParameterNvMMLiteOpen : Block : BlockType = 4 ===== MSENC ===== NvMMLiteBlockCreate : Block : BlockType = 4 NvH264MSEncSetCommonStreamAttribute: LevelIdc conformance violation NvH264MSEncSetCommonStreamAttribute: LevelIdc conformance violation ===== MSENC blits (mode: 1) into tiled surfaces ===== ===== MSENC blits (mode: 1) into tiled surfaces ===== 2019-08-01 11:01:40,635 INFO: Stop recording... 2019-08-01 11:01:40,672 DEBUG: Stopping recorder pipeline... [21, 17] The above is the number of numbers the "handoff" callback was called for the recording. It should be the total number of frames in the stream that landed on the filesystem, right? But it's not... $ ffprobe -v fatal -count_frames -select_streams v:0 -show_entries stream=nb_read_frames -of default=nokey=1:noprint_wrappers=1 capture.mkv 18 $ ffprobe -v fatal -count_frames -select_streams v:1 -show_entries stream=nb_read_frames -of default=nokey=1:noprint_wrappers=1 capture.mkv 14 What am I missing? The pertinent pipeline bits are: nvcamearsrc ! identity name=tapX ... -aps _______________________________________________ gstreamer-devel mailing list [hidden email] https://lists.freedesktop.org/mailman/listinfo/gstreamer-devel |
On Thu, Aug 1, 2019 at 11:12 AM pisymbol . <[hidden email]> wrote:
Is there a way to tell if a GstBuffer is actually frame data? (assuming an element is sending buffers that are NOT frame data???) -aps _______________________________________________ gstreamer-devel mailing list [hidden email] https://lists.freedesktop.org/mailman/listinfo/gstreamer-devel |
On Thu, Aug 1, 2019 at 12:18 PM pisymbol . <[hidden email]> wrote:
If I move my callback deeper in my pipeline, I still see "drift" for lack of a better term. The number of callbacks seem to always be higher than the number of frames in the stream. I originally thought this was due to the fact that my stream is not fixed at 30fps but ffprobe does indeed count the frames one by one (I also used ffmpeg to count frames and the number matches the output of ffprobe). How can I be sure I'm pulling the exact number of frames that land in my MKV container (i.e. the stream)? -aps _______________________________________________ gstreamer-devel mailing list [hidden email] https://lists.freedesktop.org/mailman/listinfo/gstreamer-devel |
I'm looking at this thread and couldn't make my mind what pipeline we are referring to, it makes it's hard to help. Could meany things, could be QoS doing as this is live encoding. A shot in the dark, but you could try QoS=false on your sink maybe ? Le jeu. 1 août 2019 14 h 25, pisymbol . <[hidden email]> a écrit :
_______________________________________________ gstreamer-devel mailing list [hidden email] https://lists.freedesktop.org/mailman/listinfo/gstreamer-devel |
Nicolas: Can you please please pretty please answer me the following questions: 1) Would you expect the number of I420 frames to be equal to the H.264 ones? i.e. nvcamerasrc ! identity name=count420 ! blah ! omxh264dec ! h264parse ! identity name=count264 ! mux out... Again: Would you expect the number of "handoff" calls to be equal between the two identity plugins above? 2) In the above pipeline would you expect the number of frames counted by "count264" equal the number of frames muxed to a multifilesink? i.e. a 1-to-1 match between frames IN the file and frames caught by identity "count264"? The problem I am seeing is that on stopping the pipeline, it looks like a few frames hit my handoff callback that don't make it out to the muxer and subsequently in the file stream. Is this because stopping is asynchronous, i.e. some frames hit handoff but never made it out to the muxer because the element is shutting down? Is there an idiom where I can guarantee a 1-to-1 match between number of frames that hit "handoff" vs number of frames that make it into the stream? 3) Is there any way to coordinate a multifilesink rollover (max-file-duration) event with a handoff function? I suspect the answer is no because there seems to be an inherit race condition between when my callback sees the event and when a handoff callback gets called for the "next frame" (or a frame that is past the file rollover)? Thanks! -aps On Thu, Aug 1, 2019 at 8:12 PM Nicolas Dufresne <[hidden email]> wrote:
_______________________________________________ gstreamer-devel mailing list [hidden email] https://lists.freedesktop.org/mailman/listinfo/gstreamer-devel |
Le vendredi 02 août 2019 à 06:45 -0400, pisymbol . a écrit :
> Nicolas: > > Can you please please pretty please answer me the following questions: > > 1) Would you expect the number of I420 frames to be equal to the H.264 ones? > > i.e. nvcamerasrc ! identity name=count420 ! blah ! omxh264dec ! h264parse ! identity name=count264 ! mux out... > > Again: Would you expect the number of "handoff" calls to be equal between the two identity plugins above? For most cases it should. There exist of course corner cases, when omxh264dec qos property is on, frames could be dropped at the input to ensure real-time operation. On very ancient gst-omx, I'm pretty sure there is random miss-behaviour. > > 2) In the above pipeline would you expect the number of frames counted by "count264" equal the number of frames muxed to a multifilesink? i.e. a 1-to-1 match between frames IN the file and frames caught by identity "count264"? > > The problem I am seeing is that on stopping the pipeline, it looks like a few frames hit my handoff callback that don't make it out to the muxer and subsequently in the file stream. Is this because stopping is asynchronous, i.e. some frames hit handoff but never made it out to the muxer because the element is shutting down? Is there an idiom where I can guarantee a 1-to-1 match between number of frames that hit "handoff" vs number of frames that make it into the stream? Looks like a bad "drain/finish" implementation. It's possibly an OMX implementation issue though, please report to NVidia as this bit is proprietary, hence cannot be fixed by if broken. > > 3) Is there any way to coordinate a multifilesink rollover (max-file-duration) event with a handoff function? I suspect the answer is no because there seems to be an inherit race condition between when my callback sees the event and when a handoff callback gets called for the "next frame" (or a frame that is past the file rollover)? No, I'd say use appsink and implement your own, it's really trivial thing to do, and then you can fully customized for your needs without any race. > > Thanks! > > -aps > > On Thu, Aug 1, 2019 at 8:12 PM Nicolas Dufresne <[hidden email]> wrote: > > I'm looking at this thread and couldn't make my mind what pipeline we are referring to, it makes it's hard to help. Could meany things, could be QoS doing as this is live encoding. A shot in the dark, but you could try QoS=false on your sink maybe ? > > > > Le jeu. 1 août 2019 14 h 25, pisymbol . <[hidden email]> a écrit : > > > > > > On Thu, Aug 1, 2019 at 12:18 PM pisymbol . <[hidden email]> wrote: > > > > > > > > On Thu, Aug 1, 2019 at 11:12 AM pisymbol . <[hidden email]> wrote: > > > > > Here is a short log of a pipeline starting and stopping: > > > > > > > > > > Available Sensor modes : > > > > > 4104 x 3046 FR=30.000000 CF=0x1009208a10 SensorModeType=4 CSIPixelBitDepth=12 DynPixelBitDepth=12 > > > > > > > > > > NvCameraSrc: Trying To Set Default Camera Resolution. Selected sensorModeIndex = 0 WxH = 4104x3046 FrameRate = 30.000000 ... > > > > > > > > > > > > > > > Available Sensor modes : > > > > > 4104 x 3046 FR=30.000000 CF=0x1009208a10 SensorModeType=4 CSIPixelBitDepth=12 DynPixelBitDepth=12 > > > > > > > > > > NvCameraSrc: Trying To Set Default Camera Resolution. Selected sensorModeIndex = 0 WxH = 4104x3046 FrameRate = 30.000000 ... > > > > > > > > > > Framerate set to : 30 at NvxVideoEncoderSetParameterNvMMLiteOpen : Block : BlockType = 4 > > > > > ===== MSENC ===== > > > > > NvMMLiteBlockCreate : Block : BlockType = 4 > > > > > NvH264MSEncSetCommonStreamAttribute: LevelIdc conformance violation > > > > > NvH264MSEncSetCommonStreamAttribute: LevelIdc conformance violation > > > > > Framerate set to : 30 at NvxVideoEncoderSetParameterNvMMLiteOpen : Block : BlockType = 4 > > > > > ===== MSENC ===== > > > > > NvMMLiteBlockCreate : Block : BlockType = 4 > > > > > NvH264MSEncSetCommonStreamAttribute: LevelIdc conformance violation > > > > > NvH264MSEncSetCommonStreamAttribute: LevelIdc conformance violation > > > > > ===== MSENC blits (mode: 1) into tiled surfaces ===== > > > > > ===== MSENC blits (mode: 1) into tiled surfaces ===== > > > > > 2019-08-01 11:01:40,635 INFO: Stop recording... > > > > > 2019-08-01 11:01:40,672 DEBUG: Stopping recorder pipeline... > > > > > [21, 17] > > > > > > > > > > The above is the number of numbers the "handoff" callback was called for the recording. It should be the total number of frames in the stream that landed on the filesystem, right? > > > > > > > > > > But it's not... > > > > > > > > > > $ ffprobe -v fatal -count_frames -select_streams v:0 -show_entries stream=nb_read_frames -of default=nokey=1:noprint_wrappers=1 capture.mkv > > > > > 18 > > > > > $ ffprobe -v fatal -count_frames -select_streams v:1 -show_entries stream=nb_read_frames -of default=nokey=1:noprint_wrappers=1 capture.mkv > > > > > 14 > > > > > > > > > > What am I missing? > > > > > > > > > > The pertinent pipeline bits are: > > > > > > > > > > nvcamearsrc ! identity name=tapX ... > > > > > > > > > > Why are the number of frames LESS than the number of times "handoff" was called? > > > > > > > > > > > > > > > > > > Is there a way to tell if a GstBuffer is actually frame data? (assuming an element is sending buffers that are NOT frame data???) > > > > > > > > > > If I move my callback deeper in my pipeline, I still see "drift" for lack of a better term. The number of callbacks seem to always be higher than the number of frames in the stream. I originally thought this was due to the fact that my stream is not fixed at 30fps but ffprobe does indeed count the frames one by one (I also used ffmpeg to count frames and the number matches the output of ffprobe). > > > > > > How can I be sure I'm pulling the exact number of frames that land in my MKV container (i.e. the stream)? > > > > > > -aps > > > _______________________________________________ > > > gstreamer-devel mailing list > > > [hidden email] > > > https://lists.freedesktop.org/mailman/listinfo/gstreamer-devel > > > > _______________________________________________ > > gstreamer-devel mailing list > > [hidden email] > > https://lists.freedesktop.org/mailman/listinfo/gstreamer-devel > > _______________________________________________ > gstreamer-devel mailing list > [hidden email] > https://lists.freedesktop.org/mailman/listinfo/gstreamer-devel _______________________________________________ gstreamer-devel mailing list [hidden email] https://lists.freedesktop.org/mailman/listinfo/gstreamer-devel |
On Fri, Aug 2, 2019, 7:51 AM Nicolas Dufresne <[hidden email]> wrote: Le vendredi 02 août 2019 à 06:45 -0400, pisymbol . a écrit : What's ancient? I assume 1.8+ is not.
Could be. Does multifilesink drop any frames if you use max-file-duration? i.e. I assume splitting every 60s shouldn't inherit frame loss. However, there is a thread somewhere in the NVidia forums that claims we need to use splitmuxsink instead? Sorry for the lack of clarity.
Via new-sample?
_______________________________________________ gstreamer-devel mailing list [hidden email] https://lists.freedesktop.org/mailman/listinfo/gstreamer-devel |
On Fri, Aug 2, 2019 at 9:00 AM pisymbol . <[hidden email]> wrote:
Sorry, to be more specific. Are you saying do something like this: ... ! h264parse ! tee name=t0 ! queue ! muxer.video_0 t0. ! queue ! appsink name=appsink0 And then when I receive a max-file-duration roll over event, flush the appsink queue out via pull_samples? That won't work since I need to timestamp packets as they come in. Or do you mean do something synchronous using appsrc and appsink? But I don't understand how that would work. Unless I need separate plugins, one to write a timestamp and attach it to a buffer as meta data and then one to drain the appsink later down in the pipeline to write out my side capture file. Can you show me a quick pipeline example (just pipeline syntax) of where I could catch the roll-over event from the demuxer which would in turn cause my application to write out all the packets that were written out to a location? -aps _______________________________________________ gstreamer-devel mailing list [hidden email] https://lists.freedesktop.org/mailman/listinfo/gstreamer-devel |
On Fri, Aug 2, 2019 at 10:38 AM pisymbol . <[hidden email]> wrote:
Or do you mean re-work my own multifilesink plugin using appsink and it's callbacks? -aps _______________________________________________ gstreamer-devel mailing list [hidden email] https://lists.freedesktop.org/mailman/listinfo/gstreamer-devel |
In reply to this post by pisymbol .
Le vendredi 02 août 2019 à 09:00 -0400, pisymbol . a écrit :
> > > On Fri, Aug 2, 2019, 7:51 AM Nicolas Dufresne <[hidden email]> wrote: > > Le vendredi 02 août 2019 à 06:45 -0400, pisymbol . a écrit : > > > Nicolas: > > > > > > Can you please please pretty please answer me the following questions: > > > > > > 1) Would you expect the number of I420 frames to be equal to the H.264 ones? > > > > > > i.e. nvcamerasrc ! identity name=count420 ! blah ! omxh264dec ! h264parse ! identity name=count264 ! mux out... > > > > > > Again: Would you expect the number of "handoff" calls to be equal between the two identity plugins above? > > > > > > For most cases it should. There exist of course corner cases, when > > omxh264dec qos property is on, frames could be dropped at the input to > > ensure real-time operation. On very ancient gst-omx, I'm pretty sure > > there is random miss-behaviour. > > What's ancient? I assume 1.8+ is not. landed in 1.16. I still don't understand why people keep using OMX though. > > > > > > 2) In the above pipeline would you expect the number of frames counted by "count264" equal the number of frames muxed to a multifilesink? i.e. a 1-to-1 match between frames IN the file and frames caught by identity "count264"? > > > > > > The problem I am seeing is that on stopping the pipeline, it looks like a few frames hit my handoff callback that don't make it out to the muxer and subsequently in the file stream. Is this because stopping is asynchronous, i.e. some frames hit handoff but never made it out to the muxer because the element is shutting down? Is there an idiom where I can guarantee a 1-to-1 match between number of frames that hit "handoff" vs number of frames that make it into the stream? > > > > Looks like a bad "drain/finish" implementation. It's possibly an OMX > > implementation issue though, please report to NVidia as this bit is > > proprietary, hence cannot be fixed by if broken. > > Could be. Does multifilesink drop any frames if you use max-file-duration? i.e. I assume splitting every 60s shouldn't inherit frame loss. However, there is a thread somewhere in the NVidia forums that claims we need to use splitmuxsink instead? lost caused by this sink, it mean yield an invalid file though. > > Sorry for the lack of clarity. > > > > > > 3) Is there any way to coordinate a multifilesink rollover (max-file-duration) event with a handoff function? I suspect the answer is no because there seems to be an inherit race condition between when my callback sees the event and when a handoff callback gets called for the "next frame" (or a frame that is past the file rollover)? > > > > No, I'd say use appsink and implement your own, it's really trivial > > thing to do, and then you can fully customized for your needs without > > any race. > > Via new-sample? > > > > > > > > > > > > > > Thanks! > > > > > > -aps > > > > > > On Thu, Aug 1, 2019 at 8:12 PM Nicolas Dufresne <[hidden email]> wrote: > > > > I'm looking at this thread and couldn't make my mind what pipeline we are referring to, it makes it's hard to help. Could meany things, could be QoS doing as this is live encoding. A shot in the dark, but you could try QoS=false on your sink maybe ? > > > > > > > > Le jeu. 1 août 2019 14 h 25, pisymbol . <[hidden email]> a écrit : > > > > > > > > > > On Thu, Aug 1, 2019 at 12:18 PM pisymbol . <[hidden email]> wrote: > > > > > > > > > > > > On Thu, Aug 1, 2019 at 11:12 AM pisymbol . <[hidden email]> wrote: > > > > > > > Here is a short log of a pipeline starting and stopping: > > > > > > > > > > > > > > Available Sensor modes : > > > > > > > 4104 x 3046 FR=30.000000 CF=0x1009208a10 SensorModeType=4 CSIPixelBitDepth=12 DynPixelBitDepth=12 > > > > > > > > > > > > > > NvCameraSrc: Trying To Set Default Camera Resolution. Selected sensorModeIndex = 0 WxH = 4104x3046 FrameRate = 30.000000 ... > > > > > > > > > > > > > > > > > > > > > Available Sensor modes : > > > > > > > 4104 x 3046 FR=30.000000 CF=0x1009208a10 SensorModeType=4 CSIPixelBitDepth=12 DynPixelBitDepth=12 > > > > > > > > > > > > > > NvCameraSrc: Trying To Set Default Camera Resolution. Selected sensorModeIndex = 0 WxH = 4104x3046 FrameRate = 30.000000 ... > > > > > > > > > > > > > > Framerate set to : 30 at NvxVideoEncoderSetParameterNvMMLiteOpen : Block : BlockType = 4 > > > > > > > ===== MSENC ===== > > > > > > > NvMMLiteBlockCreate : Block : BlockType = 4 > > > > > > > NvH264MSEncSetCommonStreamAttribute: LevelIdc conformance violation > > > > > > > NvH264MSEncSetCommonStreamAttribute: LevelIdc conformance violation > > > > > > > Framerate set to : 30 at NvxVideoEncoderSetParameterNvMMLiteOpen : Block : BlockType = 4 > > > > > > > ===== MSENC ===== > > > > > > > NvMMLiteBlockCreate : Block : BlockType = 4 > > > > > > > NvH264MSEncSetCommonStreamAttribute: LevelIdc conformance violation > > > > > > > NvH264MSEncSetCommonStreamAttribute: LevelIdc conformance violation > > > > > > > ===== MSENC blits (mode: 1) into tiled surfaces ===== > > > > > > > ===== MSENC blits (mode: 1) into tiled surfaces ===== > > > > > > > 2019-08-01 11:01:40,635 INFO: Stop recording... > > > > > > > 2019-08-01 11:01:40,672 DEBUG: Stopping recorder pipeline... > > > > > > > [21, 17] > > > > > > > > > > > > > > The above is the number of numbers the "handoff" callback was called for the recording. It should be the total number of frames in the stream that landed on the filesystem, right? > > > > > > > > > > > > > > But it's not... > > > > > > > > > > > > > > $ ffprobe -v fatal -count_frames -select_streams v:0 -show_entries stream=nb_read_frames -of default=nokey=1:noprint_wrappers=1 capture.mkv > > > > > > > 18 > > > > > > > $ ffprobe -v fatal -count_frames -select_streams v:1 -show_entries stream=nb_read_frames -of default=nokey=1:noprint_wrappers=1 capture.mkv > > > > > > > 14 > > > > > > > > > > > > > > What am I missing? > > > > > > > > > > > > > > The pertinent pipeline bits are: > > > > > > > > > > > > > > nvcamearsrc ! identity name=tapX ... > > > > > > > > > > > > > > Why are the number of frames LESS than the number of times "handoff" was called? > > > > > > > > > > > > > > > > > > > > > > > > > > Is there a way to tell if a GstBuffer is actually frame data? (assuming an element is sending buffers that are NOT frame data???) > > > > > > > > > > > > > > > > If I move my callback deeper in my pipeline, I still see "drift" for lack of a better term. The number of callbacks seem to always be higher than the number of frames in the stream. I originally thought this was due to the fact that my stream is not fixed at 30fps but ffprobe does indeed count the frames one by one ( > > _______________________________________________ > gstreamer-devel mailing list > [hidden email] > https://lists.freedesktop.org/mailman/listinfo/gstreamer-devel _______________________________________________ gstreamer-devel mailing list [hidden email] https://lists.freedesktop.org/mailman/listinfo/gstreamer-devel signature.asc (201 bytes) Download Attachment |
On Fri, Aug 2, 2019 at 1:18 PM Nicolas Dufresne <[hidden email]> wrote: Le vendredi 02 août 2019 à 09:00 -0400, pisymbol . a écrit : So I can talk to you! What do you suggest then? > > > 2) In the above pipeline would you expect the number of frames counted by "count264" equal the number of frames muxed to a multifilesink? i.e. a 1-to-1 match between frames IN the file and frames caught by identity "count264"? Yes, and I do plan to use that. I was looking at it today. This pipeline I inherited. -aps _______________________________________________ gstreamer-devel mailing list [hidden email] https://lists.freedesktop.org/mailman/listinfo/gstreamer-devel |
In reply to this post by Nicolas Dufresne-5
On Fri, Aug 2, 2019 at 1:18 PM Nicolas Dufresne <[hidden email]> wrote: Le vendredi 02 août 2019 à 09:00 -0400, pisymbol . a écrit : It's the only one shipped by NVIDIA on R28.2 of Jetson! I think in the most recent one there are alternatives now. The I420 -> H264/264 frame descriptancy really irks me. I have reported it to NVIDIA. Let's see what they say. I seem to loose a frame every so often (encoder is set to constant rate). -aps _______________________________________________ gstreamer-devel mailing list [hidden email] https://lists.freedesktop.org/mailman/listinfo/gstreamer-devel |
Free forum by Nabble | Edit this page |