obsproject / obs-studio

OBS Studio - Free and open source software for live streaming and screen recording
https://obsproject.com
GNU General Public License v2.0
57.22k stars 7.72k forks source link

OBS does not de-initialize encoders on RTMP stream start fail #10651

Open tt2468 opened 1 month ago

tt2468 commented 1 month ago

Operating System Info

Windows 10

Other OS

No response

OBS Studio Version

30.1.2

OBS Studio Version (Other)

No response

OBS Studio Log URL

https://obsproject.com/logs/6iizipF9Li5buy3e

OBS Studio Crash Log URL

No response

Expected Behavior

If the stream output fails to start, allocated encoders should be de-allocated if they are not being used.

Current Behavior

The encoders sit initialized but not started, as obs_output_begin_data_capture() was never called. In the case of NVENC, this results in an NVENC session lingering around taking up a slot until OBS is shut down or a stream is successfully started.

nvidia-smi:

    Encoder Stats
        Active Sessions                   : 1
        Average FPS                       : 0
        Average Latency                   : 0

Steps to Reproduce

  1. Load OBS
  2. Configure an RTMP or WHIP stream with an invalid stream key/bearer token
  3. Attempt to start stream, it should fail with the "unable to access channel" error message
  4. Observe that the encoder was initialized but never freed.

Anything else we should know?

No response

tytan652 commented 1 month ago

OBS does not de-initialize encoders on RTMP stream start fail

2. Configure an RTMP or WHIP stream with an invalid stream key/bearer token

Is it RTMP-only or it concerns RTMP and WHIP or any protocol (or even any encoded output) ?

tt2468 commented 1 month ago

I only validated this for RTMP and WHIP, though others are likely affected also. It seems as though the issue mainly stems from: